From e7bc62dc764bc50d852d18a73c3cd1cf7675f524 Mon Sep 17 00:00:00 2001
From: NadzriAdzman
Date: Sat, 11 Feb 2023 12:08:47 +0800
Subject: [PATCH 1/2] Second Test - UI
---
.env | 33 +
bootstrap/cache/services.php | 184 +
resources/views/create.blade.php | 31 +
resources/views/edit.blade.php | 32 +
resources/views/event.blade.php | 35 +
resources/views/events.blade.php | 37 +
storage/logs/laravel.log | 0
vendor/autoload.php | 7 +
vendor/bin/php-parse | 14 +
vendor/bin/php-parse.bat | 4 +
vendor/bin/phpunit | 14 +
vendor/bin/phpunit.bat | 4 +
vendor/bin/psysh | 14 +
vendor/bin/psysh.bat | 4 +
vendor/bin/upgrade-carbon | 14 +
vendor/bin/upgrade-carbon.bat | 4 +
vendor/composer/ClassLoader.php | 445 +
vendor/composer/InstalledVersions.php | 1041 +
vendor/composer/LICENSE | 21 +
vendor/composer/autoload_classmap.php | 3152 ++
vendor/composer/autoload_files.php | 22 +
vendor/composer/autoload_namespaces.php | 13 +
vendor/composer/autoload_psr4.php | 49 +
vendor/composer/autoload_real.php | 75 +
vendor/composer/autoload_static.php | 3465 +++
vendor/composer/installed.json | 4399 +++
vendor/composer/installed.php | 846 +
vendor/composer/platform_check.php | 26 +
vendor/dnoegel/php-xdg-base-dir/LICENSE | 19 +
vendor/dnoegel/php-xdg-base-dir/README.md | 41 +
vendor/dnoegel/php-xdg-base-dir/composer.json | 17 +
vendor/dnoegel/php-xdg-base-dir/src/Xdg.php | 132 +
vendor/doctrine/inflector/.gitignore | 4 +
vendor/doctrine/inflector/.travis.yml | 21 +
vendor/doctrine/inflector/LICENSE | 19 +
vendor/doctrine/inflector/README.md | 6 +
vendor/doctrine/inflector/composer.json | 29 +
.../Doctrine/Common/Inflector/Inflector.php | 482 +
vendor/doctrine/inflector/phpunit.xml.dist | 31 +
.../Tests/Common/Inflector/InflectorTest.php | 309 +
.../tests/Doctrine/Tests/DoctrineTestCase.php | 10 +
.../tests/Doctrine/Tests/TestInit.php | 27 +
vendor/doctrine/instantiator/.gitignore | 5 +
vendor/doctrine/instantiator/.scrutinizer.yml | 46 +
.../doctrine/instantiator/.travis.install.sh | 14 +
vendor/doctrine/instantiator/.travis.yml | 22 +
vendor/doctrine/instantiator/CONTRIBUTING.md | 35 +
vendor/doctrine/instantiator/LICENSE | 19 +
vendor/doctrine/instantiator/README.md | 40 +
vendor/doctrine/instantiator/composer.json | 45 +
vendor/doctrine/instantiator/phpmd.xml.dist | 27 +
vendor/doctrine/instantiator/phpunit.xml.dist | 22 +
.../Exception/ExceptionInterface.php | 29 +
.../Exception/InvalidArgumentException.php | 62 +
.../Exception/UnexpectedValueException.php | 79 +
.../Doctrine/Instantiator/Instantiator.php | 273 +
.../Instantiator/InstantiatorInterface.php | 37 +
.../InstantiatorPerformanceEvent.php | 96 +
.../InvalidArgumentExceptionTest.php | 83 +
.../UnexpectedValueExceptionTest.php | 69 +
.../InstantiatorTest/InstantiatorTest.php | 219 +
.../AbstractClassAsset.php | 29 +
.../ArrayObjectAsset.php | 41 +
.../InstantiatorTestAsset/ExceptionAsset.php | 41 +
.../FinalExceptionAsset.php | 41 +
.../InstantiatorTestAsset/PharAsset.php | 41 +
.../PharExceptionAsset.php | 44 +
.../SerializableArrayObjectAsset.php | 62 +
.../SimpleSerializableAsset.php | 61 +
.../SimpleTraitAsset.php | 29 +
.../UnCloneableAsset.php | 50 +
.../UnserializeExceptionArrayObjectAsset.php | 39 +
.../WakeUpNoticesAsset.php | 38 +
.../InstantiatorTestAsset/XMLReaderAsset.php | 41 +
vendor/erusev/parsedown/LICENSE.txt | 20 +
vendor/erusev/parsedown/Parsedown.php | 1712 ++
vendor/erusev/parsedown/README.md | 86 +
vendor/erusev/parsedown/composer.json | 33 +
.../.github/ISSUE_TEMPLATE/bug_report.md | 39 +
vendor/fzaninotto/faker/.travis/xdebug.sh | 22 +
vendor/fzaninotto/faker/CHANGELOG.md | 744 +
vendor/fzaninotto/faker/LICENSE | 22 +
vendor/fzaninotto/faker/composer.json | 42 +
vendor/fzaninotto/faker/readme.md | 1798 ++
.../faker/src/Faker/Calculator/Ean.php | 55 +
.../faker/src/Faker/Calculator/Iban.php | 73 +
.../faker/src/Faker/Calculator/Inn.php | 34 +
.../faker/src/Faker/Calculator/Luhn.php | 75 +
.../faker/src/Faker/Calculator/TCNo.php | 52 +
.../faker/src/Faker/DefaultGenerator.php | 38 +
.../fzaninotto/faker/src/Faker/Documentor.php | 66 +
vendor/fzaninotto/faker/src/Faker/Factory.php | 61 +
.../fzaninotto/faker/src/Faker/Generator.php | 297 +
.../faker/src/Faker/Guesser/Name.php | 156 +
.../Faker/ORM/CakePHP/ColumnTypeGuesser.php | 71 +
.../src/Faker/ORM/CakePHP/EntityPopulator.php | 166 +
.../faker/src/Faker/ORM/CakePHP/Populator.php | 109 +
.../Faker/ORM/Doctrine/ColumnTypeGuesser.php | 81 +
.../Faker/ORM/Doctrine/EntityPopulator.php | 251 +
.../src/Faker/ORM/Doctrine/Populator.php | 110 +
.../Faker/ORM/Mandango/ColumnTypeGuesser.php | 49 +
.../Faker/ORM/Mandango/EntityPopulator.php | 122 +
.../src/Faker/ORM/Mandango/Populator.php | 65 +
.../Faker/ORM/Propel/ColumnTypeGuesser.php | 107 +
.../src/Faker/ORM/Propel/EntityPopulator.php | 191 +
.../faker/src/Faker/ORM/Propel/Populator.php | 89 +
.../Faker/ORM/Propel2/ColumnTypeGuesser.php | 107 +
.../src/Faker/ORM/Propel2/EntityPopulator.php | 192 +
.../faker/src/Faker/ORM/Propel2/Populator.php | 92 +
.../src/Faker/ORM/Spot/ColumnTypeGuesser.php | 77 +
.../src/Faker/ORM/Spot/EntityPopulator.php | 219 +
.../faker/src/Faker/ORM/Spot/Populator.php | 88 +
.../faker/src/Faker/Provider/Address.php | 139 +
.../faker/src/Faker/Provider/Barcode.php | 114 +
.../faker/src/Faker/Provider/Base.php | 612 +
.../faker/src/Faker/Provider/Biased.php | 64 +
.../faker/src/Faker/Provider/Color.php | 143 +
.../faker/src/Faker/Provider/Company.php | 50 +
.../faker/src/Faker/Provider/DateTime.php | 340 +
.../faker/src/Faker/Provider/File.php | 606 +
.../faker/src/Faker/Provider/HtmlLorem.php | 276 +
.../faker/src/Faker/Provider/Image.php | 105 +
.../faker/src/Faker/Provider/Internet.php | 362 +
.../faker/src/Faker/Provider/Lorem.php | 203 +
.../src/Faker/Provider/Miscellaneous.php | 323 +
.../faker/src/Faker/Provider/Payment.php | 286 +
.../faker/src/Faker/Provider/Person.php | 126 +
.../faker/src/Faker/Provider/PhoneNumber.php | 43 +
.../faker/src/Faker/Provider/Text.php | 141 +
.../faker/src/Faker/Provider/UserAgent.php | 165 +
.../faker/src/Faker/Provider/Uuid.php | 58 +
.../src/Faker/Provider/ar_JO/Address.php | 152 +
.../src/Faker/Provider/ar_JO/Company.php | 63 +
.../src/Faker/Provider/ar_JO/Internet.php | 55 +
.../faker/src/Faker/Provider/ar_JO/Person.php | 108 +
.../faker/src/Faker/Provider/ar_JO/Text.php | 271 +
.../src/Faker/Provider/ar_SA/Address.php | 146 +
.../faker/src/Faker/Provider/ar_SA/Color.php | 81 +
.../src/Faker/Provider/ar_SA/Company.php | 74 +
.../src/Faker/Provider/ar_SA/Internet.php | 55 +
.../src/Faker/Provider/ar_SA/Payment.php | 19 +
.../faker/src/Faker/Provider/ar_SA/Person.php | 118 +
.../faker/src/Faker/Provider/ar_SA/Text.php | 271 +
.../src/Faker/Provider/at_AT/Payment.php | 44 +
.../src/Faker/Provider/bg_BG/Internet.php | 9 +
.../src/Faker/Provider/bg_BG/Payment.php | 43 +
.../faker/src/Faker/Provider/bg_BG/Person.php | 114 +
.../src/Faker/Provider/bg_BG/PhoneNumber.php | 20 +
.../src/Faker/Provider/bn_BD/Address.php | 310 +
.../src/Faker/Provider/bn_BD/Company.php | 28 +
.../faker/src/Faker/Provider/bn_BD/Person.php | 36 +
.../src/Faker/Provider/bn_BD/PhoneNumber.php | 14 +
.../faker/src/Faker/Provider/bn_BD/Utils.php | 14 +
.../src/Faker/Provider/cs_CZ/Address.php | 149 +
.../src/Faker/Provider/cs_CZ/Company.php | 120 +
.../src/Faker/Provider/cs_CZ/DateTime.php | 61 +
.../src/Faker/Provider/cs_CZ/Internet.php | 9 +
.../src/Faker/Provider/cs_CZ/Payment.php | 19 +
.../faker/src/Faker/Provider/cs_CZ/Person.php | 533 +
.../src/Faker/Provider/cs_CZ/PhoneNumber.php | 14 +
.../faker/src/Faker/Provider/cs_CZ/Text.php | 7185 +++++
.../src/Faker/Provider/da_DK/Address.php | 287 +
.../src/Faker/Provider/da_DK/Company.php | 70 +
.../src/Faker/Provider/da_DK/Internet.php | 30 +
.../src/Faker/Provider/da_DK/Payment.php | 19 +
.../faker/src/Faker/Provider/da_DK/Person.php | 195 +
.../src/Faker/Provider/da_DK/PhoneNumber.php | 21 +
.../src/Faker/Provider/de_AT/Address.php | 127 +
.../src/Faker/Provider/de_AT/Company.php | 13 +
.../src/Faker/Provider/de_AT/Internet.php | 9 +
.../src/Faker/Provider/de_AT/Payment.php | 19 +
.../faker/src/Faker/Provider/de_AT/Person.php | 120 +
.../src/Faker/Provider/de_AT/PhoneNumber.php | 19 +
.../faker/src/Faker/Provider/de_AT/Text.php | 7 +
.../src/Faker/Provider/de_CH/Address.php | 185 +
.../src/Faker/Provider/de_CH/Company.php | 15 +
.../src/Faker/Provider/de_CH/Internet.php | 17 +
.../src/Faker/Provider/de_CH/Payment.php | 19 +
.../faker/src/Faker/Provider/de_CH/Person.php | 117 +
.../src/Faker/Provider/de_CH/PhoneNumber.php | 43 +
.../faker/src/Faker/Provider/de_CH/Text.php | 2036 ++
.../src/Faker/Provider/de_DE/Address.php | 125 +
.../src/Faker/Provider/de_DE/Company.php | 24 +
.../src/Faker/Provider/de_DE/Internet.php | 26 +
.../src/Faker/Provider/de_DE/Payment.php | 56 +
.../faker/src/Faker/Provider/de_DE/Person.php | 129 +
.../src/Faker/Provider/de_DE/PhoneNumber.php | 20 +
.../faker/src/Faker/Provider/de_DE/Text.php | 2036 ++
.../src/Faker/Provider/el_CY/Address.php | 55 +
.../src/Faker/Provider/el_CY/Company.php | 18 +
.../src/Faker/Provider/el_CY/Internet.php | 9 +
.../src/Faker/Provider/el_CY/Payment.php | 49 +
.../faker/src/Faker/Provider/el_CY/Person.php | 97 +
.../src/Faker/Provider/el_CY/PhoneNumber.php | 32 +
.../src/Faker/Provider/el_GR/Address.php | 61 +
.../src/Faker/Provider/el_GR/Company.php | 84 +
.../src/Faker/Provider/el_GR/Payment.php | 19 +
.../faker/src/Faker/Provider/el_GR/Person.php | 178 +
.../src/Faker/Provider/el_GR/PhoneNumber.php | 85 +
.../faker/src/Faker/Provider/el_GR/Text.php | 2581 ++
.../src/Faker/Provider/en_AU/Address.php | 110 +
.../src/Faker/Provider/en_AU/Internet.php | 9 +
.../src/Faker/Provider/en_AU/PhoneNumber.php | 56 +
.../src/Faker/Provider/en_CA/Address.php | 64 +
.../src/Faker/Provider/en_CA/PhoneNumber.php | 18 +
.../src/Faker/Provider/en_GB/Address.php | 143 +
.../src/Faker/Provider/en_GB/Internet.php | 9 +
.../src/Faker/Provider/en_GB/Payment.php | 19 +
.../faker/src/Faker/Provider/en_GB/Person.php | 93 +
.../src/Faker/Provider/en_GB/PhoneNumber.php | 43 +
.../src/Faker/Provider/en_HK/Address.php | 240 +
.../src/Faker/Provider/en_HK/Internet.php | 14 +
.../src/Faker/Provider/en_HK/PhoneNumber.php | 38 +
.../src/Faker/Provider/en_IN/Address.php | 182 +
.../src/Faker/Provider/en_IN/Internet.php | 9 +
.../faker/src/Faker/Provider/en_IN/Person.php | 127 +
.../src/Faker/Provider/en_IN/PhoneNumber.php | 35 +
.../src/Faker/Provider/en_NG/Address.php | 98 +
.../src/Faker/Provider/en_NG/Internet.php | 8 +
.../faker/src/Faker/Provider/en_NG/Person.php | 89 +
.../src/Faker/Provider/en_NG/PhoneNumber.php | 133 +
.../src/Faker/Provider/en_NZ/Address.php | 78 +
.../src/Faker/Provider/en_NZ/Internet.php | 16 +
.../src/Faker/Provider/en_NZ/PhoneNumber.php | 93 +
.../src/Faker/Provider/en_PH/Address.php | 417 +
.../src/Faker/Provider/en_PH/PhoneNumber.php | 58 +
.../src/Faker/Provider/en_SG/Address.php | 126 +
.../src/Faker/Provider/en_SG/PhoneNumber.php | 107 +
.../src/Faker/Provider/en_UG/Address.php | 101 +
.../src/Faker/Provider/en_UG/Internet.php | 9 +
.../faker/src/Faker/Provider/en_UG/Person.php | 132 +
.../src/Faker/Provider/en_UG/PhoneNumber.php | 17 +
.../src/Faker/Provider/en_US/Address.php | 97 +
.../src/Faker/Provider/en_US/Company.php | 116 +
.../src/Faker/Provider/en_US/Payment.php | 37 +
.../faker/src/Faker/Provider/en_US/Person.php | 131 +
.../src/Faker/Provider/en_US/PhoneNumber.php | 108 +
.../faker/src/Faker/Provider/en_US/Text.php | 3720 +++
.../src/Faker/Provider/en_ZA/Address.php | 70 +
.../src/Faker/Provider/en_ZA/Company.php | 29 +
.../src/Faker/Provider/en_ZA/Internet.php | 18 +
.../faker/src/Faker/Provider/en_ZA/Person.php | 178 +
.../src/Faker/Provider/en_ZA/PhoneNumber.php | 100 +
.../src/Faker/Provider/es_AR/Address.php | 68 +
.../src/Faker/Provider/es_AR/Company.php | 66 +
.../faker/src/Faker/Provider/es_AR/Person.php | 90 +
.../src/Faker/Provider/es_AR/PhoneNumber.php | 42 +
.../src/Faker/Provider/es_ES/Address.php | 101 +
.../faker/src/Faker/Provider/es_ES/Color.php | 24 +
.../src/Faker/Provider/es_ES/Company.php | 80 +
.../src/Faker/Provider/es_ES/Internet.php | 9 +
.../src/Faker/Provider/es_ES/Payment.php | 39 +
.../faker/src/Faker/Provider/es_ES/Person.php | 149 +
.../src/Faker/Provider/es_ES/PhoneNumber.php | 47 +
.../faker/src/Faker/Provider/es_ES/Text.php | 687 +
.../src/Faker/Provider/es_PE/Address.php | 65 +
.../src/Faker/Provider/es_PE/Company.php | 66 +
.../faker/src/Faker/Provider/es_PE/Person.php | 106 +
.../src/Faker/Provider/es_PE/PhoneNumber.php | 17 +
.../src/Faker/Provider/es_VE/Address.php | 72 +
.../src/Faker/Provider/es_VE/Company.php | 40 +
.../src/Faker/Provider/es_VE/Internet.php | 9 +
.../faker/src/Faker/Provider/es_VE/Person.php | 167 +
.../src/Faker/Provider/es_VE/PhoneNumber.php | 29 +
.../faker/src/Faker/Provider/et_EE/Person.php | 89 +
.../src/Faker/Provider/fa_IR/Address.php | 100 +
.../src/Faker/Provider/fa_IR/Company.php | 57 +
.../src/Faker/Provider/fa_IR/Internet.php | 102 +
.../faker/src/Faker/Provider/fa_IR/Person.php | 201 +
.../src/Faker/Provider/fa_IR/PhoneNumber.php | 75 +
.../faker/src/Faker/Provider/fa_IR/Text.php | 546 +
.../src/Faker/Provider/fi_FI/Address.php | 85 +
.../src/Faker/Provider/fi_FI/Company.php | 64 +
.../src/Faker/Provider/fi_FI/Internet.php | 9 +
.../src/Faker/Provider/fi_FI/Payment.php | 19 +
.../faker/src/Faker/Provider/fi_FI/Person.php | 145 +
.../src/Faker/Provider/fi_FI/PhoneNumber.php | 99 +
.../src/Faker/Provider/fr_BE/Address.php | 72 +
.../src/Faker/Provider/fr_BE/Company.php | 13 +
.../src/Faker/Provider/fr_BE/Internet.php | 9 +
.../src/Faker/Provider/fr_BE/Payment.php | 39 +
.../faker/src/Faker/Provider/fr_BE/Person.php | 49 +
.../src/Faker/Provider/fr_BE/PhoneNumber.php | 20 +
.../src/Faker/Provider/fr_CA/Address.php | 125 +
.../src/Faker/Provider/fr_CA/Company.php | 7 +
.../faker/src/Faker/Provider/fr_CA/Person.php | 82 +
.../faker/src/Faker/Provider/fr_CA/Text.php | 2448 ++
.../src/Faker/Provider/fr_CH/Address.php | 140 +
.../src/Faker/Provider/fr_CH/Company.php | 15 +
.../src/Faker/Provider/fr_CH/Internet.php | 9 +
.../src/Faker/Provider/fr_CH/Payment.php | 19 +
.../faker/src/Faker/Provider/fr_CH/Person.php | 115 +
.../src/Faker/Provider/fr_CH/PhoneNumber.php | 43 +
.../faker/src/Faker/Provider/fr_CH/Text.php | 8 +
.../src/Faker/Provider/fr_FR/Address.php | 147 +
.../src/Faker/Provider/fr_FR/Company.php | 476 +
.../src/Faker/Provider/fr_FR/Internet.php | 9 +
.../src/Faker/Provider/fr_FR/Payment.php | 44 +
.../faker/src/Faker/Provider/fr_FR/Person.php | 129 +
.../src/Faker/Provider/fr_FR/PhoneNumber.php | 141 +
.../faker/src/Faker/Provider/fr_FR/Text.php | 15531 ++++++++++
.../src/Faker/Provider/he_IL/Address.php | 122 +
.../src/Faker/Provider/he_IL/Company.php | 14 +
.../src/Faker/Provider/he_IL/Payment.php | 19 +
.../faker/src/Faker/Provider/he_IL/Person.php | 132 +
.../src/Faker/Provider/he_IL/PhoneNumber.php | 14 +
.../src/Faker/Provider/hr_HR/Address.php | 69 +
.../src/Faker/Provider/hr_HR/Company.php | 25 +
.../src/Faker/Provider/hr_HR/Payment.php | 19 +
.../faker/src/Faker/Provider/hr_HR/Person.php | 27 +
.../src/Faker/Provider/hr_HR/PhoneNumber.php | 14 +
.../src/Faker/Provider/hu_HU/Address.php | 149 +
.../src/Faker/Provider/hu_HU/Company.php | 13 +
.../src/Faker/Provider/hu_HU/Payment.php | 19 +
.../faker/src/Faker/Provider/hu_HU/Person.php | 91 +
.../src/Faker/Provider/hu_HU/PhoneNumber.php | 14 +
.../faker/src/Faker/Provider/hu_HU/Text.php | 3407 +++
.../src/Faker/Provider/hy_AM/Address.php | 132 +
.../faker/src/Faker/Provider/hy_AM/Color.php | 12 +
.../src/Faker/Provider/hy_AM/Company.php | 54 +
.../src/Faker/Provider/hy_AM/Internet.php | 9 +
.../faker/src/Faker/Provider/hy_AM/Person.php | 112 +
.../src/Faker/Provider/hy_AM/PhoneNumber.php | 40 +
.../src/Faker/Provider/id_ID/Address.php | 316 +
.../faker/src/Faker/Provider/id_ID/Color.php | 41 +
.../src/Faker/Provider/id_ID/Company.php | 43 +
.../src/Faker/Provider/id_ID/Internet.php | 25 +
.../faker/src/Faker/Provider/id_ID/Person.php | 343 +
.../src/Faker/Provider/id_ID/PhoneNumber.php | 55 +
.../src/Faker/Provider/is_IS/Address.php | 178 +
.../src/Faker/Provider/is_IS/Company.php | 53 +
.../src/Faker/Provider/is_IS/Internet.php | 23 +
.../src/Faker/Provider/is_IS/Payment.php | 19 +
.../faker/src/Faker/Provider/is_IS/Person.php | 140 +
.../src/Faker/Provider/is_IS/PhoneNumber.php | 20 +
.../src/Faker/Provider/it_CH/Address.php | 139 +
.../src/Faker/Provider/it_CH/Company.php | 15 +
.../src/Faker/Provider/it_CH/Internet.php | 9 +
.../src/Faker/Provider/it_CH/Payment.php | 19 +
.../faker/src/Faker/Provider/it_CH/Person.php | 101 +
.../src/Faker/Provider/it_CH/PhoneNumber.php | 43 +
.../faker/src/Faker/Provider/it_CH/Text.php | 8 +
.../src/Faker/Provider/it_IT/Address.php | 97 +
.../src/Faker/Provider/it_IT/Company.php | 78 +
.../src/Faker/Provider/it_IT/Internet.php | 9 +
.../src/Faker/Provider/it_IT/Payment.php | 19 +
.../faker/src/Faker/Provider/it_IT/Person.php | 98 +
.../src/Faker/Provider/it_IT/PhoneNumber.php | 21 +
.../faker/src/Faker/Provider/it_IT/Text.php | 1994 ++
.../src/Faker/Provider/ja_JP/Address.php | 137 +
.../src/Faker/Provider/ja_JP/Company.php | 17 +
.../src/Faker/Provider/ja_JP/Internet.php | 93 +
.../faker/src/Faker/Provider/ja_JP/Person.php | 141 +
.../src/Faker/Provider/ja_JP/PhoneNumber.php | 19 +
.../faker/src/Faker/Provider/ja_JP/Text.php | 635 +
.../src/Faker/Provider/ka_GE/Address.php | 140 +
.../faker/src/Faker/Provider/ka_GE/Color.php | 16 +
.../src/Faker/Provider/ka_GE/Company.php | 54 +
.../src/Faker/Provider/ka_GE/DateTime.php | 42 +
.../src/Faker/Provider/ka_GE/Internet.php | 15 +
.../src/Faker/Provider/ka_GE/Payment.php | 53 +
.../faker/src/Faker/Provider/ka_GE/Person.php | 63 +
.../src/Faker/Provider/ka_GE/PhoneNumber.php | 14 +
.../faker/src/Faker/Provider/ka_GE/Text.php | 1000 +
.../src/Faker/Provider/kk_KZ/Address.php | 105 +
.../faker/src/Faker/Provider/kk_KZ/Color.php | 12 +
.../src/Faker/Provider/kk_KZ/Company.php | 72 +
.../src/Faker/Provider/kk_KZ/Internet.php | 9 +
.../src/Faker/Provider/kk_KZ/Payment.php | 33 +
.../faker/src/Faker/Provider/kk_KZ/Person.php | 257 +
.../src/Faker/Provider/kk_KZ/PhoneNumber.php | 16 +
.../faker/src/Faker/Provider/kk_KZ/Text.php | 490 +
.../src/Faker/Provider/ko_KR/Address.php | 96 +
.../src/Faker/Provider/ko_KR/Company.php | 31 +
.../src/Faker/Provider/ko_KR/Internet.php | 86 +
.../faker/src/Faker/Provider/ko_KR/Person.php | 55 +
.../src/Faker/Provider/ko_KR/PhoneNumber.php | 42 +
.../faker/src/Faker/Provider/ko_KR/Text.php | 1723 ++
.../src/Faker/Provider/lt_LT/Address.php | 131 +
.../src/Faker/Provider/lt_LT/Company.php | 15 +
.../src/Faker/Provider/lt_LT/Internet.php | 18 +
.../src/Faker/Provider/lt_LT/Payment.php | 19 +
.../faker/src/Faker/Provider/lt_LT/Person.php | 371 +
.../src/Faker/Provider/lt_LT/PhoneNumber.php | 17 +
.../src/Faker/Provider/lv_LV/Address.php | 117 +
.../faker/src/Faker/Provider/lv_LV/Color.php | 19 +
.../src/Faker/Provider/lv_LV/Internet.php | 9 +
.../src/Faker/Provider/lv_LV/Payment.php | 19 +
.../faker/src/Faker/Provider/lv_LV/Person.php | 128 +
.../src/Faker/Provider/lv_LV/PhoneNumber.php | 15 +
.../src/Faker/Provider/me_ME/Address.php | 119 +
.../src/Faker/Provider/me_ME/Company.php | 49 +
.../src/Faker/Provider/me_ME/Payment.php | 19 +
.../faker/src/Faker/Provider/me_ME/Person.php | 102 +
.../src/Faker/Provider/me_ME/PhoneNumber.php | 15 +
.../faker/src/Faker/Provider/mn_MN/Person.php | 100 +
.../src/Faker/Provider/mn_MN/PhoneNumber.php | 13 +
.../src/Faker/Provider/ms_MY/Address.php | 708 +
.../src/Faker/Provider/ms_MY/Company.php | 105 +
.../Faker/Provider/ms_MY/Miscellaneous.php | 169 +
.../src/Faker/Provider/ms_MY/Payment.php | 244 +
.../faker/src/Faker/Provider/ms_MY/Person.php | 813 +
.../src/Faker/Provider/ms_MY/PhoneNumber.php | 217 +
.../src/Faker/Provider/nb_NO/Address.php | 195 +
.../src/Faker/Provider/nb_NO/Company.php | 55 +
.../src/Faker/Provider/nb_NO/Payment.php | 19 +
.../faker/src/Faker/Provider/nb_NO/Person.php | 326 +
.../src/Faker/Provider/nb_NO/PhoneNumber.php | 41 +
.../src/Faker/Provider/ne_NP/Address.php | 129 +
.../src/Faker/Provider/ne_NP/Internet.php | 32 +
.../faker/src/Faker/Provider/ne_NP/Person.php | 121 +
.../src/Faker/Provider/ne_NP/PhoneNumber.php | 19 +
.../src/Faker/Provider/nl_BE/Address.php | 124 +
.../src/Faker/Provider/nl_BE/Company.php | 13 +
.../src/Faker/Provider/nl_BE/Internet.php | 9 +
.../src/Faker/Provider/nl_BE/Payment.php | 39 +
.../faker/src/Faker/Provider/nl_BE/Person.php | 106 +
.../src/Faker/Provider/nl_BE/PhoneNumber.php | 20 +
.../faker/src/Faker/Provider/nl_BE/Text.php | 25347 ++++++++++++++++
.../src/Faker/Provider/nl_NL/Address.php | 153 +
.../faker/src/Faker/Provider/nl_NL/Color.php | 36 +
.../src/Faker/Provider/nl_NL/Company.php | 115 +
.../src/Faker/Provider/nl_NL/Internet.php | 9 +
.../src/Faker/Provider/nl_NL/Payment.php | 19 +
.../faker/src/Faker/Provider/nl_NL/Person.php | 349 +
.../src/Faker/Provider/nl_NL/PhoneNumber.php | 39 +
.../faker/src/Faker/Provider/nl_NL/Text.php | 3932 +++
.../src/Faker/Provider/pl_PL/Address.php | 210 +
.../src/Faker/Provider/pl_PL/Company.php | 80 +
.../src/Faker/Provider/pl_PL/Internet.php | 9 +
.../src/Faker/Provider/pl_PL/Payment.php | 115 +
.../faker/src/Faker/Provider/pl_PL/Person.php | 227 +
.../src/Faker/Provider/pl_PL/PhoneNumber.php | 18 +
.../faker/src/Faker/Provider/pl_PL/Text.php | 2866 ++
.../src/Faker/Provider/pt_BR/Address.php | 154 +
.../src/Faker/Provider/pt_BR/Company.php | 33 +
.../src/Faker/Provider/pt_BR/Internet.php | 9 +
.../src/Faker/Provider/pt_BR/Payment.php | 146 +
.../faker/src/Faker/Provider/pt_BR/Person.php | 133 +
.../src/Faker/Provider/pt_BR/PhoneNumber.php | 137 +
.../src/Faker/Provider/pt_BR/check_digit.php | 35 +
.../src/Faker/Provider/pt_PT/Address.php | 124 +
.../src/Faker/Provider/pt_PT/Company.php | 16 +
.../src/Faker/Provider/pt_PT/Internet.php | 9 +
.../src/Faker/Provider/pt_PT/Payment.php | 19 +
.../faker/src/Faker/Provider/pt_PT/Person.php | 146 +
.../src/Faker/Provider/pt_PT/PhoneNumber.php | 50 +
.../src/Faker/Provider/ro_MD/Address.php | 148 +
.../src/Faker/Provider/ro_MD/Payment.php | 19 +
.../faker/src/Faker/Provider/ro_MD/Person.php | 90 +
.../src/Faker/Provider/ro_MD/PhoneNumber.php | 33 +
.../faker/src/Faker/Provider/ro_MD/Text.php | 2463 ++
.../src/Faker/Provider/ro_RO/Address.php | 176 +
.../src/Faker/Provider/ro_RO/Payment.php | 19 +
.../faker/src/Faker/Provider/ro_RO/Person.php | 238 +
.../src/Faker/Provider/ro_RO/PhoneNumber.php | 66 +
.../faker/src/Faker/Provider/ro_RO/Text.php | 154 +
.../src/Faker/Provider/ru_RU/Address.php | 139 +
.../faker/src/Faker/Provider/ru_RU/Color.php | 23 +
.../src/Faker/Provider/ru_RU/Company.php | 119 +
.../src/Faker/Provider/ru_RU/Internet.php | 9 +
.../src/Faker/Provider/ru_RU/Payment.php | 811 +
.../faker/src/Faker/Provider/ru_RU/Person.php | 179 +
.../src/Faker/Provider/ru_RU/PhoneNumber.php | 14 +
.../faker/src/Faker/Provider/ru_RU/Text.php | 4550 +++
.../src/Faker/Provider/sk_SK/Address.php | 344 +
.../src/Faker/Provider/sk_SK/Company.php | 64 +
.../src/Faker/Provider/sk_SK/Internet.php | 9 +
.../src/Faker/Provider/sk_SK/Payment.php | 19 +
.../faker/src/Faker/Provider/sk_SK/Person.php | 168 +
.../src/Faker/Provider/sk_SK/PhoneNumber.php | 15 +
.../src/Faker/Provider/sl_SI/Address.php | 107 +
.../src/Faker/Provider/sl_SI/Company.php | 14 +
.../src/Faker/Provider/sl_SI/Internet.php | 11 +
.../src/Faker/Provider/sl_SI/Payment.php | 19 +
.../faker/src/Faker/Provider/sl_SI/Person.php | 149 +
.../src/Faker/Provider/sl_SI/PhoneNumber.php | 18 +
.../src/Faker/Provider/sr_Cyrl_RS/Address.php | 58 +
.../src/Faker/Provider/sr_Cyrl_RS/Payment.php | 19 +
.../src/Faker/Provider/sr_Cyrl_RS/Person.php | 242 +
.../src/Faker/Provider/sr_Latn_RS/Address.php | 58 +
.../src/Faker/Provider/sr_Latn_RS/Payment.php | 19 +
.../src/Faker/Provider/sr_Latn_RS/Person.php | 213 +
.../src/Faker/Provider/sr_RS/Address.php | 58 +
.../src/Faker/Provider/sr_RS/Payment.php | 19 +
.../faker/src/Faker/Provider/sr_RS/Person.php | 145 +
.../src/Faker/Provider/sv_SE/Address.php | 150 +
.../src/Faker/Provider/sv_SE/Company.php | 26 +
.../src/Faker/Provider/sv_SE/Payment.php | 19 +
.../faker/src/Faker/Provider/sv_SE/Person.php | 143 +
.../src/Faker/Provider/sv_SE/PhoneNumber.php | 37 +
.../src/Faker/Provider/th_TH/Address.php | 139 +
.../faker/src/Faker/Provider/th_TH/Color.php | 16 +
.../src/Faker/Provider/th_TH/Company.php | 32 +
.../src/Faker/Provider/th_TH/Internet.php | 8 +
.../src/Faker/Provider/th_TH/Payment.php | 43 +
.../faker/src/Faker/Provider/th_TH/Person.php | 85 +
.../src/Faker/Provider/th_TH/PhoneNumber.php | 37 +
.../src/Faker/Provider/tr_TR/Address.php | 93 +
.../faker/src/Faker/Provider/tr_TR/Color.php | 58 +
.../src/Faker/Provider/tr_TR/Company.php | 99 +
.../src/Faker/Provider/tr_TR/DateTime.php | 46 +
.../src/Faker/Provider/tr_TR/Internet.php | 9 +
.../src/Faker/Provider/tr_TR/Payment.php | 19 +
.../faker/src/Faker/Provider/tr_TR/Person.php | 112 +
.../src/Faker/Provider/tr_TR/PhoneNumber.php | 33 +
.../src/Faker/Provider/uk_UA/Address.php | 362 +
.../faker/src/Faker/Provider/uk_UA/Color.php | 23 +
.../src/Faker/Provider/uk_UA/Company.php | 74 +
.../src/Faker/Provider/uk_UA/Internet.php | 9 +
.../src/Faker/Provider/uk_UA/Payment.php | 41 +
.../faker/src/Faker/Provider/uk_UA/Person.php | 99 +
.../src/Faker/Provider/uk_UA/PhoneNumber.php | 51 +
.../faker/src/Faker/Provider/uk_UA/Text.php | 4511 +++
.../src/Faker/Provider/vi_VN/Address.php | 170 +
.../faker/src/Faker/Provider/vi_VN/Color.php | 36 +
.../src/Faker/Provider/vi_VN/Internet.php | 8 +
.../faker/src/Faker/Provider/vi_VN/Person.php | 184 +
.../src/Faker/Provider/vi_VN/PhoneNumber.php | 61 +
.../src/Faker/Provider/zh_CN/Address.php | 149 +
.../faker/src/Faker/Provider/zh_CN/Color.php | 66 +
.../src/Faker/Provider/zh_CN/Company.php | 234 +
.../src/Faker/Provider/zh_CN/DateTime.php | 46 +
.../src/Faker/Provider/zh_CN/Internet.php | 24 +
.../src/Faker/Provider/zh_CN/Payment.php | 41 +
.../faker/src/Faker/Provider/zh_CN/Person.php | 83 +
.../src/Faker/Provider/zh_CN/PhoneNumber.php | 23 +
.../src/Faker/Provider/zh_TW/Address.php | 419 +
.../faker/src/Faker/Provider/zh_TW/Color.php | 66 +
.../src/Faker/Provider/zh_TW/Company.php | 265 +
.../src/Faker/Provider/zh_TW/DateTime.php | 46 +
.../src/Faker/Provider/zh_TW/Internet.php | 16 +
.../src/Faker/Provider/zh_TW/Payment.php | 11 +
.../faker/src/Faker/Provider/zh_TW/Person.php | 201 +
.../src/Faker/Provider/zh_TW/PhoneNumber.php | 19 +
.../faker/src/Faker/Provider/zh_TW/Text.php | 898 +
.../faker/src/Faker/UniqueGenerator.php | 58 +
.../faker/src/Faker/ValidGenerator.php | 65 +
vendor/fzaninotto/faker/src/autoload.php | 26 +
vendor/hamcrest/hamcrest-php/.coveralls.yml | 1 +
vendor/hamcrest/hamcrest-php/.gitignore | 2 +
vendor/hamcrest/hamcrest-php/.gush.yml | 7 +
vendor/hamcrest/hamcrest-php/.travis.yml | 18 +
vendor/hamcrest/hamcrest-php/CHANGES.txt | 163 +
vendor/hamcrest/hamcrest-php/LICENSE.txt | 27 +
vendor/hamcrest/hamcrest-php/README.md | 51 +
vendor/hamcrest/hamcrest-php/TODO.txt | 22 +
vendor/hamcrest/hamcrest-php/composer.json | 32 +
.../hamcrest-php/generator/FactoryCall.php | 41 +
.../hamcrest-php/generator/FactoryClass.php | 72 +
.../hamcrest-php/generator/FactoryFile.php | 122 +
.../generator/FactoryGenerator.php | 115 +
.../hamcrest-php/generator/FactoryMethod.php | 231 +
.../generator/FactoryParameter.php | 69 +
.../generator/GlobalFunctionFile.php | 42 +
.../generator/StaticMethodFile.php | 38 +
.../generator/parts/file_header.txt | 7 +
.../generator/parts/functions_footer.txt | 0
.../generator/parts/functions_header.txt | 24 +
.../generator/parts/functions_imports.txt | 0
.../generator/parts/matchers_footer.txt | 1 +
.../generator/parts/matchers_header.txt | 7 +
.../generator/parts/matchers_imports.txt | 2 +
.../hamcrest/hamcrest-php/generator/run.php | 37 +
.../hamcrest-php/hamcrest/Hamcrest.php | 805 +
.../hamcrest/Hamcrest/Arrays/IsArray.php | 118 +
.../Hamcrest/Arrays/IsArrayContaining.php | 63 +
.../Arrays/IsArrayContainingInAnyOrder.php | 59 +
.../Arrays/IsArrayContainingInOrder.php | 57 +
.../Hamcrest/Arrays/IsArrayContainingKey.php | 75 +
.../Arrays/IsArrayContainingKeyValuePair.php | 80 +
.../Hamcrest/Arrays/IsArrayWithSize.php | 73 +
.../hamcrest/Hamcrest/Arrays/MatchingOnce.php | 69 +
.../Hamcrest/Arrays/SeriesMatchingOnce.php | 75 +
.../hamcrest/Hamcrest/AssertionError.php | 10 +
.../hamcrest/Hamcrest/BaseDescription.php | 132 +
.../hamcrest/Hamcrest/BaseMatcher.php | 25 +
.../Collection/IsEmptyTraversable.php | 71 +
.../Collection/IsTraversableWithSize.php | 47 +
.../hamcrest/Hamcrest/Core/AllOf.php | 59 +
.../hamcrest/Hamcrest/Core/AnyOf.php | 58 +
.../Hamcrest/Core/CombinableMatcher.php | 78 +
.../hamcrest/Hamcrest/Core/DescribedAs.php | 68 +
.../hamcrest/Hamcrest/Core/Every.php | 56 +
.../hamcrest/Hamcrest/Core/HasToString.php | 56 +
.../hamcrest/Hamcrest/Core/Is.php | 57 +
.../hamcrest/Hamcrest/Core/IsAnything.php | 45 +
.../Hamcrest/Core/IsCollectionContaining.php | 93 +
.../hamcrest/Hamcrest/Core/IsEqual.php | 44 +
.../hamcrest/Hamcrest/Core/IsIdentical.php | 38 +
.../hamcrest/Hamcrest/Core/IsInstanceOf.php | 67 +
.../hamcrest/Hamcrest/Core/IsNot.php | 44 +
.../hamcrest/Hamcrest/Core/IsNull.php | 56 +
.../hamcrest/Hamcrest/Core/IsSame.php | 51 +
.../hamcrest/Hamcrest/Core/IsTypeOf.php | 71 +
.../hamcrest/Hamcrest/Core/Set.php | 95 +
.../Hamcrest/Core/ShortcutCombination.php | 43 +
.../hamcrest/Hamcrest/Description.php | 70 +
.../hamcrest/Hamcrest/DiagnosingMatcher.php | 25 +
.../hamcrest/Hamcrest/FeatureMatcher.php | 67 +
.../Hamcrest/Internal/SelfDescribingValue.php | 27 +
.../hamcrest/Hamcrest/Matcher.php | 50 +
.../hamcrest/Hamcrest/MatcherAssert.php | 118 +
.../hamcrest/Hamcrest/Matchers.php | 713 +
.../hamcrest/Hamcrest/NullDescription.php | 43 +
.../hamcrest/Hamcrest/Number/IsCloseTo.php | 67 +
.../Hamcrest/Number/OrderingComparison.php | 132 +
.../hamcrest/Hamcrest/SelfDescribing.php | 23 +
.../hamcrest/Hamcrest/StringDescription.php | 57 +
.../hamcrest/Hamcrest/Text/IsEmptyString.php | 85 +
.../Hamcrest/Text/IsEqualIgnoringCase.php | 52 +
.../Text/IsEqualIgnoringWhiteSpace.php | 66 +
.../hamcrest/Hamcrest/Text/MatchesPattern.php | 40 +
.../hamcrest/Hamcrest/Text/StringContains.php | 45 +
.../Text/StringContainsIgnoringCase.php | 40 +
.../Hamcrest/Text/StringContainsInOrder.php | 66 +
.../hamcrest/Hamcrest/Text/StringEndsWith.php | 40 +
.../Hamcrest/Text/StringStartsWith.php | 40 +
.../Hamcrest/Text/SubstringMatcher.php | 45 +
.../hamcrest/Hamcrest/Type/IsArray.php | 32 +
.../hamcrest/Hamcrest/Type/IsBoolean.php | 32 +
.../hamcrest/Hamcrest/Type/IsCallable.php | 37 +
.../hamcrest/Hamcrest/Type/IsDouble.php | 34 +
.../hamcrest/Hamcrest/Type/IsInteger.php | 32 +
.../hamcrest/Hamcrest/Type/IsNumeric.php | 34 +
.../hamcrest/Hamcrest/Type/IsObject.php | 32 +
.../hamcrest/Hamcrest/Type/IsResource.php | 32 +
.../hamcrest/Hamcrest/Type/IsScalar.php | 34 +
.../hamcrest/Hamcrest/Type/IsString.php | 32 +
.../Hamcrest/TypeSafeDiagnosingMatcher.php | 29 +
.../hamcrest/Hamcrest/TypeSafeMatcher.php | 107 +
.../hamcrest-php/hamcrest/Hamcrest/Util.php | 72 +
.../hamcrest/Hamcrest/Xml/HasXPath.php | 195 +
.../tests/Hamcrest/AbstractMatcherTest.php | 66 +
.../Array/IsArrayContainingInAnyOrderTest.php | 54 +
.../Array/IsArrayContainingInOrderTest.php | 44 +
.../Array/IsArrayContainingKeyTest.php | 62 +
.../IsArrayContainingKeyValuePairTest.php | 36 +
.../Hamcrest/Array/IsArrayContainingTest.php | 50 +
.../tests/Hamcrest/Array/IsArrayTest.php | 89 +
.../Hamcrest/Array/IsArrayWithSizeTest.php | 37 +
.../tests/Hamcrest/BaseMatcherTest.php | 23 +
.../Collection/IsEmptyTraversableTest.php | 77 +
.../Collection/IsTraversableWithSizeTest.php | 57 +
.../tests/Hamcrest/Core/AllOfTest.php | 56 +
.../tests/Hamcrest/Core/AnyOfTest.php | 79 +
.../Hamcrest/Core/CombinableMatcherTest.php | 59 +
.../tests/Hamcrest/Core/DescribedAsTest.php | 36 +
.../tests/Hamcrest/Core/EveryTest.php | 30 +
.../tests/Hamcrest/Core/HasToStringTest.php | 108 +
.../tests/Hamcrest/Core/IsAnythingTest.php | 29 +
.../Core/IsCollectionContainingTest.php | 91 +
.../tests/Hamcrest/Core/IsEqualTest.php | 102 +
.../tests/Hamcrest/Core/IsIdenticalTest.php | 30 +
.../tests/Hamcrest/Core/IsInstanceOfTest.php | 51 +
.../tests/Hamcrest/Core/IsNotTest.php | 31 +
.../tests/Hamcrest/Core/IsNullTest.php | 20 +
.../tests/Hamcrest/Core/IsSameTest.php | 30 +
.../tests/Hamcrest/Core/IsTest.php | 33 +
.../tests/Hamcrest/Core/IsTypeOfTest.php | 45 +
.../tests/Hamcrest/Core/SampleBaseClass.php | 18 +
.../tests/Hamcrest/Core/SampleSubClass.php | 6 +
.../tests/Hamcrest/Core/SetTest.php | 116 +
.../tests/Hamcrest/FeatureMatcherTest.php | 73 +
.../tests/Hamcrest/MatcherAssertTest.php | 190 +
.../tests/Hamcrest/Number/IsCloseToTest.php | 27 +
.../Number/OrderingComparisonTest.php | 41 +
.../tests/Hamcrest/StringDescriptionTest.php | 160 +
.../tests/Hamcrest/Text/IsEmptyStringTest.php | 86 +
.../Hamcrest/Text/IsEqualIgnoringCaseTest.php | 40 +
.../Text/IsEqualIgnoringWhiteSpaceTest.php | 51 +
.../Hamcrest/Text/MatchesPatternTest.php | 30 +
.../Text/StringContainsIgnoringCaseTest.php | 80 +
.../Text/StringContainsInOrderTest.php | 42 +
.../Hamcrest/Text/StringContainsTest.php | 86 +
.../Hamcrest/Text/StringEndsWithTest.php | 62 +
.../Hamcrest/Text/StringStartsWithTest.php | 62 +
.../tests/Hamcrest/Type/IsArrayTest.php | 35 +
.../tests/Hamcrest/Type/IsBooleanTest.php | 35 +
.../tests/Hamcrest/Type/IsCallableTest.php | 103 +
.../tests/Hamcrest/Type/IsDoubleTest.php | 35 +
.../tests/Hamcrest/Type/IsIntegerTest.php | 36 +
.../tests/Hamcrest/Type/IsNumericTest.php | 49 +
.../tests/Hamcrest/Type/IsObjectTest.php | 34 +
.../tests/Hamcrest/Type/IsResourceTest.php | 34 +
.../tests/Hamcrest/Type/IsScalarTest.php | 39 +
.../tests/Hamcrest/Type/IsStringTest.php | 35 +
.../hamcrest-php/tests/Hamcrest/UtilTest.php | 80 +
.../tests/Hamcrest/Xml/HasXPathTest.php | 198 +
.../hamcrest/hamcrest-php/tests/bootstrap.php | 18 +
.../hamcrest-php/tests/phpunit.xml.dist | 22 +
.../php-console-color/.gitignore | 3 +
.../php-console-color/.travis.yml | 24 +
.../jakub-onderka/php-console-color/LICENSE | 27 +
.../jakub-onderka/php-console-color/README.md | 10 +
.../jakub-onderka/php-console-color/build.xml | 93 +
.../php-console-color/composer.json | 23 +
.../php-console-color/example.php | 38 +
.../php-console-color/phpunit.xml | 16 +
.../php-console-color/src/ConsoleColor.php | 287 +
.../src/InvalidStyleException.php | 10 +
.../tests/ConsoleColorTest.php | 184 +
.../php-console-highlighter/.gitignore | 4 +
.../php-console-highlighter/.travis.yml | 22 +
.../php-console-highlighter/LICENSE | 21 +
.../php-console-highlighter/README.md | 42 +
.../php-console-highlighter/build.xml | 93 +
.../php-console-highlighter/composer.json | 28 +
.../examples/snippet.php | 10 +
.../examples/whole_file.php | 10 +
.../examples/whole_file_line_numbers.php | 10 +
.../php-console-highlighter/phpunit.xml | 15 +
.../src/Highlighter.php | 263 +
.../tests/HigligterTest.php | 274 +
vendor/kylekatarnls/update-helper/LICENSE | 22 +
.../kylekatarnls/update-helper/composer.json | 50 +
.../src/UpdateHelper/ComposerPlugin.php | 47 +
.../NotUpdateInterfaceInstanceException.php | 9 +
.../src/UpdateHelper/UpdateHelper.php | 391 +
.../UpdateHelper/UpdateHelperInterface.php | 8 +
vendor/laravel/framework/LICENSE.md | 21 +
vendor/laravel/framework/README.md | 45 +
vendor/laravel/framework/composer.json | 126 +
.../Auth/Access/AuthorizationException.php | 10 +
.../src/Illuminate/Auth/Access/Gate.php | 506 +
.../Auth/Access/HandlesAuthorization.php | 30 +
.../src/Illuminate/Auth/Access/Response.php | 43 +
.../src/Illuminate/Auth/AuthManager.php | 296 +
.../Illuminate/Auth/AuthServiceProvider.php | 90 +
.../src/Illuminate/Auth/Authenticatable.php | 78 +
.../Auth/AuthenticationException.php | 39 +
.../Auth/Console/AuthMakeCommand.php | 119 +
.../Auth/Console/ClearResetsCommand.php | 34 +
.../make/controllers/HomeController.stub | 28 +
.../Auth/Console/stubs/make/routes.stub | 4 +
.../Console/stubs/make/views/auth/login.stub | 69 +
.../make/views/auth/passwords/email.stub | 47 +
.../make/views/auth/passwords/reset.stub | 70 +
.../stubs/make/views/auth/register.stub | 77 +
.../Auth/Console/stubs/make/views/home.stub | 23 +
.../Console/stubs/make/views/layouts/app.stub | 80 +
.../Illuminate/Auth/CreatesUserProviders.php | 67 +
.../Illuminate/Auth/DatabaseUserProvider.php | 146 +
.../Illuminate/Auth/EloquentUserProvider.php | 188 +
.../src/Illuminate/Auth/Events/Attempting.php | 32 +
.../Illuminate/Auth/Events/Authenticated.php | 28 +
.../src/Illuminate/Auth/Events/Failed.php | 32 +
.../src/Illuminate/Auth/Events/Lockout.php | 26 +
.../src/Illuminate/Auth/Events/Login.php | 37 +
.../src/Illuminate/Auth/Events/Logout.php | 28 +
.../src/Illuminate/Auth/Events/Registered.php | 28 +
.../src/Illuminate/Auth/GenericUser.php | 134 +
.../src/Illuminate/Auth/GuardHelpers.php | 86 +
.../Auth/Middleware/Authenticate.php | 68 +
.../Middleware/AuthenticateWithBasicAuth.php | 40 +
.../Illuminate/Auth/Middleware/Authorize.php | 100 +
.../Auth/Notifications/ResetPassword.php | 52 +
.../Auth/Passwords/CanResetPassword.php | 29 +
.../Passwords/DatabaseTokenRepository.php | 204 +
.../Auth/Passwords/PasswordBroker.php | 242 +
.../Auth/Passwords/PasswordBrokerManager.php | 147 +
.../PasswordResetServiceProvider.php | 51 +
.../Passwords/TokenRepositoryInterface.php | 40 +
.../src/Illuminate/Auth/Recaller.php | 78 +
.../src/Illuminate/Auth/RequestGuard.php | 84 +
.../src/Illuminate/Auth/SessionGuard.php | 775 +
.../src/Illuminate/Auth/TokenGuard.php | 133 +
.../src/Illuminate/Auth/composer.json | 43 +
.../Broadcasting/BroadcastController.php | 21 +
.../Broadcasting/BroadcastEvent.php | 101 +
.../Broadcasting/BroadcastException.php | 10 +
.../Broadcasting/BroadcastManager.php | 315 +
.../Broadcasting/BroadcastServiceProvider.php | 51 +
.../Broadcasting/Broadcasters/Broadcaster.php | 201 +
.../Broadcasters/LogBroadcaster.php | 54 +
.../Broadcasters/NullBroadcaster.php | 30 +
.../Broadcasters/PusherBroadcaster.php | 120 +
.../Broadcasters/RedisBroadcaster.php | 102 +
.../src/Illuminate/Broadcasting/Channel.php | 34 +
.../Broadcasting/InteractsWithSockets.php | 39 +
.../Broadcasting/PendingBroadcast.php | 59 +
.../Broadcasting/PresenceChannel.php | 17 +
.../Broadcasting/PrivateChannel.php | 17 +
.../src/Illuminate/Broadcasting/composer.json | 40 +
.../src/Illuminate/Bus/BusServiceProvider.php | 54 +
.../src/Illuminate/Bus/Dispatcher.php | 212 +
.../src/Illuminate/Bus/Queueable.php | 66 +
.../src/Illuminate/Bus/composer.json | 36 +
.../src/Illuminate/Cache/ApcStore.php | 132 +
.../src/Illuminate/Cache/ApcWrapper.php | 92 +
.../src/Illuminate/Cache/ArrayStore.php | 117 +
.../src/Illuminate/Cache/CacheManager.php | 307 +
.../Illuminate/Cache/CacheServiceProvider.php | 47 +
.../Cache/Console/CacheTableCommand.php | 81 +
.../Illuminate/Cache/Console/ClearCommand.php | 107 +
.../Cache/Console/ForgetCommand.php | 57 +
.../Illuminate/Cache/Console/stubs/cache.stub | 32 +
.../src/Illuminate/Cache/DatabaseStore.php | 280 +
.../Illuminate/Cache/Events/CacheEvent.php | 46 +
.../src/Illuminate/Cache/Events/CacheHit.php | 28 +
.../Illuminate/Cache/Events/CacheMissed.php | 8 +
.../Illuminate/Cache/Events/KeyForgotten.php | 8 +
.../Illuminate/Cache/Events/KeyWritten.php | 37 +
.../src/Illuminate/Cache/FileStore.php | 263 +
.../Illuminate/Cache/MemcachedConnector.php | 87 +
.../src/Illuminate/Cache/MemcachedStore.php | 235 +
.../src/Illuminate/Cache/NullStore.php | 108 +
.../src/Illuminate/Cache/RateLimiter.php | 146 +
.../src/Illuminate/Cache/RedisStore.php | 277 +
.../src/Illuminate/Cache/RedisTaggedCache.php | 166 +
.../src/Illuminate/Cache/Repository.php | 520 +
.../Cache/RetrievesMultipleKeys.php | 39 +
.../framework/src/Illuminate/Cache/TagSet.php | 110 +
.../src/Illuminate/Cache/TaggableStore.php | 17 +
.../src/Illuminate/Cache/TaggedCache.php | 95 +
.../src/Illuminate/Cache/composer.json | 41 +
.../src/Illuminate/Config/Repository.php | 154 +
.../src/Illuminate/Config/composer.json | 35 +
.../src/Illuminate/Console/Application.php | 247 +
.../src/Illuminate/Console/Command.php | 571 +
.../Illuminate/Console/ConfirmableTrait.php | 54 +
.../Console/DetectsApplicationNamespace.php | 18 +
.../Console/Events/ArtisanStarting.php | 24 +
.../Illuminate/Console/GeneratorCommand.php | 233 +
.../src/Illuminate/Console/OutputStyle.php | 71 +
.../src/Illuminate/Console/Parser.php | 142 +
.../Console/Scheduling/CacheMutex.php | 61 +
.../Console/Scheduling/CallbackEvent.php | 136 +
.../Console/Scheduling/CommandBuilder.php | 71 +
.../Illuminate/Console/Scheduling/Event.php | 673 +
.../Console/Scheduling/ManagesFrequencies.php | 401 +
.../Illuminate/Console/Scheduling/Mutex.php | 30 +
.../Console/Scheduling/Schedule.php | 145 +
.../Scheduling/ScheduleFinishCommand.php | 61 +
.../Console/Scheduling/ScheduleRunCommand.php | 68 +
.../src/Illuminate/Console/composer.json | 42 +
.../src/Illuminate/Container/BoundMethod.php | 172 +
.../src/Illuminate/Container/Container.php | 1222 +
.../Container/ContextualBindingBuilder.php | 68 +
.../src/Illuminate/Container/composer.json | 34 +
.../Contracts/Auth/Access/Authorizable.php | 15 +
.../Illuminate/Contracts/Auth/Access/Gate.php | 104 +
.../Contracts/Auth/Authenticatable.php | 49 +
.../Contracts/Auth/CanResetPassword.php | 21 +
.../src/Illuminate/Contracts/Auth/Factory.php | 22 +
.../src/Illuminate/Contracts/Auth/Guard.php | 50 +
.../Contracts/Auth/PasswordBroker.php | 76 +
.../Contracts/Auth/PasswordBrokerFactory.php | 14 +
.../Contracts/Auth/StatefulGuard.php | 63 +
.../Contracts/Auth/SupportsBasicAuth.php | 24 +
.../Contracts/Auth/UserProvider.php | 49 +
.../Contracts/Broadcasting/Broadcaster.php | 33 +
.../Contracts/Broadcasting/Factory.php | 14 +
.../Broadcasting/ShouldBroadcast.php | 13 +
.../Broadcasting/ShouldBroadcastNow.php | 8 +
.../Illuminate/Contracts/Bus/Dispatcher.php | 31 +
.../Contracts/Bus/QueueingDispatcher.php | 14 +
.../Illuminate/Contracts/Cache/Factory.php | 14 +
.../Illuminate/Contracts/Cache/Repository.php | 117 +
.../src/Illuminate/Contracts/Cache/Store.php | 92 +
.../Contracts/Config/Repository.php | 57 +
.../Contracts/Console/Application.php | 22 +
.../Illuminate/Contracts/Console/Kernel.php | 47 +
.../Container/BindingResolutionException.php | 10 +
.../Contracts/Container/Container.php | 151 +
.../Container/ContextualBindingBuilder.php | 22 +
.../Illuminate/Contracts/Cookie/Factory.php | 43 +
.../Contracts/Cookie/QueueingFactory.php | 28 +
.../Contracts/Database/ModelIdentifier.php | 35 +
.../Contracts/Debug/ExceptionHandler.php | 34 +
.../Contracts/Encryption/DecryptException.php | 10 +
.../Contracts/Encryption/EncryptException.php | 10 +
.../Contracts/Encryption/Encrypter.php | 24 +
.../Contracts/Events/Dispatcher.php | 82 +
.../Illuminate/Contracts/Filesystem/Cloud.php | 14 +
.../Contracts/Filesystem/Factory.php | 14 +
.../Filesystem/FileNotFoundException.php | 10 +
.../Contracts/Filesystem/Filesystem.php | 175 +
.../Contracts/Foundation/Application.php | 92 +
.../Illuminate/Contracts/Hashing/Hasher.php | 34 +
.../src/Illuminate/Contracts/Http/Kernel.php | 37 +
.../src/Illuminate/Contracts/Logging/Log.php | 98 +
.../Illuminate/Contracts/Mail/MailQueue.php | 29 +
.../Illuminate/Contracts/Mail/Mailable.php | 33 +
.../src/Illuminate/Contracts/Mail/Mailer.php | 32 +
.../Contracts/Notifications/Dispatcher.php | 24 +
.../Contracts/Notifications/Factory.php | 32 +
.../Pagination/LengthAwarePaginator.php | 29 +
.../Contracts/Pagination/Paginator.php | 110 +
.../src/Illuminate/Contracts/Pipeline/Hub.php | 15 +
.../Contracts/Pipeline/Pipeline.php | 40 +
.../Queue/EntityNotFoundException.php | 22 +
.../Contracts/Queue/EntityResolver.php | 15 +
.../Illuminate/Contracts/Queue/Factory.php | 14 +
.../src/Illuminate/Contracts/Queue/Job.php | 108 +
.../Illuminate/Contracts/Queue/Monitor.php | 30 +
.../src/Illuminate/Contracts/Queue/Queue.php | 99 +
.../Contracts/Queue/QueueableCollection.php | 20 +
.../Contracts/Queue/QueueableEntity.php | 13 +
.../Contracts/Queue/ShouldQueue.php | 8 +
.../Illuminate/Contracts/Redis/Factory.php | 14 +
.../Contracts/Routing/BindingRegistrar.php | 23 +
.../Contracts/Routing/Registrar.php | 105 +
.../Contracts/Routing/ResponseFactory.php | 126 +
.../Contracts/Routing/UrlGenerator.php | 71 +
.../Contracts/Routing/UrlRoutable.php | 20 +
.../Illuminate/Contracts/Session/Session.php | 165 +
.../Contracts/Support/Arrayable.php | 13 +
.../Illuminate/Contracts/Support/Htmlable.php | 13 +
.../Illuminate/Contracts/Support/Jsonable.php | 14 +
.../Contracts/Support/MessageBag.php | 93 +
.../Contracts/Support/MessageProvider.php | 13 +
.../Contracts/Support/Renderable.php | 13 +
.../Contracts/Translation/Translator.php | 42 +
.../Contracts/Validation/Factory.php | 46 +
.../Validation/ValidatesWhenResolved.php | 13 +
.../Contracts/Validation/Validator.php | 40 +
.../src/Illuminate/Contracts/View/Factory.php | 79 +
.../src/Illuminate/Contracts/View/View.php | 24 +
.../src/Illuminate/Contracts/composer.json | 33 +
.../src/Illuminate/Cookie/CookieJar.php | 178 +
.../Cookie/CookieServiceProvider.php | 22 +
.../Middleware/AddQueuedCookiesToResponse.php | 45 +
.../Cookie/Middleware/EncryptCookies.php | 163 +
.../src/Illuminate/Cookie/composer.json | 37 +
.../Illuminate/Database/Capsule/Manager.php | 201 +
.../Database/Concerns/BuildsQueries.php | 159 +
.../Database/Concerns/ManagesTransactions.php | 219 +
.../src/Illuminate/Database/Connection.php | 1203 +
.../Database/ConnectionInterface.php | 150 +
.../Database/ConnectionResolver.php | 92 +
.../Database/ConnectionResolverInterface.php | 29 +
.../Database/Connectors/ConnectionFactory.php | 288 +
.../Database/Connectors/Connector.php | 137 +
.../Connectors/ConnectorInterface.php | 14 +
.../Database/Connectors/MySqlConnector.php | 180 +
.../Database/Connectors/PostgresConnector.php | 174 +
.../Database/Connectors/SQLiteConnector.php | 39 +
.../Connectors/SqlServerConnector.php | 175 +
.../Console/Migrations/BaseCommand.php | 39 +
.../Console/Migrations/InstallCommand.php | 70 +
.../Console/Migrations/MigrateCommand.php | 102 +
.../Console/Migrations/MigrateMakeCommand.php | 119 +
.../Console/Migrations/RefreshCommand.php | 154 +
.../Console/Migrations/ResetCommand.php | 96 +
.../Console/Migrations/RollbackCommand.php | 94 +
.../Console/Migrations/StatusCommand.php | 108 +
.../Database/Console/Seeds/SeedCommand.php | 106 +
.../Console/Seeds/SeederMakeCommand.php | 96 +
.../Database/Console/Seeds/stubs/seeder.stub | 16 +
.../Illuminate/Database/DatabaseManager.php | 329 +
.../Database/DatabaseServiceProvider.php | 99 +
.../Illuminate/Database/DetectsDeadlocks.php | 31 +
.../Database/DetectsLostConnections.php | 34 +
.../Illuminate/Database/Eloquent/Builder.php | 1296 +
.../Database/Eloquent/Collection.php | 398 +
.../Eloquent/Concerns/GuardsAttributes.php | 193 +
.../Eloquent/Concerns/HasAttributes.php | 1065 +
.../Database/Eloquent/Concerns/HasEvents.php | 325 +
.../Eloquent/Concerns/HasGlobalScopes.php | 71 +
.../Eloquent/Concerns/HasRelationships.php | 575 +
.../Eloquent/Concerns/HasTimestamps.php | 125 +
.../Eloquent/Concerns/HidesAttributes.php | 126 +
.../Concerns/QueriesRelationships.php | 313 +
.../Illuminate/Database/Eloquent/Factory.php | 253 +
.../Database/Eloquent/FactoryBuilder.php | 282 +
.../Eloquent/JsonEncodingException.php | 35 +
.../Eloquent/MassAssignmentException.php | 10 +
.../Illuminate/Database/Eloquent/Model.php | 1408 +
.../Eloquent/ModelNotFoundException.php | 65 +
.../Database/Eloquent/QueueEntityResolver.php | 29 +
.../Eloquent/RelationNotFoundException.php | 22 +
.../Database/Eloquent/Relations/BelongsTo.php | 362 +
.../Eloquent/Relations/BelongsToMany.php | 911 +
.../Concerns/InteractsWithPivotTable.php | 502 +
.../Concerns/SupportsDefaultModels.php | 63 +
.../Database/Eloquent/Relations/HasMany.php | 47 +
.../Eloquent/Relations/HasManyThrough.php | 455 +
.../Database/Eloquent/Relations/HasOne.php | 64 +
.../Eloquent/Relations/HasOneOrMany.php | 417 +
.../Database/Eloquent/Relations/MorphMany.php | 47 +
.../Database/Eloquent/Relations/MorphOne.php | 64 +
.../Eloquent/Relations/MorphOneOrMany.php | 248 +
.../Eloquent/Relations/MorphPivot.php | 79 +
.../Database/Eloquent/Relations/MorphTo.php | 275 +
.../Eloquent/Relations/MorphToMany.php | 162 +
.../Database/Eloquent/Relations/Pivot.php | 198 +
.../Database/Eloquent/Relations/Relation.php | 374 +
.../Illuminate/Database/Eloquent/Scope.php | 15 +
.../Database/Eloquent/SoftDeletes.php | 167 +
.../Database/Eloquent/SoftDeletingScope.php | 127 +
.../Database/Events/ConnectionEvent.php | 32 +
.../Database/Events/QueryExecuted.php | 58 +
.../Database/Events/StatementPrepared.php | 33 +
.../Database/Events/TransactionBeginning.php | 8 +
.../Database/Events/TransactionCommitted.php | 8 +
.../Database/Events/TransactionRolledBack.php | 8 +
.../src/Illuminate/Database/Grammar.php | 205 +
.../Database/MigrationServiceProvider.php | 87 +
.../DatabaseMigrationRepository.php | 197 +
.../Database/Migrations/Migration.php | 23 +
.../Database/Migrations/MigrationCreator.php | 204 +
.../MigrationRepositoryInterface.php | 74 +
.../Database/Migrations/Migrator.php | 577 +
.../Database/Migrations/stubs/blank.stub | 28 +
.../Database/Migrations/stubs/create.stub | 31 +
.../Database/Migrations/stubs/update.stub | 32 +
.../Illuminate/Database/MySqlConnection.php | 84 +
.../Database/PostgresConnection.php | 66 +
.../src/Illuminate/Database/Query/Builder.php | 2447 ++
.../Illuminate/Database/Query/Expression.php | 44 +
.../Database/Query/Grammars/Grammar.php | 852 +
.../Database/Query/Grammars/MySqlGrammar.php | 300 +
.../Query/Grammars/PostgresGrammar.php | 331 +
.../Database/Query/Grammars/SQLiteGrammar.php | 190 +
.../Query/Grammars/SqlServerGrammar.php | 442 +
.../Illuminate/Database/Query/JoinClause.php | 100 +
.../Database/Query/JsonExpression.php | 70 +
.../Query/Processors/MySqlProcessor.php | 19 +
.../Query/Processors/PostgresProcessor.php | 41 +
.../Database/Query/Processors/Processor.php | 49 +
.../Query/Processors/SQLiteProcessor.php | 19 +
.../Query/Processors/SqlServerProcessor.php | 69 +
.../Illuminate/Database/QueryException.php | 78 +
.../src/Illuminate/Database/README.md | 69 +
.../Illuminate/Database/SQLiteConnection.php | 51 +
.../Illuminate/Database/Schema/Blueprint.php | 1130 +
.../Illuminate/Database/Schema/Builder.php | 291 +
.../Database/Schema/Grammars/ChangeColumn.php | 205 +
.../Database/Schema/Grammars/Grammar.php | 255 +
.../Database/Schema/Grammars/MySqlGrammar.php | 829 +
.../Schema/Grammars/PostgresGrammar.php | 626 +
.../Database/Schema/Grammars/RenameColumn.php | 69 +
.../Schema/Grammars/SQLiteGrammar.php | 653 +
.../Schema/Grammars/SqlServerGrammar.php | 626 +
.../Database/Schema/MySqlBuilder.php | 38 +
.../Database/Schema/PostgresBuilder.php | 27 +
.../src/Illuminate/Database/Seeder.php | 117 +
.../Database/SqlServerConnection.php | 98 +
.../src/Illuminate/Database/composer.json | 46 +
.../src/Illuminate/Encryption/Encrypter.php | 241 +
.../Encryption/EncryptionServiceProvider.php | 30 +
.../src/Illuminate/Encryption/composer.json | 38 +
.../Illuminate/Events/CallQueuedHandler.php | 86 +
.../Illuminate/Events/CallQueuedListener.php | 141 +
.../src/Illuminate/Events/Dispatcher.php | 563 +
.../Events/EventServiceProvider.php | 23 +
.../src/Illuminate/Events/composer.json | 36 +
.../src/Illuminate/Filesystem/Filesystem.php | 570 +
.../Filesystem/FilesystemAdapter.php | 548 +
.../Filesystem/FilesystemManager.php | 345 +
.../Filesystem/FilesystemServiceProvider.php | 82 +
.../src/Illuminate/Filesystem/composer.json | 41 +
.../src/Illuminate/Foundation/AliasLoader.php | 242 +
.../src/Illuminate/Foundation/Application.php | 1173 +
.../Foundation/Auth/Access/Authorizable.php | 44 +
.../Auth/Access/AuthorizesRequests.php | 125 +
.../Foundation/Auth/AuthenticatesUsers.php | 172 +
.../Foundation/Auth/RedirectsUsers.php | 20 +
.../Foundation/Auth/RegistersUsers.php | 62 +
.../Foundation/Auth/ResetsPasswords.php | 156 +
.../Auth/SendsPasswordResetEmails.php | 87 +
.../Foundation/Auth/ThrottlesLogins.php | 124 +
.../src/Illuminate/Foundation/Auth/User.php | 19 +
.../Foundation/Bootstrap/BootProviders.php | 19 +
.../Foundation/Bootstrap/HandleExceptions.php | 161 +
.../Bootstrap/LoadConfiguration.php | 113 +
.../Bootstrap/LoadEnvironmentVariables.php | 69 +
.../Foundation/Bootstrap/RegisterFacades.php | 25 +
.../Bootstrap/RegisterProviders.php | 19 +
.../Bootstrap/SetRequestForConsole.php | 35 +
.../Foundation/Bus/Dispatchable.php | 16 +
.../Foundation/Bus/DispatchesJobs.php | 30 +
.../Foundation/Bus/PendingDispatch.php | 66 +
.../Illuminate/Foundation/ComposerScripts.php | 48 +
.../Foundation/Console/AppNameCommand.php | 289 +
.../Console/ClearCompiledCommand.php | 38 +
.../Foundation/Console/ClosureCommand.php | 71 +
.../Foundation/Console/ConfigCacheCommand.php | 76 +
.../Foundation/Console/ConfigClearCommand.php | 55 +
.../Foundation/Console/ConsoleMakeCommand.php | 90 +
.../Foundation/Console/DownCommand.php | 65 +
.../Foundation/Console/EnvironmentCommand.php | 32 +
.../Console/EventGenerateCommand.php | 74 +
.../Foundation/Console/EventMakeCommand.php | 61 +
.../Foundation/Console/JobMakeCommand.php | 65 +
.../Illuminate/Foundation/Console/Kernel.php | 334 +
.../Foundation/Console/KeyGenerateCommand.php | 110 +
.../Console/ListenerMakeCommand.php | 119 +
.../Foundation/Console/MailMakeCommand.php | 116 +
.../Foundation/Console/ModelMakeCommand.php | 122 +
.../Console/NotificationMakeCommand.php | 116 +
.../Foundation/Console/OptimizeCommand.php | 76 +
.../Foundation/Console/PolicyMakeCommand.php | 134 +
.../Console/ProviderMakeCommand.php | 50 +
.../Foundation/Console/QueuedCommand.php | 42 +
.../Foundation/Console/RequestMakeCommand.php | 50 +
.../Foundation/Console/RouteCacheCommand.php | 109 +
.../Foundation/Console/RouteClearCommand.php | 55 +
.../Foundation/Console/RouteListCommand.php | 192 +
.../Foundation/Console/ServeCommand.php | 90 +
.../Foundation/Console/StorageLinkCommand.php | 40 +
.../Foundation/Console/TestMakeCommand.php | 81 +
.../Foundation/Console/UpCommand.php | 34 +
.../Console/VendorPublishCommand.php | 189 +
.../Foundation/Console/ViewClearCommand.php | 64 +
.../Foundation/Console/stubs/console.stub | 42 +
.../Console/stubs/event-handler-queued.stub | 33 +
.../Console/stubs/event-handler.stub | 31 +
.../Foundation/Console/stubs/event.stub | 36 +
.../Foundation/Console/stubs/job-queued.stub | 34 +
.../Foundation/Console/stubs/job.stub | 31 +
.../Console/stubs/listener-queued.stub | 33 +
.../Foundation/Console/stubs/listener.stub | 31 +
.../Foundation/Console/stubs/mail.stub | 33 +
.../Console/stubs/markdown-mail.stub | 33 +
.../Console/stubs/markdown-notification.stub | 58 +
.../Foundation/Console/stubs/markdown.stub | 12 +
.../Foundation/Console/stubs/model.stub | 10 +
.../Console/stubs/notification.stub | 61 +
.../Console/stubs/policy.plain.stub | 21 +
.../Foundation/Console/stubs/policy.stub | 59 +
.../Foundation/Console/stubs/provider.stub | 28 +
.../Foundation/Console/stubs/request.stub | 30 +
.../Foundation/Console/stubs/routes.stub | 16 +
.../Foundation/Console/stubs/test.stub | 21 +
.../Foundation/Console/stubs/unit-test.stub | 20 +
.../Foundation/EnvironmentDetector.php | 69 +
.../Foundation/Events/Dispatchable.php | 26 +
.../Foundation/Events/LocaleUpdated.php | 24 +
.../Foundation/Exceptions/Handler.php | 256 +
.../Foundation/Exceptions/views/503.blade.php | 56 +
.../Foundation/Http/Events/RequestHandled.php | 33 +
.../Exceptions/MaintenanceModeException.php | 54 +
.../Foundation/Http/FormRequest.php | 249 +
.../src/Illuminate/Foundation/Http/Kernel.php | 338 +
.../Middleware/CheckForMaintenanceMode.php | 48 +
.../Middleware/ConvertEmptyStringsToNull.php | 18 +
.../Http/Middleware/TransformsRequest.php | 101 +
.../Http/Middleware/TrimStrings.php | 31 +
.../Http/Middleware/ValidatePostSize.php | 54 +
.../Http/Middleware/VerifyCsrfToken.php | 165 +
.../src/Illuminate/Foundation/Inspiring.php | 34 +
.../Foundation/ProviderRepository.php | 210 +
.../Providers/ArtisanServiceProvider.php | 869 +
.../Providers/ComposerServiceProvider.php | 38 +
.../ConsoleSupportServiceProvider.php | 27 +
.../Providers/FormRequestServiceProvider.php | 69 +
.../Providers/FoundationServiceProvider.php | 17 +
.../Support/Providers/AuthServiceProvider.php | 36 +
.../Providers/EventServiceProvider.php | 59 +
.../Providers/RouteServiceProvider.php | 101 +
.../Concerns/InteractsWithAuthentication.php | 145 +
.../Testing/Concerns/InteractsWithConsole.php | 20 +
.../Concerns/InteractsWithContainer.php | 32 +
.../Concerns/InteractsWithDatabase.php | 91 +
.../Testing/Concerns/InteractsWithSession.php | 64 +
.../Testing/Concerns/MakesHttpRequests.php | 328 +
.../Concerns/MocksApplicationServices.php | 283 +
.../Testing/Constraints/HasInDatabase.php | 103 +
.../Constraints/SoftDeletedInDatabase.php | 103 +
.../Foundation/Testing/DatabaseMigrations.php | 24 +
.../Testing/DatabaseTransactions.php | 40 +
.../Foundation/Testing/HttpException.php | 10 +
.../Foundation/Testing/TestCase.php | 178 +
.../Foundation/Testing/TestResponse.php | 657 +
.../Foundation/Testing/WithoutEvents.php | 22 +
.../Foundation/Testing/WithoutMiddleware.php | 22 +
.../Validation/ValidatesRequests.php | 168 +
.../src/Illuminate/Foundation/helpers.php | 887 +
.../Illuminate/Foundation/stubs/facade.stub | 21 +
.../src/Illuminate/Hashing/BcryptHasher.php | 93 +
.../Hashing/HashServiceProvider.php | 37 +
.../src/Illuminate/Hashing/composer.json | 35 +
.../Concerns/InteractsWithContentTypes.php | 157 +
.../Http/Concerns/InteractsWithFlashData.php | 64 +
.../Http/Concerns/InteractsWithInput.php | 315 +
.../Http/Exceptions/HttpResponseException.php | 37 +
.../Http/Exceptions/PostTooLargeException.php | 10 +
.../framework/src/Illuminate/Http/File.php | 10 +
.../src/Illuminate/Http/FileHelpers.php | 62 +
.../src/Illuminate/Http/JsonResponse.php | 110 +
.../CheckResponseForModifications.php | 27 +
.../Illuminate/Http/Middleware/FrameGuard.php | 24 +
.../src/Illuminate/Http/RedirectResponse.php | 238 +
.../framework/src/Illuminate/Http/Request.php | 616 +
.../src/Illuminate/Http/Response.php | 72 +
.../src/Illuminate/Http/ResponseTrait.php | 134 +
.../src/Illuminate/Http/Testing/File.php | 115 +
.../Illuminate/Http/Testing/FileFactory.php | 51 +
.../src/Illuminate/Http/Testing/MimeType.php | 793 +
.../src/Illuminate/Http/UploadedFile.php | 122 +
.../src/Illuminate/Http/composer.json | 37 +
.../Illuminate/Log/Events/MessageLogged.php | 42 +
.../src/Illuminate/Log/LogServiceProvider.php | 154 +
.../framework/src/Illuminate/Log/Writer.php | 377 +
.../src/Illuminate/Log/composer.json | 36 +
.../Illuminate/Mail/Events/MessageSending.php | 24 +
.../Illuminate/Mail/Events/MessageSent.php | 24 +
.../Illuminate/Mail/MailServiceProvider.php | 145 +
.../src/Illuminate/Mail/Mailable.php | 665 +
.../framework/src/Illuminate/Mail/Mailer.php | 546 +
.../src/Illuminate/Mail/Markdown.php | 148 +
.../framework/src/Illuminate/Mail/Message.php | 328 +
.../src/Illuminate/Mail/PendingMail.php | 154 +
.../Illuminate/Mail/SendQueuedMailable.php | 64 +
.../Mail/Transport/ArrayTransport.php | 58 +
.../Mail/Transport/LogTransport.php | 59 +
.../Mail/Transport/MailgunTransport.php | 168 +
.../Mail/Transport/MandrillTransport.php | 105 +
.../Mail/Transport/SesTransport.php | 48 +
.../Mail/Transport/SparkPostTransport.php | 159 +
.../Illuminate/Mail/Transport/Transport.php | 100 +
.../src/Illuminate/Mail/TransportManager.php | 210 +
.../src/Illuminate/Mail/composer.json | 44 +
.../resources/views/html/button.blade.php | 19 +
.../resources/views/html/footer.blade.php | 11 +
.../resources/views/html/header.blade.php | 7 +
.../resources/views/html/layout.blade.php | 54 +
.../resources/views/html/message.blade.php | 27 +
.../Mail/resources/views/html/panel.blade.php | 13 +
.../resources/views/html/promotion.blade.php | 7 +
.../views/html/promotion/button.blade.php | 13 +
.../resources/views/html/subcopy.blade.php | 7 +
.../Mail/resources/views/html/table.blade.php | 3 +
.../resources/views/html/themes/default.css | 285 +
.../resources/views/markdown/button.blade.php | 1 +
.../resources/views/markdown/footer.blade.php | 1 +
.../resources/views/markdown/header.blade.php | 1 +
.../resources/views/markdown/layout.blade.php | 9 +
.../views/markdown/message.blade.php | 27 +
.../resources/views/markdown/panel.blade.php | 1 +
.../views/markdown/promotion.blade.php | 1 +
.../views/markdown/promotion/button.blade.php | 1 +
.../views/markdown/subcopy.blade.php | 1 +
.../resources/views/markdown/table.blade.php | 1 +
.../src/Illuminate/Notifications/Action.php | 33 +
.../Notifications/ChannelManager.php | 174 +
.../Channels/BroadcastChannel.php | 77 +
.../Channels/DatabaseChannel.php | 51 +
.../Notifications/Channels/MailChannel.php | 196 +
.../Channels/NexmoSmsChannel.php | 64 +
.../Channels/SlackWebhookChannel.php | 114 +
.../Console/NotificationTableCommand.php | 81 +
.../Console/stubs/notifications.stub | 35 +
.../Notifications/DatabaseNotification.php | 90 +
.../DatabaseNotificationCollection.php | 20 +
.../Events/BroadcastNotificationCreated.php | 94 +
.../Events/NotificationFailed.php | 51 +
.../Events/NotificationSending.php | 42 +
.../Notifications/Events/NotificationSent.php | 51 +
.../HasDatabaseNotifications.php | 33 +
.../Messages/BroadcastMessage.php | 41 +
.../Messages/DatabaseMessage.php | 24 +
.../Notifications/Messages/MailMessage.php | 220 +
.../Notifications/Messages/NexmoMessage.php | 76 +
.../Notifications/Messages/SimpleMessage.php | 219 +
.../Messages/SlackAttachment.php | 241 +
.../Messages/SlackAttachmentField.php | 79 +
.../Notifications/Messages/SlackMessage.php | 221 +
.../Illuminate/Notifications/Notifiable.php | 8 +
.../Illuminate/Notifications/Notification.php | 27 +
.../Notifications/NotificationSender.php | 181 +
.../NotificationServiceProvider.php | 46 +
.../Notifications/RoutesNotifications.php | 42 +
.../Notifications/SendQueuedNotifications.php | 69 +
.../Illuminate/Notifications/composer.json | 47 +
.../resources/views/email.blade.php | 58 +
.../Pagination/AbstractPaginator.php | 580 +
.../Pagination/LengthAwarePaginator.php | 197 +
.../Pagination/PaginationServiceProvider.php | 50 +
.../src/Illuminate/Pagination/Paginator.php | 176 +
.../src/Illuminate/Pagination/UrlWindow.php | 218 +
.../src/Illuminate/Pagination/composer.json | 35 +
.../resources/views/bootstrap-4.blade.php | 36 +
.../resources/views/default.blade.php | 36 +
.../views/simple-bootstrap-4.blade.php | 17 +
.../resources/views/simple-default.blade.php | 17 +
.../framework/src/Illuminate/Pipeline/Hub.php | 74 +
.../src/Illuminate/Pipeline/Pipeline.php | 184 +
.../Pipeline/PipelineServiceProvider.php | 40 +
.../src/Illuminate/Pipeline/composer.json | 35 +
.../src/Illuminate/Queue/BeanstalkdQueue.php | 163 +
.../Illuminate/Queue/CallQueuedHandler.php | 101 +
.../src/Illuminate/Queue/Capsule/Manager.php | 187 +
.../Queue/Connectors/BeanstalkdConnector.php | 41 +
.../Queue/Connectors/ConnectorInterface.php | 14 +
.../Queue/Connectors/DatabaseConnector.php | 44 +
.../Queue/Connectors/NullConnector.php | 19 +
.../Queue/Connectors/RedisConnector.php | 52 +
.../Queue/Connectors/SqsConnector.php | 46 +
.../Queue/Connectors/SyncConnector.php | 19 +
.../Queue/Console/FailedTableCommand.php | 102 +
.../Queue/Console/FlushFailedCommand.php | 34 +
.../Queue/Console/ForgetFailedCommand.php | 49 +
.../Queue/Console/ListFailedCommand.php | 118 +
.../Queue/Console/ListenCommand.php | 114 +
.../Queue/Console/RestartCommand.php | 35 +
.../Illuminate/Queue/Console/RetryCommand.php | 106 +
.../Illuminate/Queue/Console/TableCommand.php | 102 +
.../Illuminate/Queue/Console/WorkCommand.php | 213 +
.../Queue/Console/stubs/failed_jobs.stub | 35 +
.../Illuminate/Queue/Console/stubs/jobs.stub | 38 +
.../src/Illuminate/Queue/DatabaseQueue.php | 323 +
.../Queue/Events/JobExceptionOccurred.php | 42 +
.../src/Illuminate/Queue/Events/JobFailed.php | 42 +
.../Illuminate/Queue/Events/JobProcessed.php | 33 +
.../Illuminate/Queue/Events/JobProcessing.php | 33 +
.../src/Illuminate/Queue/Events/Looping.php | 8 +
.../Queue/Events/WorkerStopping.php | 8 +
.../Failed/DatabaseFailedJobProvider.php | 117 +
.../Failed/FailedJobProviderInterface.php | 47 +
.../Queue/Failed/NullFailedJobProvider.php | 62 +
.../src/Illuminate/Queue/FailingJob.php | 50 +
.../Illuminate/Queue/InteractsWithQueue.php | 76 +
.../Illuminate/Queue/InteractsWithTime.php | 45 +
.../Queue/InvalidPayloadException.php | 19 +
.../Illuminate/Queue/Jobs/BeanstalkdJob.php | 135 +
.../src/Illuminate/Queue/Jobs/DatabaseJob.php | 100 +
.../Queue/Jobs/DatabaseJobRecord.php | 63 +
.../src/Illuminate/Queue/Jobs/Job.php | 254 +
.../src/Illuminate/Queue/Jobs/JobName.php | 44 +
.../src/Illuminate/Queue/Jobs/RedisJob.php | 140 +
.../src/Illuminate/Queue/Jobs/SqsJob.php | 124 +
.../src/Illuminate/Queue/Jobs/SyncJob.php | 91 +
.../src/Illuminate/Queue/Listener.php | 248 +
.../src/Illuminate/Queue/ListenerOptions.php | 31 +
.../src/Illuminate/Queue/LuaScripts.php | 103 +
.../Queue/ManuallyFailedException.php | 10 +
.../Queue/MaxAttemptsExceededException.php | 10 +
.../src/Illuminate/Queue/NullQueue.php | 70 +
.../framework/src/Illuminate/Queue/Queue.php | 193 +
.../src/Illuminate/Queue/QueueManager.php | 270 +
.../Illuminate/Queue/QueueServiceProvider.php | 230 +
.../framework/src/Illuminate/Queue/README.md | 34 +
.../src/Illuminate/Queue/RedisQueue.php | 281 +
.../SerializesAndRestoresModelIdentifiers.php | 77 +
.../src/Illuminate/Queue/SerializesModels.php | 58 +
.../src/Illuminate/Queue/SqsQueue.php | 155 +
.../src/Illuminate/Queue/SyncQueue.php | 161 +
.../framework/src/Illuminate/Queue/Worker.php | 620 +
.../src/Illuminate/Queue/WorkerOptions.php | 68 +
.../src/Illuminate/Queue/composer.json | 47 +
.../Redis/Connections/Connection.php | 86 +
.../Connections/PhpRedisClusterConnection.php | 8 +
.../Redis/Connections/PhpRedisConnection.php | 261 +
.../Connections/PredisClusterConnection.php | 8 +
.../Redis/Connections/PredisConnection.php | 45 +
.../Redis/Connectors/PhpRedisConnector.php | 117 +
.../Redis/Connectors/PredisConnector.php | 44 +
.../src/Illuminate/Redis/RedisManager.php | 132 +
.../Illuminate/Redis/RedisServiceProvider.php | 44 +
.../src/Illuminate/Redis/composer.json | 36 +
.../Routing/Console/ControllerMakeCommand.php | 172 +
.../Routing/Console/MiddlewareMakeCommand.php | 50 +
.../Console/stubs/controller.model.stub | 86 +
.../Console/stubs/controller.nested.stub | 94 +
.../Console/stubs/controller.plain.stub | 11 +
.../Routing/Console/stubs/controller.stub | 85 +
.../Routing/Console/stubs/middleware.stub | 20 +
.../src/Illuminate/Routing/Controller.php | 84 +
.../Routing/ControllerDispatcher.php | 80 +
.../Routing/ControllerMiddlewareOptions.php | 50 +
.../Routing/Events/RouteMatched.php | 33 +
.../Exceptions/UrlGenerationException.php | 19 +
.../Routing/ImplicitRouteBinding.php | 58 +
.../Routing/Matching/HostValidator.php | 25 +
.../Routing/Matching/MethodValidator.php | 21 +
.../Routing/Matching/SchemeValidator.php | 27 +
.../Routing/Matching/UriValidator.php | 23 +
.../Routing/Matching/ValidatorInterface.php | 18 +
.../Routing/Middleware/SubstituteBindings.php | 43 +
.../Routing/Middleware/ThrottleRequests.php | 130 +
.../Routing/MiddlewareNameResolver.php | 85 +
.../src/Illuminate/Routing/Pipeline.php | 90 +
.../src/Illuminate/Routing/Redirector.php | 210 +
.../Illuminate/Routing/ResourceRegistrar.php | 440 +
.../Illuminate/Routing/ResponseFactory.php | 215 +
.../src/Illuminate/Routing/Route.php | 835 +
.../src/Illuminate/Routing/RouteAction.php | 89 +
.../src/Illuminate/Routing/RouteBinding.php | 82 +
.../Illuminate/Routing/RouteCollection.php | 347 +
.../src/Illuminate/Routing/RouteCompiler.php | 54 +
.../Routing/RouteDependencyResolverTrait.php | 109 +
.../src/Illuminate/Routing/RouteGroup.php | 95 +
.../Routing/RouteParameterBinder.php | 120 +
.../src/Illuminate/Routing/RouteRegistrar.php | 175 +
.../Routing/RouteSignatureParameters.php | 45 +
.../Illuminate/Routing/RouteUrlGenerator.php | 307 +
.../src/Illuminate/Routing/Router.php | 1100 +
.../Routing/RoutingServiceProvider.php | 151 +
.../Illuminate/Routing/SortedMiddleware.php | 84 +
.../src/Illuminate/Routing/UrlGenerator.php | 618 +
.../src/Illuminate/Routing/composer.json | 47 +
.../Session/CacheBasedSessionHandler.php | 94 +
.../Session/Console/SessionTableCommand.php | 81 +
.../Session/Console/stubs/database.stub | 35 +
.../Session/CookieSessionHandler.php | 119 +
.../Session/DatabaseSessionHandler.php | 289 +
.../src/Illuminate/Session/EncryptedStore.php | 69 +
.../Session/ExistenceAwareInterface.php | 14 +
.../Illuminate/Session/FileSessionHandler.php | 113 +
.../Middleware/AuthenticateSession.php | 92 +
.../Session/Middleware/StartSession.php | 243 +
.../src/Illuminate/Session/SessionManager.php | 216 +
.../Session/SessionServiceProvider.php | 50 +
.../src/Illuminate/Session/Store.php | 656 +
.../Session/TokenMismatchException.php | 10 +
.../src/Illuminate/Session/composer.json | 42 +
.../Support/AggregateServiceProvider.php | 52 +
.../framework/src/Illuminate/Support/Arr.php | 602 +
.../src/Illuminate/Support/Collection.php | 1655 +
.../src/Illuminate/Support/Composer.php | 100 +
.../src/Illuminate/Support/Debug/Dumper.php | 26 +
.../Illuminate/Support/Debug/HtmlDumper.php | 29 +
.../src/Illuminate/Support/Facades/App.php | 31 +
.../Illuminate/Support/Facades/Artisan.php | 27 +
.../src/Illuminate/Support/Facades/Auth.php | 48 +
.../src/Illuminate/Support/Facades/Blade.php | 19 +
.../Illuminate/Support/Facades/Broadcast.php | 21 +
.../src/Illuminate/Support/Facades/Bus.php | 32 +
.../src/Illuminate/Support/Facades/Cache.php | 20 +
.../src/Illuminate/Support/Facades/Config.php | 19 +
.../src/Illuminate/Support/Facades/Cookie.php | 42 +
.../src/Illuminate/Support/Facades/Crypt.php | 19 +
.../src/Illuminate/Support/Facades/DB.php | 20 +
.../src/Illuminate/Support/Facades/Event.php | 34 +
.../src/Illuminate/Support/Facades/Facade.php | 223 +
.../src/Illuminate/Support/Facades/File.php | 19 +
.../src/Illuminate/Support/Facades/Gate.php | 21 +
.../src/Illuminate/Support/Facades/Hash.php | 19 +
.../src/Illuminate/Support/Facades/Input.php | 33 +
.../src/Illuminate/Support/Facades/Lang.php | 19 +
.../src/Illuminate/Support/Facades/Log.php | 21 +
.../src/Illuminate/Support/Facades/Mail.php | 31 +
.../Support/Facades/Notification.php | 32 +
.../Illuminate/Support/Facades/Password.php | 54 +
.../src/Illuminate/Support/Facades/Queue.php | 32 +
.../Illuminate/Support/Facades/Redirect.php | 19 +
.../src/Illuminate/Support/Facades/Redis.php | 20 +
.../Illuminate/Support/Facades/Request.php | 19 +
.../Illuminate/Support/Facades/Response.php | 21 +
.../src/Illuminate/Support/Facades/Route.php | 35 +
.../src/Illuminate/Support/Facades/Schema.php | 35 +
.../Illuminate/Support/Facades/Session.php | 20 +
.../Illuminate/Support/Facades/Storage.php | 50 +
.../src/Illuminate/Support/Facades/URL.php | 19 +
.../Illuminate/Support/Facades/Validator.php | 19 +
.../src/Illuminate/Support/Facades/View.php | 19 +
.../src/Illuminate/Support/Fluent.php | 192 +
.../Support/HigherOrderCollectionProxy.php | 63 +
.../Support/HigherOrderTapProxy.php | 38 +
.../src/Illuminate/Support/HtmlString.php | 46 +
.../src/Illuminate/Support/Manager.php | 140 +
.../src/Illuminate/Support/MessageBag.php | 384 +
.../Support/NamespacedItemResolver.php | 106 +
.../src/Illuminate/Support/Pluralizer.php | 114 +
.../Illuminate/Support/ServiceProvider.php | 277 +
.../framework/src/Illuminate/Support/Str.php | 646 +
.../Support/Testing/Fakes/BusFake.php | 113 +
.../Support/Testing/Fakes/EventFake.php | 197 +
.../Support/Testing/Fakes/MailFake.php | 178 +
.../Testing/Fakes/NotificationFake.php | 165 +
.../Support/Testing/Fakes/PendingMailFake.php | 53 +
.../Support/Testing/Fakes/QueueFake.php | 238 +
.../Support/Traits/CapsuleManagerTrait.php | 69 +
.../Illuminate/Support/Traits/Macroable.php | 83 +
.../src/Illuminate/Support/ViewErrorBag.php | 120 +
.../src/Illuminate/Support/composer.json | 48 +
.../src/Illuminate/Support/helpers.php | 1038 +
.../Illuminate/Translation/ArrayLoader.php | 72 +
.../src/Illuminate/Translation/FileLoader.php | 157 +
.../Translation/LoaderInterface.php | 32 +
.../Translation/MessageSelector.php | 412 +
.../TranslationServiceProvider.php | 62 +
.../src/Illuminate/Translation/Translator.php | 468 +
.../src/Illuminate/Translation/composer.json | 36 +
.../Validation/Concerns/FormatsMessages.php | 348 +
.../Concerns/ReplacesAttributes.php | 380 +
.../Concerns/ValidatesAttributes.php | 1457 +
.../Validation/DatabasePresenceVerifier.php | 138 +
.../src/Illuminate/Validation/Factory.php | 283 +
.../Validation/PresenceVerifierInterface.php | 30 +
.../src/Illuminate/Validation/Rule.php | 67 +
.../Validation/Rules/Dimensions.php | 131 +
.../Illuminate/Validation/Rules/Exists.php | 150 +
.../src/Illuminate/Validation/Rules/In.php | 39 +
.../src/Illuminate/Validation/Rules/NotIn.php | 39 +
.../Illuminate/Validation/Rules/Unique.php | 181 +
.../Validation/UnauthorizedException.php | 10 +
.../Validation/ValidatesWhenResolvedTrait.php | 86 +
.../Illuminate/Validation/ValidationData.php | 106 +
.../Validation/ValidationException.php | 47 +
.../Validation/ValidationRuleParser.php | 264 +
.../Validation/ValidationServiceProvider.php | 72 +
.../src/Illuminate/Validation/Validator.php | 1112 +
.../src/Illuminate/Validation/composer.json | 41 +
.../View/Compilers/BladeCompiler.php | 380 +
.../Illuminate/View/Compilers/Compiler.php | 74 +
.../View/Compilers/CompilerInterface.php | 30 +
.../Concerns/CompilesAuthorizations.php | 70 +
.../Compilers/Concerns/CompilesComments.php | 19 +
.../Compilers/Concerns/CompilesComponents.php | 48 +
.../Concerns/CompilesConditionals.php | 147 +
.../View/Compilers/Concerns/CompilesEchos.php | 105 +
.../Compilers/Concerns/CompilesIncludes.php | 56 +
.../Compilers/Concerns/CompilesInjections.php | 23 +
.../Compilers/Concerns/CompilesLayouts.php | 116 +
.../View/Compilers/Concerns/CompilesLoops.php | 180 +
.../Compilers/Concerns/CompilesRawPhp.php | 38 +
.../Compilers/Concerns/CompilesStacks.php | 59 +
.../Concerns/CompilesTranslations.php | 44 +
.../View/Concerns/ManagesComponents.php | 128 +
.../View/Concerns/ManagesEvents.php | 192 +
.../View/Concerns/ManagesLayouts.php | 218 +
.../Illuminate/View/Concerns/ManagesLoops.php | 90 +
.../View/Concerns/ManagesStacks.php | 177 +
.../View/Concerns/ManagesTranslations.php | 38 +
.../View/Engines/CompilerEngine.php | 102 +
.../src/Illuminate/View/Engines/Engine.php | 23 +
.../View/Engines/EngineInterface.php | 15 +
.../View/Engines/EngineResolver.php | 59 +
.../Illuminate/View/Engines/FileEngine.php | 18 +
.../src/Illuminate/View/Engines/PhpEngine.php | 69 +
.../framework/src/Illuminate/View/Factory.php | 542 +
.../src/Illuminate/View/FileViewFinder.php | 298 +
.../Middleware/ShareErrorsFromSession.php | 51 +
.../framework/src/Illuminate/View/View.php | 414 +
.../Illuminate/View/ViewFinderInterface.php | 71 +
.../src/Illuminate/View/ViewName.php | 25 +
.../Illuminate/View/ViewServiceProvider.php | 136 +
.../src/Illuminate/View/composer.json | 39 +
vendor/laravel/tinker/.styleci.yml | 4 +
vendor/laravel/tinker/LICENSE.md | 21 +
vendor/laravel/tinker/README.md | 30 +
vendor/laravel/tinker/composer.json | 49 +
vendor/laravel/tinker/config/tinker.php | 35 +
.../tinker/src/ClassAliasAutoloader.php | 116 +
.../tinker/src/Console/TinkerCommand.php | 129 +
vendor/laravel/tinker/src/TinkerCaster.php | 95 +
.../tinker/src/TinkerServiceProvider.php | 60 +
vendor/league/flysystem/LICENSE | 19 +
vendor/league/flysystem/SECURITY.md | 16 +
vendor/league/flysystem/composer.json | 71 +
vendor/league/flysystem/deprecations.md | 19 +
.../flysystem/src/Adapter/AbstractAdapter.php | 72 +
.../src/Adapter/AbstractFtpAdapter.php | 697 +
.../src/Adapter/CanOverwriteFiles.php | 12 +
vendor/league/flysystem/src/Adapter/Ftp.php | 574 +
vendor/league/flysystem/src/Adapter/Ftpd.php | 45 +
vendor/league/flysystem/src/Adapter/Local.php | 533 +
.../flysystem/src/Adapter/NullAdapter.php | 144 +
.../Polyfill/NotSupportingVisibilityTrait.php | 33 +
.../Adapter/Polyfill/StreamedCopyTrait.php | 51 +
.../Adapter/Polyfill/StreamedReadingTrait.php | 44 +
.../src/Adapter/Polyfill/StreamedTrait.php | 9 +
.../Adapter/Polyfill/StreamedWritingTrait.php | 60 +
.../flysystem/src/Adapter/SynologyFtp.php | 8 +
.../league/flysystem/src/AdapterInterface.php | 118 +
vendor/league/flysystem/src/Config.php | 107 +
.../league/flysystem/src/ConfigAwareTrait.php | 49 +
.../src/ConnectionErrorException.php | 9 +
.../src/ConnectionRuntimeException.php | 9 +
vendor/league/flysystem/src/Directory.php | 31 +
vendor/league/flysystem/src/Exception.php | 8 +
vendor/league/flysystem/src/File.php | 205 +
.../flysystem/src/FileExistsException.php | 37 +
.../flysystem/src/FileNotFoundException.php | 37 +
vendor/league/flysystem/src/Filesystem.php | 408 +
.../flysystem/src/FilesystemException.php | 7 +
.../flysystem/src/FilesystemInterface.php | 284 +
.../src/FilesystemNotFoundException.php | 12 +
vendor/league/flysystem/src/Handler.php | 137 +
.../flysystem/src/InvalidRootException.php | 9 +
vendor/league/flysystem/src/MountManager.php | 650 +
.../flysystem/src/NotSupportedException.php | 37 +
.../flysystem/src/Plugin/AbstractPlugin.php | 24 +
.../league/flysystem/src/Plugin/EmptyDir.php | 34 +
.../flysystem/src/Plugin/ForcedCopy.php | 44 +
.../flysystem/src/Plugin/ForcedRename.php | 44 +
.../flysystem/src/Plugin/GetWithMetadata.php | 51 +
.../league/flysystem/src/Plugin/ListFiles.php | 35 +
.../league/flysystem/src/Plugin/ListPaths.php | 36 +
.../league/flysystem/src/Plugin/ListWith.php | 60 +
.../flysystem/src/Plugin/PluggableTrait.php | 97 +
.../src/Plugin/PluginNotFoundException.php | 10 +
.../league/flysystem/src/PluginInterface.php | 20 +
vendor/league/flysystem/src/ReadInterface.php | 88 +
.../flysystem/src/RootViolationException.php | 10 +
vendor/league/flysystem/src/SafeStorage.php | 39 +
.../flysystem/src/UnreadableFileException.php | 18 +
vendor/league/flysystem/src/Util.php | 353 +
.../src/Util/ContentListingFormatter.php | 122 +
vendor/league/flysystem/src/Util/MimeType.php | 249 +
.../flysystem/src/Util/StreamHasher.php | 36 +
vendor/mockery/mockery/.gitignore | 12 +
vendor/mockery/mockery/.php_cs | 14 +
vendor/mockery/mockery/.scrutinizer.yml | 24 +
vendor/mockery/mockery/.styleci.yml | 1 +
vendor/mockery/mockery/.travis.yml | 42 +
vendor/mockery/mockery/CHANGELOG.md | 48 +
vendor/mockery/mockery/CONTRIBUTING.md | 89 +
vendor/mockery/mockery/LICENSE | 27 +
vendor/mockery/mockery/README.md | 68 +
vendor/mockery/mockery/composer.json | 35 +
vendor/mockery/mockery/docs/.gitignore | 1 +
vendor/mockery/mockery/docs/Makefile | 177 +
vendor/mockery/mockery/docs/README.md | 4 +
vendor/mockery/mockery/docs/conf.py | 259 +
.../docs/cookbook/default_expectations.rst | 17 +
.../docs/cookbook/detecting_mock_objects.rst | 13 +
.../mockery/mockery/docs/cookbook/index.rst | 11 +
.../mockery/mockery/docs/cookbook/map.rst.inc | 3 +
.../cookbook/mocking_hard_dependencies.rst | 93 +
.../mockery/docs/getting_started/index.rst | 11 +
.../docs/getting_started/installation.rst | 68 +
.../mockery/docs/getting_started/map.rst.inc | 3 +
.../docs/getting_started/simple_example.rst | 66 +
.../docs/getting_started/upgrading.rst | 26 +
vendor/mockery/mockery/docs/index.rst | 64 +
.../docs/reference/argument_validation.rst | 168 +
.../mockery/docs/reference/demeter_chains.rst | 38 +
.../mockery/docs/reference/expectations.rst | 260 +
.../docs/reference/final_methods_classes.rst | 23 +
.../mockery/mockery/docs/reference/index.rst | 20 +
.../docs/reference/instance_mocking.rst | 22 +
.../mockery/docs/reference/magic_methods.rst | 16 +
.../mockery/docs/reference/map.rst.inc | 19 +
.../docs/reference/mockery/configuration.rst | 52 +
.../docs/reference/mockery/exceptions.rst | 65 +
.../docs/reference/mockery/gotchas.rst | 42 +
.../mockery/docs/reference/mockery/index.rst | 10 +
.../mockery/reserved_method_names.rst | 20 +
.../docs/reference/object_recording.rst | 93 +
.../mockery/docs/reference/partial_mocks.rst | 94 +
.../pass_by_reference_behaviours.rst | 83 +
.../docs/reference/phpunit_integration.rst | 110 +
.../docs/reference/public_properties.rst | 16 +
.../reference/public_static_properties.rst | 12 +
.../mockery/docs/reference/quick_examples.rst | 130 +
.../docs/reference/startup_methods.rst | 230 +
.../mockery/examples/starship/Bootstrap.php | 11 +
.../mockery/examples/starship/Starship.php | 24 +
.../examples/starship/StarshipTest.php | 21 +
vendor/mockery/mockery/library/Mockery.php | 769 +
.../Phpunit/MockeryPHPUnitIntegration.php | 26 +
.../Adapter/Phpunit/MockeryTestCase.php | 30 +
.../Mockery/Adapter/Phpunit/TestListener.php | 93 +
.../library/Mockery/CompositeExpectation.php | 131 +
.../mockery/library/Mockery/Configuration.php | 131 +
.../mockery/library/Mockery/Container.php | 524 +
.../Mockery/CountValidator/AtLeast.php | 63 +
.../library/Mockery/CountValidator/AtMost.php | 52 +
.../CountValidator/CountValidatorAbstract.php | 70 +
.../library/Mockery/CountValidator/Exact.php | 52 +
.../Mockery/CountValidator/Exception.php | 25 +
.../mockery/library/Mockery/Exception.php | 25 +
.../Exception/InvalidCountException.php | 103 +
.../Exception/InvalidOrderException.php | 84 +
.../NoMatchingExpectationException.php | 71 +
.../Mockery/Exception/RuntimeException.php | 25 +
.../mockery/library/Mockery/Expectation.php | 768 +
.../library/Mockery/ExpectationDirector.php | 203 +
.../library/Mockery/ExpectationInterface.php | 39 +
.../Mockery/Generator/CachingGenerator.php | 27 +
.../Mockery/Generator/DefinedTargetClass.php | 90 +
.../library/Mockery/Generator/Generator.php | 9 +
.../library/Mockery/Generator/Method.php | 43 +
.../Mockery/Generator/MockConfiguration.php | 460 +
.../Generator/MockConfigurationBuilder.php | 124 +
.../Mockery/Generator/MockDefinition.php | 33 +
.../library/Mockery/Generator/Parameter.php | 101 +
.../Pass/CallTypeHintPass.php | 29 +
.../StringManipulation/Pass/ClassNamePass.php | 31 +
.../StringManipulation/Pass/ClassPass.php | 50 +
.../Pass/InstanceMockPass.php | 57 +
.../StringManipulation/Pass/InterfacePass.php | 23 +
.../Pass/MethodDefinitionPass.php | 155 +
.../StringManipulation/Pass/Pass.php | 10 +
.../RemoveBuiltinMethodsThatAreFinalPass.php | 35 +
...lizeForInternalSerializableClassesPass.php | 40 +
.../Generator/StringManipulationGenerator.php | 34 +
.../library/Mockery/Generator/TargetClass.php | 33 +
.../Generator/UndefinedTargetClass.php | 61 +
.../mockery/library/Mockery/Instantiator.php | 214 +
.../mockery/library/Mockery/Loader.php | 155 +
.../library/Mockery/Loader/EvalLoader.php | 18 +
.../mockery/library/Mockery/Loader/Loader.php | 10 +
.../library/Mockery/Loader/RequireLoader.php | 28 +
.../mockery/library/Mockery/Matcher/Any.php | 46 +
.../mockery/library/Mockery/Matcher/AnyOf.php | 51 +
.../library/Mockery/Matcher/Closure.php | 48 +
.../library/Mockery/Matcher/Contains.php | 65 +
.../library/Mockery/Matcher/Ducktype.php | 54 +
.../library/Mockery/Matcher/HasKey.php | 47 +
.../library/Mockery/Matcher/HasValue.php | 47 +
.../Mockery/Matcher/MatcherAbstract.php | 59 +
.../library/Mockery/Matcher/MustBe.php | 50 +
.../mockery/library/Mockery/Matcher/Not.php | 47 +
.../library/Mockery/Matcher/NotAnyOf.php | 51 +
.../library/Mockery/Matcher/Subset.php | 60 +
.../mockery/library/Mockery/Matcher/Type.php | 53 +
.../mockery/library/Mockery/MethodCall.php | 25 +
.../mockery/mockery/library/Mockery/Mock.php | 758 +
.../mockery/library/Mockery/MockInterface.php | 242 +
.../library/Mockery/ReceivedMethodCalls.php | 30 +
.../mockery/library/Mockery/Recorder.php | 103 +
.../mockery/library/Mockery/Undefined.php | 47 +
.../library/Mockery/VerificationDirector.php | 89 +
.../Mockery/VerificationExpectation.php | 17 +
vendor/mockery/mockery/library/helpers.php | 41 +
vendor/mockery/mockery/package.xml | 191 +
vendor/mockery/mockery/phpunit.xml.dist | 37 +
vendor/mockery/mockery/tests/Bootstrap.php | 85 +
.../mockery/tests/Mockery/AdhocTest.php | 90 +
.../mockery/tests/Mockery/ContainerTest.php | 1768 ++
.../tests/Mockery/DemeterChainTest.php | 170 +
.../mockery/tests/Mockery/ExpectationTest.php | 2040 ++
.../Fixtures/MethodWithNullableParameters.php | 49 +
.../Fixtures/MethodWithNullableReturnType.php | 57 +
.../tests/Mockery/Fixtures/VoidMethod.php | 27 +
.../Generator/DefinedTargetClassTest.php | 25 +
.../Generator/MockConfigurationTest.php | 197 +
.../Pass/CallTypeHintPassTest.php | 39 +
.../Pass/ClassNamePassTest.php | 58 +
.../Pass/InstanceMockPassTest.php | 24 +
.../Pass/InterfacePassTest.php | 46 +
.../tests/Mockery/GlobalHelpersTest.php | 63 +
.../tests/Mockery/HamcrestExpectationTest.php | 65 +
.../tests/Mockery/Loader/EvalLoaderTest.php | 16 +
.../tests/Mockery/Loader/LoaderTestCase.php | 27 +
.../Mockery/Loader/RequireLoaderTest.php | 16 +
.../mockery/tests/Mockery/LoaderTest.php | 45 +
.../Mockery/MockClassWithFinalWakeupTest.php | 96 +
.../MockClassWithUnknownTypeHintTest.php | 45 +
.../mockery/tests/Mockery/MockTest.php | 193 +
...MockMultipleInterfacesWhichOverlapTest.php | 66 +
...ssWithOptionalParameterByReferenceTest.php | 69 +
...ckingMethodsWithNullableParametersTest.php | 185 +
.../Mockery/MockingNullableMethodsTest.php | 184 +
.../MockingParameterAndReturnTypesTest.php | 151 +
.../Mockery/MockingProtectedMethodsTest.php | 122 +
.../Mockery/MockingVariadicArgumentsTest.php | 56 +
.../tests/Mockery/MockingVoidMethodsTest.php | 56 +
.../mockery/tests/Mockery/NamedMockTest.php | 54 +
.../mockery/tests/Mockery/RecorderTest.php | 206 +
.../mockery/mockery/tests/Mockery/SpyTest.php | 78 +
.../MockConfigurationBuilderTest.php | 43 +
.../Mockery/WithFormatterExpectationTest.php | 121 +
.../mockery/tests/Mockery/_files/file.txt | 0
.../mockery/mockery/travis/after_success.sh | 6 +
.../mockery/mockery/travis/before_script.sh | 11 +
vendor/mockery/mockery/travis/extra.ini | 3 +
vendor/mockery/mockery/travis/install.sh | 6 +
vendor/mockery/mockery/travis/script.sh | 8 +
vendor/monolog/monolog/CHANGELOG.md | 432 +
vendor/monolog/monolog/LICENSE | 19 +
vendor/monolog/monolog/README.md | 94 +
vendor/monolog/monolog/composer.json | 60 +
vendor/monolog/monolog/phpstan.neon.dist | 16 +
.../monolog/src/Monolog/ErrorHandler.php | 239 +
.../Monolog/Formatter/ChromePHPFormatter.php | 78 +
.../Monolog/Formatter/ElasticaFormatter.php | 89 +
.../Monolog/Formatter/FlowdockFormatter.php | 116 +
.../Monolog/Formatter/FluentdFormatter.php | 88 +
.../Monolog/Formatter/FormatterInterface.php | 36 +
.../Formatter/GelfMessageFormatter.php | 138 +
.../src/Monolog/Formatter/HtmlFormatter.php | 142 +
.../src/Monolog/Formatter/JsonFormatter.php | 214 +
.../src/Monolog/Formatter/LineFormatter.php | 181 +
.../src/Monolog/Formatter/LogglyFormatter.php | 47 +
.../Monolog/Formatter/LogstashFormatter.php | 166 +
.../Monolog/Formatter/MongoDBFormatter.php | 107 +
.../Monolog/Formatter/NormalizerFormatter.php | 199 +
.../src/Monolog/Formatter/ScalarFormatter.php | 48 +
.../Monolog/Formatter/WildfireFormatter.php | 113 +
.../src/Monolog/Handler/AbstractHandler.php | 196 +
.../Handler/AbstractProcessingHandler.php | 68 +
.../Monolog/Handler/AbstractSyslogHandler.php | 101 +
.../src/Monolog/Handler/AmqpHandler.php | 148 +
.../Monolog/Handler/BrowserConsoleHandler.php | 241 +
.../src/Monolog/Handler/BufferHandler.php | 148 +
.../src/Monolog/Handler/ChromePHPHandler.php | 212 +
.../src/Monolog/Handler/CouchDBHandler.php | 72 +
.../src/Monolog/Handler/CubeHandler.php | 152 +
.../monolog/src/Monolog/Handler/Curl/Util.php | 57 +
.../Monolog/Handler/DeduplicationHandler.php | 169 +
.../Handler/DoctrineCouchDBHandler.php | 45 +
.../src/Monolog/Handler/DynamoDbHandler.php | 108 +
.../Monolog/Handler/ElasticSearchHandler.php | 128 +
.../src/Monolog/Handler/ErrorLogHandler.php | 82 +
.../src/Monolog/Handler/FilterHandler.php | 172 +
.../ActivationStrategyInterface.php | 28 +
.../ChannelLevelActivationStrategy.php | 59 +
.../ErrorLevelActivationStrategy.php | 34 +
.../Monolog/Handler/FingersCrossedHandler.php | 207 +
.../src/Monolog/Handler/FirePHPHandler.php | 195 +
.../src/Monolog/Handler/FleepHookHandler.php | 126 +
.../src/Monolog/Handler/FlowdockHandler.php | 128 +
.../Handler/FormattableHandlerInterface.php | 39 +
.../Handler/FormattableHandlerTrait.php | 63 +
.../src/Monolog/Handler/GelfHandler.php | 65 +
.../src/Monolog/Handler/GroupHandler.php | 117 +
.../src/Monolog/Handler/HandlerInterface.php | 90 +
.../src/Monolog/Handler/HandlerWrapper.php | 116 +
.../src/Monolog/Handler/HipChatHandler.php | 367 +
.../src/Monolog/Handler/IFTTTHandler.php | 70 +
.../src/Monolog/Handler/InsightOpsHandler.php | 62 +
.../src/Monolog/Handler/LogEntriesHandler.php | 55 +
.../src/Monolog/Handler/LogglyHandler.php | 102 +
.../src/Monolog/Handler/MailHandler.php | 67 +
.../src/Monolog/Handler/MandrillHandler.php | 72 +
.../Handler/MissingExtensionException.php | 21 +
.../src/Monolog/Handler/MongoDBHandler.php | 59 +
.../Monolog/Handler/NativeMailerHandler.php | 185 +
.../src/Monolog/Handler/NewRelicHandler.php | 205 +
.../src/Monolog/Handler/NullHandler.php | 45 +
.../src/Monolog/Handler/PHPConsoleHandler.php | 243 +
.../Handler/ProcessableHandlerInterface.php | 40 +
.../Handler/ProcessableHandlerTrait.php | 73 +
.../src/Monolog/Handler/PsrHandler.php | 56 +
.../src/Monolog/Handler/PushoverHandler.php | 185 +
.../src/Monolog/Handler/RavenHandler.php | 234 +
.../src/Monolog/Handler/RedisHandler.php | 98 +
.../src/Monolog/Handler/RollbarHandler.php | 144 +
.../Monolog/Handler/RotatingFileHandler.php | 191 +
.../src/Monolog/Handler/SamplingHandler.php | 113 +
.../src/Monolog/Handler/Slack/SlackRecord.php | 299 +
.../src/Monolog/Handler/SlackHandler.php | 221 +
.../Monolog/Handler/SlackWebhookHandler.php | 121 +
.../src/Monolog/Handler/SlackbotHandler.php | 84 +
.../src/Monolog/Handler/SocketHandler.php | 385 +
.../src/Monolog/Handler/StreamHandler.php | 194 +
.../Monolog/Handler/SwiftMailerHandler.php | 111 +
.../src/Monolog/Handler/SyslogHandler.php | 67 +
.../Monolog/Handler/SyslogUdp/UdpSocket.php | 56 +
.../src/Monolog/Handler/SyslogUdpHandler.php | 124 +
.../src/Monolog/Handler/TestHandler.php | 177 +
.../Handler/WhatFailureGroupHandler.php | 72 +
.../Monolog/Handler/ZendMonitorHandler.php | 101 +
vendor/monolog/monolog/src/Monolog/Logger.php | 796 +
.../src/Monolog/Processor/GitProcessor.php | 64 +
.../Processor/IntrospectionProcessor.php | 112 +
.../Processor/MemoryPeakUsageProcessor.php | 35 +
.../src/Monolog/Processor/MemoryProcessor.php | 63 +
.../Processor/MemoryUsageProcessor.php | 35 +
.../Monolog/Processor/MercurialProcessor.php | 63 +
.../Monolog/Processor/ProcessIdProcessor.php | 31 +
.../Monolog/Processor/ProcessorInterface.php | 25 +
.../Processor/PsrLogMessageProcessor.php | 81 +
.../src/Monolog/Processor/TagProcessor.php | 44 +
.../src/Monolog/Processor/UidProcessor.php | 59 +
.../src/Monolog/Processor/WebProcessor.php | 113 +
.../monolog/monolog/src/Monolog/Registry.php | 134 +
.../src/Monolog/ResettableInterface.php | 31 +
.../monolog/src/Monolog/SignalHandler.php | 115 +
vendor/monolog/monolog/src/Monolog/Utils.php | 189 +
.../mtdowling/cron-expression/.editorconfig | 16 +
vendor/mtdowling/cron-expression/CHANGELOG.md | 36 +
vendor/mtdowling/cron-expression/LICENSE | 19 +
vendor/mtdowling/cron-expression/README.md | 71 +
.../mtdowling/cron-expression/composer.json | 29 +
.../src/Cron/AbstractField.php | 148 +
.../src/Cron/CronExpression.php | 389 +
.../src/Cron/DayOfMonthField.php | 173 +
.../src/Cron/DayOfWeekField.php | 141 +
.../cron-expression/src/Cron/FieldFactory.php | 57 +
.../src/Cron/FieldInterface.php | 40 +
.../cron-expression/src/Cron/HoursField.php | 71 +
.../cron-expression/src/Cron/MinutesField.php | 62 +
.../cron-expression/src/Cron/MonthField.php | 44 +
.../cron-expression/src/Cron/YearField.php | 37 +
.../tests/Cron/AbstractFieldTest.php | 86 +
.../tests/Cron/CronExpressionTest.php | 414 +
.../tests/Cron/DayOfMonthFieldTest.php | 61 +
.../tests/Cron/DayOfWeekFieldTest.php | 117 +
.../tests/Cron/FieldFactoryTest.php | 43 +
.../tests/Cron/HoursFieldTest.php | 75 +
.../tests/Cron/MinutesFieldTest.php | 37 +
.../tests/Cron/MonthFieldTest.php | 81 +
.../tests/Cron/YearFieldTest.php | 37 +
vendor/myclabs/deep-copy/.gitattributes | 7 +
vendor/myclabs/deep-copy/.gitignore | 3 +
vendor/myclabs/deep-copy/.travis.yml | 40 +
vendor/myclabs/deep-copy/LICENSE | 20 +
vendor/myclabs/deep-copy/README.md | 372 +
vendor/myclabs/deep-copy/composer.json | 35 +
vendor/myclabs/deep-copy/doc/clone.png | Bin 0 -> 12380 bytes
vendor/myclabs/deep-copy/doc/deep-clone.png | Bin 0 -> 14009 bytes
vendor/myclabs/deep-copy/doc/deep-copy.png | Bin 0 -> 10895 bytes
vendor/myclabs/deep-copy/doc/graph.png | Bin 0 -> 6436 bytes
vendor/myclabs/deep-copy/fixtures/f001/A.php | 20 +
vendor/myclabs/deep-copy/fixtures/f001/B.php | 20 +
vendor/myclabs/deep-copy/fixtures/f002/A.php | 33 +
.../myclabs/deep-copy/fixtures/f003/Foo.php | 26 +
.../fixtures/f004/UnclonableItem.php | 13 +
.../myclabs/deep-copy/fixtures/f005/Foo.php | 13 +
vendor/myclabs/deep-copy/fixtures/f006/A.php | 26 +
vendor/myclabs/deep-copy/fixtures/f006/B.php | 26 +
.../fixtures/f007/FooDateInterval.php | 15 +
.../fixtures/f007/FooDateTimeZone.php | 15 +
vendor/myclabs/deep-copy/fixtures/f008/A.php | 18 +
vendor/myclabs/deep-copy/fixtures/f008/B.php | 7 +
.../deep-copy/src/DeepCopy/DeepCopy.php | 281 +
.../src/DeepCopy/Exception/CloneException.php | 9 +
.../DeepCopy/Exception/PropertyException.php | 9 +
.../Doctrine/DoctrineCollectionFilter.php | 33 +
.../DoctrineEmptyCollectionFilter.php | 28 +
.../Filter/Doctrine/DoctrineProxyFilter.php | 22 +
.../deep-copy/src/DeepCopy/Filter/Filter.php | 18 +
.../src/DeepCopy/Filter/KeepFilter.php | 16 +
.../src/DeepCopy/Filter/ReplaceFilter.php | 39 +
.../src/DeepCopy/Filter/SetNullFilter.php | 24 +
.../Matcher/Doctrine/DoctrineProxyMatcher.php | 22 +
.../src/DeepCopy/Matcher/Matcher.php | 14 +
.../src/DeepCopy/Matcher/PropertyMatcher.php | 39 +
.../DeepCopy/Matcher/PropertyNameMatcher.php | 32 +
.../DeepCopy/Matcher/PropertyTypeMatcher.php | 46 +
.../DeepCopy/Reflection/ReflectionHelper.php | 78 +
.../TypeFilter/Date/DateIntervalFilter.php | 33 +
.../src/DeepCopy/TypeFilter/ReplaceFilter.php | 30 +
.../DeepCopy/TypeFilter/ShallowCopyFilter.php | 17 +
.../TypeFilter/Spl/SplDoublyLinkedList.php | 10 +
.../Spl/SplDoublyLinkedListFilter.php | 51 +
.../src/DeepCopy/TypeFilter/TypeFilter.php | 13 +
.../src/DeepCopy/TypeMatcher/TypeMatcher.php | 29 +
.../deep-copy/src/DeepCopy/deep_copy.php | 16 +
vendor/nesbot/carbon/LICENSE | 19 +
vendor/nesbot/carbon/bin/upgrade-carbon | 34 +
vendor/nesbot/carbon/bin/upgrade-carbon.bat | 4 +
vendor/nesbot/carbon/composer.json | 70 +
vendor/nesbot/carbon/readme.md | 94 +
vendor/nesbot/carbon/src/Carbon/Carbon.php | 5427 ++++
.../carbon/src/Carbon/CarbonInterval.php | 1163 +
.../nesbot/carbon/src/Carbon/CarbonPeriod.php | 1453 +
.../Exceptions/InvalidDateException.php | 67 +
vendor/nesbot/carbon/src/Carbon/Lang/af.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/ar.php | 31 +
.../carbon/src/Carbon/Lang/ar_Shakl.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/az.php | 40 +
vendor/nesbot/carbon/src/Carbon/Lang/bg.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/bn.php | 38 +
.../nesbot/carbon/src/Carbon/Lang/bs_BA.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/ca.php | 40 +
vendor/nesbot/carbon/src/Carbon/Lang/cs.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/cy.php | 29 +
vendor/nesbot/carbon/src/Carbon/Lang/da.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/de.php | 46 +
.../nesbot/carbon/src/Carbon/Lang/dv_MV.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/el.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/en.php | 40 +
vendor/nesbot/carbon/src/Carbon/Lang/eo.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/es.php | 36 +
vendor/nesbot/carbon/src/Carbon/Lang/et.php | 38 +
vendor/nesbot/carbon/src/Carbon/Lang/eu.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/fa.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/fi.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/fo.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/fr.php | 40 +
vendor/nesbot/carbon/src/Carbon/Lang/gl.php | 24 +
vendor/nesbot/carbon/src/Carbon/Lang/gu.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/he.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/hi.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/hr.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/hu.php | 52 +
vendor/nesbot/carbon/src/Carbon/Lang/hy.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/id.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/is.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/it.php | 36 +
vendor/nesbot/carbon/src/Carbon/Lang/ja.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/ka.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/kk.php | 29 +
vendor/nesbot/carbon/src/Carbon/Lang/km.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/ko.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/lt.php | 38 +
vendor/nesbot/carbon/src/Carbon/Lang/lv.php | 47 +
vendor/nesbot/carbon/src/Carbon/Lang/mk.php | 24 +
vendor/nesbot/carbon/src/Carbon/Lang/mn.php | 62 +
vendor/nesbot/carbon/src/Carbon/Lang/ms.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/my.php | 37 +
vendor/nesbot/carbon/src/Carbon/Lang/ne.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/nl.php | 36 +
vendor/nesbot/carbon/src/Carbon/Lang/no.php | 36 +
vendor/nesbot/carbon/src/Carbon/Lang/oc.php | 44 +
vendor/nesbot/carbon/src/Carbon/Lang/pl.php | 36 +
vendor/nesbot/carbon/src/Carbon/Lang/ps.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/pt.php | 31 +
.../nesbot/carbon/src/Carbon/Lang/pt_BR.php | 40 +
vendor/nesbot/carbon/src/Carbon/Lang/ro.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/ru.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/sh.php | 35 +
vendor/nesbot/carbon/src/Carbon/Lang/sk.php | 38 +
vendor/nesbot/carbon/src/Carbon/Lang/sl.php | 43 +
vendor/nesbot/carbon/src/Carbon/Lang/sq.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/sr.php | 37 +
.../nesbot/carbon/src/Carbon/Lang/sr_Cyrl.php | 43 +
.../carbon/src/Carbon/Lang/sr_Cyrl_ME.php | 43 +
.../carbon/src/Carbon/Lang/sr_Latn_ME.php | 43 +
.../nesbot/carbon/src/Carbon/Lang/sr_ME.php | 12 +
vendor/nesbot/carbon/src/Carbon/Lang/sv.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/sw.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/th.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/tr.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/uk.php | 40 +
vendor/nesbot/carbon/src/Carbon/Lang/ur.php | 24 +
vendor/nesbot/carbon/src/Carbon/Lang/uz.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/vi.php | 31 +
vendor/nesbot/carbon/src/Carbon/Lang/zh.php | 31 +
.../nesbot/carbon/src/Carbon/Lang/zh_TW.php | 31 +
.../src/Carbon/Laravel/ServiceProvider.php | 37 +
.../nesbot/carbon/src/Carbon/Translator.php | 143 +
vendor/nesbot/carbon/src/Carbon/Upgrade.php | 150 +
vendor/nesbot/carbon/src/JsonSerializable.php | 18 +
vendor/nikic/php-parser/.gitignore | 4 +
vendor/nikic/php-parser/.travis.yml | 31 +
vendor/nikic/php-parser/CHANGELOG.md | 422 +
vendor/nikic/php-parser/LICENSE | 31 +
vendor/nikic/php-parser/README.md | 99 +
vendor/nikic/php-parser/UPGRADE-1.0.md | 121 +
vendor/nikic/php-parser/UPGRADE-2.0.md | 74 +
vendor/nikic/php-parser/UPGRADE-3.0.md | 160 +
vendor/nikic/php-parser/bin/php-parse | 202 +
vendor/nikic/php-parser/composer.json | 30 +
.../php-parser/doc/0_Introduction.markdown | 80 +
.../doc/2_Usage_of_basic_components.markdown | 438 +
...3_Other_node_tree_representations.markdown | 330 +
.../php-parser/doc/4_Code_generation.markdown | 84 +
.../doc/component/Error_handling.markdown | 75 +
.../php-parser/doc/component/Lexer.markdown | 152 +
vendor/nikic/php-parser/grammar/README.md | 28 +
.../nikic/php-parser/grammar/parser.template | 103 +
vendor/nikic/php-parser/grammar/php5.y | 1009 +
vendor/nikic/php-parser/grammar/php7.y | 965 +
.../php-parser/grammar/rebuildParsers.php | 263 +
.../nikic/php-parser/grammar/tokens.template | 17 +
vendor/nikic/php-parser/grammar/tokens.y | 113 +
.../php-parser/lib/PhpParser/Autoloader.php | 40 +
.../php-parser/lib/PhpParser/Builder.php | 13 +
.../lib/PhpParser/Builder/Class_.php | 121 +
.../lib/PhpParser/Builder/Declaration.php | 42 +
.../lib/PhpParser/Builder/FunctionLike.php | 75 +
.../lib/PhpParser/Builder/Function_.php | 49 +
.../lib/PhpParser/Builder/Interface_.php | 80 +
.../lib/PhpParser/Builder/Method.php | 128 +
.../lib/PhpParser/Builder/Namespace_.php | 44 +
.../lib/PhpParser/Builder/Param.php | 91 +
.../lib/PhpParser/Builder/Property.php | 111 +
.../lib/PhpParser/Builder/Trait_.php | 59 +
.../php-parser/lib/PhpParser/Builder/Use_.php | 58 +
.../lib/PhpParser/BuilderAbstract.php | 175 +
.../lib/PhpParser/BuilderFactory.php | 127 +
.../php-parser/lib/PhpParser/Comment.php | 140 +
.../php-parser/lib/PhpParser/Comment/Doc.php | 7 +
.../nikic/php-parser/lib/PhpParser/Error.php | 166 +
.../php-parser/lib/PhpParser/ErrorHandler.php | 13 +
.../lib/PhpParser/ErrorHandler/Collecting.php | 46 +
.../lib/PhpParser/ErrorHandler/Throwing.php | 18 +
.../nikic/php-parser/lib/PhpParser/Lexer.php | 381 +
.../lib/PhpParser/Lexer/Emulative.php | 174 +
.../nikic/php-parser/lib/PhpParser/Node.php | 88 +
.../php-parser/lib/PhpParser/Node/Arg.php | 34 +
.../php-parser/lib/PhpParser/Node/Const_.php | 30 +
.../php-parser/lib/PhpParser/Node/Expr.php | 9 +
.../lib/PhpParser/Node/Expr/ArrayDimFetch.php | 30 +
.../lib/PhpParser/Node/Expr/ArrayItem.php | 34 +
.../lib/PhpParser/Node/Expr/Array_.php | 30 +
.../lib/PhpParser/Node/Expr/Assign.php | 30 +
.../lib/PhpParser/Node/Expr/AssignOp.php | 30 +
.../Node/Expr/AssignOp/BitwiseAnd.php | 9 +
.../Node/Expr/AssignOp/BitwiseOr.php | 9 +
.../Node/Expr/AssignOp/BitwiseXor.php | 9 +
.../PhpParser/Node/Expr/AssignOp/Concat.php | 9 +
.../lib/PhpParser/Node/Expr/AssignOp/Div.php | 9 +
.../PhpParser/Node/Expr/AssignOp/Minus.php | 9 +
.../lib/PhpParser/Node/Expr/AssignOp/Mod.php | 9 +
.../lib/PhpParser/Node/Expr/AssignOp/Mul.php | 9 +
.../lib/PhpParser/Node/Expr/AssignOp/Plus.php | 9 +
.../lib/PhpParser/Node/Expr/AssignOp/Pow.php | 9 +
.../Node/Expr/AssignOp/ShiftLeft.php | 9 +
.../Node/Expr/AssignOp/ShiftRight.php | 9 +
.../lib/PhpParser/Node/Expr/AssignRef.php | 30 +
.../lib/PhpParser/Node/Expr/BinaryOp.php | 30 +
.../Node/Expr/BinaryOp/BitwiseAnd.php | 9 +
.../Node/Expr/BinaryOp/BitwiseOr.php | 9 +
.../Node/Expr/BinaryOp/BitwiseXor.php | 9 +
.../Node/Expr/BinaryOp/BooleanAnd.php | 9 +
.../Node/Expr/BinaryOp/BooleanOr.php | 9 +
.../PhpParser/Node/Expr/BinaryOp/Coalesce.php | 9 +
.../PhpParser/Node/Expr/BinaryOp/Concat.php | 9 +
.../lib/PhpParser/Node/Expr/BinaryOp/Div.php | 9 +
.../PhpParser/Node/Expr/BinaryOp/Equal.php | 9 +
.../PhpParser/Node/Expr/BinaryOp/Greater.php | 9 +
.../Node/Expr/BinaryOp/GreaterOrEqual.php | 9 +
.../Node/Expr/BinaryOp/Identical.php | 9 +
.../Node/Expr/BinaryOp/LogicalAnd.php | 9 +
.../Node/Expr/BinaryOp/LogicalOr.php | 9 +
.../Node/Expr/BinaryOp/LogicalXor.php | 9 +
.../PhpParser/Node/Expr/BinaryOp/Minus.php | 9 +
.../lib/PhpParser/Node/Expr/BinaryOp/Mod.php | 9 +
.../lib/PhpParser/Node/Expr/BinaryOp/Mul.php | 9 +
.../PhpParser/Node/Expr/BinaryOp/NotEqual.php | 9 +
.../Node/Expr/BinaryOp/NotIdentical.php | 9 +
.../lib/PhpParser/Node/Expr/BinaryOp/Plus.php | 9 +
.../lib/PhpParser/Node/Expr/BinaryOp/Pow.php | 9 +
.../Node/Expr/BinaryOp/ShiftLeft.php | 9 +
.../Node/Expr/BinaryOp/ShiftRight.php | 9 +
.../PhpParser/Node/Expr/BinaryOp/Smaller.php | 9 +
.../Node/Expr/BinaryOp/SmallerOrEqual.php | 9 +
.../Node/Expr/BinaryOp/Spaceship.php | 9 +
.../lib/PhpParser/Node/Expr/BitwiseNot.php | 26 +
.../lib/PhpParser/Node/Expr/BooleanNot.php | 26 +
.../lib/PhpParser/Node/Expr/Cast.php | 26 +
.../lib/PhpParser/Node/Expr/Cast/Array_.php | 9 +
.../lib/PhpParser/Node/Expr/Cast/Bool_.php | 9 +
.../lib/PhpParser/Node/Expr/Cast/Double.php | 9 +
.../lib/PhpParser/Node/Expr/Cast/Int_.php | 9 +
.../lib/PhpParser/Node/Expr/Cast/Object_.php | 9 +
.../lib/PhpParser/Node/Expr/Cast/String_.php | 9 +
.../lib/PhpParser/Node/Expr/Cast/Unset_.php | 9 +
.../PhpParser/Node/Expr/ClassConstFetch.php | 31 +
.../lib/PhpParser/Node/Expr/Clone_.php | 26 +
.../lib/PhpParser/Node/Expr/Closure.php | 65 +
.../lib/PhpParser/Node/Expr/ClosureUse.php | 30 +
.../lib/PhpParser/Node/Expr/ConstFetch.php | 27 +
.../lib/PhpParser/Node/Expr/Empty_.php | 26 +
.../lib/PhpParser/Node/Expr/Error.php | 27 +
.../lib/PhpParser/Node/Expr/ErrorSuppress.php | 26 +
.../lib/PhpParser/Node/Expr/Eval_.php | 26 +
.../lib/PhpParser/Node/Expr/Exit_.php | 30 +
.../lib/PhpParser/Node/Expr/FuncCall.php | 31 +
.../lib/PhpParser/Node/Expr/Include_.php | 35 +
.../lib/PhpParser/Node/Expr/Instanceof_.php | 31 +
.../lib/PhpParser/Node/Expr/Isset_.php | 26 +
.../lib/PhpParser/Node/Expr/List_.php | 26 +
.../lib/PhpParser/Node/Expr/MethodCall.php | 35 +
.../lib/PhpParser/Node/Expr/New_.php | 31 +
.../lib/PhpParser/Node/Expr/PostDec.php | 26 +
.../lib/PhpParser/Node/Expr/PostInc.php | 26 +
.../lib/PhpParser/Node/Expr/PreDec.php | 26 +
.../lib/PhpParser/Node/Expr/PreInc.php | 26 +
.../lib/PhpParser/Node/Expr/Print_.php | 26 +
.../lib/PhpParser/Node/Expr/PropertyFetch.php | 30 +
.../lib/PhpParser/Node/Expr/ShellExec.php | 26 +
.../lib/PhpParser/Node/Expr/StaticCall.php | 35 +
.../Node/Expr/StaticPropertyFetch.php | 31 +
.../lib/PhpParser/Node/Expr/Ternary.php | 34 +
.../lib/PhpParser/Node/Expr/UnaryMinus.php | 26 +
.../lib/PhpParser/Node/Expr/UnaryPlus.php | 26 +
.../lib/PhpParser/Node/Expr/Variable.php | 26 +
.../lib/PhpParser/Node/Expr/YieldFrom.php | 26 +
.../lib/PhpParser/Node/Expr/Yield_.php | 30 +
.../lib/PhpParser/Node/FunctionLike.php | 36 +
.../php-parser/lib/PhpParser/Node/Name.php | 196 +
.../PhpParser/Node/Name/FullyQualified.php | 42 +
.../lib/PhpParser/Node/Name/Relative.php | 42 +
.../lib/PhpParser/Node/NullableType.php | 26 +
.../php-parser/lib/PhpParser/Node/Param.php | 42 +
.../php-parser/lib/PhpParser/Node/Scalar.php | 7 +
.../lib/PhpParser/Node/Scalar/DNumber.php | 64 +
.../lib/PhpParser/Node/Scalar/Encapsed.php | 27 +
.../Node/Scalar/EncapsedStringPart.php | 26 +
.../lib/PhpParser/Node/Scalar/LNumber.php | 67 +
.../lib/PhpParser/Node/Scalar/MagicConst.php | 28 +
.../Node/Scalar/MagicConst/Class_.php | 12 +
.../PhpParser/Node/Scalar/MagicConst/Dir.php | 12 +
.../PhpParser/Node/Scalar/MagicConst/File.php | 12 +
.../Node/Scalar/MagicConst/Function_.php | 12 +
.../PhpParser/Node/Scalar/MagicConst/Line.php | 12 +
.../Node/Scalar/MagicConst/Method.php | 12 +
.../Node/Scalar/MagicConst/Namespace_.php | 12 +
.../Node/Scalar/MagicConst/Trait_.php | 12 +
.../lib/PhpParser/Node/Scalar/String_.php | 153 +
.../php-parser/lib/PhpParser/Node/Stmt.php | 9 +
.../lib/PhpParser/Node/Stmt/Break_.php | 26 +
.../lib/PhpParser/Node/Stmt/Case_.php | 30 +
.../lib/PhpParser/Node/Stmt/Catch_.php | 34 +
.../lib/PhpParser/Node/Stmt/ClassConst.php | 47 +
.../lib/PhpParser/Node/Stmt/ClassLike.php | 44 +
.../lib/PhpParser/Node/Stmt/ClassMethod.php | 94 +
.../lib/PhpParser/Node/Stmt/Class_.php | 99 +
.../lib/PhpParser/Node/Stmt/Const_.php | 26 +
.../lib/PhpParser/Node/Stmt/Continue_.php | 26 +
.../PhpParser/Node/Stmt/DeclareDeclare.php | 30 +
.../lib/PhpParser/Node/Stmt/Declare_.php | 30 +
.../lib/PhpParser/Node/Stmt/Do_.php | 30 +
.../lib/PhpParser/Node/Stmt/Echo_.php | 26 +
.../lib/PhpParser/Node/Stmt/ElseIf_.php | 30 +
.../lib/PhpParser/Node/Stmt/Else_.php | 26 +
.../lib/PhpParser/Node/Stmt/Finally_.php | 26 +
.../lib/PhpParser/Node/Stmt/For_.php | 39 +
.../lib/PhpParser/Node/Stmt/Foreach_.php | 43 +
.../lib/PhpParser/Node/Stmt/Function_.php | 60 +
.../lib/PhpParser/Node/Stmt/Global_.php | 26 +
.../lib/PhpParser/Node/Stmt/Goto_.php | 26 +
.../lib/PhpParser/Node/Stmt/GroupUse.php | 35 +
.../lib/PhpParser/Node/Stmt/HaltCompiler.php | 26 +
.../lib/PhpParser/Node/Stmt/If_.php | 39 +
.../lib/PhpParser/Node/Stmt/InlineHTML.php | 26 +
.../lib/PhpParser/Node/Stmt/Interface_.php | 31 +
.../lib/PhpParser/Node/Stmt/Label.php | 26 +
.../lib/PhpParser/Node/Stmt/Namespace_.php | 34 +
.../lib/PhpParser/Node/Stmt/Nop.php | 13 +
.../lib/PhpParser/Node/Stmt/Property.php | 51 +
.../PhpParser/Node/Stmt/PropertyProperty.php | 30 +
.../lib/PhpParser/Node/Stmt/Return_.php | 26 +
.../lib/PhpParser/Node/Stmt/StaticVar.php | 30 +
.../lib/PhpParser/Node/Stmt/Static_.php | 26 +
.../lib/PhpParser/Node/Stmt/Switch_.php | 30 +
.../lib/PhpParser/Node/Stmt/Throw_.php | 26 +
.../lib/PhpParser/Node/Stmt/TraitUse.php | 31 +
.../Node/Stmt/TraitUseAdaptation.php | 13 +
.../Node/Stmt/TraitUseAdaptation/Alias.php | 34 +
.../Stmt/TraitUseAdaptation/Precedence.php | 30 +
.../lib/PhpParser/Node/Stmt/Trait_.php | 26 +
.../lib/PhpParser/Node/Stmt/TryCatch.php | 34 +
.../lib/PhpParser/Node/Stmt/Unset_.php | 26 +
.../lib/PhpParser/Node/Stmt/UseUse.php | 38 +
.../lib/PhpParser/Node/Stmt/Use_.php | 43 +
.../lib/PhpParser/Node/Stmt/While_.php | 30 +
.../php-parser/lib/PhpParser/NodeAbstract.php | 120 +
.../php-parser/lib/PhpParser/NodeDumper.php | 196 +
.../lib/PhpParser/NodeTraverser.php | 204 +
.../lib/PhpParser/NodeTraverserInterface.php | 30 +
.../php-parser/lib/PhpParser/NodeVisitor.php | 72 +
.../PhpParser/NodeVisitor/NameResolver.php | 272 +
.../lib/PhpParser/NodeVisitorAbstract.php | 14 +
.../nikic/php-parser/lib/PhpParser/Parser.php | 17 +
.../lib/PhpParser/Parser/Multiple.php | 54 +
.../php-parser/lib/PhpParser/Parser/Php5.php | 3153 ++
.../php-parser/lib/PhpParser/Parser/Php7.php | 2872 ++
.../lib/PhpParser/Parser/Tokens.php | 144 +
.../lib/PhpParser/ParserAbstract.php | 729 +
.../lib/PhpParser/ParserFactory.php | 43 +
.../lib/PhpParser/PrettyPrinter/Standard.php | 977 +
.../lib/PhpParser/PrettyPrinterAbstract.php | 348 +
.../php-parser/lib/PhpParser/Serializer.php | 18 +
.../lib/PhpParser/Serializer/XML.php | 89 +
.../php-parser/lib/PhpParser/Unserializer.php | 18 +
.../lib/PhpParser/Unserializer/XML.php | 155 +
vendor/nikic/php-parser/lib/bootstrap.php | 6 +
vendor/nikic/php-parser/phpunit.xml.dist | 24 +
.../test/PhpParser/AutoloaderTest.php | 15 +
.../test/PhpParser/Builder/ClassTest.php | 161 +
.../test/PhpParser/Builder/FunctionTest.php | 106 +
.../test/PhpParser/Builder/InterfaceTest.php | 105 +
.../test/PhpParser/Builder/MethodTest.php | 163 +
.../test/PhpParser/Builder/NamespaceTest.php | 46 +
.../test/PhpParser/Builder/ParamTest.php | 171 +
.../test/PhpParser/Builder/PropertyTest.php | 147 +
.../test/PhpParser/Builder/TraitTest.php | 48 +
.../test/PhpParser/Builder/UseTest.php | 35 +
.../test/PhpParser/BuilderFactoryTest.php | 108 +
.../test/PhpParser/CodeParsingTest.php | 70 +
.../test/PhpParser/CodeTestAbstract.php | 61 +
.../php-parser/test/PhpParser/CommentTest.php | 73 +
.../PhpParser/ErrorHandler/CollectingTest.php | 22 +
.../PhpParser/ErrorHandler/ThrowingTest.php | 16 +
.../php-parser/test/PhpParser/ErrorTest.php | 106 +
.../test/PhpParser/Lexer/EmulativeTest.php | 133 +
.../php-parser/test/PhpParser/LexerTest.php | 265 +
.../test/PhpParser/Node/NameTest.php | 134 +
.../PhpParser/Node/Scalar/MagicConstTest.php | 25 +
.../test/PhpParser/Node/Scalar/StringTest.php | 61 +
.../PhpParser/Node/Stmt/ClassConstTest.php | 35 +
.../PhpParser/Node/Stmt/ClassMethodTest.php | 63 +
.../test/PhpParser/Node/Stmt/ClassTest.php | 66 +
.../PhpParser/Node/Stmt/InterfaceTest.php | 26 +
.../test/PhpParser/Node/Stmt/PropertyTest.php | 44 +
.../test/PhpParser/NodeAbstractTest.php | 274 +
.../test/PhpParser/NodeDumperTest.php | 105 +
.../test/PhpParser/NodeTraverserTest.php | 267 +
.../NodeVisitor/NameResolverTest.php | 468 +
.../test/PhpParser/Parser/MultipleTest.php | 94 +
.../test/PhpParser/Parser/Php5Test.php | 14 +
.../test/PhpParser/Parser/Php7Test.php | 14 +
.../test/PhpParser/ParserFactoryTest.php | 34 +
.../php-parser/test/PhpParser/ParserTest.php | 184 +
.../test/PhpParser/PrettyPrinterTest.php | 207 +
.../test/PhpParser/Serializer/XMLTest.php | 172 +
.../test/PhpParser/Unserializer/XMLTest.php | 150 +
vendor/nikic/php-parser/test/bootstrap.php | 20 +
.../test/code/parser/blockComments.test | 31 +
.../php-parser/test/code/parser/comments.test | 100 +
.../code/parser/errorHandling/eofError.test | 32 +
.../parser/errorHandling/lexerErrors.test | 124 +
.../code/parser/errorHandling/recovery.test | 866 +
.../test/code/parser/expr/arrayDef.test | 142 +
.../code/parser/expr/arrayDestructuring.test | 144 +
.../test/code/parser/expr/assign.test | 301 +
.../test/code/parser/expr/assignNewByRef.test | 39 +
.../test/code/parser/expr/cast.test | 72 +
.../test/code/parser/expr/clone.test | 13 +
.../test/code/parser/expr/closure.test | 142 +
.../test/code/parser/expr/comparison.test | 107 +
.../test/code/parser/expr/constant_expr.test | 621 +
.../test/code/parser/expr/errorSuppress.test | 12 +
.../test/code/parser/expr/exit.test | 34 +
.../code/parser/expr/fetchAndCall/args.test | 99 +
.../parser/expr/fetchAndCall/constFetch.test | 33 +
.../expr/fetchAndCall/constantDeref.test | 231 +
.../parser/expr/fetchAndCall/funcCall.test | 132 +
.../parser/expr/fetchAndCall/newDeref.test | 70 +
.../expr/fetchAndCall/objectAccess.test | 145 +
.../expr/fetchAndCall/simpleArrayAccess.test | 62 +
.../parser/expr/fetchAndCall/staticCall.test | 173 +
.../fetchAndCall/staticPropertyFetch.test | 91 +
.../test/code/parser/expr/includeAndEval.test | 40 +
.../test/code/parser/expr/issetAndEmpty.test | 75 +
.../test/code/parser/expr/listWithKeys.test | 75 +
.../test/code/parser/expr/logic.test | 159 +
.../test/code/parser/expr/math.test | 256 +
.../php-parser/test/code/parser/expr/new.test | 146 +
.../code/parser/expr/newWithoutClass.test | 23 +
.../test/code/parser/expr/print.test | 12 +
.../test/code/parser/expr/shellExec.test | 46 +
.../code/parser/expr/ternaryAndCoalesce.test | 149 +
.../expr/uvs/globalNonSimpleVarError.test | 25 +
.../code/parser/expr/uvs/indirectCall.test | 481 +
.../test/code/parser/expr/uvs/isset.test | 74 +
.../test/code/parser/expr/uvs/misc.test | 109 +
.../test/code/parser/expr/uvs/new.test | 95 +
.../code/parser/expr/uvs/staticProperty.test | 93 +
.../test/code/parser/expr/variable.test | 55 +
.../code/parser/scalar/constantString.test | 60 +
.../test/code/parser/scalar/docString.test | 90 +
.../code/parser/scalar/docStringNewlines.test | 61 +
.../parser/scalar/encapsedNegVarOffset.test | 72 +
.../code/parser/scalar/encapsedString.test | 294 +
.../test/code/parser/scalar/float.test | 74 +
.../test/code/parser/scalar/int.test | 43 +
.../test/code/parser/scalar/invalidOctal.test | 22 +
.../test/code/parser/scalar/magicConst.test | 31 +
.../code/parser/scalar/unicodeEscape.test | 20 +
.../test/code/parser/semiReserved.test | 382 +
.../code/parser/stmt/blocklessStatement.test | 112 +
.../test/code/parser/stmt/class/abstract.test | 39 +
.../code/parser/stmt/class/anonymous.test | 195 +
.../code/parser/stmt/class/conditional.test | 33 +
.../stmt/class/constModifierErrors.test | 121 +
.../parser/stmt/class/constModifiers.test | 67 +
.../test/code/parser/stmt/class/final.test | 17 +
.../parser/stmt/class/implicitPublic.test | 92 +
.../code/parser/stmt/class/interface.test | 36 +
.../test/code/parser/stmt/class/modifier.test | 215 +
.../test/code/parser/stmt/class/name.test | 240 +
.../code/parser/stmt/class/php4Style.test | 50 +
.../test/code/parser/stmt/class/simple.test | 156 +
.../code/parser/stmt/class/staticMethod.test | 151 +
.../test/code/parser/stmt/class/trait.test | 160 +
.../test/code/parser/stmt/const.test | 40 +
.../test/code/parser/stmt/controlFlow.test | 55 +
.../test/code/parser/stmt/declare.test | 60 +
.../test/code/parser/stmt/echo.test | 32 +
.../function/builtinTypeDeclarations.test | 59 +
.../test/code/parser/stmt/function/byRef.test | 41 +
.../parser/stmt/function/conditional.test | 33 +
.../parser/stmt/function/defaultValues.test | 148 +
.../parser/stmt/function/nullableTypes.test | 47 +
.../parser/stmt/function/returnTypes.test | 52 +
.../parser/stmt/function/specialVars.test | 51 +
.../stmt/function/typeDeclarations.test | 49 +
.../code/parser/stmt/function/variadic.test | 110 +
.../stmt/function/variadicDefaultValue.test | 27 +
.../code/parser/stmt/generator/basic.test | 280 +
.../stmt/generator/yieldPrecedence.test | 230 +
.../stmt/generator/yieldUnaryPrecedence.test | 48 +
.../test/code/parser/stmt/haltCompiler.test | 55 +
.../stmt/haltCompilerInvalidSyntax.test | 6 +
.../code/parser/stmt/haltCompilerOffset.test | 34 +
.../stmt/haltCompilerOutermostScope.test | 8 +
.../test/code/parser/stmt/hashbang.test | 26 +
.../php-parser/test/code/parser/stmt/if.test | 103 +
.../test/code/parser/stmt/inlineHTML.test | 27 +
.../test/code/parser/stmt/loop/do.test | 17 +
.../test/code/parser/stmt/loop/for.test | 110 +
.../test/code/parser/stmt/loop/foreach.test | 164 +
.../test/code/parser/stmt/loop/while.test | 25 +
.../test/code/parser/stmt/multiCatch.test | 65 +
.../code/parser/stmt/namespace/alias.test | 168 +
.../code/parser/stmt/namespace/braced.test | 42 +
.../stmt/namespace/commentAfterNamespace.test | 22 +
.../code/parser/stmt/namespace/groupUse.test | 188 +
.../parser/stmt/namespace/groupUseErrors.test | 107 +
.../stmt/namespace/groupUsePositions.test | 28 +
.../stmt/namespace/groupUseTrailingComma.test | 47 +
.../parser/stmt/namespace/invalidName.test | 83 +
.../test/code/parser/stmt/namespace/mix.test | 103 +
.../test/code/parser/stmt/namespace/name.test | 42 +
.../code/parser/stmt/namespace/nested.test | 30 +
.../code/parser/stmt/namespace/notBraced.test | 45 +
.../stmt/namespace/nsAfterHashbang.test | 22 +
.../parser/stmt/namespace/outsideStmt.test | 58 +
.../stmt/namespace/outsideStmtInvalid.test | 105 +
.../test/code/parser/stmt/switch.test | 81 +
.../test/code/parser/stmt/tryCatch.test | 130 +
.../code/parser/stmt/tryWithoutCatch.test | 27 +
.../test/code/parser/stmt/unset.test | 26 +
.../test/code/prettyPrinter/comments.test | 67 +
.../prettyPrinter/commentsInCommaList.test | 53 +
.../prettyPrinter/expr/anonymousClass.test | 27 +
.../expr/arrayDestructuring.test | 14 +
.../test/code/prettyPrinter/expr/call.test | 13 +
.../test/code/prettyPrinter/expr/closure.test | 18 +
.../prettyPrinter/expr/constant_deref.test | 13 +
.../code/prettyPrinter/expr/docStrings.test | 86 +
.../test/code/prettyPrinter/expr/include.test | 7 +
.../code/prettyPrinter/expr/intrinsics.test | 29 +
.../test/code/prettyPrinter/expr/list.test | 19 +
.../code/prettyPrinter/expr/literals.test | 154 +
.../test/code/prettyPrinter/expr/numbers.test | 35 +
.../code/prettyPrinter/expr/operators.test | 144 +
.../code/prettyPrinter/expr/parentheses.test | 86 +
.../prettyPrinter/expr/shortArraySyntax.test | 11 +
.../prettyPrinter/expr/stringEscaping.test | 23 +
.../test/code/prettyPrinter/expr/uvs.test | 23 +
.../code/prettyPrinter/expr/variables.test | 73 +
.../test/code/prettyPrinter/expr/yield.test | 46 +
.../inlineHTMLandPHPtest.file-test | 58 +
.../prettyPrinter/onlyInlineHTML.file-test | 19 +
.../test/code/prettyPrinter/onlyPHP.file-test | 16 +
.../test/code/prettyPrinter/stmt/alias.test | 20 +
.../prettyPrinter/stmt/break_continue.test | 13 +
.../test/code/prettyPrinter/stmt/class.test | 53 +
.../code/prettyPrinter/stmt/class_const.test | 20 +
.../test/code/prettyPrinter/stmt/const.test | 11 +
.../test/code/prettyPrinter/stmt/declare.test | 17 +
.../code/prettyPrinter/stmt/do_while.test | 10 +
.../test/code/prettyPrinter/stmt/for.test | 28 +
.../test/code/prettyPrinter/stmt/foreach.test | 28 +
.../stmt/function_signatures.test | 43 +
.../stmt/global_static_variables.test | 11 +
.../test/code/prettyPrinter/stmt/goto.test | 9 +
.../code/prettyPrinter/stmt/groupUse.test | 16 +
.../prettyPrinter/stmt/haltCompiler.file-test | 27 +
.../test/code/prettyPrinter/stmt/if.test | 16 +
.../code/prettyPrinter/stmt/multiCatch.test | 19 +
.../code/prettyPrinter/stmt/namespaces.test | 50 +
.../prettyPrinter/stmt/nullable_types.test | 11 +
.../test/code/prettyPrinter/stmt/switch.test | 37 +
.../test/code/prettyPrinter/stmt/throw.test | 7 +
.../code/prettyPrinter/stmt/traitUse.test | 25 +
.../code/prettyPrinter/stmt/tryCatch.test | 24 +
.../test/code/prettyPrinter/stmt/while.test | 10 +
.../nikic/php-parser/test_old/run-php-src.sh | 4 +
vendor/nikic/php-parser/test_old/run.php | 220 +
vendor/paragonie/random_compat/LICENSE | 22 +
vendor/paragonie/random_compat/composer.json | 38 +
.../dist/random_compat.phar.pubkey | 5 +
.../dist/random_compat.phar.pubkey.asc | 11 +
.../random_compat/lib/byte_safe_strings.php | 195 +
.../random_compat/lib/cast_to_int.php | 77 +
.../random_compat/lib/error_polyfill.php | 49 +
vendor/paragonie/random_compat/lib/random.php | 226 +
.../lib/random_bytes_com_dotnet.php | 91 +
.../lib/random_bytes_dev_urandom.php | 190 +
.../lib/random_bytes_libsodium.php | 91 +
.../lib/random_bytes_libsodium_legacy.php | 93 +
.../random_compat/lib/random_bytes_mcrypt.php | 79 +
.../random_compat/lib/random_int.php | 204 +
.../reflection-common/.travis.yml | 35 +
.../phpdocumentor/reflection-common/LICENSE | 22 +
.../phpdocumentor/reflection-common/README.md | 2 +
.../reflection-common/composer.json | 29 +
.../reflection-common/src/Element.php | 32 +
.../reflection-common/src/File.php | 40 +
.../reflection-common/src/Fqsen.php | 82 +
.../reflection-common/src/Location.php | 57 +
.../reflection-common/src/Project.php | 25 +
.../reflection-common/src/ProjectFactory.php | 27 +
.../phpdocumentor/reflection-docblock/LICENSE | 21 +
.../reflection-docblock/README.md | 69 +
.../reflection-docblock/composer.json | 28 +
.../reflection-docblock/src/DocBlock.php | 220 +
.../src/DocBlock/Description.php | 113 +
.../src/DocBlock/DescriptionFactory.php | 192 +
.../src/DocBlock/ExampleFinder.php | 170 +
.../src/DocBlock/Serializer.php | 148 +
.../src/DocBlock/StandardTagFactory.php | 320 +
.../reflection-docblock/src/DocBlock/Tag.php | 26 +
.../src/DocBlock/TagFactory.php | 93 +
.../src/DocBlock/Tags/Author.php | 100 +
.../src/DocBlock/Tags/BaseTag.php | 52 +
.../src/DocBlock/Tags/Covers.php | 84 +
.../src/DocBlock/Tags/Deprecated.php | 97 +
.../src/DocBlock/Tags/Example.php | 176 +
.../DocBlock/Tags/Factory/StaticMethod.php | 18 +
.../src/DocBlock/Tags/Factory/Strategy.php | 18 +
.../src/DocBlock/Tags/Formatter.php | 27 +
.../Tags/Formatter/AlignFormatter.php | 47 +
.../Tags/Formatter/PassthroughFormatter.php | 31 +
.../src/DocBlock/Tags/Generic.php | 91 +
.../src/DocBlock/Tags/Link.php | 77 +
.../src/DocBlock/Tags/Method.php | 239 +
.../src/DocBlock/Tags/Param.php | 141 +
.../src/DocBlock/Tags/Property.php | 118 +
.../src/DocBlock/Tags/PropertyRead.php | 118 +
.../src/DocBlock/Tags/PropertyWrite.php | 118 +
.../src/DocBlock/Tags/Reference/Fqsen.php | 42 +
.../src/DocBlock/Tags/Reference/Reference.php | 21 +
.../src/DocBlock/Tags/Reference/Url.php | 40 +
.../src/DocBlock/Tags/Return_.php | 73 +
.../src/DocBlock/Tags/See.php | 89 +
.../src/DocBlock/Tags/Since.php | 94 +
.../src/DocBlock/Tags/Source.php | 96 +
.../src/DocBlock/Tags/Throws.php | 72 +
.../src/DocBlock/Tags/Uses.php | 83 +
.../src/DocBlock/Tags/Var_.php | 118 +
.../src/DocBlock/Tags/Version.php | 94 +
.../src/DocBlockFactory.php | 277 +
.../src/DocBlockFactoryInterface.php | 23 +
vendor/phpdocumentor/type-resolver/LICENSE | 21 +
vendor/phpdocumentor/type-resolver/README.md | 182 +
.../phpdocumentor/type-resolver/composer.json | 27 +
.../type-resolver/src/FqsenResolver.php | 77 +
.../phpdocumentor/type-resolver/src/Type.php | 18 +
.../type-resolver/src/TypeResolver.php | 298 +
.../type-resolver/src/Types/Array_.php | 86 +
.../type-resolver/src/Types/Boolean.php | 31 +
.../type-resolver/src/Types/Callable_.php | 31 +
.../type-resolver/src/Types/Compound.php | 93 +
.../type-resolver/src/Types/Context.php | 84 +
.../src/Types/ContextFactory.php | 210 +
.../type-resolver/src/Types/Float_.php | 31 +
.../type-resolver/src/Types/Integer.php | 28 +
.../type-resolver/src/Types/Iterable_.php | 31 +
.../type-resolver/src/Types/Mixed_.php | 31 +
.../type-resolver/src/Types/Null_.php | 31 +
.../type-resolver/src/Types/Nullable.php | 56 +
.../type-resolver/src/Types/Object_.php | 71 +
.../type-resolver/src/Types/Parent_.php | 33 +
.../type-resolver/src/Types/Resource_.php | 31 +
.../type-resolver/src/Types/Scalar.php | 31 +
.../type-resolver/src/Types/Self_.php | 33 +
.../type-resolver/src/Types/Static_.php | 38 +
.../type-resolver/src/Types/String_.php | 31 +
.../type-resolver/src/Types/This.php | 34 +
.../type-resolver/src/Types/Void_.php | 34 +
vendor/phpspec/prophecy/CHANGES.md | 248 +
vendor/phpspec/prophecy/LICENSE | 23 +
vendor/phpspec/prophecy/README.md | 402 +
vendor/phpspec/prophecy/composer.json | 50 +
.../prophecy/src/Prophecy/Argument.php | 212 +
.../Prophecy/Argument/ArgumentsWildcard.php | 101 +
.../Prophecy/Argument/Token/AnyValueToken.php | 52 +
.../Argument/Token/AnyValuesToken.php | 52 +
.../Argument/Token/ApproximateValueToken.php | 55 +
.../Argument/Token/ArrayCountToken.php | 86 +
.../Argument/Token/ArrayEntryToken.php | 143 +
.../Argument/Token/ArrayEveryEntryToken.php | 82 +
.../Prophecy/Argument/Token/CallbackToken.php | 75 +
.../Argument/Token/ExactValueToken.php | 118 +
.../Argument/Token/IdenticalValueToken.php | 74 +
.../Argument/Token/LogicalAndToken.php | 80 +
.../Argument/Token/LogicalNotToken.php | 73 +
.../Argument/Token/ObjectStateToken.php | 104 +
.../Argument/Token/StringContainsToken.php | 67 +
.../Argument/Token/TokenInterface.php | 43 +
.../src/Prophecy/Argument/Token/TypeToken.php | 76 +
.../prophecy/src/Prophecy/Call/Call.php | 162 +
.../prophecy/src/Prophecy/Call/CallCenter.php | 248 +
.../Prophecy/Comparator/ClosureComparator.php | 44 +
.../src/Prophecy/Comparator/Factory.php | 47 +
.../Comparator/ProphecyComparator.php | 28 +
.../src/Prophecy/Doubler/CachedDoubler.php | 66 +
.../ClassPatch/ClassPatchInterface.php | 48 +
.../ClassPatch/DisableConstructorPatch.php | 76 +
.../Doubler/ClassPatch/HhvmExceptionPatch.php | 63 +
.../Doubler/ClassPatch/KeywordPatch.php | 140 +
.../Doubler/ClassPatch/MagicCallPatch.php | 94 +
.../ClassPatch/ProphecySubjectPatch.php | 104 +
.../ReflectionClassNewInstancePatch.php | 57 +
.../Doubler/ClassPatch/SplFileInfoPatch.php | 123 +
.../Doubler/ClassPatch/ThrowablePatch.php | 95 +
.../Doubler/ClassPatch/TraversablePatch.php | 83 +
.../src/Prophecy/Doubler/DoubleInterface.php | 22 +
.../prophecy/src/Prophecy/Doubler/Doubler.php | 146 +
.../Doubler/Generator/ClassCodeGenerator.php | 129 +
.../Doubler/Generator/ClassCreator.php | 67 +
.../Doubler/Generator/ClassMirror.php | 260 +
.../Doubler/Generator/Node/ArgumentNode.php | 102 +
.../Doubler/Generator/Node/ClassNode.php | 169 +
.../Doubler/Generator/Node/MethodNode.php | 198 +
.../Doubler/Generator/ReflectionInterface.php | 22 +
.../Doubler/Generator/TypeHintReference.php | 46 +
.../src/Prophecy/Doubler/LazyDouble.php | 127 +
.../src/Prophecy/Doubler/NameGenerator.php | 52 +
.../Call/UnexpectedCallException.php | 40 +
.../Doubler/ClassCreatorException.php | 31 +
.../Doubler/ClassMirrorException.php | 31 +
.../Doubler/ClassNotFoundException.php | 33 +
.../Exception/Doubler/DoubleException.php | 18 +
.../Exception/Doubler/DoublerException.php | 18 +
.../Doubler/InterfaceNotFoundException.php | 20 +
.../Doubler/MethodNotExtendableException.php | 41 +
.../Doubler/MethodNotFoundException.php | 60 +
.../Doubler/ReturnByReferenceException.php | 41 +
.../src/Prophecy/Exception/Exception.php | 26 +
.../Exception/InvalidArgumentException.php | 16 +
.../Prediction/AggregateException.php | 51 +
.../Prediction/FailedPredictionException.php | 24 +
.../Exception/Prediction/NoCallsException.php | 18 +
.../Prediction/PredictionException.php | 18 +
.../UnexpectedCallsCountException.php | 31 +
.../Prediction/UnexpectedCallsException.php | 32 +
.../Prophecy/MethodProphecyException.php | 34 +
.../Prophecy/ObjectProphecyException.php | 34 +
.../Exception/Prophecy/ProphecyException.php | 18 +
.../ClassAndInterfaceTagRetriever.php | 69 +
.../PhpDocumentor/ClassTagRetriever.php | 60 +
.../PhpDocumentor/LegacyClassTagRetriever.php | 35 +
.../MethodTagRetrieverInterface.php | 30 +
.../Prophecy/Prediction/CallPrediction.php | 86 +
.../Prediction/CallTimesPrediction.php | 107 +
.../Prediction/CallbackPrediction.php | 65 +
.../Prophecy/Prediction/NoCallsPrediction.php | 68 +
.../Prediction/PredictionInterface.php | 37 +
.../src/Prophecy/Promise/CallbackPromise.php | 66 +
.../src/Prophecy/Promise/PromiseInterface.php | 35 +
.../Promise/ReturnArgumentPromise.php | 61 +
.../src/Prophecy/Promise/ReturnPromise.php | 55 +
.../src/Prophecy/Promise/ThrowPromise.php | 100 +
.../src/Prophecy/Prophecy/MethodProphecy.php | 522 +
.../src/Prophecy/Prophecy/ObjectProphecy.php | 286 +
.../Prophecy/Prophecy/ProphecyInterface.php | 27 +
.../Prophecy/ProphecySubjectInterface.php | 34 +
.../src/Prophecy/Prophecy/Revealer.php | 44 +
.../Prophecy/Prophecy/RevealerInterface.php | 29 +
.../phpspec/prophecy/src/Prophecy/Prophet.php | 138 +
.../prophecy/src/Prophecy/Util/ExportUtil.php | 210 +
.../prophecy/src/Prophecy/Util/StringUtil.php | 99 +
.../phpunit/php-code-coverage/.gitattributes | 1 +
.../php-code-coverage/.github/CONTRIBUTING.md | 1 +
.../.github/ISSUE_TEMPLATE.md | 18 +
vendor/phpunit/php-code-coverage/.gitignore | 6 +
vendor/phpunit/php-code-coverage/.php_cs | 69 +
vendor/phpunit/php-code-coverage/.travis.yml | 42 +
.../php-code-coverage/ChangeLog-2.2.md | 56 +
.../php-code-coverage/ChangeLog-3.0.md | 31 +
.../php-code-coverage/ChangeLog-3.1.md | 30 +
.../php-code-coverage/ChangeLog-3.2.md | 23 +
.../php-code-coverage/ChangeLog-3.3.md | 33 +
.../php-code-coverage/ChangeLog-4.0.md | 67 +
vendor/phpunit/php-code-coverage/LICENSE | 33 +
vendor/phpunit/php-code-coverage/README.md | 51 +
vendor/phpunit/php-code-coverage/build.xml | 21 +
.../phpunit/php-code-coverage/composer.json | 51 +
vendor/phpunit/php-code-coverage/phpunit.xml | 21 +
.../php-code-coverage/src/CodeCoverage.php | 1107 +
.../php-code-coverage/src/Driver/Driver.php | 52 +
.../php-code-coverage/src/Driver/HHVM.php | 29 +
.../php-code-coverage/src/Driver/PHPDBG.php | 111 +
.../php-code-coverage/src/Driver/Xdebug.php | 117 +
.../CoveredCodeNotExecutedException.php | 18 +
.../src/Exception/Exception.php | 18 +
.../Exception/InvalidArgumentException.php | 37 +
.../MissingCoversAnnotationException.php | 18 +
.../src/Exception/RuntimeException.php | 15 +
.../UnintentionallyCoveredCodeException.php | 54 +
.../phpunit/php-code-coverage/src/Filter.php | 173 +
.../src/Node/AbstractNode.php | 342 +
.../php-code-coverage/src/Node/Builder.php | 244 +
.../php-code-coverage/src/Node/Directory.php | 483 +
.../php-code-coverage/src/Node/File.php | 722 +
.../php-code-coverage/src/Node/Iterator.php | 103 +
.../php-code-coverage/src/Report/Clover.php | 251 +
.../php-code-coverage/src/Report/Crap4j.php | 172 +
.../src/Report/Html/Facade.php | 179 +
.../src/Report/Html/Renderer.php | 298 +
.../src/Report/Html/Renderer/Dashboard.php | 302 +
.../src/Report/Html/Renderer/Directory.php | 101 +
.../src/Report/Html/Renderer/File.php | 551 +
.../Renderer/Template/coverage_bar.html.dist | 5 +
.../Renderer/Template/css/bootstrap.min.css | 6 +
.../Html/Renderer/Template/css/nv.d3.min.css | 1 +
.../Html/Renderer/Template/css/style.css | 122 +
.../Renderer/Template/dashboard.html.dist | 284 +
.../Renderer/Template/directory.html.dist | 61 +
.../Template/directory_item.html.dist | 13 +
.../Html/Renderer/Template/file.html.dist | 90 +
.../Renderer/Template/file_item.html.dist | 14 +
.../fonts/glyphicons-halflings-regular.eot | Bin 0 -> 20127 bytes
.../fonts/glyphicons-halflings-regular.svg | 288 +
.../fonts/glyphicons-halflings-regular.ttf | Bin 0 -> 45404 bytes
.../fonts/glyphicons-halflings-regular.woff | Bin 0 -> 23424 bytes
.../fonts/glyphicons-halflings-regular.woff2 | Bin 0 -> 18028 bytes
.../Renderer/Template/js/bootstrap.min.js | 7 +
.../Html/Renderer/Template/js/d3.min.js | 5 +
.../Html/Renderer/Template/js/holder.min.js | 12 +
.../Renderer/Template/js/html5shiv.min.js | 326 +
.../Html/Renderer/Template/js/jquery.min.js | 4 +
.../Html/Renderer/Template/js/nv.d3.min.js | 8 +
.../Html/Renderer/Template/js/respond.min.js | 5 +
.../Renderer/Template/method_item.html.dist | 11 +
.../php-code-coverage/src/Report/PHP.php | 51 +
.../php-code-coverage/src/Report/Text.php | 257 +
.../src/Report/Xml/Coverage.php | 67 +
.../src/Report/Xml/Directory.php | 15 +
.../src/Report/Xml/Facade.php | 238 +
.../php-code-coverage/src/Report/Xml/File.php | 72 +
.../src/Report/Xml/Method.php | 57 +
.../php-code-coverage/src/Report/Xml/Node.php | 88 +
.../src/Report/Xml/Project.php | 62 +
.../src/Report/Xml/Report.php | 71 +
.../src/Report/Xml/Tests.php | 46 +
.../src/Report/Xml/Totals.php | 141 +
.../php-code-coverage/src/Report/Xml/Unit.php | 96 +
vendor/phpunit/php-code-coverage/src/Util.php | 48 +
.../php-code-coverage/tests/TestCase.php | 343 +
.../tests/_files/BankAccount-clover.xml | 26 +
.../tests/_files/BankAccount-crap4j.xml | 59 +
.../tests/_files/BankAccount-text.txt | 12 +
.../tests/_files/BankAccount.php | 33 +
.../tests/_files/BankAccountTest.php | 66 +
.../_files/CoverageClassExtendedTest.php | 12 +
.../tests/_files/CoverageClassTest.php | 12 +
.../CoverageFunctionParenthesesTest.php | 11 +
...erageFunctionParenthesesWhitespaceTest.php | 11 +
.../tests/_files/CoverageFunctionTest.php | 11 +
.../CoverageMethodOneLineAnnotationTest.php | 11 +
.../_files/CoverageMethodParenthesesTest.php | 12 +
...overageMethodParenthesesWhitespaceTest.php | 12 +
.../tests/_files/CoverageMethodTest.php | 12 +
.../tests/_files/CoverageNoneTest.php | 9 +
.../tests/_files/CoverageNotPrivateTest.php | 12 +
.../tests/_files/CoverageNotProtectedTest.php | 12 +
.../tests/_files/CoverageNotPublicTest.php | 12 +
.../tests/_files/CoverageNothingTest.php | 13 +
.../tests/_files/CoveragePrivateTest.php | 12 +
.../tests/_files/CoverageProtectedTest.php | 12 +
.../tests/_files/CoveragePublicTest.php | 12 +
.../CoverageTwoDefaultClassAnnotations.php | 18 +
.../tests/_files/CoveredClass.php | 36 +
.../tests/_files/CoveredFunction.php | 4 +
.../NamespaceCoverageClassExtendedTest.php | 12 +
.../_files/NamespaceCoverageClassTest.php | 12 +
...NamespaceCoverageCoversClassPublicTest.php | 15 +
.../NamespaceCoverageCoversClassTest.php | 20 +
.../_files/NamespaceCoverageMethodTest.php | 12 +
.../NamespaceCoverageNotPrivateTest.php | 12 +
.../NamespaceCoverageNotProtectedTest.php | 12 +
.../_files/NamespaceCoverageNotPublicTest.php | 12 +
.../_files/NamespaceCoveragePrivateTest.php | 12 +
.../_files/NamespaceCoverageProtectedTest.php | 12 +
.../_files/NamespaceCoveragePublicTest.php | 12 +
.../tests/_files/NamespaceCoveredClass.php | 38 +
.../_files/NotExistingCoveredElementTest.php | 24 +
.../BankAccount.php.html | 267 +
.../CoverageForBankAccount/dashboard.html | 290 +
.../HTML/CoverageForBankAccount/index.html | 119 +
.../dashboard.html | 288 +
.../index.html | 119 +
...with_class_and_anonymous_function.php.html | 211 +
.../dashboard.html | 286 +
.../index.html | 99 +
.../source_with_ignore.php.html | 234 +
.../BankAccount.php.xml | 40 +
.../XML/CoverageForBankAccount/index.xml | 29 +
.../index.xml | 26 +
..._with_class_and_anonymous_function.php.xml | 41 +
.../CoverageForFileWithIgnoredLines/index.xml | 26 +
.../source_with_ignore.php.xml | 28 +
.../class-with-anonymous-function-clover.xml | 22 +
.../class-with-anonymous-function-crap4j.xml | 37 +
.../class-with-anonymous-function-text.txt | 12 +
.../tests/_files/ignored-lines-clover.xml | 17 +
.../tests/_files/ignored-lines-crap4j.xml | 37 +
.../tests/_files/ignored-lines-text.txt | 10 +
...urce_with_class_and_anonymous_function.php | 19 +
.../tests/_files/source_with_ignore.php | 37 +
.../tests/_files/source_with_namespace.php | 20 +
.../source_with_oneline_annotations.php | 36 +
.../tests/_files/source_without_ignore.php | 4 +
.../tests/_files/source_without_namespace.php | 18 +
.../php-code-coverage/tests/bootstrap.php | 5 +
.../tests/tests/BuilderTest.php | 212 +
.../tests/tests/CloverTest.php | 49 +
.../tests/tests/CodeCoverageTest.php | 547 +
.../tests/tests/Crap4jTest.php | 49 +
.../tests/tests/FilterTest.php | 194 +
.../tests/tests/HTMLTest.php | 103 +
.../tests/tests/TextTest.php | 49 +
.../tests/tests/UtilTest.php | 27 +
.../php-code-coverage/tests/tests/XMLTest.php | 99 +
.../phpunit/php-file-iterator/.gitattributes | 1 +
vendor/phpunit/php-file-iterator/.gitignore | 7 +
vendor/phpunit/php-file-iterator/ChangeLog.md | 41 +
vendor/phpunit/php-file-iterator/LICENSE | 33 +
vendor/phpunit/php-file-iterator/README.md | 12 +
.../phpunit/php-file-iterator/composer.json | 36 +
.../phpunit/php-file-iterator/src/Facade.php | 123 +
.../phpunit/php-file-iterator/src/Factory.php | 91 +
.../php-file-iterator/src/Iterator.php | 158 +
.../phpunit/php-text-template/.gitattributes | 1 +
vendor/phpunit/php-text-template/.gitignore | 5 +
vendor/phpunit/php-text-template/LICENSE | 33 +
vendor/phpunit/php-text-template/README.md | 14 +
.../phpunit/php-text-template/composer.json | 29 +
.../php-text-template/src/Template.php | 135 +
vendor/phpunit/php-timer/.gitattributes | 1 +
vendor/phpunit/php-timer/.gitignore | 4 +
vendor/phpunit/php-timer/.travis.yml | 27 +
vendor/phpunit/php-timer/LICENSE | 33 +
vendor/phpunit/php-timer/README.md | 45 +
vendor/phpunit/php-timer/composer.json | 37 +
vendor/phpunit/php-timer/phpunit.xml | 19 +
vendor/phpunit/php-timer/src/Timer.php | 105 +
vendor/phpunit/php-timer/tests/TimerTest.php | 98 +
.../phpunit/php-token-stream/.gitattributes | 1 +
vendor/phpunit/php-token-stream/.gitignore | 4 +
vendor/phpunit/php-token-stream/.travis.yml | 31 +
vendor/phpunit/php-token-stream/LICENSE | 33 +
vendor/phpunit/php-token-stream/README.md | 14 +
vendor/phpunit/php-token-stream/build.xml | 33 +
.../php-token-stream/build/phpunit.xml | 17 +
vendor/phpunit/php-token-stream/composer.json | 34 +
vendor/phpunit/php-token-stream/src/Token.php | 849 +
.../php-token-stream/src/Token/Stream.php | 613 +
.../src/Token/Stream/CachingFactory.php | 51 +
.../tests/Token/ClassTest.php | 123 +
.../tests/Token/ClosureTest.php | 85 +
.../tests/Token/FunctionTest.php | 146 +
.../tests/Token/IncludeTest.php | 73 +
.../tests/Token/InterfaceTest.php | 191 +
.../tests/Token/NamespaceTest.php | 80 +
.../php-token-stream/tests/TokenTest.php | 42 +
.../_fixture/classExtendsNamespacedClass.php | 10 +
.../tests/_fixture/classInNamespace.php | 6 +
.../tests/_fixture/classInScopedNamespace.php | 9 +
.../_fixture/classUsesNamespacedFunction.php | 8 +
...h_method_that_declares_anonymous_class.php | 15 +
..._method_that_declares_anonymous_class2.php | 16 +
.../tests/_fixture/closure.php | 7 +
.../tests/_fixture/issue19.php | 3 +
.../tests/_fixture/issue30.php | 8 +
...tipleNamespacesWithOneClassUsingBraces.php | 12 +
...espacesWithOneClassUsingNonBraceSyntax.php | 14 +
.../tests/_fixture/source.php | 36 +
.../tests/_fixture/source2.php | 6 +
.../tests/_fixture/source3.php | 14 +
.../tests/_fixture/source4.php | 30 +
.../tests/_fixture/source5.php | 5 +
.../php-token-stream/tests/bootstrap.php | 7 +
.../phpunit-mock-objects/.gitattributes | 1 +
.../phpunit/phpunit-mock-objects/.gitignore | 7 +
vendor/phpunit/phpunit-mock-objects/.php_cs | 67 +
.../phpunit/phpunit-mock-objects/.travis.yml | 28 +
.../phpunit-mock-objects/CONTRIBUTING.md | 1 +
vendor/phpunit/phpunit-mock-objects/LICENSE | 33 +
vendor/phpunit/phpunit-mock-objects/README.md | 22 +
vendor/phpunit/phpunit-mock-objects/build.xml | 42 +
.../phpunit-mock-objects/composer.json | 53 +
.../phpunit/phpunit-mock-objects/phpunit.xml | 21 +
.../Framework/MockObject/Builder/Identity.php | 31 +
.../MockObject/Builder/InvocationMocker.php | 291 +
.../Framework/MockObject/Builder/Match.php | 27 +
.../MockObject/Builder/MethodNameMatch.php | 27 +
.../MockObject/Builder/Namespace.php | 38 +
.../MockObject/Builder/ParametersMatch.php | 49 +
.../src/Framework/MockObject/Builder/Stub.php | 27 +
.../Exception/BadMethodCallException.php | 16 +
.../MockObject/Exception/Exception.php | 18 +
.../MockObject/Exception/RuntimeException.php | 16 +
.../src/Framework/MockObject/Generator.php | 1324 +
.../MockObject/Generator/deprecation.tpl.dist | 2 +
.../Generator/mocked_class.tpl.dist | 40 +
.../Generator/mocked_class_method.tpl.dist | 7 +
.../Generator/mocked_clone.tpl.dist | 4 +
.../Generator/mocked_method.tpl.dist | 22 +
.../Generator/mocked_method_void.tpl.dist | 20 +
.../Generator/mocked_static_method.tpl.dist | 5 +
.../Generator/proxied_method.tpl.dist | 22 +
.../Generator/proxied_method_void.tpl.dist | 22 +
.../MockObject/Generator/trait_class.tpl.dist | 4 +
.../Generator/unmocked_clone.tpl.dist | 5 +
.../MockObject/Generator/wsdl_class.tpl.dist | 7 +
.../MockObject/Generator/wsdl_method.tpl.dist | 4 +
.../src/Framework/MockObject/Invocation.php | 22 +
.../MockObject/Invocation/Object.php | 37 +
.../MockObject/Invocation/Static.php | 207 +
.../Framework/MockObject/InvocationMocker.php | 178 +
.../src/Framework/MockObject/Invokable.php | 39 +
.../src/Framework/MockObject/Matcher.php | 274 +
.../MockObject/Matcher/AnyInvokedCount.php | 32 +
.../MockObject/Matcher/AnyParameters.php | 35 +
.../Matcher/ConsecutiveParameters.php | 126 +
.../MockObject/Matcher/Invocation.php | 46 +
.../MockObject/Matcher/InvokedAtIndex.php | 87 +
.../Matcher/InvokedAtLeastCount.php | 57 +
.../MockObject/Matcher/InvokedAtLeastOnce.php | 45 +
.../MockObject/Matcher/InvokedAtMostCount.php | 57 +
.../MockObject/Matcher/InvokedCount.php | 110 +
.../MockObject/Matcher/InvokedRecorder.php | 68 +
.../MockObject/Matcher/MethodName.php | 68 +
.../MockObject/Matcher/Parameters.php | 158 +
.../Matcher/StatelessInvocation.php | 54 +
.../src/Framework/MockObject/MockBuilder.php | 408 +
.../src/Framework/MockObject/MockObject.php | 55 +
.../src/Framework/MockObject/Stub.php | 30 +
.../MockObject/Stub/ConsecutiveCalls.php | 48 +
.../Framework/MockObject/Stub/Exception.php | 48 +
.../MockObject/Stub/MatcherCollection.php | 25 +
.../src/Framework/MockObject/Stub/Return.php | 41 +
.../MockObject/Stub/ReturnArgument.php | 38 +
.../MockObject/Stub/ReturnCallback.php | 51 +
.../MockObject/Stub/ReturnReference.php | 22 +
.../Framework/MockObject/Stub/ReturnSelf.php | 34 +
.../MockObject/Stub/ReturnValueMap.php | 47 +
.../src/Framework/MockObject/Verifiable.php | 25 +
.../tests/GeneratorTest.php | 200 +
.../tests/MockBuilderTest.php | 126 +
.../Builder/InvocationMockerTest.php | 63 +
.../tests/MockObject/Generator/232.phpt | 129 +
.../MockObject/Generator/abstract_class.phpt | 147 +
.../tests/MockObject/Generator/class.phpt | 125 +
.../Generator/class_call_parent_clone.phpt | 77 +
.../class_call_parent_constructor.phpt | 76 +
.../class_dont_call_parent_clone.phpt | 76 +
.../class_dont_call_parent_constructor.phpt | 76 +
...ing_interface_call_parent_constructor.phpt | 81 +
...nterface_dont_call_parent_constructor.phpt | 81 +
.../MockObject/Generator/class_partial.phpt | 103 +
.../class_with_method_named_method.phpt | 92 +
...s_with_method_with_variadic_arguments.phpt | 99 +
.../tests/MockObject/Generator/interface.phpt | 97 +
.../invocation_object_clone_object.phpt | 126 +
.../Generator/namespaced_class.phpt | 127 +
.../namespaced_class_call_parent_clone.phpt | 79 +
...espaced_class_call_parent_constructor.phpt | 78 +
...mespaced_class_dont_call_parent_clone.phpt | 78 +
...ed_class_dont_call_parent_constructor.phpt | 78 +
...ing_interface_call_parent_constructor.phpt | 83 +
...nterface_dont_call_parent_constructor.phpt | 83 +
.../Generator/namespaced_class_partial.phpt | 105 +
.../Generator/namespaced_interface.phpt | 99 +
.../Generator/nonexistent_class.phpt | 74 +
.../nonexistent_class_with_namespace.phpt | 82 +
...ith_namespace_starting_with_separator.phpt | 82 +
.../MockObject/Generator/nullable_types.phpt | 103 +
.../tests/MockObject/Generator/proxy.phpt | 121 +
.../return_type_declarations_nullable.phpt | 101 +
...eturn_type_declarations_object_method.phpt | 104 +
.../return_type_declarations_self.phpt | 101 +
...eturn_type_declarations_static_method.phpt | 87 +
.../return_type_declarations_void.phpt | 99 +
.../Generator/scalar_type_declarations.phpt | 103 +
.../MockObject/Generator/wsdl_class.phpt | 37 +
.../Generator/wsdl_class_namespace.phpt | 39 +
.../Generator/wsdl_class_partial.phpt | 30 +
.../MockObject/Invocation/ObjectTest.php | 108 +
.../MockObject/Invocation/StaticTest.php | 87 +
.../Matcher/ConsecutiveParametersTest.php | 56 +
.../class_with_deprecated_method.phpt | 105 +
.../tests/MockObjectTest.php | 1034 +
.../tests/ProxyObjectTest.php | 39 +
.../tests/_fixture/AbstractMockTestClass.php | 10 +
.../tests/_fixture/AbstractTrait.php | 15 +
.../tests/_fixture/AnInterface.php | 5 +
.../_fixture/AnInterfaceWithReturnType.php | 5 +
.../tests/_fixture/AnotherInterface.php | 5 +
.../tests/_fixture/Bar.php | 8 +
.../ClassThatImplementsSerializable.php | 15 +
.../tests/_fixture/ClassWithSelfTypeHint.php | 7 +
.../tests/_fixture/ClassWithStaticMethod.php | 7 +
.../tests/_fixture/Foo.php | 8 +
.../tests/_fixture/FunctionCallback.php | 9 +
.../tests/_fixture/GoogleSearch.wsdl | 198 +
.../InterfaceWithSemiReservedMethodName.php | 5 +
.../_fixture/InterfaceWithStaticMethod.php | 5 +
.../tests/_fixture/MethodCallback.php | 21 +
.../_fixture/MethodCallbackByReference.php | 13 +
.../tests/_fixture/MockTestInterface.php | 6 +
.../tests/_fixture/Mockable.php | 28 +
.../tests/_fixture/PartialMockTestClass.php | 18 +
.../tests/_fixture/SingletonClass.php | 28 +
.../tests/_fixture/SomeClass.php | 13 +
.../tests/_fixture/StaticMockTestClass.php | 12 +
.../tests/_fixture/StringableClass.php | 8 +
.../_fixture/TraversableMockTestInterface.php | 4 +
.../phpunit-mock-objects/tests/bootstrap.php | 3 +
vendor/phpunit/phpunit/.gitattributes | 4 +
.../phpunit/.github/CODE_OF_CONDUCT.md | 28 +
.../phpunit/phpunit/.github/CONTRIBUTING.md | 72 +
.../phpunit/phpunit/.github/ISSUE_TEMPLATE.md | 15 +
vendor/phpunit/phpunit/.gitignore | 20 +
vendor/phpunit/phpunit/.php_cs.dist | 81 +
vendor/phpunit/phpunit/.stickler.yml | 3 +
vendor/phpunit/phpunit/.travis.yml | 55 +
vendor/phpunit/phpunit/ChangeLog-5.7.md | 242 +
vendor/phpunit/phpunit/LICENSE | 33 +
vendor/phpunit/phpunit/README.md | 46 +
vendor/phpunit/phpunit/build.xml | 418 +
vendor/phpunit/phpunit/composer.json | 86 +
vendor/phpunit/phpunit/phpunit | 52 +
vendor/phpunit/phpunit/phpunit.xml | 34 +
vendor/phpunit/phpunit/phpunit.xsd | 254 +
vendor/phpunit/phpunit/src/Exception.php | 16 +
.../phpunit/src/Extensions/GroupTestSuite.php | 58 +
.../phpunit/src/Extensions/PhptTestCase.php | 430 +
.../phpunit/src/Extensions/PhptTestSuite.php | 38 +
.../phpunit/src/Extensions/RepeatedTest.php | 88 +
.../phpunit/src/Extensions/TestDecorator.php | 107 +
.../phpunit/src/Extensions/TicketListener.php | 194 +
.../src/ForwardCompatibility/Assert.php | 17 +
.../AssertionFailedError.php | 17 +
.../ForwardCompatibility/BaseTestListener.php | 17 +
.../phpunit/src/ForwardCompatibility/Test.php | 17 +
.../src/ForwardCompatibility/TestCase.php | 17 +
.../src/ForwardCompatibility/TestListener.php | 17 +
.../src/ForwardCompatibility/TestSuite.php | 17 +
.../phpunit/phpunit/src/Framework/Assert.php | 2952 ++
.../src/Framework/Assert/Functions.php | 2174 ++
.../src/Framework/AssertionFailedError.php | 25 +
.../src/Framework/BaseTestListener.php | 58 +
.../src/Framework/CodeCoverageException.php | 13 +
.../phpunit/src/Framework/Constraint.php | 149 +
.../phpunit/src/Framework/Constraint/And.php | 121 +
.../src/Framework/Constraint/ArrayHasKey.php | 80 +
.../src/Framework/Constraint/ArraySubset.php | 107 +
.../src/Framework/Constraint/Attribute.php | 84 +
.../src/Framework/Constraint/Callback.php | 59 +
.../Constraint/ClassHasAttribute.php | 80 +
.../Constraint/ClassHasStaticAttribute.php | 52 +
.../src/Framework/Constraint/Composite.php | 67 +
.../src/Framework/Constraint/Count.php | 122 +
.../Framework/Constraint/DirectoryExists.php | 58 +
.../src/Framework/Constraint/Exception.php | 85 +
.../Framework/Constraint/ExceptionCode.php | 66 +
.../Framework/Constraint/ExceptionMessage.php | 81 +
.../Constraint/ExceptionMessageRegExp.php | 74 +
.../src/Framework/Constraint/FileExists.php | 58 +
.../src/Framework/Constraint/GreaterThan.php | 53 +
.../src/Framework/Constraint/IsAnything.php | 58 +
.../src/Framework/Constraint/IsEmpty.php | 64 +
.../src/Framework/Constraint/IsEqual.php | 177 +
.../src/Framework/Constraint/IsFalse.php | 38 +
.../src/Framework/Constraint/IsFinite.php | 38 +
.../src/Framework/Constraint/IsIdentical.php | 130 +
.../src/Framework/Constraint/IsInfinite.php | 38 +
.../src/Framework/Constraint/IsInstanceOf.php | 92 +
.../src/Framework/Constraint/IsJson.php | 75 +
.../src/Framework/Constraint/IsNan.php | 38 +
.../src/Framework/Constraint/IsNull.php | 38 +
.../src/Framework/Constraint/IsReadable.php | 58 +
.../src/Framework/Constraint/IsTrue.php | 38 +
.../src/Framework/Constraint/IsType.php | 141 +
.../src/Framework/Constraint/IsWritable.php | 58 +
.../src/Framework/Constraint/JsonMatches.php | 69 +
.../JsonMatches/ErrorMessageProvider.php | 67 +
.../src/Framework/Constraint/LessThan.php | 53 +
.../phpunit/src/Framework/Constraint/Not.php | 156 +
.../Constraint/ObjectHasAttribute.php | 33 +
.../phpunit/src/Framework/Constraint/Or.php | 113 +
.../src/Framework/Constraint/PCREMatch.php | 61 +
.../src/Framework/Constraint/SameSize.php | 25 +
.../Framework/Constraint/StringContains.php | 79 +
.../Framework/Constraint/StringEndsWith.php | 53 +
.../Framework/Constraint/StringMatches.php | 99 +
.../Framework/Constraint/StringStartsWith.php | 53 +
.../Constraint/TraversableContains.php | 123 +
.../Constraint/TraversableContainsOnly.php | 93 +
.../phpunit/src/Framework/Constraint/Xor.php | 118 +
.../CoveredCodeNotExecutedException.php | 17 +
.../phpunit/phpunit/src/Framework/Error.php | 32 +
.../src/Framework/Error/Deprecated.php | 22 +
.../phpunit/src/Framework/Error/Notice.php | 22 +
.../phpunit/src/Framework/Error/Warning.php | 22 +
.../phpunit/src/Framework/Exception.php | 76 +
.../src/Framework/ExceptionWrapper.php | 89 +
.../Framework/ExpectationFailedException.php | 39 +
.../phpunit/src/Framework/IncompleteTest.php | 17 +
.../src/Framework/IncompleteTestCase.php | 82 +
.../src/Framework/IncompleteTestError.php | 17 +
.../InvalidCoversTargetException.php | 13 +
.../MissingCoversAnnotationException.php | 17 +
.../phpunit/src/Framework/OutputError.php | 17 +
.../phpunit/src/Framework/RiskyTest.php | 17 +
.../phpunit/src/Framework/RiskyTestError.php | 17 +
.../phpunit/src/Framework/SelfDescribing.php | 22 +
.../phpunit/src/Framework/SkippedTest.php | 16 +
.../phpunit/src/Framework/SkippedTestCase.php | 80 +
.../src/Framework/SkippedTestError.php | 17 +
.../src/Framework/SkippedTestSuiteError.php | 17 +
.../phpunit/src/Framework/SyntheticError.php | 78 +
vendor/phpunit/phpunit/src/Framework/Test.php | 24 +
.../phpunit/src/Framework/TestCase.php | 2491 ++
.../phpunit/src/Framework/TestFailure.php | 161 +
.../phpunit/src/Framework/TestListener.php | 102 +
.../phpunit/src/Framework/TestResult.php | 1310 +
.../phpunit/src/Framework/TestSuite.php | 1000 +
.../src/Framework/TestSuite/DataProvider.php | 24 +
.../UnintentionallyCoveredCodeError.php | 17 +
.../phpunit/phpunit/src/Framework/Warning.php | 25 +
.../phpunit/src/Framework/WarningTestCase.php | 75 +
.../phpunit/src/Runner/BaseTestRunner.php | 139 +
.../phpunit/phpunit/src/Runner/Exception.php | 13 +
.../phpunit/src/Runner/Filter/Factory.php | 48 +
.../phpunit/src/Runner/Filter/Group.php | 56 +
.../src/Runner/Filter/Group/Exclude.php | 22 +
.../src/Runner/Filter/Group/Include.php | 22 +
.../phpunit/src/Runner/Filter/Test.php | 117 +
.../src/Runner/StandardTestSuiteLoader.php | 116 +
.../phpunit/src/Runner/TestSuiteLoader.php | 30 +
vendor/phpunit/phpunit/src/Runner/Version.php | 73 +
vendor/phpunit/phpunit/src/TextUI/Command.php | 1172 +
.../phpunit/src/TextUI/ResultPrinter.php | 680 +
.../phpunit/phpunit/src/TextUI/TestRunner.php | 1142 +
vendor/phpunit/phpunit/src/Util/Blacklist.php | 111 +
.../phpunit/src/Util/Configuration.php | 1135 +
.../src/Util/ConfigurationGenerator.php | 66 +
.../phpunit/phpunit/src/Util/ErrorHandler.php | 115 +
.../phpunit/phpunit/src/Util/Fileloader.php | 68 +
.../phpunit/phpunit/src/Util/Filesystem.php | 38 +
vendor/phpunit/phpunit/src/Util/Filter.php | 103 +
vendor/phpunit/phpunit/src/Util/Getopt.php | 164 +
.../phpunit/phpunit/src/Util/GlobalState.php | 214 +
.../src/Util/InvalidArgumentHelper.php | 39 +
vendor/phpunit/phpunit/src/Util/Log/JSON.php | 254 +
vendor/phpunit/phpunit/src/Util/Log/JUnit.php | 450 +
vendor/phpunit/phpunit/src/Util/Log/TAP.php | 261 +
.../phpunit/phpunit/src/Util/Log/TeamCity.php | 406 +
vendor/phpunit/phpunit/src/Util/PHP.php | 410 +
.../phpunit/phpunit/src/Util/PHP/Default.php | 208 +
.../Util/PHP/Template/TestCaseMethod.tpl.dist | 102 +
.../phpunit/phpunit/src/Util/PHP/Windows.php | 40 +
.../phpunit/src/Util/PHP/eval-stdin.php | 10 +
vendor/phpunit/phpunit/src/Util/Printer.php | 144 +
vendor/phpunit/phpunit/src/Util/Regex.php | 33 +
vendor/phpunit/phpunit/src/Util/String.php | 61 +
vendor/phpunit/phpunit/src/Util/Test.php | 1099 +
.../src/Util/TestDox/NamePrettifier.php | 142 +
.../src/Util/TestDox/ResultPrinter.php | 399 +
.../src/Util/TestDox/ResultPrinter/HTML.php | 137 +
.../src/Util/TestDox/ResultPrinter/Text.php | 52 +
.../src/Util/TestDox/ResultPrinter/XML.php | 225 +
.../phpunit/src/Util/TestSuiteIterator.php | 101 +
vendor/phpunit/phpunit/src/Util/Type.php | 41 +
vendor/phpunit/phpunit/src/Util/XML.php | 246 +
.../tests/Extensions/PhptTestCaseTest.php | 263 +
.../tests/Extensions/RepeatedTestTest.php | 60 +
vendor/phpunit/phpunit/tests/Fail/fail.phpt | 5 +
.../phpunit/tests/Framework/AssertTest.php | 3768 +++
.../tests/Framework/BaseTestListenerTest.php | 28 +
.../Framework/Constraint/ArraySubsetTest.php | 65 +
.../tests/Framework/Constraint/CountTest.php | 92 +
.../Constraint/ExceptionMessageRegExpTest.php | 51 +
.../Constraint/ExceptionMessageTest.php | 48 +
.../tests/Framework/Constraint/IsJsonTest.php | 29 +
.../JsonMatches/ErrorMessageProviderTest.php | 78 +
.../Framework/Constraint/JsonMatchesTest.php | 39 +
.../tests/Framework/ConstraintTest.php | 3053 ++
.../phpunit/tests/Framework/SuiteTest.php | 269 +
.../phpunit/tests/Framework/TestCaseTest.php | 690 +
.../tests/Framework/TestFailureTest.php | 21 +
.../tests/Framework/TestImplementorTest.php | 24 +
.../tests/Framework/TestListenerTest.php | 110 +
.../phpunit/tests/Regression/GitHub/1149.phpt | 20 +
.../Regression/GitHub/1149/Issue1149Test.php | 18 +
.../phpunit/tests/Regression/GitHub/1216.phpt | 25 +
.../Regression/GitHub/1216/Issue1216Test.php | 8 +
.../Regression/GitHub/1216/bootstrap1216.php | 2 +
.../Regression/GitHub/1216/phpunit1216.xml | 8 +
.../phpunit/tests/Regression/GitHub/1265.phpt | 21 +
.../Regression/GitHub/1265/Issue1265Test.php | 8 +
.../Regression/GitHub/1265/phpunit1265.xml | 2 +
.../phpunit/tests/Regression/GitHub/1330.phpt | 24 +
.../Regression/GitHub/1330/Issue1330Test.php | 8 +
.../Regression/GitHub/1330/phpunit1330.xml | 5 +
.../phpunit/tests/Regression/GitHub/1335.phpt | 19 +
.../Regression/GitHub/1335/Issue1335Test.php | 67 +
.../Regression/GitHub/1335/bootstrap1335.php | 13 +
.../phpunit/tests/Regression/GitHub/1337.phpt | 19 +
.../Regression/GitHub/1337/Issue1337Test.php | 19 +
.../phpunit/tests/Regression/GitHub/1348.phpt | 34 +
.../Regression/GitHub/1348/Issue1348Test.php | 14 +
.../phpunit/tests/Regression/GitHub/1351.phpt | 46 +
.../GitHub/1351/ChildProcessClass1351.php | 4 +
.../Regression/GitHub/1351/Issue1351Test.php | 48 +
.../phpunit/tests/Regression/GitHub/1374.phpt | 19 +
.../Regression/GitHub/1374/Issue1374Test.php | 21 +
.../phpunit/tests/Regression/GitHub/1437.phpt | 26 +
.../Regression/GitHub/1437/Issue1437Test.php | 9 +
.../phpunit/tests/Regression/GitHub/1468.phpt | 20 +
.../Regression/GitHub/1468/Issue1468Test.php | 11 +
.../phpunit/tests/Regression/GitHub/1471.phpt | 26 +
.../Regression/GitHub/1471/Issue1471Test.php | 12 +
.../phpunit/tests/Regression/GitHub/1472.phpt | 25 +
.../Regression/GitHub/1472/Issue1472Test.php | 21 +
.../phpunit/tests/Regression/GitHub/1570.phpt | 20 +
.../Regression/GitHub/1570/Issue1570Test.php | 8 +
.../tests/Regression/GitHub/2137-filter.phpt | 28 +
.../Regression/GitHub/2137-no_filter.phpt | 30 +
.../Regression/GitHub/2137/Issue2137Test.php | 33 +
.../phpunit/tests/Regression/GitHub/2145.phpt | 26 +
.../Regression/GitHub/2145/Issue2145Test.php | 16 +
.../phpunit/tests/Regression/GitHub/2158.phpt | 19 +
.../Regression/GitHub/2158/Issue2158Test.php | 23 +
.../tests/Regression/GitHub/2158/constant.inc | 5 +
.../Regression/GitHub/2299/Issue2299Test.php | 20 +
.../phpunit/tests/Regression/GitHub/2366.phpt | 19 +
.../Regression/GitHub/2366/Issue2366Test.php | 30 +
.../phpunit/tests/Regression/GitHub/2380.phpt | 19 +
.../Regression/GitHub/2380/Issue2380Test.php | 21 +
.../phpunit/tests/Regression/GitHub/2382.phpt | 19 +
.../Regression/GitHub/2382/Issue2382Test.php | 22 +
.../phpunit/tests/Regression/GitHub/2435.phpt | 20 +
.../Regression/GitHub/2435/Issue2435Test.php | 12 +
.../phpunit/tests/Regression/GitHub/244.phpt | 32 +
.../Regression/GitHub/244/Issue244Test.php | 55 +
.../phpunit/tests/Regression/GitHub/2731.phpt | 26 +
.../Regression/GitHub/2731/Issue2731Test.php | 11 +
.../phpunit/tests/Regression/GitHub/2758.phpt | 22 +
.../Regression/GitHub/2758/Issue2758Test.php | 7 +
.../GitHub/2758/Issue2758TestListener.php | 12 +
.../tests/Regression/GitHub/2758/phpunit.xml | 7 +
.../phpunit/tests/Regression/GitHub/2811.phpt | 20 +
.../Regression/GitHub/2811/Issue2811Test.php | 10 +
.../phpunit/tests/Regression/GitHub/2972.phpt | 18 +
.../GitHub/2972/issue-2972-test.phpt | 10 +
.../2972/unconventiallyNamedIssue2972Test.php | 13 +
.../phpunit/tests/Regression/GitHub/322.phpt | 26 +
.../Regression/GitHub/322/Issue322Test.php | 17 +
.../Regression/GitHub/322/phpunit322.xml | 11 +
.../phpunit/tests/Regression/GitHub/433.phpt | 31 +
.../Regression/GitHub/433/Issue433Test.php | 21 +
.../phpunit/tests/Regression/GitHub/445.phpt | 32 +
.../Regression/GitHub/445/Issue445Test.php | 21 +
.../phpunit/tests/Regression/GitHub/498.phpt | 29 +
.../Regression/GitHub/498/Issue498Test.php | 44 +
.../phpunit/tests/Regression/GitHub/503.phpt | 33 +
.../Regression/GitHub/503/Issue503Test.php | 11 +
.../phpunit/tests/Regression/GitHub/581.phpt | 42 +
.../Regression/GitHub/581/Issue581Test.php | 11 +
.../phpunit/tests/Regression/GitHub/74.phpt | 28 +
.../Regression/GitHub/74/Issue74Test.php | 9 +
.../Regression/GitHub/74/NewException.php | 4 +
.../phpunit/tests/Regression/GitHub/765.phpt | 26 +
.../Regression/GitHub/765/Issue765Test.php | 22 +
.../phpunit/tests/Regression/GitHub/797.phpt | 22 +
.../Regression/GitHub/797/Issue797Test.php | 10 +
.../Regression/GitHub/797/bootstrap797.php | 6 +
.../phpunit/tests/Regression/GitHub/863.phpt | 24 +
.../tests/Regression/GitHub/873-php5.phpt | 22 +
.../tests/Regression/GitHub/873-php7.phpt | 22 +
.../Regression/GitHub/873/Issue873Test.php | 9 +
.../phpunit/tests/Regression/Trac/1021.phpt | 19 +
.../Regression/Trac/1021/Issue1021Test.php | 23 +
.../phpunit/tests/Regression/Trac/523.phpt | 19 +
.../Regression/Trac/523/Issue523Test.php | 13 +
.../phpunit/tests/Regression/Trac/578.phpt | 37 +
.../Regression/Trac/578/Issue578Test.php | 20 +
.../phpunit/tests/Regression/Trac/684.phpt | 25 +
.../Regression/Trac/684/Issue684Test.php | 4 +
.../phpunit/tests/Regression/Trac/783.phpt | 21 +
.../tests/Regression/Trac/783/ChildSuite.php | 15 +
.../tests/Regression/Trac/783/OneTest.php | 10 +
.../tests/Regression/Trac/783/ParentSuite.php | 13 +
.../tests/Regression/Trac/783/TwoTest.php | 10 +
.../tests/Runner/BaseTestRunnerTest.php | 18 +
.../tests/TextUI/_files/expect_external.txt | 1 +
.../tests/TextUI/_files/phpt-env.expected.txt | 1 +
.../tests/TextUI/_files/phpt_external.php | 2 +
.../tests/TextUI/abstract-test-class.phpt | 24 +
.../phpunit/tests/TextUI/assertion.phpt | 38 +
.../tests/TextUI/code-coverage-ignore.phpt | 36 +
.../phpunit/tests/TextUI/colors-always.phpt | 18 +
.../tests/TextUI/concrete-test-class.phpt | 18 +
.../tests/TextUI/custom-printer-debug.phpt | 26 +
.../tests/TextUI/custom-printer-verbose.phpt | 31 +
.../tests/TextUI/dataprovider-debug.phpt | 33 +
.../tests/TextUI/dataprovider-issue-2833.phpt | 17 +
.../tests/TextUI/dataprovider-issue-2859.phpt | 17 +
.../tests/TextUI/dataprovider-issue-2922.phpt | 18 +
.../dataprovider-log-xml-isolation.phpt | 46 +
.../tests/TextUI/dataprovider-log-xml.phpt | 45 +
.../tests/TextUI/dataprovider-testdox.phpt | 19 +
.../phpunit/phpunit/tests/TextUI/debug.phpt | 25 +
.../tests/TextUI/default-isolation.phpt | 19 +
.../phpunit/phpunit/tests/TextUI/default.phpt | 18 +
.../tests/TextUI/dependencies-clone.phpt | 22 +
.../tests/TextUI/dependencies-isolation.phpt | 42 +
.../phpunit/tests/TextUI/dependencies.phpt | 41 +
.../tests/TextUI/dependencies2-isolation.phpt | 19 +
.../phpunit/tests/TextUI/dependencies2.phpt | 18 +
.../tests/TextUI/dependencies3-isolation.phpt | 19 +
.../phpunit/tests/TextUI/dependencies3.phpt | 19 +
.../TextUI/disable-code-coverage-ignore.phpt | 40 +
.../phpunit/tests/TextUI/empty-testcase.phpt | 25 +
.../phpunit/tests/TextUI/exception-stack.phpt | 64 +
.../tests/TextUI/exclude-group-isolation.phpt | 21 +
.../phpunit/tests/TextUI/exclude-group.phpt | 20 +
.../tests/TextUI/failure-isolation.phpt | 141 +
.../tests/TextUI/failure-reverse-list.phpt | 141 +
.../phpunit/phpunit/tests/TextUI/failure.phpt | 140 +
.../phpunit/tests/TextUI/fatal-isolation.phpt | 25 +
.../tests/TextUI/filter-class-isolation.phpt | 21 +
.../phpunit/tests/TextUI/filter-class.phpt | 20 +
...ider-by-classname-and-range-isolation.phpt | 21 +
...r-dataprovider-by-classname-and-range.phpt | 20 +
...lter-dataprovider-by-number-isolation.phpt | 21 +
.../TextUI/filter-dataprovider-by-number.phpt | 20 +
...-dataprovider-by-only-range-isolation.phpt | 21 +
.../filter-dataprovider-by-only-range.phpt | 20 +
...dataprovider-by-only-regexp-isolation.phpt | 21 +
.../filter-dataprovider-by-only-regexp.phpt | 20 +
...dataprovider-by-only-string-isolation.phpt | 21 +
.../filter-dataprovider-by-only-string.phpt | 20 +
...ilter-dataprovider-by-range-isolation.phpt | 21 +
.../TextUI/filter-dataprovider-by-range.phpt | 20 +
...lter-dataprovider-by-regexp-isolation.phpt | 21 +
.../TextUI/filter-dataprovider-by-regexp.phpt | 20 +
...lter-dataprovider-by-string-isolation.phpt | 21 +
.../TextUI/filter-dataprovider-by-string.phpt | 20 +
.../filter-method-case-insensitive.phpt | 20 +
...ilter-method-case-sensitive-no-result.phpt | 20 +
.../tests/TextUI/filter-method-isolation.phpt | 21 +
.../phpunit/tests/TextUI/filter-method.phpt | 20 +
.../tests/TextUI/filter-no-results.phpt | 20 +
.../tests/TextUI/forward-compatibility.phpt | 18 +
.../phpunit/tests/TextUI/group-isolation.phpt | 21 +
.../phpunit/phpunit/tests/TextUI/group.phpt | 20 +
vendor/phpunit/phpunit/tests/TextUI/help.phpt | 99 +
.../phpunit/phpunit/tests/TextUI/help2.phpt | 100 +
.../phpunit/tests/TextUI/ini-isolation.phpt | 21 +
.../phpunit/tests/TextUI/list-groups.phpt | 18 +
.../phpunit/tests/TextUI/list-suites.phpt | 16 +
.../tests/TextUI/log-json-post-66021.phpt | 73 +
.../phpunit/tests/TextUI/log-junit.phpt | 68 +
.../phpunit/phpunit/tests/TextUI/log-tap.phpt | 27 +
.../phpunit/tests/TextUI/log-teamcity.phpt | 38 +
.../phpunit/tests/TextUI/mycommand.phpt | 23 +
.../tests/TextUI/options-after-arguments.phpt | 18 +
.../tests/TextUI/output-isolation.phpt | 20 +
.../TextUI/phar-extension-suppressed.phpt | 12 +
.../phpunit/tests/TextUI/phar-extension.phpt | 21 +
.../phpunit/tests/TextUI/phpt-args.phpt | 12 +
.../phpunit/tests/TextUI/phpt-env.phpt | 12 +
.../phpunit/tests/TextUI/phpt-external.phpt | 6 +
.../phpunit/tests/TextUI/phpt-stderr.phpt | 8 +
.../phpunit/tests/TextUI/phpt-stdin.phpt | 11 +
.../phpunit/tests/TextUI/phpt-xfail.phpt | 18 +
.../phpunit/phpunit/tests/TextUI/repeat.phpt | 20 +
.../report-useless-tests-incomplete.phpt | 20 +
.../report-useless-tests-isolation.phpt | 21 +
.../tests/TextUI/report-useless-tests.phpt | 28 +
.../tests/TextUI/stop-on-warning-via-cli.phpt | 25 +
.../TextUI/stop-on-warning-via-config.phpt | 26 +
vendor/phpunit/phpunit/tests/TextUI/tap.phpt | 17 +
.../TextUI/teamcity-inner-exceptions.phpt | 39 +
.../phpunit/tests/TextUI/teamcity.phpt | 37 +
.../tests/TextUI/test-suffix-multiple.phpt | 19 +
.../tests/TextUI/test-suffix-single.phpt | 19 +
.../tests/TextUI/testdox-exclude-group.phpt | 25 +
.../phpunit/tests/TextUI/testdox-group.phpt | 25 +
.../phpunit/tests/TextUI/testdox-html.phpt | 56 +
.../phpunit/tests/TextUI/testdox-text.phpt | 24 +
.../phpunit/tests/TextUI/testdox-xml.phpt | 56 +
.../phpunit/phpunit/tests/TextUI/testdox.phpt | 18 +
.../phpunit/tests/Util/ConfigurationTest.php | 431 +
.../phpunit/phpunit/tests/Util/GetoptTest.php | 60 +
.../phpunit/tests/Util/GlobalStateTest.php | 30 +
vendor/phpunit/phpunit/tests/Util/PHPTest.php | 132 +
.../phpunit/phpunit/tests/Util/RegexTest.php | 47 +
.../tests/Util/TestDox/NamePrettifierTest.php | 66 +
.../phpunit/phpunit/tests/Util/TestTest.php | 823 +
vendor/phpunit/phpunit/tests/Util/XMLTest.php | 90 +
.../phpunit/tests/_files/AbstractTest.php | 7 +
.../phpunit/tests/_files/ArrayAccessible.php | 40 +
.../phpunit/tests/_files/AssertionExample.php | 8 +
.../tests/_files/AssertionExampleTest.php | 10 +
.../phpunit/phpunit/tests/_files/Author.php | 26 +
.../phpunit/tests/_files/BankAccount.php | 81 +
.../phpunit/tests/_files/BankAccountTest.php | 93 +
.../tests/_files/BankAccountTest.test.php | 86 +
.../phpunit/tests/_files/BankAccountTest2.php | 56 +
.../tests/_files/BaseTestListenerSample.php | 11 +
.../tests/_files/BeforeAndAfterTest.php | 35 +
.../_files/BeforeClassAndAfterClassTest.php | 35 +
.../BeforeClassWithOnlyDataProviderTest.php | 39 +
vendor/phpunit/phpunit/tests/_files/Book.php | 19 +
.../phpunit/tests/_files/Calculator.php | 14 +
.../ChangeCurrentWorkingDirectoryTest.php | 9 +
.../_files/ClassWithNonPublicAttributes.php | 29 +
.../ClassWithScalarTypeDeclarations.php | 7 +
.../tests/_files/ClassWithToString.php | 21 +
.../tests/_files/ClonedDependencyTest.php | 39 +
.../phpunit/tests/_files/ConcreteTest.my.php | 7 +
.../phpunit/tests/_files/ConcreteTest.php | 7 +
.../_files/CoverageClassExtendedTest.php | 12 +
.../tests/_files/CoverageClassTest.php | 12 +
.../CoverageFunctionParenthesesTest.php | 11 +
...erageFunctionParenthesesWhitespaceTest.php | 11 +
.../tests/_files/CoverageFunctionTest.php | 11 +
.../CoverageMethodOneLineAnnotationTest.php | 11 +
.../_files/CoverageMethodParenthesesTest.php | 12 +
...overageMethodParenthesesWhitespaceTest.php | 12 +
.../tests/_files/CoverageMethodTest.php | 12 +
.../_files/CoverageNamespacedFunctionTest.php | 11 +
.../phpunit/tests/_files/CoverageNoneTest.php | 9 +
.../tests/_files/CoverageNotPrivateTest.php | 12 +
.../tests/_files/CoverageNotProtectedTest.php | 12 +
.../tests/_files/CoverageNotPublicTest.php | 12 +
.../tests/_files/CoverageNothingTest.php | 13 +
.../tests/_files/CoveragePrivateTest.php | 12 +
.../tests/_files/CoverageProtectedTest.php | 12 +
.../tests/_files/CoveragePublicTest.php | 12 +
.../CoverageTwoDefaultClassAnnotations.php | 17 +
.../phpunit/tests/_files/CoveredClass.php | 36 +
.../phpunit/tests/_files/CoveredFunction.php | 4 +
.../phpunit/tests/_files/CustomPrinter.php | 4 +
.../tests/_files/DataProviderDebugTest.php | 48 +
.../_files/DataProviderDependencyTest.php | 25 +
.../tests/_files/DataProviderFilterTest.php | 39 +
.../_files/DataProviderIncompleteTest.php | 37 +
.../DataProviderIssue2833/FirstTest.php | 23 +
.../DataProviderIssue2833/SecondTest.php | 15 +
.../_files/DataProviderIssue2859/phpunit.xml | 10 +
.../another/TestWithDataProviderTest.php | 21 +
.../DataProviderIssue2922/FirstTest.php | 24 +
.../DataProviderIssue2922/SecondTest.php | 14 +
.../tests/_files/DataProviderSkippedTest.php | 37 +
.../phpunit/tests/_files/DataProviderTest.php | 21 +
.../tests/_files/DataProviderTestDoxTest.php | 26 +
.../tests/_files/DependencyFailureTest.php | 29 +
.../tests/_files/DependencySuccessTest.php | 21 +
.../tests/_files/DependencyTestSuite.php | 13 +
.../phpunit/tests/_files/DoubleTestCase.php | 25 +
.../phpunit/tests/_files/DummyException.php | 5 +
.../tests/_files/EmptyTestCaseTest.php | 4 +
.../ExceptionInAssertPostConditionsTest.php | 35 +
.../ExceptionInAssertPreConditionsTest.php | 35 +
.../tests/_files/ExceptionInSetUpTest.php | 35 +
.../tests/_files/ExceptionInTearDownTest.php | 35 +
.../phpunit/tests/_files/ExceptionInTest.php | 35 +
.../tests/_files/ExceptionNamespaceTest.php | 38 +
.../tests/_files/ExceptionStackTest.php | 21 +
.../phpunit/tests/_files/ExceptionTest.php | 139 +
.../phpunit/phpunit/tests/_files/Failure.php | 8 +
.../phpunit/tests/_files/FailureTest.php | 75 +
.../phpunit/tests/_files/FatalTest.php | 13 +
.../tests/_files/IgnoreCodeCoverageClass.php | 16 +
.../_files/IgnoreCodeCoverageClassTest.php | 15 +
.../phpunit/tests/_files/IncompleteTest.php | 8 +
.../tests/_files/Inheritance/InheritanceA.php | 7 +
.../tests/_files/Inheritance/InheritanceB.php | 8 +
.../tests/_files/InheritedTestCase.php | 7 +
.../phpunit/phpunit/tests/_files/IniTest.php | 8 +
.../phpunit/tests/_files/IsolationTest.php | 13 +
.../tests/_files/JsonData/arrayObject.json | 1 +
.../tests/_files/JsonData/simpleObject.json | 1 +
.../phpunit/tests/_files/MockRunner.php | 7 +
.../phpunit/phpunit/tests/_files/Mockable.php | 26 +
.../tests/_files/MultiDependencyTest.php | 23 +
.../tests/_files/MultipleDataProviderTest.php | 75 +
.../phpunit/tests/_files/MyCommand.php | 15 +
.../NamespaceCoverageClassExtendedTest.php | 12 +
.../_files/NamespaceCoverageClassTest.php | 12 +
...NamespaceCoverageCoversClassPublicTest.php | 15 +
.../NamespaceCoverageCoversClassTest.php | 20 +
.../_files/NamespaceCoverageMethodTest.php | 12 +
.../NamespaceCoverageNotPrivateTest.php | 12 +
.../NamespaceCoverageNotProtectedTest.php | 12 +
.../_files/NamespaceCoverageNotPublicTest.php | 12 +
.../_files/NamespaceCoveragePrivateTest.php | 12 +
.../_files/NamespaceCoverageProtectedTest.php | 12 +
.../_files/NamespaceCoveragePublicTest.php | 12 +
.../tests/_files/NamespaceCoveredClass.php | 38 +
.../tests/_files/NamespaceCoveredFunction.php | 7 +
.../tests/_files/NoArgTestCaseTest.php | 7 +
.../phpunit/tests/_files/NoTestCaseClass.php | 4 +
.../phpunit/tests/_files/NoTestCases.php | 7 +
.../phpunit/tests/_files/NonStatic.php | 8 +
.../_files/NotExistingCoveredElementTest.php | 24 +
.../tests/_files/NotPublicTestCase.php | 11 +
.../phpunit/tests/_files/NotVoidTestCase.php | 4 +
.../phpunit/tests/_files/NothingTest.php | 7 +
.../phpunit/tests/_files/OneTestCase.php | 11 +
.../phpunit/tests/_files/OutputTestCase.php | 27 +
.../phpunit/tests/_files/OverrideTestCase.php | 7 +
.../RequirementsClassBeforeClassHookTest.php | 12 +
.../_files/RequirementsClassDocBlockTest.php | 22 +
.../phpunit/tests/_files/RequirementsTest.php | 345 +
.../tests/_files/SampleArrayAccess.php | 36 +
.../phpunit/tests/_files/SampleClass.php | 14 +
.../phpunit/tests/_files/Singleton.php | 22 +
.../phpunit/tests/_files/StackTest.php | 24 +
.../phpunit/tests/_files/StatusTest.php | 37 +
.../tests/_files/StopOnWarningTestSuite.php | 13 +
.../tests/_files/StopsOnWarningTest.php | 7 +
.../phpunit/phpunit/tests/_files/Struct.php | 10 +
.../phpunit/phpunit/tests/_files/Success.php | 7 +
.../tests/_files/TemplateMethodsTest.php | 51 +
.../tests/_files/TestAutoreferenced.php | 12 +
.../phpunit/tests/_files/TestDoxGroupTest.php | 18 +
.../tests/_files/TestGeneratorMaker.php | 11 +
.../phpunit/tests/_files/TestIncomplete.php | 8 +
.../phpunit/tests/_files/TestIterator.php | 36 +
.../phpunit/tests/_files/TestIterator2.php | 35 +
.../phpunit/tests/_files/TestSkipped.php | 8 +
.../phpunit/tests/_files/TestTestError.php | 8 +
.../phpunit/tests/_files/TestWithTest.php | 24 +
.../tests/_files/ThrowExceptionTestCase.php | 8 +
.../tests/_files/ThrowNoExceptionTestCase.php | 7 +
.../phpunit/phpunit/tests/_files/WasRun.php | 10 +
vendor/phpunit/phpunit/tests/_files/bar.xml | 1 +
.../_files/configuration.colors.empty.xml | 1 +
.../_files/configuration.colors.false.xml | 1 +
.../_files/configuration.colors.invalid.xml | 1 +
.../_files/configuration.colors.true.xml | 1 +
.../_files/configuration.custom-printer.xml | 2 +
.../tests/_files/configuration.suites.xml | 6 +
.../phpunit/tests/_files/configuration.xml | 121 +
.../tests/_files/configuration_empty.xml | 49 +
.../_files/configuration_stop_on_warning.xml | 2 +
.../tests/_files/configuration_xinclude.xml | 74 +
.../tests/_files/expectedFileFormat.txt | 1 +
vendor/phpunit/phpunit/tests/_files/foo.xml | 1 +
.../tests/_files/phpt-for-coverage.phpt | 8 +
.../phpunit/tests/_files/phpt-xfail.phpt | 11 +
.../phpunit-example-extension/phpunit.xml | 10 +
.../tests/OneTest.php | 12 +
.../phpunit-example-extension-1.0.0.phar | Bin 0 -> 3187 bytes
...uctureAttributesAreSameButValuesAreNot.xml | 10 +
.../tests/_files/structureExpected.xml | 10 +
.../tests/_files/structureIgnoreTextNodes.xml | 13 +
.../_files/structureIsSameButDataIsNot.xml | 10 +
.../structureWrongNumberOfAttributes.xml | 10 +
.../_files/structureWrongNumberOfNodes.xml | 9 +
vendor/phpunit/phpunit/tests/bootstrap.php | 6 +
vendor/psr/log/LICENSE | 19 +
vendor/psr/log/Psr/Log/AbstractLogger.php | 128 +
.../log/Psr/Log/InvalidArgumentException.php | 7 +
vendor/psr/log/Psr/Log/LogLevel.php | 18 +
.../psr/log/Psr/Log/LoggerAwareInterface.php | 18 +
vendor/psr/log/Psr/Log/LoggerAwareTrait.php | 26 +
vendor/psr/log/Psr/Log/LoggerInterface.php | 125 +
vendor/psr/log/Psr/Log/LoggerTrait.php | 142 +
vendor/psr/log/Psr/Log/NullLogger.php | 30 +
vendor/psr/log/Psr/Log/Test/DummyTest.php | 18 +
.../log/Psr/Log/Test/LoggerInterfaceTest.php | 138 +
vendor/psr/log/Psr/Log/Test/TestLogger.php | 147 +
vendor/psr/log/README.md | 58 +
vendor/psr/log/composer.json | 26 +
vendor/psy/psysh/.editorconfig | 15 +
vendor/psy/psysh/.github/CONTRIBUTING.md | 9 +
vendor/psy/psysh/.gitignore | 9 +
vendor/psy/psysh/.phan/config.php | 46 +
vendor/psy/psysh/.php_cs | 32 +
vendor/psy/psysh/.styleci.yml | 29 +
vendor/psy/psysh/.travis.yml | 47 +
vendor/psy/psysh/LICENSE | 21 +
vendor/psy/psysh/Makefile | 95 +
vendor/psy/psysh/README.md | 34 +
vendor/psy/psysh/bin/build-stub | 22 +
vendor/psy/psysh/bin/psysh | 138 +
vendor/psy/psysh/box.json.dist | 12 +
vendor/psy/psysh/composer.json | 54 +
vendor/psy/psysh/phpunit.xml.dist | 12 +
vendor/psy/psysh/src/CodeCleaner.php | 349 +
.../src/CodeCleaner/AbstractClassPass.php | 71 +
.../CodeCleaner/AssignThisVariablePass.php | 39 +
.../CallTimePassByReferencePass.php | 50 +
.../psysh/src/CodeCleaner/CalledClassPass.php | 83 +
.../psysh/src/CodeCleaner/CodeCleanerPass.php | 22 +
vendor/psy/psysh/src/CodeCleaner/ExitPass.php | 32 +
.../psysh/src/CodeCleaner/FinalClassPass.php | 70 +
.../src/CodeCleaner/FunctionContextPass.php | 61 +
.../FunctionReturnInWriteContextPass.php | 81 +
.../src/CodeCleaner/ImplicitReturnPass.php | 128 +
.../psysh/src/CodeCleaner/InstanceOfPass.php | 47 +
.../src/CodeCleaner/LeavePsyshAlonePass.php | 36 +
.../psysh/src/CodeCleaner/LegacyEmptyPass.php | 73 +
vendor/psy/psysh/src/CodeCleaner/ListPass.php | 112 +
.../psysh/src/CodeCleaner/LoopContextPass.php | 103 +
.../src/CodeCleaner/MagicConstantsPass.php | 42 +
.../src/CodeCleaner/NamespaceAwarePass.php | 71 +
.../psysh/src/CodeCleaner/NamespacePass.php | 88 +
.../psysh/src/CodeCleaner/NoReturnValue.php | 35 +
.../CodeCleaner/PassableByReferencePass.php | 109 +
.../psy/psysh/src/CodeCleaner/RequirePass.php | 101 +
.../psysh/src/CodeCleaner/StrictTypesPass.php | 87 +
.../src/CodeCleaner/UseStatementPass.php | 126 +
.../src/CodeCleaner/ValidClassNamePass.php | 411 +
.../src/CodeCleaner/ValidConstantPass.php | 90 +
.../src/CodeCleaner/ValidConstructorPass.php | 112 +
.../src/CodeCleaner/ValidFunctionNamePass.php | 97 +
.../psy/psysh/src/Command/BufferCommand.php | 79 +
vendor/psy/psysh/src/Command/ClearCommand.php | 51 +
vendor/psy/psysh/src/Command/Command.php | 282 +
vendor/psy/psysh/src/Command/DocCommand.php | 133 +
vendor/psy/psysh/src/Command/DumpCommand.php | 96 +
vendor/psy/psysh/src/Command/EditCommand.php | 189 +
vendor/psy/psysh/src/Command/ExitCommand.php | 52 +
vendor/psy/psysh/src/Command/HelpCommand.php | 100 +
.../psy/psysh/src/Command/HistoryCommand.php | 248 +
vendor/psy/psysh/src/Command/ListCommand.php | 278 +
.../ListCommand/ClassConstantEnumerator.php | 127 +
.../Command/ListCommand/ClassEnumerator.php | 126 +
.../ListCommand/ConstantEnumerator.php | 122 +
.../src/Command/ListCommand/Enumerator.php | 106 +
.../ListCommand/FunctionEnumerator.php | 112 +
.../ListCommand/GlobalVariableEnumerator.php | 92 +
.../ListCommand/InterfaceEnumerator.php | 89 +
.../Command/ListCommand/MethodEnumerator.php | 145 +
.../ListCommand/PropertyEnumerator.php | 180 +
.../Command/ListCommand/TraitEnumerator.php | 89 +
.../ListCommand/VariableEnumerator.php | 137 +
vendor/psy/psysh/src/Command/ParseCommand.php | 182 +
.../psysh/src/Command/PsyVersionCommand.php | 43 +
.../psysh/src/Command/ReflectingCommand.php | 303 +
vendor/psy/psysh/src/Command/ShowCommand.php | 292 +
vendor/psy/psysh/src/Command/SudoCommand.php | 145 +
.../psy/psysh/src/Command/ThrowUpCommand.php | 174 +
.../psy/psysh/src/Command/TimeitCommand.php | 197 +
.../Command/TimeitCommand/TimeitVisitor.php | 139 +
vendor/psy/psysh/src/Command/TraceCommand.php | 169 +
.../psy/psysh/src/Command/WhereamiCommand.php | 149 +
vendor/psy/psysh/src/Command/WtfCommand.php | 127 +
vendor/psy/psysh/src/ConfigPaths.php | 237 +
vendor/psy/psysh/src/Configuration.php | 1307 +
vendor/psy/psysh/src/ConsoleColorFactory.php | 82 +
vendor/psy/psysh/src/Context.php | 320 +
vendor/psy/psysh/src/ContextAware.php | 28 +
.../psysh/src/Exception/BreakException.php | 51 +
.../src/Exception/DeprecatedException.php | 20 +
.../psysh/src/Exception/ErrorException.php | 114 +
vendor/psy/psysh/src/Exception/Exception.php | 27 +
.../src/Exception/FatalErrorException.php | 52 +
.../src/Exception/ParseErrorException.php | 42 +
.../psysh/src/Exception/RuntimeException.php | 43 +
.../psysh/src/Exception/ThrowUpException.php | 57 +
.../src/Exception/TypeErrorException.php | 55 +
vendor/psy/psysh/src/ExecutionClosure.php | 119 +
vendor/psy/psysh/src/ExecutionLoop.php | 67 +
.../src/ExecutionLoop/AbstractListener.php | 62 +
.../psy/psysh/src/ExecutionLoop/Listener.php | 83 +
.../psysh/src/ExecutionLoop/ProcessForker.php | 219 +
.../src/ExecutionLoop/RunkitReloader.php | 135 +
vendor/psy/psysh/src/ExecutionLoopClosure.php | 104 +
.../psy/psysh/src/Formatter/CodeFormatter.php | 71 +
.../psysh/src/Formatter/DocblockFormatter.php | 168 +
vendor/psy/psysh/src/Formatter/Formatter.php | 25 +
.../src/Formatter/SignatureFormatter.php | 308 +
vendor/psy/psysh/src/Input/CodeArgument.php | 50 +
vendor/psy/psysh/src/Input/FilterOptions.php | 145 +
vendor/psy/psysh/src/Input/ShellInput.php | 336 +
vendor/psy/psysh/src/Input/SilentInput.php | 44 +
vendor/psy/psysh/src/Output/OutputPager.php | 26 +
vendor/psy/psysh/src/Output/PassthruPager.php | 39 +
.../psy/psysh/src/Output/ProcOutputPager.php | 103 +
vendor/psy/psysh/src/Output/ShellOutput.php | 204 +
vendor/psy/psysh/src/ParserFactory.php | 91 +
vendor/psy/psysh/src/Readline/GNUReadline.php | 170 +
vendor/psy/psysh/src/Readline/HoaConsole.php | 107 +
vendor/psy/psysh/src/Readline/Libedit.php | 83 +
vendor/psy/psysh/src/Readline/Readline.php | 76 +
vendor/psy/psysh/src/Readline/Transient.php | 147 +
.../Reflection/ReflectionClassConstant.php | 228 +
.../src/Reflection/ReflectionConstant.php | 30 +
.../src/Reflection/ReflectionConstant_.php | 182 +
.../ReflectionLanguageConstruct.php | 164 +
.../ReflectionLanguageConstructParameter.php | 103 +
vendor/psy/psysh/src/Shell.php | 1339 +
vendor/psy/psysh/src/Sudo.php | 150 +
vendor/psy/psysh/src/Sudo/SudoVisitor.php | 124 +
.../psysh/src/TabCompletion/AutoCompleter.php | 110 +
.../Matcher/AbstractContextAwareMatcher.php | 65 +
.../AbstractDefaultParametersMatcher.php | 76 +
.../TabCompletion/Matcher/AbstractMatcher.php | 195 +
.../Matcher/ClassAttributesMatcher.php | 87 +
.../ClassMethodDefaultParametersMatcher.php | 64 +
.../Matcher/ClassMethodsMatcher.php | 84 +
.../Matcher/ClassNamesMatcher.php | 77 +
.../TabCompletion/Matcher/CommandsMatcher.php | 114 +
.../Matcher/ConstantsMatcher.php | 54 +
.../FunctionDefaultParametersMatcher.php | 53 +
.../Matcher/FunctionsMatcher.php | 56 +
.../TabCompletion/Matcher/KeywordsMatcher.php | 85 +
.../Matcher/MongoClientMatcher.php | 71 +
.../Matcher/MongoDatabaseMatcher.php | 67 +
.../Matcher/ObjectAttributesMatcher.php | 78 +
.../ObjectMethodDefaultParametersMatcher.php | 71 +
.../Matcher/ObjectMethodsMatcher.php | 80 +
.../Matcher/VariablesMatcher.php | 51 +
vendor/psy/psysh/src/Util/Docblock.php | 241 +
vendor/psy/psysh/src/Util/Json.php | 33 +
vendor/psy/psysh/src/Util/Mirror.php | 99 +
vendor/psy/psysh/src/Util/Str.php | 114 +
vendor/psy/psysh/src/VarDumper/Cloner.php | 42 +
vendor/psy/psysh/src/VarDumper/Dumper.php | 109 +
vendor/psy/psysh/src/VarDumper/Presenter.php | 137 +
.../psysh/src/VarDumper/PresenterAware.php | 26 +
.../psy/psysh/src/VersionUpdater/Checker.php | 31 +
.../src/VersionUpdater/GitHubChecker.php | 89 +
.../src/VersionUpdater/IntervalChecker.php | 67 +
.../psysh/src/VersionUpdater/NoopChecker.php | 36 +
vendor/psy/psysh/src/functions.php | 358 +
vendor/psy/psysh/test/ClassWithSecrets.php | 37 +
.../CodeCleaner/AbstractClassPassTest.php | 57 +
.../AssignThisVariablePassTest.php | 58 +
.../CallTimePassByReferencePassTest.php | 59 +
.../test/CodeCleaner/CalledClassPassTest.php | 90 +
.../test/CodeCleaner/CodeCleanerTestCase.php | 41 +
.../psysh/test/CodeCleaner/ExitPassTest.php | 59 +
.../test/CodeCleaner/FinalClassPassTest.php | 65 +
.../Fixtures/ClassWithCallStatic.php | 20 +
.../CodeCleaner/Fixtures/ClassWithStatic.php | 20 +
.../CodeCleaner/Fixtures/TraitWithStatic.php | 20 +
.../CodeCleaner/FunctionContextPassTest.php | 56 +
.../FunctionReturnInWriteContextPassTest.php | 91 +
.../CodeCleaner/ImplicitReturnPassTest.php | 112 +
.../test/CodeCleaner/InstanceOfPassTest.php | 72 +
.../CodeCleaner/LeavePsyshAlonePassTest.php | 69 +
.../test/CodeCleaner/LegacyEmptyPassTest.php | 76 +
.../psysh/test/CodeCleaner/ListPassTest.php | 115 +
.../test/CodeCleaner/LoopContextPassTest.php | 108 +
.../CodeCleaner/MagicConstantsPassTest.php | 39 +
.../test/CodeCleaner/NamespacePassTest.php | 59 +
.../test/CodeCleaner/NoReturnValueTest.php | 32 +
.../PassableByReferencePassTest.php | 104 +
.../test/CodeCleaner/RequirePassTest.php | 93 +
.../test/CodeCleaner/StrictTypesPassTest.php | 52 +
.../test/CodeCleaner/UseStatementPassTest.php | 102 +
.../CodeCleaner/ValidClassNamePassTest.php | 325 +
.../CodeCleaner/ValidConstantPassTest.php | 65 +
.../CodeCleaner/ValidConstructorPassTest.php | 93 +
.../CodeCleaner/ValidFunctionNamePassTest.php | 180 +
vendor/psy/psysh/test/CodeCleanerTest.php | 131 +
.../psysh/test/Command/ExitCommandTest.php | 29 +
.../psysh/test/Command/ThrowUpCommandTest.php | 89 +
.../TimeitCommand/TimeitVisitorTest.php | 52 +
vendor/psy/psysh/test/ConfigurationTest.php | 256 +
.../psysh/test/ConsoleColorFactoryTest.php | 51 +
vendor/psy/psysh/test/ContextTest.php | 325 +
.../test/Exception/BreakExceptionTest.php | 42 +
.../test/Exception/ErrorExceptionTest.php | 125 +
.../Exception/FatalErrorExceptionTest.php | 51 +
.../Exception/ParseErrorExceptionTest.php | 42 +
.../test/Exception/RuntimeExceptionTest.php | 30 +
.../test/Exception/ThrowUpExceptionTest.php | 66 +
.../test/Exception/TypeErrorExceptionTest.php | 52 +
vendor/psy/psysh/test/FakeShell.php | 29 +
.../test/Formatter/CodeFormatterTest.php | 129 +
.../test/Formatter/DocblockFormatterTest.php | 63 +
.../test/Formatter/Fixtures/BoringTrait.php | 20 +
.../test/Formatter/Fixtures/SomeClass.php | 30 +
.../test/Formatter/SignatureFormatterTest.php | 95 +
.../psy/psysh/test/Input/CodeArgumentTest.php | 52 +
.../psysh/test/Input/FilterOptionsTest.php | 105 +
.../psy/psysh/test/Input/ShellInputTest.php | 254 +
vendor/psy/psysh/test/ParserTestCase.php | 97 +
.../psysh/test/Readline/GNUReadlineTest.php | 80 +
.../psysh/test/Readline/HoaConsoleTest.php | 31 +
.../psy/psysh/test/Readline/LibeditTest.php | 128 +
.../psy/psysh/test/Readline/TransientTest.php | 76 +
.../ReflectionClassConstantTest.php | 81 +
.../Reflection/ReflectionConstantBCTest.php | 26 +
.../Reflection/ReflectionConstantTest.php | 114 +
...flectionLanguageConstructParameterTest.php | 64 +
.../ReflectionLanguageConstructTest.php | 102 +
vendor/psy/psysh/test/ShellTest.php | 442 +
.../psy/psysh/test/Sudo/SudoVisitorTest.php | 142 +
vendor/psy/psysh/test/SudoTest.php | 80 +
.../test/TabCompletion/AutoCompleterTest.php | 145 +
.../psysh/test/TabCompletion/StaticSample.php | 27 +
vendor/psy/psysh/test/Util/DocblockTest.php | 100 +
vendor/psy/psysh/test/Util/MirrorTest.php | 86 +
vendor/psy/psysh/test/Util/StrTest.php | 31 +
.../test/VersionUpdater/GitHubCheckerTest.php | 82 +
.../test/VersionUpdater/NoopCheckerTest.php | 25 +
vendor/psy/psysh/test/fixtures/config.php | 20 +
.../fixtures/default/.config/psysh/config.php | 1 +
.../default/.config/psysh/psysh_history | 0
.../.local/share/psysh/php_manual.sqlite | 0
vendor/psy/psysh/test/fixtures/empty.php | 12 +
.../psysh/test/fixtures/legacy/.psysh/history | 0
.../fixtures/legacy/.psysh/php_manual.sqlite | 0
.../psysh/test/fixtures/legacy/.psysh/rc.php | 1 +
.../test/fixtures/mixed/.psysh/config.php | 1 +
.../test/fixtures/mixed/.psysh/psysh_history | 0
.../psysh/test/fixtures/mixed/.psysh/rc.php | 1 +
.../psysh/test/fixtures/project/.psysh.php | 17 +
.../psysh/test/fixtures/unvis_fixtures.json | 1 +
.../psysh/test/tools/gen_unvis_fixtures.py | 94 +
vendor/psy/psysh/test/tools/vis.py | 126 +
vendor/psy/psysh/vendor-bin/box/composer.json | 7 +
vendor/psy/psysh/vendor-bin/box/composer.lock | 2524 ++
vendor/ramsey/uuid/LICENSE | 21 +
vendor/ramsey/uuid/README.md | 187 +
vendor/ramsey/uuid/composer.json | 95 +
vendor/ramsey/uuid/src/BinaryUtils.php | 41 +
.../uuid/src/Builder/DefaultUuidBuilder.php | 54 +
.../uuid/src/Builder/DegradedUuidBuilder.php | 53 +
.../uuid/src/Builder/UuidBuilderInterface.php | 34 +
.../ramsey/uuid/src/Codec/CodecInterface.php | 60 +
.../ramsey/uuid/src/Codec/GuidStringCodec.php | 103 +
.../uuid/src/Codec/OrderedTimeCodec.php | 68 +
vendor/ramsey/uuid/src/Codec/StringCodec.php | 170 +
.../src/Codec/TimestampFirstCombCodec.php | 108 +
.../uuid/src/Codec/TimestampLastCombCodec.php | 22 +
.../Converter/Number/BigNumberConverter.php | 54 +
.../Number/DegradedNumberConverter.php | 58 +
.../Converter/NumberConverterInterface.php | 48 +
.../Converter/Time/BigNumberTimeConverter.php | 59 +
.../Converter/Time/DegradedTimeConverter.php | 42 +
.../src/Converter/Time/PhpTimeConverter.php | 47 +
.../src/Converter/TimeConverterInterface.php | 37 +
vendor/ramsey/uuid/src/DegradedUuid.php | 116 +
.../Exception/InvalidUuidStringException.php | 24 +
.../UnsatisfiedDependencyException.php | 25 +
.../UnsupportedOperationException.php | 24 +
vendor/ramsey/uuid/src/FeatureSet.php | 335 +
.../uuid/src/Generator/CombGenerator.php | 91 +
.../src/Generator/DefaultTimeGenerator.php | 141 +
.../uuid/src/Generator/MtRandGenerator.php | 45 +
.../uuid/src/Generator/OpenSslGenerator.php | 43 +
.../src/Generator/PeclUuidRandomGenerator.php | 37 +
.../src/Generator/PeclUuidTimeGenerator.php | 38 +
.../src/Generator/RandomBytesGenerator.php | 39 +
.../src/Generator/RandomGeneratorFactory.php | 31 +
.../Generator/RandomGeneratorInterface.php | 37 +
.../uuid/src/Generator/RandomLibAdapter.php | 62 +
.../src/Generator/SodiumRandomGenerator.php | 41 +
.../src/Generator/TimeGeneratorFactory.php | 72 +
.../src/Generator/TimeGeneratorInterface.php | 43 +
.../Provider/Node/FallbackNodeProvider.php | 59 +
.../src/Provider/Node/RandomNodeProvider.php | 57 +
.../src/Provider/Node/SystemNodeProvider.php | 128 +
.../src/Provider/NodeProviderInterface.php | 32 +
.../src/Provider/Time/FixedTimeProvider.php | 77 +
.../src/Provider/Time/SystemTimeProvider.php | 33 +
.../src/Provider/TimeProviderInterface.php | 29 +
vendor/ramsey/uuid/src/Uuid.php | 781 +
vendor/ramsey/uuid/src/UuidFactory.php | 315 +
.../ramsey/uuid/src/UuidFactoryInterface.php | 108 +
vendor/ramsey/uuid/src/UuidInterface.php | 274 +
vendor/ramsey/uuid/src/functions.php | 78 +
.../code-unit-reverse-lookup/.gitignore | 4 +
.../code-unit-reverse-lookup/.php_cs | 67 +
.../code-unit-reverse-lookup/.travis.yml | 25 +
.../code-unit-reverse-lookup/ChangeLog.md | 15 +
.../code-unit-reverse-lookup/LICENSE | 33 +
.../code-unit-reverse-lookup/README.md | 14 +
.../code-unit-reverse-lookup/build.xml | 22 +
.../code-unit-reverse-lookup/composer.json | 28 +
.../code-unit-reverse-lookup/phpunit.xml | 21 +
.../code-unit-reverse-lookup/src/Wizard.php | 111 +
.../tests/WizardTest.php | 45 +
vendor/sebastian/comparator/.gitignore | 6 +
vendor/sebastian/comparator/.travis.yml | 25 +
vendor/sebastian/comparator/LICENSE | 33 +
vendor/sebastian/comparator/README.md | 39 +
vendor/sebastian/comparator/build.xml | 34 +
.../sebastian/comparator/build/travis-ci.xml | 11 +
vendor/sebastian/comparator/composer.json | 44 +
vendor/sebastian/comparator/phpunit.xml.dist | 21 +
.../comparator/src/ArrayComparator.php | 132 +
.../sebastian/comparator/src/Comparator.php | 64 +
.../comparator/src/ComparisonFailure.php | 129 +
.../comparator/src/DOMNodeComparator.php | 107 +
.../comparator/src/DateTimeComparator.php | 77 +
.../comparator/src/DoubleComparator.php | 56 +
.../comparator/src/ExceptionComparator.php | 51 +
vendor/sebastian/comparator/src/Factory.php | 107 +
.../comparator/src/MockObjectComparator.php | 45 +
.../comparator/src/NumericComparator.php | 68 +
.../comparator/src/ObjectComparator.php | 105 +
.../comparator/src/ResourceComparator.php | 52 +
.../comparator/src/ScalarComparator.php | 90 +
.../src/SplObjectStorageComparator.php | 69 +
.../comparator/src/TypeComparator.php | 59 +
.../comparator/tests/ArrayComparatorTest.php | 163 +
.../tests/DOMNodeComparatorTest.php | 162 +
.../tests/DateTimeComparatorTest.php | 216 +
.../comparator/tests/DoubleComparatorTest.php | 134 +
.../tests/ExceptionComparatorTest.php | 136 +
.../comparator/tests/FactoryTest.php | 115 +
.../tests/MockObjectComparatorTest.php | 166 +
.../tests/NumericComparatorTest.php | 122 +
.../comparator/tests/ObjectComparatorTest.php | 150 +
.../tests/ResourceComparatorTest.php | 120 +
.../comparator/tests/ScalarComparatorTest.php | 158 +
.../tests/SplObjectStorageComparatorTest.php | 137 +
.../comparator/tests/TypeComparatorTest.php | 104 +
.../comparator/tests/_files/Author.php | 28 +
.../comparator/tests/_files/Book.php | 21 +
.../tests/_files/ClassWithToString.php | 19 +
.../comparator/tests/_files/SampleClass.php | 29 +
.../comparator/tests/_files/Struct.php | 25 +
.../comparator/tests/_files/TestClass.php | 14 +
.../tests/_files/TestClassComparator.php | 14 +
.../sebastian/comparator/tests/autoload.php | 38 +
.../sebastian/comparator/tests/bootstrap.php | 7 +
vendor/sebastian/diff/.gitignore | 4 +
vendor/sebastian/diff/.php_cs | 79 +
vendor/sebastian/diff/.travis.yml | 31 +
vendor/sebastian/diff/LICENSE | 33 +
vendor/sebastian/diff/README.md | 126 +
vendor/sebastian/diff/build.xml | 22 +
vendor/sebastian/diff/composer.json | 33 +
vendor/sebastian/diff/phpunit.xml | 19 +
vendor/sebastian/diff/src/Chunk.php | 103 +
vendor/sebastian/diff/src/Diff.php | 73 +
vendor/sebastian/diff/src/Differ.php | 399 +
.../diff/src/LCS/LongestCommonSubsequence.php | 27 +
...LongestCommonSubsequenceImplementation.php | 95 +
...LongestCommonSubsequenceImplementation.php | 74 +
vendor/sebastian/diff/src/Line.php | 54 +
vendor/sebastian/diff/src/Parser.php | 110 +
vendor/sebastian/diff/tests/ChunkTest.php | 68 +
vendor/sebastian/diff/tests/DiffTest.php | 55 +
vendor/sebastian/diff/tests/DifferTest.php | 415 +
.../LCS/LongestCommonSubsequenceTest.php | 198 +
.../LCS/MemoryEfficientImplementationTest.php | 22 +
.../LCS/TimeEfficientImplementationTest.php | 22 +
vendor/sebastian/diff/tests/LineTest.php | 44 +
vendor/sebastian/diff/tests/ParserTest.php | 151 +
.../sebastian/diff/tests/fixtures/patch.txt | 9 +
.../sebastian/diff/tests/fixtures/patch2.txt | 21 +
vendor/sebastian/environment/.gitignore | 4 +
vendor/sebastian/environment/.travis.yml | 16 +
vendor/sebastian/environment/LICENSE | 33 +
vendor/sebastian/environment/README.md | 72 +
vendor/sebastian/environment/build.xml | 26 +
vendor/sebastian/environment/composer.json | 30 +
vendor/sebastian/environment/phpunit.xml | 20 +
vendor/sebastian/environment/src/Console.php | 113 +
vendor/sebastian/environment/src/Runtime.php | 194 +
.../environment/tests/ConsoleTest.php | 62 +
.../environment/tests/RuntimeTest.php | 120 +
vendor/sebastian/exporter/.gitignore | 9 +
vendor/sebastian/exporter/.travis.yml | 23 +
vendor/sebastian/exporter/LICENSE | 33 +
vendor/sebastian/exporter/README.md | 172 +
vendor/sebastian/exporter/build.xml | 27 +
vendor/sebastian/exporter/composer.json | 48 +
vendor/sebastian/exporter/phpunit.xml.dist | 21 +
vendor/sebastian/exporter/src/Exporter.php | 303 +
.../sebastian/exporter/tests/ExporterTest.php | 358 +
vendor/sebastian/global-state/.gitignore | 6 +
vendor/sebastian/global-state/.travis.yml | 20 +
vendor/sebastian/global-state/LICENSE | 33 +
vendor/sebastian/global-state/README.md | 15 +
vendor/sebastian/global-state/build.xml | 33 +
vendor/sebastian/global-state/composer.json | 37 +
.../sebastian/global-state/phpunit.xml.dist | 21 +
.../sebastian/global-state/src/Blacklist.php | 149 +
.../global-state/src/CodeExporter.php | 93 +
.../sebastian/global-state/src/Exception.php | 17 +
.../sebastian/global-state/src/Restorer.php | 141 +
.../global-state/src/RuntimeException.php | 17 +
.../sebastian/global-state/src/Snapshot.php | 423 +
.../global-state/tests/BlacklistTest.php | 113 +
.../global-state/tests/SnapshotTest.php | 119 +
.../tests/_fixture/BlacklistedChildClass.php | 17 +
.../tests/_fixture/BlacklistedClass.php | 18 +
.../tests/_fixture/BlacklistedImplementor.php | 18 +
.../tests/_fixture/BlacklistedInterface.php | 17 +
.../tests/_fixture/SnapshotClass.php | 37 +
.../tests/_fixture/SnapshotDomDocument.php | 19 +
.../tests/_fixture/SnapshotFunctions.php | 15 +
.../tests/_fixture/SnapshotTrait.php | 17 +
vendor/sebastian/object-enumerator/.gitignore | 8 +
vendor/sebastian/object-enumerator/.php_cs | 67 +
.../sebastian/object-enumerator/.travis.yml | 23 +
.../sebastian/object-enumerator/ChangeLog.md | 25 +
vendor/sebastian/object-enumerator/LICENSE | 33 +
vendor/sebastian/object-enumerator/README.md | 14 +
vendor/sebastian/object-enumerator/build.xml | 23 +
.../sebastian/object-enumerator/composer.json | 34 +
.../sebastian/object-enumerator/phpunit.xml | 20 +
.../object-enumerator/src/Enumerator.php | 93 +
.../object-enumerator/src/Exception.php | 15 +
.../src/InvalidArgumentException.php | 15 +
.../tests/EnumeratorTest.php | 138 +
.../tests/Fixtures/ExceptionThrower.php | 28 +
vendor/sebastian/recursion-context/.gitignore | 9 +
.../sebastian/recursion-context/.travis.yml | 21 +
vendor/sebastian/recursion-context/LICENSE | 33 +
vendor/sebastian/recursion-context/README.md | 14 +
vendor/sebastian/recursion-context/build.xml | 27 +
.../sebastian/recursion-context/composer.json | 36 +
.../recursion-context/phpunit.xml.dist | 20 +
.../recursion-context/src/Context.php | 167 +
.../recursion-context/src/Exception.php | 17 +
.../src/InvalidArgumentException.php | 17 +
.../recursion-context/tests/ContextTest.php | 144 +
.../sebastian/resource-operations/.gitignore | 3 +
vendor/sebastian/resource-operations/LICENSE | 33 +
.../sebastian/resource-operations/README.md | 16 +
.../sebastian/resource-operations/build.xml | 24 +
.../resource-operations/build/generate.php | 62 +
.../resource-operations/composer.json | 26 +
.../src/ResourceOperations.php | 670 +
vendor/sebastian/version/.gitattributes | 1 +
vendor/sebastian/version/.gitignore | 1 +
vendor/sebastian/version/.php_cs | 66 +
vendor/sebastian/version/LICENSE | 33 +
vendor/sebastian/version/README.md | 43 +
vendor/sebastian/version/composer.json | 29 +
vendor/sebastian/version/src/Version.php | 109 +
vendor/swiftmailer/swiftmailer/.gitattributes | 9 +
.../swiftmailer/.github/ISSUE_TEMPLATE.md | 19 +
.../.github/PULL_REQUEST_TEMPLATE.md | 14 +
vendor/swiftmailer/swiftmailer/.gitignore | 8 +
vendor/swiftmailer/swiftmailer/.php_cs.dist | 15 +
vendor/swiftmailer/swiftmailer/.travis.yml | 31 +
vendor/swiftmailer/swiftmailer/CHANGES | 287 +
vendor/swiftmailer/swiftmailer/LICENSE | 19 +
vendor/swiftmailer/swiftmailer/README | 15 +
vendor/swiftmailer/swiftmailer/VERSION | 1 +
vendor/swiftmailer/swiftmailer/composer.json | 37 +
.../swiftmailer/swiftmailer/doc/headers.rst | 739 +
.../swiftmailer/doc/help-resources.rst | 44 +
.../swiftmailer/doc/including-the-files.rst | 46 +
vendor/swiftmailer/swiftmailer/doc/index.rst | 16 +
.../swiftmailer/doc/installing.rst | 89 +
.../swiftmailer/doc/introduction.rst | 135 +
.../swiftmailer/swiftmailer/doc/japanese.rst | 22 +
.../swiftmailer/swiftmailer/doc/messages.rst | 1058 +
.../swiftmailer/swiftmailer/doc/overview.rst | 159 +
.../swiftmailer/swiftmailer/doc/plugins.rst | 385 +
.../swiftmailer/swiftmailer/doc/sending.rst | 571 +
.../swiftmailer/doc/uml/Encoders.graffle | Bin 0 -> 3503 bytes
.../swiftmailer/doc/uml/Mime.graffle | Bin 0 -> 5575 bytes
.../swiftmailer/doc/uml/Transports.graffle | Bin 0 -> 3061 bytes
.../swiftmailer/lib/classes/Swift.php | 80 +
.../lib/classes/Swift/Attachment.php | 71 +
.../AbstractFilterableInputStream.php | 181 +
.../Swift/ByteStream/ArrayByteStream.php | 182 +
.../Swift/ByteStream/FileByteStream.php | 231 +
.../ByteStream/TemporaryFileByteStream.php | 42 +
.../lib/classes/Swift/CharacterReader.php | 67 +
.../GenericFixedWidthReader.php | 97 +
.../Swift/CharacterReader/UsAsciiReader.php | 84 +
.../Swift/CharacterReader/Utf8Reader.php | 176 +
.../classes/Swift/CharacterReaderFactory.php | 26 +
.../SimpleCharacterReaderFactory.php | 124 +
.../lib/classes/Swift/CharacterStream.php | 89 +
.../CharacterStream/ArrayCharacterStream.php | 293 +
.../CharacterStream/NgCharacterStream.php | 267 +
.../lib/classes/Swift/ConfigurableSpool.php | 63 +
.../lib/classes/Swift/DependencyContainer.php | 373 +
.../lib/classes/Swift/DependencyException.php | 27 +
.../lib/classes/Swift/EmbeddedFile.php | 69 +
.../swiftmailer/lib/classes/Swift/Encoder.php | 28 +
.../classes/Swift/Encoder/Base64Encoder.php | 58 +
.../lib/classes/Swift/Encoder/QpEncoder.php | 300 +
.../classes/Swift/Encoder/Rfc2231Encoder.php | 92 +
.../lib/classes/Swift/Encoding.php | 62 +
.../lib/classes/Swift/Events/CommandEvent.php | 65 +
.../classes/Swift/Events/CommandListener.php | 24 +
.../lib/classes/Swift/Events/Event.php | 38 +
.../classes/Swift/Events/EventDispatcher.php | 83 +
.../classes/Swift/Events/EventListener.php | 18 +
.../lib/classes/Swift/Events/EventObject.php | 63 +
.../classes/Swift/Events/ResponseEvent.php | 65 +
.../classes/Swift/Events/ResponseListener.php | 24 +
.../lib/classes/Swift/Events/SendEvent.php | 129 +
.../lib/classes/Swift/Events/SendListener.php | 31 +
.../Swift/Events/SimpleEventDispatcher.php | 156 +
.../Swift/Events/TransportChangeEvent.php | 27 +
.../Swift/Events/TransportChangeListener.php | 45 +
.../Swift/Events/TransportExceptionEvent.php | 46 +
.../Events/TransportExceptionListener.php | 24 +
.../lib/classes/Swift/FailoverTransport.php | 45 +
.../lib/classes/Swift/FileSpool.php | 208 +
.../lib/classes/Swift/FileStream.php | 24 +
.../lib/classes/Swift/Filterable.php | 32 +
.../swiftmailer/lib/classes/Swift/Image.php | 57 +
.../lib/classes/Swift/InputByteStream.php | 75 +
.../lib/classes/Swift/IoException.php | 29 +
.../lib/classes/Swift/KeyCache.php | 105 +
.../classes/Swift/KeyCache/ArrayKeyCache.php | 206 +
.../classes/Swift/KeyCache/DiskKeyCache.php | 321 +
.../Swift/KeyCache/KeyCacheInputStream.php | 51 +
.../classes/Swift/KeyCache/NullKeyCache.php | 115 +
.../KeyCache/SimpleKeyCacheInputStream.php | 127 +
.../classes/Swift/LoadBalancedTransport.php | 45 +
.../lib/classes/Swift/MailTransport.php | 47 +
.../swiftmailer/lib/classes/Swift/Mailer.php | 114 +
.../Swift/Mailer/ArrayRecipientIterator.php | 55 +
.../Swift/Mailer/RecipientIterator.php | 32 +
.../lib/classes/Swift/MemorySpool.php | 110 +
.../swiftmailer/lib/classes/Swift/Message.php | 289 +
.../lib/classes/Swift/Mime/Attachment.php | 149 +
.../classes/Swift/Mime/CharsetObserver.php | 24 +
.../lib/classes/Swift/Mime/ContentEncoder.php | 34 +
.../ContentEncoder/Base64ContentEncoder.php | 104 +
.../ContentEncoder/NativeQpContentEncoder.php | 123 +
.../ContentEncoder/PlainContentEncoder.php | 162 +
.../Mime/ContentEncoder/QpContentEncoder.php | 134 +
.../ContentEncoder/QpContentEncoderProxy.php | 98 +
.../Mime/ContentEncoder/RawContentEncoder.php | 64 +
.../lib/classes/Swift/Mime/EmbeddedFile.php | 45 +
.../classes/Swift/Mime/EncodingObserver.php | 24 +
.../lib/classes/Swift/Mime/Grammar.php | 176 +
.../lib/classes/Swift/Mime/Header.php | 93 +
.../lib/classes/Swift/Mime/HeaderEncoder.php | 24 +
.../HeaderEncoder/Base64HeaderEncoder.php | 55 +
.../Mime/HeaderEncoder/QpHeaderEncoder.php | 65 +
.../lib/classes/Swift/Mime/HeaderFactory.php | 78 +
.../lib/classes/Swift/Mime/HeaderSet.php | 169 +
.../Swift/Mime/Headers/AbstractHeader.php | 501 +
.../classes/Swift/Mime/Headers/DateHeader.php | 125 +
.../Mime/Headers/IdentificationHeader.php | 180 +
.../Swift/Mime/Headers/MailboxHeader.php | 351 +
.../Swift/Mime/Headers/OpenDKIMHeader.php | 133 +
.../Mime/Headers/ParameterizedHeader.php | 258 +
.../classes/Swift/Mime/Headers/PathHeader.php | 143 +
.../Swift/Mime/Headers/UnstructuredHeader.php | 112 +
.../lib/classes/Swift/Mime/Message.php | 223 +
.../lib/classes/Swift/Mime/MimeEntity.php | 117 +
.../lib/classes/Swift/Mime/MimePart.php | 212 +
.../Swift/Mime/ParameterizedHeader.php | 34 +
.../Swift/Mime/SimpleHeaderFactory.php | 193 +
.../classes/Swift/Mime/SimpleHeaderSet.php | 414 +
.../lib/classes/Swift/Mime/SimpleMessage.php | 655 +
.../classes/Swift/Mime/SimpleMimeEntity.php | 846 +
.../lib/classes/Swift/MimePart.php | 59 +
.../lib/classes/Swift/NullTransport.php | 36 +
.../lib/classes/Swift/OutputByteStream.php | 46 +
.../classes/Swift/Plugins/AntiFloodPlugin.php | 141 +
.../Swift/Plugins/BandwidthMonitorPlugin.php | 164 +
.../Swift/Plugins/Decorator/Replacements.php | 31 +
.../classes/Swift/Plugins/DecoratorPlugin.php | 204 +
.../Swift/Plugins/ImpersonatePlugin.php | 69 +
.../lib/classes/Swift/Plugins/Logger.php | 36 +
.../classes/Swift/Plugins/LoggerPlugin.php | 142 +
.../Swift/Plugins/Loggers/ArrayLogger.php | 72 +
.../Swift/Plugins/Loggers/EchoLogger.php | 58 +
.../classes/Swift/Plugins/MessageLogger.php | 74 +
.../Swift/Plugins/Pop/Pop3Connection.php | 31 +
.../Swift/Plugins/Pop/Pop3Exception.php | 27 +
.../Swift/Plugins/PopBeforeSmtpPlugin.php | 273 +
.../Swift/Plugins/RedirectingPlugin.php | 213 +
.../lib/classes/Swift/Plugins/Reporter.php | 32 +
.../classes/Swift/Plugins/ReporterPlugin.php | 61 +
.../Swift/Plugins/Reporters/HitReporter.php | 59 +
.../Swift/Plugins/Reporters/HtmlReporter.php | 39 +
.../lib/classes/Swift/Plugins/Sleeper.php | 24 +
.../classes/Swift/Plugins/ThrottlerPlugin.php | 200 +
.../lib/classes/Swift/Plugins/Timer.php | 24 +
.../lib/classes/Swift/Preferences.php | 100 +
.../Swift/ReplacementFilterFactory.php | 27 +
.../classes/Swift/RfcComplianceException.php | 27 +
.../lib/classes/Swift/SendmailTransport.php | 45 +
.../lib/classes/Swift/SignedMessage.php | 23 +
.../swiftmailer/lib/classes/Swift/Signer.php | 20 +
.../lib/classes/Swift/Signers/BodySigner.php | 33 +
.../lib/classes/Swift/Signers/DKIMSigner.php | 712 +
.../classes/Swift/Signers/DomainKeySigner.php | 524 +
.../classes/Swift/Signers/HeaderSigner.php | 65 +
.../classes/Swift/Signers/OpenDKIMSigner.php | 190 +
.../lib/classes/Swift/Signers/SMimeSigner.php | 436 +
.../lib/classes/Swift/SmtpTransport.php | 58 +
.../swiftmailer/lib/classes/Swift/Spool.php | 53 +
.../lib/classes/Swift/SpoolTransport.php | 47 +
.../lib/classes/Swift/StreamFilter.php | 35 +
.../ByteArrayReplacementFilter.php | 170 +
.../StreamFilters/StringReplacementFilter.php | 70 +
.../StringReplacementFilterFactory.php | 45 +
.../lib/classes/Swift/SwiftException.php | 29 +
.../lib/classes/Swift/Transport.php | 54 +
.../Swift/Transport/AbstractSmtpTransport.php | 499 +
.../Esmtp/Auth/CramMd5Authenticator.php | 81 +
.../Esmtp/Auth/LoginAuthenticator.php | 51 +
.../Esmtp/Auth/NTLMAuthenticator.php | 725 +
.../Esmtp/Auth/PlainAuthenticator.php | 50 +
.../Esmtp/Auth/XOAuth2Authenticator.php | 70 +
.../Swift/Transport/Esmtp/AuthHandler.php | 263 +
.../Swift/Transport/Esmtp/Authenticator.php | 35 +
.../classes/Swift/Transport/EsmtpHandler.php | 86 +
.../Swift/Transport/EsmtpTransport.php | 411 +
.../Swift/Transport/FailoverTransport.php | 88 +
.../lib/classes/Swift/Transport/IoBuffer.php | 67 +
.../Swift/Transport/LoadBalancedTransport.php | 183 +
.../classes/Swift/Transport/MailInvoker.php | 32 +
.../classes/Swift/Transport/MailTransport.php | 297 +
.../classes/Swift/Transport/NullTransport.php | 93 +
.../Swift/Transport/SendmailTransport.php | 160 +
.../Swift/Transport/SimpleMailInvoker.php | 39 +
.../lib/classes/Swift/Transport/SmtpAgent.php | 36 +
.../Swift/Transport/SpoolTransport.php | 117 +
.../classes/Swift/Transport/StreamBuffer.php | 334 +
.../lib/classes/Swift/TransportException.php | 29 +
.../lib/classes/Swift/Validate.php | 43 +
.../lib/dependency_maps/cache_deps.php | 23 +
.../lib/dependency_maps/message_deps.php | 9 +
.../lib/dependency_maps/mime_deps.php | 123 +
.../lib/dependency_maps/transport_deps.php | 76 +
.../swiftmailer/lib/mime_types.php | 1007 +
.../swiftmailer/lib/preferences.php | 25 +
.../swiftmailer/lib/swift_init.php | 28 +
.../swiftmailer/lib/swift_required.php | 30 +
.../swiftmailer/lib/swift_required_pear.php | 30 +
.../lib/swiftmailer_generate_mimes_config.php | 193 +
.../swiftmailer/swiftmailer/phpunit.xml.dist | 39 +
.../tests/IdenticalBinaryConstraint.php | 62 +
.../swiftmailer/tests/StreamCollector.php | 11 +
.../tests/SwiftMailerSmokeTestCase.php | 46 +
.../swiftmailer/tests/SwiftMailerTestCase.php | 34 +
.../_samples/charsets/iso-2022-jp/one.txt | 11 +
.../_samples/charsets/iso-8859-1/one.txt | 19 +
.../tests/_samples/charsets/utf-8/one.txt | 22 +
.../tests/_samples/charsets/utf-8/three.txt | 45 +
.../tests/_samples/charsets/utf-8/two.txt | 3 +
.../tests/_samples/dkim/dkim.test.priv | 15 +
.../tests/_samples/dkim/dkim.test.pub | 6 +
.../swiftmailer/tests/_samples/files/data.txt | 1 +
.../tests/_samples/files/swiftmailer.png | Bin 0 -> 3194 bytes
.../tests/_samples/files/textfile.zip | Bin 0 -> 202 bytes
.../swiftmailer/tests/_samples/smime/CA.srl | 1 +
.../swiftmailer/tests/_samples/smime/ca.crt | 21 +
.../swiftmailer/tests/_samples/smime/ca.key | 27 +
.../tests/_samples/smime/create-cert.sh | 40 +
.../tests/_samples/smime/encrypt.crt | 19 +
.../tests/_samples/smime/encrypt.key | 27 +
.../tests/_samples/smime/encrypt2.crt | 19 +
.../tests/_samples/smime/encrypt2.key | 27 +
.../tests/_samples/smime/intermediate.crt | 19 +
.../tests/_samples/smime/intermediate.key | 27 +
.../swiftmailer/tests/_samples/smime/sign.crt | 19 +
.../swiftmailer/tests/_samples/smime/sign.key | 27 +
.../tests/_samples/smime/sign2.crt | 19 +
.../tests/_samples/smime/sign2.key | 27 +
.../tests/acceptance.conf.php.default | 37 +
.../Swift/AttachmentAcceptanceTest.php | 12 +
.../FileByteStreamAcceptanceTest.php | 162 +
...leCharacterReaderFactoryAcceptanceTest.php | 179 +
.../DependencyContainerAcceptanceTest.php | 24 +
.../Swift/EmbeddedFileAcceptanceTest.php | 12 +
.../Encoder/Base64EncoderAcceptanceTest.php | 45 +
.../Swift/Encoder/QpEncoderAcceptanceTest.php | 54 +
.../Encoder/Rfc2231EncoderAcceptanceTest.php | 50 +
.../Swift/EncodingAcceptanceTest.php | 30 +
.../KeyCache/ArrayKeyCacheAcceptanceTest.php | 173 +
.../KeyCache/DiskKeyCacheAcceptanceTest.php | 173 +
.../Swift/MessageAcceptanceTest.php | 55 +
.../Swift/Mime/AttachmentAcceptanceTest.php | 123 +
.../Base64ContentEncoderAcceptanceTest.php | 56 +
.../NativeQpContentEncoderAcceptanceTest.php | 88 +
.../PlainContentEncoderAcceptanceTest.php | 88 +
.../QpContentEncoderAcceptanceTest.php | 160 +
.../Swift/Mime/EmbeddedFileAcceptanceTest.php | 136 +
.../Base64HeaderEncoderAcceptanceTest.php | 32 +
.../Swift/Mime/MimePartAcceptanceTest.php | 127 +
.../Mime/SimpleMessageAcceptanceTest.php | 1249 +
.../Swift/MimePartAcceptanceTest.php | 15 +
.../AbstractStreamBufferAcceptanceTest.php | 131 +
.../BasicSocketAcceptanceTest.php | 33 +
.../StreamBuffer/ProcessAcceptanceTest.php | 26 +
.../StreamBuffer/SocketTimeoutTest.php | 67 +
.../StreamBuffer/SslSocketAcceptanceTest.php | 40 +
.../StreamBuffer/TlsSocketAcceptanceTest.php | 39 +
.../swiftmailer/tests/bootstrap.php | 21 +
.../tests/bug/Swift/Bug111Test.php | 42 +
.../tests/bug/Swift/Bug118Test.php | 20 +
.../tests/bug/Swift/Bug206Test.php | 38 +
.../tests/bug/Swift/Bug274Test.php | 21 +
.../swiftmailer/tests/bug/Swift/Bug34Test.php | 75 +
.../swiftmailer/tests/bug/Swift/Bug35Test.php | 73 +
.../swiftmailer/tests/bug/Swift/Bug38Test.php | 192 +
.../tests/bug/Swift/Bug518Test.php | 38 +
.../swiftmailer/tests/bug/Swift/Bug51Test.php | 110 +
.../tests/bug/Swift/Bug534Test.php | 38 +
.../tests/bug/Swift/Bug650Test.php | 36 +
.../swiftmailer/tests/bug/Swift/Bug71Test.php | 20 +
.../swiftmailer/tests/bug/Swift/Bug76Test.php | 71 +
...FileByteStreamConsecutiveReadCallsTest.php | 19 +
.../tests/fixtures/MimeEntityFixture.php | 67 +
.../swiftmailer/tests/smoke.conf.php.default | 63 +
.../smoke/Swift/Smoke/AttachmentSmokeTest.php | 33 +
.../smoke/Swift/Smoke/BasicSmokeTest.php | 23 +
.../Smoke/HtmlWithAttachmentSmokeTest.php | 31 +
.../Swift/Smoke/InternationalSmokeTest.php | 40 +
.../Swift/ByteStream/ArrayByteStreamTest.php | 201 +
.../GenericFixedWidthReaderTest.php | 43 +
.../CharacterReader/UsAsciiReaderTest.php | 52 +
.../Swift/CharacterReader/Utf8ReaderTest.php | 65 +
.../ArrayCharacterStreamTest.php | 358 +
.../unit/Swift/DependencyContainerTest.php | 176 +
.../unit/Swift/Encoder/Base64EncoderTest.php | 173 +
.../unit/Swift/Encoder/QpEncoderTest.php | 400 +
.../unit/Swift/Encoder/Rfc2231EncoderTest.php | 141 +
.../unit/Swift/Events/CommandEventTest.php | 34 +
.../unit/Swift/Events/EventObjectTest.php | 32 +
.../unit/Swift/Events/ResponseEventTest.php | 38 +
.../tests/unit/Swift/Events/SendEventTest.php | 97 +
.../Events/SimpleEventDispatcherTest.php | 142 +
.../Swift/Events/TransportChangeEventTest.php | 30 +
.../Events/TransportExceptionEventTest.php | 41 +
.../unit/Swift/KeyCache/ArrayKeyCacheTest.php | 240 +
.../SimpleKeyCacheInputStreamTest.php | 73 +
.../Mailer/ArrayRecipientIteratorTest.php | 42 +
.../tests/unit/Swift/MailerTest.php | 145 +
.../tests/unit/Swift/MessageTest.php | 129 +
.../Swift/Mime/AbstractMimeEntityTest.php | 1092 +
.../tests/unit/Swift/Mime/AttachmentTest.php | 318 +
.../Base64ContentEncoderTest.php | 323 +
.../PlainContentEncoderTest.php | 171 +
.../ContentEncoder/QpContentEncoderTest.php | 516 +
.../unit/Swift/Mime/EmbeddedFileTest.php | 55 +
.../HeaderEncoder/Base64HeaderEncoderTest.php | 13 +
.../HeaderEncoder/QpHeaderEncoderTest.php | 221 +
.../Swift/Mime/Headers/DateHeaderTest.php | 69 +
.../Mime/Headers/IdentificationHeaderTest.php | 189 +
.../Swift/Mime/Headers/MailboxHeaderTest.php | 327 +
.../Mime/Headers/ParameterizedHeaderTest.php | 398 +
.../Swift/Mime/Headers/PathHeaderTest.php | 77 +
.../Mime/Headers/UnstructuredHeaderTest.php | 355 +
.../tests/unit/Swift/Mime/MimePartTest.php | 231 +
.../Swift/Mime/SimpleHeaderFactoryTest.php | 166 +
.../unit/Swift/Mime/SimpleHeaderSetTest.php | 737 +
.../unit/Swift/Mime/SimpleMessageTest.php | 827 +
.../unit/Swift/Mime/SimpleMimeEntityTest.php | 9 +
.../Swift/Plugins/AntiFloodPluginTest.php | 93 +
.../Plugins/BandwidthMonitorPluginTest.php | 128 +
.../Swift/Plugins/DecoratorPluginTest.php | 267 +
.../unit/Swift/Plugins/LoggerPluginTest.php | 188 +
.../Swift/Plugins/Loggers/ArrayLoggerTest.php | 65 +
.../Swift/Plugins/Loggers/EchoLoggerTest.php | 24 +
.../Swift/Plugins/PopBeforeSmtpPluginTest.php | 101 +
.../Swift/Plugins/RedirectingPluginTest.php | 183 +
.../unit/Swift/Plugins/ReporterPluginTest.php | 86 +
.../Plugins/Reporters/HitReporterTest.php | 64 +
.../Plugins/Reporters/HtmlReporterTest.php | 54 +
.../Swift/Plugins/ThrottlerPluginTest.php | 102 +
.../unit/Swift/Signers/DKIMSignerTest.php | 225 +
.../unit/Swift/Signers/OpenDKIMSignerTest.php | 45 +
.../unit/Swift/Signers/SMimeSignerTest.php | 554 +
.../ByteArrayReplacementFilterTest.php | 129 +
.../StringReplacementFilterFactoryTest.php | 36 +
.../StringReplacementFilterTest.php | 59 +
.../AbstractSmtpEventSupportTest.php | 558 +
.../unit/Swift/Transport/AbstractSmtpTest.php | 1249 +
.../Esmtp/Auth/CramMd5AuthenticatorTest.php | 64 +
.../Esmtp/Auth/LoginAuthenticatorTest.php | 64 +
.../Esmtp/Auth/NTLMAuthenticatorTest.php | 213 +
.../Esmtp/Auth/PlainAuthenticatorTest.php | 67 +
.../Swift/Transport/Esmtp/AuthHandlerTest.php | 165 +
.../EsmtpTransport/ExtensionSupportTest.php | 529 +
.../Swift/Transport/EsmtpTransportTest.php | 297 +
.../Swift/Transport/FailoverTransportTest.php | 518 +
.../Transport/LoadBalancedTransportTest.php | 749 +
.../Swift/Transport/MailTransportTest.php | 533 +
.../Swift/Transport/SendmailTransportTest.php | 151 +
.../unit/Swift/Transport/StreamBufferTest.php | 43 +
vendor/symfony/console/.gitignore | 3 +
vendor/symfony/console/Application.php | 1276 +
vendor/symfony/console/CHANGELOG.md | 112 +
vendor/symfony/console/Command/Command.php | 666 +
.../symfony/console/Command/HelpCommand.php | 81 +
.../symfony/console/Command/ListCommand.php | 90 +
.../symfony/console/Command/LockableTrait.php | 72 +
.../CommandLoader/CommandLoaderInterface.php | 46 +
.../CommandLoader/ContainerCommandLoader.php | 64 +
.../CommandLoader/FactoryCommandLoader.php | 62 +
vendor/symfony/console/ConsoleEvents.php | 60 +
.../AddConsoleCommandPass.php | 106 +
.../Descriptor/ApplicationDescription.php | 157 +
.../symfony/console/Descriptor/Descriptor.php | 107 +
.../Descriptor/DescriptorInterface.php | 29 +
.../console/Descriptor/JsonDescriptor.php | 168 +
.../console/Descriptor/MarkdownDescriptor.php | 182 +
.../console/Descriptor/TextDescriptor.php | 342 +
.../console/Descriptor/XmlDescriptor.php | 248 +
.../console/Event/ConsoleCommandEvent.php | 60 +
.../console/Event/ConsoleErrorEvent.php | 83 +
vendor/symfony/console/Event/ConsoleEvent.php | 67 +
.../console/Event/ConsoleExceptionEvent.php | 71 +
.../console/Event/ConsoleTerminateEvent.php | 58 +
.../console/EventListener/ErrorListener.php | 95 +
.../Exception/CommandNotFoundException.php | 43 +
.../console/Exception/ExceptionInterface.php | 21 +
.../Exception/InvalidArgumentException.php | 19 +
.../Exception/InvalidOptionException.php | 21 +
.../console/Exception/LogicException.php | 19 +
.../console/Exception/RuntimeException.php | 19 +
.../console/Formatter/OutputFormatter.php | 243 +
.../Formatter/OutputFormatterInterface.php | 71 +
.../Formatter/OutputFormatterStyle.php | 183 +
.../OutputFormatterStyleInterface.php | 62 +
.../Formatter/OutputFormatterStyleStack.php | 109 +
.../console/Helper/DebugFormatterHelper.php | 127 +
.../console/Helper/DescriptorHelper.php | 91 +
.../console/Helper/FormatterHelper.php | 102 +
vendor/symfony/console/Helper/Helper.php | 138 +
.../console/Helper/HelperInterface.php | 39 +
vendor/symfony/console/Helper/HelperSet.php | 108 +
.../console/Helper/InputAwareHelper.php | 33 +
.../symfony/console/Helper/ProcessHelper.php | 145 +
vendor/symfony/console/Helper/ProgressBar.php | 614 +
.../console/Helper/ProgressIndicator.php | 270 +
.../symfony/console/Helper/QuestionHelper.php | 518 +
.../console/Helper/SymfonyQuestionHelper.php | 124 +
vendor/symfony/console/Helper/Table.php | 698 +
vendor/symfony/console/Helper/TableCell.php | 75 +
.../symfony/console/Helper/TableSeparator.php | 25 +
vendor/symfony/console/Helper/TableStyle.php | 258 +
vendor/symfony/console/Input/ArgvInput.php | 370 +
vendor/symfony/console/Input/ArrayInput.php | 208 +
vendor/symfony/console/Input/Input.php | 203 +
.../symfony/console/Input/InputArgument.php | 129 +
.../console/Input/InputAwareInterface.php | 26 +
.../symfony/console/Input/InputDefinition.php | 404 +
.../symfony/console/Input/InputInterface.php | 163 +
vendor/symfony/console/Input/InputOption.php | 208 +
.../Input/StreamableInputInterface.php | 37 +
vendor/symfony/console/Input/StringInput.php | 72 +
vendor/symfony/console/LICENSE | 19 +
.../symfony/console/Logger/ConsoleLogger.php | 128 +
.../symfony/console/Output/BufferedOutput.php | 45 +
.../symfony/console/Output/ConsoleOutput.php | 152 +
.../console/Output/ConsoleOutputInterface.php | 30 +
vendor/symfony/console/Output/NullOutput.php | 123 +
vendor/symfony/console/Output/Output.php | 175 +
.../console/Output/OutputInterface.php | 114 +
.../symfony/console/Output/StreamOutput.php | 120 +
.../console/Question/ChoiceQuestion.php | 187 +
.../console/Question/ConfirmationQuestion.php | 59 +
vendor/symfony/console/Question/Question.php | 245 +
vendor/symfony/console/README.md | 20 +
.../console/Resources/bin/hiddeninput.exe | Bin 0 -> 9216 bytes
vendor/symfony/console/Style/OutputStyle.php | 155 +
.../symfony/console/Style/StyleInterface.php | 153 +
vendor/symfony/console/Style/SymfonyStyle.php | 431 +
vendor/symfony/console/Terminal.php | 181 +
.../console/Tester/ApplicationTester.php | 176 +
.../symfony/console/Tester/CommandTester.php | 162 +
.../symfony/console/Tests/ApplicationTest.php | 1786 ++
.../console/Tests/Command/CommandTest.php | 430 +
.../console/Tests/Command/HelpCommandTest.php | 71 +
.../console/Tests/Command/ListCommandTest.php | 113 +
.../Tests/Command/LockableTraitTest.php | 67 +
.../ContainerCommandLoaderTest.php | 59 +
.../FactoryCommandLoaderTest.php | 58 +
.../AddConsoleCommandPassTest.php | 256 +
.../Descriptor/AbstractDescriptorTest.php | 107 +
.../Descriptor/ApplicationDescriptionTest.php | 53 +
.../Tests/Descriptor/JsonDescriptorTest.php | 35 +
.../Descriptor/MarkdownDescriptorTest.php | 45 +
.../Tests/Descriptor/ObjectsProvider.php | 82 +
.../Tests/Descriptor/TextDescriptorTest.php | 53 +
.../Tests/Descriptor/XmlDescriptorTest.php | 27 +
.../Tests/EventListener/ErrorListenerTest.php | 156 +
.../console/Tests/Fixtures/BarBucCommand.php | 11 +
.../Tests/Fixtures/DescriptorApplication1.php | 18 +
.../Tests/Fixtures/DescriptorApplication2.php | 26 +
.../DescriptorApplicationMbString.php | 24 +
.../Tests/Fixtures/DescriptorCommand1.php | 27 +
.../Tests/Fixtures/DescriptorCommand2.php | 32 +
.../Tests/Fixtures/DescriptorCommand3.php | 27 +
.../Tests/Fixtures/DescriptorCommand4.php | 25 +
.../Fixtures/DescriptorCommandMbString.php | 32 +
.../console/Tests/Fixtures/DummyOutput.php | 36 +
.../console/Tests/Fixtures/Foo1Command.php | 26 +
.../console/Tests/Fixtures/Foo2Command.php | 21 +
.../console/Tests/Fixtures/Foo3Command.php | 29 +
.../console/Tests/Fixtures/Foo4Command.php | 11 +
.../console/Tests/Fixtures/Foo5Command.php | 10 +
.../console/Tests/Fixtures/Foo6Command.php | 11 +
.../console/Tests/Fixtures/FooCommand.php | 33 +
.../Tests/Fixtures/FooHiddenCommand.php | 21 +
.../Tests/Fixtures/FooLock2Command.php | 28 +
.../console/Tests/Fixtures/FooLockCommand.php | 27 +
.../console/Tests/Fixtures/FooOptCommand.php | 36 +
.../Fixtures/FooSameCaseLowercaseCommand.php | 11 +
.../Fixtures/FooSameCaseUppercaseCommand.php | 11 +
.../Fixtures/FooSubnamespaced1Command.php | 26 +
.../Fixtures/FooSubnamespaced2Command.php | 26 +
.../console/Tests/Fixtures/FoobarCommand.php | 25 +
.../Style/SymfonyStyle/command/command_0.php | 11 +
.../Style/SymfonyStyle/command/command_1.php | 13 +
.../Style/SymfonyStyle/command/command_10.php | 17 +
.../Style/SymfonyStyle/command/command_11.php | 12 +
.../Style/SymfonyStyle/command/command_12.php | 13 +
.../Style/SymfonyStyle/command/command_13.php | 14 +
.../Style/SymfonyStyle/command/command_14.php | 17 +
.../Style/SymfonyStyle/command/command_15.php | 14 +
.../Style/SymfonyStyle/command/command_16.php | 15 +
.../Style/SymfonyStyle/command/command_17.php | 13 +
.../Style/SymfonyStyle/command/command_2.php | 16 +
.../Style/SymfonyStyle/command/command_3.php | 12 +
.../Style/SymfonyStyle/command/command_4.php | 34 +
.../Style/SymfonyStyle/command/command_5.php | 37 +
.../Style/SymfonyStyle/command/command_6.php | 16 +
.../Style/SymfonyStyle/command/command_7.php | 15 +
.../Style/SymfonyStyle/command/command_8.php | 26 +
.../Style/SymfonyStyle/command/command_9.php | 11 +
.../command/interactive_command_1.php | 19 +
.../output/interactive_output_1.txt | 7 +
.../Style/SymfonyStyle/output/output_0.txt | 3 +
.../Style/SymfonyStyle/output/output_1.txt | 9 +
.../Style/SymfonyStyle/output/output_10.txt | 7 +
.../Style/SymfonyStyle/output/output_11.txt | 4 +
.../Style/SymfonyStyle/output/output_12.txt | 6 +
.../Style/SymfonyStyle/output/output_13.txt | 7 +
.../Style/SymfonyStyle/output/output_14.txt | 6 +
.../Style/SymfonyStyle/output/output_15.txt | 7 +
.../Style/SymfonyStyle/output/output_16.txt | 8 +
.../Style/SymfonyStyle/output/output_17.txt | 7 +
.../Style/SymfonyStyle/output/output_2.txt | 13 +
.../Style/SymfonyStyle/output/output_3.txt | 7 +
.../Style/SymfonyStyle/output/output_4.txt | 32 +
.../Style/SymfonyStyle/output/output_5.txt | 18 +
.../Style/SymfonyStyle/output/output_6.txt | 6 +
.../Style/SymfonyStyle/output/output_7.txt | 5 +
.../Style/SymfonyStyle/output/output_8.txt | 9 +
.../Style/SymfonyStyle/output/output_9.txt | 5 +
.../TestAmbiguousCommandRegistering.php | 22 +
.../TestAmbiguousCommandRegistering2.php | 21 +
.../console/Tests/Fixtures/TestCommand.php | 28 +
.../console/Tests/Fixtures/application_1.json | 156 +
.../console/Tests/Fixtures/application_1.md | 172 +
.../console/Tests/Fixtures/application_1.txt | 17 +
.../console/Tests/Fixtures/application_1.xml | 104 +
.../console/Tests/Fixtures/application_2.json | 509 +
.../console/Tests/Fixtures/application_2.md | 431 +
.../console/Tests/Fixtures/application_2.txt | 21 +
.../console/Tests/Fixtures/application_2.xml | 254 +
.../application_filtered_namespace.txt | 16 +
.../Tests/Fixtures/application_gethelp.txt | 1 +
.../Tests/Fixtures/application_mbstring.md | 269 +
.../Tests/Fixtures/application_mbstring.txt | 19 +
.../Fixtures/application_renderexception1.txt | 5 +
.../Fixtures/application_renderexception2.txt | 7 +
.../Fixtures/application_renderexception3.txt | 18 +
.../application_renderexception3decorated.txt | 18 +
.../Fixtures/application_renderexception4.txt | 6 +
...plication_renderexception_doublewidth1.txt | 8 +
..._renderexception_doublewidth1decorated.txt | 8 +
...plication_renderexception_doublewidth2.txt | 9 +
...plication_renderexception_escapeslines.txt | 9 +
...application_renderexception_linebreaks.txt | 11 +
.../Tests/Fixtures/application_run1.txt | 17 +
.../Tests/Fixtures/application_run2.txt | 26 +
.../Tests/Fixtures/application_run3.txt | 26 +
.../Tests/Fixtures/application_run4.txt | 1 +
.../console/Tests/Fixtures/command_1.json | 15 +
.../console/Tests/Fixtures/command_1.md | 12 +
.../console/Tests/Fixtures/command_1.txt | 7 +
.../console/Tests/Fixtures/command_1.xml | 12 +
.../console/Tests/Fixtures/command_2.json | 33 +
.../console/Tests/Fixtures/command_2.md | 29 +
.../console/Tests/Fixtures/command_2.txt | 13 +
.../console/Tests/Fixtures/command_2.xml | 21 +
.../Tests/Fixtures/command_mbstring.md | 29 +
.../Tests/Fixtures/command_mbstring.txt | 13 +
.../Tests/Fixtures/input_argument_1.json | 7 +
.../Tests/Fixtures/input_argument_1.md | 5 +
.../Tests/Fixtures/input_argument_1.txt | 1 +
.../Tests/Fixtures/input_argument_1.xml | 5 +
.../Tests/Fixtures/input_argument_2.json | 7 +
.../Tests/Fixtures/input_argument_2.md | 7 +
.../Tests/Fixtures/input_argument_2.txt | 1 +
.../Tests/Fixtures/input_argument_2.xml | 5 +
.../Tests/Fixtures/input_argument_3.json | 7 +
.../Tests/Fixtures/input_argument_3.md | 7 +
.../Tests/Fixtures/input_argument_3.txt | 1 +
.../Tests/Fixtures/input_argument_3.xml | 7 +
.../Tests/Fixtures/input_argument_4.json | 7 +
.../Tests/Fixtures/input_argument_4.md | 8 +
.../Tests/Fixtures/input_argument_4.txt | 2 +
.../Tests/Fixtures/input_argument_4.xml | 6 +
...input_argument_with_default_inf_value.json | 7 +
.../input_argument_with_default_inf_value.md | 7 +
.../input_argument_with_default_inf_value.txt | 1 +
.../input_argument_with_default_inf_value.xml | 7 +
.../Fixtures/input_argument_with_style.json | 7 +
.../Fixtures/input_argument_with_style.md | 7 +
.../Fixtures/input_argument_with_style.txt | 1 +
.../Fixtures/input_argument_with_style.xml | 7 +
.../Tests/Fixtures/input_definition_1.json | 4 +
.../Tests/Fixtures/input_definition_1.md | 0
.../Tests/Fixtures/input_definition_1.txt | 0
.../Tests/Fixtures/input_definition_1.xml | 5 +
.../Tests/Fixtures/input_definition_2.json | 12 +
.../Tests/Fixtures/input_definition_2.md | 7 +
.../Tests/Fixtures/input_definition_2.txt | 2 +
.../Tests/Fixtures/input_definition_2.xml | 10 +
.../Tests/Fixtures/input_definition_3.json | 14 +
.../Tests/Fixtures/input_definition_3.md | 8 +
.../Tests/Fixtures/input_definition_3.txt | 2 +
.../Tests/Fixtures/input_definition_3.xml | 9 +
.../Tests/Fixtures/input_definition_4.json | 22 +
.../Tests/Fixtures/input_definition_4.md | 16 +
.../Tests/Fixtures/input_definition_4.txt | 5 +
.../Tests/Fixtures/input_definition_4.xml | 14 +
.../Tests/Fixtures/input_option_1.json | 9 +
.../console/Tests/Fixtures/input_option_1.md | 6 +
.../console/Tests/Fixtures/input_option_1.txt | 1 +
.../console/Tests/Fixtures/input_option_1.xml | 4 +
.../Tests/Fixtures/input_option_2.json | 9 +
.../console/Tests/Fixtures/input_option_2.md | 8 +
.../console/Tests/Fixtures/input_option_2.txt | 1 +
.../console/Tests/Fixtures/input_option_2.xml | 7 +
.../Tests/Fixtures/input_option_3.json | 9 +
.../console/Tests/Fixtures/input_option_3.md | 8 +
.../console/Tests/Fixtures/input_option_3.txt | 1 +
.../console/Tests/Fixtures/input_option_3.xml | 5 +
.../Tests/Fixtures/input_option_4.json | 9 +
.../console/Tests/Fixtures/input_option_4.md | 8 +
.../console/Tests/Fixtures/input_option_4.txt | 1 +
.../console/Tests/Fixtures/input_option_4.xml | 5 +
.../Tests/Fixtures/input_option_5.json | 9 +
.../console/Tests/Fixtures/input_option_5.md | 9 +
.../console/Tests/Fixtures/input_option_5.txt | 2 +
.../console/Tests/Fixtures/input_option_5.xml | 6 +
.../Tests/Fixtures/input_option_6.json | 9 +
.../console/Tests/Fixtures/input_option_6.md | 8 +
.../console/Tests/Fixtures/input_option_6.txt | 1 +
.../console/Tests/Fixtures/input_option_6.xml | 5 +
.../input_option_with_default_inf_value.json | 9 +
.../input_option_with_default_inf_value.md | 8 +
.../input_option_with_default_inf_value.txt | 1 +
.../input_option_with_default_inf_value.xml | 7 +
.../Fixtures/input_option_with_style.json | 9 +
.../Tests/Fixtures/input_option_with_style.md | 8 +
.../Fixtures/input_option_with_style.txt | 1 +
.../Fixtures/input_option_with_style.xml | 7 +
.../input_option_with_style_array.json | 12 +
.../Fixtures/input_option_with_style_array.md | 8 +
.../input_option_with_style_array.txt | 1 +
.../input_option_with_style_array.xml | 8 +
.../Tests/Fixtures/stream_output_file.txt | 0
.../OutputFormatterStyleStackTest.php | 69 +
.../Formatter/OutputFormatterStyleTest.php | 100 +
.../Tests/Formatter/OutputFormatterTest.php | 344 +
.../Helper/AbstractQuestionHelperTest.php | 34 +
.../Tests/Helper/FormatterHelperTest.php | 129 +
.../console/Tests/Helper/HelperSetTest.php | 127 +
.../console/Tests/Helper/HelperTest.php | 55 +
.../Tests/Helper/ProcessHelperTest.php | 118 +
.../console/Tests/Helper/ProgressBarTest.php | 805 +
.../Tests/Helper/ProgressIndicatorTest.php | 175 +
.../Tests/Helper/QuestionHelperTest.php | 1115 +
.../Helper/SymfonyQuestionHelperTest.php | 214 +
.../console/Tests/Helper/TableStyleTest.php | 26 +
.../console/Tests/Helper/TableTest.php | 868 +
.../console/Tests/Input/ArgvInputTest.php | 462 +
.../console/Tests/Input/ArrayInputTest.php | 173 +
.../console/Tests/Input/InputArgumentTest.php | 109 +
.../Tests/Input/InputDefinitionTest.php | 389 +
.../console/Tests/Input/InputOptionTest.php | 194 +
.../symfony/console/Tests/Input/InputTest.php | 137 +
.../console/Tests/Input/StringInputTest.php | 87 +
.../Tests/Logger/ConsoleLoggerTest.php | 213 +
.../Tests/Output/ConsoleOutputTest.php | 42 +
.../console/Tests/Output/NullOutputTest.php | 88 +
.../console/Tests/Output/OutputTest.php | 176 +
.../console/Tests/Output/StreamOutputTest.php | 67 +
.../Tests/Question/ChoiceQuestionTest.php | 64 +
.../Question/ConfirmationQuestionTest.php | 62 +
.../console/Tests/Style/SymfonyStyleTest.php | 118 +
vendor/symfony/console/Tests/TerminalTest.php | 97 +
.../Tests/Tester/ApplicationTesterTest.php | 70 +
.../Tests/Tester/CommandTesterTest.php | 212 +
vendor/symfony/console/composer.json | 51 +
vendor/symfony/console/phpunit.xml.dist | 41 +
vendor/symfony/css-selector/.gitignore | 3 +
vendor/symfony/css-selector/CHANGELOG.md | 13 +
.../css-selector/CssSelectorConverter.php | 65 +
.../Exception/ExceptionInterface.php | 24 +
.../Exception/ExpressionErrorException.php | 24 +
.../Exception/InternalErrorException.php | 24 +
.../css-selector/Exception/ParseException.php | 24 +
.../Exception/SyntaxErrorException.php | 72 +
vendor/symfony/css-selector/LICENSE | 19 +
.../css-selector/Node/AbstractNode.php | 42 +
.../css-selector/Node/AttributeNode.php | 106 +
.../symfony/css-selector/Node/ClassNode.php | 69 +
.../Node/CombinedSelectorNode.php | 81 +
.../symfony/css-selector/Node/ElementNode.php | 72 +
.../css-selector/Node/FunctionNode.php | 86 +
vendor/symfony/css-selector/Node/HashNode.php | 69 +
.../css-selector/Node/NegationNode.php | 66 +
.../css-selector/Node/NodeInterface.php | 46 +
.../symfony/css-selector/Node/PseudoNode.php | 69 +
.../css-selector/Node/SelectorNode.php | 69 +
.../symfony/css-selector/Node/Specificity.php | 88 +
.../Parser/Handler/CommentHandler.php | 48 +
.../Parser/Handler/HandlerInterface.php | 33 +
.../Parser/Handler/HashHandler.php | 58 +
.../Parser/Handler/IdentifierHandler.php | 58 +
.../Parser/Handler/NumberHandler.php | 54 +
.../Parser/Handler/StringHandler.php | 77 +
.../Parser/Handler/WhitespaceHandler.php | 46 +
vendor/symfony/css-selector/Parser/Parser.php | 383 +
.../css-selector/Parser/ParserInterface.php | 36 +
vendor/symfony/css-selector/Parser/Reader.php | 114 +
.../Parser/Shortcut/ClassParser.php | 51 +
.../Parser/Shortcut/ElementParser.php | 47 +
.../Parser/Shortcut/EmptyStringParser.php | 46 +
.../Parser/Shortcut/HashParser.php | 51 +
vendor/symfony/css-selector/Parser/Token.php | 149 +
.../css-selector/Parser/TokenStream.php | 175 +
.../Parser/Tokenizer/Tokenizer.php | 75 +
.../Parser/Tokenizer/TokenizerEscaping.php | 80 +
.../Parser/Tokenizer/TokenizerPatterns.php | 112 +
vendor/symfony/css-selector/README.md | 20 +
.../Tests/CssSelectorConverterTest.php | 74 +
.../Tests/Node/AbstractNodeTest.php | 34 +
.../Tests/Node/AttributeNodeTest.php | 37 +
.../css-selector/Tests/Node/ClassNodeTest.php | 33 +
.../Tests/Node/CombinedSelectorNodeTest.php | 35 +
.../Tests/Node/ElementNodeTest.php | 35 +
.../Tests/Node/FunctionNodeTest.php | 47 +
.../css-selector/Tests/Node/HashNodeTest.php | 33 +
.../Tests/Node/NegationNodeTest.php | 33 +
.../Tests/Node/PseudoNodeTest.php | 32 +
.../Tests/Node/SelectorNodeTest.php | 34 +
.../Tests/Node/SpecificityTest.php | 63 +
.../Parser/Handler/AbstractHandlerTest.php | 70 +
.../Parser/Handler/CommentHandlerTest.php | 55 +
.../Tests/Parser/Handler/HashHandlerTest.php | 49 +
.../Parser/Handler/IdentifierHandlerTest.php | 49 +
.../Parser/Handler/NumberHandlerTest.php | 50 +
.../Parser/Handler/StringHandlerTest.php | 50 +
.../Parser/Handler/WhitespaceHandlerTest.php | 44 +
.../css-selector/Tests/Parser/ParserTest.php | 253 +
.../css-selector/Tests/Parser/ReaderTest.php | 102 +
.../Tests/Parser/Shortcut/ClassParserTest.php | 45 +
.../Parser/Shortcut/ElementParserTest.php | 44 +
.../Parser/Shortcut/EmptyStringParserTest.php | 36 +
.../Tests/Parser/Shortcut/HashParserTest.php | 45 +
.../Tests/Parser/TokenStreamTest.php | 96 +
.../Tests/XPath/Fixtures/ids.html | 48 +
.../Tests/XPath/Fixtures/lang.xml | 11 +
.../Tests/XPath/Fixtures/shakespear.html | 308 +
.../Tests/XPath/TranslatorTest.php | 413 +
.../XPath/Extension/AbstractExtension.php | 65 +
.../Extension/AttributeMatchingExtension.php | 167 +
.../XPath/Extension/CombinationExtension.php | 83 +
.../XPath/Extension/ExtensionInterface.php | 69 +
.../XPath/Extension/FunctionExtension.php | 188 +
.../XPath/Extension/HtmlExtension.php | 213 +
.../XPath/Extension/NodeExtension.php | 242 +
.../XPath/Extension/PseudoClassExtension.php | 150 +
.../symfony/css-selector/XPath/Translator.php | 263 +
.../XPath/TranslatorInterface.php | 46 +
.../symfony/css-selector/XPath/XPathExpr.php | 129 +
vendor/symfony/css-selector/composer.json | 32 +
vendor/symfony/css-selector/phpunit.xml.dist | 31 +
vendor/symfony/debug/.gitignore | 3 +
vendor/symfony/debug/BufferingLogger.php | 37 +
vendor/symfony/debug/CHANGELOG.md | 64 +
vendor/symfony/debug/Debug.php | 60 +
vendor/symfony/debug/DebugClassLoader.php | 455 +
vendor/symfony/debug/ErrorHandler.php | 787 +
.../Exception/ClassNotFoundException.php | 36 +
.../debug/Exception/ContextErrorException.php | 40 +
.../debug/Exception/FatalErrorException.php | 82 +
.../debug/Exception/FatalThrowableError.php | 45 +
.../debug/Exception/FlattenException.php | 263 +
.../debug/Exception/OutOfMemoryException.php | 21 +
.../debug/Exception/SilencedErrorContext.php | 67 +
.../Exception/UndefinedFunctionException.php | 36 +
.../Exception/UndefinedMethodException.php | 36 +
vendor/symfony/debug/ExceptionHandler.php | 444 +
.../ClassNotFoundFatalErrorHandler.php | 198 +
.../FatalErrorHandlerInterface.php | 32 +
.../UndefinedFunctionFatalErrorHandler.php | 84 +
.../UndefinedMethodFatalErrorHandler.php | 66 +
vendor/symfony/debug/LICENSE | 19 +
vendor/symfony/debug/README.md | 25 +
vendor/symfony/debug/Resources/ext/README.md | 134 +
vendor/symfony/debug/Resources/ext/config.m4 | 63 +
vendor/symfony/debug/Resources/ext/config.w32 | 13 +
.../debug/Resources/ext/php_symfony_debug.h | 60 +
.../debug/Resources/ext/symfony_debug.c | 283 +
.../debug/Resources/ext/tests/001.phpt | 155 +
.../debug/Resources/ext/tests/002.phpt | 65 +
.../debug/Resources/ext/tests/002_1.phpt | 48 +
.../debug/Resources/ext/tests/003.phpt | 87 +
.../debug/Tests/DebugClassLoaderTest.php | 448 +
.../symfony/debug/Tests/ErrorHandlerTest.php | 664 +
.../Tests/Exception/FlattenExceptionTest.php | 314 +
.../debug/Tests/ExceptionHandlerTest.php | 163 +
.../ClassNotFoundFatalErrorHandlerTest.php | 220 +
...UndefinedFunctionFatalErrorHandlerTest.php | 81 +
.../UndefinedMethodFatalErrorHandlerTest.php | 76 +
.../debug/Tests/Fixtures/AnnotatedClass.php | 13 +
.../debug/Tests/Fixtures/ClassAlias.php | 3 +
.../Fixtures/DefinitionInEvaluatedCode.php | 11 +
.../debug/Tests/Fixtures/DeprecatedClass.php | 12 +
.../Tests/Fixtures/DeprecatedInterface.php | 12 +
.../ErrorHandlerThatUsesThePreviousOne.php | 22 +
.../Tests/Fixtures/ExtendedFinalMethod.php | 19 +
.../debug/Tests/Fixtures/FinalClasses.php | 85 +
.../debug/Tests/Fixtures/FinalMethod.php | 26 +
.../Tests/Fixtures/FinalMethod2Trait.php | 10 +
.../debug/Tests/Fixtures/InternalClass.php | 15 +
.../Tests/Fixtures/InternalInterface.php | 10 +
.../debug/Tests/Fixtures/InternalTrait.php | 10 +
.../debug/Tests/Fixtures/InternalTrait2.php | 23 +
.../Fixtures/LoggerThatSetAnErrorHandler.php | 15 +
.../Tests/Fixtures/NonDeprecatedInterface.php | 7 +
.../debug/Tests/Fixtures/PEARClass.php | 5 +
.../symfony/debug/Tests/Fixtures/Throwing.php | 3 +
.../debug/Tests/Fixtures/ToStringThrower.php | 24 +
.../Fixtures/TraitWithInternalMethod.php | 13 +
.../debug/Tests/Fixtures/casemismatch.php | 7 +
.../debug/Tests/Fixtures/notPsr0Bis.php | 7 +
.../Tests/Fixtures/psr4/Psr4CaseMismatch.php | 7 +
.../debug/Tests/Fixtures/reallyNotPsr0.php | 7 +
.../debug/Tests/Fixtures2/RequiredTwice.php | 7 +
vendor/symfony/debug/Tests/HeaderMock.php | 38 +
.../debug/Tests/phpt/debug_class_loader.phpt | 27 +
.../Tests/phpt/decorate_exception_hander.phpt | 47 +
.../debug/Tests/phpt/exception_rethrown.phpt | 35 +
.../phpt/fatal_with_nested_handlers.phpt | 42 +
vendor/symfony/debug/composer.json | 35 +
vendor/symfony/debug/phpunit.xml.dist | 33 +
vendor/symfony/event-dispatcher/.gitignore | 3 +
vendor/symfony/event-dispatcher/CHANGELOG.md | 42 +
.../ContainerAwareEventDispatcher.php | 198 +
.../Debug/TraceableEventDispatcher.php | 332 +
.../TraceableEventDispatcherInterface.php | 36 +
.../Debug/WrappedListener.php | 125 +
.../RegisterListenersPass.php | 137 +
vendor/symfony/event-dispatcher/Event.php | 58 +
.../event-dispatcher/EventDispatcher.php | 238 +
.../EventDispatcherInterface.php | 93 +
.../EventSubscriberInterface.php | 49 +
.../symfony/event-dispatcher/GenericEvent.php | 175 +
.../ImmutableEventDispatcher.php | 91 +
vendor/symfony/event-dispatcher/LICENSE | 19 +
vendor/symfony/event-dispatcher/README.md | 15 +
.../Tests/AbstractEventDispatcherTest.php | 442 +
.../ContainerAwareEventDispatcherTest.php | 210 +
.../Debug/TraceableEventDispatcherTest.php | 294 +
.../Tests/Debug/WrappedListenerTest.php | 64 +
.../RegisterListenersPassTest.php | 143 +
.../Tests/EventDispatcherTest.php | 22 +
.../event-dispatcher/Tests/EventTest.php | 55 +
.../Tests/GenericEventTest.php | 134 +
.../Tests/ImmutableEventDispatcherTest.php | 100 +
vendor/symfony/event-dispatcher/composer.json | 43 +
.../symfony/event-dispatcher/phpunit.xml.dist | 31 +
vendor/symfony/finder/.gitignore | 3 +
vendor/symfony/finder/CHANGELOG.md | 55 +
.../symfony/finder/Comparator/Comparator.php | 98 +
.../finder/Comparator/DateComparator.php | 51 +
.../finder/Comparator/NumberComparator.php | 79 +
.../Exception/AccessDeniedException.php | 19 +
.../finder/Exception/ExceptionInterface.php | 25 +
vendor/symfony/finder/Finder.php | 759 +
vendor/symfony/finder/Glob.php | 116 +
.../finder/Iterator/CustomFilterIterator.php | 61 +
.../Iterator/DateRangeFilterIterator.php | 58 +
.../Iterator/DepthRangeFilterIterator.php | 45 +
.../ExcludeDirectoryFilterIterator.php | 84 +
.../Iterator/FileTypeFilterIterator.php | 53 +
.../Iterator/FilecontentFilterIterator.php | 58 +
.../Iterator/FilenameFilterIterator.php | 47 +
.../finder/Iterator/FilterIterator.php | 60 +
.../Iterator/MultiplePcreFilterIterator.php | 112 +
.../finder/Iterator/PathFilterIterator.php | 56 +
.../Iterator/RecursiveDirectoryIterator.php | 158 +
.../Iterator/SizeRangeFilterIterator.php | 57 +
.../finder/Iterator/SortableIterator.php | 80 +
vendor/symfony/finder/LICENSE | 19 +
vendor/symfony/finder/README.md | 14 +
vendor/symfony/finder/SplFileInfo.php | 78 +
.../Tests/Comparator/ComparatorTest.php | 65 +
.../Tests/Comparator/DateComparatorTest.php | 64 +
.../Tests/Comparator/NumberComparatorTest.php | 108 +
vendor/symfony/finder/Tests/FinderTest.php | 752 +
vendor/symfony/finder/Tests/Fixtures/.dot/a | 0
.../finder/Tests/Fixtures/.dot/b/c.neon | 0
.../finder/Tests/Fixtures/.dot/b/d.neon | 0
.../finder/Tests/Fixtures/A/B/C/abc.dat | 0
.../symfony/finder/Tests/Fixtures/A/B/ab.dat | 0
vendor/symfony/finder/Tests/Fixtures/A/a.dat | 0
.../Tests/Fixtures/copy/A/B/C/abc.dat.copy | 0
.../Tests/Fixtures/copy/A/B/ab.dat.copy | 0
.../finder/Tests/Fixtures/copy/A/a.dat.copy | 0
.../symfony/finder/Tests/Fixtures/dolor.txt | 2 +
.../symfony/finder/Tests/Fixtures/ipsum.txt | 2 +
.../symfony/finder/Tests/Fixtures/lorem.txt | 2 +
vendor/symfony/finder/Tests/Fixtures/one/.dot | 1 +
vendor/symfony/finder/Tests/Fixtures/one/a | 0
.../finder/Tests/Fixtures/one/b/c.neon | 0
.../finder/Tests/Fixtures/one/b/d.neon | 0
.../Fixtures/r+e.gex[c]a(r)s/dir/bar.dat | 0
.../finder/Tests/Fixtures/with space/foo.txt | 0
vendor/symfony/finder/Tests/GlobTest.php | 95 +
.../Iterator/CustomFilterIteratorTest.php | 44 +
.../Iterator/DateRangeFilterIteratorTest.php | 74 +
.../Iterator/DepthRangeFilterIteratorTest.php | 83 +
.../ExcludeDirectoryFilterIteratorTest.php | 80 +
.../Iterator/FileTypeFilterIteratorTest.php | 73 +
.../FilecontentFilterIteratorTest.php | 86 +
.../Iterator/FilenameFilterIteratorTest.php | 54 +
.../Tests/Iterator/FilterIteratorTest.php | 53 +
.../finder/Tests/Iterator/Iterator.php | 55 +
.../Tests/Iterator/IteratorTestCase.php | 93 +
.../Tests/Iterator/MockFileListIterator.php | 21 +
.../finder/Tests/Iterator/MockSplFileInfo.php | 132 +
.../MultiplePcreFilterIteratorTest.php | 71 +
.../Tests/Iterator/PathFilterIteratorTest.php | 82 +
.../Tests/Iterator/RealIteratorTestCase.php | 119 +
.../RecursiveDirectoryIteratorTest.php | 59 +
.../Iterator/SizeRangeFilterIteratorTest.php | 69 +
.../Tests/Iterator/SortableIteratorTest.php | 179 +
vendor/symfony/finder/composer.json | 28 +
vendor/symfony/finder/phpunit.xml.dist | 30 +
vendor/symfony/http-foundation/.gitignore | 3 +
.../symfony/http-foundation/AcceptHeader.php | 168 +
.../http-foundation/AcceptHeaderItem.php | 208 +
.../symfony/http-foundation/ApacheRequest.php | 43 +
.../http-foundation/BinaryFileResponse.php | 367 +
vendor/symfony/http-foundation/CHANGELOG.md | 165 +
vendor/symfony/http-foundation/Cookie.php | 303 +
.../Exception/ConflictingHeadersException.php | 21 +
.../Exception/RequestExceptionInterface.php | 21 +
.../SuspiciousOperationException.php | 20 +
.../ExpressionRequestMatcher.php | 47 +
.../File/Exception/AccessDeniedException.php | 28 +
.../File/Exception/FileException.php | 21 +
.../File/Exception/FileNotFoundException.php | 28 +
.../Exception/UnexpectedTypeException.php | 20 +
.../File/Exception/UploadException.php | 21 +
vendor/symfony/http-foundation/File/File.php | 138 +
.../File/MimeType/ExtensionGuesser.php | 96 +
.../MimeType/ExtensionGuesserInterface.php | 27 +
.../MimeType/FileBinaryMimeTypeGuesser.php | 99 +
.../File/MimeType/FileinfoMimeTypeGuesser.php | 75 +
.../MimeType/MimeTypeExtensionGuesser.php | 819 +
.../File/MimeType/MimeTypeGuesser.php | 135 +
.../MimeType/MimeTypeGuesserInterface.php | 35 +
.../symfony/http-foundation/File/Stream.php | 28 +
.../http-foundation/File/UploadedFile.php | 281 +
vendor/symfony/http-foundation/FileBag.php | 142 +
vendor/symfony/http-foundation/HeaderBag.php | 339 +
vendor/symfony/http-foundation/IpUtils.php | 156 +
.../symfony/http-foundation/JsonResponse.php | 235 +
vendor/symfony/http-foundation/LICENSE | 19 +
.../symfony/http-foundation/ParameterBag.php | 234 +
vendor/symfony/http-foundation/README.md | 14 +
.../http-foundation/RedirectResponse.php | 109 +
vendor/symfony/http-foundation/Request.php | 2197 ++
.../http-foundation/RequestMatcher.php | 177 +
.../RequestMatcherInterface.php | 27 +
.../symfony/http-foundation/RequestStack.php | 103 +
vendor/symfony/http-foundation/Response.php | 1312 +
.../http-foundation/ResponseHeaderBag.php | 343 +
vendor/symfony/http-foundation/ServerBag.php | 102 +
.../Session/Attribute/AttributeBag.php | 148 +
.../Attribute/AttributeBagInterface.php | 72 +
.../Attribute/NamespacedAttributeBag.php | 159 +
.../Session/Flash/AutoExpireFlashBag.php | 161 +
.../Session/Flash/FlashBag.php | 152 +
.../Session/Flash/FlashBagInterface.php | 93 +
.../http-foundation/Session/Session.php | 282 +
.../Session/SessionBagInterface.php | 46 +
.../Session/SessionBagProxy.php | 89 +
.../Session/SessionInterface.php | 180 +
.../http-foundation/Session/SessionUtils.php | 59 +
.../Handler/AbstractSessionHandler.php | 171 +
.../Handler/MemcacheSessionHandler.php | 118 +
.../Handler/MemcachedSessionHandler.php | 119 +
.../Storage/Handler/MongoDbSessionHandler.php | 255 +
.../Handler/NativeFileSessionHandler.php | 55 +
.../Storage/Handler/NativeSessionHandler.php | 24 +
.../Storage/Handler/NullSessionHandler.php | 76 +
.../Storage/Handler/PdoSessionHandler.php | 918 +
.../Storage/Handler/StrictSessionHandler.php | 103 +
.../Handler/WriteCheckSessionHandler.php | 92 +
.../Session/Storage/MetadataBag.php | 168 +
.../Storage/MockArraySessionStorage.php | 256 +
.../Storage/MockFileSessionStorage.php | 152 +
.../Session/Storage/NativeSessionStorage.php | 466 +
.../Storage/PhpBridgeSessionStorage.php | 63 +
.../Session/Storage/Proxy/AbstractProxy.php | 122 +
.../Session/Storage/Proxy/NativeProxy.php | 40 +
.../Storage/Proxy/SessionHandlerProxy.php | 101 +
.../Storage/SessionStorageInterface.php | 137 +
.../http-foundation/StreamedResponse.php | 144 +
.../Tests/AcceptHeaderItemTest.php | 113 +
.../Tests/AcceptHeaderTest.php | 103 +
.../Tests/ApacheRequestTest.php | 93 +
.../Tests/BinaryFileResponseTest.php | 387 +
.../http-foundation/Tests/CookieTest.php | 243 +
.../Tests/ExpressionRequestMatcherTest.php | 67 +
.../http-foundation/Tests/File/FakeFile.php | 45 +
.../http-foundation/Tests/File/FileTest.php | 180 +
.../http-foundation/Tests/File/Fixtures/-test | Bin 0 -> 35 bytes
.../Tests/File/Fixtures/.unknownextension | 1 +
.../Fixtures/case-sensitive-mime-type.xlsm | Bin 0 -> 4791 bytes
.../Tests/File/Fixtures/directory/.empty | 0
.../Tests/File/Fixtures/other-file.example | 0
.../http-foundation/Tests/File/Fixtures/test | Bin 0 -> 35 bytes
.../Tests/File/Fixtures/test.docx | Bin 0 -> 6062 bytes
.../Tests/File/Fixtures/test.gif | Bin 0 -> 35 bytes
.../Tests/File/MimeType/MimeTypeTest.php | 113 +
.../Tests/File/UploadedFileTest.php | 298 +
.../http-foundation/Tests/FileBagTest.php | 173 +
.../Fixtures/response-functional/common.inc | 43 +
.../cookie_max_age.expected | 11 +
.../response-functional/cookie_max_age.php | 10 +
.../cookie_raw_urlencode.expected | 10 +
.../cookie_raw_urlencode.php | 12 +
.../cookie_samesite_lax.expected | 9 +
.../cookie_samesite_lax.php | 8 +
.../cookie_samesite_strict.expected | 9 +
.../cookie_samesite_strict.php | 8 +
.../cookie_urlencode.expected | 11 +
.../response-functional/cookie_urlencode.php | 15 +
.../invalid_cookie_name.expected | 6 +
.../invalid_cookie_name.php | 11 +
.../http-foundation/Tests/HeaderBagTest.php | 213 +
.../http-foundation/Tests/IpUtilsTest.php | 104 +
.../Tests/JsonResponseTest.php | 262 +
.../Tests/ParameterBagTest.php | 194 +
.../Tests/RedirectResponseTest.php | 92 +
.../Tests/RequestMatcherTest.php | 151 +
.../Tests/RequestStackTest.php | 70 +
.../http-foundation/Tests/RequestTest.php | 2451 ++
.../Tests/ResponseFunctionalTest.php | 62 +
.../Tests/ResponseHeaderBagTest.php | 367 +
.../http-foundation/Tests/ResponseTest.php | 1012 +
.../Tests/ResponseTestCase.php | 89 +
.../http-foundation/Tests/ServerBagTest.php | 170 +
.../Session/Attribute/AttributeBagTest.php | 186 +
.../Attribute/NamespacedAttributeBagTest.php | 204 +
.../Session/Flash/AutoExpireFlashBagTest.php | 161 +
.../Tests/Session/Flash/FlashBagTest.php | 157 +
.../Tests/Session/SessionTest.php | 288 +
.../Handler/AbstractSessionHandlerTest.php | 61 +
.../Storage/Handler/Fixtures/common.inc | 151 +
.../Handler/Fixtures/empty_destroys.expected | 17 +
.../Handler/Fixtures/empty_destroys.php | 8 +
.../Handler/Fixtures/read_only.expected | 14 +
.../Storage/Handler/Fixtures/read_only.php | 8 +
.../Handler/Fixtures/regenerate.expected | 25 +
.../Storage/Handler/Fixtures/regenerate.php | 10 +
.../Storage/Handler/Fixtures/storage.expected | 21 +
.../Storage/Handler/Fixtures/storage.php | 24 +
.../Handler/Fixtures/with_cookie.expected | 15 +
.../Storage/Handler/Fixtures/with_cookie.php | 8 +
.../Fixtures/with_cookie_and_session.expected | 25 +
.../Fixtures/with_cookie_and_session.php | 13 +
.../Handler/Fixtures/with_samesite.expected | 16 +
.../Handler/Fixtures/with_samesite.php | 13 +
.../with_samesite_and_migration.expected | 23 +
.../Fixtures/with_samesite_and_migration.php | 15 +
.../Handler/MemcacheSessionHandlerTest.php | 135 +
.../Handler/MemcachedSessionHandlerTest.php | 145 +
.../Handler/MongoDbSessionHandlerTest.php | 330 +
.../Handler/NativeFileSessionHandlerTest.php | 75 +
.../Handler/NativeSessionHandlerTest.php | 38 +
.../Handler/NullSessionHandlerTest.php | 59 +
.../Storage/Handler/PdoSessionHandlerTest.php | 405 +
.../Handler/StrictSessionHandlerTest.php | 189 +
.../Handler/WriteCheckSessionHandlerTest.php | 97 +
.../Tests/Session/Storage/MetadataBagTest.php | 139 +
.../Storage/MockArraySessionStorageTest.php | 129 +
.../Storage/MockFileSessionStorageTest.php | 125 +
.../Storage/NativeSessionStorageTest.php | 303 +
.../Storage/PhpBridgeSessionStorageTest.php | 96 +
.../Storage/Proxy/AbstractProxyTest.php | 113 +
.../Session/Storage/Proxy/NativeProxyTest.php | 38 +
.../Storage/Proxy/SessionHandlerProxyTest.php | 162 +
.../Tests/StreamedResponseTest.php | 140 +
.../Tests/schema/http-status-codes.rng | 31 +
.../Tests/schema/iana-registry.rng | 198 +
vendor/symfony/http-foundation/composer.json | 33 +
.../symfony/http-foundation/phpunit.xml.dist | 31 +
vendor/symfony/http-kernel/.gitignore | 5 +
vendor/symfony/http-kernel/Bundle/Bundle.php | 211 +
.../http-kernel/Bundle/BundleInterface.php | 84 +
vendor/symfony/http-kernel/CHANGELOG.md | 151 +
.../CacheClearer/CacheClearerInterface.php | 27 +
.../CacheClearer/ChainCacheClearer.php | 56 +
.../CacheClearer/Psr6CacheClearer.php | 58 +
.../http-kernel/CacheWarmer/CacheWarmer.php | 32 +
.../CacheWarmer/CacheWarmerAggregate.php | 90 +
.../CacheWarmer/CacheWarmerInterface.php | 32 +
.../CacheWarmer/WarmableInterface.php | 27 +
vendor/symfony/http-kernel/Client.php | 206 +
.../Config/EnvParametersResource.php | 105 +
.../http-kernel/Config/FileLocator.php | 54 +
.../Controller/ArgumentResolver.php | 94 +
.../ArgumentResolver/DefaultValueResolver.php | 40 +
.../RequestAttributeValueResolver.php | 40 +
.../ArgumentResolver/RequestValueResolver.php | 40 +
.../ArgumentResolver/ServiceValueResolver.php | 77 +
.../ArgumentResolver/SessionValueResolver.php | 46 +
.../VariadicValueResolver.php | 48 +
.../Controller/ArgumentResolverInterface.php | 34 +
.../ArgumentValueResolverInterface.php | 37 +
.../ContainerControllerResolver.php | 121 +
.../Controller/ControllerReference.php | 44 +
.../Controller/ControllerResolver.php | 281 +
.../ControllerResolverInterface.php | 57 +
.../Controller/TraceableArgumentResolver.php | 44 +
.../TraceableControllerResolver.php | 69 +
.../ControllerMetadata/ArgumentMetadata.php | 115 +
.../ArgumentMetadataFactory.php | 135 +
.../ArgumentMetadataFactoryInterface.php | 27 +
.../DataCollector/AjaxDataCollector.php | 38 +
.../DataCollector/ConfigDataCollector.php | 332 +
.../DataCollector/DataCollector.php | 134 +
.../DataCollector/DataCollectorInterface.php | 37 +
.../DataCollector/DumpDataCollector.php | 315 +
.../DataCollector/EventDataCollector.php | 124 +
.../DataCollector/ExceptionDataCollector.php | 112 +
.../LateDataCollectorInterface.php | 25 +
.../DataCollector/LoggerDataCollector.php | 277 +
.../DataCollector/MemoryDataCollector.php | 120 +
.../DataCollector/RequestDataCollector.php | 415 +
.../DataCollector/RouterDataCollector.php | 108 +
.../DataCollector/TimeDataCollector.php | 157 +
.../DataCollector/Util/ValueExporter.php | 99 +
.../http-kernel/Debug/FileLinkFormatter.php | 117 +
.../Debug/TraceableEventDispatcher.php | 91 +
.../AddAnnotatedClassesToCachePass.php | 153 +
.../AddClassesToCachePass.php | 25 +
.../ConfigurableExtension.php | 42 +
.../ControllerArgumentValueResolverPass.php | 48 +
.../DependencyInjection/Extension.php | 77 +
.../FragmentRendererPass.php | 67 +
.../LazyLoadingFragmentHandler.php | 79 +
.../DependencyInjection/LoggerPass.php | 41 +
.../MergeExtensionConfigurationPass.php | 41 +
...RegisterControllerArgumentLocatorsPass.php | 179 +
...oveEmptyControllerArgumentLocatorsPass.php | 76 +
.../ResettableServicePass.php | 66 +
.../DependencyInjection/ServicesResetter.php | 39 +
.../Event/FilterControllerArgumentsEvent.php | 52 +
.../Event/FilterControllerEvent.php | 53 +
.../http-kernel/Event/FilterResponseEvent.php | 55 +
.../http-kernel/Event/FinishRequestEvent.php | 21 +
.../http-kernel/Event/GetResponseEvent.php | 58 +
.../GetResponseForControllerResultEvent.php | 61 +
.../Event/GetResponseForExceptionEvent.php | 90 +
.../symfony/http-kernel/Event/KernelEvent.php | 82 +
.../http-kernel/Event/PostResponseEvent.php | 46 +
.../EventListener/AbstractSessionListener.php | 92 +
.../AbstractTestSessionListener.php | 100 +
.../AddRequestFormatsListener.php | 50 +
.../EventListener/DebugHandlersListener.php | 160 +
.../EventListener/DumpListener.php | 55 +
.../EventListener/ExceptionListener.php | 128 +
.../EventListener/FragmentListener.php | 99 +
.../EventListener/LocaleListener.php | 83 +
.../EventListener/ProfilerListener.php | 128 +
.../EventListener/ResponseListener.php | 56 +
.../EventListener/RouterListener.php | 176 +
.../EventListener/SaveSessionListener.php | 66 +
.../EventListener/SessionListener.php | 40 +
.../StreamedResponseListener.php | 49 +
.../EventListener/SurrogateListener.php | 65 +
.../EventListener/TestSessionListener.php | 40 +
.../EventListener/TranslatorListener.php | 69 +
.../EventListener/ValidateRequestListener.php | 53 +
.../Exception/AccessDeniedHttpException.php | 29 +
.../Exception/BadRequestHttpException.php | 28 +
.../Exception/ConflictHttpException.php | 28 +
.../Exception/GoneHttpException.php | 28 +
.../http-kernel/Exception/HttpException.php | 51 +
.../Exception/HttpExceptionInterface.php | 34 +
.../Exception/LengthRequiredHttpException.php | 28 +
.../MethodNotAllowedHttpException.php | 31 +
.../Exception/NotAcceptableHttpException.php | 28 +
.../Exception/NotFoundHttpException.php | 28 +
.../PreconditionFailedHttpException.php | 28 +
.../PreconditionRequiredHttpException.php | 30 +
.../ServiceUnavailableHttpException.php | 34 +
.../TooManyRequestsHttpException.php | 36 +
.../Exception/UnauthorizedHttpException.php | 31 +
.../UnprocessableEntityHttpException.php | 28 +
.../UnsupportedMediaTypeHttpException.php | 28 +
.../AbstractSurrogateFragmentRenderer.php | 110 +
.../Fragment/EsiFragmentRenderer.php | 28 +
.../http-kernel/Fragment/FragmentHandler.php | 114 +
.../Fragment/FragmentRendererInterface.php | 42 +
.../Fragment/HIncludeFragmentRenderer.php | 167 +
.../Fragment/InlineFragmentRenderer.php | 142 +
.../Fragment/RoutableFragmentRenderer.php | 90 +
.../Fragment/SsiFragmentRenderer.php | 28 +
.../HttpCache/AbstractSurrogate.php | 136 +
vendor/symfony/http-kernel/HttpCache/Esi.php | 117 +
.../http-kernel/HttpCache/HttpCache.php | 724 +
.../HttpCache/ResponseCacheStrategy.php | 219 +
.../ResponseCacheStrategyInterface.php | 37 +
vendor/symfony/http-kernel/HttpCache/Ssi.php | 100 +
.../symfony/http-kernel/HttpCache/Store.php | 508 +
.../http-kernel/HttpCache/StoreInterface.php | 83 +
.../HttpCache/SubRequestHandler.php | 108 +
.../HttpCache/SurrogateInterface.php | 92 +
vendor/symfony/http-kernel/HttpKernel.php | 301 +
.../http-kernel/HttpKernelInterface.php | 43 +
vendor/symfony/http-kernel/Kernel.php | 978 +
vendor/symfony/http-kernel/KernelEvents.php | 103 +
.../symfony/http-kernel/KernelInterface.php | 165 +
vendor/symfony/http-kernel/LICENSE | 19 +
.../http-kernel/Log/DebugLoggerInterface.php | 40 +
vendor/symfony/http-kernel/Log/Logger.php | 119 +
.../Profiler/FileProfilerStorage.php | 292 +
.../symfony/http-kernel/Profiler/Profile.php | 290 +
.../symfony/http-kernel/Profiler/Profiler.php | 268 +
.../Profiler/ProfilerStorageInterface.php | 57 +
vendor/symfony/http-kernel/README.md | 16 +
.../http-kernel/RebootableInterface.php | 30 +
.../http-kernel/Resources/welcome.html.php | 70 +
.../http-kernel/TerminableInterface.php | 32 +
.../http-kernel/Tests/Bundle/BundleTest.php | 105 +
.../CacheClearer/ChainCacheClearerTest.php | 61 +
.../CacheClearer/Psr6CacheClearerTest.php | 67 +
.../CacheWarmer/CacheWarmerAggregateTest.php | 107 +
.../Tests/CacheWarmer/CacheWarmerTest.php | 66 +
.../symfony/http-kernel/Tests/ClientTest.php | 179 +
.../Config/EnvParametersResourceTest.php | 110 +
.../Tests/Config/FileLocatorTest.php | 48 +
.../ServiceValueResolverTest.php | 130 +
.../Tests/Controller/ArgumentResolverTest.php | 341 +
.../ContainerControllerResolverTest.php | 285 +
.../Controller/ControllerResolverTest.php | 333 +
.../ArgumentMetadataFactoryTest.php | 148 +
.../ArgumentMetadataTest.php | 44 +
.../Tests/DataCollector/Compiler.log | 4 +
.../DataCollector/ConfigDataCollectorTest.php | 66 +
.../Tests/DataCollector/DataCollectorTest.php | 38 +
.../DataCollector/DumpDataCollectorTest.php | 135 +
.../ExceptionDataCollectorTest.php | 59 +
.../DataCollector/LoggerDataCollectorTest.php | 146 +
.../DataCollector/MemoryDataCollectorTest.php | 59 +
.../RequestDataCollectorTest.php | 334 +
.../DataCollector/TimeDataCollectorTest.php | 57 +
.../DataCollector/Util/ValueExporterTest.php | 51 +
.../Tests/Debug/FileLinkFormatterTest.php | 66 +
.../Debug/TraceableEventDispatcherTest.php | 119 +
.../AddAnnotatedClassesToCachePassTest.php | 99 +
...ontrollerArgumentValueResolverPassTest.php | 67 +
.../FragmentRendererPassTest.php | 70 +
.../LazyLoadingFragmentHandlerTest.php | 66 +
.../DependencyInjection/LoggerPassTest.php | 56 +
.../MergeExtensionConfigurationPassTest.php | 50 +
...sterControllerArgumentLocatorsPassTest.php | 397 +
...mptyControllerArgumentLocatorsPassTest.php | 148 +
.../ResettableServicePassTest.php | 76 +
.../ServicesResetterTest.php | 42 +
.../FilterControllerArgumentsEventTest.php | 17 +
.../GetResponseForExceptionEventTest.php | 27 +
.../AddRequestFormatsListenerTest.php | 84 +
.../DebugHandlersListenerTest.php | 155 +
.../Tests/EventListener/DumpListenerTest.php | 81 +
.../EventListener/ExceptionListenerTest.php | 178 +
.../EventListener/FragmentListenerTest.php | 118 +
.../EventListener/LocaleListenerTest.php | 102 +
.../EventListener/ProfilerListenerTest.php | 70 +
.../EventListener/ResponseListenerTest.php | 95 +
.../EventListener/RouterListenerTest.php | 222 +
.../EventListener/SaveSessionListenerTest.php | 49 +
.../EventListener/SessionListenerTest.php | 121 +
.../EventListener/SurrogateListenerTest.php | 67 +
.../EventListener/TestSessionListenerTest.php | 221 +
.../EventListener/TranslatorListenerTest.php | 122 +
.../ValidateRequestListenerTest.php | 46 +
.../AccessDeniedHttpExceptionTest.php | 13 +
.../Exception/BadRequestHttpExceptionTest.php | 13 +
.../Exception/ConflictHttpExceptionTest.php | 13 +
.../Tests/Exception/GoneHttpExceptionTest.php | 13 +
.../Tests/Exception/HttpExceptionTest.php | 53 +
.../LengthRequiredHttpExceptionTest.php | 13 +
.../MethodNotAllowedHttpExceptionTest.php | 24 +
.../NotAcceptableHttpExceptionTest.php | 13 +
.../Exception/NotFoundHttpExceptionTest.php | 13 +
.../PreconditionFailedHttpExceptionTest.php | 13 +
.../PreconditionRequiredHttpExceptionTest.php | 13 +
.../ServiceUnavailableHttpExceptionTest.php | 29 +
.../TooManyRequestsHttpExceptionTest.php | 29 +
.../UnauthorizedHttpExceptionTest.php | 24 +
.../UnprocessableEntityHttpExceptionTest.php | 13 +
.../UnsupportedMediaTypeHttpExceptionTest.php | 13 +
.../Tests/Fixtures/123/Kernel123.php | 37 +
.../Fixtures/BaseBundle/Resources/foo.txt | 0
.../Fixtures/BaseBundle/Resources/hide.txt | 0
.../Fixtures/Bundle1Bundle/Resources/foo.txt | 0
.../Tests/Fixtures/Bundle1Bundle/bar.txt | 0
.../Tests/Fixtures/Bundle1Bundle/foo.txt | 0
.../Tests/Fixtures/Bundle2Bundle/foo.txt | 0
.../Fixtures/ChildBundle/Resources/foo.txt | 0
.../Fixtures/ChildBundle/Resources/hide.txt | 0
.../Tests/Fixtures/ClearableService.php | 13 +
.../Controller/BasicTypesController.php | 19 +
.../Fixtures/Controller/ExtendingRequest.php | 18 +
.../Fixtures/Controller/ExtendingSession.php | 18 +
.../Controller/LegacyNullableController.php | 19 +
.../Controller/NullableController.php | 19 +
.../Controller/VariadicController.php | 19 +
.../DataCollector/CloneVarDataCollector.php | 46 +
.../ExtensionAbsentBundle.php | 18 +
.../ExtensionNotValidExtension.php | 20 +
.../ExtensionNotValidBundle.php | 18 +
.../Command/FooCommand.php | 22 +
.../ExtensionPresentExtension.php | 22 +
.../ExtensionPresentBundle.php | 18 +
.../Tests/Fixtures/KernelForOverrideName.php | 28 +
.../Tests/Fixtures/KernelForTest.php | 42 +
.../Tests/Fixtures/KernelWithoutBundles.php | 33 +
.../Tests/Fixtures/ResettableService.php | 13 +
.../Fixtures/Resources/BaseBundle/hide.txt | 0
.../Fixtures/Resources/Bundle1Bundle/foo.txt | 0
.../Fixtures/Resources/ChildBundle/foo.txt | 0
.../Fixtures/Resources/FooBundle/foo.txt | 0
.../http-kernel/Tests/Fixtures/TestClient.php | 31 +
.../Fragment/EsiFragmentRendererTest.php | 114 +
.../Tests/Fragment/FragmentHandlerTest.php | 93 +
.../Fragment/HIncludeFragmentRendererTest.php | 100 +
.../Fragment/InlineFragmentRendererTest.php | 318 +
.../Fragment/RoutableFragmentRendererTest.php | 94 +
.../Fragment/SsiFragmentRendererTest.php | 93 +
.../http-kernel/Tests/HttpCache/EsiTest.php | 244 +
.../Tests/HttpCache/HttpCacheTest.php | 1702 ++
.../Tests/HttpCache/HttpCacheTestCase.php | 185 +
.../HttpCache/ResponseCacheStrategyTest.php | 469 +
.../http-kernel/Tests/HttpCache/SsiTest.php | 211 +
.../http-kernel/Tests/HttpCache/StoreTest.php | 355 +
.../Tests/HttpCache/SubRequestHandlerTest.php | 153 +
.../Tests/HttpCache/TestHttpKernel.php | 102 +
.../HttpCache/TestMultipleHttpKernel.php | 81 +
.../http-kernel/Tests/HttpKernelTest.php | 395 +
.../symfony/http-kernel/Tests/KernelTest.php | 1077 +
.../http-kernel/Tests/Log/LoggerTest.php | 206 +
vendor/symfony/http-kernel/Tests/Logger.php | 91 +
.../Profiler/FileProfilerStorageTest.php | 350 +
.../Tests/Profiler/ProfilerTest.php | 105 +
.../http-kernel/Tests/TestHttpKernel.php | 42 +
.../http-kernel/Tests/UriSignerTest.php | 76 +
vendor/symfony/http-kernel/UriSigner.php | 107 +
vendor/symfony/http-kernel/composer.json | 69 +
vendor/symfony/http-kernel/phpunit.xml.dist | 40 +
vendor/symfony/polyfill-ctype/Ctype.php | 227 +
vendor/symfony/polyfill-ctype/LICENSE | 19 +
vendor/symfony/polyfill-ctype/README.md | 12 +
vendor/symfony/polyfill-ctype/bootstrap.php | 46 +
vendor/symfony/polyfill-ctype/composer.json | 38 +
vendor/symfony/polyfill-mbstring/LICENSE | 19 +
vendor/symfony/polyfill-mbstring/Mbstring.php | 848 +
vendor/symfony/polyfill-mbstring/README.md | 13 +
.../Resources/mb_convert_variables.php8 | 31 +
.../Resources/unidata/lowerCase.php | 1397 +
.../Resources/unidata/titleCaseRegexp.php | 5 +
.../Resources/unidata/upperCase.php | 1414 +
.../symfony/polyfill-mbstring/bootstrap.php | 145 +
.../symfony/polyfill-mbstring/composer.json | 38 +
vendor/symfony/polyfill-php56/LICENSE | 19 +
vendor/symfony/polyfill-php56/Php56.php | 138 +
vendor/symfony/polyfill-php56/README.md | 15 +
vendor/symfony/polyfill-php56/bootstrap.php | 44 +
vendor/symfony/polyfill-php56/composer.json | 36 +
vendor/symfony/polyfill-php70/LICENSE | 19 +
vendor/symfony/polyfill-php70/Php70.php | 74 +
vendor/symfony/polyfill-php70/README.md | 28 +
.../Resources/stubs/ArithmeticError.php | 5 +
.../Resources/stubs/AssertionError.php | 5 +
.../Resources/stubs/DivisionByZeroError.php | 5 +
.../polyfill-php70/Resources/stubs/Error.php | 5 +
.../Resources/stubs/ParseError.php | 5 +
...SessionUpdateTimestampHandlerInterface.php | 23 +
.../Resources/stubs/TypeError.php | 5 +
vendor/symfony/polyfill-php70/bootstrap.php | 30 +
vendor/symfony/polyfill-php70/composer.json | 37 +
vendor/symfony/polyfill-util/Binary.php | 22 +
.../polyfill-util/BinaryNoFuncOverload.php | 65 +
.../polyfill-util/BinaryOnFuncOverload.php | 67 +
vendor/symfony/polyfill-util/LICENSE | 19 +
vendor/symfony/polyfill-util/README.md | 13 +
vendor/symfony/polyfill-util/TestListener.php | 28 +
.../polyfill-util/TestListenerForV5.php | 89 +
.../polyfill-util/TestListenerForV6.php | 95 +
.../polyfill-util/TestListenerForV7.php | 96 +
.../polyfill-util/TestListenerTrait.php | 129 +
vendor/symfony/polyfill-util/composer.json | 34 +
vendor/symfony/process/.gitignore | 3 +
vendor/symfony/process/CHANGELOG.md | 57 +
.../process/Exception/ExceptionInterface.php | 21 +
.../Exception/InvalidArgumentException.php | 21 +
.../process/Exception/LogicException.php | 21 +
.../Exception/ProcessFailedException.php | 54 +
.../Exception/ProcessTimedOutException.php | 69 +
.../process/Exception/RuntimeException.php | 21 +
vendor/symfony/process/ExecutableFinder.php | 88 +
vendor/symfony/process/InputStream.php | 92 +
vendor/symfony/process/LICENSE | 19 +
.../symfony/process/PhpExecutableFinder.php | 94 +
vendor/symfony/process/PhpProcess.php | 76 +
.../symfony/process/Pipes/AbstractPipes.php | 182 +
.../symfony/process/Pipes/PipesInterface.php | 67 +
vendor/symfony/process/Pipes/UnixPipes.php | 153 +
vendor/symfony/process/Pipes/WindowsPipes.php | 194 +
vendor/symfony/process/Process.php | 1746 ++
vendor/symfony/process/ProcessBuilder.php | 280 +
vendor/symfony/process/ProcessUtils.php | 123 +
vendor/symfony/process/README.md | 13 +
.../process/Tests/ErrorProcessInitiator.php | 36 +
.../process/Tests/ExecutableFinderTest.php | 175 +
.../process/Tests/NonStopableProcess.php | 47 +
.../process/Tests/PhpExecutableFinderTest.php | 72 +
.../symfony/process/Tests/PhpProcessTest.php | 48 +
.../PipeStdinInStdoutStdErrStreamSelect.php | 72 +
.../process/Tests/ProcessBuilderTest.php | 220 +
.../Tests/ProcessFailedExceptionTest.php | 133 +
vendor/symfony/process/Tests/ProcessTest.php | 1596 +
.../process/Tests/ProcessUtilsTest.php | 53 +
.../symfony/process/Tests/SignalListener.php | 21 +
vendor/symfony/process/composer.json | 28 +
vendor/symfony/process/phpunit.xml.dist | 30 +
vendor/symfony/routing/.gitignore | 3 +
vendor/symfony/routing/Annotation/Route.php | 144 +
vendor/symfony/routing/CHANGELOG.md | 228 +
vendor/symfony/routing/CompiledRoute.php | 169 +
.../RoutingResolverPass.php | 49 +
.../routing/Exception/ExceptionInterface.php | 21 +
.../Exception/InvalidParameterException.php | 21 +
.../Exception/MethodNotAllowedException.php | 41 +
.../MissingMandatoryParametersException.php | 22 +
.../Exception/NoConfigurationException.php | 21 +
.../Exception/ResourceNotFoundException.php | 23 +
.../Exception/RouteNotFoundException.php | 21 +
.../ConfigurableRequirementsInterface.php | 55 +
.../Generator/Dumper/GeneratorDumper.php | 37 +
.../Dumper/GeneratorDumperInterface.php | 39 +
.../Generator/Dumper/PhpGeneratorDumper.php | 118 +
.../routing/Generator/UrlGenerator.php | 326 +
.../Generator/UrlGeneratorInterface.php | 86 +
vendor/symfony/routing/LICENSE | 19 +
.../routing/Loader/AnnotationClassLoader.php | 278 +
.../Loader/AnnotationDirectoryLoader.php | 93 +
.../routing/Loader/AnnotationFileLoader.php | 152 +
.../symfony/routing/Loader/ClosureLoader.php | 46 +
.../Configurator/CollectionConfigurator.php | 81 +
.../Configurator/ImportConfigurator.php | 49 +
.../Loader/Configurator/RouteConfigurator.php | 34 +
.../Configurator/RoutingConfigurator.php | 63 +
.../Loader/Configurator/Traits/AddTrait.php | 55 +
.../Loader/Configurator/Traits/RouteTrait.php | 131 +
.../ServiceRouterLoader.php | 38 +
.../routing/Loader/DirectoryLoader.php | 58 +
.../symfony/routing/Loader/GlobFileLoader.php | 47 +
.../routing/Loader/ObjectRouteLoader.php | 95 +
.../symfony/routing/Loader/PhpFileLoader.php | 75 +
.../symfony/routing/Loader/XmlFileLoader.php | 361 +
.../symfony/routing/Loader/YamlFileLoader.php | 221 +
.../Loader/schema/routing/routing-1.0.xsd | 148 +
.../Matcher/Dumper/DumperCollection.php | 159 +
.../routing/Matcher/Dumper/DumperRoute.php | 57 +
.../routing/Matcher/Dumper/MatcherDumper.php | 37 +
.../Matcher/Dumper/MatcherDumperInterface.php | 39 +
.../Matcher/Dumper/PhpMatcherDumper.php | 429 +
.../Matcher/Dumper/StaticPrefixCollection.php | 238 +
.../Matcher/RedirectableUrlMatcher.php | 65 +
.../RedirectableUrlMatcherInterface.php | 31 +
.../Matcher/RequestMatcherInterface.php | 39 +
.../routing/Matcher/TraceableUrlMatcher.php | 170 +
vendor/symfony/routing/Matcher/UrlMatcher.php | 276 +
.../routing/Matcher/UrlMatcherInterface.php | 41 +
vendor/symfony/routing/README.md | 13 +
vendor/symfony/routing/RequestContext.php | 336 +
.../routing/RequestContextAwareInterface.php | 27 +
vendor/symfony/routing/Route.php | 558 +
vendor/symfony/routing/RouteCollection.php | 280 +
.../routing/RouteCollectionBuilder.php | 377 +
vendor/symfony/routing/RouteCompiler.php | 316 +
.../routing/RouteCompilerInterface.php | 30 +
vendor/symfony/routing/Router.php | 388 +
vendor/symfony/routing/RouterInterface.php | 35 +
.../routing/Tests/Annotation/RouteTest.php | 48 +
.../routing/Tests/CompiledRouteTest.php | 27 +
.../RoutingResolverPassTest.php | 36 +
.../AnnotatedClasses/AbstractClass.php | 21 +
.../Fixtures/AnnotatedClasses/BarClass.php | 19 +
.../Fixtures/AnnotatedClasses/BazClass.php | 19 +
.../AnnotatedClasses/EncodingClass.php | 10 +
.../Fixtures/AnnotatedClasses/FooClass.php | 16 +
.../Fixtures/AnnotatedClasses/FooTrait.php | 13 +
.../Tests/Fixtures/CustomCompiledRoute.php | 18 +
.../Tests/Fixtures/CustomRouteCompiler.php | 26 +
.../Tests/Fixtures/CustomXmlFileLoader.php | 26 +
.../AnonymousClassInTrait.php | 24 +
.../OtherAnnotatedClasses/NoStartTagClass.php | 3 +
.../OtherAnnotatedClasses/VariadicClass.php | 19 +
.../Tests/Fixtures/RedirectableUrlMatcher.php | 30 +
.../routing/Tests/Fixtures/annotated.php | 0
.../routing/Tests/Fixtures/bad_format.yml | 3 +
vendor/symfony/routing/Tests/Fixtures/bar.xml | 0
.../controller/import__controller.xml | 10 +
.../controller/import__controller.yml | 4 +
.../Fixtures/controller/import_controller.xml | 8 +
.../Fixtures/controller/import_controller.yml | 3 +
.../controller/import_override_defaults.xml | 10 +
.../controller/import_override_defaults.yml | 5 +
.../Fixtures/controller/override_defaults.xml | 10 +
.../Fixtures/controller/override_defaults.yml | 5 +
.../Tests/Fixtures/controller/routing.xml | 14 +
.../Tests/Fixtures/controller/routing.yml | 11 +
.../Fixtures/directory/recurse/routes1.yml | 2 +
.../Fixtures/directory/recurse/routes2.yml | 2 +
.../Tests/Fixtures/directory/routes3.yml | 2 +
.../Fixtures/directory_import/import.yml | 3 +
.../Tests/Fixtures/dumper/url_matcher0.php | 37 +
.../Tests/Fixtures/dumper/url_matcher1.php | 318 +
.../Tests/Fixtures/dumper/url_matcher2.php | 380 +
.../Tests/Fixtures/dumper/url_matcher3.php | 55 +
.../Tests/Fixtures/dumper/url_matcher4.php | 112 +
.../Tests/Fixtures/dumper/url_matcher5.php | 209 +
.../Tests/Fixtures/dumper/url_matcher6.php | 213 +
.../Tests/Fixtures/dumper/url_matcher7.php | 249 +
.../symfony/routing/Tests/Fixtures/empty.yml | 0
.../routing/Tests/Fixtures/file_resource.yml | 0
vendor/symfony/routing/Tests/Fixtures/foo.xml | 0
.../symfony/routing/Tests/Fixtures/foo1.xml | 0
.../routing/Tests/Fixtures/glob/bar.xml | 8 +
.../routing/Tests/Fixtures/glob/bar.yml | 4 +
.../routing/Tests/Fixtures/glob/baz.xml | 8 +
.../routing/Tests/Fixtures/glob/baz.yml | 4 +
.../Tests/Fixtures/glob/import_multiple.xml | 8 +
.../Tests/Fixtures/glob/import_multiple.yml | 2 +
.../Tests/Fixtures/glob/import_single.xml | 8 +
.../Tests/Fixtures/glob/import_single.yml | 2 +
.../routing/Tests/Fixtures/glob/php_dsl.php | 7 +
.../Tests/Fixtures/glob/php_dsl_bar.php | 12 +
.../Tests/Fixtures/glob/php_dsl_baz.php | 12 +
.../routing/Tests/Fixtures/incomplete.yml | 2 +
.../routing/Tests/Fixtures/list_defaults.xml | 20 +
.../Tests/Fixtures/list_in_list_defaults.xml | 22 +
.../Tests/Fixtures/list_in_map_defaults.xml | 22 +
.../Tests/Fixtures/list_null_values.xml | 22 +
.../routing/Tests/Fixtures/localized/utf8.xml | 13 +
.../routing/Tests/Fixtures/map_defaults.xml | 20 +
.../Tests/Fixtures/map_in_list_defaults.xml | 22 +
.../Tests/Fixtures/map_in_map_defaults.xml | 22 +
.../Tests/Fixtures/map_null_values.xml | 22 +
.../routing/Tests/Fixtures/missing_id.xml | 8 +
.../routing/Tests/Fixtures/missing_path.xml | 8 +
.../Tests/Fixtures/namespaceprefix.xml | 16 +
.../Fixtures/nonesense_resource_plus_path.yml | 3 +
.../nonesense_type_without_resource.yml | 3 +
.../routing/Tests/Fixtures/nonvalid.xml | 10 +
.../routing/Tests/Fixtures/nonvalid.yml | 1 +
.../routing/Tests/Fixtures/nonvalid2.yml | 1 +
.../routing/Tests/Fixtures/nonvalidkeys.yml | 3 +
.../routing/Tests/Fixtures/nonvalidnode.xml | 8 +
.../routing/Tests/Fixtures/nonvalidroute.xml | 12 +
.../routing/Tests/Fixtures/null_values.xml | 12 +
.../routing/Tests/Fixtures/php_dsl.php | 22 +
.../routing/Tests/Fixtures/php_dsl_sub.php | 14 +
.../Tests/Fixtures/scalar_defaults.xml | 33 +
.../Tests/Fixtures/special_route_name.yml | 2 +
.../routing/Tests/Fixtures/validpattern.php | 18 +
.../routing/Tests/Fixtures/validpattern.xml | 15 +
.../routing/Tests/Fixtures/validpattern.yml | 13 +
.../routing/Tests/Fixtures/validresource.php | 18 +
.../routing/Tests/Fixtures/validresource.xml | 13 +
.../routing/Tests/Fixtures/validresource.yml | 8 +
.../Fixtures/with_define_path_variable.php | 5 +
.../routing/Tests/Fixtures/withdoctype.xml | 3 +
.../Dumper/PhpGeneratorDumperTest.php | 177 +
.../Tests/Generator/UrlGeneratorTest.php | 747 +
.../Loader/AbstractAnnotationLoaderTest.php | 33 +
.../Loader/AnnotationClassLoaderTest.php | 348 +
.../Loader/AnnotationDirectoryLoaderTest.php | 110 +
.../Tests/Loader/AnnotationFileLoaderTest.php | 94 +
.../Tests/Loader/ClosureLoaderTest.php | 49 +
.../Tests/Loader/DirectoryLoaderTest.php | 74 +
.../Tests/Loader/GlobFileLoaderTest.php | 45 +
.../Tests/Loader/ObjectRouteLoaderTest.php | 117 +
.../Tests/Loader/PhpFileLoaderTest.php | 133 +
.../Tests/Loader/XmlFileLoaderTest.php | 399 +
.../Tests/Loader/YamlFileLoaderTest.php | 202 +
.../DumpedRedirectableUrlMatcherTest.php | 43 +
.../Tests/Matcher/DumpedUrlMatcherTest.php | 44 +
.../Matcher/Dumper/DumperCollectionTest.php | 34 +
.../Matcher/Dumper/PhpMatcherDumperTest.php | 454 +
.../Dumper/StaticPrefixCollectionTest.php | 175 +
.../Matcher/RedirectableUrlMatcherTest.php | 150 +
.../Tests/Matcher/TraceableUrlMatcherTest.php | 126 +
.../routing/Tests/Matcher/UrlMatcherTest.php | 616 +
.../routing/Tests/RequestContextTest.php | 160 +
.../Tests/RouteCollectionBuilderTest.php | 362 +
.../routing/Tests/RouteCollectionTest.php | 305 +
.../routing/Tests/RouteCompilerTest.php | 379 +
vendor/symfony/routing/Tests/RouteTest.php | 258 +
vendor/symfony/routing/Tests/RouterTest.php | 157 +
vendor/symfony/routing/composer.json | 49 +
vendor/symfony/routing/phpunit.xml.dist | 30 +
vendor/symfony/translation/.gitignore | 3 +
vendor/symfony/translation/CHANGELOG.md | 94 +
.../Catalogue/AbstractOperation.php | 157 +
.../translation/Catalogue/MergeOperation.php | 55 +
.../Catalogue/OperationInterface.php | 77 +
.../translation/Catalogue/TargetOperation.php | 69 +
.../translation/Command/XliffLintCommand.php | 250 +
.../TranslationDataCollector.php | 168 +
.../translation/DataCollectorTranslator.php | 177 +
.../TranslationDumperPass.php | 44 +
.../TranslationExtractorPass.php | 49 +
.../DependencyInjection/TranslatorPass.php | 95 +
.../translation/Dumper/CsvFileDumper.php | 63 +
.../translation/Dumper/DumperInterface.php | 31 +
.../symfony/translation/Dumper/FileDumper.php | 124 +
.../translation/Dumper/IcuResFileDumper.php | 104 +
.../translation/Dumper/IniFileDumper.php | 45 +
.../translation/Dumper/JsonFileDumper.php | 44 +
.../translation/Dumper/MoFileDumper.php | 82 +
.../translation/Dumper/PhpFileDumper.php | 38 +
.../translation/Dumper/PoFileDumper.php | 61 +
.../translation/Dumper/QtFileDumper.php | 50 +
.../translation/Dumper/XliffFileDumper.php | 200 +
.../translation/Dumper/YamlFileDumper.php | 62 +
.../Exception/ExceptionInterface.php | 21 +
.../Exception/InvalidArgumentException.php | 21 +
.../Exception/InvalidResourceException.php | 21 +
.../translation/Exception/LogicException.php | 21 +
.../Exception/NotFoundResourceException.php | 21 +
.../Exception/RuntimeException.php | 21 +
.../Extractor/AbstractFileExtractor.php | 85 +
.../translation/Extractor/ChainExtractor.php | 60 +
.../Extractor/ExtractorInterface.php | 38 +
.../translation/Extractor/PhpExtractor.php | 268 +
.../Extractor/PhpStringTokenParser.php | 142 +
.../ChoiceMessageFormatterInterface.php | 30 +
.../Formatter/MessageFormatter.php | 48 +
.../Formatter/MessageFormatterInterface.php | 30 +
.../translation/IdentityTranslator.php | 63 +
vendor/symfony/translation/Interval.php | 109 +
vendor/symfony/translation/LICENSE | 19 +
.../translation/Loader/ArrayLoader.php | 66 +
.../translation/Loader/CsvFileLoader.php | 69 +
.../symfony/translation/Loader/FileLoader.php | 65 +
.../translation/Loader/IcuDatFileLoader.php | 62 +
.../translation/Loader/IcuResFileLoader.php | 92 +
.../translation/Loader/IniFileLoader.php | 28 +
.../translation/Loader/JsonFileLoader.php | 64 +
.../translation/Loader/LoaderInterface.php | 38 +
.../translation/Loader/MoFileLoader.php | 143 +
.../translation/Loader/PhpFileLoader.php | 42 +
.../translation/Loader/PoFileLoader.php | 149 +
.../translation/Loader/QtFileLoader.php | 77 +
.../translation/Loader/XliffFileLoader.php | 343 +
.../translation/Loader/YamlFileLoader.php | 61 +
.../dic/xliff-core/xliff-core-1.2-strict.xsd | 2223 ++
.../schema/dic/xliff-core/xliff-core-2.0.xsd | 411 +
.../Loader/schema/dic/xliff-core/xml.xsd | 309 +
.../symfony/translation/LoggingTranslator.php | 135 +
.../symfony/translation/MessageCatalogue.php | 275 +
.../translation/MessageCatalogueInterface.php | 136 +
.../symfony/translation/MessageSelector.php | 94 +
.../translation/MetadataAwareInterface.php | 54 +
.../translation/PluralizationRules.php | 210 +
vendor/symfony/translation/README.md | 31 +
.../translation/Reader/TranslationReader.php | 62 +
.../Reader/TranslationReaderInterface.php | 29 +
.../Resources/bin/translation-status.php | 207 +
.../schemas/xliff-core-1.2-strict.xsd | 2223 ++
.../Tests/Catalogue/AbstractOperationTest.php | 74 +
.../Tests/Catalogue/MergeOperationTest.php | 83 +
.../Tests/Catalogue/TargetOperationTest.php | 82 +
.../TranslationDataCollectorTest.php | 150 +
.../Tests/DataCollectorTranslatorTest.php | 97 +
.../TranslationDumperPassTest.php | 48 +
.../TranslationExtractorPassTest.php | 61 +
.../TranslationPassTest.php | 103 +
.../Tests/Dumper/CsvFileDumperTest.php | 30 +
.../Tests/Dumper/FileDumperTest.php | 89 +
.../Tests/Dumper/IcuResFileDumperTest.php | 29 +
.../Tests/Dumper/IniFileDumperTest.php | 29 +
.../Tests/Dumper/JsonFileDumperTest.php | 39 +
.../Tests/Dumper/MoFileDumperTest.php | 29 +
.../Tests/Dumper/PhpFileDumperTest.php | 29 +
.../Tests/Dumper/PoFileDumperTest.php | 29 +
.../Tests/Dumper/QtFileDumperTest.php | 29 +
.../Tests/Dumper/XliffFileDumperTest.php | 115 +
.../Tests/Dumper/YamlFileDumperTest.php | 45 +
.../Tests/Extractor/PhpExtractorTest.php | 97 +
.../Tests/Formatter/MessageFormatterTest.php | 82 +
.../Tests/IdentityTranslatorTest.php | 112 +
.../translation/Tests/IntervalTest.php | 47 +
.../Tests/Loader/CsvFileLoaderTest.php | 57 +
.../Tests/Loader/IcuDatFileLoaderTest.php | 60 +
.../Tests/Loader/IcuResFileLoaderTest.php | 47 +
.../Tests/Loader/IniFileLoaderTest.php | 49 +
.../Tests/Loader/JsonFileLoaderTest.php | 58 +
.../Tests/Loader/LocalizedTestCase.php | 24 +
.../Tests/Loader/MoFileLoaderTest.php | 71 +
.../Tests/Loader/PhpFileLoaderTest.php | 46 +
.../Tests/Loader/PoFileLoaderTest.php | 120 +
.../Tests/Loader/QtFileLoaderTest.php | 65 +
.../Tests/Loader/XliffFileLoaderTest.php | 250 +
.../Tests/Loader/YamlFileLoaderTest.php | 65 +
.../Tests/LoggingTranslatorTest.php | 50 +
.../Tests/MessageCatalogueTest.php | 216 +
.../translation/Tests/MessageSelectorTest.php | 137 +
.../Tests/PluralizationRulesTest.php | 122 +
.../translation/Tests/TranslatorCacheTest.php | 312 +
.../translation/Tests/TranslatorTest.php | 581 +
.../Tests/Util/ArrayConverterTest.php | 74 +
.../Tests/Writer/TranslationWriterTest.php | 82 +
.../Tests/fixtures/empty-translation.mo | Bin 0 -> 49 bytes
.../Tests/fixtures/empty-translation.po | 3 +
.../translation/Tests/fixtures/empty.csv | 0
.../translation/Tests/fixtures/empty.ini | 0
.../translation/Tests/fixtures/empty.json | 0
.../translation/Tests/fixtures/empty.mo | 0
.../translation/Tests/fixtures/empty.po | 0
.../translation/Tests/fixtures/empty.xlf | 0
.../translation/Tests/fixtures/empty.yml | 0
.../translation/Tests/fixtures/encoding.xlf | 16 +
.../Tests/fixtures/escaped-id-plurals.po | 10 +
.../translation/Tests/fixtures/escaped-id.po | 8 +
.../fixtures/extractor/resource.format.engine | 0
.../this.is.a.template.format.engine | 0
.../fixtures/extractor/translation.html.php | 59 +
.../Tests/fixtures/fuzzy-translations.po | 10 +
.../Tests/fixtures/invalid-xml-resources.xlf | 23 +
.../translation/Tests/fixtures/malformed.json | 3 +
.../translation/Tests/fixtures/messages.yml | 3 +
.../Tests/fixtures/messages_linear.yml | 2 +
.../Tests/fixtures/missing-plurals.po | 4 +
.../translation/Tests/fixtures/non-valid.xlf | 11 +
.../translation/Tests/fixtures/non-valid.yml | 1 +
.../translation/Tests/fixtures/plurals.mo | Bin 0 -> 448 bytes
.../translation/Tests/fixtures/plurals.po | 7 +
.../translation/Tests/fixtures/resname.xlf | 22 +
.../resourcebundle/corrupted/resources.dat | 1 +
.../Tests/fixtures/resourcebundle/dat/en.res | Bin 0 -> 120 bytes
.../Tests/fixtures/resourcebundle/dat/en.txt | 3 +
.../Tests/fixtures/resourcebundle/dat/fr.res | Bin 0 -> 124 bytes
.../Tests/fixtures/resourcebundle/dat/fr.txt | 3 +
.../resourcebundle/dat/packagelist.txt | 2 +
.../fixtures/resourcebundle/dat/resources.dat | Bin 0 -> 352 bytes
.../Tests/fixtures/resourcebundle/res/en.res | Bin 0 -> 84 bytes
.../Tests/fixtures/resources-2.0-clean.xlf | 23 +
.../resources-2.0-multi-segment-unit.xlf | 17 +
.../Tests/fixtures/resources-2.0.xlf | 25 +
.../Tests/fixtures/resources-clean.xlf | 25 +
.../Tests/fixtures/resources-notes-meta.xlf | 26 +
.../fixtures/resources-target-attributes.xlf | 14 +
.../Tests/fixtures/resources-tool-info.xlf | 14 +
.../translation/Tests/fixtures/resources.csv | 4 +
.../Tests/fixtures/resources.dump.json | 1 +
.../translation/Tests/fixtures/resources.ini | 1 +
.../translation/Tests/fixtures/resources.json | 3 +
.../translation/Tests/fixtures/resources.mo | Bin 0 -> 52 bytes
.../translation/Tests/fixtures/resources.php | 5 +
.../translation/Tests/fixtures/resources.po | 11 +
.../translation/Tests/fixtures/resources.ts | 10 +
.../translation/Tests/fixtures/resources.xlf | 23 +
.../translation/Tests/fixtures/resources.yml | 1 +
.../translation/Tests/fixtures/valid.csv | 4 +
.../Tests/fixtures/with-attributes.xlf | 21 +
.../Tests/fixtures/withdoctype.xlf | 12 +
.../translation/Tests/fixtures/withnote.xlf | 22 +
vendor/symfony/translation/Translator.php | 465 +
.../translation/TranslatorBagInterface.php | 33 +
.../translation/TranslatorInterface.php | 67 +
.../translation/Util/ArrayConverter.php | 99 +
.../translation/Writer/TranslationWriter.php | 103 +
.../Writer/TranslationWriterInterface.php | 34 +
vendor/symfony/translation/composer.json | 49 +
vendor/symfony/translation/phpunit.xml.dist | 30 +
vendor/symfony/var-dumper/.gitignore | 3 +
vendor/symfony/var-dumper/CHANGELOG.md | 13 +
.../symfony/var-dumper/Caster/AmqpCaster.php | 210 +
vendor/symfony/var-dumper/Caster/ArgsStub.php | 80 +
vendor/symfony/var-dumper/Caster/Caster.php | 192 +
.../symfony/var-dumper/Caster/ClassStub.php | 87 +
.../symfony/var-dumper/Caster/ConstStub.php | 33 +
.../var-dumper/Caster/CutArrayStub.php | 30 +
vendor/symfony/var-dumper/Caster/CutStub.php | 59 +
.../symfony/var-dumper/Caster/DOMCaster.php | 302 +
.../symfony/var-dumper/Caster/DateCaster.php | 133 +
.../var-dumper/Caster/DoctrineCaster.php | 60 +
vendor/symfony/var-dumper/Caster/EnumStub.php | 30 +
.../var-dumper/Caster/ExceptionCaster.php | 349 +
.../symfony/var-dumper/Caster/FrameStub.php | 30 +
vendor/symfony/var-dumper/Caster/LinkStub.php | 108 +
.../symfony/var-dumper/Caster/MongoCaster.php | 38 +
.../symfony/var-dumper/Caster/PdoCaster.php | 120 +
.../symfony/var-dumper/Caster/PgSqlCaster.php | 154 +
.../symfony/var-dumper/Caster/RedisCaster.php | 77 +
.../var-dumper/Caster/ReflectionCaster.php | 345 +
.../var-dumper/Caster/ResourceCaster.php | 77 +
.../symfony/var-dumper/Caster/SplCaster.php | 236 +
.../symfony/var-dumper/Caster/StubCaster.php | 82 +
.../var-dumper/Caster/SymfonyCaster.php | 43 +
.../symfony/var-dumper/Caster/TraceStub.php | 36 +
.../var-dumper/Caster/XmlReaderCaster.php | 77 +
.../var-dumper/Caster/XmlResourceCaster.php | 61 +
.../var-dumper/Cloner/AbstractCloner.php | 336 +
.../var-dumper/Cloner/ClonerInterface.php | 27 +
vendor/symfony/var-dumper/Cloner/Cursor.php | 43 +
vendor/symfony/var-dumper/Cloner/Data.php | 441 +
.../var-dumper/Cloner/DumperInterface.php | 60 +
vendor/symfony/var-dumper/Cloner/Stub.php | 67 +
.../symfony/var-dumper/Cloner/VarCloner.php | 335 +
.../var-dumper/Dumper/AbstractDumper.php | 213 +
.../symfony/var-dumper/Dumper/CliDumper.php | 601 +
.../var-dumper/Dumper/DataDumperInterface.php | 24 +
.../symfony/var-dumper/Dumper/HtmlDumper.php | 904 +
.../Exception/ThrowingCasterException.php | 26 +
vendor/symfony/var-dumper/LICENSE | 19 +
vendor/symfony/var-dumper/README.md | 15 +
.../var-dumper/Resources/functions/dump.php | 30 +
.../var-dumper/Test/VarDumperTestTrait.php | 63 +
.../var-dumper/Tests/Caster/CasterTest.php | 181 +
.../Tests/Caster/DateCasterTest.php | 461 +
.../Tests/Caster/ExceptionCasterTest.php | 227 +
.../var-dumper/Tests/Caster/PdoCasterTest.php | 65 +
.../Tests/Caster/RedisCasterTest.php | 84 +
.../Tests/Caster/ReflectionCasterTest.php | 270 +
.../var-dumper/Tests/Caster/SplCasterTest.php | 238 +
.../Tests/Caster/StubCasterTest.php | 192 +
.../Tests/Caster/XmlReaderCasterTest.php | 248 +
.../var-dumper/Tests/Cloner/DataTest.php | 115 +
.../var-dumper/Tests/Cloner/VarClonerTest.php | 505 +
.../var-dumper/Tests/Dumper/CliDumperTest.php | 644 +
.../var-dumper/Tests/Dumper/FunctionsTest.php | 57 +
.../Tests/Dumper/HtmlDumperTest.php | 168 +
.../Tests/Fixtures/DateTimeChild.php | 8 +
.../Tests/Fixtures/FooInterface.php | 11 +
.../Tests/Fixtures/GeneratorDemo.php | 21 +
.../Tests/Fixtures/NotLoadableClass.php | 7 +
.../var-dumper/Tests/Fixtures/Php74.php | 14 +
.../var-dumper/Tests/Fixtures/Twig.php | 38 +
.../var-dumper/Tests/Fixtures/dumb-var.php | 40 +
.../var-dumper/Tests/Fixtures/xml_reader.xml | 10 +
.../Tests/Test/VarDumperTestTraitTest.php | 41 +
vendor/symfony/var-dumper/VarDumper.php | 48 +
vendor/symfony/var-dumper/composer.json | 42 +
vendor/symfony/var-dumper/phpunit.xml.dist | 33 +
vendor/symfony/yaml/.gitignore | 3 +
vendor/symfony/yaml/CHANGELOG.md | 149 +
vendor/symfony/yaml/Command/LintCommand.php | 253 +
vendor/symfony/yaml/Dumper.php | 160 +
vendor/symfony/yaml/Escaper.php | 103 +
.../symfony/yaml/Exception/DumpException.php | 21 +
.../yaml/Exception/ExceptionInterface.php | 21 +
.../symfony/yaml/Exception/ParseException.php | 139 +
.../yaml/Exception/RuntimeException.php | 21 +
vendor/symfony/yaml/Inline.php | 927 +
vendor/symfony/yaml/LICENSE | 19 +
vendor/symfony/yaml/Parser.php | 1156 +
vendor/symfony/yaml/README.md | 13 +
vendor/symfony/yaml/Tag/TaggedValue.php | 48 +
.../yaml/Tests/Command/LintCommandTest.php | 137 +
vendor/symfony/yaml/Tests/DumperTest.php | 655 +
.../yaml/Tests/Fixtures/YtsAnchorAlias.yml | 31 +
.../yaml/Tests/Fixtures/YtsBasicTests.yml | 202 +
.../yaml/Tests/Fixtures/YtsBlockMapping.yml | 51 +
.../Tests/Fixtures/YtsDocumentSeparator.yml | 85 +
.../yaml/Tests/Fixtures/YtsErrorTests.yml | 25 +
.../Tests/Fixtures/YtsFlowCollections.yml | 60 +
.../yaml/Tests/Fixtures/YtsFoldedScalars.yml | 176 +
.../Tests/Fixtures/YtsNullsAndEmpties.yml | 45 +
.../Fixtures/YtsSpecificationExamples.yml | 1701 ++
.../yaml/Tests/Fixtures/YtsTypeTransfers.yml | 266 +
vendor/symfony/yaml/Tests/Fixtures/arrow.gif | Bin 0 -> 185 bytes
.../Tests/Fixtures/booleanMappingKeys.yml | 11 +
.../yaml/Tests/Fixtures/embededPhp.yml | 1 +
.../yaml/Tests/Fixtures/escapedCharacters.yml | 155 +
vendor/symfony/yaml/Tests/Fixtures/index.yml | 18 +
.../Fixtures/legacyBooleanMappingKeys.yml | 23 +
.../Tests/Fixtures/legacyNonStringKeys.yml | 2 +
.../Tests/Fixtures/legacyNullMappingKey.yml | 9 +
.../multiple_lines_as_literal_block.yml | 14 +
...nes_as_literal_block_for_tagged_values.yml | 2 +
...eral_block_leading_space_in_first_line.yml | 4 +
.../yaml/Tests/Fixtures/nonStringKeys.yml | 3 +
.../yaml/Tests/Fixtures/not_readable.yml | 18 +
.../yaml/Tests/Fixtures/nullMappingKey.yml | 9 +
.../Tests/Fixtures/numericMappingKeys.yml | 23 +
.../yaml/Tests/Fixtures/sfComments.yml | 90 +
.../symfony/yaml/Tests/Fixtures/sfCompact.yml | 159 +
.../yaml/Tests/Fixtures/sfMergeKey.yml | 61 +
.../symfony/yaml/Tests/Fixtures/sfObjects.yml | 11 +
.../symfony/yaml/Tests/Fixtures/sfQuotes.yml | 33 +
.../symfony/yaml/Tests/Fixtures/sfTests.yml | 140 +
.../Tests/Fixtures/unindentedCollections.yml | 82 +
vendor/symfony/yaml/Tests/InlineTest.php | 873 +
.../symfony/yaml/Tests/ParseExceptionTest.php | 34 +
vendor/symfony/yaml/Tests/ParserTest.php | 2401 ++
vendor/symfony/yaml/Tests/YamlTest.php | 40 +
vendor/symfony/yaml/Unescaper.php | 142 +
vendor/symfony/yaml/Yaml.php | 150 +
vendor/symfony/yaml/composer.json | 38 +
vendor/symfony/yaml/phpunit.xml.dist | 30 +
.../css-to-inline-styles/LICENSE.md | 23 +
.../css-to-inline-styles/composer.json | 38 +
.../src/Css/Processor.php | 71 +
.../src/Css/Property/Processor.php | 127 +
.../src/Css/Property/Property.php | 90 +
.../src/Css/Rule/Processor.php | 163 +
.../src/Css/Rule/Rule.php | 85 +
.../src/CssToInlineStyles.php | 240 +
vendor/vlucas/phpdotenv/LICENSE.txt | 32 +
vendor/vlucas/phpdotenv/composer.json | 44 +
vendor/vlucas/phpdotenv/src/Dotenv.php | 138 +
.../src/Exception/ExceptionInterface.php | 11 +
.../Exception/InvalidCallbackException.php | 13 +
.../src/Exception/InvalidFileException.php | 13 +
.../src/Exception/InvalidPathException.php | 13 +
.../src/Exception/ValidationException.php | 13 +
vendor/vlucas/phpdotenv/src/Loader.php | 382 +
vendor/vlucas/phpdotenv/src/Parser.php | 132 +
vendor/vlucas/phpdotenv/src/Validator.php | 149 +
vendor/webmozart/assert/.editorconfig | 12 +
vendor/webmozart/assert/CHANGELOG.md | 175 +
vendor/webmozart/assert/LICENSE | 20 +
vendor/webmozart/assert/README.md | 283 +
vendor/webmozart/assert/composer.json | 38 +
vendor/webmozart/assert/psalm.xml | 14 +
vendor/webmozart/assert/src/Assert.php | 2048 ++
vendor/webmozart/assert/src/Mixin.php | 1971 ++
5917 files changed, 715728 insertions(+)
create mode 100644 .env
create mode 100644 bootstrap/cache/services.php
create mode 100644 resources/views/create.blade.php
create mode 100644 resources/views/edit.blade.php
create mode 100644 resources/views/event.blade.php
create mode 100644 resources/views/events.blade.php
create mode 100644 storage/logs/laravel.log
create mode 100644 vendor/autoload.php
create mode 100644 vendor/bin/php-parse
create mode 100644 vendor/bin/php-parse.bat
create mode 100644 vendor/bin/phpunit
create mode 100644 vendor/bin/phpunit.bat
create mode 100644 vendor/bin/psysh
create mode 100644 vendor/bin/psysh.bat
create mode 100644 vendor/bin/upgrade-carbon
create mode 100644 vendor/bin/upgrade-carbon.bat
create mode 100644 vendor/composer/ClassLoader.php
create mode 100644 vendor/composer/InstalledVersions.php
create mode 100644 vendor/composer/LICENSE
create mode 100644 vendor/composer/autoload_classmap.php
create mode 100644 vendor/composer/autoload_files.php
create mode 100644 vendor/composer/autoload_namespaces.php
create mode 100644 vendor/composer/autoload_psr4.php
create mode 100644 vendor/composer/autoload_real.php
create mode 100644 vendor/composer/autoload_static.php
create mode 100644 vendor/composer/installed.json
create mode 100644 vendor/composer/installed.php
create mode 100644 vendor/composer/platform_check.php
create mode 100644 vendor/dnoegel/php-xdg-base-dir/LICENSE
create mode 100644 vendor/dnoegel/php-xdg-base-dir/README.md
create mode 100644 vendor/dnoegel/php-xdg-base-dir/composer.json
create mode 100644 vendor/dnoegel/php-xdg-base-dir/src/Xdg.php
create mode 100644 vendor/doctrine/inflector/.gitignore
create mode 100644 vendor/doctrine/inflector/.travis.yml
create mode 100644 vendor/doctrine/inflector/LICENSE
create mode 100644 vendor/doctrine/inflector/README.md
create mode 100644 vendor/doctrine/inflector/composer.json
create mode 100644 vendor/doctrine/inflector/lib/Doctrine/Common/Inflector/Inflector.php
create mode 100644 vendor/doctrine/inflector/phpunit.xml.dist
create mode 100644 vendor/doctrine/inflector/tests/Doctrine/Tests/Common/Inflector/InflectorTest.php
create mode 100644 vendor/doctrine/inflector/tests/Doctrine/Tests/DoctrineTestCase.php
create mode 100644 vendor/doctrine/inflector/tests/Doctrine/Tests/TestInit.php
create mode 100644 vendor/doctrine/instantiator/.gitignore
create mode 100644 vendor/doctrine/instantiator/.scrutinizer.yml
create mode 100644 vendor/doctrine/instantiator/.travis.install.sh
create mode 100644 vendor/doctrine/instantiator/.travis.yml
create mode 100644 vendor/doctrine/instantiator/CONTRIBUTING.md
create mode 100644 vendor/doctrine/instantiator/LICENSE
create mode 100644 vendor/doctrine/instantiator/README.md
create mode 100644 vendor/doctrine/instantiator/composer.json
create mode 100644 vendor/doctrine/instantiator/phpmd.xml.dist
create mode 100644 vendor/doctrine/instantiator/phpunit.xml.dist
create mode 100644 vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/ExceptionInterface.php
create mode 100644 vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/InvalidArgumentException.php
create mode 100644 vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/UnexpectedValueException.php
create mode 100644 vendor/doctrine/instantiator/src/Doctrine/Instantiator/Instantiator.php
create mode 100644 vendor/doctrine/instantiator/src/Doctrine/Instantiator/InstantiatorInterface.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorPerformance/InstantiatorPerformanceEvent.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/Exception/InvalidArgumentExceptionTest.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/Exception/UnexpectedValueExceptionTest.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/InstantiatorTest.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/AbstractClassAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/ArrayObjectAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/ExceptionAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/FinalExceptionAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/PharAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/PharExceptionAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SerializableArrayObjectAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SimpleSerializableAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SimpleTraitAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/UnCloneableAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/UnserializeExceptionArrayObjectAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/WakeUpNoticesAsset.php
create mode 100644 vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/XMLReaderAsset.php
create mode 100644 vendor/erusev/parsedown/LICENSE.txt
create mode 100644 vendor/erusev/parsedown/Parsedown.php
create mode 100644 vendor/erusev/parsedown/README.md
create mode 100644 vendor/erusev/parsedown/composer.json
create mode 100644 vendor/fzaninotto/faker/.github/ISSUE_TEMPLATE/bug_report.md
create mode 100644 vendor/fzaninotto/faker/.travis/xdebug.sh
create mode 100644 vendor/fzaninotto/faker/CHANGELOG.md
create mode 100644 vendor/fzaninotto/faker/LICENSE
create mode 100644 vendor/fzaninotto/faker/composer.json
create mode 100644 vendor/fzaninotto/faker/readme.md
create mode 100644 vendor/fzaninotto/faker/src/Faker/Calculator/Ean.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Calculator/Iban.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Calculator/Inn.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Calculator/Luhn.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Calculator/TCNo.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/DefaultGenerator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Documentor.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Factory.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Generator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Guesser/Name.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/ColumnTypeGuesser.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/EntityPopulator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/Populator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/ColumnTypeGuesser.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/EntityPopulator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/Populator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Mandango/ColumnTypeGuesser.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Mandango/EntityPopulator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Mandango/Populator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Propel/ColumnTypeGuesser.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Propel/EntityPopulator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Propel/Populator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Propel2/ColumnTypeGuesser.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Propel2/EntityPopulator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Propel2/Populator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Spot/ColumnTypeGuesser.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Spot/EntityPopulator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ORM/Spot/Populator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Barcode.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Base.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Biased.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/DateTime.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/File.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/HtmlLorem.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Image.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Lorem.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Miscellaneous.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/UserAgent.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/Uuid.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_SA/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_SA/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_SA/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_SA/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_SA/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_SA/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ar_SA/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/at_AT/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/bg_BG/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/bg_BG/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/bg_BG/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/bg_BG/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/bn_BD/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/bn_BD/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/bn_BD/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/bn_BD/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/bn_BD/Utils.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/DateTime.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/da_DK/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_AT/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_AT/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_AT/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_AT/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_AT/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_AT/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_AT/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_CH/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_CH/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_CH/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_CH/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_CH/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_CH/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_CH/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_DE/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_DE/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_DE/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_DE/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_DE/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_DE/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/de_DE/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_CY/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_CY/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_CY/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_CY/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_CY/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_CY/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_GR/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_GR/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_GR/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_GR/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_GR/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/el_GR/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_AU/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_AU/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_AU/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_CA/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_CA/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_GB/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_GB/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_GB/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_GB/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_GB/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_HK/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_HK/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_HK/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_IN/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_IN/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_IN/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_IN/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_NG/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_NG/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_NG/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_NG/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_NZ/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_NZ/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_NZ/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_PH/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_PH/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_SG/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_SG/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_UG/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_UG/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_UG/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_UG/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_US/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_US/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_US/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_US/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_US/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_US/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_AR/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_AR/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_AR/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_AR/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_ES/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_ES/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_ES/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_ES/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_ES/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_ES/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_ES/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_ES/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_PE/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_PE/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_PE/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_PE/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_VE/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_VE/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_VE/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_VE/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/es_VE/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/et_EE/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_BE/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_BE/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_BE/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_BE/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_BE/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_BE/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CA/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CA/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CA/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CA/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CH/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CH/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CH/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CH/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CH/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CH/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_CH/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/he_IL/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/he_IL/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/he_IL/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/he_IL/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/he_IL/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hr_HR/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hr_HR/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hr_HR/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hr_HR/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hr_HR/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hu_HU/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hu_HU/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hu_HU/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hu_HU/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hu_HU/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hu_HU/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hy_AM/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hy_AM/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hy_AM/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hy_AM/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hy_AM/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/hy_AM/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/id_ID/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/is_IS/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_CH/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_IT/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_IT/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_IT/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_IT/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_IT/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_IT/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/it_IT/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/DateTime.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/me_ME/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/me_ME/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/me_ME/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/me_ME/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/me_ME/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/mn_MN/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/mn_MN/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Miscellaneous.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ne_NP/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ne_NP/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ne_NP/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ne_NP/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_BE/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_BE/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_BE/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_BE/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_BE/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_BE/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_BE/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/check_digit.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ro_MD/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ro_MD/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ro_MD/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ro_MD/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ro_MD/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sk_SK/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sk_SK/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sk_SK/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sk_SK/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sk_SK/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sk_SK/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sl_SI/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sl_SI/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sl_SI/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sl_SI/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sl_SI/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sl_SI/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sr_Cyrl_RS/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sr_Cyrl_RS/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sr_Cyrl_RS/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sr_Latn_RS/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sr_Latn_RS/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sr_Latn_RS/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sr_RS/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sr_RS/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sr_RS/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sv_SE/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sv_SE/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sv_SE/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sv_SE/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/sv_SE/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/th_TH/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/th_TH/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/th_TH/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/th_TH/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/th_TH/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/th_TH/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/th_TH/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/DateTime.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/DateTime.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Address.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Color.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Company.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/DateTime.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Internet.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Payment.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Person.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/PhoneNumber.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Text.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/UniqueGenerator.php
create mode 100644 vendor/fzaninotto/faker/src/Faker/ValidGenerator.php
create mode 100644 vendor/fzaninotto/faker/src/autoload.php
create mode 100644 vendor/hamcrest/hamcrest-php/.coveralls.yml
create mode 100644 vendor/hamcrest/hamcrest-php/.gitignore
create mode 100644 vendor/hamcrest/hamcrest-php/.gush.yml
create mode 100644 vendor/hamcrest/hamcrest-php/.travis.yml
create mode 100644 vendor/hamcrest/hamcrest-php/CHANGES.txt
create mode 100644 vendor/hamcrest/hamcrest-php/LICENSE.txt
create mode 100644 vendor/hamcrest/hamcrest-php/README.md
create mode 100644 vendor/hamcrest/hamcrest-php/TODO.txt
create mode 100644 vendor/hamcrest/hamcrest-php/composer.json
create mode 100644 vendor/hamcrest/hamcrest-php/generator/FactoryCall.php
create mode 100644 vendor/hamcrest/hamcrest-php/generator/FactoryClass.php
create mode 100644 vendor/hamcrest/hamcrest-php/generator/FactoryFile.php
create mode 100644 vendor/hamcrest/hamcrest-php/generator/FactoryGenerator.php
create mode 100644 vendor/hamcrest/hamcrest-php/generator/FactoryMethod.php
create mode 100644 vendor/hamcrest/hamcrest-php/generator/FactoryParameter.php
create mode 100644 vendor/hamcrest/hamcrest-php/generator/GlobalFunctionFile.php
create mode 100644 vendor/hamcrest/hamcrest-php/generator/StaticMethodFile.php
create mode 100644 vendor/hamcrest/hamcrest-php/generator/parts/file_header.txt
create mode 100644 vendor/hamcrest/hamcrest-php/generator/parts/functions_footer.txt
create mode 100644 vendor/hamcrest/hamcrest-php/generator/parts/functions_header.txt
create mode 100644 vendor/hamcrest/hamcrest-php/generator/parts/functions_imports.txt
create mode 100644 vendor/hamcrest/hamcrest-php/generator/parts/matchers_footer.txt
create mode 100644 vendor/hamcrest/hamcrest-php/generator/parts/matchers_header.txt
create mode 100644 vendor/hamcrest/hamcrest-php/generator/parts/matchers_imports.txt
create mode 100644 vendor/hamcrest/hamcrest-php/generator/run.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArray.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContaining.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInAnyOrder.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInOrder.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKey.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKeyValuePair.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayWithSize.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/MatchingOnce.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/SeriesMatchingOnce.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/AssertionError.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/BaseDescription.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/BaseMatcher.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsEmptyTraversable.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsTraversableWithSize.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/AllOf.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/AnyOf.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/CombinableMatcher.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/DescribedAs.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Every.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/HasToString.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Is.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsAnything.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsCollectionContaining.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsEqual.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsIdentical.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsInstanceOf.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNot.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNull.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsSame.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsTypeOf.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Set.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/ShortcutCombination.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Description.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/DiagnosingMatcher.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/FeatureMatcher.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Internal/SelfDescribingValue.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matcher.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/MatcherAssert.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matchers.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/NullDescription.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Number/IsCloseTo.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Number/OrderingComparison.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/SelfDescribing.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/StringDescription.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEmptyString.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringCase.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringWhiteSpace.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/MatchesPattern.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContains.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsIgnoringCase.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsInOrder.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringEndsWith.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringStartsWith.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/SubstringMatcher.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsArray.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsBoolean.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsCallable.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsDouble.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsInteger.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsNumeric.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsObject.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsResource.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsScalar.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsString.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/TypeSafeDiagnosingMatcher.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/TypeSafeMatcher.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Util.php
create mode 100644 vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Xml/HasXPath.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/AbstractMatcherTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingInAnyOrderTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingInOrderTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingKeyTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingKeyValuePairTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayWithSizeTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/BaseMatcherTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Collection/IsEmptyTraversableTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Collection/IsTraversableWithSizeTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/AllOfTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/AnyOfTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/CombinableMatcherTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/DescribedAsTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/EveryTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/HasToStringTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsAnythingTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsCollectionContainingTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsEqualTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsIdenticalTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsInstanceOfTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsNotTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsNullTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsSameTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsTypeOfTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/SampleBaseClass.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/SampleSubClass.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/SetTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/FeatureMatcherTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/MatcherAssertTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Number/IsCloseToTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Number/OrderingComparisonTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/StringDescriptionTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEmptyStringTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEqualIgnoringCaseTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEqualIgnoringWhiteSpaceTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/MatchesPatternTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsIgnoringCaseTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsInOrderTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringEndsWithTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringStartsWithTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsArrayTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsBooleanTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsCallableTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsDoubleTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsIntegerTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsNumericTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsObjectTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsResourceTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsScalarTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsStringTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/UtilTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/Hamcrest/Xml/HasXPathTest.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/bootstrap.php
create mode 100644 vendor/hamcrest/hamcrest-php/tests/phpunit.xml.dist
create mode 100644 vendor/jakub-onderka/php-console-color/.gitignore
create mode 100644 vendor/jakub-onderka/php-console-color/.travis.yml
create mode 100644 vendor/jakub-onderka/php-console-color/LICENSE
create mode 100644 vendor/jakub-onderka/php-console-color/README.md
create mode 100644 vendor/jakub-onderka/php-console-color/build.xml
create mode 100644 vendor/jakub-onderka/php-console-color/composer.json
create mode 100644 vendor/jakub-onderka/php-console-color/example.php
create mode 100644 vendor/jakub-onderka/php-console-color/phpunit.xml
create mode 100644 vendor/jakub-onderka/php-console-color/src/ConsoleColor.php
create mode 100644 vendor/jakub-onderka/php-console-color/src/InvalidStyleException.php
create mode 100644 vendor/jakub-onderka/php-console-color/tests/ConsoleColorTest.php
create mode 100644 vendor/jakub-onderka/php-console-highlighter/.gitignore
create mode 100644 vendor/jakub-onderka/php-console-highlighter/.travis.yml
create mode 100644 vendor/jakub-onderka/php-console-highlighter/LICENSE
create mode 100644 vendor/jakub-onderka/php-console-highlighter/README.md
create mode 100644 vendor/jakub-onderka/php-console-highlighter/build.xml
create mode 100644 vendor/jakub-onderka/php-console-highlighter/composer.json
create mode 100644 vendor/jakub-onderka/php-console-highlighter/examples/snippet.php
create mode 100644 vendor/jakub-onderka/php-console-highlighter/examples/whole_file.php
create mode 100644 vendor/jakub-onderka/php-console-highlighter/examples/whole_file_line_numbers.php
create mode 100644 vendor/jakub-onderka/php-console-highlighter/phpunit.xml
create mode 100644 vendor/jakub-onderka/php-console-highlighter/src/Highlighter.php
create mode 100644 vendor/jakub-onderka/php-console-highlighter/tests/HigligterTest.php
create mode 100644 vendor/kylekatarnls/update-helper/LICENSE
create mode 100644 vendor/kylekatarnls/update-helper/composer.json
create mode 100644 vendor/kylekatarnls/update-helper/src/UpdateHelper/ComposerPlugin.php
create mode 100644 vendor/kylekatarnls/update-helper/src/UpdateHelper/NotUpdateInterfaceInstanceException.php
create mode 100644 vendor/kylekatarnls/update-helper/src/UpdateHelper/UpdateHelper.php
create mode 100644 vendor/kylekatarnls/update-helper/src/UpdateHelper/UpdateHelperInterface.php
create mode 100644 vendor/laravel/framework/LICENSE.md
create mode 100644 vendor/laravel/framework/README.md
create mode 100644 vendor/laravel/framework/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Access/AuthorizationException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Access/Gate.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Access/HandlesAuthorization.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Access/Response.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/AuthManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/AuthServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Authenticatable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/AuthenticationException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Console/AuthMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Console/ClearResetsCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/controllers/HomeController.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/routes.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/login.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/passwords/email.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/passwords/reset.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/register.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/home.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/layouts/app.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/CreatesUserProviders.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/DatabaseUserProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/EloquentUserProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Events/Attempting.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Events/Authenticated.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Events/Failed.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Events/Lockout.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Events/Login.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Events/Logout.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Events/Registered.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/GenericUser.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/GuardHelpers.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Middleware/Authenticate.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Middleware/AuthenticateWithBasicAuth.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Middleware/Authorize.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Notifications/ResetPassword.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Passwords/CanResetPassword.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Passwords/DatabaseTokenRepository.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBroker.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBrokerManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordResetServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Passwords/TokenRepositoryInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/Recaller.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/RequestGuard.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/SessionGuard.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/TokenGuard.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Auth/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastController.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastEvent.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/Broadcaster.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/LogBroadcaster.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/NullBroadcaster.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/PusherBroadcaster.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/RedisBroadcaster.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/Channel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/InteractsWithSockets.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/PendingBroadcast.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/PresenceChannel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/PrivateChannel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Broadcasting/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Bus/BusServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Bus/Dispatcher.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Bus/Queueable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Bus/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/ApcStore.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/ApcWrapper.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/ArrayStore.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/CacheManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/CacheServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/Console/CacheTableCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/Console/ClearCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/Console/ForgetCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/Console/stubs/cache.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/DatabaseStore.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/Events/CacheEvent.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/Events/CacheHit.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/Events/CacheMissed.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/Events/KeyForgotten.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/Events/KeyWritten.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/FileStore.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/MemcachedConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/MemcachedStore.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/NullStore.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/RateLimiter.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/RedisStore.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/RedisTaggedCache.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/Repository.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/RetrievesMultipleKeys.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/TagSet.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/TaggableStore.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/TaggedCache.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cache/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Config/Repository.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Config/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Application.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Command.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/ConfirmableTrait.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/DetectsApplicationNamespace.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Events/ArtisanStarting.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/GeneratorCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/OutputStyle.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Parser.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Scheduling/CacheMutex.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Scheduling/CallbackEvent.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Scheduling/CommandBuilder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Scheduling/Event.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Scheduling/ManagesFrequencies.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Scheduling/Mutex.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Scheduling/Schedule.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleFinishCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleRunCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Console/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Container/Container.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Container/ContextualBindingBuilder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Container/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/Access/Authorizable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/Access/Gate.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/Authenticatable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/CanResetPassword.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/Guard.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/PasswordBroker.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/PasswordBrokerFactory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/StatefulGuard.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/SupportsBasicAuth.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Auth/UserProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Broadcasting/Broadcaster.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Broadcasting/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Broadcasting/ShouldBroadcast.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Broadcasting/ShouldBroadcastNow.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Bus/Dispatcher.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Bus/QueueingDispatcher.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Cache/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Cache/Repository.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Cache/Store.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Config/Repository.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Console/Application.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Console/Kernel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Container/BindingResolutionException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Container/Container.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Container/ContextualBindingBuilder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Cookie/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Cookie/QueueingFactory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Database/ModelIdentifier.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Debug/ExceptionHandler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Encryption/DecryptException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Encryption/EncryptException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Encryption/Encrypter.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Events/Dispatcher.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Filesystem/Cloud.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Filesystem/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Filesystem/FileNotFoundException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Filesystem/Filesystem.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Foundation/Application.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Hashing/Hasher.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Http/Kernel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Logging/Log.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Mail/MailQueue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Mail/Mailable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Mail/Mailer.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Notifications/Dispatcher.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Notifications/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Pagination/LengthAwarePaginator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Pagination/Paginator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Pipeline/Hub.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Pipeline/Pipeline.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Queue/EntityNotFoundException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Queue/EntityResolver.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Queue/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Queue/Job.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Queue/Monitor.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Queue/Queue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Queue/QueueableCollection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Queue/QueueableEntity.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Queue/ShouldQueue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Redis/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Routing/BindingRegistrar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Routing/Registrar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Routing/ResponseFactory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Routing/UrlGenerator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Routing/UrlRoutable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Session/Session.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Support/Arrayable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Support/Htmlable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Support/Jsonable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Support/MessageBag.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Support/MessageProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Support/Renderable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Translation/Translator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Validation/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Validation/ValidatesWhenResolved.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/Validation/Validator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/View/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/View/View.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Contracts/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Cookie/CookieJar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cookie/CookieServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cookie/Middleware/AddQueuedCookiesToResponse.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cookie/Middleware/EncryptCookies.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Cookie/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Capsule/Manager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Concerns/BuildsQueries.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Concerns/ManagesTransactions.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Connection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/ConnectionInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/ConnectionResolver.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/ConnectionResolverInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Connectors/ConnectionFactory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Connectors/ConnectorInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Connectors/MySqlConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Connectors/PostgresConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Connectors/SQLiteConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Connectors/SqlServerConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/BaseCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/InstallCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/RefreshCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/ResetCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/RollbackCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/StatusCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/SeedCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/SeederMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/stubs/seeder.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/DatabaseManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/DatabaseServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/DetectsDeadlocks.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/DetectsLostConnections.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Builder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Collection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/GuardsAttributes.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasAttributes.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasEvents.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasGlobalScopes.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasRelationships.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasTimestamps.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HidesAttributes.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/QueriesRelationships.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/JsonEncodingException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/MassAssignmentException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Model.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/ModelNotFoundException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/QueueEntityResolver.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/RelationNotFoundException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsTo.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsToMany.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/InteractsWithPivotTable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/SupportsDefaultModels.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasMany.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasManyThrough.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOne.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOneOrMany.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphMany.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOne.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOneOrMany.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphPivot.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphTo.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphToMany.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Pivot.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Relation.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/Scope.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/SoftDeletes.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Eloquent/SoftDeletingScope.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Events/ConnectionEvent.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Events/QueryExecuted.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Events/StatementPrepared.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Events/TransactionBeginning.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Events/TransactionCommitted.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Events/TransactionRolledBack.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Grammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/MigrationServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Migrations/DatabaseMigrationRepository.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Migrations/Migration.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Migrations/MigrationCreator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Migrations/MigrationRepositoryInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Migrations/Migrator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Migrations/stubs/blank.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Migrations/stubs/create.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Migrations/stubs/update.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/MySqlConnection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/PostgresConnection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Builder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Expression.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/Grammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/MySqlGrammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/PostgresGrammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/SQLiteGrammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/SqlServerGrammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/JoinClause.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/JsonExpression.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Processors/MySqlProcessor.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Processors/PostgresProcessor.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Processors/Processor.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Processors/SQLiteProcessor.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Query/Processors/SqlServerProcessor.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/QueryException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/README.md
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/SQLiteConnection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/Blueprint.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/Builder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/ChangeColumn.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/Grammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/MySqlGrammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/PostgresGrammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/RenameColumn.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/SQLiteGrammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/SqlServerGrammar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/MySqlBuilder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Schema/PostgresBuilder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/Seeder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/SqlServerConnection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Database/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Encryption/Encrypter.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Encryption/EncryptionServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Encryption/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Events/CallQueuedHandler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Events/CallQueuedListener.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Events/Dispatcher.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Events/EventServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Events/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Filesystem/Filesystem.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Filesystem/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/AliasLoader.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Application.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Auth/Access/Authorizable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Auth/Access/AuthorizesRequests.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Auth/RedirectsUsers.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Auth/RegistersUsers.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Auth/ResetsPasswords.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Auth/SendsPasswordResetEmails.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Auth/ThrottlesLogins.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Auth/User.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/BootProviders.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/HandleExceptions.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadConfiguration.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadEnvironmentVariables.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterFacades.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterProviders.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/SetRequestForConsole.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Bus/Dispatchable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Bus/DispatchesJobs.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Bus/PendingDispatch.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/ComposerScripts.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/AppNameCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/ClearCompiledCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/ClosureCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/ConfigCacheCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/ConfigClearCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/ConsoleMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/DownCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/EnvironmentCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/EventGenerateCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/EventMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/JobMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/Kernel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/KeyGenerateCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/ListenerMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/MailMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/ModelMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/NotificationMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/OptimizeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/PolicyMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/ProviderMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/QueuedCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/RequestMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/RouteCacheCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/RouteClearCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/RouteListCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/ServeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/StorageLinkCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/TestMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/UpCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/VendorPublishCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/ViewClearCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/console.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/event-handler-queued.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/event-handler.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/event.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/job-queued.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/job.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/listener-queued.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/listener.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/mail.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown-mail.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown-notification.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/model.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/notification.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/policy.plain.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/policy.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/provider.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/request.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/routes.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/test.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/unit-test.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/EnvironmentDetector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Events/Dispatchable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Events/LocaleUpdated.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Exceptions/Handler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Exceptions/views/503.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Http/Events/RequestHandled.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Http/Exceptions/MaintenanceModeException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Http/FormRequest.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Http/Kernel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/CheckForMaintenanceMode.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ConvertEmptyStringsToNull.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/TransformsRequest.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/TrimStrings.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ValidatePostSize.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/VerifyCsrfToken.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Inspiring.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/ProviderRepository.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Providers/ArtisanServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Providers/ComposerServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Providers/ConsoleSupportServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Providers/FormRequestServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Providers/FoundationServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Support/Providers/AuthServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Support/Providers/EventServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Support/Providers/RouteServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithAuthentication.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithConsole.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithContainer.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithDatabase.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithSession.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MakesHttpRequests.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MocksApplicationServices.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/HasInDatabase.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/SoftDeletedInDatabase.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseMigrations.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseTransactions.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/HttpException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/TestCase.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/TestResponse.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/WithoutEvents.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Testing/WithoutMiddleware.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/Validation/ValidatesRequests.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/helpers.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Foundation/stubs/facade.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Hashing/BcryptHasher.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Hashing/HashServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Hashing/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithContentTypes.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithFlashData.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithInput.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Exceptions/HttpResponseException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Exceptions/PostTooLargeException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/File.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/FileHelpers.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/JsonResponse.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Middleware/CheckResponseForModifications.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Middleware/FrameGuard.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/RedirectResponse.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Request.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Response.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/ResponseTrait.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Testing/File.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Testing/FileFactory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/Testing/MimeType.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/UploadedFile.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Http/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Log/Events/MessageLogged.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Log/LogServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Log/Writer.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Log/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Events/MessageSending.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Events/MessageSent.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/MailServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Mailable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Mailer.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Markdown.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Message.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/PendingMail.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/SendQueuedMailable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Transport/ArrayTransport.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Transport/LogTransport.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Transport/MailgunTransport.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Transport/MandrillTransport.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Transport/SesTransport.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Transport/SparkPostTransport.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/Transport/Transport.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/TransportManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/button.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/footer.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/header.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/layout.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/message.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/panel.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/promotion.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/promotion/button.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/subcopy.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/table.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/themes/default.css
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/button.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/footer.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/header.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/layout.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/message.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/panel.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/promotion.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/promotion/button.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/subcopy.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/table.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Action.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/ChannelManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Channels/BroadcastChannel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Channels/DatabaseChannel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Channels/MailChannel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Channels/NexmoSmsChannel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Channels/SlackWebhookChannel.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Console/NotificationTableCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Console/stubs/notifications.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/DatabaseNotification.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/DatabaseNotificationCollection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Events/BroadcastNotificationCreated.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationFailed.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationSending.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationSent.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/HasDatabaseNotifications.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Messages/BroadcastMessage.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Messages/DatabaseMessage.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Messages/MailMessage.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Messages/NexmoMessage.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Messages/SimpleMessage.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachment.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachmentField.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackMessage.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Notifiable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/Notification.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/NotificationSender.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/NotificationServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/RoutesNotifications.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/SendQueuedNotifications.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Notifications/resources/views/email.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pagination/AbstractPaginator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pagination/LengthAwarePaginator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pagination/PaginationServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pagination/Paginator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pagination/UrlWindow.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pagination/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Pagination/resources/views/bootstrap-4.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pagination/resources/views/default.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pagination/resources/views/simple-bootstrap-4.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pagination/resources/views/simple-default.blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pipeline/Hub.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pipeline/Pipeline.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pipeline/PipelineServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Pipeline/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/BeanstalkdQueue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/CallQueuedHandler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Capsule/Manager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Connectors/BeanstalkdConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Connectors/ConnectorInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Connectors/DatabaseConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Connectors/NullConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Connectors/RedisConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Connectors/SqsConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Connectors/SyncConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/FailedTableCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/FlushFailedCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/ForgetFailedCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/ListFailedCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/ListenCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/RestartCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/RetryCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/TableCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/WorkCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/stubs/failed_jobs.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Console/stubs/jobs.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/DatabaseQueue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Events/JobExceptionOccurred.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Events/JobFailed.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Events/JobProcessed.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Events/JobProcessing.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Events/Looping.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Events/WorkerStopping.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Failed/DatabaseFailedJobProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Failed/FailedJobProviderInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Failed/NullFailedJobProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/FailingJob.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/InteractsWithQueue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/InteractsWithTime.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/InvalidPayloadException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Jobs/BeanstalkdJob.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJob.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJobRecord.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Jobs/Job.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Jobs/JobName.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Jobs/RedisJob.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Jobs/SqsJob.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Jobs/SyncJob.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Listener.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/ListenerOptions.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/LuaScripts.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/ManuallyFailedException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/MaxAttemptsExceededException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/NullQueue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Queue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/QueueManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/QueueServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/README.md
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/RedisQueue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/SerializesAndRestoresModelIdentifiers.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/SerializesModels.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/SqsQueue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/SyncQueue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/Worker.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/WorkerOptions.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Queue/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Redis/Connections/Connection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Redis/Connections/PhpRedisClusterConnection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Redis/Connections/PhpRedisConnection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Redis/Connections/PredisClusterConnection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Redis/Connections/PredisConnection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Redis/Connectors/PhpRedisConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Redis/Connectors/PredisConnector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Redis/RedisManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Redis/RedisServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Redis/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Console/ControllerMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Console/MiddlewareMakeCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Console/stubs/controller.model.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Console/stubs/controller.nested.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Console/stubs/controller.plain.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Console/stubs/controller.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Console/stubs/middleware.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Controller.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/ControllerMiddlewareOptions.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Events/RouteMatched.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Exceptions/UrlGenerationException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/ImplicitRouteBinding.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Matching/HostValidator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Matching/MethodValidator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Matching/SchemeValidator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Matching/UriValidator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Matching/ValidatorInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Middleware/SubstituteBindings.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Middleware/ThrottleRequests.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/MiddlewareNameResolver.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Pipeline.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Redirector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/ResourceRegistrar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/ResponseFactory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Route.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RouteAction.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RouteBinding.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RouteCollection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RouteCompiler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RouteDependencyResolverTrait.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RouteGroup.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RouteParameterBinder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RouteRegistrar.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RouteSignatureParameters.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RouteUrlGenerator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/Router.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/RoutingServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/SortedMiddleware.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/UrlGenerator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Routing/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/CacheBasedSessionHandler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/Console/SessionTableCommand.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/Console/stubs/database.stub
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/CookieSessionHandler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/DatabaseSessionHandler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/EncryptedStore.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/ExistenceAwareInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/FileSessionHandler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/Middleware/AuthenticateSession.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/Middleware/StartSession.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/SessionManager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/SessionServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/Store.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/TokenMismatchException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Session/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/AggregateServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Arr.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Collection.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Composer.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Debug/Dumper.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Debug/HtmlDumper.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/App.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Artisan.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Auth.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Blade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Broadcast.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Bus.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Cache.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Config.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Cookie.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Crypt.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/DB.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Event.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Facade.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/File.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Gate.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Hash.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Input.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Lang.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Log.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Mail.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Notification.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Password.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Queue.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Redirect.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Redis.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Request.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Response.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Route.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Schema.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Session.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Storage.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/URL.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/Validator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Facades/View.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Fluent.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/HigherOrderCollectionProxy.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/HigherOrderTapProxy.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/HtmlString.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Manager.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/MessageBag.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/NamespacedItemResolver.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Pluralizer.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/ServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Str.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/BusFake.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/EventFake.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/MailFake.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/NotificationFake.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/PendingMailFake.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/QueueFake.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Traits/CapsuleManagerTrait.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/Traits/Macroable.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/ViewErrorBag.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Support/helpers.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Translation/ArrayLoader.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Translation/FileLoader.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Translation/LoaderInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Translation/MessageSelector.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Translation/TranslationServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Translation/Translator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Translation/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Concerns/FormatsMessages.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Concerns/ReplacesAttributes.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Concerns/ValidatesAttributes.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/DatabasePresenceVerifier.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/PresenceVerifierInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Rule.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Rules/Dimensions.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Rules/Exists.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Rules/In.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Rules/NotIn.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Rules/Unique.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/UnauthorizedException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/ValidatesWhenResolvedTrait.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/ValidationData.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/ValidationException.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/ValidationRuleParser.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/ValidationServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/Validator.php
create mode 100644 vendor/laravel/framework/src/Illuminate/Validation/composer.json
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/BladeCompiler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Compiler.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/CompilerInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesAuthorizations.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComments.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComponents.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesConditionals.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesEchos.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesIncludes.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesInjections.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLayouts.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLoops.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesRawPhp.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesStacks.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesTranslations.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesComponents.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesEvents.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesLayouts.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesLoops.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesStacks.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesTranslations.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Engines/CompilerEngine.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Engines/Engine.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Engines/EngineInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Engines/EngineResolver.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Engines/FileEngine.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Engines/PhpEngine.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Factory.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/FileViewFinder.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/Middleware/ShareErrorsFromSession.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/View.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/ViewFinderInterface.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/ViewName.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/ViewServiceProvider.php
create mode 100644 vendor/laravel/framework/src/Illuminate/View/composer.json
create mode 100644 vendor/laravel/tinker/.styleci.yml
create mode 100644 vendor/laravel/tinker/LICENSE.md
create mode 100644 vendor/laravel/tinker/README.md
create mode 100644 vendor/laravel/tinker/composer.json
create mode 100644 vendor/laravel/tinker/config/tinker.php
create mode 100644 vendor/laravel/tinker/src/ClassAliasAutoloader.php
create mode 100644 vendor/laravel/tinker/src/Console/TinkerCommand.php
create mode 100644 vendor/laravel/tinker/src/TinkerCaster.php
create mode 100644 vendor/laravel/tinker/src/TinkerServiceProvider.php
create mode 100644 vendor/league/flysystem/LICENSE
create mode 100644 vendor/league/flysystem/SECURITY.md
create mode 100644 vendor/league/flysystem/composer.json
create mode 100644 vendor/league/flysystem/deprecations.md
create mode 100644 vendor/league/flysystem/src/Adapter/AbstractAdapter.php
create mode 100644 vendor/league/flysystem/src/Adapter/AbstractFtpAdapter.php
create mode 100644 vendor/league/flysystem/src/Adapter/CanOverwriteFiles.php
create mode 100644 vendor/league/flysystem/src/Adapter/Ftp.php
create mode 100644 vendor/league/flysystem/src/Adapter/Ftpd.php
create mode 100644 vendor/league/flysystem/src/Adapter/Local.php
create mode 100644 vendor/league/flysystem/src/Adapter/NullAdapter.php
create mode 100644 vendor/league/flysystem/src/Adapter/Polyfill/NotSupportingVisibilityTrait.php
create mode 100644 vendor/league/flysystem/src/Adapter/Polyfill/StreamedCopyTrait.php
create mode 100644 vendor/league/flysystem/src/Adapter/Polyfill/StreamedReadingTrait.php
create mode 100644 vendor/league/flysystem/src/Adapter/Polyfill/StreamedTrait.php
create mode 100644 vendor/league/flysystem/src/Adapter/Polyfill/StreamedWritingTrait.php
create mode 100644 vendor/league/flysystem/src/Adapter/SynologyFtp.php
create mode 100644 vendor/league/flysystem/src/AdapterInterface.php
create mode 100644 vendor/league/flysystem/src/Config.php
create mode 100644 vendor/league/flysystem/src/ConfigAwareTrait.php
create mode 100644 vendor/league/flysystem/src/ConnectionErrorException.php
create mode 100644 vendor/league/flysystem/src/ConnectionRuntimeException.php
create mode 100644 vendor/league/flysystem/src/Directory.php
create mode 100644 vendor/league/flysystem/src/Exception.php
create mode 100644 vendor/league/flysystem/src/File.php
create mode 100644 vendor/league/flysystem/src/FileExistsException.php
create mode 100644 vendor/league/flysystem/src/FileNotFoundException.php
create mode 100644 vendor/league/flysystem/src/Filesystem.php
create mode 100644 vendor/league/flysystem/src/FilesystemException.php
create mode 100644 vendor/league/flysystem/src/FilesystemInterface.php
create mode 100644 vendor/league/flysystem/src/FilesystemNotFoundException.php
create mode 100644 vendor/league/flysystem/src/Handler.php
create mode 100644 vendor/league/flysystem/src/InvalidRootException.php
create mode 100644 vendor/league/flysystem/src/MountManager.php
create mode 100644 vendor/league/flysystem/src/NotSupportedException.php
create mode 100644 vendor/league/flysystem/src/Plugin/AbstractPlugin.php
create mode 100644 vendor/league/flysystem/src/Plugin/EmptyDir.php
create mode 100644 vendor/league/flysystem/src/Plugin/ForcedCopy.php
create mode 100644 vendor/league/flysystem/src/Plugin/ForcedRename.php
create mode 100644 vendor/league/flysystem/src/Plugin/GetWithMetadata.php
create mode 100644 vendor/league/flysystem/src/Plugin/ListFiles.php
create mode 100644 vendor/league/flysystem/src/Plugin/ListPaths.php
create mode 100644 vendor/league/flysystem/src/Plugin/ListWith.php
create mode 100644 vendor/league/flysystem/src/Plugin/PluggableTrait.php
create mode 100644 vendor/league/flysystem/src/Plugin/PluginNotFoundException.php
create mode 100644 vendor/league/flysystem/src/PluginInterface.php
create mode 100644 vendor/league/flysystem/src/ReadInterface.php
create mode 100644 vendor/league/flysystem/src/RootViolationException.php
create mode 100644 vendor/league/flysystem/src/SafeStorage.php
create mode 100644 vendor/league/flysystem/src/UnreadableFileException.php
create mode 100644 vendor/league/flysystem/src/Util.php
create mode 100644 vendor/league/flysystem/src/Util/ContentListingFormatter.php
create mode 100644 vendor/league/flysystem/src/Util/MimeType.php
create mode 100644 vendor/league/flysystem/src/Util/StreamHasher.php
create mode 100644 vendor/mockery/mockery/.gitignore
create mode 100644 vendor/mockery/mockery/.php_cs
create mode 100644 vendor/mockery/mockery/.scrutinizer.yml
create mode 100644 vendor/mockery/mockery/.styleci.yml
create mode 100644 vendor/mockery/mockery/.travis.yml
create mode 100644 vendor/mockery/mockery/CHANGELOG.md
create mode 100644 vendor/mockery/mockery/CONTRIBUTING.md
create mode 100644 vendor/mockery/mockery/LICENSE
create mode 100644 vendor/mockery/mockery/README.md
create mode 100644 vendor/mockery/mockery/composer.json
create mode 100644 vendor/mockery/mockery/docs/.gitignore
create mode 100644 vendor/mockery/mockery/docs/Makefile
create mode 100644 vendor/mockery/mockery/docs/README.md
create mode 100644 vendor/mockery/mockery/docs/conf.py
create mode 100644 vendor/mockery/mockery/docs/cookbook/default_expectations.rst
create mode 100644 vendor/mockery/mockery/docs/cookbook/detecting_mock_objects.rst
create mode 100644 vendor/mockery/mockery/docs/cookbook/index.rst
create mode 100644 vendor/mockery/mockery/docs/cookbook/map.rst.inc
create mode 100644 vendor/mockery/mockery/docs/cookbook/mocking_hard_dependencies.rst
create mode 100644 vendor/mockery/mockery/docs/getting_started/index.rst
create mode 100644 vendor/mockery/mockery/docs/getting_started/installation.rst
create mode 100644 vendor/mockery/mockery/docs/getting_started/map.rst.inc
create mode 100644 vendor/mockery/mockery/docs/getting_started/simple_example.rst
create mode 100644 vendor/mockery/mockery/docs/getting_started/upgrading.rst
create mode 100644 vendor/mockery/mockery/docs/index.rst
create mode 100644 vendor/mockery/mockery/docs/reference/argument_validation.rst
create mode 100644 vendor/mockery/mockery/docs/reference/demeter_chains.rst
create mode 100644 vendor/mockery/mockery/docs/reference/expectations.rst
create mode 100644 vendor/mockery/mockery/docs/reference/final_methods_classes.rst
create mode 100644 vendor/mockery/mockery/docs/reference/index.rst
create mode 100644 vendor/mockery/mockery/docs/reference/instance_mocking.rst
create mode 100644 vendor/mockery/mockery/docs/reference/magic_methods.rst
create mode 100644 vendor/mockery/mockery/docs/reference/map.rst.inc
create mode 100644 vendor/mockery/mockery/docs/reference/mockery/configuration.rst
create mode 100644 vendor/mockery/mockery/docs/reference/mockery/exceptions.rst
create mode 100644 vendor/mockery/mockery/docs/reference/mockery/gotchas.rst
create mode 100644 vendor/mockery/mockery/docs/reference/mockery/index.rst
create mode 100644 vendor/mockery/mockery/docs/reference/mockery/reserved_method_names.rst
create mode 100644 vendor/mockery/mockery/docs/reference/object_recording.rst
create mode 100644 vendor/mockery/mockery/docs/reference/partial_mocks.rst
create mode 100644 vendor/mockery/mockery/docs/reference/pass_by_reference_behaviours.rst
create mode 100644 vendor/mockery/mockery/docs/reference/phpunit_integration.rst
create mode 100644 vendor/mockery/mockery/docs/reference/public_properties.rst
create mode 100644 vendor/mockery/mockery/docs/reference/public_static_properties.rst
create mode 100644 vendor/mockery/mockery/docs/reference/quick_examples.rst
create mode 100644 vendor/mockery/mockery/docs/reference/startup_methods.rst
create mode 100644 vendor/mockery/mockery/examples/starship/Bootstrap.php
create mode 100644 vendor/mockery/mockery/examples/starship/Starship.php
create mode 100644 vendor/mockery/mockery/examples/starship/StarshipTest.php
create mode 100644 vendor/mockery/mockery/library/Mockery.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryPHPUnitIntegration.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryTestCase.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/TestListener.php
create mode 100644 vendor/mockery/mockery/library/Mockery/CompositeExpectation.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Configuration.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Container.php
create mode 100644 vendor/mockery/mockery/library/Mockery/CountValidator/AtLeast.php
create mode 100644 vendor/mockery/mockery/library/Mockery/CountValidator/AtMost.php
create mode 100644 vendor/mockery/mockery/library/Mockery/CountValidator/CountValidatorAbstract.php
create mode 100644 vendor/mockery/mockery/library/Mockery/CountValidator/Exact.php
create mode 100644 vendor/mockery/mockery/library/Mockery/CountValidator/Exception.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Exception.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Exception/InvalidCountException.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Exception/InvalidOrderException.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Exception/NoMatchingExpectationException.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Exception/RuntimeException.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Expectation.php
create mode 100644 vendor/mockery/mockery/library/Mockery/ExpectationDirector.php
create mode 100644 vendor/mockery/mockery/library/Mockery/ExpectationInterface.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/CachingGenerator.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/DefinedTargetClass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/Generator.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/Method.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/MockConfiguration.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/MockConfigurationBuilder.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/MockDefinition.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/Parameter.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/CallTypeHintPass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassNamePass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassPass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InstanceMockPass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InterfacePass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/MethodDefinitionPass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/Pass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/RemoveBuiltinMethodsThatAreFinalPass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/RemoveUnserializeForInternalSerializableClassesPass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/StringManipulationGenerator.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/TargetClass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Generator/UndefinedTargetClass.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Instantiator.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Loader.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Loader/EvalLoader.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Loader/Loader.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Loader/RequireLoader.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/Any.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/AnyOf.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/Closure.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/Contains.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/Ducktype.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/HasKey.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/HasValue.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/MatcherAbstract.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/MustBe.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/Not.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/NotAnyOf.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/Subset.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Matcher/Type.php
create mode 100644 vendor/mockery/mockery/library/Mockery/MethodCall.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Mock.php
create mode 100644 vendor/mockery/mockery/library/Mockery/MockInterface.php
create mode 100644 vendor/mockery/mockery/library/Mockery/ReceivedMethodCalls.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Recorder.php
create mode 100644 vendor/mockery/mockery/library/Mockery/Undefined.php
create mode 100644 vendor/mockery/mockery/library/Mockery/VerificationDirector.php
create mode 100644 vendor/mockery/mockery/library/Mockery/VerificationExpectation.php
create mode 100644 vendor/mockery/mockery/library/helpers.php
create mode 100644 vendor/mockery/mockery/package.xml
create mode 100644 vendor/mockery/mockery/phpunit.xml.dist
create mode 100644 vendor/mockery/mockery/tests/Bootstrap.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/AdhocTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/ContainerTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/DemeterChainTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/ExpectationTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Fixtures/MethodWithNullableParameters.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Fixtures/MethodWithNullableReturnType.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Fixtures/VoidMethod.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Generator/DefinedTargetClassTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Generator/MockConfigurationTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/CallTypeHintPassTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/ClassNamePassTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/InstanceMockPassTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/InterfacePassTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/GlobalHelpersTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/HamcrestExpectationTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Loader/EvalLoaderTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Loader/LoaderTestCase.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Loader/RequireLoaderTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/LoaderTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockClassWithFinalWakeupTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockClassWithUnknownTypeHintTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockeryCanMockMultipleInterfacesWhichOverlapTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockingInternalModuleClassWithOptionalParameterByReferenceTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockingMethodsWithNullableParametersTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockingNullableMethodsTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockingParameterAndReturnTypesTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockingProtectedMethodsTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockingVariadicArgumentsTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/MockingVoidMethodsTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/NamedMockTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/RecorderTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/SpyTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/Test/Generator/MockConfigurationBuilderTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/WithFormatterExpectationTest.php
create mode 100644 vendor/mockery/mockery/tests/Mockery/_files/file.txt
create mode 100644 vendor/mockery/mockery/travis/after_success.sh
create mode 100644 vendor/mockery/mockery/travis/before_script.sh
create mode 100644 vendor/mockery/mockery/travis/extra.ini
create mode 100644 vendor/mockery/mockery/travis/install.sh
create mode 100644 vendor/mockery/mockery/travis/script.sh
create mode 100644 vendor/monolog/monolog/CHANGELOG.md
create mode 100644 vendor/monolog/monolog/LICENSE
create mode 100644 vendor/monolog/monolog/README.md
create mode 100644 vendor/monolog/monolog/composer.json
create mode 100644 vendor/monolog/monolog/phpstan.neon.dist
create mode 100644 vendor/monolog/monolog/src/Monolog/ErrorHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/ChromePHPFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/ElasticaFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/FlowdockFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/FluentdFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/FormatterInterface.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/GelfMessageFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/HtmlFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/JsonFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/LineFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/LogglyFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/LogstashFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/MongoDBFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/NormalizerFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/ScalarFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Formatter/WildfireFormatter.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/AbstractHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/AbstractProcessingHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/AbstractSyslogHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/AmqpHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/BrowserConsoleHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/BufferHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/ChromePHPHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/CouchDBHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/CubeHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/Curl/Util.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/DeduplicationHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/DoctrineCouchDBHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/DynamoDbHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/ElasticSearchHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/ErrorLogHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/FilterHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/FingersCrossedHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/FirePHPHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/FleepHookHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/FlowdockHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/FormattableHandlerInterface.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/FormattableHandlerTrait.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/GelfHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/GroupHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/HandlerInterface.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/HandlerWrapper.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/HipChatHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/IFTTTHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/InsightOpsHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/LogEntriesHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/LogglyHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/MailHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/MandrillHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/MissingExtensionException.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/MongoDBHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/NativeMailerHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/NewRelicHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/NullHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/PHPConsoleHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/ProcessableHandlerInterface.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/ProcessableHandlerTrait.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/PsrHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/PushoverHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/RavenHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/RedisHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/RollbarHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/RotatingFileHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/SamplingHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/Slack/SlackRecord.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/SlackHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/SlackWebhookHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/SlackbotHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/SocketHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/StreamHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/SwiftMailerHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/SyslogHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/SyslogUdp/UdpSocket.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/SyslogUdpHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/TestHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/WhatFailureGroupHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Handler/ZendMonitorHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Logger.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/GitProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/IntrospectionProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/MemoryPeakUsageProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/MemoryProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/MemoryUsageProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/MercurialProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/ProcessIdProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/ProcessorInterface.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/PsrLogMessageProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/TagProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/UidProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Processor/WebProcessor.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Registry.php
create mode 100644 vendor/monolog/monolog/src/Monolog/ResettableInterface.php
create mode 100644 vendor/monolog/monolog/src/Monolog/SignalHandler.php
create mode 100644 vendor/monolog/monolog/src/Monolog/Utils.php
create mode 100644 vendor/mtdowling/cron-expression/.editorconfig
create mode 100644 vendor/mtdowling/cron-expression/CHANGELOG.md
create mode 100644 vendor/mtdowling/cron-expression/LICENSE
create mode 100644 vendor/mtdowling/cron-expression/README.md
create mode 100644 vendor/mtdowling/cron-expression/composer.json
create mode 100644 vendor/mtdowling/cron-expression/src/Cron/AbstractField.php
create mode 100644 vendor/mtdowling/cron-expression/src/Cron/CronExpression.php
create mode 100644 vendor/mtdowling/cron-expression/src/Cron/DayOfMonthField.php
create mode 100644 vendor/mtdowling/cron-expression/src/Cron/DayOfWeekField.php
create mode 100644 vendor/mtdowling/cron-expression/src/Cron/FieldFactory.php
create mode 100644 vendor/mtdowling/cron-expression/src/Cron/FieldInterface.php
create mode 100644 vendor/mtdowling/cron-expression/src/Cron/HoursField.php
create mode 100644 vendor/mtdowling/cron-expression/src/Cron/MinutesField.php
create mode 100644 vendor/mtdowling/cron-expression/src/Cron/MonthField.php
create mode 100644 vendor/mtdowling/cron-expression/src/Cron/YearField.php
create mode 100644 vendor/mtdowling/cron-expression/tests/Cron/AbstractFieldTest.php
create mode 100644 vendor/mtdowling/cron-expression/tests/Cron/CronExpressionTest.php
create mode 100644 vendor/mtdowling/cron-expression/tests/Cron/DayOfMonthFieldTest.php
create mode 100644 vendor/mtdowling/cron-expression/tests/Cron/DayOfWeekFieldTest.php
create mode 100644 vendor/mtdowling/cron-expression/tests/Cron/FieldFactoryTest.php
create mode 100644 vendor/mtdowling/cron-expression/tests/Cron/HoursFieldTest.php
create mode 100644 vendor/mtdowling/cron-expression/tests/Cron/MinutesFieldTest.php
create mode 100644 vendor/mtdowling/cron-expression/tests/Cron/MonthFieldTest.php
create mode 100644 vendor/mtdowling/cron-expression/tests/Cron/YearFieldTest.php
create mode 100644 vendor/myclabs/deep-copy/.gitattributes
create mode 100644 vendor/myclabs/deep-copy/.gitignore
create mode 100644 vendor/myclabs/deep-copy/.travis.yml
create mode 100644 vendor/myclabs/deep-copy/LICENSE
create mode 100644 vendor/myclabs/deep-copy/README.md
create mode 100644 vendor/myclabs/deep-copy/composer.json
create mode 100644 vendor/myclabs/deep-copy/doc/clone.png
create mode 100644 vendor/myclabs/deep-copy/doc/deep-clone.png
create mode 100644 vendor/myclabs/deep-copy/doc/deep-copy.png
create mode 100644 vendor/myclabs/deep-copy/doc/graph.png
create mode 100644 vendor/myclabs/deep-copy/fixtures/f001/A.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f001/B.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f002/A.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f003/Foo.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f004/UnclonableItem.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f005/Foo.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f006/A.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f006/B.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f007/FooDateInterval.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f007/FooDateTimeZone.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f008/A.php
create mode 100644 vendor/myclabs/deep-copy/fixtures/f008/B.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/DeepCopy.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Exception/CloneException.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Exception/PropertyException.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Filter/Doctrine/DoctrineCollectionFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Filter/Doctrine/DoctrineEmptyCollectionFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Filter/Doctrine/DoctrineProxyFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Filter/Filter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Filter/KeepFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Filter/ReplaceFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Filter/SetNullFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Matcher/Doctrine/DoctrineProxyMatcher.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Matcher/Matcher.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Matcher/PropertyMatcher.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Matcher/PropertyNameMatcher.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Matcher/PropertyTypeMatcher.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/Reflection/ReflectionHelper.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/TypeFilter/Date/DateIntervalFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/TypeFilter/ReplaceFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/TypeFilter/ShallowCopyFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/TypeFilter/Spl/SplDoublyLinkedList.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/TypeFilter/Spl/SplDoublyLinkedListFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/TypeFilter/TypeFilter.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/TypeMatcher/TypeMatcher.php
create mode 100644 vendor/myclabs/deep-copy/src/DeepCopy/deep_copy.php
create mode 100644 vendor/nesbot/carbon/LICENSE
create mode 100644 vendor/nesbot/carbon/bin/upgrade-carbon
create mode 100644 vendor/nesbot/carbon/bin/upgrade-carbon.bat
create mode 100644 vendor/nesbot/carbon/composer.json
create mode 100644 vendor/nesbot/carbon/readme.md
create mode 100644 vendor/nesbot/carbon/src/Carbon/Carbon.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/CarbonInterval.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/CarbonPeriod.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Exceptions/InvalidDateException.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/af.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ar.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ar_Shakl.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/az.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/bg.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/bn.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/bs_BA.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ca.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/cs.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/cy.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/da.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/de.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/dv_MV.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/el.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/en.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/eo.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/es.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/et.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/eu.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/fa.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/fi.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/fo.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/fr.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/gl.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/gu.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/he.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/hi.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/hr.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/hu.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/hy.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/id.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/is.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/it.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ja.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ka.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/kk.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/km.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ko.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/lt.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/lv.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/mk.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/mn.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ms.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/my.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ne.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/nl.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/no.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/oc.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/pl.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ps.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/pt.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/pt_BR.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ro.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ru.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sh.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sk.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sl.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sq.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sr.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sr_Cyrl.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sr_Cyrl_ME.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sr_Latn_ME.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sr_ME.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sv.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/sw.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/th.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/tr.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/uk.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/ur.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/uz.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/vi.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/zh.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Lang/zh_TW.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Laravel/ServiceProvider.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Translator.php
create mode 100644 vendor/nesbot/carbon/src/Carbon/Upgrade.php
create mode 100644 vendor/nesbot/carbon/src/JsonSerializable.php
create mode 100644 vendor/nikic/php-parser/.gitignore
create mode 100644 vendor/nikic/php-parser/.travis.yml
create mode 100644 vendor/nikic/php-parser/CHANGELOG.md
create mode 100644 vendor/nikic/php-parser/LICENSE
create mode 100644 vendor/nikic/php-parser/README.md
create mode 100644 vendor/nikic/php-parser/UPGRADE-1.0.md
create mode 100644 vendor/nikic/php-parser/UPGRADE-2.0.md
create mode 100644 vendor/nikic/php-parser/UPGRADE-3.0.md
create mode 100644 vendor/nikic/php-parser/bin/php-parse
create mode 100644 vendor/nikic/php-parser/composer.json
create mode 100644 vendor/nikic/php-parser/doc/0_Introduction.markdown
create mode 100644 vendor/nikic/php-parser/doc/2_Usage_of_basic_components.markdown
create mode 100644 vendor/nikic/php-parser/doc/3_Other_node_tree_representations.markdown
create mode 100644 vendor/nikic/php-parser/doc/4_Code_generation.markdown
create mode 100644 vendor/nikic/php-parser/doc/component/Error_handling.markdown
create mode 100644 vendor/nikic/php-parser/doc/component/Lexer.markdown
create mode 100644 vendor/nikic/php-parser/grammar/README.md
create mode 100644 vendor/nikic/php-parser/grammar/parser.template
create mode 100644 vendor/nikic/php-parser/grammar/php5.y
create mode 100644 vendor/nikic/php-parser/grammar/php7.y
create mode 100644 vendor/nikic/php-parser/grammar/rebuildParsers.php
create mode 100644 vendor/nikic/php-parser/grammar/tokens.template
create mode 100644 vendor/nikic/php-parser/grammar/tokens.y
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Autoloader.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/Class_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/Declaration.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/FunctionLike.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/Function_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/Interface_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/Method.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/Namespace_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/Param.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/Property.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/Trait_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Builder/Use_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/BuilderAbstract.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/BuilderFactory.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Comment.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Comment/Doc.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Error.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/ErrorHandler.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/ErrorHandler/Collecting.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/ErrorHandler/Throwing.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Lexer.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Lexer/Emulative.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Arg.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Const_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/ArrayDimFetch.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/ArrayItem.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Array_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Assign.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/BitwiseAnd.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/BitwiseOr.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/BitwiseXor.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Concat.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Div.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Minus.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Mod.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Mul.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Plus.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Pow.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/ShiftLeft.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/ShiftRight.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/AssignRef.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BitwiseAnd.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BitwiseOr.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BitwiseXor.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BooleanAnd.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BooleanOr.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Coalesce.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Concat.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Div.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Equal.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Greater.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/GreaterOrEqual.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Identical.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/LogicalAnd.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/LogicalOr.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/LogicalXor.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Minus.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Mod.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Mul.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/NotEqual.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/NotIdentical.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Plus.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Pow.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/ShiftLeft.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/ShiftRight.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Smaller.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/SmallerOrEqual.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Spaceship.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BitwiseNot.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/BooleanNot.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Cast.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Array_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Bool_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Double.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Int_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Object_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/String_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Unset_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/ClassConstFetch.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Clone_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Closure.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/ClosureUse.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/ConstFetch.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Empty_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Error.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/ErrorSuppress.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Eval_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Exit_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/FuncCall.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Include_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Instanceof_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Isset_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/List_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/MethodCall.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/New_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/PostDec.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/PostInc.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/PreDec.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/PreInc.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Print_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/PropertyFetch.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/ShellExec.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/StaticCall.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/StaticPropertyFetch.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Ternary.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/UnaryMinus.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/UnaryPlus.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Variable.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/YieldFrom.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Expr/Yield_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/FunctionLike.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Name.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Name/FullyQualified.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Name/Relative.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/NullableType.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Param.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/DNumber.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/Encapsed.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/EncapsedStringPart.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/LNumber.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Class_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Dir.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/File.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Function_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Line.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Method.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Namespace_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Trait_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Scalar/String_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Break_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Case_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Catch_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/ClassConst.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/ClassLike.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/ClassMethod.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Class_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Const_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Continue_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/DeclareDeclare.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Declare_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Do_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Echo_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/ElseIf_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Else_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Finally_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/For_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Foreach_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Function_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Global_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Goto_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/GroupUse.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/HaltCompiler.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/If_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/InlineHTML.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Interface_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Label.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Namespace_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Nop.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Property.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/PropertyProperty.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Return_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/StaticVar.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Static_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Switch_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Throw_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUse.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUseAdaptation.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUseAdaptation/Alias.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUseAdaptation/Precedence.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Trait_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/TryCatch.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Unset_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/UseUse.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/Use_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Node/Stmt/While_.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/NodeAbstract.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/NodeDumper.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/NodeTraverser.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/NodeTraverserInterface.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/NodeVisitor.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/NodeVisitor/NameResolver.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/NodeVisitorAbstract.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Parser.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Parser/Multiple.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Parser/Php5.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Parser/Php7.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Parser/Tokens.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/ParserAbstract.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/ParserFactory.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/PrettyPrinter/Standard.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/PrettyPrinterAbstract.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Serializer.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Serializer/XML.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Unserializer.php
create mode 100644 vendor/nikic/php-parser/lib/PhpParser/Unserializer/XML.php
create mode 100644 vendor/nikic/php-parser/lib/bootstrap.php
create mode 100644 vendor/nikic/php-parser/phpunit.xml.dist
create mode 100644 vendor/nikic/php-parser/test/PhpParser/AutoloaderTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Builder/ClassTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Builder/FunctionTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Builder/InterfaceTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Builder/MethodTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Builder/NamespaceTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Builder/ParamTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Builder/PropertyTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Builder/TraitTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Builder/UseTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/BuilderFactoryTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/CodeParsingTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/CodeTestAbstract.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/CommentTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/ErrorHandler/CollectingTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/ErrorHandler/ThrowingTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/ErrorTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Lexer/EmulativeTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/LexerTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Node/NameTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Node/Scalar/MagicConstTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Node/Scalar/StringTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Node/Stmt/ClassConstTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Node/Stmt/ClassMethodTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Node/Stmt/ClassTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Node/Stmt/InterfaceTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Node/Stmt/PropertyTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/NodeAbstractTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/NodeDumperTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/NodeTraverserTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/NodeVisitor/NameResolverTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Parser/MultipleTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Parser/Php5Test.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Parser/Php7Test.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/ParserFactoryTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/ParserTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/PrettyPrinterTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Serializer/XMLTest.php
create mode 100644 vendor/nikic/php-parser/test/PhpParser/Unserializer/XMLTest.php
create mode 100644 vendor/nikic/php-parser/test/bootstrap.php
create mode 100644 vendor/nikic/php-parser/test/code/parser/blockComments.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/comments.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/errorHandling/eofError.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/errorHandling/lexerErrors.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/errorHandling/recovery.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/arrayDef.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/arrayDestructuring.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/assign.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/assignNewByRef.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/cast.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/clone.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/closure.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/comparison.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/constant_expr.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/errorSuppress.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/exit.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/fetchAndCall/args.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/fetchAndCall/constFetch.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/fetchAndCall/constantDeref.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/fetchAndCall/funcCall.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/fetchAndCall/newDeref.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/fetchAndCall/objectAccess.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/fetchAndCall/simpleArrayAccess.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/fetchAndCall/staticCall.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/fetchAndCall/staticPropertyFetch.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/includeAndEval.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/issetAndEmpty.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/listWithKeys.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/logic.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/math.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/new.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/newWithoutClass.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/print.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/shellExec.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/ternaryAndCoalesce.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/uvs/globalNonSimpleVarError.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/uvs/indirectCall.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/uvs/isset.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/uvs/misc.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/uvs/new.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/uvs/staticProperty.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/expr/variable.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/scalar/constantString.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/scalar/docString.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/scalar/docStringNewlines.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/scalar/encapsedNegVarOffset.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/scalar/encapsedString.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/scalar/float.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/scalar/int.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/scalar/invalidOctal.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/scalar/magicConst.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/scalar/unicodeEscape.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/semiReserved.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/blocklessStatement.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/abstract.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/anonymous.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/conditional.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/constModifierErrors.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/constModifiers.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/final.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/implicitPublic.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/interface.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/modifier.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/name.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/php4Style.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/simple.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/staticMethod.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/class/trait.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/const.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/controlFlow.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/declare.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/echo.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/function/builtinTypeDeclarations.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/function/byRef.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/function/conditional.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/function/defaultValues.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/function/nullableTypes.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/function/returnTypes.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/function/specialVars.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/function/typeDeclarations.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/function/variadic.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/function/variadicDefaultValue.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/generator/basic.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/generator/yieldPrecedence.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/generator/yieldUnaryPrecedence.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/haltCompiler.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/haltCompilerInvalidSyntax.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/haltCompilerOffset.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/haltCompilerOutermostScope.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/hashbang.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/if.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/inlineHTML.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/loop/do.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/loop/for.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/loop/foreach.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/loop/while.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/multiCatch.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/alias.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/braced.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/commentAfterNamespace.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/groupUse.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/groupUseErrors.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/groupUsePositions.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/groupUseTrailingComma.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/invalidName.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/mix.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/name.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/nested.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/notBraced.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/nsAfterHashbang.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/outsideStmt.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/namespace/outsideStmtInvalid.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/switch.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/tryCatch.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/tryWithoutCatch.test
create mode 100644 vendor/nikic/php-parser/test/code/parser/stmt/unset.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/comments.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/commentsInCommaList.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/anonymousClass.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/arrayDestructuring.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/call.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/closure.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/constant_deref.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/docStrings.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/include.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/intrinsics.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/list.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/literals.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/numbers.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/operators.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/parentheses.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/shortArraySyntax.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/stringEscaping.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/uvs.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/variables.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/expr/yield.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/inlineHTMLandPHPtest.file-test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/onlyInlineHTML.file-test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/onlyPHP.file-test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/alias.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/break_continue.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/class.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/class_const.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/const.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/declare.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/do_while.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/for.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/foreach.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/function_signatures.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/global_static_variables.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/goto.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/groupUse.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/haltCompiler.file-test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/if.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/multiCatch.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/namespaces.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/nullable_types.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/switch.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/throw.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/traitUse.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/tryCatch.test
create mode 100644 vendor/nikic/php-parser/test/code/prettyPrinter/stmt/while.test
create mode 100644 vendor/nikic/php-parser/test_old/run-php-src.sh
create mode 100644 vendor/nikic/php-parser/test_old/run.php
create mode 100644 vendor/paragonie/random_compat/LICENSE
create mode 100644 vendor/paragonie/random_compat/composer.json
create mode 100644 vendor/paragonie/random_compat/dist/random_compat.phar.pubkey
create mode 100644 vendor/paragonie/random_compat/dist/random_compat.phar.pubkey.asc
create mode 100644 vendor/paragonie/random_compat/lib/byte_safe_strings.php
create mode 100644 vendor/paragonie/random_compat/lib/cast_to_int.php
create mode 100644 vendor/paragonie/random_compat/lib/error_polyfill.php
create mode 100644 vendor/paragonie/random_compat/lib/random.php
create mode 100644 vendor/paragonie/random_compat/lib/random_bytes_com_dotnet.php
create mode 100644 vendor/paragonie/random_compat/lib/random_bytes_dev_urandom.php
create mode 100644 vendor/paragonie/random_compat/lib/random_bytes_libsodium.php
create mode 100644 vendor/paragonie/random_compat/lib/random_bytes_libsodium_legacy.php
create mode 100644 vendor/paragonie/random_compat/lib/random_bytes_mcrypt.php
create mode 100644 vendor/paragonie/random_compat/lib/random_int.php
create mode 100644 vendor/phpdocumentor/reflection-common/.travis.yml
create mode 100644 vendor/phpdocumentor/reflection-common/LICENSE
create mode 100644 vendor/phpdocumentor/reflection-common/README.md
create mode 100644 vendor/phpdocumentor/reflection-common/composer.json
create mode 100644 vendor/phpdocumentor/reflection-common/src/Element.php
create mode 100644 vendor/phpdocumentor/reflection-common/src/File.php
create mode 100644 vendor/phpdocumentor/reflection-common/src/Fqsen.php
create mode 100644 vendor/phpdocumentor/reflection-common/src/Location.php
create mode 100644 vendor/phpdocumentor/reflection-common/src/Project.php
create mode 100644 vendor/phpdocumentor/reflection-common/src/ProjectFactory.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/LICENSE
create mode 100644 vendor/phpdocumentor/reflection-docblock/README.md
create mode 100644 vendor/phpdocumentor/reflection-docblock/composer.json
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Description.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/DescriptionFactory.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/ExampleFinder.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Serializer.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/StandardTagFactory.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tag.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/TagFactory.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Author.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/BaseTag.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Covers.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Deprecated.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Example.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Factory/StaticMethod.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Factory/Strategy.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Formatter.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Formatter/AlignFormatter.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Formatter/PassthroughFormatter.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Generic.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Link.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Method.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Param.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Property.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/PropertyRead.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/PropertyWrite.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Reference/Fqsen.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Reference/Reference.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Reference/Url.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Return_.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/See.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Since.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Source.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Throws.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Uses.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Var_.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Version.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlockFactory.php
create mode 100644 vendor/phpdocumentor/reflection-docblock/src/DocBlockFactoryInterface.php
create mode 100644 vendor/phpdocumentor/type-resolver/LICENSE
create mode 100644 vendor/phpdocumentor/type-resolver/README.md
create mode 100644 vendor/phpdocumentor/type-resolver/composer.json
create mode 100644 vendor/phpdocumentor/type-resolver/src/FqsenResolver.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Type.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/TypeResolver.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Array_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Boolean.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Callable_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Compound.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Context.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/ContextFactory.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Float_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Integer.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Iterable_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Mixed_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Null_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Nullable.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Object_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Parent_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Resource_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Scalar.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Self_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Static_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/String_.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/This.php
create mode 100644 vendor/phpdocumentor/type-resolver/src/Types/Void_.php
create mode 100644 vendor/phpspec/prophecy/CHANGES.md
create mode 100644 vendor/phpspec/prophecy/LICENSE
create mode 100644 vendor/phpspec/prophecy/README.md
create mode 100644 vendor/phpspec/prophecy/composer.json
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/ArgumentsWildcard.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/AnyValueToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/AnyValuesToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/ApproximateValueToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/ArrayCountToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/ArrayEntryToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/ArrayEveryEntryToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/CallbackToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/ExactValueToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/IdenticalValueToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/LogicalAndToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/LogicalNotToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/ObjectStateToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/StringContainsToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/TokenInterface.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Argument/Token/TypeToken.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Call/Call.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Call/CallCenter.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Comparator/ClosureComparator.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Comparator/Factory.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Comparator/ProphecyComparator.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/CachedDoubler.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ClassPatchInterface.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/DisableConstructorPatch.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/HhvmExceptionPatch.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/KeywordPatch.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/MagicCallPatch.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ProphecySubjectPatch.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ReflectionClassNewInstancePatch.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/SplFileInfoPatch.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ThrowablePatch.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/TraversablePatch.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/DoubleInterface.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/Doubler.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/Generator/ClassCodeGenerator.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/Generator/ClassCreator.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/Generator/ClassMirror.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/Generator/Node/ArgumentNode.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/Generator/Node/ClassNode.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/Generator/Node/MethodNode.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/Generator/ReflectionInterface.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/Generator/TypeHintReference.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/LazyDouble.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Doubler/NameGenerator.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Call/UnexpectedCallException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Doubler/ClassCreatorException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Doubler/ClassMirrorException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Doubler/ClassNotFoundException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Doubler/DoubleException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Doubler/DoublerException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Doubler/InterfaceNotFoundException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Doubler/MethodNotExtendableException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Doubler/MethodNotFoundException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Doubler/ReturnByReferenceException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Exception.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/InvalidArgumentException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Prediction/AggregateException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Prediction/FailedPredictionException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Prediction/NoCallsException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Prediction/PredictionException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Prediction/UnexpectedCallsCountException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Prediction/UnexpectedCallsException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Prophecy/MethodProphecyException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Prophecy/ObjectProphecyException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Exception/Prophecy/ProphecyException.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/PhpDocumentor/ClassAndInterfaceTagRetriever.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/PhpDocumentor/ClassTagRetriever.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/PhpDocumentor/LegacyClassTagRetriever.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/PhpDocumentor/MethodTagRetrieverInterface.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prediction/CallPrediction.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prediction/CallTimesPrediction.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prediction/CallbackPrediction.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prediction/NoCallsPrediction.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prediction/PredictionInterface.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Promise/CallbackPromise.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Promise/PromiseInterface.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Promise/ReturnArgumentPromise.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Promise/ReturnPromise.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Promise/ThrowPromise.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prophecy/MethodProphecy.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prophecy/ObjectProphecy.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prophecy/ProphecyInterface.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prophecy/ProphecySubjectInterface.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prophecy/Revealer.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prophecy/RevealerInterface.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Prophet.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Util/ExportUtil.php
create mode 100644 vendor/phpspec/prophecy/src/Prophecy/Util/StringUtil.php
create mode 100644 vendor/phpunit/php-code-coverage/.gitattributes
create mode 100644 vendor/phpunit/php-code-coverage/.github/CONTRIBUTING.md
create mode 100644 vendor/phpunit/php-code-coverage/.github/ISSUE_TEMPLATE.md
create mode 100644 vendor/phpunit/php-code-coverage/.gitignore
create mode 100644 vendor/phpunit/php-code-coverage/.php_cs
create mode 100644 vendor/phpunit/php-code-coverage/.travis.yml
create mode 100644 vendor/phpunit/php-code-coverage/ChangeLog-2.2.md
create mode 100644 vendor/phpunit/php-code-coverage/ChangeLog-3.0.md
create mode 100644 vendor/phpunit/php-code-coverage/ChangeLog-3.1.md
create mode 100644 vendor/phpunit/php-code-coverage/ChangeLog-3.2.md
create mode 100644 vendor/phpunit/php-code-coverage/ChangeLog-3.3.md
create mode 100644 vendor/phpunit/php-code-coverage/ChangeLog-4.0.md
create mode 100644 vendor/phpunit/php-code-coverage/LICENSE
create mode 100644 vendor/phpunit/php-code-coverage/README.md
create mode 100644 vendor/phpunit/php-code-coverage/build.xml
create mode 100644 vendor/phpunit/php-code-coverage/composer.json
create mode 100644 vendor/phpunit/php-code-coverage/phpunit.xml
create mode 100644 vendor/phpunit/php-code-coverage/src/CodeCoverage.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Driver/Driver.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Driver/HHVM.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Driver/PHPDBG.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Driver/Xdebug.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Exception/CoveredCodeNotExecutedException.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Exception/Exception.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Exception/InvalidArgumentException.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Exception/MissingCoversAnnotationException.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Exception/RuntimeException.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Exception/UnintentionallyCoveredCodeException.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Filter.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Node/AbstractNode.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Node/Builder.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Node/Directory.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Node/File.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Node/Iterator.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Clover.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Crap4j.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Facade.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Dashboard.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Directory.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/File.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/coverage_bar.html.dist
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/css/bootstrap.min.css
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/css/nv.d3.min.css
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/css/style.css
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/dashboard.html.dist
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/directory.html.dist
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/directory_item.html.dist
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/file.html.dist
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/file_item.html.dist
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/fonts/glyphicons-halflings-regular.eot
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/fonts/glyphicons-halflings-regular.svg
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/fonts/glyphicons-halflings-regular.ttf
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/fonts/glyphicons-halflings-regular.woff
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/fonts/glyphicons-halflings-regular.woff2
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/js/bootstrap.min.js
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/js/d3.min.js
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/js/holder.min.js
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/js/html5shiv.min.js
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/js/jquery.min.js
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/js/nv.d3.min.js
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/js/respond.min.js
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Html/Renderer/Template/method_item.html.dist
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/PHP.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Text.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/Coverage.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/Directory.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/Facade.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/File.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/Method.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/Node.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/Project.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/Report.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/Tests.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/Totals.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Report/Xml/Unit.php
create mode 100644 vendor/phpunit/php-code-coverage/src/Util.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/TestCase.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/BankAccount-clover.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/BankAccount-crap4j.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/BankAccount-text.txt
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/BankAccount.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/BankAccountTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageClassExtendedTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageClassTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageFunctionParenthesesTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageFunctionParenthesesWhitespaceTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageFunctionTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageMethodOneLineAnnotationTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageMethodParenthesesTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageMethodParenthesesWhitespaceTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageMethodTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageNoneTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageNotPrivateTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageNotProtectedTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageNotPublicTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageNothingTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoveragePrivateTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageProtectedTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoveragePublicTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoverageTwoDefaultClassAnnotations.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoveredClass.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/CoveredFunction.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoverageClassExtendedTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoverageClassTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoverageCoversClassPublicTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoverageCoversClassTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoverageMethodTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoverageNotPrivateTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoverageNotProtectedTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoverageNotPublicTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoveragePrivateTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoverageProtectedTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoveragePublicTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NamespaceCoveredClass.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/NotExistingCoveredElementTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/HTML/CoverageForBankAccount/BankAccount.php.html
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/HTML/CoverageForBankAccount/dashboard.html
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/HTML/CoverageForBankAccount/index.html
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/HTML/CoverageForClassWithAnonymousFunction/dashboard.html
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/HTML/CoverageForClassWithAnonymousFunction/index.html
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/HTML/CoverageForClassWithAnonymousFunction/source_with_class_and_anonymous_function.php.html
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/HTML/CoverageForFileWithIgnoredLines/dashboard.html
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/HTML/CoverageForFileWithIgnoredLines/index.html
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/HTML/CoverageForFileWithIgnoredLines/source_with_ignore.php.html
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/XML/CoverageForBankAccount/BankAccount.php.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/XML/CoverageForBankAccount/index.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/XML/CoverageForClassWithAnonymousFunction/index.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/XML/CoverageForClassWithAnonymousFunction/source_with_class_and_anonymous_function.php.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/XML/CoverageForFileWithIgnoredLines/index.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/Report/XML/CoverageForFileWithIgnoredLines/source_with_ignore.php.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/class-with-anonymous-function-clover.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/class-with-anonymous-function-crap4j.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/class-with-anonymous-function-text.txt
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/ignored-lines-clover.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/ignored-lines-crap4j.xml
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/ignored-lines-text.txt
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/source_with_class_and_anonymous_function.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/source_with_ignore.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/source_with_namespace.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/source_with_oneline_annotations.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/source_without_ignore.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/_files/source_without_namespace.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/bootstrap.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/tests/BuilderTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/tests/CloverTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/tests/CodeCoverageTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/tests/Crap4jTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/tests/FilterTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/tests/HTMLTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/tests/TextTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/tests/UtilTest.php
create mode 100644 vendor/phpunit/php-code-coverage/tests/tests/XMLTest.php
create mode 100644 vendor/phpunit/php-file-iterator/.gitattributes
create mode 100644 vendor/phpunit/php-file-iterator/.gitignore
create mode 100644 vendor/phpunit/php-file-iterator/ChangeLog.md
create mode 100644 vendor/phpunit/php-file-iterator/LICENSE
create mode 100644 vendor/phpunit/php-file-iterator/README.md
create mode 100644 vendor/phpunit/php-file-iterator/composer.json
create mode 100644 vendor/phpunit/php-file-iterator/src/Facade.php
create mode 100644 vendor/phpunit/php-file-iterator/src/Factory.php
create mode 100644 vendor/phpunit/php-file-iterator/src/Iterator.php
create mode 100644 vendor/phpunit/php-text-template/.gitattributes
create mode 100644 vendor/phpunit/php-text-template/.gitignore
create mode 100644 vendor/phpunit/php-text-template/LICENSE
create mode 100644 vendor/phpunit/php-text-template/README.md
create mode 100644 vendor/phpunit/php-text-template/composer.json
create mode 100644 vendor/phpunit/php-text-template/src/Template.php
create mode 100644 vendor/phpunit/php-timer/.gitattributes
create mode 100644 vendor/phpunit/php-timer/.gitignore
create mode 100644 vendor/phpunit/php-timer/.travis.yml
create mode 100644 vendor/phpunit/php-timer/LICENSE
create mode 100644 vendor/phpunit/php-timer/README.md
create mode 100644 vendor/phpunit/php-timer/composer.json
create mode 100644 vendor/phpunit/php-timer/phpunit.xml
create mode 100644 vendor/phpunit/php-timer/src/Timer.php
create mode 100644 vendor/phpunit/php-timer/tests/TimerTest.php
create mode 100644 vendor/phpunit/php-token-stream/.gitattributes
create mode 100644 vendor/phpunit/php-token-stream/.gitignore
create mode 100644 vendor/phpunit/php-token-stream/.travis.yml
create mode 100644 vendor/phpunit/php-token-stream/LICENSE
create mode 100644 vendor/phpunit/php-token-stream/README.md
create mode 100644 vendor/phpunit/php-token-stream/build.xml
create mode 100644 vendor/phpunit/php-token-stream/build/phpunit.xml
create mode 100644 vendor/phpunit/php-token-stream/composer.json
create mode 100644 vendor/phpunit/php-token-stream/src/Token.php
create mode 100644 vendor/phpunit/php-token-stream/src/Token/Stream.php
create mode 100644 vendor/phpunit/php-token-stream/src/Token/Stream/CachingFactory.php
create mode 100644 vendor/phpunit/php-token-stream/tests/Token/ClassTest.php
create mode 100644 vendor/phpunit/php-token-stream/tests/Token/ClosureTest.php
create mode 100644 vendor/phpunit/php-token-stream/tests/Token/FunctionTest.php
create mode 100644 vendor/phpunit/php-token-stream/tests/Token/IncludeTest.php
create mode 100644 vendor/phpunit/php-token-stream/tests/Token/InterfaceTest.php
create mode 100644 vendor/phpunit/php-token-stream/tests/Token/NamespaceTest.php
create mode 100644 vendor/phpunit/php-token-stream/tests/TokenTest.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/classExtendsNamespacedClass.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/classInNamespace.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/classInScopedNamespace.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/classUsesNamespacedFunction.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/class_with_method_that_declares_anonymous_class.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/class_with_method_that_declares_anonymous_class2.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/closure.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/issue19.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/issue30.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/multipleNamespacesWithOneClassUsingBraces.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/multipleNamespacesWithOneClassUsingNonBraceSyntax.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/source.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/source2.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/source3.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/source4.php
create mode 100644 vendor/phpunit/php-token-stream/tests/_fixture/source5.php
create mode 100644 vendor/phpunit/php-token-stream/tests/bootstrap.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/.gitattributes
create mode 100644 vendor/phpunit/phpunit-mock-objects/.gitignore
create mode 100644 vendor/phpunit/phpunit-mock-objects/.php_cs
create mode 100644 vendor/phpunit/phpunit-mock-objects/.travis.yml
create mode 100644 vendor/phpunit/phpunit-mock-objects/CONTRIBUTING.md
create mode 100644 vendor/phpunit/phpunit-mock-objects/LICENSE
create mode 100644 vendor/phpunit/phpunit-mock-objects/README.md
create mode 100644 vendor/phpunit/phpunit-mock-objects/build.xml
create mode 100644 vendor/phpunit/phpunit-mock-objects/composer.json
create mode 100644 vendor/phpunit/phpunit-mock-objects/phpunit.xml
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Identity.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/InvocationMocker.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Match.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/MethodNameMatch.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Namespace.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/ParametersMatch.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Stub.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Exception/BadMethodCallException.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Exception/Exception.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Exception/RuntimeException.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/deprecation.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/mocked_class.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/mocked_class_method.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/mocked_clone.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/mocked_method.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/mocked_method_void.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/mocked_static_method.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/proxied_method.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/proxied_method_void.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/trait_class.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/unmocked_clone.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/wsdl_class.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator/wsdl_method.tpl.dist
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invocation.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invocation/Object.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invocation/Static.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/InvocationMocker.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invokable.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/AnyInvokedCount.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/AnyParameters.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/ConsecutiveParameters.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/Invocation.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtIndex.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtLeastCount.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtLeastOnce.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtMostCount.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedCount.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedRecorder.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/MethodName.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/Parameters.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/StatelessInvocation.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/MockBuilder.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/MockObject.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ConsecutiveCalls.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/Exception.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/MatcherCollection.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/Return.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnArgument.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnCallback.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnReference.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnSelf.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnValueMap.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/src/Framework/MockObject/Verifiable.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/GeneratorTest.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockBuilderTest.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Builder/InvocationMockerTest.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/232.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/abstract_class.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/class.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/class_call_parent_clone.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/class_call_parent_constructor.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/class_dont_call_parent_clone.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/class_dont_call_parent_constructor.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/class_implementing_interface_call_parent_constructor.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/class_implementing_interface_dont_call_parent_constructor.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/class_partial.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/class_with_method_named_method.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/class_with_method_with_variadic_arguments.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/interface.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/invocation_object_clone_object.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/namespaced_class.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/namespaced_class_call_parent_clone.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/namespaced_class_call_parent_constructor.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/namespaced_class_dont_call_parent_clone.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/namespaced_class_dont_call_parent_constructor.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/namespaced_class_implementing_interface_call_parent_constructor.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/namespaced_class_implementing_interface_dont_call_parent_constructor.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/namespaced_class_partial.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/namespaced_interface.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/nonexistent_class.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/nonexistent_class_with_namespace.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/nonexistent_class_with_namespace_starting_with_separator.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/nullable_types.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/proxy.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/return_type_declarations_nullable.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/return_type_declarations_object_method.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/return_type_declarations_self.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/return_type_declarations_static_method.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/return_type_declarations_void.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/scalar_type_declarations.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/wsdl_class.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/wsdl_class_namespace.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Generator/wsdl_class_partial.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Invocation/ObjectTest.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Invocation/StaticTest.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/Matcher/ConsecutiveParametersTest.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObject/class_with_deprecated_method.phpt
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/MockObjectTest.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/ProxyObjectTest.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/AbstractMockTestClass.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/AbstractTrait.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/AnInterface.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/AnInterfaceWithReturnType.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/AnotherInterface.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/Bar.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/ClassThatImplementsSerializable.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/ClassWithSelfTypeHint.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/ClassWithStaticMethod.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/Foo.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/FunctionCallback.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/GoogleSearch.wsdl
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/InterfaceWithSemiReservedMethodName.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/InterfaceWithStaticMethod.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/MethodCallback.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/MethodCallbackByReference.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/MockTestInterface.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/Mockable.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/PartialMockTestClass.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/SingletonClass.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/SomeClass.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/StaticMockTestClass.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/StringableClass.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/_fixture/TraversableMockTestInterface.php
create mode 100644 vendor/phpunit/phpunit-mock-objects/tests/bootstrap.php
create mode 100644 vendor/phpunit/phpunit/.gitattributes
create mode 100644 vendor/phpunit/phpunit/.github/CODE_OF_CONDUCT.md
create mode 100644 vendor/phpunit/phpunit/.github/CONTRIBUTING.md
create mode 100644 vendor/phpunit/phpunit/.github/ISSUE_TEMPLATE.md
create mode 100644 vendor/phpunit/phpunit/.gitignore
create mode 100644 vendor/phpunit/phpunit/.php_cs.dist
create mode 100644 vendor/phpunit/phpunit/.stickler.yml
create mode 100644 vendor/phpunit/phpunit/.travis.yml
create mode 100644 vendor/phpunit/phpunit/ChangeLog-5.7.md
create mode 100644 vendor/phpunit/phpunit/LICENSE
create mode 100644 vendor/phpunit/phpunit/README.md
create mode 100644 vendor/phpunit/phpunit/build.xml
create mode 100644 vendor/phpunit/phpunit/composer.json
create mode 100644 vendor/phpunit/phpunit/phpunit
create mode 100644 vendor/phpunit/phpunit/phpunit.xml
create mode 100644 vendor/phpunit/phpunit/phpunit.xsd
create mode 100644 vendor/phpunit/phpunit/src/Exception.php
create mode 100644 vendor/phpunit/phpunit/src/Extensions/GroupTestSuite.php
create mode 100644 vendor/phpunit/phpunit/src/Extensions/PhptTestCase.php
create mode 100644 vendor/phpunit/phpunit/src/Extensions/PhptTestSuite.php
create mode 100644 vendor/phpunit/phpunit/src/Extensions/RepeatedTest.php
create mode 100644 vendor/phpunit/phpunit/src/Extensions/TestDecorator.php
create mode 100644 vendor/phpunit/phpunit/src/Extensions/TicketListener.php
create mode 100644 vendor/phpunit/phpunit/src/ForwardCompatibility/Assert.php
create mode 100644 vendor/phpunit/phpunit/src/ForwardCompatibility/AssertionFailedError.php
create mode 100644 vendor/phpunit/phpunit/src/ForwardCompatibility/BaseTestListener.php
create mode 100644 vendor/phpunit/phpunit/src/ForwardCompatibility/Test.php
create mode 100644 vendor/phpunit/phpunit/src/ForwardCompatibility/TestCase.php
create mode 100644 vendor/phpunit/phpunit/src/ForwardCompatibility/TestListener.php
create mode 100644 vendor/phpunit/phpunit/src/ForwardCompatibility/TestSuite.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Assert.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Assert/Functions.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/AssertionFailedError.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/BaseTestListener.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/CodeCoverageException.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/And.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/ArrayHasKey.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/ArraySubset.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/Attribute.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/Callback.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/ClassHasAttribute.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/ClassHasStaticAttribute.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/Composite.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/Count.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/DirectoryExists.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/Exception.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/ExceptionCode.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/ExceptionMessage.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/ExceptionMessageRegExp.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/FileExists.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/GreaterThan.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsAnything.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsEmpty.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsEqual.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsFalse.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsFinite.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsIdentical.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsInfinite.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsInstanceOf.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsJson.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsNan.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsNull.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsReadable.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsTrue.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsType.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/IsWritable.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/JsonMatches.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/JsonMatches/ErrorMessageProvider.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/LessThan.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/Not.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/ObjectHasAttribute.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/Or.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/PCREMatch.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/SameSize.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/StringContains.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/StringEndsWith.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/StringMatches.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/StringStartsWith.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/TraversableContains.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/TraversableContainsOnly.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Constraint/Xor.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/CoveredCodeNotExecutedException.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Error.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Error/Deprecated.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Error/Notice.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Error/Warning.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Exception.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/ExceptionWrapper.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/ExpectationFailedException.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/IncompleteTest.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/IncompleteTestCase.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/IncompleteTestError.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/InvalidCoversTargetException.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/MissingCoversAnnotationException.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/OutputError.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/RiskyTest.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/RiskyTestError.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/SelfDescribing.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/SkippedTest.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/SkippedTestCase.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/SkippedTestError.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/SkippedTestSuiteError.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/SyntheticError.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Test.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/TestCase.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/TestFailure.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/TestListener.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/TestResult.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/TestSuite.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/TestSuite/DataProvider.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/UnintentionallyCoveredCodeError.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/Warning.php
create mode 100644 vendor/phpunit/phpunit/src/Framework/WarningTestCase.php
create mode 100644 vendor/phpunit/phpunit/src/Runner/BaseTestRunner.php
create mode 100644 vendor/phpunit/phpunit/src/Runner/Exception.php
create mode 100644 vendor/phpunit/phpunit/src/Runner/Filter/Factory.php
create mode 100644 vendor/phpunit/phpunit/src/Runner/Filter/Group.php
create mode 100644 vendor/phpunit/phpunit/src/Runner/Filter/Group/Exclude.php
create mode 100644 vendor/phpunit/phpunit/src/Runner/Filter/Group/Include.php
create mode 100644 vendor/phpunit/phpunit/src/Runner/Filter/Test.php
create mode 100644 vendor/phpunit/phpunit/src/Runner/StandardTestSuiteLoader.php
create mode 100644 vendor/phpunit/phpunit/src/Runner/TestSuiteLoader.php
create mode 100644 vendor/phpunit/phpunit/src/Runner/Version.php
create mode 100644 vendor/phpunit/phpunit/src/TextUI/Command.php
create mode 100644 vendor/phpunit/phpunit/src/TextUI/ResultPrinter.php
create mode 100644 vendor/phpunit/phpunit/src/TextUI/TestRunner.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Blacklist.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Configuration.php
create mode 100644 vendor/phpunit/phpunit/src/Util/ConfigurationGenerator.php
create mode 100644 vendor/phpunit/phpunit/src/Util/ErrorHandler.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Fileloader.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Filesystem.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Filter.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Getopt.php
create mode 100644 vendor/phpunit/phpunit/src/Util/GlobalState.php
create mode 100644 vendor/phpunit/phpunit/src/Util/InvalidArgumentHelper.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Log/JSON.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Log/JUnit.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Log/TAP.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Log/TeamCity.php
create mode 100644 vendor/phpunit/phpunit/src/Util/PHP.php
create mode 100644 vendor/phpunit/phpunit/src/Util/PHP/Default.php
create mode 100644 vendor/phpunit/phpunit/src/Util/PHP/Template/TestCaseMethod.tpl.dist
create mode 100644 vendor/phpunit/phpunit/src/Util/PHP/Windows.php
create mode 100644 vendor/phpunit/phpunit/src/Util/PHP/eval-stdin.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Printer.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Regex.php
create mode 100644 vendor/phpunit/phpunit/src/Util/String.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Test.php
create mode 100644 vendor/phpunit/phpunit/src/Util/TestDox/NamePrettifier.php
create mode 100644 vendor/phpunit/phpunit/src/Util/TestDox/ResultPrinter.php
create mode 100644 vendor/phpunit/phpunit/src/Util/TestDox/ResultPrinter/HTML.php
create mode 100644 vendor/phpunit/phpunit/src/Util/TestDox/ResultPrinter/Text.php
create mode 100644 vendor/phpunit/phpunit/src/Util/TestDox/ResultPrinter/XML.php
create mode 100644 vendor/phpunit/phpunit/src/Util/TestSuiteIterator.php
create mode 100644 vendor/phpunit/phpunit/src/Util/Type.php
create mode 100644 vendor/phpunit/phpunit/src/Util/XML.php
create mode 100644 vendor/phpunit/phpunit/tests/Extensions/PhptTestCaseTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Extensions/RepeatedTestTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Fail/fail.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Framework/AssertTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/BaseTestListenerTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/Constraint/ArraySubsetTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/Constraint/CountTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/Constraint/ExceptionMessageRegExpTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/Constraint/ExceptionMessageTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/Constraint/IsJsonTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/Constraint/JsonMatches/ErrorMessageProviderTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/Constraint/JsonMatchesTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/ConstraintTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/SuiteTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/TestCaseTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/TestFailureTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/TestImplementorTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Framework/TestListenerTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1149.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1149/Issue1149Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1216.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1216/Issue1216Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1216/bootstrap1216.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1216/phpunit1216.xml
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1265.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1265/Issue1265Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1265/phpunit1265.xml
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1330.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1330/Issue1330Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1330/phpunit1330.xml
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1335.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1335/Issue1335Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1335/bootstrap1335.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1337.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1337/Issue1337Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1348.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1348/Issue1348Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1351.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1351/ChildProcessClass1351.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1351/Issue1351Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1374.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1374/Issue1374Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1437.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1437/Issue1437Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1468.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1468/Issue1468Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1471.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1471/Issue1471Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1472.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1472/Issue1472Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1570.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/1570/Issue1570Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2137-filter.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2137-no_filter.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2137/Issue2137Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2145.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2145/Issue2145Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2158.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2158/Issue2158Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2158/constant.inc
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2299/Issue2299Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2366.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2366/Issue2366Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2380.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2380/Issue2380Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2382.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2382/Issue2382Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2435.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2435/Issue2435Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/244.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/244/Issue244Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2731.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2731/Issue2731Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2758.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2758/Issue2758Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2758/Issue2758TestListener.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2758/phpunit.xml
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2811.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2811/Issue2811Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2972.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2972/issue-2972-test.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/2972/unconventiallyNamedIssue2972Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/322.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/322/Issue322Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/322/phpunit322.xml
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/433.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/433/Issue433Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/445.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/445/Issue445Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/498.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/498/Issue498Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/503.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/503/Issue503Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/581.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/581/Issue581Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/74.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/74/Issue74Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/74/NewException.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/765.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/765/Issue765Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/797.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/797/Issue797Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/797/bootstrap797.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/863.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/873-php5.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/873-php7.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/GitHub/873/Issue873Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/1021.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/1021/Issue1021Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/523.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/523/Issue523Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/578.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/578/Issue578Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/684.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/684/Issue684Test.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/783.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/783/ChildSuite.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/783/OneTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/783/ParentSuite.php
create mode 100644 vendor/phpunit/phpunit/tests/Regression/Trac/783/TwoTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Runner/BaseTestRunnerTest.php
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/_files/expect_external.txt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/_files/phpt-env.expected.txt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/_files/phpt_external.php
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/abstract-test-class.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/assertion.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/code-coverage-ignore.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/colors-always.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/concrete-test-class.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/custom-printer-debug.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/custom-printer-verbose.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dataprovider-debug.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dataprovider-issue-2833.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dataprovider-issue-2859.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dataprovider-issue-2922.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dataprovider-log-xml-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dataprovider-log-xml.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dataprovider-testdox.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/debug.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/default-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/default.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dependencies-clone.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dependencies-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dependencies.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dependencies2-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dependencies2.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dependencies3-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/dependencies3.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/disable-code-coverage-ignore.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/empty-testcase.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/exception-stack.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/exclude-group-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/exclude-group.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/failure-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/failure-reverse-list.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/failure.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/fatal-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-class-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-class.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-classname-and-range-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-classname-and-range.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-number-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-number.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-only-range-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-only-range.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-only-regexp-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-only-regexp.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-only-string-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-only-string.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-range-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-range.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-regexp-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-regexp.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-string-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-dataprovider-by-string.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-method-case-insensitive.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-method-case-sensitive-no-result.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-method-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-method.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/filter-no-results.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/forward-compatibility.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/group-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/group.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/help.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/help2.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/ini-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/list-groups.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/list-suites.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/log-json-post-66021.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/log-junit.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/log-tap.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/log-teamcity.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/mycommand.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/options-after-arguments.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/output-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/phar-extension-suppressed.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/phar-extension.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/phpt-args.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/phpt-env.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/phpt-external.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/phpt-stderr.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/phpt-stdin.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/phpt-xfail.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/repeat.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/report-useless-tests-incomplete.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/report-useless-tests-isolation.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/report-useless-tests.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/stop-on-warning-via-cli.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/stop-on-warning-via-config.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/tap.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/teamcity-inner-exceptions.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/teamcity.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/test-suffix-multiple.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/test-suffix-single.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/testdox-exclude-group.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/testdox-group.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/testdox-html.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/testdox-text.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/testdox-xml.phpt
create mode 100644 vendor/phpunit/phpunit/tests/TextUI/testdox.phpt
create mode 100644 vendor/phpunit/phpunit/tests/Util/ConfigurationTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Util/GetoptTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Util/GlobalStateTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Util/PHPTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Util/RegexTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Util/TestDox/NamePrettifierTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Util/TestTest.php
create mode 100644 vendor/phpunit/phpunit/tests/Util/XMLTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/AbstractTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ArrayAccessible.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/AssertionExample.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/AssertionExampleTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/Author.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/BankAccount.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/BankAccountTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/BankAccountTest.test.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/BankAccountTest2.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/BaseTestListenerSample.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/BeforeAndAfterTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/BeforeClassAndAfterClassTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/BeforeClassWithOnlyDataProviderTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/Book.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/Calculator.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ChangeCurrentWorkingDirectoryTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ClassWithNonPublicAttributes.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ClassWithScalarTypeDeclarations.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ClassWithToString.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ClonedDependencyTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ConcreteTest.my.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ConcreteTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageClassExtendedTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageClassTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageFunctionParenthesesTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageFunctionParenthesesWhitespaceTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageFunctionTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageMethodOneLineAnnotationTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageMethodParenthesesTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageMethodParenthesesWhitespaceTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageMethodTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageNamespacedFunctionTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageNoneTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageNotPrivateTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageNotProtectedTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageNotPublicTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageNothingTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoveragePrivateTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageProtectedTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoveragePublicTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoverageTwoDefaultClassAnnotations.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoveredClass.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CoveredFunction.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/CustomPrinter.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderDebugTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderDependencyTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderFilterTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderIncompleteTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderIssue2833/FirstTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderIssue2833/SecondTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderIssue2859/phpunit.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderIssue2859/tests/another/TestWithDataProviderTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderIssue2922/FirstTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderIssue2922/SecondTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderSkippedTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DataProviderTestDoxTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DependencyFailureTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DependencySuccessTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DependencyTestSuite.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DoubleTestCase.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/DummyException.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/EmptyTestCaseTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ExceptionInAssertPostConditionsTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ExceptionInAssertPreConditionsTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ExceptionInSetUpTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ExceptionInTearDownTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ExceptionInTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ExceptionNamespaceTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ExceptionStackTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ExceptionTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/Failure.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/FailureTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/FatalTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/IgnoreCodeCoverageClass.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/IgnoreCodeCoverageClassTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/IncompleteTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/Inheritance/InheritanceA.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/Inheritance/InheritanceB.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/InheritedTestCase.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/IniTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/IsolationTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/JsonData/arrayObject.json
create mode 100644 vendor/phpunit/phpunit/tests/_files/JsonData/simpleObject.json
create mode 100644 vendor/phpunit/phpunit/tests/_files/MockRunner.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/Mockable.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/MultiDependencyTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/MultipleDataProviderTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/MyCommand.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoverageClassExtendedTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoverageClassTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoverageCoversClassPublicTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoverageCoversClassTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoverageMethodTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoverageNotPrivateTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoverageNotProtectedTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoverageNotPublicTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoveragePrivateTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoverageProtectedTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoveragePublicTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoveredClass.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NamespaceCoveredFunction.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NoArgTestCaseTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NoTestCaseClass.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NoTestCases.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NonStatic.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NotExistingCoveredElementTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NotPublicTestCase.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NotVoidTestCase.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/NothingTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/OneTestCase.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/OutputTestCase.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/OverrideTestCase.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/RequirementsClassBeforeClassHookTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/RequirementsClassDocBlockTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/RequirementsTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/SampleArrayAccess.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/SampleClass.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/Singleton.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/StackTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/StatusTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/StopOnWarningTestSuite.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/StopsOnWarningTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/Struct.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/Success.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/TemplateMethodsTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/TestAutoreferenced.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/TestDoxGroupTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/TestGeneratorMaker.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/TestIncomplete.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/TestIterator.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/TestIterator2.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/TestSkipped.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/TestTestError.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/TestWithTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ThrowExceptionTestCase.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/ThrowNoExceptionTestCase.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/WasRun.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/bar.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/configuration.colors.empty.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/configuration.colors.false.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/configuration.colors.invalid.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/configuration.colors.true.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/configuration.custom-printer.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/configuration.suites.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/configuration.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/configuration_empty.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/configuration_stop_on_warning.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/configuration_xinclude.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/expectedFileFormat.txt
create mode 100644 vendor/phpunit/phpunit/tests/_files/foo.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/phpt-for-coverage.phpt
create mode 100644 vendor/phpunit/phpunit/tests/_files/phpt-xfail.phpt
create mode 100644 vendor/phpunit/phpunit/tests/_files/phpunit-example-extension/phpunit.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/phpunit-example-extension/tests/OneTest.php
create mode 100644 vendor/phpunit/phpunit/tests/_files/phpunit-example-extension/tools/phpunit.d/phpunit-example-extension-1.0.0.phar
create mode 100644 vendor/phpunit/phpunit/tests/_files/structureAttributesAreSameButValuesAreNot.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/structureExpected.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/structureIgnoreTextNodes.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/structureIsSameButDataIsNot.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/structureWrongNumberOfAttributes.xml
create mode 100644 vendor/phpunit/phpunit/tests/_files/structureWrongNumberOfNodes.xml
create mode 100644 vendor/phpunit/phpunit/tests/bootstrap.php
create mode 100644 vendor/psr/log/LICENSE
create mode 100644 vendor/psr/log/Psr/Log/AbstractLogger.php
create mode 100644 vendor/psr/log/Psr/Log/InvalidArgumentException.php
create mode 100644 vendor/psr/log/Psr/Log/LogLevel.php
create mode 100644 vendor/psr/log/Psr/Log/LoggerAwareInterface.php
create mode 100644 vendor/psr/log/Psr/Log/LoggerAwareTrait.php
create mode 100644 vendor/psr/log/Psr/Log/LoggerInterface.php
create mode 100644 vendor/psr/log/Psr/Log/LoggerTrait.php
create mode 100644 vendor/psr/log/Psr/Log/NullLogger.php
create mode 100644 vendor/psr/log/Psr/Log/Test/DummyTest.php
create mode 100644 vendor/psr/log/Psr/Log/Test/LoggerInterfaceTest.php
create mode 100644 vendor/psr/log/Psr/Log/Test/TestLogger.php
create mode 100644 vendor/psr/log/README.md
create mode 100644 vendor/psr/log/composer.json
create mode 100644 vendor/psy/psysh/.editorconfig
create mode 100644 vendor/psy/psysh/.github/CONTRIBUTING.md
create mode 100644 vendor/psy/psysh/.gitignore
create mode 100644 vendor/psy/psysh/.phan/config.php
create mode 100644 vendor/psy/psysh/.php_cs
create mode 100644 vendor/psy/psysh/.styleci.yml
create mode 100644 vendor/psy/psysh/.travis.yml
create mode 100644 vendor/psy/psysh/LICENSE
create mode 100644 vendor/psy/psysh/Makefile
create mode 100644 vendor/psy/psysh/README.md
create mode 100644 vendor/psy/psysh/bin/build-stub
create mode 100644 vendor/psy/psysh/bin/psysh
create mode 100644 vendor/psy/psysh/box.json.dist
create mode 100644 vendor/psy/psysh/composer.json
create mode 100644 vendor/psy/psysh/phpunit.xml.dist
create mode 100644 vendor/psy/psysh/src/CodeCleaner.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/AbstractClassPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/AssignThisVariablePass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/CallTimePassByReferencePass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/CalledClassPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/CodeCleanerPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/ExitPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/FinalClassPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/FunctionContextPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/FunctionReturnInWriteContextPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/ImplicitReturnPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/InstanceOfPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/LeavePsyshAlonePass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/LegacyEmptyPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/ListPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/LoopContextPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/MagicConstantsPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/NamespaceAwarePass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/NamespacePass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/NoReturnValue.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/PassableByReferencePass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/RequirePass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/StrictTypesPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/UseStatementPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/ValidClassNamePass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/ValidConstantPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/ValidConstructorPass.php
create mode 100644 vendor/psy/psysh/src/CodeCleaner/ValidFunctionNamePass.php
create mode 100644 vendor/psy/psysh/src/Command/BufferCommand.php
create mode 100644 vendor/psy/psysh/src/Command/ClearCommand.php
create mode 100644 vendor/psy/psysh/src/Command/Command.php
create mode 100644 vendor/psy/psysh/src/Command/DocCommand.php
create mode 100644 vendor/psy/psysh/src/Command/DumpCommand.php
create mode 100644 vendor/psy/psysh/src/Command/EditCommand.php
create mode 100644 vendor/psy/psysh/src/Command/ExitCommand.php
create mode 100644 vendor/psy/psysh/src/Command/HelpCommand.php
create mode 100644 vendor/psy/psysh/src/Command/HistoryCommand.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/ClassConstantEnumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/ClassEnumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/ConstantEnumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/Enumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/FunctionEnumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/GlobalVariableEnumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/InterfaceEnumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/MethodEnumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/PropertyEnumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/TraitEnumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ListCommand/VariableEnumerator.php
create mode 100644 vendor/psy/psysh/src/Command/ParseCommand.php
create mode 100644 vendor/psy/psysh/src/Command/PsyVersionCommand.php
create mode 100644 vendor/psy/psysh/src/Command/ReflectingCommand.php
create mode 100644 vendor/psy/psysh/src/Command/ShowCommand.php
create mode 100644 vendor/psy/psysh/src/Command/SudoCommand.php
create mode 100644 vendor/psy/psysh/src/Command/ThrowUpCommand.php
create mode 100644 vendor/psy/psysh/src/Command/TimeitCommand.php
create mode 100644 vendor/psy/psysh/src/Command/TimeitCommand/TimeitVisitor.php
create mode 100644 vendor/psy/psysh/src/Command/TraceCommand.php
create mode 100644 vendor/psy/psysh/src/Command/WhereamiCommand.php
create mode 100644 vendor/psy/psysh/src/Command/WtfCommand.php
create mode 100644 vendor/psy/psysh/src/ConfigPaths.php
create mode 100644 vendor/psy/psysh/src/Configuration.php
create mode 100644 vendor/psy/psysh/src/ConsoleColorFactory.php
create mode 100644 vendor/psy/psysh/src/Context.php
create mode 100644 vendor/psy/psysh/src/ContextAware.php
create mode 100644 vendor/psy/psysh/src/Exception/BreakException.php
create mode 100644 vendor/psy/psysh/src/Exception/DeprecatedException.php
create mode 100644 vendor/psy/psysh/src/Exception/ErrorException.php
create mode 100644 vendor/psy/psysh/src/Exception/Exception.php
create mode 100644 vendor/psy/psysh/src/Exception/FatalErrorException.php
create mode 100644 vendor/psy/psysh/src/Exception/ParseErrorException.php
create mode 100644 vendor/psy/psysh/src/Exception/RuntimeException.php
create mode 100644 vendor/psy/psysh/src/Exception/ThrowUpException.php
create mode 100644 vendor/psy/psysh/src/Exception/TypeErrorException.php
create mode 100644 vendor/psy/psysh/src/ExecutionClosure.php
create mode 100644 vendor/psy/psysh/src/ExecutionLoop.php
create mode 100644 vendor/psy/psysh/src/ExecutionLoop/AbstractListener.php
create mode 100644 vendor/psy/psysh/src/ExecutionLoop/Listener.php
create mode 100644 vendor/psy/psysh/src/ExecutionLoop/ProcessForker.php
create mode 100644 vendor/psy/psysh/src/ExecutionLoop/RunkitReloader.php
create mode 100644 vendor/psy/psysh/src/ExecutionLoopClosure.php
create mode 100644 vendor/psy/psysh/src/Formatter/CodeFormatter.php
create mode 100644 vendor/psy/psysh/src/Formatter/DocblockFormatter.php
create mode 100644 vendor/psy/psysh/src/Formatter/Formatter.php
create mode 100644 vendor/psy/psysh/src/Formatter/SignatureFormatter.php
create mode 100644 vendor/psy/psysh/src/Input/CodeArgument.php
create mode 100644 vendor/psy/psysh/src/Input/FilterOptions.php
create mode 100644 vendor/psy/psysh/src/Input/ShellInput.php
create mode 100644 vendor/psy/psysh/src/Input/SilentInput.php
create mode 100644 vendor/psy/psysh/src/Output/OutputPager.php
create mode 100644 vendor/psy/psysh/src/Output/PassthruPager.php
create mode 100644 vendor/psy/psysh/src/Output/ProcOutputPager.php
create mode 100644 vendor/psy/psysh/src/Output/ShellOutput.php
create mode 100644 vendor/psy/psysh/src/ParserFactory.php
create mode 100644 vendor/psy/psysh/src/Readline/GNUReadline.php
create mode 100644 vendor/psy/psysh/src/Readline/HoaConsole.php
create mode 100644 vendor/psy/psysh/src/Readline/Libedit.php
create mode 100644 vendor/psy/psysh/src/Readline/Readline.php
create mode 100644 vendor/psy/psysh/src/Readline/Transient.php
create mode 100644 vendor/psy/psysh/src/Reflection/ReflectionClassConstant.php
create mode 100644 vendor/psy/psysh/src/Reflection/ReflectionConstant.php
create mode 100644 vendor/psy/psysh/src/Reflection/ReflectionConstant_.php
create mode 100644 vendor/psy/psysh/src/Reflection/ReflectionLanguageConstruct.php
create mode 100644 vendor/psy/psysh/src/Reflection/ReflectionLanguageConstructParameter.php
create mode 100644 vendor/psy/psysh/src/Shell.php
create mode 100644 vendor/psy/psysh/src/Sudo.php
create mode 100644 vendor/psy/psysh/src/Sudo/SudoVisitor.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/AutoCompleter.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/AbstractContextAwareMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/AbstractDefaultParametersMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/AbstractMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/ClassAttributesMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/ClassMethodDefaultParametersMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/ClassMethodsMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/ClassNamesMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/CommandsMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/ConstantsMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/FunctionDefaultParametersMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/FunctionsMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/KeywordsMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/MongoClientMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/MongoDatabaseMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/ObjectAttributesMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/ObjectMethodDefaultParametersMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/ObjectMethodsMatcher.php
create mode 100644 vendor/psy/psysh/src/TabCompletion/Matcher/VariablesMatcher.php
create mode 100644 vendor/psy/psysh/src/Util/Docblock.php
create mode 100644 vendor/psy/psysh/src/Util/Json.php
create mode 100644 vendor/psy/psysh/src/Util/Mirror.php
create mode 100644 vendor/psy/psysh/src/Util/Str.php
create mode 100644 vendor/psy/psysh/src/VarDumper/Cloner.php
create mode 100644 vendor/psy/psysh/src/VarDumper/Dumper.php
create mode 100644 vendor/psy/psysh/src/VarDumper/Presenter.php
create mode 100644 vendor/psy/psysh/src/VarDumper/PresenterAware.php
create mode 100644 vendor/psy/psysh/src/VersionUpdater/Checker.php
create mode 100644 vendor/psy/psysh/src/VersionUpdater/GitHubChecker.php
create mode 100644 vendor/psy/psysh/src/VersionUpdater/IntervalChecker.php
create mode 100644 vendor/psy/psysh/src/VersionUpdater/NoopChecker.php
create mode 100644 vendor/psy/psysh/src/functions.php
create mode 100644 vendor/psy/psysh/test/ClassWithSecrets.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/AbstractClassPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/AssignThisVariablePassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/CallTimePassByReferencePassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/CalledClassPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/CodeCleanerTestCase.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/ExitPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/FinalClassPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/Fixtures/ClassWithCallStatic.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/Fixtures/ClassWithStatic.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/Fixtures/TraitWithStatic.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/FunctionContextPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/FunctionReturnInWriteContextPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/ImplicitReturnPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/InstanceOfPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/LeavePsyshAlonePassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/LegacyEmptyPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/ListPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/LoopContextPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/MagicConstantsPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/NamespacePassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/NoReturnValueTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/PassableByReferencePassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/RequirePassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/StrictTypesPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/UseStatementPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/ValidClassNamePassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/ValidConstantPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/ValidConstructorPassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleaner/ValidFunctionNamePassTest.php
create mode 100644 vendor/psy/psysh/test/CodeCleanerTest.php
create mode 100644 vendor/psy/psysh/test/Command/ExitCommandTest.php
create mode 100644 vendor/psy/psysh/test/Command/ThrowUpCommandTest.php
create mode 100644 vendor/psy/psysh/test/Command/TimeitCommand/TimeitVisitorTest.php
create mode 100644 vendor/psy/psysh/test/ConfigurationTest.php
create mode 100644 vendor/psy/psysh/test/ConsoleColorFactoryTest.php
create mode 100644 vendor/psy/psysh/test/ContextTest.php
create mode 100644 vendor/psy/psysh/test/Exception/BreakExceptionTest.php
create mode 100644 vendor/psy/psysh/test/Exception/ErrorExceptionTest.php
create mode 100644 vendor/psy/psysh/test/Exception/FatalErrorExceptionTest.php
create mode 100644 vendor/psy/psysh/test/Exception/ParseErrorExceptionTest.php
create mode 100644 vendor/psy/psysh/test/Exception/RuntimeExceptionTest.php
create mode 100644 vendor/psy/psysh/test/Exception/ThrowUpExceptionTest.php
create mode 100644 vendor/psy/psysh/test/Exception/TypeErrorExceptionTest.php
create mode 100644 vendor/psy/psysh/test/FakeShell.php
create mode 100644 vendor/psy/psysh/test/Formatter/CodeFormatterTest.php
create mode 100644 vendor/psy/psysh/test/Formatter/DocblockFormatterTest.php
create mode 100644 vendor/psy/psysh/test/Formatter/Fixtures/BoringTrait.php
create mode 100644 vendor/psy/psysh/test/Formatter/Fixtures/SomeClass.php
create mode 100644 vendor/psy/psysh/test/Formatter/SignatureFormatterTest.php
create mode 100644 vendor/psy/psysh/test/Input/CodeArgumentTest.php
create mode 100644 vendor/psy/psysh/test/Input/FilterOptionsTest.php
create mode 100644 vendor/psy/psysh/test/Input/ShellInputTest.php
create mode 100644 vendor/psy/psysh/test/ParserTestCase.php
create mode 100644 vendor/psy/psysh/test/Readline/GNUReadlineTest.php
create mode 100644 vendor/psy/psysh/test/Readline/HoaConsoleTest.php
create mode 100644 vendor/psy/psysh/test/Readline/LibeditTest.php
create mode 100644 vendor/psy/psysh/test/Readline/TransientTest.php
create mode 100644 vendor/psy/psysh/test/Reflection/ReflectionClassConstantTest.php
create mode 100644 vendor/psy/psysh/test/Reflection/ReflectionConstantBCTest.php
create mode 100644 vendor/psy/psysh/test/Reflection/ReflectionConstantTest.php
create mode 100644 vendor/psy/psysh/test/Reflection/ReflectionLanguageConstructParameterTest.php
create mode 100644 vendor/psy/psysh/test/Reflection/ReflectionLanguageConstructTest.php
create mode 100644 vendor/psy/psysh/test/ShellTest.php
create mode 100644 vendor/psy/psysh/test/Sudo/SudoVisitorTest.php
create mode 100644 vendor/psy/psysh/test/SudoTest.php
create mode 100644 vendor/psy/psysh/test/TabCompletion/AutoCompleterTest.php
create mode 100644 vendor/psy/psysh/test/TabCompletion/StaticSample.php
create mode 100644 vendor/psy/psysh/test/Util/DocblockTest.php
create mode 100644 vendor/psy/psysh/test/Util/MirrorTest.php
create mode 100644 vendor/psy/psysh/test/Util/StrTest.php
create mode 100644 vendor/psy/psysh/test/VersionUpdater/GitHubCheckerTest.php
create mode 100644 vendor/psy/psysh/test/VersionUpdater/NoopCheckerTest.php
create mode 100644 vendor/psy/psysh/test/fixtures/config.php
create mode 100644 vendor/psy/psysh/test/fixtures/default/.config/psysh/config.php
create mode 100644 vendor/psy/psysh/test/fixtures/default/.config/psysh/psysh_history
create mode 100644 vendor/psy/psysh/test/fixtures/default/.local/share/psysh/php_manual.sqlite
create mode 100644 vendor/psy/psysh/test/fixtures/empty.php
create mode 100644 vendor/psy/psysh/test/fixtures/legacy/.psysh/history
create mode 100644 vendor/psy/psysh/test/fixtures/legacy/.psysh/php_manual.sqlite
create mode 100644 vendor/psy/psysh/test/fixtures/legacy/.psysh/rc.php
create mode 100644 vendor/psy/psysh/test/fixtures/mixed/.psysh/config.php
create mode 100644 vendor/psy/psysh/test/fixtures/mixed/.psysh/psysh_history
create mode 100644 vendor/psy/psysh/test/fixtures/mixed/.psysh/rc.php
create mode 100644 vendor/psy/psysh/test/fixtures/project/.psysh.php
create mode 100644 vendor/psy/psysh/test/fixtures/unvis_fixtures.json
create mode 100644 vendor/psy/psysh/test/tools/gen_unvis_fixtures.py
create mode 100644 vendor/psy/psysh/test/tools/vis.py
create mode 100644 vendor/psy/psysh/vendor-bin/box/composer.json
create mode 100644 vendor/psy/psysh/vendor-bin/box/composer.lock
create mode 100644 vendor/ramsey/uuid/LICENSE
create mode 100644 vendor/ramsey/uuid/README.md
create mode 100644 vendor/ramsey/uuid/composer.json
create mode 100644 vendor/ramsey/uuid/src/BinaryUtils.php
create mode 100644 vendor/ramsey/uuid/src/Builder/DefaultUuidBuilder.php
create mode 100644 vendor/ramsey/uuid/src/Builder/DegradedUuidBuilder.php
create mode 100644 vendor/ramsey/uuid/src/Builder/UuidBuilderInterface.php
create mode 100644 vendor/ramsey/uuid/src/Codec/CodecInterface.php
create mode 100644 vendor/ramsey/uuid/src/Codec/GuidStringCodec.php
create mode 100644 vendor/ramsey/uuid/src/Codec/OrderedTimeCodec.php
create mode 100644 vendor/ramsey/uuid/src/Codec/StringCodec.php
create mode 100644 vendor/ramsey/uuid/src/Codec/TimestampFirstCombCodec.php
create mode 100644 vendor/ramsey/uuid/src/Codec/TimestampLastCombCodec.php
create mode 100644 vendor/ramsey/uuid/src/Converter/Number/BigNumberConverter.php
create mode 100644 vendor/ramsey/uuid/src/Converter/Number/DegradedNumberConverter.php
create mode 100644 vendor/ramsey/uuid/src/Converter/NumberConverterInterface.php
create mode 100644 vendor/ramsey/uuid/src/Converter/Time/BigNumberTimeConverter.php
create mode 100644 vendor/ramsey/uuid/src/Converter/Time/DegradedTimeConverter.php
create mode 100644 vendor/ramsey/uuid/src/Converter/Time/PhpTimeConverter.php
create mode 100644 vendor/ramsey/uuid/src/Converter/TimeConverterInterface.php
create mode 100644 vendor/ramsey/uuid/src/DegradedUuid.php
create mode 100644 vendor/ramsey/uuid/src/Exception/InvalidUuidStringException.php
create mode 100644 vendor/ramsey/uuid/src/Exception/UnsatisfiedDependencyException.php
create mode 100644 vendor/ramsey/uuid/src/Exception/UnsupportedOperationException.php
create mode 100644 vendor/ramsey/uuid/src/FeatureSet.php
create mode 100644 vendor/ramsey/uuid/src/Generator/CombGenerator.php
create mode 100644 vendor/ramsey/uuid/src/Generator/DefaultTimeGenerator.php
create mode 100644 vendor/ramsey/uuid/src/Generator/MtRandGenerator.php
create mode 100644 vendor/ramsey/uuid/src/Generator/OpenSslGenerator.php
create mode 100644 vendor/ramsey/uuid/src/Generator/PeclUuidRandomGenerator.php
create mode 100644 vendor/ramsey/uuid/src/Generator/PeclUuidTimeGenerator.php
create mode 100644 vendor/ramsey/uuid/src/Generator/RandomBytesGenerator.php
create mode 100644 vendor/ramsey/uuid/src/Generator/RandomGeneratorFactory.php
create mode 100644 vendor/ramsey/uuid/src/Generator/RandomGeneratorInterface.php
create mode 100644 vendor/ramsey/uuid/src/Generator/RandomLibAdapter.php
create mode 100644 vendor/ramsey/uuid/src/Generator/SodiumRandomGenerator.php
create mode 100644 vendor/ramsey/uuid/src/Generator/TimeGeneratorFactory.php
create mode 100644 vendor/ramsey/uuid/src/Generator/TimeGeneratorInterface.php
create mode 100644 vendor/ramsey/uuid/src/Provider/Node/FallbackNodeProvider.php
create mode 100644 vendor/ramsey/uuid/src/Provider/Node/RandomNodeProvider.php
create mode 100644 vendor/ramsey/uuid/src/Provider/Node/SystemNodeProvider.php
create mode 100644 vendor/ramsey/uuid/src/Provider/NodeProviderInterface.php
create mode 100644 vendor/ramsey/uuid/src/Provider/Time/FixedTimeProvider.php
create mode 100644 vendor/ramsey/uuid/src/Provider/Time/SystemTimeProvider.php
create mode 100644 vendor/ramsey/uuid/src/Provider/TimeProviderInterface.php
create mode 100644 vendor/ramsey/uuid/src/Uuid.php
create mode 100644 vendor/ramsey/uuid/src/UuidFactory.php
create mode 100644 vendor/ramsey/uuid/src/UuidFactoryInterface.php
create mode 100644 vendor/ramsey/uuid/src/UuidInterface.php
create mode 100644 vendor/ramsey/uuid/src/functions.php
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/.gitignore
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/.php_cs
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/.travis.yml
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/ChangeLog.md
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/LICENSE
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/README.md
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/build.xml
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/composer.json
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/phpunit.xml
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/src/Wizard.php
create mode 100644 vendor/sebastian/code-unit-reverse-lookup/tests/WizardTest.php
create mode 100644 vendor/sebastian/comparator/.gitignore
create mode 100644 vendor/sebastian/comparator/.travis.yml
create mode 100644 vendor/sebastian/comparator/LICENSE
create mode 100644 vendor/sebastian/comparator/README.md
create mode 100644 vendor/sebastian/comparator/build.xml
create mode 100644 vendor/sebastian/comparator/build/travis-ci.xml
create mode 100644 vendor/sebastian/comparator/composer.json
create mode 100644 vendor/sebastian/comparator/phpunit.xml.dist
create mode 100644 vendor/sebastian/comparator/src/ArrayComparator.php
create mode 100644 vendor/sebastian/comparator/src/Comparator.php
create mode 100644 vendor/sebastian/comparator/src/ComparisonFailure.php
create mode 100644 vendor/sebastian/comparator/src/DOMNodeComparator.php
create mode 100644 vendor/sebastian/comparator/src/DateTimeComparator.php
create mode 100644 vendor/sebastian/comparator/src/DoubleComparator.php
create mode 100644 vendor/sebastian/comparator/src/ExceptionComparator.php
create mode 100644 vendor/sebastian/comparator/src/Factory.php
create mode 100644 vendor/sebastian/comparator/src/MockObjectComparator.php
create mode 100644 vendor/sebastian/comparator/src/NumericComparator.php
create mode 100644 vendor/sebastian/comparator/src/ObjectComparator.php
create mode 100644 vendor/sebastian/comparator/src/ResourceComparator.php
create mode 100644 vendor/sebastian/comparator/src/ScalarComparator.php
create mode 100644 vendor/sebastian/comparator/src/SplObjectStorageComparator.php
create mode 100644 vendor/sebastian/comparator/src/TypeComparator.php
create mode 100644 vendor/sebastian/comparator/tests/ArrayComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/DOMNodeComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/DateTimeComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/DoubleComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/ExceptionComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/FactoryTest.php
create mode 100644 vendor/sebastian/comparator/tests/MockObjectComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/NumericComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/ObjectComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/ResourceComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/ScalarComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/SplObjectStorageComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/TypeComparatorTest.php
create mode 100644 vendor/sebastian/comparator/tests/_files/Author.php
create mode 100644 vendor/sebastian/comparator/tests/_files/Book.php
create mode 100644 vendor/sebastian/comparator/tests/_files/ClassWithToString.php
create mode 100644 vendor/sebastian/comparator/tests/_files/SampleClass.php
create mode 100644 vendor/sebastian/comparator/tests/_files/Struct.php
create mode 100644 vendor/sebastian/comparator/tests/_files/TestClass.php
create mode 100644 vendor/sebastian/comparator/tests/_files/TestClassComparator.php
create mode 100644 vendor/sebastian/comparator/tests/autoload.php
create mode 100644 vendor/sebastian/comparator/tests/bootstrap.php
create mode 100644 vendor/sebastian/diff/.gitignore
create mode 100644 vendor/sebastian/diff/.php_cs
create mode 100644 vendor/sebastian/diff/.travis.yml
create mode 100644 vendor/sebastian/diff/LICENSE
create mode 100644 vendor/sebastian/diff/README.md
create mode 100644 vendor/sebastian/diff/build.xml
create mode 100644 vendor/sebastian/diff/composer.json
create mode 100644 vendor/sebastian/diff/phpunit.xml
create mode 100644 vendor/sebastian/diff/src/Chunk.php
create mode 100644 vendor/sebastian/diff/src/Diff.php
create mode 100644 vendor/sebastian/diff/src/Differ.php
create mode 100644 vendor/sebastian/diff/src/LCS/LongestCommonSubsequence.php
create mode 100644 vendor/sebastian/diff/src/LCS/MemoryEfficientLongestCommonSubsequenceImplementation.php
create mode 100644 vendor/sebastian/diff/src/LCS/TimeEfficientLongestCommonSubsequenceImplementation.php
create mode 100644 vendor/sebastian/diff/src/Line.php
create mode 100644 vendor/sebastian/diff/src/Parser.php
create mode 100644 vendor/sebastian/diff/tests/ChunkTest.php
create mode 100644 vendor/sebastian/diff/tests/DiffTest.php
create mode 100644 vendor/sebastian/diff/tests/DifferTest.php
create mode 100644 vendor/sebastian/diff/tests/LCS/LongestCommonSubsequenceTest.php
create mode 100644 vendor/sebastian/diff/tests/LCS/MemoryEfficientImplementationTest.php
create mode 100644 vendor/sebastian/diff/tests/LCS/TimeEfficientImplementationTest.php
create mode 100644 vendor/sebastian/diff/tests/LineTest.php
create mode 100644 vendor/sebastian/diff/tests/ParserTest.php
create mode 100644 vendor/sebastian/diff/tests/fixtures/patch.txt
create mode 100644 vendor/sebastian/diff/tests/fixtures/patch2.txt
create mode 100644 vendor/sebastian/environment/.gitignore
create mode 100644 vendor/sebastian/environment/.travis.yml
create mode 100644 vendor/sebastian/environment/LICENSE
create mode 100644 vendor/sebastian/environment/README.md
create mode 100644 vendor/sebastian/environment/build.xml
create mode 100644 vendor/sebastian/environment/composer.json
create mode 100644 vendor/sebastian/environment/phpunit.xml
create mode 100644 vendor/sebastian/environment/src/Console.php
create mode 100644 vendor/sebastian/environment/src/Runtime.php
create mode 100644 vendor/sebastian/environment/tests/ConsoleTest.php
create mode 100644 vendor/sebastian/environment/tests/RuntimeTest.php
create mode 100644 vendor/sebastian/exporter/.gitignore
create mode 100644 vendor/sebastian/exporter/.travis.yml
create mode 100644 vendor/sebastian/exporter/LICENSE
create mode 100644 vendor/sebastian/exporter/README.md
create mode 100644 vendor/sebastian/exporter/build.xml
create mode 100644 vendor/sebastian/exporter/composer.json
create mode 100644 vendor/sebastian/exporter/phpunit.xml.dist
create mode 100644 vendor/sebastian/exporter/src/Exporter.php
create mode 100644 vendor/sebastian/exporter/tests/ExporterTest.php
create mode 100644 vendor/sebastian/global-state/.gitignore
create mode 100644 vendor/sebastian/global-state/.travis.yml
create mode 100644 vendor/sebastian/global-state/LICENSE
create mode 100644 vendor/sebastian/global-state/README.md
create mode 100644 vendor/sebastian/global-state/build.xml
create mode 100644 vendor/sebastian/global-state/composer.json
create mode 100644 vendor/sebastian/global-state/phpunit.xml.dist
create mode 100644 vendor/sebastian/global-state/src/Blacklist.php
create mode 100644 vendor/sebastian/global-state/src/CodeExporter.php
create mode 100644 vendor/sebastian/global-state/src/Exception.php
create mode 100644 vendor/sebastian/global-state/src/Restorer.php
create mode 100644 vendor/sebastian/global-state/src/RuntimeException.php
create mode 100644 vendor/sebastian/global-state/src/Snapshot.php
create mode 100644 vendor/sebastian/global-state/tests/BlacklistTest.php
create mode 100644 vendor/sebastian/global-state/tests/SnapshotTest.php
create mode 100644 vendor/sebastian/global-state/tests/_fixture/BlacklistedChildClass.php
create mode 100644 vendor/sebastian/global-state/tests/_fixture/BlacklistedClass.php
create mode 100644 vendor/sebastian/global-state/tests/_fixture/BlacklistedImplementor.php
create mode 100644 vendor/sebastian/global-state/tests/_fixture/BlacklistedInterface.php
create mode 100644 vendor/sebastian/global-state/tests/_fixture/SnapshotClass.php
create mode 100644 vendor/sebastian/global-state/tests/_fixture/SnapshotDomDocument.php
create mode 100644 vendor/sebastian/global-state/tests/_fixture/SnapshotFunctions.php
create mode 100644 vendor/sebastian/global-state/tests/_fixture/SnapshotTrait.php
create mode 100644 vendor/sebastian/object-enumerator/.gitignore
create mode 100644 vendor/sebastian/object-enumerator/.php_cs
create mode 100644 vendor/sebastian/object-enumerator/.travis.yml
create mode 100644 vendor/sebastian/object-enumerator/ChangeLog.md
create mode 100644 vendor/sebastian/object-enumerator/LICENSE
create mode 100644 vendor/sebastian/object-enumerator/README.md
create mode 100644 vendor/sebastian/object-enumerator/build.xml
create mode 100644 vendor/sebastian/object-enumerator/composer.json
create mode 100644 vendor/sebastian/object-enumerator/phpunit.xml
create mode 100644 vendor/sebastian/object-enumerator/src/Enumerator.php
create mode 100644 vendor/sebastian/object-enumerator/src/Exception.php
create mode 100644 vendor/sebastian/object-enumerator/src/InvalidArgumentException.php
create mode 100644 vendor/sebastian/object-enumerator/tests/EnumeratorTest.php
create mode 100644 vendor/sebastian/object-enumerator/tests/Fixtures/ExceptionThrower.php
create mode 100644 vendor/sebastian/recursion-context/.gitignore
create mode 100644 vendor/sebastian/recursion-context/.travis.yml
create mode 100644 vendor/sebastian/recursion-context/LICENSE
create mode 100644 vendor/sebastian/recursion-context/README.md
create mode 100644 vendor/sebastian/recursion-context/build.xml
create mode 100644 vendor/sebastian/recursion-context/composer.json
create mode 100644 vendor/sebastian/recursion-context/phpunit.xml.dist
create mode 100644 vendor/sebastian/recursion-context/src/Context.php
create mode 100644 vendor/sebastian/recursion-context/src/Exception.php
create mode 100644 vendor/sebastian/recursion-context/src/InvalidArgumentException.php
create mode 100644 vendor/sebastian/recursion-context/tests/ContextTest.php
create mode 100644 vendor/sebastian/resource-operations/.gitignore
create mode 100644 vendor/sebastian/resource-operations/LICENSE
create mode 100644 vendor/sebastian/resource-operations/README.md
create mode 100644 vendor/sebastian/resource-operations/build.xml
create mode 100644 vendor/sebastian/resource-operations/build/generate.php
create mode 100644 vendor/sebastian/resource-operations/composer.json
create mode 100644 vendor/sebastian/resource-operations/src/ResourceOperations.php
create mode 100644 vendor/sebastian/version/.gitattributes
create mode 100644 vendor/sebastian/version/.gitignore
create mode 100644 vendor/sebastian/version/.php_cs
create mode 100644 vendor/sebastian/version/LICENSE
create mode 100644 vendor/sebastian/version/README.md
create mode 100644 vendor/sebastian/version/composer.json
create mode 100644 vendor/sebastian/version/src/Version.php
create mode 100644 vendor/swiftmailer/swiftmailer/.gitattributes
create mode 100644 vendor/swiftmailer/swiftmailer/.github/ISSUE_TEMPLATE.md
create mode 100644 vendor/swiftmailer/swiftmailer/.github/PULL_REQUEST_TEMPLATE.md
create mode 100644 vendor/swiftmailer/swiftmailer/.gitignore
create mode 100644 vendor/swiftmailer/swiftmailer/.php_cs.dist
create mode 100644 vendor/swiftmailer/swiftmailer/.travis.yml
create mode 100644 vendor/swiftmailer/swiftmailer/CHANGES
create mode 100644 vendor/swiftmailer/swiftmailer/LICENSE
create mode 100644 vendor/swiftmailer/swiftmailer/README
create mode 100644 vendor/swiftmailer/swiftmailer/VERSION
create mode 100644 vendor/swiftmailer/swiftmailer/composer.json
create mode 100644 vendor/swiftmailer/swiftmailer/doc/headers.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/help-resources.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/including-the-files.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/index.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/installing.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/introduction.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/japanese.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/messages.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/overview.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/plugins.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/sending.rst
create mode 100644 vendor/swiftmailer/swiftmailer/doc/uml/Encoders.graffle
create mode 100644 vendor/swiftmailer/swiftmailer/doc/uml/Mime.graffle
create mode 100644 vendor/swiftmailer/swiftmailer/doc/uml/Transports.graffle
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Attachment.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/ByteStream/AbstractFilterableInputStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/ByteStream/ArrayByteStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/ByteStream/FileByteStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/ByteStream/TemporaryFileByteStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/CharacterReader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/CharacterReader/GenericFixedWidthReader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/CharacterReader/UsAsciiReader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/CharacterReader/Utf8Reader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/CharacterReaderFactory.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/CharacterReaderFactory/SimpleCharacterReaderFactory.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/CharacterStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/CharacterStream/ArrayCharacterStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/CharacterStream/NgCharacterStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/ConfigurableSpool.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/DependencyContainer.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/DependencyException.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/EmbeddedFile.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Encoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Encoder/Base64Encoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Encoder/QpEncoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Encoder/Rfc2231Encoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Encoding.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/CommandEvent.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/CommandListener.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/Event.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/EventDispatcher.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/EventListener.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/EventObject.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/ResponseEvent.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/ResponseListener.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/SendEvent.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/SendListener.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/SimpleEventDispatcher.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/TransportChangeEvent.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/TransportChangeListener.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/TransportExceptionEvent.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Events/TransportExceptionListener.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/FailoverTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/FileSpool.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/FileStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Filterable.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Image.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/InputByteStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/IoException.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/KeyCache.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/KeyCache/ArrayKeyCache.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/KeyCache/DiskKeyCache.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/KeyCache/KeyCacheInputStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/KeyCache/NullKeyCache.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/KeyCache/SimpleKeyCacheInputStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/LoadBalancedTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/MailTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mailer.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mailer/ArrayRecipientIterator.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mailer/RecipientIterator.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/MemorySpool.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Message.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Attachment.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/CharsetObserver.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/ContentEncoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/ContentEncoder/Base64ContentEncoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/ContentEncoder/NativeQpContentEncoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/ContentEncoder/PlainContentEncoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/ContentEncoder/QpContentEncoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/ContentEncoder/QpContentEncoderProxy.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/ContentEncoder/RawContentEncoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/EmbeddedFile.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/EncodingObserver.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Grammar.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Header.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/HeaderEncoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/HeaderEncoder/Base64HeaderEncoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/HeaderEncoder/QpHeaderEncoder.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/HeaderFactory.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/HeaderSet.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Headers/AbstractHeader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Headers/DateHeader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Headers/IdentificationHeader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Headers/MailboxHeader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Headers/OpenDKIMHeader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Headers/ParameterizedHeader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Headers/PathHeader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Headers/UnstructuredHeader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/Message.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/MimeEntity.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/MimePart.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/ParameterizedHeader.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/SimpleHeaderFactory.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/SimpleHeaderSet.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/SimpleMessage.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Mime/SimpleMimeEntity.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/MimePart.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/NullTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/OutputByteStream.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/AntiFloodPlugin.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/BandwidthMonitorPlugin.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Decorator/Replacements.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/DecoratorPlugin.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/ImpersonatePlugin.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Logger.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/LoggerPlugin.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Loggers/ArrayLogger.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Loggers/EchoLogger.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/MessageLogger.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Pop/Pop3Connection.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Pop/Pop3Exception.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/PopBeforeSmtpPlugin.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/RedirectingPlugin.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Reporter.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/ReporterPlugin.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Reporters/HitReporter.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Reporters/HtmlReporter.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Sleeper.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/ThrottlerPlugin.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Plugins/Timer.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Preferences.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/ReplacementFilterFactory.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/RfcComplianceException.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/SendmailTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/SignedMessage.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Signer.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Signers/BodySigner.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Signers/DKIMSigner.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Signers/DomainKeySigner.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Signers/HeaderSigner.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Signers/OpenDKIMSigner.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Signers/SMimeSigner.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/SmtpTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Spool.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/SpoolTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/StreamFilter.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/StreamFilters/ByteArrayReplacementFilter.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/StreamFilters/StringReplacementFilter.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/StreamFilters/StringReplacementFilterFactory.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/SwiftException.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/AbstractSmtpTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/Esmtp/Auth/CramMd5Authenticator.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/Esmtp/Auth/LoginAuthenticator.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/Esmtp/Auth/NTLMAuthenticator.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/Esmtp/Auth/PlainAuthenticator.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/Esmtp/Auth/XOAuth2Authenticator.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/Esmtp/AuthHandler.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/Esmtp/Authenticator.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/EsmtpHandler.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/EsmtpTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/FailoverTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/IoBuffer.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/LoadBalancedTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/MailInvoker.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/MailTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/NullTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/SendmailTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/SimpleMailInvoker.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/SmtpAgent.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/SpoolTransport.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Transport/StreamBuffer.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/TransportException.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/classes/Swift/Validate.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/dependency_maps/cache_deps.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/dependency_maps/message_deps.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/dependency_maps/mime_deps.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/dependency_maps/transport_deps.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/mime_types.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/preferences.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/swift_init.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/swift_required.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/swift_required_pear.php
create mode 100644 vendor/swiftmailer/swiftmailer/lib/swiftmailer_generate_mimes_config.php
create mode 100644 vendor/swiftmailer/swiftmailer/phpunit.xml.dist
create mode 100644 vendor/swiftmailer/swiftmailer/tests/IdenticalBinaryConstraint.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/StreamCollector.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/SwiftMailerSmokeTestCase.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/SwiftMailerTestCase.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/charsets/iso-2022-jp/one.txt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/charsets/iso-8859-1/one.txt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/charsets/utf-8/one.txt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/charsets/utf-8/three.txt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/charsets/utf-8/two.txt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/dkim/dkim.test.priv
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/dkim/dkim.test.pub
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/files/data.txt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/files/swiftmailer.png
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/files/textfile.zip
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/CA.srl
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/ca.crt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/ca.key
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/create-cert.sh
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/encrypt.crt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/encrypt.key
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/encrypt2.crt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/encrypt2.key
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/intermediate.crt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/intermediate.key
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/sign.crt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/sign.key
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/sign2.crt
create mode 100644 vendor/swiftmailer/swiftmailer/tests/_samples/smime/sign2.key
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance.conf.php.default
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/AttachmentAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/ByteStream/FileByteStreamAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/CharacterReaderFactory/SimpleCharacterReaderFactoryAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/DependencyContainerAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/EmbeddedFileAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Encoder/Base64EncoderAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Encoder/QpEncoderAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Encoder/Rfc2231EncoderAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/EncodingAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/KeyCache/ArrayKeyCacheAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/KeyCache/DiskKeyCacheAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/MessageAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Mime/AttachmentAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Mime/ContentEncoder/Base64ContentEncoderAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Mime/ContentEncoder/NativeQpContentEncoderAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Mime/ContentEncoder/PlainContentEncoderAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Mime/ContentEncoder/QpContentEncoderAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Mime/EmbeddedFileAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Mime/HeaderEncoder/Base64HeaderEncoderAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Mime/MimePartAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Mime/SimpleMessageAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/MimePartAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Transport/StreamBuffer/AbstractStreamBufferAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Transport/StreamBuffer/BasicSocketAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Transport/StreamBuffer/ProcessAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Transport/StreamBuffer/SocketTimeoutTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Transport/StreamBuffer/SslSocketAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/acceptance/Swift/Transport/StreamBuffer/TlsSocketAcceptanceTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bootstrap.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug111Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug118Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug206Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug274Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug34Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug35Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug38Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug518Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug51Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug534Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug650Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug71Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/Bug76Test.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/bug/Swift/BugFileByteStreamConsecutiveReadCallsTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/fixtures/MimeEntityFixture.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/smoke.conf.php.default
create mode 100644 vendor/swiftmailer/swiftmailer/tests/smoke/Swift/Smoke/AttachmentSmokeTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/smoke/Swift/Smoke/BasicSmokeTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/smoke/Swift/Smoke/HtmlWithAttachmentSmokeTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/smoke/Swift/Smoke/InternationalSmokeTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/ByteStream/ArrayByteStreamTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/CharacterReader/GenericFixedWidthReaderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/CharacterReader/UsAsciiReaderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/CharacterReader/Utf8ReaderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/CharacterStream/ArrayCharacterStreamTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/DependencyContainerTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Encoder/Base64EncoderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Encoder/QpEncoderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Encoder/Rfc2231EncoderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Events/CommandEventTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Events/EventObjectTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Events/ResponseEventTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Events/SendEventTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Events/SimpleEventDispatcherTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Events/TransportChangeEventTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Events/TransportExceptionEventTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/KeyCache/ArrayKeyCacheTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/KeyCache/SimpleKeyCacheInputStreamTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mailer/ArrayRecipientIteratorTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/MailerTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/MessageTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/AbstractMimeEntityTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/AttachmentTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/ContentEncoder/Base64ContentEncoderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/ContentEncoder/PlainContentEncoderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/ContentEncoder/QpContentEncoderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/EmbeddedFileTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/HeaderEncoder/Base64HeaderEncoderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/HeaderEncoder/QpHeaderEncoderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/Headers/DateHeaderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/Headers/IdentificationHeaderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/Headers/MailboxHeaderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/Headers/ParameterizedHeaderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/Headers/PathHeaderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/Headers/UnstructuredHeaderTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/MimePartTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/SimpleHeaderFactoryTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/SimpleHeaderSetTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/SimpleMessageTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Mime/SimpleMimeEntityTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/AntiFloodPluginTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/BandwidthMonitorPluginTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/DecoratorPluginTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/LoggerPluginTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/Loggers/ArrayLoggerTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/Loggers/EchoLoggerTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/PopBeforeSmtpPluginTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/RedirectingPluginTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/ReporterPluginTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/Reporters/HitReporterTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/Reporters/HtmlReporterTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Plugins/ThrottlerPluginTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Signers/DKIMSignerTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Signers/OpenDKIMSignerTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Signers/SMimeSignerTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/StreamFilters/ByteArrayReplacementFilterTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/StreamFilters/StringReplacementFilterFactoryTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/StreamFilters/StringReplacementFilterTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/AbstractSmtpEventSupportTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/AbstractSmtpTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/Esmtp/Auth/CramMd5AuthenticatorTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/Esmtp/Auth/LoginAuthenticatorTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/Esmtp/Auth/NTLMAuthenticatorTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/Esmtp/Auth/PlainAuthenticatorTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/Esmtp/AuthHandlerTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/EsmtpTransport/ExtensionSupportTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/EsmtpTransportTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/FailoverTransportTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/LoadBalancedTransportTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/MailTransportTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/SendmailTransportTest.php
create mode 100644 vendor/swiftmailer/swiftmailer/tests/unit/Swift/Transport/StreamBufferTest.php
create mode 100644 vendor/symfony/console/.gitignore
create mode 100644 vendor/symfony/console/Application.php
create mode 100644 vendor/symfony/console/CHANGELOG.md
create mode 100644 vendor/symfony/console/Command/Command.php
create mode 100644 vendor/symfony/console/Command/HelpCommand.php
create mode 100644 vendor/symfony/console/Command/ListCommand.php
create mode 100644 vendor/symfony/console/Command/LockableTrait.php
create mode 100644 vendor/symfony/console/CommandLoader/CommandLoaderInterface.php
create mode 100644 vendor/symfony/console/CommandLoader/ContainerCommandLoader.php
create mode 100644 vendor/symfony/console/CommandLoader/FactoryCommandLoader.php
create mode 100644 vendor/symfony/console/ConsoleEvents.php
create mode 100644 vendor/symfony/console/DependencyInjection/AddConsoleCommandPass.php
create mode 100644 vendor/symfony/console/Descriptor/ApplicationDescription.php
create mode 100644 vendor/symfony/console/Descriptor/Descriptor.php
create mode 100644 vendor/symfony/console/Descriptor/DescriptorInterface.php
create mode 100644 vendor/symfony/console/Descriptor/JsonDescriptor.php
create mode 100644 vendor/symfony/console/Descriptor/MarkdownDescriptor.php
create mode 100644 vendor/symfony/console/Descriptor/TextDescriptor.php
create mode 100644 vendor/symfony/console/Descriptor/XmlDescriptor.php
create mode 100644 vendor/symfony/console/Event/ConsoleCommandEvent.php
create mode 100644 vendor/symfony/console/Event/ConsoleErrorEvent.php
create mode 100644 vendor/symfony/console/Event/ConsoleEvent.php
create mode 100644 vendor/symfony/console/Event/ConsoleExceptionEvent.php
create mode 100644 vendor/symfony/console/Event/ConsoleTerminateEvent.php
create mode 100644 vendor/symfony/console/EventListener/ErrorListener.php
create mode 100644 vendor/symfony/console/Exception/CommandNotFoundException.php
create mode 100644 vendor/symfony/console/Exception/ExceptionInterface.php
create mode 100644 vendor/symfony/console/Exception/InvalidArgumentException.php
create mode 100644 vendor/symfony/console/Exception/InvalidOptionException.php
create mode 100644 vendor/symfony/console/Exception/LogicException.php
create mode 100644 vendor/symfony/console/Exception/RuntimeException.php
create mode 100644 vendor/symfony/console/Formatter/OutputFormatter.php
create mode 100644 vendor/symfony/console/Formatter/OutputFormatterInterface.php
create mode 100644 vendor/symfony/console/Formatter/OutputFormatterStyle.php
create mode 100644 vendor/symfony/console/Formatter/OutputFormatterStyleInterface.php
create mode 100644 vendor/symfony/console/Formatter/OutputFormatterStyleStack.php
create mode 100644 vendor/symfony/console/Helper/DebugFormatterHelper.php
create mode 100644 vendor/symfony/console/Helper/DescriptorHelper.php
create mode 100644 vendor/symfony/console/Helper/FormatterHelper.php
create mode 100644 vendor/symfony/console/Helper/Helper.php
create mode 100644 vendor/symfony/console/Helper/HelperInterface.php
create mode 100644 vendor/symfony/console/Helper/HelperSet.php
create mode 100644 vendor/symfony/console/Helper/InputAwareHelper.php
create mode 100644 vendor/symfony/console/Helper/ProcessHelper.php
create mode 100644 vendor/symfony/console/Helper/ProgressBar.php
create mode 100644 vendor/symfony/console/Helper/ProgressIndicator.php
create mode 100644 vendor/symfony/console/Helper/QuestionHelper.php
create mode 100644 vendor/symfony/console/Helper/SymfonyQuestionHelper.php
create mode 100644 vendor/symfony/console/Helper/Table.php
create mode 100644 vendor/symfony/console/Helper/TableCell.php
create mode 100644 vendor/symfony/console/Helper/TableSeparator.php
create mode 100644 vendor/symfony/console/Helper/TableStyle.php
create mode 100644 vendor/symfony/console/Input/ArgvInput.php
create mode 100644 vendor/symfony/console/Input/ArrayInput.php
create mode 100644 vendor/symfony/console/Input/Input.php
create mode 100644 vendor/symfony/console/Input/InputArgument.php
create mode 100644 vendor/symfony/console/Input/InputAwareInterface.php
create mode 100644 vendor/symfony/console/Input/InputDefinition.php
create mode 100644 vendor/symfony/console/Input/InputInterface.php
create mode 100644 vendor/symfony/console/Input/InputOption.php
create mode 100644 vendor/symfony/console/Input/StreamableInputInterface.php
create mode 100644 vendor/symfony/console/Input/StringInput.php
create mode 100644 vendor/symfony/console/LICENSE
create mode 100644 vendor/symfony/console/Logger/ConsoleLogger.php
create mode 100644 vendor/symfony/console/Output/BufferedOutput.php
create mode 100644 vendor/symfony/console/Output/ConsoleOutput.php
create mode 100644 vendor/symfony/console/Output/ConsoleOutputInterface.php
create mode 100644 vendor/symfony/console/Output/NullOutput.php
create mode 100644 vendor/symfony/console/Output/Output.php
create mode 100644 vendor/symfony/console/Output/OutputInterface.php
create mode 100644 vendor/symfony/console/Output/StreamOutput.php
create mode 100644 vendor/symfony/console/Question/ChoiceQuestion.php
create mode 100644 vendor/symfony/console/Question/ConfirmationQuestion.php
create mode 100644 vendor/symfony/console/Question/Question.php
create mode 100644 vendor/symfony/console/README.md
create mode 100644 vendor/symfony/console/Resources/bin/hiddeninput.exe
create mode 100644 vendor/symfony/console/Style/OutputStyle.php
create mode 100644 vendor/symfony/console/Style/StyleInterface.php
create mode 100644 vendor/symfony/console/Style/SymfonyStyle.php
create mode 100644 vendor/symfony/console/Terminal.php
create mode 100644 vendor/symfony/console/Tester/ApplicationTester.php
create mode 100644 vendor/symfony/console/Tester/CommandTester.php
create mode 100644 vendor/symfony/console/Tests/ApplicationTest.php
create mode 100644 vendor/symfony/console/Tests/Command/CommandTest.php
create mode 100644 vendor/symfony/console/Tests/Command/HelpCommandTest.php
create mode 100644 vendor/symfony/console/Tests/Command/ListCommandTest.php
create mode 100644 vendor/symfony/console/Tests/Command/LockableTraitTest.php
create mode 100644 vendor/symfony/console/Tests/CommandLoader/ContainerCommandLoaderTest.php
create mode 100644 vendor/symfony/console/Tests/CommandLoader/FactoryCommandLoaderTest.php
create mode 100644 vendor/symfony/console/Tests/DependencyInjection/AddConsoleCommandPassTest.php
create mode 100644 vendor/symfony/console/Tests/Descriptor/AbstractDescriptorTest.php
create mode 100644 vendor/symfony/console/Tests/Descriptor/ApplicationDescriptionTest.php
create mode 100644 vendor/symfony/console/Tests/Descriptor/JsonDescriptorTest.php
create mode 100644 vendor/symfony/console/Tests/Descriptor/MarkdownDescriptorTest.php
create mode 100644 vendor/symfony/console/Tests/Descriptor/ObjectsProvider.php
create mode 100644 vendor/symfony/console/Tests/Descriptor/TextDescriptorTest.php
create mode 100644 vendor/symfony/console/Tests/Descriptor/XmlDescriptorTest.php
create mode 100644 vendor/symfony/console/Tests/EventListener/ErrorListenerTest.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/BarBucCommand.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/DescriptorApplication1.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/DescriptorApplication2.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/DescriptorApplicationMbString.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/DescriptorCommand1.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/DescriptorCommand2.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/DescriptorCommand3.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/DescriptorCommand4.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/DescriptorCommandMbString.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/DummyOutput.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Foo1Command.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Foo2Command.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Foo3Command.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Foo4Command.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Foo5Command.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Foo6Command.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/FooCommand.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/FooHiddenCommand.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/FooLock2Command.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/FooLockCommand.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/FooOptCommand.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/FooSameCaseLowercaseCommand.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/FooSameCaseUppercaseCommand.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/FooSubnamespaced1Command.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/FooSubnamespaced2Command.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/FoobarCommand.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_0.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_1.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_10.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_11.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_12.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_13.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_14.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_15.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_16.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_17.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_2.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_3.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_4.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_5.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_6.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_7.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_8.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/command_9.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/command/interactive_command_1.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/interactive_output_1.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_0.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_1.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_10.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_11.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_12.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_13.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_14.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_15.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_16.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_17.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_2.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_3.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_4.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_5.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_6.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_7.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_8.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/Style/SymfonyStyle/output/output_9.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/TestAmbiguousCommandRegistering.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/TestAmbiguousCommandRegistering2.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/TestCommand.php
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_1.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_1.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_1.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_1.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_2.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_2.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_2.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_2.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_filtered_namespace.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_gethelp.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_mbstring.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_mbstring.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_renderexception1.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_renderexception2.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_renderexception3.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_renderexception3decorated.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_renderexception4.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_renderexception_doublewidth1.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_renderexception_doublewidth1decorated.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_renderexception_doublewidth2.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_renderexception_escapeslines.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_renderexception_linebreaks.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_run1.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_run2.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_run3.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/application_run4.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/command_1.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/command_1.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/command_1.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/command_1.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/command_2.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/command_2.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/command_2.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/command_2.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/command_mbstring.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/command_mbstring.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_1.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_1.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_1.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_1.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_2.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_2.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_2.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_2.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_3.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_3.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_3.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_3.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_4.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_4.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_4.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_4.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_with_default_inf_value.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_with_default_inf_value.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_with_default_inf_value.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_with_default_inf_value.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_with_style.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_with_style.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_with_style.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_argument_with_style.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_1.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_1.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_1.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_1.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_2.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_2.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_2.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_2.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_3.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_3.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_3.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_3.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_4.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_4.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_4.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_definition_4.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_1.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_1.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_1.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_1.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_2.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_2.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_2.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_2.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_3.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_3.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_3.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_3.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_4.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_4.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_4.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_4.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_5.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_5.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_5.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_5.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_6.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_6.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_6.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_6.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_default_inf_value.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_default_inf_value.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_default_inf_value.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_default_inf_value.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_style.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_style.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_style.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_style.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_style_array.json
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_style_array.md
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_style_array.txt
create mode 100644 vendor/symfony/console/Tests/Fixtures/input_option_with_style_array.xml
create mode 100644 vendor/symfony/console/Tests/Fixtures/stream_output_file.txt
create mode 100644 vendor/symfony/console/Tests/Formatter/OutputFormatterStyleStackTest.php
create mode 100644 vendor/symfony/console/Tests/Formatter/OutputFormatterStyleTest.php
create mode 100644 vendor/symfony/console/Tests/Formatter/OutputFormatterTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/AbstractQuestionHelperTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/FormatterHelperTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/HelperSetTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/HelperTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/ProcessHelperTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/ProgressBarTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/ProgressIndicatorTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/QuestionHelperTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/SymfonyQuestionHelperTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/TableStyleTest.php
create mode 100644 vendor/symfony/console/Tests/Helper/TableTest.php
create mode 100644 vendor/symfony/console/Tests/Input/ArgvInputTest.php
create mode 100644 vendor/symfony/console/Tests/Input/ArrayInputTest.php
create mode 100644 vendor/symfony/console/Tests/Input/InputArgumentTest.php
create mode 100644 vendor/symfony/console/Tests/Input/InputDefinitionTest.php
create mode 100644 vendor/symfony/console/Tests/Input/InputOptionTest.php
create mode 100644 vendor/symfony/console/Tests/Input/InputTest.php
create mode 100644 vendor/symfony/console/Tests/Input/StringInputTest.php
create mode 100644 vendor/symfony/console/Tests/Logger/ConsoleLoggerTest.php
create mode 100644 vendor/symfony/console/Tests/Output/ConsoleOutputTest.php
create mode 100644 vendor/symfony/console/Tests/Output/NullOutputTest.php
create mode 100644 vendor/symfony/console/Tests/Output/OutputTest.php
create mode 100644 vendor/symfony/console/Tests/Output/StreamOutputTest.php
create mode 100644 vendor/symfony/console/Tests/Question/ChoiceQuestionTest.php
create mode 100644 vendor/symfony/console/Tests/Question/ConfirmationQuestionTest.php
create mode 100644 vendor/symfony/console/Tests/Style/SymfonyStyleTest.php
create mode 100644 vendor/symfony/console/Tests/TerminalTest.php
create mode 100644 vendor/symfony/console/Tests/Tester/ApplicationTesterTest.php
create mode 100644 vendor/symfony/console/Tests/Tester/CommandTesterTest.php
create mode 100644 vendor/symfony/console/composer.json
create mode 100644 vendor/symfony/console/phpunit.xml.dist
create mode 100644 vendor/symfony/css-selector/.gitignore
create mode 100644 vendor/symfony/css-selector/CHANGELOG.md
create mode 100644 vendor/symfony/css-selector/CssSelectorConverter.php
create mode 100644 vendor/symfony/css-selector/Exception/ExceptionInterface.php
create mode 100644 vendor/symfony/css-selector/Exception/ExpressionErrorException.php
create mode 100644 vendor/symfony/css-selector/Exception/InternalErrorException.php
create mode 100644 vendor/symfony/css-selector/Exception/ParseException.php
create mode 100644 vendor/symfony/css-selector/Exception/SyntaxErrorException.php
create mode 100644 vendor/symfony/css-selector/LICENSE
create mode 100644 vendor/symfony/css-selector/Node/AbstractNode.php
create mode 100644 vendor/symfony/css-selector/Node/AttributeNode.php
create mode 100644 vendor/symfony/css-selector/Node/ClassNode.php
create mode 100644 vendor/symfony/css-selector/Node/CombinedSelectorNode.php
create mode 100644 vendor/symfony/css-selector/Node/ElementNode.php
create mode 100644 vendor/symfony/css-selector/Node/FunctionNode.php
create mode 100644 vendor/symfony/css-selector/Node/HashNode.php
create mode 100644 vendor/symfony/css-selector/Node/NegationNode.php
create mode 100644 vendor/symfony/css-selector/Node/NodeInterface.php
create mode 100644 vendor/symfony/css-selector/Node/PseudoNode.php
create mode 100644 vendor/symfony/css-selector/Node/SelectorNode.php
create mode 100644 vendor/symfony/css-selector/Node/Specificity.php
create mode 100644 vendor/symfony/css-selector/Parser/Handler/CommentHandler.php
create mode 100644 vendor/symfony/css-selector/Parser/Handler/HandlerInterface.php
create mode 100644 vendor/symfony/css-selector/Parser/Handler/HashHandler.php
create mode 100644 vendor/symfony/css-selector/Parser/Handler/IdentifierHandler.php
create mode 100644 vendor/symfony/css-selector/Parser/Handler/NumberHandler.php
create mode 100644 vendor/symfony/css-selector/Parser/Handler/StringHandler.php
create mode 100644 vendor/symfony/css-selector/Parser/Handler/WhitespaceHandler.php
create mode 100644 vendor/symfony/css-selector/Parser/Parser.php
create mode 100644 vendor/symfony/css-selector/Parser/ParserInterface.php
create mode 100644 vendor/symfony/css-selector/Parser/Reader.php
create mode 100644 vendor/symfony/css-selector/Parser/Shortcut/ClassParser.php
create mode 100644 vendor/symfony/css-selector/Parser/Shortcut/ElementParser.php
create mode 100644 vendor/symfony/css-selector/Parser/Shortcut/EmptyStringParser.php
create mode 100644 vendor/symfony/css-selector/Parser/Shortcut/HashParser.php
create mode 100644 vendor/symfony/css-selector/Parser/Token.php
create mode 100644 vendor/symfony/css-selector/Parser/TokenStream.php
create mode 100644 vendor/symfony/css-selector/Parser/Tokenizer/Tokenizer.php
create mode 100644 vendor/symfony/css-selector/Parser/Tokenizer/TokenizerEscaping.php
create mode 100644 vendor/symfony/css-selector/Parser/Tokenizer/TokenizerPatterns.php
create mode 100644 vendor/symfony/css-selector/README.md
create mode 100644 vendor/symfony/css-selector/Tests/CssSelectorConverterTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/AbstractNodeTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/AttributeNodeTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/ClassNodeTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/CombinedSelectorNodeTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/ElementNodeTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/FunctionNodeTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/HashNodeTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/NegationNodeTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/PseudoNodeTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/SelectorNodeTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Node/SpecificityTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Handler/AbstractHandlerTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Handler/CommentHandlerTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Handler/HashHandlerTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Handler/IdentifierHandlerTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Handler/NumberHandlerTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Handler/StringHandlerTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Handler/WhitespaceHandlerTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/ParserTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/ReaderTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Shortcut/ClassParserTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Shortcut/ElementParserTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Shortcut/EmptyStringParserTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/Shortcut/HashParserTest.php
create mode 100644 vendor/symfony/css-selector/Tests/Parser/TokenStreamTest.php
create mode 100644 vendor/symfony/css-selector/Tests/XPath/Fixtures/ids.html
create mode 100644 vendor/symfony/css-selector/Tests/XPath/Fixtures/lang.xml
create mode 100644 vendor/symfony/css-selector/Tests/XPath/Fixtures/shakespear.html
create mode 100644 vendor/symfony/css-selector/Tests/XPath/TranslatorTest.php
create mode 100644 vendor/symfony/css-selector/XPath/Extension/AbstractExtension.php
create mode 100644 vendor/symfony/css-selector/XPath/Extension/AttributeMatchingExtension.php
create mode 100644 vendor/symfony/css-selector/XPath/Extension/CombinationExtension.php
create mode 100644 vendor/symfony/css-selector/XPath/Extension/ExtensionInterface.php
create mode 100644 vendor/symfony/css-selector/XPath/Extension/FunctionExtension.php
create mode 100644 vendor/symfony/css-selector/XPath/Extension/HtmlExtension.php
create mode 100644 vendor/symfony/css-selector/XPath/Extension/NodeExtension.php
create mode 100644 vendor/symfony/css-selector/XPath/Extension/PseudoClassExtension.php
create mode 100644 vendor/symfony/css-selector/XPath/Translator.php
create mode 100644 vendor/symfony/css-selector/XPath/TranslatorInterface.php
create mode 100644 vendor/symfony/css-selector/XPath/XPathExpr.php
create mode 100644 vendor/symfony/css-selector/composer.json
create mode 100644 vendor/symfony/css-selector/phpunit.xml.dist
create mode 100644 vendor/symfony/debug/.gitignore
create mode 100644 vendor/symfony/debug/BufferingLogger.php
create mode 100644 vendor/symfony/debug/CHANGELOG.md
create mode 100644 vendor/symfony/debug/Debug.php
create mode 100644 vendor/symfony/debug/DebugClassLoader.php
create mode 100644 vendor/symfony/debug/ErrorHandler.php
create mode 100644 vendor/symfony/debug/Exception/ClassNotFoundException.php
create mode 100644 vendor/symfony/debug/Exception/ContextErrorException.php
create mode 100644 vendor/symfony/debug/Exception/FatalErrorException.php
create mode 100644 vendor/symfony/debug/Exception/FatalThrowableError.php
create mode 100644 vendor/symfony/debug/Exception/FlattenException.php
create mode 100644 vendor/symfony/debug/Exception/OutOfMemoryException.php
create mode 100644 vendor/symfony/debug/Exception/SilencedErrorContext.php
create mode 100644 vendor/symfony/debug/Exception/UndefinedFunctionException.php
create mode 100644 vendor/symfony/debug/Exception/UndefinedMethodException.php
create mode 100644 vendor/symfony/debug/ExceptionHandler.php
create mode 100644 vendor/symfony/debug/FatalErrorHandler/ClassNotFoundFatalErrorHandler.php
create mode 100644 vendor/symfony/debug/FatalErrorHandler/FatalErrorHandlerInterface.php
create mode 100644 vendor/symfony/debug/FatalErrorHandler/UndefinedFunctionFatalErrorHandler.php
create mode 100644 vendor/symfony/debug/FatalErrorHandler/UndefinedMethodFatalErrorHandler.php
create mode 100644 vendor/symfony/debug/LICENSE
create mode 100644 vendor/symfony/debug/README.md
create mode 100644 vendor/symfony/debug/Resources/ext/README.md
create mode 100644 vendor/symfony/debug/Resources/ext/config.m4
create mode 100644 vendor/symfony/debug/Resources/ext/config.w32
create mode 100644 vendor/symfony/debug/Resources/ext/php_symfony_debug.h
create mode 100644 vendor/symfony/debug/Resources/ext/symfony_debug.c
create mode 100644 vendor/symfony/debug/Resources/ext/tests/001.phpt
create mode 100644 vendor/symfony/debug/Resources/ext/tests/002.phpt
create mode 100644 vendor/symfony/debug/Resources/ext/tests/002_1.phpt
create mode 100644 vendor/symfony/debug/Resources/ext/tests/003.phpt
create mode 100644 vendor/symfony/debug/Tests/DebugClassLoaderTest.php
create mode 100644 vendor/symfony/debug/Tests/ErrorHandlerTest.php
create mode 100644 vendor/symfony/debug/Tests/Exception/FlattenExceptionTest.php
create mode 100644 vendor/symfony/debug/Tests/ExceptionHandlerTest.php
create mode 100644 vendor/symfony/debug/Tests/FatalErrorHandler/ClassNotFoundFatalErrorHandlerTest.php
create mode 100644 vendor/symfony/debug/Tests/FatalErrorHandler/UndefinedFunctionFatalErrorHandlerTest.php
create mode 100644 vendor/symfony/debug/Tests/FatalErrorHandler/UndefinedMethodFatalErrorHandlerTest.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/AnnotatedClass.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/ClassAlias.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/DefinitionInEvaluatedCode.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/DeprecatedClass.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/DeprecatedInterface.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/ErrorHandlerThatUsesThePreviousOne.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/ExtendedFinalMethod.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/FinalClasses.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/FinalMethod.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/FinalMethod2Trait.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/InternalClass.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/InternalInterface.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/InternalTrait.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/InternalTrait2.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/LoggerThatSetAnErrorHandler.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/NonDeprecatedInterface.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/PEARClass.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/Throwing.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/ToStringThrower.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/TraitWithInternalMethod.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/casemismatch.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/notPsr0Bis.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/psr4/Psr4CaseMismatch.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures/reallyNotPsr0.php
create mode 100644 vendor/symfony/debug/Tests/Fixtures2/RequiredTwice.php
create mode 100644 vendor/symfony/debug/Tests/HeaderMock.php
create mode 100644 vendor/symfony/debug/Tests/phpt/debug_class_loader.phpt
create mode 100644 vendor/symfony/debug/Tests/phpt/decorate_exception_hander.phpt
create mode 100644 vendor/symfony/debug/Tests/phpt/exception_rethrown.phpt
create mode 100644 vendor/symfony/debug/Tests/phpt/fatal_with_nested_handlers.phpt
create mode 100644 vendor/symfony/debug/composer.json
create mode 100644 vendor/symfony/debug/phpunit.xml.dist
create mode 100644 vendor/symfony/event-dispatcher/.gitignore
create mode 100644 vendor/symfony/event-dispatcher/CHANGELOG.md
create mode 100644 vendor/symfony/event-dispatcher/ContainerAwareEventDispatcher.php
create mode 100644 vendor/symfony/event-dispatcher/Debug/TraceableEventDispatcher.php
create mode 100644 vendor/symfony/event-dispatcher/Debug/TraceableEventDispatcherInterface.php
create mode 100644 vendor/symfony/event-dispatcher/Debug/WrappedListener.php
create mode 100644 vendor/symfony/event-dispatcher/DependencyInjection/RegisterListenersPass.php
create mode 100644 vendor/symfony/event-dispatcher/Event.php
create mode 100644 vendor/symfony/event-dispatcher/EventDispatcher.php
create mode 100644 vendor/symfony/event-dispatcher/EventDispatcherInterface.php
create mode 100644 vendor/symfony/event-dispatcher/EventSubscriberInterface.php
create mode 100644 vendor/symfony/event-dispatcher/GenericEvent.php
create mode 100644 vendor/symfony/event-dispatcher/ImmutableEventDispatcher.php
create mode 100644 vendor/symfony/event-dispatcher/LICENSE
create mode 100644 vendor/symfony/event-dispatcher/README.md
create mode 100644 vendor/symfony/event-dispatcher/Tests/AbstractEventDispatcherTest.php
create mode 100644 vendor/symfony/event-dispatcher/Tests/ContainerAwareEventDispatcherTest.php
create mode 100644 vendor/symfony/event-dispatcher/Tests/Debug/TraceableEventDispatcherTest.php
create mode 100644 vendor/symfony/event-dispatcher/Tests/Debug/WrappedListenerTest.php
create mode 100644 vendor/symfony/event-dispatcher/Tests/DependencyInjection/RegisterListenersPassTest.php
create mode 100644 vendor/symfony/event-dispatcher/Tests/EventDispatcherTest.php
create mode 100644 vendor/symfony/event-dispatcher/Tests/EventTest.php
create mode 100644 vendor/symfony/event-dispatcher/Tests/GenericEventTest.php
create mode 100644 vendor/symfony/event-dispatcher/Tests/ImmutableEventDispatcherTest.php
create mode 100644 vendor/symfony/event-dispatcher/composer.json
create mode 100644 vendor/symfony/event-dispatcher/phpunit.xml.dist
create mode 100644 vendor/symfony/finder/.gitignore
create mode 100644 vendor/symfony/finder/CHANGELOG.md
create mode 100644 vendor/symfony/finder/Comparator/Comparator.php
create mode 100644 vendor/symfony/finder/Comparator/DateComparator.php
create mode 100644 vendor/symfony/finder/Comparator/NumberComparator.php
create mode 100644 vendor/symfony/finder/Exception/AccessDeniedException.php
create mode 100644 vendor/symfony/finder/Exception/ExceptionInterface.php
create mode 100644 vendor/symfony/finder/Finder.php
create mode 100644 vendor/symfony/finder/Glob.php
create mode 100644 vendor/symfony/finder/Iterator/CustomFilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/DateRangeFilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/DepthRangeFilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/ExcludeDirectoryFilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/FileTypeFilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/FilecontentFilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/FilenameFilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/FilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/MultiplePcreFilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/PathFilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/RecursiveDirectoryIterator.php
create mode 100644 vendor/symfony/finder/Iterator/SizeRangeFilterIterator.php
create mode 100644 vendor/symfony/finder/Iterator/SortableIterator.php
create mode 100644 vendor/symfony/finder/LICENSE
create mode 100644 vendor/symfony/finder/README.md
create mode 100644 vendor/symfony/finder/SplFileInfo.php
create mode 100644 vendor/symfony/finder/Tests/Comparator/ComparatorTest.php
create mode 100644 vendor/symfony/finder/Tests/Comparator/DateComparatorTest.php
create mode 100644 vendor/symfony/finder/Tests/Comparator/NumberComparatorTest.php
create mode 100644 vendor/symfony/finder/Tests/FinderTest.php
create mode 100644 vendor/symfony/finder/Tests/Fixtures/.dot/a
create mode 100644 vendor/symfony/finder/Tests/Fixtures/.dot/b/c.neon
create mode 100644 vendor/symfony/finder/Tests/Fixtures/.dot/b/d.neon
create mode 100644 vendor/symfony/finder/Tests/Fixtures/A/B/C/abc.dat
create mode 100644 vendor/symfony/finder/Tests/Fixtures/A/B/ab.dat
create mode 100644 vendor/symfony/finder/Tests/Fixtures/A/a.dat
create mode 100644 vendor/symfony/finder/Tests/Fixtures/copy/A/B/C/abc.dat.copy
create mode 100644 vendor/symfony/finder/Tests/Fixtures/copy/A/B/ab.dat.copy
create mode 100644 vendor/symfony/finder/Tests/Fixtures/copy/A/a.dat.copy
create mode 100644 vendor/symfony/finder/Tests/Fixtures/dolor.txt
create mode 100644 vendor/symfony/finder/Tests/Fixtures/ipsum.txt
create mode 100644 vendor/symfony/finder/Tests/Fixtures/lorem.txt
create mode 100644 vendor/symfony/finder/Tests/Fixtures/one/.dot
create mode 100644 vendor/symfony/finder/Tests/Fixtures/one/a
create mode 100644 vendor/symfony/finder/Tests/Fixtures/one/b/c.neon
create mode 100644 vendor/symfony/finder/Tests/Fixtures/one/b/d.neon
create mode 100644 vendor/symfony/finder/Tests/Fixtures/r+e.gex[c]a(r)s/dir/bar.dat
create mode 100644 vendor/symfony/finder/Tests/Fixtures/with space/foo.txt
create mode 100644 vendor/symfony/finder/Tests/GlobTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/CustomFilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/DateRangeFilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/DepthRangeFilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/ExcludeDirectoryFilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/FileTypeFilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/FilecontentFilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/FilenameFilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/FilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/Iterator.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/IteratorTestCase.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/MockFileListIterator.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/MockSplFileInfo.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/MultiplePcreFilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/PathFilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/RealIteratorTestCase.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/RecursiveDirectoryIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/SizeRangeFilterIteratorTest.php
create mode 100644 vendor/symfony/finder/Tests/Iterator/SortableIteratorTest.php
create mode 100644 vendor/symfony/finder/composer.json
create mode 100644 vendor/symfony/finder/phpunit.xml.dist
create mode 100644 vendor/symfony/http-foundation/.gitignore
create mode 100644 vendor/symfony/http-foundation/AcceptHeader.php
create mode 100644 vendor/symfony/http-foundation/AcceptHeaderItem.php
create mode 100644 vendor/symfony/http-foundation/ApacheRequest.php
create mode 100644 vendor/symfony/http-foundation/BinaryFileResponse.php
create mode 100644 vendor/symfony/http-foundation/CHANGELOG.md
create mode 100644 vendor/symfony/http-foundation/Cookie.php
create mode 100644 vendor/symfony/http-foundation/Exception/ConflictingHeadersException.php
create mode 100644 vendor/symfony/http-foundation/Exception/RequestExceptionInterface.php
create mode 100644 vendor/symfony/http-foundation/Exception/SuspiciousOperationException.php
create mode 100644 vendor/symfony/http-foundation/ExpressionRequestMatcher.php
create mode 100644 vendor/symfony/http-foundation/File/Exception/AccessDeniedException.php
create mode 100644 vendor/symfony/http-foundation/File/Exception/FileException.php
create mode 100644 vendor/symfony/http-foundation/File/Exception/FileNotFoundException.php
create mode 100644 vendor/symfony/http-foundation/File/Exception/UnexpectedTypeException.php
create mode 100644 vendor/symfony/http-foundation/File/Exception/UploadException.php
create mode 100644 vendor/symfony/http-foundation/File/File.php
create mode 100644 vendor/symfony/http-foundation/File/MimeType/ExtensionGuesser.php
create mode 100644 vendor/symfony/http-foundation/File/MimeType/ExtensionGuesserInterface.php
create mode 100644 vendor/symfony/http-foundation/File/MimeType/FileBinaryMimeTypeGuesser.php
create mode 100644 vendor/symfony/http-foundation/File/MimeType/FileinfoMimeTypeGuesser.php
create mode 100644 vendor/symfony/http-foundation/File/MimeType/MimeTypeExtensionGuesser.php
create mode 100644 vendor/symfony/http-foundation/File/MimeType/MimeTypeGuesser.php
create mode 100644 vendor/symfony/http-foundation/File/MimeType/MimeTypeGuesserInterface.php
create mode 100644 vendor/symfony/http-foundation/File/Stream.php
create mode 100644 vendor/symfony/http-foundation/File/UploadedFile.php
create mode 100644 vendor/symfony/http-foundation/FileBag.php
create mode 100644 vendor/symfony/http-foundation/HeaderBag.php
create mode 100644 vendor/symfony/http-foundation/IpUtils.php
create mode 100644 vendor/symfony/http-foundation/JsonResponse.php
create mode 100644 vendor/symfony/http-foundation/LICENSE
create mode 100644 vendor/symfony/http-foundation/ParameterBag.php
create mode 100644 vendor/symfony/http-foundation/README.md
create mode 100644 vendor/symfony/http-foundation/RedirectResponse.php
create mode 100644 vendor/symfony/http-foundation/Request.php
create mode 100644 vendor/symfony/http-foundation/RequestMatcher.php
create mode 100644 vendor/symfony/http-foundation/RequestMatcherInterface.php
create mode 100644 vendor/symfony/http-foundation/RequestStack.php
create mode 100644 vendor/symfony/http-foundation/Response.php
create mode 100644 vendor/symfony/http-foundation/ResponseHeaderBag.php
create mode 100644 vendor/symfony/http-foundation/ServerBag.php
create mode 100644 vendor/symfony/http-foundation/Session/Attribute/AttributeBag.php
create mode 100644 vendor/symfony/http-foundation/Session/Attribute/AttributeBagInterface.php
create mode 100644 vendor/symfony/http-foundation/Session/Attribute/NamespacedAttributeBag.php
create mode 100644 vendor/symfony/http-foundation/Session/Flash/AutoExpireFlashBag.php
create mode 100644 vendor/symfony/http-foundation/Session/Flash/FlashBag.php
create mode 100644 vendor/symfony/http-foundation/Session/Flash/FlashBagInterface.php
create mode 100644 vendor/symfony/http-foundation/Session/Session.php
create mode 100644 vendor/symfony/http-foundation/Session/SessionBagInterface.php
create mode 100644 vendor/symfony/http-foundation/Session/SessionBagProxy.php
create mode 100644 vendor/symfony/http-foundation/Session/SessionInterface.php
create mode 100644 vendor/symfony/http-foundation/Session/SessionUtils.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Handler/AbstractSessionHandler.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Handler/MemcacheSessionHandler.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Handler/MemcachedSessionHandler.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Handler/MongoDbSessionHandler.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Handler/NativeFileSessionHandler.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Handler/NativeSessionHandler.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Handler/NullSessionHandler.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Handler/PdoSessionHandler.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Handler/StrictSessionHandler.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Handler/WriteCheckSessionHandler.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/MetadataBag.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/MockArraySessionStorage.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/MockFileSessionStorage.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/NativeSessionStorage.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/PhpBridgeSessionStorage.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Proxy/AbstractProxy.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Proxy/NativeProxy.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/Proxy/SessionHandlerProxy.php
create mode 100644 vendor/symfony/http-foundation/Session/Storage/SessionStorageInterface.php
create mode 100644 vendor/symfony/http-foundation/StreamedResponse.php
create mode 100644 vendor/symfony/http-foundation/Tests/AcceptHeaderItemTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/AcceptHeaderTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/ApacheRequestTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/BinaryFileResponseTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/CookieTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/ExpressionRequestMatcherTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/File/FakeFile.php
create mode 100644 vendor/symfony/http-foundation/Tests/File/FileTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/File/Fixtures/-test
create mode 100644 vendor/symfony/http-foundation/Tests/File/Fixtures/.unknownextension
create mode 100644 vendor/symfony/http-foundation/Tests/File/Fixtures/case-sensitive-mime-type.xlsm
create mode 100644 vendor/symfony/http-foundation/Tests/File/Fixtures/directory/.empty
create mode 100644 vendor/symfony/http-foundation/Tests/File/Fixtures/other-file.example
create mode 100644 vendor/symfony/http-foundation/Tests/File/Fixtures/test
create mode 100644 vendor/symfony/http-foundation/Tests/File/Fixtures/test.docx
create mode 100644 vendor/symfony/http-foundation/Tests/File/Fixtures/test.gif
create mode 100644 vendor/symfony/http-foundation/Tests/File/MimeType/MimeTypeTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/File/UploadedFileTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/FileBagTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/common.inc
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_max_age.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_max_age.php
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_raw_urlencode.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_raw_urlencode.php
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_samesite_lax.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_samesite_lax.php
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_samesite_strict.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_samesite_strict.php
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_urlencode.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/cookie_urlencode.php
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/invalid_cookie_name.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Fixtures/response-functional/invalid_cookie_name.php
create mode 100644 vendor/symfony/http-foundation/Tests/HeaderBagTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/IpUtilsTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/JsonResponseTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/ParameterBagTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/RedirectResponseTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/RequestMatcherTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/RequestStackTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/RequestTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/ResponseFunctionalTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/ResponseHeaderBagTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/ResponseTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/ResponseTestCase.php
create mode 100644 vendor/symfony/http-foundation/Tests/ServerBagTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Attribute/AttributeBagTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Attribute/NamespacedAttributeBagTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Flash/AutoExpireFlashBagTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Flash/FlashBagTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/SessionTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/AbstractSessionHandlerTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/common.inc
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/empty_destroys.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/empty_destroys.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/read_only.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/read_only.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/regenerate.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/regenerate.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/storage.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/storage.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_cookie.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_cookie.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_cookie_and_session.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_cookie_and_session.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_samesite.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_samesite.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_samesite_and_migration.expected
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/Fixtures/with_samesite_and_migration.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/MemcacheSessionHandlerTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/MemcachedSessionHandlerTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/MongoDbSessionHandlerTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/NativeFileSessionHandlerTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/NativeSessionHandlerTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/NullSessionHandlerTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/PdoSessionHandlerTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/StrictSessionHandlerTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Handler/WriteCheckSessionHandlerTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/MetadataBagTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/MockArraySessionStorageTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/MockFileSessionStorageTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/NativeSessionStorageTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/PhpBridgeSessionStorageTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Proxy/AbstractProxyTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Proxy/NativeProxyTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/Session/Storage/Proxy/SessionHandlerProxyTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/StreamedResponseTest.php
create mode 100644 vendor/symfony/http-foundation/Tests/schema/http-status-codes.rng
create mode 100644 vendor/symfony/http-foundation/Tests/schema/iana-registry.rng
create mode 100644 vendor/symfony/http-foundation/composer.json
create mode 100644 vendor/symfony/http-foundation/phpunit.xml.dist
create mode 100644 vendor/symfony/http-kernel/.gitignore
create mode 100644 vendor/symfony/http-kernel/Bundle/Bundle.php
create mode 100644 vendor/symfony/http-kernel/Bundle/BundleInterface.php
create mode 100644 vendor/symfony/http-kernel/CHANGELOG.md
create mode 100644 vendor/symfony/http-kernel/CacheClearer/CacheClearerInterface.php
create mode 100644 vendor/symfony/http-kernel/CacheClearer/ChainCacheClearer.php
create mode 100644 vendor/symfony/http-kernel/CacheClearer/Psr6CacheClearer.php
create mode 100644 vendor/symfony/http-kernel/CacheWarmer/CacheWarmer.php
create mode 100644 vendor/symfony/http-kernel/CacheWarmer/CacheWarmerAggregate.php
create mode 100644 vendor/symfony/http-kernel/CacheWarmer/CacheWarmerInterface.php
create mode 100644 vendor/symfony/http-kernel/CacheWarmer/WarmableInterface.php
create mode 100644 vendor/symfony/http-kernel/Client.php
create mode 100644 vendor/symfony/http-kernel/Config/EnvParametersResource.php
create mode 100644 vendor/symfony/http-kernel/Config/FileLocator.php
create mode 100644 vendor/symfony/http-kernel/Controller/ArgumentResolver.php
create mode 100644 vendor/symfony/http-kernel/Controller/ArgumentResolver/DefaultValueResolver.php
create mode 100644 vendor/symfony/http-kernel/Controller/ArgumentResolver/RequestAttributeValueResolver.php
create mode 100644 vendor/symfony/http-kernel/Controller/ArgumentResolver/RequestValueResolver.php
create mode 100644 vendor/symfony/http-kernel/Controller/ArgumentResolver/ServiceValueResolver.php
create mode 100644 vendor/symfony/http-kernel/Controller/ArgumentResolver/SessionValueResolver.php
create mode 100644 vendor/symfony/http-kernel/Controller/ArgumentResolver/VariadicValueResolver.php
create mode 100644 vendor/symfony/http-kernel/Controller/ArgumentResolverInterface.php
create mode 100644 vendor/symfony/http-kernel/Controller/ArgumentValueResolverInterface.php
create mode 100644 vendor/symfony/http-kernel/Controller/ContainerControllerResolver.php
create mode 100644 vendor/symfony/http-kernel/Controller/ControllerReference.php
create mode 100644 vendor/symfony/http-kernel/Controller/ControllerResolver.php
create mode 100644 vendor/symfony/http-kernel/Controller/ControllerResolverInterface.php
create mode 100644 vendor/symfony/http-kernel/Controller/TraceableArgumentResolver.php
create mode 100644 vendor/symfony/http-kernel/Controller/TraceableControllerResolver.php
create mode 100644 vendor/symfony/http-kernel/ControllerMetadata/ArgumentMetadata.php
create mode 100644 vendor/symfony/http-kernel/ControllerMetadata/ArgumentMetadataFactory.php
create mode 100644 vendor/symfony/http-kernel/ControllerMetadata/ArgumentMetadataFactoryInterface.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/AjaxDataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/ConfigDataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/DataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/DataCollectorInterface.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/DumpDataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/EventDataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/ExceptionDataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/LateDataCollectorInterface.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/LoggerDataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/MemoryDataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/RequestDataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/RouterDataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/TimeDataCollector.php
create mode 100644 vendor/symfony/http-kernel/DataCollector/Util/ValueExporter.php
create mode 100644 vendor/symfony/http-kernel/Debug/FileLinkFormatter.php
create mode 100644 vendor/symfony/http-kernel/Debug/TraceableEventDispatcher.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/AddAnnotatedClassesToCachePass.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/AddClassesToCachePass.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/ConfigurableExtension.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/ControllerArgumentValueResolverPass.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/Extension.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/FragmentRendererPass.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/LazyLoadingFragmentHandler.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/LoggerPass.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/MergeExtensionConfigurationPass.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/RegisterControllerArgumentLocatorsPass.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/RemoveEmptyControllerArgumentLocatorsPass.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/ResettableServicePass.php
create mode 100644 vendor/symfony/http-kernel/DependencyInjection/ServicesResetter.php
create mode 100644 vendor/symfony/http-kernel/Event/FilterControllerArgumentsEvent.php
create mode 100644 vendor/symfony/http-kernel/Event/FilterControllerEvent.php
create mode 100644 vendor/symfony/http-kernel/Event/FilterResponseEvent.php
create mode 100644 vendor/symfony/http-kernel/Event/FinishRequestEvent.php
create mode 100644 vendor/symfony/http-kernel/Event/GetResponseEvent.php
create mode 100644 vendor/symfony/http-kernel/Event/GetResponseForControllerResultEvent.php
create mode 100644 vendor/symfony/http-kernel/Event/GetResponseForExceptionEvent.php
create mode 100644 vendor/symfony/http-kernel/Event/KernelEvent.php
create mode 100644 vendor/symfony/http-kernel/Event/PostResponseEvent.php
create mode 100644 vendor/symfony/http-kernel/EventListener/AbstractSessionListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/AbstractTestSessionListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/AddRequestFormatsListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/DebugHandlersListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/DumpListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/ExceptionListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/FragmentListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/LocaleListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/ProfilerListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/ResponseListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/RouterListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/SaveSessionListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/SessionListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/StreamedResponseListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/SurrogateListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/TestSessionListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/TranslatorListener.php
create mode 100644 vendor/symfony/http-kernel/EventListener/ValidateRequestListener.php
create mode 100644 vendor/symfony/http-kernel/Exception/AccessDeniedHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/BadRequestHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/ConflictHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/GoneHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/HttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/HttpExceptionInterface.php
create mode 100644 vendor/symfony/http-kernel/Exception/LengthRequiredHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/MethodNotAllowedHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/NotAcceptableHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/NotFoundHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/PreconditionFailedHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/PreconditionRequiredHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/ServiceUnavailableHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/TooManyRequestsHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/UnauthorizedHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/UnprocessableEntityHttpException.php
create mode 100644 vendor/symfony/http-kernel/Exception/UnsupportedMediaTypeHttpException.php
create mode 100644 vendor/symfony/http-kernel/Fragment/AbstractSurrogateFragmentRenderer.php
create mode 100644 vendor/symfony/http-kernel/Fragment/EsiFragmentRenderer.php
create mode 100644 vendor/symfony/http-kernel/Fragment/FragmentHandler.php
create mode 100644 vendor/symfony/http-kernel/Fragment/FragmentRendererInterface.php
create mode 100644 vendor/symfony/http-kernel/Fragment/HIncludeFragmentRenderer.php
create mode 100644 vendor/symfony/http-kernel/Fragment/InlineFragmentRenderer.php
create mode 100644 vendor/symfony/http-kernel/Fragment/RoutableFragmentRenderer.php
create mode 100644 vendor/symfony/http-kernel/Fragment/SsiFragmentRenderer.php
create mode 100644 vendor/symfony/http-kernel/HttpCache/AbstractSurrogate.php
create mode 100644 vendor/symfony/http-kernel/HttpCache/Esi.php
create mode 100644 vendor/symfony/http-kernel/HttpCache/HttpCache.php
create mode 100644 vendor/symfony/http-kernel/HttpCache/ResponseCacheStrategy.php
create mode 100644 vendor/symfony/http-kernel/HttpCache/ResponseCacheStrategyInterface.php
create mode 100644 vendor/symfony/http-kernel/HttpCache/Ssi.php
create mode 100644 vendor/symfony/http-kernel/HttpCache/Store.php
create mode 100644 vendor/symfony/http-kernel/HttpCache/StoreInterface.php
create mode 100644 vendor/symfony/http-kernel/HttpCache/SubRequestHandler.php
create mode 100644 vendor/symfony/http-kernel/HttpCache/SurrogateInterface.php
create mode 100644 vendor/symfony/http-kernel/HttpKernel.php
create mode 100644 vendor/symfony/http-kernel/HttpKernelInterface.php
create mode 100644 vendor/symfony/http-kernel/Kernel.php
create mode 100644 vendor/symfony/http-kernel/KernelEvents.php
create mode 100644 vendor/symfony/http-kernel/KernelInterface.php
create mode 100644 vendor/symfony/http-kernel/LICENSE
create mode 100644 vendor/symfony/http-kernel/Log/DebugLoggerInterface.php
create mode 100644 vendor/symfony/http-kernel/Log/Logger.php
create mode 100644 vendor/symfony/http-kernel/Profiler/FileProfilerStorage.php
create mode 100644 vendor/symfony/http-kernel/Profiler/Profile.php
create mode 100644 vendor/symfony/http-kernel/Profiler/Profiler.php
create mode 100644 vendor/symfony/http-kernel/Profiler/ProfilerStorageInterface.php
create mode 100644 vendor/symfony/http-kernel/README.md
create mode 100644 vendor/symfony/http-kernel/RebootableInterface.php
create mode 100644 vendor/symfony/http-kernel/Resources/welcome.html.php
create mode 100644 vendor/symfony/http-kernel/TerminableInterface.php
create mode 100644 vendor/symfony/http-kernel/Tests/Bundle/BundleTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/CacheClearer/ChainCacheClearerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/CacheClearer/Psr6CacheClearerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/CacheWarmer/CacheWarmerAggregateTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/CacheWarmer/CacheWarmerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/ClientTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Config/EnvParametersResourceTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Config/FileLocatorTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Controller/ArgumentResolver/ServiceValueResolverTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Controller/ArgumentResolverTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Controller/ContainerControllerResolverTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Controller/ControllerResolverTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/ControllerMetadata/ArgumentMetadataFactoryTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/ControllerMetadata/ArgumentMetadataTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DataCollector/Compiler.log
create mode 100644 vendor/symfony/http-kernel/Tests/DataCollector/ConfigDataCollectorTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DataCollector/DataCollectorTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DataCollector/DumpDataCollectorTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DataCollector/ExceptionDataCollectorTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DataCollector/LoggerDataCollectorTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DataCollector/MemoryDataCollectorTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DataCollector/RequestDataCollectorTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DataCollector/TimeDataCollectorTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DataCollector/Util/ValueExporterTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Debug/FileLinkFormatterTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Debug/TraceableEventDispatcherTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DependencyInjection/AddAnnotatedClassesToCachePassTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DependencyInjection/ControllerArgumentValueResolverPassTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DependencyInjection/FragmentRendererPassTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DependencyInjection/LazyLoadingFragmentHandlerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DependencyInjection/LoggerPassTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DependencyInjection/MergeExtensionConfigurationPassTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DependencyInjection/RegisterControllerArgumentLocatorsPassTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DependencyInjection/RemoveEmptyControllerArgumentLocatorsPassTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DependencyInjection/ResettableServicePassTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/DependencyInjection/ServicesResetterTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Event/FilterControllerArgumentsEventTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Event/GetResponseForExceptionEventTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/AddRequestFormatsListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/DebugHandlersListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/DumpListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/ExceptionListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/FragmentListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/LocaleListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/ProfilerListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/ResponseListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/RouterListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/SaveSessionListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/SessionListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/SurrogateListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/TestSessionListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/TranslatorListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/EventListener/ValidateRequestListenerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/AccessDeniedHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/BadRequestHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/ConflictHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/GoneHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/HttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/LengthRequiredHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/MethodNotAllowedHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/NotAcceptableHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/NotFoundHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/PreconditionFailedHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/PreconditionRequiredHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/ServiceUnavailableHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/TooManyRequestsHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/UnauthorizedHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/UnprocessableEntityHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Exception/UnsupportedMediaTypeHttpExceptionTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/123/Kernel123.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/BaseBundle/Resources/foo.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/BaseBundle/Resources/hide.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Bundle1Bundle/Resources/foo.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Bundle1Bundle/bar.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Bundle1Bundle/foo.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Bundle2Bundle/foo.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/ChildBundle/Resources/foo.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/ChildBundle/Resources/hide.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/ClearableService.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Controller/BasicTypesController.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Controller/ExtendingRequest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Controller/ExtendingSession.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Controller/LegacyNullableController.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Controller/NullableController.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Controller/VariadicController.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/DataCollector/CloneVarDataCollector.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/ExtensionAbsentBundle/ExtensionAbsentBundle.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/ExtensionNotValidBundle/DependencyInjection/ExtensionNotValidExtension.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/ExtensionNotValidBundle/ExtensionNotValidBundle.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/ExtensionPresentBundle/Command/FooCommand.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/ExtensionPresentBundle/DependencyInjection/ExtensionPresentExtension.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/ExtensionPresentBundle/ExtensionPresentBundle.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/KernelForOverrideName.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/KernelForTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/KernelWithoutBundles.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/ResettableService.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Resources/BaseBundle/hide.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Resources/Bundle1Bundle/foo.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Resources/ChildBundle/foo.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/Resources/FooBundle/foo.txt
create mode 100644 vendor/symfony/http-kernel/Tests/Fixtures/TestClient.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fragment/EsiFragmentRendererTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fragment/FragmentHandlerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fragment/HIncludeFragmentRendererTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fragment/InlineFragmentRendererTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fragment/RoutableFragmentRendererTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Fragment/SsiFragmentRendererTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/HttpCache/EsiTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/HttpCache/HttpCacheTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/HttpCache/HttpCacheTestCase.php
create mode 100644 vendor/symfony/http-kernel/Tests/HttpCache/ResponseCacheStrategyTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/HttpCache/SsiTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/HttpCache/StoreTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/HttpCache/SubRequestHandlerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/HttpCache/TestHttpKernel.php
create mode 100644 vendor/symfony/http-kernel/Tests/HttpCache/TestMultipleHttpKernel.php
create mode 100644 vendor/symfony/http-kernel/Tests/HttpKernelTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/KernelTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Log/LoggerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Logger.php
create mode 100644 vendor/symfony/http-kernel/Tests/Profiler/FileProfilerStorageTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/Profiler/ProfilerTest.php
create mode 100644 vendor/symfony/http-kernel/Tests/TestHttpKernel.php
create mode 100644 vendor/symfony/http-kernel/Tests/UriSignerTest.php
create mode 100644 vendor/symfony/http-kernel/UriSigner.php
create mode 100644 vendor/symfony/http-kernel/composer.json
create mode 100644 vendor/symfony/http-kernel/phpunit.xml.dist
create mode 100644 vendor/symfony/polyfill-ctype/Ctype.php
create mode 100644 vendor/symfony/polyfill-ctype/LICENSE
create mode 100644 vendor/symfony/polyfill-ctype/README.md
create mode 100644 vendor/symfony/polyfill-ctype/bootstrap.php
create mode 100644 vendor/symfony/polyfill-ctype/composer.json
create mode 100644 vendor/symfony/polyfill-mbstring/LICENSE
create mode 100644 vendor/symfony/polyfill-mbstring/Mbstring.php
create mode 100644 vendor/symfony/polyfill-mbstring/README.md
create mode 100644 vendor/symfony/polyfill-mbstring/Resources/mb_convert_variables.php8
create mode 100644 vendor/symfony/polyfill-mbstring/Resources/unidata/lowerCase.php
create mode 100644 vendor/symfony/polyfill-mbstring/Resources/unidata/titleCaseRegexp.php
create mode 100644 vendor/symfony/polyfill-mbstring/Resources/unidata/upperCase.php
create mode 100644 vendor/symfony/polyfill-mbstring/bootstrap.php
create mode 100644 vendor/symfony/polyfill-mbstring/composer.json
create mode 100644 vendor/symfony/polyfill-php56/LICENSE
create mode 100644 vendor/symfony/polyfill-php56/Php56.php
create mode 100644 vendor/symfony/polyfill-php56/README.md
create mode 100644 vendor/symfony/polyfill-php56/bootstrap.php
create mode 100644 vendor/symfony/polyfill-php56/composer.json
create mode 100644 vendor/symfony/polyfill-php70/LICENSE
create mode 100644 vendor/symfony/polyfill-php70/Php70.php
create mode 100644 vendor/symfony/polyfill-php70/README.md
create mode 100644 vendor/symfony/polyfill-php70/Resources/stubs/ArithmeticError.php
create mode 100644 vendor/symfony/polyfill-php70/Resources/stubs/AssertionError.php
create mode 100644 vendor/symfony/polyfill-php70/Resources/stubs/DivisionByZeroError.php
create mode 100644 vendor/symfony/polyfill-php70/Resources/stubs/Error.php
create mode 100644 vendor/symfony/polyfill-php70/Resources/stubs/ParseError.php
create mode 100644 vendor/symfony/polyfill-php70/Resources/stubs/SessionUpdateTimestampHandlerInterface.php
create mode 100644 vendor/symfony/polyfill-php70/Resources/stubs/TypeError.php
create mode 100644 vendor/symfony/polyfill-php70/bootstrap.php
create mode 100644 vendor/symfony/polyfill-php70/composer.json
create mode 100644 vendor/symfony/polyfill-util/Binary.php
create mode 100644 vendor/symfony/polyfill-util/BinaryNoFuncOverload.php
create mode 100644 vendor/symfony/polyfill-util/BinaryOnFuncOverload.php
create mode 100644 vendor/symfony/polyfill-util/LICENSE
create mode 100644 vendor/symfony/polyfill-util/README.md
create mode 100644 vendor/symfony/polyfill-util/TestListener.php
create mode 100644 vendor/symfony/polyfill-util/TestListenerForV5.php
create mode 100644 vendor/symfony/polyfill-util/TestListenerForV6.php
create mode 100644 vendor/symfony/polyfill-util/TestListenerForV7.php
create mode 100644 vendor/symfony/polyfill-util/TestListenerTrait.php
create mode 100644 vendor/symfony/polyfill-util/composer.json
create mode 100644 vendor/symfony/process/.gitignore
create mode 100644 vendor/symfony/process/CHANGELOG.md
create mode 100644 vendor/symfony/process/Exception/ExceptionInterface.php
create mode 100644 vendor/symfony/process/Exception/InvalidArgumentException.php
create mode 100644 vendor/symfony/process/Exception/LogicException.php
create mode 100644 vendor/symfony/process/Exception/ProcessFailedException.php
create mode 100644 vendor/symfony/process/Exception/ProcessTimedOutException.php
create mode 100644 vendor/symfony/process/Exception/RuntimeException.php
create mode 100644 vendor/symfony/process/ExecutableFinder.php
create mode 100644 vendor/symfony/process/InputStream.php
create mode 100644 vendor/symfony/process/LICENSE
create mode 100644 vendor/symfony/process/PhpExecutableFinder.php
create mode 100644 vendor/symfony/process/PhpProcess.php
create mode 100644 vendor/symfony/process/Pipes/AbstractPipes.php
create mode 100644 vendor/symfony/process/Pipes/PipesInterface.php
create mode 100644 vendor/symfony/process/Pipes/UnixPipes.php
create mode 100644 vendor/symfony/process/Pipes/WindowsPipes.php
create mode 100644 vendor/symfony/process/Process.php
create mode 100644 vendor/symfony/process/ProcessBuilder.php
create mode 100644 vendor/symfony/process/ProcessUtils.php
create mode 100644 vendor/symfony/process/README.md
create mode 100644 vendor/symfony/process/Tests/ErrorProcessInitiator.php
create mode 100644 vendor/symfony/process/Tests/ExecutableFinderTest.php
create mode 100644 vendor/symfony/process/Tests/NonStopableProcess.php
create mode 100644 vendor/symfony/process/Tests/PhpExecutableFinderTest.php
create mode 100644 vendor/symfony/process/Tests/PhpProcessTest.php
create mode 100644 vendor/symfony/process/Tests/PipeStdinInStdoutStdErrStreamSelect.php
create mode 100644 vendor/symfony/process/Tests/ProcessBuilderTest.php
create mode 100644 vendor/symfony/process/Tests/ProcessFailedExceptionTest.php
create mode 100644 vendor/symfony/process/Tests/ProcessTest.php
create mode 100644 vendor/symfony/process/Tests/ProcessUtilsTest.php
create mode 100644 vendor/symfony/process/Tests/SignalListener.php
create mode 100644 vendor/symfony/process/composer.json
create mode 100644 vendor/symfony/process/phpunit.xml.dist
create mode 100644 vendor/symfony/routing/.gitignore
create mode 100644 vendor/symfony/routing/Annotation/Route.php
create mode 100644 vendor/symfony/routing/CHANGELOG.md
create mode 100644 vendor/symfony/routing/CompiledRoute.php
create mode 100644 vendor/symfony/routing/DependencyInjection/RoutingResolverPass.php
create mode 100644 vendor/symfony/routing/Exception/ExceptionInterface.php
create mode 100644 vendor/symfony/routing/Exception/InvalidParameterException.php
create mode 100644 vendor/symfony/routing/Exception/MethodNotAllowedException.php
create mode 100644 vendor/symfony/routing/Exception/MissingMandatoryParametersException.php
create mode 100644 vendor/symfony/routing/Exception/NoConfigurationException.php
create mode 100644 vendor/symfony/routing/Exception/ResourceNotFoundException.php
create mode 100644 vendor/symfony/routing/Exception/RouteNotFoundException.php
create mode 100644 vendor/symfony/routing/Generator/ConfigurableRequirementsInterface.php
create mode 100644 vendor/symfony/routing/Generator/Dumper/GeneratorDumper.php
create mode 100644 vendor/symfony/routing/Generator/Dumper/GeneratorDumperInterface.php
create mode 100644 vendor/symfony/routing/Generator/Dumper/PhpGeneratorDumper.php
create mode 100644 vendor/symfony/routing/Generator/UrlGenerator.php
create mode 100644 vendor/symfony/routing/Generator/UrlGeneratorInterface.php
create mode 100644 vendor/symfony/routing/LICENSE
create mode 100644 vendor/symfony/routing/Loader/AnnotationClassLoader.php
create mode 100644 vendor/symfony/routing/Loader/AnnotationDirectoryLoader.php
create mode 100644 vendor/symfony/routing/Loader/AnnotationFileLoader.php
create mode 100644 vendor/symfony/routing/Loader/ClosureLoader.php
create mode 100644 vendor/symfony/routing/Loader/Configurator/CollectionConfigurator.php
create mode 100644 vendor/symfony/routing/Loader/Configurator/ImportConfigurator.php
create mode 100644 vendor/symfony/routing/Loader/Configurator/RouteConfigurator.php
create mode 100644 vendor/symfony/routing/Loader/Configurator/RoutingConfigurator.php
create mode 100644 vendor/symfony/routing/Loader/Configurator/Traits/AddTrait.php
create mode 100644 vendor/symfony/routing/Loader/Configurator/Traits/RouteTrait.php
create mode 100644 vendor/symfony/routing/Loader/DependencyInjection/ServiceRouterLoader.php
create mode 100644 vendor/symfony/routing/Loader/DirectoryLoader.php
create mode 100644 vendor/symfony/routing/Loader/GlobFileLoader.php
create mode 100644 vendor/symfony/routing/Loader/ObjectRouteLoader.php
create mode 100644 vendor/symfony/routing/Loader/PhpFileLoader.php
create mode 100644 vendor/symfony/routing/Loader/XmlFileLoader.php
create mode 100644 vendor/symfony/routing/Loader/YamlFileLoader.php
create mode 100644 vendor/symfony/routing/Loader/schema/routing/routing-1.0.xsd
create mode 100644 vendor/symfony/routing/Matcher/Dumper/DumperCollection.php
create mode 100644 vendor/symfony/routing/Matcher/Dumper/DumperRoute.php
create mode 100644 vendor/symfony/routing/Matcher/Dumper/MatcherDumper.php
create mode 100644 vendor/symfony/routing/Matcher/Dumper/MatcherDumperInterface.php
create mode 100644 vendor/symfony/routing/Matcher/Dumper/PhpMatcherDumper.php
create mode 100644 vendor/symfony/routing/Matcher/Dumper/StaticPrefixCollection.php
create mode 100644 vendor/symfony/routing/Matcher/RedirectableUrlMatcher.php
create mode 100644 vendor/symfony/routing/Matcher/RedirectableUrlMatcherInterface.php
create mode 100644 vendor/symfony/routing/Matcher/RequestMatcherInterface.php
create mode 100644 vendor/symfony/routing/Matcher/TraceableUrlMatcher.php
create mode 100644 vendor/symfony/routing/Matcher/UrlMatcher.php
create mode 100644 vendor/symfony/routing/Matcher/UrlMatcherInterface.php
create mode 100644 vendor/symfony/routing/README.md
create mode 100644 vendor/symfony/routing/RequestContext.php
create mode 100644 vendor/symfony/routing/RequestContextAwareInterface.php
create mode 100644 vendor/symfony/routing/Route.php
create mode 100644 vendor/symfony/routing/RouteCollection.php
create mode 100644 vendor/symfony/routing/RouteCollectionBuilder.php
create mode 100644 vendor/symfony/routing/RouteCompiler.php
create mode 100644 vendor/symfony/routing/RouteCompilerInterface.php
create mode 100644 vendor/symfony/routing/Router.php
create mode 100644 vendor/symfony/routing/RouterInterface.php
create mode 100644 vendor/symfony/routing/Tests/Annotation/RouteTest.php
create mode 100644 vendor/symfony/routing/Tests/CompiledRouteTest.php
create mode 100644 vendor/symfony/routing/Tests/DependencyInjection/RoutingResolverPassTest.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/AnnotatedClasses/AbstractClass.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/AnnotatedClasses/BarClass.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/AnnotatedClasses/BazClass.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/AnnotatedClasses/EncodingClass.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/AnnotatedClasses/FooClass.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/AnnotatedClasses/FooTrait.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/CustomCompiledRoute.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/CustomRouteCompiler.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/CustomXmlFileLoader.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/OtherAnnotatedClasses/AnonymousClassInTrait.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/OtherAnnotatedClasses/NoStartTagClass.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/OtherAnnotatedClasses/VariadicClass.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/RedirectableUrlMatcher.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/annotated.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/bad_format.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/bar.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/controller/import__controller.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/controller/import__controller.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/controller/import_controller.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/controller/import_controller.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/controller/import_override_defaults.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/controller/import_override_defaults.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/controller/override_defaults.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/controller/override_defaults.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/controller/routing.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/controller/routing.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/directory/recurse/routes1.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/directory/recurse/routes2.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/directory/routes3.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/directory_import/import.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/dumper/url_matcher0.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/dumper/url_matcher1.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/dumper/url_matcher2.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/dumper/url_matcher3.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/dumper/url_matcher4.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/dumper/url_matcher5.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/dumper/url_matcher6.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/dumper/url_matcher7.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/empty.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/file_resource.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/foo.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/foo1.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/bar.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/bar.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/baz.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/baz.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/import_multiple.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/import_multiple.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/import_single.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/import_single.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/php_dsl.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/php_dsl_bar.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/glob/php_dsl_baz.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/incomplete.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/list_defaults.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/list_in_list_defaults.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/list_in_map_defaults.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/list_null_values.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/localized/utf8.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/map_defaults.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/map_in_list_defaults.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/map_in_map_defaults.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/map_null_values.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/missing_id.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/missing_path.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/namespaceprefix.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/nonesense_resource_plus_path.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/nonesense_type_without_resource.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/nonvalid.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/nonvalid.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/nonvalid2.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/nonvalidkeys.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/nonvalidnode.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/nonvalidroute.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/null_values.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/php_dsl.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/php_dsl_sub.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/scalar_defaults.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/special_route_name.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/validpattern.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/validpattern.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/validpattern.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/validresource.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/validresource.xml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/validresource.yml
create mode 100644 vendor/symfony/routing/Tests/Fixtures/with_define_path_variable.php
create mode 100644 vendor/symfony/routing/Tests/Fixtures/withdoctype.xml
create mode 100644 vendor/symfony/routing/Tests/Generator/Dumper/PhpGeneratorDumperTest.php
create mode 100644 vendor/symfony/routing/Tests/Generator/UrlGeneratorTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/AbstractAnnotationLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/AnnotationClassLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/AnnotationDirectoryLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/AnnotationFileLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/ClosureLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/DirectoryLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/GlobFileLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/ObjectRouteLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/PhpFileLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/XmlFileLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Loader/YamlFileLoaderTest.php
create mode 100644 vendor/symfony/routing/Tests/Matcher/DumpedRedirectableUrlMatcherTest.php
create mode 100644 vendor/symfony/routing/Tests/Matcher/DumpedUrlMatcherTest.php
create mode 100644 vendor/symfony/routing/Tests/Matcher/Dumper/DumperCollectionTest.php
create mode 100644 vendor/symfony/routing/Tests/Matcher/Dumper/PhpMatcherDumperTest.php
create mode 100644 vendor/symfony/routing/Tests/Matcher/Dumper/StaticPrefixCollectionTest.php
create mode 100644 vendor/symfony/routing/Tests/Matcher/RedirectableUrlMatcherTest.php
create mode 100644 vendor/symfony/routing/Tests/Matcher/TraceableUrlMatcherTest.php
create mode 100644 vendor/symfony/routing/Tests/Matcher/UrlMatcherTest.php
create mode 100644 vendor/symfony/routing/Tests/RequestContextTest.php
create mode 100644 vendor/symfony/routing/Tests/RouteCollectionBuilderTest.php
create mode 100644 vendor/symfony/routing/Tests/RouteCollectionTest.php
create mode 100644 vendor/symfony/routing/Tests/RouteCompilerTest.php
create mode 100644 vendor/symfony/routing/Tests/RouteTest.php
create mode 100644 vendor/symfony/routing/Tests/RouterTest.php
create mode 100644 vendor/symfony/routing/composer.json
create mode 100644 vendor/symfony/routing/phpunit.xml.dist
create mode 100644 vendor/symfony/translation/.gitignore
create mode 100644 vendor/symfony/translation/CHANGELOG.md
create mode 100644 vendor/symfony/translation/Catalogue/AbstractOperation.php
create mode 100644 vendor/symfony/translation/Catalogue/MergeOperation.php
create mode 100644 vendor/symfony/translation/Catalogue/OperationInterface.php
create mode 100644 vendor/symfony/translation/Catalogue/TargetOperation.php
create mode 100644 vendor/symfony/translation/Command/XliffLintCommand.php
create mode 100644 vendor/symfony/translation/DataCollector/TranslationDataCollector.php
create mode 100644 vendor/symfony/translation/DataCollectorTranslator.php
create mode 100644 vendor/symfony/translation/DependencyInjection/TranslationDumperPass.php
create mode 100644 vendor/symfony/translation/DependencyInjection/TranslationExtractorPass.php
create mode 100644 vendor/symfony/translation/DependencyInjection/TranslatorPass.php
create mode 100644 vendor/symfony/translation/Dumper/CsvFileDumper.php
create mode 100644 vendor/symfony/translation/Dumper/DumperInterface.php
create mode 100644 vendor/symfony/translation/Dumper/FileDumper.php
create mode 100644 vendor/symfony/translation/Dumper/IcuResFileDumper.php
create mode 100644 vendor/symfony/translation/Dumper/IniFileDumper.php
create mode 100644 vendor/symfony/translation/Dumper/JsonFileDumper.php
create mode 100644 vendor/symfony/translation/Dumper/MoFileDumper.php
create mode 100644 vendor/symfony/translation/Dumper/PhpFileDumper.php
create mode 100644 vendor/symfony/translation/Dumper/PoFileDumper.php
create mode 100644 vendor/symfony/translation/Dumper/QtFileDumper.php
create mode 100644 vendor/symfony/translation/Dumper/XliffFileDumper.php
create mode 100644 vendor/symfony/translation/Dumper/YamlFileDumper.php
create mode 100644 vendor/symfony/translation/Exception/ExceptionInterface.php
create mode 100644 vendor/symfony/translation/Exception/InvalidArgumentException.php
create mode 100644 vendor/symfony/translation/Exception/InvalidResourceException.php
create mode 100644 vendor/symfony/translation/Exception/LogicException.php
create mode 100644 vendor/symfony/translation/Exception/NotFoundResourceException.php
create mode 100644 vendor/symfony/translation/Exception/RuntimeException.php
create mode 100644 vendor/symfony/translation/Extractor/AbstractFileExtractor.php
create mode 100644 vendor/symfony/translation/Extractor/ChainExtractor.php
create mode 100644 vendor/symfony/translation/Extractor/ExtractorInterface.php
create mode 100644 vendor/symfony/translation/Extractor/PhpExtractor.php
create mode 100644 vendor/symfony/translation/Extractor/PhpStringTokenParser.php
create mode 100644 vendor/symfony/translation/Formatter/ChoiceMessageFormatterInterface.php
create mode 100644 vendor/symfony/translation/Formatter/MessageFormatter.php
create mode 100644 vendor/symfony/translation/Formatter/MessageFormatterInterface.php
create mode 100644 vendor/symfony/translation/IdentityTranslator.php
create mode 100644 vendor/symfony/translation/Interval.php
create mode 100644 vendor/symfony/translation/LICENSE
create mode 100644 vendor/symfony/translation/Loader/ArrayLoader.php
create mode 100644 vendor/symfony/translation/Loader/CsvFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/FileLoader.php
create mode 100644 vendor/symfony/translation/Loader/IcuDatFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/IcuResFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/IniFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/JsonFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/LoaderInterface.php
create mode 100644 vendor/symfony/translation/Loader/MoFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/PhpFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/PoFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/QtFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/XliffFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/YamlFileLoader.php
create mode 100644 vendor/symfony/translation/Loader/schema/dic/xliff-core/xliff-core-1.2-strict.xsd
create mode 100644 vendor/symfony/translation/Loader/schema/dic/xliff-core/xliff-core-2.0.xsd
create mode 100644 vendor/symfony/translation/Loader/schema/dic/xliff-core/xml.xsd
create mode 100644 vendor/symfony/translation/LoggingTranslator.php
create mode 100644 vendor/symfony/translation/MessageCatalogue.php
create mode 100644 vendor/symfony/translation/MessageCatalogueInterface.php
create mode 100644 vendor/symfony/translation/MessageSelector.php
create mode 100644 vendor/symfony/translation/MetadataAwareInterface.php
create mode 100644 vendor/symfony/translation/PluralizationRules.php
create mode 100644 vendor/symfony/translation/README.md
create mode 100644 vendor/symfony/translation/Reader/TranslationReader.php
create mode 100644 vendor/symfony/translation/Reader/TranslationReaderInterface.php
create mode 100644 vendor/symfony/translation/Resources/bin/translation-status.php
create mode 100644 vendor/symfony/translation/Resources/schemas/xliff-core-1.2-strict.xsd
create mode 100644 vendor/symfony/translation/Tests/Catalogue/AbstractOperationTest.php
create mode 100644 vendor/symfony/translation/Tests/Catalogue/MergeOperationTest.php
create mode 100644 vendor/symfony/translation/Tests/Catalogue/TargetOperationTest.php
create mode 100644 vendor/symfony/translation/Tests/DataCollector/TranslationDataCollectorTest.php
create mode 100644 vendor/symfony/translation/Tests/DataCollectorTranslatorTest.php
create mode 100644 vendor/symfony/translation/Tests/DependencyInjection/TranslationDumperPassTest.php
create mode 100644 vendor/symfony/translation/Tests/DependencyInjection/TranslationExtractorPassTest.php
create mode 100644 vendor/symfony/translation/Tests/DependencyInjection/TranslationPassTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/CsvFileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/FileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/IcuResFileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/IniFileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/JsonFileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/MoFileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/PhpFileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/PoFileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/QtFileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/XliffFileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Dumper/YamlFileDumperTest.php
create mode 100644 vendor/symfony/translation/Tests/Extractor/PhpExtractorTest.php
create mode 100644 vendor/symfony/translation/Tests/Formatter/MessageFormatterTest.php
create mode 100644 vendor/symfony/translation/Tests/IdentityTranslatorTest.php
create mode 100644 vendor/symfony/translation/Tests/IntervalTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/CsvFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/IcuDatFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/IcuResFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/IniFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/JsonFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/LocalizedTestCase.php
create mode 100644 vendor/symfony/translation/Tests/Loader/MoFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/PhpFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/PoFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/QtFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/XliffFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/Loader/YamlFileLoaderTest.php
create mode 100644 vendor/symfony/translation/Tests/LoggingTranslatorTest.php
create mode 100644 vendor/symfony/translation/Tests/MessageCatalogueTest.php
create mode 100644 vendor/symfony/translation/Tests/MessageSelectorTest.php
create mode 100644 vendor/symfony/translation/Tests/PluralizationRulesTest.php
create mode 100644 vendor/symfony/translation/Tests/TranslatorCacheTest.php
create mode 100644 vendor/symfony/translation/Tests/TranslatorTest.php
create mode 100644 vendor/symfony/translation/Tests/Util/ArrayConverterTest.php
create mode 100644 vendor/symfony/translation/Tests/Writer/TranslationWriterTest.php
create mode 100644 vendor/symfony/translation/Tests/fixtures/empty-translation.mo
create mode 100644 vendor/symfony/translation/Tests/fixtures/empty-translation.po
create mode 100644 vendor/symfony/translation/Tests/fixtures/empty.csv
create mode 100644 vendor/symfony/translation/Tests/fixtures/empty.ini
create mode 100644 vendor/symfony/translation/Tests/fixtures/empty.json
create mode 100644 vendor/symfony/translation/Tests/fixtures/empty.mo
create mode 100644 vendor/symfony/translation/Tests/fixtures/empty.po
create mode 100644 vendor/symfony/translation/Tests/fixtures/empty.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/empty.yml
create mode 100644 vendor/symfony/translation/Tests/fixtures/encoding.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/escaped-id-plurals.po
create mode 100644 vendor/symfony/translation/Tests/fixtures/escaped-id.po
create mode 100644 vendor/symfony/translation/Tests/fixtures/extractor/resource.format.engine
create mode 100644 vendor/symfony/translation/Tests/fixtures/extractor/this.is.a.template.format.engine
create mode 100644 vendor/symfony/translation/Tests/fixtures/extractor/translation.html.php
create mode 100644 vendor/symfony/translation/Tests/fixtures/fuzzy-translations.po
create mode 100644 vendor/symfony/translation/Tests/fixtures/invalid-xml-resources.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/malformed.json
create mode 100644 vendor/symfony/translation/Tests/fixtures/messages.yml
create mode 100644 vendor/symfony/translation/Tests/fixtures/messages_linear.yml
create mode 100644 vendor/symfony/translation/Tests/fixtures/missing-plurals.po
create mode 100644 vendor/symfony/translation/Tests/fixtures/non-valid.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/non-valid.yml
create mode 100644 vendor/symfony/translation/Tests/fixtures/plurals.mo
create mode 100644 vendor/symfony/translation/Tests/fixtures/plurals.po
create mode 100644 vendor/symfony/translation/Tests/fixtures/resname.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/resourcebundle/corrupted/resources.dat
create mode 100644 vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/en.res
create mode 100644 vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/en.txt
create mode 100644 vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/fr.res
create mode 100644 vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/fr.txt
create mode 100644 vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/packagelist.txt
create mode 100644 vendor/symfony/translation/Tests/fixtures/resourcebundle/dat/resources.dat
create mode 100644 vendor/symfony/translation/Tests/fixtures/resourcebundle/res/en.res
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources-2.0-clean.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources-2.0-multi-segment-unit.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources-2.0.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources-clean.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources-notes-meta.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources-target-attributes.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources-tool-info.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources.csv
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources.dump.json
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources.ini
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources.json
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources.mo
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources.php
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources.po
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources.ts
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/resources.yml
create mode 100644 vendor/symfony/translation/Tests/fixtures/valid.csv
create mode 100644 vendor/symfony/translation/Tests/fixtures/with-attributes.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/withdoctype.xlf
create mode 100644 vendor/symfony/translation/Tests/fixtures/withnote.xlf
create mode 100644 vendor/symfony/translation/Translator.php
create mode 100644 vendor/symfony/translation/TranslatorBagInterface.php
create mode 100644 vendor/symfony/translation/TranslatorInterface.php
create mode 100644 vendor/symfony/translation/Util/ArrayConverter.php
create mode 100644 vendor/symfony/translation/Writer/TranslationWriter.php
create mode 100644 vendor/symfony/translation/Writer/TranslationWriterInterface.php
create mode 100644 vendor/symfony/translation/composer.json
create mode 100644 vendor/symfony/translation/phpunit.xml.dist
create mode 100644 vendor/symfony/var-dumper/.gitignore
create mode 100644 vendor/symfony/var-dumper/CHANGELOG.md
create mode 100644 vendor/symfony/var-dumper/Caster/AmqpCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/ArgsStub.php
create mode 100644 vendor/symfony/var-dumper/Caster/Caster.php
create mode 100644 vendor/symfony/var-dumper/Caster/ClassStub.php
create mode 100644 vendor/symfony/var-dumper/Caster/ConstStub.php
create mode 100644 vendor/symfony/var-dumper/Caster/CutArrayStub.php
create mode 100644 vendor/symfony/var-dumper/Caster/CutStub.php
create mode 100644 vendor/symfony/var-dumper/Caster/DOMCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/DateCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/DoctrineCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/EnumStub.php
create mode 100644 vendor/symfony/var-dumper/Caster/ExceptionCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/FrameStub.php
create mode 100644 vendor/symfony/var-dumper/Caster/LinkStub.php
create mode 100644 vendor/symfony/var-dumper/Caster/MongoCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/PdoCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/PgSqlCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/RedisCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/ReflectionCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/ResourceCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/SplCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/StubCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/SymfonyCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/TraceStub.php
create mode 100644 vendor/symfony/var-dumper/Caster/XmlReaderCaster.php
create mode 100644 vendor/symfony/var-dumper/Caster/XmlResourceCaster.php
create mode 100644 vendor/symfony/var-dumper/Cloner/AbstractCloner.php
create mode 100644 vendor/symfony/var-dumper/Cloner/ClonerInterface.php
create mode 100644 vendor/symfony/var-dumper/Cloner/Cursor.php
create mode 100644 vendor/symfony/var-dumper/Cloner/Data.php
create mode 100644 vendor/symfony/var-dumper/Cloner/DumperInterface.php
create mode 100644 vendor/symfony/var-dumper/Cloner/Stub.php
create mode 100644 vendor/symfony/var-dumper/Cloner/VarCloner.php
create mode 100644 vendor/symfony/var-dumper/Dumper/AbstractDumper.php
create mode 100644 vendor/symfony/var-dumper/Dumper/CliDumper.php
create mode 100644 vendor/symfony/var-dumper/Dumper/DataDumperInterface.php
create mode 100644 vendor/symfony/var-dumper/Dumper/HtmlDumper.php
create mode 100644 vendor/symfony/var-dumper/Exception/ThrowingCasterException.php
create mode 100644 vendor/symfony/var-dumper/LICENSE
create mode 100644 vendor/symfony/var-dumper/README.md
create mode 100644 vendor/symfony/var-dumper/Resources/functions/dump.php
create mode 100644 vendor/symfony/var-dumper/Test/VarDumperTestTrait.php
create mode 100644 vendor/symfony/var-dumper/Tests/Caster/CasterTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Caster/DateCasterTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Caster/ExceptionCasterTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Caster/PdoCasterTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Caster/RedisCasterTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Caster/ReflectionCasterTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Caster/SplCasterTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Caster/StubCasterTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Caster/XmlReaderCasterTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Cloner/DataTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Cloner/VarClonerTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Dumper/CliDumperTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Dumper/FunctionsTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Dumper/HtmlDumperTest.php
create mode 100644 vendor/symfony/var-dumper/Tests/Fixtures/DateTimeChild.php
create mode 100644 vendor/symfony/var-dumper/Tests/Fixtures/FooInterface.php
create mode 100644 vendor/symfony/var-dumper/Tests/Fixtures/GeneratorDemo.php
create mode 100644 vendor/symfony/var-dumper/Tests/Fixtures/NotLoadableClass.php
create mode 100644 vendor/symfony/var-dumper/Tests/Fixtures/Php74.php
create mode 100644 vendor/symfony/var-dumper/Tests/Fixtures/Twig.php
create mode 100644 vendor/symfony/var-dumper/Tests/Fixtures/dumb-var.php
create mode 100644 vendor/symfony/var-dumper/Tests/Fixtures/xml_reader.xml
create mode 100644 vendor/symfony/var-dumper/Tests/Test/VarDumperTestTraitTest.php
create mode 100644 vendor/symfony/var-dumper/VarDumper.php
create mode 100644 vendor/symfony/var-dumper/composer.json
create mode 100644 vendor/symfony/var-dumper/phpunit.xml.dist
create mode 100644 vendor/symfony/yaml/.gitignore
create mode 100644 vendor/symfony/yaml/CHANGELOG.md
create mode 100644 vendor/symfony/yaml/Command/LintCommand.php
create mode 100644 vendor/symfony/yaml/Dumper.php
create mode 100644 vendor/symfony/yaml/Escaper.php
create mode 100644 vendor/symfony/yaml/Exception/DumpException.php
create mode 100644 vendor/symfony/yaml/Exception/ExceptionInterface.php
create mode 100644 vendor/symfony/yaml/Exception/ParseException.php
create mode 100644 vendor/symfony/yaml/Exception/RuntimeException.php
create mode 100644 vendor/symfony/yaml/Inline.php
create mode 100644 vendor/symfony/yaml/LICENSE
create mode 100644 vendor/symfony/yaml/Parser.php
create mode 100644 vendor/symfony/yaml/README.md
create mode 100644 vendor/symfony/yaml/Tag/TaggedValue.php
create mode 100644 vendor/symfony/yaml/Tests/Command/LintCommandTest.php
create mode 100644 vendor/symfony/yaml/Tests/DumperTest.php
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/YtsAnchorAlias.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/YtsBasicTests.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/YtsBlockMapping.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/YtsDocumentSeparator.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/YtsErrorTests.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/YtsFlowCollections.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/YtsFoldedScalars.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/YtsNullsAndEmpties.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/YtsSpecificationExamples.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/YtsTypeTransfers.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/arrow.gif
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/booleanMappingKeys.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/embededPhp.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/escapedCharacters.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/index.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/legacyBooleanMappingKeys.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/legacyNonStringKeys.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/legacyNullMappingKey.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/multiple_lines_as_literal_block.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/multiple_lines_as_literal_block_for_tagged_values.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/multiple_lines_as_literal_block_leading_space_in_first_line.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/nonStringKeys.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/not_readable.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/nullMappingKey.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/numericMappingKeys.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/sfComments.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/sfCompact.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/sfMergeKey.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/sfObjects.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/sfQuotes.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/sfTests.yml
create mode 100644 vendor/symfony/yaml/Tests/Fixtures/unindentedCollections.yml
create mode 100644 vendor/symfony/yaml/Tests/InlineTest.php
create mode 100644 vendor/symfony/yaml/Tests/ParseExceptionTest.php
create mode 100644 vendor/symfony/yaml/Tests/ParserTest.php
create mode 100644 vendor/symfony/yaml/Tests/YamlTest.php
create mode 100644 vendor/symfony/yaml/Unescaper.php
create mode 100644 vendor/symfony/yaml/Yaml.php
create mode 100644 vendor/symfony/yaml/composer.json
create mode 100644 vendor/symfony/yaml/phpunit.xml.dist
create mode 100644 vendor/tijsverkoyen/css-to-inline-styles/LICENSE.md
create mode 100644 vendor/tijsverkoyen/css-to-inline-styles/composer.json
create mode 100644 vendor/tijsverkoyen/css-to-inline-styles/src/Css/Processor.php
create mode 100644 vendor/tijsverkoyen/css-to-inline-styles/src/Css/Property/Processor.php
create mode 100644 vendor/tijsverkoyen/css-to-inline-styles/src/Css/Property/Property.php
create mode 100644 vendor/tijsverkoyen/css-to-inline-styles/src/Css/Rule/Processor.php
create mode 100644 vendor/tijsverkoyen/css-to-inline-styles/src/Css/Rule/Rule.php
create mode 100644 vendor/tijsverkoyen/css-to-inline-styles/src/CssToInlineStyles.php
create mode 100644 vendor/vlucas/phpdotenv/LICENSE.txt
create mode 100644 vendor/vlucas/phpdotenv/composer.json
create mode 100644 vendor/vlucas/phpdotenv/src/Dotenv.php
create mode 100644 vendor/vlucas/phpdotenv/src/Exception/ExceptionInterface.php
create mode 100644 vendor/vlucas/phpdotenv/src/Exception/InvalidCallbackException.php
create mode 100644 vendor/vlucas/phpdotenv/src/Exception/InvalidFileException.php
create mode 100644 vendor/vlucas/phpdotenv/src/Exception/InvalidPathException.php
create mode 100644 vendor/vlucas/phpdotenv/src/Exception/ValidationException.php
create mode 100644 vendor/vlucas/phpdotenv/src/Loader.php
create mode 100644 vendor/vlucas/phpdotenv/src/Parser.php
create mode 100644 vendor/vlucas/phpdotenv/src/Validator.php
create mode 100644 vendor/webmozart/assert/.editorconfig
create mode 100644 vendor/webmozart/assert/CHANGELOG.md
create mode 100644 vendor/webmozart/assert/LICENSE
create mode 100644 vendor/webmozart/assert/README.md
create mode 100644 vendor/webmozart/assert/composer.json
create mode 100644 vendor/webmozart/assert/psalm.xml
create mode 100644 vendor/webmozart/assert/src/Assert.php
create mode 100644 vendor/webmozart/assert/src/Mixin.php
diff --git a/.env b/.env
new file mode 100644
index 000000000..9fb01c324
--- /dev/null
+++ b/.env
@@ -0,0 +1,33 @@
+APP_NAME=Laravel
+APP_ENV=local
+APP_KEY=base64:uZ2MpBEC0cZHefJMbQlFhgT8ZIcNKyYRPyBOGWyr0R4=
+APP_DEBUG=true
+APP_LOG_LEVEL=debug
+APP_URL=http://localhost
+
+DB_CONNECTION=mysql
+DB_HOST=127.0.0.1
+DB_PORT=3306
+DB_DATABASE=laravel_test_1
+DB_USERNAME=root
+DB_PASSWORD=
+
+BROADCAST_DRIVER=log
+CACHE_DRIVER=file
+SESSION_DRIVER=file
+QUEUE_DRIVER=sync
+
+REDIS_HOST=127.0.0.1
+REDIS_PASSWORD=null
+REDIS_PORT=6379
+
+MAIL_DRIVER=smtp
+MAIL_HOST=smtp.mailtrap.io
+MAIL_PORT=2525
+MAIL_USERNAME=null
+MAIL_PASSWORD=null
+MAIL_ENCRYPTION=null
+
+PUSHER_APP_ID=
+PUSHER_APP_KEY=
+PUSHER_APP_SECRET=
diff --git a/bootstrap/cache/services.php b/bootstrap/cache/services.php
new file mode 100644
index 000000000..7fccd266a
--- /dev/null
+++ b/bootstrap/cache/services.php
@@ -0,0 +1,184 @@
+
+ array (
+ 0 => 'Illuminate\\Auth\\AuthServiceProvider',
+ 1 => 'Illuminate\\Broadcasting\\BroadcastServiceProvider',
+ 2 => 'Illuminate\\Bus\\BusServiceProvider',
+ 3 => 'Illuminate\\Cache\\CacheServiceProvider',
+ 4 => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 5 => 'Illuminate\\Cookie\\CookieServiceProvider',
+ 6 => 'Illuminate\\Database\\DatabaseServiceProvider',
+ 7 => 'Illuminate\\Encryption\\EncryptionServiceProvider',
+ 8 => 'Illuminate\\Filesystem\\FilesystemServiceProvider',
+ 9 => 'Illuminate\\Foundation\\Providers\\FoundationServiceProvider',
+ 10 => 'Illuminate\\Hashing\\HashServiceProvider',
+ 11 => 'Illuminate\\Mail\\MailServiceProvider',
+ 12 => 'Illuminate\\Notifications\\NotificationServiceProvider',
+ 13 => 'Illuminate\\Pagination\\PaginationServiceProvider',
+ 14 => 'Illuminate\\Pipeline\\PipelineServiceProvider',
+ 15 => 'Illuminate\\Queue\\QueueServiceProvider',
+ 16 => 'Illuminate\\Redis\\RedisServiceProvider',
+ 17 => 'Illuminate\\Auth\\Passwords\\PasswordResetServiceProvider',
+ 18 => 'Illuminate\\Session\\SessionServiceProvider',
+ 19 => 'Illuminate\\Translation\\TranslationServiceProvider',
+ 20 => 'Illuminate\\Validation\\ValidationServiceProvider',
+ 21 => 'Illuminate\\View\\ViewServiceProvider',
+ 22 => 'Laravel\\Tinker\\TinkerServiceProvider',
+ 23 => 'App\\Providers\\AppServiceProvider',
+ 24 => 'App\\Providers\\AuthServiceProvider',
+ 25 => 'App\\Providers\\EventServiceProvider',
+ 26 => 'App\\Providers\\RouteServiceProvider',
+ ),
+ 'eager' =>
+ array (
+ 0 => 'Illuminate\\Auth\\AuthServiceProvider',
+ 1 => 'Illuminate\\Cookie\\CookieServiceProvider',
+ 2 => 'Illuminate\\Database\\DatabaseServiceProvider',
+ 3 => 'Illuminate\\Encryption\\EncryptionServiceProvider',
+ 4 => 'Illuminate\\Filesystem\\FilesystemServiceProvider',
+ 5 => 'Illuminate\\Foundation\\Providers\\FoundationServiceProvider',
+ 6 => 'Illuminate\\Notifications\\NotificationServiceProvider',
+ 7 => 'Illuminate\\Pagination\\PaginationServiceProvider',
+ 8 => 'Illuminate\\Session\\SessionServiceProvider',
+ 9 => 'Illuminate\\View\\ViewServiceProvider',
+ 10 => 'App\\Providers\\AppServiceProvider',
+ 11 => 'App\\Providers\\AuthServiceProvider',
+ 12 => 'App\\Providers\\EventServiceProvider',
+ 13 => 'App\\Providers\\RouteServiceProvider',
+ ),
+ 'deferred' =>
+ array (
+ 'Illuminate\\Broadcasting\\BroadcastManager' => 'Illuminate\\Broadcasting\\BroadcastServiceProvider',
+ 'Illuminate\\Contracts\\Broadcasting\\Factory' => 'Illuminate\\Broadcasting\\BroadcastServiceProvider',
+ 'Illuminate\\Contracts\\Broadcasting\\Broadcaster' => 'Illuminate\\Broadcasting\\BroadcastServiceProvider',
+ 'Illuminate\\Bus\\Dispatcher' => 'Illuminate\\Bus\\BusServiceProvider',
+ 'Illuminate\\Contracts\\Bus\\Dispatcher' => 'Illuminate\\Bus\\BusServiceProvider',
+ 'Illuminate\\Contracts\\Bus\\QueueingDispatcher' => 'Illuminate\\Bus\\BusServiceProvider',
+ 'cache' => 'Illuminate\\Cache\\CacheServiceProvider',
+ 'cache.store' => 'Illuminate\\Cache\\CacheServiceProvider',
+ 'memcached.connector' => 'Illuminate\\Cache\\CacheServiceProvider',
+ 'command.cache.clear' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.cache.forget' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.clear-compiled' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.auth.resets.clear' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.config.cache' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.config.clear' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.down' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.environment' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.key.generate' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.migrate' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.migrate.install' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.migrate.refresh' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.migrate.reset' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.migrate.rollback' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.migrate.status' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.optimize' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.queue.failed' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.queue.flush' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.queue.forget' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.queue.listen' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.queue.restart' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.queue.retry' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.queue.work' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.route.cache' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.route.clear' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.route.list' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.seed' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'Illuminate\\Console\\Scheduling\\ScheduleFinishCommand' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'Illuminate\\Console\\Scheduling\\ScheduleRunCommand' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.storage.link' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.up' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.view.clear' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.app.name' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.auth.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.cache.table' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.console.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.controller.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.event.generate' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.event.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.job.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.listener.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.mail.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.middleware.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.migrate.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.model.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.notification.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.notification.table' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.policy.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.provider.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.queue.failed-table' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.queue.table' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.request.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.seeder.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.session.table' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.serve' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.test.make' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'command.vendor.publish' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'migrator' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'migration.repository' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'migration.creator' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'composer' => 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider',
+ 'hash' => 'Illuminate\\Hashing\\HashServiceProvider',
+ 'mailer' => 'Illuminate\\Mail\\MailServiceProvider',
+ 'swift.mailer' => 'Illuminate\\Mail\\MailServiceProvider',
+ 'swift.transport' => 'Illuminate\\Mail\\MailServiceProvider',
+ 'Illuminate\\Mail\\Markdown' => 'Illuminate\\Mail\\MailServiceProvider',
+ 'Illuminate\\Contracts\\Pipeline\\Hub' => 'Illuminate\\Pipeline\\PipelineServiceProvider',
+ 'queue' => 'Illuminate\\Queue\\QueueServiceProvider',
+ 'queue.worker' => 'Illuminate\\Queue\\QueueServiceProvider',
+ 'queue.listener' => 'Illuminate\\Queue\\QueueServiceProvider',
+ 'queue.failer' => 'Illuminate\\Queue\\QueueServiceProvider',
+ 'queue.connection' => 'Illuminate\\Queue\\QueueServiceProvider',
+ 'redis' => 'Illuminate\\Redis\\RedisServiceProvider',
+ 'redis.connection' => 'Illuminate\\Redis\\RedisServiceProvider',
+ 'auth.password' => 'Illuminate\\Auth\\Passwords\\PasswordResetServiceProvider',
+ 'auth.password.broker' => 'Illuminate\\Auth\\Passwords\\PasswordResetServiceProvider',
+ 'translator' => 'Illuminate\\Translation\\TranslationServiceProvider',
+ 'translation.loader' => 'Illuminate\\Translation\\TranslationServiceProvider',
+ 'validator' => 'Illuminate\\Validation\\ValidationServiceProvider',
+ 'validation.presence' => 'Illuminate\\Validation\\ValidationServiceProvider',
+ 'command.tinker' => 'Laravel\\Tinker\\TinkerServiceProvider',
+ ),
+ 'when' =>
+ array (
+ 'Illuminate\\Broadcasting\\BroadcastServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Bus\\BusServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Cache\\CacheServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Hashing\\HashServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Mail\\MailServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Pipeline\\PipelineServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Queue\\QueueServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Redis\\RedisServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Auth\\Passwords\\PasswordResetServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Translation\\TranslationServiceProvider' =>
+ array (
+ ),
+ 'Illuminate\\Validation\\ValidationServiceProvider' =>
+ array (
+ ),
+ 'Laravel\\Tinker\\TinkerServiceProvider' =>
+ array (
+ ),
+ ),
+);
\ No newline at end of file
diff --git a/resources/views/create.blade.php b/resources/views/create.blade.php
new file mode 100644
index 000000000..90f598d52
--- /dev/null
+++ b/resources/views/create.blade.php
@@ -0,0 +1,31 @@
+
+
+
+
+ Event
+
+
+
+ Create Event
+
+
+
diff --git a/resources/views/edit.blade.php b/resources/views/edit.blade.php
new file mode 100644
index 000000000..6e70eecaa
--- /dev/null
+++ b/resources/views/edit.blade.php
@@ -0,0 +1,32 @@
+
+
+
+
+ Event
+
+
+
+ Edit Event
+
+
+
\ No newline at end of file
diff --git a/resources/views/event.blade.php b/resources/views/event.blade.php
new file mode 100644
index 000000000..cc08a65c5
--- /dev/null
+++ b/resources/views/event.blade.php
@@ -0,0 +1,35 @@
+
+
+
+
+ Event
+
+
+
+
+
+
+ ID
+ {{ $event->id }}
+
+
+ Name
+ {{ $event->name }}
+
+
+ Slug
+ {{ $event->slug }}
+
+
+ Created At
+ {{ $event->created_at }}
+
+
+ Updated At
+ {{ $event->updated_at }}
+
+
+
+ Back to events
+
+
\ No newline at end of file
diff --git a/resources/views/events.blade.php b/resources/views/events.blade.php
new file mode 100644
index 000000000..fd0c6123e
--- /dev/null
+++ b/resources/views/events.blade.php
@@ -0,0 +1,37 @@
+
+
+
+
+ Events
+
+
+
+
+
+
+ ID
+ Name
+ Slug
+ Created At
+ Updated At
+ Actions
+
+
+
+ @foreach ($events as $event)
+
+ {{ $event->id }}
+ {{ $event->name }}
+ {{ $event->slug }}
+ {{ $event->created_at }}
+ {{ $event->updated_at }}
+
+ >Edit
+ Delete
+
+
+ @endforeach
+
+
+
+
\ No newline at end of file
diff --git a/storage/logs/laravel.log b/storage/logs/laravel.log
new file mode 100644
index 000000000..e69de29bb
diff --git a/vendor/autoload.php b/vendor/autoload.php
new file mode 100644
index 000000000..2cb8a1fa8
--- /dev/null
+++ b/vendor/autoload.php
@@ -0,0 +1,7 @@
+ /dev/null; cd "../nikic/php-parser/bin" && pwd)
+
+if [ -d /proc/cygdrive ]; then
+ case $(which php) in
+ $(readlink -n /proc/cygdrive)/*)
+ # We are in Cygwin using Windows php, so the path must be translated
+ dir=$(cygpath -m "$dir");
+ ;;
+ esac
+fi
+
+"${dir}/php-parse" "$@"
diff --git a/vendor/bin/php-parse.bat b/vendor/bin/php-parse.bat
new file mode 100644
index 000000000..a5baa4eda
--- /dev/null
+++ b/vendor/bin/php-parse.bat
@@ -0,0 +1,4 @@
+@ECHO OFF
+setlocal DISABLEDELAYEDEXPANSION
+SET BIN_TARGET=%~dp0/../nikic/php-parser/bin/php-parse
+php "%BIN_TARGET%" %*
diff --git a/vendor/bin/phpunit b/vendor/bin/phpunit
new file mode 100644
index 000000000..990f1947c
--- /dev/null
+++ b/vendor/bin/phpunit
@@ -0,0 +1,14 @@
+#!/usr/bin/env sh
+
+dir=$(cd "${0%[/\\]*}" > /dev/null; cd "../phpunit/phpunit" && pwd)
+
+if [ -d /proc/cygdrive ]; then
+ case $(which php) in
+ $(readlink -n /proc/cygdrive)/*)
+ # We are in Cygwin using Windows php, so the path must be translated
+ dir=$(cygpath -m "$dir");
+ ;;
+ esac
+fi
+
+"${dir}/phpunit" "$@"
diff --git a/vendor/bin/phpunit.bat b/vendor/bin/phpunit.bat
new file mode 100644
index 000000000..b17792348
--- /dev/null
+++ b/vendor/bin/phpunit.bat
@@ -0,0 +1,4 @@
+@ECHO OFF
+setlocal DISABLEDELAYEDEXPANSION
+SET BIN_TARGET=%~dp0/../phpunit/phpunit/phpunit
+php "%BIN_TARGET%" %*
diff --git a/vendor/bin/psysh b/vendor/bin/psysh
new file mode 100644
index 000000000..3331cd0c3
--- /dev/null
+++ b/vendor/bin/psysh
@@ -0,0 +1,14 @@
+#!/usr/bin/env sh
+
+dir=$(cd "${0%[/\\]*}" > /dev/null; cd "../psy/psysh/bin" && pwd)
+
+if [ -d /proc/cygdrive ]; then
+ case $(which php) in
+ $(readlink -n /proc/cygdrive)/*)
+ # We are in Cygwin using Windows php, so the path must be translated
+ dir=$(cygpath -m "$dir");
+ ;;
+ esac
+fi
+
+"${dir}/psysh" "$@"
diff --git a/vendor/bin/psysh.bat b/vendor/bin/psysh.bat
new file mode 100644
index 000000000..b27592f3d
--- /dev/null
+++ b/vendor/bin/psysh.bat
@@ -0,0 +1,4 @@
+@ECHO OFF
+setlocal DISABLEDELAYEDEXPANSION
+SET BIN_TARGET=%~dp0/../psy/psysh/bin/psysh
+php "%BIN_TARGET%" %*
diff --git a/vendor/bin/upgrade-carbon b/vendor/bin/upgrade-carbon
new file mode 100644
index 000000000..00f27f40d
--- /dev/null
+++ b/vendor/bin/upgrade-carbon
@@ -0,0 +1,14 @@
+#!/usr/bin/env sh
+
+dir=$(cd "${0%[/\\]*}" > /dev/null; cd "../nesbot/carbon/bin" && pwd)
+
+if [ -d /proc/cygdrive ]; then
+ case $(which php) in
+ $(readlink -n /proc/cygdrive)/*)
+ # We are in Cygwin using Windows php, so the path must be translated
+ dir=$(cygpath -m "$dir");
+ ;;
+ esac
+fi
+
+"${dir}/upgrade-carbon" "$@"
diff --git a/vendor/bin/upgrade-carbon.bat b/vendor/bin/upgrade-carbon.bat
new file mode 100644
index 000000000..a6372b27d
--- /dev/null
+++ b/vendor/bin/upgrade-carbon.bat
@@ -0,0 +1,4 @@
+@ECHO OFF
+setlocal DISABLEDELAYEDEXPANSION
+SET BIN_TARGET=%~dp0/../nesbot/carbon/bin/upgrade-carbon
+php "%BIN_TARGET%" %*
diff --git a/vendor/composer/ClassLoader.php b/vendor/composer/ClassLoader.php
new file mode 100644
index 000000000..1a58957d2
--- /dev/null
+++ b/vendor/composer/ClassLoader.php
@@ -0,0 +1,445 @@
+
+ * Jordi Boggiano
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Composer\Autoload;
+
+/**
+ * ClassLoader implements a PSR-0, PSR-4 and classmap class loader.
+ *
+ * $loader = new \Composer\Autoload\ClassLoader();
+ *
+ * // register classes with namespaces
+ * $loader->add('Symfony\Component', __DIR__.'/component');
+ * $loader->add('Symfony', __DIR__.'/framework');
+ *
+ * // activate the autoloader
+ * $loader->register();
+ *
+ * // to enable searching the include path (eg. for PEAR packages)
+ * $loader->setUseIncludePath(true);
+ *
+ * In this example, if you try to use a class in the Symfony\Component
+ * namespace or one of its children (Symfony\Component\Console for instance),
+ * the autoloader will first look for the class under the component/
+ * directory, and it will then fallback to the framework/ directory if not
+ * found before giving up.
+ *
+ * This class is loosely based on the Symfony UniversalClassLoader.
+ *
+ * @author Fabien Potencier
+ * @author Jordi Boggiano
+ * @see https://www.php-fig.org/psr/psr-0/
+ * @see https://www.php-fig.org/psr/psr-4/
+ */
+class ClassLoader
+{
+ // PSR-4
+ private $prefixLengthsPsr4 = array();
+ private $prefixDirsPsr4 = array();
+ private $fallbackDirsPsr4 = array();
+
+ // PSR-0
+ private $prefixesPsr0 = array();
+ private $fallbackDirsPsr0 = array();
+
+ private $useIncludePath = false;
+ private $classMap = array();
+ private $classMapAuthoritative = false;
+ private $missingClasses = array();
+ private $apcuPrefix;
+
+ public function getPrefixes()
+ {
+ if (!empty($this->prefixesPsr0)) {
+ return call_user_func_array('array_merge', array_values($this->prefixesPsr0));
+ }
+
+ return array();
+ }
+
+ public function getPrefixesPsr4()
+ {
+ return $this->prefixDirsPsr4;
+ }
+
+ public function getFallbackDirs()
+ {
+ return $this->fallbackDirsPsr0;
+ }
+
+ public function getFallbackDirsPsr4()
+ {
+ return $this->fallbackDirsPsr4;
+ }
+
+ public function getClassMap()
+ {
+ return $this->classMap;
+ }
+
+ /**
+ * @param array $classMap Class to filename map
+ */
+ public function addClassMap(array $classMap)
+ {
+ if ($this->classMap) {
+ $this->classMap = array_merge($this->classMap, $classMap);
+ } else {
+ $this->classMap = $classMap;
+ }
+ }
+
+ /**
+ * Registers a set of PSR-0 directories for a given prefix, either
+ * appending or prepending to the ones previously set for this prefix.
+ *
+ * @param string $prefix The prefix
+ * @param array|string $paths The PSR-0 root directories
+ * @param bool $prepend Whether to prepend the directories
+ */
+ public function add($prefix, $paths, $prepend = false)
+ {
+ if (!$prefix) {
+ if ($prepend) {
+ $this->fallbackDirsPsr0 = array_merge(
+ (array) $paths,
+ $this->fallbackDirsPsr0
+ );
+ } else {
+ $this->fallbackDirsPsr0 = array_merge(
+ $this->fallbackDirsPsr0,
+ (array) $paths
+ );
+ }
+
+ return;
+ }
+
+ $first = $prefix[0];
+ if (!isset($this->prefixesPsr0[$first][$prefix])) {
+ $this->prefixesPsr0[$first][$prefix] = (array) $paths;
+
+ return;
+ }
+ if ($prepend) {
+ $this->prefixesPsr0[$first][$prefix] = array_merge(
+ (array) $paths,
+ $this->prefixesPsr0[$first][$prefix]
+ );
+ } else {
+ $this->prefixesPsr0[$first][$prefix] = array_merge(
+ $this->prefixesPsr0[$first][$prefix],
+ (array) $paths
+ );
+ }
+ }
+
+ /**
+ * Registers a set of PSR-4 directories for a given namespace, either
+ * appending or prepending to the ones previously set for this namespace.
+ *
+ * @param string $prefix The prefix/namespace, with trailing '\\'
+ * @param array|string $paths The PSR-4 base directories
+ * @param bool $prepend Whether to prepend the directories
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function addPsr4($prefix, $paths, $prepend = false)
+ {
+ if (!$prefix) {
+ // Register directories for the root namespace.
+ if ($prepend) {
+ $this->fallbackDirsPsr4 = array_merge(
+ (array) $paths,
+ $this->fallbackDirsPsr4
+ );
+ } else {
+ $this->fallbackDirsPsr4 = array_merge(
+ $this->fallbackDirsPsr4,
+ (array) $paths
+ );
+ }
+ } elseif (!isset($this->prefixDirsPsr4[$prefix])) {
+ // Register directories for a new namespace.
+ $length = strlen($prefix);
+ if ('\\' !== $prefix[$length - 1]) {
+ throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
+ }
+ $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
+ $this->prefixDirsPsr4[$prefix] = (array) $paths;
+ } elseif ($prepend) {
+ // Prepend directories for an already registered namespace.
+ $this->prefixDirsPsr4[$prefix] = array_merge(
+ (array) $paths,
+ $this->prefixDirsPsr4[$prefix]
+ );
+ } else {
+ // Append directories for an already registered namespace.
+ $this->prefixDirsPsr4[$prefix] = array_merge(
+ $this->prefixDirsPsr4[$prefix],
+ (array) $paths
+ );
+ }
+ }
+
+ /**
+ * Registers a set of PSR-0 directories for a given prefix,
+ * replacing any others previously set for this prefix.
+ *
+ * @param string $prefix The prefix
+ * @param array|string $paths The PSR-0 base directories
+ */
+ public function set($prefix, $paths)
+ {
+ if (!$prefix) {
+ $this->fallbackDirsPsr0 = (array) $paths;
+ } else {
+ $this->prefixesPsr0[$prefix[0]][$prefix] = (array) $paths;
+ }
+ }
+
+ /**
+ * Registers a set of PSR-4 directories for a given namespace,
+ * replacing any others previously set for this namespace.
+ *
+ * @param string $prefix The prefix/namespace, with trailing '\\'
+ * @param array|string $paths The PSR-4 base directories
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function setPsr4($prefix, $paths)
+ {
+ if (!$prefix) {
+ $this->fallbackDirsPsr4 = (array) $paths;
+ } else {
+ $length = strlen($prefix);
+ if ('\\' !== $prefix[$length - 1]) {
+ throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
+ }
+ $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
+ $this->prefixDirsPsr4[$prefix] = (array) $paths;
+ }
+ }
+
+ /**
+ * Turns on searching the include path for class files.
+ *
+ * @param bool $useIncludePath
+ */
+ public function setUseIncludePath($useIncludePath)
+ {
+ $this->useIncludePath = $useIncludePath;
+ }
+
+ /**
+ * Can be used to check if the autoloader uses the include path to check
+ * for classes.
+ *
+ * @return bool
+ */
+ public function getUseIncludePath()
+ {
+ return $this->useIncludePath;
+ }
+
+ /**
+ * Turns off searching the prefix and fallback directories for classes
+ * that have not been registered with the class map.
+ *
+ * @param bool $classMapAuthoritative
+ */
+ public function setClassMapAuthoritative($classMapAuthoritative)
+ {
+ $this->classMapAuthoritative = $classMapAuthoritative;
+ }
+
+ /**
+ * Should class lookup fail if not found in the current class map?
+ *
+ * @return bool
+ */
+ public function isClassMapAuthoritative()
+ {
+ return $this->classMapAuthoritative;
+ }
+
+ /**
+ * APCu prefix to use to cache found/not-found classes, if the extension is enabled.
+ *
+ * @param string|null $apcuPrefix
+ */
+ public function setApcuPrefix($apcuPrefix)
+ {
+ $this->apcuPrefix = function_exists('apcu_fetch') && filter_var(ini_get('apc.enabled'), FILTER_VALIDATE_BOOLEAN) ? $apcuPrefix : null;
+ }
+
+ /**
+ * The APCu prefix in use, or null if APCu caching is not enabled.
+ *
+ * @return string|null
+ */
+ public function getApcuPrefix()
+ {
+ return $this->apcuPrefix;
+ }
+
+ /**
+ * Registers this instance as an autoloader.
+ *
+ * @param bool $prepend Whether to prepend the autoloader or not
+ */
+ public function register($prepend = false)
+ {
+ spl_autoload_register(array($this, 'loadClass'), true, $prepend);
+ }
+
+ /**
+ * Unregisters this instance as an autoloader.
+ */
+ public function unregister()
+ {
+ spl_autoload_unregister(array($this, 'loadClass'));
+ }
+
+ /**
+ * Loads the given class or interface.
+ *
+ * @param string $class The name of the class
+ * @return bool|null True if loaded, null otherwise
+ */
+ public function loadClass($class)
+ {
+ if ($file = $this->findFile($class)) {
+ includeFile($file);
+
+ return true;
+ }
+ }
+
+ /**
+ * Finds the path to the file where the class is defined.
+ *
+ * @param string $class The name of the class
+ *
+ * @return string|false The path if found, false otherwise
+ */
+ public function findFile($class)
+ {
+ // class map lookup
+ if (isset($this->classMap[$class])) {
+ return $this->classMap[$class];
+ }
+ if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) {
+ return false;
+ }
+ if (null !== $this->apcuPrefix) {
+ $file = apcu_fetch($this->apcuPrefix.$class, $hit);
+ if ($hit) {
+ return $file;
+ }
+ }
+
+ $file = $this->findFileWithExtension($class, '.php');
+
+ // Search for Hack files if we are running on HHVM
+ if (false === $file && defined('HHVM_VERSION')) {
+ $file = $this->findFileWithExtension($class, '.hh');
+ }
+
+ if (null !== $this->apcuPrefix) {
+ apcu_add($this->apcuPrefix.$class, $file);
+ }
+
+ if (false === $file) {
+ // Remember that this class does not exist.
+ $this->missingClasses[$class] = true;
+ }
+
+ return $file;
+ }
+
+ private function findFileWithExtension($class, $ext)
+ {
+ // PSR-4 lookup
+ $logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext;
+
+ $first = $class[0];
+ if (isset($this->prefixLengthsPsr4[$first])) {
+ $subPath = $class;
+ while (false !== $lastPos = strrpos($subPath, '\\')) {
+ $subPath = substr($subPath, 0, $lastPos);
+ $search = $subPath . '\\';
+ if (isset($this->prefixDirsPsr4[$search])) {
+ $pathEnd = DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $lastPos + 1);
+ foreach ($this->prefixDirsPsr4[$search] as $dir) {
+ if (file_exists($file = $dir . $pathEnd)) {
+ return $file;
+ }
+ }
+ }
+ }
+ }
+
+ // PSR-4 fallback dirs
+ foreach ($this->fallbackDirsPsr4 as $dir) {
+ if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) {
+ return $file;
+ }
+ }
+
+ // PSR-0 lookup
+ if (false !== $pos = strrpos($class, '\\')) {
+ // namespaced class name
+ $logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1)
+ . strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR);
+ } else {
+ // PEAR-like class name
+ $logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext;
+ }
+
+ if (isset($this->prefixesPsr0[$first])) {
+ foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) {
+ if (0 === strpos($class, $prefix)) {
+ foreach ($dirs as $dir) {
+ if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
+ return $file;
+ }
+ }
+ }
+ }
+ }
+
+ // PSR-0 fallback dirs
+ foreach ($this->fallbackDirsPsr0 as $dir) {
+ if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
+ return $file;
+ }
+ }
+
+ // PSR-0 include paths.
+ if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) {
+ return $file;
+ }
+
+ return false;
+ }
+}
+
+/**
+ * Scope isolated include.
+ *
+ * Prevents access to $this/self from included files.
+ */
+function includeFile($file)
+{
+ include $file;
+}
diff --git a/vendor/composer/InstalledVersions.php b/vendor/composer/InstalledVersions.php
new file mode 100644
index 000000000..05d633981
--- /dev/null
+++ b/vendor/composer/InstalledVersions.php
@@ -0,0 +1,1041 @@
+
+ array (
+ 'pretty_version' => 'v5.4.30',
+ 'version' => '5.4.30.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => NULL,
+ 'name' => 'laravel/laravel',
+ ),
+ 'versions' =>
+ array (
+ 'cordoval/hamcrest-php' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => '*',
+ ),
+ ),
+ 'davedevelopment/hamcrest-php' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => '*',
+ ),
+ ),
+ 'dnoegel/php-xdg-base-dir' =>
+ array (
+ 'pretty_version' => 'v0.1.1',
+ 'version' => '0.1.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '8f8a6e48c5ecb0f991c2fdcf5f154a47d85f9ffd',
+ ),
+ 'doctrine/inflector' =>
+ array (
+ 'pretty_version' => 'v1.1.0',
+ 'version' => '1.1.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '90b2128806bfde671b6952ab8bea493942c1fdae',
+ ),
+ 'doctrine/instantiator' =>
+ array (
+ 'pretty_version' => '1.0.5',
+ 'version' => '1.0.5.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '8e884e78f9f0eb1329e445619e04456e64d8051d',
+ ),
+ 'erusev/parsedown' =>
+ array (
+ 'pretty_version' => '1.7.4',
+ 'version' => '1.7.4.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'cb17b6477dfff935958ba01325f2e8a2bfa6dab3',
+ ),
+ 'fzaninotto/faker' =>
+ array (
+ 'pretty_version' => 'v1.9.2',
+ 'version' => '1.9.2.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '848d8125239d7dbf8ab25cb7f054f1a630e68c2e',
+ ),
+ 'hamcrest/hamcrest-php' =>
+ array (
+ 'pretty_version' => 'v1.2.2',
+ 'version' => '1.2.2.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b37020aa976fa52d3de9aa904aa2522dc518f79c',
+ ),
+ 'illuminate/auth' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/broadcasting' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/bus' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/cache' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/config' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/console' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/container' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/contracts' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/cookie' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/database' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/encryption' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/events' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/exception' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/filesystem' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/hashing' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/http' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/log' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/mail' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/notifications' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/pagination' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/pipeline' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/queue' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/redis' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/routing' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/session' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/support' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/translation' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/validation' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/view' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'jakub-onderka/php-console-color' =>
+ array (
+ 'pretty_version' => 'v0.2',
+ 'version' => '0.2.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'd5deaecff52a0d61ccb613bb3804088da0307191',
+ ),
+ 'jakub-onderka/php-console-highlighter' =>
+ array (
+ 'pretty_version' => 'v0.4',
+ 'version' => '0.4.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '9f7a229a69d52506914b4bc61bfdb199d90c5547',
+ ),
+ 'kodova/hamcrest-php' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => '*',
+ ),
+ ),
+ 'kylekatarnls/update-helper' =>
+ array (
+ 'pretty_version' => '1.2.1',
+ 'version' => '1.2.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '429be50660ed8a196e0798e5939760f168ec8ce9',
+ ),
+ 'laravel/framework' =>
+ array (
+ 'pretty_version' => 'v5.4.36',
+ 'version' => '5.4.36.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '1062a22232071c3e8636487c86ec1ae75681bbf9',
+ ),
+ 'laravel/laravel' =>
+ array (
+ 'pretty_version' => 'v5.4.30',
+ 'version' => '5.4.30.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => NULL,
+ ),
+ 'laravel/tinker' =>
+ array (
+ 'pretty_version' => 'v1.0.10',
+ 'version' => '1.0.10.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ad571aacbac1539c30d480908f9d0c9614eaf1a7',
+ ),
+ 'league/flysystem' =>
+ array (
+ 'pretty_version' => '1.0.70',
+ 'version' => '1.0.70.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '585824702f534f8d3cf7fab7225e8466cc4b7493',
+ ),
+ 'mockery/mockery' =>
+ array (
+ 'pretty_version' => '0.9.11',
+ 'version' => '0.9.11.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'be9bf28d8e57d67883cba9fcadfcff8caab667f8',
+ ),
+ 'monolog/monolog' =>
+ array (
+ 'pretty_version' => '1.27.1',
+ 'version' => '1.27.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '904713c5929655dc9b97288b69cfeedad610c9a1',
+ ),
+ 'mtdowling/cron-expression' =>
+ array (
+ 'pretty_version' => 'v1.2.3',
+ 'version' => '1.2.3.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '9be552eebcc1ceec9776378f7dcc085246cacca6',
+ ),
+ 'myclabs/deep-copy' =>
+ array (
+ 'pretty_version' => '1.7.0',
+ 'version' => '1.7.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '3b8a3a99ba1f6a3952ac2747d989303cbd6b7a3e',
+ ),
+ 'nesbot/carbon' =>
+ array (
+ 'pretty_version' => '1.39.1',
+ 'version' => '1.39.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '4be0c005164249208ce1b5ca633cd57bdd42ff33',
+ ),
+ 'nikic/php-parser' =>
+ array (
+ 'pretty_version' => 'v3.1.5',
+ 'version' => '3.1.5.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'bb87e28e7d7b8d9a7fda231d37457c9210faf6ce',
+ ),
+ 'paragonie/random_compat' =>
+ array (
+ 'pretty_version' => 'v2.0.21',
+ 'version' => '2.0.21.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '96c132c7f2f7bc3230723b66e89f8f150b29d5ae',
+ ),
+ 'phpdocumentor/reflection-common' =>
+ array (
+ 'pretty_version' => '1.0.1',
+ 'version' => '1.0.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '21bdeb5f65d7ebf9f43b1b25d404f87deab5bfb6',
+ ),
+ 'phpdocumentor/reflection-docblock' =>
+ array (
+ 'pretty_version' => '3.3.2',
+ 'version' => '3.3.2.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'bf329f6c1aadea3299f08ee804682b7c45b326a2',
+ ),
+ 'phpdocumentor/type-resolver' =>
+ array (
+ 'pretty_version' => '0.4.0',
+ 'version' => '0.4.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '9c977708995954784726e25d0cd1dddf4e65b0f7',
+ ),
+ 'phpspec/prophecy' =>
+ array (
+ 'pretty_version' => 'v1.10.3',
+ 'version' => '1.10.3.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '451c3cd1418cf640de218914901e51b064abb093',
+ ),
+ 'phpunit/php-code-coverage' =>
+ array (
+ 'pretty_version' => '4.0.8',
+ 'version' => '4.0.8.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ef7b2f56815df854e66ceaee8ebe9393ae36a40d',
+ ),
+ 'phpunit/php-file-iterator' =>
+ array (
+ 'pretty_version' => '1.4.5',
+ 'version' => '1.4.5.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '730b01bc3e867237eaac355e06a36b85dd93a8b4',
+ ),
+ 'phpunit/php-text-template' =>
+ array (
+ 'pretty_version' => '1.2.1',
+ 'version' => '1.2.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '31f8b717e51d9a2afca6c9f046f5d69fc27c8686',
+ ),
+ 'phpunit/php-timer' =>
+ array (
+ 'pretty_version' => '1.0.9',
+ 'version' => '1.0.9.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '3dcf38ca72b158baf0bc245e9184d3fdffa9c46f',
+ ),
+ 'phpunit/php-token-stream' =>
+ array (
+ 'pretty_version' => '1.4.12',
+ 'version' => '1.4.12.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '1ce90ba27c42e4e44e6d8458241466380b51fa16',
+ ),
+ 'phpunit/phpunit' =>
+ array (
+ 'pretty_version' => '5.7.27',
+ 'version' => '5.7.27.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b7803aeca3ccb99ad0a506fa80b64cd6a56bbc0c',
+ ),
+ 'phpunit/phpunit-mock-objects' =>
+ array (
+ 'pretty_version' => '3.4.4',
+ 'version' => '3.4.4.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'a23b761686d50a560cc56233b9ecf49597cc9118',
+ ),
+ 'psr/log' =>
+ array (
+ 'pretty_version' => '1.1.4',
+ 'version' => '1.1.4.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'd49695b909c3b7628b6289db5479a1c204601f11',
+ ),
+ 'psr/log-implementation' =>
+ array (
+ 'provided' =>
+ array (
+ 0 => '1.0',
+ 1 => '1.0.0',
+ ),
+ ),
+ 'psy/psysh' =>
+ array (
+ 'pretty_version' => 'v0.9.12',
+ 'version' => '0.9.12.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '90da7f37568aee36b116a030c5f99c915267edd4',
+ ),
+ 'ramsey/uuid' =>
+ array (
+ 'pretty_version' => '3.9.7',
+ 'version' => '3.9.7.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'dc75aa439eb4c1b77f5379fd958b3dc0e6014178',
+ ),
+ 'rhumsaa/uuid' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => '3.9.7',
+ ),
+ ),
+ 'sebastian/code-unit-reverse-lookup' =>
+ array (
+ 'pretty_version' => '1.0.2',
+ 'version' => '1.0.2.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '1de8cd5c010cb153fcd68b8d0f64606f523f7619',
+ ),
+ 'sebastian/comparator' =>
+ array (
+ 'pretty_version' => '1.2.4',
+ 'version' => '1.2.4.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '2b7424b55f5047b47ac6e5ccb20b2aea4011d9be',
+ ),
+ 'sebastian/diff' =>
+ array (
+ 'pretty_version' => '1.4.3',
+ 'version' => '1.4.3.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '7f066a26a962dbe58ddea9f72a4e82874a3975a4',
+ ),
+ 'sebastian/environment' =>
+ array (
+ 'pretty_version' => '2.0.0',
+ 'version' => '2.0.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '5795ffe5dc5b02460c3e34222fee8cbe245d8fac',
+ ),
+ 'sebastian/exporter' =>
+ array (
+ 'pretty_version' => '2.0.0',
+ 'version' => '2.0.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ce474bdd1a34744d7ac5d6aad3a46d48d9bac4c4',
+ ),
+ 'sebastian/global-state' =>
+ array (
+ 'pretty_version' => '1.1.1',
+ 'version' => '1.1.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'bc37d50fea7d017d3d340f230811c9f1d7280af4',
+ ),
+ 'sebastian/object-enumerator' =>
+ array (
+ 'pretty_version' => '2.0.1',
+ 'version' => '2.0.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '1311872ac850040a79c3c058bea3e22d0f09cbb7',
+ ),
+ 'sebastian/recursion-context' =>
+ array (
+ 'pretty_version' => '2.0.0',
+ 'version' => '2.0.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '2c3ba150cbec723aa057506e73a8d33bdb286c9a',
+ ),
+ 'sebastian/resource-operations' =>
+ array (
+ 'pretty_version' => '1.0.0',
+ 'version' => '1.0.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ce990bb21759f94aeafd30209e8cfcdfa8bc3f52',
+ ),
+ 'sebastian/version' =>
+ array (
+ 'pretty_version' => '2.0.1',
+ 'version' => '2.0.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '99732be0ddb3361e16ad77b68ba41efc8e979019',
+ ),
+ 'swiftmailer/swiftmailer' =>
+ array (
+ 'pretty_version' => 'v5.4.12',
+ 'version' => '5.4.12.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '181b89f18a90f8925ef805f950d47a7190e9b950',
+ ),
+ 'symfony/console' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'a10b1da6fc93080c180bba7219b5ff5b7518fe81',
+ ),
+ 'symfony/css-selector' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'da3d9da2ce0026771f5fe64cb332158f1bd2bc33',
+ ),
+ 'symfony/debug' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ab42889de57fdfcfcc0759ab102e2fd4ea72dcae',
+ ),
+ 'symfony/event-dispatcher' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '31fde73757b6bad247c54597beef974919ec6860',
+ ),
+ 'symfony/finder' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b6b6ad3db3edb1b4b1c1896b1975fb684994de6e',
+ ),
+ 'symfony/http-foundation' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b9885fcce6fe494201da4f70a9309770e9d13dc8',
+ ),
+ 'symfony/http-kernel' =>
+ array (
+ 'pretty_version' => 'v3.4.49',
+ 'version' => '3.4.49.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '5aa72405f5bd5583c36ed6e756acb17d3f98ac40',
+ ),
+ 'symfony/polyfill-ctype' =>
+ array (
+ 'pretty_version' => 'v1.19.0',
+ 'version' => '1.19.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'aed596913b70fae57be53d86faa2e9ef85a2297b',
+ ),
+ 'symfony/polyfill-mbstring' =>
+ array (
+ 'pretty_version' => 'v1.19.0',
+ 'version' => '1.19.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b5f7b932ee6fa802fc792eabd77c4c88084517ce',
+ ),
+ 'symfony/polyfill-php56' =>
+ array (
+ 'pretty_version' => 'v1.19.0',
+ 'version' => '1.19.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ea19621731cbd973a6702cfedef3419768bf3372',
+ ),
+ 'symfony/polyfill-php70' =>
+ array (
+ 'pretty_version' => 'v1.19.0',
+ 'version' => '1.19.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '3fe414077251a81a1b15b1c709faf5c2fbae3d4e',
+ ),
+ 'symfony/polyfill-util' =>
+ array (
+ 'pretty_version' => 'v1.19.0',
+ 'version' => '1.19.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '8df0c3e6a4b85df9a5c6f3f2f46fba5c5c47058a',
+ ),
+ 'symfony/process' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b8648cf1d5af12a44a51d07ef9bf980921f15fca',
+ ),
+ 'symfony/routing' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '3e522ac69cadffd8131cc2b22157fa7662331a6c',
+ ),
+ 'symfony/translation' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'be83ee6c065cb32becdb306ba61160d598b1ce88',
+ ),
+ 'symfony/var-dumper' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '0719f6cf4633a38b2c1585140998579ce23b4b7d',
+ ),
+ 'symfony/yaml' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '88289caa3c166321883f67fe5130188ebbb47094',
+ ),
+ 'tightenco/collect' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'tijsverkoyen/css-to-inline-styles' =>
+ array (
+ 'pretty_version' => '2.2.6',
+ 'version' => '2.2.6.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'c42125b83a4fa63b187fdf29f9c93cb7733da30c',
+ ),
+ 'vlucas/phpdotenv' =>
+ array (
+ 'pretty_version' => 'v2.6.9',
+ 'version' => '2.6.9.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '2e93cc98e2e8e869f8d9cfa61bb3a99ba4fc4141',
+ ),
+ 'webmozart/assert' =>
+ array (
+ 'pretty_version' => '1.9.1',
+ 'version' => '1.9.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'bafc69caeb4d49c39fd0779086c03a3738cbb389',
+ ),
+ ),
+);
+
+
+
+
+
+
+
+public static function getInstalledPackages()
+{
+return array_keys(self::$installed['versions']);
+}
+
+
+
+
+
+
+
+
+
+public static function isInstalled($packageName)
+{
+return isset(self::$installed['versions'][$packageName]);
+}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+public static function satisfies(VersionParser $parser, $packageName, $constraint)
+{
+$constraint = $parser->parseConstraints($constraint);
+$provided = $parser->parseConstraints(self::getVersionRanges($packageName));
+
+return $provided->matches($constraint);
+}
+
+
+
+
+
+
+
+
+
+
+public static function getVersionRanges($packageName)
+{
+if (!isset(self::$installed['versions'][$packageName])) {
+throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
+}
+
+$ranges = array();
+if (isset(self::$installed['versions'][$packageName]['pretty_version'])) {
+$ranges[] = self::$installed['versions'][$packageName]['pretty_version'];
+}
+if (array_key_exists('aliases', self::$installed['versions'][$packageName])) {
+$ranges = array_merge($ranges, self::$installed['versions'][$packageName]['aliases']);
+}
+if (array_key_exists('replaced', self::$installed['versions'][$packageName])) {
+$ranges = array_merge($ranges, self::$installed['versions'][$packageName]['replaced']);
+}
+if (array_key_exists('provided', self::$installed['versions'][$packageName])) {
+$ranges = array_merge($ranges, self::$installed['versions'][$packageName]['provided']);
+}
+
+return implode(' || ', $ranges);
+}
+
+
+
+
+
+public static function getVersion($packageName)
+{
+if (!isset(self::$installed['versions'][$packageName])) {
+throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
+}
+
+if (!isset(self::$installed['versions'][$packageName]['version'])) {
+return null;
+}
+
+return self::$installed['versions'][$packageName]['version'];
+}
+
+
+
+
+
+public static function getPrettyVersion($packageName)
+{
+if (!isset(self::$installed['versions'][$packageName])) {
+throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
+}
+
+if (!isset(self::$installed['versions'][$packageName]['pretty_version'])) {
+return null;
+}
+
+return self::$installed['versions'][$packageName]['pretty_version'];
+}
+
+
+
+
+
+public static function getReference($packageName)
+{
+if (!isset(self::$installed['versions'][$packageName])) {
+throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
+}
+
+if (!isset(self::$installed['versions'][$packageName]['reference'])) {
+return null;
+}
+
+return self::$installed['versions'][$packageName]['reference'];
+}
+
+
+
+
+
+public static function getRootPackage()
+{
+return self::$installed['root'];
+}
+
+
+
+
+
+
+
+public static function getRawData()
+{
+return self::$installed;
+}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+public static function reload($data)
+{
+self::$installed = $data;
+}
+}
diff --git a/vendor/composer/LICENSE b/vendor/composer/LICENSE
new file mode 100644
index 000000000..f27399a04
--- /dev/null
+++ b/vendor/composer/LICENSE
@@ -0,0 +1,21 @@
+
+Copyright (c) Nils Adermann, Jordi Boggiano
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is furnished
+to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
+
diff --git a/vendor/composer/autoload_classmap.php b/vendor/composer/autoload_classmap.php
new file mode 100644
index 000000000..d835c8e6e
--- /dev/null
+++ b/vendor/composer/autoload_classmap.php
@@ -0,0 +1,3152 @@
+ $baseDir . '/app/Console/Kernel.php',
+ 'App\\Event' => $baseDir . '/app/Event.php',
+ 'App\\Exceptions\\Handler' => $baseDir . '/app/Exceptions/Handler.php',
+ 'App\\Http\\Controllers\\Auth\\ForgotPasswordController' => $baseDir . '/app/Http/Controllers/Auth/ForgotPasswordController.php',
+ 'App\\Http\\Controllers\\Auth\\LoginController' => $baseDir . '/app/Http/Controllers/Auth/LoginController.php',
+ 'App\\Http\\Controllers\\Auth\\RegisterController' => $baseDir . '/app/Http/Controllers/Auth/RegisterController.php',
+ 'App\\Http\\Controllers\\Auth\\ResetPasswordController' => $baseDir . '/app/Http/Controllers/Auth/ResetPasswordController.php',
+ 'App\\Http\\Controllers\\Controller' => $baseDir . '/app/Http/Controllers/Controller.php',
+ 'App\\Http\\Controllers\\EventController' => $baseDir . '/app/Http/Controllers/EventController.php',
+ 'App\\Http\\Kernel' => $baseDir . '/app/Http/Kernel.php',
+ 'App\\Http\\Middleware\\EncryptCookies' => $baseDir . '/app/Http/Middleware/EncryptCookies.php',
+ 'App\\Http\\Middleware\\RedirectIfAuthenticated' => $baseDir . '/app/Http/Middleware/RedirectIfAuthenticated.php',
+ 'App\\Http\\Middleware\\TrimStrings' => $baseDir . '/app/Http/Middleware/TrimStrings.php',
+ 'App\\Http\\Middleware\\VerifyCsrfToken' => $baseDir . '/app/Http/Middleware/VerifyCsrfToken.php',
+ 'App\\Providers\\AppServiceProvider' => $baseDir . '/app/Providers/AppServiceProvider.php',
+ 'App\\Providers\\AuthServiceProvider' => $baseDir . '/app/Providers/AuthServiceProvider.php',
+ 'App\\Providers\\BroadcastServiceProvider' => $baseDir . '/app/Providers/BroadcastServiceProvider.php',
+ 'App\\Providers\\EventServiceProvider' => $baseDir . '/app/Providers/EventServiceProvider.php',
+ 'App\\Providers\\RouteServiceProvider' => $baseDir . '/app/Providers/RouteServiceProvider.php',
+ 'App\\User' => $baseDir . '/app/User.php',
+ 'ArithmeticError' => $vendorDir . '/symfony/polyfill-php70/Resources/stubs/ArithmeticError.php',
+ 'AssertionError' => $vendorDir . '/symfony/polyfill-php70/Resources/stubs/AssertionError.php',
+ 'Carbon\\Carbon' => $vendorDir . '/nesbot/carbon/src/Carbon/Carbon.php',
+ 'Carbon\\CarbonInterval' => $vendorDir . '/nesbot/carbon/src/Carbon/CarbonInterval.php',
+ 'Carbon\\CarbonPeriod' => $vendorDir . '/nesbot/carbon/src/Carbon/CarbonPeriod.php',
+ 'Carbon\\Exceptions\\InvalidDateException' => $vendorDir . '/nesbot/carbon/src/Carbon/Exceptions/InvalidDateException.php',
+ 'Carbon\\Laravel\\ServiceProvider' => $vendorDir . '/nesbot/carbon/src/Carbon/Laravel/ServiceProvider.php',
+ 'Carbon\\Translator' => $vendorDir . '/nesbot/carbon/src/Carbon/Translator.php',
+ 'Carbon\\Upgrade' => $vendorDir . '/nesbot/carbon/src/Carbon/Upgrade.php',
+ 'Composer\\InstalledVersions' => $vendorDir . '/composer/InstalledVersions.php',
+ 'CreateEventsTable' => $baseDir . '/database/migrations/2023_02_11_013624_create_events_table.php',
+ 'CreatePasswordResetsTable' => $baseDir . '/database/migrations/2014_10_12_100000_create_password_resets_table.php',
+ 'CreateUsersTable' => $baseDir . '/database/migrations/2014_10_12_000000_create_users_table.php',
+ 'Cron\\AbstractField' => $vendorDir . '/mtdowling/cron-expression/src/Cron/AbstractField.php',
+ 'Cron\\CronExpression' => $vendorDir . '/mtdowling/cron-expression/src/Cron/CronExpression.php',
+ 'Cron\\DayOfMonthField' => $vendorDir . '/mtdowling/cron-expression/src/Cron/DayOfMonthField.php',
+ 'Cron\\DayOfWeekField' => $vendorDir . '/mtdowling/cron-expression/src/Cron/DayOfWeekField.php',
+ 'Cron\\FieldFactory' => $vendorDir . '/mtdowling/cron-expression/src/Cron/FieldFactory.php',
+ 'Cron\\FieldInterface' => $vendorDir . '/mtdowling/cron-expression/src/Cron/FieldInterface.php',
+ 'Cron\\HoursField' => $vendorDir . '/mtdowling/cron-expression/src/Cron/HoursField.php',
+ 'Cron\\MinutesField' => $vendorDir . '/mtdowling/cron-expression/src/Cron/MinutesField.php',
+ 'Cron\\MonthField' => $vendorDir . '/mtdowling/cron-expression/src/Cron/MonthField.php',
+ 'Cron\\YearField' => $vendorDir . '/mtdowling/cron-expression/src/Cron/YearField.php',
+ 'DatabaseSeeder' => $baseDir . '/database/seeds/DatabaseSeeder.php',
+ 'DeepCopy\\DeepCopy' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/DeepCopy.php',
+ 'DeepCopy\\Exception\\CloneException' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Exception/CloneException.php',
+ 'DeepCopy\\Exception\\PropertyException' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Exception/PropertyException.php',
+ 'DeepCopy\\Filter\\Doctrine\\DoctrineCollectionFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Filter/Doctrine/DoctrineCollectionFilter.php',
+ 'DeepCopy\\Filter\\Doctrine\\DoctrineEmptyCollectionFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Filter/Doctrine/DoctrineEmptyCollectionFilter.php',
+ 'DeepCopy\\Filter\\Doctrine\\DoctrineProxyFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Filter/Doctrine/DoctrineProxyFilter.php',
+ 'DeepCopy\\Filter\\Filter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Filter/Filter.php',
+ 'DeepCopy\\Filter\\KeepFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Filter/KeepFilter.php',
+ 'DeepCopy\\Filter\\ReplaceFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Filter/ReplaceFilter.php',
+ 'DeepCopy\\Filter\\SetNullFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Filter/SetNullFilter.php',
+ 'DeepCopy\\Matcher\\Doctrine\\DoctrineProxyMatcher' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Matcher/Doctrine/DoctrineProxyMatcher.php',
+ 'DeepCopy\\Matcher\\Matcher' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Matcher/Matcher.php',
+ 'DeepCopy\\Matcher\\PropertyMatcher' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Matcher/PropertyMatcher.php',
+ 'DeepCopy\\Matcher\\PropertyNameMatcher' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Matcher/PropertyNameMatcher.php',
+ 'DeepCopy\\Matcher\\PropertyTypeMatcher' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Matcher/PropertyTypeMatcher.php',
+ 'DeepCopy\\Reflection\\ReflectionHelper' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/Reflection/ReflectionHelper.php',
+ 'DeepCopy\\TypeFilter\\Date\\DateIntervalFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/Date/DateIntervalFilter.php',
+ 'DeepCopy\\TypeFilter\\ReplaceFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/ReplaceFilter.php',
+ 'DeepCopy\\TypeFilter\\ShallowCopyFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/ShallowCopyFilter.php',
+ 'DeepCopy\\TypeFilter\\Spl\\SplDoublyLinkedList' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/Spl/SplDoublyLinkedList.php',
+ 'DeepCopy\\TypeFilter\\Spl\\SplDoublyLinkedListFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/Spl/SplDoublyLinkedListFilter.php',
+ 'DeepCopy\\TypeFilter\\TypeFilter' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/TypeFilter.php',
+ 'DeepCopy\\TypeMatcher\\TypeMatcher' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/TypeMatcher/TypeMatcher.php',
+ 'DivisionByZeroError' => $vendorDir . '/symfony/polyfill-php70/Resources/stubs/DivisionByZeroError.php',
+ 'Doctrine\\Common\\Inflector\\Inflector' => $vendorDir . '/doctrine/inflector/lib/Doctrine/Common/Inflector/Inflector.php',
+ 'Doctrine\\Instantiator\\Exception\\ExceptionInterface' => $vendorDir . '/doctrine/instantiator/src/Doctrine/Instantiator/Exception/ExceptionInterface.php',
+ 'Doctrine\\Instantiator\\Exception\\InvalidArgumentException' => $vendorDir . '/doctrine/instantiator/src/Doctrine/Instantiator/Exception/InvalidArgumentException.php',
+ 'Doctrine\\Instantiator\\Exception\\UnexpectedValueException' => $vendorDir . '/doctrine/instantiator/src/Doctrine/Instantiator/Exception/UnexpectedValueException.php',
+ 'Doctrine\\Instantiator\\Instantiator' => $vendorDir . '/doctrine/instantiator/src/Doctrine/Instantiator/Instantiator.php',
+ 'Doctrine\\Instantiator\\InstantiatorInterface' => $vendorDir . '/doctrine/instantiator/src/Doctrine/Instantiator/InstantiatorInterface.php',
+ 'Dotenv\\Dotenv' => $vendorDir . '/vlucas/phpdotenv/src/Dotenv.php',
+ 'Dotenv\\Exception\\ExceptionInterface' => $vendorDir . '/vlucas/phpdotenv/src/Exception/ExceptionInterface.php',
+ 'Dotenv\\Exception\\InvalidCallbackException' => $vendorDir . '/vlucas/phpdotenv/src/Exception/InvalidCallbackException.php',
+ 'Dotenv\\Exception\\InvalidFileException' => $vendorDir . '/vlucas/phpdotenv/src/Exception/InvalidFileException.php',
+ 'Dotenv\\Exception\\InvalidPathException' => $vendorDir . '/vlucas/phpdotenv/src/Exception/InvalidPathException.php',
+ 'Dotenv\\Exception\\ValidationException' => $vendorDir . '/vlucas/phpdotenv/src/Exception/ValidationException.php',
+ 'Dotenv\\Loader' => $vendorDir . '/vlucas/phpdotenv/src/Loader.php',
+ 'Dotenv\\Parser' => $vendorDir . '/vlucas/phpdotenv/src/Parser.php',
+ 'Dotenv\\Validator' => $vendorDir . '/vlucas/phpdotenv/src/Validator.php',
+ 'Error' => $vendorDir . '/symfony/polyfill-php70/Resources/stubs/Error.php',
+ 'EventSeeder' => $baseDir . '/database/seeds/EventSeeder.php',
+ 'Faker\\Calculator\\Ean' => $vendorDir . '/fzaninotto/faker/src/Faker/Calculator/Ean.php',
+ 'Faker\\Calculator\\Iban' => $vendorDir . '/fzaninotto/faker/src/Faker/Calculator/Iban.php',
+ 'Faker\\Calculator\\Inn' => $vendorDir . '/fzaninotto/faker/src/Faker/Calculator/Inn.php',
+ 'Faker\\Calculator\\Luhn' => $vendorDir . '/fzaninotto/faker/src/Faker/Calculator/Luhn.php',
+ 'Faker\\Calculator\\TCNo' => $vendorDir . '/fzaninotto/faker/src/Faker/Calculator/TCNo.php',
+ 'Faker\\DefaultGenerator' => $vendorDir . '/fzaninotto/faker/src/Faker/DefaultGenerator.php',
+ 'Faker\\Documentor' => $vendorDir . '/fzaninotto/faker/src/Faker/Documentor.php',
+ 'Faker\\Factory' => $vendorDir . '/fzaninotto/faker/src/Faker/Factory.php',
+ 'Faker\\Generator' => $vendorDir . '/fzaninotto/faker/src/Faker/Generator.php',
+ 'Faker\\Guesser\\Name' => $vendorDir . '/fzaninotto/faker/src/Faker/Guesser/Name.php',
+ 'Faker\\ORM\\CakePHP\\ColumnTypeGuesser' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/CakePHP/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\CakePHP\\EntityPopulator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/CakePHP/EntityPopulator.php',
+ 'Faker\\ORM\\CakePHP\\Populator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/CakePHP/Populator.php',
+ 'Faker\\ORM\\Doctrine\\ColumnTypeGuesser' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Doctrine/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\Doctrine\\EntityPopulator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Doctrine/EntityPopulator.php',
+ 'Faker\\ORM\\Doctrine\\Populator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Doctrine/Populator.php',
+ 'Faker\\ORM\\Mandango\\ColumnTypeGuesser' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Mandango/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\Mandango\\EntityPopulator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Mandango/EntityPopulator.php',
+ 'Faker\\ORM\\Mandango\\Populator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Mandango/Populator.php',
+ 'Faker\\ORM\\Propel2\\ColumnTypeGuesser' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Propel2/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\Propel2\\EntityPopulator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Propel2/EntityPopulator.php',
+ 'Faker\\ORM\\Propel2\\Populator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Propel2/Populator.php',
+ 'Faker\\ORM\\Propel\\ColumnTypeGuesser' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Propel/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\Propel\\EntityPopulator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Propel/EntityPopulator.php',
+ 'Faker\\ORM\\Propel\\Populator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Propel/Populator.php',
+ 'Faker\\ORM\\Spot\\ColumnTypeGuesser' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Spot/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\Spot\\EntityPopulator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Spot/EntityPopulator.php',
+ 'Faker\\ORM\\Spot\\Populator' => $vendorDir . '/fzaninotto/faker/src/Faker/ORM/Spot/Populator.php',
+ 'Faker\\Provider\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Address.php',
+ 'Faker\\Provider\\Barcode' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Barcode.php',
+ 'Faker\\Provider\\Base' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Base.php',
+ 'Faker\\Provider\\Biased' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Biased.php',
+ 'Faker\\Provider\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Color.php',
+ 'Faker\\Provider\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Company.php',
+ 'Faker\\Provider\\DateTime' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/DateTime.php',
+ 'Faker\\Provider\\File' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/File.php',
+ 'Faker\\Provider\\HtmlLorem' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/HtmlLorem.php',
+ 'Faker\\Provider\\Image' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Image.php',
+ 'Faker\\Provider\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Internet.php',
+ 'Faker\\Provider\\Lorem' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Lorem.php',
+ 'Faker\\Provider\\Miscellaneous' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Miscellaneous.php',
+ 'Faker\\Provider\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Payment.php',
+ 'Faker\\Provider\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Person.php',
+ 'Faker\\Provider\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/PhoneNumber.php',
+ 'Faker\\Provider\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Text.php',
+ 'Faker\\Provider\\UserAgent' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/UserAgent.php',
+ 'Faker\\Provider\\Uuid' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/Uuid.php',
+ 'Faker\\Provider\\ar_JO\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_JO/Address.php',
+ 'Faker\\Provider\\ar_JO\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_JO/Company.php',
+ 'Faker\\Provider\\ar_JO\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_JO/Internet.php',
+ 'Faker\\Provider\\ar_JO\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_JO/Person.php',
+ 'Faker\\Provider\\ar_JO\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_JO/Text.php',
+ 'Faker\\Provider\\ar_SA\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Address.php',
+ 'Faker\\Provider\\ar_SA\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Color.php',
+ 'Faker\\Provider\\ar_SA\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Company.php',
+ 'Faker\\Provider\\ar_SA\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Internet.php',
+ 'Faker\\Provider\\ar_SA\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Payment.php',
+ 'Faker\\Provider\\ar_SA\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Person.php',
+ 'Faker\\Provider\\ar_SA\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Text.php',
+ 'Faker\\Provider\\at_AT\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/at_AT/Payment.php',
+ 'Faker\\Provider\\bg_BG\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/bg_BG/Internet.php',
+ 'Faker\\Provider\\bg_BG\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/bg_BG/Payment.php',
+ 'Faker\\Provider\\bg_BG\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/bg_BG/Person.php',
+ 'Faker\\Provider\\bg_BG\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/bg_BG/PhoneNumber.php',
+ 'Faker\\Provider\\bn_BD\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/bn_BD/Address.php',
+ 'Faker\\Provider\\bn_BD\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/bn_BD/Company.php',
+ 'Faker\\Provider\\bn_BD\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/bn_BD/Person.php',
+ 'Faker\\Provider\\bn_BD\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/bn_BD/PhoneNumber.php',
+ 'Faker\\Provider\\bn_BD\\Utils' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/bn_BD/Utils.php',
+ 'Faker\\Provider\\cs_CZ\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/Address.php',
+ 'Faker\\Provider\\cs_CZ\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/Company.php',
+ 'Faker\\Provider\\cs_CZ\\DateTime' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/DateTime.php',
+ 'Faker\\Provider\\cs_CZ\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/Internet.php',
+ 'Faker\\Provider\\cs_CZ\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/Payment.php',
+ 'Faker\\Provider\\cs_CZ\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/Person.php',
+ 'Faker\\Provider\\cs_CZ\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/PhoneNumber.php',
+ 'Faker\\Provider\\da_DK\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/da_DK/Address.php',
+ 'Faker\\Provider\\da_DK\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/da_DK/Company.php',
+ 'Faker\\Provider\\da_DK\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/da_DK/Internet.php',
+ 'Faker\\Provider\\da_DK\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/da_DK/Payment.php',
+ 'Faker\\Provider\\da_DK\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/da_DK/Person.php',
+ 'Faker\\Provider\\da_DK\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/da_DK/PhoneNumber.php',
+ 'Faker\\Provider\\de_AT\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_AT/Address.php',
+ 'Faker\\Provider\\de_AT\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_AT/Company.php',
+ 'Faker\\Provider\\de_AT\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_AT/Internet.php',
+ 'Faker\\Provider\\de_AT\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_AT/Payment.php',
+ 'Faker\\Provider\\de_AT\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_AT/Person.php',
+ 'Faker\\Provider\\de_AT\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_AT/PhoneNumber.php',
+ 'Faker\\Provider\\de_AT\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_AT/Text.php',
+ 'Faker\\Provider\\de_CH\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_CH/Address.php',
+ 'Faker\\Provider\\de_CH\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_CH/Company.php',
+ 'Faker\\Provider\\de_CH\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_CH/Internet.php',
+ 'Faker\\Provider\\de_CH\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_CH/Payment.php',
+ 'Faker\\Provider\\de_CH\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_CH/Person.php',
+ 'Faker\\Provider\\de_CH\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_CH/PhoneNumber.php',
+ 'Faker\\Provider\\de_CH\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_CH/Text.php',
+ 'Faker\\Provider\\de_DE\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_DE/Address.php',
+ 'Faker\\Provider\\de_DE\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_DE/Company.php',
+ 'Faker\\Provider\\de_DE\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_DE/Internet.php',
+ 'Faker\\Provider\\de_DE\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_DE/Payment.php',
+ 'Faker\\Provider\\de_DE\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_DE/Person.php',
+ 'Faker\\Provider\\de_DE\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_DE/PhoneNumber.php',
+ 'Faker\\Provider\\de_DE\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/de_DE/Text.php',
+ 'Faker\\Provider\\el_CY\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_CY/Address.php',
+ 'Faker\\Provider\\el_CY\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_CY/Company.php',
+ 'Faker\\Provider\\el_CY\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_CY/Internet.php',
+ 'Faker\\Provider\\el_CY\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_CY/Payment.php',
+ 'Faker\\Provider\\el_CY\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_CY/Person.php',
+ 'Faker\\Provider\\el_CY\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_CY/PhoneNumber.php',
+ 'Faker\\Provider\\el_GR\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_GR/Address.php',
+ 'Faker\\Provider\\el_GR\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_GR/Company.php',
+ 'Faker\\Provider\\el_GR\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_GR/Payment.php',
+ 'Faker\\Provider\\el_GR\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_GR/Person.php',
+ 'Faker\\Provider\\el_GR\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/el_GR/PhoneNumber.php',
+ 'Faker\\Provider\\en_AU\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_AU/Address.php',
+ 'Faker\\Provider\\en_AU\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_AU/Internet.php',
+ 'Faker\\Provider\\en_AU\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_AU/PhoneNumber.php',
+ 'Faker\\Provider\\en_CA\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_CA/Address.php',
+ 'Faker\\Provider\\en_CA\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_CA/PhoneNumber.php',
+ 'Faker\\Provider\\en_GB\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_GB/Address.php',
+ 'Faker\\Provider\\en_GB\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_GB/Internet.php',
+ 'Faker\\Provider\\en_GB\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_GB/Payment.php',
+ 'Faker\\Provider\\en_GB\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_GB/Person.php',
+ 'Faker\\Provider\\en_GB\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_GB/PhoneNumber.php',
+ 'Faker\\Provider\\en_HK\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_HK/Address.php',
+ 'Faker\\Provider\\en_HK\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_HK/Internet.php',
+ 'Faker\\Provider\\en_HK\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_HK/PhoneNumber.php',
+ 'Faker\\Provider\\en_IN\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_IN/Address.php',
+ 'Faker\\Provider\\en_IN\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_IN/Internet.php',
+ 'Faker\\Provider\\en_IN\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_IN/Person.php',
+ 'Faker\\Provider\\en_IN\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_IN/PhoneNumber.php',
+ 'Faker\\Provider\\en_NG\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_NG/Address.php',
+ 'Faker\\Provider\\en_NG\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_NG/Internet.php',
+ 'Faker\\Provider\\en_NG\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_NG/Person.php',
+ 'Faker\\Provider\\en_NG\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_NG/PhoneNumber.php',
+ 'Faker\\Provider\\en_NZ\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_NZ/Address.php',
+ 'Faker\\Provider\\en_NZ\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_NZ/Internet.php',
+ 'Faker\\Provider\\en_NZ\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_NZ/PhoneNumber.php',
+ 'Faker\\Provider\\en_PH\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_PH/Address.php',
+ 'Faker\\Provider\\en_PH\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_PH/PhoneNumber.php',
+ 'Faker\\Provider\\en_SG\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_SG/Address.php',
+ 'Faker\\Provider\\en_SG\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_SG/PhoneNumber.php',
+ 'Faker\\Provider\\en_UG\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_UG/Address.php',
+ 'Faker\\Provider\\en_UG\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_UG/Internet.php',
+ 'Faker\\Provider\\en_UG\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_UG/Person.php',
+ 'Faker\\Provider\\en_UG\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_UG/PhoneNumber.php',
+ 'Faker\\Provider\\en_US\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_US/Address.php',
+ 'Faker\\Provider\\en_US\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_US/Company.php',
+ 'Faker\\Provider\\en_US\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_US/Payment.php',
+ 'Faker\\Provider\\en_US\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_US/Person.php',
+ 'Faker\\Provider\\en_US\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_US/PhoneNumber.php',
+ 'Faker\\Provider\\en_US\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_US/Text.php',
+ 'Faker\\Provider\\en_ZA\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_ZA/Address.php',
+ 'Faker\\Provider\\en_ZA\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_ZA/Company.php',
+ 'Faker\\Provider\\en_ZA\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_ZA/Internet.php',
+ 'Faker\\Provider\\en_ZA\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_ZA/Person.php',
+ 'Faker\\Provider\\en_ZA\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/en_ZA/PhoneNumber.php',
+ 'Faker\\Provider\\es_AR\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_AR/Address.php',
+ 'Faker\\Provider\\es_AR\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_AR/Company.php',
+ 'Faker\\Provider\\es_AR\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_AR/Person.php',
+ 'Faker\\Provider\\es_AR\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_AR/PhoneNumber.php',
+ 'Faker\\Provider\\es_ES\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_ES/Address.php',
+ 'Faker\\Provider\\es_ES\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_ES/Color.php',
+ 'Faker\\Provider\\es_ES\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_ES/Company.php',
+ 'Faker\\Provider\\es_ES\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_ES/Internet.php',
+ 'Faker\\Provider\\es_ES\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_ES/Payment.php',
+ 'Faker\\Provider\\es_ES\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_ES/Person.php',
+ 'Faker\\Provider\\es_ES\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_ES/PhoneNumber.php',
+ 'Faker\\Provider\\es_PE\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_PE/Address.php',
+ 'Faker\\Provider\\es_PE\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_PE/Company.php',
+ 'Faker\\Provider\\es_PE\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_PE/Person.php',
+ 'Faker\\Provider\\es_PE\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_PE/PhoneNumber.php',
+ 'Faker\\Provider\\es_VE\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_VE/Address.php',
+ 'Faker\\Provider\\es_VE\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_VE/Company.php',
+ 'Faker\\Provider\\es_VE\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_VE/Internet.php',
+ 'Faker\\Provider\\es_VE\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_VE/Person.php',
+ 'Faker\\Provider\\es_VE\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/es_VE/PhoneNumber.php',
+ 'Faker\\Provider\\et_EE\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/et_EE/Person.php',
+ 'Faker\\Provider\\fa_IR\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fa_IR/Address.php',
+ 'Faker\\Provider\\fa_IR\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fa_IR/Company.php',
+ 'Faker\\Provider\\fa_IR\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fa_IR/Internet.php',
+ 'Faker\\Provider\\fa_IR\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fa_IR/Person.php',
+ 'Faker\\Provider\\fa_IR\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fa_IR/PhoneNumber.php',
+ 'Faker\\Provider\\fa_IR\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fa_IR/Text.php',
+ 'Faker\\Provider\\fi_FI\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fi_FI/Address.php',
+ 'Faker\\Provider\\fi_FI\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fi_FI/Company.php',
+ 'Faker\\Provider\\fi_FI\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fi_FI/Internet.php',
+ 'Faker\\Provider\\fi_FI\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fi_FI/Payment.php',
+ 'Faker\\Provider\\fi_FI\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fi_FI/Person.php',
+ 'Faker\\Provider\\fi_FI\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fi_FI/PhoneNumber.php',
+ 'Faker\\Provider\\fr_BE\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_BE/Address.php',
+ 'Faker\\Provider\\fr_BE\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_BE/Company.php',
+ 'Faker\\Provider\\fr_BE\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_BE/Internet.php',
+ 'Faker\\Provider\\fr_BE\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_BE/Payment.php',
+ 'Faker\\Provider\\fr_BE\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_BE/Person.php',
+ 'Faker\\Provider\\fr_BE\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_BE/PhoneNumber.php',
+ 'Faker\\Provider\\fr_CA\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CA/Address.php',
+ 'Faker\\Provider\\fr_CA\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CA/Company.php',
+ 'Faker\\Provider\\fr_CA\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CA/Person.php',
+ 'Faker\\Provider\\fr_CA\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CA/Text.php',
+ 'Faker\\Provider\\fr_CH\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Address.php',
+ 'Faker\\Provider\\fr_CH\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Company.php',
+ 'Faker\\Provider\\fr_CH\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Internet.php',
+ 'Faker\\Provider\\fr_CH\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Payment.php',
+ 'Faker\\Provider\\fr_CH\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Person.php',
+ 'Faker\\Provider\\fr_CH\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CH/PhoneNumber.php',
+ 'Faker\\Provider\\fr_CH\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Text.php',
+ 'Faker\\Provider\\fr_FR\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_FR/Address.php',
+ 'Faker\\Provider\\fr_FR\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_FR/Company.php',
+ 'Faker\\Provider\\fr_FR\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_FR/Internet.php',
+ 'Faker\\Provider\\fr_FR\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_FR/Payment.php',
+ 'Faker\\Provider\\fr_FR\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_FR/Person.php',
+ 'Faker\\Provider\\fr_FR\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/fr_FR/PhoneNumber.php',
+ 'Faker\\Provider\\he_IL\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/he_IL/Address.php',
+ 'Faker\\Provider\\he_IL\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/he_IL/Company.php',
+ 'Faker\\Provider\\he_IL\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/he_IL/Payment.php',
+ 'Faker\\Provider\\he_IL\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/he_IL/Person.php',
+ 'Faker\\Provider\\he_IL\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/he_IL/PhoneNumber.php',
+ 'Faker\\Provider\\hr_HR\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hr_HR/Address.php',
+ 'Faker\\Provider\\hr_HR\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hr_HR/Company.php',
+ 'Faker\\Provider\\hr_HR\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hr_HR/Payment.php',
+ 'Faker\\Provider\\hr_HR\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hr_HR/Person.php',
+ 'Faker\\Provider\\hr_HR\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hr_HR/PhoneNumber.php',
+ 'Faker\\Provider\\hu_HU\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hu_HU/Address.php',
+ 'Faker\\Provider\\hu_HU\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hu_HU/Company.php',
+ 'Faker\\Provider\\hu_HU\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hu_HU/Payment.php',
+ 'Faker\\Provider\\hu_HU\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hu_HU/Person.php',
+ 'Faker\\Provider\\hu_HU\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hu_HU/PhoneNumber.php',
+ 'Faker\\Provider\\hy_AM\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hy_AM/Address.php',
+ 'Faker\\Provider\\hy_AM\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hy_AM/Color.php',
+ 'Faker\\Provider\\hy_AM\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hy_AM/Company.php',
+ 'Faker\\Provider\\hy_AM\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hy_AM/Internet.php',
+ 'Faker\\Provider\\hy_AM\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hy_AM/Person.php',
+ 'Faker\\Provider\\hy_AM\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/hy_AM/PhoneNumber.php',
+ 'Faker\\Provider\\id_ID\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/id_ID/Address.php',
+ 'Faker\\Provider\\id_ID\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/id_ID/Color.php',
+ 'Faker\\Provider\\id_ID\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/id_ID/Company.php',
+ 'Faker\\Provider\\id_ID\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/id_ID/Internet.php',
+ 'Faker\\Provider\\id_ID\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/id_ID/Person.php',
+ 'Faker\\Provider\\id_ID\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/id_ID/PhoneNumber.php',
+ 'Faker\\Provider\\is_IS\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/is_IS/Address.php',
+ 'Faker\\Provider\\is_IS\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/is_IS/Company.php',
+ 'Faker\\Provider\\is_IS\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/is_IS/Internet.php',
+ 'Faker\\Provider\\is_IS\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/is_IS/Payment.php',
+ 'Faker\\Provider\\is_IS\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/is_IS/Person.php',
+ 'Faker\\Provider\\is_IS\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/is_IS/PhoneNumber.php',
+ 'Faker\\Provider\\it_CH\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_CH/Address.php',
+ 'Faker\\Provider\\it_CH\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_CH/Company.php',
+ 'Faker\\Provider\\it_CH\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_CH/Internet.php',
+ 'Faker\\Provider\\it_CH\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_CH/Payment.php',
+ 'Faker\\Provider\\it_CH\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_CH/Person.php',
+ 'Faker\\Provider\\it_CH\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_CH/PhoneNumber.php',
+ 'Faker\\Provider\\it_CH\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_CH/Text.php',
+ 'Faker\\Provider\\it_IT\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_IT/Address.php',
+ 'Faker\\Provider\\it_IT\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_IT/Company.php',
+ 'Faker\\Provider\\it_IT\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_IT/Internet.php',
+ 'Faker\\Provider\\it_IT\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_IT/Payment.php',
+ 'Faker\\Provider\\it_IT\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_IT/Person.php',
+ 'Faker\\Provider\\it_IT\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_IT/PhoneNumber.php',
+ 'Faker\\Provider\\it_IT\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/it_IT/Text.php',
+ 'Faker\\Provider\\ja_JP\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ja_JP/Address.php',
+ 'Faker\\Provider\\ja_JP\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ja_JP/Company.php',
+ 'Faker\\Provider\\ja_JP\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ja_JP/Internet.php',
+ 'Faker\\Provider\\ja_JP\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ja_JP/Person.php',
+ 'Faker\\Provider\\ja_JP\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ja_JP/PhoneNumber.php',
+ 'Faker\\Provider\\ja_JP\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ja_JP/Text.php',
+ 'Faker\\Provider\\ka_GE\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Address.php',
+ 'Faker\\Provider\\ka_GE\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Color.php',
+ 'Faker\\Provider\\ka_GE\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Company.php',
+ 'Faker\\Provider\\ka_GE\\DateTime' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ka_GE/DateTime.php',
+ 'Faker\\Provider\\ka_GE\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Internet.php',
+ 'Faker\\Provider\\ka_GE\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Payment.php',
+ 'Faker\\Provider\\ka_GE\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Person.php',
+ 'Faker\\Provider\\ka_GE\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ka_GE/PhoneNumber.php',
+ 'Faker\\Provider\\kk_KZ\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Address.php',
+ 'Faker\\Provider\\kk_KZ\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Color.php',
+ 'Faker\\Provider\\kk_KZ\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Company.php',
+ 'Faker\\Provider\\kk_KZ\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Internet.php',
+ 'Faker\\Provider\\kk_KZ\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Payment.php',
+ 'Faker\\Provider\\kk_KZ\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Person.php',
+ 'Faker\\Provider\\kk_KZ\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/PhoneNumber.php',
+ 'Faker\\Provider\\kk_KZ\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Text.php',
+ 'Faker\\Provider\\ko_KR\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ko_KR/Address.php',
+ 'Faker\\Provider\\ko_KR\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ko_KR/Company.php',
+ 'Faker\\Provider\\ko_KR\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ko_KR/Internet.php',
+ 'Faker\\Provider\\ko_KR\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ko_KR/Person.php',
+ 'Faker\\Provider\\ko_KR\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ko_KR/PhoneNumber.php',
+ 'Faker\\Provider\\lt_LT\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lt_LT/Address.php',
+ 'Faker\\Provider\\lt_LT\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lt_LT/Company.php',
+ 'Faker\\Provider\\lt_LT\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lt_LT/Internet.php',
+ 'Faker\\Provider\\lt_LT\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lt_LT/Payment.php',
+ 'Faker\\Provider\\lt_LT\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lt_LT/Person.php',
+ 'Faker\\Provider\\lt_LT\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lt_LT/PhoneNumber.php',
+ 'Faker\\Provider\\lv_LV\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lv_LV/Address.php',
+ 'Faker\\Provider\\lv_LV\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lv_LV/Color.php',
+ 'Faker\\Provider\\lv_LV\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lv_LV/Internet.php',
+ 'Faker\\Provider\\lv_LV\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lv_LV/Payment.php',
+ 'Faker\\Provider\\lv_LV\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lv_LV/Person.php',
+ 'Faker\\Provider\\lv_LV\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/lv_LV/PhoneNumber.php',
+ 'Faker\\Provider\\me_ME\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/me_ME/Address.php',
+ 'Faker\\Provider\\me_ME\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/me_ME/Company.php',
+ 'Faker\\Provider\\me_ME\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/me_ME/Payment.php',
+ 'Faker\\Provider\\me_ME\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/me_ME/Person.php',
+ 'Faker\\Provider\\me_ME\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/me_ME/PhoneNumber.php',
+ 'Faker\\Provider\\mn_MN\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/mn_MN/Person.php',
+ 'Faker\\Provider\\mn_MN\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/mn_MN/PhoneNumber.php',
+ 'Faker\\Provider\\ms_MY\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ms_MY/Address.php',
+ 'Faker\\Provider\\ms_MY\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ms_MY/Company.php',
+ 'Faker\\Provider\\ms_MY\\Miscellaneous' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ms_MY/Miscellaneous.php',
+ 'Faker\\Provider\\ms_MY\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ms_MY/Payment.php',
+ 'Faker\\Provider\\ms_MY\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ms_MY/Person.php',
+ 'Faker\\Provider\\ms_MY\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ms_MY/PhoneNumber.php',
+ 'Faker\\Provider\\nb_NO\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nb_NO/Address.php',
+ 'Faker\\Provider\\nb_NO\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nb_NO/Company.php',
+ 'Faker\\Provider\\nb_NO\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nb_NO/Payment.php',
+ 'Faker\\Provider\\nb_NO\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nb_NO/Person.php',
+ 'Faker\\Provider\\nb_NO\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nb_NO/PhoneNumber.php',
+ 'Faker\\Provider\\ne_NP\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ne_NP/Address.php',
+ 'Faker\\Provider\\ne_NP\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ne_NP/Internet.php',
+ 'Faker\\Provider\\ne_NP\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ne_NP/Person.php',
+ 'Faker\\Provider\\ne_NP\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ne_NP/PhoneNumber.php',
+ 'Faker\\Provider\\nl_BE\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_BE/Address.php',
+ 'Faker\\Provider\\nl_BE\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_BE/Company.php',
+ 'Faker\\Provider\\nl_BE\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_BE/Internet.php',
+ 'Faker\\Provider\\nl_BE\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_BE/Payment.php',
+ 'Faker\\Provider\\nl_BE\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_BE/Person.php',
+ 'Faker\\Provider\\nl_BE\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_BE/PhoneNumber.php',
+ 'Faker\\Provider\\nl_NL\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Address.php',
+ 'Faker\\Provider\\nl_NL\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Color.php',
+ 'Faker\\Provider\\nl_NL\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Company.php',
+ 'Faker\\Provider\\nl_NL\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Internet.php',
+ 'Faker\\Provider\\nl_NL\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Payment.php',
+ 'Faker\\Provider\\nl_NL\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Person.php',
+ 'Faker\\Provider\\nl_NL\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_NL/PhoneNumber.php',
+ 'Faker\\Provider\\nl_NL\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Text.php',
+ 'Faker\\Provider\\pl_PL\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Address.php',
+ 'Faker\\Provider\\pl_PL\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Company.php',
+ 'Faker\\Provider\\pl_PL\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Internet.php',
+ 'Faker\\Provider\\pl_PL\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Payment.php',
+ 'Faker\\Provider\\pl_PL\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Person.php',
+ 'Faker\\Provider\\pl_PL\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pl_PL/PhoneNumber.php',
+ 'Faker\\Provider\\pl_PL\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Text.php',
+ 'Faker\\Provider\\pt_BR\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_BR/Address.php',
+ 'Faker\\Provider\\pt_BR\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_BR/Company.php',
+ 'Faker\\Provider\\pt_BR\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_BR/Internet.php',
+ 'Faker\\Provider\\pt_BR\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_BR/Payment.php',
+ 'Faker\\Provider\\pt_BR\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_BR/Person.php',
+ 'Faker\\Provider\\pt_BR\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_BR/PhoneNumber.php',
+ 'Faker\\Provider\\pt_PT\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_PT/Address.php',
+ 'Faker\\Provider\\pt_PT\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_PT/Company.php',
+ 'Faker\\Provider\\pt_PT\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_PT/Internet.php',
+ 'Faker\\Provider\\pt_PT\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_PT/Payment.php',
+ 'Faker\\Provider\\pt_PT\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_PT/Person.php',
+ 'Faker\\Provider\\pt_PT\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/pt_PT/PhoneNumber.php',
+ 'Faker\\Provider\\ro_MD\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ro_MD/Address.php',
+ 'Faker\\Provider\\ro_MD\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ro_MD/Payment.php',
+ 'Faker\\Provider\\ro_MD\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ro_MD/Person.php',
+ 'Faker\\Provider\\ro_MD\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ro_MD/PhoneNumber.php',
+ 'Faker\\Provider\\ro_MD\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ro_MD/Text.php',
+ 'Faker\\Provider\\ro_RO\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ro_RO/Address.php',
+ 'Faker\\Provider\\ro_RO\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ro_RO/Payment.php',
+ 'Faker\\Provider\\ro_RO\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ro_RO/Person.php',
+ 'Faker\\Provider\\ro_RO\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ro_RO/PhoneNumber.php',
+ 'Faker\\Provider\\ro_RO\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ro_RO/Text.php',
+ 'Faker\\Provider\\ru_RU\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Address.php',
+ 'Faker\\Provider\\ru_RU\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Color.php',
+ 'Faker\\Provider\\ru_RU\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Company.php',
+ 'Faker\\Provider\\ru_RU\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Internet.php',
+ 'Faker\\Provider\\ru_RU\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Payment.php',
+ 'Faker\\Provider\\ru_RU\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Person.php',
+ 'Faker\\Provider\\ru_RU\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/ru_RU/PhoneNumber.php',
+ 'Faker\\Provider\\sk_SK\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sk_SK/Address.php',
+ 'Faker\\Provider\\sk_SK\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sk_SK/Company.php',
+ 'Faker\\Provider\\sk_SK\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sk_SK/Internet.php',
+ 'Faker\\Provider\\sk_SK\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sk_SK/Payment.php',
+ 'Faker\\Provider\\sk_SK\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sk_SK/Person.php',
+ 'Faker\\Provider\\sk_SK\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sk_SK/PhoneNumber.php',
+ 'Faker\\Provider\\sl_SI\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sl_SI/Address.php',
+ 'Faker\\Provider\\sl_SI\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sl_SI/Company.php',
+ 'Faker\\Provider\\sl_SI\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sl_SI/Internet.php',
+ 'Faker\\Provider\\sl_SI\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sl_SI/Payment.php',
+ 'Faker\\Provider\\sl_SI\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sl_SI/Person.php',
+ 'Faker\\Provider\\sl_SI\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sl_SI/PhoneNumber.php',
+ 'Faker\\Provider\\sr_Cyrl_RS\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sr_Cyrl_RS/Address.php',
+ 'Faker\\Provider\\sr_Cyrl_RS\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sr_Cyrl_RS/Payment.php',
+ 'Faker\\Provider\\sr_Cyrl_RS\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sr_Cyrl_RS/Person.php',
+ 'Faker\\Provider\\sr_Latn_RS\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sr_Latn_RS/Address.php',
+ 'Faker\\Provider\\sr_Latn_RS\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sr_Latn_RS/Payment.php',
+ 'Faker\\Provider\\sr_Latn_RS\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sr_Latn_RS/Person.php',
+ 'Faker\\Provider\\sr_RS\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sr_RS/Address.php',
+ 'Faker\\Provider\\sr_RS\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sr_RS/Payment.php',
+ 'Faker\\Provider\\sr_RS\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sr_RS/Person.php',
+ 'Faker\\Provider\\sv_SE\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sv_SE/Address.php',
+ 'Faker\\Provider\\sv_SE\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sv_SE/Company.php',
+ 'Faker\\Provider\\sv_SE\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sv_SE/Payment.php',
+ 'Faker\\Provider\\sv_SE\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sv_SE/Person.php',
+ 'Faker\\Provider\\sv_SE\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/sv_SE/PhoneNumber.php',
+ 'Faker\\Provider\\th_TH\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/th_TH/Address.php',
+ 'Faker\\Provider\\th_TH\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/th_TH/Color.php',
+ 'Faker\\Provider\\th_TH\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/th_TH/Company.php',
+ 'Faker\\Provider\\th_TH\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/th_TH/Internet.php',
+ 'Faker\\Provider\\th_TH\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/th_TH/Payment.php',
+ 'Faker\\Provider\\th_TH\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/th_TH/Person.php',
+ 'Faker\\Provider\\th_TH\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/th_TH/PhoneNumber.php',
+ 'Faker\\Provider\\tr_TR\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Address.php',
+ 'Faker\\Provider\\tr_TR\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Color.php',
+ 'Faker\\Provider\\tr_TR\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Company.php',
+ 'Faker\\Provider\\tr_TR\\DateTime' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/tr_TR/DateTime.php',
+ 'Faker\\Provider\\tr_TR\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Internet.php',
+ 'Faker\\Provider\\tr_TR\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Payment.php',
+ 'Faker\\Provider\\tr_TR\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Person.php',
+ 'Faker\\Provider\\tr_TR\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/tr_TR/PhoneNumber.php',
+ 'Faker\\Provider\\uk_UA\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Address.php',
+ 'Faker\\Provider\\uk_UA\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Color.php',
+ 'Faker\\Provider\\uk_UA\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Company.php',
+ 'Faker\\Provider\\uk_UA\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Internet.php',
+ 'Faker\\Provider\\uk_UA\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Payment.php',
+ 'Faker\\Provider\\uk_UA\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Person.php',
+ 'Faker\\Provider\\uk_UA\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/uk_UA/PhoneNumber.php',
+ 'Faker\\Provider\\vi_VN\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/vi_VN/Address.php',
+ 'Faker\\Provider\\vi_VN\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/vi_VN/Color.php',
+ 'Faker\\Provider\\vi_VN\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/vi_VN/Internet.php',
+ 'Faker\\Provider\\vi_VN\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/vi_VN/Person.php',
+ 'Faker\\Provider\\vi_VN\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/vi_VN/PhoneNumber.php',
+ 'Faker\\Provider\\zh_CN\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Address.php',
+ 'Faker\\Provider\\zh_CN\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Color.php',
+ 'Faker\\Provider\\zh_CN\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Company.php',
+ 'Faker\\Provider\\zh_CN\\DateTime' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_CN/DateTime.php',
+ 'Faker\\Provider\\zh_CN\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Internet.php',
+ 'Faker\\Provider\\zh_CN\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Payment.php',
+ 'Faker\\Provider\\zh_CN\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Person.php',
+ 'Faker\\Provider\\zh_CN\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_CN/PhoneNumber.php',
+ 'Faker\\Provider\\zh_TW\\Address' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Address.php',
+ 'Faker\\Provider\\zh_TW\\Color' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Color.php',
+ 'Faker\\Provider\\zh_TW\\Company' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Company.php',
+ 'Faker\\Provider\\zh_TW\\DateTime' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_TW/DateTime.php',
+ 'Faker\\Provider\\zh_TW\\Internet' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Internet.php',
+ 'Faker\\Provider\\zh_TW\\Payment' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Payment.php',
+ 'Faker\\Provider\\zh_TW\\Person' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Person.php',
+ 'Faker\\Provider\\zh_TW\\PhoneNumber' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_TW/PhoneNumber.php',
+ 'Faker\\Provider\\zh_TW\\Text' => $vendorDir . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Text.php',
+ 'Faker\\UniqueGenerator' => $vendorDir . '/fzaninotto/faker/src/Faker/UniqueGenerator.php',
+ 'Faker\\ValidGenerator' => $vendorDir . '/fzaninotto/faker/src/Faker/ValidGenerator.php',
+ 'File_Iterator' => $vendorDir . '/phpunit/php-file-iterator/src/Iterator.php',
+ 'File_Iterator_Facade' => $vendorDir . '/phpunit/php-file-iterator/src/Facade.php',
+ 'File_Iterator_Factory' => $vendorDir . '/phpunit/php-file-iterator/src/Factory.php',
+ 'Hamcrest\\Arrays\\IsArray' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArray.php',
+ 'Hamcrest\\Arrays\\IsArrayContaining' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContaining.php',
+ 'Hamcrest\\Arrays\\IsArrayContainingInAnyOrder' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInAnyOrder.php',
+ 'Hamcrest\\Arrays\\IsArrayContainingInOrder' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInOrder.php',
+ 'Hamcrest\\Arrays\\IsArrayContainingKey' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKey.php',
+ 'Hamcrest\\Arrays\\IsArrayContainingKeyValuePair' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKeyValuePair.php',
+ 'Hamcrest\\Arrays\\IsArrayWithSize' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayWithSize.php',
+ 'Hamcrest\\Arrays\\MatchingOnce' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/MatchingOnce.php',
+ 'Hamcrest\\Arrays\\SeriesMatchingOnce' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/SeriesMatchingOnce.php',
+ 'Hamcrest\\AssertionError' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/AssertionError.php',
+ 'Hamcrest\\BaseDescription' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/BaseDescription.php',
+ 'Hamcrest\\BaseMatcher' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/BaseMatcher.php',
+ 'Hamcrest\\Collection\\IsEmptyTraversable' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsEmptyTraversable.php',
+ 'Hamcrest\\Collection\\IsTraversableWithSize' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsTraversableWithSize.php',
+ 'Hamcrest\\Core\\AllOf' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/AllOf.php',
+ 'Hamcrest\\Core\\AnyOf' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/AnyOf.php',
+ 'Hamcrest\\Core\\CombinableMatcher' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/CombinableMatcher.php',
+ 'Hamcrest\\Core\\DescribedAs' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/DescribedAs.php',
+ 'Hamcrest\\Core\\Every' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Every.php',
+ 'Hamcrest\\Core\\HasToString' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/HasToString.php',
+ 'Hamcrest\\Core\\Is' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Is.php',
+ 'Hamcrest\\Core\\IsAnything' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsAnything.php',
+ 'Hamcrest\\Core\\IsCollectionContaining' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsCollectionContaining.php',
+ 'Hamcrest\\Core\\IsEqual' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsEqual.php',
+ 'Hamcrest\\Core\\IsIdentical' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsIdentical.php',
+ 'Hamcrest\\Core\\IsInstanceOf' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsInstanceOf.php',
+ 'Hamcrest\\Core\\IsNot' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNot.php',
+ 'Hamcrest\\Core\\IsNull' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNull.php',
+ 'Hamcrest\\Core\\IsSame' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsSame.php',
+ 'Hamcrest\\Core\\IsTypeOf' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsTypeOf.php',
+ 'Hamcrest\\Core\\Set' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Set.php',
+ 'Hamcrest\\Core\\ShortcutCombination' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/ShortcutCombination.php',
+ 'Hamcrest\\Description' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Description.php',
+ 'Hamcrest\\DiagnosingMatcher' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/DiagnosingMatcher.php',
+ 'Hamcrest\\FeatureMatcher' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/FeatureMatcher.php',
+ 'Hamcrest\\Internal\\SelfDescribingValue' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Internal/SelfDescribingValue.php',
+ 'Hamcrest\\Matcher' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matcher.php',
+ 'Hamcrest\\MatcherAssert' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/MatcherAssert.php',
+ 'Hamcrest\\Matchers' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matchers.php',
+ 'Hamcrest\\NullDescription' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/NullDescription.php',
+ 'Hamcrest\\Number\\IsCloseTo' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Number/IsCloseTo.php',
+ 'Hamcrest\\Number\\OrderingComparison' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Number/OrderingComparison.php',
+ 'Hamcrest\\SelfDescribing' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/SelfDescribing.php',
+ 'Hamcrest\\StringDescription' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/StringDescription.php',
+ 'Hamcrest\\Text\\IsEmptyString' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEmptyString.php',
+ 'Hamcrest\\Text\\IsEqualIgnoringCase' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringCase.php',
+ 'Hamcrest\\Text\\IsEqualIgnoringWhiteSpace' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringWhiteSpace.php',
+ 'Hamcrest\\Text\\MatchesPattern' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/MatchesPattern.php',
+ 'Hamcrest\\Text\\StringContains' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContains.php',
+ 'Hamcrest\\Text\\StringContainsIgnoringCase' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsIgnoringCase.php',
+ 'Hamcrest\\Text\\StringContainsInOrder' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsInOrder.php',
+ 'Hamcrest\\Text\\StringEndsWith' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringEndsWith.php',
+ 'Hamcrest\\Text\\StringStartsWith' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringStartsWith.php',
+ 'Hamcrest\\Text\\SubstringMatcher' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/SubstringMatcher.php',
+ 'Hamcrest\\TypeSafeDiagnosingMatcher' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/TypeSafeDiagnosingMatcher.php',
+ 'Hamcrest\\TypeSafeMatcher' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/TypeSafeMatcher.php',
+ 'Hamcrest\\Type\\IsArray' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsArray.php',
+ 'Hamcrest\\Type\\IsBoolean' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsBoolean.php',
+ 'Hamcrest\\Type\\IsCallable' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsCallable.php',
+ 'Hamcrest\\Type\\IsDouble' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsDouble.php',
+ 'Hamcrest\\Type\\IsInteger' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsInteger.php',
+ 'Hamcrest\\Type\\IsNumeric' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsNumeric.php',
+ 'Hamcrest\\Type\\IsObject' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsObject.php',
+ 'Hamcrest\\Type\\IsResource' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsResource.php',
+ 'Hamcrest\\Type\\IsScalar' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsScalar.php',
+ 'Hamcrest\\Type\\IsString' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsString.php',
+ 'Hamcrest\\Util' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Util.php',
+ 'Hamcrest\\Xml\\HasXPath' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Xml/HasXPath.php',
+ 'Illuminate\\Auth\\Access\\AuthorizationException' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Access/AuthorizationException.php',
+ 'Illuminate\\Auth\\Access\\Gate' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Access/Gate.php',
+ 'Illuminate\\Auth\\Access\\HandlesAuthorization' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Access/HandlesAuthorization.php',
+ 'Illuminate\\Auth\\Access\\Response' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Access/Response.php',
+ 'Illuminate\\Auth\\AuthManager' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/AuthManager.php',
+ 'Illuminate\\Auth\\AuthServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/AuthServiceProvider.php',
+ 'Illuminate\\Auth\\Authenticatable' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Authenticatable.php',
+ 'Illuminate\\Auth\\AuthenticationException' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/AuthenticationException.php',
+ 'Illuminate\\Auth\\Console\\AuthMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Console/AuthMakeCommand.php',
+ 'Illuminate\\Auth\\Console\\ClearResetsCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Console/ClearResetsCommand.php',
+ 'Illuminate\\Auth\\CreatesUserProviders' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/CreatesUserProviders.php',
+ 'Illuminate\\Auth\\DatabaseUserProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/DatabaseUserProvider.php',
+ 'Illuminate\\Auth\\EloquentUserProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/EloquentUserProvider.php',
+ 'Illuminate\\Auth\\Events\\Attempting' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Events/Attempting.php',
+ 'Illuminate\\Auth\\Events\\Authenticated' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Events/Authenticated.php',
+ 'Illuminate\\Auth\\Events\\Failed' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Events/Failed.php',
+ 'Illuminate\\Auth\\Events\\Lockout' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Events/Lockout.php',
+ 'Illuminate\\Auth\\Events\\Login' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Events/Login.php',
+ 'Illuminate\\Auth\\Events\\Logout' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Events/Logout.php',
+ 'Illuminate\\Auth\\Events\\Registered' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Events/Registered.php',
+ 'Illuminate\\Auth\\GenericUser' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/GenericUser.php',
+ 'Illuminate\\Auth\\GuardHelpers' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/GuardHelpers.php',
+ 'Illuminate\\Auth\\Middleware\\Authenticate' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Middleware/Authenticate.php',
+ 'Illuminate\\Auth\\Middleware\\AuthenticateWithBasicAuth' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Middleware/AuthenticateWithBasicAuth.php',
+ 'Illuminate\\Auth\\Middleware\\Authorize' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Middleware/Authorize.php',
+ 'Illuminate\\Auth\\Notifications\\ResetPassword' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Notifications/ResetPassword.php',
+ 'Illuminate\\Auth\\Passwords\\CanResetPassword' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Passwords/CanResetPassword.php',
+ 'Illuminate\\Auth\\Passwords\\DatabaseTokenRepository' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Passwords/DatabaseTokenRepository.php',
+ 'Illuminate\\Auth\\Passwords\\PasswordBroker' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBroker.php',
+ 'Illuminate\\Auth\\Passwords\\PasswordBrokerManager' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBrokerManager.php',
+ 'Illuminate\\Auth\\Passwords\\PasswordResetServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Passwords/PasswordResetServiceProvider.php',
+ 'Illuminate\\Auth\\Passwords\\TokenRepositoryInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Passwords/TokenRepositoryInterface.php',
+ 'Illuminate\\Auth\\Recaller' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/Recaller.php',
+ 'Illuminate\\Auth\\RequestGuard' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/RequestGuard.php',
+ 'Illuminate\\Auth\\SessionGuard' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/SessionGuard.php',
+ 'Illuminate\\Auth\\TokenGuard' => $vendorDir . '/laravel/framework/src/Illuminate/Auth/TokenGuard.php',
+ 'Illuminate\\Broadcasting\\BroadcastController' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/BroadcastController.php',
+ 'Illuminate\\Broadcasting\\BroadcastEvent' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/BroadcastEvent.php',
+ 'Illuminate\\Broadcasting\\BroadcastException' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/BroadcastException.php',
+ 'Illuminate\\Broadcasting\\BroadcastManager' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/BroadcastManager.php',
+ 'Illuminate\\Broadcasting\\BroadcastServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/BroadcastServiceProvider.php',
+ 'Illuminate\\Broadcasting\\Broadcasters\\Broadcaster' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/Broadcaster.php',
+ 'Illuminate\\Broadcasting\\Broadcasters\\LogBroadcaster' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/LogBroadcaster.php',
+ 'Illuminate\\Broadcasting\\Broadcasters\\NullBroadcaster' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/NullBroadcaster.php',
+ 'Illuminate\\Broadcasting\\Broadcasters\\PusherBroadcaster' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/PusherBroadcaster.php',
+ 'Illuminate\\Broadcasting\\Broadcasters\\RedisBroadcaster' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/RedisBroadcaster.php',
+ 'Illuminate\\Broadcasting\\Channel' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/Channel.php',
+ 'Illuminate\\Broadcasting\\InteractsWithSockets' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/InteractsWithSockets.php',
+ 'Illuminate\\Broadcasting\\PendingBroadcast' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/PendingBroadcast.php',
+ 'Illuminate\\Broadcasting\\PresenceChannel' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/PresenceChannel.php',
+ 'Illuminate\\Broadcasting\\PrivateChannel' => $vendorDir . '/laravel/framework/src/Illuminate/Broadcasting/PrivateChannel.php',
+ 'Illuminate\\Bus\\BusServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Bus/BusServiceProvider.php',
+ 'Illuminate\\Bus\\Dispatcher' => $vendorDir . '/laravel/framework/src/Illuminate/Bus/Dispatcher.php',
+ 'Illuminate\\Bus\\Queueable' => $vendorDir . '/laravel/framework/src/Illuminate/Bus/Queueable.php',
+ 'Illuminate\\Cache\\ApcStore' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/ApcStore.php',
+ 'Illuminate\\Cache\\ApcWrapper' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/ApcWrapper.php',
+ 'Illuminate\\Cache\\ArrayStore' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/ArrayStore.php',
+ 'Illuminate\\Cache\\CacheManager' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/CacheManager.php',
+ 'Illuminate\\Cache\\CacheServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/CacheServiceProvider.php',
+ 'Illuminate\\Cache\\Console\\CacheTableCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/Console/CacheTableCommand.php',
+ 'Illuminate\\Cache\\Console\\ClearCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/Console/ClearCommand.php',
+ 'Illuminate\\Cache\\Console\\ForgetCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/Console/ForgetCommand.php',
+ 'Illuminate\\Cache\\DatabaseStore' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/DatabaseStore.php',
+ 'Illuminate\\Cache\\Events\\CacheEvent' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/Events/CacheEvent.php',
+ 'Illuminate\\Cache\\Events\\CacheHit' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/Events/CacheHit.php',
+ 'Illuminate\\Cache\\Events\\CacheMissed' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/Events/CacheMissed.php',
+ 'Illuminate\\Cache\\Events\\KeyForgotten' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/Events/KeyForgotten.php',
+ 'Illuminate\\Cache\\Events\\KeyWritten' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/Events/KeyWritten.php',
+ 'Illuminate\\Cache\\FileStore' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/FileStore.php',
+ 'Illuminate\\Cache\\MemcachedConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/MemcachedConnector.php',
+ 'Illuminate\\Cache\\MemcachedStore' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/MemcachedStore.php',
+ 'Illuminate\\Cache\\NullStore' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/NullStore.php',
+ 'Illuminate\\Cache\\RateLimiter' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/RateLimiter.php',
+ 'Illuminate\\Cache\\RedisStore' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/RedisStore.php',
+ 'Illuminate\\Cache\\RedisTaggedCache' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/RedisTaggedCache.php',
+ 'Illuminate\\Cache\\Repository' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/Repository.php',
+ 'Illuminate\\Cache\\RetrievesMultipleKeys' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/RetrievesMultipleKeys.php',
+ 'Illuminate\\Cache\\TagSet' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/TagSet.php',
+ 'Illuminate\\Cache\\TaggableStore' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/TaggableStore.php',
+ 'Illuminate\\Cache\\TaggedCache' => $vendorDir . '/laravel/framework/src/Illuminate/Cache/TaggedCache.php',
+ 'Illuminate\\Config\\Repository' => $vendorDir . '/laravel/framework/src/Illuminate/Config/Repository.php',
+ 'Illuminate\\Console\\Application' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Application.php',
+ 'Illuminate\\Console\\Command' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Command.php',
+ 'Illuminate\\Console\\ConfirmableTrait' => $vendorDir . '/laravel/framework/src/Illuminate/Console/ConfirmableTrait.php',
+ 'Illuminate\\Console\\DetectsApplicationNamespace' => $vendorDir . '/laravel/framework/src/Illuminate/Console/DetectsApplicationNamespace.php',
+ 'Illuminate\\Console\\Events\\ArtisanStarting' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Events/ArtisanStarting.php',
+ 'Illuminate\\Console\\GeneratorCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Console/GeneratorCommand.php',
+ 'Illuminate\\Console\\OutputStyle' => $vendorDir . '/laravel/framework/src/Illuminate/Console/OutputStyle.php',
+ 'Illuminate\\Console\\Parser' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Parser.php',
+ 'Illuminate\\Console\\Scheduling\\CacheMutex' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Scheduling/CacheMutex.php',
+ 'Illuminate\\Console\\Scheduling\\CallbackEvent' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Scheduling/CallbackEvent.php',
+ 'Illuminate\\Console\\Scheduling\\CommandBuilder' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Scheduling/CommandBuilder.php',
+ 'Illuminate\\Console\\Scheduling\\Event' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Scheduling/Event.php',
+ 'Illuminate\\Console\\Scheduling\\ManagesFrequencies' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Scheduling/ManagesFrequencies.php',
+ 'Illuminate\\Console\\Scheduling\\Mutex' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Scheduling/Mutex.php',
+ 'Illuminate\\Console\\Scheduling\\Schedule' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Scheduling/Schedule.php',
+ 'Illuminate\\Console\\Scheduling\\ScheduleFinishCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleFinishCommand.php',
+ 'Illuminate\\Console\\Scheduling\\ScheduleRunCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleRunCommand.php',
+ 'Illuminate\\Container\\BoundMethod' => $vendorDir . '/laravel/framework/src/Illuminate/Container/BoundMethod.php',
+ 'Illuminate\\Container\\Container' => $vendorDir . '/laravel/framework/src/Illuminate/Container/Container.php',
+ 'Illuminate\\Container\\ContextualBindingBuilder' => $vendorDir . '/laravel/framework/src/Illuminate/Container/ContextualBindingBuilder.php',
+ 'Illuminate\\Contracts\\Auth\\Access\\Authorizable' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/Access/Authorizable.php',
+ 'Illuminate\\Contracts\\Auth\\Access\\Gate' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/Access/Gate.php',
+ 'Illuminate\\Contracts\\Auth\\Authenticatable' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/Authenticatable.php',
+ 'Illuminate\\Contracts\\Auth\\CanResetPassword' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/CanResetPassword.php',
+ 'Illuminate\\Contracts\\Auth\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/Factory.php',
+ 'Illuminate\\Contracts\\Auth\\Guard' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/Guard.php',
+ 'Illuminate\\Contracts\\Auth\\PasswordBroker' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/PasswordBroker.php',
+ 'Illuminate\\Contracts\\Auth\\PasswordBrokerFactory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/PasswordBrokerFactory.php',
+ 'Illuminate\\Contracts\\Auth\\StatefulGuard' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/StatefulGuard.php',
+ 'Illuminate\\Contracts\\Auth\\SupportsBasicAuth' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/SupportsBasicAuth.php',
+ 'Illuminate\\Contracts\\Auth\\UserProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Auth/UserProvider.php',
+ 'Illuminate\\Contracts\\Broadcasting\\Broadcaster' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Broadcasting/Broadcaster.php',
+ 'Illuminate\\Contracts\\Broadcasting\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Broadcasting/Factory.php',
+ 'Illuminate\\Contracts\\Broadcasting\\ShouldBroadcast' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Broadcasting/ShouldBroadcast.php',
+ 'Illuminate\\Contracts\\Broadcasting\\ShouldBroadcastNow' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Broadcasting/ShouldBroadcastNow.php',
+ 'Illuminate\\Contracts\\Bus\\Dispatcher' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Bus/Dispatcher.php',
+ 'Illuminate\\Contracts\\Bus\\QueueingDispatcher' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Bus/QueueingDispatcher.php',
+ 'Illuminate\\Contracts\\Cache\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Cache/Factory.php',
+ 'Illuminate\\Contracts\\Cache\\Repository' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Cache/Repository.php',
+ 'Illuminate\\Contracts\\Cache\\Store' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Cache/Store.php',
+ 'Illuminate\\Contracts\\Config\\Repository' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Config/Repository.php',
+ 'Illuminate\\Contracts\\Console\\Application' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Console/Application.php',
+ 'Illuminate\\Contracts\\Console\\Kernel' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Console/Kernel.php',
+ 'Illuminate\\Contracts\\Container\\BindingResolutionException' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Container/BindingResolutionException.php',
+ 'Illuminate\\Contracts\\Container\\Container' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Container/Container.php',
+ 'Illuminate\\Contracts\\Container\\ContextualBindingBuilder' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Container/ContextualBindingBuilder.php',
+ 'Illuminate\\Contracts\\Cookie\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Cookie/Factory.php',
+ 'Illuminate\\Contracts\\Cookie\\QueueingFactory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Cookie/QueueingFactory.php',
+ 'Illuminate\\Contracts\\Database\\ModelIdentifier' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Database/ModelIdentifier.php',
+ 'Illuminate\\Contracts\\Debug\\ExceptionHandler' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Debug/ExceptionHandler.php',
+ 'Illuminate\\Contracts\\Encryption\\DecryptException' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Encryption/DecryptException.php',
+ 'Illuminate\\Contracts\\Encryption\\EncryptException' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Encryption/EncryptException.php',
+ 'Illuminate\\Contracts\\Encryption\\Encrypter' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Encryption/Encrypter.php',
+ 'Illuminate\\Contracts\\Events\\Dispatcher' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Events/Dispatcher.php',
+ 'Illuminate\\Contracts\\Filesystem\\Cloud' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Filesystem/Cloud.php',
+ 'Illuminate\\Contracts\\Filesystem\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Filesystem/Factory.php',
+ 'Illuminate\\Contracts\\Filesystem\\FileNotFoundException' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Filesystem/FileNotFoundException.php',
+ 'Illuminate\\Contracts\\Filesystem\\Filesystem' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Filesystem/Filesystem.php',
+ 'Illuminate\\Contracts\\Foundation\\Application' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Foundation/Application.php',
+ 'Illuminate\\Contracts\\Hashing\\Hasher' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Hashing/Hasher.php',
+ 'Illuminate\\Contracts\\Http\\Kernel' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Http/Kernel.php',
+ 'Illuminate\\Contracts\\Logging\\Log' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Logging/Log.php',
+ 'Illuminate\\Contracts\\Mail\\MailQueue' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Mail/MailQueue.php',
+ 'Illuminate\\Contracts\\Mail\\Mailable' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Mail/Mailable.php',
+ 'Illuminate\\Contracts\\Mail\\Mailer' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Mail/Mailer.php',
+ 'Illuminate\\Contracts\\Notifications\\Dispatcher' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Notifications/Dispatcher.php',
+ 'Illuminate\\Contracts\\Notifications\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Notifications/Factory.php',
+ 'Illuminate\\Contracts\\Pagination\\LengthAwarePaginator' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Pagination/LengthAwarePaginator.php',
+ 'Illuminate\\Contracts\\Pagination\\Paginator' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Pagination/Paginator.php',
+ 'Illuminate\\Contracts\\Pipeline\\Hub' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Pipeline/Hub.php',
+ 'Illuminate\\Contracts\\Pipeline\\Pipeline' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Pipeline/Pipeline.php',
+ 'Illuminate\\Contracts\\Queue\\EntityNotFoundException' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Queue/EntityNotFoundException.php',
+ 'Illuminate\\Contracts\\Queue\\EntityResolver' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Queue/EntityResolver.php',
+ 'Illuminate\\Contracts\\Queue\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Queue/Factory.php',
+ 'Illuminate\\Contracts\\Queue\\Job' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Queue/Job.php',
+ 'Illuminate\\Contracts\\Queue\\Monitor' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Queue/Monitor.php',
+ 'Illuminate\\Contracts\\Queue\\Queue' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Queue/Queue.php',
+ 'Illuminate\\Contracts\\Queue\\QueueableCollection' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Queue/QueueableCollection.php',
+ 'Illuminate\\Contracts\\Queue\\QueueableEntity' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Queue/QueueableEntity.php',
+ 'Illuminate\\Contracts\\Queue\\ShouldQueue' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Queue/ShouldQueue.php',
+ 'Illuminate\\Contracts\\Redis\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Redis/Factory.php',
+ 'Illuminate\\Contracts\\Routing\\BindingRegistrar' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Routing/BindingRegistrar.php',
+ 'Illuminate\\Contracts\\Routing\\Registrar' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Routing/Registrar.php',
+ 'Illuminate\\Contracts\\Routing\\ResponseFactory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Routing/ResponseFactory.php',
+ 'Illuminate\\Contracts\\Routing\\UrlGenerator' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Routing/UrlGenerator.php',
+ 'Illuminate\\Contracts\\Routing\\UrlRoutable' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Routing/UrlRoutable.php',
+ 'Illuminate\\Contracts\\Session\\Session' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Session/Session.php',
+ 'Illuminate\\Contracts\\Support\\Arrayable' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Support/Arrayable.php',
+ 'Illuminate\\Contracts\\Support\\Htmlable' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Support/Htmlable.php',
+ 'Illuminate\\Contracts\\Support\\Jsonable' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Support/Jsonable.php',
+ 'Illuminate\\Contracts\\Support\\MessageBag' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Support/MessageBag.php',
+ 'Illuminate\\Contracts\\Support\\MessageProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Support/MessageProvider.php',
+ 'Illuminate\\Contracts\\Support\\Renderable' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Support/Renderable.php',
+ 'Illuminate\\Contracts\\Translation\\Translator' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Translation/Translator.php',
+ 'Illuminate\\Contracts\\Validation\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Validation/Factory.php',
+ 'Illuminate\\Contracts\\Validation\\ValidatesWhenResolved' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Validation/ValidatesWhenResolved.php',
+ 'Illuminate\\Contracts\\Validation\\Validator' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/Validation/Validator.php',
+ 'Illuminate\\Contracts\\View\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/View/Factory.php',
+ 'Illuminate\\Contracts\\View\\View' => $vendorDir . '/laravel/framework/src/Illuminate/Contracts/View/View.php',
+ 'Illuminate\\Cookie\\CookieJar' => $vendorDir . '/laravel/framework/src/Illuminate/Cookie/CookieJar.php',
+ 'Illuminate\\Cookie\\CookieServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Cookie/CookieServiceProvider.php',
+ 'Illuminate\\Cookie\\Middleware\\AddQueuedCookiesToResponse' => $vendorDir . '/laravel/framework/src/Illuminate/Cookie/Middleware/AddQueuedCookiesToResponse.php',
+ 'Illuminate\\Cookie\\Middleware\\EncryptCookies' => $vendorDir . '/laravel/framework/src/Illuminate/Cookie/Middleware/EncryptCookies.php',
+ 'Illuminate\\Database\\Capsule\\Manager' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Capsule/Manager.php',
+ 'Illuminate\\Database\\Concerns\\BuildsQueries' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Concerns/BuildsQueries.php',
+ 'Illuminate\\Database\\Concerns\\ManagesTransactions' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Concerns/ManagesTransactions.php',
+ 'Illuminate\\Database\\Connection' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Connection.php',
+ 'Illuminate\\Database\\ConnectionInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Database/ConnectionInterface.php',
+ 'Illuminate\\Database\\ConnectionResolver' => $vendorDir . '/laravel/framework/src/Illuminate/Database/ConnectionResolver.php',
+ 'Illuminate\\Database\\ConnectionResolverInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Database/ConnectionResolverInterface.php',
+ 'Illuminate\\Database\\Connectors\\ConnectionFactory' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Connectors/ConnectionFactory.php',
+ 'Illuminate\\Database\\Connectors\\Connector' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Connectors/Connector.php',
+ 'Illuminate\\Database\\Connectors\\ConnectorInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Connectors/ConnectorInterface.php',
+ 'Illuminate\\Database\\Connectors\\MySqlConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Connectors/MySqlConnector.php',
+ 'Illuminate\\Database\\Connectors\\PostgresConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Connectors/PostgresConnector.php',
+ 'Illuminate\\Database\\Connectors\\SQLiteConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Connectors/SQLiteConnector.php',
+ 'Illuminate\\Database\\Connectors\\SqlServerConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Connectors/SqlServerConnector.php',
+ 'Illuminate\\Database\\Console\\Migrations\\BaseCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Console/Migrations/BaseCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\InstallCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Console/Migrations/InstallCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\MigrateCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\MigrateMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateMakeCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\RefreshCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Console/Migrations/RefreshCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\ResetCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Console/Migrations/ResetCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\RollbackCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Console/Migrations/RollbackCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\StatusCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Console/Migrations/StatusCommand.php',
+ 'Illuminate\\Database\\Console\\Seeds\\SeedCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Console/Seeds/SeedCommand.php',
+ 'Illuminate\\Database\\Console\\Seeds\\SeederMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Console/Seeds/SeederMakeCommand.php',
+ 'Illuminate\\Database\\DatabaseManager' => $vendorDir . '/laravel/framework/src/Illuminate/Database/DatabaseManager.php',
+ 'Illuminate\\Database\\DatabaseServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Database/DatabaseServiceProvider.php',
+ 'Illuminate\\Database\\DetectsDeadlocks' => $vendorDir . '/laravel/framework/src/Illuminate/Database/DetectsDeadlocks.php',
+ 'Illuminate\\Database\\DetectsLostConnections' => $vendorDir . '/laravel/framework/src/Illuminate/Database/DetectsLostConnections.php',
+ 'Illuminate\\Database\\Eloquent\\Builder' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Builder.php',
+ 'Illuminate\\Database\\Eloquent\\Collection' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Collection.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\GuardsAttributes' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/GuardsAttributes.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HasAttributes' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasAttributes.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HasEvents' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasEvents.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HasGlobalScopes' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasGlobalScopes.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HasRelationships' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasRelationships.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HasTimestamps' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasTimestamps.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HidesAttributes' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HidesAttributes.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\QueriesRelationships' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/QueriesRelationships.php',
+ 'Illuminate\\Database\\Eloquent\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Factory.php',
+ 'Illuminate\\Database\\Eloquent\\FactoryBuilder' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php',
+ 'Illuminate\\Database\\Eloquent\\JsonEncodingException' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/JsonEncodingException.php',
+ 'Illuminate\\Database\\Eloquent\\MassAssignmentException' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/MassAssignmentException.php',
+ 'Illuminate\\Database\\Eloquent\\Model' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Model.php',
+ 'Illuminate\\Database\\Eloquent\\ModelNotFoundException' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/ModelNotFoundException.php',
+ 'Illuminate\\Database\\Eloquent\\QueueEntityResolver' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/QueueEntityResolver.php',
+ 'Illuminate\\Database\\Eloquent\\RelationNotFoundException' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/RelationNotFoundException.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\BelongsTo' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsTo.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\BelongsToMany' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsToMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\Concerns\\InteractsWithPivotTable' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/InteractsWithPivotTable.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\Concerns\\SupportsDefaultModels' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/SupportsDefaultModels.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\HasMany' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\HasManyThrough' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasManyThrough.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\HasOne' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOne.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\HasOneOrMany' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOneOrMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphMany' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphOne' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOne.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphOneOrMany' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOneOrMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphPivot' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphPivot.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphTo' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphTo.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphToMany' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphToMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\Pivot' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Pivot.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\Relation' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Relation.php',
+ 'Illuminate\\Database\\Eloquent\\Scope' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/Scope.php',
+ 'Illuminate\\Database\\Eloquent\\SoftDeletes' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/SoftDeletes.php',
+ 'Illuminate\\Database\\Eloquent\\SoftDeletingScope' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Eloquent/SoftDeletingScope.php',
+ 'Illuminate\\Database\\Events\\ConnectionEvent' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Events/ConnectionEvent.php',
+ 'Illuminate\\Database\\Events\\QueryExecuted' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Events/QueryExecuted.php',
+ 'Illuminate\\Database\\Events\\StatementPrepared' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Events/StatementPrepared.php',
+ 'Illuminate\\Database\\Events\\TransactionBeginning' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Events/TransactionBeginning.php',
+ 'Illuminate\\Database\\Events\\TransactionCommitted' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Events/TransactionCommitted.php',
+ 'Illuminate\\Database\\Events\\TransactionRolledBack' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Events/TransactionRolledBack.php',
+ 'Illuminate\\Database\\Grammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Grammar.php',
+ 'Illuminate\\Database\\MigrationServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Database/MigrationServiceProvider.php',
+ 'Illuminate\\Database\\Migrations\\DatabaseMigrationRepository' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Migrations/DatabaseMigrationRepository.php',
+ 'Illuminate\\Database\\Migrations\\Migration' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Migrations/Migration.php',
+ 'Illuminate\\Database\\Migrations\\MigrationCreator' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Migrations/MigrationCreator.php',
+ 'Illuminate\\Database\\Migrations\\MigrationRepositoryInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Migrations/MigrationRepositoryInterface.php',
+ 'Illuminate\\Database\\Migrations\\Migrator' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Migrations/Migrator.php',
+ 'Illuminate\\Database\\MySqlConnection' => $vendorDir . '/laravel/framework/src/Illuminate/Database/MySqlConnection.php',
+ 'Illuminate\\Database\\PostgresConnection' => $vendorDir . '/laravel/framework/src/Illuminate/Database/PostgresConnection.php',
+ 'Illuminate\\Database\\QueryException' => $vendorDir . '/laravel/framework/src/Illuminate/Database/QueryException.php',
+ 'Illuminate\\Database\\Query\\Builder' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Builder.php',
+ 'Illuminate\\Database\\Query\\Expression' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Expression.php',
+ 'Illuminate\\Database\\Query\\Grammars\\Grammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Grammars/Grammar.php',
+ 'Illuminate\\Database\\Query\\Grammars\\MySqlGrammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Grammars/MySqlGrammar.php',
+ 'Illuminate\\Database\\Query\\Grammars\\PostgresGrammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Grammars/PostgresGrammar.php',
+ 'Illuminate\\Database\\Query\\Grammars\\SQLiteGrammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Grammars/SQLiteGrammar.php',
+ 'Illuminate\\Database\\Query\\Grammars\\SqlServerGrammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Grammars/SqlServerGrammar.php',
+ 'Illuminate\\Database\\Query\\JoinClause' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/JoinClause.php',
+ 'Illuminate\\Database\\Query\\JsonExpression' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/JsonExpression.php',
+ 'Illuminate\\Database\\Query\\Processors\\MySqlProcessor' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Processors/MySqlProcessor.php',
+ 'Illuminate\\Database\\Query\\Processors\\PostgresProcessor' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Processors/PostgresProcessor.php',
+ 'Illuminate\\Database\\Query\\Processors\\Processor' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Processors/Processor.php',
+ 'Illuminate\\Database\\Query\\Processors\\SQLiteProcessor' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Processors/SQLiteProcessor.php',
+ 'Illuminate\\Database\\Query\\Processors\\SqlServerProcessor' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Query/Processors/SqlServerProcessor.php',
+ 'Illuminate\\Database\\SQLiteConnection' => $vendorDir . '/laravel/framework/src/Illuminate/Database/SQLiteConnection.php',
+ 'Illuminate\\Database\\Schema\\Blueprint' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/Blueprint.php',
+ 'Illuminate\\Database\\Schema\\Builder' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/Builder.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\ChangeColumn' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/ChangeColumn.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\Grammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/Grammar.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\MySqlGrammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/MySqlGrammar.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\PostgresGrammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/PostgresGrammar.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\RenameColumn' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/RenameColumn.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\SQLiteGrammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/SQLiteGrammar.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\SqlServerGrammar' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/SqlServerGrammar.php',
+ 'Illuminate\\Database\\Schema\\MySqlBuilder' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/MySqlBuilder.php',
+ 'Illuminate\\Database\\Schema\\PostgresBuilder' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Schema/PostgresBuilder.php',
+ 'Illuminate\\Database\\Seeder' => $vendorDir . '/laravel/framework/src/Illuminate/Database/Seeder.php',
+ 'Illuminate\\Database\\SqlServerConnection' => $vendorDir . '/laravel/framework/src/Illuminate/Database/SqlServerConnection.php',
+ 'Illuminate\\Encryption\\Encrypter' => $vendorDir . '/laravel/framework/src/Illuminate/Encryption/Encrypter.php',
+ 'Illuminate\\Encryption\\EncryptionServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Encryption/EncryptionServiceProvider.php',
+ 'Illuminate\\Events\\CallQueuedHandler' => $vendorDir . '/laravel/framework/src/Illuminate/Events/CallQueuedHandler.php',
+ 'Illuminate\\Events\\CallQueuedListener' => $vendorDir . '/laravel/framework/src/Illuminate/Events/CallQueuedListener.php',
+ 'Illuminate\\Events\\Dispatcher' => $vendorDir . '/laravel/framework/src/Illuminate/Events/Dispatcher.php',
+ 'Illuminate\\Events\\EventServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Events/EventServiceProvider.php',
+ 'Illuminate\\Filesystem\\Filesystem' => $vendorDir . '/laravel/framework/src/Illuminate/Filesystem/Filesystem.php',
+ 'Illuminate\\Filesystem\\FilesystemAdapter' => $vendorDir . '/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php',
+ 'Illuminate\\Filesystem\\FilesystemManager' => $vendorDir . '/laravel/framework/src/Illuminate/Filesystem/FilesystemManager.php',
+ 'Illuminate\\Filesystem\\FilesystemServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Filesystem/FilesystemServiceProvider.php',
+ 'Illuminate\\Foundation\\AliasLoader' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/AliasLoader.php',
+ 'Illuminate\\Foundation\\Application' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Application.php',
+ 'Illuminate\\Foundation\\Auth\\Access\\Authorizable' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Auth/Access/Authorizable.php',
+ 'Illuminate\\Foundation\\Auth\\Access\\AuthorizesRequests' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Auth/Access/AuthorizesRequests.php',
+ 'Illuminate\\Foundation\\Auth\\AuthenticatesUsers' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php',
+ 'Illuminate\\Foundation\\Auth\\RedirectsUsers' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Auth/RedirectsUsers.php',
+ 'Illuminate\\Foundation\\Auth\\RegistersUsers' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Auth/RegistersUsers.php',
+ 'Illuminate\\Foundation\\Auth\\ResetsPasswords' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Auth/ResetsPasswords.php',
+ 'Illuminate\\Foundation\\Auth\\SendsPasswordResetEmails' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Auth/SendsPasswordResetEmails.php',
+ 'Illuminate\\Foundation\\Auth\\ThrottlesLogins' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Auth/ThrottlesLogins.php',
+ 'Illuminate\\Foundation\\Auth\\User' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Auth/User.php',
+ 'Illuminate\\Foundation\\Bootstrap\\BootProviders' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/BootProviders.php',
+ 'Illuminate\\Foundation\\Bootstrap\\HandleExceptions' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/HandleExceptions.php',
+ 'Illuminate\\Foundation\\Bootstrap\\LoadConfiguration' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadConfiguration.php',
+ 'Illuminate\\Foundation\\Bootstrap\\LoadEnvironmentVariables' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadEnvironmentVariables.php',
+ 'Illuminate\\Foundation\\Bootstrap\\RegisterFacades' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterFacades.php',
+ 'Illuminate\\Foundation\\Bootstrap\\RegisterProviders' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterProviders.php',
+ 'Illuminate\\Foundation\\Bootstrap\\SetRequestForConsole' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/SetRequestForConsole.php',
+ 'Illuminate\\Foundation\\Bus\\Dispatchable' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Bus/Dispatchable.php',
+ 'Illuminate\\Foundation\\Bus\\DispatchesJobs' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Bus/DispatchesJobs.php',
+ 'Illuminate\\Foundation\\Bus\\PendingDispatch' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Bus/PendingDispatch.php',
+ 'Illuminate\\Foundation\\ComposerScripts' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/ComposerScripts.php',
+ 'Illuminate\\Foundation\\Console\\AppNameCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/AppNameCommand.php',
+ 'Illuminate\\Foundation\\Console\\ClearCompiledCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/ClearCompiledCommand.php',
+ 'Illuminate\\Foundation\\Console\\ClosureCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/ClosureCommand.php',
+ 'Illuminate\\Foundation\\Console\\ConfigCacheCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/ConfigCacheCommand.php',
+ 'Illuminate\\Foundation\\Console\\ConfigClearCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/ConfigClearCommand.php',
+ 'Illuminate\\Foundation\\Console\\ConsoleMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/ConsoleMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\DownCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/DownCommand.php',
+ 'Illuminate\\Foundation\\Console\\EnvironmentCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/EnvironmentCommand.php',
+ 'Illuminate\\Foundation\\Console\\EventGenerateCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/EventGenerateCommand.php',
+ 'Illuminate\\Foundation\\Console\\EventMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/EventMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\JobMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/JobMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\Kernel' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/Kernel.php',
+ 'Illuminate\\Foundation\\Console\\KeyGenerateCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/KeyGenerateCommand.php',
+ 'Illuminate\\Foundation\\Console\\ListenerMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/ListenerMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\MailMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/MailMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\ModelMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/ModelMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\NotificationMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/NotificationMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\OptimizeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/OptimizeCommand.php',
+ 'Illuminate\\Foundation\\Console\\PolicyMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/PolicyMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\ProviderMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/ProviderMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\QueuedCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/QueuedCommand.php',
+ 'Illuminate\\Foundation\\Console\\RequestMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/RequestMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\RouteCacheCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/RouteCacheCommand.php',
+ 'Illuminate\\Foundation\\Console\\RouteClearCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/RouteClearCommand.php',
+ 'Illuminate\\Foundation\\Console\\RouteListCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/RouteListCommand.php',
+ 'Illuminate\\Foundation\\Console\\ServeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/ServeCommand.php',
+ 'Illuminate\\Foundation\\Console\\StorageLinkCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/StorageLinkCommand.php',
+ 'Illuminate\\Foundation\\Console\\TestMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/TestMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\UpCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/UpCommand.php',
+ 'Illuminate\\Foundation\\Console\\VendorPublishCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/VendorPublishCommand.php',
+ 'Illuminate\\Foundation\\Console\\ViewClearCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Console/ViewClearCommand.php',
+ 'Illuminate\\Foundation\\EnvironmentDetector' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/EnvironmentDetector.php',
+ 'Illuminate\\Foundation\\Events\\Dispatchable' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Events/Dispatchable.php',
+ 'Illuminate\\Foundation\\Events\\LocaleUpdated' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Events/LocaleUpdated.php',
+ 'Illuminate\\Foundation\\Exceptions\\Handler' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Exceptions/Handler.php',
+ 'Illuminate\\Foundation\\Http\\Events\\RequestHandled' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Http/Events/RequestHandled.php',
+ 'Illuminate\\Foundation\\Http\\Exceptions\\MaintenanceModeException' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Http/Exceptions/MaintenanceModeException.php',
+ 'Illuminate\\Foundation\\Http\\FormRequest' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Http/FormRequest.php',
+ 'Illuminate\\Foundation\\Http\\Kernel' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Http/Kernel.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\CheckForMaintenanceMode' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/CheckForMaintenanceMode.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\ConvertEmptyStringsToNull' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ConvertEmptyStringsToNull.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\TransformsRequest' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/TransformsRequest.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\TrimStrings' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/TrimStrings.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\ValidatePostSize' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ValidatePostSize.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\VerifyCsrfToken' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/VerifyCsrfToken.php',
+ 'Illuminate\\Foundation\\Inspiring' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Inspiring.php',
+ 'Illuminate\\Foundation\\ProviderRepository' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/ProviderRepository.php',
+ 'Illuminate\\Foundation\\Providers\\ArtisanServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Providers/ArtisanServiceProvider.php',
+ 'Illuminate\\Foundation\\Providers\\ComposerServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Providers/ComposerServiceProvider.php',
+ 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Providers/ConsoleSupportServiceProvider.php',
+ 'Illuminate\\Foundation\\Providers\\FormRequestServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Providers/FormRequestServiceProvider.php',
+ 'Illuminate\\Foundation\\Providers\\FoundationServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Providers/FoundationServiceProvider.php',
+ 'Illuminate\\Foundation\\Support\\Providers\\AuthServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Support/Providers/AuthServiceProvider.php',
+ 'Illuminate\\Foundation\\Support\\Providers\\EventServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Support/Providers/EventServiceProvider.php',
+ 'Illuminate\\Foundation\\Support\\Providers\\RouteServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Support/Providers/RouteServiceProvider.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\InteractsWithAuthentication' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithAuthentication.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\InteractsWithConsole' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithConsole.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\InteractsWithContainer' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithContainer.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\InteractsWithDatabase' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithDatabase.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\InteractsWithSession' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithSession.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\MakesHttpRequests' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MakesHttpRequests.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\MocksApplicationServices' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MocksApplicationServices.php',
+ 'Illuminate\\Foundation\\Testing\\Constraints\\HasInDatabase' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/HasInDatabase.php',
+ 'Illuminate\\Foundation\\Testing\\Constraints\\SoftDeletedInDatabase' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/SoftDeletedInDatabase.php',
+ 'Illuminate\\Foundation\\Testing\\DatabaseMigrations' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseMigrations.php',
+ 'Illuminate\\Foundation\\Testing\\DatabaseTransactions' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseTransactions.php',
+ 'Illuminate\\Foundation\\Testing\\HttpException' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/HttpException.php',
+ 'Illuminate\\Foundation\\Testing\\TestCase' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/TestCase.php',
+ 'Illuminate\\Foundation\\Testing\\TestResponse' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/TestResponse.php',
+ 'Illuminate\\Foundation\\Testing\\WithoutEvents' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/WithoutEvents.php',
+ 'Illuminate\\Foundation\\Testing\\WithoutMiddleware' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Testing/WithoutMiddleware.php',
+ 'Illuminate\\Foundation\\Validation\\ValidatesRequests' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/Validation/ValidatesRequests.php',
+ 'Illuminate\\Hashing\\BcryptHasher' => $vendorDir . '/laravel/framework/src/Illuminate/Hashing/BcryptHasher.php',
+ 'Illuminate\\Hashing\\HashServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Hashing/HashServiceProvider.php',
+ 'Illuminate\\Http\\Concerns\\InteractsWithContentTypes' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithContentTypes.php',
+ 'Illuminate\\Http\\Concerns\\InteractsWithFlashData' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithFlashData.php',
+ 'Illuminate\\Http\\Concerns\\InteractsWithInput' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithInput.php',
+ 'Illuminate\\Http\\Exceptions\\HttpResponseException' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Exceptions/HttpResponseException.php',
+ 'Illuminate\\Http\\Exceptions\\PostTooLargeException' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Exceptions/PostTooLargeException.php',
+ 'Illuminate\\Http\\File' => $vendorDir . '/laravel/framework/src/Illuminate/Http/File.php',
+ 'Illuminate\\Http\\FileHelpers' => $vendorDir . '/laravel/framework/src/Illuminate/Http/FileHelpers.php',
+ 'Illuminate\\Http\\JsonResponse' => $vendorDir . '/laravel/framework/src/Illuminate/Http/JsonResponse.php',
+ 'Illuminate\\Http\\Middleware\\CheckResponseForModifications' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Middleware/CheckResponseForModifications.php',
+ 'Illuminate\\Http\\Middleware\\FrameGuard' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Middleware/FrameGuard.php',
+ 'Illuminate\\Http\\RedirectResponse' => $vendorDir . '/laravel/framework/src/Illuminate/Http/RedirectResponse.php',
+ 'Illuminate\\Http\\Request' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Request.php',
+ 'Illuminate\\Http\\Response' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Response.php',
+ 'Illuminate\\Http\\ResponseTrait' => $vendorDir . '/laravel/framework/src/Illuminate/Http/ResponseTrait.php',
+ 'Illuminate\\Http\\Testing\\File' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Testing/File.php',
+ 'Illuminate\\Http\\Testing\\FileFactory' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Testing/FileFactory.php',
+ 'Illuminate\\Http\\Testing\\MimeType' => $vendorDir . '/laravel/framework/src/Illuminate/Http/Testing/MimeType.php',
+ 'Illuminate\\Http\\UploadedFile' => $vendorDir . '/laravel/framework/src/Illuminate/Http/UploadedFile.php',
+ 'Illuminate\\Log\\Events\\MessageLogged' => $vendorDir . '/laravel/framework/src/Illuminate/Log/Events/MessageLogged.php',
+ 'Illuminate\\Log\\LogServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Log/LogServiceProvider.php',
+ 'Illuminate\\Log\\Writer' => $vendorDir . '/laravel/framework/src/Illuminate/Log/Writer.php',
+ 'Illuminate\\Mail\\Events\\MessageSending' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Events/MessageSending.php',
+ 'Illuminate\\Mail\\Events\\MessageSent' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Events/MessageSent.php',
+ 'Illuminate\\Mail\\MailServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/MailServiceProvider.php',
+ 'Illuminate\\Mail\\Mailable' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Mailable.php',
+ 'Illuminate\\Mail\\Mailer' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Mailer.php',
+ 'Illuminate\\Mail\\Markdown' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Markdown.php',
+ 'Illuminate\\Mail\\Message' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Message.php',
+ 'Illuminate\\Mail\\PendingMail' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/PendingMail.php',
+ 'Illuminate\\Mail\\SendQueuedMailable' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/SendQueuedMailable.php',
+ 'Illuminate\\Mail\\TransportManager' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/TransportManager.php',
+ 'Illuminate\\Mail\\Transport\\ArrayTransport' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Transport/ArrayTransport.php',
+ 'Illuminate\\Mail\\Transport\\LogTransport' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Transport/LogTransport.php',
+ 'Illuminate\\Mail\\Transport\\MailgunTransport' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Transport/MailgunTransport.php',
+ 'Illuminate\\Mail\\Transport\\MandrillTransport' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Transport/MandrillTransport.php',
+ 'Illuminate\\Mail\\Transport\\SesTransport' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Transport/SesTransport.php',
+ 'Illuminate\\Mail\\Transport\\SparkPostTransport' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Transport/SparkPostTransport.php',
+ 'Illuminate\\Mail\\Transport\\Transport' => $vendorDir . '/laravel/framework/src/Illuminate/Mail/Transport/Transport.php',
+ 'Illuminate\\Notifications\\Action' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Action.php',
+ 'Illuminate\\Notifications\\ChannelManager' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/ChannelManager.php',
+ 'Illuminate\\Notifications\\Channels\\BroadcastChannel' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Channels/BroadcastChannel.php',
+ 'Illuminate\\Notifications\\Channels\\DatabaseChannel' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Channels/DatabaseChannel.php',
+ 'Illuminate\\Notifications\\Channels\\MailChannel' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Channels/MailChannel.php',
+ 'Illuminate\\Notifications\\Channels\\NexmoSmsChannel' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Channels/NexmoSmsChannel.php',
+ 'Illuminate\\Notifications\\Channels\\SlackWebhookChannel' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Channels/SlackWebhookChannel.php',
+ 'Illuminate\\Notifications\\Console\\NotificationTableCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Console/NotificationTableCommand.php',
+ 'Illuminate\\Notifications\\DatabaseNotification' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/DatabaseNotification.php',
+ 'Illuminate\\Notifications\\DatabaseNotificationCollection' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/DatabaseNotificationCollection.php',
+ 'Illuminate\\Notifications\\Events\\BroadcastNotificationCreated' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Events/BroadcastNotificationCreated.php',
+ 'Illuminate\\Notifications\\Events\\NotificationFailed' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Events/NotificationFailed.php',
+ 'Illuminate\\Notifications\\Events\\NotificationSending' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Events/NotificationSending.php',
+ 'Illuminate\\Notifications\\Events\\NotificationSent' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Events/NotificationSent.php',
+ 'Illuminate\\Notifications\\HasDatabaseNotifications' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/HasDatabaseNotifications.php',
+ 'Illuminate\\Notifications\\Messages\\BroadcastMessage' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Messages/BroadcastMessage.php',
+ 'Illuminate\\Notifications\\Messages\\DatabaseMessage' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Messages/DatabaseMessage.php',
+ 'Illuminate\\Notifications\\Messages\\MailMessage' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Messages/MailMessage.php',
+ 'Illuminate\\Notifications\\Messages\\NexmoMessage' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Messages/NexmoMessage.php',
+ 'Illuminate\\Notifications\\Messages\\SimpleMessage' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Messages/SimpleMessage.php',
+ 'Illuminate\\Notifications\\Messages\\SlackAttachment' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachment.php',
+ 'Illuminate\\Notifications\\Messages\\SlackAttachmentField' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachmentField.php',
+ 'Illuminate\\Notifications\\Messages\\SlackMessage' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Messages/SlackMessage.php',
+ 'Illuminate\\Notifications\\Notifiable' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Notifiable.php',
+ 'Illuminate\\Notifications\\Notification' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/Notification.php',
+ 'Illuminate\\Notifications\\NotificationSender' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/NotificationSender.php',
+ 'Illuminate\\Notifications\\NotificationServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/NotificationServiceProvider.php',
+ 'Illuminate\\Notifications\\RoutesNotifications' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/RoutesNotifications.php',
+ 'Illuminate\\Notifications\\SendQueuedNotifications' => $vendorDir . '/laravel/framework/src/Illuminate/Notifications/SendQueuedNotifications.php',
+ 'Illuminate\\Pagination\\AbstractPaginator' => $vendorDir . '/laravel/framework/src/Illuminate/Pagination/AbstractPaginator.php',
+ 'Illuminate\\Pagination\\LengthAwarePaginator' => $vendorDir . '/laravel/framework/src/Illuminate/Pagination/LengthAwarePaginator.php',
+ 'Illuminate\\Pagination\\PaginationServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Pagination/PaginationServiceProvider.php',
+ 'Illuminate\\Pagination\\Paginator' => $vendorDir . '/laravel/framework/src/Illuminate/Pagination/Paginator.php',
+ 'Illuminate\\Pagination\\UrlWindow' => $vendorDir . '/laravel/framework/src/Illuminate/Pagination/UrlWindow.php',
+ 'Illuminate\\Pipeline\\Hub' => $vendorDir . '/laravel/framework/src/Illuminate/Pipeline/Hub.php',
+ 'Illuminate\\Pipeline\\Pipeline' => $vendorDir . '/laravel/framework/src/Illuminate/Pipeline/Pipeline.php',
+ 'Illuminate\\Pipeline\\PipelineServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Pipeline/PipelineServiceProvider.php',
+ 'Illuminate\\Queue\\BeanstalkdQueue' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/BeanstalkdQueue.php',
+ 'Illuminate\\Queue\\CallQueuedHandler' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/CallQueuedHandler.php',
+ 'Illuminate\\Queue\\Capsule\\Manager' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Capsule/Manager.php',
+ 'Illuminate\\Queue\\Connectors\\BeanstalkdConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Connectors/BeanstalkdConnector.php',
+ 'Illuminate\\Queue\\Connectors\\ConnectorInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Connectors/ConnectorInterface.php',
+ 'Illuminate\\Queue\\Connectors\\DatabaseConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Connectors/DatabaseConnector.php',
+ 'Illuminate\\Queue\\Connectors\\NullConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Connectors/NullConnector.php',
+ 'Illuminate\\Queue\\Connectors\\RedisConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Connectors/RedisConnector.php',
+ 'Illuminate\\Queue\\Connectors\\SqsConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Connectors/SqsConnector.php',
+ 'Illuminate\\Queue\\Connectors\\SyncConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Connectors/SyncConnector.php',
+ 'Illuminate\\Queue\\Console\\FailedTableCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Console/FailedTableCommand.php',
+ 'Illuminate\\Queue\\Console\\FlushFailedCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Console/FlushFailedCommand.php',
+ 'Illuminate\\Queue\\Console\\ForgetFailedCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Console/ForgetFailedCommand.php',
+ 'Illuminate\\Queue\\Console\\ListFailedCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Console/ListFailedCommand.php',
+ 'Illuminate\\Queue\\Console\\ListenCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Console/ListenCommand.php',
+ 'Illuminate\\Queue\\Console\\RestartCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Console/RestartCommand.php',
+ 'Illuminate\\Queue\\Console\\RetryCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Console/RetryCommand.php',
+ 'Illuminate\\Queue\\Console\\TableCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Console/TableCommand.php',
+ 'Illuminate\\Queue\\Console\\WorkCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Console/WorkCommand.php',
+ 'Illuminate\\Queue\\DatabaseQueue' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/DatabaseQueue.php',
+ 'Illuminate\\Queue\\Events\\JobExceptionOccurred' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Events/JobExceptionOccurred.php',
+ 'Illuminate\\Queue\\Events\\JobFailed' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Events/JobFailed.php',
+ 'Illuminate\\Queue\\Events\\JobProcessed' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Events/JobProcessed.php',
+ 'Illuminate\\Queue\\Events\\JobProcessing' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Events/JobProcessing.php',
+ 'Illuminate\\Queue\\Events\\Looping' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Events/Looping.php',
+ 'Illuminate\\Queue\\Events\\WorkerStopping' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Events/WorkerStopping.php',
+ 'Illuminate\\Queue\\Failed\\DatabaseFailedJobProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Failed/DatabaseFailedJobProvider.php',
+ 'Illuminate\\Queue\\Failed\\FailedJobProviderInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Failed/FailedJobProviderInterface.php',
+ 'Illuminate\\Queue\\Failed\\NullFailedJobProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Failed/NullFailedJobProvider.php',
+ 'Illuminate\\Queue\\FailingJob' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/FailingJob.php',
+ 'Illuminate\\Queue\\InteractsWithQueue' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/InteractsWithQueue.php',
+ 'Illuminate\\Queue\\InteractsWithTime' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/InteractsWithTime.php',
+ 'Illuminate\\Queue\\InvalidPayloadException' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/InvalidPayloadException.php',
+ 'Illuminate\\Queue\\Jobs\\BeanstalkdJob' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Jobs/BeanstalkdJob.php',
+ 'Illuminate\\Queue\\Jobs\\DatabaseJob' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJob.php',
+ 'Illuminate\\Queue\\Jobs\\DatabaseJobRecord' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJobRecord.php',
+ 'Illuminate\\Queue\\Jobs\\Job' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Jobs/Job.php',
+ 'Illuminate\\Queue\\Jobs\\JobName' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Jobs/JobName.php',
+ 'Illuminate\\Queue\\Jobs\\RedisJob' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Jobs/RedisJob.php',
+ 'Illuminate\\Queue\\Jobs\\SqsJob' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Jobs/SqsJob.php',
+ 'Illuminate\\Queue\\Jobs\\SyncJob' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Jobs/SyncJob.php',
+ 'Illuminate\\Queue\\Listener' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Listener.php',
+ 'Illuminate\\Queue\\ListenerOptions' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/ListenerOptions.php',
+ 'Illuminate\\Queue\\LuaScripts' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/LuaScripts.php',
+ 'Illuminate\\Queue\\ManuallyFailedException' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/ManuallyFailedException.php',
+ 'Illuminate\\Queue\\MaxAttemptsExceededException' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/MaxAttemptsExceededException.php',
+ 'Illuminate\\Queue\\NullQueue' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/NullQueue.php',
+ 'Illuminate\\Queue\\Queue' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Queue.php',
+ 'Illuminate\\Queue\\QueueManager' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/QueueManager.php',
+ 'Illuminate\\Queue\\QueueServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/QueueServiceProvider.php',
+ 'Illuminate\\Queue\\RedisQueue' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/RedisQueue.php',
+ 'Illuminate\\Queue\\SerializesAndRestoresModelIdentifiers' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/SerializesAndRestoresModelIdentifiers.php',
+ 'Illuminate\\Queue\\SerializesModels' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/SerializesModels.php',
+ 'Illuminate\\Queue\\SqsQueue' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/SqsQueue.php',
+ 'Illuminate\\Queue\\SyncQueue' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/SyncQueue.php',
+ 'Illuminate\\Queue\\Worker' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/Worker.php',
+ 'Illuminate\\Queue\\WorkerOptions' => $vendorDir . '/laravel/framework/src/Illuminate/Queue/WorkerOptions.php',
+ 'Illuminate\\Redis\\Connections\\Connection' => $vendorDir . '/laravel/framework/src/Illuminate/Redis/Connections/Connection.php',
+ 'Illuminate\\Redis\\Connections\\PhpRedisClusterConnection' => $vendorDir . '/laravel/framework/src/Illuminate/Redis/Connections/PhpRedisClusterConnection.php',
+ 'Illuminate\\Redis\\Connections\\PhpRedisConnection' => $vendorDir . '/laravel/framework/src/Illuminate/Redis/Connections/PhpRedisConnection.php',
+ 'Illuminate\\Redis\\Connections\\PredisClusterConnection' => $vendorDir . '/laravel/framework/src/Illuminate/Redis/Connections/PredisClusterConnection.php',
+ 'Illuminate\\Redis\\Connections\\PredisConnection' => $vendorDir . '/laravel/framework/src/Illuminate/Redis/Connections/PredisConnection.php',
+ 'Illuminate\\Redis\\Connectors\\PhpRedisConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Redis/Connectors/PhpRedisConnector.php',
+ 'Illuminate\\Redis\\Connectors\\PredisConnector' => $vendorDir . '/laravel/framework/src/Illuminate/Redis/Connectors/PredisConnector.php',
+ 'Illuminate\\Redis\\RedisManager' => $vendorDir . '/laravel/framework/src/Illuminate/Redis/RedisManager.php',
+ 'Illuminate\\Redis\\RedisServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Redis/RedisServiceProvider.php',
+ 'Illuminate\\Routing\\Console\\ControllerMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Console/ControllerMakeCommand.php',
+ 'Illuminate\\Routing\\Console\\MiddlewareMakeCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Console/MiddlewareMakeCommand.php',
+ 'Illuminate\\Routing\\Controller' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Controller.php',
+ 'Illuminate\\Routing\\ControllerDispatcher' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php',
+ 'Illuminate\\Routing\\ControllerMiddlewareOptions' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/ControllerMiddlewareOptions.php',
+ 'Illuminate\\Routing\\Events\\RouteMatched' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Events/RouteMatched.php',
+ 'Illuminate\\Routing\\Exceptions\\UrlGenerationException' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Exceptions/UrlGenerationException.php',
+ 'Illuminate\\Routing\\ImplicitRouteBinding' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/ImplicitRouteBinding.php',
+ 'Illuminate\\Routing\\Matching\\HostValidator' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Matching/HostValidator.php',
+ 'Illuminate\\Routing\\Matching\\MethodValidator' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Matching/MethodValidator.php',
+ 'Illuminate\\Routing\\Matching\\SchemeValidator' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Matching/SchemeValidator.php',
+ 'Illuminate\\Routing\\Matching\\UriValidator' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Matching/UriValidator.php',
+ 'Illuminate\\Routing\\Matching\\ValidatorInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Matching/ValidatorInterface.php',
+ 'Illuminate\\Routing\\MiddlewareNameResolver' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/MiddlewareNameResolver.php',
+ 'Illuminate\\Routing\\Middleware\\SubstituteBindings' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Middleware/SubstituteBindings.php',
+ 'Illuminate\\Routing\\Middleware\\ThrottleRequests' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Middleware/ThrottleRequests.php',
+ 'Illuminate\\Routing\\Pipeline' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Pipeline.php',
+ 'Illuminate\\Routing\\Redirector' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Redirector.php',
+ 'Illuminate\\Routing\\ResourceRegistrar' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/ResourceRegistrar.php',
+ 'Illuminate\\Routing\\ResponseFactory' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/ResponseFactory.php',
+ 'Illuminate\\Routing\\Route' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Route.php',
+ 'Illuminate\\Routing\\RouteAction' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RouteAction.php',
+ 'Illuminate\\Routing\\RouteBinding' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RouteBinding.php',
+ 'Illuminate\\Routing\\RouteCollection' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RouteCollection.php',
+ 'Illuminate\\Routing\\RouteCompiler' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RouteCompiler.php',
+ 'Illuminate\\Routing\\RouteDependencyResolverTrait' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RouteDependencyResolverTrait.php',
+ 'Illuminate\\Routing\\RouteGroup' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RouteGroup.php',
+ 'Illuminate\\Routing\\RouteParameterBinder' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RouteParameterBinder.php',
+ 'Illuminate\\Routing\\RouteRegistrar' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RouteRegistrar.php',
+ 'Illuminate\\Routing\\RouteSignatureParameters' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RouteSignatureParameters.php',
+ 'Illuminate\\Routing\\RouteUrlGenerator' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RouteUrlGenerator.php',
+ 'Illuminate\\Routing\\Router' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/Router.php',
+ 'Illuminate\\Routing\\RoutingServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/RoutingServiceProvider.php',
+ 'Illuminate\\Routing\\SortedMiddleware' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/SortedMiddleware.php',
+ 'Illuminate\\Routing\\UrlGenerator' => $vendorDir . '/laravel/framework/src/Illuminate/Routing/UrlGenerator.php',
+ 'Illuminate\\Session\\CacheBasedSessionHandler' => $vendorDir . '/laravel/framework/src/Illuminate/Session/CacheBasedSessionHandler.php',
+ 'Illuminate\\Session\\Console\\SessionTableCommand' => $vendorDir . '/laravel/framework/src/Illuminate/Session/Console/SessionTableCommand.php',
+ 'Illuminate\\Session\\CookieSessionHandler' => $vendorDir . '/laravel/framework/src/Illuminate/Session/CookieSessionHandler.php',
+ 'Illuminate\\Session\\DatabaseSessionHandler' => $vendorDir . '/laravel/framework/src/Illuminate/Session/DatabaseSessionHandler.php',
+ 'Illuminate\\Session\\EncryptedStore' => $vendorDir . '/laravel/framework/src/Illuminate/Session/EncryptedStore.php',
+ 'Illuminate\\Session\\ExistenceAwareInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Session/ExistenceAwareInterface.php',
+ 'Illuminate\\Session\\FileSessionHandler' => $vendorDir . '/laravel/framework/src/Illuminate/Session/FileSessionHandler.php',
+ 'Illuminate\\Session\\Middleware\\AuthenticateSession' => $vendorDir . '/laravel/framework/src/Illuminate/Session/Middleware/AuthenticateSession.php',
+ 'Illuminate\\Session\\Middleware\\StartSession' => $vendorDir . '/laravel/framework/src/Illuminate/Session/Middleware/StartSession.php',
+ 'Illuminate\\Session\\SessionManager' => $vendorDir . '/laravel/framework/src/Illuminate/Session/SessionManager.php',
+ 'Illuminate\\Session\\SessionServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Session/SessionServiceProvider.php',
+ 'Illuminate\\Session\\Store' => $vendorDir . '/laravel/framework/src/Illuminate/Session/Store.php',
+ 'Illuminate\\Session\\TokenMismatchException' => $vendorDir . '/laravel/framework/src/Illuminate/Session/TokenMismatchException.php',
+ 'Illuminate\\Support\\AggregateServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Support/AggregateServiceProvider.php',
+ 'Illuminate\\Support\\Arr' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Arr.php',
+ 'Illuminate\\Support\\Collection' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Collection.php',
+ 'Illuminate\\Support\\Composer' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Composer.php',
+ 'Illuminate\\Support\\Debug\\Dumper' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Debug/Dumper.php',
+ 'Illuminate\\Support\\Debug\\HtmlDumper' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Debug/HtmlDumper.php',
+ 'Illuminate\\Support\\Facades\\App' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/App.php',
+ 'Illuminate\\Support\\Facades\\Artisan' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Artisan.php',
+ 'Illuminate\\Support\\Facades\\Auth' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Auth.php',
+ 'Illuminate\\Support\\Facades\\Blade' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Blade.php',
+ 'Illuminate\\Support\\Facades\\Broadcast' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Broadcast.php',
+ 'Illuminate\\Support\\Facades\\Bus' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Bus.php',
+ 'Illuminate\\Support\\Facades\\Cache' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Cache.php',
+ 'Illuminate\\Support\\Facades\\Config' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Config.php',
+ 'Illuminate\\Support\\Facades\\Cookie' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Cookie.php',
+ 'Illuminate\\Support\\Facades\\Crypt' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Crypt.php',
+ 'Illuminate\\Support\\Facades\\DB' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/DB.php',
+ 'Illuminate\\Support\\Facades\\Event' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Event.php',
+ 'Illuminate\\Support\\Facades\\Facade' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Facade.php',
+ 'Illuminate\\Support\\Facades\\File' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/File.php',
+ 'Illuminate\\Support\\Facades\\Gate' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Gate.php',
+ 'Illuminate\\Support\\Facades\\Hash' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Hash.php',
+ 'Illuminate\\Support\\Facades\\Input' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Input.php',
+ 'Illuminate\\Support\\Facades\\Lang' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Lang.php',
+ 'Illuminate\\Support\\Facades\\Log' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Log.php',
+ 'Illuminate\\Support\\Facades\\Mail' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Mail.php',
+ 'Illuminate\\Support\\Facades\\Notification' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Notification.php',
+ 'Illuminate\\Support\\Facades\\Password' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Password.php',
+ 'Illuminate\\Support\\Facades\\Queue' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Queue.php',
+ 'Illuminate\\Support\\Facades\\Redirect' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Redirect.php',
+ 'Illuminate\\Support\\Facades\\Redis' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Redis.php',
+ 'Illuminate\\Support\\Facades\\Request' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Request.php',
+ 'Illuminate\\Support\\Facades\\Response' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Response.php',
+ 'Illuminate\\Support\\Facades\\Route' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Route.php',
+ 'Illuminate\\Support\\Facades\\Schema' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Schema.php',
+ 'Illuminate\\Support\\Facades\\Session' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Session.php',
+ 'Illuminate\\Support\\Facades\\Storage' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Storage.php',
+ 'Illuminate\\Support\\Facades\\URL' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/URL.php',
+ 'Illuminate\\Support\\Facades\\Validator' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/Validator.php',
+ 'Illuminate\\Support\\Facades\\View' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Facades/View.php',
+ 'Illuminate\\Support\\Fluent' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Fluent.php',
+ 'Illuminate\\Support\\HigherOrderCollectionProxy' => $vendorDir . '/laravel/framework/src/Illuminate/Support/HigherOrderCollectionProxy.php',
+ 'Illuminate\\Support\\HigherOrderTapProxy' => $vendorDir . '/laravel/framework/src/Illuminate/Support/HigherOrderTapProxy.php',
+ 'Illuminate\\Support\\HtmlString' => $vendorDir . '/laravel/framework/src/Illuminate/Support/HtmlString.php',
+ 'Illuminate\\Support\\Manager' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Manager.php',
+ 'Illuminate\\Support\\MessageBag' => $vendorDir . '/laravel/framework/src/Illuminate/Support/MessageBag.php',
+ 'Illuminate\\Support\\NamespacedItemResolver' => $vendorDir . '/laravel/framework/src/Illuminate/Support/NamespacedItemResolver.php',
+ 'Illuminate\\Support\\Pluralizer' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Pluralizer.php',
+ 'Illuminate\\Support\\ServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Support/ServiceProvider.php',
+ 'Illuminate\\Support\\Str' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Str.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\BusFake' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/BusFake.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\EventFake' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/EventFake.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\MailFake' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/MailFake.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\NotificationFake' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/NotificationFake.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\PendingMailFake' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/PendingMailFake.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\QueueFake' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/QueueFake.php',
+ 'Illuminate\\Support\\Traits\\CapsuleManagerTrait' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Traits/CapsuleManagerTrait.php',
+ 'Illuminate\\Support\\Traits\\Macroable' => $vendorDir . '/laravel/framework/src/Illuminate/Support/Traits/Macroable.php',
+ 'Illuminate\\Support\\ViewErrorBag' => $vendorDir . '/laravel/framework/src/Illuminate/Support/ViewErrorBag.php',
+ 'Illuminate\\Translation\\ArrayLoader' => $vendorDir . '/laravel/framework/src/Illuminate/Translation/ArrayLoader.php',
+ 'Illuminate\\Translation\\FileLoader' => $vendorDir . '/laravel/framework/src/Illuminate/Translation/FileLoader.php',
+ 'Illuminate\\Translation\\LoaderInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Translation/LoaderInterface.php',
+ 'Illuminate\\Translation\\MessageSelector' => $vendorDir . '/laravel/framework/src/Illuminate/Translation/MessageSelector.php',
+ 'Illuminate\\Translation\\TranslationServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Translation/TranslationServiceProvider.php',
+ 'Illuminate\\Translation\\Translator' => $vendorDir . '/laravel/framework/src/Illuminate/Translation/Translator.php',
+ 'Illuminate\\Validation\\Concerns\\FormatsMessages' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Concerns/FormatsMessages.php',
+ 'Illuminate\\Validation\\Concerns\\ReplacesAttributes' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Concerns/ReplacesAttributes.php',
+ 'Illuminate\\Validation\\Concerns\\ValidatesAttributes' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Concerns/ValidatesAttributes.php',
+ 'Illuminate\\Validation\\DatabasePresenceVerifier' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/DatabasePresenceVerifier.php',
+ 'Illuminate\\Validation\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Factory.php',
+ 'Illuminate\\Validation\\PresenceVerifierInterface' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/PresenceVerifierInterface.php',
+ 'Illuminate\\Validation\\Rule' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Rule.php',
+ 'Illuminate\\Validation\\Rules\\Dimensions' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Rules/Dimensions.php',
+ 'Illuminate\\Validation\\Rules\\Exists' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Rules/Exists.php',
+ 'Illuminate\\Validation\\Rules\\In' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Rules/In.php',
+ 'Illuminate\\Validation\\Rules\\NotIn' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Rules/NotIn.php',
+ 'Illuminate\\Validation\\Rules\\Unique' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Rules/Unique.php',
+ 'Illuminate\\Validation\\UnauthorizedException' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/UnauthorizedException.php',
+ 'Illuminate\\Validation\\ValidatesWhenResolvedTrait' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/ValidatesWhenResolvedTrait.php',
+ 'Illuminate\\Validation\\ValidationData' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/ValidationData.php',
+ 'Illuminate\\Validation\\ValidationException' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/ValidationException.php',
+ 'Illuminate\\Validation\\ValidationRuleParser' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/ValidationRuleParser.php',
+ 'Illuminate\\Validation\\ValidationServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/ValidationServiceProvider.php',
+ 'Illuminate\\Validation\\Validator' => $vendorDir . '/laravel/framework/src/Illuminate/Validation/Validator.php',
+ 'Illuminate\\View\\Compilers\\BladeCompiler' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/BladeCompiler.php',
+ 'Illuminate\\View\\Compilers\\Compiler' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Compiler.php',
+ 'Illuminate\\View\\Compilers\\CompilerInterface' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/CompilerInterface.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesAuthorizations' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesAuthorizations.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesComments' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComments.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesComponents' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComponents.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesConditionals' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesConditionals.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesEchos' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesEchos.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesIncludes' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesIncludes.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesInjections' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesInjections.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesLayouts' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLayouts.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesLoops' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLoops.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesRawPhp' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesRawPhp.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesStacks' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesStacks.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesTranslations' => $vendorDir . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesTranslations.php',
+ 'Illuminate\\View\\Concerns\\ManagesComponents' => $vendorDir . '/laravel/framework/src/Illuminate/View/Concerns/ManagesComponents.php',
+ 'Illuminate\\View\\Concerns\\ManagesEvents' => $vendorDir . '/laravel/framework/src/Illuminate/View/Concerns/ManagesEvents.php',
+ 'Illuminate\\View\\Concerns\\ManagesLayouts' => $vendorDir . '/laravel/framework/src/Illuminate/View/Concerns/ManagesLayouts.php',
+ 'Illuminate\\View\\Concerns\\ManagesLoops' => $vendorDir . '/laravel/framework/src/Illuminate/View/Concerns/ManagesLoops.php',
+ 'Illuminate\\View\\Concerns\\ManagesStacks' => $vendorDir . '/laravel/framework/src/Illuminate/View/Concerns/ManagesStacks.php',
+ 'Illuminate\\View\\Concerns\\ManagesTranslations' => $vendorDir . '/laravel/framework/src/Illuminate/View/Concerns/ManagesTranslations.php',
+ 'Illuminate\\View\\Engines\\CompilerEngine' => $vendorDir . '/laravel/framework/src/Illuminate/View/Engines/CompilerEngine.php',
+ 'Illuminate\\View\\Engines\\Engine' => $vendorDir . '/laravel/framework/src/Illuminate/View/Engines/Engine.php',
+ 'Illuminate\\View\\Engines\\EngineInterface' => $vendorDir . '/laravel/framework/src/Illuminate/View/Engines/EngineInterface.php',
+ 'Illuminate\\View\\Engines\\EngineResolver' => $vendorDir . '/laravel/framework/src/Illuminate/View/Engines/EngineResolver.php',
+ 'Illuminate\\View\\Engines\\FileEngine' => $vendorDir . '/laravel/framework/src/Illuminate/View/Engines/FileEngine.php',
+ 'Illuminate\\View\\Engines\\PhpEngine' => $vendorDir . '/laravel/framework/src/Illuminate/View/Engines/PhpEngine.php',
+ 'Illuminate\\View\\Factory' => $vendorDir . '/laravel/framework/src/Illuminate/View/Factory.php',
+ 'Illuminate\\View\\FileViewFinder' => $vendorDir . '/laravel/framework/src/Illuminate/View/FileViewFinder.php',
+ 'Illuminate\\View\\Middleware\\ShareErrorsFromSession' => $vendorDir . '/laravel/framework/src/Illuminate/View/Middleware/ShareErrorsFromSession.php',
+ 'Illuminate\\View\\View' => $vendorDir . '/laravel/framework/src/Illuminate/View/View.php',
+ 'Illuminate\\View\\ViewFinderInterface' => $vendorDir . '/laravel/framework/src/Illuminate/View/ViewFinderInterface.php',
+ 'Illuminate\\View\\ViewName' => $vendorDir . '/laravel/framework/src/Illuminate/View/ViewName.php',
+ 'Illuminate\\View\\ViewServiceProvider' => $vendorDir . '/laravel/framework/src/Illuminate/View/ViewServiceProvider.php',
+ 'JakubOnderka\\PhpConsoleColor\\ConsoleColor' => $vendorDir . '/jakub-onderka/php-console-color/src/ConsoleColor.php',
+ 'JakubOnderka\\PhpConsoleColor\\InvalidStyleException' => $vendorDir . '/jakub-onderka/php-console-color/src/InvalidStyleException.php',
+ 'JakubOnderka\\PhpConsoleHighlighter\\Highlighter' => $vendorDir . '/jakub-onderka/php-console-highlighter/src/Highlighter.php',
+ 'JsonSerializable' => $vendorDir . '/nesbot/carbon/src/JsonSerializable.php',
+ 'Laravel\\Tinker\\ClassAliasAutoloader' => $vendorDir . '/laravel/tinker/src/ClassAliasAutoloader.php',
+ 'Laravel\\Tinker\\Console\\TinkerCommand' => $vendorDir . '/laravel/tinker/src/Console/TinkerCommand.php',
+ 'Laravel\\Tinker\\TinkerCaster' => $vendorDir . '/laravel/tinker/src/TinkerCaster.php',
+ 'Laravel\\Tinker\\TinkerServiceProvider' => $vendorDir . '/laravel/tinker/src/TinkerServiceProvider.php',
+ 'League\\Flysystem\\AdapterInterface' => $vendorDir . '/league/flysystem/src/AdapterInterface.php',
+ 'League\\Flysystem\\Adapter\\AbstractAdapter' => $vendorDir . '/league/flysystem/src/Adapter/AbstractAdapter.php',
+ 'League\\Flysystem\\Adapter\\AbstractFtpAdapter' => $vendorDir . '/league/flysystem/src/Adapter/AbstractFtpAdapter.php',
+ 'League\\Flysystem\\Adapter\\CanOverwriteFiles' => $vendorDir . '/league/flysystem/src/Adapter/CanOverwriteFiles.php',
+ 'League\\Flysystem\\Adapter\\Ftp' => $vendorDir . '/league/flysystem/src/Adapter/Ftp.php',
+ 'League\\Flysystem\\Adapter\\Ftpd' => $vendorDir . '/league/flysystem/src/Adapter/Ftpd.php',
+ 'League\\Flysystem\\Adapter\\Local' => $vendorDir . '/league/flysystem/src/Adapter/Local.php',
+ 'League\\Flysystem\\Adapter\\NullAdapter' => $vendorDir . '/league/flysystem/src/Adapter/NullAdapter.php',
+ 'League\\Flysystem\\Adapter\\Polyfill\\NotSupportingVisibilityTrait' => $vendorDir . '/league/flysystem/src/Adapter/Polyfill/NotSupportingVisibilityTrait.php',
+ 'League\\Flysystem\\Adapter\\Polyfill\\StreamedCopyTrait' => $vendorDir . '/league/flysystem/src/Adapter/Polyfill/StreamedCopyTrait.php',
+ 'League\\Flysystem\\Adapter\\Polyfill\\StreamedReadingTrait' => $vendorDir . '/league/flysystem/src/Adapter/Polyfill/StreamedReadingTrait.php',
+ 'League\\Flysystem\\Adapter\\Polyfill\\StreamedTrait' => $vendorDir . '/league/flysystem/src/Adapter/Polyfill/StreamedTrait.php',
+ 'League\\Flysystem\\Adapter\\Polyfill\\StreamedWritingTrait' => $vendorDir . '/league/flysystem/src/Adapter/Polyfill/StreamedWritingTrait.php',
+ 'League\\Flysystem\\Adapter\\SynologyFtp' => $vendorDir . '/league/flysystem/src/Adapter/SynologyFtp.php',
+ 'League\\Flysystem\\Config' => $vendorDir . '/league/flysystem/src/Config.php',
+ 'League\\Flysystem\\ConfigAwareTrait' => $vendorDir . '/league/flysystem/src/ConfigAwareTrait.php',
+ 'League\\Flysystem\\ConnectionErrorException' => $vendorDir . '/league/flysystem/src/ConnectionErrorException.php',
+ 'League\\Flysystem\\ConnectionRuntimeException' => $vendorDir . '/league/flysystem/src/ConnectionRuntimeException.php',
+ 'League\\Flysystem\\Directory' => $vendorDir . '/league/flysystem/src/Directory.php',
+ 'League\\Flysystem\\Exception' => $vendorDir . '/league/flysystem/src/Exception.php',
+ 'League\\Flysystem\\File' => $vendorDir . '/league/flysystem/src/File.php',
+ 'League\\Flysystem\\FileExistsException' => $vendorDir . '/league/flysystem/src/FileExistsException.php',
+ 'League\\Flysystem\\FileNotFoundException' => $vendorDir . '/league/flysystem/src/FileNotFoundException.php',
+ 'League\\Flysystem\\Filesystem' => $vendorDir . '/league/flysystem/src/Filesystem.php',
+ 'League\\Flysystem\\FilesystemException' => $vendorDir . '/league/flysystem/src/FilesystemException.php',
+ 'League\\Flysystem\\FilesystemInterface' => $vendorDir . '/league/flysystem/src/FilesystemInterface.php',
+ 'League\\Flysystem\\FilesystemNotFoundException' => $vendorDir . '/league/flysystem/src/FilesystemNotFoundException.php',
+ 'League\\Flysystem\\Handler' => $vendorDir . '/league/flysystem/src/Handler.php',
+ 'League\\Flysystem\\InvalidRootException' => $vendorDir . '/league/flysystem/src/InvalidRootException.php',
+ 'League\\Flysystem\\MountManager' => $vendorDir . '/league/flysystem/src/MountManager.php',
+ 'League\\Flysystem\\NotSupportedException' => $vendorDir . '/league/flysystem/src/NotSupportedException.php',
+ 'League\\Flysystem\\PluginInterface' => $vendorDir . '/league/flysystem/src/PluginInterface.php',
+ 'League\\Flysystem\\Plugin\\AbstractPlugin' => $vendorDir . '/league/flysystem/src/Plugin/AbstractPlugin.php',
+ 'League\\Flysystem\\Plugin\\EmptyDir' => $vendorDir . '/league/flysystem/src/Plugin/EmptyDir.php',
+ 'League\\Flysystem\\Plugin\\ForcedCopy' => $vendorDir . '/league/flysystem/src/Plugin/ForcedCopy.php',
+ 'League\\Flysystem\\Plugin\\ForcedRename' => $vendorDir . '/league/flysystem/src/Plugin/ForcedRename.php',
+ 'League\\Flysystem\\Plugin\\GetWithMetadata' => $vendorDir . '/league/flysystem/src/Plugin/GetWithMetadata.php',
+ 'League\\Flysystem\\Plugin\\ListFiles' => $vendorDir . '/league/flysystem/src/Plugin/ListFiles.php',
+ 'League\\Flysystem\\Plugin\\ListPaths' => $vendorDir . '/league/flysystem/src/Plugin/ListPaths.php',
+ 'League\\Flysystem\\Plugin\\ListWith' => $vendorDir . '/league/flysystem/src/Plugin/ListWith.php',
+ 'League\\Flysystem\\Plugin\\PluggableTrait' => $vendorDir . '/league/flysystem/src/Plugin/PluggableTrait.php',
+ 'League\\Flysystem\\Plugin\\PluginNotFoundException' => $vendorDir . '/league/flysystem/src/Plugin/PluginNotFoundException.php',
+ 'League\\Flysystem\\ReadInterface' => $vendorDir . '/league/flysystem/src/ReadInterface.php',
+ 'League\\Flysystem\\RootViolationException' => $vendorDir . '/league/flysystem/src/RootViolationException.php',
+ 'League\\Flysystem\\SafeStorage' => $vendorDir . '/league/flysystem/src/SafeStorage.php',
+ 'League\\Flysystem\\UnreadableFileException' => $vendorDir . '/league/flysystem/src/UnreadableFileException.php',
+ 'League\\Flysystem\\Util' => $vendorDir . '/league/flysystem/src/Util.php',
+ 'League\\Flysystem\\Util\\ContentListingFormatter' => $vendorDir . '/league/flysystem/src/Util/ContentListingFormatter.php',
+ 'League\\Flysystem\\Util\\MimeType' => $vendorDir . '/league/flysystem/src/Util/MimeType.php',
+ 'League\\Flysystem\\Util\\StreamHasher' => $vendorDir . '/league/flysystem/src/Util/StreamHasher.php',
+ 'Mockery' => $vendorDir . '/mockery/mockery/library/Mockery.php',
+ 'Mockery\\Adapter\\Phpunit\\MockeryPHPUnitIntegration' => $vendorDir . '/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryPHPUnitIntegration.php',
+ 'Mockery\\Adapter\\Phpunit\\MockeryTestCase' => $vendorDir . '/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryTestCase.php',
+ 'Mockery\\Adapter\\Phpunit\\TestListener' => $vendorDir . '/mockery/mockery/library/Mockery/Adapter/Phpunit/TestListener.php',
+ 'Mockery\\CompositeExpectation' => $vendorDir . '/mockery/mockery/library/Mockery/CompositeExpectation.php',
+ 'Mockery\\Configuration' => $vendorDir . '/mockery/mockery/library/Mockery/Configuration.php',
+ 'Mockery\\Container' => $vendorDir . '/mockery/mockery/library/Mockery/Container.php',
+ 'Mockery\\CountValidator\\AtLeast' => $vendorDir . '/mockery/mockery/library/Mockery/CountValidator/AtLeast.php',
+ 'Mockery\\CountValidator\\AtMost' => $vendorDir . '/mockery/mockery/library/Mockery/CountValidator/AtMost.php',
+ 'Mockery\\CountValidator\\CountValidatorAbstract' => $vendorDir . '/mockery/mockery/library/Mockery/CountValidator/CountValidatorAbstract.php',
+ 'Mockery\\CountValidator\\Exact' => $vendorDir . '/mockery/mockery/library/Mockery/CountValidator/Exact.php',
+ 'Mockery\\CountValidator\\Exception' => $vendorDir . '/mockery/mockery/library/Mockery/CountValidator/Exception.php',
+ 'Mockery\\Exception' => $vendorDir . '/mockery/mockery/library/Mockery/Exception.php',
+ 'Mockery\\Exception\\InvalidCountException' => $vendorDir . '/mockery/mockery/library/Mockery/Exception/InvalidCountException.php',
+ 'Mockery\\Exception\\InvalidOrderException' => $vendorDir . '/mockery/mockery/library/Mockery/Exception/InvalidOrderException.php',
+ 'Mockery\\Exception\\NoMatchingExpectationException' => $vendorDir . '/mockery/mockery/library/Mockery/Exception/NoMatchingExpectationException.php',
+ 'Mockery\\Exception\\RuntimeException' => $vendorDir . '/mockery/mockery/library/Mockery/Exception/RuntimeException.php',
+ 'Mockery\\Expectation' => $vendorDir . '/mockery/mockery/library/Mockery/Expectation.php',
+ 'Mockery\\ExpectationDirector' => $vendorDir . '/mockery/mockery/library/Mockery/ExpectationDirector.php',
+ 'Mockery\\ExpectationInterface' => $vendorDir . '/mockery/mockery/library/Mockery/ExpectationInterface.php',
+ 'Mockery\\Generator\\CachingGenerator' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/CachingGenerator.php',
+ 'Mockery\\Generator\\DefinedTargetClass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/DefinedTargetClass.php',
+ 'Mockery\\Generator\\Generator' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/Generator.php',
+ 'Mockery\\Generator\\Method' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/Method.php',
+ 'Mockery\\Generator\\MockConfiguration' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/MockConfiguration.php',
+ 'Mockery\\Generator\\MockConfigurationBuilder' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/MockConfigurationBuilder.php',
+ 'Mockery\\Generator\\MockDefinition' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/MockDefinition.php',
+ 'Mockery\\Generator\\Parameter' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/Parameter.php',
+ 'Mockery\\Generator\\StringManipulationGenerator' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/StringManipulationGenerator.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\CallTypeHintPass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/CallTypeHintPass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\ClassNamePass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassNamePass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\ClassPass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassPass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\InstanceMockPass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InstanceMockPass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\InterfacePass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InterfacePass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\MethodDefinitionPass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/MethodDefinitionPass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\Pass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/Pass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\RemoveBuiltinMethodsThatAreFinalPass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/RemoveBuiltinMethodsThatAreFinalPass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\RemoveUnserializeForInternalSerializableClassesPass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/RemoveUnserializeForInternalSerializableClassesPass.php',
+ 'Mockery\\Generator\\TargetClass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/TargetClass.php',
+ 'Mockery\\Generator\\UndefinedTargetClass' => $vendorDir . '/mockery/mockery/library/Mockery/Generator/UndefinedTargetClass.php',
+ 'Mockery\\Instantiator' => $vendorDir . '/mockery/mockery/library/Mockery/Instantiator.php',
+ 'Mockery\\Loader' => $vendorDir . '/mockery/mockery/library/Mockery/Loader.php',
+ 'Mockery\\Loader\\EvalLoader' => $vendorDir . '/mockery/mockery/library/Mockery/Loader/EvalLoader.php',
+ 'Mockery\\Loader\\Loader' => $vendorDir . '/mockery/mockery/library/Mockery/Loader/Loader.php',
+ 'Mockery\\Loader\\RequireLoader' => $vendorDir . '/mockery/mockery/library/Mockery/Loader/RequireLoader.php',
+ 'Mockery\\Matcher\\Any' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/Any.php',
+ 'Mockery\\Matcher\\AnyOf' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/AnyOf.php',
+ 'Mockery\\Matcher\\Closure' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/Closure.php',
+ 'Mockery\\Matcher\\Contains' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/Contains.php',
+ 'Mockery\\Matcher\\Ducktype' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/Ducktype.php',
+ 'Mockery\\Matcher\\HasKey' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/HasKey.php',
+ 'Mockery\\Matcher\\HasValue' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/HasValue.php',
+ 'Mockery\\Matcher\\MatcherAbstract' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/MatcherAbstract.php',
+ 'Mockery\\Matcher\\MustBe' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/MustBe.php',
+ 'Mockery\\Matcher\\Not' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/Not.php',
+ 'Mockery\\Matcher\\NotAnyOf' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/NotAnyOf.php',
+ 'Mockery\\Matcher\\Subset' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/Subset.php',
+ 'Mockery\\Matcher\\Type' => $vendorDir . '/mockery/mockery/library/Mockery/Matcher/Type.php',
+ 'Mockery\\MethodCall' => $vendorDir . '/mockery/mockery/library/Mockery/MethodCall.php',
+ 'Mockery\\Mock' => $vendorDir . '/mockery/mockery/library/Mockery/Mock.php',
+ 'Mockery\\MockInterface' => $vendorDir . '/mockery/mockery/library/Mockery/MockInterface.php',
+ 'Mockery\\ReceivedMethodCalls' => $vendorDir . '/mockery/mockery/library/Mockery/ReceivedMethodCalls.php',
+ 'Mockery\\Recorder' => $vendorDir . '/mockery/mockery/library/Mockery/Recorder.php',
+ 'Mockery\\Undefined' => $vendorDir . '/mockery/mockery/library/Mockery/Undefined.php',
+ 'Mockery\\VerificationDirector' => $vendorDir . '/mockery/mockery/library/Mockery/VerificationDirector.php',
+ 'Mockery\\VerificationExpectation' => $vendorDir . '/mockery/mockery/library/Mockery/VerificationExpectation.php',
+ 'Monolog\\ErrorHandler' => $vendorDir . '/monolog/monolog/src/Monolog/ErrorHandler.php',
+ 'Monolog\\Formatter\\ChromePHPFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/ChromePHPFormatter.php',
+ 'Monolog\\Formatter\\ElasticaFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/ElasticaFormatter.php',
+ 'Monolog\\Formatter\\FlowdockFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/FlowdockFormatter.php',
+ 'Monolog\\Formatter\\FluentdFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/FluentdFormatter.php',
+ 'Monolog\\Formatter\\FormatterInterface' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/FormatterInterface.php',
+ 'Monolog\\Formatter\\GelfMessageFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/GelfMessageFormatter.php',
+ 'Monolog\\Formatter\\HtmlFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/HtmlFormatter.php',
+ 'Monolog\\Formatter\\JsonFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/JsonFormatter.php',
+ 'Monolog\\Formatter\\LineFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/LineFormatter.php',
+ 'Monolog\\Formatter\\LogglyFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/LogglyFormatter.php',
+ 'Monolog\\Formatter\\LogstashFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/LogstashFormatter.php',
+ 'Monolog\\Formatter\\MongoDBFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/MongoDBFormatter.php',
+ 'Monolog\\Formatter\\NormalizerFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/NormalizerFormatter.php',
+ 'Monolog\\Formatter\\ScalarFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/ScalarFormatter.php',
+ 'Monolog\\Formatter\\WildfireFormatter' => $vendorDir . '/monolog/monolog/src/Monolog/Formatter/WildfireFormatter.php',
+ 'Monolog\\Handler\\AbstractHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/AbstractHandler.php',
+ 'Monolog\\Handler\\AbstractProcessingHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/AbstractProcessingHandler.php',
+ 'Monolog\\Handler\\AbstractSyslogHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/AbstractSyslogHandler.php',
+ 'Monolog\\Handler\\AmqpHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/AmqpHandler.php',
+ 'Monolog\\Handler\\BrowserConsoleHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/BrowserConsoleHandler.php',
+ 'Monolog\\Handler\\BufferHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/BufferHandler.php',
+ 'Monolog\\Handler\\ChromePHPHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/ChromePHPHandler.php',
+ 'Monolog\\Handler\\CouchDBHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/CouchDBHandler.php',
+ 'Monolog\\Handler\\CubeHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/CubeHandler.php',
+ 'Monolog\\Handler\\Curl\\Util' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/Curl/Util.php',
+ 'Monolog\\Handler\\DeduplicationHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/DeduplicationHandler.php',
+ 'Monolog\\Handler\\DoctrineCouchDBHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/DoctrineCouchDBHandler.php',
+ 'Monolog\\Handler\\DynamoDbHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/DynamoDbHandler.php',
+ 'Monolog\\Handler\\ElasticSearchHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/ElasticSearchHandler.php',
+ 'Monolog\\Handler\\ErrorLogHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/ErrorLogHandler.php',
+ 'Monolog\\Handler\\FilterHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/FilterHandler.php',
+ 'Monolog\\Handler\\FingersCrossedHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/FingersCrossedHandler.php',
+ 'Monolog\\Handler\\FingersCrossed\\ActivationStrategyInterface' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php',
+ 'Monolog\\Handler\\FingersCrossed\\ChannelLevelActivationStrategy' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php',
+ 'Monolog\\Handler\\FingersCrossed\\ErrorLevelActivationStrategy' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php',
+ 'Monolog\\Handler\\FirePHPHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/FirePHPHandler.php',
+ 'Monolog\\Handler\\FleepHookHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/FleepHookHandler.php',
+ 'Monolog\\Handler\\FlowdockHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/FlowdockHandler.php',
+ 'Monolog\\Handler\\FormattableHandlerInterface' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/FormattableHandlerInterface.php',
+ 'Monolog\\Handler\\FormattableHandlerTrait' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/FormattableHandlerTrait.php',
+ 'Monolog\\Handler\\GelfHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/GelfHandler.php',
+ 'Monolog\\Handler\\GroupHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/GroupHandler.php',
+ 'Monolog\\Handler\\HandlerInterface' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/HandlerInterface.php',
+ 'Monolog\\Handler\\HandlerWrapper' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/HandlerWrapper.php',
+ 'Monolog\\Handler\\HipChatHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/HipChatHandler.php',
+ 'Monolog\\Handler\\IFTTTHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/IFTTTHandler.php',
+ 'Monolog\\Handler\\InsightOpsHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/InsightOpsHandler.php',
+ 'Monolog\\Handler\\LogEntriesHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/LogEntriesHandler.php',
+ 'Monolog\\Handler\\LogglyHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/LogglyHandler.php',
+ 'Monolog\\Handler\\MailHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/MailHandler.php',
+ 'Monolog\\Handler\\MandrillHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/MandrillHandler.php',
+ 'Monolog\\Handler\\MissingExtensionException' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/MissingExtensionException.php',
+ 'Monolog\\Handler\\MongoDBHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/MongoDBHandler.php',
+ 'Monolog\\Handler\\NativeMailerHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/NativeMailerHandler.php',
+ 'Monolog\\Handler\\NewRelicHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/NewRelicHandler.php',
+ 'Monolog\\Handler\\NullHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/NullHandler.php',
+ 'Monolog\\Handler\\PHPConsoleHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/PHPConsoleHandler.php',
+ 'Monolog\\Handler\\ProcessableHandlerInterface' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/ProcessableHandlerInterface.php',
+ 'Monolog\\Handler\\ProcessableHandlerTrait' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/ProcessableHandlerTrait.php',
+ 'Monolog\\Handler\\PsrHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/PsrHandler.php',
+ 'Monolog\\Handler\\PushoverHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/PushoverHandler.php',
+ 'Monolog\\Handler\\RavenHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/RavenHandler.php',
+ 'Monolog\\Handler\\RedisHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/RedisHandler.php',
+ 'Monolog\\Handler\\RollbarHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/RollbarHandler.php',
+ 'Monolog\\Handler\\RotatingFileHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/RotatingFileHandler.php',
+ 'Monolog\\Handler\\SamplingHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/SamplingHandler.php',
+ 'Monolog\\Handler\\SlackHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/SlackHandler.php',
+ 'Monolog\\Handler\\SlackWebhookHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/SlackWebhookHandler.php',
+ 'Monolog\\Handler\\Slack\\SlackRecord' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/Slack/SlackRecord.php',
+ 'Monolog\\Handler\\SlackbotHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/SlackbotHandler.php',
+ 'Monolog\\Handler\\SocketHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/SocketHandler.php',
+ 'Monolog\\Handler\\StreamHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/StreamHandler.php',
+ 'Monolog\\Handler\\SwiftMailerHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/SwiftMailerHandler.php',
+ 'Monolog\\Handler\\SyslogHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/SyslogHandler.php',
+ 'Monolog\\Handler\\SyslogUdpHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/SyslogUdpHandler.php',
+ 'Monolog\\Handler\\SyslogUdp\\UdpSocket' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/SyslogUdp/UdpSocket.php',
+ 'Monolog\\Handler\\TestHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/TestHandler.php',
+ 'Monolog\\Handler\\WhatFailureGroupHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/WhatFailureGroupHandler.php',
+ 'Monolog\\Handler\\ZendMonitorHandler' => $vendorDir . '/monolog/monolog/src/Monolog/Handler/ZendMonitorHandler.php',
+ 'Monolog\\Logger' => $vendorDir . '/monolog/monolog/src/Monolog/Logger.php',
+ 'Monolog\\Processor\\GitProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/GitProcessor.php',
+ 'Monolog\\Processor\\IntrospectionProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/IntrospectionProcessor.php',
+ 'Monolog\\Processor\\MemoryPeakUsageProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/MemoryPeakUsageProcessor.php',
+ 'Monolog\\Processor\\MemoryProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/MemoryProcessor.php',
+ 'Monolog\\Processor\\MemoryUsageProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/MemoryUsageProcessor.php',
+ 'Monolog\\Processor\\MercurialProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/MercurialProcessor.php',
+ 'Monolog\\Processor\\ProcessIdProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/ProcessIdProcessor.php',
+ 'Monolog\\Processor\\ProcessorInterface' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/ProcessorInterface.php',
+ 'Monolog\\Processor\\PsrLogMessageProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/PsrLogMessageProcessor.php',
+ 'Monolog\\Processor\\TagProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/TagProcessor.php',
+ 'Monolog\\Processor\\UidProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/UidProcessor.php',
+ 'Monolog\\Processor\\WebProcessor' => $vendorDir . '/monolog/monolog/src/Monolog/Processor/WebProcessor.php',
+ 'Monolog\\Registry' => $vendorDir . '/monolog/monolog/src/Monolog/Registry.php',
+ 'Monolog\\ResettableInterface' => $vendorDir . '/monolog/monolog/src/Monolog/ResettableInterface.php',
+ 'Monolog\\SignalHandler' => $vendorDir . '/monolog/monolog/src/Monolog/SignalHandler.php',
+ 'Monolog\\Utils' => $vendorDir . '/monolog/monolog/src/Monolog/Utils.php',
+ 'PHPUnit\\Framework\\Assert' => $vendorDir . '/phpunit/phpunit/src/ForwardCompatibility/Assert.php',
+ 'PHPUnit\\Framework\\AssertionFailedError' => $vendorDir . '/phpunit/phpunit/src/ForwardCompatibility/AssertionFailedError.php',
+ 'PHPUnit\\Framework\\BaseTestListener' => $vendorDir . '/phpunit/phpunit/src/ForwardCompatibility/BaseTestListener.php',
+ 'PHPUnit\\Framework\\Test' => $vendorDir . '/phpunit/phpunit/src/ForwardCompatibility/Test.php',
+ 'PHPUnit\\Framework\\TestCase' => $vendorDir . '/phpunit/phpunit/src/ForwardCompatibility/TestCase.php',
+ 'PHPUnit\\Framework\\TestListener' => $vendorDir . '/phpunit/phpunit/src/ForwardCompatibility/TestListener.php',
+ 'PHPUnit\\Framework\\TestSuite' => $vendorDir . '/phpunit/phpunit/src/ForwardCompatibility/TestSuite.php',
+ 'PHPUnit_Exception' => $vendorDir . '/phpunit/phpunit/src/Exception.php',
+ 'PHPUnit_Extensions_GroupTestSuite' => $vendorDir . '/phpunit/phpunit/src/Extensions/GroupTestSuite.php',
+ 'PHPUnit_Extensions_PhptTestCase' => $vendorDir . '/phpunit/phpunit/src/Extensions/PhptTestCase.php',
+ 'PHPUnit_Extensions_PhptTestSuite' => $vendorDir . '/phpunit/phpunit/src/Extensions/PhptTestSuite.php',
+ 'PHPUnit_Extensions_RepeatedTest' => $vendorDir . '/phpunit/phpunit/src/Extensions/RepeatedTest.php',
+ 'PHPUnit_Extensions_TestDecorator' => $vendorDir . '/phpunit/phpunit/src/Extensions/TestDecorator.php',
+ 'PHPUnit_Extensions_TicketListener' => $vendorDir . '/phpunit/phpunit/src/Extensions/TicketListener.php',
+ 'PHPUnit_Framework_Assert' => $vendorDir . '/phpunit/phpunit/src/Framework/Assert.php',
+ 'PHPUnit_Framework_AssertionFailedError' => $vendorDir . '/phpunit/phpunit/src/Framework/AssertionFailedError.php',
+ 'PHPUnit_Framework_BaseTestListener' => $vendorDir . '/phpunit/phpunit/src/Framework/BaseTestListener.php',
+ 'PHPUnit_Framework_CodeCoverageException' => $vendorDir . '/phpunit/phpunit/src/Framework/CodeCoverageException.php',
+ 'PHPUnit_Framework_Constraint' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint.php',
+ 'PHPUnit_Framework_Constraint_And' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/And.php',
+ 'PHPUnit_Framework_Constraint_ArrayHasKey' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/ArrayHasKey.php',
+ 'PHPUnit_Framework_Constraint_ArraySubset' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/ArraySubset.php',
+ 'PHPUnit_Framework_Constraint_Attribute' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/Attribute.php',
+ 'PHPUnit_Framework_Constraint_Callback' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/Callback.php',
+ 'PHPUnit_Framework_Constraint_ClassHasAttribute' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/ClassHasAttribute.php',
+ 'PHPUnit_Framework_Constraint_ClassHasStaticAttribute' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/ClassHasStaticAttribute.php',
+ 'PHPUnit_Framework_Constraint_Composite' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/Composite.php',
+ 'PHPUnit_Framework_Constraint_Count' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/Count.php',
+ 'PHPUnit_Framework_Constraint_DirectoryExists' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/DirectoryExists.php',
+ 'PHPUnit_Framework_Constraint_Exception' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/Exception.php',
+ 'PHPUnit_Framework_Constraint_ExceptionCode' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/ExceptionCode.php',
+ 'PHPUnit_Framework_Constraint_ExceptionMessage' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/ExceptionMessage.php',
+ 'PHPUnit_Framework_Constraint_ExceptionMessageRegExp' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/ExceptionMessageRegExp.php',
+ 'PHPUnit_Framework_Constraint_FileExists' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/FileExists.php',
+ 'PHPUnit_Framework_Constraint_GreaterThan' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/GreaterThan.php',
+ 'PHPUnit_Framework_Constraint_IsAnything' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsAnything.php',
+ 'PHPUnit_Framework_Constraint_IsEmpty' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsEmpty.php',
+ 'PHPUnit_Framework_Constraint_IsEqual' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsEqual.php',
+ 'PHPUnit_Framework_Constraint_IsFalse' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsFalse.php',
+ 'PHPUnit_Framework_Constraint_IsFinite' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsFinite.php',
+ 'PHPUnit_Framework_Constraint_IsIdentical' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsIdentical.php',
+ 'PHPUnit_Framework_Constraint_IsInfinite' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsInfinite.php',
+ 'PHPUnit_Framework_Constraint_IsInstanceOf' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsInstanceOf.php',
+ 'PHPUnit_Framework_Constraint_IsJson' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsJson.php',
+ 'PHPUnit_Framework_Constraint_IsNan' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsNan.php',
+ 'PHPUnit_Framework_Constraint_IsNull' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsNull.php',
+ 'PHPUnit_Framework_Constraint_IsReadable' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsReadable.php',
+ 'PHPUnit_Framework_Constraint_IsTrue' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsTrue.php',
+ 'PHPUnit_Framework_Constraint_IsType' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsType.php',
+ 'PHPUnit_Framework_Constraint_IsWritable' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/IsWritable.php',
+ 'PHPUnit_Framework_Constraint_JsonMatches' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/JsonMatches.php',
+ 'PHPUnit_Framework_Constraint_JsonMatches_ErrorMessageProvider' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/JsonMatches/ErrorMessageProvider.php',
+ 'PHPUnit_Framework_Constraint_LessThan' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/LessThan.php',
+ 'PHPUnit_Framework_Constraint_Not' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/Not.php',
+ 'PHPUnit_Framework_Constraint_ObjectHasAttribute' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/ObjectHasAttribute.php',
+ 'PHPUnit_Framework_Constraint_Or' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/Or.php',
+ 'PHPUnit_Framework_Constraint_PCREMatch' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/PCREMatch.php',
+ 'PHPUnit_Framework_Constraint_SameSize' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/SameSize.php',
+ 'PHPUnit_Framework_Constraint_StringContains' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/StringContains.php',
+ 'PHPUnit_Framework_Constraint_StringEndsWith' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/StringEndsWith.php',
+ 'PHPUnit_Framework_Constraint_StringMatches' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/StringMatches.php',
+ 'PHPUnit_Framework_Constraint_StringStartsWith' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/StringStartsWith.php',
+ 'PHPUnit_Framework_Constraint_TraversableContains' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/TraversableContains.php',
+ 'PHPUnit_Framework_Constraint_TraversableContainsOnly' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/TraversableContainsOnly.php',
+ 'PHPUnit_Framework_Constraint_Xor' => $vendorDir . '/phpunit/phpunit/src/Framework/Constraint/Xor.php',
+ 'PHPUnit_Framework_CoveredCodeNotExecutedException' => $vendorDir . '/phpunit/phpunit/src/Framework/CoveredCodeNotExecutedException.php',
+ 'PHPUnit_Framework_Error' => $vendorDir . '/phpunit/phpunit/src/Framework/Error.php',
+ 'PHPUnit_Framework_Error_Deprecated' => $vendorDir . '/phpunit/phpunit/src/Framework/Error/Deprecated.php',
+ 'PHPUnit_Framework_Error_Notice' => $vendorDir . '/phpunit/phpunit/src/Framework/Error/Notice.php',
+ 'PHPUnit_Framework_Error_Warning' => $vendorDir . '/phpunit/phpunit/src/Framework/Error/Warning.php',
+ 'PHPUnit_Framework_Exception' => $vendorDir . '/phpunit/phpunit/src/Framework/Exception.php',
+ 'PHPUnit_Framework_ExceptionWrapper' => $vendorDir . '/phpunit/phpunit/src/Framework/ExceptionWrapper.php',
+ 'PHPUnit_Framework_ExpectationFailedException' => $vendorDir . '/phpunit/phpunit/src/Framework/ExpectationFailedException.php',
+ 'PHPUnit_Framework_IncompleteTest' => $vendorDir . '/phpunit/phpunit/src/Framework/IncompleteTest.php',
+ 'PHPUnit_Framework_IncompleteTestCase' => $vendorDir . '/phpunit/phpunit/src/Framework/IncompleteTestCase.php',
+ 'PHPUnit_Framework_IncompleteTestError' => $vendorDir . '/phpunit/phpunit/src/Framework/IncompleteTestError.php',
+ 'PHPUnit_Framework_InvalidCoversTargetException' => $vendorDir . '/phpunit/phpunit/src/Framework/InvalidCoversTargetException.php',
+ 'PHPUnit_Framework_MissingCoversAnnotationException' => $vendorDir . '/phpunit/phpunit/src/Framework/MissingCoversAnnotationException.php',
+ 'PHPUnit_Framework_MockObject_BadMethodCallException' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Exception/BadMethodCallException.php',
+ 'PHPUnit_Framework_MockObject_Builder_Identity' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Identity.php',
+ 'PHPUnit_Framework_MockObject_Builder_InvocationMocker' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/InvocationMocker.php',
+ 'PHPUnit_Framework_MockObject_Builder_Match' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Match.php',
+ 'PHPUnit_Framework_MockObject_Builder_MethodNameMatch' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/MethodNameMatch.php',
+ 'PHPUnit_Framework_MockObject_Builder_Namespace' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Namespace.php',
+ 'PHPUnit_Framework_MockObject_Builder_ParametersMatch' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/ParametersMatch.php',
+ 'PHPUnit_Framework_MockObject_Builder_Stub' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Stub.php',
+ 'PHPUnit_Framework_MockObject_Exception' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Exception/Exception.php',
+ 'PHPUnit_Framework_MockObject_Generator' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator.php',
+ 'PHPUnit_Framework_MockObject_Invocation' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invocation.php',
+ 'PHPUnit_Framework_MockObject_InvocationMocker' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/InvocationMocker.php',
+ 'PHPUnit_Framework_MockObject_Invocation_Object' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invocation/Object.php',
+ 'PHPUnit_Framework_MockObject_Invocation_Static' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invocation/Static.php',
+ 'PHPUnit_Framework_MockObject_Invokable' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invokable.php',
+ 'PHPUnit_Framework_MockObject_Matcher' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher.php',
+ 'PHPUnit_Framework_MockObject_Matcher_AnyInvokedCount' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/AnyInvokedCount.php',
+ 'PHPUnit_Framework_MockObject_Matcher_AnyParameters' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/AnyParameters.php',
+ 'PHPUnit_Framework_MockObject_Matcher_ConsecutiveParameters' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/ConsecutiveParameters.php',
+ 'PHPUnit_Framework_MockObject_Matcher_Invocation' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/Invocation.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedAtIndex' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtIndex.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedAtLeastCount' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtLeastCount.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedAtLeastOnce' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtLeastOnce.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedAtMostCount' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtMostCount.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedCount' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedCount.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedRecorder' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedRecorder.php',
+ 'PHPUnit_Framework_MockObject_Matcher_MethodName' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/MethodName.php',
+ 'PHPUnit_Framework_MockObject_Matcher_Parameters' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/Parameters.php',
+ 'PHPUnit_Framework_MockObject_Matcher_StatelessInvocation' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/StatelessInvocation.php',
+ 'PHPUnit_Framework_MockObject_MockBuilder' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/MockBuilder.php',
+ 'PHPUnit_Framework_MockObject_MockObject' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/MockObject.php',
+ 'PHPUnit_Framework_MockObject_RuntimeException' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Exception/RuntimeException.php',
+ 'PHPUnit_Framework_MockObject_Stub' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub.php',
+ 'PHPUnit_Framework_MockObject_Stub_ConsecutiveCalls' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ConsecutiveCalls.php',
+ 'PHPUnit_Framework_MockObject_Stub_Exception' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/Exception.php',
+ 'PHPUnit_Framework_MockObject_Stub_MatcherCollection' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/MatcherCollection.php',
+ 'PHPUnit_Framework_MockObject_Stub_Return' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/Return.php',
+ 'PHPUnit_Framework_MockObject_Stub_ReturnArgument' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnArgument.php',
+ 'PHPUnit_Framework_MockObject_Stub_ReturnCallback' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnCallback.php',
+ 'PHPUnit_Framework_MockObject_Stub_ReturnReference' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnReference.php',
+ 'PHPUnit_Framework_MockObject_Stub_ReturnSelf' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnSelf.php',
+ 'PHPUnit_Framework_MockObject_Stub_ReturnValueMap' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnValueMap.php',
+ 'PHPUnit_Framework_MockObject_Verifiable' => $vendorDir . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Verifiable.php',
+ 'PHPUnit_Framework_OutputError' => $vendorDir . '/phpunit/phpunit/src/Framework/OutputError.php',
+ 'PHPUnit_Framework_RiskyTest' => $vendorDir . '/phpunit/phpunit/src/Framework/RiskyTest.php',
+ 'PHPUnit_Framework_RiskyTestError' => $vendorDir . '/phpunit/phpunit/src/Framework/RiskyTestError.php',
+ 'PHPUnit_Framework_SelfDescribing' => $vendorDir . '/phpunit/phpunit/src/Framework/SelfDescribing.php',
+ 'PHPUnit_Framework_SkippedTest' => $vendorDir . '/phpunit/phpunit/src/Framework/SkippedTest.php',
+ 'PHPUnit_Framework_SkippedTestCase' => $vendorDir . '/phpunit/phpunit/src/Framework/SkippedTestCase.php',
+ 'PHPUnit_Framework_SkippedTestError' => $vendorDir . '/phpunit/phpunit/src/Framework/SkippedTestError.php',
+ 'PHPUnit_Framework_SkippedTestSuiteError' => $vendorDir . '/phpunit/phpunit/src/Framework/SkippedTestSuiteError.php',
+ 'PHPUnit_Framework_SyntheticError' => $vendorDir . '/phpunit/phpunit/src/Framework/SyntheticError.php',
+ 'PHPUnit_Framework_Test' => $vendorDir . '/phpunit/phpunit/src/Framework/Test.php',
+ 'PHPUnit_Framework_TestCase' => $vendorDir . '/phpunit/phpunit/src/Framework/TestCase.php',
+ 'PHPUnit_Framework_TestFailure' => $vendorDir . '/phpunit/phpunit/src/Framework/TestFailure.php',
+ 'PHPUnit_Framework_TestListener' => $vendorDir . '/phpunit/phpunit/src/Framework/TestListener.php',
+ 'PHPUnit_Framework_TestResult' => $vendorDir . '/phpunit/phpunit/src/Framework/TestResult.php',
+ 'PHPUnit_Framework_TestSuite' => $vendorDir . '/phpunit/phpunit/src/Framework/TestSuite.php',
+ 'PHPUnit_Framework_TestSuite_DataProvider' => $vendorDir . '/phpunit/phpunit/src/Framework/TestSuite/DataProvider.php',
+ 'PHPUnit_Framework_UnintentionallyCoveredCodeError' => $vendorDir . '/phpunit/phpunit/src/Framework/UnintentionallyCoveredCodeError.php',
+ 'PHPUnit_Framework_Warning' => $vendorDir . '/phpunit/phpunit/src/Framework/Warning.php',
+ 'PHPUnit_Framework_WarningTestCase' => $vendorDir . '/phpunit/phpunit/src/Framework/WarningTestCase.php',
+ 'PHPUnit_Runner_BaseTestRunner' => $vendorDir . '/phpunit/phpunit/src/Runner/BaseTestRunner.php',
+ 'PHPUnit_Runner_Exception' => $vendorDir . '/phpunit/phpunit/src/Runner/Exception.php',
+ 'PHPUnit_Runner_Filter_Factory' => $vendorDir . '/phpunit/phpunit/src/Runner/Filter/Factory.php',
+ 'PHPUnit_Runner_Filter_GroupFilterIterator' => $vendorDir . '/phpunit/phpunit/src/Runner/Filter/Group.php',
+ 'PHPUnit_Runner_Filter_Group_Exclude' => $vendorDir . '/phpunit/phpunit/src/Runner/Filter/Group/Exclude.php',
+ 'PHPUnit_Runner_Filter_Group_Include' => $vendorDir . '/phpunit/phpunit/src/Runner/Filter/Group/Include.php',
+ 'PHPUnit_Runner_Filter_Test' => $vendorDir . '/phpunit/phpunit/src/Runner/Filter/Test.php',
+ 'PHPUnit_Runner_StandardTestSuiteLoader' => $vendorDir . '/phpunit/phpunit/src/Runner/StandardTestSuiteLoader.php',
+ 'PHPUnit_Runner_TestSuiteLoader' => $vendorDir . '/phpunit/phpunit/src/Runner/TestSuiteLoader.php',
+ 'PHPUnit_Runner_Version' => $vendorDir . '/phpunit/phpunit/src/Runner/Version.php',
+ 'PHPUnit_TextUI_Command' => $vendorDir . '/phpunit/phpunit/src/TextUI/Command.php',
+ 'PHPUnit_TextUI_ResultPrinter' => $vendorDir . '/phpunit/phpunit/src/TextUI/ResultPrinter.php',
+ 'PHPUnit_TextUI_TestRunner' => $vendorDir . '/phpunit/phpunit/src/TextUI/TestRunner.php',
+ 'PHPUnit_Util_Blacklist' => $vendorDir . '/phpunit/phpunit/src/Util/Blacklist.php',
+ 'PHPUnit_Util_Configuration' => $vendorDir . '/phpunit/phpunit/src/Util/Configuration.php',
+ 'PHPUnit_Util_ConfigurationGenerator' => $vendorDir . '/phpunit/phpunit/src/Util/ConfigurationGenerator.php',
+ 'PHPUnit_Util_ErrorHandler' => $vendorDir . '/phpunit/phpunit/src/Util/ErrorHandler.php',
+ 'PHPUnit_Util_Fileloader' => $vendorDir . '/phpunit/phpunit/src/Util/Fileloader.php',
+ 'PHPUnit_Util_Filesystem' => $vendorDir . '/phpunit/phpunit/src/Util/Filesystem.php',
+ 'PHPUnit_Util_Filter' => $vendorDir . '/phpunit/phpunit/src/Util/Filter.php',
+ 'PHPUnit_Util_Getopt' => $vendorDir . '/phpunit/phpunit/src/Util/Getopt.php',
+ 'PHPUnit_Util_GlobalState' => $vendorDir . '/phpunit/phpunit/src/Util/GlobalState.php',
+ 'PHPUnit_Util_InvalidArgumentHelper' => $vendorDir . '/phpunit/phpunit/src/Util/InvalidArgumentHelper.php',
+ 'PHPUnit_Util_Log_JSON' => $vendorDir . '/phpunit/phpunit/src/Util/Log/JSON.php',
+ 'PHPUnit_Util_Log_JUnit' => $vendorDir . '/phpunit/phpunit/src/Util/Log/JUnit.php',
+ 'PHPUnit_Util_Log_TAP' => $vendorDir . '/phpunit/phpunit/src/Util/Log/TAP.php',
+ 'PHPUnit_Util_Log_TeamCity' => $vendorDir . '/phpunit/phpunit/src/Util/Log/TeamCity.php',
+ 'PHPUnit_Util_PHP' => $vendorDir . '/phpunit/phpunit/src/Util/PHP.php',
+ 'PHPUnit_Util_PHP_Default' => $vendorDir . '/phpunit/phpunit/src/Util/PHP/Default.php',
+ 'PHPUnit_Util_PHP_Windows' => $vendorDir . '/phpunit/phpunit/src/Util/PHP/Windows.php',
+ 'PHPUnit_Util_Printer' => $vendorDir . '/phpunit/phpunit/src/Util/Printer.php',
+ 'PHPUnit_Util_Regex' => $vendorDir . '/phpunit/phpunit/src/Util/Regex.php',
+ 'PHPUnit_Util_String' => $vendorDir . '/phpunit/phpunit/src/Util/String.php',
+ 'PHPUnit_Util_Test' => $vendorDir . '/phpunit/phpunit/src/Util/Test.php',
+ 'PHPUnit_Util_TestDox_NamePrettifier' => $vendorDir . '/phpunit/phpunit/src/Util/TestDox/NamePrettifier.php',
+ 'PHPUnit_Util_TestDox_ResultPrinter' => $vendorDir . '/phpunit/phpunit/src/Util/TestDox/ResultPrinter.php',
+ 'PHPUnit_Util_TestDox_ResultPrinter_HTML' => $vendorDir . '/phpunit/phpunit/src/Util/TestDox/ResultPrinter/HTML.php',
+ 'PHPUnit_Util_TestDox_ResultPrinter_Text' => $vendorDir . '/phpunit/phpunit/src/Util/TestDox/ResultPrinter/Text.php',
+ 'PHPUnit_Util_TestDox_ResultPrinter_XML' => $vendorDir . '/phpunit/phpunit/src/Util/TestDox/ResultPrinter/XML.php',
+ 'PHPUnit_Util_TestSuiteIterator' => $vendorDir . '/phpunit/phpunit/src/Util/TestSuiteIterator.php',
+ 'PHPUnit_Util_Type' => $vendorDir . '/phpunit/phpunit/src/Util/Type.php',
+ 'PHPUnit_Util_XML' => $vendorDir . '/phpunit/phpunit/src/Util/XML.php',
+ 'PHP_Timer' => $vendorDir . '/phpunit/php-timer/src/Timer.php',
+ 'PHP_Token' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_TokenWithScope' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_TokenWithScopeAndVisibility' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ABSTRACT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_AMPERSAND' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_AND_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ARRAY' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ARRAY_CAST' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_AS' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ASYNC' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_AT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_AWAIT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BACKTICK' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BAD_CHARACTER' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BOOLEAN_AND' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BOOLEAN_OR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BOOL_CAST' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BREAK' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CALLABLE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CARET' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CASE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CATCH' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CHARACTER' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLASS' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLASS_C' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLASS_NAME_CONSTANT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLONE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLOSE_BRACKET' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLOSE_CURLY' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLOSE_SQUARE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLOSE_TAG' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_COALESCE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_COLON' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_COMMA' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_COMMENT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_COMPILER_HALT_OFFSET' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CONCAT_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CONST' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CONSTANT_ENCAPSED_STRING' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CONTINUE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CURLY_OPEN' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DEC' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DECLARE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DEFAULT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DIR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DIV' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DIV_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DNUMBER' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DO' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOC_COMMENT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOLLAR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOLLAR_OPEN_CURLY_BRACES' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOUBLE_ARROW' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOUBLE_CAST' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOUBLE_COLON' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOUBLE_QUOTES' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ECHO' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ELLIPSIS' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ELSE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ELSEIF' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EMPTY' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENCAPSED_AND_WHITESPACE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDDECLARE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDFOR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDFOREACH' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDIF' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDSWITCH' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDWHILE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_END_HEREDOC' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENUM' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EQUALS' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EVAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EXCLAMATION_MARK' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EXIT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EXTENDS' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FILE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FINAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FINALLY' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FOR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FOREACH' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FUNCTION' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FUNC_C' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_GLOBAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_GOTO' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_GT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_HALT_COMPILER' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IF' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IMPLEMENTS' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IN' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INC' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INCLUDE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INCLUDE_ONCE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INLINE_HTML' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INSTANCEOF' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INSTEADOF' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INTERFACE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INT_CAST' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ISSET' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_GREATER_OR_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_IDENTICAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_NOT_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_NOT_IDENTICAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_SMALLER_OR_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_Includes' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_JOIN' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LAMBDA_ARROW' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LAMBDA_CP' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LAMBDA_OP' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LINE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LIST' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LNUMBER' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LOGICAL_AND' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LOGICAL_OR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LOGICAL_XOR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_METHOD_C' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_MINUS' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_MINUS_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_MOD_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_MULT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_MUL_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NAMESPACE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NEW' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NS_C' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NS_SEPARATOR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NULLSAFE_OBJECT_OPERATOR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NUM_STRING' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OBJECT_CAST' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OBJECT_OPERATOR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ONUMBER' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OPEN_BRACKET' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OPEN_CURLY' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OPEN_SQUARE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OPEN_TAG' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OPEN_TAG_WITH_ECHO' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OR_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PAAMAYIM_NEKUDOTAYIM' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PERCENT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PIPE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PLUS' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PLUS_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_POW' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_POW_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PRINT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PRIVATE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PROTECTED' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PUBLIC' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_QUESTION_MARK' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_REQUIRE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_REQUIRE_ONCE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_RETURN' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SEMICOLON' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SHAPE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SL_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SPACESHIP' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SR_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_START_HEREDOC' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_STATIC' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_STRING' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_STRING_CAST' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_STRING_VARNAME' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SUPER' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SWITCH' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_Stream' => $vendorDir . '/phpunit/php-token-stream/src/Token/Stream.php',
+ 'PHP_Token_Stream_CachingFactory' => $vendorDir . '/phpunit/php-token-stream/src/Token/Stream/CachingFactory.php',
+ 'PHP_Token_THROW' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TILDE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TRAIT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TRAIT_C' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TRY' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TYPE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TYPELIST_GT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TYPELIST_LT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_UNSET' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_UNSET_CAST' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_USE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_USE_FUNCTION' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_VAR' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_VARIABLE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_WHERE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_WHILE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_WHITESPACE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_ATTRIBUTE' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_CATEGORY' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_CATEGORY_LABEL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_CHILDREN' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_LABEL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_REQUIRED' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_TAG_GT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_TAG_LT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_TEXT' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XOR_EQUAL' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_YIELD' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_YIELD_FROM' => $vendorDir . '/phpunit/php-token-stream/src/Token.php',
+ 'ParseError' => $vendorDir . '/symfony/polyfill-php70/Resources/stubs/ParseError.php',
+ 'Parsedown' => $vendorDir . '/erusev/parsedown/Parsedown.php',
+ 'PhpParser\\Autoloader' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Autoloader.php',
+ 'PhpParser\\Builder' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder.php',
+ 'PhpParser\\BuilderAbstract' => $vendorDir . '/nikic/php-parser/lib/PhpParser/BuilderAbstract.php',
+ 'PhpParser\\BuilderFactory' => $vendorDir . '/nikic/php-parser/lib/PhpParser/BuilderFactory.php',
+ 'PhpParser\\Builder\\Class_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/Class_.php',
+ 'PhpParser\\Builder\\Declaration' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/Declaration.php',
+ 'PhpParser\\Builder\\FunctionLike' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/FunctionLike.php',
+ 'PhpParser\\Builder\\Function_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/Function_.php',
+ 'PhpParser\\Builder\\Interface_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/Interface_.php',
+ 'PhpParser\\Builder\\Method' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/Method.php',
+ 'PhpParser\\Builder\\Namespace_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/Namespace_.php',
+ 'PhpParser\\Builder\\Param' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/Param.php',
+ 'PhpParser\\Builder\\Property' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/Property.php',
+ 'PhpParser\\Builder\\Trait_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/Trait_.php',
+ 'PhpParser\\Builder\\Use_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Builder/Use_.php',
+ 'PhpParser\\Comment' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Comment.php',
+ 'PhpParser\\Comment\\Doc' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Comment/Doc.php',
+ 'PhpParser\\Error' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Error.php',
+ 'PhpParser\\ErrorHandler' => $vendorDir . '/nikic/php-parser/lib/PhpParser/ErrorHandler.php',
+ 'PhpParser\\ErrorHandler\\Collecting' => $vendorDir . '/nikic/php-parser/lib/PhpParser/ErrorHandler/Collecting.php',
+ 'PhpParser\\ErrorHandler\\Throwing' => $vendorDir . '/nikic/php-parser/lib/PhpParser/ErrorHandler/Throwing.php',
+ 'PhpParser\\Lexer' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Lexer.php',
+ 'PhpParser\\Lexer\\Emulative' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Lexer/Emulative.php',
+ 'PhpParser\\Node' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node.php',
+ 'PhpParser\\NodeAbstract' => $vendorDir . '/nikic/php-parser/lib/PhpParser/NodeAbstract.php',
+ 'PhpParser\\NodeDumper' => $vendorDir . '/nikic/php-parser/lib/PhpParser/NodeDumper.php',
+ 'PhpParser\\NodeTraverser' => $vendorDir . '/nikic/php-parser/lib/PhpParser/NodeTraverser.php',
+ 'PhpParser\\NodeTraverserInterface' => $vendorDir . '/nikic/php-parser/lib/PhpParser/NodeTraverserInterface.php',
+ 'PhpParser\\NodeVisitor' => $vendorDir . '/nikic/php-parser/lib/PhpParser/NodeVisitor.php',
+ 'PhpParser\\NodeVisitorAbstract' => $vendorDir . '/nikic/php-parser/lib/PhpParser/NodeVisitorAbstract.php',
+ 'PhpParser\\NodeVisitor\\NameResolver' => $vendorDir . '/nikic/php-parser/lib/PhpParser/NodeVisitor/NameResolver.php',
+ 'PhpParser\\Node\\Arg' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Arg.php',
+ 'PhpParser\\Node\\Const_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Const_.php',
+ 'PhpParser\\Node\\Expr' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr.php',
+ 'PhpParser\\Node\\Expr\\ArrayDimFetch' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/ArrayDimFetch.php',
+ 'PhpParser\\Node\\Expr\\ArrayItem' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/ArrayItem.php',
+ 'PhpParser\\Node\\Expr\\Array_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Array_.php',
+ 'PhpParser\\Node\\Expr\\Assign' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Assign.php',
+ 'PhpParser\\Node\\Expr\\AssignOp' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\BitwiseAnd' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/BitwiseAnd.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\BitwiseOr' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/BitwiseOr.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\BitwiseXor' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/BitwiseXor.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Concat' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Concat.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Div' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Div.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Minus' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Minus.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Mod' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Mod.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Mul' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Mul.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Plus' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Plus.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Pow' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Pow.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\ShiftLeft' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/ShiftLeft.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\ShiftRight' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/ShiftRight.php',
+ 'PhpParser\\Node\\Expr\\AssignRef' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignRef.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\BitwiseAnd' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BitwiseAnd.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\BitwiseOr' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BitwiseOr.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\BitwiseXor' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BitwiseXor.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\BooleanAnd' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BooleanAnd.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\BooleanOr' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BooleanOr.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Coalesce' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Coalesce.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Concat' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Concat.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Div' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Div.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Equal' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Equal.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Greater' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Greater.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\GreaterOrEqual' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/GreaterOrEqual.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Identical' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Identical.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\LogicalAnd' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/LogicalAnd.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\LogicalOr' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/LogicalOr.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\LogicalXor' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/LogicalXor.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Minus' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Minus.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Mod' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Mod.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Mul' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Mul.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\NotEqual' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/NotEqual.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\NotIdentical' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/NotIdentical.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Plus' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Plus.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Pow' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Pow.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\ShiftLeft' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/ShiftLeft.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\ShiftRight' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/ShiftRight.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Smaller' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Smaller.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\SmallerOrEqual' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/SmallerOrEqual.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Spaceship' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Spaceship.php',
+ 'PhpParser\\Node\\Expr\\BitwiseNot' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BitwiseNot.php',
+ 'PhpParser\\Node\\Expr\\BooleanNot' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/BooleanNot.php',
+ 'PhpParser\\Node\\Expr\\Cast' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Array_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Array_.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Bool_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Bool_.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Double' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Double.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Int_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Int_.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Object_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Object_.php',
+ 'PhpParser\\Node\\Expr\\Cast\\String_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/String_.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Unset_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Unset_.php',
+ 'PhpParser\\Node\\Expr\\ClassConstFetch' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/ClassConstFetch.php',
+ 'PhpParser\\Node\\Expr\\Clone_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Clone_.php',
+ 'PhpParser\\Node\\Expr\\Closure' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Closure.php',
+ 'PhpParser\\Node\\Expr\\ClosureUse' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/ClosureUse.php',
+ 'PhpParser\\Node\\Expr\\ConstFetch' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/ConstFetch.php',
+ 'PhpParser\\Node\\Expr\\Empty_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Empty_.php',
+ 'PhpParser\\Node\\Expr\\Error' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Error.php',
+ 'PhpParser\\Node\\Expr\\ErrorSuppress' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/ErrorSuppress.php',
+ 'PhpParser\\Node\\Expr\\Eval_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Eval_.php',
+ 'PhpParser\\Node\\Expr\\Exit_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Exit_.php',
+ 'PhpParser\\Node\\Expr\\FuncCall' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/FuncCall.php',
+ 'PhpParser\\Node\\Expr\\Include_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Include_.php',
+ 'PhpParser\\Node\\Expr\\Instanceof_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Instanceof_.php',
+ 'PhpParser\\Node\\Expr\\Isset_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Isset_.php',
+ 'PhpParser\\Node\\Expr\\List_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/List_.php',
+ 'PhpParser\\Node\\Expr\\MethodCall' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/MethodCall.php',
+ 'PhpParser\\Node\\Expr\\New_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/New_.php',
+ 'PhpParser\\Node\\Expr\\PostDec' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/PostDec.php',
+ 'PhpParser\\Node\\Expr\\PostInc' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/PostInc.php',
+ 'PhpParser\\Node\\Expr\\PreDec' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/PreDec.php',
+ 'PhpParser\\Node\\Expr\\PreInc' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/PreInc.php',
+ 'PhpParser\\Node\\Expr\\Print_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Print_.php',
+ 'PhpParser\\Node\\Expr\\PropertyFetch' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/PropertyFetch.php',
+ 'PhpParser\\Node\\Expr\\ShellExec' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/ShellExec.php',
+ 'PhpParser\\Node\\Expr\\StaticCall' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/StaticCall.php',
+ 'PhpParser\\Node\\Expr\\StaticPropertyFetch' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/StaticPropertyFetch.php',
+ 'PhpParser\\Node\\Expr\\Ternary' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Ternary.php',
+ 'PhpParser\\Node\\Expr\\UnaryMinus' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/UnaryMinus.php',
+ 'PhpParser\\Node\\Expr\\UnaryPlus' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/UnaryPlus.php',
+ 'PhpParser\\Node\\Expr\\Variable' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Variable.php',
+ 'PhpParser\\Node\\Expr\\YieldFrom' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/YieldFrom.php',
+ 'PhpParser\\Node\\Expr\\Yield_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Expr/Yield_.php',
+ 'PhpParser\\Node\\FunctionLike' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/FunctionLike.php',
+ 'PhpParser\\Node\\Name' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Name.php',
+ 'PhpParser\\Node\\Name\\FullyQualified' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Name/FullyQualified.php',
+ 'PhpParser\\Node\\Name\\Relative' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Name/Relative.php',
+ 'PhpParser\\Node\\NullableType' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/NullableType.php',
+ 'PhpParser\\Node\\Param' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Param.php',
+ 'PhpParser\\Node\\Scalar' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar.php',
+ 'PhpParser\\Node\\Scalar\\DNumber' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/DNumber.php',
+ 'PhpParser\\Node\\Scalar\\Encapsed' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/Encapsed.php',
+ 'PhpParser\\Node\\Scalar\\EncapsedStringPart' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/EncapsedStringPart.php',
+ 'PhpParser\\Node\\Scalar\\LNumber' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/LNumber.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Class_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Class_.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Dir' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Dir.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\File' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/File.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Function_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Function_.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Line' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Line.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Method' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Method.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Namespace_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Namespace_.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Trait_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Trait_.php',
+ 'PhpParser\\Node\\Scalar\\String_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Scalar/String_.php',
+ 'PhpParser\\Node\\Stmt' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt.php',
+ 'PhpParser\\Node\\Stmt\\Break_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Break_.php',
+ 'PhpParser\\Node\\Stmt\\Case_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Case_.php',
+ 'PhpParser\\Node\\Stmt\\Catch_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Catch_.php',
+ 'PhpParser\\Node\\Stmt\\ClassConst' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/ClassConst.php',
+ 'PhpParser\\Node\\Stmt\\ClassLike' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/ClassLike.php',
+ 'PhpParser\\Node\\Stmt\\ClassMethod' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/ClassMethod.php',
+ 'PhpParser\\Node\\Stmt\\Class_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Class_.php',
+ 'PhpParser\\Node\\Stmt\\Const_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Const_.php',
+ 'PhpParser\\Node\\Stmt\\Continue_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Continue_.php',
+ 'PhpParser\\Node\\Stmt\\DeclareDeclare' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/DeclareDeclare.php',
+ 'PhpParser\\Node\\Stmt\\Declare_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Declare_.php',
+ 'PhpParser\\Node\\Stmt\\Do_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Do_.php',
+ 'PhpParser\\Node\\Stmt\\Echo_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Echo_.php',
+ 'PhpParser\\Node\\Stmt\\ElseIf_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/ElseIf_.php',
+ 'PhpParser\\Node\\Stmt\\Else_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Else_.php',
+ 'PhpParser\\Node\\Stmt\\Finally_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Finally_.php',
+ 'PhpParser\\Node\\Stmt\\For_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/For_.php',
+ 'PhpParser\\Node\\Stmt\\Foreach_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Foreach_.php',
+ 'PhpParser\\Node\\Stmt\\Function_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Function_.php',
+ 'PhpParser\\Node\\Stmt\\Global_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Global_.php',
+ 'PhpParser\\Node\\Stmt\\Goto_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Goto_.php',
+ 'PhpParser\\Node\\Stmt\\GroupUse' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/GroupUse.php',
+ 'PhpParser\\Node\\Stmt\\HaltCompiler' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/HaltCompiler.php',
+ 'PhpParser\\Node\\Stmt\\If_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/If_.php',
+ 'PhpParser\\Node\\Stmt\\InlineHTML' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/InlineHTML.php',
+ 'PhpParser\\Node\\Stmt\\Interface_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Interface_.php',
+ 'PhpParser\\Node\\Stmt\\Label' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Label.php',
+ 'PhpParser\\Node\\Stmt\\Namespace_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Namespace_.php',
+ 'PhpParser\\Node\\Stmt\\Nop' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Nop.php',
+ 'PhpParser\\Node\\Stmt\\Property' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Property.php',
+ 'PhpParser\\Node\\Stmt\\PropertyProperty' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/PropertyProperty.php',
+ 'PhpParser\\Node\\Stmt\\Return_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Return_.php',
+ 'PhpParser\\Node\\Stmt\\StaticVar' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/StaticVar.php',
+ 'PhpParser\\Node\\Stmt\\Static_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Static_.php',
+ 'PhpParser\\Node\\Stmt\\Switch_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Switch_.php',
+ 'PhpParser\\Node\\Stmt\\Throw_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Throw_.php',
+ 'PhpParser\\Node\\Stmt\\TraitUse' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUse.php',
+ 'PhpParser\\Node\\Stmt\\TraitUseAdaptation' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUseAdaptation.php',
+ 'PhpParser\\Node\\Stmt\\TraitUseAdaptation\\Alias' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUseAdaptation/Alias.php',
+ 'PhpParser\\Node\\Stmt\\TraitUseAdaptation\\Precedence' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUseAdaptation/Precedence.php',
+ 'PhpParser\\Node\\Stmt\\Trait_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Trait_.php',
+ 'PhpParser\\Node\\Stmt\\TryCatch' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/TryCatch.php',
+ 'PhpParser\\Node\\Stmt\\Unset_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Unset_.php',
+ 'PhpParser\\Node\\Stmt\\UseUse' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/UseUse.php',
+ 'PhpParser\\Node\\Stmt\\Use_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Use_.php',
+ 'PhpParser\\Node\\Stmt\\While_' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Node/Stmt/While_.php',
+ 'PhpParser\\Parser' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Parser.php',
+ 'PhpParser\\ParserAbstract' => $vendorDir . '/nikic/php-parser/lib/PhpParser/ParserAbstract.php',
+ 'PhpParser\\ParserFactory' => $vendorDir . '/nikic/php-parser/lib/PhpParser/ParserFactory.php',
+ 'PhpParser\\Parser\\Multiple' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Parser/Multiple.php',
+ 'PhpParser\\Parser\\Php5' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Parser/Php5.php',
+ 'PhpParser\\Parser\\Php7' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Parser/Php7.php',
+ 'PhpParser\\Parser\\Tokens' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Parser/Tokens.php',
+ 'PhpParser\\PrettyPrinterAbstract' => $vendorDir . '/nikic/php-parser/lib/PhpParser/PrettyPrinterAbstract.php',
+ 'PhpParser\\PrettyPrinter\\Standard' => $vendorDir . '/nikic/php-parser/lib/PhpParser/PrettyPrinter/Standard.php',
+ 'PhpParser\\Serializer' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Serializer.php',
+ 'PhpParser\\Serializer\\XML' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Serializer/XML.php',
+ 'PhpParser\\Unserializer' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Unserializer.php',
+ 'PhpParser\\Unserializer\\XML' => $vendorDir . '/nikic/php-parser/lib/PhpParser/Unserializer/XML.php',
+ 'Prophecy\\Argument' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument.php',
+ 'Prophecy\\Argument\\ArgumentsWildcard' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/ArgumentsWildcard.php',
+ 'Prophecy\\Argument\\Token\\AnyValueToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/AnyValueToken.php',
+ 'Prophecy\\Argument\\Token\\AnyValuesToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/AnyValuesToken.php',
+ 'Prophecy\\Argument\\Token\\ApproximateValueToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/ApproximateValueToken.php',
+ 'Prophecy\\Argument\\Token\\ArrayCountToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/ArrayCountToken.php',
+ 'Prophecy\\Argument\\Token\\ArrayEntryToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/ArrayEntryToken.php',
+ 'Prophecy\\Argument\\Token\\ArrayEveryEntryToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/ArrayEveryEntryToken.php',
+ 'Prophecy\\Argument\\Token\\CallbackToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/CallbackToken.php',
+ 'Prophecy\\Argument\\Token\\ExactValueToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/ExactValueToken.php',
+ 'Prophecy\\Argument\\Token\\IdenticalValueToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/IdenticalValueToken.php',
+ 'Prophecy\\Argument\\Token\\LogicalAndToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/LogicalAndToken.php',
+ 'Prophecy\\Argument\\Token\\LogicalNotToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/LogicalNotToken.php',
+ 'Prophecy\\Argument\\Token\\ObjectStateToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/ObjectStateToken.php',
+ 'Prophecy\\Argument\\Token\\StringContainsToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/StringContainsToken.php',
+ 'Prophecy\\Argument\\Token\\TokenInterface' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/TokenInterface.php',
+ 'Prophecy\\Argument\\Token\\TypeToken' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Argument/Token/TypeToken.php',
+ 'Prophecy\\Call\\Call' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Call/Call.php',
+ 'Prophecy\\Call\\CallCenter' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Call/CallCenter.php',
+ 'Prophecy\\Comparator\\ClosureComparator' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Comparator/ClosureComparator.php',
+ 'Prophecy\\Comparator\\Factory' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Comparator/Factory.php',
+ 'Prophecy\\Comparator\\ProphecyComparator' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Comparator/ProphecyComparator.php',
+ 'Prophecy\\Doubler\\CachedDoubler' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/CachedDoubler.php',
+ 'Prophecy\\Doubler\\ClassPatch\\ClassPatchInterface' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ClassPatchInterface.php',
+ 'Prophecy\\Doubler\\ClassPatch\\DisableConstructorPatch' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/DisableConstructorPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\HhvmExceptionPatch' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/HhvmExceptionPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\KeywordPatch' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/KeywordPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\MagicCallPatch' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/MagicCallPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\ProphecySubjectPatch' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ProphecySubjectPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\ReflectionClassNewInstancePatch' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ReflectionClassNewInstancePatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\SplFileInfoPatch' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/SplFileInfoPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\ThrowablePatch' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ThrowablePatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\TraversablePatch' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/TraversablePatch.php',
+ 'Prophecy\\Doubler\\DoubleInterface' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/DoubleInterface.php',
+ 'Prophecy\\Doubler\\Doubler' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/Doubler.php',
+ 'Prophecy\\Doubler\\Generator\\ClassCodeGenerator' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/ClassCodeGenerator.php',
+ 'Prophecy\\Doubler\\Generator\\ClassCreator' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/ClassCreator.php',
+ 'Prophecy\\Doubler\\Generator\\ClassMirror' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/ClassMirror.php',
+ 'Prophecy\\Doubler\\Generator\\Node\\ArgumentNode' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/Node/ArgumentNode.php',
+ 'Prophecy\\Doubler\\Generator\\Node\\ClassNode' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/Node/ClassNode.php',
+ 'Prophecy\\Doubler\\Generator\\Node\\MethodNode' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/Node/MethodNode.php',
+ 'Prophecy\\Doubler\\Generator\\ReflectionInterface' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/ReflectionInterface.php',
+ 'Prophecy\\Doubler\\Generator\\TypeHintReference' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/TypeHintReference.php',
+ 'Prophecy\\Doubler\\LazyDouble' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/LazyDouble.php',
+ 'Prophecy\\Doubler\\NameGenerator' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Doubler/NameGenerator.php',
+ 'Prophecy\\Exception\\Call\\UnexpectedCallException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Call/UnexpectedCallException.php',
+ 'Prophecy\\Exception\\Doubler\\ClassCreatorException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/ClassCreatorException.php',
+ 'Prophecy\\Exception\\Doubler\\ClassMirrorException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/ClassMirrorException.php',
+ 'Prophecy\\Exception\\Doubler\\ClassNotFoundException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/ClassNotFoundException.php',
+ 'Prophecy\\Exception\\Doubler\\DoubleException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/DoubleException.php',
+ 'Prophecy\\Exception\\Doubler\\DoublerException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/DoublerException.php',
+ 'Prophecy\\Exception\\Doubler\\InterfaceNotFoundException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/InterfaceNotFoundException.php',
+ 'Prophecy\\Exception\\Doubler\\MethodNotExtendableException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/MethodNotExtendableException.php',
+ 'Prophecy\\Exception\\Doubler\\MethodNotFoundException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/MethodNotFoundException.php',
+ 'Prophecy\\Exception\\Doubler\\ReturnByReferenceException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/ReturnByReferenceException.php',
+ 'Prophecy\\Exception\\Exception' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Exception.php',
+ 'Prophecy\\Exception\\InvalidArgumentException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/InvalidArgumentException.php',
+ 'Prophecy\\Exception\\Prediction\\AggregateException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/AggregateException.php',
+ 'Prophecy\\Exception\\Prediction\\FailedPredictionException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/FailedPredictionException.php',
+ 'Prophecy\\Exception\\Prediction\\NoCallsException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/NoCallsException.php',
+ 'Prophecy\\Exception\\Prediction\\PredictionException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/PredictionException.php',
+ 'Prophecy\\Exception\\Prediction\\UnexpectedCallsCountException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/UnexpectedCallsCountException.php',
+ 'Prophecy\\Exception\\Prediction\\UnexpectedCallsException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/UnexpectedCallsException.php',
+ 'Prophecy\\Exception\\Prophecy\\MethodProphecyException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Prophecy/MethodProphecyException.php',
+ 'Prophecy\\Exception\\Prophecy\\ObjectProphecyException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Prophecy/ObjectProphecyException.php',
+ 'Prophecy\\Exception\\Prophecy\\ProphecyException' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Exception/Prophecy/ProphecyException.php',
+ 'Prophecy\\PhpDocumentor\\ClassAndInterfaceTagRetriever' => $vendorDir . '/phpspec/prophecy/src/Prophecy/PhpDocumentor/ClassAndInterfaceTagRetriever.php',
+ 'Prophecy\\PhpDocumentor\\ClassTagRetriever' => $vendorDir . '/phpspec/prophecy/src/Prophecy/PhpDocumentor/ClassTagRetriever.php',
+ 'Prophecy\\PhpDocumentor\\LegacyClassTagRetriever' => $vendorDir . '/phpspec/prophecy/src/Prophecy/PhpDocumentor/LegacyClassTagRetriever.php',
+ 'Prophecy\\PhpDocumentor\\MethodTagRetrieverInterface' => $vendorDir . '/phpspec/prophecy/src/Prophecy/PhpDocumentor/MethodTagRetrieverInterface.php',
+ 'Prophecy\\Prediction\\CallPrediction' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prediction/CallPrediction.php',
+ 'Prophecy\\Prediction\\CallTimesPrediction' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prediction/CallTimesPrediction.php',
+ 'Prophecy\\Prediction\\CallbackPrediction' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prediction/CallbackPrediction.php',
+ 'Prophecy\\Prediction\\NoCallsPrediction' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prediction/NoCallsPrediction.php',
+ 'Prophecy\\Prediction\\PredictionInterface' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prediction/PredictionInterface.php',
+ 'Prophecy\\Promise\\CallbackPromise' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Promise/CallbackPromise.php',
+ 'Prophecy\\Promise\\PromiseInterface' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Promise/PromiseInterface.php',
+ 'Prophecy\\Promise\\ReturnArgumentPromise' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Promise/ReturnArgumentPromise.php',
+ 'Prophecy\\Promise\\ReturnPromise' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Promise/ReturnPromise.php',
+ 'Prophecy\\Promise\\ThrowPromise' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Promise/ThrowPromise.php',
+ 'Prophecy\\Prophecy\\MethodProphecy' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prophecy/MethodProphecy.php',
+ 'Prophecy\\Prophecy\\ObjectProphecy' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prophecy/ObjectProphecy.php',
+ 'Prophecy\\Prophecy\\ProphecyInterface' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prophecy/ProphecyInterface.php',
+ 'Prophecy\\Prophecy\\ProphecySubjectInterface' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prophecy/ProphecySubjectInterface.php',
+ 'Prophecy\\Prophecy\\Revealer' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prophecy/Revealer.php',
+ 'Prophecy\\Prophecy\\RevealerInterface' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prophecy/RevealerInterface.php',
+ 'Prophecy\\Prophet' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Prophet.php',
+ 'Prophecy\\Util\\ExportUtil' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Util/ExportUtil.php',
+ 'Prophecy\\Util\\StringUtil' => $vendorDir . '/phpspec/prophecy/src/Prophecy/Util/StringUtil.php',
+ 'Psr\\Log\\AbstractLogger' => $vendorDir . '/psr/log/Psr/Log/AbstractLogger.php',
+ 'Psr\\Log\\InvalidArgumentException' => $vendorDir . '/psr/log/Psr/Log/InvalidArgumentException.php',
+ 'Psr\\Log\\LogLevel' => $vendorDir . '/psr/log/Psr/Log/LogLevel.php',
+ 'Psr\\Log\\LoggerAwareInterface' => $vendorDir . '/psr/log/Psr/Log/LoggerAwareInterface.php',
+ 'Psr\\Log\\LoggerAwareTrait' => $vendorDir . '/psr/log/Psr/Log/LoggerAwareTrait.php',
+ 'Psr\\Log\\LoggerInterface' => $vendorDir . '/psr/log/Psr/Log/LoggerInterface.php',
+ 'Psr\\Log\\LoggerTrait' => $vendorDir . '/psr/log/Psr/Log/LoggerTrait.php',
+ 'Psr\\Log\\NullLogger' => $vendorDir . '/psr/log/Psr/Log/NullLogger.php',
+ 'Psr\\Log\\Test\\DummyTest' => $vendorDir . '/psr/log/Psr/Log/Test/DummyTest.php',
+ 'Psr\\Log\\Test\\LoggerInterfaceTest' => $vendorDir . '/psr/log/Psr/Log/Test/LoggerInterfaceTest.php',
+ 'Psr\\Log\\Test\\TestLogger' => $vendorDir . '/psr/log/Psr/Log/Test/TestLogger.php',
+ 'Psy\\CodeCleaner' => $vendorDir . '/psy/psysh/src/CodeCleaner.php',
+ 'Psy\\CodeCleaner\\AbstractClassPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/AbstractClassPass.php',
+ 'Psy\\CodeCleaner\\AssignThisVariablePass' => $vendorDir . '/psy/psysh/src/CodeCleaner/AssignThisVariablePass.php',
+ 'Psy\\CodeCleaner\\CallTimePassByReferencePass' => $vendorDir . '/psy/psysh/src/CodeCleaner/CallTimePassByReferencePass.php',
+ 'Psy\\CodeCleaner\\CalledClassPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/CalledClassPass.php',
+ 'Psy\\CodeCleaner\\CodeCleanerPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/CodeCleanerPass.php',
+ 'Psy\\CodeCleaner\\ExitPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/ExitPass.php',
+ 'Psy\\CodeCleaner\\FinalClassPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/FinalClassPass.php',
+ 'Psy\\CodeCleaner\\FunctionContextPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/FunctionContextPass.php',
+ 'Psy\\CodeCleaner\\FunctionReturnInWriteContextPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/FunctionReturnInWriteContextPass.php',
+ 'Psy\\CodeCleaner\\ImplicitReturnPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/ImplicitReturnPass.php',
+ 'Psy\\CodeCleaner\\InstanceOfPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/InstanceOfPass.php',
+ 'Psy\\CodeCleaner\\LeavePsyshAlonePass' => $vendorDir . '/psy/psysh/src/CodeCleaner/LeavePsyshAlonePass.php',
+ 'Psy\\CodeCleaner\\LegacyEmptyPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/LegacyEmptyPass.php',
+ 'Psy\\CodeCleaner\\ListPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/ListPass.php',
+ 'Psy\\CodeCleaner\\LoopContextPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/LoopContextPass.php',
+ 'Psy\\CodeCleaner\\MagicConstantsPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/MagicConstantsPass.php',
+ 'Psy\\CodeCleaner\\NamespaceAwarePass' => $vendorDir . '/psy/psysh/src/CodeCleaner/NamespaceAwarePass.php',
+ 'Psy\\CodeCleaner\\NamespacePass' => $vendorDir . '/psy/psysh/src/CodeCleaner/NamespacePass.php',
+ 'Psy\\CodeCleaner\\NoReturnValue' => $vendorDir . '/psy/psysh/src/CodeCleaner/NoReturnValue.php',
+ 'Psy\\CodeCleaner\\PassableByReferencePass' => $vendorDir . '/psy/psysh/src/CodeCleaner/PassableByReferencePass.php',
+ 'Psy\\CodeCleaner\\RequirePass' => $vendorDir . '/psy/psysh/src/CodeCleaner/RequirePass.php',
+ 'Psy\\CodeCleaner\\StrictTypesPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/StrictTypesPass.php',
+ 'Psy\\CodeCleaner\\UseStatementPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/UseStatementPass.php',
+ 'Psy\\CodeCleaner\\ValidClassNamePass' => $vendorDir . '/psy/psysh/src/CodeCleaner/ValidClassNamePass.php',
+ 'Psy\\CodeCleaner\\ValidConstantPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/ValidConstantPass.php',
+ 'Psy\\CodeCleaner\\ValidConstructorPass' => $vendorDir . '/psy/psysh/src/CodeCleaner/ValidConstructorPass.php',
+ 'Psy\\CodeCleaner\\ValidFunctionNamePass' => $vendorDir . '/psy/psysh/src/CodeCleaner/ValidFunctionNamePass.php',
+ 'Psy\\Command\\BufferCommand' => $vendorDir . '/psy/psysh/src/Command/BufferCommand.php',
+ 'Psy\\Command\\ClearCommand' => $vendorDir . '/psy/psysh/src/Command/ClearCommand.php',
+ 'Psy\\Command\\Command' => $vendorDir . '/psy/psysh/src/Command/Command.php',
+ 'Psy\\Command\\DocCommand' => $vendorDir . '/psy/psysh/src/Command/DocCommand.php',
+ 'Psy\\Command\\DumpCommand' => $vendorDir . '/psy/psysh/src/Command/DumpCommand.php',
+ 'Psy\\Command\\EditCommand' => $vendorDir . '/psy/psysh/src/Command/EditCommand.php',
+ 'Psy\\Command\\ExitCommand' => $vendorDir . '/psy/psysh/src/Command/ExitCommand.php',
+ 'Psy\\Command\\HelpCommand' => $vendorDir . '/psy/psysh/src/Command/HelpCommand.php',
+ 'Psy\\Command\\HistoryCommand' => $vendorDir . '/psy/psysh/src/Command/HistoryCommand.php',
+ 'Psy\\Command\\ListCommand' => $vendorDir . '/psy/psysh/src/Command/ListCommand.php',
+ 'Psy\\Command\\ListCommand\\ClassConstantEnumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/ClassConstantEnumerator.php',
+ 'Psy\\Command\\ListCommand\\ClassEnumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/ClassEnumerator.php',
+ 'Psy\\Command\\ListCommand\\ConstantEnumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/ConstantEnumerator.php',
+ 'Psy\\Command\\ListCommand\\Enumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/Enumerator.php',
+ 'Psy\\Command\\ListCommand\\FunctionEnumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/FunctionEnumerator.php',
+ 'Psy\\Command\\ListCommand\\GlobalVariableEnumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/GlobalVariableEnumerator.php',
+ 'Psy\\Command\\ListCommand\\InterfaceEnumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/InterfaceEnumerator.php',
+ 'Psy\\Command\\ListCommand\\MethodEnumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/MethodEnumerator.php',
+ 'Psy\\Command\\ListCommand\\PropertyEnumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/PropertyEnumerator.php',
+ 'Psy\\Command\\ListCommand\\TraitEnumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/TraitEnumerator.php',
+ 'Psy\\Command\\ListCommand\\VariableEnumerator' => $vendorDir . '/psy/psysh/src/Command/ListCommand/VariableEnumerator.php',
+ 'Psy\\Command\\ParseCommand' => $vendorDir . '/psy/psysh/src/Command/ParseCommand.php',
+ 'Psy\\Command\\PsyVersionCommand' => $vendorDir . '/psy/psysh/src/Command/PsyVersionCommand.php',
+ 'Psy\\Command\\ReflectingCommand' => $vendorDir . '/psy/psysh/src/Command/ReflectingCommand.php',
+ 'Psy\\Command\\ShowCommand' => $vendorDir . '/psy/psysh/src/Command/ShowCommand.php',
+ 'Psy\\Command\\SudoCommand' => $vendorDir . '/psy/psysh/src/Command/SudoCommand.php',
+ 'Psy\\Command\\ThrowUpCommand' => $vendorDir . '/psy/psysh/src/Command/ThrowUpCommand.php',
+ 'Psy\\Command\\TimeitCommand' => $vendorDir . '/psy/psysh/src/Command/TimeitCommand.php',
+ 'Psy\\Command\\TimeitCommand\\TimeitVisitor' => $vendorDir . '/psy/psysh/src/Command/TimeitCommand/TimeitVisitor.php',
+ 'Psy\\Command\\TraceCommand' => $vendorDir . '/psy/psysh/src/Command/TraceCommand.php',
+ 'Psy\\Command\\WhereamiCommand' => $vendorDir . '/psy/psysh/src/Command/WhereamiCommand.php',
+ 'Psy\\Command\\WtfCommand' => $vendorDir . '/psy/psysh/src/Command/WtfCommand.php',
+ 'Psy\\ConfigPaths' => $vendorDir . '/psy/psysh/src/ConfigPaths.php',
+ 'Psy\\Configuration' => $vendorDir . '/psy/psysh/src/Configuration.php',
+ 'Psy\\ConsoleColorFactory' => $vendorDir . '/psy/psysh/src/ConsoleColorFactory.php',
+ 'Psy\\Context' => $vendorDir . '/psy/psysh/src/Context.php',
+ 'Psy\\ContextAware' => $vendorDir . '/psy/psysh/src/ContextAware.php',
+ 'Psy\\Exception\\BreakException' => $vendorDir . '/psy/psysh/src/Exception/BreakException.php',
+ 'Psy\\Exception\\DeprecatedException' => $vendorDir . '/psy/psysh/src/Exception/DeprecatedException.php',
+ 'Psy\\Exception\\ErrorException' => $vendorDir . '/psy/psysh/src/Exception/ErrorException.php',
+ 'Psy\\Exception\\Exception' => $vendorDir . '/psy/psysh/src/Exception/Exception.php',
+ 'Psy\\Exception\\FatalErrorException' => $vendorDir . '/psy/psysh/src/Exception/FatalErrorException.php',
+ 'Psy\\Exception\\ParseErrorException' => $vendorDir . '/psy/psysh/src/Exception/ParseErrorException.php',
+ 'Psy\\Exception\\RuntimeException' => $vendorDir . '/psy/psysh/src/Exception/RuntimeException.php',
+ 'Psy\\Exception\\ThrowUpException' => $vendorDir . '/psy/psysh/src/Exception/ThrowUpException.php',
+ 'Psy\\Exception\\TypeErrorException' => $vendorDir . '/psy/psysh/src/Exception/TypeErrorException.php',
+ 'Psy\\ExecutionClosure' => $vendorDir . '/psy/psysh/src/ExecutionClosure.php',
+ 'Psy\\ExecutionLoop' => $vendorDir . '/psy/psysh/src/ExecutionLoop.php',
+ 'Psy\\ExecutionLoopClosure' => $vendorDir . '/psy/psysh/src/ExecutionLoopClosure.php',
+ 'Psy\\ExecutionLoop\\AbstractListener' => $vendorDir . '/psy/psysh/src/ExecutionLoop/AbstractListener.php',
+ 'Psy\\ExecutionLoop\\Listener' => $vendorDir . '/psy/psysh/src/ExecutionLoop/Listener.php',
+ 'Psy\\ExecutionLoop\\ProcessForker' => $vendorDir . '/psy/psysh/src/ExecutionLoop/ProcessForker.php',
+ 'Psy\\ExecutionLoop\\RunkitReloader' => $vendorDir . '/psy/psysh/src/ExecutionLoop/RunkitReloader.php',
+ 'Psy\\Formatter\\CodeFormatter' => $vendorDir . '/psy/psysh/src/Formatter/CodeFormatter.php',
+ 'Psy\\Formatter\\DocblockFormatter' => $vendorDir . '/psy/psysh/src/Formatter/DocblockFormatter.php',
+ 'Psy\\Formatter\\Formatter' => $vendorDir . '/psy/psysh/src/Formatter/Formatter.php',
+ 'Psy\\Formatter\\SignatureFormatter' => $vendorDir . '/psy/psysh/src/Formatter/SignatureFormatter.php',
+ 'Psy\\Input\\CodeArgument' => $vendorDir . '/psy/psysh/src/Input/CodeArgument.php',
+ 'Psy\\Input\\FilterOptions' => $vendorDir . '/psy/psysh/src/Input/FilterOptions.php',
+ 'Psy\\Input\\ShellInput' => $vendorDir . '/psy/psysh/src/Input/ShellInput.php',
+ 'Psy\\Input\\SilentInput' => $vendorDir . '/psy/psysh/src/Input/SilentInput.php',
+ 'Psy\\Output\\OutputPager' => $vendorDir . '/psy/psysh/src/Output/OutputPager.php',
+ 'Psy\\Output\\PassthruPager' => $vendorDir . '/psy/psysh/src/Output/PassthruPager.php',
+ 'Psy\\Output\\ProcOutputPager' => $vendorDir . '/psy/psysh/src/Output/ProcOutputPager.php',
+ 'Psy\\Output\\ShellOutput' => $vendorDir . '/psy/psysh/src/Output/ShellOutput.php',
+ 'Psy\\ParserFactory' => $vendorDir . '/psy/psysh/src/ParserFactory.php',
+ 'Psy\\Readline\\GNUReadline' => $vendorDir . '/psy/psysh/src/Readline/GNUReadline.php',
+ 'Psy\\Readline\\HoaConsole' => $vendorDir . '/psy/psysh/src/Readline/HoaConsole.php',
+ 'Psy\\Readline\\Libedit' => $vendorDir . '/psy/psysh/src/Readline/Libedit.php',
+ 'Psy\\Readline\\Readline' => $vendorDir . '/psy/psysh/src/Readline/Readline.php',
+ 'Psy\\Readline\\Transient' => $vendorDir . '/psy/psysh/src/Readline/Transient.php',
+ 'Psy\\Reflection\\ReflectionClassConstant' => $vendorDir . '/psy/psysh/src/Reflection/ReflectionClassConstant.php',
+ 'Psy\\Reflection\\ReflectionConstant' => $vendorDir . '/psy/psysh/src/Reflection/ReflectionConstant.php',
+ 'Psy\\Reflection\\ReflectionConstant_' => $vendorDir . '/psy/psysh/src/Reflection/ReflectionConstant_.php',
+ 'Psy\\Reflection\\ReflectionLanguageConstruct' => $vendorDir . '/psy/psysh/src/Reflection/ReflectionLanguageConstruct.php',
+ 'Psy\\Reflection\\ReflectionLanguageConstructParameter' => $vendorDir . '/psy/psysh/src/Reflection/ReflectionLanguageConstructParameter.php',
+ 'Psy\\Shell' => $vendorDir . '/psy/psysh/src/Shell.php',
+ 'Psy\\Sudo' => $vendorDir . '/psy/psysh/src/Sudo.php',
+ 'Psy\\Sudo\\SudoVisitor' => $vendorDir . '/psy/psysh/src/Sudo/SudoVisitor.php',
+ 'Psy\\TabCompletion\\AutoCompleter' => $vendorDir . '/psy/psysh/src/TabCompletion/AutoCompleter.php',
+ 'Psy\\TabCompletion\\Matcher\\AbstractContextAwareMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/AbstractContextAwareMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\AbstractDefaultParametersMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/AbstractDefaultParametersMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\AbstractMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/AbstractMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ClassAttributesMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/ClassAttributesMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ClassMethodDefaultParametersMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/ClassMethodDefaultParametersMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ClassMethodsMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/ClassMethodsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ClassNamesMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/ClassNamesMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\CommandsMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/CommandsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ConstantsMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/ConstantsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\FunctionDefaultParametersMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/FunctionDefaultParametersMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\FunctionsMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/FunctionsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\KeywordsMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/KeywordsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\MongoClientMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/MongoClientMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\MongoDatabaseMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/MongoDatabaseMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ObjectAttributesMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/ObjectAttributesMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ObjectMethodDefaultParametersMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/ObjectMethodDefaultParametersMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ObjectMethodsMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/ObjectMethodsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\VariablesMatcher' => $vendorDir . '/psy/psysh/src/TabCompletion/Matcher/VariablesMatcher.php',
+ 'Psy\\Util\\Docblock' => $vendorDir . '/psy/psysh/src/Util/Docblock.php',
+ 'Psy\\Util\\Json' => $vendorDir . '/psy/psysh/src/Util/Json.php',
+ 'Psy\\Util\\Mirror' => $vendorDir . '/psy/psysh/src/Util/Mirror.php',
+ 'Psy\\Util\\Str' => $vendorDir . '/psy/psysh/src/Util/Str.php',
+ 'Psy\\VarDumper\\Cloner' => $vendorDir . '/psy/psysh/src/VarDumper/Cloner.php',
+ 'Psy\\VarDumper\\Dumper' => $vendorDir . '/psy/psysh/src/VarDumper/Dumper.php',
+ 'Psy\\VarDumper\\Presenter' => $vendorDir . '/psy/psysh/src/VarDumper/Presenter.php',
+ 'Psy\\VarDumper\\PresenterAware' => $vendorDir . '/psy/psysh/src/VarDumper/PresenterAware.php',
+ 'Psy\\VersionUpdater\\Checker' => $vendorDir . '/psy/psysh/src/VersionUpdater/Checker.php',
+ 'Psy\\VersionUpdater\\GitHubChecker' => $vendorDir . '/psy/psysh/src/VersionUpdater/GitHubChecker.php',
+ 'Psy\\VersionUpdater\\IntervalChecker' => $vendorDir . '/psy/psysh/src/VersionUpdater/IntervalChecker.php',
+ 'Psy\\VersionUpdater\\NoopChecker' => $vendorDir . '/psy/psysh/src/VersionUpdater/NoopChecker.php',
+ 'Ramsey\\Uuid\\BinaryUtils' => $vendorDir . '/ramsey/uuid/src/BinaryUtils.php',
+ 'Ramsey\\Uuid\\Builder\\DefaultUuidBuilder' => $vendorDir . '/ramsey/uuid/src/Builder/DefaultUuidBuilder.php',
+ 'Ramsey\\Uuid\\Builder\\DegradedUuidBuilder' => $vendorDir . '/ramsey/uuid/src/Builder/DegradedUuidBuilder.php',
+ 'Ramsey\\Uuid\\Builder\\UuidBuilderInterface' => $vendorDir . '/ramsey/uuid/src/Builder/UuidBuilderInterface.php',
+ 'Ramsey\\Uuid\\Codec\\CodecInterface' => $vendorDir . '/ramsey/uuid/src/Codec/CodecInterface.php',
+ 'Ramsey\\Uuid\\Codec\\GuidStringCodec' => $vendorDir . '/ramsey/uuid/src/Codec/GuidStringCodec.php',
+ 'Ramsey\\Uuid\\Codec\\OrderedTimeCodec' => $vendorDir . '/ramsey/uuid/src/Codec/OrderedTimeCodec.php',
+ 'Ramsey\\Uuid\\Codec\\StringCodec' => $vendorDir . '/ramsey/uuid/src/Codec/StringCodec.php',
+ 'Ramsey\\Uuid\\Codec\\TimestampFirstCombCodec' => $vendorDir . '/ramsey/uuid/src/Codec/TimestampFirstCombCodec.php',
+ 'Ramsey\\Uuid\\Codec\\TimestampLastCombCodec' => $vendorDir . '/ramsey/uuid/src/Codec/TimestampLastCombCodec.php',
+ 'Ramsey\\Uuid\\Converter\\NumberConverterInterface' => $vendorDir . '/ramsey/uuid/src/Converter/NumberConverterInterface.php',
+ 'Ramsey\\Uuid\\Converter\\Number\\BigNumberConverter' => $vendorDir . '/ramsey/uuid/src/Converter/Number/BigNumberConverter.php',
+ 'Ramsey\\Uuid\\Converter\\Number\\DegradedNumberConverter' => $vendorDir . '/ramsey/uuid/src/Converter/Number/DegradedNumberConverter.php',
+ 'Ramsey\\Uuid\\Converter\\TimeConverterInterface' => $vendorDir . '/ramsey/uuid/src/Converter/TimeConverterInterface.php',
+ 'Ramsey\\Uuid\\Converter\\Time\\BigNumberTimeConverter' => $vendorDir . '/ramsey/uuid/src/Converter/Time/BigNumberTimeConverter.php',
+ 'Ramsey\\Uuid\\Converter\\Time\\DegradedTimeConverter' => $vendorDir . '/ramsey/uuid/src/Converter/Time/DegradedTimeConverter.php',
+ 'Ramsey\\Uuid\\Converter\\Time\\PhpTimeConverter' => $vendorDir . '/ramsey/uuid/src/Converter/Time/PhpTimeConverter.php',
+ 'Ramsey\\Uuid\\DegradedUuid' => $vendorDir . '/ramsey/uuid/src/DegradedUuid.php',
+ 'Ramsey\\Uuid\\Exception\\InvalidUuidStringException' => $vendorDir . '/ramsey/uuid/src/Exception/InvalidUuidStringException.php',
+ 'Ramsey\\Uuid\\Exception\\UnsatisfiedDependencyException' => $vendorDir . '/ramsey/uuid/src/Exception/UnsatisfiedDependencyException.php',
+ 'Ramsey\\Uuid\\Exception\\UnsupportedOperationException' => $vendorDir . '/ramsey/uuid/src/Exception/UnsupportedOperationException.php',
+ 'Ramsey\\Uuid\\FeatureSet' => $vendorDir . '/ramsey/uuid/src/FeatureSet.php',
+ 'Ramsey\\Uuid\\Generator\\CombGenerator' => $vendorDir . '/ramsey/uuid/src/Generator/CombGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\DefaultTimeGenerator' => $vendorDir . '/ramsey/uuid/src/Generator/DefaultTimeGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\MtRandGenerator' => $vendorDir . '/ramsey/uuid/src/Generator/MtRandGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\OpenSslGenerator' => $vendorDir . '/ramsey/uuid/src/Generator/OpenSslGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\PeclUuidRandomGenerator' => $vendorDir . '/ramsey/uuid/src/Generator/PeclUuidRandomGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\PeclUuidTimeGenerator' => $vendorDir . '/ramsey/uuid/src/Generator/PeclUuidTimeGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\RandomBytesGenerator' => $vendorDir . '/ramsey/uuid/src/Generator/RandomBytesGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\RandomGeneratorFactory' => $vendorDir . '/ramsey/uuid/src/Generator/RandomGeneratorFactory.php',
+ 'Ramsey\\Uuid\\Generator\\RandomGeneratorInterface' => $vendorDir . '/ramsey/uuid/src/Generator/RandomGeneratorInterface.php',
+ 'Ramsey\\Uuid\\Generator\\RandomLibAdapter' => $vendorDir . '/ramsey/uuid/src/Generator/RandomLibAdapter.php',
+ 'Ramsey\\Uuid\\Generator\\SodiumRandomGenerator' => $vendorDir . '/ramsey/uuid/src/Generator/SodiumRandomGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\TimeGeneratorFactory' => $vendorDir . '/ramsey/uuid/src/Generator/TimeGeneratorFactory.php',
+ 'Ramsey\\Uuid\\Generator\\TimeGeneratorInterface' => $vendorDir . '/ramsey/uuid/src/Generator/TimeGeneratorInterface.php',
+ 'Ramsey\\Uuid\\Provider\\NodeProviderInterface' => $vendorDir . '/ramsey/uuid/src/Provider/NodeProviderInterface.php',
+ 'Ramsey\\Uuid\\Provider\\Node\\FallbackNodeProvider' => $vendorDir . '/ramsey/uuid/src/Provider/Node/FallbackNodeProvider.php',
+ 'Ramsey\\Uuid\\Provider\\Node\\RandomNodeProvider' => $vendorDir . '/ramsey/uuid/src/Provider/Node/RandomNodeProvider.php',
+ 'Ramsey\\Uuid\\Provider\\Node\\SystemNodeProvider' => $vendorDir . '/ramsey/uuid/src/Provider/Node/SystemNodeProvider.php',
+ 'Ramsey\\Uuid\\Provider\\TimeProviderInterface' => $vendorDir . '/ramsey/uuid/src/Provider/TimeProviderInterface.php',
+ 'Ramsey\\Uuid\\Provider\\Time\\FixedTimeProvider' => $vendorDir . '/ramsey/uuid/src/Provider/Time/FixedTimeProvider.php',
+ 'Ramsey\\Uuid\\Provider\\Time\\SystemTimeProvider' => $vendorDir . '/ramsey/uuid/src/Provider/Time/SystemTimeProvider.php',
+ 'Ramsey\\Uuid\\Uuid' => $vendorDir . '/ramsey/uuid/src/Uuid.php',
+ 'Ramsey\\Uuid\\UuidFactory' => $vendorDir . '/ramsey/uuid/src/UuidFactory.php',
+ 'Ramsey\\Uuid\\UuidFactoryInterface' => $vendorDir . '/ramsey/uuid/src/UuidFactoryInterface.php',
+ 'Ramsey\\Uuid\\UuidInterface' => $vendorDir . '/ramsey/uuid/src/UuidInterface.php',
+ 'SebastianBergmann\\CodeCoverage\\CodeCoverage' => $vendorDir . '/phpunit/php-code-coverage/src/CodeCoverage.php',
+ 'SebastianBergmann\\CodeCoverage\\CoveredCodeNotExecutedException' => $vendorDir . '/phpunit/php-code-coverage/src/Exception/CoveredCodeNotExecutedException.php',
+ 'SebastianBergmann\\CodeCoverage\\Driver\\Driver' => $vendorDir . '/phpunit/php-code-coverage/src/Driver/Driver.php',
+ 'SebastianBergmann\\CodeCoverage\\Driver\\HHVM' => $vendorDir . '/phpunit/php-code-coverage/src/Driver/HHVM.php',
+ 'SebastianBergmann\\CodeCoverage\\Driver\\PHPDBG' => $vendorDir . '/phpunit/php-code-coverage/src/Driver/PHPDBG.php',
+ 'SebastianBergmann\\CodeCoverage\\Driver\\Xdebug' => $vendorDir . '/phpunit/php-code-coverage/src/Driver/Xdebug.php',
+ 'SebastianBergmann\\CodeCoverage\\Exception' => $vendorDir . '/phpunit/php-code-coverage/src/Exception/Exception.php',
+ 'SebastianBergmann\\CodeCoverage\\Filter' => $vendorDir . '/phpunit/php-code-coverage/src/Filter.php',
+ 'SebastianBergmann\\CodeCoverage\\InvalidArgumentException' => $vendorDir . '/phpunit/php-code-coverage/src/Exception/InvalidArgumentException.php',
+ 'SebastianBergmann\\CodeCoverage\\MissingCoversAnnotationException' => $vendorDir . '/phpunit/php-code-coverage/src/Exception/MissingCoversAnnotationException.php',
+ 'SebastianBergmann\\CodeCoverage\\Node\\AbstractNode' => $vendorDir . '/phpunit/php-code-coverage/src/Node/AbstractNode.php',
+ 'SebastianBergmann\\CodeCoverage\\Node\\Builder' => $vendorDir . '/phpunit/php-code-coverage/src/Node/Builder.php',
+ 'SebastianBergmann\\CodeCoverage\\Node\\Directory' => $vendorDir . '/phpunit/php-code-coverage/src/Node/Directory.php',
+ 'SebastianBergmann\\CodeCoverage\\Node\\File' => $vendorDir . '/phpunit/php-code-coverage/src/Node/File.php',
+ 'SebastianBergmann\\CodeCoverage\\Node\\Iterator' => $vendorDir . '/phpunit/php-code-coverage/src/Node/Iterator.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Clover' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Clover.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Crap4j' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Crap4j.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Html\\Dashboard' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Html/Renderer/Dashboard.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Html\\Directory' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Html/Renderer/Directory.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Html\\Facade' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Html/Facade.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Html\\File' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Html/Renderer/File.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Html\\Renderer' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Html/Renderer.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\PHP' => $vendorDir . '/phpunit/php-code-coverage/src/Report/PHP.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Text' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Text.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Coverage' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/Coverage.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Directory' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/Directory.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Facade' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/Facade.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\File' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/File.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Method' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/Method.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Node' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/Node.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Project' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/Project.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Report' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/Report.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Tests' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/Tests.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Totals' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/Totals.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Unit' => $vendorDir . '/phpunit/php-code-coverage/src/Report/Xml/Unit.php',
+ 'SebastianBergmann\\CodeCoverage\\RuntimeException' => $vendorDir . '/phpunit/php-code-coverage/src/Exception/RuntimeException.php',
+ 'SebastianBergmann\\CodeCoverage\\UnintentionallyCoveredCodeException' => $vendorDir . '/phpunit/php-code-coverage/src/Exception/UnintentionallyCoveredCodeException.php',
+ 'SebastianBergmann\\CodeCoverage\\Util' => $vendorDir . '/phpunit/php-code-coverage/src/Util.php',
+ 'SebastianBergmann\\CodeUnitReverseLookup\\Wizard' => $vendorDir . '/sebastian/code-unit-reverse-lookup/src/Wizard.php',
+ 'SebastianBergmann\\Comparator\\ArrayComparator' => $vendorDir . '/sebastian/comparator/src/ArrayComparator.php',
+ 'SebastianBergmann\\Comparator\\Comparator' => $vendorDir . '/sebastian/comparator/src/Comparator.php',
+ 'SebastianBergmann\\Comparator\\ComparisonFailure' => $vendorDir . '/sebastian/comparator/src/ComparisonFailure.php',
+ 'SebastianBergmann\\Comparator\\DOMNodeComparator' => $vendorDir . '/sebastian/comparator/src/DOMNodeComparator.php',
+ 'SebastianBergmann\\Comparator\\DateTimeComparator' => $vendorDir . '/sebastian/comparator/src/DateTimeComparator.php',
+ 'SebastianBergmann\\Comparator\\DoubleComparator' => $vendorDir . '/sebastian/comparator/src/DoubleComparator.php',
+ 'SebastianBergmann\\Comparator\\ExceptionComparator' => $vendorDir . '/sebastian/comparator/src/ExceptionComparator.php',
+ 'SebastianBergmann\\Comparator\\Factory' => $vendorDir . '/sebastian/comparator/src/Factory.php',
+ 'SebastianBergmann\\Comparator\\MockObjectComparator' => $vendorDir . '/sebastian/comparator/src/MockObjectComparator.php',
+ 'SebastianBergmann\\Comparator\\NumericComparator' => $vendorDir . '/sebastian/comparator/src/NumericComparator.php',
+ 'SebastianBergmann\\Comparator\\ObjectComparator' => $vendorDir . '/sebastian/comparator/src/ObjectComparator.php',
+ 'SebastianBergmann\\Comparator\\ResourceComparator' => $vendorDir . '/sebastian/comparator/src/ResourceComparator.php',
+ 'SebastianBergmann\\Comparator\\ScalarComparator' => $vendorDir . '/sebastian/comparator/src/ScalarComparator.php',
+ 'SebastianBergmann\\Comparator\\SplObjectStorageComparator' => $vendorDir . '/sebastian/comparator/src/SplObjectStorageComparator.php',
+ 'SebastianBergmann\\Comparator\\TypeComparator' => $vendorDir . '/sebastian/comparator/src/TypeComparator.php',
+ 'SebastianBergmann\\Diff\\Chunk' => $vendorDir . '/sebastian/diff/src/Chunk.php',
+ 'SebastianBergmann\\Diff\\Diff' => $vendorDir . '/sebastian/diff/src/Diff.php',
+ 'SebastianBergmann\\Diff\\Differ' => $vendorDir . '/sebastian/diff/src/Differ.php',
+ 'SebastianBergmann\\Diff\\LCS\\LongestCommonSubsequence' => $vendorDir . '/sebastian/diff/src/LCS/LongestCommonSubsequence.php',
+ 'SebastianBergmann\\Diff\\LCS\\MemoryEfficientImplementation' => $vendorDir . '/sebastian/diff/src/LCS/MemoryEfficientLongestCommonSubsequenceImplementation.php',
+ 'SebastianBergmann\\Diff\\LCS\\TimeEfficientImplementation' => $vendorDir . '/sebastian/diff/src/LCS/TimeEfficientLongestCommonSubsequenceImplementation.php',
+ 'SebastianBergmann\\Diff\\Line' => $vendorDir . '/sebastian/diff/src/Line.php',
+ 'SebastianBergmann\\Diff\\Parser' => $vendorDir . '/sebastian/diff/src/Parser.php',
+ 'SebastianBergmann\\Environment\\Console' => $vendorDir . '/sebastian/environment/src/Console.php',
+ 'SebastianBergmann\\Environment\\Runtime' => $vendorDir . '/sebastian/environment/src/Runtime.php',
+ 'SebastianBergmann\\Exporter\\Exporter' => $vendorDir . '/sebastian/exporter/src/Exporter.php',
+ 'SebastianBergmann\\GlobalState\\Blacklist' => $vendorDir . '/sebastian/global-state/src/Blacklist.php',
+ 'SebastianBergmann\\GlobalState\\CodeExporter' => $vendorDir . '/sebastian/global-state/src/CodeExporter.php',
+ 'SebastianBergmann\\GlobalState\\Exception' => $vendorDir . '/sebastian/global-state/src/Exception.php',
+ 'SebastianBergmann\\GlobalState\\Restorer' => $vendorDir . '/sebastian/global-state/src/Restorer.php',
+ 'SebastianBergmann\\GlobalState\\RuntimeException' => $vendorDir . '/sebastian/global-state/src/RuntimeException.php',
+ 'SebastianBergmann\\GlobalState\\Snapshot' => $vendorDir . '/sebastian/global-state/src/Snapshot.php',
+ 'SebastianBergmann\\ObjectEnumerator\\Enumerator' => $vendorDir . '/sebastian/object-enumerator/src/Enumerator.php',
+ 'SebastianBergmann\\ObjectEnumerator\\Exception' => $vendorDir . '/sebastian/object-enumerator/src/Exception.php',
+ 'SebastianBergmann\\ObjectEnumerator\\InvalidArgumentException' => $vendorDir . '/sebastian/object-enumerator/src/InvalidArgumentException.php',
+ 'SebastianBergmann\\RecursionContext\\Context' => $vendorDir . '/sebastian/recursion-context/src/Context.php',
+ 'SebastianBergmann\\RecursionContext\\Exception' => $vendorDir . '/sebastian/recursion-context/src/Exception.php',
+ 'SebastianBergmann\\RecursionContext\\InvalidArgumentException' => $vendorDir . '/sebastian/recursion-context/src/InvalidArgumentException.php',
+ 'SebastianBergmann\\ResourceOperations\\ResourceOperations' => $vendorDir . '/sebastian/resource-operations/src/ResourceOperations.php',
+ 'SebastianBergmann\\Version' => $vendorDir . '/sebastian/version/src/Version.php',
+ 'SessionUpdateTimestampHandlerInterface' => $vendorDir . '/symfony/polyfill-php70/Resources/stubs/SessionUpdateTimestampHandlerInterface.php',
+ 'Symfony\\Component\\Console\\Application' => $vendorDir . '/symfony/console/Application.php',
+ 'Symfony\\Component\\Console\\CommandLoader\\CommandLoaderInterface' => $vendorDir . '/symfony/console/CommandLoader/CommandLoaderInterface.php',
+ 'Symfony\\Component\\Console\\CommandLoader\\ContainerCommandLoader' => $vendorDir . '/symfony/console/CommandLoader/ContainerCommandLoader.php',
+ 'Symfony\\Component\\Console\\CommandLoader\\FactoryCommandLoader' => $vendorDir . '/symfony/console/CommandLoader/FactoryCommandLoader.php',
+ 'Symfony\\Component\\Console\\Command\\Command' => $vendorDir . '/symfony/console/Command/Command.php',
+ 'Symfony\\Component\\Console\\Command\\HelpCommand' => $vendorDir . '/symfony/console/Command/HelpCommand.php',
+ 'Symfony\\Component\\Console\\Command\\ListCommand' => $vendorDir . '/symfony/console/Command/ListCommand.php',
+ 'Symfony\\Component\\Console\\Command\\LockableTrait' => $vendorDir . '/symfony/console/Command/LockableTrait.php',
+ 'Symfony\\Component\\Console\\ConsoleEvents' => $vendorDir . '/symfony/console/ConsoleEvents.php',
+ 'Symfony\\Component\\Console\\DependencyInjection\\AddConsoleCommandPass' => $vendorDir . '/symfony/console/DependencyInjection/AddConsoleCommandPass.php',
+ 'Symfony\\Component\\Console\\Descriptor\\ApplicationDescription' => $vendorDir . '/symfony/console/Descriptor/ApplicationDescription.php',
+ 'Symfony\\Component\\Console\\Descriptor\\Descriptor' => $vendorDir . '/symfony/console/Descriptor/Descriptor.php',
+ 'Symfony\\Component\\Console\\Descriptor\\DescriptorInterface' => $vendorDir . '/symfony/console/Descriptor/DescriptorInterface.php',
+ 'Symfony\\Component\\Console\\Descriptor\\JsonDescriptor' => $vendorDir . '/symfony/console/Descriptor/JsonDescriptor.php',
+ 'Symfony\\Component\\Console\\Descriptor\\MarkdownDescriptor' => $vendorDir . '/symfony/console/Descriptor/MarkdownDescriptor.php',
+ 'Symfony\\Component\\Console\\Descriptor\\TextDescriptor' => $vendorDir . '/symfony/console/Descriptor/TextDescriptor.php',
+ 'Symfony\\Component\\Console\\Descriptor\\XmlDescriptor' => $vendorDir . '/symfony/console/Descriptor/XmlDescriptor.php',
+ 'Symfony\\Component\\Console\\EventListener\\ErrorListener' => $vendorDir . '/symfony/console/EventListener/ErrorListener.php',
+ 'Symfony\\Component\\Console\\Event\\ConsoleCommandEvent' => $vendorDir . '/symfony/console/Event/ConsoleCommandEvent.php',
+ 'Symfony\\Component\\Console\\Event\\ConsoleErrorEvent' => $vendorDir . '/symfony/console/Event/ConsoleErrorEvent.php',
+ 'Symfony\\Component\\Console\\Event\\ConsoleEvent' => $vendorDir . '/symfony/console/Event/ConsoleEvent.php',
+ 'Symfony\\Component\\Console\\Event\\ConsoleExceptionEvent' => $vendorDir . '/symfony/console/Event/ConsoleExceptionEvent.php',
+ 'Symfony\\Component\\Console\\Event\\ConsoleTerminateEvent' => $vendorDir . '/symfony/console/Event/ConsoleTerminateEvent.php',
+ 'Symfony\\Component\\Console\\Exception\\CommandNotFoundException' => $vendorDir . '/symfony/console/Exception/CommandNotFoundException.php',
+ 'Symfony\\Component\\Console\\Exception\\ExceptionInterface' => $vendorDir . '/symfony/console/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Console\\Exception\\InvalidArgumentException' => $vendorDir . '/symfony/console/Exception/InvalidArgumentException.php',
+ 'Symfony\\Component\\Console\\Exception\\InvalidOptionException' => $vendorDir . '/symfony/console/Exception/InvalidOptionException.php',
+ 'Symfony\\Component\\Console\\Exception\\LogicException' => $vendorDir . '/symfony/console/Exception/LogicException.php',
+ 'Symfony\\Component\\Console\\Exception\\RuntimeException' => $vendorDir . '/symfony/console/Exception/RuntimeException.php',
+ 'Symfony\\Component\\Console\\Formatter\\OutputFormatter' => $vendorDir . '/symfony/console/Formatter/OutputFormatter.php',
+ 'Symfony\\Component\\Console\\Formatter\\OutputFormatterInterface' => $vendorDir . '/symfony/console/Formatter/OutputFormatterInterface.php',
+ 'Symfony\\Component\\Console\\Formatter\\OutputFormatterStyle' => $vendorDir . '/symfony/console/Formatter/OutputFormatterStyle.php',
+ 'Symfony\\Component\\Console\\Formatter\\OutputFormatterStyleInterface' => $vendorDir . '/symfony/console/Formatter/OutputFormatterStyleInterface.php',
+ 'Symfony\\Component\\Console\\Formatter\\OutputFormatterStyleStack' => $vendorDir . '/symfony/console/Formatter/OutputFormatterStyleStack.php',
+ 'Symfony\\Component\\Console\\Helper\\DebugFormatterHelper' => $vendorDir . '/symfony/console/Helper/DebugFormatterHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\DescriptorHelper' => $vendorDir . '/symfony/console/Helper/DescriptorHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\FormatterHelper' => $vendorDir . '/symfony/console/Helper/FormatterHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\Helper' => $vendorDir . '/symfony/console/Helper/Helper.php',
+ 'Symfony\\Component\\Console\\Helper\\HelperInterface' => $vendorDir . '/symfony/console/Helper/HelperInterface.php',
+ 'Symfony\\Component\\Console\\Helper\\HelperSet' => $vendorDir . '/symfony/console/Helper/HelperSet.php',
+ 'Symfony\\Component\\Console\\Helper\\InputAwareHelper' => $vendorDir . '/symfony/console/Helper/InputAwareHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\ProcessHelper' => $vendorDir . '/symfony/console/Helper/ProcessHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\ProgressBar' => $vendorDir . '/symfony/console/Helper/ProgressBar.php',
+ 'Symfony\\Component\\Console\\Helper\\ProgressIndicator' => $vendorDir . '/symfony/console/Helper/ProgressIndicator.php',
+ 'Symfony\\Component\\Console\\Helper\\QuestionHelper' => $vendorDir . '/symfony/console/Helper/QuestionHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\SymfonyQuestionHelper' => $vendorDir . '/symfony/console/Helper/SymfonyQuestionHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\Table' => $vendorDir . '/symfony/console/Helper/Table.php',
+ 'Symfony\\Component\\Console\\Helper\\TableCell' => $vendorDir . '/symfony/console/Helper/TableCell.php',
+ 'Symfony\\Component\\Console\\Helper\\TableSeparator' => $vendorDir . '/symfony/console/Helper/TableSeparator.php',
+ 'Symfony\\Component\\Console\\Helper\\TableStyle' => $vendorDir . '/symfony/console/Helper/TableStyle.php',
+ 'Symfony\\Component\\Console\\Input\\ArgvInput' => $vendorDir . '/symfony/console/Input/ArgvInput.php',
+ 'Symfony\\Component\\Console\\Input\\ArrayInput' => $vendorDir . '/symfony/console/Input/ArrayInput.php',
+ 'Symfony\\Component\\Console\\Input\\Input' => $vendorDir . '/symfony/console/Input/Input.php',
+ 'Symfony\\Component\\Console\\Input\\InputArgument' => $vendorDir . '/symfony/console/Input/InputArgument.php',
+ 'Symfony\\Component\\Console\\Input\\InputAwareInterface' => $vendorDir . '/symfony/console/Input/InputAwareInterface.php',
+ 'Symfony\\Component\\Console\\Input\\InputDefinition' => $vendorDir . '/symfony/console/Input/InputDefinition.php',
+ 'Symfony\\Component\\Console\\Input\\InputInterface' => $vendorDir . '/symfony/console/Input/InputInterface.php',
+ 'Symfony\\Component\\Console\\Input\\InputOption' => $vendorDir . '/symfony/console/Input/InputOption.php',
+ 'Symfony\\Component\\Console\\Input\\StreamableInputInterface' => $vendorDir . '/symfony/console/Input/StreamableInputInterface.php',
+ 'Symfony\\Component\\Console\\Input\\StringInput' => $vendorDir . '/symfony/console/Input/StringInput.php',
+ 'Symfony\\Component\\Console\\Logger\\ConsoleLogger' => $vendorDir . '/symfony/console/Logger/ConsoleLogger.php',
+ 'Symfony\\Component\\Console\\Output\\BufferedOutput' => $vendorDir . '/symfony/console/Output/BufferedOutput.php',
+ 'Symfony\\Component\\Console\\Output\\ConsoleOutput' => $vendorDir . '/symfony/console/Output/ConsoleOutput.php',
+ 'Symfony\\Component\\Console\\Output\\ConsoleOutputInterface' => $vendorDir . '/symfony/console/Output/ConsoleOutputInterface.php',
+ 'Symfony\\Component\\Console\\Output\\NullOutput' => $vendorDir . '/symfony/console/Output/NullOutput.php',
+ 'Symfony\\Component\\Console\\Output\\Output' => $vendorDir . '/symfony/console/Output/Output.php',
+ 'Symfony\\Component\\Console\\Output\\OutputInterface' => $vendorDir . '/symfony/console/Output/OutputInterface.php',
+ 'Symfony\\Component\\Console\\Output\\StreamOutput' => $vendorDir . '/symfony/console/Output/StreamOutput.php',
+ 'Symfony\\Component\\Console\\Question\\ChoiceQuestion' => $vendorDir . '/symfony/console/Question/ChoiceQuestion.php',
+ 'Symfony\\Component\\Console\\Question\\ConfirmationQuestion' => $vendorDir . '/symfony/console/Question/ConfirmationQuestion.php',
+ 'Symfony\\Component\\Console\\Question\\Question' => $vendorDir . '/symfony/console/Question/Question.php',
+ 'Symfony\\Component\\Console\\Style\\OutputStyle' => $vendorDir . '/symfony/console/Style/OutputStyle.php',
+ 'Symfony\\Component\\Console\\Style\\StyleInterface' => $vendorDir . '/symfony/console/Style/StyleInterface.php',
+ 'Symfony\\Component\\Console\\Style\\SymfonyStyle' => $vendorDir . '/symfony/console/Style/SymfonyStyle.php',
+ 'Symfony\\Component\\Console\\Terminal' => $vendorDir . '/symfony/console/Terminal.php',
+ 'Symfony\\Component\\Console\\Tester\\ApplicationTester' => $vendorDir . '/symfony/console/Tester/ApplicationTester.php',
+ 'Symfony\\Component\\Console\\Tester\\CommandTester' => $vendorDir . '/symfony/console/Tester/CommandTester.php',
+ 'Symfony\\Component\\CssSelector\\CssSelectorConverter' => $vendorDir . '/symfony/css-selector/CssSelectorConverter.php',
+ 'Symfony\\Component\\CssSelector\\Exception\\ExceptionInterface' => $vendorDir . '/symfony/css-selector/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\CssSelector\\Exception\\ExpressionErrorException' => $vendorDir . '/symfony/css-selector/Exception/ExpressionErrorException.php',
+ 'Symfony\\Component\\CssSelector\\Exception\\InternalErrorException' => $vendorDir . '/symfony/css-selector/Exception/InternalErrorException.php',
+ 'Symfony\\Component\\CssSelector\\Exception\\ParseException' => $vendorDir . '/symfony/css-selector/Exception/ParseException.php',
+ 'Symfony\\Component\\CssSelector\\Exception\\SyntaxErrorException' => $vendorDir . '/symfony/css-selector/Exception/SyntaxErrorException.php',
+ 'Symfony\\Component\\CssSelector\\Node\\AbstractNode' => $vendorDir . '/symfony/css-selector/Node/AbstractNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\AttributeNode' => $vendorDir . '/symfony/css-selector/Node/AttributeNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\ClassNode' => $vendorDir . '/symfony/css-selector/Node/ClassNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\CombinedSelectorNode' => $vendorDir . '/symfony/css-selector/Node/CombinedSelectorNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\ElementNode' => $vendorDir . '/symfony/css-selector/Node/ElementNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\FunctionNode' => $vendorDir . '/symfony/css-selector/Node/FunctionNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\HashNode' => $vendorDir . '/symfony/css-selector/Node/HashNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\NegationNode' => $vendorDir . '/symfony/css-selector/Node/NegationNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\NodeInterface' => $vendorDir . '/symfony/css-selector/Node/NodeInterface.php',
+ 'Symfony\\Component\\CssSelector\\Node\\PseudoNode' => $vendorDir . '/symfony/css-selector/Node/PseudoNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\SelectorNode' => $vendorDir . '/symfony/css-selector/Node/SelectorNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\Specificity' => $vendorDir . '/symfony/css-selector/Node/Specificity.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\CommentHandler' => $vendorDir . '/symfony/css-selector/Parser/Handler/CommentHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\HandlerInterface' => $vendorDir . '/symfony/css-selector/Parser/Handler/HandlerInterface.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\HashHandler' => $vendorDir . '/symfony/css-selector/Parser/Handler/HashHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\IdentifierHandler' => $vendorDir . '/symfony/css-selector/Parser/Handler/IdentifierHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\NumberHandler' => $vendorDir . '/symfony/css-selector/Parser/Handler/NumberHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\StringHandler' => $vendorDir . '/symfony/css-selector/Parser/Handler/StringHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\WhitespaceHandler' => $vendorDir . '/symfony/css-selector/Parser/Handler/WhitespaceHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Parser' => $vendorDir . '/symfony/css-selector/Parser/Parser.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\ParserInterface' => $vendorDir . '/symfony/css-selector/Parser/ParserInterface.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Reader' => $vendorDir . '/symfony/css-selector/Parser/Reader.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Shortcut\\ClassParser' => $vendorDir . '/symfony/css-selector/Parser/Shortcut/ClassParser.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Shortcut\\ElementParser' => $vendorDir . '/symfony/css-selector/Parser/Shortcut/ElementParser.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Shortcut\\EmptyStringParser' => $vendorDir . '/symfony/css-selector/Parser/Shortcut/EmptyStringParser.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Shortcut\\HashParser' => $vendorDir . '/symfony/css-selector/Parser/Shortcut/HashParser.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Token' => $vendorDir . '/symfony/css-selector/Parser/Token.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\TokenStream' => $vendorDir . '/symfony/css-selector/Parser/TokenStream.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Tokenizer\\Tokenizer' => $vendorDir . '/symfony/css-selector/Parser/Tokenizer/Tokenizer.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Tokenizer\\TokenizerEscaping' => $vendorDir . '/symfony/css-selector/Parser/Tokenizer/TokenizerEscaping.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Tokenizer\\TokenizerPatterns' => $vendorDir . '/symfony/css-selector/Parser/Tokenizer/TokenizerPatterns.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\AbstractExtension' => $vendorDir . '/symfony/css-selector/XPath/Extension/AbstractExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\AttributeMatchingExtension' => $vendorDir . '/symfony/css-selector/XPath/Extension/AttributeMatchingExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\CombinationExtension' => $vendorDir . '/symfony/css-selector/XPath/Extension/CombinationExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\ExtensionInterface' => $vendorDir . '/symfony/css-selector/XPath/Extension/ExtensionInterface.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\FunctionExtension' => $vendorDir . '/symfony/css-selector/XPath/Extension/FunctionExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\HtmlExtension' => $vendorDir . '/symfony/css-selector/XPath/Extension/HtmlExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\NodeExtension' => $vendorDir . '/symfony/css-selector/XPath/Extension/NodeExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\PseudoClassExtension' => $vendorDir . '/symfony/css-selector/XPath/Extension/PseudoClassExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Translator' => $vendorDir . '/symfony/css-selector/XPath/Translator.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\TranslatorInterface' => $vendorDir . '/symfony/css-selector/XPath/TranslatorInterface.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\XPathExpr' => $vendorDir . '/symfony/css-selector/XPath/XPathExpr.php',
+ 'Symfony\\Component\\Debug\\BufferingLogger' => $vendorDir . '/symfony/debug/BufferingLogger.php',
+ 'Symfony\\Component\\Debug\\Debug' => $vendorDir . '/symfony/debug/Debug.php',
+ 'Symfony\\Component\\Debug\\DebugClassLoader' => $vendorDir . '/symfony/debug/DebugClassLoader.php',
+ 'Symfony\\Component\\Debug\\ErrorHandler' => $vendorDir . '/symfony/debug/ErrorHandler.php',
+ 'Symfony\\Component\\Debug\\ExceptionHandler' => $vendorDir . '/symfony/debug/ExceptionHandler.php',
+ 'Symfony\\Component\\Debug\\Exception\\ClassNotFoundException' => $vendorDir . '/symfony/debug/Exception/ClassNotFoundException.php',
+ 'Symfony\\Component\\Debug\\Exception\\ContextErrorException' => $vendorDir . '/symfony/debug/Exception/ContextErrorException.php',
+ 'Symfony\\Component\\Debug\\Exception\\FatalErrorException' => $vendorDir . '/symfony/debug/Exception/FatalErrorException.php',
+ 'Symfony\\Component\\Debug\\Exception\\FatalThrowableError' => $vendorDir . '/symfony/debug/Exception/FatalThrowableError.php',
+ 'Symfony\\Component\\Debug\\Exception\\FlattenException' => $vendorDir . '/symfony/debug/Exception/FlattenException.php',
+ 'Symfony\\Component\\Debug\\Exception\\OutOfMemoryException' => $vendorDir . '/symfony/debug/Exception/OutOfMemoryException.php',
+ 'Symfony\\Component\\Debug\\Exception\\SilencedErrorContext' => $vendorDir . '/symfony/debug/Exception/SilencedErrorContext.php',
+ 'Symfony\\Component\\Debug\\Exception\\UndefinedFunctionException' => $vendorDir . '/symfony/debug/Exception/UndefinedFunctionException.php',
+ 'Symfony\\Component\\Debug\\Exception\\UndefinedMethodException' => $vendorDir . '/symfony/debug/Exception/UndefinedMethodException.php',
+ 'Symfony\\Component\\Debug\\FatalErrorHandler\\ClassNotFoundFatalErrorHandler' => $vendorDir . '/symfony/debug/FatalErrorHandler/ClassNotFoundFatalErrorHandler.php',
+ 'Symfony\\Component\\Debug\\FatalErrorHandler\\FatalErrorHandlerInterface' => $vendorDir . '/symfony/debug/FatalErrorHandler/FatalErrorHandlerInterface.php',
+ 'Symfony\\Component\\Debug\\FatalErrorHandler\\UndefinedFunctionFatalErrorHandler' => $vendorDir . '/symfony/debug/FatalErrorHandler/UndefinedFunctionFatalErrorHandler.php',
+ 'Symfony\\Component\\Debug\\FatalErrorHandler\\UndefinedMethodFatalErrorHandler' => $vendorDir . '/symfony/debug/FatalErrorHandler/UndefinedMethodFatalErrorHandler.php',
+ 'Symfony\\Component\\EventDispatcher\\ContainerAwareEventDispatcher' => $vendorDir . '/symfony/event-dispatcher/ContainerAwareEventDispatcher.php',
+ 'Symfony\\Component\\EventDispatcher\\Debug\\TraceableEventDispatcher' => $vendorDir . '/symfony/event-dispatcher/Debug/TraceableEventDispatcher.php',
+ 'Symfony\\Component\\EventDispatcher\\Debug\\TraceableEventDispatcherInterface' => $vendorDir . '/symfony/event-dispatcher/Debug/TraceableEventDispatcherInterface.php',
+ 'Symfony\\Component\\EventDispatcher\\Debug\\WrappedListener' => $vendorDir . '/symfony/event-dispatcher/Debug/WrappedListener.php',
+ 'Symfony\\Component\\EventDispatcher\\DependencyInjection\\RegisterListenersPass' => $vendorDir . '/symfony/event-dispatcher/DependencyInjection/RegisterListenersPass.php',
+ 'Symfony\\Component\\EventDispatcher\\Event' => $vendorDir . '/symfony/event-dispatcher/Event.php',
+ 'Symfony\\Component\\EventDispatcher\\EventDispatcher' => $vendorDir . '/symfony/event-dispatcher/EventDispatcher.php',
+ 'Symfony\\Component\\EventDispatcher\\EventDispatcherInterface' => $vendorDir . '/symfony/event-dispatcher/EventDispatcherInterface.php',
+ 'Symfony\\Component\\EventDispatcher\\EventSubscriberInterface' => $vendorDir . '/symfony/event-dispatcher/EventSubscriberInterface.php',
+ 'Symfony\\Component\\EventDispatcher\\GenericEvent' => $vendorDir . '/symfony/event-dispatcher/GenericEvent.php',
+ 'Symfony\\Component\\EventDispatcher\\ImmutableEventDispatcher' => $vendorDir . '/symfony/event-dispatcher/ImmutableEventDispatcher.php',
+ 'Symfony\\Component\\Finder\\Comparator\\Comparator' => $vendorDir . '/symfony/finder/Comparator/Comparator.php',
+ 'Symfony\\Component\\Finder\\Comparator\\DateComparator' => $vendorDir . '/symfony/finder/Comparator/DateComparator.php',
+ 'Symfony\\Component\\Finder\\Comparator\\NumberComparator' => $vendorDir . '/symfony/finder/Comparator/NumberComparator.php',
+ 'Symfony\\Component\\Finder\\Exception\\AccessDeniedException' => $vendorDir . '/symfony/finder/Exception/AccessDeniedException.php',
+ 'Symfony\\Component\\Finder\\Exception\\ExceptionInterface' => $vendorDir . '/symfony/finder/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Finder\\Finder' => $vendorDir . '/symfony/finder/Finder.php',
+ 'Symfony\\Component\\Finder\\Glob' => $vendorDir . '/symfony/finder/Glob.php',
+ 'Symfony\\Component\\Finder\\Iterator\\CustomFilterIterator' => $vendorDir . '/symfony/finder/Iterator/CustomFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\DateRangeFilterIterator' => $vendorDir . '/symfony/finder/Iterator/DateRangeFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\DepthRangeFilterIterator' => $vendorDir . '/symfony/finder/Iterator/DepthRangeFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\ExcludeDirectoryFilterIterator' => $vendorDir . '/symfony/finder/Iterator/ExcludeDirectoryFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\FileTypeFilterIterator' => $vendorDir . '/symfony/finder/Iterator/FileTypeFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\FilecontentFilterIterator' => $vendorDir . '/symfony/finder/Iterator/FilecontentFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\FilenameFilterIterator' => $vendorDir . '/symfony/finder/Iterator/FilenameFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\FilterIterator' => $vendorDir . '/symfony/finder/Iterator/FilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\MultiplePcreFilterIterator' => $vendorDir . '/symfony/finder/Iterator/MultiplePcreFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\PathFilterIterator' => $vendorDir . '/symfony/finder/Iterator/PathFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\RecursiveDirectoryIterator' => $vendorDir . '/symfony/finder/Iterator/RecursiveDirectoryIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\SizeRangeFilterIterator' => $vendorDir . '/symfony/finder/Iterator/SizeRangeFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\SortableIterator' => $vendorDir . '/symfony/finder/Iterator/SortableIterator.php',
+ 'Symfony\\Component\\Finder\\SplFileInfo' => $vendorDir . '/symfony/finder/SplFileInfo.php',
+ 'Symfony\\Component\\HttpFoundation\\AcceptHeader' => $vendorDir . '/symfony/http-foundation/AcceptHeader.php',
+ 'Symfony\\Component\\HttpFoundation\\AcceptHeaderItem' => $vendorDir . '/symfony/http-foundation/AcceptHeaderItem.php',
+ 'Symfony\\Component\\HttpFoundation\\ApacheRequest' => $vendorDir . '/symfony/http-foundation/ApacheRequest.php',
+ 'Symfony\\Component\\HttpFoundation\\BinaryFileResponse' => $vendorDir . '/symfony/http-foundation/BinaryFileResponse.php',
+ 'Symfony\\Component\\HttpFoundation\\Cookie' => $vendorDir . '/symfony/http-foundation/Cookie.php',
+ 'Symfony\\Component\\HttpFoundation\\Exception\\ConflictingHeadersException' => $vendorDir . '/symfony/http-foundation/Exception/ConflictingHeadersException.php',
+ 'Symfony\\Component\\HttpFoundation\\Exception\\RequestExceptionInterface' => $vendorDir . '/symfony/http-foundation/Exception/RequestExceptionInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\Exception\\SuspiciousOperationException' => $vendorDir . '/symfony/http-foundation/Exception/SuspiciousOperationException.php',
+ 'Symfony\\Component\\HttpFoundation\\ExpressionRequestMatcher' => $vendorDir . '/symfony/http-foundation/ExpressionRequestMatcher.php',
+ 'Symfony\\Component\\HttpFoundation\\FileBag' => $vendorDir . '/symfony/http-foundation/FileBag.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Exception\\AccessDeniedException' => $vendorDir . '/symfony/http-foundation/File/Exception/AccessDeniedException.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Exception\\FileException' => $vendorDir . '/symfony/http-foundation/File/Exception/FileException.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Exception\\FileNotFoundException' => $vendorDir . '/symfony/http-foundation/File/Exception/FileNotFoundException.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Exception\\UnexpectedTypeException' => $vendorDir . '/symfony/http-foundation/File/Exception/UnexpectedTypeException.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Exception\\UploadException' => $vendorDir . '/symfony/http-foundation/File/Exception/UploadException.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\File' => $vendorDir . '/symfony/http-foundation/File/File.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\ExtensionGuesser' => $vendorDir . '/symfony/http-foundation/File/MimeType/ExtensionGuesser.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\ExtensionGuesserInterface' => $vendorDir . '/symfony/http-foundation/File/MimeType/ExtensionGuesserInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\FileBinaryMimeTypeGuesser' => $vendorDir . '/symfony/http-foundation/File/MimeType/FileBinaryMimeTypeGuesser.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\FileinfoMimeTypeGuesser' => $vendorDir . '/symfony/http-foundation/File/MimeType/FileinfoMimeTypeGuesser.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\MimeTypeExtensionGuesser' => $vendorDir . '/symfony/http-foundation/File/MimeType/MimeTypeExtensionGuesser.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\MimeTypeGuesser' => $vendorDir . '/symfony/http-foundation/File/MimeType/MimeTypeGuesser.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\MimeTypeGuesserInterface' => $vendorDir . '/symfony/http-foundation/File/MimeType/MimeTypeGuesserInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Stream' => $vendorDir . '/symfony/http-foundation/File/Stream.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\UploadedFile' => $vendorDir . '/symfony/http-foundation/File/UploadedFile.php',
+ 'Symfony\\Component\\HttpFoundation\\HeaderBag' => $vendorDir . '/symfony/http-foundation/HeaderBag.php',
+ 'Symfony\\Component\\HttpFoundation\\IpUtils' => $vendorDir . '/symfony/http-foundation/IpUtils.php',
+ 'Symfony\\Component\\HttpFoundation\\JsonResponse' => $vendorDir . '/symfony/http-foundation/JsonResponse.php',
+ 'Symfony\\Component\\HttpFoundation\\ParameterBag' => $vendorDir . '/symfony/http-foundation/ParameterBag.php',
+ 'Symfony\\Component\\HttpFoundation\\RedirectResponse' => $vendorDir . '/symfony/http-foundation/RedirectResponse.php',
+ 'Symfony\\Component\\HttpFoundation\\Request' => $vendorDir . '/symfony/http-foundation/Request.php',
+ 'Symfony\\Component\\HttpFoundation\\RequestMatcher' => $vendorDir . '/symfony/http-foundation/RequestMatcher.php',
+ 'Symfony\\Component\\HttpFoundation\\RequestMatcherInterface' => $vendorDir . '/symfony/http-foundation/RequestMatcherInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\RequestStack' => $vendorDir . '/symfony/http-foundation/RequestStack.php',
+ 'Symfony\\Component\\HttpFoundation\\Response' => $vendorDir . '/symfony/http-foundation/Response.php',
+ 'Symfony\\Component\\HttpFoundation\\ResponseHeaderBag' => $vendorDir . '/symfony/http-foundation/ResponseHeaderBag.php',
+ 'Symfony\\Component\\HttpFoundation\\ServerBag' => $vendorDir . '/symfony/http-foundation/ServerBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Attribute\\AttributeBag' => $vendorDir . '/symfony/http-foundation/Session/Attribute/AttributeBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Attribute\\AttributeBagInterface' => $vendorDir . '/symfony/http-foundation/Session/Attribute/AttributeBagInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Attribute\\NamespacedAttributeBag' => $vendorDir . '/symfony/http-foundation/Session/Attribute/NamespacedAttributeBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Flash\\AutoExpireFlashBag' => $vendorDir . '/symfony/http-foundation/Session/Flash/AutoExpireFlashBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Flash\\FlashBag' => $vendorDir . '/symfony/http-foundation/Session/Flash/FlashBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Flash\\FlashBagInterface' => $vendorDir . '/symfony/http-foundation/Session/Flash/FlashBagInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Session' => $vendorDir . '/symfony/http-foundation/Session/Session.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\SessionBagInterface' => $vendorDir . '/symfony/http-foundation/Session/SessionBagInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\SessionBagProxy' => $vendorDir . '/symfony/http-foundation/Session/SessionBagProxy.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\SessionInterface' => $vendorDir . '/symfony/http-foundation/Session/SessionInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\SessionUtils' => $vendorDir . '/symfony/http-foundation/Session/SessionUtils.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\AbstractSessionHandler' => $vendorDir . '/symfony/http-foundation/Session/Storage/Handler/AbstractSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\MemcacheSessionHandler' => $vendorDir . '/symfony/http-foundation/Session/Storage/Handler/MemcacheSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\MemcachedSessionHandler' => $vendorDir . '/symfony/http-foundation/Session/Storage/Handler/MemcachedSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\MongoDbSessionHandler' => $vendorDir . '/symfony/http-foundation/Session/Storage/Handler/MongoDbSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\NativeFileSessionHandler' => $vendorDir . '/symfony/http-foundation/Session/Storage/Handler/NativeFileSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\NativeSessionHandler' => $vendorDir . '/symfony/http-foundation/Session/Storage/Handler/NativeSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\NullSessionHandler' => $vendorDir . '/symfony/http-foundation/Session/Storage/Handler/NullSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\PdoSessionHandler' => $vendorDir . '/symfony/http-foundation/Session/Storage/Handler/PdoSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\StrictSessionHandler' => $vendorDir . '/symfony/http-foundation/Session/Storage/Handler/StrictSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\WriteCheckSessionHandler' => $vendorDir . '/symfony/http-foundation/Session/Storage/Handler/WriteCheckSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\MetadataBag' => $vendorDir . '/symfony/http-foundation/Session/Storage/MetadataBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\MockArraySessionStorage' => $vendorDir . '/symfony/http-foundation/Session/Storage/MockArraySessionStorage.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\MockFileSessionStorage' => $vendorDir . '/symfony/http-foundation/Session/Storage/MockFileSessionStorage.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\NativeSessionStorage' => $vendorDir . '/symfony/http-foundation/Session/Storage/NativeSessionStorage.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\PhpBridgeSessionStorage' => $vendorDir . '/symfony/http-foundation/Session/Storage/PhpBridgeSessionStorage.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Proxy\\AbstractProxy' => $vendorDir . '/symfony/http-foundation/Session/Storage/Proxy/AbstractProxy.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Proxy\\NativeProxy' => $vendorDir . '/symfony/http-foundation/Session/Storage/Proxy/NativeProxy.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Proxy\\SessionHandlerProxy' => $vendorDir . '/symfony/http-foundation/Session/Storage/Proxy/SessionHandlerProxy.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\SessionStorageInterface' => $vendorDir . '/symfony/http-foundation/Session/Storage/SessionStorageInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\StreamedResponse' => $vendorDir . '/symfony/http-foundation/StreamedResponse.php',
+ 'Symfony\\Component\\HttpKernel\\Bundle\\Bundle' => $vendorDir . '/symfony/http-kernel/Bundle/Bundle.php',
+ 'Symfony\\Component\\HttpKernel\\Bundle\\BundleInterface' => $vendorDir . '/symfony/http-kernel/Bundle/BundleInterface.php',
+ 'Symfony\\Component\\HttpKernel\\CacheClearer\\CacheClearerInterface' => $vendorDir . '/symfony/http-kernel/CacheClearer/CacheClearerInterface.php',
+ 'Symfony\\Component\\HttpKernel\\CacheClearer\\ChainCacheClearer' => $vendorDir . '/symfony/http-kernel/CacheClearer/ChainCacheClearer.php',
+ 'Symfony\\Component\\HttpKernel\\CacheClearer\\Psr6CacheClearer' => $vendorDir . '/symfony/http-kernel/CacheClearer/Psr6CacheClearer.php',
+ 'Symfony\\Component\\HttpKernel\\CacheWarmer\\CacheWarmer' => $vendorDir . '/symfony/http-kernel/CacheWarmer/CacheWarmer.php',
+ 'Symfony\\Component\\HttpKernel\\CacheWarmer\\CacheWarmerAggregate' => $vendorDir . '/symfony/http-kernel/CacheWarmer/CacheWarmerAggregate.php',
+ 'Symfony\\Component\\HttpKernel\\CacheWarmer\\CacheWarmerInterface' => $vendorDir . '/symfony/http-kernel/CacheWarmer/CacheWarmerInterface.php',
+ 'Symfony\\Component\\HttpKernel\\CacheWarmer\\WarmableInterface' => $vendorDir . '/symfony/http-kernel/CacheWarmer/WarmableInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Client' => $vendorDir . '/symfony/http-kernel/Client.php',
+ 'Symfony\\Component\\HttpKernel\\Config\\EnvParametersResource' => $vendorDir . '/symfony/http-kernel/Config/EnvParametersResource.php',
+ 'Symfony\\Component\\HttpKernel\\Config\\FileLocator' => $vendorDir . '/symfony/http-kernel/Config/FileLocator.php',
+ 'Symfony\\Component\\HttpKernel\\ControllerMetadata\\ArgumentMetadata' => $vendorDir . '/symfony/http-kernel/ControllerMetadata/ArgumentMetadata.php',
+ 'Symfony\\Component\\HttpKernel\\ControllerMetadata\\ArgumentMetadataFactory' => $vendorDir . '/symfony/http-kernel/ControllerMetadata/ArgumentMetadataFactory.php',
+ 'Symfony\\Component\\HttpKernel\\ControllerMetadata\\ArgumentMetadataFactoryInterface' => $vendorDir . '/symfony/http-kernel/ControllerMetadata/ArgumentMetadataFactoryInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver' => $vendorDir . '/symfony/http-kernel/Controller/ArgumentResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolverInterface' => $vendorDir . '/symfony/http-kernel/Controller/ArgumentResolverInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\DefaultValueResolver' => $vendorDir . '/symfony/http-kernel/Controller/ArgumentResolver/DefaultValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\RequestAttributeValueResolver' => $vendorDir . '/symfony/http-kernel/Controller/ArgumentResolver/RequestAttributeValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\RequestValueResolver' => $vendorDir . '/symfony/http-kernel/Controller/ArgumentResolver/RequestValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\ServiceValueResolver' => $vendorDir . '/symfony/http-kernel/Controller/ArgumentResolver/ServiceValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\SessionValueResolver' => $vendorDir . '/symfony/http-kernel/Controller/ArgumentResolver/SessionValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\VariadicValueResolver' => $vendorDir . '/symfony/http-kernel/Controller/ArgumentResolver/VariadicValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentValueResolverInterface' => $vendorDir . '/symfony/http-kernel/Controller/ArgumentValueResolverInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ContainerControllerResolver' => $vendorDir . '/symfony/http-kernel/Controller/ContainerControllerResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ControllerReference' => $vendorDir . '/symfony/http-kernel/Controller/ControllerReference.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ControllerResolver' => $vendorDir . '/symfony/http-kernel/Controller/ControllerResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ControllerResolverInterface' => $vendorDir . '/symfony/http-kernel/Controller/ControllerResolverInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\TraceableArgumentResolver' => $vendorDir . '/symfony/http-kernel/Controller/TraceableArgumentResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\TraceableControllerResolver' => $vendorDir . '/symfony/http-kernel/Controller/TraceableControllerResolver.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\AjaxDataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/AjaxDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\ConfigDataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/ConfigDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\DataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/DataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\DataCollectorInterface' => $vendorDir . '/symfony/http-kernel/DataCollector/DataCollectorInterface.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\DumpDataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/DumpDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\EventDataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/EventDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\ExceptionDataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/ExceptionDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\LateDataCollectorInterface' => $vendorDir . '/symfony/http-kernel/DataCollector/LateDataCollectorInterface.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\LoggerDataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/LoggerDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\MemoryDataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/MemoryDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\RequestDataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/RequestDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\RouterDataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/RouterDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\TimeDataCollector' => $vendorDir . '/symfony/http-kernel/DataCollector/TimeDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\Util\\ValueExporter' => $vendorDir . '/symfony/http-kernel/DataCollector/Util/ValueExporter.php',
+ 'Symfony\\Component\\HttpKernel\\Debug\\FileLinkFormatter' => $vendorDir . '/symfony/http-kernel/Debug/FileLinkFormatter.php',
+ 'Symfony\\Component\\HttpKernel\\Debug\\TraceableEventDispatcher' => $vendorDir . '/symfony/http-kernel/Debug/TraceableEventDispatcher.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\AddAnnotatedClassesToCachePass' => $vendorDir . '/symfony/http-kernel/DependencyInjection/AddAnnotatedClassesToCachePass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\AddClassesToCachePass' => $vendorDir . '/symfony/http-kernel/DependencyInjection/AddClassesToCachePass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\ConfigurableExtension' => $vendorDir . '/symfony/http-kernel/DependencyInjection/ConfigurableExtension.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\ControllerArgumentValueResolverPass' => $vendorDir . '/symfony/http-kernel/DependencyInjection/ControllerArgumentValueResolverPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\Extension' => $vendorDir . '/symfony/http-kernel/DependencyInjection/Extension.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\FragmentRendererPass' => $vendorDir . '/symfony/http-kernel/DependencyInjection/FragmentRendererPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\LazyLoadingFragmentHandler' => $vendorDir . '/symfony/http-kernel/DependencyInjection/LazyLoadingFragmentHandler.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\LoggerPass' => $vendorDir . '/symfony/http-kernel/DependencyInjection/LoggerPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\MergeExtensionConfigurationPass' => $vendorDir . '/symfony/http-kernel/DependencyInjection/MergeExtensionConfigurationPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\RegisterControllerArgumentLocatorsPass' => $vendorDir . '/symfony/http-kernel/DependencyInjection/RegisterControllerArgumentLocatorsPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\RemoveEmptyControllerArgumentLocatorsPass' => $vendorDir . '/symfony/http-kernel/DependencyInjection/RemoveEmptyControllerArgumentLocatorsPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\ResettableServicePass' => $vendorDir . '/symfony/http-kernel/DependencyInjection/ResettableServicePass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\ServicesResetter' => $vendorDir . '/symfony/http-kernel/DependencyInjection/ServicesResetter.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\AbstractSessionListener' => $vendorDir . '/symfony/http-kernel/EventListener/AbstractSessionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\AbstractTestSessionListener' => $vendorDir . '/symfony/http-kernel/EventListener/AbstractTestSessionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\AddRequestFormatsListener' => $vendorDir . '/symfony/http-kernel/EventListener/AddRequestFormatsListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\DebugHandlersListener' => $vendorDir . '/symfony/http-kernel/EventListener/DebugHandlersListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\DumpListener' => $vendorDir . '/symfony/http-kernel/EventListener/DumpListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\ExceptionListener' => $vendorDir . '/symfony/http-kernel/EventListener/ExceptionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\FragmentListener' => $vendorDir . '/symfony/http-kernel/EventListener/FragmentListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\LocaleListener' => $vendorDir . '/symfony/http-kernel/EventListener/LocaleListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\ProfilerListener' => $vendorDir . '/symfony/http-kernel/EventListener/ProfilerListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\ResponseListener' => $vendorDir . '/symfony/http-kernel/EventListener/ResponseListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\RouterListener' => $vendorDir . '/symfony/http-kernel/EventListener/RouterListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\SaveSessionListener' => $vendorDir . '/symfony/http-kernel/EventListener/SaveSessionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\SessionListener' => $vendorDir . '/symfony/http-kernel/EventListener/SessionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\StreamedResponseListener' => $vendorDir . '/symfony/http-kernel/EventListener/StreamedResponseListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\SurrogateListener' => $vendorDir . '/symfony/http-kernel/EventListener/SurrogateListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\TestSessionListener' => $vendorDir . '/symfony/http-kernel/EventListener/TestSessionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\TranslatorListener' => $vendorDir . '/symfony/http-kernel/EventListener/TranslatorListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\ValidateRequestListener' => $vendorDir . '/symfony/http-kernel/EventListener/ValidateRequestListener.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\FilterControllerArgumentsEvent' => $vendorDir . '/symfony/http-kernel/Event/FilterControllerArgumentsEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\FilterControllerEvent' => $vendorDir . '/symfony/http-kernel/Event/FilterControllerEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\FilterResponseEvent' => $vendorDir . '/symfony/http-kernel/Event/FilterResponseEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\FinishRequestEvent' => $vendorDir . '/symfony/http-kernel/Event/FinishRequestEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\GetResponseEvent' => $vendorDir . '/symfony/http-kernel/Event/GetResponseEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\GetResponseForControllerResultEvent' => $vendorDir . '/symfony/http-kernel/Event/GetResponseForControllerResultEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\GetResponseForExceptionEvent' => $vendorDir . '/symfony/http-kernel/Event/GetResponseForExceptionEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\KernelEvent' => $vendorDir . '/symfony/http-kernel/Event/KernelEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\PostResponseEvent' => $vendorDir . '/symfony/http-kernel/Event/PostResponseEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\AccessDeniedHttpException' => $vendorDir . '/symfony/http-kernel/Exception/AccessDeniedHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\BadRequestHttpException' => $vendorDir . '/symfony/http-kernel/Exception/BadRequestHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\ConflictHttpException' => $vendorDir . '/symfony/http-kernel/Exception/ConflictHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\GoneHttpException' => $vendorDir . '/symfony/http-kernel/Exception/GoneHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\HttpException' => $vendorDir . '/symfony/http-kernel/Exception/HttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\HttpExceptionInterface' => $vendorDir . '/symfony/http-kernel/Exception/HttpExceptionInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\LengthRequiredHttpException' => $vendorDir . '/symfony/http-kernel/Exception/LengthRequiredHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\MethodNotAllowedHttpException' => $vendorDir . '/symfony/http-kernel/Exception/MethodNotAllowedHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\NotAcceptableHttpException' => $vendorDir . '/symfony/http-kernel/Exception/NotAcceptableHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\NotFoundHttpException' => $vendorDir . '/symfony/http-kernel/Exception/NotFoundHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\PreconditionFailedHttpException' => $vendorDir . '/symfony/http-kernel/Exception/PreconditionFailedHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\PreconditionRequiredHttpException' => $vendorDir . '/symfony/http-kernel/Exception/PreconditionRequiredHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\ServiceUnavailableHttpException' => $vendorDir . '/symfony/http-kernel/Exception/ServiceUnavailableHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\TooManyRequestsHttpException' => $vendorDir . '/symfony/http-kernel/Exception/TooManyRequestsHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\UnauthorizedHttpException' => $vendorDir . '/symfony/http-kernel/Exception/UnauthorizedHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\UnprocessableEntityHttpException' => $vendorDir . '/symfony/http-kernel/Exception/UnprocessableEntityHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\UnsupportedMediaTypeHttpException' => $vendorDir . '/symfony/http-kernel/Exception/UnsupportedMediaTypeHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\AbstractSurrogateFragmentRenderer' => $vendorDir . '/symfony/http-kernel/Fragment/AbstractSurrogateFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\EsiFragmentRenderer' => $vendorDir . '/symfony/http-kernel/Fragment/EsiFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\FragmentHandler' => $vendorDir . '/symfony/http-kernel/Fragment/FragmentHandler.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\FragmentRendererInterface' => $vendorDir . '/symfony/http-kernel/Fragment/FragmentRendererInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\HIncludeFragmentRenderer' => $vendorDir . '/symfony/http-kernel/Fragment/HIncludeFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\InlineFragmentRenderer' => $vendorDir . '/symfony/http-kernel/Fragment/InlineFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\RoutableFragmentRenderer' => $vendorDir . '/symfony/http-kernel/Fragment/RoutableFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\SsiFragmentRenderer' => $vendorDir . '/symfony/http-kernel/Fragment/SsiFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\AbstractSurrogate' => $vendorDir . '/symfony/http-kernel/HttpCache/AbstractSurrogate.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\Esi' => $vendorDir . '/symfony/http-kernel/HttpCache/Esi.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\HttpCache' => $vendorDir . '/symfony/http-kernel/HttpCache/HttpCache.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\ResponseCacheStrategy' => $vendorDir . '/symfony/http-kernel/HttpCache/ResponseCacheStrategy.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\ResponseCacheStrategyInterface' => $vendorDir . '/symfony/http-kernel/HttpCache/ResponseCacheStrategyInterface.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\Ssi' => $vendorDir . '/symfony/http-kernel/HttpCache/Ssi.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\Store' => $vendorDir . '/symfony/http-kernel/HttpCache/Store.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\StoreInterface' => $vendorDir . '/symfony/http-kernel/HttpCache/StoreInterface.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\SubRequestHandler' => $vendorDir . '/symfony/http-kernel/HttpCache/SubRequestHandler.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\SurrogateInterface' => $vendorDir . '/symfony/http-kernel/HttpCache/SurrogateInterface.php',
+ 'Symfony\\Component\\HttpKernel\\HttpKernel' => $vendorDir . '/symfony/http-kernel/HttpKernel.php',
+ 'Symfony\\Component\\HttpKernel\\HttpKernelInterface' => $vendorDir . '/symfony/http-kernel/HttpKernelInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Kernel' => $vendorDir . '/symfony/http-kernel/Kernel.php',
+ 'Symfony\\Component\\HttpKernel\\KernelEvents' => $vendorDir . '/symfony/http-kernel/KernelEvents.php',
+ 'Symfony\\Component\\HttpKernel\\KernelInterface' => $vendorDir . '/symfony/http-kernel/KernelInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Log\\DebugLoggerInterface' => $vendorDir . '/symfony/http-kernel/Log/DebugLoggerInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Log\\Logger' => $vendorDir . '/symfony/http-kernel/Log/Logger.php',
+ 'Symfony\\Component\\HttpKernel\\Profiler\\FileProfilerStorage' => $vendorDir . '/symfony/http-kernel/Profiler/FileProfilerStorage.php',
+ 'Symfony\\Component\\HttpKernel\\Profiler\\Profile' => $vendorDir . '/symfony/http-kernel/Profiler/Profile.php',
+ 'Symfony\\Component\\HttpKernel\\Profiler\\Profiler' => $vendorDir . '/symfony/http-kernel/Profiler/Profiler.php',
+ 'Symfony\\Component\\HttpKernel\\Profiler\\ProfilerStorageInterface' => $vendorDir . '/symfony/http-kernel/Profiler/ProfilerStorageInterface.php',
+ 'Symfony\\Component\\HttpKernel\\RebootableInterface' => $vendorDir . '/symfony/http-kernel/RebootableInterface.php',
+ 'Symfony\\Component\\HttpKernel\\TerminableInterface' => $vendorDir . '/symfony/http-kernel/TerminableInterface.php',
+ 'Symfony\\Component\\HttpKernel\\UriSigner' => $vendorDir . '/symfony/http-kernel/UriSigner.php',
+ 'Symfony\\Component\\Process\\Exception\\ExceptionInterface' => $vendorDir . '/symfony/process/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Process\\Exception\\InvalidArgumentException' => $vendorDir . '/symfony/process/Exception/InvalidArgumentException.php',
+ 'Symfony\\Component\\Process\\Exception\\LogicException' => $vendorDir . '/symfony/process/Exception/LogicException.php',
+ 'Symfony\\Component\\Process\\Exception\\ProcessFailedException' => $vendorDir . '/symfony/process/Exception/ProcessFailedException.php',
+ 'Symfony\\Component\\Process\\Exception\\ProcessTimedOutException' => $vendorDir . '/symfony/process/Exception/ProcessTimedOutException.php',
+ 'Symfony\\Component\\Process\\Exception\\RuntimeException' => $vendorDir . '/symfony/process/Exception/RuntimeException.php',
+ 'Symfony\\Component\\Process\\ExecutableFinder' => $vendorDir . '/symfony/process/ExecutableFinder.php',
+ 'Symfony\\Component\\Process\\InputStream' => $vendorDir . '/symfony/process/InputStream.php',
+ 'Symfony\\Component\\Process\\PhpExecutableFinder' => $vendorDir . '/symfony/process/PhpExecutableFinder.php',
+ 'Symfony\\Component\\Process\\PhpProcess' => $vendorDir . '/symfony/process/PhpProcess.php',
+ 'Symfony\\Component\\Process\\Pipes\\AbstractPipes' => $vendorDir . '/symfony/process/Pipes/AbstractPipes.php',
+ 'Symfony\\Component\\Process\\Pipes\\PipesInterface' => $vendorDir . '/symfony/process/Pipes/PipesInterface.php',
+ 'Symfony\\Component\\Process\\Pipes\\UnixPipes' => $vendorDir . '/symfony/process/Pipes/UnixPipes.php',
+ 'Symfony\\Component\\Process\\Pipes\\WindowsPipes' => $vendorDir . '/symfony/process/Pipes/WindowsPipes.php',
+ 'Symfony\\Component\\Process\\Process' => $vendorDir . '/symfony/process/Process.php',
+ 'Symfony\\Component\\Process\\ProcessBuilder' => $vendorDir . '/symfony/process/ProcessBuilder.php',
+ 'Symfony\\Component\\Process\\ProcessUtils' => $vendorDir . '/symfony/process/ProcessUtils.php',
+ 'Symfony\\Component\\Routing\\Annotation\\Route' => $vendorDir . '/symfony/routing/Annotation/Route.php',
+ 'Symfony\\Component\\Routing\\CompiledRoute' => $vendorDir . '/symfony/routing/CompiledRoute.php',
+ 'Symfony\\Component\\Routing\\DependencyInjection\\RoutingResolverPass' => $vendorDir . '/symfony/routing/DependencyInjection/RoutingResolverPass.php',
+ 'Symfony\\Component\\Routing\\Exception\\ExceptionInterface' => $vendorDir . '/symfony/routing/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Routing\\Exception\\InvalidParameterException' => $vendorDir . '/symfony/routing/Exception/InvalidParameterException.php',
+ 'Symfony\\Component\\Routing\\Exception\\MethodNotAllowedException' => $vendorDir . '/symfony/routing/Exception/MethodNotAllowedException.php',
+ 'Symfony\\Component\\Routing\\Exception\\MissingMandatoryParametersException' => $vendorDir . '/symfony/routing/Exception/MissingMandatoryParametersException.php',
+ 'Symfony\\Component\\Routing\\Exception\\NoConfigurationException' => $vendorDir . '/symfony/routing/Exception/NoConfigurationException.php',
+ 'Symfony\\Component\\Routing\\Exception\\ResourceNotFoundException' => $vendorDir . '/symfony/routing/Exception/ResourceNotFoundException.php',
+ 'Symfony\\Component\\Routing\\Exception\\RouteNotFoundException' => $vendorDir . '/symfony/routing/Exception/RouteNotFoundException.php',
+ 'Symfony\\Component\\Routing\\Generator\\ConfigurableRequirementsInterface' => $vendorDir . '/symfony/routing/Generator/ConfigurableRequirementsInterface.php',
+ 'Symfony\\Component\\Routing\\Generator\\Dumper\\GeneratorDumper' => $vendorDir . '/symfony/routing/Generator/Dumper/GeneratorDumper.php',
+ 'Symfony\\Component\\Routing\\Generator\\Dumper\\GeneratorDumperInterface' => $vendorDir . '/symfony/routing/Generator/Dumper/GeneratorDumperInterface.php',
+ 'Symfony\\Component\\Routing\\Generator\\Dumper\\PhpGeneratorDumper' => $vendorDir . '/symfony/routing/Generator/Dumper/PhpGeneratorDumper.php',
+ 'Symfony\\Component\\Routing\\Generator\\UrlGenerator' => $vendorDir . '/symfony/routing/Generator/UrlGenerator.php',
+ 'Symfony\\Component\\Routing\\Generator\\UrlGeneratorInterface' => $vendorDir . '/symfony/routing/Generator/UrlGeneratorInterface.php',
+ 'Symfony\\Component\\Routing\\Loader\\AnnotationClassLoader' => $vendorDir . '/symfony/routing/Loader/AnnotationClassLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\AnnotationDirectoryLoader' => $vendorDir . '/symfony/routing/Loader/AnnotationDirectoryLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\AnnotationFileLoader' => $vendorDir . '/symfony/routing/Loader/AnnotationFileLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\ClosureLoader' => $vendorDir . '/symfony/routing/Loader/ClosureLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\CollectionConfigurator' => $vendorDir . '/symfony/routing/Loader/Configurator/CollectionConfigurator.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\ImportConfigurator' => $vendorDir . '/symfony/routing/Loader/Configurator/ImportConfigurator.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\RouteConfigurator' => $vendorDir . '/symfony/routing/Loader/Configurator/RouteConfigurator.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\RoutingConfigurator' => $vendorDir . '/symfony/routing/Loader/Configurator/RoutingConfigurator.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\Traits\\AddTrait' => $vendorDir . '/symfony/routing/Loader/Configurator/Traits/AddTrait.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\Traits\\RouteTrait' => $vendorDir . '/symfony/routing/Loader/Configurator/Traits/RouteTrait.php',
+ 'Symfony\\Component\\Routing\\Loader\\DependencyInjection\\ServiceRouterLoader' => $vendorDir . '/symfony/routing/Loader/DependencyInjection/ServiceRouterLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\DirectoryLoader' => $vendorDir . '/symfony/routing/Loader/DirectoryLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\GlobFileLoader' => $vendorDir . '/symfony/routing/Loader/GlobFileLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\ObjectRouteLoader' => $vendorDir . '/symfony/routing/Loader/ObjectRouteLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\PhpFileLoader' => $vendorDir . '/symfony/routing/Loader/PhpFileLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\XmlFileLoader' => $vendorDir . '/symfony/routing/Loader/XmlFileLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\YamlFileLoader' => $vendorDir . '/symfony/routing/Loader/YamlFileLoader.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\DumperCollection' => $vendorDir . '/symfony/routing/Matcher/Dumper/DumperCollection.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\DumperRoute' => $vendorDir . '/symfony/routing/Matcher/Dumper/DumperRoute.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\MatcherDumper' => $vendorDir . '/symfony/routing/Matcher/Dumper/MatcherDumper.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\MatcherDumperInterface' => $vendorDir . '/symfony/routing/Matcher/Dumper/MatcherDumperInterface.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\PhpMatcherDumper' => $vendorDir . '/symfony/routing/Matcher/Dumper/PhpMatcherDumper.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\StaticPrefixCollection' => $vendorDir . '/symfony/routing/Matcher/Dumper/StaticPrefixCollection.php',
+ 'Symfony\\Component\\Routing\\Matcher\\RedirectableUrlMatcher' => $vendorDir . '/symfony/routing/Matcher/RedirectableUrlMatcher.php',
+ 'Symfony\\Component\\Routing\\Matcher\\RedirectableUrlMatcherInterface' => $vendorDir . '/symfony/routing/Matcher/RedirectableUrlMatcherInterface.php',
+ 'Symfony\\Component\\Routing\\Matcher\\RequestMatcherInterface' => $vendorDir . '/symfony/routing/Matcher/RequestMatcherInterface.php',
+ 'Symfony\\Component\\Routing\\Matcher\\TraceableUrlMatcher' => $vendorDir . '/symfony/routing/Matcher/TraceableUrlMatcher.php',
+ 'Symfony\\Component\\Routing\\Matcher\\UrlMatcher' => $vendorDir . '/symfony/routing/Matcher/UrlMatcher.php',
+ 'Symfony\\Component\\Routing\\Matcher\\UrlMatcherInterface' => $vendorDir . '/symfony/routing/Matcher/UrlMatcherInterface.php',
+ 'Symfony\\Component\\Routing\\RequestContext' => $vendorDir . '/symfony/routing/RequestContext.php',
+ 'Symfony\\Component\\Routing\\RequestContextAwareInterface' => $vendorDir . '/symfony/routing/RequestContextAwareInterface.php',
+ 'Symfony\\Component\\Routing\\Route' => $vendorDir . '/symfony/routing/Route.php',
+ 'Symfony\\Component\\Routing\\RouteCollection' => $vendorDir . '/symfony/routing/RouteCollection.php',
+ 'Symfony\\Component\\Routing\\RouteCollectionBuilder' => $vendorDir . '/symfony/routing/RouteCollectionBuilder.php',
+ 'Symfony\\Component\\Routing\\RouteCompiler' => $vendorDir . '/symfony/routing/RouteCompiler.php',
+ 'Symfony\\Component\\Routing\\RouteCompilerInterface' => $vendorDir . '/symfony/routing/RouteCompilerInterface.php',
+ 'Symfony\\Component\\Routing\\Router' => $vendorDir . '/symfony/routing/Router.php',
+ 'Symfony\\Component\\Routing\\RouterInterface' => $vendorDir . '/symfony/routing/RouterInterface.php',
+ 'Symfony\\Component\\Translation\\Catalogue\\AbstractOperation' => $vendorDir . '/symfony/translation/Catalogue/AbstractOperation.php',
+ 'Symfony\\Component\\Translation\\Catalogue\\MergeOperation' => $vendorDir . '/symfony/translation/Catalogue/MergeOperation.php',
+ 'Symfony\\Component\\Translation\\Catalogue\\OperationInterface' => $vendorDir . '/symfony/translation/Catalogue/OperationInterface.php',
+ 'Symfony\\Component\\Translation\\Catalogue\\TargetOperation' => $vendorDir . '/symfony/translation/Catalogue/TargetOperation.php',
+ 'Symfony\\Component\\Translation\\Command\\XliffLintCommand' => $vendorDir . '/symfony/translation/Command/XliffLintCommand.php',
+ 'Symfony\\Component\\Translation\\DataCollectorTranslator' => $vendorDir . '/symfony/translation/DataCollectorTranslator.php',
+ 'Symfony\\Component\\Translation\\DataCollector\\TranslationDataCollector' => $vendorDir . '/symfony/translation/DataCollector/TranslationDataCollector.php',
+ 'Symfony\\Component\\Translation\\DependencyInjection\\TranslationDumperPass' => $vendorDir . '/symfony/translation/DependencyInjection/TranslationDumperPass.php',
+ 'Symfony\\Component\\Translation\\DependencyInjection\\TranslationExtractorPass' => $vendorDir . '/symfony/translation/DependencyInjection/TranslationExtractorPass.php',
+ 'Symfony\\Component\\Translation\\DependencyInjection\\TranslatorPass' => $vendorDir . '/symfony/translation/DependencyInjection/TranslatorPass.php',
+ 'Symfony\\Component\\Translation\\Dumper\\CsvFileDumper' => $vendorDir . '/symfony/translation/Dumper/CsvFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\DumperInterface' => $vendorDir . '/symfony/translation/Dumper/DumperInterface.php',
+ 'Symfony\\Component\\Translation\\Dumper\\FileDumper' => $vendorDir . '/symfony/translation/Dumper/FileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\IcuResFileDumper' => $vendorDir . '/symfony/translation/Dumper/IcuResFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\IniFileDumper' => $vendorDir . '/symfony/translation/Dumper/IniFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\JsonFileDumper' => $vendorDir . '/symfony/translation/Dumper/JsonFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\MoFileDumper' => $vendorDir . '/symfony/translation/Dumper/MoFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\PhpFileDumper' => $vendorDir . '/symfony/translation/Dumper/PhpFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\PoFileDumper' => $vendorDir . '/symfony/translation/Dumper/PoFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\QtFileDumper' => $vendorDir . '/symfony/translation/Dumper/QtFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\XliffFileDumper' => $vendorDir . '/symfony/translation/Dumper/XliffFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\YamlFileDumper' => $vendorDir . '/symfony/translation/Dumper/YamlFileDumper.php',
+ 'Symfony\\Component\\Translation\\Exception\\ExceptionInterface' => $vendorDir . '/symfony/translation/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Translation\\Exception\\InvalidArgumentException' => $vendorDir . '/symfony/translation/Exception/InvalidArgumentException.php',
+ 'Symfony\\Component\\Translation\\Exception\\InvalidResourceException' => $vendorDir . '/symfony/translation/Exception/InvalidResourceException.php',
+ 'Symfony\\Component\\Translation\\Exception\\LogicException' => $vendorDir . '/symfony/translation/Exception/LogicException.php',
+ 'Symfony\\Component\\Translation\\Exception\\NotFoundResourceException' => $vendorDir . '/symfony/translation/Exception/NotFoundResourceException.php',
+ 'Symfony\\Component\\Translation\\Exception\\RuntimeException' => $vendorDir . '/symfony/translation/Exception/RuntimeException.php',
+ 'Symfony\\Component\\Translation\\Extractor\\AbstractFileExtractor' => $vendorDir . '/symfony/translation/Extractor/AbstractFileExtractor.php',
+ 'Symfony\\Component\\Translation\\Extractor\\ChainExtractor' => $vendorDir . '/symfony/translation/Extractor/ChainExtractor.php',
+ 'Symfony\\Component\\Translation\\Extractor\\ExtractorInterface' => $vendorDir . '/symfony/translation/Extractor/ExtractorInterface.php',
+ 'Symfony\\Component\\Translation\\Extractor\\PhpExtractor' => $vendorDir . '/symfony/translation/Extractor/PhpExtractor.php',
+ 'Symfony\\Component\\Translation\\Extractor\\PhpStringTokenParser' => $vendorDir . '/symfony/translation/Extractor/PhpStringTokenParser.php',
+ 'Symfony\\Component\\Translation\\Formatter\\ChoiceMessageFormatterInterface' => $vendorDir . '/symfony/translation/Formatter/ChoiceMessageFormatterInterface.php',
+ 'Symfony\\Component\\Translation\\Formatter\\MessageFormatter' => $vendorDir . '/symfony/translation/Formatter/MessageFormatter.php',
+ 'Symfony\\Component\\Translation\\Formatter\\MessageFormatterInterface' => $vendorDir . '/symfony/translation/Formatter/MessageFormatterInterface.php',
+ 'Symfony\\Component\\Translation\\IdentityTranslator' => $vendorDir . '/symfony/translation/IdentityTranslator.php',
+ 'Symfony\\Component\\Translation\\Interval' => $vendorDir . '/symfony/translation/Interval.php',
+ 'Symfony\\Component\\Translation\\Loader\\ArrayLoader' => $vendorDir . '/symfony/translation/Loader/ArrayLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\CsvFileLoader' => $vendorDir . '/symfony/translation/Loader/CsvFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\FileLoader' => $vendorDir . '/symfony/translation/Loader/FileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\IcuDatFileLoader' => $vendorDir . '/symfony/translation/Loader/IcuDatFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\IcuResFileLoader' => $vendorDir . '/symfony/translation/Loader/IcuResFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\IniFileLoader' => $vendorDir . '/symfony/translation/Loader/IniFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\JsonFileLoader' => $vendorDir . '/symfony/translation/Loader/JsonFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\LoaderInterface' => $vendorDir . '/symfony/translation/Loader/LoaderInterface.php',
+ 'Symfony\\Component\\Translation\\Loader\\MoFileLoader' => $vendorDir . '/symfony/translation/Loader/MoFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\PhpFileLoader' => $vendorDir . '/symfony/translation/Loader/PhpFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\PoFileLoader' => $vendorDir . '/symfony/translation/Loader/PoFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\QtFileLoader' => $vendorDir . '/symfony/translation/Loader/QtFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\XliffFileLoader' => $vendorDir . '/symfony/translation/Loader/XliffFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\YamlFileLoader' => $vendorDir . '/symfony/translation/Loader/YamlFileLoader.php',
+ 'Symfony\\Component\\Translation\\LoggingTranslator' => $vendorDir . '/symfony/translation/LoggingTranslator.php',
+ 'Symfony\\Component\\Translation\\MessageCatalogue' => $vendorDir . '/symfony/translation/MessageCatalogue.php',
+ 'Symfony\\Component\\Translation\\MessageCatalogueInterface' => $vendorDir . '/symfony/translation/MessageCatalogueInterface.php',
+ 'Symfony\\Component\\Translation\\MessageSelector' => $vendorDir . '/symfony/translation/MessageSelector.php',
+ 'Symfony\\Component\\Translation\\MetadataAwareInterface' => $vendorDir . '/symfony/translation/MetadataAwareInterface.php',
+ 'Symfony\\Component\\Translation\\PluralizationRules' => $vendorDir . '/symfony/translation/PluralizationRules.php',
+ 'Symfony\\Component\\Translation\\Reader\\TranslationReader' => $vendorDir . '/symfony/translation/Reader/TranslationReader.php',
+ 'Symfony\\Component\\Translation\\Reader\\TranslationReaderInterface' => $vendorDir . '/symfony/translation/Reader/TranslationReaderInterface.php',
+ 'Symfony\\Component\\Translation\\Translator' => $vendorDir . '/symfony/translation/Translator.php',
+ 'Symfony\\Component\\Translation\\TranslatorBagInterface' => $vendorDir . '/symfony/translation/TranslatorBagInterface.php',
+ 'Symfony\\Component\\Translation\\TranslatorInterface' => $vendorDir . '/symfony/translation/TranslatorInterface.php',
+ 'Symfony\\Component\\Translation\\Util\\ArrayConverter' => $vendorDir . '/symfony/translation/Util/ArrayConverter.php',
+ 'Symfony\\Component\\Translation\\Writer\\TranslationWriter' => $vendorDir . '/symfony/translation/Writer/TranslationWriter.php',
+ 'Symfony\\Component\\Translation\\Writer\\TranslationWriterInterface' => $vendorDir . '/symfony/translation/Writer/TranslationWriterInterface.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\AmqpCaster' => $vendorDir . '/symfony/var-dumper/Caster/AmqpCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ArgsStub' => $vendorDir . '/symfony/var-dumper/Caster/ArgsStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\Caster' => $vendorDir . '/symfony/var-dumper/Caster/Caster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ClassStub' => $vendorDir . '/symfony/var-dumper/Caster/ClassStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ConstStub' => $vendorDir . '/symfony/var-dumper/Caster/ConstStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\CutArrayStub' => $vendorDir . '/symfony/var-dumper/Caster/CutArrayStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\CutStub' => $vendorDir . '/symfony/var-dumper/Caster/CutStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\DOMCaster' => $vendorDir . '/symfony/var-dumper/Caster/DOMCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\DateCaster' => $vendorDir . '/symfony/var-dumper/Caster/DateCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\DoctrineCaster' => $vendorDir . '/symfony/var-dumper/Caster/DoctrineCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\EnumStub' => $vendorDir . '/symfony/var-dumper/Caster/EnumStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ExceptionCaster' => $vendorDir . '/symfony/var-dumper/Caster/ExceptionCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\FrameStub' => $vendorDir . '/symfony/var-dumper/Caster/FrameStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\LinkStub' => $vendorDir . '/symfony/var-dumper/Caster/LinkStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\MongoCaster' => $vendorDir . '/symfony/var-dumper/Caster/MongoCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\PdoCaster' => $vendorDir . '/symfony/var-dumper/Caster/PdoCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\PgSqlCaster' => $vendorDir . '/symfony/var-dumper/Caster/PgSqlCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\RedisCaster' => $vendorDir . '/symfony/var-dumper/Caster/RedisCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ReflectionCaster' => $vendorDir . '/symfony/var-dumper/Caster/ReflectionCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ResourceCaster' => $vendorDir . '/symfony/var-dumper/Caster/ResourceCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\SplCaster' => $vendorDir . '/symfony/var-dumper/Caster/SplCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\StubCaster' => $vendorDir . '/symfony/var-dumper/Caster/StubCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\SymfonyCaster' => $vendorDir . '/symfony/var-dumper/Caster/SymfonyCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\TraceStub' => $vendorDir . '/symfony/var-dumper/Caster/TraceStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\XmlReaderCaster' => $vendorDir . '/symfony/var-dumper/Caster/XmlReaderCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\XmlResourceCaster' => $vendorDir . '/symfony/var-dumper/Caster/XmlResourceCaster.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\AbstractCloner' => $vendorDir . '/symfony/var-dumper/Cloner/AbstractCloner.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\ClonerInterface' => $vendorDir . '/symfony/var-dumper/Cloner/ClonerInterface.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\Cursor' => $vendorDir . '/symfony/var-dumper/Cloner/Cursor.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\Data' => $vendorDir . '/symfony/var-dumper/Cloner/Data.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\DumperInterface' => $vendorDir . '/symfony/var-dumper/Cloner/DumperInterface.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\Stub' => $vendorDir . '/symfony/var-dumper/Cloner/Stub.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\VarCloner' => $vendorDir . '/symfony/var-dumper/Cloner/VarCloner.php',
+ 'Symfony\\Component\\VarDumper\\Dumper\\AbstractDumper' => $vendorDir . '/symfony/var-dumper/Dumper/AbstractDumper.php',
+ 'Symfony\\Component\\VarDumper\\Dumper\\CliDumper' => $vendorDir . '/symfony/var-dumper/Dumper/CliDumper.php',
+ 'Symfony\\Component\\VarDumper\\Dumper\\DataDumperInterface' => $vendorDir . '/symfony/var-dumper/Dumper/DataDumperInterface.php',
+ 'Symfony\\Component\\VarDumper\\Dumper\\HtmlDumper' => $vendorDir . '/symfony/var-dumper/Dumper/HtmlDumper.php',
+ 'Symfony\\Component\\VarDumper\\Exception\\ThrowingCasterException' => $vendorDir . '/symfony/var-dumper/Exception/ThrowingCasterException.php',
+ 'Symfony\\Component\\VarDumper\\Test\\VarDumperTestTrait' => $vendorDir . '/symfony/var-dumper/Test/VarDumperTestTrait.php',
+ 'Symfony\\Component\\VarDumper\\VarDumper' => $vendorDir . '/symfony/var-dumper/VarDumper.php',
+ 'Symfony\\Component\\Yaml\\Command\\LintCommand' => $vendorDir . '/symfony/yaml/Command/LintCommand.php',
+ 'Symfony\\Component\\Yaml\\Dumper' => $vendorDir . '/symfony/yaml/Dumper.php',
+ 'Symfony\\Component\\Yaml\\Escaper' => $vendorDir . '/symfony/yaml/Escaper.php',
+ 'Symfony\\Component\\Yaml\\Exception\\DumpException' => $vendorDir . '/symfony/yaml/Exception/DumpException.php',
+ 'Symfony\\Component\\Yaml\\Exception\\ExceptionInterface' => $vendorDir . '/symfony/yaml/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Yaml\\Exception\\ParseException' => $vendorDir . '/symfony/yaml/Exception/ParseException.php',
+ 'Symfony\\Component\\Yaml\\Exception\\RuntimeException' => $vendorDir . '/symfony/yaml/Exception/RuntimeException.php',
+ 'Symfony\\Component\\Yaml\\Inline' => $vendorDir . '/symfony/yaml/Inline.php',
+ 'Symfony\\Component\\Yaml\\Parser' => $vendorDir . '/symfony/yaml/Parser.php',
+ 'Symfony\\Component\\Yaml\\Tag\\TaggedValue' => $vendorDir . '/symfony/yaml/Tag/TaggedValue.php',
+ 'Symfony\\Component\\Yaml\\Unescaper' => $vendorDir . '/symfony/yaml/Unescaper.php',
+ 'Symfony\\Component\\Yaml\\Yaml' => $vendorDir . '/symfony/yaml/Yaml.php',
+ 'Symfony\\Polyfill\\Ctype\\Ctype' => $vendorDir . '/symfony/polyfill-ctype/Ctype.php',
+ 'Symfony\\Polyfill\\Mbstring\\Mbstring' => $vendorDir . '/symfony/polyfill-mbstring/Mbstring.php',
+ 'Symfony\\Polyfill\\Php56\\Php56' => $vendorDir . '/symfony/polyfill-php56/Php56.php',
+ 'Symfony\\Polyfill\\Php70\\Php70' => $vendorDir . '/symfony/polyfill-php70/Php70.php',
+ 'Symfony\\Polyfill\\Util\\Binary' => $vendorDir . '/symfony/polyfill-util/Binary.php',
+ 'Symfony\\Polyfill\\Util\\BinaryNoFuncOverload' => $vendorDir . '/symfony/polyfill-util/BinaryNoFuncOverload.php',
+ 'Symfony\\Polyfill\\Util\\BinaryOnFuncOverload' => $vendorDir . '/symfony/polyfill-util/BinaryOnFuncOverload.php',
+ 'Symfony\\Polyfill\\Util\\TestListener' => $vendorDir . '/symfony/polyfill-util/TestListener.php',
+ 'Symfony\\Polyfill\\Util\\TestListenerForV5' => $vendorDir . '/symfony/polyfill-util/TestListenerForV5.php',
+ 'Symfony\\Polyfill\\Util\\TestListenerForV6' => $vendorDir . '/symfony/polyfill-util/TestListenerForV6.php',
+ 'Symfony\\Polyfill\\Util\\TestListenerForV7' => $vendorDir . '/symfony/polyfill-util/TestListenerForV7.php',
+ 'Symfony\\Polyfill\\Util\\TestListenerTrait' => $vendorDir . '/symfony/polyfill-util/TestListenerTrait.php',
+ 'Tests\\CreatesApplication' => $baseDir . '/tests/CreatesApplication.php',
+ 'Tests\\Feature\\ExampleTest' => $baseDir . '/tests/Feature/ExampleTest.php',
+ 'Tests\\TestCase' => $baseDir . '/tests/TestCase.php',
+ 'Tests\\Unit\\ExampleTest' => $baseDir . '/tests/Unit/ExampleTest.php',
+ 'Text_Template' => $vendorDir . '/phpunit/php-text-template/src/Template.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\CssToInlineStyles' => $vendorDir . '/tijsverkoyen/css-to-inline-styles/src/CssToInlineStyles.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\Css\\Processor' => $vendorDir . '/tijsverkoyen/css-to-inline-styles/src/Css/Processor.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\Css\\Property\\Processor' => $vendorDir . '/tijsverkoyen/css-to-inline-styles/src/Css/Property/Processor.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\Css\\Property\\Property' => $vendorDir . '/tijsverkoyen/css-to-inline-styles/src/Css/Property/Property.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\Css\\Rule\\Processor' => $vendorDir . '/tijsverkoyen/css-to-inline-styles/src/Css/Rule/Processor.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\Css\\Rule\\Rule' => $vendorDir . '/tijsverkoyen/css-to-inline-styles/src/Css/Rule/Rule.php',
+ 'TypeError' => $vendorDir . '/symfony/polyfill-php70/Resources/stubs/TypeError.php',
+ 'UpdateHelper\\ComposerPlugin' => $vendorDir . '/kylekatarnls/update-helper/src/UpdateHelper/ComposerPlugin.php',
+ 'UpdateHelper\\NotUpdateInterfaceInstanceException' => $vendorDir . '/kylekatarnls/update-helper/src/UpdateHelper/NotUpdateInterfaceInstanceException.php',
+ 'UpdateHelper\\UpdateHelper' => $vendorDir . '/kylekatarnls/update-helper/src/UpdateHelper/UpdateHelper.php',
+ 'UpdateHelper\\UpdateHelperInterface' => $vendorDir . '/kylekatarnls/update-helper/src/UpdateHelper/UpdateHelperInterface.php',
+ 'Webmozart\\Assert\\Assert' => $vendorDir . '/webmozart/assert/src/Assert.php',
+ 'Webmozart\\Assert\\Mixin' => $vendorDir . '/webmozart/assert/src/Mixin.php',
+ 'XdgBaseDir\\Xdg' => $vendorDir . '/dnoegel/php-xdg-base-dir/src/Xdg.php',
+ 'phpDocumentor\\Reflection\\DocBlock' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock.php',
+ 'phpDocumentor\\Reflection\\DocBlockFactory' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlockFactory.php',
+ 'phpDocumentor\\Reflection\\DocBlockFactoryInterface' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlockFactoryInterface.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Description' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Description.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\DescriptionFactory' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/DescriptionFactory.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\ExampleFinder' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/ExampleFinder.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Serializer' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Serializer.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\StandardTagFactory' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/StandardTagFactory.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tag' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tag.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\TagFactory' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/TagFactory.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Author' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Author.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\BaseTag' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/BaseTag.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Covers' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Covers.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Deprecated' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Deprecated.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Example' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Example.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Factory\\StaticMethod' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Factory/StaticMethod.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Factory\\Strategy' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Factory/Strategy.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Formatter' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Formatter.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Formatter\\AlignFormatter' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Formatter/AlignFormatter.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Formatter\\PassthroughFormatter' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Formatter/PassthroughFormatter.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Generic' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Generic.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Link' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Link.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Method' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Method.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Param' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Param.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Property' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Property.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\PropertyRead' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/PropertyRead.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\PropertyWrite' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/PropertyWrite.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Reference\\Fqsen' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Reference/Fqsen.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Reference\\Reference' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Reference/Reference.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Reference\\Url' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Reference/Url.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Return_' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Return_.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\See' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/See.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Since' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Since.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Source' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Source.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Throws' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Throws.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Uses' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Uses.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Var_' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Var_.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Version' => $vendorDir . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Version.php',
+ 'phpDocumentor\\Reflection\\Element' => $vendorDir . '/phpdocumentor/reflection-common/src/Element.php',
+ 'phpDocumentor\\Reflection\\File' => $vendorDir . '/phpdocumentor/reflection-common/src/File.php',
+ 'phpDocumentor\\Reflection\\Fqsen' => $vendorDir . '/phpdocumentor/reflection-common/src/Fqsen.php',
+ 'phpDocumentor\\Reflection\\FqsenResolver' => $vendorDir . '/phpdocumentor/type-resolver/src/FqsenResolver.php',
+ 'phpDocumentor\\Reflection\\Location' => $vendorDir . '/phpdocumentor/reflection-common/src/Location.php',
+ 'phpDocumentor\\Reflection\\Project' => $vendorDir . '/phpdocumentor/reflection-common/src/Project.php',
+ 'phpDocumentor\\Reflection\\ProjectFactory' => $vendorDir . '/phpdocumentor/reflection-common/src/ProjectFactory.php',
+ 'phpDocumentor\\Reflection\\Type' => $vendorDir . '/phpdocumentor/type-resolver/src/Type.php',
+ 'phpDocumentor\\Reflection\\TypeResolver' => $vendorDir . '/phpdocumentor/type-resolver/src/TypeResolver.php',
+ 'phpDocumentor\\Reflection\\Types\\Array_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Array_.php',
+ 'phpDocumentor\\Reflection\\Types\\Boolean' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Boolean.php',
+ 'phpDocumentor\\Reflection\\Types\\Callable_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Callable_.php',
+ 'phpDocumentor\\Reflection\\Types\\Compound' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Compound.php',
+ 'phpDocumentor\\Reflection\\Types\\Context' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Context.php',
+ 'phpDocumentor\\Reflection\\Types\\ContextFactory' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/ContextFactory.php',
+ 'phpDocumentor\\Reflection\\Types\\Float_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Float_.php',
+ 'phpDocumentor\\Reflection\\Types\\Integer' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Integer.php',
+ 'phpDocumentor\\Reflection\\Types\\Iterable_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Iterable_.php',
+ 'phpDocumentor\\Reflection\\Types\\Mixed_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Mixed_.php',
+ 'phpDocumentor\\Reflection\\Types\\Null_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Null_.php',
+ 'phpDocumentor\\Reflection\\Types\\Nullable' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Nullable.php',
+ 'phpDocumentor\\Reflection\\Types\\Object_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Object_.php',
+ 'phpDocumentor\\Reflection\\Types\\Parent_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Parent_.php',
+ 'phpDocumentor\\Reflection\\Types\\Resource_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Resource_.php',
+ 'phpDocumentor\\Reflection\\Types\\Scalar' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Scalar.php',
+ 'phpDocumentor\\Reflection\\Types\\Self_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Self_.php',
+ 'phpDocumentor\\Reflection\\Types\\Static_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Static_.php',
+ 'phpDocumentor\\Reflection\\Types\\String_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/String_.php',
+ 'phpDocumentor\\Reflection\\Types\\This' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/This.php',
+ 'phpDocumentor\\Reflection\\Types\\Void_' => $vendorDir . '/phpdocumentor/type-resolver/src/Types/Void_.php',
+);
diff --git a/vendor/composer/autoload_files.php b/vendor/composer/autoload_files.php
new file mode 100644
index 000000000..5439f7f66
--- /dev/null
+++ b/vendor/composer/autoload_files.php
@@ -0,0 +1,22 @@
+ $vendorDir . '/symfony/polyfill-mbstring/bootstrap.php',
+ '320cde22f66dd4f5d3fd621d3e88b98f' => $vendorDir . '/symfony/polyfill-ctype/bootstrap.php',
+ '5255c38a0faeba867671b61dfda6d864' => $vendorDir . '/paragonie/random_compat/lib/random.php',
+ '667aeda72477189d0494fecd327c3641' => $vendorDir . '/symfony/var-dumper/Resources/functions/dump.php',
+ '023d27dca8066ef29e6739335ea73bad' => $vendorDir . '/symfony/polyfill-php70/bootstrap.php',
+ 'bd9634f2d41831496de0d3dfe4c94881' => $vendorDir . '/symfony/polyfill-php56/bootstrap.php',
+ '1d1b89d124cc9cb8219922c9d5569199' => $vendorDir . '/hamcrest/hamcrest-php/hamcrest/Hamcrest.php',
+ '2c102faa651ef8ea5874edb585946bce' => $vendorDir . '/swiftmailer/swiftmailer/lib/swift_required.php',
+ '6124b4c8570aa390c21fafd04a26c69f' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/deep_copy.php',
+ '801c31d8ed748cfa537fa45402288c95' => $vendorDir . '/psy/psysh/src/functions.php',
+ 'e39a8b23c42d4e1452234d762b03835a' => $vendorDir . '/ramsey/uuid/src/functions.php',
+ 'f0906e6318348a765ffb6eb24e0d0938' => $vendorDir . '/laravel/framework/src/Illuminate/Foundation/helpers.php',
+ '58571171fd5812e6e447dce228f52f4d' => $vendorDir . '/laravel/framework/src/Illuminate/Support/helpers.php',
+);
diff --git a/vendor/composer/autoload_namespaces.php b/vendor/composer/autoload_namespaces.php
new file mode 100644
index 000000000..05a028dc6
--- /dev/null
+++ b/vendor/composer/autoload_namespaces.php
@@ -0,0 +1,13 @@
+ array($vendorDir . '/kylekatarnls/update-helper/src'),
+ 'Parsedown' => array($vendorDir . '/erusev/parsedown'),
+ 'Mockery' => array($vendorDir . '/mockery/mockery/library'),
+ 'Doctrine\\Common\\Inflector\\' => array($vendorDir . '/doctrine/inflector/lib'),
+);
diff --git a/vendor/composer/autoload_psr4.php b/vendor/composer/autoload_psr4.php
new file mode 100644
index 000000000..5ade7afe3
--- /dev/null
+++ b/vendor/composer/autoload_psr4.php
@@ -0,0 +1,49 @@
+ array($vendorDir . '/phpdocumentor/reflection-common/src', $vendorDir . '/phpdocumentor/reflection-docblock/src', $vendorDir . '/phpdocumentor/type-resolver/src'),
+ 'XdgBaseDir\\' => array($vendorDir . '/dnoegel/php-xdg-base-dir/src'),
+ 'Webmozart\\Assert\\' => array($vendorDir . '/webmozart/assert/src'),
+ 'TijsVerkoyen\\CssToInlineStyles\\' => array($vendorDir . '/tijsverkoyen/css-to-inline-styles/src'),
+ 'Tests\\' => array($baseDir . '/tests'),
+ 'Symfony\\Polyfill\\Util\\' => array($vendorDir . '/symfony/polyfill-util'),
+ 'Symfony\\Polyfill\\Php70\\' => array($vendorDir . '/symfony/polyfill-php70'),
+ 'Symfony\\Polyfill\\Php56\\' => array($vendorDir . '/symfony/polyfill-php56'),
+ 'Symfony\\Polyfill\\Mbstring\\' => array($vendorDir . '/symfony/polyfill-mbstring'),
+ 'Symfony\\Polyfill\\Ctype\\' => array($vendorDir . '/symfony/polyfill-ctype'),
+ 'Symfony\\Component\\Yaml\\' => array($vendorDir . '/symfony/yaml'),
+ 'Symfony\\Component\\VarDumper\\' => array($vendorDir . '/symfony/var-dumper'),
+ 'Symfony\\Component\\Translation\\' => array($vendorDir . '/symfony/translation'),
+ 'Symfony\\Component\\Routing\\' => array($vendorDir . '/symfony/routing'),
+ 'Symfony\\Component\\Process\\' => array($vendorDir . '/symfony/process'),
+ 'Symfony\\Component\\HttpKernel\\' => array($vendorDir . '/symfony/http-kernel'),
+ 'Symfony\\Component\\HttpFoundation\\' => array($vendorDir . '/symfony/http-foundation'),
+ 'Symfony\\Component\\Finder\\' => array($vendorDir . '/symfony/finder'),
+ 'Symfony\\Component\\EventDispatcher\\' => array($vendorDir . '/symfony/event-dispatcher'),
+ 'Symfony\\Component\\Debug\\' => array($vendorDir . '/symfony/debug'),
+ 'Symfony\\Component\\CssSelector\\' => array($vendorDir . '/symfony/css-selector'),
+ 'Symfony\\Component\\Console\\' => array($vendorDir . '/symfony/console'),
+ 'Ramsey\\Uuid\\' => array($vendorDir . '/ramsey/uuid/src'),
+ 'Psy\\' => array($vendorDir . '/psy/psysh/src'),
+ 'Psr\\Log\\' => array($vendorDir . '/psr/log/Psr/Log'),
+ 'Prophecy\\' => array($vendorDir . '/phpspec/prophecy/src/Prophecy'),
+ 'PhpParser\\' => array($vendorDir . '/nikic/php-parser/lib/PhpParser'),
+ 'Monolog\\' => array($vendorDir . '/monolog/monolog/src/Monolog'),
+ 'League\\Flysystem\\' => array($vendorDir . '/league/flysystem/src'),
+ 'Laravel\\Tinker\\' => array($vendorDir . '/laravel/tinker/src'),
+ 'JakubOnderka\\PhpConsoleHighlighter\\' => array($vendorDir . '/jakub-onderka/php-console-highlighter/src'),
+ 'JakubOnderka\\PhpConsoleColor\\' => array($vendorDir . '/jakub-onderka/php-console-color/src'),
+ 'Illuminate\\' => array($vendorDir . '/laravel/framework/src/Illuminate'),
+ 'Faker\\' => array($vendorDir . '/fzaninotto/faker/src/Faker'),
+ 'Dotenv\\' => array($vendorDir . '/vlucas/phpdotenv/src'),
+ 'Doctrine\\Instantiator\\' => array($vendorDir . '/doctrine/instantiator/src/Doctrine/Instantiator'),
+ 'DeepCopy\\' => array($vendorDir . '/myclabs/deep-copy/src/DeepCopy'),
+ 'Cron\\' => array($vendorDir . '/mtdowling/cron-expression/src/Cron'),
+ 'App\\' => array($baseDir . '/app'),
+ '' => array($vendorDir . '/nesbot/carbon/src'),
+);
diff --git a/vendor/composer/autoload_real.php b/vendor/composer/autoload_real.php
new file mode 100644
index 000000000..b6df2b479
--- /dev/null
+++ b/vendor/composer/autoload_real.php
@@ -0,0 +1,75 @@
+= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
+ if ($useStaticLoader) {
+ require __DIR__ . '/autoload_static.php';
+
+ call_user_func(\Composer\Autoload\ComposerStaticInit32220b89e337d5c8ea9feb0fd5ac6779::getInitializer($loader));
+ } else {
+ $map = require __DIR__ . '/autoload_namespaces.php';
+ foreach ($map as $namespace => $path) {
+ $loader->set($namespace, $path);
+ }
+
+ $map = require __DIR__ . '/autoload_psr4.php';
+ foreach ($map as $namespace => $path) {
+ $loader->setPsr4($namespace, $path);
+ }
+
+ $classMap = require __DIR__ . '/autoload_classmap.php';
+ if ($classMap) {
+ $loader->addClassMap($classMap);
+ }
+ }
+
+ $loader->register(true);
+
+ if ($useStaticLoader) {
+ $includeFiles = Composer\Autoload\ComposerStaticInit32220b89e337d5c8ea9feb0fd5ac6779::$files;
+ } else {
+ $includeFiles = require __DIR__ . '/autoload_files.php';
+ }
+ foreach ($includeFiles as $fileIdentifier => $file) {
+ composerRequire32220b89e337d5c8ea9feb0fd5ac6779($fileIdentifier, $file);
+ }
+
+ return $loader;
+ }
+}
+
+function composerRequire32220b89e337d5c8ea9feb0fd5ac6779($fileIdentifier, $file)
+{
+ if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
+ require $file;
+
+ $GLOBALS['__composer_autoload_files'][$fileIdentifier] = true;
+ }
+}
diff --git a/vendor/composer/autoload_static.php b/vendor/composer/autoload_static.php
new file mode 100644
index 000000000..57082e259
--- /dev/null
+++ b/vendor/composer/autoload_static.php
@@ -0,0 +1,3465 @@
+ __DIR__ . '/..' . '/symfony/polyfill-mbstring/bootstrap.php',
+ '320cde22f66dd4f5d3fd621d3e88b98f' => __DIR__ . '/..' . '/symfony/polyfill-ctype/bootstrap.php',
+ '5255c38a0faeba867671b61dfda6d864' => __DIR__ . '/..' . '/paragonie/random_compat/lib/random.php',
+ '667aeda72477189d0494fecd327c3641' => __DIR__ . '/..' . '/symfony/var-dumper/Resources/functions/dump.php',
+ '023d27dca8066ef29e6739335ea73bad' => __DIR__ . '/..' . '/symfony/polyfill-php70/bootstrap.php',
+ 'bd9634f2d41831496de0d3dfe4c94881' => __DIR__ . '/..' . '/symfony/polyfill-php56/bootstrap.php',
+ '1d1b89d124cc9cb8219922c9d5569199' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest.php',
+ '2c102faa651ef8ea5874edb585946bce' => __DIR__ . '/..' . '/swiftmailer/swiftmailer/lib/swift_required.php',
+ '6124b4c8570aa390c21fafd04a26c69f' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/deep_copy.php',
+ '801c31d8ed748cfa537fa45402288c95' => __DIR__ . '/..' . '/psy/psysh/src/functions.php',
+ 'e39a8b23c42d4e1452234d762b03835a' => __DIR__ . '/..' . '/ramsey/uuid/src/functions.php',
+ 'f0906e6318348a765ffb6eb24e0d0938' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/helpers.php',
+ '58571171fd5812e6e447dce228f52f4d' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/helpers.php',
+ );
+
+ public static $prefixLengthsPsr4 = array (
+ 'p' =>
+ array (
+ 'phpDocumentor\\Reflection\\' => 25,
+ ),
+ 'X' =>
+ array (
+ 'XdgBaseDir\\' => 11,
+ ),
+ 'W' =>
+ array (
+ 'Webmozart\\Assert\\' => 17,
+ ),
+ 'T' =>
+ array (
+ 'TijsVerkoyen\\CssToInlineStyles\\' => 31,
+ 'Tests\\' => 6,
+ ),
+ 'S' =>
+ array (
+ 'Symfony\\Polyfill\\Util\\' => 22,
+ 'Symfony\\Polyfill\\Php70\\' => 23,
+ 'Symfony\\Polyfill\\Php56\\' => 23,
+ 'Symfony\\Polyfill\\Mbstring\\' => 26,
+ 'Symfony\\Polyfill\\Ctype\\' => 23,
+ 'Symfony\\Component\\Yaml\\' => 23,
+ 'Symfony\\Component\\VarDumper\\' => 28,
+ 'Symfony\\Component\\Translation\\' => 30,
+ 'Symfony\\Component\\Routing\\' => 26,
+ 'Symfony\\Component\\Process\\' => 26,
+ 'Symfony\\Component\\HttpKernel\\' => 29,
+ 'Symfony\\Component\\HttpFoundation\\' => 33,
+ 'Symfony\\Component\\Finder\\' => 25,
+ 'Symfony\\Component\\EventDispatcher\\' => 34,
+ 'Symfony\\Component\\Debug\\' => 24,
+ 'Symfony\\Component\\CssSelector\\' => 30,
+ 'Symfony\\Component\\Console\\' => 26,
+ ),
+ 'R' =>
+ array (
+ 'Ramsey\\Uuid\\' => 12,
+ ),
+ 'P' =>
+ array (
+ 'Psy\\' => 4,
+ 'Psr\\Log\\' => 8,
+ 'Prophecy\\' => 9,
+ 'PhpParser\\' => 10,
+ ),
+ 'M' =>
+ array (
+ 'Monolog\\' => 8,
+ ),
+ 'L' =>
+ array (
+ 'League\\Flysystem\\' => 17,
+ 'Laravel\\Tinker\\' => 15,
+ ),
+ 'J' =>
+ array (
+ 'JakubOnderka\\PhpConsoleHighlighter\\' => 35,
+ 'JakubOnderka\\PhpConsoleColor\\' => 29,
+ ),
+ 'I' =>
+ array (
+ 'Illuminate\\' => 11,
+ ),
+ 'F' =>
+ array (
+ 'Faker\\' => 6,
+ ),
+ 'D' =>
+ array (
+ 'Dotenv\\' => 7,
+ 'Doctrine\\Instantiator\\' => 22,
+ 'DeepCopy\\' => 9,
+ ),
+ 'C' =>
+ array (
+ 'Cron\\' => 5,
+ ),
+ 'A' =>
+ array (
+ 'App\\' => 4,
+ ),
+ );
+
+ public static $prefixDirsPsr4 = array (
+ 'phpDocumentor\\Reflection\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/phpdocumentor/reflection-common/src',
+ 1 => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src',
+ 2 => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src',
+ ),
+ 'XdgBaseDir\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/dnoegel/php-xdg-base-dir/src',
+ ),
+ 'Webmozart\\Assert\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/webmozart/assert/src',
+ ),
+ 'TijsVerkoyen\\CssToInlineStyles\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/tijsverkoyen/css-to-inline-styles/src',
+ ),
+ 'Tests\\' =>
+ array (
+ 0 => __DIR__ . '/../..' . '/tests',
+ ),
+ 'Symfony\\Polyfill\\Util\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/polyfill-util',
+ ),
+ 'Symfony\\Polyfill\\Php70\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/polyfill-php70',
+ ),
+ 'Symfony\\Polyfill\\Php56\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/polyfill-php56',
+ ),
+ 'Symfony\\Polyfill\\Mbstring\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/polyfill-mbstring',
+ ),
+ 'Symfony\\Polyfill\\Ctype\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/polyfill-ctype',
+ ),
+ 'Symfony\\Component\\Yaml\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/yaml',
+ ),
+ 'Symfony\\Component\\VarDumper\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/var-dumper',
+ ),
+ 'Symfony\\Component\\Translation\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/translation',
+ ),
+ 'Symfony\\Component\\Routing\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/routing',
+ ),
+ 'Symfony\\Component\\Process\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/process',
+ ),
+ 'Symfony\\Component\\HttpKernel\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/http-kernel',
+ ),
+ 'Symfony\\Component\\HttpFoundation\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/http-foundation',
+ ),
+ 'Symfony\\Component\\Finder\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/finder',
+ ),
+ 'Symfony\\Component\\EventDispatcher\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/event-dispatcher',
+ ),
+ 'Symfony\\Component\\Debug\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/debug',
+ ),
+ 'Symfony\\Component\\CssSelector\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/css-selector',
+ ),
+ 'Symfony\\Component\\Console\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/symfony/console',
+ ),
+ 'Ramsey\\Uuid\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/ramsey/uuid/src',
+ ),
+ 'Psy\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/psy/psysh/src',
+ ),
+ 'Psr\\Log\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/psr/log/Psr/Log',
+ ),
+ 'Prophecy\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy',
+ ),
+ 'PhpParser\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser',
+ ),
+ 'Monolog\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/monolog/monolog/src/Monolog',
+ ),
+ 'League\\Flysystem\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/league/flysystem/src',
+ ),
+ 'Laravel\\Tinker\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/laravel/tinker/src',
+ ),
+ 'JakubOnderka\\PhpConsoleHighlighter\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/jakub-onderka/php-console-highlighter/src',
+ ),
+ 'JakubOnderka\\PhpConsoleColor\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/jakub-onderka/php-console-color/src',
+ ),
+ 'Illuminate\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/laravel/framework/src/Illuminate',
+ ),
+ 'Faker\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker',
+ ),
+ 'Dotenv\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/vlucas/phpdotenv/src',
+ ),
+ 'Doctrine\\Instantiator\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/doctrine/instantiator/src/Doctrine/Instantiator',
+ ),
+ 'DeepCopy\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy',
+ ),
+ 'Cron\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron',
+ ),
+ 'App\\' =>
+ array (
+ 0 => __DIR__ . '/../..' . '/app',
+ ),
+ );
+
+ public static $fallbackDirsPsr4 = array (
+ 0 => __DIR__ . '/..' . '/nesbot/carbon/src',
+ );
+
+ public static $prefixesPsr0 = array (
+ 'U' =>
+ array (
+ 'UpdateHelper\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/kylekatarnls/update-helper/src',
+ ),
+ ),
+ 'P' =>
+ array (
+ 'Parsedown' =>
+ array (
+ 0 => __DIR__ . '/..' . '/erusev/parsedown',
+ ),
+ ),
+ 'M' =>
+ array (
+ 'Mockery' =>
+ array (
+ 0 => __DIR__ . '/..' . '/mockery/mockery/library',
+ ),
+ ),
+ 'D' =>
+ array (
+ 'Doctrine\\Common\\Inflector\\' =>
+ array (
+ 0 => __DIR__ . '/..' . '/doctrine/inflector/lib',
+ ),
+ ),
+ );
+
+ public static $classMap = array (
+ 'App\\Console\\Kernel' => __DIR__ . '/../..' . '/app/Console/Kernel.php',
+ 'App\\Event' => __DIR__ . '/../..' . '/app/Event.php',
+ 'App\\Exceptions\\Handler' => __DIR__ . '/../..' . '/app/Exceptions/Handler.php',
+ 'App\\Http\\Controllers\\Auth\\ForgotPasswordController' => __DIR__ . '/../..' . '/app/Http/Controllers/Auth/ForgotPasswordController.php',
+ 'App\\Http\\Controllers\\Auth\\LoginController' => __DIR__ . '/../..' . '/app/Http/Controllers/Auth/LoginController.php',
+ 'App\\Http\\Controllers\\Auth\\RegisterController' => __DIR__ . '/../..' . '/app/Http/Controllers/Auth/RegisterController.php',
+ 'App\\Http\\Controllers\\Auth\\ResetPasswordController' => __DIR__ . '/../..' . '/app/Http/Controllers/Auth/ResetPasswordController.php',
+ 'App\\Http\\Controllers\\Controller' => __DIR__ . '/../..' . '/app/Http/Controllers/Controller.php',
+ 'App\\Http\\Controllers\\EventController' => __DIR__ . '/../..' . '/app/Http/Controllers/EventController.php',
+ 'App\\Http\\Kernel' => __DIR__ . '/../..' . '/app/Http/Kernel.php',
+ 'App\\Http\\Middleware\\EncryptCookies' => __DIR__ . '/../..' . '/app/Http/Middleware/EncryptCookies.php',
+ 'App\\Http\\Middleware\\RedirectIfAuthenticated' => __DIR__ . '/../..' . '/app/Http/Middleware/RedirectIfAuthenticated.php',
+ 'App\\Http\\Middleware\\TrimStrings' => __DIR__ . '/../..' . '/app/Http/Middleware/TrimStrings.php',
+ 'App\\Http\\Middleware\\VerifyCsrfToken' => __DIR__ . '/../..' . '/app/Http/Middleware/VerifyCsrfToken.php',
+ 'App\\Providers\\AppServiceProvider' => __DIR__ . '/../..' . '/app/Providers/AppServiceProvider.php',
+ 'App\\Providers\\AuthServiceProvider' => __DIR__ . '/../..' . '/app/Providers/AuthServiceProvider.php',
+ 'App\\Providers\\BroadcastServiceProvider' => __DIR__ . '/../..' . '/app/Providers/BroadcastServiceProvider.php',
+ 'App\\Providers\\EventServiceProvider' => __DIR__ . '/../..' . '/app/Providers/EventServiceProvider.php',
+ 'App\\Providers\\RouteServiceProvider' => __DIR__ . '/../..' . '/app/Providers/RouteServiceProvider.php',
+ 'App\\User' => __DIR__ . '/../..' . '/app/User.php',
+ 'ArithmeticError' => __DIR__ . '/..' . '/symfony/polyfill-php70/Resources/stubs/ArithmeticError.php',
+ 'AssertionError' => __DIR__ . '/..' . '/symfony/polyfill-php70/Resources/stubs/AssertionError.php',
+ 'Carbon\\Carbon' => __DIR__ . '/..' . '/nesbot/carbon/src/Carbon/Carbon.php',
+ 'Carbon\\CarbonInterval' => __DIR__ . '/..' . '/nesbot/carbon/src/Carbon/CarbonInterval.php',
+ 'Carbon\\CarbonPeriod' => __DIR__ . '/..' . '/nesbot/carbon/src/Carbon/CarbonPeriod.php',
+ 'Carbon\\Exceptions\\InvalidDateException' => __DIR__ . '/..' . '/nesbot/carbon/src/Carbon/Exceptions/InvalidDateException.php',
+ 'Carbon\\Laravel\\ServiceProvider' => __DIR__ . '/..' . '/nesbot/carbon/src/Carbon/Laravel/ServiceProvider.php',
+ 'Carbon\\Translator' => __DIR__ . '/..' . '/nesbot/carbon/src/Carbon/Translator.php',
+ 'Carbon\\Upgrade' => __DIR__ . '/..' . '/nesbot/carbon/src/Carbon/Upgrade.php',
+ 'Composer\\InstalledVersions' => __DIR__ . '/..' . '/composer/InstalledVersions.php',
+ 'CreateEventsTable' => __DIR__ . '/../..' . '/database/migrations/2023_02_11_013624_create_events_table.php',
+ 'CreatePasswordResetsTable' => __DIR__ . '/../..' . '/database/migrations/2014_10_12_100000_create_password_resets_table.php',
+ 'CreateUsersTable' => __DIR__ . '/../..' . '/database/migrations/2014_10_12_000000_create_users_table.php',
+ 'Cron\\AbstractField' => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron/AbstractField.php',
+ 'Cron\\CronExpression' => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron/CronExpression.php',
+ 'Cron\\DayOfMonthField' => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron/DayOfMonthField.php',
+ 'Cron\\DayOfWeekField' => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron/DayOfWeekField.php',
+ 'Cron\\FieldFactory' => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron/FieldFactory.php',
+ 'Cron\\FieldInterface' => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron/FieldInterface.php',
+ 'Cron\\HoursField' => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron/HoursField.php',
+ 'Cron\\MinutesField' => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron/MinutesField.php',
+ 'Cron\\MonthField' => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron/MonthField.php',
+ 'Cron\\YearField' => __DIR__ . '/..' . '/mtdowling/cron-expression/src/Cron/YearField.php',
+ 'DatabaseSeeder' => __DIR__ . '/../..' . '/database/seeds/DatabaseSeeder.php',
+ 'DeepCopy\\DeepCopy' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/DeepCopy.php',
+ 'DeepCopy\\Exception\\CloneException' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Exception/CloneException.php',
+ 'DeepCopy\\Exception\\PropertyException' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Exception/PropertyException.php',
+ 'DeepCopy\\Filter\\Doctrine\\DoctrineCollectionFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Filter/Doctrine/DoctrineCollectionFilter.php',
+ 'DeepCopy\\Filter\\Doctrine\\DoctrineEmptyCollectionFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Filter/Doctrine/DoctrineEmptyCollectionFilter.php',
+ 'DeepCopy\\Filter\\Doctrine\\DoctrineProxyFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Filter/Doctrine/DoctrineProxyFilter.php',
+ 'DeepCopy\\Filter\\Filter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Filter/Filter.php',
+ 'DeepCopy\\Filter\\KeepFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Filter/KeepFilter.php',
+ 'DeepCopy\\Filter\\ReplaceFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Filter/ReplaceFilter.php',
+ 'DeepCopy\\Filter\\SetNullFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Filter/SetNullFilter.php',
+ 'DeepCopy\\Matcher\\Doctrine\\DoctrineProxyMatcher' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Matcher/Doctrine/DoctrineProxyMatcher.php',
+ 'DeepCopy\\Matcher\\Matcher' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Matcher/Matcher.php',
+ 'DeepCopy\\Matcher\\PropertyMatcher' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Matcher/PropertyMatcher.php',
+ 'DeepCopy\\Matcher\\PropertyNameMatcher' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Matcher/PropertyNameMatcher.php',
+ 'DeepCopy\\Matcher\\PropertyTypeMatcher' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Matcher/PropertyTypeMatcher.php',
+ 'DeepCopy\\Reflection\\ReflectionHelper' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/Reflection/ReflectionHelper.php',
+ 'DeepCopy\\TypeFilter\\Date\\DateIntervalFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/Date/DateIntervalFilter.php',
+ 'DeepCopy\\TypeFilter\\ReplaceFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/ReplaceFilter.php',
+ 'DeepCopy\\TypeFilter\\ShallowCopyFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/ShallowCopyFilter.php',
+ 'DeepCopy\\TypeFilter\\Spl\\SplDoublyLinkedList' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/Spl/SplDoublyLinkedList.php',
+ 'DeepCopy\\TypeFilter\\Spl\\SplDoublyLinkedListFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/Spl/SplDoublyLinkedListFilter.php',
+ 'DeepCopy\\TypeFilter\\TypeFilter' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/TypeFilter/TypeFilter.php',
+ 'DeepCopy\\TypeMatcher\\TypeMatcher' => __DIR__ . '/..' . '/myclabs/deep-copy/src/DeepCopy/TypeMatcher/TypeMatcher.php',
+ 'DivisionByZeroError' => __DIR__ . '/..' . '/symfony/polyfill-php70/Resources/stubs/DivisionByZeroError.php',
+ 'Doctrine\\Common\\Inflector\\Inflector' => __DIR__ . '/..' . '/doctrine/inflector/lib/Doctrine/Common/Inflector/Inflector.php',
+ 'Doctrine\\Instantiator\\Exception\\ExceptionInterface' => __DIR__ . '/..' . '/doctrine/instantiator/src/Doctrine/Instantiator/Exception/ExceptionInterface.php',
+ 'Doctrine\\Instantiator\\Exception\\InvalidArgumentException' => __DIR__ . '/..' . '/doctrine/instantiator/src/Doctrine/Instantiator/Exception/InvalidArgumentException.php',
+ 'Doctrine\\Instantiator\\Exception\\UnexpectedValueException' => __DIR__ . '/..' . '/doctrine/instantiator/src/Doctrine/Instantiator/Exception/UnexpectedValueException.php',
+ 'Doctrine\\Instantiator\\Instantiator' => __DIR__ . '/..' . '/doctrine/instantiator/src/Doctrine/Instantiator/Instantiator.php',
+ 'Doctrine\\Instantiator\\InstantiatorInterface' => __DIR__ . '/..' . '/doctrine/instantiator/src/Doctrine/Instantiator/InstantiatorInterface.php',
+ 'Dotenv\\Dotenv' => __DIR__ . '/..' . '/vlucas/phpdotenv/src/Dotenv.php',
+ 'Dotenv\\Exception\\ExceptionInterface' => __DIR__ . '/..' . '/vlucas/phpdotenv/src/Exception/ExceptionInterface.php',
+ 'Dotenv\\Exception\\InvalidCallbackException' => __DIR__ . '/..' . '/vlucas/phpdotenv/src/Exception/InvalidCallbackException.php',
+ 'Dotenv\\Exception\\InvalidFileException' => __DIR__ . '/..' . '/vlucas/phpdotenv/src/Exception/InvalidFileException.php',
+ 'Dotenv\\Exception\\InvalidPathException' => __DIR__ . '/..' . '/vlucas/phpdotenv/src/Exception/InvalidPathException.php',
+ 'Dotenv\\Exception\\ValidationException' => __DIR__ . '/..' . '/vlucas/phpdotenv/src/Exception/ValidationException.php',
+ 'Dotenv\\Loader' => __DIR__ . '/..' . '/vlucas/phpdotenv/src/Loader.php',
+ 'Dotenv\\Parser' => __DIR__ . '/..' . '/vlucas/phpdotenv/src/Parser.php',
+ 'Dotenv\\Validator' => __DIR__ . '/..' . '/vlucas/phpdotenv/src/Validator.php',
+ 'Error' => __DIR__ . '/..' . '/symfony/polyfill-php70/Resources/stubs/Error.php',
+ 'EventSeeder' => __DIR__ . '/../..' . '/database/seeds/EventSeeder.php',
+ 'Faker\\Calculator\\Ean' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Calculator/Ean.php',
+ 'Faker\\Calculator\\Iban' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Calculator/Iban.php',
+ 'Faker\\Calculator\\Inn' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Calculator/Inn.php',
+ 'Faker\\Calculator\\Luhn' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Calculator/Luhn.php',
+ 'Faker\\Calculator\\TCNo' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Calculator/TCNo.php',
+ 'Faker\\DefaultGenerator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/DefaultGenerator.php',
+ 'Faker\\Documentor' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Documentor.php',
+ 'Faker\\Factory' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Factory.php',
+ 'Faker\\Generator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Generator.php',
+ 'Faker\\Guesser\\Name' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Guesser/Name.php',
+ 'Faker\\ORM\\CakePHP\\ColumnTypeGuesser' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/CakePHP/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\CakePHP\\EntityPopulator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/CakePHP/EntityPopulator.php',
+ 'Faker\\ORM\\CakePHP\\Populator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/CakePHP/Populator.php',
+ 'Faker\\ORM\\Doctrine\\ColumnTypeGuesser' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Doctrine/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\Doctrine\\EntityPopulator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Doctrine/EntityPopulator.php',
+ 'Faker\\ORM\\Doctrine\\Populator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Doctrine/Populator.php',
+ 'Faker\\ORM\\Mandango\\ColumnTypeGuesser' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Mandango/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\Mandango\\EntityPopulator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Mandango/EntityPopulator.php',
+ 'Faker\\ORM\\Mandango\\Populator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Mandango/Populator.php',
+ 'Faker\\ORM\\Propel2\\ColumnTypeGuesser' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Propel2/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\Propel2\\EntityPopulator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Propel2/EntityPopulator.php',
+ 'Faker\\ORM\\Propel2\\Populator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Propel2/Populator.php',
+ 'Faker\\ORM\\Propel\\ColumnTypeGuesser' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Propel/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\Propel\\EntityPopulator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Propel/EntityPopulator.php',
+ 'Faker\\ORM\\Propel\\Populator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Propel/Populator.php',
+ 'Faker\\ORM\\Spot\\ColumnTypeGuesser' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Spot/ColumnTypeGuesser.php',
+ 'Faker\\ORM\\Spot\\EntityPopulator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Spot/EntityPopulator.php',
+ 'Faker\\ORM\\Spot\\Populator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ORM/Spot/Populator.php',
+ 'Faker\\Provider\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Address.php',
+ 'Faker\\Provider\\Barcode' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Barcode.php',
+ 'Faker\\Provider\\Base' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Base.php',
+ 'Faker\\Provider\\Biased' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Biased.php',
+ 'Faker\\Provider\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Color.php',
+ 'Faker\\Provider\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Company.php',
+ 'Faker\\Provider\\DateTime' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/DateTime.php',
+ 'Faker\\Provider\\File' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/File.php',
+ 'Faker\\Provider\\HtmlLorem' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/HtmlLorem.php',
+ 'Faker\\Provider\\Image' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Image.php',
+ 'Faker\\Provider\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Internet.php',
+ 'Faker\\Provider\\Lorem' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Lorem.php',
+ 'Faker\\Provider\\Miscellaneous' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Miscellaneous.php',
+ 'Faker\\Provider\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Payment.php',
+ 'Faker\\Provider\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Person.php',
+ 'Faker\\Provider\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/PhoneNumber.php',
+ 'Faker\\Provider\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Text.php',
+ 'Faker\\Provider\\UserAgent' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/UserAgent.php',
+ 'Faker\\Provider\\Uuid' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/Uuid.php',
+ 'Faker\\Provider\\ar_JO\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_JO/Address.php',
+ 'Faker\\Provider\\ar_JO\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_JO/Company.php',
+ 'Faker\\Provider\\ar_JO\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_JO/Internet.php',
+ 'Faker\\Provider\\ar_JO\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_JO/Person.php',
+ 'Faker\\Provider\\ar_JO\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_JO/Text.php',
+ 'Faker\\Provider\\ar_SA\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Address.php',
+ 'Faker\\Provider\\ar_SA\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Color.php',
+ 'Faker\\Provider\\ar_SA\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Company.php',
+ 'Faker\\Provider\\ar_SA\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Internet.php',
+ 'Faker\\Provider\\ar_SA\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Payment.php',
+ 'Faker\\Provider\\ar_SA\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Person.php',
+ 'Faker\\Provider\\ar_SA\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ar_SA/Text.php',
+ 'Faker\\Provider\\at_AT\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/at_AT/Payment.php',
+ 'Faker\\Provider\\bg_BG\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/bg_BG/Internet.php',
+ 'Faker\\Provider\\bg_BG\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/bg_BG/Payment.php',
+ 'Faker\\Provider\\bg_BG\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/bg_BG/Person.php',
+ 'Faker\\Provider\\bg_BG\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/bg_BG/PhoneNumber.php',
+ 'Faker\\Provider\\bn_BD\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/bn_BD/Address.php',
+ 'Faker\\Provider\\bn_BD\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/bn_BD/Company.php',
+ 'Faker\\Provider\\bn_BD\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/bn_BD/Person.php',
+ 'Faker\\Provider\\bn_BD\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/bn_BD/PhoneNumber.php',
+ 'Faker\\Provider\\bn_BD\\Utils' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/bn_BD/Utils.php',
+ 'Faker\\Provider\\cs_CZ\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/Address.php',
+ 'Faker\\Provider\\cs_CZ\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/Company.php',
+ 'Faker\\Provider\\cs_CZ\\DateTime' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/DateTime.php',
+ 'Faker\\Provider\\cs_CZ\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/Internet.php',
+ 'Faker\\Provider\\cs_CZ\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/Payment.php',
+ 'Faker\\Provider\\cs_CZ\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/Person.php',
+ 'Faker\\Provider\\cs_CZ\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/cs_CZ/PhoneNumber.php',
+ 'Faker\\Provider\\da_DK\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/da_DK/Address.php',
+ 'Faker\\Provider\\da_DK\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/da_DK/Company.php',
+ 'Faker\\Provider\\da_DK\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/da_DK/Internet.php',
+ 'Faker\\Provider\\da_DK\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/da_DK/Payment.php',
+ 'Faker\\Provider\\da_DK\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/da_DK/Person.php',
+ 'Faker\\Provider\\da_DK\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/da_DK/PhoneNumber.php',
+ 'Faker\\Provider\\de_AT\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_AT/Address.php',
+ 'Faker\\Provider\\de_AT\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_AT/Company.php',
+ 'Faker\\Provider\\de_AT\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_AT/Internet.php',
+ 'Faker\\Provider\\de_AT\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_AT/Payment.php',
+ 'Faker\\Provider\\de_AT\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_AT/Person.php',
+ 'Faker\\Provider\\de_AT\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_AT/PhoneNumber.php',
+ 'Faker\\Provider\\de_AT\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_AT/Text.php',
+ 'Faker\\Provider\\de_CH\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_CH/Address.php',
+ 'Faker\\Provider\\de_CH\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_CH/Company.php',
+ 'Faker\\Provider\\de_CH\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_CH/Internet.php',
+ 'Faker\\Provider\\de_CH\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_CH/Payment.php',
+ 'Faker\\Provider\\de_CH\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_CH/Person.php',
+ 'Faker\\Provider\\de_CH\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_CH/PhoneNumber.php',
+ 'Faker\\Provider\\de_CH\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_CH/Text.php',
+ 'Faker\\Provider\\de_DE\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_DE/Address.php',
+ 'Faker\\Provider\\de_DE\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_DE/Company.php',
+ 'Faker\\Provider\\de_DE\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_DE/Internet.php',
+ 'Faker\\Provider\\de_DE\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_DE/Payment.php',
+ 'Faker\\Provider\\de_DE\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_DE/Person.php',
+ 'Faker\\Provider\\de_DE\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_DE/PhoneNumber.php',
+ 'Faker\\Provider\\de_DE\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/de_DE/Text.php',
+ 'Faker\\Provider\\el_CY\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_CY/Address.php',
+ 'Faker\\Provider\\el_CY\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_CY/Company.php',
+ 'Faker\\Provider\\el_CY\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_CY/Internet.php',
+ 'Faker\\Provider\\el_CY\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_CY/Payment.php',
+ 'Faker\\Provider\\el_CY\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_CY/Person.php',
+ 'Faker\\Provider\\el_CY\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_CY/PhoneNumber.php',
+ 'Faker\\Provider\\el_GR\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_GR/Address.php',
+ 'Faker\\Provider\\el_GR\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_GR/Company.php',
+ 'Faker\\Provider\\el_GR\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_GR/Payment.php',
+ 'Faker\\Provider\\el_GR\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_GR/Person.php',
+ 'Faker\\Provider\\el_GR\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/el_GR/PhoneNumber.php',
+ 'Faker\\Provider\\en_AU\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_AU/Address.php',
+ 'Faker\\Provider\\en_AU\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_AU/Internet.php',
+ 'Faker\\Provider\\en_AU\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_AU/PhoneNumber.php',
+ 'Faker\\Provider\\en_CA\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_CA/Address.php',
+ 'Faker\\Provider\\en_CA\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_CA/PhoneNumber.php',
+ 'Faker\\Provider\\en_GB\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_GB/Address.php',
+ 'Faker\\Provider\\en_GB\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_GB/Internet.php',
+ 'Faker\\Provider\\en_GB\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_GB/Payment.php',
+ 'Faker\\Provider\\en_GB\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_GB/Person.php',
+ 'Faker\\Provider\\en_GB\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_GB/PhoneNumber.php',
+ 'Faker\\Provider\\en_HK\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_HK/Address.php',
+ 'Faker\\Provider\\en_HK\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_HK/Internet.php',
+ 'Faker\\Provider\\en_HK\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_HK/PhoneNumber.php',
+ 'Faker\\Provider\\en_IN\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_IN/Address.php',
+ 'Faker\\Provider\\en_IN\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_IN/Internet.php',
+ 'Faker\\Provider\\en_IN\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_IN/Person.php',
+ 'Faker\\Provider\\en_IN\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_IN/PhoneNumber.php',
+ 'Faker\\Provider\\en_NG\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_NG/Address.php',
+ 'Faker\\Provider\\en_NG\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_NG/Internet.php',
+ 'Faker\\Provider\\en_NG\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_NG/Person.php',
+ 'Faker\\Provider\\en_NG\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_NG/PhoneNumber.php',
+ 'Faker\\Provider\\en_NZ\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_NZ/Address.php',
+ 'Faker\\Provider\\en_NZ\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_NZ/Internet.php',
+ 'Faker\\Provider\\en_NZ\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_NZ/PhoneNumber.php',
+ 'Faker\\Provider\\en_PH\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_PH/Address.php',
+ 'Faker\\Provider\\en_PH\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_PH/PhoneNumber.php',
+ 'Faker\\Provider\\en_SG\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_SG/Address.php',
+ 'Faker\\Provider\\en_SG\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_SG/PhoneNumber.php',
+ 'Faker\\Provider\\en_UG\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_UG/Address.php',
+ 'Faker\\Provider\\en_UG\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_UG/Internet.php',
+ 'Faker\\Provider\\en_UG\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_UG/Person.php',
+ 'Faker\\Provider\\en_UG\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_UG/PhoneNumber.php',
+ 'Faker\\Provider\\en_US\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_US/Address.php',
+ 'Faker\\Provider\\en_US\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_US/Company.php',
+ 'Faker\\Provider\\en_US\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_US/Payment.php',
+ 'Faker\\Provider\\en_US\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_US/Person.php',
+ 'Faker\\Provider\\en_US\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_US/PhoneNumber.php',
+ 'Faker\\Provider\\en_US\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_US/Text.php',
+ 'Faker\\Provider\\en_ZA\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_ZA/Address.php',
+ 'Faker\\Provider\\en_ZA\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_ZA/Company.php',
+ 'Faker\\Provider\\en_ZA\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_ZA/Internet.php',
+ 'Faker\\Provider\\en_ZA\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_ZA/Person.php',
+ 'Faker\\Provider\\en_ZA\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/en_ZA/PhoneNumber.php',
+ 'Faker\\Provider\\es_AR\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_AR/Address.php',
+ 'Faker\\Provider\\es_AR\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_AR/Company.php',
+ 'Faker\\Provider\\es_AR\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_AR/Person.php',
+ 'Faker\\Provider\\es_AR\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_AR/PhoneNumber.php',
+ 'Faker\\Provider\\es_ES\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_ES/Address.php',
+ 'Faker\\Provider\\es_ES\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_ES/Color.php',
+ 'Faker\\Provider\\es_ES\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_ES/Company.php',
+ 'Faker\\Provider\\es_ES\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_ES/Internet.php',
+ 'Faker\\Provider\\es_ES\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_ES/Payment.php',
+ 'Faker\\Provider\\es_ES\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_ES/Person.php',
+ 'Faker\\Provider\\es_ES\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_ES/PhoneNumber.php',
+ 'Faker\\Provider\\es_PE\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_PE/Address.php',
+ 'Faker\\Provider\\es_PE\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_PE/Company.php',
+ 'Faker\\Provider\\es_PE\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_PE/Person.php',
+ 'Faker\\Provider\\es_PE\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_PE/PhoneNumber.php',
+ 'Faker\\Provider\\es_VE\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_VE/Address.php',
+ 'Faker\\Provider\\es_VE\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_VE/Company.php',
+ 'Faker\\Provider\\es_VE\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_VE/Internet.php',
+ 'Faker\\Provider\\es_VE\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_VE/Person.php',
+ 'Faker\\Provider\\es_VE\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/es_VE/PhoneNumber.php',
+ 'Faker\\Provider\\et_EE\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/et_EE/Person.php',
+ 'Faker\\Provider\\fa_IR\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fa_IR/Address.php',
+ 'Faker\\Provider\\fa_IR\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fa_IR/Company.php',
+ 'Faker\\Provider\\fa_IR\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fa_IR/Internet.php',
+ 'Faker\\Provider\\fa_IR\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fa_IR/Person.php',
+ 'Faker\\Provider\\fa_IR\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fa_IR/PhoneNumber.php',
+ 'Faker\\Provider\\fa_IR\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fa_IR/Text.php',
+ 'Faker\\Provider\\fi_FI\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fi_FI/Address.php',
+ 'Faker\\Provider\\fi_FI\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fi_FI/Company.php',
+ 'Faker\\Provider\\fi_FI\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fi_FI/Internet.php',
+ 'Faker\\Provider\\fi_FI\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fi_FI/Payment.php',
+ 'Faker\\Provider\\fi_FI\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fi_FI/Person.php',
+ 'Faker\\Provider\\fi_FI\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fi_FI/PhoneNumber.php',
+ 'Faker\\Provider\\fr_BE\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_BE/Address.php',
+ 'Faker\\Provider\\fr_BE\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_BE/Company.php',
+ 'Faker\\Provider\\fr_BE\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_BE/Internet.php',
+ 'Faker\\Provider\\fr_BE\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_BE/Payment.php',
+ 'Faker\\Provider\\fr_BE\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_BE/Person.php',
+ 'Faker\\Provider\\fr_BE\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_BE/PhoneNumber.php',
+ 'Faker\\Provider\\fr_CA\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CA/Address.php',
+ 'Faker\\Provider\\fr_CA\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CA/Company.php',
+ 'Faker\\Provider\\fr_CA\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CA/Person.php',
+ 'Faker\\Provider\\fr_CA\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CA/Text.php',
+ 'Faker\\Provider\\fr_CH\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Address.php',
+ 'Faker\\Provider\\fr_CH\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Company.php',
+ 'Faker\\Provider\\fr_CH\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Internet.php',
+ 'Faker\\Provider\\fr_CH\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Payment.php',
+ 'Faker\\Provider\\fr_CH\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Person.php',
+ 'Faker\\Provider\\fr_CH\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CH/PhoneNumber.php',
+ 'Faker\\Provider\\fr_CH\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_CH/Text.php',
+ 'Faker\\Provider\\fr_FR\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_FR/Address.php',
+ 'Faker\\Provider\\fr_FR\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_FR/Company.php',
+ 'Faker\\Provider\\fr_FR\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_FR/Internet.php',
+ 'Faker\\Provider\\fr_FR\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_FR/Payment.php',
+ 'Faker\\Provider\\fr_FR\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_FR/Person.php',
+ 'Faker\\Provider\\fr_FR\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/fr_FR/PhoneNumber.php',
+ 'Faker\\Provider\\he_IL\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/he_IL/Address.php',
+ 'Faker\\Provider\\he_IL\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/he_IL/Company.php',
+ 'Faker\\Provider\\he_IL\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/he_IL/Payment.php',
+ 'Faker\\Provider\\he_IL\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/he_IL/Person.php',
+ 'Faker\\Provider\\he_IL\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/he_IL/PhoneNumber.php',
+ 'Faker\\Provider\\hr_HR\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hr_HR/Address.php',
+ 'Faker\\Provider\\hr_HR\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hr_HR/Company.php',
+ 'Faker\\Provider\\hr_HR\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hr_HR/Payment.php',
+ 'Faker\\Provider\\hr_HR\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hr_HR/Person.php',
+ 'Faker\\Provider\\hr_HR\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hr_HR/PhoneNumber.php',
+ 'Faker\\Provider\\hu_HU\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hu_HU/Address.php',
+ 'Faker\\Provider\\hu_HU\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hu_HU/Company.php',
+ 'Faker\\Provider\\hu_HU\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hu_HU/Payment.php',
+ 'Faker\\Provider\\hu_HU\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hu_HU/Person.php',
+ 'Faker\\Provider\\hu_HU\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hu_HU/PhoneNumber.php',
+ 'Faker\\Provider\\hy_AM\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hy_AM/Address.php',
+ 'Faker\\Provider\\hy_AM\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hy_AM/Color.php',
+ 'Faker\\Provider\\hy_AM\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hy_AM/Company.php',
+ 'Faker\\Provider\\hy_AM\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hy_AM/Internet.php',
+ 'Faker\\Provider\\hy_AM\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hy_AM/Person.php',
+ 'Faker\\Provider\\hy_AM\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/hy_AM/PhoneNumber.php',
+ 'Faker\\Provider\\id_ID\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/id_ID/Address.php',
+ 'Faker\\Provider\\id_ID\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/id_ID/Color.php',
+ 'Faker\\Provider\\id_ID\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/id_ID/Company.php',
+ 'Faker\\Provider\\id_ID\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/id_ID/Internet.php',
+ 'Faker\\Provider\\id_ID\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/id_ID/Person.php',
+ 'Faker\\Provider\\id_ID\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/id_ID/PhoneNumber.php',
+ 'Faker\\Provider\\is_IS\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/is_IS/Address.php',
+ 'Faker\\Provider\\is_IS\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/is_IS/Company.php',
+ 'Faker\\Provider\\is_IS\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/is_IS/Internet.php',
+ 'Faker\\Provider\\is_IS\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/is_IS/Payment.php',
+ 'Faker\\Provider\\is_IS\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/is_IS/Person.php',
+ 'Faker\\Provider\\is_IS\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/is_IS/PhoneNumber.php',
+ 'Faker\\Provider\\it_CH\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_CH/Address.php',
+ 'Faker\\Provider\\it_CH\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_CH/Company.php',
+ 'Faker\\Provider\\it_CH\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_CH/Internet.php',
+ 'Faker\\Provider\\it_CH\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_CH/Payment.php',
+ 'Faker\\Provider\\it_CH\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_CH/Person.php',
+ 'Faker\\Provider\\it_CH\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_CH/PhoneNumber.php',
+ 'Faker\\Provider\\it_CH\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_CH/Text.php',
+ 'Faker\\Provider\\it_IT\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_IT/Address.php',
+ 'Faker\\Provider\\it_IT\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_IT/Company.php',
+ 'Faker\\Provider\\it_IT\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_IT/Internet.php',
+ 'Faker\\Provider\\it_IT\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_IT/Payment.php',
+ 'Faker\\Provider\\it_IT\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_IT/Person.php',
+ 'Faker\\Provider\\it_IT\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_IT/PhoneNumber.php',
+ 'Faker\\Provider\\it_IT\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/it_IT/Text.php',
+ 'Faker\\Provider\\ja_JP\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ja_JP/Address.php',
+ 'Faker\\Provider\\ja_JP\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ja_JP/Company.php',
+ 'Faker\\Provider\\ja_JP\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ja_JP/Internet.php',
+ 'Faker\\Provider\\ja_JP\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ja_JP/Person.php',
+ 'Faker\\Provider\\ja_JP\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ja_JP/PhoneNumber.php',
+ 'Faker\\Provider\\ja_JP\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ja_JP/Text.php',
+ 'Faker\\Provider\\ka_GE\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Address.php',
+ 'Faker\\Provider\\ka_GE\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Color.php',
+ 'Faker\\Provider\\ka_GE\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Company.php',
+ 'Faker\\Provider\\ka_GE\\DateTime' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ka_GE/DateTime.php',
+ 'Faker\\Provider\\ka_GE\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Internet.php',
+ 'Faker\\Provider\\ka_GE\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Payment.php',
+ 'Faker\\Provider\\ka_GE\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ka_GE/Person.php',
+ 'Faker\\Provider\\ka_GE\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ka_GE/PhoneNumber.php',
+ 'Faker\\Provider\\kk_KZ\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Address.php',
+ 'Faker\\Provider\\kk_KZ\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Color.php',
+ 'Faker\\Provider\\kk_KZ\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Company.php',
+ 'Faker\\Provider\\kk_KZ\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Internet.php',
+ 'Faker\\Provider\\kk_KZ\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Payment.php',
+ 'Faker\\Provider\\kk_KZ\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Person.php',
+ 'Faker\\Provider\\kk_KZ\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/PhoneNumber.php',
+ 'Faker\\Provider\\kk_KZ\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/kk_KZ/Text.php',
+ 'Faker\\Provider\\ko_KR\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ko_KR/Address.php',
+ 'Faker\\Provider\\ko_KR\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ko_KR/Company.php',
+ 'Faker\\Provider\\ko_KR\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ko_KR/Internet.php',
+ 'Faker\\Provider\\ko_KR\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ko_KR/Person.php',
+ 'Faker\\Provider\\ko_KR\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ko_KR/PhoneNumber.php',
+ 'Faker\\Provider\\lt_LT\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lt_LT/Address.php',
+ 'Faker\\Provider\\lt_LT\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lt_LT/Company.php',
+ 'Faker\\Provider\\lt_LT\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lt_LT/Internet.php',
+ 'Faker\\Provider\\lt_LT\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lt_LT/Payment.php',
+ 'Faker\\Provider\\lt_LT\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lt_LT/Person.php',
+ 'Faker\\Provider\\lt_LT\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lt_LT/PhoneNumber.php',
+ 'Faker\\Provider\\lv_LV\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lv_LV/Address.php',
+ 'Faker\\Provider\\lv_LV\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lv_LV/Color.php',
+ 'Faker\\Provider\\lv_LV\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lv_LV/Internet.php',
+ 'Faker\\Provider\\lv_LV\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lv_LV/Payment.php',
+ 'Faker\\Provider\\lv_LV\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lv_LV/Person.php',
+ 'Faker\\Provider\\lv_LV\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/lv_LV/PhoneNumber.php',
+ 'Faker\\Provider\\me_ME\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/me_ME/Address.php',
+ 'Faker\\Provider\\me_ME\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/me_ME/Company.php',
+ 'Faker\\Provider\\me_ME\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/me_ME/Payment.php',
+ 'Faker\\Provider\\me_ME\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/me_ME/Person.php',
+ 'Faker\\Provider\\me_ME\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/me_ME/PhoneNumber.php',
+ 'Faker\\Provider\\mn_MN\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/mn_MN/Person.php',
+ 'Faker\\Provider\\mn_MN\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/mn_MN/PhoneNumber.php',
+ 'Faker\\Provider\\ms_MY\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ms_MY/Address.php',
+ 'Faker\\Provider\\ms_MY\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ms_MY/Company.php',
+ 'Faker\\Provider\\ms_MY\\Miscellaneous' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ms_MY/Miscellaneous.php',
+ 'Faker\\Provider\\ms_MY\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ms_MY/Payment.php',
+ 'Faker\\Provider\\ms_MY\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ms_MY/Person.php',
+ 'Faker\\Provider\\ms_MY\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ms_MY/PhoneNumber.php',
+ 'Faker\\Provider\\nb_NO\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nb_NO/Address.php',
+ 'Faker\\Provider\\nb_NO\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nb_NO/Company.php',
+ 'Faker\\Provider\\nb_NO\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nb_NO/Payment.php',
+ 'Faker\\Provider\\nb_NO\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nb_NO/Person.php',
+ 'Faker\\Provider\\nb_NO\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nb_NO/PhoneNumber.php',
+ 'Faker\\Provider\\ne_NP\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ne_NP/Address.php',
+ 'Faker\\Provider\\ne_NP\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ne_NP/Internet.php',
+ 'Faker\\Provider\\ne_NP\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ne_NP/Person.php',
+ 'Faker\\Provider\\ne_NP\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ne_NP/PhoneNumber.php',
+ 'Faker\\Provider\\nl_BE\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_BE/Address.php',
+ 'Faker\\Provider\\nl_BE\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_BE/Company.php',
+ 'Faker\\Provider\\nl_BE\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_BE/Internet.php',
+ 'Faker\\Provider\\nl_BE\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_BE/Payment.php',
+ 'Faker\\Provider\\nl_BE\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_BE/Person.php',
+ 'Faker\\Provider\\nl_BE\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_BE/PhoneNumber.php',
+ 'Faker\\Provider\\nl_NL\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Address.php',
+ 'Faker\\Provider\\nl_NL\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Color.php',
+ 'Faker\\Provider\\nl_NL\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Company.php',
+ 'Faker\\Provider\\nl_NL\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Internet.php',
+ 'Faker\\Provider\\nl_NL\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Payment.php',
+ 'Faker\\Provider\\nl_NL\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Person.php',
+ 'Faker\\Provider\\nl_NL\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_NL/PhoneNumber.php',
+ 'Faker\\Provider\\nl_NL\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/nl_NL/Text.php',
+ 'Faker\\Provider\\pl_PL\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Address.php',
+ 'Faker\\Provider\\pl_PL\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Company.php',
+ 'Faker\\Provider\\pl_PL\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Internet.php',
+ 'Faker\\Provider\\pl_PL\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Payment.php',
+ 'Faker\\Provider\\pl_PL\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Person.php',
+ 'Faker\\Provider\\pl_PL\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pl_PL/PhoneNumber.php',
+ 'Faker\\Provider\\pl_PL\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pl_PL/Text.php',
+ 'Faker\\Provider\\pt_BR\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_BR/Address.php',
+ 'Faker\\Provider\\pt_BR\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_BR/Company.php',
+ 'Faker\\Provider\\pt_BR\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_BR/Internet.php',
+ 'Faker\\Provider\\pt_BR\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_BR/Payment.php',
+ 'Faker\\Provider\\pt_BR\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_BR/Person.php',
+ 'Faker\\Provider\\pt_BR\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_BR/PhoneNumber.php',
+ 'Faker\\Provider\\pt_PT\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_PT/Address.php',
+ 'Faker\\Provider\\pt_PT\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_PT/Company.php',
+ 'Faker\\Provider\\pt_PT\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_PT/Internet.php',
+ 'Faker\\Provider\\pt_PT\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_PT/Payment.php',
+ 'Faker\\Provider\\pt_PT\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_PT/Person.php',
+ 'Faker\\Provider\\pt_PT\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/pt_PT/PhoneNumber.php',
+ 'Faker\\Provider\\ro_MD\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ro_MD/Address.php',
+ 'Faker\\Provider\\ro_MD\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ro_MD/Payment.php',
+ 'Faker\\Provider\\ro_MD\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ro_MD/Person.php',
+ 'Faker\\Provider\\ro_MD\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ro_MD/PhoneNumber.php',
+ 'Faker\\Provider\\ro_MD\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ro_MD/Text.php',
+ 'Faker\\Provider\\ro_RO\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ro_RO/Address.php',
+ 'Faker\\Provider\\ro_RO\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ro_RO/Payment.php',
+ 'Faker\\Provider\\ro_RO\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ro_RO/Person.php',
+ 'Faker\\Provider\\ro_RO\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ro_RO/PhoneNumber.php',
+ 'Faker\\Provider\\ro_RO\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ro_RO/Text.php',
+ 'Faker\\Provider\\ru_RU\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Address.php',
+ 'Faker\\Provider\\ru_RU\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Color.php',
+ 'Faker\\Provider\\ru_RU\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Company.php',
+ 'Faker\\Provider\\ru_RU\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Internet.php',
+ 'Faker\\Provider\\ru_RU\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Payment.php',
+ 'Faker\\Provider\\ru_RU\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ru_RU/Person.php',
+ 'Faker\\Provider\\ru_RU\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/ru_RU/PhoneNumber.php',
+ 'Faker\\Provider\\sk_SK\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sk_SK/Address.php',
+ 'Faker\\Provider\\sk_SK\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sk_SK/Company.php',
+ 'Faker\\Provider\\sk_SK\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sk_SK/Internet.php',
+ 'Faker\\Provider\\sk_SK\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sk_SK/Payment.php',
+ 'Faker\\Provider\\sk_SK\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sk_SK/Person.php',
+ 'Faker\\Provider\\sk_SK\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sk_SK/PhoneNumber.php',
+ 'Faker\\Provider\\sl_SI\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sl_SI/Address.php',
+ 'Faker\\Provider\\sl_SI\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sl_SI/Company.php',
+ 'Faker\\Provider\\sl_SI\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sl_SI/Internet.php',
+ 'Faker\\Provider\\sl_SI\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sl_SI/Payment.php',
+ 'Faker\\Provider\\sl_SI\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sl_SI/Person.php',
+ 'Faker\\Provider\\sl_SI\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sl_SI/PhoneNumber.php',
+ 'Faker\\Provider\\sr_Cyrl_RS\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sr_Cyrl_RS/Address.php',
+ 'Faker\\Provider\\sr_Cyrl_RS\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sr_Cyrl_RS/Payment.php',
+ 'Faker\\Provider\\sr_Cyrl_RS\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sr_Cyrl_RS/Person.php',
+ 'Faker\\Provider\\sr_Latn_RS\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sr_Latn_RS/Address.php',
+ 'Faker\\Provider\\sr_Latn_RS\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sr_Latn_RS/Payment.php',
+ 'Faker\\Provider\\sr_Latn_RS\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sr_Latn_RS/Person.php',
+ 'Faker\\Provider\\sr_RS\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sr_RS/Address.php',
+ 'Faker\\Provider\\sr_RS\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sr_RS/Payment.php',
+ 'Faker\\Provider\\sr_RS\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sr_RS/Person.php',
+ 'Faker\\Provider\\sv_SE\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sv_SE/Address.php',
+ 'Faker\\Provider\\sv_SE\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sv_SE/Company.php',
+ 'Faker\\Provider\\sv_SE\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sv_SE/Payment.php',
+ 'Faker\\Provider\\sv_SE\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sv_SE/Person.php',
+ 'Faker\\Provider\\sv_SE\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/sv_SE/PhoneNumber.php',
+ 'Faker\\Provider\\th_TH\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/th_TH/Address.php',
+ 'Faker\\Provider\\th_TH\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/th_TH/Color.php',
+ 'Faker\\Provider\\th_TH\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/th_TH/Company.php',
+ 'Faker\\Provider\\th_TH\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/th_TH/Internet.php',
+ 'Faker\\Provider\\th_TH\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/th_TH/Payment.php',
+ 'Faker\\Provider\\th_TH\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/th_TH/Person.php',
+ 'Faker\\Provider\\th_TH\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/th_TH/PhoneNumber.php',
+ 'Faker\\Provider\\tr_TR\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Address.php',
+ 'Faker\\Provider\\tr_TR\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Color.php',
+ 'Faker\\Provider\\tr_TR\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Company.php',
+ 'Faker\\Provider\\tr_TR\\DateTime' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/tr_TR/DateTime.php',
+ 'Faker\\Provider\\tr_TR\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Internet.php',
+ 'Faker\\Provider\\tr_TR\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Payment.php',
+ 'Faker\\Provider\\tr_TR\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/tr_TR/Person.php',
+ 'Faker\\Provider\\tr_TR\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/tr_TR/PhoneNumber.php',
+ 'Faker\\Provider\\uk_UA\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Address.php',
+ 'Faker\\Provider\\uk_UA\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Color.php',
+ 'Faker\\Provider\\uk_UA\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Company.php',
+ 'Faker\\Provider\\uk_UA\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Internet.php',
+ 'Faker\\Provider\\uk_UA\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Payment.php',
+ 'Faker\\Provider\\uk_UA\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/uk_UA/Person.php',
+ 'Faker\\Provider\\uk_UA\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/uk_UA/PhoneNumber.php',
+ 'Faker\\Provider\\vi_VN\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/vi_VN/Address.php',
+ 'Faker\\Provider\\vi_VN\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/vi_VN/Color.php',
+ 'Faker\\Provider\\vi_VN\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/vi_VN/Internet.php',
+ 'Faker\\Provider\\vi_VN\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/vi_VN/Person.php',
+ 'Faker\\Provider\\vi_VN\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/vi_VN/PhoneNumber.php',
+ 'Faker\\Provider\\zh_CN\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Address.php',
+ 'Faker\\Provider\\zh_CN\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Color.php',
+ 'Faker\\Provider\\zh_CN\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Company.php',
+ 'Faker\\Provider\\zh_CN\\DateTime' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_CN/DateTime.php',
+ 'Faker\\Provider\\zh_CN\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Internet.php',
+ 'Faker\\Provider\\zh_CN\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Payment.php',
+ 'Faker\\Provider\\zh_CN\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_CN/Person.php',
+ 'Faker\\Provider\\zh_CN\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_CN/PhoneNumber.php',
+ 'Faker\\Provider\\zh_TW\\Address' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Address.php',
+ 'Faker\\Provider\\zh_TW\\Color' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Color.php',
+ 'Faker\\Provider\\zh_TW\\Company' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Company.php',
+ 'Faker\\Provider\\zh_TW\\DateTime' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_TW/DateTime.php',
+ 'Faker\\Provider\\zh_TW\\Internet' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Internet.php',
+ 'Faker\\Provider\\zh_TW\\Payment' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Payment.php',
+ 'Faker\\Provider\\zh_TW\\Person' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Person.php',
+ 'Faker\\Provider\\zh_TW\\PhoneNumber' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_TW/PhoneNumber.php',
+ 'Faker\\Provider\\zh_TW\\Text' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/Provider/zh_TW/Text.php',
+ 'Faker\\UniqueGenerator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/UniqueGenerator.php',
+ 'Faker\\ValidGenerator' => __DIR__ . '/..' . '/fzaninotto/faker/src/Faker/ValidGenerator.php',
+ 'File_Iterator' => __DIR__ . '/..' . '/phpunit/php-file-iterator/src/Iterator.php',
+ 'File_Iterator_Facade' => __DIR__ . '/..' . '/phpunit/php-file-iterator/src/Facade.php',
+ 'File_Iterator_Factory' => __DIR__ . '/..' . '/phpunit/php-file-iterator/src/Factory.php',
+ 'Hamcrest\\Arrays\\IsArray' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArray.php',
+ 'Hamcrest\\Arrays\\IsArrayContaining' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContaining.php',
+ 'Hamcrest\\Arrays\\IsArrayContainingInAnyOrder' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInAnyOrder.php',
+ 'Hamcrest\\Arrays\\IsArrayContainingInOrder' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInOrder.php',
+ 'Hamcrest\\Arrays\\IsArrayContainingKey' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKey.php',
+ 'Hamcrest\\Arrays\\IsArrayContainingKeyValuePair' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKeyValuePair.php',
+ 'Hamcrest\\Arrays\\IsArrayWithSize' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayWithSize.php',
+ 'Hamcrest\\Arrays\\MatchingOnce' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/MatchingOnce.php',
+ 'Hamcrest\\Arrays\\SeriesMatchingOnce' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/SeriesMatchingOnce.php',
+ 'Hamcrest\\AssertionError' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/AssertionError.php',
+ 'Hamcrest\\BaseDescription' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/BaseDescription.php',
+ 'Hamcrest\\BaseMatcher' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/BaseMatcher.php',
+ 'Hamcrest\\Collection\\IsEmptyTraversable' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsEmptyTraversable.php',
+ 'Hamcrest\\Collection\\IsTraversableWithSize' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsTraversableWithSize.php',
+ 'Hamcrest\\Core\\AllOf' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/AllOf.php',
+ 'Hamcrest\\Core\\AnyOf' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/AnyOf.php',
+ 'Hamcrest\\Core\\CombinableMatcher' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/CombinableMatcher.php',
+ 'Hamcrest\\Core\\DescribedAs' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/DescribedAs.php',
+ 'Hamcrest\\Core\\Every' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Every.php',
+ 'Hamcrest\\Core\\HasToString' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/HasToString.php',
+ 'Hamcrest\\Core\\Is' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Is.php',
+ 'Hamcrest\\Core\\IsAnything' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsAnything.php',
+ 'Hamcrest\\Core\\IsCollectionContaining' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsCollectionContaining.php',
+ 'Hamcrest\\Core\\IsEqual' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsEqual.php',
+ 'Hamcrest\\Core\\IsIdentical' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsIdentical.php',
+ 'Hamcrest\\Core\\IsInstanceOf' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsInstanceOf.php',
+ 'Hamcrest\\Core\\IsNot' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNot.php',
+ 'Hamcrest\\Core\\IsNull' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNull.php',
+ 'Hamcrest\\Core\\IsSame' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsSame.php',
+ 'Hamcrest\\Core\\IsTypeOf' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsTypeOf.php',
+ 'Hamcrest\\Core\\Set' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Set.php',
+ 'Hamcrest\\Core\\ShortcutCombination' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/ShortcutCombination.php',
+ 'Hamcrest\\Description' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Description.php',
+ 'Hamcrest\\DiagnosingMatcher' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/DiagnosingMatcher.php',
+ 'Hamcrest\\FeatureMatcher' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/FeatureMatcher.php',
+ 'Hamcrest\\Internal\\SelfDescribingValue' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Internal/SelfDescribingValue.php',
+ 'Hamcrest\\Matcher' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matcher.php',
+ 'Hamcrest\\MatcherAssert' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/MatcherAssert.php',
+ 'Hamcrest\\Matchers' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matchers.php',
+ 'Hamcrest\\NullDescription' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/NullDescription.php',
+ 'Hamcrest\\Number\\IsCloseTo' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Number/IsCloseTo.php',
+ 'Hamcrest\\Number\\OrderingComparison' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Number/OrderingComparison.php',
+ 'Hamcrest\\SelfDescribing' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/SelfDescribing.php',
+ 'Hamcrest\\StringDescription' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/StringDescription.php',
+ 'Hamcrest\\Text\\IsEmptyString' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEmptyString.php',
+ 'Hamcrest\\Text\\IsEqualIgnoringCase' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringCase.php',
+ 'Hamcrest\\Text\\IsEqualIgnoringWhiteSpace' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringWhiteSpace.php',
+ 'Hamcrest\\Text\\MatchesPattern' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/MatchesPattern.php',
+ 'Hamcrest\\Text\\StringContains' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContains.php',
+ 'Hamcrest\\Text\\StringContainsIgnoringCase' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsIgnoringCase.php',
+ 'Hamcrest\\Text\\StringContainsInOrder' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsInOrder.php',
+ 'Hamcrest\\Text\\StringEndsWith' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringEndsWith.php',
+ 'Hamcrest\\Text\\StringStartsWith' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringStartsWith.php',
+ 'Hamcrest\\Text\\SubstringMatcher' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/SubstringMatcher.php',
+ 'Hamcrest\\TypeSafeDiagnosingMatcher' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/TypeSafeDiagnosingMatcher.php',
+ 'Hamcrest\\TypeSafeMatcher' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/TypeSafeMatcher.php',
+ 'Hamcrest\\Type\\IsArray' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsArray.php',
+ 'Hamcrest\\Type\\IsBoolean' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsBoolean.php',
+ 'Hamcrest\\Type\\IsCallable' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsCallable.php',
+ 'Hamcrest\\Type\\IsDouble' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsDouble.php',
+ 'Hamcrest\\Type\\IsInteger' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsInteger.php',
+ 'Hamcrest\\Type\\IsNumeric' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsNumeric.php',
+ 'Hamcrest\\Type\\IsObject' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsObject.php',
+ 'Hamcrest\\Type\\IsResource' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsResource.php',
+ 'Hamcrest\\Type\\IsScalar' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsScalar.php',
+ 'Hamcrest\\Type\\IsString' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsString.php',
+ 'Hamcrest\\Util' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Util.php',
+ 'Hamcrest\\Xml\\HasXPath' => __DIR__ . '/..' . '/hamcrest/hamcrest-php/hamcrest/Hamcrest/Xml/HasXPath.php',
+ 'Illuminate\\Auth\\Access\\AuthorizationException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Access/AuthorizationException.php',
+ 'Illuminate\\Auth\\Access\\Gate' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Access/Gate.php',
+ 'Illuminate\\Auth\\Access\\HandlesAuthorization' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Access/HandlesAuthorization.php',
+ 'Illuminate\\Auth\\Access\\Response' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Access/Response.php',
+ 'Illuminate\\Auth\\AuthManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/AuthManager.php',
+ 'Illuminate\\Auth\\AuthServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/AuthServiceProvider.php',
+ 'Illuminate\\Auth\\Authenticatable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Authenticatable.php',
+ 'Illuminate\\Auth\\AuthenticationException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/AuthenticationException.php',
+ 'Illuminate\\Auth\\Console\\AuthMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Console/AuthMakeCommand.php',
+ 'Illuminate\\Auth\\Console\\ClearResetsCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Console/ClearResetsCommand.php',
+ 'Illuminate\\Auth\\CreatesUserProviders' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/CreatesUserProviders.php',
+ 'Illuminate\\Auth\\DatabaseUserProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/DatabaseUserProvider.php',
+ 'Illuminate\\Auth\\EloquentUserProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/EloquentUserProvider.php',
+ 'Illuminate\\Auth\\Events\\Attempting' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Events/Attempting.php',
+ 'Illuminate\\Auth\\Events\\Authenticated' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Events/Authenticated.php',
+ 'Illuminate\\Auth\\Events\\Failed' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Events/Failed.php',
+ 'Illuminate\\Auth\\Events\\Lockout' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Events/Lockout.php',
+ 'Illuminate\\Auth\\Events\\Login' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Events/Login.php',
+ 'Illuminate\\Auth\\Events\\Logout' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Events/Logout.php',
+ 'Illuminate\\Auth\\Events\\Registered' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Events/Registered.php',
+ 'Illuminate\\Auth\\GenericUser' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/GenericUser.php',
+ 'Illuminate\\Auth\\GuardHelpers' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/GuardHelpers.php',
+ 'Illuminate\\Auth\\Middleware\\Authenticate' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Middleware/Authenticate.php',
+ 'Illuminate\\Auth\\Middleware\\AuthenticateWithBasicAuth' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Middleware/AuthenticateWithBasicAuth.php',
+ 'Illuminate\\Auth\\Middleware\\Authorize' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Middleware/Authorize.php',
+ 'Illuminate\\Auth\\Notifications\\ResetPassword' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Notifications/ResetPassword.php',
+ 'Illuminate\\Auth\\Passwords\\CanResetPassword' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Passwords/CanResetPassword.php',
+ 'Illuminate\\Auth\\Passwords\\DatabaseTokenRepository' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Passwords/DatabaseTokenRepository.php',
+ 'Illuminate\\Auth\\Passwords\\PasswordBroker' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBroker.php',
+ 'Illuminate\\Auth\\Passwords\\PasswordBrokerManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBrokerManager.php',
+ 'Illuminate\\Auth\\Passwords\\PasswordResetServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Passwords/PasswordResetServiceProvider.php',
+ 'Illuminate\\Auth\\Passwords\\TokenRepositoryInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Passwords/TokenRepositoryInterface.php',
+ 'Illuminate\\Auth\\Recaller' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/Recaller.php',
+ 'Illuminate\\Auth\\RequestGuard' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/RequestGuard.php',
+ 'Illuminate\\Auth\\SessionGuard' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/SessionGuard.php',
+ 'Illuminate\\Auth\\TokenGuard' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Auth/TokenGuard.php',
+ 'Illuminate\\Broadcasting\\BroadcastController' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/BroadcastController.php',
+ 'Illuminate\\Broadcasting\\BroadcastEvent' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/BroadcastEvent.php',
+ 'Illuminate\\Broadcasting\\BroadcastException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/BroadcastException.php',
+ 'Illuminate\\Broadcasting\\BroadcastManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/BroadcastManager.php',
+ 'Illuminate\\Broadcasting\\BroadcastServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/BroadcastServiceProvider.php',
+ 'Illuminate\\Broadcasting\\Broadcasters\\Broadcaster' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/Broadcaster.php',
+ 'Illuminate\\Broadcasting\\Broadcasters\\LogBroadcaster' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/LogBroadcaster.php',
+ 'Illuminate\\Broadcasting\\Broadcasters\\NullBroadcaster' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/NullBroadcaster.php',
+ 'Illuminate\\Broadcasting\\Broadcasters\\PusherBroadcaster' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/PusherBroadcaster.php',
+ 'Illuminate\\Broadcasting\\Broadcasters\\RedisBroadcaster' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/RedisBroadcaster.php',
+ 'Illuminate\\Broadcasting\\Channel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/Channel.php',
+ 'Illuminate\\Broadcasting\\InteractsWithSockets' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/InteractsWithSockets.php',
+ 'Illuminate\\Broadcasting\\PendingBroadcast' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/PendingBroadcast.php',
+ 'Illuminate\\Broadcasting\\PresenceChannel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/PresenceChannel.php',
+ 'Illuminate\\Broadcasting\\PrivateChannel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Broadcasting/PrivateChannel.php',
+ 'Illuminate\\Bus\\BusServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Bus/BusServiceProvider.php',
+ 'Illuminate\\Bus\\Dispatcher' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Bus/Dispatcher.php',
+ 'Illuminate\\Bus\\Queueable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Bus/Queueable.php',
+ 'Illuminate\\Cache\\ApcStore' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/ApcStore.php',
+ 'Illuminate\\Cache\\ApcWrapper' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/ApcWrapper.php',
+ 'Illuminate\\Cache\\ArrayStore' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/ArrayStore.php',
+ 'Illuminate\\Cache\\CacheManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/CacheManager.php',
+ 'Illuminate\\Cache\\CacheServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/CacheServiceProvider.php',
+ 'Illuminate\\Cache\\Console\\CacheTableCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/Console/CacheTableCommand.php',
+ 'Illuminate\\Cache\\Console\\ClearCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/Console/ClearCommand.php',
+ 'Illuminate\\Cache\\Console\\ForgetCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/Console/ForgetCommand.php',
+ 'Illuminate\\Cache\\DatabaseStore' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/DatabaseStore.php',
+ 'Illuminate\\Cache\\Events\\CacheEvent' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/Events/CacheEvent.php',
+ 'Illuminate\\Cache\\Events\\CacheHit' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/Events/CacheHit.php',
+ 'Illuminate\\Cache\\Events\\CacheMissed' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/Events/CacheMissed.php',
+ 'Illuminate\\Cache\\Events\\KeyForgotten' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/Events/KeyForgotten.php',
+ 'Illuminate\\Cache\\Events\\KeyWritten' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/Events/KeyWritten.php',
+ 'Illuminate\\Cache\\FileStore' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/FileStore.php',
+ 'Illuminate\\Cache\\MemcachedConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/MemcachedConnector.php',
+ 'Illuminate\\Cache\\MemcachedStore' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/MemcachedStore.php',
+ 'Illuminate\\Cache\\NullStore' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/NullStore.php',
+ 'Illuminate\\Cache\\RateLimiter' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/RateLimiter.php',
+ 'Illuminate\\Cache\\RedisStore' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/RedisStore.php',
+ 'Illuminate\\Cache\\RedisTaggedCache' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/RedisTaggedCache.php',
+ 'Illuminate\\Cache\\Repository' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/Repository.php',
+ 'Illuminate\\Cache\\RetrievesMultipleKeys' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/RetrievesMultipleKeys.php',
+ 'Illuminate\\Cache\\TagSet' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/TagSet.php',
+ 'Illuminate\\Cache\\TaggableStore' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/TaggableStore.php',
+ 'Illuminate\\Cache\\TaggedCache' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cache/TaggedCache.php',
+ 'Illuminate\\Config\\Repository' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Config/Repository.php',
+ 'Illuminate\\Console\\Application' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Application.php',
+ 'Illuminate\\Console\\Command' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Command.php',
+ 'Illuminate\\Console\\ConfirmableTrait' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/ConfirmableTrait.php',
+ 'Illuminate\\Console\\DetectsApplicationNamespace' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/DetectsApplicationNamespace.php',
+ 'Illuminate\\Console\\Events\\ArtisanStarting' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Events/ArtisanStarting.php',
+ 'Illuminate\\Console\\GeneratorCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/GeneratorCommand.php',
+ 'Illuminate\\Console\\OutputStyle' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/OutputStyle.php',
+ 'Illuminate\\Console\\Parser' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Parser.php',
+ 'Illuminate\\Console\\Scheduling\\CacheMutex' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Scheduling/CacheMutex.php',
+ 'Illuminate\\Console\\Scheduling\\CallbackEvent' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Scheduling/CallbackEvent.php',
+ 'Illuminate\\Console\\Scheduling\\CommandBuilder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Scheduling/CommandBuilder.php',
+ 'Illuminate\\Console\\Scheduling\\Event' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Scheduling/Event.php',
+ 'Illuminate\\Console\\Scheduling\\ManagesFrequencies' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Scheduling/ManagesFrequencies.php',
+ 'Illuminate\\Console\\Scheduling\\Mutex' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Scheduling/Mutex.php',
+ 'Illuminate\\Console\\Scheduling\\Schedule' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Scheduling/Schedule.php',
+ 'Illuminate\\Console\\Scheduling\\ScheduleFinishCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleFinishCommand.php',
+ 'Illuminate\\Console\\Scheduling\\ScheduleRunCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleRunCommand.php',
+ 'Illuminate\\Container\\BoundMethod' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Container/BoundMethod.php',
+ 'Illuminate\\Container\\Container' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Container/Container.php',
+ 'Illuminate\\Container\\ContextualBindingBuilder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Container/ContextualBindingBuilder.php',
+ 'Illuminate\\Contracts\\Auth\\Access\\Authorizable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/Access/Authorizable.php',
+ 'Illuminate\\Contracts\\Auth\\Access\\Gate' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/Access/Gate.php',
+ 'Illuminate\\Contracts\\Auth\\Authenticatable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/Authenticatable.php',
+ 'Illuminate\\Contracts\\Auth\\CanResetPassword' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/CanResetPassword.php',
+ 'Illuminate\\Contracts\\Auth\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/Factory.php',
+ 'Illuminate\\Contracts\\Auth\\Guard' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/Guard.php',
+ 'Illuminate\\Contracts\\Auth\\PasswordBroker' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/PasswordBroker.php',
+ 'Illuminate\\Contracts\\Auth\\PasswordBrokerFactory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/PasswordBrokerFactory.php',
+ 'Illuminate\\Contracts\\Auth\\StatefulGuard' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/StatefulGuard.php',
+ 'Illuminate\\Contracts\\Auth\\SupportsBasicAuth' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/SupportsBasicAuth.php',
+ 'Illuminate\\Contracts\\Auth\\UserProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Auth/UserProvider.php',
+ 'Illuminate\\Contracts\\Broadcasting\\Broadcaster' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Broadcasting/Broadcaster.php',
+ 'Illuminate\\Contracts\\Broadcasting\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Broadcasting/Factory.php',
+ 'Illuminate\\Contracts\\Broadcasting\\ShouldBroadcast' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Broadcasting/ShouldBroadcast.php',
+ 'Illuminate\\Contracts\\Broadcasting\\ShouldBroadcastNow' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Broadcasting/ShouldBroadcastNow.php',
+ 'Illuminate\\Contracts\\Bus\\Dispatcher' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Bus/Dispatcher.php',
+ 'Illuminate\\Contracts\\Bus\\QueueingDispatcher' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Bus/QueueingDispatcher.php',
+ 'Illuminate\\Contracts\\Cache\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Cache/Factory.php',
+ 'Illuminate\\Contracts\\Cache\\Repository' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Cache/Repository.php',
+ 'Illuminate\\Contracts\\Cache\\Store' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Cache/Store.php',
+ 'Illuminate\\Contracts\\Config\\Repository' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Config/Repository.php',
+ 'Illuminate\\Contracts\\Console\\Application' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Console/Application.php',
+ 'Illuminate\\Contracts\\Console\\Kernel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Console/Kernel.php',
+ 'Illuminate\\Contracts\\Container\\BindingResolutionException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Container/BindingResolutionException.php',
+ 'Illuminate\\Contracts\\Container\\Container' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Container/Container.php',
+ 'Illuminate\\Contracts\\Container\\ContextualBindingBuilder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Container/ContextualBindingBuilder.php',
+ 'Illuminate\\Contracts\\Cookie\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Cookie/Factory.php',
+ 'Illuminate\\Contracts\\Cookie\\QueueingFactory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Cookie/QueueingFactory.php',
+ 'Illuminate\\Contracts\\Database\\ModelIdentifier' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Database/ModelIdentifier.php',
+ 'Illuminate\\Contracts\\Debug\\ExceptionHandler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Debug/ExceptionHandler.php',
+ 'Illuminate\\Contracts\\Encryption\\DecryptException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Encryption/DecryptException.php',
+ 'Illuminate\\Contracts\\Encryption\\EncryptException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Encryption/EncryptException.php',
+ 'Illuminate\\Contracts\\Encryption\\Encrypter' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Encryption/Encrypter.php',
+ 'Illuminate\\Contracts\\Events\\Dispatcher' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Events/Dispatcher.php',
+ 'Illuminate\\Contracts\\Filesystem\\Cloud' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Filesystem/Cloud.php',
+ 'Illuminate\\Contracts\\Filesystem\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Filesystem/Factory.php',
+ 'Illuminate\\Contracts\\Filesystem\\FileNotFoundException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Filesystem/FileNotFoundException.php',
+ 'Illuminate\\Contracts\\Filesystem\\Filesystem' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Filesystem/Filesystem.php',
+ 'Illuminate\\Contracts\\Foundation\\Application' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Foundation/Application.php',
+ 'Illuminate\\Contracts\\Hashing\\Hasher' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Hashing/Hasher.php',
+ 'Illuminate\\Contracts\\Http\\Kernel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Http/Kernel.php',
+ 'Illuminate\\Contracts\\Logging\\Log' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Logging/Log.php',
+ 'Illuminate\\Contracts\\Mail\\MailQueue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Mail/MailQueue.php',
+ 'Illuminate\\Contracts\\Mail\\Mailable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Mail/Mailable.php',
+ 'Illuminate\\Contracts\\Mail\\Mailer' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Mail/Mailer.php',
+ 'Illuminate\\Contracts\\Notifications\\Dispatcher' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Notifications/Dispatcher.php',
+ 'Illuminate\\Contracts\\Notifications\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Notifications/Factory.php',
+ 'Illuminate\\Contracts\\Pagination\\LengthAwarePaginator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Pagination/LengthAwarePaginator.php',
+ 'Illuminate\\Contracts\\Pagination\\Paginator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Pagination/Paginator.php',
+ 'Illuminate\\Contracts\\Pipeline\\Hub' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Pipeline/Hub.php',
+ 'Illuminate\\Contracts\\Pipeline\\Pipeline' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Pipeline/Pipeline.php',
+ 'Illuminate\\Contracts\\Queue\\EntityNotFoundException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Queue/EntityNotFoundException.php',
+ 'Illuminate\\Contracts\\Queue\\EntityResolver' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Queue/EntityResolver.php',
+ 'Illuminate\\Contracts\\Queue\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Queue/Factory.php',
+ 'Illuminate\\Contracts\\Queue\\Job' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Queue/Job.php',
+ 'Illuminate\\Contracts\\Queue\\Monitor' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Queue/Monitor.php',
+ 'Illuminate\\Contracts\\Queue\\Queue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Queue/Queue.php',
+ 'Illuminate\\Contracts\\Queue\\QueueableCollection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Queue/QueueableCollection.php',
+ 'Illuminate\\Contracts\\Queue\\QueueableEntity' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Queue/QueueableEntity.php',
+ 'Illuminate\\Contracts\\Queue\\ShouldQueue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Queue/ShouldQueue.php',
+ 'Illuminate\\Contracts\\Redis\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Redis/Factory.php',
+ 'Illuminate\\Contracts\\Routing\\BindingRegistrar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Routing/BindingRegistrar.php',
+ 'Illuminate\\Contracts\\Routing\\Registrar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Routing/Registrar.php',
+ 'Illuminate\\Contracts\\Routing\\ResponseFactory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Routing/ResponseFactory.php',
+ 'Illuminate\\Contracts\\Routing\\UrlGenerator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Routing/UrlGenerator.php',
+ 'Illuminate\\Contracts\\Routing\\UrlRoutable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Routing/UrlRoutable.php',
+ 'Illuminate\\Contracts\\Session\\Session' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Session/Session.php',
+ 'Illuminate\\Contracts\\Support\\Arrayable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Support/Arrayable.php',
+ 'Illuminate\\Contracts\\Support\\Htmlable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Support/Htmlable.php',
+ 'Illuminate\\Contracts\\Support\\Jsonable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Support/Jsonable.php',
+ 'Illuminate\\Contracts\\Support\\MessageBag' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Support/MessageBag.php',
+ 'Illuminate\\Contracts\\Support\\MessageProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Support/MessageProvider.php',
+ 'Illuminate\\Contracts\\Support\\Renderable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Support/Renderable.php',
+ 'Illuminate\\Contracts\\Translation\\Translator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Translation/Translator.php',
+ 'Illuminate\\Contracts\\Validation\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Validation/Factory.php',
+ 'Illuminate\\Contracts\\Validation\\ValidatesWhenResolved' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Validation/ValidatesWhenResolved.php',
+ 'Illuminate\\Contracts\\Validation\\Validator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/Validation/Validator.php',
+ 'Illuminate\\Contracts\\View\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/View/Factory.php',
+ 'Illuminate\\Contracts\\View\\View' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Contracts/View/View.php',
+ 'Illuminate\\Cookie\\CookieJar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cookie/CookieJar.php',
+ 'Illuminate\\Cookie\\CookieServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cookie/CookieServiceProvider.php',
+ 'Illuminate\\Cookie\\Middleware\\AddQueuedCookiesToResponse' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cookie/Middleware/AddQueuedCookiesToResponse.php',
+ 'Illuminate\\Cookie\\Middleware\\EncryptCookies' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Cookie/Middleware/EncryptCookies.php',
+ 'Illuminate\\Database\\Capsule\\Manager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Capsule/Manager.php',
+ 'Illuminate\\Database\\Concerns\\BuildsQueries' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Concerns/BuildsQueries.php',
+ 'Illuminate\\Database\\Concerns\\ManagesTransactions' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Concerns/ManagesTransactions.php',
+ 'Illuminate\\Database\\Connection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Connection.php',
+ 'Illuminate\\Database\\ConnectionInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/ConnectionInterface.php',
+ 'Illuminate\\Database\\ConnectionResolver' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/ConnectionResolver.php',
+ 'Illuminate\\Database\\ConnectionResolverInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/ConnectionResolverInterface.php',
+ 'Illuminate\\Database\\Connectors\\ConnectionFactory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Connectors/ConnectionFactory.php',
+ 'Illuminate\\Database\\Connectors\\Connector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Connectors/Connector.php',
+ 'Illuminate\\Database\\Connectors\\ConnectorInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Connectors/ConnectorInterface.php',
+ 'Illuminate\\Database\\Connectors\\MySqlConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Connectors/MySqlConnector.php',
+ 'Illuminate\\Database\\Connectors\\PostgresConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Connectors/PostgresConnector.php',
+ 'Illuminate\\Database\\Connectors\\SQLiteConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Connectors/SQLiteConnector.php',
+ 'Illuminate\\Database\\Connectors\\SqlServerConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Connectors/SqlServerConnector.php',
+ 'Illuminate\\Database\\Console\\Migrations\\BaseCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Console/Migrations/BaseCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\InstallCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Console/Migrations/InstallCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\MigrateCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\MigrateMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateMakeCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\RefreshCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Console/Migrations/RefreshCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\ResetCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Console/Migrations/ResetCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\RollbackCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Console/Migrations/RollbackCommand.php',
+ 'Illuminate\\Database\\Console\\Migrations\\StatusCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Console/Migrations/StatusCommand.php',
+ 'Illuminate\\Database\\Console\\Seeds\\SeedCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Console/Seeds/SeedCommand.php',
+ 'Illuminate\\Database\\Console\\Seeds\\SeederMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Console/Seeds/SeederMakeCommand.php',
+ 'Illuminate\\Database\\DatabaseManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/DatabaseManager.php',
+ 'Illuminate\\Database\\DatabaseServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/DatabaseServiceProvider.php',
+ 'Illuminate\\Database\\DetectsDeadlocks' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/DetectsDeadlocks.php',
+ 'Illuminate\\Database\\DetectsLostConnections' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/DetectsLostConnections.php',
+ 'Illuminate\\Database\\Eloquent\\Builder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Builder.php',
+ 'Illuminate\\Database\\Eloquent\\Collection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Collection.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\GuardsAttributes' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/GuardsAttributes.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HasAttributes' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasAttributes.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HasEvents' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasEvents.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HasGlobalScopes' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasGlobalScopes.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HasRelationships' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasRelationships.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HasTimestamps' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasTimestamps.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\HidesAttributes' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HidesAttributes.php',
+ 'Illuminate\\Database\\Eloquent\\Concerns\\QueriesRelationships' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/QueriesRelationships.php',
+ 'Illuminate\\Database\\Eloquent\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Factory.php',
+ 'Illuminate\\Database\\Eloquent\\FactoryBuilder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php',
+ 'Illuminate\\Database\\Eloquent\\JsonEncodingException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/JsonEncodingException.php',
+ 'Illuminate\\Database\\Eloquent\\MassAssignmentException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/MassAssignmentException.php',
+ 'Illuminate\\Database\\Eloquent\\Model' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Model.php',
+ 'Illuminate\\Database\\Eloquent\\ModelNotFoundException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/ModelNotFoundException.php',
+ 'Illuminate\\Database\\Eloquent\\QueueEntityResolver' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/QueueEntityResolver.php',
+ 'Illuminate\\Database\\Eloquent\\RelationNotFoundException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/RelationNotFoundException.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\BelongsTo' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsTo.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\BelongsToMany' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsToMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\Concerns\\InteractsWithPivotTable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/InteractsWithPivotTable.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\Concerns\\SupportsDefaultModels' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/SupportsDefaultModels.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\HasMany' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\HasManyThrough' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasManyThrough.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\HasOne' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOne.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\HasOneOrMany' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOneOrMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphMany' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphOne' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOne.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphOneOrMany' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOneOrMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphPivot' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphPivot.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphTo' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphTo.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\MorphToMany' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphToMany.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\Pivot' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Pivot.php',
+ 'Illuminate\\Database\\Eloquent\\Relations\\Relation' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Relation.php',
+ 'Illuminate\\Database\\Eloquent\\Scope' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/Scope.php',
+ 'Illuminate\\Database\\Eloquent\\SoftDeletes' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/SoftDeletes.php',
+ 'Illuminate\\Database\\Eloquent\\SoftDeletingScope' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Eloquent/SoftDeletingScope.php',
+ 'Illuminate\\Database\\Events\\ConnectionEvent' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Events/ConnectionEvent.php',
+ 'Illuminate\\Database\\Events\\QueryExecuted' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Events/QueryExecuted.php',
+ 'Illuminate\\Database\\Events\\StatementPrepared' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Events/StatementPrepared.php',
+ 'Illuminate\\Database\\Events\\TransactionBeginning' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Events/TransactionBeginning.php',
+ 'Illuminate\\Database\\Events\\TransactionCommitted' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Events/TransactionCommitted.php',
+ 'Illuminate\\Database\\Events\\TransactionRolledBack' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Events/TransactionRolledBack.php',
+ 'Illuminate\\Database\\Grammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Grammar.php',
+ 'Illuminate\\Database\\MigrationServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/MigrationServiceProvider.php',
+ 'Illuminate\\Database\\Migrations\\DatabaseMigrationRepository' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Migrations/DatabaseMigrationRepository.php',
+ 'Illuminate\\Database\\Migrations\\Migration' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Migrations/Migration.php',
+ 'Illuminate\\Database\\Migrations\\MigrationCreator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Migrations/MigrationCreator.php',
+ 'Illuminate\\Database\\Migrations\\MigrationRepositoryInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Migrations/MigrationRepositoryInterface.php',
+ 'Illuminate\\Database\\Migrations\\Migrator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Migrations/Migrator.php',
+ 'Illuminate\\Database\\MySqlConnection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/MySqlConnection.php',
+ 'Illuminate\\Database\\PostgresConnection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/PostgresConnection.php',
+ 'Illuminate\\Database\\QueryException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/QueryException.php',
+ 'Illuminate\\Database\\Query\\Builder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Builder.php',
+ 'Illuminate\\Database\\Query\\Expression' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Expression.php',
+ 'Illuminate\\Database\\Query\\Grammars\\Grammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Grammars/Grammar.php',
+ 'Illuminate\\Database\\Query\\Grammars\\MySqlGrammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Grammars/MySqlGrammar.php',
+ 'Illuminate\\Database\\Query\\Grammars\\PostgresGrammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Grammars/PostgresGrammar.php',
+ 'Illuminate\\Database\\Query\\Grammars\\SQLiteGrammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Grammars/SQLiteGrammar.php',
+ 'Illuminate\\Database\\Query\\Grammars\\SqlServerGrammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Grammars/SqlServerGrammar.php',
+ 'Illuminate\\Database\\Query\\JoinClause' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/JoinClause.php',
+ 'Illuminate\\Database\\Query\\JsonExpression' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/JsonExpression.php',
+ 'Illuminate\\Database\\Query\\Processors\\MySqlProcessor' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Processors/MySqlProcessor.php',
+ 'Illuminate\\Database\\Query\\Processors\\PostgresProcessor' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Processors/PostgresProcessor.php',
+ 'Illuminate\\Database\\Query\\Processors\\Processor' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Processors/Processor.php',
+ 'Illuminate\\Database\\Query\\Processors\\SQLiteProcessor' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Processors/SQLiteProcessor.php',
+ 'Illuminate\\Database\\Query\\Processors\\SqlServerProcessor' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Query/Processors/SqlServerProcessor.php',
+ 'Illuminate\\Database\\SQLiteConnection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/SQLiteConnection.php',
+ 'Illuminate\\Database\\Schema\\Blueprint' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/Blueprint.php',
+ 'Illuminate\\Database\\Schema\\Builder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/Builder.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\ChangeColumn' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/ChangeColumn.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\Grammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/Grammar.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\MySqlGrammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/MySqlGrammar.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\PostgresGrammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/PostgresGrammar.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\RenameColumn' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/RenameColumn.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\SQLiteGrammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/SQLiteGrammar.php',
+ 'Illuminate\\Database\\Schema\\Grammars\\SqlServerGrammar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/Grammars/SqlServerGrammar.php',
+ 'Illuminate\\Database\\Schema\\MySqlBuilder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/MySqlBuilder.php',
+ 'Illuminate\\Database\\Schema\\PostgresBuilder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Schema/PostgresBuilder.php',
+ 'Illuminate\\Database\\Seeder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/Seeder.php',
+ 'Illuminate\\Database\\SqlServerConnection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Database/SqlServerConnection.php',
+ 'Illuminate\\Encryption\\Encrypter' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Encryption/Encrypter.php',
+ 'Illuminate\\Encryption\\EncryptionServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Encryption/EncryptionServiceProvider.php',
+ 'Illuminate\\Events\\CallQueuedHandler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Events/CallQueuedHandler.php',
+ 'Illuminate\\Events\\CallQueuedListener' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Events/CallQueuedListener.php',
+ 'Illuminate\\Events\\Dispatcher' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Events/Dispatcher.php',
+ 'Illuminate\\Events\\EventServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Events/EventServiceProvider.php',
+ 'Illuminate\\Filesystem\\Filesystem' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Filesystem/Filesystem.php',
+ 'Illuminate\\Filesystem\\FilesystemAdapter' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php',
+ 'Illuminate\\Filesystem\\FilesystemManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Filesystem/FilesystemManager.php',
+ 'Illuminate\\Filesystem\\FilesystemServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Filesystem/FilesystemServiceProvider.php',
+ 'Illuminate\\Foundation\\AliasLoader' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/AliasLoader.php',
+ 'Illuminate\\Foundation\\Application' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Application.php',
+ 'Illuminate\\Foundation\\Auth\\Access\\Authorizable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Auth/Access/Authorizable.php',
+ 'Illuminate\\Foundation\\Auth\\Access\\AuthorizesRequests' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Auth/Access/AuthorizesRequests.php',
+ 'Illuminate\\Foundation\\Auth\\AuthenticatesUsers' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php',
+ 'Illuminate\\Foundation\\Auth\\RedirectsUsers' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Auth/RedirectsUsers.php',
+ 'Illuminate\\Foundation\\Auth\\RegistersUsers' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Auth/RegistersUsers.php',
+ 'Illuminate\\Foundation\\Auth\\ResetsPasswords' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Auth/ResetsPasswords.php',
+ 'Illuminate\\Foundation\\Auth\\SendsPasswordResetEmails' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Auth/SendsPasswordResetEmails.php',
+ 'Illuminate\\Foundation\\Auth\\ThrottlesLogins' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Auth/ThrottlesLogins.php',
+ 'Illuminate\\Foundation\\Auth\\User' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Auth/User.php',
+ 'Illuminate\\Foundation\\Bootstrap\\BootProviders' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/BootProviders.php',
+ 'Illuminate\\Foundation\\Bootstrap\\HandleExceptions' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/HandleExceptions.php',
+ 'Illuminate\\Foundation\\Bootstrap\\LoadConfiguration' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadConfiguration.php',
+ 'Illuminate\\Foundation\\Bootstrap\\LoadEnvironmentVariables' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadEnvironmentVariables.php',
+ 'Illuminate\\Foundation\\Bootstrap\\RegisterFacades' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterFacades.php',
+ 'Illuminate\\Foundation\\Bootstrap\\RegisterProviders' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterProviders.php',
+ 'Illuminate\\Foundation\\Bootstrap\\SetRequestForConsole' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Bootstrap/SetRequestForConsole.php',
+ 'Illuminate\\Foundation\\Bus\\Dispatchable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Bus/Dispatchable.php',
+ 'Illuminate\\Foundation\\Bus\\DispatchesJobs' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Bus/DispatchesJobs.php',
+ 'Illuminate\\Foundation\\Bus\\PendingDispatch' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Bus/PendingDispatch.php',
+ 'Illuminate\\Foundation\\ComposerScripts' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/ComposerScripts.php',
+ 'Illuminate\\Foundation\\Console\\AppNameCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/AppNameCommand.php',
+ 'Illuminate\\Foundation\\Console\\ClearCompiledCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/ClearCompiledCommand.php',
+ 'Illuminate\\Foundation\\Console\\ClosureCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/ClosureCommand.php',
+ 'Illuminate\\Foundation\\Console\\ConfigCacheCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/ConfigCacheCommand.php',
+ 'Illuminate\\Foundation\\Console\\ConfigClearCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/ConfigClearCommand.php',
+ 'Illuminate\\Foundation\\Console\\ConsoleMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/ConsoleMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\DownCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/DownCommand.php',
+ 'Illuminate\\Foundation\\Console\\EnvironmentCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/EnvironmentCommand.php',
+ 'Illuminate\\Foundation\\Console\\EventGenerateCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/EventGenerateCommand.php',
+ 'Illuminate\\Foundation\\Console\\EventMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/EventMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\JobMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/JobMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\Kernel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/Kernel.php',
+ 'Illuminate\\Foundation\\Console\\KeyGenerateCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/KeyGenerateCommand.php',
+ 'Illuminate\\Foundation\\Console\\ListenerMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/ListenerMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\MailMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/MailMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\ModelMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/ModelMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\NotificationMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/NotificationMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\OptimizeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/OptimizeCommand.php',
+ 'Illuminate\\Foundation\\Console\\PolicyMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/PolicyMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\ProviderMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/ProviderMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\QueuedCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/QueuedCommand.php',
+ 'Illuminate\\Foundation\\Console\\RequestMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/RequestMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\RouteCacheCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/RouteCacheCommand.php',
+ 'Illuminate\\Foundation\\Console\\RouteClearCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/RouteClearCommand.php',
+ 'Illuminate\\Foundation\\Console\\RouteListCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/RouteListCommand.php',
+ 'Illuminate\\Foundation\\Console\\ServeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/ServeCommand.php',
+ 'Illuminate\\Foundation\\Console\\StorageLinkCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/StorageLinkCommand.php',
+ 'Illuminate\\Foundation\\Console\\TestMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/TestMakeCommand.php',
+ 'Illuminate\\Foundation\\Console\\UpCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/UpCommand.php',
+ 'Illuminate\\Foundation\\Console\\VendorPublishCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/VendorPublishCommand.php',
+ 'Illuminate\\Foundation\\Console\\ViewClearCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Console/ViewClearCommand.php',
+ 'Illuminate\\Foundation\\EnvironmentDetector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/EnvironmentDetector.php',
+ 'Illuminate\\Foundation\\Events\\Dispatchable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Events/Dispatchable.php',
+ 'Illuminate\\Foundation\\Events\\LocaleUpdated' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Events/LocaleUpdated.php',
+ 'Illuminate\\Foundation\\Exceptions\\Handler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Exceptions/Handler.php',
+ 'Illuminate\\Foundation\\Http\\Events\\RequestHandled' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Http/Events/RequestHandled.php',
+ 'Illuminate\\Foundation\\Http\\Exceptions\\MaintenanceModeException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Http/Exceptions/MaintenanceModeException.php',
+ 'Illuminate\\Foundation\\Http\\FormRequest' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Http/FormRequest.php',
+ 'Illuminate\\Foundation\\Http\\Kernel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Http/Kernel.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\CheckForMaintenanceMode' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/CheckForMaintenanceMode.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\ConvertEmptyStringsToNull' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ConvertEmptyStringsToNull.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\TransformsRequest' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/TransformsRequest.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\TrimStrings' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/TrimStrings.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\ValidatePostSize' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ValidatePostSize.php',
+ 'Illuminate\\Foundation\\Http\\Middleware\\VerifyCsrfToken' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Http/Middleware/VerifyCsrfToken.php',
+ 'Illuminate\\Foundation\\Inspiring' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Inspiring.php',
+ 'Illuminate\\Foundation\\ProviderRepository' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/ProviderRepository.php',
+ 'Illuminate\\Foundation\\Providers\\ArtisanServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Providers/ArtisanServiceProvider.php',
+ 'Illuminate\\Foundation\\Providers\\ComposerServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Providers/ComposerServiceProvider.php',
+ 'Illuminate\\Foundation\\Providers\\ConsoleSupportServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Providers/ConsoleSupportServiceProvider.php',
+ 'Illuminate\\Foundation\\Providers\\FormRequestServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Providers/FormRequestServiceProvider.php',
+ 'Illuminate\\Foundation\\Providers\\FoundationServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Providers/FoundationServiceProvider.php',
+ 'Illuminate\\Foundation\\Support\\Providers\\AuthServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Support/Providers/AuthServiceProvider.php',
+ 'Illuminate\\Foundation\\Support\\Providers\\EventServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Support/Providers/EventServiceProvider.php',
+ 'Illuminate\\Foundation\\Support\\Providers\\RouteServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Support/Providers/RouteServiceProvider.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\InteractsWithAuthentication' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithAuthentication.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\InteractsWithConsole' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithConsole.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\InteractsWithContainer' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithContainer.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\InteractsWithDatabase' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithDatabase.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\InteractsWithSession' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithSession.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\MakesHttpRequests' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MakesHttpRequests.php',
+ 'Illuminate\\Foundation\\Testing\\Concerns\\MocksApplicationServices' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MocksApplicationServices.php',
+ 'Illuminate\\Foundation\\Testing\\Constraints\\HasInDatabase' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/HasInDatabase.php',
+ 'Illuminate\\Foundation\\Testing\\Constraints\\SoftDeletedInDatabase' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/SoftDeletedInDatabase.php',
+ 'Illuminate\\Foundation\\Testing\\DatabaseMigrations' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseMigrations.php',
+ 'Illuminate\\Foundation\\Testing\\DatabaseTransactions' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseTransactions.php',
+ 'Illuminate\\Foundation\\Testing\\HttpException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/HttpException.php',
+ 'Illuminate\\Foundation\\Testing\\TestCase' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/TestCase.php',
+ 'Illuminate\\Foundation\\Testing\\TestResponse' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/TestResponse.php',
+ 'Illuminate\\Foundation\\Testing\\WithoutEvents' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/WithoutEvents.php',
+ 'Illuminate\\Foundation\\Testing\\WithoutMiddleware' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Testing/WithoutMiddleware.php',
+ 'Illuminate\\Foundation\\Validation\\ValidatesRequests' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Foundation/Validation/ValidatesRequests.php',
+ 'Illuminate\\Hashing\\BcryptHasher' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Hashing/BcryptHasher.php',
+ 'Illuminate\\Hashing\\HashServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Hashing/HashServiceProvider.php',
+ 'Illuminate\\Http\\Concerns\\InteractsWithContentTypes' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithContentTypes.php',
+ 'Illuminate\\Http\\Concerns\\InteractsWithFlashData' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithFlashData.php',
+ 'Illuminate\\Http\\Concerns\\InteractsWithInput' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithInput.php',
+ 'Illuminate\\Http\\Exceptions\\HttpResponseException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Exceptions/HttpResponseException.php',
+ 'Illuminate\\Http\\Exceptions\\PostTooLargeException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Exceptions/PostTooLargeException.php',
+ 'Illuminate\\Http\\File' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/File.php',
+ 'Illuminate\\Http\\FileHelpers' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/FileHelpers.php',
+ 'Illuminate\\Http\\JsonResponse' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/JsonResponse.php',
+ 'Illuminate\\Http\\Middleware\\CheckResponseForModifications' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Middleware/CheckResponseForModifications.php',
+ 'Illuminate\\Http\\Middleware\\FrameGuard' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Middleware/FrameGuard.php',
+ 'Illuminate\\Http\\RedirectResponse' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/RedirectResponse.php',
+ 'Illuminate\\Http\\Request' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Request.php',
+ 'Illuminate\\Http\\Response' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Response.php',
+ 'Illuminate\\Http\\ResponseTrait' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/ResponseTrait.php',
+ 'Illuminate\\Http\\Testing\\File' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Testing/File.php',
+ 'Illuminate\\Http\\Testing\\FileFactory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Testing/FileFactory.php',
+ 'Illuminate\\Http\\Testing\\MimeType' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/Testing/MimeType.php',
+ 'Illuminate\\Http\\UploadedFile' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Http/UploadedFile.php',
+ 'Illuminate\\Log\\Events\\MessageLogged' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Log/Events/MessageLogged.php',
+ 'Illuminate\\Log\\LogServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Log/LogServiceProvider.php',
+ 'Illuminate\\Log\\Writer' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Log/Writer.php',
+ 'Illuminate\\Mail\\Events\\MessageSending' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Events/MessageSending.php',
+ 'Illuminate\\Mail\\Events\\MessageSent' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Events/MessageSent.php',
+ 'Illuminate\\Mail\\MailServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/MailServiceProvider.php',
+ 'Illuminate\\Mail\\Mailable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Mailable.php',
+ 'Illuminate\\Mail\\Mailer' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Mailer.php',
+ 'Illuminate\\Mail\\Markdown' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Markdown.php',
+ 'Illuminate\\Mail\\Message' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Message.php',
+ 'Illuminate\\Mail\\PendingMail' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/PendingMail.php',
+ 'Illuminate\\Mail\\SendQueuedMailable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/SendQueuedMailable.php',
+ 'Illuminate\\Mail\\TransportManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/TransportManager.php',
+ 'Illuminate\\Mail\\Transport\\ArrayTransport' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Transport/ArrayTransport.php',
+ 'Illuminate\\Mail\\Transport\\LogTransport' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Transport/LogTransport.php',
+ 'Illuminate\\Mail\\Transport\\MailgunTransport' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Transport/MailgunTransport.php',
+ 'Illuminate\\Mail\\Transport\\MandrillTransport' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Transport/MandrillTransport.php',
+ 'Illuminate\\Mail\\Transport\\SesTransport' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Transport/SesTransport.php',
+ 'Illuminate\\Mail\\Transport\\SparkPostTransport' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Transport/SparkPostTransport.php',
+ 'Illuminate\\Mail\\Transport\\Transport' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Mail/Transport/Transport.php',
+ 'Illuminate\\Notifications\\Action' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Action.php',
+ 'Illuminate\\Notifications\\ChannelManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/ChannelManager.php',
+ 'Illuminate\\Notifications\\Channels\\BroadcastChannel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Channels/BroadcastChannel.php',
+ 'Illuminate\\Notifications\\Channels\\DatabaseChannel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Channels/DatabaseChannel.php',
+ 'Illuminate\\Notifications\\Channels\\MailChannel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Channels/MailChannel.php',
+ 'Illuminate\\Notifications\\Channels\\NexmoSmsChannel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Channels/NexmoSmsChannel.php',
+ 'Illuminate\\Notifications\\Channels\\SlackWebhookChannel' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Channels/SlackWebhookChannel.php',
+ 'Illuminate\\Notifications\\Console\\NotificationTableCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Console/NotificationTableCommand.php',
+ 'Illuminate\\Notifications\\DatabaseNotification' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/DatabaseNotification.php',
+ 'Illuminate\\Notifications\\DatabaseNotificationCollection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/DatabaseNotificationCollection.php',
+ 'Illuminate\\Notifications\\Events\\BroadcastNotificationCreated' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Events/BroadcastNotificationCreated.php',
+ 'Illuminate\\Notifications\\Events\\NotificationFailed' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Events/NotificationFailed.php',
+ 'Illuminate\\Notifications\\Events\\NotificationSending' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Events/NotificationSending.php',
+ 'Illuminate\\Notifications\\Events\\NotificationSent' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Events/NotificationSent.php',
+ 'Illuminate\\Notifications\\HasDatabaseNotifications' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/HasDatabaseNotifications.php',
+ 'Illuminate\\Notifications\\Messages\\BroadcastMessage' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Messages/BroadcastMessage.php',
+ 'Illuminate\\Notifications\\Messages\\DatabaseMessage' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Messages/DatabaseMessage.php',
+ 'Illuminate\\Notifications\\Messages\\MailMessage' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Messages/MailMessage.php',
+ 'Illuminate\\Notifications\\Messages\\NexmoMessage' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Messages/NexmoMessage.php',
+ 'Illuminate\\Notifications\\Messages\\SimpleMessage' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Messages/SimpleMessage.php',
+ 'Illuminate\\Notifications\\Messages\\SlackAttachment' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachment.php',
+ 'Illuminate\\Notifications\\Messages\\SlackAttachmentField' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachmentField.php',
+ 'Illuminate\\Notifications\\Messages\\SlackMessage' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Messages/SlackMessage.php',
+ 'Illuminate\\Notifications\\Notifiable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Notifiable.php',
+ 'Illuminate\\Notifications\\Notification' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/Notification.php',
+ 'Illuminate\\Notifications\\NotificationSender' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/NotificationSender.php',
+ 'Illuminate\\Notifications\\NotificationServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/NotificationServiceProvider.php',
+ 'Illuminate\\Notifications\\RoutesNotifications' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/RoutesNotifications.php',
+ 'Illuminate\\Notifications\\SendQueuedNotifications' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Notifications/SendQueuedNotifications.php',
+ 'Illuminate\\Pagination\\AbstractPaginator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Pagination/AbstractPaginator.php',
+ 'Illuminate\\Pagination\\LengthAwarePaginator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Pagination/LengthAwarePaginator.php',
+ 'Illuminate\\Pagination\\PaginationServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Pagination/PaginationServiceProvider.php',
+ 'Illuminate\\Pagination\\Paginator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Pagination/Paginator.php',
+ 'Illuminate\\Pagination\\UrlWindow' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Pagination/UrlWindow.php',
+ 'Illuminate\\Pipeline\\Hub' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Pipeline/Hub.php',
+ 'Illuminate\\Pipeline\\Pipeline' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Pipeline/Pipeline.php',
+ 'Illuminate\\Pipeline\\PipelineServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Pipeline/PipelineServiceProvider.php',
+ 'Illuminate\\Queue\\BeanstalkdQueue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/BeanstalkdQueue.php',
+ 'Illuminate\\Queue\\CallQueuedHandler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/CallQueuedHandler.php',
+ 'Illuminate\\Queue\\Capsule\\Manager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Capsule/Manager.php',
+ 'Illuminate\\Queue\\Connectors\\BeanstalkdConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Connectors/BeanstalkdConnector.php',
+ 'Illuminate\\Queue\\Connectors\\ConnectorInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Connectors/ConnectorInterface.php',
+ 'Illuminate\\Queue\\Connectors\\DatabaseConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Connectors/DatabaseConnector.php',
+ 'Illuminate\\Queue\\Connectors\\NullConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Connectors/NullConnector.php',
+ 'Illuminate\\Queue\\Connectors\\RedisConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Connectors/RedisConnector.php',
+ 'Illuminate\\Queue\\Connectors\\SqsConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Connectors/SqsConnector.php',
+ 'Illuminate\\Queue\\Connectors\\SyncConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Connectors/SyncConnector.php',
+ 'Illuminate\\Queue\\Console\\FailedTableCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Console/FailedTableCommand.php',
+ 'Illuminate\\Queue\\Console\\FlushFailedCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Console/FlushFailedCommand.php',
+ 'Illuminate\\Queue\\Console\\ForgetFailedCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Console/ForgetFailedCommand.php',
+ 'Illuminate\\Queue\\Console\\ListFailedCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Console/ListFailedCommand.php',
+ 'Illuminate\\Queue\\Console\\ListenCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Console/ListenCommand.php',
+ 'Illuminate\\Queue\\Console\\RestartCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Console/RestartCommand.php',
+ 'Illuminate\\Queue\\Console\\RetryCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Console/RetryCommand.php',
+ 'Illuminate\\Queue\\Console\\TableCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Console/TableCommand.php',
+ 'Illuminate\\Queue\\Console\\WorkCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Console/WorkCommand.php',
+ 'Illuminate\\Queue\\DatabaseQueue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/DatabaseQueue.php',
+ 'Illuminate\\Queue\\Events\\JobExceptionOccurred' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Events/JobExceptionOccurred.php',
+ 'Illuminate\\Queue\\Events\\JobFailed' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Events/JobFailed.php',
+ 'Illuminate\\Queue\\Events\\JobProcessed' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Events/JobProcessed.php',
+ 'Illuminate\\Queue\\Events\\JobProcessing' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Events/JobProcessing.php',
+ 'Illuminate\\Queue\\Events\\Looping' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Events/Looping.php',
+ 'Illuminate\\Queue\\Events\\WorkerStopping' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Events/WorkerStopping.php',
+ 'Illuminate\\Queue\\Failed\\DatabaseFailedJobProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Failed/DatabaseFailedJobProvider.php',
+ 'Illuminate\\Queue\\Failed\\FailedJobProviderInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Failed/FailedJobProviderInterface.php',
+ 'Illuminate\\Queue\\Failed\\NullFailedJobProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Failed/NullFailedJobProvider.php',
+ 'Illuminate\\Queue\\FailingJob' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/FailingJob.php',
+ 'Illuminate\\Queue\\InteractsWithQueue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/InteractsWithQueue.php',
+ 'Illuminate\\Queue\\InteractsWithTime' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/InteractsWithTime.php',
+ 'Illuminate\\Queue\\InvalidPayloadException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/InvalidPayloadException.php',
+ 'Illuminate\\Queue\\Jobs\\BeanstalkdJob' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Jobs/BeanstalkdJob.php',
+ 'Illuminate\\Queue\\Jobs\\DatabaseJob' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJob.php',
+ 'Illuminate\\Queue\\Jobs\\DatabaseJobRecord' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJobRecord.php',
+ 'Illuminate\\Queue\\Jobs\\Job' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Jobs/Job.php',
+ 'Illuminate\\Queue\\Jobs\\JobName' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Jobs/JobName.php',
+ 'Illuminate\\Queue\\Jobs\\RedisJob' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Jobs/RedisJob.php',
+ 'Illuminate\\Queue\\Jobs\\SqsJob' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Jobs/SqsJob.php',
+ 'Illuminate\\Queue\\Jobs\\SyncJob' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Jobs/SyncJob.php',
+ 'Illuminate\\Queue\\Listener' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Listener.php',
+ 'Illuminate\\Queue\\ListenerOptions' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/ListenerOptions.php',
+ 'Illuminate\\Queue\\LuaScripts' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/LuaScripts.php',
+ 'Illuminate\\Queue\\ManuallyFailedException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/ManuallyFailedException.php',
+ 'Illuminate\\Queue\\MaxAttemptsExceededException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/MaxAttemptsExceededException.php',
+ 'Illuminate\\Queue\\NullQueue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/NullQueue.php',
+ 'Illuminate\\Queue\\Queue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Queue.php',
+ 'Illuminate\\Queue\\QueueManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/QueueManager.php',
+ 'Illuminate\\Queue\\QueueServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/QueueServiceProvider.php',
+ 'Illuminate\\Queue\\RedisQueue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/RedisQueue.php',
+ 'Illuminate\\Queue\\SerializesAndRestoresModelIdentifiers' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/SerializesAndRestoresModelIdentifiers.php',
+ 'Illuminate\\Queue\\SerializesModels' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/SerializesModels.php',
+ 'Illuminate\\Queue\\SqsQueue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/SqsQueue.php',
+ 'Illuminate\\Queue\\SyncQueue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/SyncQueue.php',
+ 'Illuminate\\Queue\\Worker' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/Worker.php',
+ 'Illuminate\\Queue\\WorkerOptions' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Queue/WorkerOptions.php',
+ 'Illuminate\\Redis\\Connections\\Connection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Redis/Connections/Connection.php',
+ 'Illuminate\\Redis\\Connections\\PhpRedisClusterConnection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Redis/Connections/PhpRedisClusterConnection.php',
+ 'Illuminate\\Redis\\Connections\\PhpRedisConnection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Redis/Connections/PhpRedisConnection.php',
+ 'Illuminate\\Redis\\Connections\\PredisClusterConnection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Redis/Connections/PredisClusterConnection.php',
+ 'Illuminate\\Redis\\Connections\\PredisConnection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Redis/Connections/PredisConnection.php',
+ 'Illuminate\\Redis\\Connectors\\PhpRedisConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Redis/Connectors/PhpRedisConnector.php',
+ 'Illuminate\\Redis\\Connectors\\PredisConnector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Redis/Connectors/PredisConnector.php',
+ 'Illuminate\\Redis\\RedisManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Redis/RedisManager.php',
+ 'Illuminate\\Redis\\RedisServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Redis/RedisServiceProvider.php',
+ 'Illuminate\\Routing\\Console\\ControllerMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Console/ControllerMakeCommand.php',
+ 'Illuminate\\Routing\\Console\\MiddlewareMakeCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Console/MiddlewareMakeCommand.php',
+ 'Illuminate\\Routing\\Controller' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Controller.php',
+ 'Illuminate\\Routing\\ControllerDispatcher' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php',
+ 'Illuminate\\Routing\\ControllerMiddlewareOptions' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/ControllerMiddlewareOptions.php',
+ 'Illuminate\\Routing\\Events\\RouteMatched' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Events/RouteMatched.php',
+ 'Illuminate\\Routing\\Exceptions\\UrlGenerationException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Exceptions/UrlGenerationException.php',
+ 'Illuminate\\Routing\\ImplicitRouteBinding' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/ImplicitRouteBinding.php',
+ 'Illuminate\\Routing\\Matching\\HostValidator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Matching/HostValidator.php',
+ 'Illuminate\\Routing\\Matching\\MethodValidator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Matching/MethodValidator.php',
+ 'Illuminate\\Routing\\Matching\\SchemeValidator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Matching/SchemeValidator.php',
+ 'Illuminate\\Routing\\Matching\\UriValidator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Matching/UriValidator.php',
+ 'Illuminate\\Routing\\Matching\\ValidatorInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Matching/ValidatorInterface.php',
+ 'Illuminate\\Routing\\MiddlewareNameResolver' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/MiddlewareNameResolver.php',
+ 'Illuminate\\Routing\\Middleware\\SubstituteBindings' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Middleware/SubstituteBindings.php',
+ 'Illuminate\\Routing\\Middleware\\ThrottleRequests' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Middleware/ThrottleRequests.php',
+ 'Illuminate\\Routing\\Pipeline' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Pipeline.php',
+ 'Illuminate\\Routing\\Redirector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Redirector.php',
+ 'Illuminate\\Routing\\ResourceRegistrar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/ResourceRegistrar.php',
+ 'Illuminate\\Routing\\ResponseFactory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/ResponseFactory.php',
+ 'Illuminate\\Routing\\Route' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Route.php',
+ 'Illuminate\\Routing\\RouteAction' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RouteAction.php',
+ 'Illuminate\\Routing\\RouteBinding' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RouteBinding.php',
+ 'Illuminate\\Routing\\RouteCollection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RouteCollection.php',
+ 'Illuminate\\Routing\\RouteCompiler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RouteCompiler.php',
+ 'Illuminate\\Routing\\RouteDependencyResolverTrait' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RouteDependencyResolverTrait.php',
+ 'Illuminate\\Routing\\RouteGroup' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RouteGroup.php',
+ 'Illuminate\\Routing\\RouteParameterBinder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RouteParameterBinder.php',
+ 'Illuminate\\Routing\\RouteRegistrar' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RouteRegistrar.php',
+ 'Illuminate\\Routing\\RouteSignatureParameters' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RouteSignatureParameters.php',
+ 'Illuminate\\Routing\\RouteUrlGenerator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RouteUrlGenerator.php',
+ 'Illuminate\\Routing\\Router' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/Router.php',
+ 'Illuminate\\Routing\\RoutingServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/RoutingServiceProvider.php',
+ 'Illuminate\\Routing\\SortedMiddleware' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/SortedMiddleware.php',
+ 'Illuminate\\Routing\\UrlGenerator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Routing/UrlGenerator.php',
+ 'Illuminate\\Session\\CacheBasedSessionHandler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/CacheBasedSessionHandler.php',
+ 'Illuminate\\Session\\Console\\SessionTableCommand' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/Console/SessionTableCommand.php',
+ 'Illuminate\\Session\\CookieSessionHandler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/CookieSessionHandler.php',
+ 'Illuminate\\Session\\DatabaseSessionHandler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/DatabaseSessionHandler.php',
+ 'Illuminate\\Session\\EncryptedStore' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/EncryptedStore.php',
+ 'Illuminate\\Session\\ExistenceAwareInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/ExistenceAwareInterface.php',
+ 'Illuminate\\Session\\FileSessionHandler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/FileSessionHandler.php',
+ 'Illuminate\\Session\\Middleware\\AuthenticateSession' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/Middleware/AuthenticateSession.php',
+ 'Illuminate\\Session\\Middleware\\StartSession' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/Middleware/StartSession.php',
+ 'Illuminate\\Session\\SessionManager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/SessionManager.php',
+ 'Illuminate\\Session\\SessionServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/SessionServiceProvider.php',
+ 'Illuminate\\Session\\Store' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/Store.php',
+ 'Illuminate\\Session\\TokenMismatchException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Session/TokenMismatchException.php',
+ 'Illuminate\\Support\\AggregateServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/AggregateServiceProvider.php',
+ 'Illuminate\\Support\\Arr' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Arr.php',
+ 'Illuminate\\Support\\Collection' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Collection.php',
+ 'Illuminate\\Support\\Composer' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Composer.php',
+ 'Illuminate\\Support\\Debug\\Dumper' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Debug/Dumper.php',
+ 'Illuminate\\Support\\Debug\\HtmlDumper' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Debug/HtmlDumper.php',
+ 'Illuminate\\Support\\Facades\\App' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/App.php',
+ 'Illuminate\\Support\\Facades\\Artisan' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Artisan.php',
+ 'Illuminate\\Support\\Facades\\Auth' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Auth.php',
+ 'Illuminate\\Support\\Facades\\Blade' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Blade.php',
+ 'Illuminate\\Support\\Facades\\Broadcast' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Broadcast.php',
+ 'Illuminate\\Support\\Facades\\Bus' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Bus.php',
+ 'Illuminate\\Support\\Facades\\Cache' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Cache.php',
+ 'Illuminate\\Support\\Facades\\Config' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Config.php',
+ 'Illuminate\\Support\\Facades\\Cookie' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Cookie.php',
+ 'Illuminate\\Support\\Facades\\Crypt' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Crypt.php',
+ 'Illuminate\\Support\\Facades\\DB' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/DB.php',
+ 'Illuminate\\Support\\Facades\\Event' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Event.php',
+ 'Illuminate\\Support\\Facades\\Facade' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Facade.php',
+ 'Illuminate\\Support\\Facades\\File' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/File.php',
+ 'Illuminate\\Support\\Facades\\Gate' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Gate.php',
+ 'Illuminate\\Support\\Facades\\Hash' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Hash.php',
+ 'Illuminate\\Support\\Facades\\Input' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Input.php',
+ 'Illuminate\\Support\\Facades\\Lang' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Lang.php',
+ 'Illuminate\\Support\\Facades\\Log' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Log.php',
+ 'Illuminate\\Support\\Facades\\Mail' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Mail.php',
+ 'Illuminate\\Support\\Facades\\Notification' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Notification.php',
+ 'Illuminate\\Support\\Facades\\Password' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Password.php',
+ 'Illuminate\\Support\\Facades\\Queue' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Queue.php',
+ 'Illuminate\\Support\\Facades\\Redirect' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Redirect.php',
+ 'Illuminate\\Support\\Facades\\Redis' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Redis.php',
+ 'Illuminate\\Support\\Facades\\Request' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Request.php',
+ 'Illuminate\\Support\\Facades\\Response' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Response.php',
+ 'Illuminate\\Support\\Facades\\Route' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Route.php',
+ 'Illuminate\\Support\\Facades\\Schema' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Schema.php',
+ 'Illuminate\\Support\\Facades\\Session' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Session.php',
+ 'Illuminate\\Support\\Facades\\Storage' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Storage.php',
+ 'Illuminate\\Support\\Facades\\URL' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/URL.php',
+ 'Illuminate\\Support\\Facades\\Validator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/Validator.php',
+ 'Illuminate\\Support\\Facades\\View' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Facades/View.php',
+ 'Illuminate\\Support\\Fluent' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Fluent.php',
+ 'Illuminate\\Support\\HigherOrderCollectionProxy' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/HigherOrderCollectionProxy.php',
+ 'Illuminate\\Support\\HigherOrderTapProxy' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/HigherOrderTapProxy.php',
+ 'Illuminate\\Support\\HtmlString' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/HtmlString.php',
+ 'Illuminate\\Support\\Manager' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Manager.php',
+ 'Illuminate\\Support\\MessageBag' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/MessageBag.php',
+ 'Illuminate\\Support\\NamespacedItemResolver' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/NamespacedItemResolver.php',
+ 'Illuminate\\Support\\Pluralizer' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Pluralizer.php',
+ 'Illuminate\\Support\\ServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/ServiceProvider.php',
+ 'Illuminate\\Support\\Str' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Str.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\BusFake' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/BusFake.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\EventFake' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/EventFake.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\MailFake' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/MailFake.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\NotificationFake' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/NotificationFake.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\PendingMailFake' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/PendingMailFake.php',
+ 'Illuminate\\Support\\Testing\\Fakes\\QueueFake' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Testing/Fakes/QueueFake.php',
+ 'Illuminate\\Support\\Traits\\CapsuleManagerTrait' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Traits/CapsuleManagerTrait.php',
+ 'Illuminate\\Support\\Traits\\Macroable' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/Traits/Macroable.php',
+ 'Illuminate\\Support\\ViewErrorBag' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Support/ViewErrorBag.php',
+ 'Illuminate\\Translation\\ArrayLoader' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Translation/ArrayLoader.php',
+ 'Illuminate\\Translation\\FileLoader' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Translation/FileLoader.php',
+ 'Illuminate\\Translation\\LoaderInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Translation/LoaderInterface.php',
+ 'Illuminate\\Translation\\MessageSelector' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Translation/MessageSelector.php',
+ 'Illuminate\\Translation\\TranslationServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Translation/TranslationServiceProvider.php',
+ 'Illuminate\\Translation\\Translator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Translation/Translator.php',
+ 'Illuminate\\Validation\\Concerns\\FormatsMessages' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Concerns/FormatsMessages.php',
+ 'Illuminate\\Validation\\Concerns\\ReplacesAttributes' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Concerns/ReplacesAttributes.php',
+ 'Illuminate\\Validation\\Concerns\\ValidatesAttributes' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Concerns/ValidatesAttributes.php',
+ 'Illuminate\\Validation\\DatabasePresenceVerifier' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/DatabasePresenceVerifier.php',
+ 'Illuminate\\Validation\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Factory.php',
+ 'Illuminate\\Validation\\PresenceVerifierInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/PresenceVerifierInterface.php',
+ 'Illuminate\\Validation\\Rule' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Rule.php',
+ 'Illuminate\\Validation\\Rules\\Dimensions' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Rules/Dimensions.php',
+ 'Illuminate\\Validation\\Rules\\Exists' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Rules/Exists.php',
+ 'Illuminate\\Validation\\Rules\\In' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Rules/In.php',
+ 'Illuminate\\Validation\\Rules\\NotIn' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Rules/NotIn.php',
+ 'Illuminate\\Validation\\Rules\\Unique' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Rules/Unique.php',
+ 'Illuminate\\Validation\\UnauthorizedException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/UnauthorizedException.php',
+ 'Illuminate\\Validation\\ValidatesWhenResolvedTrait' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/ValidatesWhenResolvedTrait.php',
+ 'Illuminate\\Validation\\ValidationData' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/ValidationData.php',
+ 'Illuminate\\Validation\\ValidationException' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/ValidationException.php',
+ 'Illuminate\\Validation\\ValidationRuleParser' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/ValidationRuleParser.php',
+ 'Illuminate\\Validation\\ValidationServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/ValidationServiceProvider.php',
+ 'Illuminate\\Validation\\Validator' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/Validation/Validator.php',
+ 'Illuminate\\View\\Compilers\\BladeCompiler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/BladeCompiler.php',
+ 'Illuminate\\View\\Compilers\\Compiler' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Compiler.php',
+ 'Illuminate\\View\\Compilers\\CompilerInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/CompilerInterface.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesAuthorizations' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesAuthorizations.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesComments' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComments.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesComponents' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComponents.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesConditionals' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesConditionals.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesEchos' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesEchos.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesIncludes' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesIncludes.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesInjections' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesInjections.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesLayouts' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLayouts.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesLoops' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLoops.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesRawPhp' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesRawPhp.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesStacks' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesStacks.php',
+ 'Illuminate\\View\\Compilers\\Concerns\\CompilesTranslations' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesTranslations.php',
+ 'Illuminate\\View\\Concerns\\ManagesComponents' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Concerns/ManagesComponents.php',
+ 'Illuminate\\View\\Concerns\\ManagesEvents' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Concerns/ManagesEvents.php',
+ 'Illuminate\\View\\Concerns\\ManagesLayouts' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Concerns/ManagesLayouts.php',
+ 'Illuminate\\View\\Concerns\\ManagesLoops' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Concerns/ManagesLoops.php',
+ 'Illuminate\\View\\Concerns\\ManagesStacks' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Concerns/ManagesStacks.php',
+ 'Illuminate\\View\\Concerns\\ManagesTranslations' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Concerns/ManagesTranslations.php',
+ 'Illuminate\\View\\Engines\\CompilerEngine' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Engines/CompilerEngine.php',
+ 'Illuminate\\View\\Engines\\Engine' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Engines/Engine.php',
+ 'Illuminate\\View\\Engines\\EngineInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Engines/EngineInterface.php',
+ 'Illuminate\\View\\Engines\\EngineResolver' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Engines/EngineResolver.php',
+ 'Illuminate\\View\\Engines\\FileEngine' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Engines/FileEngine.php',
+ 'Illuminate\\View\\Engines\\PhpEngine' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Engines/PhpEngine.php',
+ 'Illuminate\\View\\Factory' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Factory.php',
+ 'Illuminate\\View\\FileViewFinder' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/FileViewFinder.php',
+ 'Illuminate\\View\\Middleware\\ShareErrorsFromSession' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/Middleware/ShareErrorsFromSession.php',
+ 'Illuminate\\View\\View' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/View.php',
+ 'Illuminate\\View\\ViewFinderInterface' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/ViewFinderInterface.php',
+ 'Illuminate\\View\\ViewName' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/ViewName.php',
+ 'Illuminate\\View\\ViewServiceProvider' => __DIR__ . '/..' . '/laravel/framework/src/Illuminate/View/ViewServiceProvider.php',
+ 'JakubOnderka\\PhpConsoleColor\\ConsoleColor' => __DIR__ . '/..' . '/jakub-onderka/php-console-color/src/ConsoleColor.php',
+ 'JakubOnderka\\PhpConsoleColor\\InvalidStyleException' => __DIR__ . '/..' . '/jakub-onderka/php-console-color/src/InvalidStyleException.php',
+ 'JakubOnderka\\PhpConsoleHighlighter\\Highlighter' => __DIR__ . '/..' . '/jakub-onderka/php-console-highlighter/src/Highlighter.php',
+ 'JsonSerializable' => __DIR__ . '/..' . '/nesbot/carbon/src/JsonSerializable.php',
+ 'Laravel\\Tinker\\ClassAliasAutoloader' => __DIR__ . '/..' . '/laravel/tinker/src/ClassAliasAutoloader.php',
+ 'Laravel\\Tinker\\Console\\TinkerCommand' => __DIR__ . '/..' . '/laravel/tinker/src/Console/TinkerCommand.php',
+ 'Laravel\\Tinker\\TinkerCaster' => __DIR__ . '/..' . '/laravel/tinker/src/TinkerCaster.php',
+ 'Laravel\\Tinker\\TinkerServiceProvider' => __DIR__ . '/..' . '/laravel/tinker/src/TinkerServiceProvider.php',
+ 'League\\Flysystem\\AdapterInterface' => __DIR__ . '/..' . '/league/flysystem/src/AdapterInterface.php',
+ 'League\\Flysystem\\Adapter\\AbstractAdapter' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/AbstractAdapter.php',
+ 'League\\Flysystem\\Adapter\\AbstractFtpAdapter' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/AbstractFtpAdapter.php',
+ 'League\\Flysystem\\Adapter\\CanOverwriteFiles' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/CanOverwriteFiles.php',
+ 'League\\Flysystem\\Adapter\\Ftp' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Ftp.php',
+ 'League\\Flysystem\\Adapter\\Ftpd' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Ftpd.php',
+ 'League\\Flysystem\\Adapter\\Local' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Local.php',
+ 'League\\Flysystem\\Adapter\\NullAdapter' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/NullAdapter.php',
+ 'League\\Flysystem\\Adapter\\Polyfill\\NotSupportingVisibilityTrait' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Polyfill/NotSupportingVisibilityTrait.php',
+ 'League\\Flysystem\\Adapter\\Polyfill\\StreamedCopyTrait' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Polyfill/StreamedCopyTrait.php',
+ 'League\\Flysystem\\Adapter\\Polyfill\\StreamedReadingTrait' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Polyfill/StreamedReadingTrait.php',
+ 'League\\Flysystem\\Adapter\\Polyfill\\StreamedTrait' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Polyfill/StreamedTrait.php',
+ 'League\\Flysystem\\Adapter\\Polyfill\\StreamedWritingTrait' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/Polyfill/StreamedWritingTrait.php',
+ 'League\\Flysystem\\Adapter\\SynologyFtp' => __DIR__ . '/..' . '/league/flysystem/src/Adapter/SynologyFtp.php',
+ 'League\\Flysystem\\Config' => __DIR__ . '/..' . '/league/flysystem/src/Config.php',
+ 'League\\Flysystem\\ConfigAwareTrait' => __DIR__ . '/..' . '/league/flysystem/src/ConfigAwareTrait.php',
+ 'League\\Flysystem\\ConnectionErrorException' => __DIR__ . '/..' . '/league/flysystem/src/ConnectionErrorException.php',
+ 'League\\Flysystem\\ConnectionRuntimeException' => __DIR__ . '/..' . '/league/flysystem/src/ConnectionRuntimeException.php',
+ 'League\\Flysystem\\Directory' => __DIR__ . '/..' . '/league/flysystem/src/Directory.php',
+ 'League\\Flysystem\\Exception' => __DIR__ . '/..' . '/league/flysystem/src/Exception.php',
+ 'League\\Flysystem\\File' => __DIR__ . '/..' . '/league/flysystem/src/File.php',
+ 'League\\Flysystem\\FileExistsException' => __DIR__ . '/..' . '/league/flysystem/src/FileExistsException.php',
+ 'League\\Flysystem\\FileNotFoundException' => __DIR__ . '/..' . '/league/flysystem/src/FileNotFoundException.php',
+ 'League\\Flysystem\\Filesystem' => __DIR__ . '/..' . '/league/flysystem/src/Filesystem.php',
+ 'League\\Flysystem\\FilesystemException' => __DIR__ . '/..' . '/league/flysystem/src/FilesystemException.php',
+ 'League\\Flysystem\\FilesystemInterface' => __DIR__ . '/..' . '/league/flysystem/src/FilesystemInterface.php',
+ 'League\\Flysystem\\FilesystemNotFoundException' => __DIR__ . '/..' . '/league/flysystem/src/FilesystemNotFoundException.php',
+ 'League\\Flysystem\\Handler' => __DIR__ . '/..' . '/league/flysystem/src/Handler.php',
+ 'League\\Flysystem\\InvalidRootException' => __DIR__ . '/..' . '/league/flysystem/src/InvalidRootException.php',
+ 'League\\Flysystem\\MountManager' => __DIR__ . '/..' . '/league/flysystem/src/MountManager.php',
+ 'League\\Flysystem\\NotSupportedException' => __DIR__ . '/..' . '/league/flysystem/src/NotSupportedException.php',
+ 'League\\Flysystem\\PluginInterface' => __DIR__ . '/..' . '/league/flysystem/src/PluginInterface.php',
+ 'League\\Flysystem\\Plugin\\AbstractPlugin' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/AbstractPlugin.php',
+ 'League\\Flysystem\\Plugin\\EmptyDir' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/EmptyDir.php',
+ 'League\\Flysystem\\Plugin\\ForcedCopy' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/ForcedCopy.php',
+ 'League\\Flysystem\\Plugin\\ForcedRename' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/ForcedRename.php',
+ 'League\\Flysystem\\Plugin\\GetWithMetadata' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/GetWithMetadata.php',
+ 'League\\Flysystem\\Plugin\\ListFiles' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/ListFiles.php',
+ 'League\\Flysystem\\Plugin\\ListPaths' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/ListPaths.php',
+ 'League\\Flysystem\\Plugin\\ListWith' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/ListWith.php',
+ 'League\\Flysystem\\Plugin\\PluggableTrait' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/PluggableTrait.php',
+ 'League\\Flysystem\\Plugin\\PluginNotFoundException' => __DIR__ . '/..' . '/league/flysystem/src/Plugin/PluginNotFoundException.php',
+ 'League\\Flysystem\\ReadInterface' => __DIR__ . '/..' . '/league/flysystem/src/ReadInterface.php',
+ 'League\\Flysystem\\RootViolationException' => __DIR__ . '/..' . '/league/flysystem/src/RootViolationException.php',
+ 'League\\Flysystem\\SafeStorage' => __DIR__ . '/..' . '/league/flysystem/src/SafeStorage.php',
+ 'League\\Flysystem\\UnreadableFileException' => __DIR__ . '/..' . '/league/flysystem/src/UnreadableFileException.php',
+ 'League\\Flysystem\\Util' => __DIR__ . '/..' . '/league/flysystem/src/Util.php',
+ 'League\\Flysystem\\Util\\ContentListingFormatter' => __DIR__ . '/..' . '/league/flysystem/src/Util/ContentListingFormatter.php',
+ 'League\\Flysystem\\Util\\MimeType' => __DIR__ . '/..' . '/league/flysystem/src/Util/MimeType.php',
+ 'League\\Flysystem\\Util\\StreamHasher' => __DIR__ . '/..' . '/league/flysystem/src/Util/StreamHasher.php',
+ 'Mockery' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery.php',
+ 'Mockery\\Adapter\\Phpunit\\MockeryPHPUnitIntegration' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryPHPUnitIntegration.php',
+ 'Mockery\\Adapter\\Phpunit\\MockeryTestCase' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryTestCase.php',
+ 'Mockery\\Adapter\\Phpunit\\TestListener' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Adapter/Phpunit/TestListener.php',
+ 'Mockery\\CompositeExpectation' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/CompositeExpectation.php',
+ 'Mockery\\Configuration' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Configuration.php',
+ 'Mockery\\Container' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Container.php',
+ 'Mockery\\CountValidator\\AtLeast' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/CountValidator/AtLeast.php',
+ 'Mockery\\CountValidator\\AtMost' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/CountValidator/AtMost.php',
+ 'Mockery\\CountValidator\\CountValidatorAbstract' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/CountValidator/CountValidatorAbstract.php',
+ 'Mockery\\CountValidator\\Exact' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/CountValidator/Exact.php',
+ 'Mockery\\CountValidator\\Exception' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/CountValidator/Exception.php',
+ 'Mockery\\Exception' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Exception.php',
+ 'Mockery\\Exception\\InvalidCountException' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Exception/InvalidCountException.php',
+ 'Mockery\\Exception\\InvalidOrderException' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Exception/InvalidOrderException.php',
+ 'Mockery\\Exception\\NoMatchingExpectationException' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Exception/NoMatchingExpectationException.php',
+ 'Mockery\\Exception\\RuntimeException' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Exception/RuntimeException.php',
+ 'Mockery\\Expectation' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Expectation.php',
+ 'Mockery\\ExpectationDirector' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/ExpectationDirector.php',
+ 'Mockery\\ExpectationInterface' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/ExpectationInterface.php',
+ 'Mockery\\Generator\\CachingGenerator' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/CachingGenerator.php',
+ 'Mockery\\Generator\\DefinedTargetClass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/DefinedTargetClass.php',
+ 'Mockery\\Generator\\Generator' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/Generator.php',
+ 'Mockery\\Generator\\Method' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/Method.php',
+ 'Mockery\\Generator\\MockConfiguration' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/MockConfiguration.php',
+ 'Mockery\\Generator\\MockConfigurationBuilder' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/MockConfigurationBuilder.php',
+ 'Mockery\\Generator\\MockDefinition' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/MockDefinition.php',
+ 'Mockery\\Generator\\Parameter' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/Parameter.php',
+ 'Mockery\\Generator\\StringManipulationGenerator' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/StringManipulationGenerator.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\CallTypeHintPass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/CallTypeHintPass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\ClassNamePass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassNamePass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\ClassPass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassPass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\InstanceMockPass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InstanceMockPass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\InterfacePass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InterfacePass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\MethodDefinitionPass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/MethodDefinitionPass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\Pass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/Pass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\RemoveBuiltinMethodsThatAreFinalPass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/RemoveBuiltinMethodsThatAreFinalPass.php',
+ 'Mockery\\Generator\\StringManipulation\\Pass\\RemoveUnserializeForInternalSerializableClassesPass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/RemoveUnserializeForInternalSerializableClassesPass.php',
+ 'Mockery\\Generator\\TargetClass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/TargetClass.php',
+ 'Mockery\\Generator\\UndefinedTargetClass' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Generator/UndefinedTargetClass.php',
+ 'Mockery\\Instantiator' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Instantiator.php',
+ 'Mockery\\Loader' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Loader.php',
+ 'Mockery\\Loader\\EvalLoader' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Loader/EvalLoader.php',
+ 'Mockery\\Loader\\Loader' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Loader/Loader.php',
+ 'Mockery\\Loader\\RequireLoader' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Loader/RequireLoader.php',
+ 'Mockery\\Matcher\\Any' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/Any.php',
+ 'Mockery\\Matcher\\AnyOf' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/AnyOf.php',
+ 'Mockery\\Matcher\\Closure' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/Closure.php',
+ 'Mockery\\Matcher\\Contains' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/Contains.php',
+ 'Mockery\\Matcher\\Ducktype' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/Ducktype.php',
+ 'Mockery\\Matcher\\HasKey' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/HasKey.php',
+ 'Mockery\\Matcher\\HasValue' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/HasValue.php',
+ 'Mockery\\Matcher\\MatcherAbstract' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/MatcherAbstract.php',
+ 'Mockery\\Matcher\\MustBe' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/MustBe.php',
+ 'Mockery\\Matcher\\Not' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/Not.php',
+ 'Mockery\\Matcher\\NotAnyOf' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/NotAnyOf.php',
+ 'Mockery\\Matcher\\Subset' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/Subset.php',
+ 'Mockery\\Matcher\\Type' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Matcher/Type.php',
+ 'Mockery\\MethodCall' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/MethodCall.php',
+ 'Mockery\\Mock' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Mock.php',
+ 'Mockery\\MockInterface' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/MockInterface.php',
+ 'Mockery\\ReceivedMethodCalls' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/ReceivedMethodCalls.php',
+ 'Mockery\\Recorder' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Recorder.php',
+ 'Mockery\\Undefined' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/Undefined.php',
+ 'Mockery\\VerificationDirector' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/VerificationDirector.php',
+ 'Mockery\\VerificationExpectation' => __DIR__ . '/..' . '/mockery/mockery/library/Mockery/VerificationExpectation.php',
+ 'Monolog\\ErrorHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/ErrorHandler.php',
+ 'Monolog\\Formatter\\ChromePHPFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/ChromePHPFormatter.php',
+ 'Monolog\\Formatter\\ElasticaFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/ElasticaFormatter.php',
+ 'Monolog\\Formatter\\FlowdockFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/FlowdockFormatter.php',
+ 'Monolog\\Formatter\\FluentdFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/FluentdFormatter.php',
+ 'Monolog\\Formatter\\FormatterInterface' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/FormatterInterface.php',
+ 'Monolog\\Formatter\\GelfMessageFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/GelfMessageFormatter.php',
+ 'Monolog\\Formatter\\HtmlFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/HtmlFormatter.php',
+ 'Monolog\\Formatter\\JsonFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/JsonFormatter.php',
+ 'Monolog\\Formatter\\LineFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/LineFormatter.php',
+ 'Monolog\\Formatter\\LogglyFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/LogglyFormatter.php',
+ 'Monolog\\Formatter\\LogstashFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/LogstashFormatter.php',
+ 'Monolog\\Formatter\\MongoDBFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/MongoDBFormatter.php',
+ 'Monolog\\Formatter\\NormalizerFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/NormalizerFormatter.php',
+ 'Monolog\\Formatter\\ScalarFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/ScalarFormatter.php',
+ 'Monolog\\Formatter\\WildfireFormatter' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Formatter/WildfireFormatter.php',
+ 'Monolog\\Handler\\AbstractHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/AbstractHandler.php',
+ 'Monolog\\Handler\\AbstractProcessingHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/AbstractProcessingHandler.php',
+ 'Monolog\\Handler\\AbstractSyslogHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/AbstractSyslogHandler.php',
+ 'Monolog\\Handler\\AmqpHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/AmqpHandler.php',
+ 'Monolog\\Handler\\BrowserConsoleHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/BrowserConsoleHandler.php',
+ 'Monolog\\Handler\\BufferHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/BufferHandler.php',
+ 'Monolog\\Handler\\ChromePHPHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/ChromePHPHandler.php',
+ 'Monolog\\Handler\\CouchDBHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/CouchDBHandler.php',
+ 'Monolog\\Handler\\CubeHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/CubeHandler.php',
+ 'Monolog\\Handler\\Curl\\Util' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/Curl/Util.php',
+ 'Monolog\\Handler\\DeduplicationHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/DeduplicationHandler.php',
+ 'Monolog\\Handler\\DoctrineCouchDBHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/DoctrineCouchDBHandler.php',
+ 'Monolog\\Handler\\DynamoDbHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/DynamoDbHandler.php',
+ 'Monolog\\Handler\\ElasticSearchHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/ElasticSearchHandler.php',
+ 'Monolog\\Handler\\ErrorLogHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/ErrorLogHandler.php',
+ 'Monolog\\Handler\\FilterHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/FilterHandler.php',
+ 'Monolog\\Handler\\FingersCrossedHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/FingersCrossedHandler.php',
+ 'Monolog\\Handler\\FingersCrossed\\ActivationStrategyInterface' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php',
+ 'Monolog\\Handler\\FingersCrossed\\ChannelLevelActivationStrategy' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php',
+ 'Monolog\\Handler\\FingersCrossed\\ErrorLevelActivationStrategy' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php',
+ 'Monolog\\Handler\\FirePHPHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/FirePHPHandler.php',
+ 'Monolog\\Handler\\FleepHookHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/FleepHookHandler.php',
+ 'Monolog\\Handler\\FlowdockHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/FlowdockHandler.php',
+ 'Monolog\\Handler\\FormattableHandlerInterface' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/FormattableHandlerInterface.php',
+ 'Monolog\\Handler\\FormattableHandlerTrait' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/FormattableHandlerTrait.php',
+ 'Monolog\\Handler\\GelfHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/GelfHandler.php',
+ 'Monolog\\Handler\\GroupHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/GroupHandler.php',
+ 'Monolog\\Handler\\HandlerInterface' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/HandlerInterface.php',
+ 'Monolog\\Handler\\HandlerWrapper' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/HandlerWrapper.php',
+ 'Monolog\\Handler\\HipChatHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/HipChatHandler.php',
+ 'Monolog\\Handler\\IFTTTHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/IFTTTHandler.php',
+ 'Monolog\\Handler\\InsightOpsHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/InsightOpsHandler.php',
+ 'Monolog\\Handler\\LogEntriesHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/LogEntriesHandler.php',
+ 'Monolog\\Handler\\LogglyHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/LogglyHandler.php',
+ 'Monolog\\Handler\\MailHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/MailHandler.php',
+ 'Monolog\\Handler\\MandrillHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/MandrillHandler.php',
+ 'Monolog\\Handler\\MissingExtensionException' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/MissingExtensionException.php',
+ 'Monolog\\Handler\\MongoDBHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/MongoDBHandler.php',
+ 'Monolog\\Handler\\NativeMailerHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/NativeMailerHandler.php',
+ 'Monolog\\Handler\\NewRelicHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/NewRelicHandler.php',
+ 'Monolog\\Handler\\NullHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/NullHandler.php',
+ 'Monolog\\Handler\\PHPConsoleHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/PHPConsoleHandler.php',
+ 'Monolog\\Handler\\ProcessableHandlerInterface' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/ProcessableHandlerInterface.php',
+ 'Monolog\\Handler\\ProcessableHandlerTrait' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/ProcessableHandlerTrait.php',
+ 'Monolog\\Handler\\PsrHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/PsrHandler.php',
+ 'Monolog\\Handler\\PushoverHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/PushoverHandler.php',
+ 'Monolog\\Handler\\RavenHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/RavenHandler.php',
+ 'Monolog\\Handler\\RedisHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/RedisHandler.php',
+ 'Monolog\\Handler\\RollbarHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/RollbarHandler.php',
+ 'Monolog\\Handler\\RotatingFileHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/RotatingFileHandler.php',
+ 'Monolog\\Handler\\SamplingHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/SamplingHandler.php',
+ 'Monolog\\Handler\\SlackHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/SlackHandler.php',
+ 'Monolog\\Handler\\SlackWebhookHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/SlackWebhookHandler.php',
+ 'Monolog\\Handler\\Slack\\SlackRecord' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/Slack/SlackRecord.php',
+ 'Monolog\\Handler\\SlackbotHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/SlackbotHandler.php',
+ 'Monolog\\Handler\\SocketHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/SocketHandler.php',
+ 'Monolog\\Handler\\StreamHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/StreamHandler.php',
+ 'Monolog\\Handler\\SwiftMailerHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/SwiftMailerHandler.php',
+ 'Monolog\\Handler\\SyslogHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/SyslogHandler.php',
+ 'Monolog\\Handler\\SyslogUdpHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/SyslogUdpHandler.php',
+ 'Monolog\\Handler\\SyslogUdp\\UdpSocket' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/SyslogUdp/UdpSocket.php',
+ 'Monolog\\Handler\\TestHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/TestHandler.php',
+ 'Monolog\\Handler\\WhatFailureGroupHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/WhatFailureGroupHandler.php',
+ 'Monolog\\Handler\\ZendMonitorHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Handler/ZendMonitorHandler.php',
+ 'Monolog\\Logger' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Logger.php',
+ 'Monolog\\Processor\\GitProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/GitProcessor.php',
+ 'Monolog\\Processor\\IntrospectionProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/IntrospectionProcessor.php',
+ 'Monolog\\Processor\\MemoryPeakUsageProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/MemoryPeakUsageProcessor.php',
+ 'Monolog\\Processor\\MemoryProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/MemoryProcessor.php',
+ 'Monolog\\Processor\\MemoryUsageProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/MemoryUsageProcessor.php',
+ 'Monolog\\Processor\\MercurialProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/MercurialProcessor.php',
+ 'Monolog\\Processor\\ProcessIdProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/ProcessIdProcessor.php',
+ 'Monolog\\Processor\\ProcessorInterface' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/ProcessorInterface.php',
+ 'Monolog\\Processor\\PsrLogMessageProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/PsrLogMessageProcessor.php',
+ 'Monolog\\Processor\\TagProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/TagProcessor.php',
+ 'Monolog\\Processor\\UidProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/UidProcessor.php',
+ 'Monolog\\Processor\\WebProcessor' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Processor/WebProcessor.php',
+ 'Monolog\\Registry' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Registry.php',
+ 'Monolog\\ResettableInterface' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/ResettableInterface.php',
+ 'Monolog\\SignalHandler' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/SignalHandler.php',
+ 'Monolog\\Utils' => __DIR__ . '/..' . '/monolog/monolog/src/Monolog/Utils.php',
+ 'PHPUnit\\Framework\\Assert' => __DIR__ . '/..' . '/phpunit/phpunit/src/ForwardCompatibility/Assert.php',
+ 'PHPUnit\\Framework\\AssertionFailedError' => __DIR__ . '/..' . '/phpunit/phpunit/src/ForwardCompatibility/AssertionFailedError.php',
+ 'PHPUnit\\Framework\\BaseTestListener' => __DIR__ . '/..' . '/phpunit/phpunit/src/ForwardCompatibility/BaseTestListener.php',
+ 'PHPUnit\\Framework\\Test' => __DIR__ . '/..' . '/phpunit/phpunit/src/ForwardCompatibility/Test.php',
+ 'PHPUnit\\Framework\\TestCase' => __DIR__ . '/..' . '/phpunit/phpunit/src/ForwardCompatibility/TestCase.php',
+ 'PHPUnit\\Framework\\TestListener' => __DIR__ . '/..' . '/phpunit/phpunit/src/ForwardCompatibility/TestListener.php',
+ 'PHPUnit\\Framework\\TestSuite' => __DIR__ . '/..' . '/phpunit/phpunit/src/ForwardCompatibility/TestSuite.php',
+ 'PHPUnit_Exception' => __DIR__ . '/..' . '/phpunit/phpunit/src/Exception.php',
+ 'PHPUnit_Extensions_GroupTestSuite' => __DIR__ . '/..' . '/phpunit/phpunit/src/Extensions/GroupTestSuite.php',
+ 'PHPUnit_Extensions_PhptTestCase' => __DIR__ . '/..' . '/phpunit/phpunit/src/Extensions/PhptTestCase.php',
+ 'PHPUnit_Extensions_PhptTestSuite' => __DIR__ . '/..' . '/phpunit/phpunit/src/Extensions/PhptTestSuite.php',
+ 'PHPUnit_Extensions_RepeatedTest' => __DIR__ . '/..' . '/phpunit/phpunit/src/Extensions/RepeatedTest.php',
+ 'PHPUnit_Extensions_TestDecorator' => __DIR__ . '/..' . '/phpunit/phpunit/src/Extensions/TestDecorator.php',
+ 'PHPUnit_Extensions_TicketListener' => __DIR__ . '/..' . '/phpunit/phpunit/src/Extensions/TicketListener.php',
+ 'PHPUnit_Framework_Assert' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Assert.php',
+ 'PHPUnit_Framework_AssertionFailedError' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/AssertionFailedError.php',
+ 'PHPUnit_Framework_BaseTestListener' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/BaseTestListener.php',
+ 'PHPUnit_Framework_CodeCoverageException' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/CodeCoverageException.php',
+ 'PHPUnit_Framework_Constraint' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint.php',
+ 'PHPUnit_Framework_Constraint_And' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/And.php',
+ 'PHPUnit_Framework_Constraint_ArrayHasKey' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/ArrayHasKey.php',
+ 'PHPUnit_Framework_Constraint_ArraySubset' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/ArraySubset.php',
+ 'PHPUnit_Framework_Constraint_Attribute' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/Attribute.php',
+ 'PHPUnit_Framework_Constraint_Callback' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/Callback.php',
+ 'PHPUnit_Framework_Constraint_ClassHasAttribute' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/ClassHasAttribute.php',
+ 'PHPUnit_Framework_Constraint_ClassHasStaticAttribute' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/ClassHasStaticAttribute.php',
+ 'PHPUnit_Framework_Constraint_Composite' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/Composite.php',
+ 'PHPUnit_Framework_Constraint_Count' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/Count.php',
+ 'PHPUnit_Framework_Constraint_DirectoryExists' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/DirectoryExists.php',
+ 'PHPUnit_Framework_Constraint_Exception' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/Exception.php',
+ 'PHPUnit_Framework_Constraint_ExceptionCode' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/ExceptionCode.php',
+ 'PHPUnit_Framework_Constraint_ExceptionMessage' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/ExceptionMessage.php',
+ 'PHPUnit_Framework_Constraint_ExceptionMessageRegExp' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/ExceptionMessageRegExp.php',
+ 'PHPUnit_Framework_Constraint_FileExists' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/FileExists.php',
+ 'PHPUnit_Framework_Constraint_GreaterThan' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/GreaterThan.php',
+ 'PHPUnit_Framework_Constraint_IsAnything' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsAnything.php',
+ 'PHPUnit_Framework_Constraint_IsEmpty' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsEmpty.php',
+ 'PHPUnit_Framework_Constraint_IsEqual' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsEqual.php',
+ 'PHPUnit_Framework_Constraint_IsFalse' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsFalse.php',
+ 'PHPUnit_Framework_Constraint_IsFinite' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsFinite.php',
+ 'PHPUnit_Framework_Constraint_IsIdentical' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsIdentical.php',
+ 'PHPUnit_Framework_Constraint_IsInfinite' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsInfinite.php',
+ 'PHPUnit_Framework_Constraint_IsInstanceOf' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsInstanceOf.php',
+ 'PHPUnit_Framework_Constraint_IsJson' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsJson.php',
+ 'PHPUnit_Framework_Constraint_IsNan' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsNan.php',
+ 'PHPUnit_Framework_Constraint_IsNull' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsNull.php',
+ 'PHPUnit_Framework_Constraint_IsReadable' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsReadable.php',
+ 'PHPUnit_Framework_Constraint_IsTrue' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsTrue.php',
+ 'PHPUnit_Framework_Constraint_IsType' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsType.php',
+ 'PHPUnit_Framework_Constraint_IsWritable' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/IsWritable.php',
+ 'PHPUnit_Framework_Constraint_JsonMatches' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/JsonMatches.php',
+ 'PHPUnit_Framework_Constraint_JsonMatches_ErrorMessageProvider' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/JsonMatches/ErrorMessageProvider.php',
+ 'PHPUnit_Framework_Constraint_LessThan' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/LessThan.php',
+ 'PHPUnit_Framework_Constraint_Not' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/Not.php',
+ 'PHPUnit_Framework_Constraint_ObjectHasAttribute' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/ObjectHasAttribute.php',
+ 'PHPUnit_Framework_Constraint_Or' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/Or.php',
+ 'PHPUnit_Framework_Constraint_PCREMatch' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/PCREMatch.php',
+ 'PHPUnit_Framework_Constraint_SameSize' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/SameSize.php',
+ 'PHPUnit_Framework_Constraint_StringContains' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/StringContains.php',
+ 'PHPUnit_Framework_Constraint_StringEndsWith' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/StringEndsWith.php',
+ 'PHPUnit_Framework_Constraint_StringMatches' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/StringMatches.php',
+ 'PHPUnit_Framework_Constraint_StringStartsWith' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/StringStartsWith.php',
+ 'PHPUnit_Framework_Constraint_TraversableContains' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/TraversableContains.php',
+ 'PHPUnit_Framework_Constraint_TraversableContainsOnly' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/TraversableContainsOnly.php',
+ 'PHPUnit_Framework_Constraint_Xor' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Constraint/Xor.php',
+ 'PHPUnit_Framework_CoveredCodeNotExecutedException' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/CoveredCodeNotExecutedException.php',
+ 'PHPUnit_Framework_Error' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Error.php',
+ 'PHPUnit_Framework_Error_Deprecated' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Error/Deprecated.php',
+ 'PHPUnit_Framework_Error_Notice' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Error/Notice.php',
+ 'PHPUnit_Framework_Error_Warning' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Error/Warning.php',
+ 'PHPUnit_Framework_Exception' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Exception.php',
+ 'PHPUnit_Framework_ExceptionWrapper' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/ExceptionWrapper.php',
+ 'PHPUnit_Framework_ExpectationFailedException' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/ExpectationFailedException.php',
+ 'PHPUnit_Framework_IncompleteTest' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/IncompleteTest.php',
+ 'PHPUnit_Framework_IncompleteTestCase' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/IncompleteTestCase.php',
+ 'PHPUnit_Framework_IncompleteTestError' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/IncompleteTestError.php',
+ 'PHPUnit_Framework_InvalidCoversTargetException' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/InvalidCoversTargetException.php',
+ 'PHPUnit_Framework_MissingCoversAnnotationException' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/MissingCoversAnnotationException.php',
+ 'PHPUnit_Framework_MockObject_BadMethodCallException' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Exception/BadMethodCallException.php',
+ 'PHPUnit_Framework_MockObject_Builder_Identity' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Identity.php',
+ 'PHPUnit_Framework_MockObject_Builder_InvocationMocker' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/InvocationMocker.php',
+ 'PHPUnit_Framework_MockObject_Builder_Match' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Match.php',
+ 'PHPUnit_Framework_MockObject_Builder_MethodNameMatch' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/MethodNameMatch.php',
+ 'PHPUnit_Framework_MockObject_Builder_Namespace' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Namespace.php',
+ 'PHPUnit_Framework_MockObject_Builder_ParametersMatch' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/ParametersMatch.php',
+ 'PHPUnit_Framework_MockObject_Builder_Stub' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Builder/Stub.php',
+ 'PHPUnit_Framework_MockObject_Exception' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Exception/Exception.php',
+ 'PHPUnit_Framework_MockObject_Generator' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Generator.php',
+ 'PHPUnit_Framework_MockObject_Invocation' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invocation.php',
+ 'PHPUnit_Framework_MockObject_InvocationMocker' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/InvocationMocker.php',
+ 'PHPUnit_Framework_MockObject_Invocation_Object' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invocation/Object.php',
+ 'PHPUnit_Framework_MockObject_Invocation_Static' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invocation/Static.php',
+ 'PHPUnit_Framework_MockObject_Invokable' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Invokable.php',
+ 'PHPUnit_Framework_MockObject_Matcher' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher.php',
+ 'PHPUnit_Framework_MockObject_Matcher_AnyInvokedCount' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/AnyInvokedCount.php',
+ 'PHPUnit_Framework_MockObject_Matcher_AnyParameters' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/AnyParameters.php',
+ 'PHPUnit_Framework_MockObject_Matcher_ConsecutiveParameters' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/ConsecutiveParameters.php',
+ 'PHPUnit_Framework_MockObject_Matcher_Invocation' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/Invocation.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedAtIndex' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtIndex.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedAtLeastCount' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtLeastCount.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedAtLeastOnce' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtLeastOnce.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedAtMostCount' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedAtMostCount.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedCount' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedCount.php',
+ 'PHPUnit_Framework_MockObject_Matcher_InvokedRecorder' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/InvokedRecorder.php',
+ 'PHPUnit_Framework_MockObject_Matcher_MethodName' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/MethodName.php',
+ 'PHPUnit_Framework_MockObject_Matcher_Parameters' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/Parameters.php',
+ 'PHPUnit_Framework_MockObject_Matcher_StatelessInvocation' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Matcher/StatelessInvocation.php',
+ 'PHPUnit_Framework_MockObject_MockBuilder' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/MockBuilder.php',
+ 'PHPUnit_Framework_MockObject_MockObject' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/MockObject.php',
+ 'PHPUnit_Framework_MockObject_RuntimeException' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Exception/RuntimeException.php',
+ 'PHPUnit_Framework_MockObject_Stub' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub.php',
+ 'PHPUnit_Framework_MockObject_Stub_ConsecutiveCalls' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ConsecutiveCalls.php',
+ 'PHPUnit_Framework_MockObject_Stub_Exception' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/Exception.php',
+ 'PHPUnit_Framework_MockObject_Stub_MatcherCollection' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/MatcherCollection.php',
+ 'PHPUnit_Framework_MockObject_Stub_Return' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/Return.php',
+ 'PHPUnit_Framework_MockObject_Stub_ReturnArgument' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnArgument.php',
+ 'PHPUnit_Framework_MockObject_Stub_ReturnCallback' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnCallback.php',
+ 'PHPUnit_Framework_MockObject_Stub_ReturnReference' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnReference.php',
+ 'PHPUnit_Framework_MockObject_Stub_ReturnSelf' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnSelf.php',
+ 'PHPUnit_Framework_MockObject_Stub_ReturnValueMap' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Stub/ReturnValueMap.php',
+ 'PHPUnit_Framework_MockObject_Verifiable' => __DIR__ . '/..' . '/phpunit/phpunit-mock-objects/src/Framework/MockObject/Verifiable.php',
+ 'PHPUnit_Framework_OutputError' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/OutputError.php',
+ 'PHPUnit_Framework_RiskyTest' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/RiskyTest.php',
+ 'PHPUnit_Framework_RiskyTestError' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/RiskyTestError.php',
+ 'PHPUnit_Framework_SelfDescribing' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/SelfDescribing.php',
+ 'PHPUnit_Framework_SkippedTest' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/SkippedTest.php',
+ 'PHPUnit_Framework_SkippedTestCase' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/SkippedTestCase.php',
+ 'PHPUnit_Framework_SkippedTestError' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/SkippedTestError.php',
+ 'PHPUnit_Framework_SkippedTestSuiteError' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/SkippedTestSuiteError.php',
+ 'PHPUnit_Framework_SyntheticError' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/SyntheticError.php',
+ 'PHPUnit_Framework_Test' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Test.php',
+ 'PHPUnit_Framework_TestCase' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/TestCase.php',
+ 'PHPUnit_Framework_TestFailure' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/TestFailure.php',
+ 'PHPUnit_Framework_TestListener' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/TestListener.php',
+ 'PHPUnit_Framework_TestResult' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/TestResult.php',
+ 'PHPUnit_Framework_TestSuite' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/TestSuite.php',
+ 'PHPUnit_Framework_TestSuite_DataProvider' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/TestSuite/DataProvider.php',
+ 'PHPUnit_Framework_UnintentionallyCoveredCodeError' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/UnintentionallyCoveredCodeError.php',
+ 'PHPUnit_Framework_Warning' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/Warning.php',
+ 'PHPUnit_Framework_WarningTestCase' => __DIR__ . '/..' . '/phpunit/phpunit/src/Framework/WarningTestCase.php',
+ 'PHPUnit_Runner_BaseTestRunner' => __DIR__ . '/..' . '/phpunit/phpunit/src/Runner/BaseTestRunner.php',
+ 'PHPUnit_Runner_Exception' => __DIR__ . '/..' . '/phpunit/phpunit/src/Runner/Exception.php',
+ 'PHPUnit_Runner_Filter_Factory' => __DIR__ . '/..' . '/phpunit/phpunit/src/Runner/Filter/Factory.php',
+ 'PHPUnit_Runner_Filter_GroupFilterIterator' => __DIR__ . '/..' . '/phpunit/phpunit/src/Runner/Filter/Group.php',
+ 'PHPUnit_Runner_Filter_Group_Exclude' => __DIR__ . '/..' . '/phpunit/phpunit/src/Runner/Filter/Group/Exclude.php',
+ 'PHPUnit_Runner_Filter_Group_Include' => __DIR__ . '/..' . '/phpunit/phpunit/src/Runner/Filter/Group/Include.php',
+ 'PHPUnit_Runner_Filter_Test' => __DIR__ . '/..' . '/phpunit/phpunit/src/Runner/Filter/Test.php',
+ 'PHPUnit_Runner_StandardTestSuiteLoader' => __DIR__ . '/..' . '/phpunit/phpunit/src/Runner/StandardTestSuiteLoader.php',
+ 'PHPUnit_Runner_TestSuiteLoader' => __DIR__ . '/..' . '/phpunit/phpunit/src/Runner/TestSuiteLoader.php',
+ 'PHPUnit_Runner_Version' => __DIR__ . '/..' . '/phpunit/phpunit/src/Runner/Version.php',
+ 'PHPUnit_TextUI_Command' => __DIR__ . '/..' . '/phpunit/phpunit/src/TextUI/Command.php',
+ 'PHPUnit_TextUI_ResultPrinter' => __DIR__ . '/..' . '/phpunit/phpunit/src/TextUI/ResultPrinter.php',
+ 'PHPUnit_TextUI_TestRunner' => __DIR__ . '/..' . '/phpunit/phpunit/src/TextUI/TestRunner.php',
+ 'PHPUnit_Util_Blacklist' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Blacklist.php',
+ 'PHPUnit_Util_Configuration' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Configuration.php',
+ 'PHPUnit_Util_ConfigurationGenerator' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/ConfigurationGenerator.php',
+ 'PHPUnit_Util_ErrorHandler' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/ErrorHandler.php',
+ 'PHPUnit_Util_Fileloader' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Fileloader.php',
+ 'PHPUnit_Util_Filesystem' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Filesystem.php',
+ 'PHPUnit_Util_Filter' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Filter.php',
+ 'PHPUnit_Util_Getopt' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Getopt.php',
+ 'PHPUnit_Util_GlobalState' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/GlobalState.php',
+ 'PHPUnit_Util_InvalidArgumentHelper' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/InvalidArgumentHelper.php',
+ 'PHPUnit_Util_Log_JSON' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Log/JSON.php',
+ 'PHPUnit_Util_Log_JUnit' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Log/JUnit.php',
+ 'PHPUnit_Util_Log_TAP' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Log/TAP.php',
+ 'PHPUnit_Util_Log_TeamCity' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Log/TeamCity.php',
+ 'PHPUnit_Util_PHP' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/PHP.php',
+ 'PHPUnit_Util_PHP_Default' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/PHP/Default.php',
+ 'PHPUnit_Util_PHP_Windows' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/PHP/Windows.php',
+ 'PHPUnit_Util_Printer' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Printer.php',
+ 'PHPUnit_Util_Regex' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Regex.php',
+ 'PHPUnit_Util_String' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/String.php',
+ 'PHPUnit_Util_Test' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Test.php',
+ 'PHPUnit_Util_TestDox_NamePrettifier' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/TestDox/NamePrettifier.php',
+ 'PHPUnit_Util_TestDox_ResultPrinter' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/TestDox/ResultPrinter.php',
+ 'PHPUnit_Util_TestDox_ResultPrinter_HTML' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/TestDox/ResultPrinter/HTML.php',
+ 'PHPUnit_Util_TestDox_ResultPrinter_Text' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/TestDox/ResultPrinter/Text.php',
+ 'PHPUnit_Util_TestDox_ResultPrinter_XML' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/TestDox/ResultPrinter/XML.php',
+ 'PHPUnit_Util_TestSuiteIterator' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/TestSuiteIterator.php',
+ 'PHPUnit_Util_Type' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/Type.php',
+ 'PHPUnit_Util_XML' => __DIR__ . '/..' . '/phpunit/phpunit/src/Util/XML.php',
+ 'PHP_Timer' => __DIR__ . '/..' . '/phpunit/php-timer/src/Timer.php',
+ 'PHP_Token' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_TokenWithScope' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_TokenWithScopeAndVisibility' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ABSTRACT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_AMPERSAND' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_AND_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ARRAY' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ARRAY_CAST' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_AS' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ASYNC' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_AT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_AWAIT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BACKTICK' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BAD_CHARACTER' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BOOLEAN_AND' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BOOLEAN_OR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BOOL_CAST' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_BREAK' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CALLABLE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CARET' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CASE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CATCH' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CHARACTER' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLASS' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLASS_C' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLASS_NAME_CONSTANT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLONE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLOSE_BRACKET' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLOSE_CURLY' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLOSE_SQUARE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CLOSE_TAG' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_COALESCE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_COLON' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_COMMA' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_COMMENT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_COMPILER_HALT_OFFSET' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CONCAT_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CONST' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CONSTANT_ENCAPSED_STRING' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CONTINUE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_CURLY_OPEN' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DEC' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DECLARE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DEFAULT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DIR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DIV' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DIV_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DNUMBER' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DO' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOC_COMMENT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOLLAR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOLLAR_OPEN_CURLY_BRACES' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOUBLE_ARROW' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOUBLE_CAST' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOUBLE_COLON' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_DOUBLE_QUOTES' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ECHO' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ELLIPSIS' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ELSE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ELSEIF' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EMPTY' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENCAPSED_AND_WHITESPACE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDDECLARE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDFOR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDFOREACH' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDIF' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDSWITCH' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENDWHILE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_END_HEREDOC' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ENUM' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EQUALS' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EVAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EXCLAMATION_MARK' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EXIT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_EXTENDS' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FILE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FINAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FINALLY' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FOR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FOREACH' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FUNCTION' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_FUNC_C' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_GLOBAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_GOTO' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_GT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_HALT_COMPILER' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IF' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IMPLEMENTS' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IN' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INC' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INCLUDE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INCLUDE_ONCE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INLINE_HTML' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INSTANCEOF' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INSTEADOF' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INTERFACE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_INT_CAST' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ISSET' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_GREATER_OR_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_IDENTICAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_NOT_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_NOT_IDENTICAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_IS_SMALLER_OR_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_Includes' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_JOIN' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LAMBDA_ARROW' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LAMBDA_CP' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LAMBDA_OP' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LINE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LIST' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LNUMBER' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LOGICAL_AND' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LOGICAL_OR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LOGICAL_XOR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_LT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_METHOD_C' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_MINUS' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_MINUS_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_MOD_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_MULT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_MUL_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NAMESPACE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NEW' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NS_C' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NS_SEPARATOR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NULLSAFE_OBJECT_OPERATOR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_NUM_STRING' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OBJECT_CAST' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OBJECT_OPERATOR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_ONUMBER' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OPEN_BRACKET' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OPEN_CURLY' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OPEN_SQUARE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OPEN_TAG' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OPEN_TAG_WITH_ECHO' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_OR_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PAAMAYIM_NEKUDOTAYIM' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PERCENT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PIPE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PLUS' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PLUS_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_POW' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_POW_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PRINT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PRIVATE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PROTECTED' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_PUBLIC' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_QUESTION_MARK' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_REQUIRE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_REQUIRE_ONCE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_RETURN' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SEMICOLON' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SHAPE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SL_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SPACESHIP' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SR_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_START_HEREDOC' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_STATIC' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_STRING' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_STRING_CAST' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_STRING_VARNAME' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SUPER' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_SWITCH' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_Stream' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token/Stream.php',
+ 'PHP_Token_Stream_CachingFactory' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token/Stream/CachingFactory.php',
+ 'PHP_Token_THROW' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TILDE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TRAIT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TRAIT_C' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TRY' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TYPE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TYPELIST_GT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_TYPELIST_LT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_UNSET' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_UNSET_CAST' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_USE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_USE_FUNCTION' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_VAR' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_VARIABLE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_WHERE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_WHILE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_WHITESPACE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_ATTRIBUTE' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_CATEGORY' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_CATEGORY_LABEL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_CHILDREN' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_LABEL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_REQUIRED' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_TAG_GT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_TAG_LT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XHP_TEXT' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_XOR_EQUAL' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_YIELD' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'PHP_Token_YIELD_FROM' => __DIR__ . '/..' . '/phpunit/php-token-stream/src/Token.php',
+ 'ParseError' => __DIR__ . '/..' . '/symfony/polyfill-php70/Resources/stubs/ParseError.php',
+ 'Parsedown' => __DIR__ . '/..' . '/erusev/parsedown/Parsedown.php',
+ 'PhpParser\\Autoloader' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Autoloader.php',
+ 'PhpParser\\Builder' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder.php',
+ 'PhpParser\\BuilderAbstract' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/BuilderAbstract.php',
+ 'PhpParser\\BuilderFactory' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/BuilderFactory.php',
+ 'PhpParser\\Builder\\Class_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/Class_.php',
+ 'PhpParser\\Builder\\Declaration' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/Declaration.php',
+ 'PhpParser\\Builder\\FunctionLike' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/FunctionLike.php',
+ 'PhpParser\\Builder\\Function_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/Function_.php',
+ 'PhpParser\\Builder\\Interface_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/Interface_.php',
+ 'PhpParser\\Builder\\Method' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/Method.php',
+ 'PhpParser\\Builder\\Namespace_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/Namespace_.php',
+ 'PhpParser\\Builder\\Param' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/Param.php',
+ 'PhpParser\\Builder\\Property' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/Property.php',
+ 'PhpParser\\Builder\\Trait_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/Trait_.php',
+ 'PhpParser\\Builder\\Use_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Builder/Use_.php',
+ 'PhpParser\\Comment' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Comment.php',
+ 'PhpParser\\Comment\\Doc' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Comment/Doc.php',
+ 'PhpParser\\Error' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Error.php',
+ 'PhpParser\\ErrorHandler' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/ErrorHandler.php',
+ 'PhpParser\\ErrorHandler\\Collecting' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/ErrorHandler/Collecting.php',
+ 'PhpParser\\ErrorHandler\\Throwing' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/ErrorHandler/Throwing.php',
+ 'PhpParser\\Lexer' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Lexer.php',
+ 'PhpParser\\Lexer\\Emulative' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Lexer/Emulative.php',
+ 'PhpParser\\Node' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node.php',
+ 'PhpParser\\NodeAbstract' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/NodeAbstract.php',
+ 'PhpParser\\NodeDumper' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/NodeDumper.php',
+ 'PhpParser\\NodeTraverser' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/NodeTraverser.php',
+ 'PhpParser\\NodeTraverserInterface' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/NodeTraverserInterface.php',
+ 'PhpParser\\NodeVisitor' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/NodeVisitor.php',
+ 'PhpParser\\NodeVisitorAbstract' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/NodeVisitorAbstract.php',
+ 'PhpParser\\NodeVisitor\\NameResolver' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/NodeVisitor/NameResolver.php',
+ 'PhpParser\\Node\\Arg' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Arg.php',
+ 'PhpParser\\Node\\Const_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Const_.php',
+ 'PhpParser\\Node\\Expr' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr.php',
+ 'PhpParser\\Node\\Expr\\ArrayDimFetch' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/ArrayDimFetch.php',
+ 'PhpParser\\Node\\Expr\\ArrayItem' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/ArrayItem.php',
+ 'PhpParser\\Node\\Expr\\Array_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Array_.php',
+ 'PhpParser\\Node\\Expr\\Assign' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Assign.php',
+ 'PhpParser\\Node\\Expr\\AssignOp' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\BitwiseAnd' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/BitwiseAnd.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\BitwiseOr' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/BitwiseOr.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\BitwiseXor' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/BitwiseXor.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Concat' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Concat.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Div' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Div.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Minus' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Minus.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Mod' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Mod.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Mul' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Mul.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Plus' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Plus.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\Pow' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/Pow.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\ShiftLeft' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/ShiftLeft.php',
+ 'PhpParser\\Node\\Expr\\AssignOp\\ShiftRight' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignOp/ShiftRight.php',
+ 'PhpParser\\Node\\Expr\\AssignRef' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/AssignRef.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\BitwiseAnd' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BitwiseAnd.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\BitwiseOr' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BitwiseOr.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\BitwiseXor' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BitwiseXor.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\BooleanAnd' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BooleanAnd.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\BooleanOr' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/BooleanOr.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Coalesce' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Coalesce.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Concat' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Concat.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Div' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Div.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Equal' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Equal.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Greater' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Greater.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\GreaterOrEqual' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/GreaterOrEqual.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Identical' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Identical.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\LogicalAnd' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/LogicalAnd.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\LogicalOr' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/LogicalOr.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\LogicalXor' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/LogicalXor.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Minus' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Minus.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Mod' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Mod.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Mul' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Mul.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\NotEqual' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/NotEqual.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\NotIdentical' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/NotIdentical.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Plus' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Plus.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Pow' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Pow.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\ShiftLeft' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/ShiftLeft.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\ShiftRight' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/ShiftRight.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Smaller' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Smaller.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\SmallerOrEqual' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/SmallerOrEqual.php',
+ 'PhpParser\\Node\\Expr\\BinaryOp\\Spaceship' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BinaryOp/Spaceship.php',
+ 'PhpParser\\Node\\Expr\\BitwiseNot' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BitwiseNot.php',
+ 'PhpParser\\Node\\Expr\\BooleanNot' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/BooleanNot.php',
+ 'PhpParser\\Node\\Expr\\Cast' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Array_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Array_.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Bool_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Bool_.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Double' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Double.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Int_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Int_.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Object_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Object_.php',
+ 'PhpParser\\Node\\Expr\\Cast\\String_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/String_.php',
+ 'PhpParser\\Node\\Expr\\Cast\\Unset_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Cast/Unset_.php',
+ 'PhpParser\\Node\\Expr\\ClassConstFetch' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/ClassConstFetch.php',
+ 'PhpParser\\Node\\Expr\\Clone_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Clone_.php',
+ 'PhpParser\\Node\\Expr\\Closure' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Closure.php',
+ 'PhpParser\\Node\\Expr\\ClosureUse' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/ClosureUse.php',
+ 'PhpParser\\Node\\Expr\\ConstFetch' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/ConstFetch.php',
+ 'PhpParser\\Node\\Expr\\Empty_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Empty_.php',
+ 'PhpParser\\Node\\Expr\\Error' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Error.php',
+ 'PhpParser\\Node\\Expr\\ErrorSuppress' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/ErrorSuppress.php',
+ 'PhpParser\\Node\\Expr\\Eval_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Eval_.php',
+ 'PhpParser\\Node\\Expr\\Exit_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Exit_.php',
+ 'PhpParser\\Node\\Expr\\FuncCall' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/FuncCall.php',
+ 'PhpParser\\Node\\Expr\\Include_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Include_.php',
+ 'PhpParser\\Node\\Expr\\Instanceof_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Instanceof_.php',
+ 'PhpParser\\Node\\Expr\\Isset_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Isset_.php',
+ 'PhpParser\\Node\\Expr\\List_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/List_.php',
+ 'PhpParser\\Node\\Expr\\MethodCall' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/MethodCall.php',
+ 'PhpParser\\Node\\Expr\\New_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/New_.php',
+ 'PhpParser\\Node\\Expr\\PostDec' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/PostDec.php',
+ 'PhpParser\\Node\\Expr\\PostInc' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/PostInc.php',
+ 'PhpParser\\Node\\Expr\\PreDec' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/PreDec.php',
+ 'PhpParser\\Node\\Expr\\PreInc' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/PreInc.php',
+ 'PhpParser\\Node\\Expr\\Print_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Print_.php',
+ 'PhpParser\\Node\\Expr\\PropertyFetch' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/PropertyFetch.php',
+ 'PhpParser\\Node\\Expr\\ShellExec' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/ShellExec.php',
+ 'PhpParser\\Node\\Expr\\StaticCall' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/StaticCall.php',
+ 'PhpParser\\Node\\Expr\\StaticPropertyFetch' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/StaticPropertyFetch.php',
+ 'PhpParser\\Node\\Expr\\Ternary' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Ternary.php',
+ 'PhpParser\\Node\\Expr\\UnaryMinus' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/UnaryMinus.php',
+ 'PhpParser\\Node\\Expr\\UnaryPlus' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/UnaryPlus.php',
+ 'PhpParser\\Node\\Expr\\Variable' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Variable.php',
+ 'PhpParser\\Node\\Expr\\YieldFrom' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/YieldFrom.php',
+ 'PhpParser\\Node\\Expr\\Yield_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Expr/Yield_.php',
+ 'PhpParser\\Node\\FunctionLike' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/FunctionLike.php',
+ 'PhpParser\\Node\\Name' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Name.php',
+ 'PhpParser\\Node\\Name\\FullyQualified' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Name/FullyQualified.php',
+ 'PhpParser\\Node\\Name\\Relative' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Name/Relative.php',
+ 'PhpParser\\Node\\NullableType' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/NullableType.php',
+ 'PhpParser\\Node\\Param' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Param.php',
+ 'PhpParser\\Node\\Scalar' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar.php',
+ 'PhpParser\\Node\\Scalar\\DNumber' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/DNumber.php',
+ 'PhpParser\\Node\\Scalar\\Encapsed' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/Encapsed.php',
+ 'PhpParser\\Node\\Scalar\\EncapsedStringPart' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/EncapsedStringPart.php',
+ 'PhpParser\\Node\\Scalar\\LNumber' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/LNumber.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Class_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Class_.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Dir' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Dir.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\File' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/File.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Function_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Function_.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Line' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Line.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Method' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Method.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Namespace_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Namespace_.php',
+ 'PhpParser\\Node\\Scalar\\MagicConst\\Trait_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/MagicConst/Trait_.php',
+ 'PhpParser\\Node\\Scalar\\String_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Scalar/String_.php',
+ 'PhpParser\\Node\\Stmt' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt.php',
+ 'PhpParser\\Node\\Stmt\\Break_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Break_.php',
+ 'PhpParser\\Node\\Stmt\\Case_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Case_.php',
+ 'PhpParser\\Node\\Stmt\\Catch_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Catch_.php',
+ 'PhpParser\\Node\\Stmt\\ClassConst' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/ClassConst.php',
+ 'PhpParser\\Node\\Stmt\\ClassLike' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/ClassLike.php',
+ 'PhpParser\\Node\\Stmt\\ClassMethod' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/ClassMethod.php',
+ 'PhpParser\\Node\\Stmt\\Class_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Class_.php',
+ 'PhpParser\\Node\\Stmt\\Const_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Const_.php',
+ 'PhpParser\\Node\\Stmt\\Continue_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Continue_.php',
+ 'PhpParser\\Node\\Stmt\\DeclareDeclare' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/DeclareDeclare.php',
+ 'PhpParser\\Node\\Stmt\\Declare_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Declare_.php',
+ 'PhpParser\\Node\\Stmt\\Do_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Do_.php',
+ 'PhpParser\\Node\\Stmt\\Echo_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Echo_.php',
+ 'PhpParser\\Node\\Stmt\\ElseIf_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/ElseIf_.php',
+ 'PhpParser\\Node\\Stmt\\Else_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Else_.php',
+ 'PhpParser\\Node\\Stmt\\Finally_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Finally_.php',
+ 'PhpParser\\Node\\Stmt\\For_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/For_.php',
+ 'PhpParser\\Node\\Stmt\\Foreach_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Foreach_.php',
+ 'PhpParser\\Node\\Stmt\\Function_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Function_.php',
+ 'PhpParser\\Node\\Stmt\\Global_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Global_.php',
+ 'PhpParser\\Node\\Stmt\\Goto_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Goto_.php',
+ 'PhpParser\\Node\\Stmt\\GroupUse' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/GroupUse.php',
+ 'PhpParser\\Node\\Stmt\\HaltCompiler' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/HaltCompiler.php',
+ 'PhpParser\\Node\\Stmt\\If_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/If_.php',
+ 'PhpParser\\Node\\Stmt\\InlineHTML' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/InlineHTML.php',
+ 'PhpParser\\Node\\Stmt\\Interface_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Interface_.php',
+ 'PhpParser\\Node\\Stmt\\Label' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Label.php',
+ 'PhpParser\\Node\\Stmt\\Namespace_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Namespace_.php',
+ 'PhpParser\\Node\\Stmt\\Nop' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Nop.php',
+ 'PhpParser\\Node\\Stmt\\Property' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Property.php',
+ 'PhpParser\\Node\\Stmt\\PropertyProperty' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/PropertyProperty.php',
+ 'PhpParser\\Node\\Stmt\\Return_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Return_.php',
+ 'PhpParser\\Node\\Stmt\\StaticVar' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/StaticVar.php',
+ 'PhpParser\\Node\\Stmt\\Static_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Static_.php',
+ 'PhpParser\\Node\\Stmt\\Switch_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Switch_.php',
+ 'PhpParser\\Node\\Stmt\\Throw_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Throw_.php',
+ 'PhpParser\\Node\\Stmt\\TraitUse' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUse.php',
+ 'PhpParser\\Node\\Stmt\\TraitUseAdaptation' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUseAdaptation.php',
+ 'PhpParser\\Node\\Stmt\\TraitUseAdaptation\\Alias' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUseAdaptation/Alias.php',
+ 'PhpParser\\Node\\Stmt\\TraitUseAdaptation\\Precedence' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/TraitUseAdaptation/Precedence.php',
+ 'PhpParser\\Node\\Stmt\\Trait_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Trait_.php',
+ 'PhpParser\\Node\\Stmt\\TryCatch' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/TryCatch.php',
+ 'PhpParser\\Node\\Stmt\\Unset_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Unset_.php',
+ 'PhpParser\\Node\\Stmt\\UseUse' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/UseUse.php',
+ 'PhpParser\\Node\\Stmt\\Use_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/Use_.php',
+ 'PhpParser\\Node\\Stmt\\While_' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Node/Stmt/While_.php',
+ 'PhpParser\\Parser' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Parser.php',
+ 'PhpParser\\ParserAbstract' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/ParserAbstract.php',
+ 'PhpParser\\ParserFactory' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/ParserFactory.php',
+ 'PhpParser\\Parser\\Multiple' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Parser/Multiple.php',
+ 'PhpParser\\Parser\\Php5' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Parser/Php5.php',
+ 'PhpParser\\Parser\\Php7' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Parser/Php7.php',
+ 'PhpParser\\Parser\\Tokens' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Parser/Tokens.php',
+ 'PhpParser\\PrettyPrinterAbstract' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/PrettyPrinterAbstract.php',
+ 'PhpParser\\PrettyPrinter\\Standard' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/PrettyPrinter/Standard.php',
+ 'PhpParser\\Serializer' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Serializer.php',
+ 'PhpParser\\Serializer\\XML' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Serializer/XML.php',
+ 'PhpParser\\Unserializer' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Unserializer.php',
+ 'PhpParser\\Unserializer\\XML' => __DIR__ . '/..' . '/nikic/php-parser/lib/PhpParser/Unserializer/XML.php',
+ 'Prophecy\\Argument' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument.php',
+ 'Prophecy\\Argument\\ArgumentsWildcard' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/ArgumentsWildcard.php',
+ 'Prophecy\\Argument\\Token\\AnyValueToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/AnyValueToken.php',
+ 'Prophecy\\Argument\\Token\\AnyValuesToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/AnyValuesToken.php',
+ 'Prophecy\\Argument\\Token\\ApproximateValueToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/ApproximateValueToken.php',
+ 'Prophecy\\Argument\\Token\\ArrayCountToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/ArrayCountToken.php',
+ 'Prophecy\\Argument\\Token\\ArrayEntryToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/ArrayEntryToken.php',
+ 'Prophecy\\Argument\\Token\\ArrayEveryEntryToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/ArrayEveryEntryToken.php',
+ 'Prophecy\\Argument\\Token\\CallbackToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/CallbackToken.php',
+ 'Prophecy\\Argument\\Token\\ExactValueToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/ExactValueToken.php',
+ 'Prophecy\\Argument\\Token\\IdenticalValueToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/IdenticalValueToken.php',
+ 'Prophecy\\Argument\\Token\\LogicalAndToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/LogicalAndToken.php',
+ 'Prophecy\\Argument\\Token\\LogicalNotToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/LogicalNotToken.php',
+ 'Prophecy\\Argument\\Token\\ObjectStateToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/ObjectStateToken.php',
+ 'Prophecy\\Argument\\Token\\StringContainsToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/StringContainsToken.php',
+ 'Prophecy\\Argument\\Token\\TokenInterface' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/TokenInterface.php',
+ 'Prophecy\\Argument\\Token\\TypeToken' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Argument/Token/TypeToken.php',
+ 'Prophecy\\Call\\Call' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Call/Call.php',
+ 'Prophecy\\Call\\CallCenter' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Call/CallCenter.php',
+ 'Prophecy\\Comparator\\ClosureComparator' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Comparator/ClosureComparator.php',
+ 'Prophecy\\Comparator\\Factory' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Comparator/Factory.php',
+ 'Prophecy\\Comparator\\ProphecyComparator' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Comparator/ProphecyComparator.php',
+ 'Prophecy\\Doubler\\CachedDoubler' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/CachedDoubler.php',
+ 'Prophecy\\Doubler\\ClassPatch\\ClassPatchInterface' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ClassPatchInterface.php',
+ 'Prophecy\\Doubler\\ClassPatch\\DisableConstructorPatch' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/DisableConstructorPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\HhvmExceptionPatch' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/HhvmExceptionPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\KeywordPatch' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/KeywordPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\MagicCallPatch' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/MagicCallPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\ProphecySubjectPatch' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ProphecySubjectPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\ReflectionClassNewInstancePatch' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ReflectionClassNewInstancePatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\SplFileInfoPatch' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/SplFileInfoPatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\ThrowablePatch' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/ThrowablePatch.php',
+ 'Prophecy\\Doubler\\ClassPatch\\TraversablePatch' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/ClassPatch/TraversablePatch.php',
+ 'Prophecy\\Doubler\\DoubleInterface' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/DoubleInterface.php',
+ 'Prophecy\\Doubler\\Doubler' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/Doubler.php',
+ 'Prophecy\\Doubler\\Generator\\ClassCodeGenerator' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/ClassCodeGenerator.php',
+ 'Prophecy\\Doubler\\Generator\\ClassCreator' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/ClassCreator.php',
+ 'Prophecy\\Doubler\\Generator\\ClassMirror' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/ClassMirror.php',
+ 'Prophecy\\Doubler\\Generator\\Node\\ArgumentNode' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/Node/ArgumentNode.php',
+ 'Prophecy\\Doubler\\Generator\\Node\\ClassNode' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/Node/ClassNode.php',
+ 'Prophecy\\Doubler\\Generator\\Node\\MethodNode' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/Node/MethodNode.php',
+ 'Prophecy\\Doubler\\Generator\\ReflectionInterface' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/ReflectionInterface.php',
+ 'Prophecy\\Doubler\\Generator\\TypeHintReference' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/Generator/TypeHintReference.php',
+ 'Prophecy\\Doubler\\LazyDouble' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/LazyDouble.php',
+ 'Prophecy\\Doubler\\NameGenerator' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Doubler/NameGenerator.php',
+ 'Prophecy\\Exception\\Call\\UnexpectedCallException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Call/UnexpectedCallException.php',
+ 'Prophecy\\Exception\\Doubler\\ClassCreatorException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/ClassCreatorException.php',
+ 'Prophecy\\Exception\\Doubler\\ClassMirrorException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/ClassMirrorException.php',
+ 'Prophecy\\Exception\\Doubler\\ClassNotFoundException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/ClassNotFoundException.php',
+ 'Prophecy\\Exception\\Doubler\\DoubleException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/DoubleException.php',
+ 'Prophecy\\Exception\\Doubler\\DoublerException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/DoublerException.php',
+ 'Prophecy\\Exception\\Doubler\\InterfaceNotFoundException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/InterfaceNotFoundException.php',
+ 'Prophecy\\Exception\\Doubler\\MethodNotExtendableException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/MethodNotExtendableException.php',
+ 'Prophecy\\Exception\\Doubler\\MethodNotFoundException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/MethodNotFoundException.php',
+ 'Prophecy\\Exception\\Doubler\\ReturnByReferenceException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Doubler/ReturnByReferenceException.php',
+ 'Prophecy\\Exception\\Exception' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Exception.php',
+ 'Prophecy\\Exception\\InvalidArgumentException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/InvalidArgumentException.php',
+ 'Prophecy\\Exception\\Prediction\\AggregateException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/AggregateException.php',
+ 'Prophecy\\Exception\\Prediction\\FailedPredictionException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/FailedPredictionException.php',
+ 'Prophecy\\Exception\\Prediction\\NoCallsException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/NoCallsException.php',
+ 'Prophecy\\Exception\\Prediction\\PredictionException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/PredictionException.php',
+ 'Prophecy\\Exception\\Prediction\\UnexpectedCallsCountException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/UnexpectedCallsCountException.php',
+ 'Prophecy\\Exception\\Prediction\\UnexpectedCallsException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Prediction/UnexpectedCallsException.php',
+ 'Prophecy\\Exception\\Prophecy\\MethodProphecyException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Prophecy/MethodProphecyException.php',
+ 'Prophecy\\Exception\\Prophecy\\ObjectProphecyException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Prophecy/ObjectProphecyException.php',
+ 'Prophecy\\Exception\\Prophecy\\ProphecyException' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Exception/Prophecy/ProphecyException.php',
+ 'Prophecy\\PhpDocumentor\\ClassAndInterfaceTagRetriever' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/PhpDocumentor/ClassAndInterfaceTagRetriever.php',
+ 'Prophecy\\PhpDocumentor\\ClassTagRetriever' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/PhpDocumentor/ClassTagRetriever.php',
+ 'Prophecy\\PhpDocumentor\\LegacyClassTagRetriever' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/PhpDocumentor/LegacyClassTagRetriever.php',
+ 'Prophecy\\PhpDocumentor\\MethodTagRetrieverInterface' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/PhpDocumentor/MethodTagRetrieverInterface.php',
+ 'Prophecy\\Prediction\\CallPrediction' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prediction/CallPrediction.php',
+ 'Prophecy\\Prediction\\CallTimesPrediction' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prediction/CallTimesPrediction.php',
+ 'Prophecy\\Prediction\\CallbackPrediction' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prediction/CallbackPrediction.php',
+ 'Prophecy\\Prediction\\NoCallsPrediction' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prediction/NoCallsPrediction.php',
+ 'Prophecy\\Prediction\\PredictionInterface' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prediction/PredictionInterface.php',
+ 'Prophecy\\Promise\\CallbackPromise' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Promise/CallbackPromise.php',
+ 'Prophecy\\Promise\\PromiseInterface' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Promise/PromiseInterface.php',
+ 'Prophecy\\Promise\\ReturnArgumentPromise' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Promise/ReturnArgumentPromise.php',
+ 'Prophecy\\Promise\\ReturnPromise' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Promise/ReturnPromise.php',
+ 'Prophecy\\Promise\\ThrowPromise' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Promise/ThrowPromise.php',
+ 'Prophecy\\Prophecy\\MethodProphecy' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prophecy/MethodProphecy.php',
+ 'Prophecy\\Prophecy\\ObjectProphecy' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prophecy/ObjectProphecy.php',
+ 'Prophecy\\Prophecy\\ProphecyInterface' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prophecy/ProphecyInterface.php',
+ 'Prophecy\\Prophecy\\ProphecySubjectInterface' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prophecy/ProphecySubjectInterface.php',
+ 'Prophecy\\Prophecy\\Revealer' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prophecy/Revealer.php',
+ 'Prophecy\\Prophecy\\RevealerInterface' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prophecy/RevealerInterface.php',
+ 'Prophecy\\Prophet' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Prophet.php',
+ 'Prophecy\\Util\\ExportUtil' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Util/ExportUtil.php',
+ 'Prophecy\\Util\\StringUtil' => __DIR__ . '/..' . '/phpspec/prophecy/src/Prophecy/Util/StringUtil.php',
+ 'Psr\\Log\\AbstractLogger' => __DIR__ . '/..' . '/psr/log/Psr/Log/AbstractLogger.php',
+ 'Psr\\Log\\InvalidArgumentException' => __DIR__ . '/..' . '/psr/log/Psr/Log/InvalidArgumentException.php',
+ 'Psr\\Log\\LogLevel' => __DIR__ . '/..' . '/psr/log/Psr/Log/LogLevel.php',
+ 'Psr\\Log\\LoggerAwareInterface' => __DIR__ . '/..' . '/psr/log/Psr/Log/LoggerAwareInterface.php',
+ 'Psr\\Log\\LoggerAwareTrait' => __DIR__ . '/..' . '/psr/log/Psr/Log/LoggerAwareTrait.php',
+ 'Psr\\Log\\LoggerInterface' => __DIR__ . '/..' . '/psr/log/Psr/Log/LoggerInterface.php',
+ 'Psr\\Log\\LoggerTrait' => __DIR__ . '/..' . '/psr/log/Psr/Log/LoggerTrait.php',
+ 'Psr\\Log\\NullLogger' => __DIR__ . '/..' . '/psr/log/Psr/Log/NullLogger.php',
+ 'Psr\\Log\\Test\\DummyTest' => __DIR__ . '/..' . '/psr/log/Psr/Log/Test/DummyTest.php',
+ 'Psr\\Log\\Test\\LoggerInterfaceTest' => __DIR__ . '/..' . '/psr/log/Psr/Log/Test/LoggerInterfaceTest.php',
+ 'Psr\\Log\\Test\\TestLogger' => __DIR__ . '/..' . '/psr/log/Psr/Log/Test/TestLogger.php',
+ 'Psy\\CodeCleaner' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner.php',
+ 'Psy\\CodeCleaner\\AbstractClassPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/AbstractClassPass.php',
+ 'Psy\\CodeCleaner\\AssignThisVariablePass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/AssignThisVariablePass.php',
+ 'Psy\\CodeCleaner\\CallTimePassByReferencePass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/CallTimePassByReferencePass.php',
+ 'Psy\\CodeCleaner\\CalledClassPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/CalledClassPass.php',
+ 'Psy\\CodeCleaner\\CodeCleanerPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/CodeCleanerPass.php',
+ 'Psy\\CodeCleaner\\ExitPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/ExitPass.php',
+ 'Psy\\CodeCleaner\\FinalClassPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/FinalClassPass.php',
+ 'Psy\\CodeCleaner\\FunctionContextPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/FunctionContextPass.php',
+ 'Psy\\CodeCleaner\\FunctionReturnInWriteContextPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/FunctionReturnInWriteContextPass.php',
+ 'Psy\\CodeCleaner\\ImplicitReturnPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/ImplicitReturnPass.php',
+ 'Psy\\CodeCleaner\\InstanceOfPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/InstanceOfPass.php',
+ 'Psy\\CodeCleaner\\LeavePsyshAlonePass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/LeavePsyshAlonePass.php',
+ 'Psy\\CodeCleaner\\LegacyEmptyPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/LegacyEmptyPass.php',
+ 'Psy\\CodeCleaner\\ListPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/ListPass.php',
+ 'Psy\\CodeCleaner\\LoopContextPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/LoopContextPass.php',
+ 'Psy\\CodeCleaner\\MagicConstantsPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/MagicConstantsPass.php',
+ 'Psy\\CodeCleaner\\NamespaceAwarePass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/NamespaceAwarePass.php',
+ 'Psy\\CodeCleaner\\NamespacePass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/NamespacePass.php',
+ 'Psy\\CodeCleaner\\NoReturnValue' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/NoReturnValue.php',
+ 'Psy\\CodeCleaner\\PassableByReferencePass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/PassableByReferencePass.php',
+ 'Psy\\CodeCleaner\\RequirePass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/RequirePass.php',
+ 'Psy\\CodeCleaner\\StrictTypesPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/StrictTypesPass.php',
+ 'Psy\\CodeCleaner\\UseStatementPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/UseStatementPass.php',
+ 'Psy\\CodeCleaner\\ValidClassNamePass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/ValidClassNamePass.php',
+ 'Psy\\CodeCleaner\\ValidConstantPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/ValidConstantPass.php',
+ 'Psy\\CodeCleaner\\ValidConstructorPass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/ValidConstructorPass.php',
+ 'Psy\\CodeCleaner\\ValidFunctionNamePass' => __DIR__ . '/..' . '/psy/psysh/src/CodeCleaner/ValidFunctionNamePass.php',
+ 'Psy\\Command\\BufferCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/BufferCommand.php',
+ 'Psy\\Command\\ClearCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/ClearCommand.php',
+ 'Psy\\Command\\Command' => __DIR__ . '/..' . '/psy/psysh/src/Command/Command.php',
+ 'Psy\\Command\\DocCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/DocCommand.php',
+ 'Psy\\Command\\DumpCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/DumpCommand.php',
+ 'Psy\\Command\\EditCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/EditCommand.php',
+ 'Psy\\Command\\ExitCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/ExitCommand.php',
+ 'Psy\\Command\\HelpCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/HelpCommand.php',
+ 'Psy\\Command\\HistoryCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/HistoryCommand.php',
+ 'Psy\\Command\\ListCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand.php',
+ 'Psy\\Command\\ListCommand\\ClassConstantEnumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/ClassConstantEnumerator.php',
+ 'Psy\\Command\\ListCommand\\ClassEnumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/ClassEnumerator.php',
+ 'Psy\\Command\\ListCommand\\ConstantEnumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/ConstantEnumerator.php',
+ 'Psy\\Command\\ListCommand\\Enumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/Enumerator.php',
+ 'Psy\\Command\\ListCommand\\FunctionEnumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/FunctionEnumerator.php',
+ 'Psy\\Command\\ListCommand\\GlobalVariableEnumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/GlobalVariableEnumerator.php',
+ 'Psy\\Command\\ListCommand\\InterfaceEnumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/InterfaceEnumerator.php',
+ 'Psy\\Command\\ListCommand\\MethodEnumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/MethodEnumerator.php',
+ 'Psy\\Command\\ListCommand\\PropertyEnumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/PropertyEnumerator.php',
+ 'Psy\\Command\\ListCommand\\TraitEnumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/TraitEnumerator.php',
+ 'Psy\\Command\\ListCommand\\VariableEnumerator' => __DIR__ . '/..' . '/psy/psysh/src/Command/ListCommand/VariableEnumerator.php',
+ 'Psy\\Command\\ParseCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/ParseCommand.php',
+ 'Psy\\Command\\PsyVersionCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/PsyVersionCommand.php',
+ 'Psy\\Command\\ReflectingCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/ReflectingCommand.php',
+ 'Psy\\Command\\ShowCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/ShowCommand.php',
+ 'Psy\\Command\\SudoCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/SudoCommand.php',
+ 'Psy\\Command\\ThrowUpCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/ThrowUpCommand.php',
+ 'Psy\\Command\\TimeitCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/TimeitCommand.php',
+ 'Psy\\Command\\TimeitCommand\\TimeitVisitor' => __DIR__ . '/..' . '/psy/psysh/src/Command/TimeitCommand/TimeitVisitor.php',
+ 'Psy\\Command\\TraceCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/TraceCommand.php',
+ 'Psy\\Command\\WhereamiCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/WhereamiCommand.php',
+ 'Psy\\Command\\WtfCommand' => __DIR__ . '/..' . '/psy/psysh/src/Command/WtfCommand.php',
+ 'Psy\\ConfigPaths' => __DIR__ . '/..' . '/psy/psysh/src/ConfigPaths.php',
+ 'Psy\\Configuration' => __DIR__ . '/..' . '/psy/psysh/src/Configuration.php',
+ 'Psy\\ConsoleColorFactory' => __DIR__ . '/..' . '/psy/psysh/src/ConsoleColorFactory.php',
+ 'Psy\\Context' => __DIR__ . '/..' . '/psy/psysh/src/Context.php',
+ 'Psy\\ContextAware' => __DIR__ . '/..' . '/psy/psysh/src/ContextAware.php',
+ 'Psy\\Exception\\BreakException' => __DIR__ . '/..' . '/psy/psysh/src/Exception/BreakException.php',
+ 'Psy\\Exception\\DeprecatedException' => __DIR__ . '/..' . '/psy/psysh/src/Exception/DeprecatedException.php',
+ 'Psy\\Exception\\ErrorException' => __DIR__ . '/..' . '/psy/psysh/src/Exception/ErrorException.php',
+ 'Psy\\Exception\\Exception' => __DIR__ . '/..' . '/psy/psysh/src/Exception/Exception.php',
+ 'Psy\\Exception\\FatalErrorException' => __DIR__ . '/..' . '/psy/psysh/src/Exception/FatalErrorException.php',
+ 'Psy\\Exception\\ParseErrorException' => __DIR__ . '/..' . '/psy/psysh/src/Exception/ParseErrorException.php',
+ 'Psy\\Exception\\RuntimeException' => __DIR__ . '/..' . '/psy/psysh/src/Exception/RuntimeException.php',
+ 'Psy\\Exception\\ThrowUpException' => __DIR__ . '/..' . '/psy/psysh/src/Exception/ThrowUpException.php',
+ 'Psy\\Exception\\TypeErrorException' => __DIR__ . '/..' . '/psy/psysh/src/Exception/TypeErrorException.php',
+ 'Psy\\ExecutionClosure' => __DIR__ . '/..' . '/psy/psysh/src/ExecutionClosure.php',
+ 'Psy\\ExecutionLoop' => __DIR__ . '/..' . '/psy/psysh/src/ExecutionLoop.php',
+ 'Psy\\ExecutionLoopClosure' => __DIR__ . '/..' . '/psy/psysh/src/ExecutionLoopClosure.php',
+ 'Psy\\ExecutionLoop\\AbstractListener' => __DIR__ . '/..' . '/psy/psysh/src/ExecutionLoop/AbstractListener.php',
+ 'Psy\\ExecutionLoop\\Listener' => __DIR__ . '/..' . '/psy/psysh/src/ExecutionLoop/Listener.php',
+ 'Psy\\ExecutionLoop\\ProcessForker' => __DIR__ . '/..' . '/psy/psysh/src/ExecutionLoop/ProcessForker.php',
+ 'Psy\\ExecutionLoop\\RunkitReloader' => __DIR__ . '/..' . '/psy/psysh/src/ExecutionLoop/RunkitReloader.php',
+ 'Psy\\Formatter\\CodeFormatter' => __DIR__ . '/..' . '/psy/psysh/src/Formatter/CodeFormatter.php',
+ 'Psy\\Formatter\\DocblockFormatter' => __DIR__ . '/..' . '/psy/psysh/src/Formatter/DocblockFormatter.php',
+ 'Psy\\Formatter\\Formatter' => __DIR__ . '/..' . '/psy/psysh/src/Formatter/Formatter.php',
+ 'Psy\\Formatter\\SignatureFormatter' => __DIR__ . '/..' . '/psy/psysh/src/Formatter/SignatureFormatter.php',
+ 'Psy\\Input\\CodeArgument' => __DIR__ . '/..' . '/psy/psysh/src/Input/CodeArgument.php',
+ 'Psy\\Input\\FilterOptions' => __DIR__ . '/..' . '/psy/psysh/src/Input/FilterOptions.php',
+ 'Psy\\Input\\ShellInput' => __DIR__ . '/..' . '/psy/psysh/src/Input/ShellInput.php',
+ 'Psy\\Input\\SilentInput' => __DIR__ . '/..' . '/psy/psysh/src/Input/SilentInput.php',
+ 'Psy\\Output\\OutputPager' => __DIR__ . '/..' . '/psy/psysh/src/Output/OutputPager.php',
+ 'Psy\\Output\\PassthruPager' => __DIR__ . '/..' . '/psy/psysh/src/Output/PassthruPager.php',
+ 'Psy\\Output\\ProcOutputPager' => __DIR__ . '/..' . '/psy/psysh/src/Output/ProcOutputPager.php',
+ 'Psy\\Output\\ShellOutput' => __DIR__ . '/..' . '/psy/psysh/src/Output/ShellOutput.php',
+ 'Psy\\ParserFactory' => __DIR__ . '/..' . '/psy/psysh/src/ParserFactory.php',
+ 'Psy\\Readline\\GNUReadline' => __DIR__ . '/..' . '/psy/psysh/src/Readline/GNUReadline.php',
+ 'Psy\\Readline\\HoaConsole' => __DIR__ . '/..' . '/psy/psysh/src/Readline/HoaConsole.php',
+ 'Psy\\Readline\\Libedit' => __DIR__ . '/..' . '/psy/psysh/src/Readline/Libedit.php',
+ 'Psy\\Readline\\Readline' => __DIR__ . '/..' . '/psy/psysh/src/Readline/Readline.php',
+ 'Psy\\Readline\\Transient' => __DIR__ . '/..' . '/psy/psysh/src/Readline/Transient.php',
+ 'Psy\\Reflection\\ReflectionClassConstant' => __DIR__ . '/..' . '/psy/psysh/src/Reflection/ReflectionClassConstant.php',
+ 'Psy\\Reflection\\ReflectionConstant' => __DIR__ . '/..' . '/psy/psysh/src/Reflection/ReflectionConstant.php',
+ 'Psy\\Reflection\\ReflectionConstant_' => __DIR__ . '/..' . '/psy/psysh/src/Reflection/ReflectionConstant_.php',
+ 'Psy\\Reflection\\ReflectionLanguageConstruct' => __DIR__ . '/..' . '/psy/psysh/src/Reflection/ReflectionLanguageConstruct.php',
+ 'Psy\\Reflection\\ReflectionLanguageConstructParameter' => __DIR__ . '/..' . '/psy/psysh/src/Reflection/ReflectionLanguageConstructParameter.php',
+ 'Psy\\Shell' => __DIR__ . '/..' . '/psy/psysh/src/Shell.php',
+ 'Psy\\Sudo' => __DIR__ . '/..' . '/psy/psysh/src/Sudo.php',
+ 'Psy\\Sudo\\SudoVisitor' => __DIR__ . '/..' . '/psy/psysh/src/Sudo/SudoVisitor.php',
+ 'Psy\\TabCompletion\\AutoCompleter' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/AutoCompleter.php',
+ 'Psy\\TabCompletion\\Matcher\\AbstractContextAwareMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/AbstractContextAwareMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\AbstractDefaultParametersMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/AbstractDefaultParametersMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\AbstractMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/AbstractMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ClassAttributesMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/ClassAttributesMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ClassMethodDefaultParametersMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/ClassMethodDefaultParametersMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ClassMethodsMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/ClassMethodsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ClassNamesMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/ClassNamesMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\CommandsMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/CommandsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ConstantsMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/ConstantsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\FunctionDefaultParametersMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/FunctionDefaultParametersMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\FunctionsMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/FunctionsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\KeywordsMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/KeywordsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\MongoClientMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/MongoClientMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\MongoDatabaseMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/MongoDatabaseMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ObjectAttributesMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/ObjectAttributesMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ObjectMethodDefaultParametersMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/ObjectMethodDefaultParametersMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\ObjectMethodsMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/ObjectMethodsMatcher.php',
+ 'Psy\\TabCompletion\\Matcher\\VariablesMatcher' => __DIR__ . '/..' . '/psy/psysh/src/TabCompletion/Matcher/VariablesMatcher.php',
+ 'Psy\\Util\\Docblock' => __DIR__ . '/..' . '/psy/psysh/src/Util/Docblock.php',
+ 'Psy\\Util\\Json' => __DIR__ . '/..' . '/psy/psysh/src/Util/Json.php',
+ 'Psy\\Util\\Mirror' => __DIR__ . '/..' . '/psy/psysh/src/Util/Mirror.php',
+ 'Psy\\Util\\Str' => __DIR__ . '/..' . '/psy/psysh/src/Util/Str.php',
+ 'Psy\\VarDumper\\Cloner' => __DIR__ . '/..' . '/psy/psysh/src/VarDumper/Cloner.php',
+ 'Psy\\VarDumper\\Dumper' => __DIR__ . '/..' . '/psy/psysh/src/VarDumper/Dumper.php',
+ 'Psy\\VarDumper\\Presenter' => __DIR__ . '/..' . '/psy/psysh/src/VarDumper/Presenter.php',
+ 'Psy\\VarDumper\\PresenterAware' => __DIR__ . '/..' . '/psy/psysh/src/VarDumper/PresenterAware.php',
+ 'Psy\\VersionUpdater\\Checker' => __DIR__ . '/..' . '/psy/psysh/src/VersionUpdater/Checker.php',
+ 'Psy\\VersionUpdater\\GitHubChecker' => __DIR__ . '/..' . '/psy/psysh/src/VersionUpdater/GitHubChecker.php',
+ 'Psy\\VersionUpdater\\IntervalChecker' => __DIR__ . '/..' . '/psy/psysh/src/VersionUpdater/IntervalChecker.php',
+ 'Psy\\VersionUpdater\\NoopChecker' => __DIR__ . '/..' . '/psy/psysh/src/VersionUpdater/NoopChecker.php',
+ 'Ramsey\\Uuid\\BinaryUtils' => __DIR__ . '/..' . '/ramsey/uuid/src/BinaryUtils.php',
+ 'Ramsey\\Uuid\\Builder\\DefaultUuidBuilder' => __DIR__ . '/..' . '/ramsey/uuid/src/Builder/DefaultUuidBuilder.php',
+ 'Ramsey\\Uuid\\Builder\\DegradedUuidBuilder' => __DIR__ . '/..' . '/ramsey/uuid/src/Builder/DegradedUuidBuilder.php',
+ 'Ramsey\\Uuid\\Builder\\UuidBuilderInterface' => __DIR__ . '/..' . '/ramsey/uuid/src/Builder/UuidBuilderInterface.php',
+ 'Ramsey\\Uuid\\Codec\\CodecInterface' => __DIR__ . '/..' . '/ramsey/uuid/src/Codec/CodecInterface.php',
+ 'Ramsey\\Uuid\\Codec\\GuidStringCodec' => __DIR__ . '/..' . '/ramsey/uuid/src/Codec/GuidStringCodec.php',
+ 'Ramsey\\Uuid\\Codec\\OrderedTimeCodec' => __DIR__ . '/..' . '/ramsey/uuid/src/Codec/OrderedTimeCodec.php',
+ 'Ramsey\\Uuid\\Codec\\StringCodec' => __DIR__ . '/..' . '/ramsey/uuid/src/Codec/StringCodec.php',
+ 'Ramsey\\Uuid\\Codec\\TimestampFirstCombCodec' => __DIR__ . '/..' . '/ramsey/uuid/src/Codec/TimestampFirstCombCodec.php',
+ 'Ramsey\\Uuid\\Codec\\TimestampLastCombCodec' => __DIR__ . '/..' . '/ramsey/uuid/src/Codec/TimestampLastCombCodec.php',
+ 'Ramsey\\Uuid\\Converter\\NumberConverterInterface' => __DIR__ . '/..' . '/ramsey/uuid/src/Converter/NumberConverterInterface.php',
+ 'Ramsey\\Uuid\\Converter\\Number\\BigNumberConverter' => __DIR__ . '/..' . '/ramsey/uuid/src/Converter/Number/BigNumberConverter.php',
+ 'Ramsey\\Uuid\\Converter\\Number\\DegradedNumberConverter' => __DIR__ . '/..' . '/ramsey/uuid/src/Converter/Number/DegradedNumberConverter.php',
+ 'Ramsey\\Uuid\\Converter\\TimeConverterInterface' => __DIR__ . '/..' . '/ramsey/uuid/src/Converter/TimeConverterInterface.php',
+ 'Ramsey\\Uuid\\Converter\\Time\\BigNumberTimeConverter' => __DIR__ . '/..' . '/ramsey/uuid/src/Converter/Time/BigNumberTimeConverter.php',
+ 'Ramsey\\Uuid\\Converter\\Time\\DegradedTimeConverter' => __DIR__ . '/..' . '/ramsey/uuid/src/Converter/Time/DegradedTimeConverter.php',
+ 'Ramsey\\Uuid\\Converter\\Time\\PhpTimeConverter' => __DIR__ . '/..' . '/ramsey/uuid/src/Converter/Time/PhpTimeConverter.php',
+ 'Ramsey\\Uuid\\DegradedUuid' => __DIR__ . '/..' . '/ramsey/uuid/src/DegradedUuid.php',
+ 'Ramsey\\Uuid\\Exception\\InvalidUuidStringException' => __DIR__ . '/..' . '/ramsey/uuid/src/Exception/InvalidUuidStringException.php',
+ 'Ramsey\\Uuid\\Exception\\UnsatisfiedDependencyException' => __DIR__ . '/..' . '/ramsey/uuid/src/Exception/UnsatisfiedDependencyException.php',
+ 'Ramsey\\Uuid\\Exception\\UnsupportedOperationException' => __DIR__ . '/..' . '/ramsey/uuid/src/Exception/UnsupportedOperationException.php',
+ 'Ramsey\\Uuid\\FeatureSet' => __DIR__ . '/..' . '/ramsey/uuid/src/FeatureSet.php',
+ 'Ramsey\\Uuid\\Generator\\CombGenerator' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/CombGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\DefaultTimeGenerator' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/DefaultTimeGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\MtRandGenerator' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/MtRandGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\OpenSslGenerator' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/OpenSslGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\PeclUuidRandomGenerator' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/PeclUuidRandomGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\PeclUuidTimeGenerator' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/PeclUuidTimeGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\RandomBytesGenerator' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/RandomBytesGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\RandomGeneratorFactory' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/RandomGeneratorFactory.php',
+ 'Ramsey\\Uuid\\Generator\\RandomGeneratorInterface' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/RandomGeneratorInterface.php',
+ 'Ramsey\\Uuid\\Generator\\RandomLibAdapter' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/RandomLibAdapter.php',
+ 'Ramsey\\Uuid\\Generator\\SodiumRandomGenerator' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/SodiumRandomGenerator.php',
+ 'Ramsey\\Uuid\\Generator\\TimeGeneratorFactory' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/TimeGeneratorFactory.php',
+ 'Ramsey\\Uuid\\Generator\\TimeGeneratorInterface' => __DIR__ . '/..' . '/ramsey/uuid/src/Generator/TimeGeneratorInterface.php',
+ 'Ramsey\\Uuid\\Provider\\NodeProviderInterface' => __DIR__ . '/..' . '/ramsey/uuid/src/Provider/NodeProviderInterface.php',
+ 'Ramsey\\Uuid\\Provider\\Node\\FallbackNodeProvider' => __DIR__ . '/..' . '/ramsey/uuid/src/Provider/Node/FallbackNodeProvider.php',
+ 'Ramsey\\Uuid\\Provider\\Node\\RandomNodeProvider' => __DIR__ . '/..' . '/ramsey/uuid/src/Provider/Node/RandomNodeProvider.php',
+ 'Ramsey\\Uuid\\Provider\\Node\\SystemNodeProvider' => __DIR__ . '/..' . '/ramsey/uuid/src/Provider/Node/SystemNodeProvider.php',
+ 'Ramsey\\Uuid\\Provider\\TimeProviderInterface' => __DIR__ . '/..' . '/ramsey/uuid/src/Provider/TimeProviderInterface.php',
+ 'Ramsey\\Uuid\\Provider\\Time\\FixedTimeProvider' => __DIR__ . '/..' . '/ramsey/uuid/src/Provider/Time/FixedTimeProvider.php',
+ 'Ramsey\\Uuid\\Provider\\Time\\SystemTimeProvider' => __DIR__ . '/..' . '/ramsey/uuid/src/Provider/Time/SystemTimeProvider.php',
+ 'Ramsey\\Uuid\\Uuid' => __DIR__ . '/..' . '/ramsey/uuid/src/Uuid.php',
+ 'Ramsey\\Uuid\\UuidFactory' => __DIR__ . '/..' . '/ramsey/uuid/src/UuidFactory.php',
+ 'Ramsey\\Uuid\\UuidFactoryInterface' => __DIR__ . '/..' . '/ramsey/uuid/src/UuidFactoryInterface.php',
+ 'Ramsey\\Uuid\\UuidInterface' => __DIR__ . '/..' . '/ramsey/uuid/src/UuidInterface.php',
+ 'SebastianBergmann\\CodeCoverage\\CodeCoverage' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/CodeCoverage.php',
+ 'SebastianBergmann\\CodeCoverage\\CoveredCodeNotExecutedException' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Exception/CoveredCodeNotExecutedException.php',
+ 'SebastianBergmann\\CodeCoverage\\Driver\\Driver' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Driver/Driver.php',
+ 'SebastianBergmann\\CodeCoverage\\Driver\\HHVM' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Driver/HHVM.php',
+ 'SebastianBergmann\\CodeCoverage\\Driver\\PHPDBG' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Driver/PHPDBG.php',
+ 'SebastianBergmann\\CodeCoverage\\Driver\\Xdebug' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Driver/Xdebug.php',
+ 'SebastianBergmann\\CodeCoverage\\Exception' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Exception/Exception.php',
+ 'SebastianBergmann\\CodeCoverage\\Filter' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Filter.php',
+ 'SebastianBergmann\\CodeCoverage\\InvalidArgumentException' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Exception/InvalidArgumentException.php',
+ 'SebastianBergmann\\CodeCoverage\\MissingCoversAnnotationException' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Exception/MissingCoversAnnotationException.php',
+ 'SebastianBergmann\\CodeCoverage\\Node\\AbstractNode' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Node/AbstractNode.php',
+ 'SebastianBergmann\\CodeCoverage\\Node\\Builder' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Node/Builder.php',
+ 'SebastianBergmann\\CodeCoverage\\Node\\Directory' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Node/Directory.php',
+ 'SebastianBergmann\\CodeCoverage\\Node\\File' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Node/File.php',
+ 'SebastianBergmann\\CodeCoverage\\Node\\Iterator' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Node/Iterator.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Clover' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Clover.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Crap4j' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Crap4j.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Html\\Dashboard' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Html/Renderer/Dashboard.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Html\\Directory' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Html/Renderer/Directory.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Html\\Facade' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Html/Facade.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Html\\File' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Html/Renderer/File.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Html\\Renderer' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Html/Renderer.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\PHP' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/PHP.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Text' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Text.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Coverage' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/Coverage.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Directory' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/Directory.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Facade' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/Facade.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\File' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/File.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Method' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/Method.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Node' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/Node.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Project' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/Project.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Report' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/Report.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Tests' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/Tests.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Totals' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/Totals.php',
+ 'SebastianBergmann\\CodeCoverage\\Report\\Xml\\Unit' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Report/Xml/Unit.php',
+ 'SebastianBergmann\\CodeCoverage\\RuntimeException' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Exception/RuntimeException.php',
+ 'SebastianBergmann\\CodeCoverage\\UnintentionallyCoveredCodeException' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Exception/UnintentionallyCoveredCodeException.php',
+ 'SebastianBergmann\\CodeCoverage\\Util' => __DIR__ . '/..' . '/phpunit/php-code-coverage/src/Util.php',
+ 'SebastianBergmann\\CodeUnitReverseLookup\\Wizard' => __DIR__ . '/..' . '/sebastian/code-unit-reverse-lookup/src/Wizard.php',
+ 'SebastianBergmann\\Comparator\\ArrayComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/ArrayComparator.php',
+ 'SebastianBergmann\\Comparator\\Comparator' => __DIR__ . '/..' . '/sebastian/comparator/src/Comparator.php',
+ 'SebastianBergmann\\Comparator\\ComparisonFailure' => __DIR__ . '/..' . '/sebastian/comparator/src/ComparisonFailure.php',
+ 'SebastianBergmann\\Comparator\\DOMNodeComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/DOMNodeComparator.php',
+ 'SebastianBergmann\\Comparator\\DateTimeComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/DateTimeComparator.php',
+ 'SebastianBergmann\\Comparator\\DoubleComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/DoubleComparator.php',
+ 'SebastianBergmann\\Comparator\\ExceptionComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/ExceptionComparator.php',
+ 'SebastianBergmann\\Comparator\\Factory' => __DIR__ . '/..' . '/sebastian/comparator/src/Factory.php',
+ 'SebastianBergmann\\Comparator\\MockObjectComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/MockObjectComparator.php',
+ 'SebastianBergmann\\Comparator\\NumericComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/NumericComparator.php',
+ 'SebastianBergmann\\Comparator\\ObjectComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/ObjectComparator.php',
+ 'SebastianBergmann\\Comparator\\ResourceComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/ResourceComparator.php',
+ 'SebastianBergmann\\Comparator\\ScalarComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/ScalarComparator.php',
+ 'SebastianBergmann\\Comparator\\SplObjectStorageComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/SplObjectStorageComparator.php',
+ 'SebastianBergmann\\Comparator\\TypeComparator' => __DIR__ . '/..' . '/sebastian/comparator/src/TypeComparator.php',
+ 'SebastianBergmann\\Diff\\Chunk' => __DIR__ . '/..' . '/sebastian/diff/src/Chunk.php',
+ 'SebastianBergmann\\Diff\\Diff' => __DIR__ . '/..' . '/sebastian/diff/src/Diff.php',
+ 'SebastianBergmann\\Diff\\Differ' => __DIR__ . '/..' . '/sebastian/diff/src/Differ.php',
+ 'SebastianBergmann\\Diff\\LCS\\LongestCommonSubsequence' => __DIR__ . '/..' . '/sebastian/diff/src/LCS/LongestCommonSubsequence.php',
+ 'SebastianBergmann\\Diff\\LCS\\MemoryEfficientImplementation' => __DIR__ . '/..' . '/sebastian/diff/src/LCS/MemoryEfficientLongestCommonSubsequenceImplementation.php',
+ 'SebastianBergmann\\Diff\\LCS\\TimeEfficientImplementation' => __DIR__ . '/..' . '/sebastian/diff/src/LCS/TimeEfficientLongestCommonSubsequenceImplementation.php',
+ 'SebastianBergmann\\Diff\\Line' => __DIR__ . '/..' . '/sebastian/diff/src/Line.php',
+ 'SebastianBergmann\\Diff\\Parser' => __DIR__ . '/..' . '/sebastian/diff/src/Parser.php',
+ 'SebastianBergmann\\Environment\\Console' => __DIR__ . '/..' . '/sebastian/environment/src/Console.php',
+ 'SebastianBergmann\\Environment\\Runtime' => __DIR__ . '/..' . '/sebastian/environment/src/Runtime.php',
+ 'SebastianBergmann\\Exporter\\Exporter' => __DIR__ . '/..' . '/sebastian/exporter/src/Exporter.php',
+ 'SebastianBergmann\\GlobalState\\Blacklist' => __DIR__ . '/..' . '/sebastian/global-state/src/Blacklist.php',
+ 'SebastianBergmann\\GlobalState\\CodeExporter' => __DIR__ . '/..' . '/sebastian/global-state/src/CodeExporter.php',
+ 'SebastianBergmann\\GlobalState\\Exception' => __DIR__ . '/..' . '/sebastian/global-state/src/Exception.php',
+ 'SebastianBergmann\\GlobalState\\Restorer' => __DIR__ . '/..' . '/sebastian/global-state/src/Restorer.php',
+ 'SebastianBergmann\\GlobalState\\RuntimeException' => __DIR__ . '/..' . '/sebastian/global-state/src/RuntimeException.php',
+ 'SebastianBergmann\\GlobalState\\Snapshot' => __DIR__ . '/..' . '/sebastian/global-state/src/Snapshot.php',
+ 'SebastianBergmann\\ObjectEnumerator\\Enumerator' => __DIR__ . '/..' . '/sebastian/object-enumerator/src/Enumerator.php',
+ 'SebastianBergmann\\ObjectEnumerator\\Exception' => __DIR__ . '/..' . '/sebastian/object-enumerator/src/Exception.php',
+ 'SebastianBergmann\\ObjectEnumerator\\InvalidArgumentException' => __DIR__ . '/..' . '/sebastian/object-enumerator/src/InvalidArgumentException.php',
+ 'SebastianBergmann\\RecursionContext\\Context' => __DIR__ . '/..' . '/sebastian/recursion-context/src/Context.php',
+ 'SebastianBergmann\\RecursionContext\\Exception' => __DIR__ . '/..' . '/sebastian/recursion-context/src/Exception.php',
+ 'SebastianBergmann\\RecursionContext\\InvalidArgumentException' => __DIR__ . '/..' . '/sebastian/recursion-context/src/InvalidArgumentException.php',
+ 'SebastianBergmann\\ResourceOperations\\ResourceOperations' => __DIR__ . '/..' . '/sebastian/resource-operations/src/ResourceOperations.php',
+ 'SebastianBergmann\\Version' => __DIR__ . '/..' . '/sebastian/version/src/Version.php',
+ 'SessionUpdateTimestampHandlerInterface' => __DIR__ . '/..' . '/symfony/polyfill-php70/Resources/stubs/SessionUpdateTimestampHandlerInterface.php',
+ 'Symfony\\Component\\Console\\Application' => __DIR__ . '/..' . '/symfony/console/Application.php',
+ 'Symfony\\Component\\Console\\CommandLoader\\CommandLoaderInterface' => __DIR__ . '/..' . '/symfony/console/CommandLoader/CommandLoaderInterface.php',
+ 'Symfony\\Component\\Console\\CommandLoader\\ContainerCommandLoader' => __DIR__ . '/..' . '/symfony/console/CommandLoader/ContainerCommandLoader.php',
+ 'Symfony\\Component\\Console\\CommandLoader\\FactoryCommandLoader' => __DIR__ . '/..' . '/symfony/console/CommandLoader/FactoryCommandLoader.php',
+ 'Symfony\\Component\\Console\\Command\\Command' => __DIR__ . '/..' . '/symfony/console/Command/Command.php',
+ 'Symfony\\Component\\Console\\Command\\HelpCommand' => __DIR__ . '/..' . '/symfony/console/Command/HelpCommand.php',
+ 'Symfony\\Component\\Console\\Command\\ListCommand' => __DIR__ . '/..' . '/symfony/console/Command/ListCommand.php',
+ 'Symfony\\Component\\Console\\Command\\LockableTrait' => __DIR__ . '/..' . '/symfony/console/Command/LockableTrait.php',
+ 'Symfony\\Component\\Console\\ConsoleEvents' => __DIR__ . '/..' . '/symfony/console/ConsoleEvents.php',
+ 'Symfony\\Component\\Console\\DependencyInjection\\AddConsoleCommandPass' => __DIR__ . '/..' . '/symfony/console/DependencyInjection/AddConsoleCommandPass.php',
+ 'Symfony\\Component\\Console\\Descriptor\\ApplicationDescription' => __DIR__ . '/..' . '/symfony/console/Descriptor/ApplicationDescription.php',
+ 'Symfony\\Component\\Console\\Descriptor\\Descriptor' => __DIR__ . '/..' . '/symfony/console/Descriptor/Descriptor.php',
+ 'Symfony\\Component\\Console\\Descriptor\\DescriptorInterface' => __DIR__ . '/..' . '/symfony/console/Descriptor/DescriptorInterface.php',
+ 'Symfony\\Component\\Console\\Descriptor\\JsonDescriptor' => __DIR__ . '/..' . '/symfony/console/Descriptor/JsonDescriptor.php',
+ 'Symfony\\Component\\Console\\Descriptor\\MarkdownDescriptor' => __DIR__ . '/..' . '/symfony/console/Descriptor/MarkdownDescriptor.php',
+ 'Symfony\\Component\\Console\\Descriptor\\TextDescriptor' => __DIR__ . '/..' . '/symfony/console/Descriptor/TextDescriptor.php',
+ 'Symfony\\Component\\Console\\Descriptor\\XmlDescriptor' => __DIR__ . '/..' . '/symfony/console/Descriptor/XmlDescriptor.php',
+ 'Symfony\\Component\\Console\\EventListener\\ErrorListener' => __DIR__ . '/..' . '/symfony/console/EventListener/ErrorListener.php',
+ 'Symfony\\Component\\Console\\Event\\ConsoleCommandEvent' => __DIR__ . '/..' . '/symfony/console/Event/ConsoleCommandEvent.php',
+ 'Symfony\\Component\\Console\\Event\\ConsoleErrorEvent' => __DIR__ . '/..' . '/symfony/console/Event/ConsoleErrorEvent.php',
+ 'Symfony\\Component\\Console\\Event\\ConsoleEvent' => __DIR__ . '/..' . '/symfony/console/Event/ConsoleEvent.php',
+ 'Symfony\\Component\\Console\\Event\\ConsoleExceptionEvent' => __DIR__ . '/..' . '/symfony/console/Event/ConsoleExceptionEvent.php',
+ 'Symfony\\Component\\Console\\Event\\ConsoleTerminateEvent' => __DIR__ . '/..' . '/symfony/console/Event/ConsoleTerminateEvent.php',
+ 'Symfony\\Component\\Console\\Exception\\CommandNotFoundException' => __DIR__ . '/..' . '/symfony/console/Exception/CommandNotFoundException.php',
+ 'Symfony\\Component\\Console\\Exception\\ExceptionInterface' => __DIR__ . '/..' . '/symfony/console/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Console\\Exception\\InvalidArgumentException' => __DIR__ . '/..' . '/symfony/console/Exception/InvalidArgumentException.php',
+ 'Symfony\\Component\\Console\\Exception\\InvalidOptionException' => __DIR__ . '/..' . '/symfony/console/Exception/InvalidOptionException.php',
+ 'Symfony\\Component\\Console\\Exception\\LogicException' => __DIR__ . '/..' . '/symfony/console/Exception/LogicException.php',
+ 'Symfony\\Component\\Console\\Exception\\RuntimeException' => __DIR__ . '/..' . '/symfony/console/Exception/RuntimeException.php',
+ 'Symfony\\Component\\Console\\Formatter\\OutputFormatter' => __DIR__ . '/..' . '/symfony/console/Formatter/OutputFormatter.php',
+ 'Symfony\\Component\\Console\\Formatter\\OutputFormatterInterface' => __DIR__ . '/..' . '/symfony/console/Formatter/OutputFormatterInterface.php',
+ 'Symfony\\Component\\Console\\Formatter\\OutputFormatterStyle' => __DIR__ . '/..' . '/symfony/console/Formatter/OutputFormatterStyle.php',
+ 'Symfony\\Component\\Console\\Formatter\\OutputFormatterStyleInterface' => __DIR__ . '/..' . '/symfony/console/Formatter/OutputFormatterStyleInterface.php',
+ 'Symfony\\Component\\Console\\Formatter\\OutputFormatterStyleStack' => __DIR__ . '/..' . '/symfony/console/Formatter/OutputFormatterStyleStack.php',
+ 'Symfony\\Component\\Console\\Helper\\DebugFormatterHelper' => __DIR__ . '/..' . '/symfony/console/Helper/DebugFormatterHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\DescriptorHelper' => __DIR__ . '/..' . '/symfony/console/Helper/DescriptorHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\FormatterHelper' => __DIR__ . '/..' . '/symfony/console/Helper/FormatterHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\Helper' => __DIR__ . '/..' . '/symfony/console/Helper/Helper.php',
+ 'Symfony\\Component\\Console\\Helper\\HelperInterface' => __DIR__ . '/..' . '/symfony/console/Helper/HelperInterface.php',
+ 'Symfony\\Component\\Console\\Helper\\HelperSet' => __DIR__ . '/..' . '/symfony/console/Helper/HelperSet.php',
+ 'Symfony\\Component\\Console\\Helper\\InputAwareHelper' => __DIR__ . '/..' . '/symfony/console/Helper/InputAwareHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\ProcessHelper' => __DIR__ . '/..' . '/symfony/console/Helper/ProcessHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\ProgressBar' => __DIR__ . '/..' . '/symfony/console/Helper/ProgressBar.php',
+ 'Symfony\\Component\\Console\\Helper\\ProgressIndicator' => __DIR__ . '/..' . '/symfony/console/Helper/ProgressIndicator.php',
+ 'Symfony\\Component\\Console\\Helper\\QuestionHelper' => __DIR__ . '/..' . '/symfony/console/Helper/QuestionHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\SymfonyQuestionHelper' => __DIR__ . '/..' . '/symfony/console/Helper/SymfonyQuestionHelper.php',
+ 'Symfony\\Component\\Console\\Helper\\Table' => __DIR__ . '/..' . '/symfony/console/Helper/Table.php',
+ 'Symfony\\Component\\Console\\Helper\\TableCell' => __DIR__ . '/..' . '/symfony/console/Helper/TableCell.php',
+ 'Symfony\\Component\\Console\\Helper\\TableSeparator' => __DIR__ . '/..' . '/symfony/console/Helper/TableSeparator.php',
+ 'Symfony\\Component\\Console\\Helper\\TableStyle' => __DIR__ . '/..' . '/symfony/console/Helper/TableStyle.php',
+ 'Symfony\\Component\\Console\\Input\\ArgvInput' => __DIR__ . '/..' . '/symfony/console/Input/ArgvInput.php',
+ 'Symfony\\Component\\Console\\Input\\ArrayInput' => __DIR__ . '/..' . '/symfony/console/Input/ArrayInput.php',
+ 'Symfony\\Component\\Console\\Input\\Input' => __DIR__ . '/..' . '/symfony/console/Input/Input.php',
+ 'Symfony\\Component\\Console\\Input\\InputArgument' => __DIR__ . '/..' . '/symfony/console/Input/InputArgument.php',
+ 'Symfony\\Component\\Console\\Input\\InputAwareInterface' => __DIR__ . '/..' . '/symfony/console/Input/InputAwareInterface.php',
+ 'Symfony\\Component\\Console\\Input\\InputDefinition' => __DIR__ . '/..' . '/symfony/console/Input/InputDefinition.php',
+ 'Symfony\\Component\\Console\\Input\\InputInterface' => __DIR__ . '/..' . '/symfony/console/Input/InputInterface.php',
+ 'Symfony\\Component\\Console\\Input\\InputOption' => __DIR__ . '/..' . '/symfony/console/Input/InputOption.php',
+ 'Symfony\\Component\\Console\\Input\\StreamableInputInterface' => __DIR__ . '/..' . '/symfony/console/Input/StreamableInputInterface.php',
+ 'Symfony\\Component\\Console\\Input\\StringInput' => __DIR__ . '/..' . '/symfony/console/Input/StringInput.php',
+ 'Symfony\\Component\\Console\\Logger\\ConsoleLogger' => __DIR__ . '/..' . '/symfony/console/Logger/ConsoleLogger.php',
+ 'Symfony\\Component\\Console\\Output\\BufferedOutput' => __DIR__ . '/..' . '/symfony/console/Output/BufferedOutput.php',
+ 'Symfony\\Component\\Console\\Output\\ConsoleOutput' => __DIR__ . '/..' . '/symfony/console/Output/ConsoleOutput.php',
+ 'Symfony\\Component\\Console\\Output\\ConsoleOutputInterface' => __DIR__ . '/..' . '/symfony/console/Output/ConsoleOutputInterface.php',
+ 'Symfony\\Component\\Console\\Output\\NullOutput' => __DIR__ . '/..' . '/symfony/console/Output/NullOutput.php',
+ 'Symfony\\Component\\Console\\Output\\Output' => __DIR__ . '/..' . '/symfony/console/Output/Output.php',
+ 'Symfony\\Component\\Console\\Output\\OutputInterface' => __DIR__ . '/..' . '/symfony/console/Output/OutputInterface.php',
+ 'Symfony\\Component\\Console\\Output\\StreamOutput' => __DIR__ . '/..' . '/symfony/console/Output/StreamOutput.php',
+ 'Symfony\\Component\\Console\\Question\\ChoiceQuestion' => __DIR__ . '/..' . '/symfony/console/Question/ChoiceQuestion.php',
+ 'Symfony\\Component\\Console\\Question\\ConfirmationQuestion' => __DIR__ . '/..' . '/symfony/console/Question/ConfirmationQuestion.php',
+ 'Symfony\\Component\\Console\\Question\\Question' => __DIR__ . '/..' . '/symfony/console/Question/Question.php',
+ 'Symfony\\Component\\Console\\Style\\OutputStyle' => __DIR__ . '/..' . '/symfony/console/Style/OutputStyle.php',
+ 'Symfony\\Component\\Console\\Style\\StyleInterface' => __DIR__ . '/..' . '/symfony/console/Style/StyleInterface.php',
+ 'Symfony\\Component\\Console\\Style\\SymfonyStyle' => __DIR__ . '/..' . '/symfony/console/Style/SymfonyStyle.php',
+ 'Symfony\\Component\\Console\\Terminal' => __DIR__ . '/..' . '/symfony/console/Terminal.php',
+ 'Symfony\\Component\\Console\\Tester\\ApplicationTester' => __DIR__ . '/..' . '/symfony/console/Tester/ApplicationTester.php',
+ 'Symfony\\Component\\Console\\Tester\\CommandTester' => __DIR__ . '/..' . '/symfony/console/Tester/CommandTester.php',
+ 'Symfony\\Component\\CssSelector\\CssSelectorConverter' => __DIR__ . '/..' . '/symfony/css-selector/CssSelectorConverter.php',
+ 'Symfony\\Component\\CssSelector\\Exception\\ExceptionInterface' => __DIR__ . '/..' . '/symfony/css-selector/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\CssSelector\\Exception\\ExpressionErrorException' => __DIR__ . '/..' . '/symfony/css-selector/Exception/ExpressionErrorException.php',
+ 'Symfony\\Component\\CssSelector\\Exception\\InternalErrorException' => __DIR__ . '/..' . '/symfony/css-selector/Exception/InternalErrorException.php',
+ 'Symfony\\Component\\CssSelector\\Exception\\ParseException' => __DIR__ . '/..' . '/symfony/css-selector/Exception/ParseException.php',
+ 'Symfony\\Component\\CssSelector\\Exception\\SyntaxErrorException' => __DIR__ . '/..' . '/symfony/css-selector/Exception/SyntaxErrorException.php',
+ 'Symfony\\Component\\CssSelector\\Node\\AbstractNode' => __DIR__ . '/..' . '/symfony/css-selector/Node/AbstractNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\AttributeNode' => __DIR__ . '/..' . '/symfony/css-selector/Node/AttributeNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\ClassNode' => __DIR__ . '/..' . '/symfony/css-selector/Node/ClassNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\CombinedSelectorNode' => __DIR__ . '/..' . '/symfony/css-selector/Node/CombinedSelectorNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\ElementNode' => __DIR__ . '/..' . '/symfony/css-selector/Node/ElementNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\FunctionNode' => __DIR__ . '/..' . '/symfony/css-selector/Node/FunctionNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\HashNode' => __DIR__ . '/..' . '/symfony/css-selector/Node/HashNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\NegationNode' => __DIR__ . '/..' . '/symfony/css-selector/Node/NegationNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\NodeInterface' => __DIR__ . '/..' . '/symfony/css-selector/Node/NodeInterface.php',
+ 'Symfony\\Component\\CssSelector\\Node\\PseudoNode' => __DIR__ . '/..' . '/symfony/css-selector/Node/PseudoNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\SelectorNode' => __DIR__ . '/..' . '/symfony/css-selector/Node/SelectorNode.php',
+ 'Symfony\\Component\\CssSelector\\Node\\Specificity' => __DIR__ . '/..' . '/symfony/css-selector/Node/Specificity.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\CommentHandler' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Handler/CommentHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\HandlerInterface' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Handler/HandlerInterface.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\HashHandler' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Handler/HashHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\IdentifierHandler' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Handler/IdentifierHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\NumberHandler' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Handler/NumberHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\StringHandler' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Handler/StringHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Handler\\WhitespaceHandler' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Handler/WhitespaceHandler.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Parser' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Parser.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\ParserInterface' => __DIR__ . '/..' . '/symfony/css-selector/Parser/ParserInterface.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Reader' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Reader.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Shortcut\\ClassParser' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Shortcut/ClassParser.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Shortcut\\ElementParser' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Shortcut/ElementParser.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Shortcut\\EmptyStringParser' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Shortcut/EmptyStringParser.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Shortcut\\HashParser' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Shortcut/HashParser.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Token' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Token.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\TokenStream' => __DIR__ . '/..' . '/symfony/css-selector/Parser/TokenStream.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Tokenizer\\Tokenizer' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Tokenizer/Tokenizer.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Tokenizer\\TokenizerEscaping' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Tokenizer/TokenizerEscaping.php',
+ 'Symfony\\Component\\CssSelector\\Parser\\Tokenizer\\TokenizerPatterns' => __DIR__ . '/..' . '/symfony/css-selector/Parser/Tokenizer/TokenizerPatterns.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\AbstractExtension' => __DIR__ . '/..' . '/symfony/css-selector/XPath/Extension/AbstractExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\AttributeMatchingExtension' => __DIR__ . '/..' . '/symfony/css-selector/XPath/Extension/AttributeMatchingExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\CombinationExtension' => __DIR__ . '/..' . '/symfony/css-selector/XPath/Extension/CombinationExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\ExtensionInterface' => __DIR__ . '/..' . '/symfony/css-selector/XPath/Extension/ExtensionInterface.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\FunctionExtension' => __DIR__ . '/..' . '/symfony/css-selector/XPath/Extension/FunctionExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\HtmlExtension' => __DIR__ . '/..' . '/symfony/css-selector/XPath/Extension/HtmlExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\NodeExtension' => __DIR__ . '/..' . '/symfony/css-selector/XPath/Extension/NodeExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Extension\\PseudoClassExtension' => __DIR__ . '/..' . '/symfony/css-selector/XPath/Extension/PseudoClassExtension.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\Translator' => __DIR__ . '/..' . '/symfony/css-selector/XPath/Translator.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\TranslatorInterface' => __DIR__ . '/..' . '/symfony/css-selector/XPath/TranslatorInterface.php',
+ 'Symfony\\Component\\CssSelector\\XPath\\XPathExpr' => __DIR__ . '/..' . '/symfony/css-selector/XPath/XPathExpr.php',
+ 'Symfony\\Component\\Debug\\BufferingLogger' => __DIR__ . '/..' . '/symfony/debug/BufferingLogger.php',
+ 'Symfony\\Component\\Debug\\Debug' => __DIR__ . '/..' . '/symfony/debug/Debug.php',
+ 'Symfony\\Component\\Debug\\DebugClassLoader' => __DIR__ . '/..' . '/symfony/debug/DebugClassLoader.php',
+ 'Symfony\\Component\\Debug\\ErrorHandler' => __DIR__ . '/..' . '/symfony/debug/ErrorHandler.php',
+ 'Symfony\\Component\\Debug\\ExceptionHandler' => __DIR__ . '/..' . '/symfony/debug/ExceptionHandler.php',
+ 'Symfony\\Component\\Debug\\Exception\\ClassNotFoundException' => __DIR__ . '/..' . '/symfony/debug/Exception/ClassNotFoundException.php',
+ 'Symfony\\Component\\Debug\\Exception\\ContextErrorException' => __DIR__ . '/..' . '/symfony/debug/Exception/ContextErrorException.php',
+ 'Symfony\\Component\\Debug\\Exception\\FatalErrorException' => __DIR__ . '/..' . '/symfony/debug/Exception/FatalErrorException.php',
+ 'Symfony\\Component\\Debug\\Exception\\FatalThrowableError' => __DIR__ . '/..' . '/symfony/debug/Exception/FatalThrowableError.php',
+ 'Symfony\\Component\\Debug\\Exception\\FlattenException' => __DIR__ . '/..' . '/symfony/debug/Exception/FlattenException.php',
+ 'Symfony\\Component\\Debug\\Exception\\OutOfMemoryException' => __DIR__ . '/..' . '/symfony/debug/Exception/OutOfMemoryException.php',
+ 'Symfony\\Component\\Debug\\Exception\\SilencedErrorContext' => __DIR__ . '/..' . '/symfony/debug/Exception/SilencedErrorContext.php',
+ 'Symfony\\Component\\Debug\\Exception\\UndefinedFunctionException' => __DIR__ . '/..' . '/symfony/debug/Exception/UndefinedFunctionException.php',
+ 'Symfony\\Component\\Debug\\Exception\\UndefinedMethodException' => __DIR__ . '/..' . '/symfony/debug/Exception/UndefinedMethodException.php',
+ 'Symfony\\Component\\Debug\\FatalErrorHandler\\ClassNotFoundFatalErrorHandler' => __DIR__ . '/..' . '/symfony/debug/FatalErrorHandler/ClassNotFoundFatalErrorHandler.php',
+ 'Symfony\\Component\\Debug\\FatalErrorHandler\\FatalErrorHandlerInterface' => __DIR__ . '/..' . '/symfony/debug/FatalErrorHandler/FatalErrorHandlerInterface.php',
+ 'Symfony\\Component\\Debug\\FatalErrorHandler\\UndefinedFunctionFatalErrorHandler' => __DIR__ . '/..' . '/symfony/debug/FatalErrorHandler/UndefinedFunctionFatalErrorHandler.php',
+ 'Symfony\\Component\\Debug\\FatalErrorHandler\\UndefinedMethodFatalErrorHandler' => __DIR__ . '/..' . '/symfony/debug/FatalErrorHandler/UndefinedMethodFatalErrorHandler.php',
+ 'Symfony\\Component\\EventDispatcher\\ContainerAwareEventDispatcher' => __DIR__ . '/..' . '/symfony/event-dispatcher/ContainerAwareEventDispatcher.php',
+ 'Symfony\\Component\\EventDispatcher\\Debug\\TraceableEventDispatcher' => __DIR__ . '/..' . '/symfony/event-dispatcher/Debug/TraceableEventDispatcher.php',
+ 'Symfony\\Component\\EventDispatcher\\Debug\\TraceableEventDispatcherInterface' => __DIR__ . '/..' . '/symfony/event-dispatcher/Debug/TraceableEventDispatcherInterface.php',
+ 'Symfony\\Component\\EventDispatcher\\Debug\\WrappedListener' => __DIR__ . '/..' . '/symfony/event-dispatcher/Debug/WrappedListener.php',
+ 'Symfony\\Component\\EventDispatcher\\DependencyInjection\\RegisterListenersPass' => __DIR__ . '/..' . '/symfony/event-dispatcher/DependencyInjection/RegisterListenersPass.php',
+ 'Symfony\\Component\\EventDispatcher\\Event' => __DIR__ . '/..' . '/symfony/event-dispatcher/Event.php',
+ 'Symfony\\Component\\EventDispatcher\\EventDispatcher' => __DIR__ . '/..' . '/symfony/event-dispatcher/EventDispatcher.php',
+ 'Symfony\\Component\\EventDispatcher\\EventDispatcherInterface' => __DIR__ . '/..' . '/symfony/event-dispatcher/EventDispatcherInterface.php',
+ 'Symfony\\Component\\EventDispatcher\\EventSubscriberInterface' => __DIR__ . '/..' . '/symfony/event-dispatcher/EventSubscriberInterface.php',
+ 'Symfony\\Component\\EventDispatcher\\GenericEvent' => __DIR__ . '/..' . '/symfony/event-dispatcher/GenericEvent.php',
+ 'Symfony\\Component\\EventDispatcher\\ImmutableEventDispatcher' => __DIR__ . '/..' . '/symfony/event-dispatcher/ImmutableEventDispatcher.php',
+ 'Symfony\\Component\\Finder\\Comparator\\Comparator' => __DIR__ . '/..' . '/symfony/finder/Comparator/Comparator.php',
+ 'Symfony\\Component\\Finder\\Comparator\\DateComparator' => __DIR__ . '/..' . '/symfony/finder/Comparator/DateComparator.php',
+ 'Symfony\\Component\\Finder\\Comparator\\NumberComparator' => __DIR__ . '/..' . '/symfony/finder/Comparator/NumberComparator.php',
+ 'Symfony\\Component\\Finder\\Exception\\AccessDeniedException' => __DIR__ . '/..' . '/symfony/finder/Exception/AccessDeniedException.php',
+ 'Symfony\\Component\\Finder\\Exception\\ExceptionInterface' => __DIR__ . '/..' . '/symfony/finder/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Finder\\Finder' => __DIR__ . '/..' . '/symfony/finder/Finder.php',
+ 'Symfony\\Component\\Finder\\Glob' => __DIR__ . '/..' . '/symfony/finder/Glob.php',
+ 'Symfony\\Component\\Finder\\Iterator\\CustomFilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/CustomFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\DateRangeFilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/DateRangeFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\DepthRangeFilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/DepthRangeFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\ExcludeDirectoryFilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/ExcludeDirectoryFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\FileTypeFilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/FileTypeFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\FilecontentFilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/FilecontentFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\FilenameFilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/FilenameFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\FilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/FilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\MultiplePcreFilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/MultiplePcreFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\PathFilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/PathFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\RecursiveDirectoryIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/RecursiveDirectoryIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\SizeRangeFilterIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/SizeRangeFilterIterator.php',
+ 'Symfony\\Component\\Finder\\Iterator\\SortableIterator' => __DIR__ . '/..' . '/symfony/finder/Iterator/SortableIterator.php',
+ 'Symfony\\Component\\Finder\\SplFileInfo' => __DIR__ . '/..' . '/symfony/finder/SplFileInfo.php',
+ 'Symfony\\Component\\HttpFoundation\\AcceptHeader' => __DIR__ . '/..' . '/symfony/http-foundation/AcceptHeader.php',
+ 'Symfony\\Component\\HttpFoundation\\AcceptHeaderItem' => __DIR__ . '/..' . '/symfony/http-foundation/AcceptHeaderItem.php',
+ 'Symfony\\Component\\HttpFoundation\\ApacheRequest' => __DIR__ . '/..' . '/symfony/http-foundation/ApacheRequest.php',
+ 'Symfony\\Component\\HttpFoundation\\BinaryFileResponse' => __DIR__ . '/..' . '/symfony/http-foundation/BinaryFileResponse.php',
+ 'Symfony\\Component\\HttpFoundation\\Cookie' => __DIR__ . '/..' . '/symfony/http-foundation/Cookie.php',
+ 'Symfony\\Component\\HttpFoundation\\Exception\\ConflictingHeadersException' => __DIR__ . '/..' . '/symfony/http-foundation/Exception/ConflictingHeadersException.php',
+ 'Symfony\\Component\\HttpFoundation\\Exception\\RequestExceptionInterface' => __DIR__ . '/..' . '/symfony/http-foundation/Exception/RequestExceptionInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\Exception\\SuspiciousOperationException' => __DIR__ . '/..' . '/symfony/http-foundation/Exception/SuspiciousOperationException.php',
+ 'Symfony\\Component\\HttpFoundation\\ExpressionRequestMatcher' => __DIR__ . '/..' . '/symfony/http-foundation/ExpressionRequestMatcher.php',
+ 'Symfony\\Component\\HttpFoundation\\FileBag' => __DIR__ . '/..' . '/symfony/http-foundation/FileBag.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Exception\\AccessDeniedException' => __DIR__ . '/..' . '/symfony/http-foundation/File/Exception/AccessDeniedException.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Exception\\FileException' => __DIR__ . '/..' . '/symfony/http-foundation/File/Exception/FileException.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Exception\\FileNotFoundException' => __DIR__ . '/..' . '/symfony/http-foundation/File/Exception/FileNotFoundException.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Exception\\UnexpectedTypeException' => __DIR__ . '/..' . '/symfony/http-foundation/File/Exception/UnexpectedTypeException.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Exception\\UploadException' => __DIR__ . '/..' . '/symfony/http-foundation/File/Exception/UploadException.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\File' => __DIR__ . '/..' . '/symfony/http-foundation/File/File.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\ExtensionGuesser' => __DIR__ . '/..' . '/symfony/http-foundation/File/MimeType/ExtensionGuesser.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\ExtensionGuesserInterface' => __DIR__ . '/..' . '/symfony/http-foundation/File/MimeType/ExtensionGuesserInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\FileBinaryMimeTypeGuesser' => __DIR__ . '/..' . '/symfony/http-foundation/File/MimeType/FileBinaryMimeTypeGuesser.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\FileinfoMimeTypeGuesser' => __DIR__ . '/..' . '/symfony/http-foundation/File/MimeType/FileinfoMimeTypeGuesser.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\MimeTypeExtensionGuesser' => __DIR__ . '/..' . '/symfony/http-foundation/File/MimeType/MimeTypeExtensionGuesser.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\MimeTypeGuesser' => __DIR__ . '/..' . '/symfony/http-foundation/File/MimeType/MimeTypeGuesser.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\MimeType\\MimeTypeGuesserInterface' => __DIR__ . '/..' . '/symfony/http-foundation/File/MimeType/MimeTypeGuesserInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\Stream' => __DIR__ . '/..' . '/symfony/http-foundation/File/Stream.php',
+ 'Symfony\\Component\\HttpFoundation\\File\\UploadedFile' => __DIR__ . '/..' . '/symfony/http-foundation/File/UploadedFile.php',
+ 'Symfony\\Component\\HttpFoundation\\HeaderBag' => __DIR__ . '/..' . '/symfony/http-foundation/HeaderBag.php',
+ 'Symfony\\Component\\HttpFoundation\\IpUtils' => __DIR__ . '/..' . '/symfony/http-foundation/IpUtils.php',
+ 'Symfony\\Component\\HttpFoundation\\JsonResponse' => __DIR__ . '/..' . '/symfony/http-foundation/JsonResponse.php',
+ 'Symfony\\Component\\HttpFoundation\\ParameterBag' => __DIR__ . '/..' . '/symfony/http-foundation/ParameterBag.php',
+ 'Symfony\\Component\\HttpFoundation\\RedirectResponse' => __DIR__ . '/..' . '/symfony/http-foundation/RedirectResponse.php',
+ 'Symfony\\Component\\HttpFoundation\\Request' => __DIR__ . '/..' . '/symfony/http-foundation/Request.php',
+ 'Symfony\\Component\\HttpFoundation\\RequestMatcher' => __DIR__ . '/..' . '/symfony/http-foundation/RequestMatcher.php',
+ 'Symfony\\Component\\HttpFoundation\\RequestMatcherInterface' => __DIR__ . '/..' . '/symfony/http-foundation/RequestMatcherInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\RequestStack' => __DIR__ . '/..' . '/symfony/http-foundation/RequestStack.php',
+ 'Symfony\\Component\\HttpFoundation\\Response' => __DIR__ . '/..' . '/symfony/http-foundation/Response.php',
+ 'Symfony\\Component\\HttpFoundation\\ResponseHeaderBag' => __DIR__ . '/..' . '/symfony/http-foundation/ResponseHeaderBag.php',
+ 'Symfony\\Component\\HttpFoundation\\ServerBag' => __DIR__ . '/..' . '/symfony/http-foundation/ServerBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Attribute\\AttributeBag' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Attribute/AttributeBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Attribute\\AttributeBagInterface' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Attribute/AttributeBagInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Attribute\\NamespacedAttributeBag' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Attribute/NamespacedAttributeBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Flash\\AutoExpireFlashBag' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Flash/AutoExpireFlashBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Flash\\FlashBag' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Flash/FlashBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Flash\\FlashBagInterface' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Flash/FlashBagInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Session' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Session.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\SessionBagInterface' => __DIR__ . '/..' . '/symfony/http-foundation/Session/SessionBagInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\SessionBagProxy' => __DIR__ . '/..' . '/symfony/http-foundation/Session/SessionBagProxy.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\SessionInterface' => __DIR__ . '/..' . '/symfony/http-foundation/Session/SessionInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\SessionUtils' => __DIR__ . '/..' . '/symfony/http-foundation/Session/SessionUtils.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\AbstractSessionHandler' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Handler/AbstractSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\MemcacheSessionHandler' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Handler/MemcacheSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\MemcachedSessionHandler' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Handler/MemcachedSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\MongoDbSessionHandler' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Handler/MongoDbSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\NativeFileSessionHandler' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Handler/NativeFileSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\NativeSessionHandler' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Handler/NativeSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\NullSessionHandler' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Handler/NullSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\PdoSessionHandler' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Handler/PdoSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\StrictSessionHandler' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Handler/StrictSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Handler\\WriteCheckSessionHandler' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Handler/WriteCheckSessionHandler.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\MetadataBag' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/MetadataBag.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\MockArraySessionStorage' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/MockArraySessionStorage.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\MockFileSessionStorage' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/MockFileSessionStorage.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\NativeSessionStorage' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/NativeSessionStorage.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\PhpBridgeSessionStorage' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/PhpBridgeSessionStorage.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Proxy\\AbstractProxy' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Proxy/AbstractProxy.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Proxy\\NativeProxy' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Proxy/NativeProxy.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\Proxy\\SessionHandlerProxy' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/Proxy/SessionHandlerProxy.php',
+ 'Symfony\\Component\\HttpFoundation\\Session\\Storage\\SessionStorageInterface' => __DIR__ . '/..' . '/symfony/http-foundation/Session/Storage/SessionStorageInterface.php',
+ 'Symfony\\Component\\HttpFoundation\\StreamedResponse' => __DIR__ . '/..' . '/symfony/http-foundation/StreamedResponse.php',
+ 'Symfony\\Component\\HttpKernel\\Bundle\\Bundle' => __DIR__ . '/..' . '/symfony/http-kernel/Bundle/Bundle.php',
+ 'Symfony\\Component\\HttpKernel\\Bundle\\BundleInterface' => __DIR__ . '/..' . '/symfony/http-kernel/Bundle/BundleInterface.php',
+ 'Symfony\\Component\\HttpKernel\\CacheClearer\\CacheClearerInterface' => __DIR__ . '/..' . '/symfony/http-kernel/CacheClearer/CacheClearerInterface.php',
+ 'Symfony\\Component\\HttpKernel\\CacheClearer\\ChainCacheClearer' => __DIR__ . '/..' . '/symfony/http-kernel/CacheClearer/ChainCacheClearer.php',
+ 'Symfony\\Component\\HttpKernel\\CacheClearer\\Psr6CacheClearer' => __DIR__ . '/..' . '/symfony/http-kernel/CacheClearer/Psr6CacheClearer.php',
+ 'Symfony\\Component\\HttpKernel\\CacheWarmer\\CacheWarmer' => __DIR__ . '/..' . '/symfony/http-kernel/CacheWarmer/CacheWarmer.php',
+ 'Symfony\\Component\\HttpKernel\\CacheWarmer\\CacheWarmerAggregate' => __DIR__ . '/..' . '/symfony/http-kernel/CacheWarmer/CacheWarmerAggregate.php',
+ 'Symfony\\Component\\HttpKernel\\CacheWarmer\\CacheWarmerInterface' => __DIR__ . '/..' . '/symfony/http-kernel/CacheWarmer/CacheWarmerInterface.php',
+ 'Symfony\\Component\\HttpKernel\\CacheWarmer\\WarmableInterface' => __DIR__ . '/..' . '/symfony/http-kernel/CacheWarmer/WarmableInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Client' => __DIR__ . '/..' . '/symfony/http-kernel/Client.php',
+ 'Symfony\\Component\\HttpKernel\\Config\\EnvParametersResource' => __DIR__ . '/..' . '/symfony/http-kernel/Config/EnvParametersResource.php',
+ 'Symfony\\Component\\HttpKernel\\Config\\FileLocator' => __DIR__ . '/..' . '/symfony/http-kernel/Config/FileLocator.php',
+ 'Symfony\\Component\\HttpKernel\\ControllerMetadata\\ArgumentMetadata' => __DIR__ . '/..' . '/symfony/http-kernel/ControllerMetadata/ArgumentMetadata.php',
+ 'Symfony\\Component\\HttpKernel\\ControllerMetadata\\ArgumentMetadataFactory' => __DIR__ . '/..' . '/symfony/http-kernel/ControllerMetadata/ArgumentMetadataFactory.php',
+ 'Symfony\\Component\\HttpKernel\\ControllerMetadata\\ArgumentMetadataFactoryInterface' => __DIR__ . '/..' . '/symfony/http-kernel/ControllerMetadata/ArgumentMetadataFactoryInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ArgumentResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolverInterface' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ArgumentResolverInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\DefaultValueResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ArgumentResolver/DefaultValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\RequestAttributeValueResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ArgumentResolver/RequestAttributeValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\RequestValueResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ArgumentResolver/RequestValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\ServiceValueResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ArgumentResolver/ServiceValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\SessionValueResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ArgumentResolver/SessionValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\VariadicValueResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ArgumentResolver/VariadicValueResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ArgumentValueResolverInterface' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ArgumentValueResolverInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ContainerControllerResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ContainerControllerResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ControllerReference' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ControllerReference.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ControllerResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ControllerResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\ControllerResolverInterface' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/ControllerResolverInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\TraceableArgumentResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/TraceableArgumentResolver.php',
+ 'Symfony\\Component\\HttpKernel\\Controller\\TraceableControllerResolver' => __DIR__ . '/..' . '/symfony/http-kernel/Controller/TraceableControllerResolver.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\AjaxDataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/AjaxDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\ConfigDataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/ConfigDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\DataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/DataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\DataCollectorInterface' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/DataCollectorInterface.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\DumpDataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/DumpDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\EventDataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/EventDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\ExceptionDataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/ExceptionDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\LateDataCollectorInterface' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/LateDataCollectorInterface.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\LoggerDataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/LoggerDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\MemoryDataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/MemoryDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\RequestDataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/RequestDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\RouterDataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/RouterDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\TimeDataCollector' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/TimeDataCollector.php',
+ 'Symfony\\Component\\HttpKernel\\DataCollector\\Util\\ValueExporter' => __DIR__ . '/..' . '/symfony/http-kernel/DataCollector/Util/ValueExporter.php',
+ 'Symfony\\Component\\HttpKernel\\Debug\\FileLinkFormatter' => __DIR__ . '/..' . '/symfony/http-kernel/Debug/FileLinkFormatter.php',
+ 'Symfony\\Component\\HttpKernel\\Debug\\TraceableEventDispatcher' => __DIR__ . '/..' . '/symfony/http-kernel/Debug/TraceableEventDispatcher.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\AddAnnotatedClassesToCachePass' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/AddAnnotatedClassesToCachePass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\AddClassesToCachePass' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/AddClassesToCachePass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\ConfigurableExtension' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/ConfigurableExtension.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\ControllerArgumentValueResolverPass' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/ControllerArgumentValueResolverPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\Extension' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/Extension.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\FragmentRendererPass' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/FragmentRendererPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\LazyLoadingFragmentHandler' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/LazyLoadingFragmentHandler.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\LoggerPass' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/LoggerPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\MergeExtensionConfigurationPass' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/MergeExtensionConfigurationPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\RegisterControllerArgumentLocatorsPass' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/RegisterControllerArgumentLocatorsPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\RemoveEmptyControllerArgumentLocatorsPass' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/RemoveEmptyControllerArgumentLocatorsPass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\ResettableServicePass' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/ResettableServicePass.php',
+ 'Symfony\\Component\\HttpKernel\\DependencyInjection\\ServicesResetter' => __DIR__ . '/..' . '/symfony/http-kernel/DependencyInjection/ServicesResetter.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\AbstractSessionListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/AbstractSessionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\AbstractTestSessionListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/AbstractTestSessionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\AddRequestFormatsListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/AddRequestFormatsListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\DebugHandlersListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/DebugHandlersListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\DumpListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/DumpListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\ExceptionListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/ExceptionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\FragmentListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/FragmentListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\LocaleListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/LocaleListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\ProfilerListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/ProfilerListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\ResponseListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/ResponseListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\RouterListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/RouterListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\SaveSessionListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/SaveSessionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\SessionListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/SessionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\StreamedResponseListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/StreamedResponseListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\SurrogateListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/SurrogateListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\TestSessionListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/TestSessionListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\TranslatorListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/TranslatorListener.php',
+ 'Symfony\\Component\\HttpKernel\\EventListener\\ValidateRequestListener' => __DIR__ . '/..' . '/symfony/http-kernel/EventListener/ValidateRequestListener.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\FilterControllerArgumentsEvent' => __DIR__ . '/..' . '/symfony/http-kernel/Event/FilterControllerArgumentsEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\FilterControllerEvent' => __DIR__ . '/..' . '/symfony/http-kernel/Event/FilterControllerEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\FilterResponseEvent' => __DIR__ . '/..' . '/symfony/http-kernel/Event/FilterResponseEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\FinishRequestEvent' => __DIR__ . '/..' . '/symfony/http-kernel/Event/FinishRequestEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\GetResponseEvent' => __DIR__ . '/..' . '/symfony/http-kernel/Event/GetResponseEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\GetResponseForControllerResultEvent' => __DIR__ . '/..' . '/symfony/http-kernel/Event/GetResponseForControllerResultEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\GetResponseForExceptionEvent' => __DIR__ . '/..' . '/symfony/http-kernel/Event/GetResponseForExceptionEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\KernelEvent' => __DIR__ . '/..' . '/symfony/http-kernel/Event/KernelEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Event\\PostResponseEvent' => __DIR__ . '/..' . '/symfony/http-kernel/Event/PostResponseEvent.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\AccessDeniedHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/AccessDeniedHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\BadRequestHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/BadRequestHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\ConflictHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/ConflictHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\GoneHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/GoneHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\HttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/HttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\HttpExceptionInterface' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/HttpExceptionInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\LengthRequiredHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/LengthRequiredHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\MethodNotAllowedHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/MethodNotAllowedHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\NotAcceptableHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/NotAcceptableHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\NotFoundHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/NotFoundHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\PreconditionFailedHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/PreconditionFailedHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\PreconditionRequiredHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/PreconditionRequiredHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\ServiceUnavailableHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/ServiceUnavailableHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\TooManyRequestsHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/TooManyRequestsHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\UnauthorizedHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/UnauthorizedHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\UnprocessableEntityHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/UnprocessableEntityHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Exception\\UnsupportedMediaTypeHttpException' => __DIR__ . '/..' . '/symfony/http-kernel/Exception/UnsupportedMediaTypeHttpException.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\AbstractSurrogateFragmentRenderer' => __DIR__ . '/..' . '/symfony/http-kernel/Fragment/AbstractSurrogateFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\EsiFragmentRenderer' => __DIR__ . '/..' . '/symfony/http-kernel/Fragment/EsiFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\FragmentHandler' => __DIR__ . '/..' . '/symfony/http-kernel/Fragment/FragmentHandler.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\FragmentRendererInterface' => __DIR__ . '/..' . '/symfony/http-kernel/Fragment/FragmentRendererInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\HIncludeFragmentRenderer' => __DIR__ . '/..' . '/symfony/http-kernel/Fragment/HIncludeFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\InlineFragmentRenderer' => __DIR__ . '/..' . '/symfony/http-kernel/Fragment/InlineFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\RoutableFragmentRenderer' => __DIR__ . '/..' . '/symfony/http-kernel/Fragment/RoutableFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\Fragment\\SsiFragmentRenderer' => __DIR__ . '/..' . '/symfony/http-kernel/Fragment/SsiFragmentRenderer.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\AbstractSurrogate' => __DIR__ . '/..' . '/symfony/http-kernel/HttpCache/AbstractSurrogate.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\Esi' => __DIR__ . '/..' . '/symfony/http-kernel/HttpCache/Esi.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\HttpCache' => __DIR__ . '/..' . '/symfony/http-kernel/HttpCache/HttpCache.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\ResponseCacheStrategy' => __DIR__ . '/..' . '/symfony/http-kernel/HttpCache/ResponseCacheStrategy.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\ResponseCacheStrategyInterface' => __DIR__ . '/..' . '/symfony/http-kernel/HttpCache/ResponseCacheStrategyInterface.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\Ssi' => __DIR__ . '/..' . '/symfony/http-kernel/HttpCache/Ssi.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\Store' => __DIR__ . '/..' . '/symfony/http-kernel/HttpCache/Store.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\StoreInterface' => __DIR__ . '/..' . '/symfony/http-kernel/HttpCache/StoreInterface.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\SubRequestHandler' => __DIR__ . '/..' . '/symfony/http-kernel/HttpCache/SubRequestHandler.php',
+ 'Symfony\\Component\\HttpKernel\\HttpCache\\SurrogateInterface' => __DIR__ . '/..' . '/symfony/http-kernel/HttpCache/SurrogateInterface.php',
+ 'Symfony\\Component\\HttpKernel\\HttpKernel' => __DIR__ . '/..' . '/symfony/http-kernel/HttpKernel.php',
+ 'Symfony\\Component\\HttpKernel\\HttpKernelInterface' => __DIR__ . '/..' . '/symfony/http-kernel/HttpKernelInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Kernel' => __DIR__ . '/..' . '/symfony/http-kernel/Kernel.php',
+ 'Symfony\\Component\\HttpKernel\\KernelEvents' => __DIR__ . '/..' . '/symfony/http-kernel/KernelEvents.php',
+ 'Symfony\\Component\\HttpKernel\\KernelInterface' => __DIR__ . '/..' . '/symfony/http-kernel/KernelInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Log\\DebugLoggerInterface' => __DIR__ . '/..' . '/symfony/http-kernel/Log/DebugLoggerInterface.php',
+ 'Symfony\\Component\\HttpKernel\\Log\\Logger' => __DIR__ . '/..' . '/symfony/http-kernel/Log/Logger.php',
+ 'Symfony\\Component\\HttpKernel\\Profiler\\FileProfilerStorage' => __DIR__ . '/..' . '/symfony/http-kernel/Profiler/FileProfilerStorage.php',
+ 'Symfony\\Component\\HttpKernel\\Profiler\\Profile' => __DIR__ . '/..' . '/symfony/http-kernel/Profiler/Profile.php',
+ 'Symfony\\Component\\HttpKernel\\Profiler\\Profiler' => __DIR__ . '/..' . '/symfony/http-kernel/Profiler/Profiler.php',
+ 'Symfony\\Component\\HttpKernel\\Profiler\\ProfilerStorageInterface' => __DIR__ . '/..' . '/symfony/http-kernel/Profiler/ProfilerStorageInterface.php',
+ 'Symfony\\Component\\HttpKernel\\RebootableInterface' => __DIR__ . '/..' . '/symfony/http-kernel/RebootableInterface.php',
+ 'Symfony\\Component\\HttpKernel\\TerminableInterface' => __DIR__ . '/..' . '/symfony/http-kernel/TerminableInterface.php',
+ 'Symfony\\Component\\HttpKernel\\UriSigner' => __DIR__ . '/..' . '/symfony/http-kernel/UriSigner.php',
+ 'Symfony\\Component\\Process\\Exception\\ExceptionInterface' => __DIR__ . '/..' . '/symfony/process/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Process\\Exception\\InvalidArgumentException' => __DIR__ . '/..' . '/symfony/process/Exception/InvalidArgumentException.php',
+ 'Symfony\\Component\\Process\\Exception\\LogicException' => __DIR__ . '/..' . '/symfony/process/Exception/LogicException.php',
+ 'Symfony\\Component\\Process\\Exception\\ProcessFailedException' => __DIR__ . '/..' . '/symfony/process/Exception/ProcessFailedException.php',
+ 'Symfony\\Component\\Process\\Exception\\ProcessTimedOutException' => __DIR__ . '/..' . '/symfony/process/Exception/ProcessTimedOutException.php',
+ 'Symfony\\Component\\Process\\Exception\\RuntimeException' => __DIR__ . '/..' . '/symfony/process/Exception/RuntimeException.php',
+ 'Symfony\\Component\\Process\\ExecutableFinder' => __DIR__ . '/..' . '/symfony/process/ExecutableFinder.php',
+ 'Symfony\\Component\\Process\\InputStream' => __DIR__ . '/..' . '/symfony/process/InputStream.php',
+ 'Symfony\\Component\\Process\\PhpExecutableFinder' => __DIR__ . '/..' . '/symfony/process/PhpExecutableFinder.php',
+ 'Symfony\\Component\\Process\\PhpProcess' => __DIR__ . '/..' . '/symfony/process/PhpProcess.php',
+ 'Symfony\\Component\\Process\\Pipes\\AbstractPipes' => __DIR__ . '/..' . '/symfony/process/Pipes/AbstractPipes.php',
+ 'Symfony\\Component\\Process\\Pipes\\PipesInterface' => __DIR__ . '/..' . '/symfony/process/Pipes/PipesInterface.php',
+ 'Symfony\\Component\\Process\\Pipes\\UnixPipes' => __DIR__ . '/..' . '/symfony/process/Pipes/UnixPipes.php',
+ 'Symfony\\Component\\Process\\Pipes\\WindowsPipes' => __DIR__ . '/..' . '/symfony/process/Pipes/WindowsPipes.php',
+ 'Symfony\\Component\\Process\\Process' => __DIR__ . '/..' . '/symfony/process/Process.php',
+ 'Symfony\\Component\\Process\\ProcessBuilder' => __DIR__ . '/..' . '/symfony/process/ProcessBuilder.php',
+ 'Symfony\\Component\\Process\\ProcessUtils' => __DIR__ . '/..' . '/symfony/process/ProcessUtils.php',
+ 'Symfony\\Component\\Routing\\Annotation\\Route' => __DIR__ . '/..' . '/symfony/routing/Annotation/Route.php',
+ 'Symfony\\Component\\Routing\\CompiledRoute' => __DIR__ . '/..' . '/symfony/routing/CompiledRoute.php',
+ 'Symfony\\Component\\Routing\\DependencyInjection\\RoutingResolverPass' => __DIR__ . '/..' . '/symfony/routing/DependencyInjection/RoutingResolverPass.php',
+ 'Symfony\\Component\\Routing\\Exception\\ExceptionInterface' => __DIR__ . '/..' . '/symfony/routing/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Routing\\Exception\\InvalidParameterException' => __DIR__ . '/..' . '/symfony/routing/Exception/InvalidParameterException.php',
+ 'Symfony\\Component\\Routing\\Exception\\MethodNotAllowedException' => __DIR__ . '/..' . '/symfony/routing/Exception/MethodNotAllowedException.php',
+ 'Symfony\\Component\\Routing\\Exception\\MissingMandatoryParametersException' => __DIR__ . '/..' . '/symfony/routing/Exception/MissingMandatoryParametersException.php',
+ 'Symfony\\Component\\Routing\\Exception\\NoConfigurationException' => __DIR__ . '/..' . '/symfony/routing/Exception/NoConfigurationException.php',
+ 'Symfony\\Component\\Routing\\Exception\\ResourceNotFoundException' => __DIR__ . '/..' . '/symfony/routing/Exception/ResourceNotFoundException.php',
+ 'Symfony\\Component\\Routing\\Exception\\RouteNotFoundException' => __DIR__ . '/..' . '/symfony/routing/Exception/RouteNotFoundException.php',
+ 'Symfony\\Component\\Routing\\Generator\\ConfigurableRequirementsInterface' => __DIR__ . '/..' . '/symfony/routing/Generator/ConfigurableRequirementsInterface.php',
+ 'Symfony\\Component\\Routing\\Generator\\Dumper\\GeneratorDumper' => __DIR__ . '/..' . '/symfony/routing/Generator/Dumper/GeneratorDumper.php',
+ 'Symfony\\Component\\Routing\\Generator\\Dumper\\GeneratorDumperInterface' => __DIR__ . '/..' . '/symfony/routing/Generator/Dumper/GeneratorDumperInterface.php',
+ 'Symfony\\Component\\Routing\\Generator\\Dumper\\PhpGeneratorDumper' => __DIR__ . '/..' . '/symfony/routing/Generator/Dumper/PhpGeneratorDumper.php',
+ 'Symfony\\Component\\Routing\\Generator\\UrlGenerator' => __DIR__ . '/..' . '/symfony/routing/Generator/UrlGenerator.php',
+ 'Symfony\\Component\\Routing\\Generator\\UrlGeneratorInterface' => __DIR__ . '/..' . '/symfony/routing/Generator/UrlGeneratorInterface.php',
+ 'Symfony\\Component\\Routing\\Loader\\AnnotationClassLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/AnnotationClassLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\AnnotationDirectoryLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/AnnotationDirectoryLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\AnnotationFileLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/AnnotationFileLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\ClosureLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/ClosureLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\CollectionConfigurator' => __DIR__ . '/..' . '/symfony/routing/Loader/Configurator/CollectionConfigurator.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\ImportConfigurator' => __DIR__ . '/..' . '/symfony/routing/Loader/Configurator/ImportConfigurator.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\RouteConfigurator' => __DIR__ . '/..' . '/symfony/routing/Loader/Configurator/RouteConfigurator.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\RoutingConfigurator' => __DIR__ . '/..' . '/symfony/routing/Loader/Configurator/RoutingConfigurator.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\Traits\\AddTrait' => __DIR__ . '/..' . '/symfony/routing/Loader/Configurator/Traits/AddTrait.php',
+ 'Symfony\\Component\\Routing\\Loader\\Configurator\\Traits\\RouteTrait' => __DIR__ . '/..' . '/symfony/routing/Loader/Configurator/Traits/RouteTrait.php',
+ 'Symfony\\Component\\Routing\\Loader\\DependencyInjection\\ServiceRouterLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/DependencyInjection/ServiceRouterLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\DirectoryLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/DirectoryLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\GlobFileLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/GlobFileLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\ObjectRouteLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/ObjectRouteLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\PhpFileLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/PhpFileLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\XmlFileLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/XmlFileLoader.php',
+ 'Symfony\\Component\\Routing\\Loader\\YamlFileLoader' => __DIR__ . '/..' . '/symfony/routing/Loader/YamlFileLoader.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\DumperCollection' => __DIR__ . '/..' . '/symfony/routing/Matcher/Dumper/DumperCollection.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\DumperRoute' => __DIR__ . '/..' . '/symfony/routing/Matcher/Dumper/DumperRoute.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\MatcherDumper' => __DIR__ . '/..' . '/symfony/routing/Matcher/Dumper/MatcherDumper.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\MatcherDumperInterface' => __DIR__ . '/..' . '/symfony/routing/Matcher/Dumper/MatcherDumperInterface.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\PhpMatcherDumper' => __DIR__ . '/..' . '/symfony/routing/Matcher/Dumper/PhpMatcherDumper.php',
+ 'Symfony\\Component\\Routing\\Matcher\\Dumper\\StaticPrefixCollection' => __DIR__ . '/..' . '/symfony/routing/Matcher/Dumper/StaticPrefixCollection.php',
+ 'Symfony\\Component\\Routing\\Matcher\\RedirectableUrlMatcher' => __DIR__ . '/..' . '/symfony/routing/Matcher/RedirectableUrlMatcher.php',
+ 'Symfony\\Component\\Routing\\Matcher\\RedirectableUrlMatcherInterface' => __DIR__ . '/..' . '/symfony/routing/Matcher/RedirectableUrlMatcherInterface.php',
+ 'Symfony\\Component\\Routing\\Matcher\\RequestMatcherInterface' => __DIR__ . '/..' . '/symfony/routing/Matcher/RequestMatcherInterface.php',
+ 'Symfony\\Component\\Routing\\Matcher\\TraceableUrlMatcher' => __DIR__ . '/..' . '/symfony/routing/Matcher/TraceableUrlMatcher.php',
+ 'Symfony\\Component\\Routing\\Matcher\\UrlMatcher' => __DIR__ . '/..' . '/symfony/routing/Matcher/UrlMatcher.php',
+ 'Symfony\\Component\\Routing\\Matcher\\UrlMatcherInterface' => __DIR__ . '/..' . '/symfony/routing/Matcher/UrlMatcherInterface.php',
+ 'Symfony\\Component\\Routing\\RequestContext' => __DIR__ . '/..' . '/symfony/routing/RequestContext.php',
+ 'Symfony\\Component\\Routing\\RequestContextAwareInterface' => __DIR__ . '/..' . '/symfony/routing/RequestContextAwareInterface.php',
+ 'Symfony\\Component\\Routing\\Route' => __DIR__ . '/..' . '/symfony/routing/Route.php',
+ 'Symfony\\Component\\Routing\\RouteCollection' => __DIR__ . '/..' . '/symfony/routing/RouteCollection.php',
+ 'Symfony\\Component\\Routing\\RouteCollectionBuilder' => __DIR__ . '/..' . '/symfony/routing/RouteCollectionBuilder.php',
+ 'Symfony\\Component\\Routing\\RouteCompiler' => __DIR__ . '/..' . '/symfony/routing/RouteCompiler.php',
+ 'Symfony\\Component\\Routing\\RouteCompilerInterface' => __DIR__ . '/..' . '/symfony/routing/RouteCompilerInterface.php',
+ 'Symfony\\Component\\Routing\\Router' => __DIR__ . '/..' . '/symfony/routing/Router.php',
+ 'Symfony\\Component\\Routing\\RouterInterface' => __DIR__ . '/..' . '/symfony/routing/RouterInterface.php',
+ 'Symfony\\Component\\Translation\\Catalogue\\AbstractOperation' => __DIR__ . '/..' . '/symfony/translation/Catalogue/AbstractOperation.php',
+ 'Symfony\\Component\\Translation\\Catalogue\\MergeOperation' => __DIR__ . '/..' . '/symfony/translation/Catalogue/MergeOperation.php',
+ 'Symfony\\Component\\Translation\\Catalogue\\OperationInterface' => __DIR__ . '/..' . '/symfony/translation/Catalogue/OperationInterface.php',
+ 'Symfony\\Component\\Translation\\Catalogue\\TargetOperation' => __DIR__ . '/..' . '/symfony/translation/Catalogue/TargetOperation.php',
+ 'Symfony\\Component\\Translation\\Command\\XliffLintCommand' => __DIR__ . '/..' . '/symfony/translation/Command/XliffLintCommand.php',
+ 'Symfony\\Component\\Translation\\DataCollectorTranslator' => __DIR__ . '/..' . '/symfony/translation/DataCollectorTranslator.php',
+ 'Symfony\\Component\\Translation\\DataCollector\\TranslationDataCollector' => __DIR__ . '/..' . '/symfony/translation/DataCollector/TranslationDataCollector.php',
+ 'Symfony\\Component\\Translation\\DependencyInjection\\TranslationDumperPass' => __DIR__ . '/..' . '/symfony/translation/DependencyInjection/TranslationDumperPass.php',
+ 'Symfony\\Component\\Translation\\DependencyInjection\\TranslationExtractorPass' => __DIR__ . '/..' . '/symfony/translation/DependencyInjection/TranslationExtractorPass.php',
+ 'Symfony\\Component\\Translation\\DependencyInjection\\TranslatorPass' => __DIR__ . '/..' . '/symfony/translation/DependencyInjection/TranslatorPass.php',
+ 'Symfony\\Component\\Translation\\Dumper\\CsvFileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/CsvFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\DumperInterface' => __DIR__ . '/..' . '/symfony/translation/Dumper/DumperInterface.php',
+ 'Symfony\\Component\\Translation\\Dumper\\FileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/FileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\IcuResFileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/IcuResFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\IniFileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/IniFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\JsonFileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/JsonFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\MoFileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/MoFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\PhpFileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/PhpFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\PoFileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/PoFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\QtFileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/QtFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\XliffFileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/XliffFileDumper.php',
+ 'Symfony\\Component\\Translation\\Dumper\\YamlFileDumper' => __DIR__ . '/..' . '/symfony/translation/Dumper/YamlFileDumper.php',
+ 'Symfony\\Component\\Translation\\Exception\\ExceptionInterface' => __DIR__ . '/..' . '/symfony/translation/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Translation\\Exception\\InvalidArgumentException' => __DIR__ . '/..' . '/symfony/translation/Exception/InvalidArgumentException.php',
+ 'Symfony\\Component\\Translation\\Exception\\InvalidResourceException' => __DIR__ . '/..' . '/symfony/translation/Exception/InvalidResourceException.php',
+ 'Symfony\\Component\\Translation\\Exception\\LogicException' => __DIR__ . '/..' . '/symfony/translation/Exception/LogicException.php',
+ 'Symfony\\Component\\Translation\\Exception\\NotFoundResourceException' => __DIR__ . '/..' . '/symfony/translation/Exception/NotFoundResourceException.php',
+ 'Symfony\\Component\\Translation\\Exception\\RuntimeException' => __DIR__ . '/..' . '/symfony/translation/Exception/RuntimeException.php',
+ 'Symfony\\Component\\Translation\\Extractor\\AbstractFileExtractor' => __DIR__ . '/..' . '/symfony/translation/Extractor/AbstractFileExtractor.php',
+ 'Symfony\\Component\\Translation\\Extractor\\ChainExtractor' => __DIR__ . '/..' . '/symfony/translation/Extractor/ChainExtractor.php',
+ 'Symfony\\Component\\Translation\\Extractor\\ExtractorInterface' => __DIR__ . '/..' . '/symfony/translation/Extractor/ExtractorInterface.php',
+ 'Symfony\\Component\\Translation\\Extractor\\PhpExtractor' => __DIR__ . '/..' . '/symfony/translation/Extractor/PhpExtractor.php',
+ 'Symfony\\Component\\Translation\\Extractor\\PhpStringTokenParser' => __DIR__ . '/..' . '/symfony/translation/Extractor/PhpStringTokenParser.php',
+ 'Symfony\\Component\\Translation\\Formatter\\ChoiceMessageFormatterInterface' => __DIR__ . '/..' . '/symfony/translation/Formatter/ChoiceMessageFormatterInterface.php',
+ 'Symfony\\Component\\Translation\\Formatter\\MessageFormatter' => __DIR__ . '/..' . '/symfony/translation/Formatter/MessageFormatter.php',
+ 'Symfony\\Component\\Translation\\Formatter\\MessageFormatterInterface' => __DIR__ . '/..' . '/symfony/translation/Formatter/MessageFormatterInterface.php',
+ 'Symfony\\Component\\Translation\\IdentityTranslator' => __DIR__ . '/..' . '/symfony/translation/IdentityTranslator.php',
+ 'Symfony\\Component\\Translation\\Interval' => __DIR__ . '/..' . '/symfony/translation/Interval.php',
+ 'Symfony\\Component\\Translation\\Loader\\ArrayLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/ArrayLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\CsvFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/CsvFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\FileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/FileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\IcuDatFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/IcuDatFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\IcuResFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/IcuResFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\IniFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/IniFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\JsonFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/JsonFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\LoaderInterface' => __DIR__ . '/..' . '/symfony/translation/Loader/LoaderInterface.php',
+ 'Symfony\\Component\\Translation\\Loader\\MoFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/MoFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\PhpFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/PhpFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\PoFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/PoFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\QtFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/QtFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\XliffFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/XliffFileLoader.php',
+ 'Symfony\\Component\\Translation\\Loader\\YamlFileLoader' => __DIR__ . '/..' . '/symfony/translation/Loader/YamlFileLoader.php',
+ 'Symfony\\Component\\Translation\\LoggingTranslator' => __DIR__ . '/..' . '/symfony/translation/LoggingTranslator.php',
+ 'Symfony\\Component\\Translation\\MessageCatalogue' => __DIR__ . '/..' . '/symfony/translation/MessageCatalogue.php',
+ 'Symfony\\Component\\Translation\\MessageCatalogueInterface' => __DIR__ . '/..' . '/symfony/translation/MessageCatalogueInterface.php',
+ 'Symfony\\Component\\Translation\\MessageSelector' => __DIR__ . '/..' . '/symfony/translation/MessageSelector.php',
+ 'Symfony\\Component\\Translation\\MetadataAwareInterface' => __DIR__ . '/..' . '/symfony/translation/MetadataAwareInterface.php',
+ 'Symfony\\Component\\Translation\\PluralizationRules' => __DIR__ . '/..' . '/symfony/translation/PluralizationRules.php',
+ 'Symfony\\Component\\Translation\\Reader\\TranslationReader' => __DIR__ . '/..' . '/symfony/translation/Reader/TranslationReader.php',
+ 'Symfony\\Component\\Translation\\Reader\\TranslationReaderInterface' => __DIR__ . '/..' . '/symfony/translation/Reader/TranslationReaderInterface.php',
+ 'Symfony\\Component\\Translation\\Translator' => __DIR__ . '/..' . '/symfony/translation/Translator.php',
+ 'Symfony\\Component\\Translation\\TranslatorBagInterface' => __DIR__ . '/..' . '/symfony/translation/TranslatorBagInterface.php',
+ 'Symfony\\Component\\Translation\\TranslatorInterface' => __DIR__ . '/..' . '/symfony/translation/TranslatorInterface.php',
+ 'Symfony\\Component\\Translation\\Util\\ArrayConverter' => __DIR__ . '/..' . '/symfony/translation/Util/ArrayConverter.php',
+ 'Symfony\\Component\\Translation\\Writer\\TranslationWriter' => __DIR__ . '/..' . '/symfony/translation/Writer/TranslationWriter.php',
+ 'Symfony\\Component\\Translation\\Writer\\TranslationWriterInterface' => __DIR__ . '/..' . '/symfony/translation/Writer/TranslationWriterInterface.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\AmqpCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/AmqpCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ArgsStub' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/ArgsStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\Caster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/Caster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ClassStub' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/ClassStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ConstStub' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/ConstStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\CutArrayStub' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/CutArrayStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\CutStub' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/CutStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\DOMCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/DOMCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\DateCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/DateCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\DoctrineCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/DoctrineCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\EnumStub' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/EnumStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ExceptionCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/ExceptionCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\FrameStub' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/FrameStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\LinkStub' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/LinkStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\MongoCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/MongoCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\PdoCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/PdoCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\PgSqlCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/PgSqlCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\RedisCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/RedisCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ReflectionCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/ReflectionCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\ResourceCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/ResourceCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\SplCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/SplCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\StubCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/StubCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\SymfonyCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/SymfonyCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\TraceStub' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/TraceStub.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\XmlReaderCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/XmlReaderCaster.php',
+ 'Symfony\\Component\\VarDumper\\Caster\\XmlResourceCaster' => __DIR__ . '/..' . '/symfony/var-dumper/Caster/XmlResourceCaster.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\AbstractCloner' => __DIR__ . '/..' . '/symfony/var-dumper/Cloner/AbstractCloner.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\ClonerInterface' => __DIR__ . '/..' . '/symfony/var-dumper/Cloner/ClonerInterface.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\Cursor' => __DIR__ . '/..' . '/symfony/var-dumper/Cloner/Cursor.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\Data' => __DIR__ . '/..' . '/symfony/var-dumper/Cloner/Data.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\DumperInterface' => __DIR__ . '/..' . '/symfony/var-dumper/Cloner/DumperInterface.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\Stub' => __DIR__ . '/..' . '/symfony/var-dumper/Cloner/Stub.php',
+ 'Symfony\\Component\\VarDumper\\Cloner\\VarCloner' => __DIR__ . '/..' . '/symfony/var-dumper/Cloner/VarCloner.php',
+ 'Symfony\\Component\\VarDumper\\Dumper\\AbstractDumper' => __DIR__ . '/..' . '/symfony/var-dumper/Dumper/AbstractDumper.php',
+ 'Symfony\\Component\\VarDumper\\Dumper\\CliDumper' => __DIR__ . '/..' . '/symfony/var-dumper/Dumper/CliDumper.php',
+ 'Symfony\\Component\\VarDumper\\Dumper\\DataDumperInterface' => __DIR__ . '/..' . '/symfony/var-dumper/Dumper/DataDumperInterface.php',
+ 'Symfony\\Component\\VarDumper\\Dumper\\HtmlDumper' => __DIR__ . '/..' . '/symfony/var-dumper/Dumper/HtmlDumper.php',
+ 'Symfony\\Component\\VarDumper\\Exception\\ThrowingCasterException' => __DIR__ . '/..' . '/symfony/var-dumper/Exception/ThrowingCasterException.php',
+ 'Symfony\\Component\\VarDumper\\Test\\VarDumperTestTrait' => __DIR__ . '/..' . '/symfony/var-dumper/Test/VarDumperTestTrait.php',
+ 'Symfony\\Component\\VarDumper\\VarDumper' => __DIR__ . '/..' . '/symfony/var-dumper/VarDumper.php',
+ 'Symfony\\Component\\Yaml\\Command\\LintCommand' => __DIR__ . '/..' . '/symfony/yaml/Command/LintCommand.php',
+ 'Symfony\\Component\\Yaml\\Dumper' => __DIR__ . '/..' . '/symfony/yaml/Dumper.php',
+ 'Symfony\\Component\\Yaml\\Escaper' => __DIR__ . '/..' . '/symfony/yaml/Escaper.php',
+ 'Symfony\\Component\\Yaml\\Exception\\DumpException' => __DIR__ . '/..' . '/symfony/yaml/Exception/DumpException.php',
+ 'Symfony\\Component\\Yaml\\Exception\\ExceptionInterface' => __DIR__ . '/..' . '/symfony/yaml/Exception/ExceptionInterface.php',
+ 'Symfony\\Component\\Yaml\\Exception\\ParseException' => __DIR__ . '/..' . '/symfony/yaml/Exception/ParseException.php',
+ 'Symfony\\Component\\Yaml\\Exception\\RuntimeException' => __DIR__ . '/..' . '/symfony/yaml/Exception/RuntimeException.php',
+ 'Symfony\\Component\\Yaml\\Inline' => __DIR__ . '/..' . '/symfony/yaml/Inline.php',
+ 'Symfony\\Component\\Yaml\\Parser' => __DIR__ . '/..' . '/symfony/yaml/Parser.php',
+ 'Symfony\\Component\\Yaml\\Tag\\TaggedValue' => __DIR__ . '/..' . '/symfony/yaml/Tag/TaggedValue.php',
+ 'Symfony\\Component\\Yaml\\Unescaper' => __DIR__ . '/..' . '/symfony/yaml/Unescaper.php',
+ 'Symfony\\Component\\Yaml\\Yaml' => __DIR__ . '/..' . '/symfony/yaml/Yaml.php',
+ 'Symfony\\Polyfill\\Ctype\\Ctype' => __DIR__ . '/..' . '/symfony/polyfill-ctype/Ctype.php',
+ 'Symfony\\Polyfill\\Mbstring\\Mbstring' => __DIR__ . '/..' . '/symfony/polyfill-mbstring/Mbstring.php',
+ 'Symfony\\Polyfill\\Php56\\Php56' => __DIR__ . '/..' . '/symfony/polyfill-php56/Php56.php',
+ 'Symfony\\Polyfill\\Php70\\Php70' => __DIR__ . '/..' . '/symfony/polyfill-php70/Php70.php',
+ 'Symfony\\Polyfill\\Util\\Binary' => __DIR__ . '/..' . '/symfony/polyfill-util/Binary.php',
+ 'Symfony\\Polyfill\\Util\\BinaryNoFuncOverload' => __DIR__ . '/..' . '/symfony/polyfill-util/BinaryNoFuncOverload.php',
+ 'Symfony\\Polyfill\\Util\\BinaryOnFuncOverload' => __DIR__ . '/..' . '/symfony/polyfill-util/BinaryOnFuncOverload.php',
+ 'Symfony\\Polyfill\\Util\\TestListener' => __DIR__ . '/..' . '/symfony/polyfill-util/TestListener.php',
+ 'Symfony\\Polyfill\\Util\\TestListenerForV5' => __DIR__ . '/..' . '/symfony/polyfill-util/TestListenerForV5.php',
+ 'Symfony\\Polyfill\\Util\\TestListenerForV6' => __DIR__ . '/..' . '/symfony/polyfill-util/TestListenerForV6.php',
+ 'Symfony\\Polyfill\\Util\\TestListenerForV7' => __DIR__ . '/..' . '/symfony/polyfill-util/TestListenerForV7.php',
+ 'Symfony\\Polyfill\\Util\\TestListenerTrait' => __DIR__ . '/..' . '/symfony/polyfill-util/TestListenerTrait.php',
+ 'Tests\\CreatesApplication' => __DIR__ . '/../..' . '/tests/CreatesApplication.php',
+ 'Tests\\Feature\\ExampleTest' => __DIR__ . '/../..' . '/tests/Feature/ExampleTest.php',
+ 'Tests\\TestCase' => __DIR__ . '/../..' . '/tests/TestCase.php',
+ 'Tests\\Unit\\ExampleTest' => __DIR__ . '/../..' . '/tests/Unit/ExampleTest.php',
+ 'Text_Template' => __DIR__ . '/..' . '/phpunit/php-text-template/src/Template.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\CssToInlineStyles' => __DIR__ . '/..' . '/tijsverkoyen/css-to-inline-styles/src/CssToInlineStyles.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\Css\\Processor' => __DIR__ . '/..' . '/tijsverkoyen/css-to-inline-styles/src/Css/Processor.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\Css\\Property\\Processor' => __DIR__ . '/..' . '/tijsverkoyen/css-to-inline-styles/src/Css/Property/Processor.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\Css\\Property\\Property' => __DIR__ . '/..' . '/tijsverkoyen/css-to-inline-styles/src/Css/Property/Property.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\Css\\Rule\\Processor' => __DIR__ . '/..' . '/tijsverkoyen/css-to-inline-styles/src/Css/Rule/Processor.php',
+ 'TijsVerkoyen\\CssToInlineStyles\\Css\\Rule\\Rule' => __DIR__ . '/..' . '/tijsverkoyen/css-to-inline-styles/src/Css/Rule/Rule.php',
+ 'TypeError' => __DIR__ . '/..' . '/symfony/polyfill-php70/Resources/stubs/TypeError.php',
+ 'UpdateHelper\\ComposerPlugin' => __DIR__ . '/..' . '/kylekatarnls/update-helper/src/UpdateHelper/ComposerPlugin.php',
+ 'UpdateHelper\\NotUpdateInterfaceInstanceException' => __DIR__ . '/..' . '/kylekatarnls/update-helper/src/UpdateHelper/NotUpdateInterfaceInstanceException.php',
+ 'UpdateHelper\\UpdateHelper' => __DIR__ . '/..' . '/kylekatarnls/update-helper/src/UpdateHelper/UpdateHelper.php',
+ 'UpdateHelper\\UpdateHelperInterface' => __DIR__ . '/..' . '/kylekatarnls/update-helper/src/UpdateHelper/UpdateHelperInterface.php',
+ 'Webmozart\\Assert\\Assert' => __DIR__ . '/..' . '/webmozart/assert/src/Assert.php',
+ 'Webmozart\\Assert\\Mixin' => __DIR__ . '/..' . '/webmozart/assert/src/Mixin.php',
+ 'XdgBaseDir\\Xdg' => __DIR__ . '/..' . '/dnoegel/php-xdg-base-dir/src/Xdg.php',
+ 'phpDocumentor\\Reflection\\DocBlock' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock.php',
+ 'phpDocumentor\\Reflection\\DocBlockFactory' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlockFactory.php',
+ 'phpDocumentor\\Reflection\\DocBlockFactoryInterface' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlockFactoryInterface.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Description' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Description.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\DescriptionFactory' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/DescriptionFactory.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\ExampleFinder' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/ExampleFinder.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Serializer' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Serializer.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\StandardTagFactory' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/StandardTagFactory.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tag' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tag.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\TagFactory' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/TagFactory.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Author' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Author.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\BaseTag' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/BaseTag.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Covers' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Covers.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Deprecated' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Deprecated.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Example' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Example.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Factory\\StaticMethod' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Factory/StaticMethod.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Factory\\Strategy' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Factory/Strategy.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Formatter' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Formatter.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Formatter\\AlignFormatter' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Formatter/AlignFormatter.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Formatter\\PassthroughFormatter' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Formatter/PassthroughFormatter.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Generic' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Generic.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Link' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Link.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Method' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Method.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Param' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Param.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Property' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Property.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\PropertyRead' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/PropertyRead.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\PropertyWrite' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/PropertyWrite.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Reference\\Fqsen' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Reference/Fqsen.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Reference\\Reference' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Reference/Reference.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Reference\\Url' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Reference/Url.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Return_' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Return_.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\See' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/See.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Since' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Since.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Source' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Source.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Throws' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Throws.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Uses' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Uses.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Var_' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Var_.php',
+ 'phpDocumentor\\Reflection\\DocBlock\\Tags\\Version' => __DIR__ . '/..' . '/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Version.php',
+ 'phpDocumentor\\Reflection\\Element' => __DIR__ . '/..' . '/phpdocumentor/reflection-common/src/Element.php',
+ 'phpDocumentor\\Reflection\\File' => __DIR__ . '/..' . '/phpdocumentor/reflection-common/src/File.php',
+ 'phpDocumentor\\Reflection\\Fqsen' => __DIR__ . '/..' . '/phpdocumentor/reflection-common/src/Fqsen.php',
+ 'phpDocumentor\\Reflection\\FqsenResolver' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/FqsenResolver.php',
+ 'phpDocumentor\\Reflection\\Location' => __DIR__ . '/..' . '/phpdocumentor/reflection-common/src/Location.php',
+ 'phpDocumentor\\Reflection\\Project' => __DIR__ . '/..' . '/phpdocumentor/reflection-common/src/Project.php',
+ 'phpDocumentor\\Reflection\\ProjectFactory' => __DIR__ . '/..' . '/phpdocumentor/reflection-common/src/ProjectFactory.php',
+ 'phpDocumentor\\Reflection\\Type' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Type.php',
+ 'phpDocumentor\\Reflection\\TypeResolver' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/TypeResolver.php',
+ 'phpDocumentor\\Reflection\\Types\\Array_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Array_.php',
+ 'phpDocumentor\\Reflection\\Types\\Boolean' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Boolean.php',
+ 'phpDocumentor\\Reflection\\Types\\Callable_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Callable_.php',
+ 'phpDocumentor\\Reflection\\Types\\Compound' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Compound.php',
+ 'phpDocumentor\\Reflection\\Types\\Context' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Context.php',
+ 'phpDocumentor\\Reflection\\Types\\ContextFactory' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/ContextFactory.php',
+ 'phpDocumentor\\Reflection\\Types\\Float_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Float_.php',
+ 'phpDocumentor\\Reflection\\Types\\Integer' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Integer.php',
+ 'phpDocumentor\\Reflection\\Types\\Iterable_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Iterable_.php',
+ 'phpDocumentor\\Reflection\\Types\\Mixed_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Mixed_.php',
+ 'phpDocumentor\\Reflection\\Types\\Null_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Null_.php',
+ 'phpDocumentor\\Reflection\\Types\\Nullable' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Nullable.php',
+ 'phpDocumentor\\Reflection\\Types\\Object_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Object_.php',
+ 'phpDocumentor\\Reflection\\Types\\Parent_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Parent_.php',
+ 'phpDocumentor\\Reflection\\Types\\Resource_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Resource_.php',
+ 'phpDocumentor\\Reflection\\Types\\Scalar' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Scalar.php',
+ 'phpDocumentor\\Reflection\\Types\\Self_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Self_.php',
+ 'phpDocumentor\\Reflection\\Types\\Static_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Static_.php',
+ 'phpDocumentor\\Reflection\\Types\\String_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/String_.php',
+ 'phpDocumentor\\Reflection\\Types\\This' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/This.php',
+ 'phpDocumentor\\Reflection\\Types\\Void_' => __DIR__ . '/..' . '/phpdocumentor/type-resolver/src/Types/Void_.php',
+ );
+
+ public static function getInitializer(ClassLoader $loader)
+ {
+ return \Closure::bind(function () use ($loader) {
+ $loader->prefixLengthsPsr4 = ComposerStaticInit32220b89e337d5c8ea9feb0fd5ac6779::$prefixLengthsPsr4;
+ $loader->prefixDirsPsr4 = ComposerStaticInit32220b89e337d5c8ea9feb0fd5ac6779::$prefixDirsPsr4;
+ $loader->fallbackDirsPsr4 = ComposerStaticInit32220b89e337d5c8ea9feb0fd5ac6779::$fallbackDirsPsr4;
+ $loader->prefixesPsr0 = ComposerStaticInit32220b89e337d5c8ea9feb0fd5ac6779::$prefixesPsr0;
+ $loader->classMap = ComposerStaticInit32220b89e337d5c8ea9feb0fd5ac6779::$classMap;
+
+ }, null, ClassLoader::class);
+ }
+}
diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json
new file mode 100644
index 000000000..4df0acee0
--- /dev/null
+++ b/vendor/composer/installed.json
@@ -0,0 +1,4399 @@
+{
+ "packages": [
+ {
+ "name": "dnoegel/php-xdg-base-dir",
+ "version": "v0.1.1",
+ "version_normalized": "0.1.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/dnoegel/php-xdg-base-dir.git",
+ "reference": "8f8a6e48c5ecb0f991c2fdcf5f154a47d85f9ffd"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/dnoegel/php-xdg-base-dir/zipball/8f8a6e48c5ecb0f991c2fdcf5f154a47d85f9ffd",
+ "reference": "8f8a6e48c5ecb0f991c2fdcf5f154a47d85f9ffd",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~7.0|~6.0|~5.0|~4.8.35"
+ },
+ "time": "2019-12-04T15:06:13+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "XdgBaseDir\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "implementation of xdg base directory specification for php",
+ "support": {
+ "issues": "https://github.com/dnoegel/php-xdg-base-dir/issues",
+ "source": "https://github.com/dnoegel/php-xdg-base-dir/tree/v0.1.1"
+ },
+ "install-path": "../dnoegel/php-xdg-base-dir"
+ },
+ {
+ "name": "doctrine/inflector",
+ "version": "v1.1.0",
+ "version_normalized": "1.1.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/doctrine/inflector.git",
+ "reference": "90b2128806bfde671b6952ab8bea493942c1fdae"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/doctrine/inflector/zipball/90b2128806bfde671b6952ab8bea493942c1fdae",
+ "reference": "90b2128806bfde671b6952ab8bea493942c1fdae",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "4.*"
+ },
+ "time": "2015-11-06T14:35:42+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.1.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-0": {
+ "Doctrine\\Common\\Inflector\\": "lib/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Roman Borschel",
+ "email": "roman@code-factory.org"
+ },
+ {
+ "name": "Benjamin Eberlei",
+ "email": "kontakt@beberlei.de"
+ },
+ {
+ "name": "Guilherme Blanco",
+ "email": "guilhermeblanco@gmail.com"
+ },
+ {
+ "name": "Jonathan Wage",
+ "email": "jonwage@gmail.com"
+ },
+ {
+ "name": "Johannes Schmitt",
+ "email": "schmittjoh@gmail.com"
+ }
+ ],
+ "description": "Common String Manipulations with regard to casing and singular/plural rules.",
+ "homepage": "http://www.doctrine-project.org",
+ "keywords": [
+ "inflection",
+ "pluralize",
+ "singularize",
+ "string"
+ ],
+ "support": {
+ "source": "https://github.com/doctrine/inflector/tree/master"
+ },
+ "install-path": "../doctrine/inflector"
+ },
+ {
+ "name": "doctrine/instantiator",
+ "version": "1.0.5",
+ "version_normalized": "1.0.5.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/doctrine/instantiator.git",
+ "reference": "8e884e78f9f0eb1329e445619e04456e64d8051d"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/doctrine/instantiator/zipball/8e884e78f9f0eb1329e445619e04456e64d8051d",
+ "reference": "8e884e78f9f0eb1329e445619e04456e64d8051d",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3,<8.0-DEV"
+ },
+ "require-dev": {
+ "athletic/athletic": "~0.1.8",
+ "ext-pdo": "*",
+ "ext-phar": "*",
+ "phpunit/phpunit": "~4.0",
+ "squizlabs/php_codesniffer": "~2.0"
+ },
+ "time": "2015-06-14T21:17:01+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Doctrine\\Instantiator\\": "src/Doctrine/Instantiator/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Marco Pivetta",
+ "email": "ocramius@gmail.com",
+ "homepage": "http://ocramius.github.com/"
+ }
+ ],
+ "description": "A small, lightweight utility to instantiate objects in PHP without invoking their constructors",
+ "homepage": "https://github.com/doctrine/instantiator",
+ "keywords": [
+ "constructor",
+ "instantiate"
+ ],
+ "support": {
+ "issues": "https://github.com/doctrine/instantiator/issues",
+ "source": "https://github.com/doctrine/instantiator/tree/master"
+ },
+ "install-path": "../doctrine/instantiator"
+ },
+ {
+ "name": "erusev/parsedown",
+ "version": "1.7.4",
+ "version_normalized": "1.7.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/erusev/parsedown.git",
+ "reference": "cb17b6477dfff935958ba01325f2e8a2bfa6dab3"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/erusev/parsedown/zipball/cb17b6477dfff935958ba01325f2e8a2bfa6dab3",
+ "reference": "cb17b6477dfff935958ba01325f2e8a2bfa6dab3",
+ "shasum": ""
+ },
+ "require": {
+ "ext-mbstring": "*",
+ "php": ">=5.3.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^4.8.35"
+ },
+ "time": "2019-12-30T22:54:17+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-0": {
+ "Parsedown": ""
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Emanuil Rusev",
+ "email": "hello@erusev.com",
+ "homepage": "http://erusev.com"
+ }
+ ],
+ "description": "Parser for Markdown.",
+ "homepage": "http://parsedown.org",
+ "keywords": [
+ "markdown",
+ "parser"
+ ],
+ "support": {
+ "issues": "https://github.com/erusev/parsedown/issues",
+ "source": "https://github.com/erusev/parsedown/tree/1.7.x"
+ },
+ "install-path": "../erusev/parsedown"
+ },
+ {
+ "name": "fzaninotto/faker",
+ "version": "v1.9.2",
+ "version_normalized": "1.9.2.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/fzaninotto/Faker.git",
+ "reference": "848d8125239d7dbf8ab25cb7f054f1a630e68c2e"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/fzaninotto/Faker/zipball/848d8125239d7dbf8ab25cb7f054f1a630e68c2e",
+ "reference": "848d8125239d7dbf8ab25cb7f054f1a630e68c2e",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.3.3 || ^7.0"
+ },
+ "require-dev": {
+ "ext-intl": "*",
+ "phpunit/phpunit": "^4.8.35 || ^5.7",
+ "squizlabs/php_codesniffer": "^2.9.2"
+ },
+ "time": "2020-12-11T09:56:16+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.9-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Faker\\": "src/Faker/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "François Zaninotto"
+ }
+ ],
+ "description": "Faker is a PHP library that generates fake data for you.",
+ "keywords": [
+ "data",
+ "faker",
+ "fixtures"
+ ],
+ "support": {
+ "issues": "https://github.com/fzaninotto/Faker/issues",
+ "source": "https://github.com/fzaninotto/Faker/tree/v1.9.2"
+ },
+ "abandoned": true,
+ "install-path": "../fzaninotto/faker"
+ },
+ {
+ "name": "hamcrest/hamcrest-php",
+ "version": "v1.2.2",
+ "version_normalized": "1.2.2.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/hamcrest/hamcrest-php.git",
+ "reference": "b37020aa976fa52d3de9aa904aa2522dc518f79c"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/hamcrest/hamcrest-php/zipball/b37020aa976fa52d3de9aa904aa2522dc518f79c",
+ "reference": "b37020aa976fa52d3de9aa904aa2522dc518f79c",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.2"
+ },
+ "replace": {
+ "cordoval/hamcrest-php": "*",
+ "davedevelopment/hamcrest-php": "*",
+ "kodova/hamcrest-php": "*"
+ },
+ "require-dev": {
+ "phpunit/php-file-iterator": "1.3.3",
+ "satooshi/php-coveralls": "dev-master"
+ },
+ "time": "2015-05-11T14:41:42+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "hamcrest/Hamcrest.php"
+ ],
+ "classmap": [
+ "hamcrest"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD"
+ ],
+ "description": "This is the PHP port of Hamcrest Matchers",
+ "keywords": [
+ "test"
+ ],
+ "support": {
+ "issues": "https://github.com/hamcrest/hamcrest-php/issues",
+ "source": "https://github.com/hamcrest/hamcrest-php/tree/master"
+ },
+ "install-path": "../hamcrest/hamcrest-php"
+ },
+ {
+ "name": "jakub-onderka/php-console-color",
+ "version": "v0.2",
+ "version_normalized": "0.2.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/JakubOnderka/PHP-Console-Color.git",
+ "reference": "d5deaecff52a0d61ccb613bb3804088da0307191"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/JakubOnderka/PHP-Console-Color/zipball/d5deaecff52a0d61ccb613bb3804088da0307191",
+ "reference": "d5deaecff52a0d61ccb613bb3804088da0307191",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.4.0"
+ },
+ "require-dev": {
+ "jakub-onderka/php-code-style": "1.0",
+ "jakub-onderka/php-parallel-lint": "1.0",
+ "jakub-onderka/php-var-dump-check": "0.*",
+ "phpunit/phpunit": "~4.3",
+ "squizlabs/php_codesniffer": "1.*"
+ },
+ "time": "2018-09-29T17:23:10+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "JakubOnderka\\PhpConsoleColor\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-2-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Jakub Onderka",
+ "email": "jakub.onderka@gmail.com"
+ }
+ ],
+ "support": {
+ "issues": "https://github.com/JakubOnderka/PHP-Console-Color/issues",
+ "source": "https://github.com/JakubOnderka/PHP-Console-Color/tree/master"
+ },
+ "abandoned": "php-parallel-lint/php-console-color",
+ "install-path": "../jakub-onderka/php-console-color"
+ },
+ {
+ "name": "jakub-onderka/php-console-highlighter",
+ "version": "v0.4",
+ "version_normalized": "0.4.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/JakubOnderka/PHP-Console-Highlighter.git",
+ "reference": "9f7a229a69d52506914b4bc61bfdb199d90c5547"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/JakubOnderka/PHP-Console-Highlighter/zipball/9f7a229a69d52506914b4bc61bfdb199d90c5547",
+ "reference": "9f7a229a69d52506914b4bc61bfdb199d90c5547",
+ "shasum": ""
+ },
+ "require": {
+ "ext-tokenizer": "*",
+ "jakub-onderka/php-console-color": "~0.2",
+ "php": ">=5.4.0"
+ },
+ "require-dev": {
+ "jakub-onderka/php-code-style": "~1.0",
+ "jakub-onderka/php-parallel-lint": "~1.0",
+ "jakub-onderka/php-var-dump-check": "~0.1",
+ "phpunit/phpunit": "~4.0",
+ "squizlabs/php_codesniffer": "~1.5"
+ },
+ "time": "2018-09-29T18:48:56+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "JakubOnderka\\PhpConsoleHighlighter\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Jakub Onderka",
+ "email": "acci@acci.cz",
+ "homepage": "http://www.acci.cz/"
+ }
+ ],
+ "description": "Highlight PHP code in terminal",
+ "support": {
+ "issues": "https://github.com/JakubOnderka/PHP-Console-Highlighter/issues",
+ "source": "https://github.com/JakubOnderka/PHP-Console-Highlighter/tree/master"
+ },
+ "abandoned": "php-parallel-lint/php-console-highlighter",
+ "install-path": "../jakub-onderka/php-console-highlighter"
+ },
+ {
+ "name": "kylekatarnls/update-helper",
+ "version": "1.2.1",
+ "version_normalized": "1.2.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/kylekatarnls/update-helper.git",
+ "reference": "429be50660ed8a196e0798e5939760f168ec8ce9"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/kylekatarnls/update-helper/zipball/429be50660ed8a196e0798e5939760f168ec8ce9",
+ "reference": "429be50660ed8a196e0798e5939760f168ec8ce9",
+ "shasum": ""
+ },
+ "require": {
+ "composer-plugin-api": "^1.1.0 || ^2.0.0",
+ "php": ">=5.3.0"
+ },
+ "require-dev": {
+ "codeclimate/php-test-reporter": "dev-master",
+ "composer/composer": "2.0.x-dev || ^2.0.0-dev",
+ "phpunit/phpunit": ">=4.8.35 <6.0"
+ },
+ "time": "2020-04-07T20:44:10+00:00",
+ "type": "composer-plugin",
+ "extra": {
+ "class": "UpdateHelper\\ComposerPlugin"
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-0": {
+ "UpdateHelper\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Kyle",
+ "email": "kylekatarnls@gmail.com"
+ }
+ ],
+ "description": "Update helper",
+ "support": {
+ "issues": "https://github.com/kylekatarnls/update-helper/issues",
+ "source": "https://github.com/kylekatarnls/update-helper/tree/1.2.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/kylekatarnls",
+ "type": "github"
+ },
+ {
+ "url": "https://opencollective.com/Carbon",
+ "type": "open_collective"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/nesbot/carbon",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../kylekatarnls/update-helper"
+ },
+ {
+ "name": "laravel/framework",
+ "version": "v5.4.36",
+ "version_normalized": "5.4.36.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/laravel/framework.git",
+ "reference": "1062a22232071c3e8636487c86ec1ae75681bbf9"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/laravel/framework/zipball/1062a22232071c3e8636487c86ec1ae75681bbf9",
+ "reference": "1062a22232071c3e8636487c86ec1ae75681bbf9",
+ "shasum": ""
+ },
+ "require": {
+ "doctrine/inflector": "~1.1",
+ "erusev/parsedown": "~1.6",
+ "ext-mbstring": "*",
+ "ext-openssl": "*",
+ "league/flysystem": "~1.0",
+ "monolog/monolog": "~1.11",
+ "mtdowling/cron-expression": "~1.0",
+ "nesbot/carbon": "~1.20",
+ "paragonie/random_compat": "~1.4|~2.0",
+ "php": ">=5.6.4",
+ "ramsey/uuid": "~3.0",
+ "swiftmailer/swiftmailer": "~5.4",
+ "symfony/console": "~3.2",
+ "symfony/debug": "~3.2",
+ "symfony/finder": "~3.2",
+ "symfony/http-foundation": "~3.2",
+ "symfony/http-kernel": "~3.2",
+ "symfony/process": "~3.2",
+ "symfony/routing": "~3.2",
+ "symfony/var-dumper": "~3.2",
+ "tijsverkoyen/css-to-inline-styles": "~2.2",
+ "vlucas/phpdotenv": "~2.2"
+ },
+ "replace": {
+ "illuminate/auth": "self.version",
+ "illuminate/broadcasting": "self.version",
+ "illuminate/bus": "self.version",
+ "illuminate/cache": "self.version",
+ "illuminate/config": "self.version",
+ "illuminate/console": "self.version",
+ "illuminate/container": "self.version",
+ "illuminate/contracts": "self.version",
+ "illuminate/cookie": "self.version",
+ "illuminate/database": "self.version",
+ "illuminate/encryption": "self.version",
+ "illuminate/events": "self.version",
+ "illuminate/exception": "self.version",
+ "illuminate/filesystem": "self.version",
+ "illuminate/hashing": "self.version",
+ "illuminate/http": "self.version",
+ "illuminate/log": "self.version",
+ "illuminate/mail": "self.version",
+ "illuminate/notifications": "self.version",
+ "illuminate/pagination": "self.version",
+ "illuminate/pipeline": "self.version",
+ "illuminate/queue": "self.version",
+ "illuminate/redis": "self.version",
+ "illuminate/routing": "self.version",
+ "illuminate/session": "self.version",
+ "illuminate/support": "self.version",
+ "illuminate/translation": "self.version",
+ "illuminate/validation": "self.version",
+ "illuminate/view": "self.version",
+ "tightenco/collect": "self.version"
+ },
+ "require-dev": {
+ "aws/aws-sdk-php": "~3.0",
+ "doctrine/dbal": "~2.5",
+ "mockery/mockery": "~0.9.4",
+ "pda/pheanstalk": "~3.0",
+ "phpunit/phpunit": "~5.7",
+ "predis/predis": "~1.0",
+ "symfony/css-selector": "~3.2",
+ "symfony/dom-crawler": "~3.2"
+ },
+ "suggest": {
+ "aws/aws-sdk-php": "Required to use the SQS queue driver and SES mail driver (~3.0).",
+ "doctrine/dbal": "Required to rename columns and drop SQLite columns (~2.5).",
+ "fzaninotto/faker": "Required to use the eloquent factory builder (~1.4).",
+ "guzzlehttp/guzzle": "Required to use the Mailgun and Mandrill mail drivers and the ping methods on schedules (~6.0).",
+ "laravel/tinker": "Required to use the tinker console command (~1.0).",
+ "league/flysystem-aws-s3-v3": "Required to use the Flysystem S3 driver (~1.0).",
+ "league/flysystem-rackspace": "Required to use the Flysystem Rackspace driver (~1.0).",
+ "nexmo/client": "Required to use the Nexmo transport (~1.0).",
+ "pda/pheanstalk": "Required to use the beanstalk queue driver (~3.0).",
+ "predis/predis": "Required to use the redis cache and queue drivers (~1.0).",
+ "pusher/pusher-php-server": "Required to use the Pusher broadcast driver (~2.0).",
+ "symfony/css-selector": "Required to use some of the crawler integration testing tools (~3.2).",
+ "symfony/dom-crawler": "Required to use most of the crawler integration testing tools (~3.2).",
+ "symfony/psr-http-message-bridge": "Required to psr7 bridging features (0.2.*)."
+ },
+ "time": "2017-08-30T09:26:16+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "src/Illuminate/Foundation/helpers.php",
+ "src/Illuminate/Support/helpers.php"
+ ],
+ "psr-4": {
+ "Illuminate\\": "src/Illuminate/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "description": "The Laravel Framework.",
+ "homepage": "https://laravel.com",
+ "keywords": [
+ "framework",
+ "laravel"
+ ],
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "install-path": "../laravel/framework"
+ },
+ {
+ "name": "laravel/tinker",
+ "version": "v1.0.10",
+ "version_normalized": "1.0.10.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/laravel/tinker.git",
+ "reference": "ad571aacbac1539c30d480908f9d0c9614eaf1a7"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/laravel/tinker/zipball/ad571aacbac1539c30d480908f9d0c9614eaf1a7",
+ "reference": "ad571aacbac1539c30d480908f9d0c9614eaf1a7",
+ "shasum": ""
+ },
+ "require": {
+ "illuminate/console": "~5.1|^6.0",
+ "illuminate/contracts": "~5.1|^6.0",
+ "illuminate/support": "~5.1|^6.0",
+ "php": ">=5.5.9",
+ "psy/psysh": "0.7.*|0.8.*|0.9.*",
+ "symfony/var-dumper": "~3.0|~4.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.0|~5.0"
+ },
+ "suggest": {
+ "illuminate/database": "The Illuminate Database package (~5.1)."
+ },
+ "time": "2019-08-07T15:10:45+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0-dev"
+ },
+ "laravel": {
+ "providers": [
+ "Laravel\\Tinker\\TinkerServiceProvider"
+ ]
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Laravel\\Tinker\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "description": "Powerful REPL for the Laravel framework.",
+ "keywords": [
+ "REPL",
+ "Tinker",
+ "laravel",
+ "psysh"
+ ],
+ "support": {
+ "issues": "https://github.com/laravel/tinker/issues",
+ "source": "https://github.com/laravel/tinker/tree/v1.0.10"
+ },
+ "install-path": "../laravel/tinker"
+ },
+ {
+ "name": "league/flysystem",
+ "version": "1.0.70",
+ "version_normalized": "1.0.70.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/thephpleague/flysystem.git",
+ "reference": "585824702f534f8d3cf7fab7225e8466cc4b7493"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/thephpleague/flysystem/zipball/585824702f534f8d3cf7fab7225e8466cc4b7493",
+ "reference": "585824702f534f8d3cf7fab7225e8466cc4b7493",
+ "shasum": ""
+ },
+ "require": {
+ "ext-fileinfo": "*",
+ "php": ">=5.5.9"
+ },
+ "conflict": {
+ "league/flysystem-sftp": "<1.0.6"
+ },
+ "require-dev": {
+ "phpspec/phpspec": "^3.4 || ^4.0 || ^5.0 || ^6.0",
+ "phpunit/phpunit": "^5.7.26"
+ },
+ "suggest": {
+ "ext-fileinfo": "Required for MimeType",
+ "ext-ftp": "Allows you to use FTP server storage",
+ "ext-openssl": "Allows you to use FTPS server storage",
+ "league/flysystem-aws-s3-v2": "Allows you to use S3 storage with AWS SDK v2",
+ "league/flysystem-aws-s3-v3": "Allows you to use S3 storage with AWS SDK v3",
+ "league/flysystem-azure": "Allows you to use Windows Azure Blob storage",
+ "league/flysystem-cached-adapter": "Flysystem adapter decorator for metadata caching",
+ "league/flysystem-eventable-filesystem": "Allows you to use EventableFilesystem",
+ "league/flysystem-rackspace": "Allows you to use Rackspace Cloud Files",
+ "league/flysystem-sftp": "Allows you to use SFTP server storage via phpseclib",
+ "league/flysystem-webdav": "Allows you to use WebDAV storage",
+ "league/flysystem-ziparchive": "Allows you to use ZipArchive adapter",
+ "spatie/flysystem-dropbox": "Allows you to use Dropbox storage",
+ "srmklive/flysystem-dropbox-v2": "Allows you to use Dropbox storage for PHP 5 applications"
+ },
+ "time": "2020-07-26T07:20:36+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.1-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "League\\Flysystem\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Frank de Jonge",
+ "email": "info@frenky.net"
+ }
+ ],
+ "description": "Filesystem abstraction: Many filesystems, one API.",
+ "keywords": [
+ "Cloud Files",
+ "WebDAV",
+ "abstraction",
+ "aws",
+ "cloud",
+ "copy.com",
+ "dropbox",
+ "file systems",
+ "files",
+ "filesystem",
+ "filesystems",
+ "ftp",
+ "rackspace",
+ "remote",
+ "s3",
+ "sftp",
+ "storage"
+ ],
+ "support": {
+ "issues": "https://github.com/thephpleague/flysystem/issues",
+ "source": "https://github.com/thephpleague/flysystem/tree/1.0.70"
+ },
+ "funding": [
+ {
+ "url": "https://offset.earth/frankdejonge",
+ "type": "other"
+ }
+ ],
+ "install-path": "../league/flysystem"
+ },
+ {
+ "name": "mockery/mockery",
+ "version": "0.9.11",
+ "version_normalized": "0.9.11.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/mockery/mockery.git",
+ "reference": "be9bf28d8e57d67883cba9fcadfcff8caab667f8"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/mockery/mockery/zipball/be9bf28d8e57d67883cba9fcadfcff8caab667f8",
+ "reference": "be9bf28d8e57d67883cba9fcadfcff8caab667f8",
+ "shasum": ""
+ },
+ "require": {
+ "hamcrest/hamcrest-php": "~1.1",
+ "lib-pcre": ">=7.0",
+ "php": ">=5.3.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.0"
+ },
+ "time": "2019-02-12T16:07:13+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "0.9.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-0": {
+ "Mockery": "library/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Pádraic Brady",
+ "email": "padraic.brady@gmail.com",
+ "homepage": "http://blog.astrumfutura.com"
+ },
+ {
+ "name": "Dave Marshall",
+ "email": "dave.marshall@atstsolutions.co.uk",
+ "homepage": "http://davedevelopment.co.uk"
+ }
+ ],
+ "description": "Mockery is a simple yet flexible PHP mock object framework for use in unit testing with PHPUnit, PHPSpec or any other testing framework. Its core goal is to offer a test double framework with a succinct API capable of clearly defining all possible object operations and interactions using a human readable Domain Specific Language (DSL). Designed as a drop in alternative to PHPUnit's phpunit-mock-objects library, Mockery is easy to integrate with PHPUnit and can operate alongside phpunit-mock-objects without the World ending.",
+ "homepage": "http://github.com/padraic/mockery",
+ "keywords": [
+ "BDD",
+ "TDD",
+ "library",
+ "mock",
+ "mock objects",
+ "mockery",
+ "stub",
+ "test",
+ "test double",
+ "testing"
+ ],
+ "support": {
+ "issues": "https://github.com/mockery/mockery/issues",
+ "source": "https://github.com/mockery/mockery/tree/0.9"
+ },
+ "install-path": "../mockery/mockery"
+ },
+ {
+ "name": "monolog/monolog",
+ "version": "1.27.1",
+ "version_normalized": "1.27.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/Seldaek/monolog.git",
+ "reference": "904713c5929655dc9b97288b69cfeedad610c9a1"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/Seldaek/monolog/zipball/904713c5929655dc9b97288b69cfeedad610c9a1",
+ "reference": "904713c5929655dc9b97288b69cfeedad610c9a1",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.0",
+ "psr/log": "~1.0"
+ },
+ "provide": {
+ "psr/log-implementation": "1.0.0"
+ },
+ "require-dev": {
+ "aws/aws-sdk-php": "^2.4.9 || ^3.0",
+ "doctrine/couchdb": "~1.0@dev",
+ "graylog2/gelf-php": "~1.0",
+ "php-amqplib/php-amqplib": "~2.4",
+ "php-console/php-console": "^3.1.3",
+ "phpstan/phpstan": "^0.12.59",
+ "phpunit/phpunit": "~4.5",
+ "ruflin/elastica": ">=0.90 <3.0",
+ "sentry/sentry": "^0.13",
+ "swiftmailer/swiftmailer": "^5.3|^6.0"
+ },
+ "suggest": {
+ "aws/aws-sdk-php": "Allow sending log messages to AWS services like DynamoDB",
+ "doctrine/couchdb": "Allow sending log messages to a CouchDB server",
+ "ext-amqp": "Allow sending log messages to an AMQP server (1.0+ required)",
+ "ext-mongo": "Allow sending log messages to a MongoDB server",
+ "graylog2/gelf-php": "Allow sending log messages to a GrayLog2 server",
+ "mongodb/mongodb": "Allow sending log messages to a MongoDB server via PHP Driver",
+ "php-amqplib/php-amqplib": "Allow sending log messages to an AMQP server using php-amqplib",
+ "php-console/php-console": "Allow sending log messages to Google Chrome",
+ "rollbar/rollbar": "Allow sending log messages to Rollbar",
+ "ruflin/elastica": "Allow sending log messages to an Elastic Search server",
+ "sentry/sentry": "Allow sending log messages to a Sentry server"
+ },
+ "time": "2022-06-09T08:53:42+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Monolog\\": "src/Monolog"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Jordi Boggiano",
+ "email": "j.boggiano@seld.be",
+ "homepage": "http://seld.be"
+ }
+ ],
+ "description": "Sends your logs to files, sockets, inboxes, databases and various web services",
+ "homepage": "http://github.com/Seldaek/monolog",
+ "keywords": [
+ "log",
+ "logging",
+ "psr-3"
+ ],
+ "support": {
+ "issues": "https://github.com/Seldaek/monolog/issues",
+ "source": "https://github.com/Seldaek/monolog/tree/1.27.1"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/Seldaek",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/monolog/monolog",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../monolog/monolog"
+ },
+ {
+ "name": "mtdowling/cron-expression",
+ "version": "v1.2.3",
+ "version_normalized": "1.2.3.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/mtdowling/cron-expression.git",
+ "reference": "9be552eebcc1ceec9776378f7dcc085246cacca6"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/mtdowling/cron-expression/zipball/9be552eebcc1ceec9776378f7dcc085246cacca6",
+ "reference": "9be552eebcc1ceec9776378f7dcc085246cacca6",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.0|~5.0"
+ },
+ "time": "2019-12-28T04:23:06+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Cron\\": "src/Cron/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Michael Dowling",
+ "email": "mtdowling@gmail.com",
+ "homepage": "https://github.com/mtdowling"
+ }
+ ],
+ "description": "CRON for PHP: Calculate the next or previous run date and determine if a CRON expression is due",
+ "keywords": [
+ "cron",
+ "schedule"
+ ],
+ "support": {
+ "issues": "https://github.com/mtdowling/cron-expression/issues",
+ "source": "https://github.com/mtdowling/cron-expression/tree/v1.2.3"
+ },
+ "abandoned": "dragonmantank/cron-expression",
+ "install-path": "../mtdowling/cron-expression"
+ },
+ {
+ "name": "myclabs/deep-copy",
+ "version": "1.7.0",
+ "version_normalized": "1.7.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/myclabs/DeepCopy.git",
+ "reference": "3b8a3a99ba1f6a3952ac2747d989303cbd6b7a3e"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/myclabs/DeepCopy/zipball/3b8a3a99ba1f6a3952ac2747d989303cbd6b7a3e",
+ "reference": "3b8a3a99ba1f6a3952ac2747d989303cbd6b7a3e",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.6 || ^7.0"
+ },
+ "require-dev": {
+ "doctrine/collections": "^1.0",
+ "doctrine/common": "^2.6",
+ "phpunit/phpunit": "^4.1"
+ },
+ "time": "2017-10-19T19:58:43+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "src/DeepCopy/deep_copy.php"
+ ],
+ "psr-4": {
+ "DeepCopy\\": "src/DeepCopy/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "description": "Create deep copies (clones) of your objects",
+ "keywords": [
+ "clone",
+ "copy",
+ "duplicate",
+ "object",
+ "object graph"
+ ],
+ "support": {
+ "issues": "https://github.com/myclabs/DeepCopy/issues",
+ "source": "https://github.com/myclabs/DeepCopy/tree/1.x"
+ },
+ "install-path": "../myclabs/deep-copy"
+ },
+ {
+ "name": "nesbot/carbon",
+ "version": "1.39.1",
+ "version_normalized": "1.39.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/briannesbitt/Carbon.git",
+ "reference": "4be0c005164249208ce1b5ca633cd57bdd42ff33"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/briannesbitt/Carbon/zipball/4be0c005164249208ce1b5ca633cd57bdd42ff33",
+ "reference": "4be0c005164249208ce1b5ca633cd57bdd42ff33",
+ "shasum": ""
+ },
+ "require": {
+ "kylekatarnls/update-helper": "^1.1",
+ "php": ">=5.3.9",
+ "symfony/translation": "~2.6 || ~3.0 || ~4.0"
+ },
+ "require-dev": {
+ "composer/composer": "^1.2",
+ "friendsofphp/php-cs-fixer": "~2",
+ "phpunit/phpunit": "^4.8.35 || ^5.7"
+ },
+ "time": "2019-10-14T05:51:36+00:00",
+ "bin": [
+ "bin/upgrade-carbon"
+ ],
+ "type": "library",
+ "extra": {
+ "update-helper": "Carbon\\Upgrade",
+ "laravel": {
+ "providers": [
+ "Carbon\\Laravel\\ServiceProvider"
+ ]
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Brian Nesbitt",
+ "email": "brian@nesbot.com",
+ "homepage": "http://nesbot.com"
+ }
+ ],
+ "description": "A simple API extension for DateTime.",
+ "homepage": "http://carbon.nesbot.com",
+ "keywords": [
+ "date",
+ "datetime",
+ "time"
+ ],
+ "support": {
+ "issues": "https://github.com/briannesbitt/Carbon/issues",
+ "source": "https://github.com/briannesbitt/Carbon"
+ },
+ "install-path": "../nesbot/carbon"
+ },
+ {
+ "name": "nikic/php-parser",
+ "version": "v3.1.5",
+ "version_normalized": "3.1.5.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/nikic/PHP-Parser.git",
+ "reference": "bb87e28e7d7b8d9a7fda231d37457c9210faf6ce"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/bb87e28e7d7b8d9a7fda231d37457c9210faf6ce",
+ "reference": "bb87e28e7d7b8d9a7fda231d37457c9210faf6ce",
+ "shasum": ""
+ },
+ "require": {
+ "ext-tokenizer": "*",
+ "php": ">=5.5"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.0|~5.0"
+ },
+ "time": "2018-02-28T20:30:58+00:00",
+ "bin": [
+ "bin/php-parse"
+ ],
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "3.0-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "PhpParser\\": "lib/PhpParser"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Nikita Popov"
+ }
+ ],
+ "description": "A PHP parser written in PHP",
+ "keywords": [
+ "parser",
+ "php"
+ ],
+ "support": {
+ "issues": "https://github.com/nikic/PHP-Parser/issues",
+ "source": "https://github.com/nikic/PHP-Parser/tree/v3.1.5"
+ },
+ "install-path": "../nikic/php-parser"
+ },
+ {
+ "name": "paragonie/random_compat",
+ "version": "v2.0.21",
+ "version_normalized": "2.0.21.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/paragonie/random_compat.git",
+ "reference": "96c132c7f2f7bc3230723b66e89f8f150b29d5ae"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/paragonie/random_compat/zipball/96c132c7f2f7bc3230723b66e89f8f150b29d5ae",
+ "reference": "96c132c7f2f7bc3230723b66e89f8f150b29d5ae",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.2.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "*"
+ },
+ "suggest": {
+ "ext-libsodium": "Provides a modern crypto API that can be used to generate random bytes."
+ },
+ "time": "2022-02-16T17:07:03+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "lib/random.php"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Paragon Initiative Enterprises",
+ "email": "security@paragonie.com",
+ "homepage": "https://paragonie.com"
+ }
+ ],
+ "description": "PHP 5.x polyfill for random_bytes() and random_int() from PHP 7",
+ "keywords": [
+ "csprng",
+ "polyfill",
+ "pseudorandom",
+ "random"
+ ],
+ "support": {
+ "email": "info@paragonie.com",
+ "issues": "https://github.com/paragonie/random_compat/issues",
+ "source": "https://github.com/paragonie/random_compat"
+ },
+ "install-path": "../paragonie/random_compat"
+ },
+ {
+ "name": "phpdocumentor/reflection-common",
+ "version": "1.0.1",
+ "version_normalized": "1.0.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phpDocumentor/ReflectionCommon.git",
+ "reference": "21bdeb5f65d7ebf9f43b1b25d404f87deab5bfb6"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpDocumentor/ReflectionCommon/zipball/21bdeb5f65d7ebf9f43b1b25d404f87deab5bfb6",
+ "reference": "21bdeb5f65d7ebf9f43b1b25d404f87deab5bfb6",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.5"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^4.6"
+ },
+ "time": "2017-09-11T18:02:19+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "phpDocumentor\\Reflection\\": [
+ "src"
+ ]
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Jaap van Otterdijk",
+ "email": "opensource@ijaap.nl"
+ }
+ ],
+ "description": "Common reflection classes used by phpdocumentor to reflect the code structure",
+ "homepage": "http://www.phpdoc.org",
+ "keywords": [
+ "FQSEN",
+ "phpDocumentor",
+ "phpdoc",
+ "reflection",
+ "static analysis"
+ ],
+ "support": {
+ "issues": "https://github.com/phpDocumentor/ReflectionCommon/issues",
+ "source": "https://github.com/phpDocumentor/ReflectionCommon/tree/master"
+ },
+ "install-path": "../phpdocumentor/reflection-common"
+ },
+ {
+ "name": "phpdocumentor/reflection-docblock",
+ "version": "3.3.2",
+ "version_normalized": "3.3.2.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phpDocumentor/ReflectionDocBlock.git",
+ "reference": "bf329f6c1aadea3299f08ee804682b7c45b326a2"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpDocumentor/ReflectionDocBlock/zipball/bf329f6c1aadea3299f08ee804682b7c45b326a2",
+ "reference": "bf329f6c1aadea3299f08ee804682b7c45b326a2",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.6 || ^7.0",
+ "phpdocumentor/reflection-common": "^1.0.0",
+ "phpdocumentor/type-resolver": "^0.4.0",
+ "webmozart/assert": "^1.0"
+ },
+ "require-dev": {
+ "mockery/mockery": "^0.9.4",
+ "phpunit/phpunit": "^4.4"
+ },
+ "time": "2017-11-10T14:09:06+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "phpDocumentor\\Reflection\\": [
+ "src/"
+ ]
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Mike van Riel",
+ "email": "me@mikevanriel.com"
+ }
+ ],
+ "description": "With this component, a library can provide support for annotations via DocBlocks or otherwise retrieve information that is embedded in a DocBlock.",
+ "support": {
+ "issues": "https://github.com/phpDocumentor/ReflectionDocBlock/issues",
+ "source": "https://github.com/phpDocumentor/ReflectionDocBlock/tree/release/3.x"
+ },
+ "install-path": "../phpdocumentor/reflection-docblock"
+ },
+ {
+ "name": "phpdocumentor/type-resolver",
+ "version": "0.4.0",
+ "version_normalized": "0.4.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phpDocumentor/TypeResolver.git",
+ "reference": "9c977708995954784726e25d0cd1dddf4e65b0f7"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpDocumentor/TypeResolver/zipball/9c977708995954784726e25d0cd1dddf4e65b0f7",
+ "reference": "9c977708995954784726e25d0cd1dddf4e65b0f7",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5 || ^7.0",
+ "phpdocumentor/reflection-common": "^1.0"
+ },
+ "require-dev": {
+ "mockery/mockery": "^0.9.4",
+ "phpunit/phpunit": "^5.2||^4.8.24"
+ },
+ "time": "2017-07-14T14:27:02+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "phpDocumentor\\Reflection\\": [
+ "src/"
+ ]
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Mike van Riel",
+ "email": "me@mikevanriel.com"
+ }
+ ],
+ "support": {
+ "issues": "https://github.com/phpDocumentor/TypeResolver/issues",
+ "source": "https://github.com/phpDocumentor/TypeResolver/tree/master"
+ },
+ "install-path": "../phpdocumentor/type-resolver"
+ },
+ {
+ "name": "phpspec/prophecy",
+ "version": "v1.10.3",
+ "version_normalized": "1.10.3.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/phpspec/prophecy.git",
+ "reference": "451c3cd1418cf640de218914901e51b064abb093"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/phpspec/prophecy/zipball/451c3cd1418cf640de218914901e51b064abb093",
+ "reference": "451c3cd1418cf640de218914901e51b064abb093",
+ "shasum": ""
+ },
+ "require": {
+ "doctrine/instantiator": "^1.0.2",
+ "php": "^5.3|^7.0",
+ "phpdocumentor/reflection-docblock": "^2.0|^3.0.2|^4.0|^5.0",
+ "sebastian/comparator": "^1.2.3|^2.0|^3.0|^4.0",
+ "sebastian/recursion-context": "^1.0|^2.0|^3.0|^4.0"
+ },
+ "require-dev": {
+ "phpspec/phpspec": "^2.5 || ^3.2",
+ "phpunit/phpunit": "^4.8.35 || ^5.7 || ^6.5 || ^7.1"
+ },
+ "time": "2020-03-05T15:02:03+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.10.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Prophecy\\": "src/Prophecy"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Konstantin Kudryashov",
+ "email": "ever.zet@gmail.com",
+ "homepage": "http://everzet.com"
+ },
+ {
+ "name": "Marcello Duarte",
+ "email": "marcello.duarte@gmail.com"
+ }
+ ],
+ "description": "Highly opinionated mocking framework for PHP 5.3+",
+ "homepage": "https://github.com/phpspec/prophecy",
+ "keywords": [
+ "Double",
+ "Dummy",
+ "fake",
+ "mock",
+ "spy",
+ "stub"
+ ],
+ "support": {
+ "issues": "https://github.com/phpspec/prophecy/issues",
+ "source": "https://github.com/phpspec/prophecy/tree/v1.10.3"
+ },
+ "install-path": "../phpspec/prophecy"
+ },
+ {
+ "name": "phpunit/php-code-coverage",
+ "version": "4.0.8",
+ "version_normalized": "4.0.8.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/php-code-coverage.git",
+ "reference": "ef7b2f56815df854e66ceaee8ebe9393ae36a40d"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/ef7b2f56815df854e66ceaee8ebe9393ae36a40d",
+ "reference": "ef7b2f56815df854e66ceaee8ebe9393ae36a40d",
+ "shasum": ""
+ },
+ "require": {
+ "ext-dom": "*",
+ "ext-xmlwriter": "*",
+ "php": "^5.6 || ^7.0",
+ "phpunit/php-file-iterator": "^1.3",
+ "phpunit/php-text-template": "^1.2",
+ "phpunit/php-token-stream": "^1.4.2 || ^2.0",
+ "sebastian/code-unit-reverse-lookup": "^1.0",
+ "sebastian/environment": "^1.3.2 || ^2.0",
+ "sebastian/version": "^1.0 || ^2.0"
+ },
+ "require-dev": {
+ "ext-xdebug": "^2.1.4",
+ "phpunit/phpunit": "^5.7"
+ },
+ "suggest": {
+ "ext-xdebug": "^2.5.1"
+ },
+ "time": "2017-04-02T07:44:40+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "4.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sb@sebastian-bergmann.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Library that provides collection, processing, and rendering functionality for PHP code coverage information.",
+ "homepage": "https://github.com/sebastianbergmann/php-code-coverage",
+ "keywords": [
+ "coverage",
+ "testing",
+ "xunit"
+ ],
+ "support": {
+ "irc": "irc://irc.freenode.net/phpunit",
+ "issues": "https://github.com/sebastianbergmann/php-code-coverage/issues",
+ "source": "https://github.com/sebastianbergmann/php-code-coverage/tree/4.0"
+ },
+ "install-path": "../phpunit/php-code-coverage"
+ },
+ {
+ "name": "phpunit/php-file-iterator",
+ "version": "1.4.5",
+ "version_normalized": "1.4.5.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/php-file-iterator.git",
+ "reference": "730b01bc3e867237eaac355e06a36b85dd93a8b4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/730b01bc3e867237eaac355e06a36b85dd93a8b4",
+ "reference": "730b01bc3e867237eaac355e06a36b85dd93a8b4",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3"
+ },
+ "time": "2017-11-27T13:52:08+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.4.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sb@sebastian-bergmann.de",
+ "role": "lead"
+ }
+ ],
+ "description": "FilterIterator implementation that filters files based on a list of suffixes.",
+ "homepage": "https://github.com/sebastianbergmann/php-file-iterator/",
+ "keywords": [
+ "filesystem",
+ "iterator"
+ ],
+ "support": {
+ "irc": "irc://irc.freenode.net/phpunit",
+ "issues": "https://github.com/sebastianbergmann/php-file-iterator/issues",
+ "source": "https://github.com/sebastianbergmann/php-file-iterator/tree/1.4.5"
+ },
+ "install-path": "../phpunit/php-file-iterator"
+ },
+ {
+ "name": "phpunit/php-text-template",
+ "version": "1.2.1",
+ "version_normalized": "1.2.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/php-text-template.git",
+ "reference": "31f8b717e51d9a2afca6c9f046f5d69fc27c8686"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/31f8b717e51d9a2afca6c9f046f5d69fc27c8686",
+ "reference": "31f8b717e51d9a2afca6c9f046f5d69fc27c8686",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3"
+ },
+ "time": "2015-06-21T13:50:34+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Simple template engine.",
+ "homepage": "https://github.com/sebastianbergmann/php-text-template/",
+ "keywords": [
+ "template"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/php-text-template/issues",
+ "source": "https://github.com/sebastianbergmann/php-text-template/tree/1.2.1"
+ },
+ "install-path": "../phpunit/php-text-template"
+ },
+ {
+ "name": "phpunit/php-timer",
+ "version": "1.0.9",
+ "version_normalized": "1.0.9.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/php-timer.git",
+ "reference": "3dcf38ca72b158baf0bc245e9184d3fdffa9c46f"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/3dcf38ca72b158baf0bc245e9184d3fdffa9c46f",
+ "reference": "3dcf38ca72b158baf0bc245e9184d3fdffa9c46f",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.3.3 || ^7.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^4.8.35 || ^5.7 || ^6.0"
+ },
+ "time": "2017-02-26T11:10:40+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sb@sebastian-bergmann.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Utility class for timing",
+ "homepage": "https://github.com/sebastianbergmann/php-timer/",
+ "keywords": [
+ "timer"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/php-timer/issues",
+ "source": "https://github.com/sebastianbergmann/php-timer/tree/master"
+ },
+ "install-path": "../phpunit/php-timer"
+ },
+ {
+ "name": "phpunit/php-token-stream",
+ "version": "1.4.12",
+ "version_normalized": "1.4.12.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/php-token-stream.git",
+ "reference": "1ce90ba27c42e4e44e6d8458241466380b51fa16"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-token-stream/zipball/1ce90ba27c42e4e44e6d8458241466380b51fa16",
+ "reference": "1ce90ba27c42e4e44e6d8458241466380b51fa16",
+ "shasum": ""
+ },
+ "require": {
+ "ext-tokenizer": "*",
+ "php": ">=5.3.3"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.2"
+ },
+ "time": "2017-12-04T08:55:13+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.4-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Wrapper around PHP's tokenizer extension.",
+ "homepage": "https://github.com/sebastianbergmann/php-token-stream/",
+ "keywords": [
+ "tokenizer"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/php-token-stream/issues",
+ "source": "https://github.com/sebastianbergmann/php-token-stream/tree/1.4"
+ },
+ "abandoned": true,
+ "install-path": "../phpunit/php-token-stream"
+ },
+ {
+ "name": "phpunit/phpunit",
+ "version": "5.7.27",
+ "version_normalized": "5.7.27.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/phpunit.git",
+ "reference": "b7803aeca3ccb99ad0a506fa80b64cd6a56bbc0c"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/b7803aeca3ccb99ad0a506fa80b64cd6a56bbc0c",
+ "reference": "b7803aeca3ccb99ad0a506fa80b64cd6a56bbc0c",
+ "shasum": ""
+ },
+ "require": {
+ "ext-dom": "*",
+ "ext-json": "*",
+ "ext-libxml": "*",
+ "ext-mbstring": "*",
+ "ext-xml": "*",
+ "myclabs/deep-copy": "~1.3",
+ "php": "^5.6 || ^7.0",
+ "phpspec/prophecy": "^1.6.2",
+ "phpunit/php-code-coverage": "^4.0.4",
+ "phpunit/php-file-iterator": "~1.4",
+ "phpunit/php-text-template": "~1.2",
+ "phpunit/php-timer": "^1.0.6",
+ "phpunit/phpunit-mock-objects": "^3.2",
+ "sebastian/comparator": "^1.2.4",
+ "sebastian/diff": "^1.4.3",
+ "sebastian/environment": "^1.3.4 || ^2.0",
+ "sebastian/exporter": "~2.0",
+ "sebastian/global-state": "^1.1",
+ "sebastian/object-enumerator": "~2.0",
+ "sebastian/resource-operations": "~1.0",
+ "sebastian/version": "^1.0.6|^2.0.1",
+ "symfony/yaml": "~2.1|~3.0|~4.0"
+ },
+ "conflict": {
+ "phpdocumentor/reflection-docblock": "3.0.2"
+ },
+ "require-dev": {
+ "ext-pdo": "*"
+ },
+ "suggest": {
+ "ext-xdebug": "*",
+ "phpunit/php-invoker": "~1.1"
+ },
+ "time": "2018-02-01T05:50:59+00:00",
+ "bin": [
+ "phpunit"
+ ],
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.7.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "The PHP Unit Testing framework.",
+ "homepage": "https://phpunit.de/",
+ "keywords": [
+ "phpunit",
+ "testing",
+ "xunit"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/phpunit/issues",
+ "source": "https://github.com/sebastianbergmann/phpunit/tree/5.7.27"
+ },
+ "install-path": "../phpunit/phpunit"
+ },
+ {
+ "name": "phpunit/phpunit-mock-objects",
+ "version": "3.4.4",
+ "version_normalized": "3.4.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/phpunit-mock-objects.git",
+ "reference": "a23b761686d50a560cc56233b9ecf49597cc9118"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/phpunit-mock-objects/zipball/a23b761686d50a560cc56233b9ecf49597cc9118",
+ "reference": "a23b761686d50a560cc56233b9ecf49597cc9118",
+ "shasum": ""
+ },
+ "require": {
+ "doctrine/instantiator": "^1.0.2",
+ "php": "^5.6 || ^7.0",
+ "phpunit/php-text-template": "^1.2",
+ "sebastian/exporter": "^1.2 || ^2.0"
+ },
+ "conflict": {
+ "phpunit/phpunit": "<5.4.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^5.4"
+ },
+ "suggest": {
+ "ext-soap": "*"
+ },
+ "time": "2017-06-30T09:13:00+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "3.2.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sb@sebastian-bergmann.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Mock Object library for PHPUnit",
+ "homepage": "https://github.com/sebastianbergmann/phpunit-mock-objects/",
+ "keywords": [
+ "mock",
+ "xunit"
+ ],
+ "support": {
+ "irc": "irc://irc.freenode.net/phpunit",
+ "issues": "https://github.com/sebastianbergmann/phpunit-mock-objects/issues",
+ "source": "https://github.com/sebastianbergmann/phpunit-mock-objects/tree/3.4"
+ },
+ "abandoned": true,
+ "install-path": "../phpunit/phpunit-mock-objects"
+ },
+ {
+ "name": "psr/log",
+ "version": "1.1.4",
+ "version_normalized": "1.1.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/php-fig/log.git",
+ "reference": "d49695b909c3b7628b6289db5479a1c204601f11"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/php-fig/log/zipball/d49695b909c3b7628b6289db5479a1c204601f11",
+ "reference": "d49695b909c3b7628b6289db5479a1c204601f11",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.0"
+ },
+ "time": "2021-05-03T11:20:27+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.1.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Psr\\Log\\": "Psr/Log/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "PHP-FIG",
+ "homepage": "https://www.php-fig.org/"
+ }
+ ],
+ "description": "Common interface for logging libraries",
+ "homepage": "https://github.com/php-fig/log",
+ "keywords": [
+ "log",
+ "psr",
+ "psr-3"
+ ],
+ "support": {
+ "source": "https://github.com/php-fig/log/tree/1.1.4"
+ },
+ "install-path": "../psr/log"
+ },
+ {
+ "name": "psy/psysh",
+ "version": "v0.9.12",
+ "version_normalized": "0.9.12.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/bobthecow/psysh.git",
+ "reference": "90da7f37568aee36b116a030c5f99c915267edd4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/bobthecow/psysh/zipball/90da7f37568aee36b116a030c5f99c915267edd4",
+ "reference": "90da7f37568aee36b116a030c5f99c915267edd4",
+ "shasum": ""
+ },
+ "require": {
+ "dnoegel/php-xdg-base-dir": "0.1.*",
+ "ext-json": "*",
+ "ext-tokenizer": "*",
+ "jakub-onderka/php-console-highlighter": "0.3.*|0.4.*",
+ "nikic/php-parser": "~1.3|~2.0|~3.0|~4.0",
+ "php": ">=5.4.0",
+ "symfony/console": "~2.3.10|^2.4.2|~3.0|~4.0|~5.0",
+ "symfony/var-dumper": "~2.7|~3.0|~4.0|~5.0"
+ },
+ "require-dev": {
+ "bamarni/composer-bin-plugin": "^1.2",
+ "hoa/console": "~2.15|~3.16",
+ "phpunit/phpunit": "~4.8.35|~5.0|~6.0|~7.0"
+ },
+ "suggest": {
+ "ext-pcntl": "Enabling the PCNTL extension makes PsySH a lot happier :)",
+ "ext-pdo-sqlite": "The doc command requires SQLite to work.",
+ "ext-posix": "If you have PCNTL, you'll want the POSIX extension as well.",
+ "ext-readline": "Enables support for arrow-key history navigation, and showing and manipulating command history.",
+ "hoa/console": "A pure PHP readline implementation. You'll want this if your PHP install doesn't already support readline or libedit."
+ },
+ "time": "2019-12-06T14:19:43+00:00",
+ "bin": [
+ "bin/psysh"
+ ],
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-develop": "0.9.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "src/functions.php"
+ ],
+ "psr-4": {
+ "Psy\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Justin Hileman",
+ "email": "justin@justinhileman.info",
+ "homepage": "http://justinhileman.com"
+ }
+ ],
+ "description": "An interactive shell for modern PHP.",
+ "homepage": "http://psysh.org",
+ "keywords": [
+ "REPL",
+ "console",
+ "interactive",
+ "shell"
+ ],
+ "support": {
+ "issues": "https://github.com/bobthecow/psysh/issues",
+ "source": "https://github.com/bobthecow/psysh/tree/v0.9.12"
+ },
+ "install-path": "../psy/psysh"
+ },
+ {
+ "name": "ramsey/uuid",
+ "version": "3.9.7",
+ "version_normalized": "3.9.7.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/ramsey/uuid.git",
+ "reference": "dc75aa439eb4c1b77f5379fd958b3dc0e6014178"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/ramsey/uuid/zipball/dc75aa439eb4c1b77f5379fd958b3dc0e6014178",
+ "reference": "dc75aa439eb4c1b77f5379fd958b3dc0e6014178",
+ "shasum": ""
+ },
+ "require": {
+ "ext-json": "*",
+ "paragonie/random_compat": "^1 | ^2 | ^9.99.99",
+ "php": "^5.4 | ^7.0 | ^8.0",
+ "symfony/polyfill-ctype": "^1.8"
+ },
+ "replace": {
+ "rhumsaa/uuid": "self.version"
+ },
+ "require-dev": {
+ "codeception/aspect-mock": "^1 | ^2",
+ "doctrine/annotations": "^1.2",
+ "goaop/framework": "1.0.0-alpha.2 | ^1 | >=2.1.0 <=2.3.2",
+ "mockery/mockery": "^0.9.11 | ^1",
+ "moontoast/math": "^1.1",
+ "nikic/php-parser": "<=4.5.0",
+ "paragonie/random-lib": "^2",
+ "php-mock/php-mock-phpunit": "^0.3 | ^1.1 | ^2.6",
+ "php-parallel-lint/php-parallel-lint": "^1.3",
+ "phpunit/phpunit": ">=4.8.36 <9.0.0 | >=9.3.0",
+ "squizlabs/php_codesniffer": "^3.5",
+ "yoast/phpunit-polyfills": "^1.0"
+ },
+ "suggest": {
+ "ext-ctype": "Provides support for PHP Ctype functions",
+ "ext-libsodium": "Provides the PECL libsodium extension for use with the SodiumRandomGenerator",
+ "ext-openssl": "Provides the OpenSSL extension for use with the OpenSslGenerator",
+ "ext-uuid": "Provides the PECL UUID extension for use with the PeclUuidTimeGenerator and PeclUuidRandomGenerator",
+ "moontoast/math": "Provides support for converting UUID to 128-bit integer (in string form).",
+ "paragonie/random-lib": "Provides RandomLib for use with the RandomLibAdapter",
+ "ramsey/uuid-console": "A console application for generating UUIDs with ramsey/uuid",
+ "ramsey/uuid-doctrine": "Allows the use of Ramsey\\Uuid\\Uuid as Doctrine field type."
+ },
+ "time": "2022-12-19T21:55:10+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "src/functions.php"
+ ],
+ "psr-4": {
+ "Ramsey\\Uuid\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Ben Ramsey",
+ "email": "ben@benramsey.com",
+ "homepage": "https://benramsey.com"
+ },
+ {
+ "name": "Marijn Huizendveld",
+ "email": "marijn.huizendveld@gmail.com"
+ },
+ {
+ "name": "Thibaud Fabre",
+ "email": "thibaud@aztech.io"
+ }
+ ],
+ "description": "Formerly rhumsaa/uuid. A PHP 5.4+ library for generating RFC 4122 version 1, 3, 4, and 5 universally unique identifiers (UUID).",
+ "homepage": "https://github.com/ramsey/uuid",
+ "keywords": [
+ "guid",
+ "identifier",
+ "uuid"
+ ],
+ "support": {
+ "issues": "https://github.com/ramsey/uuid/issues",
+ "rss": "https://github.com/ramsey/uuid/releases.atom",
+ "source": "https://github.com/ramsey/uuid",
+ "wiki": "https://github.com/ramsey/uuid/wiki"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/ramsey",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/ramsey/uuid",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../ramsey/uuid"
+ },
+ {
+ "name": "sebastian/code-unit-reverse-lookup",
+ "version": "1.0.2",
+ "version_normalized": "1.0.2.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/code-unit-reverse-lookup.git",
+ "reference": "1de8cd5c010cb153fcd68b8d0f64606f523f7619"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/code-unit-reverse-lookup/zipball/1de8cd5c010cb153fcd68b8d0f64606f523f7619",
+ "reference": "1de8cd5c010cb153fcd68b8d0f64606f523f7619",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.6"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^8.5"
+ },
+ "time": "2020-11-30T08:15:22+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Looks up which function or method a line of code belongs to",
+ "homepage": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/issues",
+ "source": "https://github.com/sebastianbergmann/code-unit-reverse-lookup/tree/1.0.2"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/sebastianbergmann",
+ "type": "github"
+ }
+ ],
+ "install-path": "../sebastian/code-unit-reverse-lookup"
+ },
+ {
+ "name": "sebastian/comparator",
+ "version": "1.2.4",
+ "version_normalized": "1.2.4.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/comparator.git",
+ "reference": "2b7424b55f5047b47ac6e5ccb20b2aea4011d9be"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/comparator/zipball/2b7424b55f5047b47ac6e5ccb20b2aea4011d9be",
+ "reference": "2b7424b55f5047b47ac6e5ccb20b2aea4011d9be",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3",
+ "sebastian/diff": "~1.2",
+ "sebastian/exporter": "~1.2 || ~2.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.4"
+ },
+ "time": "2017-01-29T09:50:25+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.2.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Jeff Welch",
+ "email": "whatthejeff@gmail.com"
+ },
+ {
+ "name": "Volker Dusch",
+ "email": "github@wallbash.com"
+ },
+ {
+ "name": "Bernhard Schussek",
+ "email": "bschussek@2bepublished.at"
+ },
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Provides the functionality to compare PHP values for equality",
+ "homepage": "http://www.github.com/sebastianbergmann/comparator",
+ "keywords": [
+ "comparator",
+ "compare",
+ "equality"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/comparator/issues",
+ "source": "https://github.com/sebastianbergmann/comparator/tree/1.2"
+ },
+ "install-path": "../sebastian/comparator"
+ },
+ {
+ "name": "sebastian/diff",
+ "version": "1.4.3",
+ "version_normalized": "1.4.3.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/diff.git",
+ "reference": "7f066a26a962dbe58ddea9f72a4e82874a3975a4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/7f066a26a962dbe58ddea9f72a4e82874a3975a4",
+ "reference": "7f066a26a962dbe58ddea9f72a4e82874a3975a4",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.3.3 || ^7.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^4.8.35 || ^5.7 || ^6.0"
+ },
+ "time": "2017-05-22T07:24:03+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.4-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Kore Nordmann",
+ "email": "mail@kore-nordmann.de"
+ },
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Diff implementation",
+ "homepage": "https://github.com/sebastianbergmann/diff",
+ "keywords": [
+ "diff"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/diff/issues",
+ "source": "https://github.com/sebastianbergmann/diff/tree/1.4"
+ },
+ "install-path": "../sebastian/diff"
+ },
+ {
+ "name": "sebastian/environment",
+ "version": "2.0.0",
+ "version_normalized": "2.0.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/environment.git",
+ "reference": "5795ffe5dc5b02460c3e34222fee8cbe245d8fac"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/5795ffe5dc5b02460c3e34222fee8cbe245d8fac",
+ "reference": "5795ffe5dc5b02460c3e34222fee8cbe245d8fac",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.6 || ^7.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^5.0"
+ },
+ "time": "2016-11-26T07:53:53+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Provides functionality to handle HHVM/PHP environments",
+ "homepage": "http://www.github.com/sebastianbergmann/environment",
+ "keywords": [
+ "Xdebug",
+ "environment",
+ "hhvm"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/environment/issues",
+ "source": "https://github.com/sebastianbergmann/environment/tree/master"
+ },
+ "install-path": "../sebastian/environment"
+ },
+ {
+ "name": "sebastian/exporter",
+ "version": "2.0.0",
+ "version_normalized": "2.0.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/exporter.git",
+ "reference": "ce474bdd1a34744d7ac5d6aad3a46d48d9bac4c4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/ce474bdd1a34744d7ac5d6aad3a46d48d9bac4c4",
+ "reference": "ce474bdd1a34744d7ac5d6aad3a46d48d9bac4c4",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3",
+ "sebastian/recursion-context": "~2.0"
+ },
+ "require-dev": {
+ "ext-mbstring": "*",
+ "phpunit/phpunit": "~4.4"
+ },
+ "time": "2016-11-19T08:54:04+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Jeff Welch",
+ "email": "whatthejeff@gmail.com"
+ },
+ {
+ "name": "Volker Dusch",
+ "email": "github@wallbash.com"
+ },
+ {
+ "name": "Bernhard Schussek",
+ "email": "bschussek@2bepublished.at"
+ },
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ },
+ {
+ "name": "Adam Harvey",
+ "email": "aharvey@php.net"
+ }
+ ],
+ "description": "Provides the functionality to export PHP variables for visualization",
+ "homepage": "http://www.github.com/sebastianbergmann/exporter",
+ "keywords": [
+ "export",
+ "exporter"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/exporter/issues",
+ "source": "https://github.com/sebastianbergmann/exporter/tree/master"
+ },
+ "install-path": "../sebastian/exporter"
+ },
+ {
+ "name": "sebastian/global-state",
+ "version": "1.1.1",
+ "version_normalized": "1.1.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/global-state.git",
+ "reference": "bc37d50fea7d017d3d340f230811c9f1d7280af4"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/global-state/zipball/bc37d50fea7d017d3d340f230811c9f1d7280af4",
+ "reference": "bc37d50fea7d017d3d340f230811c9f1d7280af4",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.2"
+ },
+ "suggest": {
+ "ext-uopz": "*"
+ },
+ "time": "2015-10-12T03:26:01+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Snapshotting of global state",
+ "homepage": "http://www.github.com/sebastianbergmann/global-state",
+ "keywords": [
+ "global state"
+ ],
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/global-state/issues",
+ "source": "https://github.com/sebastianbergmann/global-state/tree/1.1.1"
+ },
+ "install-path": "../sebastian/global-state"
+ },
+ {
+ "name": "sebastian/object-enumerator",
+ "version": "2.0.1",
+ "version_normalized": "2.0.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/object-enumerator.git",
+ "reference": "1311872ac850040a79c3c058bea3e22d0f09cbb7"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/object-enumerator/zipball/1311872ac850040a79c3c058bea3e22d0f09cbb7",
+ "reference": "1311872ac850040a79c3c058bea3e22d0f09cbb7",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.6",
+ "sebastian/recursion-context": "~2.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~5"
+ },
+ "time": "2017-02-18T15:18:39+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Traverses array structures and object graphs to enumerate all referenced objects",
+ "homepage": "https://github.com/sebastianbergmann/object-enumerator/",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/object-enumerator/issues",
+ "source": "https://github.com/sebastianbergmann/object-enumerator/tree/master"
+ },
+ "install-path": "../sebastian/object-enumerator"
+ },
+ {
+ "name": "sebastian/recursion-context",
+ "version": "2.0.0",
+ "version_normalized": "2.0.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/recursion-context.git",
+ "reference": "2c3ba150cbec723aa057506e73a8d33bdb286c9a"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/recursion-context/zipball/2c3ba150cbec723aa057506e73a8d33bdb286c9a",
+ "reference": "2c3ba150cbec723aa057506e73a8d33bdb286c9a",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.4"
+ },
+ "time": "2016-11-19T07:33:16+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Jeff Welch",
+ "email": "whatthejeff@gmail.com"
+ },
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ },
+ {
+ "name": "Adam Harvey",
+ "email": "aharvey@php.net"
+ }
+ ],
+ "description": "Provides functionality to recursively process PHP variables",
+ "homepage": "http://www.github.com/sebastianbergmann/recursion-context",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/recursion-context/issues",
+ "source": "https://github.com/sebastianbergmann/recursion-context/tree/master"
+ },
+ "install-path": "../sebastian/recursion-context"
+ },
+ {
+ "name": "sebastian/resource-operations",
+ "version": "1.0.0",
+ "version_normalized": "1.0.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/resource-operations.git",
+ "reference": "ce990bb21759f94aeafd30209e8cfcdfa8bc3f52"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/resource-operations/zipball/ce990bb21759f94aeafd30209e8cfcdfa8bc3f52",
+ "reference": "ce990bb21759f94aeafd30209e8cfcdfa8bc3f52",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.6.0"
+ },
+ "time": "2015-07-28T20:34:47+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de"
+ }
+ ],
+ "description": "Provides a list of PHP built-in functions that operate on resources",
+ "homepage": "https://www.github.com/sebastianbergmann/resource-operations",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/resource-operations/issues",
+ "source": "https://github.com/sebastianbergmann/resource-operations/tree/master"
+ },
+ "install-path": "../sebastian/resource-operations"
+ },
+ {
+ "name": "sebastian/version",
+ "version": "2.0.1",
+ "version_normalized": "2.0.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/sebastianbergmann/version.git",
+ "reference": "99732be0ddb3361e16ad77b68ba41efc8e979019"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/sebastianbergmann/version/zipball/99732be0ddb3361e16ad77b68ba41efc8e979019",
+ "reference": "99732be0ddb3361e16ad77b68ba41efc8e979019",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.6"
+ },
+ "time": "2016-10-03T07:35:21+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.0.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "classmap": [
+ "src/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Sebastian Bergmann",
+ "email": "sebastian@phpunit.de",
+ "role": "lead"
+ }
+ ],
+ "description": "Library that helps with managing the version number of Git-hosted PHP projects",
+ "homepage": "https://github.com/sebastianbergmann/version",
+ "support": {
+ "issues": "https://github.com/sebastianbergmann/version/issues",
+ "source": "https://github.com/sebastianbergmann/version/tree/master"
+ },
+ "install-path": "../sebastian/version"
+ },
+ {
+ "name": "swiftmailer/swiftmailer",
+ "version": "v5.4.12",
+ "version_normalized": "5.4.12.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/swiftmailer/swiftmailer.git",
+ "reference": "181b89f18a90f8925ef805f950d47a7190e9b950"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/swiftmailer/swiftmailer/zipball/181b89f18a90f8925ef805f950d47a7190e9b950",
+ "reference": "181b89f18a90f8925ef805f950d47a7190e9b950",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3"
+ },
+ "require-dev": {
+ "mockery/mockery": "~0.9.1",
+ "symfony/phpunit-bridge": "~3.2"
+ },
+ "time": "2018-07-31T09:26:32+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "lib/swift_required.php"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Chris Corbyn"
+ },
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ }
+ ],
+ "description": "Swiftmailer, free feature-rich PHP mailer",
+ "homepage": "https://swiftmailer.symfony.com",
+ "keywords": [
+ "email",
+ "mail",
+ "mailer"
+ ],
+ "support": {
+ "issues": "https://github.com/swiftmailer/swiftmailer/issues",
+ "source": "https://github.com/swiftmailer/swiftmailer/tree/v5.4.12"
+ },
+ "abandoned": "symfony/mailer",
+ "install-path": "../swiftmailer/swiftmailer"
+ },
+ {
+ "name": "symfony/console",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/console.git",
+ "reference": "a10b1da6fc93080c180bba7219b5ff5b7518fe81"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/console/zipball/a10b1da6fc93080c180bba7219b5ff5b7518fe81",
+ "reference": "a10b1da6fc93080c180bba7219b5ff5b7518fe81",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8",
+ "symfony/debug": "~2.8|~3.0|~4.0",
+ "symfony/polyfill-mbstring": "~1.0"
+ },
+ "conflict": {
+ "symfony/dependency-injection": "<3.4",
+ "symfony/process": "<3.3"
+ },
+ "provide": {
+ "psr/log-implementation": "1.0"
+ },
+ "require-dev": {
+ "psr/log": "~1.0",
+ "symfony/config": "~3.3|~4.0",
+ "symfony/dependency-injection": "~3.4|~4.0",
+ "symfony/event-dispatcher": "~2.8|~3.0|~4.0",
+ "symfony/lock": "~3.4|~4.0",
+ "symfony/process": "~3.3|~4.0"
+ },
+ "suggest": {
+ "psr/log": "For using the console logger",
+ "symfony/event-dispatcher": "",
+ "symfony/lock": "",
+ "symfony/process": ""
+ },
+ "time": "2020-10-24T10:57:07+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Console\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony Console Component",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/console/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/console"
+ },
+ {
+ "name": "symfony/css-selector",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/css-selector.git",
+ "reference": "da3d9da2ce0026771f5fe64cb332158f1bd2bc33"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/css-selector/zipball/da3d9da2ce0026771f5fe64cb332158f1bd2bc33",
+ "reference": "da3d9da2ce0026771f5fe64cb332158f1bd2bc33",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8"
+ },
+ "time": "2020-10-24T10:57:07+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\CssSelector\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Jean-François Simon",
+ "email": "jeanfrancois.simon@sensiolabs.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony CssSelector Component",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/css-selector/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/css-selector"
+ },
+ {
+ "name": "symfony/debug",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/debug.git",
+ "reference": "ab42889de57fdfcfcc0759ab102e2fd4ea72dcae"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/debug/zipball/ab42889de57fdfcfcc0759ab102e2fd4ea72dcae",
+ "reference": "ab42889de57fdfcfcc0759ab102e2fd4ea72dcae",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8",
+ "psr/log": "~1.0"
+ },
+ "conflict": {
+ "symfony/http-kernel": ">=2.3,<2.3.24|~2.4.0|>=2.5,<2.5.9|>=2.6,<2.6.2"
+ },
+ "require-dev": {
+ "symfony/http-kernel": "~2.8|~3.0|~4.0"
+ },
+ "time": "2020-10-24T10:57:07+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Debug\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony Debug Component",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/debug/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "abandoned": "symfony/error-handler",
+ "install-path": "../symfony/debug"
+ },
+ {
+ "name": "symfony/event-dispatcher",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/event-dispatcher.git",
+ "reference": "31fde73757b6bad247c54597beef974919ec6860"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/31fde73757b6bad247c54597beef974919ec6860",
+ "reference": "31fde73757b6bad247c54597beef974919ec6860",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8"
+ },
+ "conflict": {
+ "symfony/dependency-injection": "<3.3"
+ },
+ "require-dev": {
+ "psr/log": "~1.0",
+ "symfony/config": "~2.8|~3.0|~4.0",
+ "symfony/debug": "~3.4|~4.4",
+ "symfony/dependency-injection": "~3.3|~4.0",
+ "symfony/expression-language": "~2.8|~3.0|~4.0",
+ "symfony/stopwatch": "~2.8|~3.0|~4.0"
+ },
+ "suggest": {
+ "symfony/dependency-injection": "",
+ "symfony/http-kernel": ""
+ },
+ "time": "2020-10-24T10:57:07+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\EventDispatcher\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony EventDispatcher Component",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/event-dispatcher/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/event-dispatcher"
+ },
+ {
+ "name": "symfony/finder",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/finder.git",
+ "reference": "b6b6ad3db3edb1b4b1c1896b1975fb684994de6e"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/finder/zipball/b6b6ad3db3edb1b4b1c1896b1975fb684994de6e",
+ "reference": "b6b6ad3db3edb1b4b1c1896b1975fb684994de6e",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8"
+ },
+ "time": "2020-11-16T17:02:08+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Finder\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony Finder Component",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/finder/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/finder"
+ },
+ {
+ "name": "symfony/http-foundation",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/http-foundation.git",
+ "reference": "b9885fcce6fe494201da4f70a9309770e9d13dc8"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/http-foundation/zipball/b9885fcce6fe494201da4f70a9309770e9d13dc8",
+ "reference": "b9885fcce6fe494201da4f70a9309770e9d13dc8",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8",
+ "symfony/polyfill-mbstring": "~1.1",
+ "symfony/polyfill-php70": "~1.6"
+ },
+ "require-dev": {
+ "symfony/expression-language": "~2.8|~3.0|~4.0"
+ },
+ "time": "2020-10-24T10:57:07+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\HttpFoundation\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony HttpFoundation Component",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/http-foundation/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/http-foundation"
+ },
+ {
+ "name": "symfony/http-kernel",
+ "version": "v3.4.49",
+ "version_normalized": "3.4.49.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/http-kernel.git",
+ "reference": "5aa72405f5bd5583c36ed6e756acb17d3f98ac40"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/http-kernel/zipball/5aa72405f5bd5583c36ed6e756acb17d3f98ac40",
+ "reference": "5aa72405f5bd5583c36ed6e756acb17d3f98ac40",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8",
+ "psr/log": "~1.0",
+ "symfony/debug": "^3.3.3|~4.0",
+ "symfony/event-dispatcher": "~2.8|~3.0|~4.0",
+ "symfony/http-foundation": "~3.4.12|~4.0.12|^4.1.1",
+ "symfony/polyfill-ctype": "~1.8",
+ "symfony/polyfill-php56": "~1.8"
+ },
+ "conflict": {
+ "symfony/config": "<2.8",
+ "symfony/dependency-injection": "<3.4.10|<4.0.10,>=4",
+ "symfony/var-dumper": "<3.3",
+ "twig/twig": "<1.34|<2.4,>=2"
+ },
+ "provide": {
+ "psr/log-implementation": "1.0"
+ },
+ "require-dev": {
+ "psr/cache": "~1.0",
+ "symfony/browser-kit": "~2.8|~3.0|~4.0",
+ "symfony/class-loader": "~2.8|~3.0",
+ "symfony/config": "~2.8|~3.0|~4.0",
+ "symfony/console": "~2.8|~3.0|~4.0",
+ "symfony/css-selector": "~2.8|~3.0|~4.0",
+ "symfony/dependency-injection": "^3.4.10|^4.0.10",
+ "symfony/dom-crawler": "~2.8|~3.0|~4.0",
+ "symfony/expression-language": "~2.8|~3.0|~4.0",
+ "symfony/finder": "~2.8|~3.0|~4.0",
+ "symfony/process": "~2.8|~3.0|~4.0",
+ "symfony/routing": "~3.4|~4.0",
+ "symfony/stopwatch": "~2.8|~3.0|~4.0",
+ "symfony/templating": "~2.8|~3.0|~4.0",
+ "symfony/translation": "~2.8|~3.0|~4.0",
+ "symfony/var-dumper": "~3.3|~4.0"
+ },
+ "suggest": {
+ "symfony/browser-kit": "",
+ "symfony/config": "",
+ "symfony/console": "",
+ "symfony/dependency-injection": "",
+ "symfony/finder": "",
+ "symfony/var-dumper": ""
+ },
+ "time": "2021-05-19T12:06:59+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\HttpKernel\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony HttpKernel Component",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/http-kernel/tree/v3.4.49"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/http-kernel"
+ },
+ {
+ "name": "symfony/polyfill-ctype",
+ "version": "v1.19.0",
+ "version_normalized": "1.19.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-ctype.git",
+ "reference": "aed596913b70fae57be53d86faa2e9ef85a2297b"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/aed596913b70fae57be53d86faa2e9ef85a2297b",
+ "reference": "aed596913b70fae57be53d86faa2e9ef85a2297b",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3"
+ },
+ "suggest": {
+ "ext-ctype": "For best performance"
+ },
+ "time": "2020-10-23T09:01:57+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "1.19-dev"
+ },
+ "thanks": {
+ "name": "symfony/polyfill",
+ "url": "https://github.com/symfony/polyfill"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Ctype\\": ""
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Gert de Pagter",
+ "email": "BackEndTea@gmail.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill for ctype functions",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "ctype",
+ "polyfill",
+ "portable"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-ctype/tree/v1.19.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/polyfill-ctype"
+ },
+ {
+ "name": "symfony/polyfill-mbstring",
+ "version": "v1.19.0",
+ "version_normalized": "1.19.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-mbstring.git",
+ "reference": "b5f7b932ee6fa802fc792eabd77c4c88084517ce"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/b5f7b932ee6fa802fc792eabd77c4c88084517ce",
+ "reference": "b5f7b932ee6fa802fc792eabd77c4c88084517ce",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3"
+ },
+ "suggest": {
+ "ext-mbstring": "For best performance"
+ },
+ "time": "2020-10-23T09:01:57+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "1.19-dev"
+ },
+ "thanks": {
+ "name": "symfony/polyfill",
+ "url": "https://github.com/symfony/polyfill"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Mbstring\\": ""
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill for the Mbstring extension",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "mbstring",
+ "polyfill",
+ "portable",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-mbstring/tree/v1.19.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/polyfill-mbstring"
+ },
+ {
+ "name": "symfony/polyfill-php56",
+ "version": "v1.19.0",
+ "version_normalized": "1.19.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-php56.git",
+ "reference": "ea19621731cbd973a6702cfedef3419768bf3372"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-php56/zipball/ea19621731cbd973a6702cfedef3419768bf3372",
+ "reference": "ea19621731cbd973a6702cfedef3419768bf3372",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3",
+ "symfony/polyfill-util": "~1.0"
+ },
+ "time": "2020-10-23T09:01:57+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "1.19-dev"
+ },
+ "thanks": {
+ "name": "symfony/polyfill",
+ "url": "https://github.com/symfony/polyfill"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Php56\\": ""
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill backporting some PHP 5.6+ features to lower PHP versions",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "polyfill",
+ "portable",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-php56/tree/v1.19.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/polyfill-php56"
+ },
+ {
+ "name": "symfony/polyfill-php70",
+ "version": "v1.19.0",
+ "version_normalized": "1.19.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-php70.git",
+ "reference": "3fe414077251a81a1b15b1c709faf5c2fbae3d4e"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-php70/zipball/3fe414077251a81a1b15b1c709faf5c2fbae3d4e",
+ "reference": "3fe414077251a81a1b15b1c709faf5c2fbae3d4e",
+ "shasum": ""
+ },
+ "require": {
+ "paragonie/random_compat": "~1.0|~2.0|~9.99",
+ "php": ">=5.3.3"
+ },
+ "time": "2020-10-23T09:01:57+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "1.19-dev"
+ },
+ "thanks": {
+ "name": "symfony/polyfill",
+ "url": "https://github.com/symfony/polyfill"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "bootstrap.php"
+ ],
+ "psr-4": {
+ "Symfony\\Polyfill\\Php70\\": ""
+ },
+ "classmap": [
+ "Resources/stubs"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony polyfill backporting some PHP 7.0+ features to lower PHP versions",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compatibility",
+ "polyfill",
+ "portable",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-php70/tree/v1.19.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/polyfill-php70"
+ },
+ {
+ "name": "symfony/polyfill-util",
+ "version": "v1.19.0",
+ "version_normalized": "1.19.0.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/polyfill-util.git",
+ "reference": "8df0c3e6a4b85df9a5c6f3f2f46fba5c5c47058a"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/polyfill-util/zipball/8df0c3e6a4b85df9a5c6f3f2f46fba5c5c47058a",
+ "reference": "8df0c3e6a4b85df9a5c6f3f2f46fba5c5c47058a",
+ "shasum": ""
+ },
+ "require": {
+ "php": ">=5.3.3"
+ },
+ "time": "2020-10-21T09:57:48+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-main": "1.19-dev"
+ },
+ "thanks": {
+ "name": "symfony/polyfill",
+ "url": "https://github.com/symfony/polyfill"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Polyfill\\Util\\": ""
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony utilities for portability of PHP codes",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "compat",
+ "compatibility",
+ "polyfill",
+ "shim"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/polyfill-util/tree/v1.19.0"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/polyfill-util"
+ },
+ {
+ "name": "symfony/process",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/process.git",
+ "reference": "b8648cf1d5af12a44a51d07ef9bf980921f15fca"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/process/zipball/b8648cf1d5af12a44a51d07ef9bf980921f15fca",
+ "reference": "b8648cf1d5af12a44a51d07ef9bf980921f15fca",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8"
+ },
+ "time": "2020-10-24T10:57:07+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Process\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony Process Component",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/process/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/process"
+ },
+ {
+ "name": "symfony/routing",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/routing.git",
+ "reference": "3e522ac69cadffd8131cc2b22157fa7662331a6c"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/routing/zipball/3e522ac69cadffd8131cc2b22157fa7662331a6c",
+ "reference": "3e522ac69cadffd8131cc2b22157fa7662331a6c",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8"
+ },
+ "conflict": {
+ "symfony/config": "<3.3.1",
+ "symfony/dependency-injection": "<3.3",
+ "symfony/yaml": "<3.4"
+ },
+ "require-dev": {
+ "doctrine/annotations": "~1.0",
+ "psr/log": "~1.0",
+ "symfony/config": "^3.3.1|~4.0",
+ "symfony/dependency-injection": "~3.3|~4.0",
+ "symfony/expression-language": "~2.8|~3.0|~4.0",
+ "symfony/http-foundation": "~2.8|~3.0|~4.0",
+ "symfony/yaml": "~3.4|~4.0"
+ },
+ "suggest": {
+ "doctrine/annotations": "For using the annotation loader",
+ "symfony/config": "For using the all-in-one router or any loader",
+ "symfony/expression-language": "For using expression matching",
+ "symfony/http-foundation": "For using a Symfony Request object",
+ "symfony/yaml": "For using the YAML loader"
+ },
+ "time": "2020-10-24T10:57:07+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Routing\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony Routing Component",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "router",
+ "routing",
+ "uri",
+ "url"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/routing/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/routing"
+ },
+ {
+ "name": "symfony/translation",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/translation.git",
+ "reference": "be83ee6c065cb32becdb306ba61160d598b1ce88"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/translation/zipball/be83ee6c065cb32becdb306ba61160d598b1ce88",
+ "reference": "be83ee6c065cb32becdb306ba61160d598b1ce88",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8",
+ "symfony/polyfill-mbstring": "~1.0"
+ },
+ "conflict": {
+ "symfony/config": "<2.8",
+ "symfony/dependency-injection": "<3.4",
+ "symfony/yaml": "<3.4"
+ },
+ "require-dev": {
+ "psr/log": "~1.0",
+ "symfony/config": "~2.8|~3.0|~4.0",
+ "symfony/dependency-injection": "~3.4|~4.0",
+ "symfony/finder": "~2.8|~3.0|~4.0",
+ "symfony/http-kernel": "~3.4|~4.0",
+ "symfony/intl": "^2.8.18|^3.2.5|~4.0",
+ "symfony/var-dumper": "~3.4|~4.0",
+ "symfony/yaml": "~3.4|~4.0"
+ },
+ "suggest": {
+ "psr/log-implementation": "To use logging capability in translator",
+ "symfony/config": "",
+ "symfony/yaml": ""
+ },
+ "time": "2020-10-24T10:57:07+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Translation\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony Translation Component",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/translation/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/translation"
+ },
+ {
+ "name": "symfony/var-dumper",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/var-dumper.git",
+ "reference": "0719f6cf4633a38b2c1585140998579ce23b4b7d"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/var-dumper/zipball/0719f6cf4633a38b2c1585140998579ce23b4b7d",
+ "reference": "0719f6cf4633a38b2c1585140998579ce23b4b7d",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8",
+ "symfony/polyfill-mbstring": "~1.0"
+ },
+ "conflict": {
+ "phpunit/phpunit": "<4.8.35|<5.4.3,>=5.0"
+ },
+ "require-dev": {
+ "ext-iconv": "*",
+ "twig/twig": "~1.34|~2.4"
+ },
+ "suggest": {
+ "ext-iconv": "To convert non-UTF-8 strings to UTF-8 (or symfony/polyfill-iconv in case ext-iconv cannot be used).",
+ "ext-intl": "To show region name in time zone dump",
+ "ext-symfony_debug": ""
+ },
+ "time": "2020-10-24T10:57:07+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "files": [
+ "Resources/functions/dump.php"
+ ],
+ "psr-4": {
+ "Symfony\\Component\\VarDumper\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Nicolas Grekas",
+ "email": "p@tchwork.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony mechanism for exploring and dumping PHP variables",
+ "homepage": "https://symfony.com",
+ "keywords": [
+ "debug",
+ "dump"
+ ],
+ "support": {
+ "source": "https://github.com/symfony/var-dumper/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/var-dumper"
+ },
+ {
+ "name": "symfony/yaml",
+ "version": "v3.4.47",
+ "version_normalized": "3.4.47.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/symfony/yaml.git",
+ "reference": "88289caa3c166321883f67fe5130188ebbb47094"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/symfony/yaml/zipball/88289caa3c166321883f67fe5130188ebbb47094",
+ "reference": "88289caa3c166321883f67fe5130188ebbb47094",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.5.9|>=7.0.8",
+ "symfony/polyfill-ctype": "~1.8"
+ },
+ "conflict": {
+ "symfony/console": "<3.4"
+ },
+ "require-dev": {
+ "symfony/console": "~3.4|~4.0"
+ },
+ "suggest": {
+ "symfony/console": "For validating YAML files using the lint command"
+ },
+ "time": "2020-10-24T10:57:07+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Symfony\\Component\\Yaml\\": ""
+ },
+ "exclude-from-classmap": [
+ "/Tests/"
+ ]
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Fabien Potencier",
+ "email": "fabien@symfony.com"
+ },
+ {
+ "name": "Symfony Community",
+ "homepage": "https://symfony.com/contributors"
+ }
+ ],
+ "description": "Symfony Yaml Component",
+ "homepage": "https://symfony.com",
+ "support": {
+ "source": "https://github.com/symfony/yaml/tree/v3.4.47"
+ },
+ "funding": [
+ {
+ "url": "https://symfony.com/sponsor",
+ "type": "custom"
+ },
+ {
+ "url": "https://github.com/fabpot",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../symfony/yaml"
+ },
+ {
+ "name": "tijsverkoyen/css-to-inline-styles",
+ "version": "2.2.6",
+ "version_normalized": "2.2.6.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/tijsverkoyen/CssToInlineStyles.git",
+ "reference": "c42125b83a4fa63b187fdf29f9c93cb7733da30c"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/tijsverkoyen/CssToInlineStyles/zipball/c42125b83a4fa63b187fdf29f9c93cb7733da30c",
+ "reference": "c42125b83a4fa63b187fdf29f9c93cb7733da30c",
+ "shasum": ""
+ },
+ "require": {
+ "ext-dom": "*",
+ "ext-libxml": "*",
+ "php": "^5.5 || ^7.0 || ^8.0",
+ "symfony/css-selector": "^2.7 || ^3.0 || ^4.0 || ^5.0 || ^6.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^4.8.35 || ^5.7 || ^6.0 || ^7.5 || ^8.5.21 || ^9.5.10"
+ },
+ "time": "2023-01-03T09:29:04+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.2.x-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "TijsVerkoyen\\CssToInlineStyles\\": "src"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Tijs Verkoyen",
+ "email": "css_to_inline_styles@verkoyen.eu",
+ "role": "Developer"
+ }
+ ],
+ "description": "CssToInlineStyles is a class that enables you to convert HTML-pages/files into HTML-pages/files with inline styles. This is very useful when you're sending emails.",
+ "homepage": "https://github.com/tijsverkoyen/CssToInlineStyles",
+ "support": {
+ "issues": "https://github.com/tijsverkoyen/CssToInlineStyles/issues",
+ "source": "https://github.com/tijsverkoyen/CssToInlineStyles/tree/2.2.6"
+ },
+ "install-path": "../tijsverkoyen/css-to-inline-styles"
+ },
+ {
+ "name": "vlucas/phpdotenv",
+ "version": "v2.6.9",
+ "version_normalized": "2.6.9.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/vlucas/phpdotenv.git",
+ "reference": "2e93cc98e2e8e869f8d9cfa61bb3a99ba4fc4141"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/vlucas/phpdotenv/zipball/2e93cc98e2e8e869f8d9cfa61bb3a99ba4fc4141",
+ "reference": "2e93cc98e2e8e869f8d9cfa61bb3a99ba4fc4141",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.3.9 || ^7.0 || ^8.0",
+ "symfony/polyfill-ctype": "^1.17"
+ },
+ "require-dev": {
+ "ext-filter": "*",
+ "ext-pcre": "*",
+ "phpunit/phpunit": "^4.8.36 || ^5.7.27 || ^6.5.14 || ^7.5.20 || ^8.5.21"
+ },
+ "suggest": {
+ "ext-filter": "Required to use the boolean validator.",
+ "ext-pcre": "Required to use most of the library."
+ },
+ "time": "2021-12-12T22:59:22+00:00",
+ "type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.6-dev"
+ }
+ },
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Dotenv\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "BSD-3-Clause"
+ ],
+ "authors": [
+ {
+ "name": "Graham Campbell",
+ "email": "hello@gjcampbell.co.uk",
+ "homepage": "https://github.com/GrahamCampbell"
+ },
+ {
+ "name": "Vance Lucas",
+ "email": "vance@vancelucas.com",
+ "homepage": "https://github.com/vlucas"
+ }
+ ],
+ "description": "Loads environment variables from `.env` to `getenv()`, `$_ENV` and `$_SERVER` automagically.",
+ "keywords": [
+ "dotenv",
+ "env",
+ "environment"
+ ],
+ "support": {
+ "issues": "https://github.com/vlucas/phpdotenv/issues",
+ "source": "https://github.com/vlucas/phpdotenv/tree/v2.6.9"
+ },
+ "funding": [
+ {
+ "url": "https://github.com/GrahamCampbell",
+ "type": "github"
+ },
+ {
+ "url": "https://tidelift.com/funding/github/packagist/vlucas/phpdotenv",
+ "type": "tidelift"
+ }
+ ],
+ "install-path": "../vlucas/phpdotenv"
+ },
+ {
+ "name": "webmozart/assert",
+ "version": "1.9.1",
+ "version_normalized": "1.9.1.0",
+ "source": {
+ "type": "git",
+ "url": "https://github.com/webmozarts/assert.git",
+ "reference": "bafc69caeb4d49c39fd0779086c03a3738cbb389"
+ },
+ "dist": {
+ "type": "zip",
+ "url": "https://api.github.com/repos/webmozarts/assert/zipball/bafc69caeb4d49c39fd0779086c03a3738cbb389",
+ "reference": "bafc69caeb4d49c39fd0779086c03a3738cbb389",
+ "shasum": ""
+ },
+ "require": {
+ "php": "^5.3.3 || ^7.0 || ^8.0",
+ "symfony/polyfill-ctype": "^1.8"
+ },
+ "conflict": {
+ "phpstan/phpstan": "<0.12.20",
+ "vimeo/psalm": "<3.9.1"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^4.8.36 || ^7.5.13"
+ },
+ "time": "2020-07-08T17:02:28+00:00",
+ "type": "library",
+ "installation-source": "dist",
+ "autoload": {
+ "psr-4": {
+ "Webmozart\\Assert\\": "src/"
+ }
+ },
+ "notification-url": "https://packagist.org/downloads/",
+ "license": [
+ "MIT"
+ ],
+ "authors": [
+ {
+ "name": "Bernhard Schussek",
+ "email": "bschussek@gmail.com"
+ }
+ ],
+ "description": "Assertions to validate method input/output with nice error messages.",
+ "keywords": [
+ "assert",
+ "check",
+ "validate"
+ ],
+ "support": {
+ "issues": "https://github.com/webmozarts/assert/issues",
+ "source": "https://github.com/webmozarts/assert/tree/1.9.1"
+ },
+ "install-path": "../webmozart/assert"
+ }
+ ],
+ "dev": true,
+ "dev-package-names": [
+ "doctrine/instantiator",
+ "fzaninotto/faker",
+ "hamcrest/hamcrest-php",
+ "mockery/mockery",
+ "myclabs/deep-copy",
+ "phpdocumentor/reflection-common",
+ "phpdocumentor/reflection-docblock",
+ "phpdocumentor/type-resolver",
+ "phpspec/prophecy",
+ "phpunit/php-code-coverage",
+ "phpunit/php-file-iterator",
+ "phpunit/php-text-template",
+ "phpunit/php-timer",
+ "phpunit/php-token-stream",
+ "phpunit/phpunit",
+ "phpunit/phpunit-mock-objects",
+ "sebastian/code-unit-reverse-lookup",
+ "sebastian/comparator",
+ "sebastian/diff",
+ "sebastian/environment",
+ "sebastian/exporter",
+ "sebastian/global-state",
+ "sebastian/object-enumerator",
+ "sebastian/recursion-context",
+ "sebastian/resource-operations",
+ "sebastian/version",
+ "symfony/yaml",
+ "webmozart/assert"
+ ]
+}
diff --git a/vendor/composer/installed.php b/vendor/composer/installed.php
new file mode 100644
index 000000000..7e922eccc
--- /dev/null
+++ b/vendor/composer/installed.php
@@ -0,0 +1,846 @@
+
+ array (
+ 'pretty_version' => 'v5.4.30',
+ 'version' => '5.4.30.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => NULL,
+ 'name' => 'laravel/laravel',
+ ),
+ 'versions' =>
+ array (
+ 'cordoval/hamcrest-php' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => '*',
+ ),
+ ),
+ 'davedevelopment/hamcrest-php' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => '*',
+ ),
+ ),
+ 'dnoegel/php-xdg-base-dir' =>
+ array (
+ 'pretty_version' => 'v0.1.1',
+ 'version' => '0.1.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '8f8a6e48c5ecb0f991c2fdcf5f154a47d85f9ffd',
+ ),
+ 'doctrine/inflector' =>
+ array (
+ 'pretty_version' => 'v1.1.0',
+ 'version' => '1.1.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '90b2128806bfde671b6952ab8bea493942c1fdae',
+ ),
+ 'doctrine/instantiator' =>
+ array (
+ 'pretty_version' => '1.0.5',
+ 'version' => '1.0.5.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '8e884e78f9f0eb1329e445619e04456e64d8051d',
+ ),
+ 'erusev/parsedown' =>
+ array (
+ 'pretty_version' => '1.7.4',
+ 'version' => '1.7.4.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'cb17b6477dfff935958ba01325f2e8a2bfa6dab3',
+ ),
+ 'fzaninotto/faker' =>
+ array (
+ 'pretty_version' => 'v1.9.2',
+ 'version' => '1.9.2.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '848d8125239d7dbf8ab25cb7f054f1a630e68c2e',
+ ),
+ 'hamcrest/hamcrest-php' =>
+ array (
+ 'pretty_version' => 'v1.2.2',
+ 'version' => '1.2.2.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b37020aa976fa52d3de9aa904aa2522dc518f79c',
+ ),
+ 'illuminate/auth' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/broadcasting' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/bus' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/cache' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/config' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/console' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/container' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/contracts' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/cookie' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/database' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/encryption' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/events' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/exception' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/filesystem' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/hashing' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/http' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/log' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/mail' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/notifications' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/pagination' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/pipeline' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/queue' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/redis' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/routing' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/session' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/support' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/translation' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/validation' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'illuminate/view' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'jakub-onderka/php-console-color' =>
+ array (
+ 'pretty_version' => 'v0.2',
+ 'version' => '0.2.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'd5deaecff52a0d61ccb613bb3804088da0307191',
+ ),
+ 'jakub-onderka/php-console-highlighter' =>
+ array (
+ 'pretty_version' => 'v0.4',
+ 'version' => '0.4.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '9f7a229a69d52506914b4bc61bfdb199d90c5547',
+ ),
+ 'kodova/hamcrest-php' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => '*',
+ ),
+ ),
+ 'kylekatarnls/update-helper' =>
+ array (
+ 'pretty_version' => '1.2.1',
+ 'version' => '1.2.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '429be50660ed8a196e0798e5939760f168ec8ce9',
+ ),
+ 'laravel/framework' =>
+ array (
+ 'pretty_version' => 'v5.4.36',
+ 'version' => '5.4.36.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '1062a22232071c3e8636487c86ec1ae75681bbf9',
+ ),
+ 'laravel/laravel' =>
+ array (
+ 'pretty_version' => 'v5.4.30',
+ 'version' => '5.4.30.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => NULL,
+ ),
+ 'laravel/tinker' =>
+ array (
+ 'pretty_version' => 'v1.0.10',
+ 'version' => '1.0.10.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ad571aacbac1539c30d480908f9d0c9614eaf1a7',
+ ),
+ 'league/flysystem' =>
+ array (
+ 'pretty_version' => '1.0.70',
+ 'version' => '1.0.70.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '585824702f534f8d3cf7fab7225e8466cc4b7493',
+ ),
+ 'mockery/mockery' =>
+ array (
+ 'pretty_version' => '0.9.11',
+ 'version' => '0.9.11.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'be9bf28d8e57d67883cba9fcadfcff8caab667f8',
+ ),
+ 'monolog/monolog' =>
+ array (
+ 'pretty_version' => '1.27.1',
+ 'version' => '1.27.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '904713c5929655dc9b97288b69cfeedad610c9a1',
+ ),
+ 'mtdowling/cron-expression' =>
+ array (
+ 'pretty_version' => 'v1.2.3',
+ 'version' => '1.2.3.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '9be552eebcc1ceec9776378f7dcc085246cacca6',
+ ),
+ 'myclabs/deep-copy' =>
+ array (
+ 'pretty_version' => '1.7.0',
+ 'version' => '1.7.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '3b8a3a99ba1f6a3952ac2747d989303cbd6b7a3e',
+ ),
+ 'nesbot/carbon' =>
+ array (
+ 'pretty_version' => '1.39.1',
+ 'version' => '1.39.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '4be0c005164249208ce1b5ca633cd57bdd42ff33',
+ ),
+ 'nikic/php-parser' =>
+ array (
+ 'pretty_version' => 'v3.1.5',
+ 'version' => '3.1.5.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'bb87e28e7d7b8d9a7fda231d37457c9210faf6ce',
+ ),
+ 'paragonie/random_compat' =>
+ array (
+ 'pretty_version' => 'v2.0.21',
+ 'version' => '2.0.21.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '96c132c7f2f7bc3230723b66e89f8f150b29d5ae',
+ ),
+ 'phpdocumentor/reflection-common' =>
+ array (
+ 'pretty_version' => '1.0.1',
+ 'version' => '1.0.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '21bdeb5f65d7ebf9f43b1b25d404f87deab5bfb6',
+ ),
+ 'phpdocumentor/reflection-docblock' =>
+ array (
+ 'pretty_version' => '3.3.2',
+ 'version' => '3.3.2.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'bf329f6c1aadea3299f08ee804682b7c45b326a2',
+ ),
+ 'phpdocumentor/type-resolver' =>
+ array (
+ 'pretty_version' => '0.4.0',
+ 'version' => '0.4.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '9c977708995954784726e25d0cd1dddf4e65b0f7',
+ ),
+ 'phpspec/prophecy' =>
+ array (
+ 'pretty_version' => 'v1.10.3',
+ 'version' => '1.10.3.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '451c3cd1418cf640de218914901e51b064abb093',
+ ),
+ 'phpunit/php-code-coverage' =>
+ array (
+ 'pretty_version' => '4.0.8',
+ 'version' => '4.0.8.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ef7b2f56815df854e66ceaee8ebe9393ae36a40d',
+ ),
+ 'phpunit/php-file-iterator' =>
+ array (
+ 'pretty_version' => '1.4.5',
+ 'version' => '1.4.5.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '730b01bc3e867237eaac355e06a36b85dd93a8b4',
+ ),
+ 'phpunit/php-text-template' =>
+ array (
+ 'pretty_version' => '1.2.1',
+ 'version' => '1.2.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '31f8b717e51d9a2afca6c9f046f5d69fc27c8686',
+ ),
+ 'phpunit/php-timer' =>
+ array (
+ 'pretty_version' => '1.0.9',
+ 'version' => '1.0.9.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '3dcf38ca72b158baf0bc245e9184d3fdffa9c46f',
+ ),
+ 'phpunit/php-token-stream' =>
+ array (
+ 'pretty_version' => '1.4.12',
+ 'version' => '1.4.12.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '1ce90ba27c42e4e44e6d8458241466380b51fa16',
+ ),
+ 'phpunit/phpunit' =>
+ array (
+ 'pretty_version' => '5.7.27',
+ 'version' => '5.7.27.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b7803aeca3ccb99ad0a506fa80b64cd6a56bbc0c',
+ ),
+ 'phpunit/phpunit-mock-objects' =>
+ array (
+ 'pretty_version' => '3.4.4',
+ 'version' => '3.4.4.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'a23b761686d50a560cc56233b9ecf49597cc9118',
+ ),
+ 'psr/log' =>
+ array (
+ 'pretty_version' => '1.1.4',
+ 'version' => '1.1.4.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'd49695b909c3b7628b6289db5479a1c204601f11',
+ ),
+ 'psr/log-implementation' =>
+ array (
+ 'provided' =>
+ array (
+ 0 => '1.0',
+ 1 => '1.0.0',
+ ),
+ ),
+ 'psy/psysh' =>
+ array (
+ 'pretty_version' => 'v0.9.12',
+ 'version' => '0.9.12.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '90da7f37568aee36b116a030c5f99c915267edd4',
+ ),
+ 'ramsey/uuid' =>
+ array (
+ 'pretty_version' => '3.9.7',
+ 'version' => '3.9.7.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'dc75aa439eb4c1b77f5379fd958b3dc0e6014178',
+ ),
+ 'rhumsaa/uuid' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => '3.9.7',
+ ),
+ ),
+ 'sebastian/code-unit-reverse-lookup' =>
+ array (
+ 'pretty_version' => '1.0.2',
+ 'version' => '1.0.2.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '1de8cd5c010cb153fcd68b8d0f64606f523f7619',
+ ),
+ 'sebastian/comparator' =>
+ array (
+ 'pretty_version' => '1.2.4',
+ 'version' => '1.2.4.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '2b7424b55f5047b47ac6e5ccb20b2aea4011d9be',
+ ),
+ 'sebastian/diff' =>
+ array (
+ 'pretty_version' => '1.4.3',
+ 'version' => '1.4.3.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '7f066a26a962dbe58ddea9f72a4e82874a3975a4',
+ ),
+ 'sebastian/environment' =>
+ array (
+ 'pretty_version' => '2.0.0',
+ 'version' => '2.0.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '5795ffe5dc5b02460c3e34222fee8cbe245d8fac',
+ ),
+ 'sebastian/exporter' =>
+ array (
+ 'pretty_version' => '2.0.0',
+ 'version' => '2.0.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ce474bdd1a34744d7ac5d6aad3a46d48d9bac4c4',
+ ),
+ 'sebastian/global-state' =>
+ array (
+ 'pretty_version' => '1.1.1',
+ 'version' => '1.1.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'bc37d50fea7d017d3d340f230811c9f1d7280af4',
+ ),
+ 'sebastian/object-enumerator' =>
+ array (
+ 'pretty_version' => '2.0.1',
+ 'version' => '2.0.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '1311872ac850040a79c3c058bea3e22d0f09cbb7',
+ ),
+ 'sebastian/recursion-context' =>
+ array (
+ 'pretty_version' => '2.0.0',
+ 'version' => '2.0.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '2c3ba150cbec723aa057506e73a8d33bdb286c9a',
+ ),
+ 'sebastian/resource-operations' =>
+ array (
+ 'pretty_version' => '1.0.0',
+ 'version' => '1.0.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ce990bb21759f94aeafd30209e8cfcdfa8bc3f52',
+ ),
+ 'sebastian/version' =>
+ array (
+ 'pretty_version' => '2.0.1',
+ 'version' => '2.0.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '99732be0ddb3361e16ad77b68ba41efc8e979019',
+ ),
+ 'swiftmailer/swiftmailer' =>
+ array (
+ 'pretty_version' => 'v5.4.12',
+ 'version' => '5.4.12.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '181b89f18a90f8925ef805f950d47a7190e9b950',
+ ),
+ 'symfony/console' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'a10b1da6fc93080c180bba7219b5ff5b7518fe81',
+ ),
+ 'symfony/css-selector' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'da3d9da2ce0026771f5fe64cb332158f1bd2bc33',
+ ),
+ 'symfony/debug' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ab42889de57fdfcfcc0759ab102e2fd4ea72dcae',
+ ),
+ 'symfony/event-dispatcher' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '31fde73757b6bad247c54597beef974919ec6860',
+ ),
+ 'symfony/finder' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b6b6ad3db3edb1b4b1c1896b1975fb684994de6e',
+ ),
+ 'symfony/http-foundation' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b9885fcce6fe494201da4f70a9309770e9d13dc8',
+ ),
+ 'symfony/http-kernel' =>
+ array (
+ 'pretty_version' => 'v3.4.49',
+ 'version' => '3.4.49.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '5aa72405f5bd5583c36ed6e756acb17d3f98ac40',
+ ),
+ 'symfony/polyfill-ctype' =>
+ array (
+ 'pretty_version' => 'v1.19.0',
+ 'version' => '1.19.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'aed596913b70fae57be53d86faa2e9ef85a2297b',
+ ),
+ 'symfony/polyfill-mbstring' =>
+ array (
+ 'pretty_version' => 'v1.19.0',
+ 'version' => '1.19.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b5f7b932ee6fa802fc792eabd77c4c88084517ce',
+ ),
+ 'symfony/polyfill-php56' =>
+ array (
+ 'pretty_version' => 'v1.19.0',
+ 'version' => '1.19.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'ea19621731cbd973a6702cfedef3419768bf3372',
+ ),
+ 'symfony/polyfill-php70' =>
+ array (
+ 'pretty_version' => 'v1.19.0',
+ 'version' => '1.19.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '3fe414077251a81a1b15b1c709faf5c2fbae3d4e',
+ ),
+ 'symfony/polyfill-util' =>
+ array (
+ 'pretty_version' => 'v1.19.0',
+ 'version' => '1.19.0.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '8df0c3e6a4b85df9a5c6f3f2f46fba5c5c47058a',
+ ),
+ 'symfony/process' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'b8648cf1d5af12a44a51d07ef9bf980921f15fca',
+ ),
+ 'symfony/routing' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '3e522ac69cadffd8131cc2b22157fa7662331a6c',
+ ),
+ 'symfony/translation' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'be83ee6c065cb32becdb306ba61160d598b1ce88',
+ ),
+ 'symfony/var-dumper' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '0719f6cf4633a38b2c1585140998579ce23b4b7d',
+ ),
+ 'symfony/yaml' =>
+ array (
+ 'pretty_version' => 'v3.4.47',
+ 'version' => '3.4.47.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '88289caa3c166321883f67fe5130188ebbb47094',
+ ),
+ 'tightenco/collect' =>
+ array (
+ 'replaced' =>
+ array (
+ 0 => 'v5.4.36',
+ ),
+ ),
+ 'tijsverkoyen/css-to-inline-styles' =>
+ array (
+ 'pretty_version' => '2.2.6',
+ 'version' => '2.2.6.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'c42125b83a4fa63b187fdf29f9c93cb7733da30c',
+ ),
+ 'vlucas/phpdotenv' =>
+ array (
+ 'pretty_version' => 'v2.6.9',
+ 'version' => '2.6.9.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => '2e93cc98e2e8e869f8d9cfa61bb3a99ba4fc4141',
+ ),
+ 'webmozart/assert' =>
+ array (
+ 'pretty_version' => '1.9.1',
+ 'version' => '1.9.1.0',
+ 'aliases' =>
+ array (
+ ),
+ 'reference' => 'bafc69caeb4d49c39fd0779086c03a3738cbb389',
+ ),
+ ),
+);
diff --git a/vendor/composer/platform_check.php b/vendor/composer/platform_check.php
new file mode 100644
index 000000000..d5929a5af
--- /dev/null
+++ b/vendor/composer/platform_check.php
@@ -0,0 +1,26 @@
+= 50604)) {
+ $issues[] = 'Your Composer dependencies require a PHP version ">= 5.6.4". You are running ' . PHP_VERSION . '.';
+}
+
+if ($issues) {
+ if (!headers_sent()) {
+ header('HTTP/1.1 500 Internal Server Error');
+ }
+ if (!ini_get('display_errors')) {
+ if (PHP_SAPI === 'cli' || PHP_SAPI === 'phpdbg') {
+ fwrite(STDERR, 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . implode(PHP_EOL, $issues) . PHP_EOL.PHP_EOL);
+ } elseif (!headers_sent()) {
+ echo 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . str_replace('You are running '.PHP_VERSION.'.', '', implode(PHP_EOL, $issues)) . PHP_EOL.PHP_EOL;
+ }
+ }
+ trigger_error(
+ 'Composer detected issues in your platform: ' . implode(' ', $issues),
+ E_USER_ERROR
+ );
+}
diff --git a/vendor/dnoegel/php-xdg-base-dir/LICENSE b/vendor/dnoegel/php-xdg-base-dir/LICENSE
new file mode 100644
index 000000000..029a00ab5
--- /dev/null
+++ b/vendor/dnoegel/php-xdg-base-dir/LICENSE
@@ -0,0 +1,19 @@
+Copyright (c) 2014 Daniel Nögel
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
diff --git a/vendor/dnoegel/php-xdg-base-dir/README.md b/vendor/dnoegel/php-xdg-base-dir/README.md
new file mode 100644
index 000000000..ee06b2d64
--- /dev/null
+++ b/vendor/dnoegel/php-xdg-base-dir/README.md
@@ -0,0 +1,41 @@
+# XDG Base Directory
+
+[](https://packagist.org/packages/dnoegel/php-xdg-base-dir)
+[](https://packagist.org/packages/dnoegel/php-xdg-base-dir)
+[](LICENSE.md)
+[](https://travis-ci.org/dnoegel/php-xdg-base-dir)
+
+Implementation of XDG Base Directory specification for php
+
+## Install
+
+Via Composer
+
+``` bash
+$ composer require dnoegel/php-xdg-base-dir
+```
+
+## Usage
+
+``` php
+$xdg = new \XdgBaseDir\Xdg();
+
+echo $xdg->getHomeDir();
+echo $xdg->getHomeConfigDir();
+echo $xdg->getHomeDataDir();
+echo $xdg->getHomeCacheDir();
+echo $xdg->getRuntimeDir();
+
+print_r($xdg->getDataDirs()); // returns array
+print_r($xdg->getConfigDirs()); // returns array
+```
+
+## Testing
+
+``` bash
+$ phpunit
+```
+
+## License
+
+The MIT License (MIT). Please see [License File](https://github.com/dnoegel/php-xdg-base-dir/blob/master/LICENSE) for more information.
diff --git a/vendor/dnoegel/php-xdg-base-dir/composer.json b/vendor/dnoegel/php-xdg-base-dir/composer.json
new file mode 100644
index 000000000..94c463745
--- /dev/null
+++ b/vendor/dnoegel/php-xdg-base-dir/composer.json
@@ -0,0 +1,17 @@
+{
+ "name": "dnoegel/php-xdg-base-dir",
+ "description": "implementation of xdg base directory specification for php",
+ "type": "library",
+ "license": "MIT",
+ "require": {
+ "php": ">=5.3.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~7.0|~6.0|~5.0|~4.8.35"
+ },
+ "autoload": {
+ "psr-4": {
+ "XdgBaseDir\\": "src/"
+ }
+ }
+}
diff --git a/vendor/dnoegel/php-xdg-base-dir/src/Xdg.php b/vendor/dnoegel/php-xdg-base-dir/src/Xdg.php
new file mode 100644
index 000000000..2dd314d0b
--- /dev/null
+++ b/vendor/dnoegel/php-xdg-base-dir/src/Xdg.php
@@ -0,0 +1,132 @@
+getHomeDir();
+
+ $path = DIRECTORY_SEPARATOR === $homeDir ? $homeDir.'.config' : $homeDir . DIRECTORY_SEPARATOR . '.config';
+
+ return $path;
+ }
+
+ /**
+ * @return string
+ */
+ public function getHomeDataDir()
+ {
+ $path = getenv('XDG_DATA_HOME') ?: $this->getHomeDir() . DIRECTORY_SEPARATOR . '.local' . DIRECTORY_SEPARATOR . 'share';
+
+ return $path;
+ }
+
+ /**
+ * @return array
+ */
+ public function getConfigDirs()
+ {
+ $configDirs = getenv('XDG_CONFIG_DIRS') ? explode(':', getenv('XDG_CONFIG_DIRS')) : array('/etc/xdg');
+
+ $paths = array_merge(array($this->getHomeConfigDir()), $configDirs);
+
+ return $paths;
+ }
+
+ /**
+ * @return array
+ */
+ public function getDataDirs()
+ {
+ $dataDirs = getenv('XDG_DATA_DIRS') ? explode(':', getenv('XDG_DATA_DIRS')) : array('/usr/local/share', '/usr/share');
+
+ $paths = array_merge(array($this->getHomeDataDir()), $dataDirs);
+
+ return $paths;
+ }
+
+ /**
+ * @return string
+ */
+ public function getHomeCacheDir()
+ {
+ $path = getenv('XDG_CACHE_HOME') ?: $this->getHomeDir() . DIRECTORY_SEPARATOR . '.cache';
+
+ return $path;
+
+ }
+
+ public function getRuntimeDir($strict=true)
+ {
+ if ($runtimeDir = getenv('XDG_RUNTIME_DIR')) {
+ return $runtimeDir;
+ }
+
+ if ($strict) {
+ throw new \RuntimeException('XDG_RUNTIME_DIR was not set');
+ }
+
+ $fallback = sys_get_temp_dir() . DIRECTORY_SEPARATOR . self::RUNTIME_DIR_FALLBACK . getenv('USER');
+
+ $create = false;
+
+ if (!is_dir($fallback)) {
+ mkdir($fallback, 0700, true);
+ }
+
+ $st = lstat($fallback);
+
+ # The fallback must be a directory
+ if (!$st['mode'] & self::S_IFDIR) {
+ rmdir($fallback);
+ $create = true;
+ } elseif ($st['uid'] != $this->getUid() ||
+ $st['mode'] & (self::S_IRWXG | self::S_IRWXO)
+ ) {
+ rmdir($fallback);
+ $create = true;
+ }
+
+ if ($create) {
+ mkdir($fallback, 0700, true);
+ }
+
+ return $fallback;
+ }
+
+ private function getUid()
+ {
+ if (function_exists('posix_getuid')) {
+ return posix_getuid();
+ }
+
+ return getmyuid();
+ }
+}
diff --git a/vendor/doctrine/inflector/.gitignore b/vendor/doctrine/inflector/.gitignore
new file mode 100644
index 000000000..f2cb7f83e
--- /dev/null
+++ b/vendor/doctrine/inflector/.gitignore
@@ -0,0 +1,4 @@
+vendor/
+composer.lock
+composer.phar
+phpunit.xml
diff --git a/vendor/doctrine/inflector/.travis.yml b/vendor/doctrine/inflector/.travis.yml
new file mode 100644
index 000000000..9ec68f765
--- /dev/null
+++ b/vendor/doctrine/inflector/.travis.yml
@@ -0,0 +1,21 @@
+language: php
+
+sudo: false
+
+cache:
+ directory:
+ - $HOME/.composer/cache
+
+php:
+ - 5.3
+ - 5.4
+ - 5.5
+ - 5.6
+ - 7.0
+ - hhvm
+
+install:
+ - composer install -n
+
+script:
+ - phpunit
diff --git a/vendor/doctrine/inflector/LICENSE b/vendor/doctrine/inflector/LICENSE
new file mode 100644
index 000000000..8c38cc1bc
--- /dev/null
+++ b/vendor/doctrine/inflector/LICENSE
@@ -0,0 +1,19 @@
+Copyright (c) 2006-2015 Doctrine Project
+
+Permission is hereby granted, free of charge, to any person obtaining a copy of
+this software and associated documentation files (the "Software"), to deal in
+the Software without restriction, including without limitation the rights to
+use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
+of the Software, and to permit persons to whom the Software is furnished to do
+so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
diff --git a/vendor/doctrine/inflector/README.md b/vendor/doctrine/inflector/README.md
new file mode 100644
index 000000000..acb55a014
--- /dev/null
+++ b/vendor/doctrine/inflector/README.md
@@ -0,0 +1,6 @@
+# Doctrine Inflector
+
+Doctrine Inflector is a small library that can perform string manipulations
+with regard to upper-/lowercase and singular/plural forms of words.
+
+[](https://travis-ci.org/doctrine/inflector)
diff --git a/vendor/doctrine/inflector/composer.json b/vendor/doctrine/inflector/composer.json
new file mode 100644
index 000000000..7e5b2efbf
--- /dev/null
+++ b/vendor/doctrine/inflector/composer.json
@@ -0,0 +1,29 @@
+{
+ "name": "doctrine/inflector",
+ "type": "library",
+ "description": "Common String Manipulations with regard to casing and singular/plural rules.",
+ "keywords": ["string", "inflection", "singularize", "pluralize"],
+ "homepage": "http://www.doctrine-project.org",
+ "license": "MIT",
+ "authors": [
+ {"name": "Guilherme Blanco", "email": "guilhermeblanco@gmail.com"},
+ {"name": "Roman Borschel", "email": "roman@code-factory.org"},
+ {"name": "Benjamin Eberlei", "email": "kontakt@beberlei.de"},
+ {"name": "Jonathan Wage", "email": "jonwage@gmail.com"},
+ {"name": "Johannes Schmitt", "email": "schmittjoh@gmail.com"}
+ ],
+ "require": {
+ "php": ">=5.3.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "4.*"
+ },
+ "autoload": {
+ "psr-0": { "Doctrine\\Common\\Inflector\\": "lib/" }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.1.x-dev"
+ }
+ }
+}
diff --git a/vendor/doctrine/inflector/lib/Doctrine/Common/Inflector/Inflector.php b/vendor/doctrine/inflector/lib/Doctrine/Common/Inflector/Inflector.php
new file mode 100644
index 000000000..a53828aba
--- /dev/null
+++ b/vendor/doctrine/inflector/lib/Doctrine/Common/Inflector/Inflector.php
@@ -0,0 +1,482 @@
+.
+ */
+
+namespace Doctrine\Common\Inflector;
+
+/**
+ * Doctrine inflector has static methods for inflecting text.
+ *
+ * The methods in these classes are from several different sources collected
+ * across several different php projects and several different authors. The
+ * original author names and emails are not known.
+ *
+ * Pluralize & Singularize implementation are borrowed from CakePHP with some modifications.
+ *
+ * @link www.doctrine-project.org
+ * @since 1.0
+ * @author Konsta Vesterinen
+ * @author Jonathan H. Wage
+ */
+class Inflector
+{
+ /**
+ * Plural inflector rules.
+ *
+ * @var array
+ */
+ private static $plural = array(
+ 'rules' => array(
+ '/(s)tatus$/i' => '\1\2tatuses',
+ '/(quiz)$/i' => '\1zes',
+ '/^(ox)$/i' => '\1\2en',
+ '/([m|l])ouse$/i' => '\1ice',
+ '/(matr|vert|ind)(ix|ex)$/i' => '\1ices',
+ '/(x|ch|ss|sh)$/i' => '\1es',
+ '/([^aeiouy]|qu)y$/i' => '\1ies',
+ '/(hive)$/i' => '\1s',
+ '/(?:([^f])fe|([lr])f)$/i' => '\1\2ves',
+ '/sis$/i' => 'ses',
+ '/([ti])um$/i' => '\1a',
+ '/(p)erson$/i' => '\1eople',
+ '/(m)an$/i' => '\1en',
+ '/(c)hild$/i' => '\1hildren',
+ '/(f)oot$/i' => '\1eet',
+ '/(buffal|her|potat|tomat|volcan)o$/i' => '\1\2oes',
+ '/(alumn|bacill|cact|foc|fung|nucle|radi|stimul|syllab|termin|vir)us$/i' => '\1i',
+ '/us$/i' => 'uses',
+ '/(alias)$/i' => '\1es',
+ '/(analys|ax|cris|test|thes)is$/i' => '\1es',
+ '/s$/' => 's',
+ '/^$/' => '',
+ '/$/' => 's',
+ ),
+ 'uninflected' => array(
+ '.*[nrlm]ese', '.*deer', '.*fish', '.*measles', '.*ois', '.*pox', '.*sheep', 'people', 'cookie'
+ ),
+ 'irregular' => array(
+ 'atlas' => 'atlases',
+ 'axe' => 'axes',
+ 'beef' => 'beefs',
+ 'brother' => 'brothers',
+ 'cafe' => 'cafes',
+ 'chateau' => 'chateaux',
+ 'child' => 'children',
+ 'cookie' => 'cookies',
+ 'corpus' => 'corpuses',
+ 'cow' => 'cows',
+ 'criterion' => 'criteria',
+ 'curriculum' => 'curricula',
+ 'demo' => 'demos',
+ 'domino' => 'dominoes',
+ 'echo' => 'echoes',
+ 'foot' => 'feet',
+ 'fungus' => 'fungi',
+ 'ganglion' => 'ganglions',
+ 'genie' => 'genies',
+ 'genus' => 'genera',
+ 'graffito' => 'graffiti',
+ 'hippopotamus' => 'hippopotami',
+ 'hoof' => 'hoofs',
+ 'human' => 'humans',
+ 'iris' => 'irises',
+ 'leaf' => 'leaves',
+ 'loaf' => 'loaves',
+ 'man' => 'men',
+ 'medium' => 'media',
+ 'memorandum' => 'memoranda',
+ 'money' => 'monies',
+ 'mongoose' => 'mongooses',
+ 'motto' => 'mottoes',
+ 'move' => 'moves',
+ 'mythos' => 'mythoi',
+ 'niche' => 'niches',
+ 'nucleus' => 'nuclei',
+ 'numen' => 'numina',
+ 'occiput' => 'occiputs',
+ 'octopus' => 'octopuses',
+ 'opus' => 'opuses',
+ 'ox' => 'oxen',
+ 'penis' => 'penises',
+ 'person' => 'people',
+ 'plateau' => 'plateaux',
+ 'runner-up' => 'runners-up',
+ 'sex' => 'sexes',
+ 'soliloquy' => 'soliloquies',
+ 'son-in-law' => 'sons-in-law',
+ 'syllabus' => 'syllabi',
+ 'testis' => 'testes',
+ 'thief' => 'thieves',
+ 'tooth' => 'teeth',
+ 'tornado' => 'tornadoes',
+ 'trilby' => 'trilbys',
+ 'turf' => 'turfs',
+ 'volcano' => 'volcanoes',
+ )
+ );
+
+ /**
+ * Singular inflector rules.
+ *
+ * @var array
+ */
+ private static $singular = array(
+ 'rules' => array(
+ '/(s)tatuses$/i' => '\1\2tatus',
+ '/^(.*)(menu)s$/i' => '\1\2',
+ '/(quiz)zes$/i' => '\\1',
+ '/(matr)ices$/i' => '\1ix',
+ '/(vert|ind)ices$/i' => '\1ex',
+ '/^(ox)en/i' => '\1',
+ '/(alias)(es)*$/i' => '\1',
+ '/(buffal|her|potat|tomat|volcan)oes$/i' => '\1o',
+ '/(alumn|bacill|cact|foc|fung|nucle|radi|stimul|syllab|termin|viri?)i$/i' => '\1us',
+ '/([ftw]ax)es/i' => '\1',
+ '/(analys|ax|cris|test|thes)es$/i' => '\1is',
+ '/(shoe|slave)s$/i' => '\1',
+ '/(o)es$/i' => '\1',
+ '/ouses$/' => 'ouse',
+ '/([^a])uses$/' => '\1us',
+ '/([m|l])ice$/i' => '\1ouse',
+ '/(x|ch|ss|sh)es$/i' => '\1',
+ '/(m)ovies$/i' => '\1\2ovie',
+ '/(s)eries$/i' => '\1\2eries',
+ '/([^aeiouy]|qu)ies$/i' => '\1y',
+ '/([lr])ves$/i' => '\1f',
+ '/(tive)s$/i' => '\1',
+ '/(hive)s$/i' => '\1',
+ '/(drive)s$/i' => '\1',
+ '/([^fo])ves$/i' => '\1fe',
+ '/(^analy)ses$/i' => '\1sis',
+ '/(analy|diagno|^ba|(p)arenthe|(p)rogno|(s)ynop|(t)he)ses$/i' => '\1\2sis',
+ '/([ti])a$/i' => '\1um',
+ '/(p)eople$/i' => '\1\2erson',
+ '/(m)en$/i' => '\1an',
+ '/(c)hildren$/i' => '\1\2hild',
+ '/(f)eet$/i' => '\1oot',
+ '/(n)ews$/i' => '\1\2ews',
+ '/eaus$/' => 'eau',
+ '/^(.*us)$/' => '\\1',
+ '/s$/i' => '',
+ ),
+ 'uninflected' => array(
+ '.*[nrlm]ese',
+ '.*deer',
+ '.*fish',
+ '.*measles',
+ '.*ois',
+ '.*pox',
+ '.*sheep',
+ '.*ss',
+ ),
+ 'irregular' => array(
+ 'criteria' => 'criterion',
+ 'curves' => 'curve',
+ 'emphases' => 'emphasis',
+ 'foes' => 'foe',
+ 'hoaxes' => 'hoax',
+ 'media' => 'medium',
+ 'neuroses' => 'neurosis',
+ 'waves' => 'wave',
+ 'oases' => 'oasis',
+ )
+ );
+
+ /**
+ * Words that should not be inflected.
+ *
+ * @var array
+ */
+ private static $uninflected = array(
+ 'Amoyese', 'bison', 'Borghese', 'bream', 'breeches', 'britches', 'buffalo', 'cantus',
+ 'carp', 'chassis', 'clippers', 'cod', 'coitus', 'Congoese', 'contretemps', 'corps',
+ 'debris', 'diabetes', 'djinn', 'eland', 'elk', 'equipment', 'Faroese', 'flounder',
+ 'Foochowese', 'gallows', 'Genevese', 'Genoese', 'Gilbertese', 'graffiti',
+ 'headquarters', 'herpes', 'hijinks', 'Hottentotese', 'information', 'innings',
+ 'jackanapes', 'Kiplingese', 'Kongoese', 'Lucchese', 'mackerel', 'Maltese', '.*?media',
+ 'mews', 'moose', 'mumps', 'Nankingese', 'news', 'nexus', 'Niasese',
+ 'Pekingese', 'Piedmontese', 'pincers', 'Pistoiese', 'pliers', 'Portuguese',
+ 'proceedings', 'rabies', 'rice', 'rhinoceros', 'salmon', 'Sarawakese', 'scissors',
+ 'sea[- ]bass', 'series', 'Shavese', 'shears', 'siemens', 'species', 'staff', 'swine',
+ 'testes', 'trousers', 'trout', 'tuna', 'Vermontese', 'Wenchowese', 'whiting',
+ 'wildebeest', 'Yengeese'
+ );
+
+ /**
+ * Method cache array.
+ *
+ * @var array
+ */
+ private static $cache = array();
+
+ /**
+ * The initial state of Inflector so reset() works.
+ *
+ * @var array
+ */
+ private static $initialState = array();
+
+ /**
+ * Converts a word into the format for a Doctrine table name. Converts 'ModelName' to 'model_name'.
+ *
+ * @param string $word The word to tableize.
+ *
+ * @return string The tableized word.
+ */
+ public static function tableize($word)
+ {
+ return strtolower(preg_replace('~(?<=\\w)([A-Z])~', '_$1', $word));
+ }
+
+ /**
+ * Converts a word into the format for a Doctrine class name. Converts 'table_name' to 'TableName'.
+ *
+ * @param string $word The word to classify.
+ *
+ * @return string The classified word.
+ */
+ public static function classify($word)
+ {
+ return str_replace(" ", "", ucwords(strtr($word, "_-", " ")));
+ }
+
+ /**
+ * Camelizes a word. This uses the classify() method and turns the first character to lowercase.
+ *
+ * @param string $word The word to camelize.
+ *
+ * @return string The camelized word.
+ */
+ public static function camelize($word)
+ {
+ return lcfirst(self::classify($word));
+ }
+
+ /**
+ * Uppercases words with configurable delimeters between words.
+ *
+ * Takes a string and capitalizes all of the words, like PHP's built-in
+ * ucwords function. This extends that behavior, however, by allowing the
+ * word delimeters to be configured, rather than only separating on
+ * whitespace.
+ *
+ * Here is an example:
+ *
+ *
+ *
+ *
+ * @param string $string The string to operate on.
+ * @param string $delimiters A list of word separators.
+ *
+ * @return string The string with all delimeter-separated words capitalized.
+ */
+ public static function ucwords($string, $delimiters = " \n\t\r\0\x0B-")
+ {
+ return preg_replace_callback(
+ '/[^' . preg_quote($delimiters, '/') . ']+/',
+ function($matches) {
+ return ucfirst($matches[0]);
+ },
+ $string
+ );
+ }
+
+ /**
+ * Clears Inflectors inflected value caches, and resets the inflection
+ * rules to the initial values.
+ *
+ * @return void
+ */
+ public static function reset()
+ {
+ if (empty(self::$initialState)) {
+ self::$initialState = get_class_vars('Inflector');
+
+ return;
+ }
+
+ foreach (self::$initialState as $key => $val) {
+ if ($key != 'initialState') {
+ self::${$key} = $val;
+ }
+ }
+ }
+
+ /**
+ * Adds custom inflection $rules, of either 'plural' or 'singular' $type.
+ *
+ * ### Usage:
+ *
+ * {{{
+ * Inflector::rules('plural', array('/^(inflect)or$/i' => '\1ables'));
+ * Inflector::rules('plural', array(
+ * 'rules' => array('/^(inflect)ors$/i' => '\1ables'),
+ * 'uninflected' => array('dontinflectme'),
+ * 'irregular' => array('red' => 'redlings')
+ * ));
+ * }}}
+ *
+ * @param string $type The type of inflection, either 'plural' or 'singular'
+ * @param array $rules An array of rules to be added.
+ * @param boolean $reset If true, will unset default inflections for all
+ * new rules that are being defined in $rules.
+ *
+ * @return void
+ */
+ public static function rules($type, $rules, $reset = false)
+ {
+ foreach ($rules as $rule => $pattern) {
+ if ( ! is_array($pattern)) {
+ continue;
+ }
+
+ if ($reset) {
+ self::${$type}[$rule] = $pattern;
+ } else {
+ self::${$type}[$rule] = ($rule === 'uninflected')
+ ? array_merge($pattern, self::${$type}[$rule])
+ : $pattern + self::${$type}[$rule];
+ }
+
+ unset($rules[$rule], self::${$type}['cache' . ucfirst($rule)]);
+
+ if (isset(self::${$type}['merged'][$rule])) {
+ unset(self::${$type}['merged'][$rule]);
+ }
+
+ if ($type === 'plural') {
+ self::$cache['pluralize'] = self::$cache['tableize'] = array();
+ } elseif ($type === 'singular') {
+ self::$cache['singularize'] = array();
+ }
+ }
+
+ self::${$type}['rules'] = $rules + self::${$type}['rules'];
+ }
+
+ /**
+ * Returns a word in plural form.
+ *
+ * @param string $word The word in singular form.
+ *
+ * @return string The word in plural form.
+ */
+ public static function pluralize($word)
+ {
+ if (isset(self::$cache['pluralize'][$word])) {
+ return self::$cache['pluralize'][$word];
+ }
+
+ if (!isset(self::$plural['merged']['irregular'])) {
+ self::$plural['merged']['irregular'] = self::$plural['irregular'];
+ }
+
+ if (!isset(self::$plural['merged']['uninflected'])) {
+ self::$plural['merged']['uninflected'] = array_merge(self::$plural['uninflected'], self::$uninflected);
+ }
+
+ if (!isset(self::$plural['cacheUninflected']) || !isset(self::$plural['cacheIrregular'])) {
+ self::$plural['cacheUninflected'] = '(?:' . implode('|', self::$plural['merged']['uninflected']) . ')';
+ self::$plural['cacheIrregular'] = '(?:' . implode('|', array_keys(self::$plural['merged']['irregular'])) . ')';
+ }
+
+ if (preg_match('/(.*)\\b(' . self::$plural['cacheIrregular'] . ')$/i', $word, $regs)) {
+ self::$cache['pluralize'][$word] = $regs[1] . substr($word, 0, 1) . substr(self::$plural['merged']['irregular'][strtolower($regs[2])], 1);
+
+ return self::$cache['pluralize'][$word];
+ }
+
+ if (preg_match('/^(' . self::$plural['cacheUninflected'] . ')$/i', $word, $regs)) {
+ self::$cache['pluralize'][$word] = $word;
+
+ return $word;
+ }
+
+ foreach (self::$plural['rules'] as $rule => $replacement) {
+ if (preg_match($rule, $word)) {
+ self::$cache['pluralize'][$word] = preg_replace($rule, $replacement, $word);
+
+ return self::$cache['pluralize'][$word];
+ }
+ }
+ }
+
+ /**
+ * Returns a word in singular form.
+ *
+ * @param string $word The word in plural form.
+ *
+ * @return string The word in singular form.
+ */
+ public static function singularize($word)
+ {
+ if (isset(self::$cache['singularize'][$word])) {
+ return self::$cache['singularize'][$word];
+ }
+
+ if (!isset(self::$singular['merged']['uninflected'])) {
+ self::$singular['merged']['uninflected'] = array_merge(
+ self::$singular['uninflected'],
+ self::$uninflected
+ );
+ }
+
+ if (!isset(self::$singular['merged']['irregular'])) {
+ self::$singular['merged']['irregular'] = array_merge(
+ self::$singular['irregular'],
+ array_flip(self::$plural['irregular'])
+ );
+ }
+
+ if (!isset(self::$singular['cacheUninflected']) || !isset(self::$singular['cacheIrregular'])) {
+ self::$singular['cacheUninflected'] = '(?:' . join('|', self::$singular['merged']['uninflected']) . ')';
+ self::$singular['cacheIrregular'] = '(?:' . join('|', array_keys(self::$singular['merged']['irregular'])) . ')';
+ }
+
+ if (preg_match('/(.*)\\b(' . self::$singular['cacheIrregular'] . ')$/i', $word, $regs)) {
+ self::$cache['singularize'][$word] = $regs[1] . substr($word, 0, 1) . substr(self::$singular['merged']['irregular'][strtolower($regs[2])], 1);
+
+ return self::$cache['singularize'][$word];
+ }
+
+ if (preg_match('/^(' . self::$singular['cacheUninflected'] . ')$/i', $word, $regs)) {
+ self::$cache['singularize'][$word] = $word;
+
+ return $word;
+ }
+
+ foreach (self::$singular['rules'] as $rule => $replacement) {
+ if (preg_match($rule, $word)) {
+ self::$cache['singularize'][$word] = preg_replace($rule, $replacement, $word);
+
+ return self::$cache['singularize'][$word];
+ }
+ }
+
+ self::$cache['singularize'][$word] = $word;
+
+ return $word;
+ }
+}
diff --git a/vendor/doctrine/inflector/phpunit.xml.dist b/vendor/doctrine/inflector/phpunit.xml.dist
new file mode 100644
index 000000000..ef07faa53
--- /dev/null
+++ b/vendor/doctrine/inflector/phpunit.xml.dist
@@ -0,0 +1,31 @@
+
+
+
+
+
+ ./tests/Doctrine/
+
+
+
+
+
+ ./lib/Doctrine/
+
+
+
+
+
+ performance
+
+
+
diff --git a/vendor/doctrine/inflector/tests/Doctrine/Tests/Common/Inflector/InflectorTest.php b/vendor/doctrine/inflector/tests/Doctrine/Tests/Common/Inflector/InflectorTest.php
new file mode 100644
index 000000000..4198d22c1
--- /dev/null
+++ b/vendor/doctrine/inflector/tests/Doctrine/Tests/Common/Inflector/InflectorTest.php
@@ -0,0 +1,309 @@
+assertEquals(
+ $singular,
+ Inflector::singularize($plural),
+ "'$plural' should be singularized to '$singular'"
+ );
+ }
+
+ /**
+ * testInflectingPlurals method
+ *
+ * @dataProvider dataSampleWords
+ * @return void
+ */
+ public function testInflectingPlurals($singular, $plural)
+ {
+ $this->assertEquals(
+ $plural,
+ Inflector::pluralize($singular),
+ "'$singular' should be pluralized to '$plural'"
+ );
+ }
+
+ /**
+ * testCustomPluralRule method
+ *
+ * @return void
+ */
+ public function testCustomPluralRule()
+ {
+ Inflector::reset();
+ Inflector::rules('plural', array('/^(custom)$/i' => '\1izables'));
+
+ $this->assertEquals(Inflector::pluralize('custom'), 'customizables');
+
+ Inflector::rules('plural', array('uninflected' => array('uninflectable')));
+
+ $this->assertEquals(Inflector::pluralize('uninflectable'), 'uninflectable');
+
+ Inflector::rules('plural', array(
+ 'rules' => array('/^(alert)$/i' => '\1ables'),
+ 'uninflected' => array('noflect', 'abtuse'),
+ 'irregular' => array('amaze' => 'amazable', 'phone' => 'phonezes')
+ ));
+
+ $this->assertEquals(Inflector::pluralize('noflect'), 'noflect');
+ $this->assertEquals(Inflector::pluralize('abtuse'), 'abtuse');
+ $this->assertEquals(Inflector::pluralize('alert'), 'alertables');
+ $this->assertEquals(Inflector::pluralize('amaze'), 'amazable');
+ $this->assertEquals(Inflector::pluralize('phone'), 'phonezes');
+ }
+
+ /**
+ * testCustomSingularRule method
+ *
+ * @return void
+ */
+ public function testCustomSingularRule()
+ {
+ Inflector::reset();
+ Inflector::rules('singular', array('/(eple)r$/i' => '\1', '/(jente)r$/i' => '\1'));
+
+ $this->assertEquals(Inflector::singularize('epler'), 'eple');
+ $this->assertEquals(Inflector::singularize('jenter'), 'jente');
+
+ Inflector::rules('singular', array(
+ 'rules' => array('/^(bil)er$/i' => '\1', '/^(inflec|contribu)tors$/i' => '\1ta'),
+ 'uninflected' => array('singulars'),
+ 'irregular' => array('spins' => 'spinor')
+ ));
+
+ $this->assertEquals(Inflector::singularize('inflectors'), 'inflecta');
+ $this->assertEquals(Inflector::singularize('contributors'), 'contributa');
+ $this->assertEquals(Inflector::singularize('spins'), 'spinor');
+ $this->assertEquals(Inflector::singularize('singulars'), 'singulars');
+ }
+
+ /**
+ * test that setting new rules clears the inflector caches.
+ *
+ * @return void
+ */
+ public function testRulesClearsCaches()
+ {
+ Inflector::reset();
+
+ $this->assertEquals(Inflector::singularize('Bananas'), 'Banana');
+ $this->assertEquals(Inflector::pluralize('Banana'), 'Bananas');
+
+ Inflector::rules('singular', array(
+ 'rules' => array('/(.*)nas$/i' => '\1zzz')
+ ));
+
+ $this->assertEquals('Banazzz', Inflector::singularize('Bananas'), 'Was inflected with old rules.');
+
+ Inflector::rules('plural', array(
+ 'rules' => array('/(.*)na$/i' => '\1zzz'),
+ 'irregular' => array('corpus' => 'corpora')
+ ));
+
+ $this->assertEquals(Inflector::pluralize('Banana'), 'Banazzz', 'Was inflected with old rules.');
+ $this->assertEquals(Inflector::pluralize('corpus'), 'corpora', 'Was inflected with old irregular form.');
+ }
+
+ /**
+ * Test resetting inflection rules.
+ *
+ * @return void
+ */
+ public function testCustomRuleWithReset()
+ {
+ Inflector::reset();
+
+ $uninflected = array('atlas', 'lapis', 'onibus', 'pires', 'virus', '.*x');
+ $pluralIrregular = array('as' => 'ases');
+
+ Inflector::rules('singular', array(
+ 'rules' => array('/^(.*)(a|e|o|u)is$/i' => '\1\2l'),
+ 'uninflected' => $uninflected,
+ ), true);
+
+ Inflector::rules('plural', array(
+ 'rules' => array(
+ '/^(.*)(a|e|o|u)l$/i' => '\1\2is',
+ ),
+ 'uninflected' => $uninflected,
+ 'irregular' => $pluralIrregular
+ ), true);
+
+ $this->assertEquals(Inflector::pluralize('Alcool'), 'Alcoois');
+ $this->assertEquals(Inflector::pluralize('Atlas'), 'Atlas');
+ $this->assertEquals(Inflector::singularize('Alcoois'), 'Alcool');
+ $this->assertEquals(Inflector::singularize('Atlas'), 'Atlas');
+ }
+
+ /**
+ * Test basic ucwords functionality.
+ *
+ * @return void
+ */
+ public function testUcwords()
+ {
+ $this->assertSame('Top-O-The-Morning To All_of_you!', Inflector::ucwords( 'top-o-the-morning to all_of_you!'));
+ }
+
+ /**
+ * Test ucwords functionality with custom delimeters.
+ *
+ * @return void
+ */
+ public function testUcwordsWithCustomDelimeters()
+ {
+ $this->assertSame('Top-O-The-Morning To All_Of_You!', Inflector::ucwords( 'top-o-the-morning to all_of_you!', '-_ '));
+ }
+}
+
diff --git a/vendor/doctrine/inflector/tests/Doctrine/Tests/DoctrineTestCase.php b/vendor/doctrine/inflector/tests/Doctrine/Tests/DoctrineTestCase.php
new file mode 100644
index 000000000..e8323d294
--- /dev/null
+++ b/vendor/doctrine/inflector/tests/Doctrine/Tests/DoctrineTestCase.php
@@ -0,0 +1,10 @@
+ composer-installer.php
+ hhvm composer-installer.php
+ hhvm -v ResourceLimit.SocketDefaultTimeout=30 -v Http.SlowQueryThreshold=30000 composer.phar update --prefer-source
+elif [ "$TRAVIS_PHP_VERSION" = '5.3.3' ] ; then
+ composer self-update
+ composer update --prefer-source --no-dev
+ composer dump-autoload
+else
+ composer self-update
+ composer update --prefer-source
+fi
diff --git a/vendor/doctrine/instantiator/.travis.yml b/vendor/doctrine/instantiator/.travis.yml
new file mode 100644
index 000000000..7f1ec5f98
--- /dev/null
+++ b/vendor/doctrine/instantiator/.travis.yml
@@ -0,0 +1,22 @@
+language: php
+
+php:
+ - 5.3.3
+ - 5.3
+ - 5.4
+ - 5.5
+ - 5.6
+ - hhvm
+
+before_script:
+ - ./.travis.install.sh
+ - if [ $TRAVIS_PHP_VERSION = '5.6' ]; then PHPUNIT_FLAGS="--coverage-clover coverage.clover"; else PHPUNIT_FLAGS=""; fi
+
+script:
+ - if [ $TRAVIS_PHP_VERSION = '5.3.3' ]; then phpunit; fi
+ - if [ $TRAVIS_PHP_VERSION != '5.3.3' ]; then ./vendor/bin/phpunit $PHPUNIT_FLAGS; fi
+ - if [ $TRAVIS_PHP_VERSION != '5.3.3' ]; then ./vendor/bin/phpcs --standard=PSR2 ./src/ ./tests/; fi
+ - if [[ $TRAVIS_PHP_VERSION != '5.3.3' && $TRAVIS_PHP_VERSION != '5.4.29' && $TRAVIS_PHP_VERSION != '5.5.13' ]]; then php -n ./vendor/bin/athletic -p ./tests/DoctrineTest/InstantiatorPerformance/ -f GroupedFormatter; fi
+
+after_script:
+ - if [ $TRAVIS_PHP_VERSION = '5.6' ]; then wget https://scrutinizer-ci.com/ocular.phar; php ocular.phar code-coverage:upload --format=php-clover coverage.clover; fi
diff --git a/vendor/doctrine/instantiator/CONTRIBUTING.md b/vendor/doctrine/instantiator/CONTRIBUTING.md
new file mode 100644
index 000000000..75b84b2aa
--- /dev/null
+++ b/vendor/doctrine/instantiator/CONTRIBUTING.md
@@ -0,0 +1,35 @@
+# Contributing
+
+ * Coding standard for the project is [PSR-2](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-2-coding-style-guide.md)
+ * The project will follow strict [object calisthenics](http://www.slideshare.net/guilhermeblanco/object-calisthenics-applied-to-php)
+ * Any contribution must provide tests for additional introduced conditions
+ * Any un-confirmed issue needs a failing test case before being accepted
+ * Pull requests must be sent from a new hotfix/feature branch, not from `master`.
+
+## Installation
+
+To install the project and run the tests, you need to clone it first:
+
+```sh
+$ git clone git://github.com/doctrine/instantiator.git
+```
+
+You will then need to run a composer installation:
+
+```sh
+$ cd Instantiator
+$ curl -s https://getcomposer.org/installer | php
+$ php composer.phar update
+```
+
+## Testing
+
+The PHPUnit version to be used is the one installed as a dev- dependency via composer:
+
+```sh
+$ ./vendor/bin/phpunit
+```
+
+Accepted coverage for new contributions is 80%. Any contribution not satisfying this requirement
+won't be merged.
+
diff --git a/vendor/doctrine/instantiator/LICENSE b/vendor/doctrine/instantiator/LICENSE
new file mode 100644
index 000000000..4d983d1ac
--- /dev/null
+++ b/vendor/doctrine/instantiator/LICENSE
@@ -0,0 +1,19 @@
+Copyright (c) 2014 Doctrine Project
+
+Permission is hereby granted, free of charge, to any person obtaining a copy of
+this software and associated documentation files (the "Software"), to deal in
+the Software without restriction, including without limitation the rights to
+use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
+of the Software, and to permit persons to whom the Software is furnished to do
+so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
diff --git a/vendor/doctrine/instantiator/README.md b/vendor/doctrine/instantiator/README.md
new file mode 100644
index 000000000..393ec7caa
--- /dev/null
+++ b/vendor/doctrine/instantiator/README.md
@@ -0,0 +1,40 @@
+# Instantiator
+
+This library provides a way of avoiding usage of constructors when instantiating PHP classes.
+
+[](https://travis-ci.org/doctrine/instantiator)
+[](https://scrutinizer-ci.com/g/doctrine/instantiator/?branch=master)
+[](https://scrutinizer-ci.com/g/doctrine/instantiator/?branch=master)
+[](https://www.versioneye.com/package/php--doctrine--instantiator)
+[](http://hhvm.h4cc.de/package/doctrine/instantiator)
+
+[](https://packagist.org/packages/doctrine/instantiator)
+[](https://packagist.org/packages/doctrine/instantiator)
+
+## Installation
+
+The suggested installation method is via [composer](https://getcomposer.org/):
+
+```sh
+php composer.phar require "doctrine/instantiator:~1.0.3"
+```
+
+## Usage
+
+The instantiator is able to create new instances of any class without using the constructor or any API of the class
+itself:
+
+```php
+$instantiator = new \Doctrine\Instantiator\Instantiator();
+
+$instance = $instantiator->instantiate('My\\ClassName\\Here');
+```
+
+## Contributing
+
+Please read the [CONTRIBUTING.md](CONTRIBUTING.md) contents if you wish to help out!
+
+## Credits
+
+This library was migrated from [ocramius/instantiator](https://github.com/Ocramius/Instantiator), which
+has been donated to the doctrine organization, and which is now deprecated in favour of this package.
diff --git a/vendor/doctrine/instantiator/composer.json b/vendor/doctrine/instantiator/composer.json
new file mode 100644
index 000000000..4823890b4
--- /dev/null
+++ b/vendor/doctrine/instantiator/composer.json
@@ -0,0 +1,45 @@
+{
+ "name": "doctrine/instantiator",
+ "description": "A small, lightweight utility to instantiate objects in PHP without invoking their constructors",
+ "type": "library",
+ "license": "MIT",
+ "homepage": "https://github.com/doctrine/instantiator",
+ "keywords": [
+ "instantiate",
+ "constructor"
+ ],
+ "authors": [
+ {
+ "name": "Marco Pivetta",
+ "email": "ocramius@gmail.com",
+ "homepage": "http://ocramius.github.com/"
+ }
+ ],
+ "require": {
+ "php": ">=5.3,<8.0-DEV"
+ },
+ "require-dev": {
+ "ext-phar": "*",
+ "ext-pdo": "*",
+ "phpunit/phpunit": "~4.0",
+ "squizlabs/php_codesniffer": "~2.0",
+ "athletic/athletic": "~0.1.8"
+ },
+ "autoload": {
+ "psr-4": {
+ "Doctrine\\Instantiator\\": "src/Doctrine/Instantiator/"
+ }
+ },
+ "autoload-dev": {
+ "psr-0": {
+ "DoctrineTest\\InstantiatorPerformance\\": "tests",
+ "DoctrineTest\\InstantiatorTest\\": "tests",
+ "DoctrineTest\\InstantiatorTestAsset\\": "tests"
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0.x-dev"
+ }
+ }
+}
diff --git a/vendor/doctrine/instantiator/phpmd.xml.dist b/vendor/doctrine/instantiator/phpmd.xml.dist
new file mode 100644
index 000000000..825410562
--- /dev/null
+++ b/vendor/doctrine/instantiator/phpmd.xml.dist
@@ -0,0 +1,27 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/vendor/doctrine/instantiator/phpunit.xml.dist b/vendor/doctrine/instantiator/phpunit.xml.dist
new file mode 100644
index 000000000..0a8d5709b
--- /dev/null
+++ b/vendor/doctrine/instantiator/phpunit.xml.dist
@@ -0,0 +1,22 @@
+
+
+
+ ./tests/DoctrineTest/InstantiatorTest
+
+
+
+ ./src
+
+
+
diff --git a/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/ExceptionInterface.php b/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/ExceptionInterface.php
new file mode 100644
index 000000000..3065375a8
--- /dev/null
+++ b/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/ExceptionInterface.php
@@ -0,0 +1,29 @@
+.
+ */
+
+namespace Doctrine\Instantiator\Exception;
+
+/**
+ * Base exception marker interface for the instantiator component
+ *
+ * @author Marco Pivetta
+ */
+interface ExceptionInterface
+{
+}
diff --git a/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/InvalidArgumentException.php b/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/InvalidArgumentException.php
new file mode 100644
index 000000000..ea8d28c5c
--- /dev/null
+++ b/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/InvalidArgumentException.php
@@ -0,0 +1,62 @@
+.
+ */
+
+namespace Doctrine\Instantiator\Exception;
+
+use InvalidArgumentException as BaseInvalidArgumentException;
+use ReflectionClass;
+
+/**
+ * Exception for invalid arguments provided to the instantiator
+ *
+ * @author Marco Pivetta
+ */
+class InvalidArgumentException extends BaseInvalidArgumentException implements ExceptionInterface
+{
+ /**
+ * @param string $className
+ *
+ * @return self
+ */
+ public static function fromNonExistingClass($className)
+ {
+ if (interface_exists($className)) {
+ return new self(sprintf('The provided type "%s" is an interface, and can not be instantiated', $className));
+ }
+
+ if (PHP_VERSION_ID >= 50400 && trait_exists($className)) {
+ return new self(sprintf('The provided type "%s" is a trait, and can not be instantiated', $className));
+ }
+
+ return new self(sprintf('The provided class "%s" does not exist', $className));
+ }
+
+ /**
+ * @param ReflectionClass $reflectionClass
+ *
+ * @return self
+ */
+ public static function fromAbstractClass(ReflectionClass $reflectionClass)
+ {
+ return new self(sprintf(
+ 'The provided class "%s" is abstract, and can not be instantiated',
+ $reflectionClass->getName()
+ ));
+ }
+}
diff --git a/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/UnexpectedValueException.php b/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/UnexpectedValueException.php
new file mode 100644
index 000000000..1681e56e8
--- /dev/null
+++ b/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Exception/UnexpectedValueException.php
@@ -0,0 +1,79 @@
+.
+ */
+
+namespace Doctrine\Instantiator\Exception;
+
+use Exception;
+use ReflectionClass;
+use UnexpectedValueException as BaseUnexpectedValueException;
+
+/**
+ * Exception for given parameters causing invalid/unexpected state on instantiation
+ *
+ * @author Marco Pivetta
+ */
+class UnexpectedValueException extends BaseUnexpectedValueException implements ExceptionInterface
+{
+ /**
+ * @param ReflectionClass $reflectionClass
+ * @param Exception $exception
+ *
+ * @return self
+ */
+ public static function fromSerializationTriggeredException(ReflectionClass $reflectionClass, Exception $exception)
+ {
+ return new self(
+ sprintf(
+ 'An exception was raised while trying to instantiate an instance of "%s" via un-serialization',
+ $reflectionClass->getName()
+ ),
+ 0,
+ $exception
+ );
+ }
+
+ /**
+ * @param ReflectionClass $reflectionClass
+ * @param string $errorString
+ * @param int $errorCode
+ * @param string $errorFile
+ * @param int $errorLine
+ *
+ * @return UnexpectedValueException
+ */
+ public static function fromUncleanUnSerialization(
+ ReflectionClass $reflectionClass,
+ $errorString,
+ $errorCode,
+ $errorFile,
+ $errorLine
+ ) {
+ return new self(
+ sprintf(
+ 'Could not produce an instance of "%s" via un-serialization, since an error was triggered '
+ . 'in file "%s" at line "%d"',
+ $reflectionClass->getName(),
+ $errorFile,
+ $errorLine
+ ),
+ 0,
+ new Exception($errorString, $errorCode)
+ );
+ }
+}
diff --git a/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Instantiator.php b/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Instantiator.php
new file mode 100644
index 000000000..6d5b3b656
--- /dev/null
+++ b/vendor/doctrine/instantiator/src/Doctrine/Instantiator/Instantiator.php
@@ -0,0 +1,273 @@
+.
+ */
+
+namespace Doctrine\Instantiator;
+
+use Closure;
+use Doctrine\Instantiator\Exception\InvalidArgumentException;
+use Doctrine\Instantiator\Exception\UnexpectedValueException;
+use Exception;
+use ReflectionClass;
+
+/**
+ * {@inheritDoc}
+ *
+ * @author Marco Pivetta
+ */
+final class Instantiator implements InstantiatorInterface
+{
+ /**
+ * Markers used internally by PHP to define whether {@see \unserialize} should invoke
+ * the method {@see \Serializable::unserialize()} when dealing with classes implementing
+ * the {@see \Serializable} interface.
+ */
+ const SERIALIZATION_FORMAT_USE_UNSERIALIZER = 'C';
+ const SERIALIZATION_FORMAT_AVOID_UNSERIALIZER = 'O';
+
+ /**
+ * @var \Closure[] of {@see \Closure} instances used to instantiate specific classes
+ */
+ private static $cachedInstantiators = array();
+
+ /**
+ * @var object[] of objects that can directly be cloned
+ */
+ private static $cachedCloneables = array();
+
+ /**
+ * {@inheritDoc}
+ */
+ public function instantiate($className)
+ {
+ if (isset(self::$cachedCloneables[$className])) {
+ return clone self::$cachedCloneables[$className];
+ }
+
+ if (isset(self::$cachedInstantiators[$className])) {
+ $factory = self::$cachedInstantiators[$className];
+
+ return $factory();
+ }
+
+ return $this->buildAndCacheFromFactory($className);
+ }
+
+ /**
+ * Builds the requested object and caches it in static properties for performance
+ *
+ * @param string $className
+ *
+ * @return object
+ */
+ private function buildAndCacheFromFactory($className)
+ {
+ $factory = self::$cachedInstantiators[$className] = $this->buildFactory($className);
+ $instance = $factory();
+
+ if ($this->isSafeToClone(new ReflectionClass($instance))) {
+ self::$cachedCloneables[$className] = clone $instance;
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Builds a {@see \Closure} capable of instantiating the given $className without
+ * invoking its constructor.
+ *
+ * @param string $className
+ *
+ * @return Closure
+ */
+ private function buildFactory($className)
+ {
+ $reflectionClass = $this->getReflectionClass($className);
+
+ if ($this->isInstantiableViaReflection($reflectionClass)) {
+ return function () use ($reflectionClass) {
+ return $reflectionClass->newInstanceWithoutConstructor();
+ };
+ }
+
+ $serializedString = sprintf(
+ '%s:%d:"%s":0:{}',
+ $this->getSerializationFormat($reflectionClass),
+ strlen($className),
+ $className
+ );
+
+ $this->checkIfUnSerializationIsSupported($reflectionClass, $serializedString);
+
+ return function () use ($serializedString) {
+ return unserialize($serializedString);
+ };
+ }
+
+ /**
+ * @param string $className
+ *
+ * @return ReflectionClass
+ *
+ * @throws InvalidArgumentException
+ */
+ private function getReflectionClass($className)
+ {
+ if (! class_exists($className)) {
+ throw InvalidArgumentException::fromNonExistingClass($className);
+ }
+
+ $reflection = new ReflectionClass($className);
+
+ if ($reflection->isAbstract()) {
+ throw InvalidArgumentException::fromAbstractClass($reflection);
+ }
+
+ return $reflection;
+ }
+
+ /**
+ * @param ReflectionClass $reflectionClass
+ * @param string $serializedString
+ *
+ * @throws UnexpectedValueException
+ *
+ * @return void
+ */
+ private function checkIfUnSerializationIsSupported(ReflectionClass $reflectionClass, $serializedString)
+ {
+ set_error_handler(function ($code, $message, $file, $line) use ($reflectionClass, & $error) {
+ $error = UnexpectedValueException::fromUncleanUnSerialization(
+ $reflectionClass,
+ $message,
+ $code,
+ $file,
+ $line
+ );
+ });
+
+ $this->attemptInstantiationViaUnSerialization($reflectionClass, $serializedString);
+
+ restore_error_handler();
+
+ if ($error) {
+ throw $error;
+ }
+ }
+
+ /**
+ * @param ReflectionClass $reflectionClass
+ * @param string $serializedString
+ *
+ * @throws UnexpectedValueException
+ *
+ * @return void
+ */
+ private function attemptInstantiationViaUnSerialization(ReflectionClass $reflectionClass, $serializedString)
+ {
+ try {
+ unserialize($serializedString);
+ } catch (Exception $exception) {
+ restore_error_handler();
+
+ throw UnexpectedValueException::fromSerializationTriggeredException($reflectionClass, $exception);
+ }
+ }
+
+ /**
+ * @param ReflectionClass $reflectionClass
+ *
+ * @return bool
+ */
+ private function isInstantiableViaReflection(ReflectionClass $reflectionClass)
+ {
+ if (\PHP_VERSION_ID >= 50600) {
+ return ! ($this->hasInternalAncestors($reflectionClass) && $reflectionClass->isFinal());
+ }
+
+ return \PHP_VERSION_ID >= 50400 && ! $this->hasInternalAncestors($reflectionClass);
+ }
+
+ /**
+ * Verifies whether the given class is to be considered internal
+ *
+ * @param ReflectionClass $reflectionClass
+ *
+ * @return bool
+ */
+ private function hasInternalAncestors(ReflectionClass $reflectionClass)
+ {
+ do {
+ if ($reflectionClass->isInternal()) {
+ return true;
+ }
+ } while ($reflectionClass = $reflectionClass->getParentClass());
+
+ return false;
+ }
+
+ /**
+ * Verifies if the given PHP version implements the `Serializable` interface serialization
+ * with an incompatible serialization format. If that's the case, use serialization marker
+ * "C" instead of "O".
+ *
+ * @link http://news.php.net/php.internals/74654
+ *
+ * @param ReflectionClass $reflectionClass
+ *
+ * @return string the serialization format marker, either self::SERIALIZATION_FORMAT_USE_UNSERIALIZER
+ * or self::SERIALIZATION_FORMAT_AVOID_UNSERIALIZER
+ */
+ private function getSerializationFormat(ReflectionClass $reflectionClass)
+ {
+ if ($this->isPhpVersionWithBrokenSerializationFormat()
+ && $reflectionClass->implementsInterface('Serializable')
+ ) {
+ return self::SERIALIZATION_FORMAT_USE_UNSERIALIZER;
+ }
+
+ return self::SERIALIZATION_FORMAT_AVOID_UNSERIALIZER;
+ }
+
+ /**
+ * Checks whether the current PHP runtime uses an incompatible serialization format
+ *
+ * @return bool
+ */
+ private function isPhpVersionWithBrokenSerializationFormat()
+ {
+ return PHP_VERSION_ID === 50429 || PHP_VERSION_ID === 50513;
+ }
+
+ /**
+ * Checks if a class is cloneable
+ *
+ * @param ReflectionClass $reflection
+ *
+ * @return bool
+ */
+ private function isSafeToClone(ReflectionClass $reflection)
+ {
+ if (method_exists($reflection, 'isCloneable') && ! $reflection->isCloneable()) {
+ return false;
+ }
+
+ // not cloneable if it implements `__clone`, as we want to avoid calling it
+ return ! $reflection->hasMethod('__clone');
+ }
+}
diff --git a/vendor/doctrine/instantiator/src/Doctrine/Instantiator/InstantiatorInterface.php b/vendor/doctrine/instantiator/src/Doctrine/Instantiator/InstantiatorInterface.php
new file mode 100644
index 000000000..b665bea85
--- /dev/null
+++ b/vendor/doctrine/instantiator/src/Doctrine/Instantiator/InstantiatorInterface.php
@@ -0,0 +1,37 @@
+.
+ */
+
+namespace Doctrine\Instantiator;
+
+/**
+ * Instantiator provides utility methods to build objects without invoking their constructors
+ *
+ * @author Marco Pivetta
+ */
+interface InstantiatorInterface
+{
+ /**
+ * @param string $className
+ *
+ * @return object
+ *
+ * @throws \Doctrine\Instantiator\Exception\ExceptionInterface
+ */
+ public function instantiate($className);
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorPerformance/InstantiatorPerformanceEvent.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorPerformance/InstantiatorPerformanceEvent.php
new file mode 100644
index 000000000..3e8fc6ff4
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorPerformance/InstantiatorPerformanceEvent.php
@@ -0,0 +1,96 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorPerformance;
+
+use Athletic\AthleticEvent;
+use Doctrine\Instantiator\Instantiator;
+
+/**
+ * Performance tests for {@see \Doctrine\Instantiator\Instantiator}
+ *
+ * @author Marco Pivetta
+ */
+class InstantiatorPerformanceEvent extends AthleticEvent
+{
+ /**
+ * @var \Doctrine\Instantiator\Instantiator
+ */
+ private $instantiator;
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function setUp()
+ {
+ $this->instantiator = new Instantiator();
+
+ $this->instantiator->instantiate(__CLASS__);
+ $this->instantiator->instantiate('ArrayObject');
+ $this->instantiator->instantiate('DoctrineTest\\InstantiatorTestAsset\\SimpleSerializableAsset');
+ $this->instantiator->instantiate('DoctrineTest\\InstantiatorTestAsset\\SerializableArrayObjectAsset');
+ $this->instantiator->instantiate('DoctrineTest\\InstantiatorTestAsset\\UnCloneableAsset');
+ }
+
+ /**
+ * @iterations 20000
+ * @baseline
+ * @group instantiation
+ */
+ public function testInstantiateSelf()
+ {
+ $this->instantiator->instantiate(__CLASS__);
+ }
+
+ /**
+ * @iterations 20000
+ * @group instantiation
+ */
+ public function testInstantiateInternalClass()
+ {
+ $this->instantiator->instantiate('ArrayObject');
+ }
+
+ /**
+ * @iterations 20000
+ * @group instantiation
+ */
+ public function testInstantiateSimpleSerializableAssetClass()
+ {
+ $this->instantiator->instantiate('DoctrineTest\\InstantiatorTestAsset\\SimpleSerializableAsset');
+ }
+
+ /**
+ * @iterations 20000
+ * @group instantiation
+ */
+ public function testInstantiateSerializableArrayObjectAsset()
+ {
+ $this->instantiator->instantiate('DoctrineTest\\InstantiatorTestAsset\\SerializableArrayObjectAsset');
+ }
+
+ /**
+ * @iterations 20000
+ * @group instantiation
+ */
+ public function testInstantiateUnCloneableAsset()
+ {
+ $this->instantiator->instantiate('DoctrineTest\\InstantiatorTestAsset\\UnCloneableAsset');
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/Exception/InvalidArgumentExceptionTest.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/Exception/InvalidArgumentExceptionTest.php
new file mode 100644
index 000000000..39d9b94df
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/Exception/InvalidArgumentExceptionTest.php
@@ -0,0 +1,83 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTest\Exception;
+
+use Doctrine\Instantiator\Exception\InvalidArgumentException;
+use PHPUnit_Framework_TestCase;
+use ReflectionClass;
+
+/**
+ * Tests for {@see \Doctrine\Instantiator\Exception\InvalidArgumentException}
+ *
+ * @author Marco Pivetta
+ *
+ * @covers \Doctrine\Instantiator\Exception\InvalidArgumentException
+ */
+class InvalidArgumentExceptionTest extends PHPUnit_Framework_TestCase
+{
+ public function testFromNonExistingTypeWithNonExistingClass()
+ {
+ $className = __CLASS__ . uniqid();
+ $exception = InvalidArgumentException::fromNonExistingClass($className);
+
+ $this->assertInstanceOf('Doctrine\\Instantiator\\Exception\\InvalidArgumentException', $exception);
+ $this->assertSame('The provided class "' . $className . '" does not exist', $exception->getMessage());
+ }
+
+ public function testFromNonExistingTypeWithTrait()
+ {
+ if (PHP_VERSION_ID < 50400) {
+ $this->markTestSkipped('Need at least PHP 5.4.0, as this test requires traits support to run');
+ }
+
+ $exception = InvalidArgumentException::fromNonExistingClass(
+ 'DoctrineTest\\InstantiatorTestAsset\\SimpleTraitAsset'
+ );
+
+ $this->assertSame(
+ 'The provided type "DoctrineTest\\InstantiatorTestAsset\\SimpleTraitAsset" is a trait, '
+ . 'and can not be instantiated',
+ $exception->getMessage()
+ );
+ }
+
+ public function testFromNonExistingTypeWithInterface()
+ {
+ $exception = InvalidArgumentException::fromNonExistingClass('Doctrine\\Instantiator\\InstantiatorInterface');
+
+ $this->assertSame(
+ 'The provided type "Doctrine\\Instantiator\\InstantiatorInterface" is an interface, '
+ . 'and can not be instantiated',
+ $exception->getMessage()
+ );
+ }
+
+ public function testFromAbstractClass()
+ {
+ $reflection = new ReflectionClass('DoctrineTest\\InstantiatorTestAsset\\AbstractClassAsset');
+ $exception = InvalidArgumentException::fromAbstractClass($reflection);
+
+ $this->assertSame(
+ 'The provided class "DoctrineTest\\InstantiatorTestAsset\\AbstractClassAsset" is abstract, '
+ . 'and can not be instantiated',
+ $exception->getMessage()
+ );
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/Exception/UnexpectedValueExceptionTest.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/Exception/UnexpectedValueExceptionTest.php
new file mode 100644
index 000000000..84154e739
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/Exception/UnexpectedValueExceptionTest.php
@@ -0,0 +1,69 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTest\Exception;
+
+use Doctrine\Instantiator\Exception\UnexpectedValueException;
+use Exception;
+use PHPUnit_Framework_TestCase;
+use ReflectionClass;
+
+/**
+ * Tests for {@see \Doctrine\Instantiator\Exception\UnexpectedValueException}
+ *
+ * @author Marco Pivetta
+ *
+ * @covers \Doctrine\Instantiator\Exception\UnexpectedValueException
+ */
+class UnexpectedValueExceptionTest extends PHPUnit_Framework_TestCase
+{
+ public function testFromSerializationTriggeredException()
+ {
+ $reflectionClass = new ReflectionClass($this);
+ $previous = new Exception();
+ $exception = UnexpectedValueException::fromSerializationTriggeredException($reflectionClass, $previous);
+
+ $this->assertInstanceOf('Doctrine\\Instantiator\\Exception\\UnexpectedValueException', $exception);
+ $this->assertSame($previous, $exception->getPrevious());
+ $this->assertSame(
+ 'An exception was raised while trying to instantiate an instance of "'
+ . __CLASS__ . '" via un-serialization',
+ $exception->getMessage()
+ );
+ }
+
+ public function testFromUncleanUnSerialization()
+ {
+ $reflection = new ReflectionClass('DoctrineTest\\InstantiatorTestAsset\\AbstractClassAsset');
+ $exception = UnexpectedValueException::fromUncleanUnSerialization($reflection, 'foo', 123, 'bar', 456);
+
+ $this->assertInstanceOf('Doctrine\\Instantiator\\Exception\\UnexpectedValueException', $exception);
+ $this->assertSame(
+ 'Could not produce an instance of "DoctrineTest\\InstantiatorTestAsset\\AbstractClassAsset" '
+ . 'via un-serialization, since an error was triggered in file "bar" at line "456"',
+ $exception->getMessage()
+ );
+
+ $previous = $exception->getPrevious();
+
+ $this->assertInstanceOf('Exception', $previous);
+ $this->assertSame('foo', $previous->getMessage());
+ $this->assertSame(123, $previous->getCode());
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/InstantiatorTest.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/InstantiatorTest.php
new file mode 100644
index 000000000..0a2cb9313
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTest/InstantiatorTest.php
@@ -0,0 +1,219 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTest;
+
+use Doctrine\Instantiator\Exception\UnexpectedValueException;
+use Doctrine\Instantiator\Instantiator;
+use PHPUnit_Framework_TestCase;
+use ReflectionClass;
+
+/**
+ * Tests for {@see \Doctrine\Instantiator\Instantiator}
+ *
+ * @author Marco Pivetta
+ *
+ * @covers \Doctrine\Instantiator\Instantiator
+ */
+class InstantiatorTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @var Instantiator
+ */
+ private $instantiator;
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function setUp()
+ {
+ $this->instantiator = new Instantiator();
+ }
+
+ /**
+ * @param string $className
+ *
+ * @dataProvider getInstantiableClasses
+ */
+ public function testCanInstantiate($className)
+ {
+ $this->assertInstanceOf($className, $this->instantiator->instantiate($className));
+ }
+
+ /**
+ * @param string $className
+ *
+ * @dataProvider getInstantiableClasses
+ */
+ public function testInstantiatesSeparateInstances($className)
+ {
+ $instance1 = $this->instantiator->instantiate($className);
+ $instance2 = $this->instantiator->instantiate($className);
+
+ $this->assertEquals($instance1, $instance2);
+ $this->assertNotSame($instance1, $instance2);
+ }
+
+ public function testExceptionOnUnSerializationException()
+ {
+ if (defined('HHVM_VERSION')) {
+ $this->markTestSkipped(
+ 'As of facebook/hhvm#3432, HHVM has no PDORow, and therefore '
+ . ' no internal final classes that cannot be instantiated'
+ );
+ }
+
+ $className = 'DoctrineTest\\InstantiatorTestAsset\\UnserializeExceptionArrayObjectAsset';
+
+ if (\PHP_VERSION_ID >= 50600) {
+ $className = 'PDORow';
+ }
+
+ if (\PHP_VERSION_ID === 50429 || \PHP_VERSION_ID === 50513) {
+ $className = 'DoctrineTest\\InstantiatorTestAsset\\SerializableArrayObjectAsset';
+ }
+
+ $this->setExpectedException('Doctrine\\Instantiator\\Exception\\UnexpectedValueException');
+
+ $this->instantiator->instantiate($className);
+ }
+
+ public function testNoticeOnUnSerializationException()
+ {
+ if (\PHP_VERSION_ID >= 50600) {
+ $this->markTestSkipped(
+ 'PHP 5.6 supports `ReflectionClass#newInstanceWithoutConstructor()` for some internal classes'
+ );
+ }
+
+ try {
+ $this->instantiator->instantiate('DoctrineTest\\InstantiatorTestAsset\\WakeUpNoticesAsset');
+
+ $this->fail('No exception was raised');
+ } catch (UnexpectedValueException $exception) {
+ $wakeUpNoticesReflection = new ReflectionClass('DoctrineTest\\InstantiatorTestAsset\\WakeUpNoticesAsset');
+ $previous = $exception->getPrevious();
+
+ $this->assertInstanceOf('Exception', $previous);
+
+ // in PHP 5.4.29 and PHP 5.5.13, this case is not a notice, but an exception being thrown
+ if (! (\PHP_VERSION_ID === 50429 || \PHP_VERSION_ID === 50513)) {
+ $this->assertSame(
+ 'Could not produce an instance of "DoctrineTest\\InstantiatorTestAsset\WakeUpNoticesAsset" '
+ . 'via un-serialization, since an error was triggered in file "'
+ . $wakeUpNoticesReflection->getFileName() . '" at line "36"',
+ $exception->getMessage()
+ );
+
+ $this->assertSame('Something went bananas while un-serializing this instance', $previous->getMessage());
+ $this->assertSame(\E_USER_NOTICE, $previous->getCode());
+ }
+ }
+ }
+
+ /**
+ * @param string $invalidClassName
+ *
+ * @dataProvider getInvalidClassNames
+ */
+ public function testInstantiationFromNonExistingClass($invalidClassName)
+ {
+ $this->setExpectedException('Doctrine\\Instantiator\\Exception\\InvalidArgumentException');
+
+ $this->instantiator->instantiate($invalidClassName);
+ }
+
+ public function testInstancesAreNotCloned()
+ {
+ $className = 'TemporaryClass' . uniqid();
+
+ eval('namespace ' . __NAMESPACE__ . '; class ' . $className . '{}');
+
+ $instance = $this->instantiator->instantiate(__NAMESPACE__ . '\\' . $className);
+
+ $instance->foo = 'bar';
+
+ $instance2 = $this->instantiator->instantiate(__NAMESPACE__ . '\\' . $className);
+
+ $this->assertObjectNotHasAttribute('foo', $instance2);
+ }
+
+ /**
+ * Provides a list of instantiable classes (existing)
+ *
+ * @return string[][]
+ */
+ public function getInstantiableClasses()
+ {
+ $classes = array(
+ array('stdClass'),
+ array(__CLASS__),
+ array('Doctrine\\Instantiator\\Instantiator'),
+ array('Exception'),
+ array('PharException'),
+ array('DoctrineTest\\InstantiatorTestAsset\\SimpleSerializableAsset'),
+ array('DoctrineTest\\InstantiatorTestAsset\\ExceptionAsset'),
+ array('DoctrineTest\\InstantiatorTestAsset\\FinalExceptionAsset'),
+ array('DoctrineTest\\InstantiatorTestAsset\\PharExceptionAsset'),
+ array('DoctrineTest\\InstantiatorTestAsset\\UnCloneableAsset'),
+ array('DoctrineTest\\InstantiatorTestAsset\\XMLReaderAsset'),
+ );
+
+ if (\PHP_VERSION_ID === 50429 || \PHP_VERSION_ID === 50513) {
+ return $classes;
+ }
+
+ $classes = array_merge(
+ $classes,
+ array(
+ array('PharException'),
+ array('ArrayObject'),
+ array('DoctrineTest\\InstantiatorTestAsset\\ArrayObjectAsset'),
+ array('DoctrineTest\\InstantiatorTestAsset\\SerializableArrayObjectAsset'),
+ )
+ );
+
+ if (\PHP_VERSION_ID >= 50600) {
+ $classes[] = array('DoctrineTest\\InstantiatorTestAsset\\WakeUpNoticesAsset');
+ $classes[] = array('DoctrineTest\\InstantiatorTestAsset\\UnserializeExceptionArrayObjectAsset');
+ }
+
+ return $classes;
+ }
+
+ /**
+ * Provides a list of instantiable classes (existing)
+ *
+ * @return string[][]
+ */
+ public function getInvalidClassNames()
+ {
+ $classNames = array(
+ array(__CLASS__ . uniqid()),
+ array('Doctrine\\Instantiator\\InstantiatorInterface'),
+ array('DoctrineTest\\InstantiatorTestAsset\\AbstractClassAsset'),
+ );
+
+ if (\PHP_VERSION_ID >= 50400) {
+ $classNames[] = array('DoctrineTest\\InstantiatorTestAsset\\SimpleTraitAsset');
+ }
+
+ return $classNames;
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/AbstractClassAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/AbstractClassAsset.php
new file mode 100644
index 000000000..fbe28ddd0
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/AbstractClassAsset.php
@@ -0,0 +1,29 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+/**
+ * A simple asset for an abstract class
+ *
+ * @author Marco Pivetta
+ */
+abstract class AbstractClassAsset
+{
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/ArrayObjectAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/ArrayObjectAsset.php
new file mode 100644
index 000000000..56146d709
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/ArrayObjectAsset.php
@@ -0,0 +1,41 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use ArrayObject;
+use BadMethodCallException;
+
+/**
+ * Test asset that extends an internal PHP class
+ *
+ * @author Marco Pivetta
+ */
+class ArrayObjectAsset extends ArrayObject
+{
+ /**
+ * Constructor - should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function __construct()
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/ExceptionAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/ExceptionAsset.php
new file mode 100644
index 000000000..43bbe46b7
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/ExceptionAsset.php
@@ -0,0 +1,41 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use BadMethodCallException;
+use Exception;
+
+/**
+ * Test asset that extends an internal PHP base exception
+ *
+ * @author Marco Pivetta
+ */
+class ExceptionAsset extends Exception
+{
+ /**
+ * Constructor - should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function __construct()
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/FinalExceptionAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/FinalExceptionAsset.php
new file mode 100644
index 000000000..7d268f5b3
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/FinalExceptionAsset.php
@@ -0,0 +1,41 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use BadMethodCallException;
+use Exception;
+
+/**
+ * Test asset that extends an internal PHP base exception
+ *
+ * @author Marco Pivetta
+ */
+final class FinalExceptionAsset extends Exception
+{
+ /**
+ * Constructor - should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function __construct()
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/PharAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/PharAsset.php
new file mode 100644
index 000000000..553fd5612
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/PharAsset.php
@@ -0,0 +1,41 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use BadMethodCallException;
+use Phar;
+
+/**
+ * Test asset that extends an internal PHP class
+ *
+ * @author Marco Pivetta
+ */
+class PharAsset extends Phar
+{
+ /**
+ * Constructor - should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function __construct()
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/PharExceptionAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/PharExceptionAsset.php
new file mode 100644
index 000000000..42bf73e7e
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/PharExceptionAsset.php
@@ -0,0 +1,44 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use BadMethodCallException;
+use PharException;
+
+/**
+ * Test asset that extends an internal PHP class
+ * This class should be serializable without problems
+ * and without getting the "Erroneous data format for unserializing"
+ * error
+ *
+ * @author Marco Pivetta
+ */
+class PharExceptionAsset extends PharException
+{
+ /**
+ * Constructor - should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function __construct()
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SerializableArrayObjectAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SerializableArrayObjectAsset.php
new file mode 100644
index 000000000..ba19aaf63
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SerializableArrayObjectAsset.php
@@ -0,0 +1,62 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use ArrayObject;
+use BadMethodCallException;
+use Serializable;
+
+/**
+ * Serializable test asset that also extends an internal class
+ *
+ * @author Marco Pivetta
+ */
+class SerializableArrayObjectAsset extends ArrayObject implements Serializable
+{
+ /**
+ * Constructor - should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function __construct()
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public function serialize()
+ {
+ return '';
+ }
+
+ /**
+ * {@inheritDoc}
+ *
+ * Should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function unserialize($serialized)
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SimpleSerializableAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SimpleSerializableAsset.php
new file mode 100644
index 000000000..39f84a6c0
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SimpleSerializableAsset.php
@@ -0,0 +1,61 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use BadMethodCallException;
+use Serializable;
+
+/**
+ * Base serializable test asset
+ *
+ * @author Marco Pivetta
+ */
+class SimpleSerializableAsset implements Serializable
+{
+ /**
+ * Constructor - should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function __construct()
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public function serialize()
+ {
+ return '';
+ }
+
+ /**
+ * {@inheritDoc}
+ *
+ * Should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function unserialize($serialized)
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SimpleTraitAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SimpleTraitAsset.php
new file mode 100644
index 000000000..04e78069d
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/SimpleTraitAsset.php
@@ -0,0 +1,29 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+/**
+ * A simple trait with no attached logic
+ *
+ * @author Marco Pivetta
+ */
+trait SimpleTraitAsset
+{
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/UnCloneableAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/UnCloneableAsset.php
new file mode 100644
index 000000000..7d03bdab0
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/UnCloneableAsset.php
@@ -0,0 +1,50 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use BadMethodCallException;
+
+/**
+ * Base un-cloneable asset
+ *
+ * @author Marco Pivetta
+ */
+class UnCloneableAsset
+{
+ /**
+ * Constructor - should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function __construct()
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+
+ /**
+ * Magic `__clone` - should not be invoked
+ *
+ * @throws BadMethodCallException
+ */
+ public function __clone()
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/UnserializeExceptionArrayObjectAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/UnserializeExceptionArrayObjectAsset.php
new file mode 100644
index 000000000..b348a4053
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/UnserializeExceptionArrayObjectAsset.php
@@ -0,0 +1,39 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use ArrayObject;
+use BadMethodCallException;
+
+/**
+ * A simple asset for an abstract class
+ *
+ * @author Marco Pivetta
+ */
+class UnserializeExceptionArrayObjectAsset extends ArrayObject
+{
+ /**
+ * {@inheritDoc}
+ */
+ public function __wakeup()
+ {
+ throw new BadMethodCallException();
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/WakeUpNoticesAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/WakeUpNoticesAsset.php
new file mode 100644
index 000000000..18dc6711d
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/WakeUpNoticesAsset.php
@@ -0,0 +1,38 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use ArrayObject;
+
+/**
+ * A simple asset for an abstract class
+ *
+ * @author Marco Pivetta
+ */
+class WakeUpNoticesAsset extends ArrayObject
+{
+ /**
+ * Wakeup method called after un-serialization
+ */
+ public function __wakeup()
+ {
+ trigger_error('Something went bananas while un-serializing this instance');
+ }
+}
diff --git a/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/XMLReaderAsset.php b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/XMLReaderAsset.php
new file mode 100644
index 000000000..39ee6992a
--- /dev/null
+++ b/vendor/doctrine/instantiator/tests/DoctrineTest/InstantiatorTestAsset/XMLReaderAsset.php
@@ -0,0 +1,41 @@
+.
+ */
+
+namespace DoctrineTest\InstantiatorTestAsset;
+
+use BadMethodCallException;
+use XMLReader;
+
+/**
+ * Test asset that extends an internal PHP class
+ *
+ * @author Dave Marshall
+ */
+class XMLReaderAsset extends XMLReader
+{
+ /**
+ * Constructor - should not be called
+ *
+ * @throws BadMethodCallException
+ */
+ public function __construct()
+ {
+ throw new BadMethodCallException('Not supposed to be called!');
+ }
+}
diff --git a/vendor/erusev/parsedown/LICENSE.txt b/vendor/erusev/parsedown/LICENSE.txt
new file mode 100644
index 000000000..8e7c764d1
--- /dev/null
+++ b/vendor/erusev/parsedown/LICENSE.txt
@@ -0,0 +1,20 @@
+The MIT License (MIT)
+
+Copyright (c) 2013-2018 Emanuil Rusev, erusev.com
+
+Permission is hereby granted, free of charge, to any person obtaining a copy of
+this software and associated documentation files (the "Software"), to deal in
+the Software without restriction, including without limitation the rights to
+use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
+the Software, and to permit persons to whom the Software is furnished to do so,
+subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
+FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
+COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
+IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
diff --git a/vendor/erusev/parsedown/Parsedown.php b/vendor/erusev/parsedown/Parsedown.php
new file mode 100644
index 000000000..1b9d6d5bc
--- /dev/null
+++ b/vendor/erusev/parsedown/Parsedown.php
@@ -0,0 +1,1712 @@
+DefinitionData = array();
+
+ # standardize line breaks
+ $text = str_replace(array("\r\n", "\r"), "\n", $text);
+
+ # remove surrounding line breaks
+ $text = trim($text, "\n");
+
+ # split text into lines
+ $lines = explode("\n", $text);
+
+ # iterate through lines to identify blocks
+ $markup = $this->lines($lines);
+
+ # trim line breaks
+ $markup = trim($markup, "\n");
+
+ return $markup;
+ }
+
+ #
+ # Setters
+ #
+
+ function setBreaksEnabled($breaksEnabled)
+ {
+ $this->breaksEnabled = $breaksEnabled;
+
+ return $this;
+ }
+
+ protected $breaksEnabled;
+
+ function setMarkupEscaped($markupEscaped)
+ {
+ $this->markupEscaped = $markupEscaped;
+
+ return $this;
+ }
+
+ protected $markupEscaped;
+
+ function setUrlsLinked($urlsLinked)
+ {
+ $this->urlsLinked = $urlsLinked;
+
+ return $this;
+ }
+
+ protected $urlsLinked = true;
+
+ function setSafeMode($safeMode)
+ {
+ $this->safeMode = (bool) $safeMode;
+
+ return $this;
+ }
+
+ protected $safeMode;
+
+ protected $safeLinksWhitelist = array(
+ 'http://',
+ 'https://',
+ 'ftp://',
+ 'ftps://',
+ 'mailto:',
+ 'data:image/png;base64,',
+ 'data:image/gif;base64,',
+ 'data:image/jpeg;base64,',
+ 'irc:',
+ 'ircs:',
+ 'git:',
+ 'ssh:',
+ 'news:',
+ 'steam:',
+ );
+
+ #
+ # Lines
+ #
+
+ protected $BlockTypes = array(
+ '#' => array('Header'),
+ '*' => array('Rule', 'List'),
+ '+' => array('List'),
+ '-' => array('SetextHeader', 'Table', 'Rule', 'List'),
+ '0' => array('List'),
+ '1' => array('List'),
+ '2' => array('List'),
+ '3' => array('List'),
+ '4' => array('List'),
+ '5' => array('List'),
+ '6' => array('List'),
+ '7' => array('List'),
+ '8' => array('List'),
+ '9' => array('List'),
+ ':' => array('Table'),
+ '<' => array('Comment', 'Markup'),
+ '=' => array('SetextHeader'),
+ '>' => array('Quote'),
+ '[' => array('Reference'),
+ '_' => array('Rule'),
+ '`' => array('FencedCode'),
+ '|' => array('Table'),
+ '~' => array('FencedCode'),
+ );
+
+ # ~
+
+ protected $unmarkedBlockTypes = array(
+ 'Code',
+ );
+
+ #
+ # Blocks
+ #
+
+ protected function lines(array $lines)
+ {
+ $CurrentBlock = null;
+
+ foreach ($lines as $line)
+ {
+ if (chop($line) === '')
+ {
+ if (isset($CurrentBlock))
+ {
+ $CurrentBlock['interrupted'] = true;
+ }
+
+ continue;
+ }
+
+ if (strpos($line, "\t") !== false)
+ {
+ $parts = explode("\t", $line);
+
+ $line = $parts[0];
+
+ unset($parts[0]);
+
+ foreach ($parts as $part)
+ {
+ $shortage = 4 - mb_strlen($line, 'utf-8') % 4;
+
+ $line .= str_repeat(' ', $shortage);
+ $line .= $part;
+ }
+ }
+
+ $indent = 0;
+
+ while (isset($line[$indent]) and $line[$indent] === ' ')
+ {
+ $indent ++;
+ }
+
+ $text = $indent > 0 ? substr($line, $indent) : $line;
+
+ # ~
+
+ $Line = array('body' => $line, 'indent' => $indent, 'text' => $text);
+
+ # ~
+
+ if (isset($CurrentBlock['continuable']))
+ {
+ $Block = $this->{'block'.$CurrentBlock['type'].'Continue'}($Line, $CurrentBlock);
+
+ if (isset($Block))
+ {
+ $CurrentBlock = $Block;
+
+ continue;
+ }
+ else
+ {
+ if ($this->isBlockCompletable($CurrentBlock['type']))
+ {
+ $CurrentBlock = $this->{'block'.$CurrentBlock['type'].'Complete'}($CurrentBlock);
+ }
+ }
+ }
+
+ # ~
+
+ $marker = $text[0];
+
+ # ~
+
+ $blockTypes = $this->unmarkedBlockTypes;
+
+ if (isset($this->BlockTypes[$marker]))
+ {
+ foreach ($this->BlockTypes[$marker] as $blockType)
+ {
+ $blockTypes []= $blockType;
+ }
+ }
+
+ #
+ # ~
+
+ foreach ($blockTypes as $blockType)
+ {
+ $Block = $this->{'block'.$blockType}($Line, $CurrentBlock);
+
+ if (isset($Block))
+ {
+ $Block['type'] = $blockType;
+
+ if ( ! isset($Block['identified']))
+ {
+ $Blocks []= $CurrentBlock;
+
+ $Block['identified'] = true;
+ }
+
+ if ($this->isBlockContinuable($blockType))
+ {
+ $Block['continuable'] = true;
+ }
+
+ $CurrentBlock = $Block;
+
+ continue 2;
+ }
+ }
+
+ # ~
+
+ if (isset($CurrentBlock) and ! isset($CurrentBlock['type']) and ! isset($CurrentBlock['interrupted']))
+ {
+ $CurrentBlock['element']['text'] .= "\n".$text;
+ }
+ else
+ {
+ $Blocks []= $CurrentBlock;
+
+ $CurrentBlock = $this->paragraph($Line);
+
+ $CurrentBlock['identified'] = true;
+ }
+ }
+
+ # ~
+
+ if (isset($CurrentBlock['continuable']) and $this->isBlockCompletable($CurrentBlock['type']))
+ {
+ $CurrentBlock = $this->{'block'.$CurrentBlock['type'].'Complete'}($CurrentBlock);
+ }
+
+ # ~
+
+ $Blocks []= $CurrentBlock;
+
+ unset($Blocks[0]);
+
+ # ~
+
+ $markup = '';
+
+ foreach ($Blocks as $Block)
+ {
+ if (isset($Block['hidden']))
+ {
+ continue;
+ }
+
+ $markup .= "\n";
+ $markup .= isset($Block['markup']) ? $Block['markup'] : $this->element($Block['element']);
+ }
+
+ $markup .= "\n";
+
+ # ~
+
+ return $markup;
+ }
+
+ protected function isBlockContinuable($Type)
+ {
+ return method_exists($this, 'block'.$Type.'Continue');
+ }
+
+ protected function isBlockCompletable($Type)
+ {
+ return method_exists($this, 'block'.$Type.'Complete');
+ }
+
+ #
+ # Code
+
+ protected function blockCode($Line, $Block = null)
+ {
+ if (isset($Block) and ! isset($Block['type']) and ! isset($Block['interrupted']))
+ {
+ return;
+ }
+
+ if ($Line['indent'] >= 4)
+ {
+ $text = substr($Line['body'], 4);
+
+ $Block = array(
+ 'element' => array(
+ 'name' => 'pre',
+ 'handler' => 'element',
+ 'text' => array(
+ 'name' => 'code',
+ 'text' => $text,
+ ),
+ ),
+ );
+
+ return $Block;
+ }
+ }
+
+ protected function blockCodeContinue($Line, $Block)
+ {
+ if ($Line['indent'] >= 4)
+ {
+ if (isset($Block['interrupted']))
+ {
+ $Block['element']['text']['text'] .= "\n";
+
+ unset($Block['interrupted']);
+ }
+
+ $Block['element']['text']['text'] .= "\n";
+
+ $text = substr($Line['body'], 4);
+
+ $Block['element']['text']['text'] .= $text;
+
+ return $Block;
+ }
+ }
+
+ protected function blockCodeComplete($Block)
+ {
+ $text = $Block['element']['text']['text'];
+
+ $Block['element']['text']['text'] = $text;
+
+ return $Block;
+ }
+
+ #
+ # Comment
+
+ protected function blockComment($Line)
+ {
+ if ($this->markupEscaped or $this->safeMode)
+ {
+ return;
+ }
+
+ if (isset($Line['text'][3]) and $Line['text'][3] === '-' and $Line['text'][2] === '-' and $Line['text'][1] === '!')
+ {
+ $Block = array(
+ 'markup' => $Line['body'],
+ );
+
+ if (preg_match('/-->$/', $Line['text']))
+ {
+ $Block['closed'] = true;
+ }
+
+ return $Block;
+ }
+ }
+
+ protected function blockCommentContinue($Line, array $Block)
+ {
+ if (isset($Block['closed']))
+ {
+ return;
+ }
+
+ $Block['markup'] .= "\n" . $Line['body'];
+
+ if (preg_match('/-->$/', $Line['text']))
+ {
+ $Block['closed'] = true;
+ }
+
+ return $Block;
+ }
+
+ #
+ # Fenced Code
+
+ protected function blockFencedCode($Line)
+ {
+ if (preg_match('/^['.$Line['text'][0].']{3,}[ ]*([^`]+)?[ ]*$/', $Line['text'], $matches))
+ {
+ $Element = array(
+ 'name' => 'code',
+ 'text' => '',
+ );
+
+ if (isset($matches[1]))
+ {
+ /**
+ * https://www.w3.org/TR/2011/WD-html5-20110525/elements.html#classes
+ * Every HTML element may have a class attribute specified.
+ * The attribute, if specified, must have a value that is a set
+ * of space-separated tokens representing the various classes
+ * that the element belongs to.
+ * [...]
+ * The space characters, for the purposes of this specification,
+ * are U+0020 SPACE, U+0009 CHARACTER TABULATION (tab),
+ * U+000A LINE FEED (LF), U+000C FORM FEED (FF), and
+ * U+000D CARRIAGE RETURN (CR).
+ */
+ $language = substr($matches[1], 0, strcspn($matches[1], " \t\n\f\r"));
+
+ $class = 'language-'.$language;
+
+ $Element['attributes'] = array(
+ 'class' => $class,
+ );
+ }
+
+ $Block = array(
+ 'char' => $Line['text'][0],
+ 'element' => array(
+ 'name' => 'pre',
+ 'handler' => 'element',
+ 'text' => $Element,
+ ),
+ );
+
+ return $Block;
+ }
+ }
+
+ protected function blockFencedCodeContinue($Line, $Block)
+ {
+ if (isset($Block['complete']))
+ {
+ return;
+ }
+
+ if (isset($Block['interrupted']))
+ {
+ $Block['element']['text']['text'] .= "\n";
+
+ unset($Block['interrupted']);
+ }
+
+ if (preg_match('/^'.$Block['char'].'{3,}[ ]*$/', $Line['text']))
+ {
+ $Block['element']['text']['text'] = substr($Block['element']['text']['text'], 1);
+
+ $Block['complete'] = true;
+
+ return $Block;
+ }
+
+ $Block['element']['text']['text'] .= "\n".$Line['body'];
+
+ return $Block;
+ }
+
+ protected function blockFencedCodeComplete($Block)
+ {
+ $text = $Block['element']['text']['text'];
+
+ $Block['element']['text']['text'] = $text;
+
+ return $Block;
+ }
+
+ #
+ # Header
+
+ protected function blockHeader($Line)
+ {
+ if (isset($Line['text'][1]))
+ {
+ $level = 1;
+
+ while (isset($Line['text'][$level]) and $Line['text'][$level] === '#')
+ {
+ $level ++;
+ }
+
+ if ($level > 6)
+ {
+ return;
+ }
+
+ $text = trim($Line['text'], '# ');
+
+ $Block = array(
+ 'element' => array(
+ 'name' => 'h' . min(6, $level),
+ 'text' => $text,
+ 'handler' => 'line',
+ ),
+ );
+
+ return $Block;
+ }
+ }
+
+ #
+ # List
+
+ protected function blockList($Line)
+ {
+ list($name, $pattern) = $Line['text'][0] <= '-' ? array('ul', '[*+-]') : array('ol', '[0-9]+[.]');
+
+ if (preg_match('/^('.$pattern.'[ ]+)(.*)/', $Line['text'], $matches))
+ {
+ $Block = array(
+ 'indent' => $Line['indent'],
+ 'pattern' => $pattern,
+ 'element' => array(
+ 'name' => $name,
+ 'handler' => 'elements',
+ ),
+ );
+
+ if($name === 'ol')
+ {
+ $listStart = stristr($matches[0], '.', true);
+
+ if($listStart !== '1')
+ {
+ $Block['element']['attributes'] = array('start' => $listStart);
+ }
+ }
+
+ $Block['li'] = array(
+ 'name' => 'li',
+ 'handler' => 'li',
+ 'text' => array(
+ $matches[2],
+ ),
+ );
+
+ $Block['element']['text'] []= & $Block['li'];
+
+ return $Block;
+ }
+ }
+
+ protected function blockListContinue($Line, array $Block)
+ {
+ if ($Block['indent'] === $Line['indent'] and preg_match('/^'.$Block['pattern'].'(?:[ ]+(.*)|$)/', $Line['text'], $matches))
+ {
+ if (isset($Block['interrupted']))
+ {
+ $Block['li']['text'] []= '';
+
+ $Block['loose'] = true;
+
+ unset($Block['interrupted']);
+ }
+
+ unset($Block['li']);
+
+ $text = isset($matches[1]) ? $matches[1] : '';
+
+ $Block['li'] = array(
+ 'name' => 'li',
+ 'handler' => 'li',
+ 'text' => array(
+ $text,
+ ),
+ );
+
+ $Block['element']['text'] []= & $Block['li'];
+
+ return $Block;
+ }
+
+ if ($Line['text'][0] === '[' and $this->blockReference($Line))
+ {
+ return $Block;
+ }
+
+ if ( ! isset($Block['interrupted']))
+ {
+ $text = preg_replace('/^[ ]{0,4}/', '', $Line['body']);
+
+ $Block['li']['text'] []= $text;
+
+ return $Block;
+ }
+
+ if ($Line['indent'] > 0)
+ {
+ $Block['li']['text'] []= '';
+
+ $text = preg_replace('/^[ ]{0,4}/', '', $Line['body']);
+
+ $Block['li']['text'] []= $text;
+
+ unset($Block['interrupted']);
+
+ return $Block;
+ }
+ }
+
+ protected function blockListComplete(array $Block)
+ {
+ if (isset($Block['loose']))
+ {
+ foreach ($Block['element']['text'] as &$li)
+ {
+ if (end($li['text']) !== '')
+ {
+ $li['text'] []= '';
+ }
+ }
+ }
+
+ return $Block;
+ }
+
+ #
+ # Quote
+
+ protected function blockQuote($Line)
+ {
+ if (preg_match('/^>[ ]?(.*)/', $Line['text'], $matches))
+ {
+ $Block = array(
+ 'element' => array(
+ 'name' => 'blockquote',
+ 'handler' => 'lines',
+ 'text' => (array) $matches[1],
+ ),
+ );
+
+ return $Block;
+ }
+ }
+
+ protected function blockQuoteContinue($Line, array $Block)
+ {
+ if ($Line['text'][0] === '>' and preg_match('/^>[ ]?(.*)/', $Line['text'], $matches))
+ {
+ if (isset($Block['interrupted']))
+ {
+ $Block['element']['text'] []= '';
+
+ unset($Block['interrupted']);
+ }
+
+ $Block['element']['text'] []= $matches[1];
+
+ return $Block;
+ }
+
+ if ( ! isset($Block['interrupted']))
+ {
+ $Block['element']['text'] []= $Line['text'];
+
+ return $Block;
+ }
+ }
+
+ #
+ # Rule
+
+ protected function blockRule($Line)
+ {
+ if (preg_match('/^(['.$Line['text'][0].'])([ ]*\1){2,}[ ]*$/', $Line['text']))
+ {
+ $Block = array(
+ 'element' => array(
+ 'name' => 'hr'
+ ),
+ );
+
+ return $Block;
+ }
+ }
+
+ #
+ # Setext
+
+ protected function blockSetextHeader($Line, array $Block = null)
+ {
+ if ( ! isset($Block) or isset($Block['type']) or isset($Block['interrupted']))
+ {
+ return;
+ }
+
+ if (chop($Line['text'], $Line['text'][0]) === '')
+ {
+ $Block['element']['name'] = $Line['text'][0] === '=' ? 'h1' : 'h2';
+
+ return $Block;
+ }
+ }
+
+ #
+ # Markup
+
+ protected function blockMarkup($Line)
+ {
+ if ($this->markupEscaped or $this->safeMode)
+ {
+ return;
+ }
+
+ if (preg_match('/^<(\w[\w-]*)(?:[ ]*'.$this->regexHtmlAttribute.')*[ ]*(\/)?>/', $Line['text'], $matches))
+ {
+ $element = strtolower($matches[1]);
+
+ if (in_array($element, $this->textLevelElements))
+ {
+ return;
+ }
+
+ $Block = array(
+ 'name' => $matches[1],
+ 'depth' => 0,
+ 'markup' => $Line['text'],
+ );
+
+ $length = strlen($matches[0]);
+
+ $remainder = substr($Line['text'], $length);
+
+ if (trim($remainder) === '')
+ {
+ if (isset($matches[2]) or in_array($matches[1], $this->voidElements))
+ {
+ $Block['closed'] = true;
+
+ $Block['void'] = true;
+ }
+ }
+ else
+ {
+ if (isset($matches[2]) or in_array($matches[1], $this->voidElements))
+ {
+ return;
+ }
+
+ if (preg_match('/<\/'.$matches[1].'>[ ]*$/i', $remainder))
+ {
+ $Block['closed'] = true;
+ }
+ }
+
+ return $Block;
+ }
+ }
+
+ protected function blockMarkupContinue($Line, array $Block)
+ {
+ if (isset($Block['closed']))
+ {
+ return;
+ }
+
+ if (preg_match('/^<'.$Block['name'].'(?:[ ]*'.$this->regexHtmlAttribute.')*[ ]*>/i', $Line['text'])) # open
+ {
+ $Block['depth'] ++;
+ }
+
+ if (preg_match('/(.*?)<\/'.$Block['name'].'>[ ]*$/i', $Line['text'], $matches)) # close
+ {
+ if ($Block['depth'] > 0)
+ {
+ $Block['depth'] --;
+ }
+ else
+ {
+ $Block['closed'] = true;
+ }
+ }
+
+ if (isset($Block['interrupted']))
+ {
+ $Block['markup'] .= "\n";
+
+ unset($Block['interrupted']);
+ }
+
+ $Block['markup'] .= "\n".$Line['body'];
+
+ return $Block;
+ }
+
+ #
+ # Reference
+
+ protected function blockReference($Line)
+ {
+ if (preg_match('/^\[(.+?)\]:[ ]*(\S+?)>?(?:[ ]+["\'(](.+)["\')])?[ ]*$/', $Line['text'], $matches))
+ {
+ $id = strtolower($matches[1]);
+
+ $Data = array(
+ 'url' => $matches[2],
+ 'title' => null,
+ );
+
+ if (isset($matches[3]))
+ {
+ $Data['title'] = $matches[3];
+ }
+
+ $this->DefinitionData['Reference'][$id] = $Data;
+
+ $Block = array(
+ 'hidden' => true,
+ );
+
+ return $Block;
+ }
+ }
+
+ #
+ # Table
+
+ protected function blockTable($Line, array $Block = null)
+ {
+ if ( ! isset($Block) or isset($Block['type']) or isset($Block['interrupted']))
+ {
+ return;
+ }
+
+ if (strpos($Block['element']['text'], '|') !== false and chop($Line['text'], ' -:|') === '')
+ {
+ $alignments = array();
+
+ $divider = $Line['text'];
+
+ $divider = trim($divider);
+ $divider = trim($divider, '|');
+
+ $dividerCells = explode('|', $divider);
+
+ foreach ($dividerCells as $dividerCell)
+ {
+ $dividerCell = trim($dividerCell);
+
+ if ($dividerCell === '')
+ {
+ continue;
+ }
+
+ $alignment = null;
+
+ if ($dividerCell[0] === ':')
+ {
+ $alignment = 'left';
+ }
+
+ if (substr($dividerCell, - 1) === ':')
+ {
+ $alignment = $alignment === 'left' ? 'center' : 'right';
+ }
+
+ $alignments []= $alignment;
+ }
+
+ # ~
+
+ $HeaderElements = array();
+
+ $header = $Block['element']['text'];
+
+ $header = trim($header);
+ $header = trim($header, '|');
+
+ $headerCells = explode('|', $header);
+
+ foreach ($headerCells as $index => $headerCell)
+ {
+ $headerCell = trim($headerCell);
+
+ $HeaderElement = array(
+ 'name' => 'th',
+ 'text' => $headerCell,
+ 'handler' => 'line',
+ );
+
+ if (isset($alignments[$index]))
+ {
+ $alignment = $alignments[$index];
+
+ $HeaderElement['attributes'] = array(
+ 'style' => 'text-align: '.$alignment.';',
+ );
+ }
+
+ $HeaderElements []= $HeaderElement;
+ }
+
+ # ~
+
+ $Block = array(
+ 'alignments' => $alignments,
+ 'identified' => true,
+ 'element' => array(
+ 'name' => 'table',
+ 'handler' => 'elements',
+ ),
+ );
+
+ $Block['element']['text'] []= array(
+ 'name' => 'thead',
+ 'handler' => 'elements',
+ );
+
+ $Block['element']['text'] []= array(
+ 'name' => 'tbody',
+ 'handler' => 'elements',
+ 'text' => array(),
+ );
+
+ $Block['element']['text'][0]['text'] []= array(
+ 'name' => 'tr',
+ 'handler' => 'elements',
+ 'text' => $HeaderElements,
+ );
+
+ return $Block;
+ }
+ }
+
+ protected function blockTableContinue($Line, array $Block)
+ {
+ if (isset($Block['interrupted']))
+ {
+ return;
+ }
+
+ if ($Line['text'][0] === '|' or strpos($Line['text'], '|'))
+ {
+ $Elements = array();
+
+ $row = $Line['text'];
+
+ $row = trim($row);
+ $row = trim($row, '|');
+
+ preg_match_all('/(?:(\\\\[|])|[^|`]|`[^`]+`|`)+/', $row, $matches);
+
+ foreach ($matches[0] as $index => $cell)
+ {
+ $cell = trim($cell);
+
+ $Element = array(
+ 'name' => 'td',
+ 'handler' => 'line',
+ 'text' => $cell,
+ );
+
+ if (isset($Block['alignments'][$index]))
+ {
+ $Element['attributes'] = array(
+ 'style' => 'text-align: '.$Block['alignments'][$index].';',
+ );
+ }
+
+ $Elements []= $Element;
+ }
+
+ $Element = array(
+ 'name' => 'tr',
+ 'handler' => 'elements',
+ 'text' => $Elements,
+ );
+
+ $Block['element']['text'][1]['text'] []= $Element;
+
+ return $Block;
+ }
+ }
+
+ #
+ # ~
+ #
+
+ protected function paragraph($Line)
+ {
+ $Block = array(
+ 'element' => array(
+ 'name' => 'p',
+ 'text' => $Line['text'],
+ 'handler' => 'line',
+ ),
+ );
+
+ return $Block;
+ }
+
+ #
+ # Inline Elements
+ #
+
+ protected $InlineTypes = array(
+ '"' => array('SpecialCharacter'),
+ '!' => array('Image'),
+ '&' => array('SpecialCharacter'),
+ '*' => array('Emphasis'),
+ ':' => array('Url'),
+ '<' => array('UrlTag', 'EmailTag', 'Markup', 'SpecialCharacter'),
+ '>' => array('SpecialCharacter'),
+ '[' => array('Link'),
+ '_' => array('Emphasis'),
+ '`' => array('Code'),
+ '~' => array('Strikethrough'),
+ '\\' => array('EscapeSequence'),
+ );
+
+ # ~
+
+ protected $inlineMarkerList = '!"*_&[:<>`~\\';
+
+ #
+ # ~
+ #
+
+ public function line($text, $nonNestables=array())
+ {
+ $markup = '';
+
+ # $excerpt is based on the first occurrence of a marker
+
+ while ($excerpt = strpbrk($text, $this->inlineMarkerList))
+ {
+ $marker = $excerpt[0];
+
+ $markerPosition = strpos($text, $marker);
+
+ $Excerpt = array('text' => $excerpt, 'context' => $text);
+
+ foreach ($this->InlineTypes[$marker] as $inlineType)
+ {
+ # check to see if the current inline type is nestable in the current context
+
+ if ( ! empty($nonNestables) and in_array($inlineType, $nonNestables))
+ {
+ continue;
+ }
+
+ $Inline = $this->{'inline'.$inlineType}($Excerpt);
+
+ if ( ! isset($Inline))
+ {
+ continue;
+ }
+
+ # makes sure that the inline belongs to "our" marker
+
+ if (isset($Inline['position']) and $Inline['position'] > $markerPosition)
+ {
+ continue;
+ }
+
+ # sets a default inline position
+
+ if ( ! isset($Inline['position']))
+ {
+ $Inline['position'] = $markerPosition;
+ }
+
+ # cause the new element to 'inherit' our non nestables
+
+ foreach ($nonNestables as $non_nestable)
+ {
+ $Inline['element']['nonNestables'][] = $non_nestable;
+ }
+
+ # the text that comes before the inline
+ $unmarkedText = substr($text, 0, $Inline['position']);
+
+ # compile the unmarked text
+ $markup .= $this->unmarkedText($unmarkedText);
+
+ # compile the inline
+ $markup .= isset($Inline['markup']) ? $Inline['markup'] : $this->element($Inline['element']);
+
+ # remove the examined text
+ $text = substr($text, $Inline['position'] + $Inline['extent']);
+
+ continue 2;
+ }
+
+ # the marker does not belong to an inline
+
+ $unmarkedText = substr($text, 0, $markerPosition + 1);
+
+ $markup .= $this->unmarkedText($unmarkedText);
+
+ $text = substr($text, $markerPosition + 1);
+ }
+
+ $markup .= $this->unmarkedText($text);
+
+ return $markup;
+ }
+
+ #
+ # ~
+ #
+
+ protected function inlineCode($Excerpt)
+ {
+ $marker = $Excerpt['text'][0];
+
+ if (preg_match('/^('.$marker.'+)[ ]*(.+?)[ ]*(? strlen($matches[0]),
+ 'element' => array(
+ 'name' => 'code',
+ 'text' => $text,
+ ),
+ );
+ }
+ }
+
+ protected function inlineEmailTag($Excerpt)
+ {
+ if (strpos($Excerpt['text'], '>') !== false and preg_match('/^<((mailto:)?\S+?@\S+?)>/i', $Excerpt['text'], $matches))
+ {
+ $url = $matches[1];
+
+ if ( ! isset($matches[2]))
+ {
+ $url = 'mailto:' . $url;
+ }
+
+ return array(
+ 'extent' => strlen($matches[0]),
+ 'element' => array(
+ 'name' => 'a',
+ 'text' => $matches[1],
+ 'attributes' => array(
+ 'href' => $url,
+ ),
+ ),
+ );
+ }
+ }
+
+ protected function inlineEmphasis($Excerpt)
+ {
+ if ( ! isset($Excerpt['text'][1]))
+ {
+ return;
+ }
+
+ $marker = $Excerpt['text'][0];
+
+ if ($Excerpt['text'][1] === $marker and preg_match($this->StrongRegex[$marker], $Excerpt['text'], $matches))
+ {
+ $emphasis = 'strong';
+ }
+ elseif (preg_match($this->EmRegex[$marker], $Excerpt['text'], $matches))
+ {
+ $emphasis = 'em';
+ }
+ else
+ {
+ return;
+ }
+
+ return array(
+ 'extent' => strlen($matches[0]),
+ 'element' => array(
+ 'name' => $emphasis,
+ 'handler' => 'line',
+ 'text' => $matches[1],
+ ),
+ );
+ }
+
+ protected function inlineEscapeSequence($Excerpt)
+ {
+ if (isset($Excerpt['text'][1]) and in_array($Excerpt['text'][1], $this->specialCharacters))
+ {
+ return array(
+ 'markup' => $Excerpt['text'][1],
+ 'extent' => 2,
+ );
+ }
+ }
+
+ protected function inlineImage($Excerpt)
+ {
+ if ( ! isset($Excerpt['text'][1]) or $Excerpt['text'][1] !== '[')
+ {
+ return;
+ }
+
+ $Excerpt['text']= substr($Excerpt['text'], 1);
+
+ $Link = $this->inlineLink($Excerpt);
+
+ if ($Link === null)
+ {
+ return;
+ }
+
+ $Inline = array(
+ 'extent' => $Link['extent'] + 1,
+ 'element' => array(
+ 'name' => 'img',
+ 'attributes' => array(
+ 'src' => $Link['element']['attributes']['href'],
+ 'alt' => $Link['element']['text'],
+ ),
+ ),
+ );
+
+ $Inline['element']['attributes'] += $Link['element']['attributes'];
+
+ unset($Inline['element']['attributes']['href']);
+
+ return $Inline;
+ }
+
+ protected function inlineLink($Excerpt)
+ {
+ $Element = array(
+ 'name' => 'a',
+ 'handler' => 'line',
+ 'nonNestables' => array('Url', 'Link'),
+ 'text' => null,
+ 'attributes' => array(
+ 'href' => null,
+ 'title' => null,
+ ),
+ );
+
+ $extent = 0;
+
+ $remainder = $Excerpt['text'];
+
+ if (preg_match('/\[((?:[^][]++|(?R))*+)\]/', $remainder, $matches))
+ {
+ $Element['text'] = $matches[1];
+
+ $extent += strlen($matches[0]);
+
+ $remainder = substr($remainder, $extent);
+ }
+ else
+ {
+ return;
+ }
+
+ if (preg_match('/^[(]\s*+((?:[^ ()]++|[(][^ )]+[)])++)(?:[ ]+("[^"]*"|\'[^\']*\'))?\s*[)]/', $remainder, $matches))
+ {
+ $Element['attributes']['href'] = $matches[1];
+
+ if (isset($matches[2]))
+ {
+ $Element['attributes']['title'] = substr($matches[2], 1, - 1);
+ }
+
+ $extent += strlen($matches[0]);
+ }
+ else
+ {
+ if (preg_match('/^\s*\[(.*?)\]/', $remainder, $matches))
+ {
+ $definition = strlen($matches[1]) ? $matches[1] : $Element['text'];
+ $definition = strtolower($definition);
+
+ $extent += strlen($matches[0]);
+ }
+ else
+ {
+ $definition = strtolower($Element['text']);
+ }
+
+ if ( ! isset($this->DefinitionData['Reference'][$definition]))
+ {
+ return;
+ }
+
+ $Definition = $this->DefinitionData['Reference'][$definition];
+
+ $Element['attributes']['href'] = $Definition['url'];
+ $Element['attributes']['title'] = $Definition['title'];
+ }
+
+ return array(
+ 'extent' => $extent,
+ 'element' => $Element,
+ );
+ }
+
+ protected function inlineMarkup($Excerpt)
+ {
+ if ($this->markupEscaped or $this->safeMode or strpos($Excerpt['text'], '>') === false)
+ {
+ return;
+ }
+
+ if ($Excerpt['text'][1] === '/' and preg_match('/^<\/\w[\w-]*[ ]*>/s', $Excerpt['text'], $matches))
+ {
+ return array(
+ 'markup' => $matches[0],
+ 'extent' => strlen($matches[0]),
+ );
+ }
+
+ if ($Excerpt['text'][1] === '!' and preg_match('/^/s', $Excerpt['text'], $matches))
+ {
+ return array(
+ 'markup' => $matches[0],
+ 'extent' => strlen($matches[0]),
+ );
+ }
+
+ if ($Excerpt['text'][1] !== ' ' and preg_match('/^<\w[\w-]*(?:[ ]*'.$this->regexHtmlAttribute.')*[ ]*\/?>/s', $Excerpt['text'], $matches))
+ {
+ return array(
+ 'markup' => $matches[0],
+ 'extent' => strlen($matches[0]),
+ );
+ }
+ }
+
+ protected function inlineSpecialCharacter($Excerpt)
+ {
+ if ($Excerpt['text'][0] === '&' and ! preg_match('/^?\w+;/', $Excerpt['text']))
+ {
+ return array(
+ 'markup' => '&',
+ 'extent' => 1,
+ );
+ }
+
+ $SpecialCharacter = array('>' => 'gt', '<' => 'lt', '"' => 'quot');
+
+ if (isset($SpecialCharacter[$Excerpt['text'][0]]))
+ {
+ return array(
+ 'markup' => '&'.$SpecialCharacter[$Excerpt['text'][0]].';',
+ 'extent' => 1,
+ );
+ }
+ }
+
+ protected function inlineStrikethrough($Excerpt)
+ {
+ if ( ! isset($Excerpt['text'][1]))
+ {
+ return;
+ }
+
+ if ($Excerpt['text'][1] === '~' and preg_match('/^~~(?=\S)(.+?)(?<=\S)~~/', $Excerpt['text'], $matches))
+ {
+ return array(
+ 'extent' => strlen($matches[0]),
+ 'element' => array(
+ 'name' => 'del',
+ 'text' => $matches[1],
+ 'handler' => 'line',
+ ),
+ );
+ }
+ }
+
+ protected function inlineUrl($Excerpt)
+ {
+ if ($this->urlsLinked !== true or ! isset($Excerpt['text'][2]) or $Excerpt['text'][2] !== '/')
+ {
+ return;
+ }
+
+ if (preg_match('/\bhttps?:[\/]{2}[^\s<]+\b\/*/ui', $Excerpt['context'], $matches, PREG_OFFSET_CAPTURE))
+ {
+ $url = $matches[0][0];
+
+ $Inline = array(
+ 'extent' => strlen($matches[0][0]),
+ 'position' => $matches[0][1],
+ 'element' => array(
+ 'name' => 'a',
+ 'text' => $url,
+ 'attributes' => array(
+ 'href' => $url,
+ ),
+ ),
+ );
+
+ return $Inline;
+ }
+ }
+
+ protected function inlineUrlTag($Excerpt)
+ {
+ if (strpos($Excerpt['text'], '>') !== false and preg_match('/^<(\w+:\/{2}[^ >]+)>/i', $Excerpt['text'], $matches))
+ {
+ $url = $matches[1];
+
+ return array(
+ 'extent' => strlen($matches[0]),
+ 'element' => array(
+ 'name' => 'a',
+ 'text' => $url,
+ 'attributes' => array(
+ 'href' => $url,
+ ),
+ ),
+ );
+ }
+ }
+
+ # ~
+
+ protected function unmarkedText($text)
+ {
+ if ($this->breaksEnabled)
+ {
+ $text = preg_replace('/[ ]*\n/', " \n", $text);
+ }
+ else
+ {
+ $text = preg_replace('/(?:[ ][ ]+|[ ]*\\\\)\n/', " \n", $text);
+ $text = str_replace(" \n", "\n", $text);
+ }
+
+ return $text;
+ }
+
+ #
+ # Handlers
+ #
+
+ protected function element(array $Element)
+ {
+ if ($this->safeMode)
+ {
+ $Element = $this->sanitiseElement($Element);
+ }
+
+ $markup = '<'.$Element['name'];
+
+ if (isset($Element['attributes']))
+ {
+ foreach ($Element['attributes'] as $name => $value)
+ {
+ if ($value === null)
+ {
+ continue;
+ }
+
+ $markup .= ' '.$name.'="'.self::escape($value).'"';
+ }
+ }
+
+ $permitRawHtml = false;
+
+ if (isset($Element['text']))
+ {
+ $text = $Element['text'];
+ }
+ // very strongly consider an alternative if you're writing an
+ // extension
+ elseif (isset($Element['rawHtml']))
+ {
+ $text = $Element['rawHtml'];
+ $allowRawHtmlInSafeMode = isset($Element['allowRawHtmlInSafeMode']) && $Element['allowRawHtmlInSafeMode'];
+ $permitRawHtml = !$this->safeMode || $allowRawHtmlInSafeMode;
+ }
+
+ if (isset($text))
+ {
+ $markup .= '>';
+
+ if (!isset($Element['nonNestables']))
+ {
+ $Element['nonNestables'] = array();
+ }
+
+ if (isset($Element['handler']))
+ {
+ $markup .= $this->{$Element['handler']}($text, $Element['nonNestables']);
+ }
+ elseif (!$permitRawHtml)
+ {
+ $markup .= self::escape($text, true);
+ }
+ else
+ {
+ $markup .= $text;
+ }
+
+ $markup .= ''.$Element['name'].'>';
+ }
+ else
+ {
+ $markup .= ' />';
+ }
+
+ return $markup;
+ }
+
+ protected function elements(array $Elements)
+ {
+ $markup = '';
+
+ foreach ($Elements as $Element)
+ {
+ $markup .= "\n" . $this->element($Element);
+ }
+
+ $markup .= "\n";
+
+ return $markup;
+ }
+
+ # ~
+
+ protected function li($lines)
+ {
+ $markup = $this->lines($lines);
+
+ $trimmedMarkup = trim($markup);
+
+ if ( ! in_array('', $lines) and substr($trimmedMarkup, 0, 3) === '')
+ {
+ $markup = $trimmedMarkup;
+ $markup = substr($markup, 3);
+
+ $position = strpos($markup, "
");
+
+ $markup = substr_replace($markup, '', $position, 4);
+ }
+
+ return $markup;
+ }
+
+ #
+ # Deprecated Methods
+ #
+
+ function parse($text)
+ {
+ $markup = $this->text($text);
+
+ return $markup;
+ }
+
+ protected function sanitiseElement(array $Element)
+ {
+ static $goodAttribute = '/^[a-zA-Z0-9][a-zA-Z0-9-_]*+$/';
+ static $safeUrlNameToAtt = array(
+ 'a' => 'href',
+ 'img' => 'src',
+ );
+
+ if (isset($safeUrlNameToAtt[$Element['name']]))
+ {
+ $Element = $this->filterUnsafeUrlInAttribute($Element, $safeUrlNameToAtt[$Element['name']]);
+ }
+
+ if ( ! empty($Element['attributes']))
+ {
+ foreach ($Element['attributes'] as $att => $val)
+ {
+ # filter out badly parsed attribute
+ if ( ! preg_match($goodAttribute, $att))
+ {
+ unset($Element['attributes'][$att]);
+ }
+ # dump onevent attribute
+ elseif (self::striAtStart($att, 'on'))
+ {
+ unset($Element['attributes'][$att]);
+ }
+ }
+ }
+
+ return $Element;
+ }
+
+ protected function filterUnsafeUrlInAttribute(array $Element, $attribute)
+ {
+ foreach ($this->safeLinksWhitelist as $scheme)
+ {
+ if (self::striAtStart($Element['attributes'][$attribute], $scheme))
+ {
+ return $Element;
+ }
+ }
+
+ $Element['attributes'][$attribute] = str_replace(':', '%3A', $Element['attributes'][$attribute]);
+
+ return $Element;
+ }
+
+ #
+ # Static Methods
+ #
+
+ protected static function escape($text, $allowQuotes = false)
+ {
+ return htmlspecialchars($text, $allowQuotes ? ENT_NOQUOTES : ENT_QUOTES, 'UTF-8');
+ }
+
+ protected static function striAtStart($string, $needle)
+ {
+ $len = strlen($needle);
+
+ if ($len > strlen($string))
+ {
+ return false;
+ }
+ else
+ {
+ return strtolower(substr($string, 0, $len)) === strtolower($needle);
+ }
+ }
+
+ static function instance($name = 'default')
+ {
+ if (isset(self::$instances[$name]))
+ {
+ return self::$instances[$name];
+ }
+
+ $instance = new static();
+
+ self::$instances[$name] = $instance;
+
+ return $instance;
+ }
+
+ private static $instances = array();
+
+ #
+ # Fields
+ #
+
+ protected $DefinitionData;
+
+ #
+ # Read-Only
+
+ protected $specialCharacters = array(
+ '\\', '`', '*', '_', '{', '}', '[', ']', '(', ')', '>', '#', '+', '-', '.', '!', '|',
+ );
+
+ protected $StrongRegex = array(
+ '*' => '/^[*]{2}((?:\\\\\*|[^*]|[*][^*]*[*])+?)[*]{2}(?![*])/s',
+ '_' => '/^__((?:\\\\_|[^_]|_[^_]*_)+?)__(?!_)/us',
+ );
+
+ protected $EmRegex = array(
+ '*' => '/^[*]((?:\\\\\*|[^*]|[*][*][^*]+?[*][*])+?)[*](?![*])/s',
+ '_' => '/^_((?:\\\\_|[^_]|__[^_]*__)+?)_(?!_)\b/us',
+ );
+
+ protected $regexHtmlAttribute = '[a-zA-Z_:][\w:.-]*(?:\s*=\s*(?:[^"\'=<>`\s]+|"[^"]*"|\'[^\']*\'))?';
+
+ protected $voidElements = array(
+ 'area', 'base', 'br', 'col', 'command', 'embed', 'hr', 'img', 'input', 'link', 'meta', 'param', 'source',
+ );
+
+ protected $textLevelElements = array(
+ 'a', 'br', 'bdo', 'abbr', 'blink', 'nextid', 'acronym', 'basefont',
+ 'b', 'em', 'big', 'cite', 'small', 'spacer', 'listing',
+ 'i', 'rp', 'del', 'code', 'strike', 'marquee',
+ 'q', 'rt', 'ins', 'font', 'strong',
+ 's', 'tt', 'kbd', 'mark',
+ 'u', 'xm', 'sub', 'nobr',
+ 'sup', 'ruby',
+ 'var', 'span',
+ 'wbr', 'time',
+ );
+}
diff --git a/vendor/erusev/parsedown/README.md b/vendor/erusev/parsedown/README.md
new file mode 100644
index 000000000..b5d9ed2ee
--- /dev/null
+++ b/vendor/erusev/parsedown/README.md
@@ -0,0 +1,86 @@
+> I also make [Caret](https://caret.io?ref=parsedown) - a Markdown editor for Mac and PC.
+
+## Parsedown
+
+[](https://travis-ci.org/erusev/parsedown)
+
+
+Better Markdown Parser in PHP
+
+[Demo](http://parsedown.org/demo) |
+[Benchmarks](http://parsedown.org/speed) |
+[Tests](http://parsedown.org/tests/) |
+[Documentation](https://github.com/erusev/parsedown/wiki/)
+
+### Features
+
+* One File
+* No Dependencies
+* Super Fast
+* Extensible
+* [GitHub flavored](https://help.github.com/articles/github-flavored-markdown)
+* Tested in 5.3 to 7.1 and in HHVM
+* [Markdown Extra extension](https://github.com/erusev/parsedown-extra)
+
+### Installation
+
+Include `Parsedown.php` or install [the composer package](https://packagist.org/packages/erusev/parsedown).
+
+### Example
+
+``` php
+$Parsedown = new Parsedown();
+
+echo $Parsedown->text('Hello _Parsedown_!'); # prints: Hello Parsedown !
+```
+
+More examples in [the wiki](https://github.com/erusev/parsedown/wiki/) and in [this video tutorial](http://youtu.be/wYZBY8DEikI).
+
+### Security
+
+Parsedown is capable of escaping user-input within the HTML that it generates. Additionally Parsedown will apply sanitisation to additional scripting vectors (such as scripting link destinations) that are introduced by the markdown syntax itself.
+
+To tell Parsedown that it is processing untrusted user-input, use the following:
+```php
+$parsedown = new Parsedown;
+$parsedown->setSafeMode(true);
+```
+
+If instead, you wish to allow HTML within untrusted user-input, but still want output to be free from XSS it is recommended that you make use of a HTML sanitiser that allows HTML tags to be whitelisted, like [HTML Purifier](http://htmlpurifier.org/).
+
+In both cases you should strongly consider employing defence-in-depth measures, like [deploying a Content-Security-Policy](https://scotthelme.co.uk/content-security-policy-an-introduction/) (a browser security feature) so that your page is likely to be safe even if an attacker finds a vulnerability in one of the first lines of defence above.
+
+#### Security of Parsedown Extensions
+
+Safe mode does not necessarily yield safe results when using extensions to Parsedown. Extensions should be evaluated on their own to determine their specific safety against XSS.
+
+### Escaping HTML
+> âš ï¸Â  **WARNING:** This method isn't safe from XSS!
+
+If you wish to escape HTML **in trusted input**, you can use the following:
+```php
+$parsedown = new Parsedown;
+$parsedown->setMarkupEscaped(true);
+```
+
+Beware that this still allows users to insert unsafe scripting vectors, such as links like `[xss](javascript:alert%281%29)`.
+
+### Questions
+
+**How does Parsedown work?**
+
+It tries to read Markdown like a human. First, it looks at the lines. It’s interested in how the lines start. This helps it recognise blocks. It knows, for example, that if a line starts with a `-` then perhaps it belongs to a list. Once it recognises the blocks, it continues to the content. As it reads, it watches out for special characters. This helps it recognise inline elements (or inlines).
+
+We call this approach "line based". We believe that Parsedown is the first Markdown parser to use it. Since the release of Parsedown, other developers have used the same approach to develop other Markdown parsers in PHP and in other languages.
+
+**Is it compliant with CommonMark?**
+
+It passes most of the CommonMark tests. Most of the tests that don't pass deal with cases that are quite uncommon. Still, as CommonMark matures, compliance should improve.
+
+**Who uses it?**
+
+[Laravel Framework](https://laravel.com/), [Bolt CMS](http://bolt.cm/), [Grav CMS](http://getgrav.org/), [Herbie CMS](http://www.getherbie.org/), [Kirby CMS](http://getkirby.com/), [October CMS](http://octobercms.com/), [Pico CMS](http://picocms.org), [Statamic CMS](http://www.statamic.com/), [phpDocumentor](http://www.phpdoc.org/), [RaspberryPi.org](http://www.raspberrypi.org/), [Symfony demo](https://github.com/symfony/symfony-demo) and [more](https://packagist.org/packages/erusev/parsedown/dependents).
+
+**How can I help?**
+
+Use it, star it, share it and if you feel generous, [donate](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=528P3NZQMP8N2).
diff --git a/vendor/erusev/parsedown/composer.json b/vendor/erusev/parsedown/composer.json
new file mode 100644
index 000000000..f8b40f8ce
--- /dev/null
+++ b/vendor/erusev/parsedown/composer.json
@@ -0,0 +1,33 @@
+{
+ "name": "erusev/parsedown",
+ "description": "Parser for Markdown.",
+ "keywords": ["markdown", "parser"],
+ "homepage": "http://parsedown.org",
+ "type": "library",
+ "license": "MIT",
+ "authors": [
+ {
+ "name": "Emanuil Rusev",
+ "email": "hello@erusev.com",
+ "homepage": "http://erusev.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.3.0",
+ "ext-mbstring": "*"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "^4.8.35"
+ },
+ "autoload": {
+ "psr-0": {"Parsedown": ""}
+ },
+ "autoload-dev": {
+ "psr-0": {
+ "TestParsedown": "test/",
+ "ParsedownTest": "test/",
+ "CommonMarkTest": "test/",
+ "CommonMarkTestWeak": "test/"
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/.github/ISSUE_TEMPLATE/bug_report.md b/vendor/fzaninotto/faker/.github/ISSUE_TEMPLATE/bug_report.md
new file mode 100644
index 000000000..3e8543bcd
--- /dev/null
+++ b/vendor/fzaninotto/faker/.github/ISSUE_TEMPLATE/bug_report.md
@@ -0,0 +1,39 @@
+---
+name: Bug report
+about: Create a report to help us improve
+title: ''
+labels: ''
+assignees: ''
+
+---
+
+### Summary
+
+
+
+### Versions
+
+
+
+| | Version |
+|:--------------------|:--------|
+| PHP | x.y.z |
+| `fzaninotto/faker` | x.y.z |
+
+### Self-enclosed code snippet for reproduction
+
+```php
+
+```
+
+### Expected output
+
+```txt
+
+```
+
+### Actual output
+
+```txt
+
+```
diff --git a/vendor/fzaninotto/faker/.travis/xdebug.sh b/vendor/fzaninotto/faker/.travis/xdebug.sh
new file mode 100644
index 000000000..c3cebe3c6
--- /dev/null
+++ b/vendor/fzaninotto/faker/.travis/xdebug.sh
@@ -0,0 +1,22 @@
+#!/usr/bin/env bash
+
+# The problem is that we do not want to remove the configuration file, just disable it for a few tasks, then enable it
+#
+# For reference, see
+#
+# - https://docs.travis-ci.com/user/languages/php#Disabling-preinstalled-PHP-extensions
+# - https://docs.travis-ci.com/user/languages/php#Custom-PHP-configuration
+
+config="/home/travis/.phpenv/versions/$(phpenv version-name)/etc/conf.d/xdebug.ini"
+
+function xdebug-disable() {
+ if [[ -f $config ]]; then
+ mv $config "$config.bak"
+ fi
+}
+
+function xdebug-enable() {
+ if [[ -f "$config.bak" ]]; then
+ mv "$config.bak" $config
+ fi
+}
diff --git a/vendor/fzaninotto/faker/CHANGELOG.md b/vendor/fzaninotto/faker/CHANGELOG.md
new file mode 100644
index 000000000..d27a7bed9
--- /dev/null
+++ b/vendor/fzaninotto/faker/CHANGELOG.md
@@ -0,0 +1,744 @@
+# CHANGELOG
+
+## 2019-12-03, v1.9.1
+
+- Add link to PHPStan extension to readme [\#1834](https://github.com/fzaninotto/Faker/pull/1834) ([finwe](https://github.com/finwe))
+- Enhancement: Collect code coverage [\#1824](https://github.com/fzaninotto/Faker/pull/1824) ([localheinz](https://github.com/localheinz))
+- Enhancement: Use all columns when running tests [\#1823](https://github.com/fzaninotto/Faker/pull/1823) ([localheinz](https://github.com/localheinz))
+- Enhancement: Configure verbose output via phpunit.xml.dist [\#1822](https://github.com/fzaninotto/Faker/pull/1822) ([localheinz](https://github.com/localheinz))
+- Curly braces for arrays is deprecated in PHP 7.4 [\#1843](https://github.com/fzaninotto/Faker/pull/1843) ([wimg](https://github.com/wimg))
+- Fix: Reduce visibility of setUp\(\) and tearDown\(\) [\#1821](https://github.com/fzaninotto/Faker/pull/1821) ([localheinz](https://github.com/localheinz))
+- Fix: Mark test classes as final [\#1820](https://github.com/fzaninotto/Faker/pull/1820) ([localheinz](https://github.com/localheinz))
+- Fix: Remove unnecessary class-level DocBlocks [\#1819](https://github.com/fzaninotto/Faker/pull/1819) ([localheinz](https://github.com/localheinz))
+
+## 2019-11-10, v1.9.0
+
+This will the last minor release in the `1.x` cycle.
+
+- Add all Iran's provinces land lines numbers [\#1806](https://github.com/fzaninotto/Faker/pull/1806) ([kingofnull](https://github.com/kingofnull))
+- replace latin "B" to cyrillic "B" for uk\_UA locale [\#1800](https://github.com/fzaninotto/Faker/pull/1800) ([FI-LIFE](https://github.com/FI-LIFE))
+- Add elgentos/masquerade to third-party library list [\#1798](https://github.com/fzaninotto/Faker/pull/1798) ([erikhansen](https://github.com/erikhansen))
+- Add link to Gravatar provider repository [\#1796](https://github.com/fzaninotto/Faker/pull/1796) ([ottaviano](https://github.com/ottaviano))
+- Add mobileNumber\(\) method for nb\_NO [\#1788](https://github.com/fzaninotto/Faker/pull/1788) ([carestad](https://github.com/carestad))
+- Enhancement: Slightly clean up Company provider [\#1783](https://github.com/fzaninotto/Faker/pull/1783) ([localheinz](https://github.com/localheinz))
+- Added some more information for autoloading in the readme [\#1780](https://github.com/fzaninotto/Faker/pull/1780) ([pimjansen](https://github.com/pimjansen))
+- Enhancement: Add issue template for bug report [\#1779](https://github.com/fzaninotto/Faker/pull/1779) ([localheinz](https://github.com/localheinz))
+- Add hslColor to ColorProvider [\#1776](https://github.com/fzaninotto/Faker/pull/1776) ([icanhazstring](https://github.com/icanhazstring))
+- Enhancement: Consistently use composer package name for link content [\#1770](https://github.com/fzaninotto/Faker/pull/1770) ([localheinz](https://github.com/localheinz))
+- Add Correct Thai words for streets,soi etc names and add Thai First a… [\#1769](https://github.com/fzaninotto/Faker/pull/1769) ([pierrejoye](https://github.com/pierrejoye))
+- Enhancement: Assert that postcode generated by Austrian Address provider matches format [\#1766](https://github.com/fzaninotto/Faker/pull/1766) ([localheinz](https://github.com/localheinz))
+- Enhancement: Update squizlabs/php\_codesniffer [\#1763](https://github.com/fzaninotto/Faker/pull/1763) ([localheinz](https://github.com/localheinz))
+- Enhancement: Assert that imageUrl can be used with gray flag [\#1762](https://github.com/fzaninotto/Faker/pull/1762) ([localheinz](https://github.com/localheinz))
+- Enhancement: Introduce build and help targets [\#1761](https://github.com/fzaninotto/Faker/pull/1761) ([localheinz](https://github.com/localheinz))
+- Enhancement: Disable Xdebug as early as possible [\#1758](https://github.com/fzaninotto/Faker/pull/1758) ([localheinz](https://github.com/localheinz))
+- Enhancement: Clean up .gitattributes [\#1756](https://github.com/fzaninotto/Faker/pull/1756) ([localheinz](https://github.com/localheinz))
+- Enhancement: Reference phpunit.xsd as installed with composer [\#1755](https://github.com/fzaninotto/Faker/pull/1755) ([localheinz](https://github.com/localheinz))
+- add id\_ID Color [\#1754](https://github.com/fzaninotto/Faker/pull/1754) ([cacing69](https://github.com/cacing69))
+- PHP 7.4 compatibility [\#1748](https://github.com/fzaninotto/Faker/pull/1748) ([pimjansen](https://github.com/pimjansen))
+- Add lastName gender specific on ru\_RU locale [\#1747](https://github.com/fzaninotto/Faker/pull/1747) ([aanfarhan](https://github.com/aanfarhan))
+- Update README - Add a new faker. [\#1731](https://github.com/fzaninotto/Faker/pull/1731) ([drupol](https://github.com/drupol))
+- Add faker-eddy-malou third-party library [\#1717](https://github.com/fzaninotto/Faker/pull/1717) ([Metrakit](https://github.com/Metrakit))
+- \[de\_DE\] Company\JobTitle: list of common german job titles [\#1716](https://github.com/fzaninotto/Faker/pull/1716) ([amacado](https://github.com/amacado))
+- Added 'red' to $safeColorNames [\#1701](https://github.com/fzaninotto/Faker/pull/1701) ([xfudox](https://github.com/xfudox))
+- \[pt\_PT/Address\] Add abbreviature to 'travessa' and 'largo' [\#1606](https://github.com/fzaninotto/Faker/pull/1606) ([simaolemos](https://github.com/simaolemos))
+- Fix method name for en\_NZ provider in readme [\#1595](https://github.com/fzaninotto/Faker/pull/1595) ([gdhnz](https://github.com/gdhnz))
+- Refactoring of the TextTest class [\#1590](https://github.com/fzaninotto/Faker/pull/1590) ([stevegrunwell](https://github.com/stevegrunwell))
+- add gender variants for last name \[lt\_LT\] [\#1586](https://github.com/fzaninotto/Faker/pull/1586) ([ikerasLT](https://github.com/ikerasLT))
+- add .id TLD [\#1566](https://github.com/fzaninotto/Faker/pull/1566) ([ad3n](https://github.com/ad3n))
+- Add Color provider to es\_ES locale [\#1559](https://github.com/fzaninotto/Faker/pull/1559) ([juananruiz](https://github.com/juananruiz))
+- Enhancement: Keep packages sorted in composer.json [\#1551](https://github.com/fzaninotto/Faker/pull/1551) ([localheinz](https://github.com/localheinz))
+- Portuguese providers for Companies and Internet [\#1537](https://github.com/fzaninotto/Faker/pull/1537) ([promatik](https://github.com/promatik))
+- Improve Dutch company names [\#1529](https://github.com/fzaninotto/Faker/pull/1529) ([koole](https://github.com/koole))
+- Document randomDigitNot base formatter. [\#1514](https://github.com/fzaninotto/Faker/pull/1514) ([shawnlindstrom](https://github.com/shawnlindstrom))
+- Estonian names [\#1461](https://github.com/fzaninotto/Faker/pull/1461) ([much-rebel](https://github.com/much-rebel))
+- add birthplace support for ID nik generator [\#1451](https://github.com/fzaninotto/Faker/pull/1451) ([mikk150](https://github.com/mikk150))
+- List of banks in Brazil added [\#1427](https://github.com/fzaninotto/Faker/pull/1427) ([diegohenicka](https://github.com/diegohenicka))
+- Remove last names from the male first names array \(et\_EE\) [\#1799](https://github.com/fzaninotto/Faker/pull/1799) ([Mihkel100](https://github.com/Mihkel100))
+- Update out-of-date currency codes [\#1795](https://github.com/fzaninotto/Faker/pull/1795) ([Brindster](https://github.com/Brindster))
+- Floor is not always returning an int [\#1790](https://github.com/fzaninotto/Faker/pull/1790) ([pimjansen](https://github.com/pimjansen))
+- typo [\#1789](https://github.com/fzaninotto/Faker/pull/1789) ([enumag](https://github.com/enumag))
+- Added batch inserts for doctrine orm populate [\#1781](https://github.com/fzaninotto/Faker/pull/1781) ([pimjansen](https://github.com/pimjansen))
+- FIx: Avoid deprecation warning in newer CakePHP version [\#1777](https://github.com/fzaninotto/Faker/pull/1777) ([icanhazstring](https://github.com/icanhazstring))
+- Fix: Consistently link to GitHub repositories [\#1774](https://github.com/fzaninotto/Faker/pull/1774) ([localheinz](https://github.com/localheinz))
+- Fix: Name of package [\#1772](https://github.com/fzaninotto/Faker/pull/1772) ([localheinz](https://github.com/localheinz))
+- Remove BV and HM country codes. [\#1767](https://github.com/fzaninotto/Faker/pull/1767) ([oliverpool](https://github.com/oliverpool))
+- Fix: Remove sudo configuration [\#1760](https://github.com/fzaninotto/Faker/pull/1760) ([localheinz](https://github.com/localheinz))
+- Fix: Allow nightly builds to fail [\#1759](https://github.com/fzaninotto/Faker/pull/1759) ([localheinz](https://github.com/localheinz))
+- Fix: No need to update composer itself [\#1757](https://github.com/fzaninotto/Faker/pull/1757) ([localheinz](https://github.com/localheinz))
+- duplicate first name and last name removal [\#1729](https://github.com/fzaninotto/Faker/pull/1729) ([sagautam5](https://github.com/sagautam5))
+- Fix-Isreal--Israel [\#1724](https://github.com/fzaninotto/Faker/pull/1724) ([GitEvil](https://github.com/GitEvil))
+- fix\(issue-1721\): add phpdoc method and properties annotations for php… [\#1722](https://github.com/fzaninotto/Faker/pull/1722) ([lugus](https://github.com/lugus))
+- Typo in function PHPDoc [\#1711](https://github.com/fzaninotto/Faker/pull/1711) ([Dzhuneyt](https://github.com/Dzhuneyt))
+- Fix: Add allowed type DateTime to param annotation [\#1697](https://github.com/fzaninotto/Faker/pull/1697) ([localheinz](https://github.com/localheinz))
+- Calling a non static method as static not allowed. [\#1696](https://github.com/fzaninotto/Faker/pull/1696) ([wilco-1985](https://github.com/wilco-1985))
+- Bug Fix en\_SG mobile number generation [\#1658](https://github.com/fzaninotto/Faker/pull/1658) ([ziming](https://github.com/ziming))
+- Update ja\_JP Address Provider [\#1649](https://github.com/fzaninotto/Faker/pull/1649) ([atmngw](https://github.com/atmngw))
+- Fixed realText on ja\_JP locale broken, /u missing [\#1634](https://github.com/fzaninotto/Faker/pull/1634) ([mihit](https://github.com/mihit))
+- Removed comma and space from $firstNameMale for en\_IN [\#1608](https://github.com/fzaninotto/Faker/pull/1608) ([phpspider](https://github.com/phpspider))
+- Prevent Transliterator class autoloading [\#1575](https://github.com/fzaninotto/Faker/pull/1575) ([MontealegreLuis](https://github.com/MontealegreLuis))
+- building numbers in Germany never start with a zero or are zero [\#1530](https://github.com/fzaninotto/Faker/pull/1530) ([fostam](https://github.com/fostam))
+- Fixing sk\_SK men last names set [\#1459](https://github.com/fzaninotto/Faker/pull/1459) ([pavoltanuska](https://github.com/pavoltanuska))
+- Taiwan ID. The initial letter must be a capital letter. p-\>P [\#1434](https://github.com/fzaninotto/Faker/pull/1434) ([slawa-dev](https://github.com/slawa-dev))
+- Revert "Added 'red' to $safeColorNames" [\#1778](https://github.com/fzaninotto/Faker/pull/1778) ([fzaninotto](https://github.com/fzaninotto))
+- Added realText capability for fr\_CA [\#1686](https://github.com/fzaninotto/Faker/pull/1686) ([bobanum](https://github.com/bobanum))
+- Add loremflickr.com Provider to the thrid parties [\#1683](https://github.com/fzaninotto/Faker/pull/1683) ([xvladxtremal](https://github.com/xvladxtremal))
+- Add Undeclared Faker Instance to PhoneNumber Test in en\_NG [\#1682](https://github.com/fzaninotto/Faker/pull/1682) ([thearsalan](https://github.com/thearsalan))
+- PSR-2 updates to readme [\#1679](https://github.com/fzaninotto/Faker/pull/1679) ([b3none](https://github.com/b3none))
+- PHPDoc for `passthrough` function on Generator [\#1678](https://github.com/fzaninotto/Faker/pull/1678) ([tabakhase](https://github.com/tabakhase))
+- Make en\_CA Phone Provider Extend the en\_US One [\#1676](https://github.com/fzaninotto/Faker/pull/1676) ([darrylhein](https://github.com/darrylhein))
+- Add Valid National Code Generator to fa\_IR Person [\#1675](https://github.com/fzaninotto/Faker/pull/1675) ([thearsalan](https://github.com/thearsalan))
+- Updated readme.md: added a missing backslash [\#1673](https://github.com/fzaninotto/Faker/pull/1673) ([aubryfr](https://github.com/aubryfr))
+- Add 'Faker\Provider\en\_US\Company::catchPhrase' to ru\_RU locale [\#1668](https://github.com/fzaninotto/Faker/pull/1668) ([axklim](https://github.com/axklim))
+- Update deprecated \PHPUnit\_Framework\_TestCase with PHPUnit\Framework\TestCase [\#1664](https://github.com/fzaninotto/Faker/pull/1664) ([thewhit](https://github.com/thewhit))
+- Support populating Doctrine's immutable date types [\#1639](https://github.com/fzaninotto/Faker/pull/1639) ([voronkovich](https://github.com/voronkovich))
+- add titleMale and titleFemale method to all Person classes [\#1635](https://github.com/fzaninotto/Faker/pull/1635) ([RiverDanceGit](https://github.com/RiverDanceGit))
+- Minor typo fix [\#1631](https://github.com/fzaninotto/Faker/pull/1631) ([nhedger](https://github.com/nhedger))
+- Add link to er1z/fakemock [\#1622](https://github.com/fzaninotto/Faker/pull/1622) ([er1z](https://github.com/er1z))
+- Add Dutch \(nl\_NL\) job titles [\#1618](https://github.com/fzaninotto/Faker/pull/1618) ([SjorsO](https://github.com/SjorsO))
+- Exclude files and folder from release archive [\#1617](https://github.com/fzaninotto/Faker/pull/1617) ([ankurk91](https://github.com/ankurk91))
+- Update doc block [\#1615](https://github.com/fzaninotto/Faker/pull/1615) ([ankurk91](https://github.com/ankurk91))
+- Suggest PSR-4 compliant autoloader in comment [\#1614](https://github.com/fzaninotto/Faker/pull/1614) ([samnela](https://github.com/samnela))
+- Fix dateTimeBetween\(\) Argument on Generator phpdoc [\#1583](https://github.com/fzaninotto/Faker/pull/1583) ([hisomura](https://github.com/hisomura))
+- Fix Dutch typo [\#1580](https://github.com/fzaninotto/Faker/pull/1580) ([gizburdt](https://github.com/gizburdt))
+- Old city names changed to new ones [\#1578](https://github.com/fzaninotto/Faker/pull/1578) ([goszowski](https://github.com/goszowski))
+- Correct documentation [\#1571](https://github.com/fzaninotto/Faker/pull/1571) ([rquadling](https://github.com/rquadling))
+- Make $suffix protected not private in nl\_NL\Person provider [\#1561](https://github.com/fzaninotto/Faker/pull/1561) ([SpadXIII](https://github.com/SpadXIII))
+- Add PicsumPhotos Provider to the thrid parties [\#1560](https://github.com/fzaninotto/Faker/pull/1560) ([bluemmb](https://github.com/bluemmb))
+- fix austrian postal codes starting with invalid 0 [\#1545](https://github.com/fzaninotto/Faker/pull/1545) ([mpge](https://github.com/mpge))
+- Restore a random seed when the Generator is destroyed [\#1534](https://github.com/fzaninotto/Faker/pull/1534) ([lyrixx](https://github.com/lyrixx))
+- Add a swiss social security number \(AVS13\) generator [\#1533](https://github.com/fzaninotto/Faker/pull/1533) ([nhedger](https://github.com/nhedger))
+- Small tweaks [\#1526](https://github.com/fzaninotto/Faker/pull/1526) ([carusogabriel](https://github.com/carusogabriel))
+- fix ukraine first name person, delete space [\#1525](https://github.com/fzaninotto/Faker/pull/1525) ([Yasuslik](https://github.com/Yasuslik))
+- Removed unknown postcode [\#1440](https://github.com/fzaninotto/Faker/pull/1440) ([ayanozturk](https://github.com/ayanozturk))
+- Add more PhoneNumber options for es\_ES [\#1219](https://github.com/fzaninotto/Faker/pull/1219) ([driade](https://github.com/driade))
+- Fix duplication in uk\_UA male first names [\#1214](https://github.com/fzaninotto/Faker/pull/1214) ([fre5h](https://github.com/fre5h))
+- Added missing grayscale option/flag to Image provider [\#928](https://github.com/fzaninotto/Faker/pull/928) ([sebastianvilla](https://github.com/sebastianvilla))
+
+## 2018-07-12, v1.8.0
+
+- Typo in readme [\#1521](https://github.com/fzaninotto/Faker/pull/1521) ([jmhobbs](https://github.com/jmhobbs))
+- Replaced Hilll with Hill [\#1516](https://github.com/fzaninotto/Faker/pull/1516) ([MarkVaughn](https://github.com/MarkVaughn))
+- \[it\_IT\] Improve vat ID generated using official rules [\#1508](https://github.com/fzaninotto/Faker/pull/1508) ([mavimo](https://github.com/mavimo))
+- \[hu\_HU\] Address: Fix unnecessary new line in string [\#1507](https://github.com/fzaninotto/Faker/pull/1507) ([ntomka](https://github.com/ntomka))
+- add phone numer format [\#1506](https://github.com/fzaninotto/Faker/pull/1506) ([Enosh-Yu](https://github.com/Enosh-Yu))
+- Fix typo in fr\_CA Provider [\#1505](https://github.com/fzaninotto/Faker/pull/1505) ([ultreson](https://github.com/ultreson))
+- Add fake-car provider link [\#1497](https://github.com/fzaninotto/Faker/pull/1497) ([pelmered](https://github.com/pelmered))
+- create `passthrough` function [\#1493](https://github.com/fzaninotto/Faker/pull/1493) ([browner12](https://github.com/browner12))
+- update Polish bank list [\#1482](https://github.com/fzaninotto/Faker/pull/1482) ([IonBazan](https://github.com/IonBazan))
+- Update the parameters to check if the setter is callable [\#1470](https://github.com/fzaninotto/Faker/pull/1470) ([rossmitchell](https://github.com/rossmitchell))
+- Push the max date far into the future so the test can pass [\#1469](https://github.com/fzaninotto/Faker/pull/1469) ([rossmitchell](https://github.com/rossmitchell))
+- Update Address.php [\#1465](https://github.com/fzaninotto/Faker/pull/1465) ([Saibamen](https://github.com/Saibamen))
+- Turkish identity number for tr\_TR [\#1462](https://github.com/fzaninotto/Faker/pull/1462) ([aykutaras](https://github.com/aykutaras))
+- Fixing rare iin with 13-digits. [\#1450](https://github.com/fzaninotto/Faker/pull/1450) ([vadimonus](https://github.com/vadimonus))
+- Fix Polish PESEL faker [\#1449](https://github.com/fzaninotto/Faker/pull/1449) ([Dartui](https://github.com/Dartui))
+- Adds valid 08 number formats for fr\_FR [\#1439](https://github.com/fzaninotto/Faker/pull/1439) ([ppelgrims](https://github.com/ppelgrims))
+- Add YouTube provider link [\#1422](https://github.com/fzaninotto/Faker/pull/1422) ([aalaap](https://github.com/aalaap))
+- Update PHPDoc of the DateTime provider. [\#1419](https://github.com/fzaninotto/Faker/pull/1419) ([tomzx](https://github.com/tomzx))
+- Normalize name of variable [\#1412](https://github.com/fzaninotto/Faker/pull/1412) ([eaglewu](https://github.com/eaglewu))
+- Added "blockchain" to en-us company provider catchPhrase method [\#1411](https://github.com/fzaninotto/Faker/pull/1411) ([samoldenburg](https://github.com/samoldenburg))
+- Fix for Spot2 ORM EntityPopulator [\#1408](https://github.com/fzaninotto/Faker/pull/1408) ([michal-borek](https://github.com/michal-borek))
+- TH color name [\#1404](https://github.com/fzaninotto/Faker/pull/1404) ([Naruedom](https://github.com/Naruedom))
+- added Malaysia \[ms\_MY\] locale [\#1403](https://github.com/fzaninotto/Faker/pull/1403) ([kenfai](https://github.com/kenfai))
+- Implementation of the function that generates Brazilian area codes fixed. [\#1401](https://github.com/fzaninotto/Faker/pull/1401) ([jackmiras](https://github.com/jackmiras))
+- VISA retired the 13 digit PAN moved to new cardParams [\#1400](https://github.com/fzaninotto/Faker/pull/1400) ([hppycoder](https://github.com/hppycoder))
+- Remove unused variable inside closure [\#1395](https://github.com/fzaninotto/Faker/pull/1395) ([carusogabriel](https://github.com/carusogabriel))
+- .nz domain updates [\#1393](https://github.com/fzaninotto/Faker/pull/1393) ([xurizaemon](https://github.com/xurizaemon))
+- Add licenceCode method in the to es\_ES person provider [\#1392](https://github.com/fzaninotto/Faker/pull/1392) ([ffiguereo](https://github.com/ffiguereo))
+- allow `randomElements` to accept a Traversable object [\#1389](https://github.com/fzaninotto/Faker/pull/1389) ([browner12](https://github.com/browner12))
+- Doc: rg remove formatting [\#1387](https://github.com/fzaninotto/Faker/pull/1387) ([emtudo](https://github.com/emtudo))
+- Add numbers with start 4 [\#1386](https://github.com/fzaninotto/Faker/pull/1386) ([emtudo](https://github.com/emtudo))
+- update th\_TH mobile number format [\#1385](https://github.com/fzaninotto/Faker/pull/1385) ([earthpyy](https://github.com/earthpyy))
+- Translate country names for lv\_LV provider. [\#1383](https://github.com/fzaninotto/Faker/pull/1383) ([ronaldsgailis](https://github.com/ronaldsgailis))
+- Clean elses [\#1382](https://github.com/fzaninotto/Faker/pull/1382) ([carusogabriel](https://github.com/carusogabriel))
+- French vat formatter [\#1381](https://github.com/fzaninotto/Faker/pull/1381) ([ppelgrims](https://github.com/ppelgrims))
+- Replaces rtrim with preg\_replace [\#1380](https://github.com/fzaninotto/Faker/pull/1380) ([ppelgrims](https://github.com/ppelgrims))
+- Refactoring tests [\#1375](https://github.com/fzaninotto/Faker/pull/1375) ([carusogabriel](https://github.com/carusogabriel))
+- Added link in readme to provider FakerRestaurant [\#1374](https://github.com/fzaninotto/Faker/pull/1374) ([jzonta](https://github.com/jzonta))
+- Remove obsolete currency codes [\#1373](https://github.com/fzaninotto/Faker/pull/1373) ([tpraxl](https://github.com/tpraxl))
+- \[ru\_RU\] Updated countries and added source link [\#1372](https://github.com/fzaninotto/Faker/pull/1372) ([ilyahoilik](https://github.com/ilyahoilik))
+- Test against PHP 7.2 [\#1371](https://github.com/fzaninotto/Faker/pull/1371) ([carusogabriel](https://github.com/carusogabriel))
+- Feature: nl\_BE text provider [\#1370](https://github.com/fzaninotto/Faker/pull/1370) ([rauwebieten](https://github.com/rauwebieten))
+- default value for Payment::iban\(\) country code [\#1369](https://github.com/fzaninotto/Faker/pull/1369) ([madmanmax](https://github.com/madmanmax))
+- skip test failing on bigendian [\#1365](https://github.com/fzaninotto/Faker/pull/1365) ([remicollet](https://github.com/remicollet))
+- Update Person.php [\#1364](https://github.com/fzaninotto/Faker/pull/1364) ([majamusan](https://github.com/majamusan))
+- Prevent errors on private methods [\#1363](https://github.com/fzaninotto/Faker/pull/1363) ([petecoop](https://github.com/petecoop))
+- adds rijksregisternummer [\#1361](https://github.com/fzaninotto/Faker/pull/1361) ([ppelgrims](https://github.com/ppelgrims))
+- Add secondary address to fr\_FR provider [\#1356](https://github.com/fzaninotto/Faker/pull/1356) ([nicodmf](https://github.com/nicodmf))
+- Add company provider for tr\_TR [\#1355](https://github.com/fzaninotto/Faker/pull/1355) ([yuks](https://github.com/yuks))
+- nb\_NO provider updates [\#1350](https://github.com/fzaninotto/Faker/pull/1350) ([alexqhj](https://github.com/alexqhj))
+- only test available date range on 32-bit [\#1348](https://github.com/fzaninotto/Faker/pull/1348) ([remicollet](https://github.com/remicollet))
+- Bump PHPUnit version for namespace compatibility [\#1345](https://github.com/fzaninotto/Faker/pull/1345) ([carusogabriel](https://github.com/carusogabriel))
+- Use PSR-1 for PHPUnit TestCase [\#1344](https://github.com/fzaninotto/Faker/pull/1344) ([carusogabriel](https://github.com/carusogabriel))
+- Fix FR\_fr 07 prefix mobile number generation [\#1343](https://github.com/fzaninotto/Faker/pull/1343) ([svanpoeck](https://github.com/svanpoeck))
+- Update Text.php [\#1339](https://github.com/fzaninotto/Faker/pull/1339) ([gulaandrij](https://github.com/gulaandrij))
+- Add two new company type in the Swiss Provider [\#1336](https://github.com/fzaninotto/Faker/pull/1336) ([pvullioud](https://github.com/pvullioud))
+- Change symbol 'minus' with code 226 to 'minus' with code 45 [\#1333](https://github.com/fzaninotto/Faker/pull/1333) ([Negasus](https://github.com/Negasus))
+- \[sl\_SI\] Created provider for Company [\#1331](https://github.com/fzaninotto/Faker/pull/1331) ([alesvaupotic](https://github.com/alesvaupotic))
+- Update city name [\#1328](https://github.com/fzaninotto/Faker/pull/1328) ([s9801077](https://github.com/s9801077))
+- Fix \#1305 realText in some cases breaks last character [\#1326](https://github.com/fzaninotto/Faker/pull/1326) ([iamraccoon](https://github.com/iamraccoon))
+- Real Dutch postal codes [\#1323](https://github.com/fzaninotto/Faker/pull/1323) ([ametad](https://github.com/ametad))
+- Added male and female titles for the en\_ZA locale [\#1321](https://github.com/fzaninotto/Faker/pull/1321) ([ViGouRCanberra](https://github.com/ViGouRCanberra))
+- Add German Email Providers [\#1320](https://github.com/fzaninotto/Faker/pull/1320) ([Stoffo](https://github.com/Stoffo))
+- Fix "Resource temporarily unavailable" [\#1319](https://github.com/fzaninotto/Faker/pull/1319) ([eberkund](https://github.com/eberkund))
+- Introduced the ability to specify a default timezone... [\#1316](https://github.com/fzaninotto/Faker/pull/1316) ([telkins](https://github.com/telkins))
+- South African licence codes [\#1315](https://github.com/fzaninotto/Faker/pull/1315) ([royalmitten](https://github.com/royalmitten))
+- Fix with incorrect name city. [\#1309](https://github.com/fzaninotto/Faker/pull/1309) ([zzenmate](https://github.com/zzenmate))
+- Fixed type-o in readme under section about Language specific formatters [\#1302](https://github.com/fzaninotto/Faker/pull/1302) ([espenkn](https://github.com/espenkn))
+- Update Person.php [\#1298](https://github.com/fzaninotto/Faker/pull/1298) ([yappkahowe](https://github.com/yappkahowe))
+- Allow children classes to access self::$suffix [\#1296](https://github.com/fzaninotto/Faker/pull/1296) ([greg0ire](https://github.com/greg0ire))
+- Fix with namespace payment provider for uk\_UA [\#1293](https://github.com/fzaninotto/Faker/pull/1293) ([zzenmate](https://github.com/zzenmate))
+- Update zh\_TW text provider [\#1292](https://github.com/fzaninotto/Faker/pull/1292) ([s9801077](https://github.com/s9801077))
+- Fix CURL status code in ImageTest.php [\#1290](https://github.com/fzaninotto/Faker/pull/1290) ([Sanfra1407](https://github.com/Sanfra1407))
+- Tax Id for companies and new formats for es\_VE [\#1287](https://github.com/fzaninotto/Faker/pull/1287) ([DIOHz0r](https://github.com/DIOHz0r))
+- Added idNumber for nl\_NL [\#1283](https://github.com/fzaninotto/Faker/pull/1283) ([artorozenga](https://github.com/artorozenga))
+- Feature/en us company ein [\#1273](https://github.com/fzaninotto/Faker/pull/1273) ([zachflower](https://github.com/zachflower))
+
+## 2017-08-15, v1.7.0
+
+- Added more Ukrainian banks [\#1271](https://github.com/fzaninotto/Faker/pull/1271) ([iamraccoon](https://github.com/iamraccoon))
+- Hotfix/failing unit tests [\#1269](https://github.com/fzaninotto/Faker/pull/1269) ([zachflower](https://github.com/zachflower))
+- Lock Travis-CI environment to Ubuntu Precise [\#1268](https://github.com/fzaninotto/Faker/pull/1268) ([zachflower](https://github.com/zachflower))
+- Added Ukrainian job title [\#1267](https://github.com/fzaninotto/Faker/pull/1267) ([iamraccoon](https://github.com/iamraccoon))
+- Add compliant en\_US SSN generator [\#1266](https://github.com/fzaninotto/Faker/pull/1266) ([zachflower](https://github.com/zachflower))
+- Added more Ukrainian streets and removed irrelevant names. Added more Ukrainian mobile formats [\#1265](https://github.com/fzaninotto/Faker/pull/1265) ([iamraccoon](https://github.com/iamraccoon))
+- Add Internet Format for ja\_JP. [\#1260](https://github.com/fzaninotto/Faker/pull/1260) ([itigoppo](https://github.com/itigoppo))
+- rectify ISO 4217 codes [\#1258](https://github.com/fzaninotto/Faker/pull/1258) ([eidng8](https://github.com/eidng8))
+- Corrected of grammar of Ukrainian middlenames and test added [\#1257](https://github.com/fzaninotto/Faker/pull/1257) ([vladbuk](https://github.com/vladbuk))
+- Update ISO 4217 active codes [\#1251](https://github.com/fzaninotto/Faker/pull/1251) ([eidng8](https://github.com/eidng8))
+- Update Composer File [\#1248](https://github.com/fzaninotto/Faker/pull/1248) ([vinkla](https://github.com/vinkla))
+- Set capitals to false [\#1243](https://github.com/fzaninotto/Faker/pull/1243) ([Stichoza](https://github.com/Stichoza))
+- Use static instead of self [\#1242](https://github.com/fzaninotto/Faker/pull/1242) ([Stichoza](https://github.com/Stichoza))
+- Add VAT french format [\#1241](https://github.com/fzaninotto/Faker/pull/1241) ([baptistedonaux](https://github.com/baptistedonaux))
+- Add swedish job titles [\#1234](https://github.com/fzaninotto/Faker/pull/1234) ([vinkla](https://github.com/vinkla))
+- Name Simo shouldn't have comma in it [\#1230](https://github.com/fzaninotto/Faker/pull/1230) ([simoheinonen](https://github.com/simoheinonen))
+- Fix: Add method annotation for ValidGenerator [\#1223](https://github.com/fzaninotto/Faker/pull/1223) ([localheinz](https://github.com/localheinz))
+- Add real text for es\_ES [\#1220](https://github.com/fzaninotto/Faker/pull/1220) ([driade](https://github.com/driade))
+- Fix spelling errors [\#1218](https://github.com/fzaninotto/Faker/pull/1218) ([driade](https://github.com/driade))
+- Fix spelling errors [\#1217](https://github.com/fzaninotto/Faker/pull/1217) ([driade](https://github.com/driade))
+- Fixes typo [\#1212](https://github.com/fzaninotto/Faker/pull/1212) ([skullboner](https://github.com/skullboner))
+- Add Person::middleName for ru\_RU provider [\#1209](https://github.com/fzaninotto/Faker/pull/1209) ([JustBlackBird](https://github.com/JustBlackBird))
+- Fix creditCardDetails type hint [\#1208](https://github.com/fzaninotto/Faker/pull/1208) ([jejung](https://github.com/jejung))
+- Expand dictionaries for ru\_RU locale [\#1206](https://github.com/fzaninotto/Faker/pull/1206) ([pwsdotru](https://github.com/pwsdotru))
+- Fix ng\_NG to en\_NG [\#1205](https://github.com/fzaninotto/Faker/pull/1205) ([raphaeldealmeida](https://github.com/raphaeldealmeida))
+- Add INN and KPP support for ru\_RU locale [\#1204](https://github.com/fzaninotto/Faker/pull/1204) ([pwsdotru](https://github.com/pwsdotru))
+- Remove break line on pt\_PT Address format [\#1203](https://github.com/fzaninotto/Faker/pull/1203) ([raphaeldealmeida](https://github.com/raphaeldealmeida))
+- Fix syntax of phpdoc boolean property [\#1198](https://github.com/fzaninotto/Faker/pull/1198) ([pavelkovar](https://github.com/pavelkovar))
+- add en\_HK provider [\#1196](https://github.com/fzaninotto/Faker/pull/1196) ([miklcct](https://github.com/miklcct))
+- use secure https [\#1186](https://github.com/fzaninotto/Faker/pull/1186) ([jpuck](https://github.com/jpuck))
+- Add PhoneNumberFormat for ja\_JP. [\#1185](https://github.com/fzaninotto/Faker/pull/1185) ([itigoppo](https://github.com/itigoppo))
+- Fix: Add class-level method annotations for DateTime provider [\#1183](https://github.com/fzaninotto/Faker/pull/1183) ([localheinz](https://github.com/localheinz))
+- Add ar\_SA Color Provider [\#1182](https://github.com/fzaninotto/Faker/pull/1182) ([alhoqbani](https://github.com/alhoqbani))
+- Added uk\_UA Payment provider with bank name generator [\#1181](https://github.com/fzaninotto/Faker/pull/1181) ([spaghettimaster](https://github.com/spaghettimaster))
+- Typos [\#1177](https://github.com/fzaninotto/Faker/pull/1177) ([ankitpokhrel](https://github.com/ankitpokhrel))
+- Fix XML document example [\#1176](https://github.com/fzaninotto/Faker/pull/1176) ([ankitpokhrel](https://github.com/ankitpokhrel))
+- Added Emoji to Miscellaneous [\#1175](https://github.com/fzaninotto/Faker/pull/1175) ([thomasfdm](https://github.com/thomasfdm))
+- Typos and doc block fixes [\#1170](https://github.com/fzaninotto/Faker/pull/1170) ([ankitpokhrel](https://github.com/ankitpokhrel))
+- Rewrote deprecated `each\(\)` usage [\#1168](https://github.com/fzaninotto/Faker/pull/1168) ([hboomsma](https://github.com/hboomsma))
+- Refactor text method to remove duplication [\#1163](https://github.com/fzaninotto/Faker/pull/1163) ([ankitpokhrel](https://github.com/ankitpokhrel))
+- Generate valid individual identification numbers kk\_KZ [\#1161](https://github.com/fzaninotto/Faker/pull/1161) ([YerlenZhubangaliyev](https://github.com/YerlenZhubangaliyev))
+- Added Address and Company \[fa\_IR\] [\#1160](https://github.com/fzaninotto/Faker/pull/1160) ([thisissorna](https://github.com/thisissorna))
+- Add Peruvian DNI generator [\#1158](https://github.com/fzaninotto/Faker/pull/1158) ([jgwong](https://github.com/jgwong))
+- Removed double semicolon [\#1154](https://github.com/fzaninotto/Faker/pull/1154) ([pjona](https://github.com/pjona))
+- Add prefixes for nl\_NL [\#1151](https://github.com/fzaninotto/Faker/pull/1151) ([hyperized](https://github.com/hyperized))
+- Separated male and female names for sr\_RS locale. [\#1144](https://github.com/fzaninotto/Faker/pull/1144) ([bogdanpet](https://github.com/bogdanpet))
+- Add personal ID, VAT for zh\_TW [\#1135](https://github.com/fzaninotto/Faker/pull/1135) ([Dagolin](https://github.com/Dagolin))
+- Updating ninth digit on whole country [\#1132](https://github.com/fzaninotto/Faker/pull/1132) ([gpressutto5](https://github.com/gpressutto5))
+- Indian states added to en\_IN locale [\#1131](https://github.com/fzaninotto/Faker/pull/1131) ([jiveshsg](https://github.com/jiveshsg))
+- Add Text provider for ro\_MD [\#1129](https://github.com/fzaninotto/Faker/pull/1129) ([wecerny](https://github.com/wecerny))
+- Add strict to randomNumber example [\#1124](https://github.com/fzaninotto/Faker/pull/1124) ([leepownall](https://github.com/leepownall))
+- Say Eloquent is supported [\#1123](https://github.com/fzaninotto/Faker/pull/1123) ([guidocella](https://github.com/guidocella))
+- Link Eloquent Populator [\#1120](https://github.com/fzaninotto/Faker/pull/1120) ([guidocella](https://github.com/guidocella))
+- Removed dead code from Luhn.php [\#1118](https://github.com/fzaninotto/Faker/pull/1118) ([Newman101](https://github.com/Newman101))
+- Improve Internet::transliterate performance [\#1112](https://github.com/fzaninotto/Faker/pull/1112) ([dunglas](https://github.com/dunglas))
+- fix typo [\#1109](https://github.com/fzaninotto/Faker/pull/1109) ([johannesnagl](https://github.com/johannesnagl))
+- \[cs\_CZ\] Fixed Czech phone numbers [\#1108](https://github.com/fzaninotto/Faker/pull/1108) ([tomasbedrich](https://github.com/tomasbedrich))
+- Update MasterCard BIN Range [\#1103](https://github.com/fzaninotto/Faker/pull/1103) ([andysnell](https://github.com/andysnell))
+- Add biggest german cities [\#1102](https://github.com/fzaninotto/Faker/pull/1102) ([Konafets](https://github.com/Konafets))
+- Change postal code format for ko\_KR [\#1094](https://github.com/fzaninotto/Faker/pull/1094) ([coozplz](https://github.com/coozplz))
+- Introduced the ability to specify the timezone for dateTimeThis\*\(\) methods [\#1090](https://github.com/fzaninotto/Faker/pull/1090) ([telkins](https://github.com/telkins))
+- Fixed Issue \#1086 [\#1088](https://github.com/fzaninotto/Faker/pull/1088) ([Newman101](https://github.com/Newman101))
+- \[ja\_JP\]kana of Japanese name by gender. [\#1087](https://github.com/fzaninotto/Faker/pull/1087) ([itigoppo](https://github.com/itigoppo))
+- Fix unused code [\#1083](https://github.com/fzaninotto/Faker/pull/1083) ([borgogelli](https://github.com/borgogelli))
+- Amended permissions for en\_GB AddressTest.php [\#1071](https://github.com/fzaninotto/Faker/pull/1071) ([Newman101](https://github.com/Newman101))
+- Ensure unique IDs in randomHtml [\#1068](https://github.com/fzaninotto/Faker/pull/1068) ([vlakoff](https://github.com/vlakoff))
+- Updated \[de\_DE\] city names [\#1067](https://github.com/fzaninotto/Faker/pull/1067) ([plxx](https://github.com/plxx))
+- Update method signature in Generator phpdoc [\#1066](https://github.com/fzaninotto/Faker/pull/1066) ([vlakoff](https://github.com/vlakoff))
+- Add Thai providers [\#1065](https://github.com/fzaninotto/Faker/pull/1065) ([tuwannu](https://github.com/tuwannu))
+- \(Minor\) Fixed the default locale stated in the readme [\#1064](https://github.com/fzaninotto/Faker/pull/1064) ([taylankasap](https://github.com/taylankasap))
+- \[nl\_NL\] Make person provider behave more realistically [\#1061](https://github.com/fzaninotto/Faker/pull/1061) ([curry684](https://github.com/curry684))
+- Add allowDuplicates option to randomElements\(\) [\#1060](https://github.com/fzaninotto/Faker/pull/1060) ([vlakoff](https://github.com/vlakoff))
+- Docblocks: Add some missing @method tags [\#1059](https://github.com/fzaninotto/Faker/pull/1059) ([Kurre](https://github.com/Kurre))
+- \[fi\_FI\] Improve phone number generator [\#1054](https://github.com/fzaninotto/Faker/pull/1054) ([Kurre](https://github.com/Kurre))
+- Add personalIdentityNumber\(\) to fi\_FI/Person.php [\#1053](https://github.com/fzaninotto/Faker/pull/1053) ([oittaa](https://github.com/oittaa))
+- Issue \#1041 [\#1052](https://github.com/fzaninotto/Faker/pull/1052) ([daleattree](https://github.com/daleattree))
+- Update Text.php [\#1051](https://github.com/fzaninotto/Faker/pull/1051) ([gulaandrij](https://github.com/gulaandrij))
+- Fix French phone numbers with 07 prefix [\#1046](https://github.com/fzaninotto/Faker/pull/1046) ([fzaninotto](https://github.com/fzaninotto))
+- \[Generator.php\] mt\_rand\(\) changed in PHP 7.1 [\#1045](https://github.com/fzaninotto/Faker/pull/1045) ([oittaa](https://github.com/oittaa))
+- Add 'FI' to Payment Provider [\#1044](https://github.com/fzaninotto/Faker/pull/1044) ([oittaa](https://github.com/oittaa))
+- Added id number generator to Person Provider for the en\_ZA locale [\#1039](https://github.com/fzaninotto/Faker/pull/1039) ([smithandre](https://github.com/smithandre))
+- \[Feature\] Add nigerian provider [\#1030](https://github.com/fzaninotto/Faker/pull/1030) ([elchroy](https://github.com/elchroy))
+- \[pl\_PL\] Handle state. [\#1029](https://github.com/fzaninotto/Faker/pull/1029) ([piotrooo](https://github.com/piotrooo))
+- Fixed polish text - change '--' into '-'. [\#1027](https://github.com/fzaninotto/Faker/pull/1027) ([piotrooo](https://github.com/piotrooo))
+- Update Text.php [\#1025](https://github.com/fzaninotto/Faker/pull/1025) ([gulaandrij](https://github.com/gulaandrij))
+- Adding Nationalized Citizens to DNI in Person.php [\#1021](https://github.com/fzaninotto/Faker/pull/1021) ([celisflen-bers](https://github.com/celisflen-bers))
+- Add nik to indonesia [\#1019](https://github.com/fzaninotto/Faker/pull/1019) ([Nuffic](https://github.com/Nuffic))
+- fix mb\_substr missing parameter error when generating japanese string with realText method [\#1018](https://github.com/fzaninotto/Faker/pull/1018) ([horan-geeker](https://github.com/horan-geeker))
+- IBAN Formatters for New Locales [\#1015](https://github.com/fzaninotto/Faker/pull/1015) ([okj579](https://github.com/okj579))
+- German Bank Names [\#1014](https://github.com/fzaninotto/Faker/pull/1014) ([okj579](https://github.com/okj579))
+- Adding countries for pl\_PL provider [\#1009](https://github.com/fzaninotto/Faker/pull/1009) ([mertcanesen](https://github.com/mertcanesen))
+- Adding Pattern Lab plugin to list of 3rd party libraries [\#1008](https://github.com/fzaninotto/Faker/pull/1008) ([EvanLovely](https://github.com/EvanLovely))
+- Korea top 100 lastName [\#1006](https://github.com/fzaninotto/Faker/pull/1006) ([tael](https://github.com/tael))
+- Use real Belgian postcodes instead of random number [\#1004](https://github.com/fzaninotto/Faker/pull/1004) ([toonevdb](https://github.com/toonevdb))
+- Add bankAccountNumber implementations [\#1000](https://github.com/fzaninotto/Faker/pull/1000) ([akramfares](https://github.com/akramfares))
+- Generates a random NIR number \(fr\_FR\) [\#997](https://github.com/fzaninotto/Faker/pull/997) ([Ultim4T0m](https://github.com/Ultim4T0m))
+- \#989 Fix country typo [\#996](https://github.com/fzaninotto/Faker/pull/996) ([adriantombu](https://github.com/adriantombu))
+- adding back CNP [\#988](https://github.com/fzaninotto/Faker/pull/988) ([the-noob](https://github.com/the-noob))
+- Fix phpunit tests fail on 64-bit systems \#982 [\#983](https://github.com/fzaninotto/Faker/pull/983) ([Powerhead13](https://github.com/Powerhead13))
+- Remove trailing dot in username if any [\#975](https://github.com/fzaninotto/Faker/pull/975) ([vlakoff](https://github.com/vlakoff))
+- HTML Lorem [\#971](https://github.com/fzaninotto/Faker/pull/971) ([rudkjobing](https://github.com/rudkjobing))
+- Fix a mixup between male and female last names in Icelandic. [\#970](https://github.com/fzaninotto/Faker/pull/970) ([arthur-olafsson](https://github.com/arthur-olafsson))
+- Remove duplicate [\#969](https://github.com/fzaninotto/Faker/pull/969) ([mijgame](https://github.com/mijgame))
+- fix \[zh\_CN\]PhoneNumber illegal operator prefix [\#966](https://github.com/fzaninotto/Faker/pull/966) ([zhwei](https://github.com/zhwei))
+- es\_ES: Generate VAT Number [\#964](https://github.com/fzaninotto/Faker/pull/964) ([miguelgf](https://github.com/miguelgf))
+- Update Image.php [\#963](https://github.com/fzaninotto/Faker/pull/963) ([gulaandrij](https://github.com/gulaandrij))
+- Remove cnp formatter from RO\_ro locale \(fails tests\) [\#962](https://github.com/fzaninotto/Faker/pull/962) ([fzaninotto](https://github.com/fzaninotto))
+- Adding valid en\_GB postcodes [\#961](https://github.com/fzaninotto/Faker/pull/961) ([the-noob](https://github.com/the-noob))
+- Adding Text for ro\_RO [\#959](https://github.com/fzaninotto/Faker/pull/959) ([the-noob](https://github.com/the-noob))
+- Minor: Fixed trailing space in DateTime provider [\#956](https://github.com/fzaninotto/Faker/pull/956) ([tifabien](https://github.com/tifabien))
+- Remove 'Stripper' from en\_US job titles [\#954](https://github.com/fzaninotto/Faker/pull/954) ([amcsi](https://github.com/amcsi))
+- fix 32bits issue [\#953](https://github.com/fzaninotto/Faker/pull/953) ([remicollet](https://github.com/remicollet))
+- Fix EAN8 checkSum generator [\#951](https://github.com/fzaninotto/Faker/pull/951) ([MatthieuMota](https://github.com/MatthieuMota))
+- Fixed description and the use of early undocumented parameters. [\#949](https://github.com/fzaninotto/Faker/pull/949) ([andrey-helldar](https://github.com/andrey-helldar))
+- Pushing new mobile prefixes in philippines [\#944](https://github.com/fzaninotto/Faker/pull/944) ([napoleon101392](https://github.com/napoleon101392))
+- Update Company.php [\#943](https://github.com/fzaninotto/Faker/pull/943) ([thiagotalma](https://github.com/thiagotalma))
+- Fix to Issue \#935 - German Locale [\#936](https://github.com/fzaninotto/Faker/pull/936) ([Newman101](https://github.com/Newman101))
+- el\_CY Locale [\#930](https://github.com/fzaninotto/Faker/pull/930) ([softius](https://github.com/softius))
+- Add phpdoc method dateTimeInInterval in Generator.php [\#926](https://github.com/fzaninotto/Faker/pull/926) ([KeithYeh](https://github.com/KeithYeh))
+- Harmonize fr\_\*\Company [\#918](https://github.com/fzaninotto/Faker/pull/918) ([Max13](https://github.com/Max13))
+- Fix: fix invalid parameter of mb\_substr\(\) [\#917](https://github.com/fzaninotto/Faker/pull/917) ([tkawaji](https://github.com/tkawaji))
+- kk\_KZ Company/person identification numbers unit tests [\#916](https://github.com/fzaninotto/Faker/pull/916) ([YerlenZhubangaliyev](https://github.com/YerlenZhubangaliyev))
+- ka\_GE: overall improvements to ka\_GE locale [\#913](https://github.com/fzaninotto/Faker/pull/913) ([hertzg](https://github.com/hertzg))
+- Fix: Do not pick a random float less than minimum [\#909](https://github.com/fzaninotto/Faker/pull/909) ([localheinz](https://github.com/localheinz))
+- Fix: Prefer dependencies installed from dist [\#908](https://github.com/fzaninotto/Faker/pull/908) ([localheinz](https://github.com/localheinz))
+- Add a building number with letter to German speaking locales. [\#903](https://github.com/fzaninotto/Faker/pull/903) ([markuspoerschke](https://github.com/markuspoerschke))
+- \[RFR\] Remove parts of the hu\_HU address formatters [\#902](https://github.com/fzaninotto/Faker/pull/902) ([fzaninotto](https://github.com/fzaninotto))
+- use Luhn to calculate ar\_SA id numbers. [\#875](https://github.com/fzaninotto/Faker/pull/875) ([FooBarQuaxx](https://github.com/FooBarQuaxx))
+- Fix Doctrine ODM Support [\#489](https://github.com/fzaninotto/Faker/pull/489) ([cbourgois](https://github.com/cbourgois))
+
+
+## 2016-04-29, v1.6.0
+
+- Remove parts of the Hungarian (hu\_HU) address formatters [\#902](https://github.com/fzaninotto/Faker/pull/902) ([fzaninotto](https://github.com/fzaninotto))
+- Renamed norwegian (nb\_NO) locale [\#901](https://github.com/fzaninotto/Faker/pull/901) ([fzaninotto](https://github.com/fzaninotto))
+- Improveed German (de\_DE) titles [\#897](https://github.com/fzaninotto/Faker/pull/897) ([christianbartels](https://github.com/christianbartels))
+- Added VAT formatter to nl\_BE and fr\_BE providers [\#896](https://github.com/fzaninotto/Faker/pull/896) ([anvanza](https://github.com/anvanza))
+- Fixed provider namespace for Lithuanian (lt\_LT) [\#894](https://github.com/fzaninotto/Faker/pull/894) ([sanis](https://github.com/sanis))
+- Removed unnecessary (and incompatible) license from Russian and Ukrainian (uk\_UA & ru\_RU) Text providers [\#892](https://github.com/fzaninotto/Faker/pull/892) ([Newman101](https://github.com/Newman101))
+- Improved `languageCode` formatted to include all ISO-639-1 standard codes [\#889](https://github.com/fzaninotto/Faker/pull/889) ([andrewnicols](https://github.com/andrewnicols))
+- Improved Hungarian provider [\#883](https://github.com/fzaninotto/Faker/pull/883) ([balping](https://github.com/balping))
+- Fixed typo in Austrian Person provider [\#880](https://github.com/fzaninotto/Faker/pull/880) ([xelan](https://github.com/xelan))
+- Added Chines (zh\_CN) `catchPhrase` formatter [\#878](https://github.com/fzaninotto/Faker/pull/878) ([z-song](https://github.com/z-song))
+- Added mention of Brazilian (pt\_BR) providers in readme [\#877](https://github.com/fzaninotto/Faker/pull/877) ([iget-master](https://github.com/iget-master))
+- Updated composer `require` section to allow PHP 7 in safer way [\#874](https://github.com/fzaninotto/Faker/pull/874) ([TomasVotruba](https://github.com/TomasVotruba))
+- Added Greek (el\_GR) `mobilePhoneNumber` and `tollFreeNumber` formatters [\#869](https://github.com/fzaninotto/Faker/pull/869) ([sebdesign](https://github.com/sebdesign))
+- Added Lorempixel check for `ImageTest.php` to avoid test fails when the service is offline [\#866](https://github.com/fzaninotto/Faker/pull/866) ([Newman101](https://github.com/Newman101))
+- Added Chinese (zh\_CN) Providers [\#864](https://github.com/fzaninotto/Faker/pull/864) ([z-song](https://github.com/z-song))
+- Added unit tests for Canadian (en\_CA) provider [\#862](https://github.com/fzaninotto/Faker/pull/862) ([Newman101](https://github.com/Newman101))
+- Added Dutch BTW \(vat\) Number [\#861](https://github.com/fzaninotto/Faker/pull/861) ([LauLaman](https://github.com/LauLaman))
+- Improved Australian (en\_AU) provider [\#858](https://github.com/fzaninotto/Faker/pull/858) ([Newman101](https://github.com/Newman101))
+- Added Propel2 ORM support [\#852](https://github.com/fzaninotto/Faker/pull/852) ([iTechDhaval](https://github.com/iTechDhaval))
+- Added en\_IN unit test for `Address.php` [\#849](https://github.com/fzaninotto/Faker/pull/849) ([Newman101](https://github.com/Newman101))
+- Updated docs to clarify that `randomElements` does not repeat input elements [\#848](https://github.com/fzaninotto/Faker/pull/848) ([sustmi](https://github.com/sustmi))
+- Optimized Taiwanese (zh\_TW) `realText` provider [\#844](https://github.com/fzaninotto/Faker/pull/844) ([Newman101](https://github.com/Newman101))
+- Added more Iranian (fa\_IR) TLDs [\#843](https://github.com/fzaninotto/Faker/pull/843) ([VagrantStory](https://github.com/VagrantStory))
+- Added Hebrew (he\_IL) `country` formatter [\#841](https://github.com/fzaninotto/Faker/pull/841) ([yonirom](https://github.com/yonirom))
+- Documented `boolean` formatter [\#840](https://github.com/fzaninotto/Faker/pull/840) ([danieliancu](https://github.com/danieliancu))
+- Fixed modifiers anchor readme [\#838](https://github.com/fzaninotto/Faker/pull/838) ([danieliancu](https://github.com/danieliancu))
+- Added Dutch (nl\_NL) real text provider [\#837](https://github.com/fzaninotto/Faker/pull/837) ([endroid](https://github.com/endroid))
+- Added `valid` modifier [\#836](https://github.com/fzaninotto/Faker/pull/836) ([fzaninotto](https://github.com/fzaninotto))
+- Added Iranian (fa\_IR) `PhoneNumber` provider [\#833](https://github.com/fzaninotto/Faker/pull/833) ([ghost](https://github.com/ghost))
+- Add Brazilian (pt\_BR) `region` and `regionAbbr` formatters [\#828](https://github.com/fzaninotto/Faker/pull/828) ([francinaldo](https://github.com/francinaldo))
+- Improved Austrian (de\_AT) names, states, and realtext [\#826](https://github.com/fzaninotto/Faker/pull/826) ([Findus23](https://github.com/Findus23))
+- Improved German (de\_DE) names [\#825](https://github.com/fzaninotto/Faker/pull/825) ([Findus23](https://github.com/Findus23))
+- Improved Latvian (lv\_LV) first names [\#823](https://github.com/fzaninotto/Faker/pull/823) ([veisis](https://github.com/veisis))
+- Improved Latvian (lv\_LV) `phoneNumber` formatter [\#822](https://github.com/fzaninotto/Faker/pull/822) ([veisis](https://github.com/veisis))
+- Updated phpDoc link to IBAN format reference in `Payment` provider [\#821](https://github.com/fzaninotto/Faker/pull/821) ([god107](https://github.com/god107))
+- Updated Sport ORM populator to populate values for numeric fields [\#820](https://github.com/fzaninotto/Faker/pull/820) ([urisavka](https://github.com/urisavka))
+- Updated Chinese (zh\_CN) operators' phone number prefix. [\#819](https://github.com/fzaninotto/Faker/pull/819) ([vistart](https://github.com/vistart))
+- Optimized Spot ORM `EntityPopulator` [\#817](https://github.com/fzaninotto/Faker/pull/817) ([Newman101](https://github.com/Newman101))
+- Added Korean (ko\_KR) `realText` formatter [\#815](https://github.com/fzaninotto/Faker/pull/815) ([jdssem](https://github.com/jdssem))
+- Updated `imageUrl` formatter phpDoc [\#814](https://github.com/fzaninotto/Faker/pull/814) ([jonwurtzler](https://github.com/jonwurtzler))
+- Optimized Taiwanese (zh\_TW) text provider [\#809](https://github.com/fzaninotto/Faker/pull/809) ([BePsvPT](https://github.com/BePsvPT))
+- Added strict comparison to Czech (cs\_CS) `birthNumber` formatter [\#807](https://github.com/fzaninotto/Faker/pull/807) ([Newman101](https://github.com/Newman101))
+- Added Greek (el\_GR) `realText` formatter [\#805](https://github.com/fzaninotto/Faker/pull/805) ([hootlex](https://github.com/hootlex))
+- Added Simplified Chinese \(zh\_CN\) `state` and `stateAbbr` formatters [\#804](https://github.com/fzaninotto/Faker/pull/804) ([zhanghuanchong](https://github.com/zhanghuanchong))
+- Update `Image` provider to allow generation of grayscale images [\#801](https://github.com/fzaninotto/Faker/pull/801) ([neutralrockets](https://github.com/neutralrockets))
+- Fixed Taiwanese (zh_TW) incorrect `mb_substr()` arguments [\#799](https://github.com/fzaninotto/Faker/pull/799) ([BePsvPT](https://github.com/BePsvPT))
+- Added Spot ORM populator [\#796](https://github.com/fzaninotto/Faker/pull/796) ([urisavka](https://github.com/urisavka))
+- Added Italian (it\_IT) `vatId` and `taxId` formatters [\#790](https://github.com/fzaninotto/Faker/pull/790) ([brainrepo](https://github.com/brainrepo))
+- Added some fixes to Armenian (hy\_AM) locale [\#788](https://github.com/fzaninotto/Faker/pull/788) ([mhamlet](https://github.com/mhamlet))
+- Removed duplicate entries in `toAscii()` transliteration table, used in `Internet` provider [\#787](https://github.com/fzaninotto/Faker/pull/787) ([vlakoff](https://github.com/vlakoff))
+- Added Indian (en\_IN) providers [\#785](https://github.com/fzaninotto/Faker/pull/785) ([kartiksomani](https://github.com/kartiksomani))
+- Removed duplicate country names in various locales, removed non-random country arrays [\#784](https://github.com/fzaninotto/Faker/pull/784) ([fzaninotto](https://github.com/fzaninotto))
+- Improved Swiss (de\_CH) phone numbers [\#782](https://github.com/fzaninotto/Faker/pull/782) ([z38](https://github.com/z38))
+- Added Swiss (de\_CH) names [\#781](https://github.com/fzaninotto/Faker/pull/781) ([z38](https://github.com/z38))
+- Make capitalization of first word optional in Text Provider [\#778](https://github.com/fzaninotto/Faker/pull/778) ([LagunaJavier](https://github.com/LagunaJavier))
+- Added Georgian (ka\_GE) providers [\#777](https://github.com/fzaninotto/Faker/pull/777) ([akalongman](https://github.com/akalongman))
+- Fix CakePHP populator [\#776](https://github.com/fzaninotto/Faker/pull/776) ([daniel-mueller](https://github.com/daniel-mueller))
+- Added unit tests for `Address` provider in many locales [\#775](https://github.com/fzaninotto/Faker/pull/775) [\#773](https://github.com/fzaninotto/Faker/pull/773) [\#772](https://github.com/fzaninotto/Faker/pull/772) [\#767](https://github.com/fzaninotto/Faker/pull/767) [\#765](https://github.com/fzaninotto/Faker/pull/765) [\#764](https://github.com/fzaninotto/Faker/pull/764) [\#758](https://github.com/fzaninotto/Faker/pull/758) [\#756](https://github.com/fzaninotto/Faker/pull/756) [\#747](https://github.com/fzaninotto/Faker/pull/747) [\#741](https://github.com/fzaninotto/Faker/pull/741) ([Newman101](https://github.com/Newman101))
+- Added `dbi` formatter to Spanish (es\_ES) Person provider [\#763](https://github.com/fzaninotto/Faker/pull/763) ([mikk150](https://github.com/mikk150))
+- Added South Africa (en\_ZA) locale [\#761](https://github.com/fzaninotto/Faker/pull/761) ([smithandre](https://github.com/smithandre)) [\#760](https://github.com/fzaninotto/Faker/pull/760) ([smithandre](https://github.com/smithandre)) [\#759](https://github.com/fzaninotto/Faker/pull/759) ([smithandre](https://github.com/smithandre))
+- Added E.164 phone number generator [\#753](https://github.com/fzaninotto/Faker/pull/753) ([daleattree](https://github.com/daleattree))
+- Fixed serialization issue in `unique` modifier [\#749](https://github.com/fzaninotto/Faker/pull/749) ([EmanueleMinotto](https://github.com/EmanueleMinotto))
+- Added Switzerland (de\_CH, fr\_CH, it\_CH) providers [\#739](https://github.com/fzaninotto/Faker/pull/739) ([r3h6](https://github.com/r3h6))
+- Added PHPDocs, removed unused variable [\#738](https://github.com/fzaninotto/Faker/pull/738) ([daniel-mueller](https://github.com/daniel-mueller))
+- Fixed building numbers to have non-zero first bumber [\#737](https://github.com/fzaninotto/Faker/pull/737) ([jmauerhan](https://github.com/jmauerhan))
+- Updated ninth digit for Brazilian cell phone numbers [\#734](https://github.com/fzaninotto/Faker/pull/734) ([igorsantos07](https://github.com/igorsantos07))
+- Simplified Factory code [\#732](https://github.com/fzaninotto/Faker/pull/732) ([vlakoff](https://github.com/vlakoff))
+- Added mention of [images-generator](https://github.com/bruceheller/images-generator) in readme [\#731](https://github.com/fzaninotto/Faker/pull/731) ([bruceheller](https://github.com/bruceheller))
+- Optimize Internet::toAscii\(\) by using a static cache and translitteration [\#730](https://github.com/fzaninotto/Faker/pull/730) [\#729](https://github.com/fzaninotto/Faker/pull/729)
+[\#725](https://github.com/fzaninotto/Faker/pull/725) [\#724](https://github.com/fzaninotto/Faker/pull/724) ([vlakoff](https://github.com/vlakoff))
+- Added more English (en\_GB) Phone Number formats [\#721](https://github.com/fzaninotto/Faker/pull/721) ([nickwebcouk](https://github.com/nickwebcouk))
+- Cleaned up `use` statements across the code [\#719](https://github.com/fzaninotto/Faker/pull/719) ([pomaxa](https://github.com/pomaxa))
+- Fixed CackePHP populator [\#718](https://github.com/fzaninotto/Faker/pull/718) ([sdustinh](https://github.com/sdustinh))
+- Cleaned up various phpmd notices [\#715](https://github.com/fzaninotto/Faker/pull/715) ([pomaxa](https://github.com/pomaxa))
+- Added `Color` provider to Latvian (lv_LV) locale [\#714](https://github.com/fzaninotto/Faker/pull/714) ([pomaxa](https://github.com/pomaxa))
+- Fixed bad randomization in Doctrine populator [\#713](https://github.com/fzaninotto/Faker/pull/713) ([pomaxa](https://github.com/pomaxa))
+- Added Mongolian (mn\_MN) providers [\#709](https://github.com/fzaninotto/Faker/pull/709) ([selmonal](https://github.com/selmonal))
+- Improved Australian (en\_AU) `postcode` formatter [\#703](https://github.com/fzaninotto/Faker/pull/703) ([xfxf](https://github.com/xfxf))
+- Added support for asterisks in `bothify` and `optimize` [\#701](https://github.com/fzaninotto/Faker/pull/701) ([nineinchnick](https://github.com/nineinchnick))
+- Fixed important distinction between ORM and database framework in README’s reference to an external Faker provider for POMM that I have never even tested. Anyway, POMM is highly recommended if you are a Postgres fan, or if you want to please Grégoire and help him finish his lifelong project of listening to music on a hi-fi audio equipment he built from his own hands [\#696](https://github.com/fzaninotto/Faker/pull/696) ([chanmix51](https://github.com/chanmix51))
+- Fixed example `text()` output in README [\#694](https://github.com/fzaninotto/Faker/pull/694) ([vlakoff](https://github.com/vlakoff))
+- Added mention of CakePHP 2.x Seeder Plugin to readme [\#691](https://github.com/fzaninotto/Faker/pull/691) ([ravage84](https://github.com/ravage84))
+- Fixed invalid email bug for Korean (ko\_KR) [\#690](https://github.com/fzaninotto/Faker/pull/690) ([pearlc](https://github.com/pearlc))
+- Removed an invalid Dutch (nl\_NL) lastname that breaks email generator [\#689](https://github.com/fzaninotto/Faker/pull/689) ([SpaceK33z](https://github.com/SpaceK33z))
+- Updated `numberBetween()` to be order agnostic [\#683](https://github.com/fzaninotto/Faker/pull/683) ([xfxf](https://github.com/xfxf))
+- Added several English (en\_US) bank-related formatters [\#682](https://github.com/fzaninotto/Faker/pull/682) ([okj579](https://github.com/okj579))
+- Fixed `ipv4` formatter to avoid generating special purpose addresses [\#681](https://github.com/fzaninotto/Faker/pull/681) ([ravage84](https://github.com/ravage84))
+- Moved `intl` extension to `require-dev` in `composer.json` file [\#680](https://github.com/fzaninotto/Faker/pull/680) ([jaschweder](https://github.com/jaschweder))
+- Added more Turkish (tr\_TR) phones number formats [\#678](https://github.com/fzaninotto/Faker/pull/678) ([Quanthir](https://github.com/Quanthir))
+- Fixed primary Key warning in CakePHP ORM populator [\#677](https://github.com/fzaninotto/Faker/pull/677) ([davidyell](https://github.com/davidyell))
+- Added time zone support for provider methods returning DateTime instance [\#675](https://github.com/fzaninotto/Faker/pull/675) ([bishopb](https://github.com/bishopb))
+- Removed trailing spaces from some Argentinian (es\_AR) female first names [\#674](https://github.com/fzaninotto/Faker/pull/674) ([ivanmirson](https://github.com/ivanmirson))
+- Added Lithuanian (lt\_LT) locale [\#673](https://github.com/fzaninotto/Faker/pull/673) ([ekateiva](https://github.com/ekateiva))
+- Added mention of Alice to readme [\#665](https://github.com/fzaninotto/Faker/pull/665) ([Seldaek](https://github.com/Seldaek))
+- Fixed namespace in tests [\#663](https://github.com/fzaninotto/Faker/pull/663) ([localheinz](https://github.com/localheinz))
+- Fixed trailing spaces in `Color` provider [\#662](https://github.com/fzaninotto/Faker/pull/662) ([apsylone](https://github.com/apsylone))
+- Removed duplicate country names in Russian (ru\_RU) `Address` provider [\#659](https://github.com/fzaninotto/Faker/pull/659) ([nurolopher](https://github.com/nurolopher))
+- Added `rgba` formatter to `Color` provider [\#653](https://github.com/fzaninotto/Faker/pull/653) ([apsylone](https://github.com/apsylone))
+- Fixed bad randomization in CakePHP populator [\#648](https://github.com/fzaninotto/Faker/pull/648) ([jadb](https://github.com/jadb))
+- Updated phpunit configuration to better use colors [\#643](https://github.com/fzaninotto/Faker/pull/643) ([localheinz](https://github.com/localheinz))
+- Updated `makefile` to install dev dependencies by default [\#642](https://github.com/fzaninotto/Faker/pull/642) ([localheinz](https://github.com/localheinz))
+- Updated Travis configuration to cache dependencies between builds [\#641](https://github.com/fzaninotto/Faker/pull/641) ([localheinz](https://github.com/localheinz))
+- Added SVG badge to readme for displaying Travis build status [\#640](https://github.com/fzaninotto/Faker/pull/640) ([localheinz](https://github.com/localheinz))
+- Added Croatian (hr\_HR) locale [\#638](https://github.com/fzaninotto/Faker/pull/638) ([toniperic](https://github.com/toniperic))
+- Updated `dateTimeBetween` PHPDoc [\#635](https://github.com/fzaninotto/Faker/pull/635) ([theofidry](https://github.com/theofidry))
+- Add mention of Symfony2 bundles in readme [\#634](https://github.com/fzaninotto/Faker/pull/634) ([theofidry](https://github.com/theofidry))
+- Added Hebrew (he\_IL) locale [\#633](https://github.com/fzaninotto/Faker/pull/633) ([yonirom](https://github.com/yonirom))
+- Updated `seed` to accept non-integer seeds [\#632](https://github.com/fzaninotto/Faker/pull/632) ([theofidry](https://github.com/theofidry))
+- Added DocBlock to `Factory::create()` [\#631](https://github.com/fzaninotto/Faker/pull/631) ([tonynelson19](https://github.com/tonynelson19))
+- Added `jobTitle` generator [\#630](https://github.com/fzaninotto/Faker/pull/630) ([gregoryduckworth](https://github.com/gregoryduckworth))
+- Updated Chinese (zh\_CN) `Person` provider to generate more correct names [\#628](https://github.com/fzaninotto/Faker/pull/628) ([phoenixgao](https://github.com/phoenixgao))
+- Updated Brazilian (pt\_BR) `cellphone` formatter to make it more flexible [\#623](https://github.com/fzaninotto/Faker/pull/623) ([igorsantos07](https://github.com/igorsantos07))
+- Add Arabic for Saudi Arabia (ar\_SA) locale [\#618](https://github.com/fzaninotto/Faker/pull/618) ([ibrasho](https://github.com/ibrasho))
+- Updated en\_US phone numbers [\#615](https://github.com/fzaninotto/Faker/pull/615) ([okj579](https://github.com/okj579))
+- Fixed typos in variable names and exceptions [\#614](https://github.com/fzaninotto/Faker/pull/614) ([pborreli](https://github.com/pborreli))
+- Added a table of contents to the readme file. [\#613](https://github.com/fzaninotto/Faker/pull/613) ([camilopayan](https://github.com/camilopayan))
+- Added Brazilian (es_BR) credit card formatters [\#608](https://github.com/fzaninotto/Faker/pull/608) ([igorsantos07](https://github.com/igorsantos07))
+- Updated `iban` formatter to be cross-locale [\#607](https://github.com/fzaninotto/Faker/pull/607) ([okj579](https://github.com/okj579))
+- Improved ORM name guesser logic [\#606](https://github.com/fzaninotto/Faker/pull/606) ([watermanio](https://github.com/watermanio))
+- Fixed doc typo [\#605](https://github.com/fzaninotto/Faker/pull/605) ([igorsantos07](https://github.com/igorsantos07))
+- Removed executable bits [\#593](https://github.com/fzaninotto/Faker/pull/593) ([siwinski](https://github.com/siwinski))
+- Fixed `iban` generator [\#590](https://github.com/fzaninotto/Faker/pull/590) ([okj579](https://github.com/okj579))
+- Added Philippines (en\_PH) `mobileNumber` formatter [\#589](https://github.com/fzaninotto/Faker/pull/589) ([lozadaOmr](https://github.com/lozadaOmr))
+- Added support for min / max params in `latitude` and `longitude` formatters [\#570](https://github.com/fzaninotto/Faker/pull/570) ([actuallymab](https://github.com/actuallymab))
+- Added Czech (cs_CZ) `birthNumber` formatter [\#535](https://github.com/fzaninotto/Faker/pull/535) ([tomasbedrich](https://github.com/tomasbedrich))
+- Added `dateTimeInInterval` formatter [\#526](https://github.com/fzaninotto/Faker/pull/526) ([nicodmf](https://github.com/nicodmf))
+- Updated `optional` and `boolean` apis to be more consistent [\#513](https://github.com/fzaninotto/Faker/pull/513) ([EmanueleMinotto](https://github.com/EmanueleMinotto))
+- Added Greek (el\_GR) `Address` provider [\#504](https://github.com/fzaninotto/Faker/pull/504) ([drakakisgeo](https://github.com/drakakisgeo))
+
+## 2015-05-29, v1.5.0
+
+* Added ability to print custom text on the images fetched by the Image provider [\#583](https://github.com/fzaninotto/Faker/pull/583) ([fzaninotto](https://github.com/fzaninotto))
+* Fixed typos in Peruvian (es\_PE) Person provider [\#581](https://github.com/fzaninotto/Faker/pull/581) [\#580](https://github.com/fzaninotto/Faker/pull/580) ([ysramirez](https://github.com/ysramirez))
+* Added instructions for installing with composer to readme.md [\#572](https://github.com/fzaninotto/Faker/pull/572) ([totophe](https://github.com/totophe))
+* Added Kazakh (kk\_KZ) locale [\#569](https://github.com/fzaninotto/Faker/pull/569) ([YerlenZhubangaliyev](https://github.com/YerlenZhubangaliyev))
+* Added Korean (ko\_KR) locale [\#566](https://github.com/fzaninotto/Faker/pull/566) ([pearlc](https://github.com/pearlc))
+* Fixed file provider to ignore unreadable and special files [\#565](https://github.com/fzaninotto/Faker/pull/565) ([svrnm](https://github.com/svrnm))
+* Fixed Dutch (nl\_NL) Address and Person providers [\#560](https://github.com/fzaninotto/Faker/pull/560) ([killerog](https://github.com/killerog))
+* Fixed Dutch (nl\_NL) Person provider [\#559](https://github.com/fzaninotto/Faker/pull/559) ([pauledenburg](https://github.com/pauledenburg))
+* Added Russian (ru\_RU) Bank names provider [\#553](https://github.com/fzaninotto/Faker/pull/553) ([wizardjedi](https://github.com/wizardjedi))
+* Added mobile phone function in French (fr\_FR) provider [\#552](https://github.com/fzaninotto/Faker/pull/552) ([kletellier](https://github.com/kletellier))
+* Added phpdoc for new magic methods in Generator to help IntelliSense completion [\#550](https://github.com/fzaninotto/Faker/pull/550) ([stof](https://github.com/stof))
+* Fixed File provider bug 'The first argument to copy() function cannot be a directory' [\#547](https://github.com/fzaninotto/Faker/pull/547) ([svrnm](https://github.com/svrnm))
+* Added new Brazilian (pt\_BR) Providers [\#545](https://github.com/fzaninotto/Faker/pull/545) ([igorsantos07](https://github.com/igorsantos07))
+* Fixed ability to seed the generator [\#543](https://github.com/fzaninotto/Faker/pull/543) ([schmengler](https://github.com/schmengler))
+* Added streetAddress formatter to Russian (ru\_RU) provider [\#542](https://github.com/fzaninotto/Faker/pull/542) ([ZAYEC77](https://github.com/ZAYEC77))
+* Fixed Internet provider warning "Could not create transliterator"* [\#541](https://github.com/fzaninotto/Faker/pull/541) ([fonsecas72](https://github.com/fonsecas72))
+* Fixed Spanish for Argentina (es\_AR) Address provider [\#540](https://github.com/fzaninotto/Faker/pull/540) ([ivanmirson](https://github.com/ivanmirson))
+* Fixed region names in French for Belgium (fr\_BE) address provider [\#536](https://github.com/fzaninotto/Faker/pull/536) ([miclf](https://github.com/miclf))
+* Fixed broken Doctrine2 link in README [\#534](https://github.com/fzaninotto/Faker/pull/534) ([JonathanKryza](https://github.com/JonathanKryza))
+* Added link to faker-context Behat extension in readme [\#532](https://github.com/fzaninotto/Faker/pull/532) ([denheck](https://github.com/denheck))
+* Added PHP 7.0 nightly to Travis build targets [\#525](https://github.com/fzaninotto/Faker/pull/525) ([TomasVotruba](https://github.com/TomasVotruba))
+* Added Dutch (nl\_NL) color names [\#523](https://github.com/fzaninotto/Faker/pull/523) ([belendel](https://github.com/belendel))
+* Fixed Chinese (zh\_CN) Address provider (remove Taipei) [\#522](https://github.com/fzaninotto/Faker/pull/522) ([asika32764](https://github.com/asika32764))
+* Fixed phonenumber formats in Dutch (nl\_NL) PhoneNumber provider [\#521](https://github.com/fzaninotto/Faker/pull/521) ([SpaceK33z](https://github.com/SpaceK33z))
+* Fixed Russian (ru\_RU) Address provider [\#518](https://github.com/fzaninotto/Faker/pull/518) ([glagola](https://github.com/glagola))
+* Added Italian (it\_IT) Text provider [\#517](https://github.com/fzaninotto/Faker/pull/517) ([endelwar](https://github.com/endelwar))
+* Added Norwegian (no\_NO) locale [\#515](https://github.com/fzaninotto/Faker/pull/515) ([phaza](https://github.com/phaza))
+* Added VAT number to Bulgarian (bg\_BG) Payment provider [\#512](https://github.com/fzaninotto/Faker/pull/512) ([ronanguilloux](https://github.com/ronanguilloux))
+* Fixed UserAgent provider outdated user agents [\#511](https://github.com/fzaninotto/Faker/pull/511) ([ajbdev](https://github.com/ajbdev))
+* Fixed `image()` formatter to make it work with temp dir of any (decent) OS [\#507](https://github.com/fzaninotto/Faker/pull/507) ([ronanguilloux](https://github.com/ronanguilloux))
+* Added Persian (fa\_IR) locale [\#500](https://github.com/fzaninotto/Faker/pull/500) ([zoli](https://github.com/zoli))
+* Added Currency Code formatter [\#497](https://github.com/fzaninotto/Faker/pull/497) ([stelgenhof](https://github.com/stelgenhof))
+* Added VAT number to Belgium (be_BE) Payment provider [\#495](https://github.com/fzaninotto/Faker/pull/495) ([ronanguilloux](https://github.com/ronanguilloux))
+* Fixed `imageUrl` formatter bug where it would always return the same image [\#494](https://github.com/fzaninotto/Faker/pull/494) ([fzaninotto](https://github.com/fzaninotto))
+* Added more Indonesian (id\_ID) providers [\#493](https://github.com/fzaninotto/Faker/pull/493) ([deerawan](https://github.com/deerawan))
+* Added Indonesian (id\_ID) locale [\#492](https://github.com/fzaninotto/Faker/pull/492) ([stoutZero](https://github.com/stoutZero))
+* Fixed unique generator performance [\#491](https://github.com/fzaninotto/Faker/pull/491) ([ikwattro](https://github.com/ikwattro))
+* Added transliterator to `email` and `username` [\#490](https://github.com/fzaninotto/Faker/pull/490) ([fzaninotto](https://github.com/fzaninotto))
+* Added Hungarian (hu\_HU) Text provider [\#486](https://github.com/fzaninotto/Faker/pull/486) ([lintaba](https://github.com/lintaba))
+* Fixed CakePHP Entity Popolator (some cases where no entities prev. inserted) [\#483](https://github.com/fzaninotto/Faker/pull/483) ([jadb](https://github.com/jadb))
+* Added Color and DateTime Turkish (tr\_TR) Providers [\#481](https://github.com/fzaninotto/Faker/pull/481) ([behramcelen](https://github.com/behramcelen))
+* Added Latvian (lv\_LV) `personalIdentityNumber` formatter [\#472](https://github.com/fzaninotto/Faker/pull/472) ([MatissJanis](https://github.com/MatissJanis))
+* Added VAT number to Austrian (at_AT) Payment provider [\#470](https://github.com/fzaninotto/Faker/pull/470) ([ronanguilloux](https://github.com/ronanguilloux))
+* Fixed missing @return phpDoc in Payment provider [\#469](https://github.com/fzaninotto/Faker/pull/469) ([ronanguilloux](https://github.com/ronanguilloux))
+* Added SWIFT/BIC payment type formatter to the Payment provider [\#465](https://github.com/fzaninotto/Faker/pull/465) ([ronanguilloux](https://github.com/ronanguilloux))
+* Fixed small typo in Base provider exception [\#460](https://github.com/fzaninotto/Faker/pull/460) ([miclf](https://github.com/miclf))
+* Added Georgian (ka\_Ge) locale [\#457](https://github.com/fzaninotto/Faker/pull/457) ([lperto](https://github.com/lperto))
+* Added PSR-4 Autoloading [\#455](https://github.com/fzaninotto/Faker/pull/455) ([GrahamCampbell](https://github.com/GrahamCampbell))
+* Added Uganda (en_UG) locale [\#454](https://github.com/fzaninotto/Faker/pull/454) ([tharoldD](https://github.com/tharoldD))
+* Added `regexify` formatter, generating a random string based on a regular expression [\#453](https://github.com/fzaninotto/Faker/pull/453) ([fzaninotto](https://github.com/fzaninotto))
+* Added shuffle formatter, to shuffle an array or a string [\#452](https://github.com/fzaninotto/Faker/pull/452) ([fzaninotto](https://github.com/fzaninotto))
+* Added ISBN-10 & ISBN-13 codes formatters to Barcode provider [\#451](https://github.com/fzaninotto/Faker/pull/451) ([gietos](https://github.com/gietos))
+* Fixed Russian (ru\_RU) middle names (different for different genders) [\#450](https://github.com/fzaninotto/Faker/pull/450) ([gietos](https://github.com/gietos))
+* Fixed Ukranian (uk\_UA) Person provider [\#448](https://github.com/fzaninotto/Faker/pull/448) ([aivus](https://github.com/aivus))
+* Added Vietnamese (vi\_VN) locale [\#447](https://github.com/fzaninotto/Faker/pull/447) ([huy95](https://github.com/huy95))
+* Added type hint to the Documentor constructor [\#446](https://github.com/fzaninotto/Faker/pull/446) ([JeroenDeDauw](https://github.com/JeroenDeDauw))
+* Fixed Russian (ru\_RU) Person provider (joined names) [\#445](https://github.com/fzaninotto/Faker/pull/445) ([aivus](https://github.com/aivus))
+* Added English (en\_GB) `mobileNumber` methods [\#438](https://github.com/fzaninotto/Faker/pull/438) ([daveblake](https://github.com/daveblake))
+* Added Traditional Chinese (zh\_TW) Realtext provider [\#434](https://github.com/fzaninotto/Faker/pull/434) ([tzhuan](https://github.com/tzhuan))
+* Fixed first name in Spanish for Argentina (es\_AR) Person provider [\#433](https://github.com/fzaninotto/Faker/pull/433) ([fzaninotto](https://github.com/fzaninotto))
+* Fixed Canadian (en_CA) state abbreviation for Nunavut [\#430](https://github.com/fzaninotto/Faker/pull/430) ([julien-c](https://github.com/julien-c))
+* Added CakePHP ORM entity populator [\#428](https://github.com/fzaninotto/Faker/pull/428) ([jadb](https://github.com/jadb))
+* Added Traditional Chinese (zh\_TW) locale [\#427](https://github.com/fzaninotto/Faker/pull/427) ([tzhuan](https://github.com/tzhuan))
+* Fixed typo in Doctrine Populator phpDoc [\#425](https://github.com/fzaninotto/Faker/pull/425) ([ihsanudin](https://github.com/ihsanudin))
+* Added Chinese (zh_CN) Internet provider [\#424](https://github.com/fzaninotto/Faker/pull/424) ([Lisso-Me](https://github.com/Lisso-Me))
+* Added Country ISO 3166-1 alpha-3 code to the Miscellaneous provider[\#422](https://github.com/fzaninotto/Faker/pull/422) ([gido](https://github.com/gido))
+* Added English (en\_GB) Person provider [\#421](https://github.com/fzaninotto/Faker/pull/421) ([AlexCutts](https://github.com/AlexCutts))
+* Added missing tests for the Color Provider [\#420](https://github.com/fzaninotto/Faker/pull/420) ([bessl](https://github.com/bessl))
+* Added Nepali (ne\_NP) locale [\#419](https://github.com/fzaninotto/Faker/pull/419) ([ankitpokhrel](https://github.com/ankitpokhrel))
+* Fixed latitude and longitude formatters bug (numeric value out of range for 32bits) [\#416](https://github.com/fzaninotto/Faker/pull/416) ([fzaninotto](https://github.com/fzaninotto))
+* Added a dedicated calculator Luhn calculator service [\#414](https://github.com/fzaninotto/Faker/pull/414) ([fzaninotto](https://github.com/fzaninotto))
+* Fixed Russian (ru_RU) Person provider (removed lowercase duplications) [\#413](https://github.com/fzaninotto/Faker/pull/413) ([Ragazzo](https://github.com/Ragazzo))
+* Fixed barcode formatter (improved speed, added tests) [\#412](https://github.com/fzaninotto/Faker/pull/412) ([fzaninotto](https://github.com/fzaninotto))
+* Added ipv4 and barcode formatters tests [\#410](https://github.com/fzaninotto/Faker/pull/410) ([bessl](https://github.com/bessl))
+* Fixed typos in various comments blocks [\#409](https://github.com/fzaninotto/Faker/pull/409) ([bessl](https://github.com/bessl))
+* Fixed InternetTest (replaced regex with PHP filter) [\#406](https://github.com/fzaninotto/Faker/pull/406) ([bessl](https://github.com/bessl))
+* Added password formatter to the Internet provider[\#402](https://github.com/fzaninotto/Faker/pull/402) ([fzaninotto](https://github.com/fzaninotto))
+* Added Company and Internet Austrian (de\_AT) Providers [\#400](https://github.com/fzaninotto/Faker/pull/400) ([bessl](https://github.com/bessl))
+* Added third-party libraries section in README [\#399](https://github.com/fzaninotto/Faker/pull/399) ([fzaninotto](https://github.com/fzaninotto))
+* Added Spanish for Venezuela (es\_VE) locale [\#398](https://github.com/fzaninotto/Faker/pull/398) ([DIOHz0r](https://github.com/DIOHz0r))
+* Added PhoneNumber Autrian (de\_AT) Provider, and missing test for the 'locale' method. [\#395](https://github.com/fzaninotto/Faker/pull/395) ([bessl](https://github.com/bessl))
+* Removed wrongly localized Lorem provider [\#394](https://github.com/fzaninotto/Faker/pull/394) ([fzaninotto](https://github.com/fzaninotto))
+* Fixed Miscellaneous provider (made the `locale` formatter static) [\#390](https://github.com/fzaninotto/Faker/pull/390) ([bessl](https://github.com/bessl))
+* Added a unit test file for the Miscellaneous Provider [\#389](https://github.com/fzaninotto/Faker/pull/389) ([bessl](https://github.com/bessl))
+* Added warning in README about using `rand()`` and the seed functions [\#386](https://github.com/fzaninotto/Faker/pull/386) ([paulvalla](https://github.com/paulvalla))
+* Fixed French (fr\_FR) Person provider (Uppercased a first name) [\#385](https://github.com/fzaninotto/Faker/pull/385) ([netcarver](https://github.com/netcarver))
+* Added Russian (ru\_RU) and Ukrainian (uk\_UA) Text providers [\#383](https://github.com/fzaninotto/Faker/pull/383) ([terion-name](https://github.com/terion-name))
+* Added more street prefixes to French (fr\_FR) Address provider [\#381](https://github.com/fzaninotto/Faker/pull/381) ([ronanguilloux](https://github.com/ronanguilloux))
+* Added PHP 5.6 to CI targets [\#378](https://github.com/fzaninotto/Faker/pull/378) ([GrahamCampbell](https://github.com/GrahamCampbell))
+* Fixed spaces remaining at the end of liine in various files [\#377](https://github.com/fzaninotto/Faker/pull/377) ([GrahamCampbell](https://github.com/GrahamCampbell))
+* Fixed UserAgent provider (added space before processor on linux platform) [\#374](https://github.com/fzaninotto/Faker/pull/374) ([TomK](https://github.com/TomK))
+* Added Company generator for Russian (ru\_RU) locale [\#371](https://github.com/fzaninotto/Faker/pull/371) ([kix](https://github.com/kix))
+* Fixed Russian (ru\_RU) Color provider (uppercase letters) [\#370](https://github.com/fzaninotto/Faker/pull/370) ([semanser](https://github.com/semanser))
+* Added more Polish (pl\_PL) phone numbers [\#369](https://github.com/fzaninotto/Faker/pull/369) ([piotrantosik](https://github.com/piotrantosik))
+* Fixed Ruby Faker link in readme [\#368](https://github.com/fzaninotto/Faker/pull/368) ([philsturgeon](https://github.com/philsturgeon))
+* Added more Japanese (ja\_JP) names in Person provider [\#366](https://github.com/fzaninotto/Faker/pull/366) ([kumamidori](https://github.com/kumamidori))
+* Added Slovenian (sl\_SL) locale [\#363](https://github.com/fzaninotto/Faker/pull/363) ([alesf](https://github.com/alesf))
+* Fixed German (de\_DE) Person provider (first names) [\#362](https://github.com/fzaninotto/Faker/pull/362) ([mikehaertl](https://github.com/mikehaertl))
+* Fixed Ukrainian (uk\_UA) Person providr (there is no such letter "Ñ‹" in Ukrainian) [\#359](https://github.com/fzaninotto/Faker/pull/359) ([nazar-pc](https://github.com/nazar-pc))
+* Fixed Chinese (zh\_CN) PhoneNumber provider (the length of mobile phone number is 11) [\#358](https://github.com/fzaninotto/Faker/pull/358) ([byan](https://github.com/byan))
+* Added Arabic (ar_\JO) Locale [\#357](https://github.com/fzaninotto/Faker/pull/357) ([zrashwani](https://github.com/zrashwani))
+* Fixed Czech (cs\_CZ) Person provider (missing lowercase in last name) [\#355](https://github.com/fzaninotto/Faker/pull/355) ([halaxa](https://github.com/halaxa))
+* Fixed French for Belgium (fr\_BE) Address Provider (doubled city names) [\#354](https://github.com/fzaninotto/Faker/pull/354) ([miclf](https://github.com/miclf))
+* Added Biased Integer Provider [\#332](https://github.com/fzaninotto/Faker/pull/332) ([TimWolla](https://github.com/TimWolla))
+* Added Swedish (sv\_SE) locale [\#316](https://github.com/fzaninotto/Faker/pull/316) ([ulrikjohansson](https://github.com/ulrikjohansson))
+* Added English for New Zealand (en\_NZ) locale [\#283](https://github.com/fzaninotto/Faker/pull/283) ([JasonMortonNZ](https://github.com/JasonMortonNZ))
+* Added mention of external Provider for cron expressions to readme[\#498](https://github.com/fzaninotto/Faker/pull/498) ([swekaj](https://github.com/swekaj))
+
+## 2014-06-04, v1.4.0
+
+* Fixed typo in Slovak person names (cinan)
+* Added tests for uk_UA providers (serge-kuharev)
+* Fixed numerify() performance by making it 30% faster (fzaninotto)
+* Added strict option to randomNumber to force number of digits (fzaninotto)
+* Fixed randomNumber usage duplicating numberBetween (fzaninotto)
+* Fixed address provider for latvian language (MatissJA)
+* Added Czech Republic (cs_CZ) address, company, datetime and text providers (Mikulas)
+* Fixed da_DK Person provider data containing an 'unnamed' person (tolnem)
+* Added slug provider (fzaninotto)
+* Fixed IDE insights for new local IP and MAC address providers (hugofonseca)
+* Added firstname gender method to all Person providers (csanquer)
+* Fixed tr_TR email service, city name, person, and phone number formats (ogunkarakus)
+* Fixed US_en state list (fzaninotto)
+* Fixed en_US address provider so state abbr are ISO 3166 codes (Garbee)
+* Added local IP and MAC address providers (kielabokkie)
+* Fixed typo in century list affecting the century provider (fzaninotto)
+* Added default value to optional modifier (joshuajabbour)
+* Fixed Portuguese phonenumbers have 9 digits (hugofonseca)
+* Added fileCopy to File provider to simulate file upload (stefanosala)
+* Added pt_PT providers (hugofonseca)
+* Fixed dead code in text provider (hugofonseca)
+* Fixed IDE insights for magic properties (hugofonseca)
+* Added tin (NIF) generator for pt_PT provider (hugofonseca)
+* Fixed numberBetween max default value handling (fzaninotto)
+* Added pt_PT phone number provider (hugofonseca)
+* Fixed PSR-2 standards and add make task to force it on Travis (terite)
+* Added new ro_RO Personal Numerical Code (CNP) and phone number providers (avataru)
+* Fixed Internet provider for sk_SK locale (cinan)
+* Fixed typo in en_ZA Internet provider (bjorntheart)
+* Fixed phpdoc for DateTime magic methods (stof)
+* Added doc about seeding with maximum timestamp using dateTime formatters (fzaninotto)
+* Added Maximum Timestamp option to get always same unix timestamp when using a fixed seed (csanquer)
+* Added Montenegrian (me_ME) providers (ognjenm)
+* Added ean barcode provider (nineinchnick)
+* Added fullPath parameter to Image provider (stefanosala)
+* Added more Polish company formats (nineinchnick)
+* Added Polish realText provider (nineinchnick)
+* Fixed remaining non-seedable random generators (terite)
+* Added randomElements provider (terite)
+* Added French realText provider (fzaninotto)
+* Fixed realText provider bootstrap slowness (fzaninotto)
+* Added realText provider for English and German, based on Markov Chains Generator (TimWolla)
+* Fixed address format in nl_NL provider (doenietzomoeilijk)
+* Fixed potentially offensive word from last name list (joshuajabbour)
+* Fixed reamde documentation about the optional modifier (cryode)
+* Fixed Image provider and documentor routine (fzaninotto)
+* Fixed IDE insights for methods (PedroTroller)
+* Fixed missing data in en_US Address provider (Garbee)
+* Added Bengali (bn_BD) providers (masnun)
+* Fixed warning on test file when short tags are on (bateller)
+* Fixed Doctrine populator undefined index warning (dbojdo)
+* Added French Canadian (fr_CA) Address and Person providers (marcaube)
+* Fixed typo in NullGenerator (mhanson01)
+* Fixed Doctrine populator issue with one-to-one nullable relationship (jpetitcolas)
+* Added Canadian English (en_CA) address and phone number providers (cviebrock)
+* Fixed duplicated Payment example in readme (Garbee)
+* Fixed Polish (pl_PL) Person provider data (czogori)
+* Added Hungarian (hu_HU) providers (sagikazarmark)
+* Added 'kana' (ja_JP) name formatters (kzykhys)
+* Added allow_failure for hhvm to travis-ci and test against php 5.5 (toin0u)
+
+## 2013-12-16, v1.3.0
+
+* Fixed state generator in Australian (en_AU) provider (sebklaus)
+* Fixed IDE insights for locale specific providers (ulrikjohansson)
+* Added English (South Africa) (en_ZA) person, address, Internet and phone number providers (dmfaux)
+* Fixed integer values overflowing on signed INTEGER columns on Doctrine populator (Thinkscape)
+* Fixed spelling error in French (fr_FR) address provider (leihog)
+* Added improvements based on SensioLabsInsights analysis
+* Fixed Italian (it_IT) email provider (garak)
+* Added Spanish (es_ES) Internet provider (eusonlito)
+* Added English Philippines (en_PH) address provider (kamote)
+* Added Brazilian (pt_BR) email provider data (KennedyTedesco)
+* Fixed UK country code (pgscandeias)
+* Added Peruvian (es_PE) person, address, phone number, and company providers (cslucano)
+* Added Ukrainian (uk_UA) color provider (ruden)
+* Fixed Ukrainian (uk_UA) namespace and email translitteration (ruden)
+* Added Romanian (Moldova) (ro_MD) person, address, and phone number providers (AlexanderC)
+* Added IBAN generator for every currently known locale that uses it (nineinchnick)
+* Added Image generation powered by LoremPixel (weotch)
+* Fixed missing timezone with dateTimeBetween (baldurrensch)
+* Fixed call to undefined method cardType in Payment (WMeldon)
+* Added Romanian (ro_RO) address and person providers (calina-c)
+* Fixed Doctrine populator to use ObjectManager instead of EntityManagerInterface (mgiustiniani)
+* Fixed docblock for Provider\Base::unique() (pschultz)
+* Added Payment providers (creditCardType, creditCardNumber, creditCardExpirationDate, creditCardExpirationDateString) (pomaxa)
+* Added unique() modifier
+* Added IDE insights to allow better intellisense/phpStorm autocompletion (thallisphp)
+* Added Polish (pl_PL) address provider, personal identity number and pesel number generator (nineinchnick)
+* Added Turkish (tr_TR) address provider, and improved internet provider (hasandz)
+* Fixed Propel column number guesser to use signed range of values (gunnarlium)
+* Added Greek (el_GR) person, address, and phone number providers (georgeharito)
+* Added Austrian (en_AU) address, Internet, and phone number providers (rcuddy)
+* Fixed phpDoc in Doctrine Entity populator (rogamoore)
+* Added French (fr_FR) phone number formats (vchabot)
+* Added optional() modifier (weotch)
+* Fixed typo in the Person provider documentation (jtreminio)
+* Fixed Russian (ru_RU) person format (alexshadow007)
+* Added Japanese (ja_JP) person, address, Internet, phone number, and company providers (kumamidori)
+* Added color providers, driver license and passport number formats for the ru_RU locale (pomaxa)
+* Added Latvian (lv_LV) person, address, Internet, and phone number providers (pomaxa)
+* Added Brazilian (pt_BR) Internet provider (vjnrv)
+* Added more Czech (cs_CZ) lastnames (petrkle)
+* Added Chinese Simplified (zh_CN) person, address, Internet, and phone number providers (tlikai)
+* Fixed Typos (pborelli)
+* Added Color provider with hexColor, rgbColor, rgbColorAsArray, rgbCssColor, safeColorName, and colorName formatters (lsv)
+* Added support for associative arrays in `randomElement` (aRn0D)
+
+## 2013-06-09, v1.2.0
+
+* Added new provider for fr_BE locale (jflefebvre)
+* Updated locale provider to use a static locale list (spawn-guy)
+* Fixed invalid UTF-8 sequence in domain provider with the Bulgarian provider (Dynom)
+* Fixed the nl_NL Person provider (Dynom)
+* Removed all requires and added the autoload definition to composer (Dynom)
+* Fixed encoding problems in nl_NL Address provider (Dynom)
+* Added icelandic provider (is_IS) (birkir)
+* Added en_CA address and phone numbers (cviebrock)
+* Updated safeEmail provider to be really safe (TimWolla)
+* Documented alternative randomNumber usage (Seldaek)
+* Added basic file provider (anroots)
+* Fixed use of fourth argument on Doctrine addEntity (ecentinela)
+* Added nl_BE provider (wimvds)
+* Added Random Float provider (csanquer)
+* Fixed bug in Faker\ORM\Doctrine\Populator (mmf-amarcos)
+* Updated ru_RU provider (rmrevin)
+* Added safe email domain provider (csanquer)
+* Fixed latitude provider (rumpl)
+* Fixed unpredictability of fake data generated by Faker\Provider\Base::numberBetween() (goatherd)
+* Added uuid provider (goatherd)
+* Added possibility to call methods on Doctrine entities, possibility to generate unique id (nenadalm)
+* Fixed prefixes typos in 'pl_PL' Person provider (krymen)
+* Added more fake data to the Ukraininan providers (lysenkobv)
+* Added more fake data to the Italian providers (EmanueleMinotto)
+* Fixed spaces appearing in generated emails (alchy58)
+* Added Armenian (hy_AM) provider (artash)
+* Added Generation of valid SIREN & SIRET codes to French providers (alexsegura)
+* Added Dutch (nl_NL) provider (WouterJ)
+* Fixed missing typehint in Base::__construct() (benja-M-1)
+* Fixed typo in README (benja-M-1)
+* Added Ukrainian (ua_UA) provider (rsvasilyev)
+* Added Turkish (tr_TR) Provider (faridmovsumov)
+* Fixed executable bit in some PHP files (siwinski)
+* Added Brazilian Portuguese (pt_BR) provider (oliveiraev)
+* Added Spanish (es_ES) provider (ivannis)
+* Fixed Doctrine populator to allow for the population of entity data that has associations to other entities (afishnamedsquish)
+* Added Danish (da_DK) providers (toin0u)
+* Cleaned up whitespaces (toin0u)
+* Fixed utf-8 bug with lowercase generators (toin0u)
+* Fixed composer.json (Seldaek)
+* Fixed bug in Doctrine EntityPopulator (beberlei)
+* Added Finnish (fi_FI) provider (drodil)
+
+## 2012-10-29, v1.1.0
+
+* Updated text provider to return paragraphs as a string instead of array. Great for populating markdown textarea fields (Seldaek)
+* Updated dateTimeBetween to accept DateTime instances (Seldaek)
+* Added random number generator between a and b, simply like rand() (Seldaek)
+* Fixed spaces in generated emails (blaugueux)
+* Fixed Person provider in Russian locale (Isamashii)
+* Added new UserAgent provider (blaugueux)
+* Added locale generator to Miscellaneous provider (blaugueux)
+* Added timezone generator to DateTime provider (blaugueux)
+* Added new generators to French Address providers (departments, regions) (geoffrey-brier)
+* Added new generators to French Company provider (catch phrase, SIREN, and SIRET numbers) (geoffrey-brier)
+* Added state generator to German Address provider (Powerhamster)
+* Added Slovak provider (bazo)
+* Added latitude and longitude formatters to Address provider (fixe)
+* Added Serbian provider (umpirsky)
+
+## 2012-07-10, v1.0.0
+
+* Initial Version
diff --git a/vendor/fzaninotto/faker/LICENSE b/vendor/fzaninotto/faker/LICENSE
new file mode 100644
index 000000000..99ed0075f
--- /dev/null
+++ b/vendor/fzaninotto/faker/LICENSE
@@ -0,0 +1,22 @@
+Copyright (c) 2011 François Zaninotto
+Portions Copyright (c) 2008 Caius Durling
+Portions Copyright (c) 2008 Adam Royle
+Portions Copyright (c) 2008 Fiona Burrows
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
diff --git a/vendor/fzaninotto/faker/composer.json b/vendor/fzaninotto/faker/composer.json
new file mode 100644
index 000000000..acf673ec0
--- /dev/null
+++ b/vendor/fzaninotto/faker/composer.json
@@ -0,0 +1,42 @@
+{
+ "name": "fzaninotto/faker",
+ "type": "library",
+ "description": "Faker is a PHP library that generates fake data for you.",
+ "keywords": [
+ "faker",
+ "fixtures",
+ "data"
+ ],
+ "license": "MIT",
+ "authors": [
+ {
+ "name": "François Zaninotto"
+ }
+ ],
+ "require": {
+ "php": "^5.3.3 || ^7.0"
+ },
+ "require-dev": {
+ "ext-intl": "*",
+ "phpunit/phpunit": "^4.8.35 || ^5.7",
+ "squizlabs/php_codesniffer": "^2.9.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Faker\\": "src/Faker/"
+ }
+ },
+ "autoload-dev": {
+ "psr-4": {
+ "Faker\\Test\\": "test/Faker/"
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.9-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ }
+}
diff --git a/vendor/fzaninotto/faker/readme.md b/vendor/fzaninotto/faker/readme.md
new file mode 100644
index 000000000..1c0659ce8
--- /dev/null
+++ b/vendor/fzaninotto/faker/readme.md
@@ -0,0 +1,1798 @@
+# Faker
+
+[](https://codecov.io/gh/fzaninotto/Faker)
+
+Faker is a PHP library that generates fake data for you. Whether you need to bootstrap your database, create good-looking XML documents, fill-in your persistence to stress test it, or anonymize data taken from a production service, Faker is for you.
+
+Faker is heavily inspired by Perl's [Data::Faker](http://search.cpan.org/~jasonk/Data-Faker-0.07/), and by ruby's [Faker](https://rubygems.org/gems/faker).
+
+Faker requires PHP >= 5.3.3.
+
+[](https://packagist.org/packages/fzaninotto/faker) [](https://travis-ci.org/fzaninotto/Faker) [](https://insight.sensiolabs.com/projects/eceb78a9-38d4-4ad5-8b6b-b52f323e3549)
+
+# Table of Contents
+
+- [Installation](#installation)
+- [Basic Usage](#basic-usage)
+- [Formatters](#formatters)
+ - [Base](#fakerproviderbase)
+ - [Lorem Ipsum Text](#fakerproviderlorem)
+ - [Person](#fakerprovideren_usperson)
+ - [Address](#fakerprovideren_usaddress)
+ - [Phone Number](#fakerprovideren_usphonenumber)
+ - [Company](#fakerprovideren_uscompany)
+ - [Real Text](#fakerprovideren_ustext)
+ - [Date and Time](#fakerproviderdatetime)
+ - [Internet](#fakerproviderinternet)
+ - [User Agent](#fakerprovideruseragent)
+ - [Payment](#fakerproviderpayment)
+ - [Color](#fakerprovidercolor)
+ - [File](#fakerproviderfile)
+ - [Image](#fakerproviderimage)
+ - [Uuid](#fakerprovideruuid)
+ - [Barcode](#fakerproviderbarcode)
+ - [Miscellaneous](#fakerprovidermiscellaneous)
+ - [Biased](#fakerproviderbiased)
+ - [Html Lorem](#fakerproviderhtmllorem)
+- [Modifiers](#modifiers)
+- [Localization](#localization)
+- [Populating Entities Using an ORM or an ODM](#populating-entities-using-an-orm-or-an-odm)
+- [Seeding the Generator](#seeding-the-generator)
+- [Faker Internals: Understanding Providers](#faker-internals-understanding-providers)
+- [Real Life Usage](#real-life-usage)
+- [Language specific formatters](#language-specific-formatters)
+- [Third-Party Libraries Extending/Based On Faker](#third-party-libraries-extendingbased-on-faker)
+- [License](#license)
+
+
+## Installation
+
+```sh
+composer require fzaninotto/faker
+```
+
+## Basic Usage
+
+### Autoloading
+
+Faker supports both `PSR-0` as `PSR-4` autoloaders.
+```php
+name;
+ // 'Lucy Cechtelar';
+echo $faker->address;
+ // "426 Jordy Lodge
+ // Cartwrightshire, SC 88120-6700"
+echo $faker->text;
+ // Dolores sit sint laboriosam dolorem culpa et autem. Beatae nam sunt fugit
+ // et sit et mollitia sed.
+ // Fuga deserunt tempora facere magni omnis. Omnis quia temporibus laudantium
+ // sit minima sint.
+```
+
+Even if this example shows a property access, each call to `$faker->name` yields a different (random) result. This is because Faker uses `__get()` magic, and forwards `Faker\Generator->$property` calls to `Faker\Generator->format($property)`.
+
+```php
+name, "\n";
+}
+ // Adaline Reichel
+ // Dr. Santa Prosacco DVM
+ // Noemy Vandervort V
+ // Lexi O'Conner
+ // Gracie Weber
+ // Roscoe Johns
+ // Emmett Lebsack
+ // Keegan Thiel
+ // Wellington Koelpin II
+ // Ms. Karley Kiehn V
+```
+
+**Tip**: For a quick generation of fake data, you can also use Faker as a command line tool thanks to [faker-cli](https://github.com/bit3/faker-cli).
+
+## Formatters
+
+Each of the generator properties (like `name`, `address`, and `lorem`) are called "formatters". A faker generator has many of them, packaged in "providers". Here is a list of the bundled formatters in the default locale.
+
+### `Faker\Provider\Base`
+
+ randomDigit // 7
+ randomDigitNot(5) // 0, 1, 2, 3, 4, 6, 7, 8, or 9
+ randomDigitNotNull // 5
+ randomNumber($nbDigits = NULL, $strict = false) // 79907610
+ randomFloat($nbMaxDecimals = NULL, $min = 0, $max = NULL) // 48.8932
+ numberBetween($min = 1000, $max = 9000) // 8567
+ randomLetter // 'b'
+ // returns randomly ordered subsequence of a provided array
+ randomElements($array = array ('a','b','c'), $count = 1) // array('c')
+ randomElement($array = array ('a','b','c')) // 'b'
+ shuffle('hello, world') // 'rlo,h eoldlw'
+ shuffle(array(1, 2, 3)) // array(2, 1, 3)
+ numerify('Hello ###') // 'Hello 609'
+ lexify('Hello ???') // 'Hello wgt'
+ bothify('Hello ##??') // 'Hello 42jz'
+ asciify('Hello ***') // 'Hello R6+'
+ regexify('[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,4}'); // sm0@y8k96a.ej
+
+### `Faker\Provider\Lorem`
+
+ word // 'aut'
+ words($nb = 3, $asText = false) // array('porro', 'sed', 'magni')
+ sentence($nbWords = 6, $variableNbWords = true) // 'Sit vitae voluptas sint non voluptates.'
+ sentences($nb = 3, $asText = false) // array('Optio quos qui illo error.', 'Laborum vero a officia id corporis.', 'Saepe provident esse hic eligendi.')
+ paragraph($nbSentences = 3, $variableNbSentences = true) // 'Ut ab voluptas sed a nam. Sint autem inventore aut officia aut aut blanditiis. Ducimus eos odit amet et est ut eum.'
+ paragraphs($nb = 3, $asText = false) // array('Quidem ut sunt et quidem est accusamus aut. Fuga est placeat rerum ut. Enim ex eveniet facere sunt.', 'Aut nam et eum architecto fugit repellendus illo. Qui ex esse veritatis.', 'Possimus omnis aut incidunt sunt. Asperiores incidunt iure sequi cum culpa rem. Rerum exercitationem est rem.')
+ text($maxNbChars = 200) // 'Fuga totam reiciendis qui architecto fugiat nemo. Consequatur recusandae qui cupiditate eos quod.'
+
+### `Faker\Provider\en_US\Person`
+
+ title($gender = null|'male'|'female') // 'Ms.'
+ titleMale // 'Mr.'
+ titleFemale // 'Ms.'
+ suffix // 'Jr.'
+ name($gender = null|'male'|'female') // 'Dr. Zane Stroman'
+ firstName($gender = null|'male'|'female') // 'Maynard'
+ firstNameMale // 'Maynard'
+ firstNameFemale // 'Rachel'
+ lastName // 'Zulauf'
+
+### `Faker\Provider\en_US\Address`
+
+ cityPrefix // 'Lake'
+ secondaryAddress // 'Suite 961'
+ state // 'NewMexico'
+ stateAbbr // 'OH'
+ citySuffix // 'borough'
+ streetSuffix // 'Keys'
+ buildingNumber // '484'
+ city // 'West Judge'
+ streetName // 'Keegan Trail'
+ streetAddress // '439 Karley Loaf Suite 897'
+ postcode // '17916'
+ address // '8888 Cummings Vista Apt. 101, Susanbury, NY 95473'
+ country // 'Falkland Islands (Malvinas)'
+ latitude($min = -90, $max = 90) // 77.147489
+ longitude($min = -180, $max = 180) // 86.211205
+
+### `Faker\Provider\en_US\PhoneNumber`
+
+ phoneNumber // '201-886-0269 x3767'
+ tollFreePhoneNumber // '(888) 937-7238'
+ e164PhoneNumber // '+27113456789'
+
+### `Faker\Provider\en_US\Company`
+
+ catchPhrase // 'Monitored regional contingency'
+ bs // 'e-enable robust architectures'
+ company // 'Bogan-Treutel'
+ companySuffix // 'and Sons'
+ jobTitle // 'Cashier'
+
+### `Faker\Provider\en_US\Text`
+
+ realText($maxNbChars = 200, $indexSize = 2) // "And yet I wish you could manage it?) 'And what are they made of?' Alice asked in a shrill, passionate voice. 'Would YOU like cats if you were never even spoke to Time!' 'Perhaps not,' Alice replied."
+
+### `Faker\Provider\DateTime`
+
+ unixTime($max = 'now') // 58781813
+ dateTime($max = 'now', $timezone = null) // DateTime('2008-04-25 08:37:17', 'UTC')
+ dateTimeAD($max = 'now', $timezone = null) // DateTime('1800-04-29 20:38:49', 'Europe/Paris')
+ iso8601($max = 'now') // '1978-12-09T10:10:29+0000'
+ date($format = 'Y-m-d', $max = 'now') // '1979-06-09'
+ time($format = 'H:i:s', $max = 'now') // '20:49:42'
+ dateTimeBetween($startDate = '-30 years', $endDate = 'now', $timezone = null) // DateTime('2003-03-15 02:00:49', 'Africa/Lagos')
+ dateTimeInInterval($startDate = '-30 years', $interval = '+ 5 days', $timezone = null) // DateTime('2003-03-15 02:00:49', 'Antartica/Vostok')
+ dateTimeThisCentury($max = 'now', $timezone = null) // DateTime('1915-05-30 19:28:21', 'UTC')
+ dateTimeThisDecade($max = 'now', $timezone = null) // DateTime('2007-05-29 22:30:48', 'Europe/Paris')
+ dateTimeThisYear($max = 'now', $timezone = null) // DateTime('2011-02-27 20:52:14', 'Africa/Lagos')
+ dateTimeThisMonth($max = 'now', $timezone = null) // DateTime('2011-10-23 13:46:23', 'Antarctica/Vostok')
+ amPm($max = 'now') // 'pm'
+ dayOfMonth($max = 'now') // '04'
+ dayOfWeek($max = 'now') // 'Friday'
+ month($max = 'now') // '06'
+ monthName($max = 'now') // 'January'
+ year($max = 'now') // '1993'
+ century // 'VI'
+ timezone // 'Europe/Paris'
+
+Methods accepting a `$timezone` argument default to `date_default_timezone_get()`. You can pass a custom timezone string to each method, or define a custom timezone for all time methods at once using `$faker::setDefaultTimezone($timezone)`.
+
+### `Faker\Provider\Internet`
+
+ email // 'tkshlerin@collins.com'
+ safeEmail // 'king.alford@example.org'
+ freeEmail // 'bradley72@gmail.com'
+ companyEmail // 'russel.durward@mcdermott.org'
+ freeEmailDomain // 'yahoo.com'
+ safeEmailDomain // 'example.org'
+ userName // 'wade55'
+ password // 'k&|X+a45*2['
+ domainName // 'wolffdeckow.net'
+ domainWord // 'feeney'
+ tld // 'biz'
+ url // 'http://www.skilesdonnelly.biz/aut-accusantium-ut-architecto-sit-et.html'
+ slug // 'aut-repellat-commodi-vel-itaque-nihil-id-saepe-nostrum'
+ ipv4 // '109.133.32.252'
+ localIpv4 // '10.242.58.8'
+ ipv6 // '8e65:933d:22ee:a232:f1c1:2741:1f10:117c'
+ macAddress // '43:85:B7:08:10:CA'
+
+### `Faker\Provider\UserAgent`
+
+ userAgent // 'Mozilla/5.0 (Windows CE) AppleWebKit/5350 (KHTML, like Gecko) Chrome/13.0.888.0 Safari/5350'
+ chrome // 'Mozilla/5.0 (Macintosh; PPC Mac OS X 10_6_5) AppleWebKit/5312 (KHTML, like Gecko) Chrome/14.0.894.0 Safari/5312'
+ firefox // 'Mozilla/5.0 (X11; Linuxi686; rv:7.0) Gecko/20101231 Firefox/3.6'
+ safari // 'Mozilla/5.0 (Macintosh; U; PPC Mac OS X 10_7_1 rv:3.0; en-US) AppleWebKit/534.11.3 (KHTML, like Gecko) Version/4.0 Safari/534.11.3'
+ opera // 'Opera/8.25 (Windows NT 5.1; en-US) Presto/2.9.188 Version/10.00'
+ internetExplorer // 'Mozilla/5.0 (compatible; MSIE 7.0; Windows 98; Win 9x 4.90; Trident/3.0)'
+
+### `Faker\Provider\Payment`
+
+ creditCardType // 'MasterCard'
+ creditCardNumber // '4485480221084675'
+ creditCardExpirationDate // 04/13
+ creditCardExpirationDateString // '04/13'
+ creditCardDetails // array('MasterCard', '4485480221084675', 'Aleksander Nowak', '04/13')
+ // Generates a random IBAN. Set $countryCode to null for a random country
+ iban($countryCode) // 'IT31A8497112740YZ575DJ28BP4'
+ swiftBicNumber // 'RZTIAT22263'
+
+### `Faker\Provider\Color`
+
+ hexcolor // '#fa3cc2'
+ rgbcolor // '0,255,122'
+ rgbColorAsArray // array(0,255,122)
+ rgbCssColor // 'rgb(0,255,122)'
+ safeColorName // 'fuchsia'
+ colorName // 'Gainsbor'
+ hslColor // '340,50,20'
+ hslColorAsArray // array(340,50,20)
+
+### `Faker\Provider\File`
+
+ fileExtension // 'avi'
+ mimeType // 'video/x-msvideo'
+ // Copy a random file from the source to the target directory and returns the fullpath or filename
+ file($sourceDir = '/tmp', $targetDir = '/tmp') // '/path/to/targetDir/13b73edae8443990be1aa8f1a483bc27.jpg'
+ file($sourceDir, $targetDir, false) // '13b73edae8443990be1aa8f1a483bc27.jpg'
+
+### `Faker\Provider\Image`
+
+ // Image generation provided by LoremPixel (http://lorempixel.com/)
+ imageUrl($width = 640, $height = 480) // 'http://lorempixel.com/640/480/'
+ imageUrl($width, $height, 'cats') // 'http://lorempixel.com/800/600/cats/'
+ imageUrl($width, $height, 'cats', true, 'Faker') // 'http://lorempixel.com/800/400/cats/Faker'
+ imageUrl($width, $height, 'cats', true, 'Faker', true) // 'http://lorempixel.com/gray/800/400/cats/Faker/' Monochrome image
+ image($dir = '/tmp', $width = 640, $height = 480) // '/tmp/13b73edae8443990be1aa8f1a483bc27.jpg'
+ image($dir, $width, $height, 'cats') // 'tmp/13b73edae8443990be1aa8f1a483bc27.jpg' it's a cat!
+ image($dir, $width, $height, 'cats', false) // '13b73edae8443990be1aa8f1a483bc27.jpg' it's a filename without path
+ image($dir, $width, $height, 'cats', true, false) // it's a no randomize images (default: `true`)
+ image($dir, $width, $height, 'cats', true, true, 'Faker') // 'tmp/13b73edae8443990be1aa8f1a483bc27.jpg' it's a cat with 'Faker' text. Default, `null`.
+
+### `Faker\Provider\Uuid`
+
+ uuid // '7e57d004-2b97-0e7a-b45f-5387367791cd'
+
+### `Faker\Provider\Barcode`
+
+ ean13 // '4006381333931'
+ ean8 // '73513537'
+ isbn13 // '9790404436093'
+ isbn10 // '4881416324'
+
+### `Faker\Provider\Miscellaneous`
+
+ boolean // false
+ boolean($chanceOfGettingTrue = 50) // true
+ md5 // 'de99a620c50f2990e87144735cd357e7'
+ sha1 // 'f08e7f04ca1a413807ebc47551a40a20a0b4de5c'
+ sha256 // '0061e4c60dac5c1d82db0135a42e00c89ae3a333e7c26485321f24348c7e98a5'
+ locale // en_UK
+ countryCode // UK
+ languageCode // en
+ currencyCode // EUR
+ emoji // ðŸ˜
+
+### `Faker\Provider\Biased`
+
+ // get a random number between 10 and 20,
+ // with more chances to be close to 20
+ biasedNumberBetween($min = 10, $max = 20, $function = 'sqrt')
+
+### `Faker\Provider\HtmlLorem`
+
+ //Generate HTML document which is no more than 2 levels deep, and no more than 3 elements wide at any level.
+ randomHtml(2,3) // Aut illo dolorem et accusantium eum. Id aut saepe non mollitia voluptas voluptas. Non consequatur. Incidunt est. Aut voluptatem. Officia voluptas rerum quo. Asperiores similique. Sapiente dolorum dolorem sint laboriosam commodi qui. Commodi nihil nesciunt eveniet quo repudiandae. Voluptates explicabo numquam distinctio necessitatibus repellat. Provident ut doloremque nam eum modi aspernatur. Iusto inventore. Animi nihil ratione id mollitia libero ipsa quia tempore. Velit est officia et aut tenetur dolorem sed mollitia expedita. Modi modi repudiandae pariatur voluptas rerum ea incidunt non molestiae eligendi eos deleniti. Exercitationem voluptatibus dolor est iste quod molestiae. Quia reiciendis. Inventore impedit exercitationem voluptatibus rerum cupiditate. Qui. Aliquam. Autem nihil aut et. Dolor ut quia error. Enim facilis iusto earum et minus rerum assumenda quis quia. Reprehenderit ut sapiente occaecati voluptatum dolor voluptatem vitae qui velit. Quod fugiat non. Sunt nobis totam mollitia sed nesciunt est deleniti cumque. Repudiandae quo. Modi dicta libero quisquam doloremque qui autem. Voluptatem aliquid saepe laudantium facere eos sunt dolor. Est eos quis laboriosam officia expedita repellendus quia natus. Et neque delectus quod fugit enim repudiandae qui. Fugit soluta sit facilis facere repellat culpa magni voluptatem maiores tempora. Enim dolores doloremque. Assumenda voluptatem eum perferendis exercitationem. Quasi in fugit deserunt ea perferendis sunt nemo consequatur dolorum soluta. Maxime repellat qui numquam voluptatem est modi. Alias rerum rerum hic hic eveniet. Tempore voluptatem. Eaque. Et sit quas fugit iusto. Nemo nihil rerum dignissimos et esse. Repudiandae ipsum numquam. Nemo sunt quia. Sint tempore est neque ducimus harum sed. Dicta placeat atque libero nihil. Et qui aperiam temporibus facilis eum. Ut dolores qui enim et maiores nesciunt. Dolorum totam sint debitis saepe laborum. Quidem corrupti ea. Cum voluptas quod. Possimus consequatur quasi dolorem ut et. Et velit non hic labore repudiandae quis.
+
+## Modifiers
+
+Faker provides three special providers, `unique()`, `optional()`, and `valid()`, to be called before any provider.
+
+```php
+// unique() forces providers to return unique values
+$values = array();
+for ($i = 0; $i < 10; $i++) {
+ // get a random digit, but always a new one, to avoid duplicates
+ $values []= $faker->unique()->randomDigit;
+}
+print_r($values); // [4, 1, 8, 5, 0, 2, 6, 9, 7, 3]
+
+// providers with a limited range will throw an exception when no new unique value can be generated
+$values = array();
+try {
+ for ($i = 0; $i < 10; $i++) {
+ $values []= $faker->unique()->randomDigitNotNull;
+ }
+} catch (\OverflowException $e) {
+ echo "There are only 9 unique digits not null, Faker can't generate 10 of them!";
+}
+
+// you can reset the unique modifier for all providers by passing true as first argument
+$faker->unique($reset = true)->randomDigitNotNull; // will not throw OverflowException since unique() was reset
+// tip: unique() keeps one array of values per provider
+
+// optional() sometimes bypasses the provider to return a default value instead (which defaults to NULL)
+$values = array();
+for ($i = 0; $i < 10; $i++) {
+ // get a random digit, but also null sometimes
+ $values []= $faker->optional()->randomDigit;
+}
+print_r($values); // [1, 4, null, 9, 5, null, null, 4, 6, null]
+
+// optional() accepts a weight argument to specify the probability of receiving the default value.
+// 0 will always return the default value; 1 will always return the provider. Default weight is 0.5 (50% chance).
+$faker->optional($weight = 0.1)->randomDigit; // 90% chance of NULL
+$faker->optional($weight = 0.9)->randomDigit; // 10% chance of NULL
+
+// optional() accepts a default argument to specify the default value to return.
+// Defaults to NULL.
+$faker->optional($weight = 0.5, $default = false)->randomDigit; // 50% chance of FALSE
+$faker->optional($weight = 0.9, $default = 'abc')->word; // 10% chance of 'abc'
+
+// valid() only accepts valid values according to the passed validator functions
+$values = array();
+$evenValidator = function($digit) {
+ return $digit % 2 === 0;
+};
+for ($i = 0; $i < 10; $i++) {
+ $values []= $faker->valid($evenValidator)->randomDigit;
+}
+print_r($values); // [0, 4, 8, 4, 2, 6, 0, 8, 8, 6]
+
+// just like unique(), valid() throws an overflow exception when it can't generate a valid value
+$values = array();
+try {
+ $faker->valid($evenValidator)->randomElement(1, 3, 5, 7, 9);
+} catch (\OverflowException $e) {
+ echo "Can't pick an even number in that set!";
+}
+```
+
+If you would like to use a modifier with a value not generated by Faker, use the `passthrough()` method. `passthrough()` simply returns whatever value it was given.
+
+```php
+$faker->optional()->passthrough(mt_rand(5, 15));
+```
+
+## Localization
+
+`Faker\Factory` can take a locale as an argument, to return localized data. If no localized provider is found, the factory fallbacks to the default locale (en_US).
+
+```php
+name, "\n";
+}
+ // Luce du Coulon
+ // Auguste Dupont
+ // Roger Le Voisin
+ // Alexandre Lacroix
+ // Jacques Humbert-Roy
+ // Thérèse Guillet-Andre
+ // Gilles Gros-Bodin
+ // Amélie Pires
+ // Marcel Laporte
+ // Geneviève Marchal
+```
+
+You can check available Faker locales in the source code, [under the `Provider` directory](https://github.com/fzaninotto/Faker/tree/master/src/Faker/Provider). The localization of Faker is an ongoing process, for which we need your help. Don't hesitate to create localized providers to your own locale and submit a PR!
+
+## Populating Entities Using an ORM or an ODM
+
+Faker provides adapters for Object-Relational and Object-Document Mappers (currently, [Propel](http://www.propelorm.org), [Doctrine2](http://docs.doctrine-project.org/projects/doctrine-orm/en/latest/), [CakePHP](http://cakephp.org), [Spot2](https://github.com/vlucas/spot2), [Mandango](https://github.com/mandango/mandango) and [Eloquent](https://laravel.com/docs/master/eloquent) are supported). These adapters ease the population of databases through the Entity classes provided by an ORM library (or the population of document stores using Document classes provided by an ODM library).
+
+To populate entities, create a new populator class (using a generator instance as parameter), then list the class and number of all the entities that must be generated. To launch the actual data population, call the `execute()` method.
+
+Note that some of the `populators` could require additional parameters. As example the `doctrine` populator has an option to specify
+its batchSize on how often it will flush the UnitOfWork to the database.
+
+Here is an example showing how to populate 5 `Author` and 10 `Book` objects:
+
+```php
+addEntity('Author', 5);
+$populator->addEntity('Book', 10);
+$insertedPKs = $populator->execute();
+```
+
+The populator uses name and column type guessers to populate each column with relevant data. For instance, Faker populates a column named `first_name` using the `firstName` formatter, and a column with a `TIMESTAMP` type using the `dateTime` formatter. The resulting entities are therefore coherent. If Faker misinterprets a column name, you can still specify a custom closure to be used for populating a particular column, using the third argument to `addEntity()`:
+
+```php
+addEntity('Book', 5, array(
+ 'ISBN' => function() use ($generator) { return $generator->ean13(); }
+));
+```
+
+In this example, Faker will guess a formatter for all columns except `ISBN`, for which the given anonymous function will be used.
+
+**Tip**: To ignore some columns, specify `null` for the column names in the third argument of `addEntity()`. This is usually necessary for columns added by a behavior:
+
+```php
+addEntity('Book', 5, array(
+ 'CreatedAt' => null,
+ 'UpdatedAt' => null,
+));
+```
+
+Of course, Faker does not populate autoincremented primary keys. In addition, `Faker\ORM\Propel\Populator::execute()` returns the list of inserted PKs, indexed by class:
+
+```php
+ (34, 35, 36, 37, 38),
+// 'Book' => (456, 457, 458, 459, 470, 471, 472, 473, 474, 475)
+// )
+```
+
+**Note:** Due to the fact that `Faker` returns all the primary keys inserted, the memory consumption will go up drastically when you do batch inserts due to the big list of data.
+
+In the previous example, the `Book` and `Author` models share a relationship. Since `Author` entities are populated first, Faker is smart enough to relate the populated `Book` entities to one of the populated `Author` entities.
+
+Lastly, if you want to execute an arbitrary function on an entity before insertion, use the fourth argument of the `addEntity()` method:
+
+```php
+addEntity('Book', 5, array(), array(
+ function($book) { $book->publish(); },
+));
+```
+
+## Seeding the Generator
+
+You may want to get always the same generated data - for instance when using Faker for unit testing purposes. The generator offers a `seed()` method, which seeds the random number generator. Calling the same script twice with the same seed produces the same results.
+
+```php
+seed(1234);
+
+echo $faker->name; // 'Jess Mraz I';
+```
+
+> **Tip**: DateTime formatters won't reproduce the same fake data if you don't fix the `$max` value:
+>
+> ```php
+> // even when seeded, this line will return different results because $max varies
+> $faker->dateTime(); // equivalent to $faker->dateTime($max = 'now')
+> // make sure you fix the $max parameter
+> $faker->dateTime('2014-02-25 08:37:17'); // will return always the same date when seeded
+> ```
+>
+> **Tip**: Formatters won't reproduce the same fake data if you use the `rand()` php function. Use `$faker` or `mt_rand()` instead:
+>
+> ```php
+> // bad
+> $faker->realText(rand(10,20));
+> // good
+> $faker->realText($faker->numberBetween(10,20));
+> ```
+
+
+
+## Faker Internals: Understanding Providers
+
+A `Faker\Generator` alone can't do much generation. It needs `Faker\Provider` objects to delegate the data generation to them. `Faker\Factory::create()` actually creates a `Faker\Generator` bundled with the default providers. Here is what happens under the hood:
+
+```php
+addProvider(new Faker\Provider\en_US\Person($faker));
+$faker->addProvider(new Faker\Provider\en_US\Address($faker));
+$faker->addProvider(new Faker\Provider\en_US\PhoneNumber($faker));
+$faker->addProvider(new Faker\Provider\en_US\Company($faker));
+$faker->addProvider(new Faker\Provider\Lorem($faker));
+$faker->addProvider(new Faker\Provider\Internet($faker));
+````
+
+Whenever you try to access a property on the `$faker` object, the generator looks for a method with the same name in all the providers attached to it. For instance, calling `$faker->name` triggers a call to `Faker\Provider\Person::name()`. And since Faker starts with the last provider, you can easily override existing formatters: just add a provider containing methods named after the formatters you want to override.
+
+That means that you can easily add your own providers to a `Faker\Generator` instance. A provider is usually a class extending `\Faker\Provider\Base`. This parent class allows you to use methods like `lexify()` or `randomNumber()`; it also gives you access to formatters of other providers, through the protected `$generator` property. The new formatters are the public methods of the provider class.
+
+Here is an example provider for populating Book data:
+
+```php
+generator->sentence($nbWords);
+ return substr($sentence, 0, strlen($sentence) - 1);
+ }
+
+ public function ISBN()
+ {
+ return $this->generator->ean13();
+ }
+}
+```
+
+To register this provider, just add a new instance of `\Faker\Provider\Book` to an existing generator:
+
+```php
+addProvider(new \Faker\Provider\Book($faker));
+```
+
+Now you can use the two new formatters like any other Faker formatter:
+
+```php
+setTitle($faker->title);
+$book->setISBN($faker->ISBN);
+$book->setSummary($faker->text);
+$book->setPrice($faker->randomNumber(2));
+```
+
+**Tip**: A provider can also be a Plain Old PHP Object. In that case, all the public methods of the provider become available to the generator.
+
+## Real Life Usage
+
+The following script generates a valid XML document:
+
+```php
+
+
+
+
+
+
+boolean(25)): ?>
+
+
+
+ streetAddress ?>
+ city ?>
+ postcode ?>
+ state ?>
+
+
+boolean(33)): ?>
+ bs ?>
+
+boolean(33)): ?>
+
+
+
+boolean(15)): ?>
+
+text(400) ?>
+]]>
+
+
+
+
+
+```
+
+Running this script produces a document looking like:
+
+```xml
+
+
+
+
+
+ 182 Harrison Cove
+ North Lloyd
+ 45577
+ Alabama
+
+
+ orchestrate compelling web-readiness
+
+
+
+
+
+
+
+
+ 90111 Hegmann Inlet
+ South Geovanymouth
+ 69961-9311
+ Colorado
+
+
+
+
+
+
+
+ 9791 Nona Corner
+ Harberhaven
+ 74062-8191
+ RhodeIsland
+
+
+
+
+
+
+
+ 11161 Schultz Via
+ Feilstad
+ 98019
+ NewJersey
+
+
+
+
+
+
+
+
+
+
+
+ 6106 Nader Village Suite 753
+ McLaughlinstad
+ 43189-8621
+ Missouri
+
+
+ expedite viral synergies
+
+
+
+
+
+
+ 7546 Kuvalis Plaza
+ South Wilfrid
+ 77069
+ Georgia
+
+
+
+
+
+
+
+
+ 478 Daisha Landing Apt. 510
+ West Lizethhaven
+ 30566-5362
+ WestVirginia
+
+
+ orchestrate dynamic networks
+
+
+
+
+
+
+
+
+
+ 1251 Koelpin Mission
+ North Revastad
+ 81620
+ Maryland
+
+
+
+
+
+
+
+ 6396 Langworth Hills Apt. 446
+ New Carlos
+ 89399-0268
+ Wyoming
+
+
+
+
+
+
+
+
+
+ 2246 Kreiger Station Apt. 291
+ Kaydenmouth
+ 11397-1072
+ Wyoming
+
+
+ grow sticky portals
+
+
+
+
+
+
+```
+
+## Language specific formatters
+
+### `Faker\Provider\ar_SA\Person`
+
+```php
+idNumber; // ID number
+echo $faker->nationalIdNumber // Citizen ID number
+echo $faker->foreignerIdNumber // Foreigner ID number
+echo $faker->companyIdNumber // Company ID number
+```
+
+### `Faker\Provider\ar_SA\Payment`
+
+```php
+bankAccountNumber // "SA0218IBYZVZJSEC8536V4XC"
+```
+
+### `Faker\Provider\at_AT\Payment`
+
+```php
+vat; // "AT U12345678" - Austrian Value Added Tax number
+echo $faker->vat(false); // "ATU12345678" - unspaced Austrian Value Added Tax number
+```
+
+### `Faker\Provider\bg_BG\Payment`
+
+```php
+vat; // "BG 0123456789" - Bulgarian Value Added Tax number
+echo $faker->vat(false); // "BG0123456789" - unspaced Bulgarian Value Added Tax number
+```
+
+### `Faker\Provider\cs_CZ\Address`
+
+```php
+region; // "Liberecký kraj"
+```
+
+### `Faker\Provider\cs_CZ\Company`
+
+```php
+ico; // "69663963"
+```
+
+### `Faker\Provider\cs_CZ\DateTime`
+
+```php
+monthNameGenitive; // "prosince"
+echo $faker->formattedDate; // "12. listopadu 2015"
+```
+
+### `Faker\Provider\cs_CZ\Person`
+
+```php
+birthNumber; // "7304243452"
+```
+
+### `Faker\Provider\da_DK\Person`
+
+```php
+cpr; // "051280-2387"
+```
+
+### `Faker\Provider\da_DK\Address`
+
+```php
+kommune; // "Frederiksberg"
+
+// Generates a random region name
+echo $faker->region; // "Region Sjælland"
+```
+
+### `Faker\Provider\da_DK\Company`
+
+```php
+cvr; // "32458723"
+
+// Generates a random P number
+echo $faker->p; // "5398237590"
+```
+
+### `Faker\Provider\de_CH\Person`
+```php
+avs13; // "756.1234.5678.97" OR
+echo $faker->ahv13; // "756.1234.5678.97"
+```
+
+### `Faker\Provider\de_DE\Payment`
+
+```php
+bankAccountNumber; // "DE41849025553661169313"
+echo $faker->bank; // "Volksbank Stuttgart"
+
+```
+
+### `Faker\Provider\en_HK\Address`
+
+```php
+town; // "Yuen Long"
+
+// Generates a fake village name based on the words commonly found in Hong Kong
+echo $faker->village; // "O Tau"
+
+// Generates a fake estate name based on the words commonly found in Hong Kong
+echo $faker->estate; // "Ching Lai Court"
+
+```
+
+### `Faker\Provider\en_HK\Phone`
+
+```php
+mobileNumber; // "92150087"
+
+// Generates a Hong Kong landline number (starting with 2 or 3)
+echo $faker->landlineNumber; // "32750132"
+
+// Generates a Hong Kong fax number (starting with 7)
+echo $faker->faxNumber; // "71937729"
+
+```
+
+### `Faker\Provider\en_NG\Address`
+
+```php
+region; // 'Katsina'
+```
+
+### `Faker\Provider\en_NG\Person`
+
+```php
+name; // 'Oluwunmi Mayowa'
+```
+
+### `Faker\Provider\en_NZ\Phone`
+
+```php
+mobileNumber; // "021 123 4567"
+
+// Generates a toll free number
+echo $faker->tollFreeNumber; // "0800 123 456"
+
+// Area Code
+echo $faker->areaCode; // "03"
+```
+
+### `Faker\Provider\en_US\Company`
+
+```php
+ein; // '12-3456789'
+```
+
+### `Faker\Provider\en_US\Payment`
+
+```php
+bankAccountNumber; // '51915734310'
+echo $faker->bankRoutingNumber; // '212240302'
+```
+
+### `Faker\Provider\en_US\Person`
+
+```php
+ssn; // '123-45-6789'
+```
+
+### `Faker\Provider\en_ZA\Company`
+
+```php
+companyNumber; // 1999/789634/01
+```
+
+### `Faker\Provider\en_ZA\Person`
+
+```php
+idNumber; // 6606192211041
+
+// Generates a random valid licence code
+echo $faker->licenceCode; // EB
+```
+
+### `Faker\Provider\en_ZA\PhoneNumber`
+
+```php
+tollFreeNumber; // 0800 555 5555
+
+// Generates a mobile phone number
+echo $faker->mobileNumber; // 082 123 5555
+```
+
+### `Faker\Provider\es_ES\Person`
+
+```php
+dni; // '77446565E'
+
+// Generates a random valid licence code
+echo $faker->licenceCode; // B
+```
+
+### `Faker\Provider\es_ES\Payment`
+
+```php
+vat; // "A35864370"
+```
+
+### `Faker\Provider\es_ES\PhoneNumber`
+
+```php
+tollFreeNumber; // 900 123 456
+
+// Generates a mobile phone number
+echo $faker->mobileNumber; // +34 612 12 24
+```
+
+### `Faker\Provider\es_PE\Person`
+
+```php
+dni; // '83367512'
+```
+
+### `Faker\Provider\fa_IR\Person`
+
+```php
+nationalCode; // "0078475759"
+```
+
+### `Faker\Provider\fa_IR\Address`
+
+```php
+building; // "ساختمان Ø¢ÙØªØ§Ø¨"
+
+// Returns a random city name
+echo $faker->city // "استان زنجان"
+```
+
+### `Faker\Provider\fa_IR\Company`
+
+```php
+contract; // "رسمی"
+```
+
+### `Faker\Provider\fi_FI\Payment`
+
+```php
+bankAccountNumber; // "FI8350799879879616"
+```
+
+### `Faker\Provider\fi_FI\Person`
+
+```php
+personalIdentityNumber() // '170974-007J'
+
+//Since the numbers are different for male and female persons, optionally you can specify gender.
+echo $faker->personalIdentityNumber(\DateTime::createFromFormat('Y-m-d', '2015-12-14'), 'female') // '141215A520B'
+```
+
+### `Faker\Provider\fr_BE\Payment`
+
+```php
+vat; // "BE 0123456789" - Belgian Value Added Tax number
+echo $faker->vat(false); // "BE0123456789" - unspaced Belgian Value Added Tax number
+```
+
+### `Faker\Provider\es_VE\Person`
+
+```php
+nationalId; // 'V11223344'
+```
+
+### `Faker\Provider\es_VE\Company`
+
+```php
+taxpayerIdentificationNumber; // 'J1234567891'
+```
+
+### `Faker\Provider\fr_CH\Person`
+```php
+avs13; // "756.1234.5678.97"
+```
+
+### `Faker\Provider\fr_FR\Address`
+
+```php
+departmentName; // "Haut-Rhin"
+
+// Generates a random department number
+echo $faker->departmentNumber; // "2B"
+
+// Generates a random department info (department number => department name)
+$faker->department; // array('18' => 'Cher');
+
+// Generates a random region
+echo $faker->region; // "Saint-Pierre-et-Miquelon"
+
+// Generates a random appartement,stair
+echo $faker->secondaryAddress; // "Bat. 961"
+```
+
+### `Faker\Provider\fr_FR\Company`
+
+```php
+siren; // 082 250 104
+
+// Generates a random SIRET number
+echo $faker->siret; // 347 355 708 00224
+```
+
+### `Faker\Provider\fr_FR\Payment`
+
+```php
+vat; // FR 12 123 456 789
+```
+
+### `Faker\Provider\fr_FR\Person`
+
+```php
+nir; // 1 88 07 35 127 571 - 19
+```
+
+### `Faker\Provider\fr_FR\PhoneNumber`
+
+```php
+phoneNumber; // +33 (0)1 67 97 01 31
+echo $faker->mobileNumber; // +33 6 21 12 72 84
+echo $faker->serviceNumber // 08 98 04 84 46
+```
+
+
+### `Faker\Provider\he_IL\Payment`
+
+```php
+bankAccountNumber // "IL392237392219429527697"
+```
+
+### `Faker\Provider\hr_HR\Payment`
+
+```php
+bankAccountNumber // "HR3789114847226078672"
+```
+
+### `Faker\Provider\hu_HU\Payment`
+
+```php
+bankAccountNumber; // "HU09904437680048220079300783"
+```
+
+### `Faker\Provider\id_ID\Person`
+
+```php
+nik(); // "8522246001570940"
+```
+
+### `Faker\Provider\it_CH\Person`
+```php
+avs13; // "756.1234.5678.97"
+```
+
+### `Faker\Provider\it_IT\Company`
+
+```php
+vatId(); // "IT98746784967"
+```
+
+### `Faker\Provider\it_IT\Person`
+
+```php
+taxId(); // "DIXDPZ44E08F367A"
+```
+
+### `Faker\Provider\ja_JP\Person`
+
+```php
+kanaName($gender = null|'male'|'female') // "アオタ ミノル"
+
+// Generates a 'kana' first name
+echo $faker->firstKanaName($gender = null|'male'|'female') // "ヒデã‚"
+
+// Generates a 'kana' first name on the male
+echo $faker->firstKanaNameMale // "ヒデã‚"
+
+// Generates a 'kana' first name on the female
+echo $faker->firstKanaNameFemale // "マアヤ"
+
+// Generates a 'kana' last name
+echo $faker->lastKanaName; // "ナカジマ"
+```
+
+### `Faker\Provider\ka_GE\Payment`
+
+```php
+bankAccountNumber; // "GE33ZV9773853617253389"
+```
+
+### `Faker\Provider\kk_KZ\Company`
+
+```php
+businessIdentificationNumber; // "150140000019"
+```
+
+### `Faker\Provider\kk_KZ\Payment`
+
+```php
+bank; // "Қазкоммерцбанк"
+
+// Generates a random bank account number
+echo $faker->bankAccountNumber; // "KZ1076321LO4H6X41I37"
+```
+
+### `Faker\Provider\kk_KZ\Person`
+
+```php
+individualIdentificationNumber; // "780322300455"
+
+// Generates an individual identification number based on his/her birth date
+echo $faker->individualIdentificationNumber(new \DateTime('1999-03-01')); // "990301300455"
+```
+
+### `Faker\Provider\ko_KR\Address`
+
+```php
+metropolitanCity; // "서울특별시"
+
+// Generates a borough
+echo $faker->borough; // "강남구"
+```
+
+### `Faker\Provider\ko_KR\PhoneNumber`
+
+```php
+localAreaPhoneNumber; // "02-1234-4567"
+
+// Generates a cell phone number
+echo $faker->cellPhoneNumber; // "010-9876-5432"
+```
+
+### `Faker\Provider\lt_LT\Payment`
+
+```php
+bankAccountNumber // "LT300848876740317118"
+```
+
+### `Faker\Provider\lv_LV\Person`
+
+```php
+personalIdentityNumber; // "140190-12301"
+```
+
+### `Faker\Provider\ms_MY\Address`
+
+```php
+township; // "Taman Bahagia"
+
+// Generates a random Malaysian town address with matching postcode and state
+echo $faker->townState; // "55100 Bukit Bintang, Kuala Lumpur"
+```
+
+### `Faker\Provider\ms_MY\Miscellaneous`
+
+```php
+jpjNumberPlate; // "WPL 5169"
+```
+
+### `Faker\Provider\ms_MY\Payment`
+
+```php
+bank; // "Maybank"
+
+// Generates a random Malaysian bank account number (10-16 digits)
+echo $faker->bankAccountNumber; // "1234567890123456"
+
+// Generates a random Malaysian insurance company
+echo $faker->insurance; // "AIA Malaysia"
+
+// Generates a random Malaysian bank SWIFT Code
+echo $faker->swiftCode; // "MBBEMYKLXXX"
+```
+
+### `Faker\Provider\ms_MY\Person`
+
+```php
+myKadNumber($gender = null|'male'|'female', $hyphen = null|true|false); // "710703471796"
+```
+
+### `Faker\Provider\ms_MY\PhoneNumber`
+
+```php
+mobileNumber($countryCodePrefix = null|true|false, $formatting = null|true|false); // "+6012-705 3767"
+
+// Generates a random Malaysian landline number
+echo $faker->fixedLineNumber($countryCodePrefix = null|true|false, $formatting = null|true|false); // "03-7112 0455"
+
+// Generates a random Malaysian voip number
+echo $faker->voipNumber($countryCodePrefix = null|true|false, $formatting = null|true|false); // "015-458 7099"
+```
+
+### `Faker\Provider\ne_NP\Address`
+
+```php
+district;
+
+//Generates a Nepali city name
+echo $faker->cityName;
+```
+
+### `Faker\Provider\nl_BE\Payment`
+
+```php
+vat; // "BE 0123456789" - Belgian Value Added Tax number
+echo $faker->vat(false); // "BE0123456789" - unspaced Belgian Value Added Tax number
+```
+
+### `Faker\Provider\nl_BE\Person`
+
+```php
+rrn(); // "83051711784" - Belgian Rijksregisternummer
+echo $faker->rrn('female'); // "50032089858" - Belgian Rijksregisternummer for a female
+```
+
+### `Faker\Provider\nl_NL\Company`
+
+```php
+jobTitle; // "Houtbewerker"
+echo $faker->vat; // "NL123456789B01" - Dutch Value Added Tax number
+echo $faker->btw; // "NL123456789B01" - Dutch Value Added Tax number (alias)
+```
+
+### `Faker\Provider\nl_NL\Person`
+
+```php
+idNumber; // "111222333" - Dutch Personal identification number (BSN)
+```
+
+### `Faker\Provider\nb_NO\MobileNumber`
+
+```php
+mobileNumber; // "+4799988777"
+echo $faker->mobileNumber; // "999 88 777"
+echo $faker->mobileNumber; // "99988777"
+```
+
+### `Faker\Provider\nb_NO\Payment`
+
+```php
+bankAccountNumber; // "NO3246764709816"
+```
+
+### `Faker\Provider\pl_PL\Person`
+
+```php
+pesel; // "40061451555"
+// Generates a random personal identity card number
+echo $faker->personalIdentityNumber; // "AKX383360"
+// Generates a random taxpayer identification number (NIP)
+echo $faker->taxpayerIdentificationNumber; // '8211575109'
+```
+
+### `Faker\Provider\pl_PL\Company`
+
+```php
+regon; // "714676680"
+// Generates a random local REGON number
+echo $faker->regonLocal; // "15346111382836"
+```
+
+### `Faker\Provider\pl_PL\Payment`
+
+```php
+bank; // "Narodowy Bank Polski"
+// Generates a random bank account number
+echo $faker->bankAccountNumber; // "PL14968907563953822118075816"
+```
+
+### `Faker\Provider\pt_PT\Person`
+
+```php
+taxpayerIdentificationNumber; // '165249277'
+```
+
+### `Faker\Provider\pt_BR\Address`
+
+```php
+region; // 'Nordeste'
+
+// Generates a random region abbreviation
+echo $faker->regionAbbr; // 'NE'
+```
+
+### `Faker\Provider\pt_BR\PhoneNumber`
+
+```php
+areaCode; // 21
+echo $faker->cellphone; // 9432-5656
+echo $faker->landline; // 2654-3445
+echo $faker->phone; // random landline, 8-digit or 9-digit cellphone number
+
+// Using the phone functions with a false argument returns unformatted numbers
+echo $faker->cellphone(false); // 74336667
+
+// cellphone() has a special second argument to add the 9th digit. Ignored if generated a Radio number
+echo $faker->cellphone(true, true); // 98983-3945 or 7343-1290
+
+// Using the "Number" suffix adds area code to the phone
+echo $faker->cellphoneNumber; // (11) 98309-2935
+echo $faker->landlineNumber(false); // 3522835934
+echo $faker->phoneNumber; // formatted, random landline or cellphone (obeying the 9th digit rule)
+echo $faker->phoneNumberCleared; // not formatted, random landline or cellphone (obeying the 9th digit rule)
+```
+
+### `Faker\Provider\pt_BR\Person`
+
+```php
+name; // 'Sr. Luis Adriano Sepúlveda Filho'
+
+// Valid document generators have a boolean argument to remove formatting
+echo $faker->cpf; // '145.343.345-76'
+echo $faker->cpf(false); // '45623467866'
+echo $faker->rg; // '84.405.736-3'
+echo $faker->rg(false); // '844057363'
+```
+
+### `Faker\Provider\pt_BR\Company`
+
+```php
+cnpj; // '23.663.478/0001-24'
+echo $faker->cnpj(false); // '23663478000124'
+```
+
+### `Faker\Provider\ro_MD\Payment`
+
+```php
+bankAccountNumber; // "MD83BQW1CKMUW34HBESDP3A8"
+```
+
+### `Faker\Provider\ro_RO\Payment`
+
+```php
+bankAccountNumber; // "RO55WRJE3OE8X3YQI7J26U1E"
+```
+
+### `Faker\Provider\ro_RO\Person`
+
+```php
+prefixMale; // "ing."
+// Generates a random female name prefix/title
+echo $faker->prefixFemale; // "d-na."
+// Generates a random male first name
+echo $faker->firstNameMale; // "Adrian"
+// Generates a random female first name
+echo $faker->firstNameFemale; // "Miruna"
+
+
+// Generates a random Personal Numerical Code (CNP)
+echo $faker->cnp; // "2800523081231"
+// Valid option values:
+// $gender: null (random), male, female
+// $dateOfBirth (1800+): null (random), Y-m-d, Y-m (random day), Y (random month and day)
+// i.e. '1981-06-16', '2015-03', '1900'
+// $county: 2 letter ISO 3166-2:RO county codes and B1, B2, B3, B4, B5, B6 for Bucharest's 6 sectors
+// $isResident true/false flag if the person resides in Romania
+echo $faker->cnp($gender = null, $dateOfBirth = null, $county = null, $isResident = true);
+
+```
+
+### `Faker\Provider\ro_RO\PhoneNumber`
+
+```php
+tollFreePhoneNumber; // "0800123456"
+// Generates a random premium-rate phone number
+echo $faker->premiumRatePhoneNumber; // "0900123456"
+```
+
+### `Faker\Provider\ru_RU\Payment`
+
+```php
+bank; // "ОТП Банк"
+
+//Generate a Russian Tax Payment Number for Company
+echo $faker->inn; // 7813540735
+
+//Generate a Russian Tax Code for Company
+echo $faker->kpp; // 781301001
+```
+
+### `Faker\Provider\sv_SE\Payment`
+
+```php
+bankAccountNumber; // "SE5018548608468284909192"
+```
+
+### `Faker\Provider\sv_SE\Person`
+
+```php
+personalIdentityNumber() // '950910-0799'
+
+//Since the numbers are different for male and female persons, optionally you can specify gender.
+echo $faker->personalIdentityNumber('female') // '950910-0781'
+```
+### `Faker\Provider\tr_TR\Person`
+
+```php
+tcNo // '55300634882'
+
+```
+
+
+### `Faker\Provider\zh_CN\Payment`
+
+```php
+bank; // 'ä¸å›½å»ºè®¾é“¶è¡Œ'
+```
+
+### `Faker\Provider\uk_UA\Payment`
+
+```php
+bank; // "Ощадбанк"
+```
+
+### `Faker\Provider\zh_TW\Person`
+
+```php
+personalIdentityNumber; // A223456789
+```
+
+### `Faker\Provider\zh_TW\Company`
+
+```php
+VAT; //23456789
+```
+
+
+## Third-Party Libraries Extending/Based On Faker
+
+* Symfony bundles:
+ * [`willdurand/faker-bundle`](https://github.com/willdurand/BazingaFakerBundle): Put the awesome Faker library into the Symfony2 DIC and populate your database with fake data.
+ * [`hautelook/alice-bundle`](https://github.com/hautelook/AliceBundle), [`h4cc/alice-fixtures-bundle`](https://github.com/h4cc/AliceFixturesBundle): Bundles for using [`nelmio/alice`](https://packagist.org/packages/nelmio/alice) and Faker with data fixtures. Able to use Doctrine ORM as well as Doctrine MongoDB ODM.
+* [`emanueleminotto/faker-service-provider`](https://github.com/EmanueleMinotto/FakerServiceProvider): Faker Service Provider for Silex
+* [`bit3/faker-cli`](https://github.com/bit3/faker-cli): Command Line Tool for the Faker PHP library
+* [`league/factory-muffin`](https://github.com/thephpleague/factory-muffin): enable the rapid creation of objects (PHP port of factory-girl)
+* [`fzaninotto/company-name-generator`](https://github.com/fzaninotto/CompanyNameGenerator): Generate names for English tech companies with class
+* [`emanueleminotto/faker-placehold-it-provider`](https://github.com/EmanueleMinotto/PlaceholdItProvider): Generate images using placehold.it
+* [`spyrit/datalea`](https://github.com/spyrit/datalea) A highly customizable random test data generator web app
+* [`frequenc1/newage-ipsum`](https://github.com/frequenc1/newage-ipsum): A new aged ipsum provider for the faker library inspired by http://sebpearce.com/bullshit/
+* [`prewk/xml-faker`](https://github.com/prewk/xml-faker): Create fake XML with Faker
+* [`denheck/faker-context`](https://github.com/denheck/faker-context): Behat context using Faker to generate testdata
+* [`swekaj/cron-expression-generator`](https://github.com/swekaj/CronExpressionGenerator): Faker provider for generating random, valid cron expressions.
+* [`pragmafabrik/pomm-faker`](https://github.com/pragmafabrik/Pomm2Faker): Faker client for Pomm database framework (PostgreSQL)
+* [`nelmio/alice`](https://github.com/nelmio/alice): Fixtures/object generator with a yaml DSL that can use Faker as data generator.
+* [`ravage84/cakephp-fake-seeder`](https://github.com/ravage84/cakephp-fake-seeder) A CakePHP 2.x shell to seed your database with fake and/or fixed data.
+* [`bheller/images-generator`](https://github.com/bruceheller/images-generator): An image generator provider using GD for placeholder type pictures
+* [`pattern-lab/plugin-faker`](https://github.com/pattern-lab/plugin-php-faker): Pattern Lab is a Styleguide, Component Library, and Prototyping tool. This creates unique content each time Pattern Lab is generated.
+* [`guidocella/eloquent-populator`](https://github.com/guidocella/eloquent-populator): Adapter for Laravel's Eloquent ORM.
+* [`tamperdata/exiges`](https://github.com/tamperdata/exiges): Faker provider for generating random temperatures
+* [`jzonta/faker-restaurant`](https://github.com/jzonta/FakerRestaurant): Faker for Food and Beverage names generate
+* [`aalaap/faker-youtube`](https://github.com/aalaap/faker-youtube): Faker for YouTube URLs in various formats
+* [`pelmered/fake-car`](https://github.com/pelmered/fake-car): Faker for cars and car data
+* [`bluemmb/faker-picsum-photos-provider`](https://github.com/bluemmb/Faker-PicsumPhotos): Generate images using [picsum.photos](http://picsum.photos/)
+* [`er1z/fakemock`](https://github.com/er1z/fakemock): Generate mocks using class-configuration and detection via Faker's guesser and Symfony asserts
+* [`xvladqt/faker-lorem-flickr`](https://github.com/xvladxtremal/Faker-LoremFlickr): Generate images using [loremflickr.com](http://loremflickr.com/)
+* [`metrakit/faker-eddy-malou`](https://github.com/Metrakit/faker-eddy-malou): Generate French Eddy Malou sentences & paragraphs
+* [`drupol/belgian-national-number-faker`](https://github.com/drupol/belgian-national-number-faker): Generate fake Belgian national numbers
+* [`elgentos/masquerade`](https://github.com/elgentos/masquerade): Configuration-based, platform-agnostic, locale-compatible data faker tool (out-of-the-box support for Magento 2)
+* [`ottaviano/faker-gravatar`](https://github.com/ottaviano/faker-gravatar): Generate avatars using [Gravatar](https://en.gravatar.com/site/implement/images/)
+* [`finwe/phpstan-faker`](https://github.com/finwe/phpstan-faker): PHPStan extension for Faker methods
+
+## License
+
+Faker is released under the MIT License. See the bundled LICENSE file for details.
diff --git a/vendor/fzaninotto/faker/src/Faker/Calculator/Ean.php b/vendor/fzaninotto/faker/src/Faker/Calculator/Ean.php
new file mode 100644
index 000000000..a1e0c076e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Calculator/Ean.php
@@ -0,0 +1,55 @@
+= 0; $i -= 2) {
+ $even += $digits[$i];
+ }
+
+ $odd = 0;
+ for ($i = $length - 2; $i >= 0; $i -= 2) {
+ $odd += $digits[$i];
+ }
+
+ return (10 - ((3 * $even + $odd) % 10)) % 10;
+ }
+
+ /**
+ * Checks whether the provided number is an EAN compliant number and that
+ * the checksum is correct.
+ *
+ * @param string $ean An EAN number
+ * @return boolean
+ */
+ public static function isValid($ean)
+ {
+ if (!preg_match(self::PATTERN, $ean)) {
+ return false;
+ }
+
+ return self::checksum(substr($ean, 0, -1)) === intval(substr($ean, -1));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Calculator/Iban.php b/vendor/fzaninotto/faker/src/Faker/Calculator/Iban.php
new file mode 100644
index 000000000..8a5823120
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Calculator/Iban.php
@@ -0,0 +1,73 @@
+ 2, 2 => 4, 3 => 10, 4 => 3, 5 => 5, 6 => 9, 7 => 4, 8 => 6, 9 => 8);
+ $sum = 0;
+ for ($i = 1; $i <= 9; $i++) {
+ $sum += intval(substr($inn, $i-1, 1)) * $multipliers[$i];
+ }
+ return strval(($sum % 11) % 10);
+ }
+
+ /**
+ * Checks whether an INN has a valid checksum
+ *
+ * @param string $inn
+ * @return boolean
+ */
+ public static function isValid($inn)
+ {
+ return self::checksum(substr($inn, 0, -1)) === substr($inn, -1, 1);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Calculator/Luhn.php b/vendor/fzaninotto/faker/src/Faker/Calculator/Luhn.php
new file mode 100644
index 000000000..1cb71a165
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Calculator/Luhn.php
@@ -0,0 +1,75 @@
+= 0; $i -= 2) {
+ $sum += $number[$i];
+ }
+ for ($i = $length - 2; $i >= 0; $i -= 2) {
+ $sum += array_sum(str_split($number[$i] * 2));
+ }
+
+ return $sum % 10;
+ }
+
+ /**
+ * @param $partialNumber
+ * @return string
+ */
+ public static function computeCheckDigit($partialNumber)
+ {
+ $checkDigit = self::checksum($partialNumber . '0');
+ if ($checkDigit === 0) {
+ return 0;
+ }
+
+ return (string) (10 - $checkDigit);
+ }
+
+ /**
+ * Checks whether a number (partial number + check digit) is Luhn compliant
+ *
+ * @param string $number
+ * @return bool
+ */
+ public static function isValid($number)
+ {
+ return self::checksum($number) === 0;
+ }
+
+ /**
+ * Generate a Luhn compliant number.
+ *
+ * @param string $partialValue
+ *
+ * @return string
+ */
+ public static function generateLuhnNumber($partialValue)
+ {
+ if (!preg_match('/^\d+$/', $partialValue)) {
+ throw new InvalidArgumentException('Argument should be an integer.');
+ }
+ return $partialValue . Luhn::computeCheckDigit($partialValue);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Calculator/TCNo.php b/vendor/fzaninotto/faker/src/Faker/Calculator/TCNo.php
new file mode 100644
index 000000000..392d45524
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Calculator/TCNo.php
@@ -0,0 +1,52 @@
+ $digit) {
+ if ($index % 2 == 0) {
+ $evenSum += $digit;
+ } else {
+ $oddSum += $digit;
+ }
+ }
+
+ $tenthDigit = (7 * $evenSum - $oddSum) % 10;
+ $eleventhDigit = ($evenSum + $oddSum + $tenthDigit) % 10;
+
+ return $tenthDigit . $eleventhDigit;
+ }
+
+ /**
+ * Checks whether an TCNo has a valid checksum
+ *
+ * @param string $tcNo
+ * @return boolean
+ */
+ public static function isValid($tcNo)
+ {
+ return self::checksum(substr($tcNo, 0, -2)) === substr($tcNo, -2, 2);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/DefaultGenerator.php b/vendor/fzaninotto/faker/src/Faker/DefaultGenerator.php
new file mode 100644
index 000000000..eafd2ecaf
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/DefaultGenerator.php
@@ -0,0 +1,38 @@
+optional().
+ */
+class DefaultGenerator
+{
+ protected $default;
+
+ public function __construct($default = null)
+ {
+ $this->default = $default;
+ }
+
+ /**
+ * @param string $attribute
+ *
+ * @return mixed
+ */
+ public function __get($attribute)
+ {
+ return $this->default;
+ }
+
+ /**
+ * @param string $method
+ * @param array $attributes
+ *
+ * @return mixed
+ */
+ public function __call($method, $attributes)
+ {
+ return $this->default;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Documentor.php b/vendor/fzaninotto/faker/src/Faker/Documentor.php
new file mode 100644
index 000000000..e42bdf40d
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Documentor.php
@@ -0,0 +1,66 @@
+generator = $generator;
+ }
+
+ /**
+ * @return array
+ */
+ public function getFormatters()
+ {
+ $formatters = array();
+ $providers = array_reverse($this->generator->getProviders());
+ $providers[]= new Provider\Base($this->generator);
+ foreach ($providers as $provider) {
+ $providerClass = get_class($provider);
+ $formatters[$providerClass] = array();
+ $refl = new \ReflectionObject($provider);
+ foreach ($refl->getMethods(\ReflectionMethod::IS_PUBLIC) as $reflmethod) {
+ if ($reflmethod->getDeclaringClass()->getName() == 'Faker\Provider\Base' && $providerClass != 'Faker\Provider\Base') {
+ continue;
+ }
+ $methodName = $reflmethod->name;
+ if ($reflmethod->isConstructor()) {
+ continue;
+ }
+ $parameters = array();
+ foreach ($reflmethod->getParameters() as $reflparameter) {
+ $parameter = '$'. $reflparameter->getName();
+ if ($reflparameter->isDefaultValueAvailable()) {
+ $parameter .= ' = ' . var_export($reflparameter->getDefaultValue(), true);
+ }
+ $parameters []= $parameter;
+ }
+ $parameters = $parameters ? '('. join(', ', $parameters) . ')' : '';
+ try {
+ $example = $this->generator->format($methodName);
+ } catch (\InvalidArgumentException $e) {
+ $example = '';
+ }
+ if (is_array($example)) {
+ $example = "array('". join("', '", $example) . "')";
+ } elseif ($example instanceof \DateTime) {
+ $example = "DateTime('" . $example->format('Y-m-d H:i:s') . "')";
+ } elseif ($example instanceof Generator || $example instanceof UniqueGenerator) { // modifier
+ $example = '';
+ } else {
+ $example = var_export($example, true);
+ }
+ $formatters[$providerClass][$methodName . $parameters] = $example;
+ }
+ }
+
+ return $formatters;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Factory.php b/vendor/fzaninotto/faker/src/Faker/Factory.php
new file mode 100644
index 000000000..1d687817e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Factory.php
@@ -0,0 +1,61 @@
+addProvider(new $providerClassName($generator));
+ }
+
+ return $generator;
+ }
+
+ /**
+ * @param string $provider
+ * @param string $locale
+ * @return string
+ */
+ protected static function getProviderClassname($provider, $locale = '')
+ {
+ if ($providerClass = self::findProviderClassname($provider, $locale)) {
+ return $providerClass;
+ }
+ // fallback to default locale
+ if ($providerClass = self::findProviderClassname($provider, static::DEFAULT_LOCALE)) {
+ return $providerClass;
+ }
+ // fallback to no locale
+ if ($providerClass = self::findProviderClassname($provider)) {
+ return $providerClass;
+ }
+ throw new \InvalidArgumentException(sprintf('Unable to find provider "%s" with locale "%s"', $provider, $locale));
+ }
+
+ /**
+ * @param string $provider
+ * @param string $locale
+ * @return string
+ */
+ protected static function findProviderClassname($provider, $locale = '')
+ {
+ $providerClass = 'Faker\\' . ($locale ? sprintf('Provider\%s\%s', $locale, $provider) : sprintf('Provider\%s', $provider));
+ if (class_exists($providerClass, true)) {
+ return $providerClass;
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Generator.php b/vendor/fzaninotto/faker/src/Faker/Generator.php
new file mode 100644
index 000000000..1db2608ec
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Generator.php
@@ -0,0 +1,297 @@
+providers, $provider);
+ }
+
+ public function getProviders()
+ {
+ return $this->providers;
+ }
+
+ public function seed($seed = null)
+ {
+ if ($seed === null) {
+ mt_srand();
+ } else {
+ if (PHP_VERSION_ID < 70100) {
+ mt_srand((int) $seed);
+ } else {
+ mt_srand((int) $seed, MT_RAND_PHP);
+ }
+ }
+ }
+
+ public function format($formatter, $arguments = array())
+ {
+ return call_user_func_array($this->getFormatter($formatter), $arguments);
+ }
+
+ /**
+ * @param string $formatter
+ *
+ * @return Callable
+ */
+ public function getFormatter($formatter)
+ {
+ if (isset($this->formatters[$formatter])) {
+ return $this->formatters[$formatter];
+ }
+ foreach ($this->providers as $provider) {
+ if (method_exists($provider, $formatter)) {
+ $this->formatters[$formatter] = array($provider, $formatter);
+
+ return $this->formatters[$formatter];
+ }
+ }
+ throw new \InvalidArgumentException(sprintf('Unknown formatter "%s"', $formatter));
+ }
+
+ /**
+ * Replaces tokens ('{{ tokenName }}') with the result from the token method call
+ *
+ * @param string $string String that needs to bet parsed
+ * @return string
+ */
+ public function parse($string)
+ {
+ return preg_replace_callback('/\{\{\s?(\w+)\s?\}\}/u', array($this, 'callFormatWithMatches'), $string);
+ }
+
+ protected function callFormatWithMatches($matches)
+ {
+ return $this->format($matches[1]);
+ }
+
+ /**
+ * @param string $attribute
+ *
+ * @return mixed
+ */
+ public function __get($attribute)
+ {
+ return $this->format($attribute);
+ }
+
+ /**
+ * @param string $method
+ * @param array $attributes
+ *
+ * @return mixed
+ */
+ public function __call($method, $attributes)
+ {
+ return $this->format($method, $attributes);
+ }
+
+ public function __destruct()
+ {
+ $this->seed();
+ }
+
+ public function __wakeup()
+ {
+ $this->formatters = [];
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Guesser/Name.php b/vendor/fzaninotto/faker/src/Faker/Guesser/Name.php
new file mode 100644
index 000000000..0b303db16
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Guesser/Name.php
@@ -0,0 +1,156 @@
+generator = $generator;
+ }
+
+ /**
+ * @param string $name
+ * @param int|null $size Length of field, if known
+ * @return callable
+ */
+ public function guessFormat($name, $size = null)
+ {
+ $name = Base::toLower($name);
+ $generator = $this->generator;
+ if (preg_match('/^is[_A-Z]/', $name)) {
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ }
+ if (preg_match('/(_a|A)t$/', $name)) {
+ return function () use ($generator) {
+ return $generator->dateTime;
+ };
+ }
+ switch (str_replace('_', '', $name)) {
+ case 'firstname':
+ return function () use ($generator) {
+ return $generator->firstName;
+ };
+ case 'lastname':
+ return function () use ($generator) {
+ return $generator->lastName;
+ };
+ case 'username':
+ case 'login':
+ return function () use ($generator) {
+ return $generator->userName;
+ };
+ case 'email':
+ case 'emailaddress':
+ return function () use ($generator) {
+ return $generator->email;
+ };
+ case 'phonenumber':
+ case 'phone':
+ case 'telephone':
+ case 'telnumber':
+ return function () use ($generator) {
+ return $generator->phoneNumber;
+ };
+ case 'address':
+ return function () use ($generator) {
+ return $generator->address;
+ };
+ case 'city':
+ case 'town':
+ return function () use ($generator) {
+ return $generator->city;
+ };
+ case 'streetaddress':
+ return function () use ($generator) {
+ return $generator->streetAddress;
+ };
+ case 'postcode':
+ case 'zipcode':
+ return function () use ($generator) {
+ return $generator->postcode;
+ };
+ case 'state':
+ return function () use ($generator) {
+ return $generator->state;
+ };
+ case 'county':
+ if ($this->generator->locale == 'en_US') {
+ return function () use ($generator) {
+ return sprintf('%s County', $generator->city);
+ };
+ }
+
+ return function () use ($generator) {
+ return $generator->state;
+ };
+ case 'country':
+ switch ($size) {
+ case 2:
+ return function () use ($generator) {
+ return $generator->countryCode;
+ };
+ case 3:
+ return function () use ($generator) {
+ return $generator->countryISOAlpha3;
+ };
+ case 5:
+ case 6:
+ return function () use ($generator) {
+ return $generator->locale;
+ };
+ default:
+ return function () use ($generator) {
+ return $generator->country;
+ };
+ }
+ break;
+ case 'locale':
+ return function () use ($generator) {
+ return $generator->locale;
+ };
+ case 'currency':
+ case 'currencycode':
+ return function () use ($generator) {
+ return $generator->currencyCode;
+ };
+ case 'url':
+ case 'website':
+ return function () use ($generator) {
+ return $generator->url;
+ };
+ case 'company':
+ case 'companyname':
+ case 'employer':
+ return function () use ($generator) {
+ return $generator->company;
+ };
+ case 'title':
+ if ($size !== null && $size <= 10) {
+ return function () use ($generator) {
+ return $generator->title;
+ };
+ }
+
+ return function () use ($generator) {
+ return $generator->sentence;
+ };
+ case 'body':
+ case 'summary':
+ case 'article':
+ case 'description':
+ return function () use ($generator) {
+ return $generator->text;
+ };
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/ColumnTypeGuesser.php b/vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/ColumnTypeGuesser.php
new file mode 100644
index 000000000..0aa341300
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/ColumnTypeGuesser.php
@@ -0,0 +1,71 @@
+generator = $generator;
+ }
+
+ /**
+ * @return \Closure|null
+ */
+ public function guessFormat($column, $table)
+ {
+ $generator = $this->generator;
+ $schema = $table->schema();
+
+ switch ($schema->columnType($column)) {
+ case 'boolean':
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case 'integer':
+ return function () {
+ return mt_rand(0, intval('2147483647'));
+ };
+ case 'biginteger':
+ return function () {
+ return mt_rand(0, intval('9223372036854775807'));
+ };
+ case 'decimal':
+ case 'float':
+ return function () use ($generator) {
+ return $generator->randomFloat();
+ };
+ case 'uuid':
+ return function () use ($generator) {
+ return $generator->uuid();
+ };
+ case 'string':
+ if (method_exists($schema, 'getColumn')) {
+ $columnData = $schema->getColumn($column);
+ } else {
+ $columnData = $schema->column($column);
+ }
+ $length = $columnData['length'];
+ return function () use ($generator, $length) {
+ return $generator->text($length);
+ };
+ case 'text':
+ return function () use ($generator) {
+ return $generator->text();
+ };
+ case 'date':
+ case 'datetime':
+ case 'timestamp':
+ case 'time':
+ return function () use ($generator) {
+ return $generator->datetime();
+ };
+
+ case 'binary':
+ default:
+ return null;
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/EntityPopulator.php b/vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/EntityPopulator.php
new file mode 100644
index 000000000..2ec312aa3
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/EntityPopulator.php
@@ -0,0 +1,166 @@
+class = $class;
+ }
+
+ /**
+ * @param string $name
+ */
+ public function __get($name)
+ {
+ return $this->{$name};
+ }
+
+ /**
+ * @param string $name
+ */
+ public function __set($name, $value)
+ {
+ $this->{$name} = $value;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ public function mergeModifiersWith($modifiers)
+ {
+ $this->modifiers = array_merge($this->modifiers, $modifiers);
+ }
+
+ /**
+ * @return array
+ */
+ public function guessColumnFormatters($populator)
+ {
+ $formatters = [];
+ $class = $this->class;
+ $table = $this->getTable($class);
+ $schema = $table->schema();
+ $pk = $schema->primaryKey();
+ $guessers = $populator->getGuessers() + ['ColumnTypeGuesser' => new ColumnTypeGuesser($populator->getGenerator())];
+ $isForeignKey = function ($column) use ($table) {
+ foreach ($table->associations()->type('BelongsTo') as $assoc) {
+ if ($column == $assoc->foreignKey()) {
+ return true;
+ }
+ }
+ return false;
+ };
+
+
+ foreach ($schema->columns() as $column) {
+ if ($column == $pk[0] || $isForeignKey($column)) {
+ continue;
+ }
+
+ foreach ($guessers as $guesser) {
+ if ($formatter = $guesser->guessFormat($column, $table)) {
+ $formatters[$column] = $formatter;
+ break;
+ }
+ }
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function guessModifiers()
+ {
+ $modifiers = [];
+ $table = $this->getTable($this->class);
+
+ $belongsTo = $table->associations()->type('BelongsTo');
+ foreach ($belongsTo as $assoc) {
+ $modifiers['belongsTo' . $assoc->name()] = function ($data, $insertedEntities) use ($assoc) {
+ $table = $assoc->target();
+ $foreignModel = $table->alias();
+
+ $foreignKeys = [];
+ if (!empty($insertedEntities[$foreignModel])) {
+ $foreignKeys = $insertedEntities[$foreignModel];
+ } else {
+ $foreignKeys = $table->find('all')
+ ->select(['id'])
+ ->map(function ($row) {
+ return $row->id;
+ })
+ ->toArray();
+ }
+
+ if (empty($foreignKeys)) {
+ throw new \Exception(sprintf('%s belongsTo %s, which seems empty at this point.', $this->getTable($this->class)->table(), $assoc->table()));
+ }
+
+ $foreignKey = $foreignKeys[array_rand($foreignKeys)];
+ $data[$assoc->foreignKey()] = $foreignKey;
+ return $data;
+ };
+ }
+
+ // TODO check if TreeBehavior attached to modify lft/rgt cols
+
+ return $modifiers;
+ }
+
+ /**
+ * @param array $options
+ */
+ public function execute($class, $insertedEntities, $options = [])
+ {
+ $table = $this->getTable($class);
+ $entity = $table->newEntity();
+
+ foreach ($this->columnFormatters as $column => $format) {
+ if (!is_null($format)) {
+ $entity->{$column} = is_callable($format) ? $format($insertedEntities, $table) : $format;
+ }
+ }
+
+ foreach ($this->modifiers as $modifier) {
+ $entity = $modifier($entity, $insertedEntities);
+ }
+
+ if (!$entity = $table->save($entity, $options)) {
+ throw new \RuntimeException("Failed saving $class record");
+ }
+
+ $pk = $table->primaryKey();
+ if (is_string($pk)) {
+ return $entity->{$pk};
+ }
+
+ return $entity->{$pk[0]};
+ }
+
+ public function setConnection($name)
+ {
+ $this->connectionName = $name;
+ }
+
+ protected function getTable($class)
+ {
+ $options = [];
+ if (!empty($this->connectionName)) {
+ $options['connection'] = $this->connectionName;
+ }
+ return TableRegistry::get($class, $options);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/Populator.php b/vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/Populator.php
new file mode 100644
index 000000000..eda30a8ef
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/CakePHP/Populator.php
@@ -0,0 +1,109 @@
+generator = $generator;
+ }
+
+ /**
+ * @return \Faker\Generator
+ */
+ public function getGenerator()
+ {
+ return $this->generator;
+ }
+
+ /**
+ * @return array
+ */
+ public function getGuessers()
+ {
+ return $this->guessers;
+ }
+
+ /**
+ * @return $this
+ */
+ public function removeGuesser($name)
+ {
+ if ($this->guessers[$name]) {
+ unset($this->guessers[$name]);
+ }
+ return $this;
+ }
+
+ /**
+ * @return $this
+ * @throws \Exception
+ */
+ public function addGuesser($class)
+ {
+ if (!is_object($class)) {
+ $class = new $class($this->generator);
+ }
+
+ if (!method_exists($class, 'guessFormat')) {
+ throw new \Exception('Missing required custom guesser method: ' . get_class($class) . '::guessFormat()');
+ }
+
+ $this->guessers[get_class($class)] = $class;
+ return $this;
+ }
+
+ /**
+ * @param array $customColumnFormatters
+ * @param array $customModifiers
+ * @return $this
+ */
+ public function addEntity($entity, $number, $customColumnFormatters = [], $customModifiers = [])
+ {
+ if (!$entity instanceof EntityPopulator) {
+ $entity = new EntityPopulator($entity);
+ }
+
+ $entity->columnFormatters = $entity->guessColumnFormatters($this);
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+
+ $entity->modifiers = $entity->guessModifiers($this);
+ if ($customModifiers) {
+ $entity->mergeModifiersWith($customModifiers);
+ }
+
+ $class = $entity->class;
+ $this->entities[$class] = $entity;
+ $this->quantities[$class] = $number;
+ return $this;
+ }
+
+ /**
+ * @param array $options
+ * @return array
+ */
+ public function execute($options = [])
+ {
+ $insertedEntities = [];
+
+ foreach ($this->quantities as $class => $number) {
+ for ($i = 0; $i < $number; $i++) {
+ $insertedEntities[$class][] = $this->entities[$class]->execute($class, $insertedEntities, $options);
+ }
+ }
+
+ return $insertedEntities;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/ColumnTypeGuesser.php b/vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/ColumnTypeGuesser.php
new file mode 100644
index 000000000..bd608f961
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/ColumnTypeGuesser.php
@@ -0,0 +1,81 @@
+generator = $generator;
+ }
+
+ /**
+ * @param ClassMetadata $class
+ * @return \Closure|null
+ */
+ public function guessFormat($fieldName, ClassMetadata $class)
+ {
+ $generator = $this->generator;
+ $type = $class->getTypeOfField($fieldName);
+ switch ($type) {
+ case 'boolean':
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case 'decimal':
+ $size = isset($class->fieldMappings[$fieldName]['precision']) ? $class->fieldMappings[$fieldName]['precision'] : 2;
+
+ return function () use ($generator, $size) {
+ return $generator->randomNumber($size + 2) / 100;
+ };
+ case 'smallint':
+ return function () {
+ return mt_rand(0, 65535);
+ };
+ case 'integer':
+ return function () {
+ return mt_rand(0, intval('2147483647'));
+ };
+ case 'bigint':
+ return function () {
+ return mt_rand(0, intval('18446744073709551615'));
+ };
+ case 'float':
+ return function () {
+ return mt_rand(0, intval('4294967295'))/mt_rand(1, intval('4294967295'));
+ };
+ case 'string':
+ $size = isset($class->fieldMappings[$fieldName]['length']) ? $class->fieldMappings[$fieldName]['length'] : 255;
+
+ return function () use ($generator, $size) {
+ return $generator->text($size);
+ };
+ case 'text':
+ return function () use ($generator) {
+ return $generator->text;
+ };
+ case 'datetime':
+ case 'date':
+ case 'time':
+ return function () use ($generator) {
+ return $generator->datetime;
+ };
+ case 'datetime_immutable':
+ case 'date_immutable':
+ case 'time_immutable':
+ return function () use ($generator) {
+ return \DateTimeImmutable::createFromMutable($generator->datetime);
+ };
+ default:
+ // no smart way to guess what the user expects here
+ return null;
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/EntityPopulator.php b/vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/EntityPopulator.php
new file mode 100644
index 000000000..bc703e549
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/EntityPopulator.php
@@ -0,0 +1,251 @@
+class = $class;
+ }
+
+ /**
+ * @return string
+ */
+ public function getClass()
+ {
+ return $this->class->getName();
+ }
+
+ /**
+ * @param $columnFormatters
+ */
+ public function setColumnFormatters($columnFormatters)
+ {
+ $this->columnFormatters = $columnFormatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function getColumnFormatters()
+ {
+ return $this->columnFormatters;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ /**
+ * @param array $modifiers
+ */
+ public function setModifiers(array $modifiers)
+ {
+ $this->modifiers = $modifiers;
+ }
+
+ /**
+ * @return array
+ */
+ public function getModifiers()
+ {
+ return $this->modifiers;
+ }
+
+ /**
+ * @param array $modifiers
+ */
+ public function mergeModifiersWith(array $modifiers)
+ {
+ $this->modifiers = array_merge($this->modifiers, $modifiers);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @return array
+ */
+ public function guessColumnFormatters(\Faker\Generator $generator)
+ {
+ $formatters = array();
+ $nameGuesser = new \Faker\Guesser\Name($generator);
+ $columnTypeGuesser = new ColumnTypeGuesser($generator);
+ foreach ($this->class->getFieldNames() as $fieldName) {
+ if ($this->class->isIdentifier($fieldName) || !$this->class->hasField($fieldName)) {
+ continue;
+ }
+
+ $size = isset($this->class->fieldMappings[$fieldName]['length']) ? $this->class->fieldMappings[$fieldName]['length'] : null;
+ if ($formatter = $nameGuesser->guessFormat($fieldName, $size)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ if ($formatter = $columnTypeGuesser->guessFormat($fieldName, $this->class)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ }
+
+ foreach ($this->class->getAssociationNames() as $assocName) {
+ if ($this->class->isCollectionValuedAssociation($assocName)) {
+ continue;
+ }
+
+ $relatedClass = $this->class->getAssociationTargetClass($assocName);
+
+ $unique = $optional = false;
+ if ($this->class instanceof \Doctrine\ORM\Mapping\ClassMetadata) {
+ $mappings = $this->class->getAssociationMappings();
+ foreach ($mappings as $mapping) {
+ if ($mapping['targetEntity'] == $relatedClass) {
+ if ($mapping['type'] == \Doctrine\ORM\Mapping\ClassMetadata::ONE_TO_ONE) {
+ $unique = true;
+ $optional = isset($mapping['joinColumns'][0]['nullable']) ? $mapping['joinColumns'][0]['nullable'] : false;
+ break;
+ }
+ }
+ }
+ } elseif ($this->class instanceof \Doctrine\ODM\MongoDB\Mapping\ClassMetadata) {
+ $mappings = $this->class->associationMappings;
+ foreach ($mappings as $mapping) {
+ if ($mapping['targetDocument'] == $relatedClass) {
+ if ($mapping['type'] == \Doctrine\ODM\MongoDB\Mapping\ClassMetadata::ONE && $mapping['association'] == \Doctrine\ODM\MongoDB\Mapping\ClassMetadata::REFERENCE_ONE) {
+ $unique = true;
+ $optional = isset($mapping['nullable']) ? $mapping['nullable'] : false;
+ break;
+ }
+ }
+ }
+ }
+
+ $index = 0;
+ $formatters[$assocName] = function ($inserted) use ($relatedClass, &$index, $unique, $optional) {
+
+ if (isset($inserted[$relatedClass])) {
+ if ($unique) {
+ $related = null;
+ if (isset($inserted[$relatedClass][$index]) || !$optional) {
+ $related = $inserted[$relatedClass][$index];
+ }
+
+ $index++;
+
+ return $related;
+ }
+
+ return $inserted[$relatedClass][mt_rand(0, count($inserted[$relatedClass]) - 1)];
+ }
+
+ return null;
+ };
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * Insert one new record using the Entity class.
+ * @param ObjectManager $manager
+ * @param bool $generateId
+ * @return EntityPopulator
+ */
+ public function execute(ObjectManager $manager, $insertedEntities, $generateId = false)
+ {
+ $obj = $this->class->newInstance();
+
+ $this->fillColumns($obj, $insertedEntities);
+ $this->callMethods($obj, $insertedEntities);
+
+ if ($generateId) {
+ $idsName = $this->class->getIdentifier();
+ foreach ($idsName as $idName) {
+ $id = $this->generateId($obj, $idName, $manager);
+ $this->class->reflFields[$idName]->setValue($obj, $id);
+ }
+ }
+
+ $manager->persist($obj);
+
+ return $obj;
+ }
+
+ private function fillColumns($obj, $insertedEntities)
+ {
+ foreach ($this->columnFormatters as $field => $format) {
+ if (null !== $format) {
+ // Add some extended debugging information to any errors thrown by the formatter
+ try {
+ $value = is_callable($format) ? $format($insertedEntities, $obj) : $format;
+ } catch (\InvalidArgumentException $ex) {
+ throw new \InvalidArgumentException(sprintf(
+ "Failed to generate a value for %s::%s: %s",
+ get_class($obj),
+ $field,
+ $ex->getMessage()
+ ));
+ }
+ // Try a standard setter if it's available, otherwise fall back on reflection
+ $setter = sprintf("set%s", ucfirst($field));
+ if (is_callable(array($obj, $setter))) {
+ $obj->$setter($value);
+ } else {
+ $this->class->reflFields[$field]->setValue($obj, $value);
+ }
+ }
+ }
+ }
+
+ private function callMethods($obj, $insertedEntities)
+ {
+ foreach ($this->getModifiers() as $modifier) {
+ $modifier($obj, $insertedEntities);
+ }
+ }
+
+ /**
+ * @param ObjectManager $manager
+ * @return int|null
+ */
+ private function generateId($obj, $column, ObjectManager $manager)
+ {
+ /* @var $repository \Doctrine\Common\Persistence\ObjectRepository */
+ $repository = $manager->getRepository(get_class($obj));
+ $result = $repository->createQueryBuilder('e')
+ ->select(sprintf('e.%s', $column))
+ ->getQuery()
+ ->execute();
+ $ids = array_map('current', $result->toArray());
+
+ $id = null;
+ do {
+ $id = mt_rand();
+ } while (in_array($id, $ids));
+
+ return $id;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/Populator.php b/vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/Populator.php
new file mode 100644
index 000000000..d4c5dfb87
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Doctrine/Populator.php
@@ -0,0 +1,110 @@
+generator = $generator;
+ $this->manager = $manager;
+ $this->batchSize = $batchSize;
+ }
+
+ /**
+ * Add an order for the generation of $number records for $entity.
+ *
+ * @param mixed $entity A Doctrine classname, or a \Faker\ORM\Doctrine\EntityPopulator instance
+ * @param int $number The number of entities to populate
+ */
+ public function addEntity($entity, $number, $customColumnFormatters = array(), $customModifiers = array(), $generateId = false)
+ {
+ if (!$entity instanceof \Faker\ORM\Doctrine\EntityPopulator) {
+ if (null === $this->manager) {
+ throw new \InvalidArgumentException("No entity manager passed to Doctrine Populator.");
+ }
+ $entity = new \Faker\ORM\Doctrine\EntityPopulator($this->manager->getClassMetadata($entity));
+ }
+ $entity->setColumnFormatters($entity->guessColumnFormatters($this->generator));
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+ $entity->mergeModifiersWith($customModifiers);
+ $this->generateId[$entity->getClass()] = $generateId;
+
+ $class = $entity->getClass();
+ $this->entities[$class] = $entity;
+ $this->quantities[$class] = $number;
+ }
+
+ /**
+ * Populate the database using all the Entity classes previously added.
+ *
+ * Please note that large amounts of data will result in more memory usage since the the Populator will return
+ * all newly created primary keys after executing.
+ *
+ * @param null|EntityManager $entityManager A Doctrine connection object
+ *
+ * @return array A list of the inserted PKs
+ */
+ public function execute($entityManager = null)
+ {
+ if (null === $entityManager) {
+ $entityManager = $this->manager;
+ }
+ if (null === $entityManager) {
+ throw new \InvalidArgumentException("No entity manager passed to Doctrine Populator.");
+ }
+
+ $insertedEntities = array();
+ foreach ($this->quantities as $class => $number) {
+ $generateId = $this->generateId[$class];
+ for ($i=0; $i < $number; $i++) {
+ $insertedEntities[$class][]= $this->entities[$class]->execute(
+ $entityManager,
+ $insertedEntities,
+ $generateId
+ );
+ if (count($insertedEntities) % $this->batchSize === 0) {
+ $entityManager->flush();
+ $entityManager->clear($class);
+ }
+ }
+ $entityManager->flush();
+ $entityManager->clear($class);
+ }
+
+ return $insertedEntities;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Mandango/ColumnTypeGuesser.php b/vendor/fzaninotto/faker/src/Faker/ORM/Mandango/ColumnTypeGuesser.php
new file mode 100644
index 000000000..d318b0aa0
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Mandango/ColumnTypeGuesser.php
@@ -0,0 +1,49 @@
+generator = $generator;
+ }
+
+ /**
+ * @return \Closure|null
+ */
+ public function guessFormat($field)
+ {
+ $generator = $this->generator;
+ switch ($field['type']) {
+ case 'boolean':
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case 'integer':
+ return function () {
+ return mt_rand(0, intval('4294967295'));
+ };
+ case 'float':
+ return function () {
+ return mt_rand(0, intval('4294967295'))/mt_rand(1, intval('4294967295'));
+ };
+ case 'string':
+ return function () use ($generator) {
+ return $generator->text(255);
+ };
+ case 'date':
+ return function () use ($generator) {
+ return $generator->datetime;
+ };
+ default:
+ // no smart way to guess what the user expects here
+ return null;
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Mandango/EntityPopulator.php b/vendor/fzaninotto/faker/src/Faker/ORM/Mandango/EntityPopulator.php
new file mode 100644
index 000000000..667f5bec3
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Mandango/EntityPopulator.php
@@ -0,0 +1,122 @@
+class = $class;
+ }
+
+ /**
+ * @return string
+ */
+ public function getClass()
+ {
+ return $this->class;
+ }
+
+ public function setColumnFormatters($columnFormatters)
+ {
+ $this->columnFormatters = $columnFormatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function getColumnFormatters()
+ {
+ return $this->columnFormatters;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @param Mandango $mandango
+ * @return array
+ */
+ public function guessColumnFormatters(\Faker\Generator $generator, Mandango $mandango)
+ {
+ $formatters = array();
+ $nameGuesser = new \Faker\Guesser\Name($generator);
+ $columnTypeGuesser = new \Faker\ORM\Mandango\ColumnTypeGuesser($generator);
+
+ $metadata = $mandango->getMetadata($this->class);
+
+ // fields
+ foreach ($metadata['fields'] as $fieldName => $field) {
+ if ($formatter = $nameGuesser->guessFormat($fieldName)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ if ($formatter = $columnTypeGuesser->guessFormat($field)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ }
+
+ // references
+ foreach (array_merge($metadata['referencesOne'], $metadata['referencesMany']) as $referenceName => $reference) {
+ if (!isset($reference['class'])) {
+ continue;
+ }
+ $referenceClass = $reference['class'];
+
+ $formatters[$referenceName] = function ($insertedEntities) use ($referenceClass) {
+ if (isset($insertedEntities[$referenceClass])) {
+ return Base::randomElement($insertedEntities[$referenceClass]);
+ }
+ };
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * Insert one new record using the Entity class.
+ * @param Mandango $mandango
+ */
+ public function execute(Mandango $mandango, $insertedEntities)
+ {
+ $metadata = $mandango->getMetadata($this->class);
+
+ $obj = $mandango->create($this->class);
+ foreach ($this->columnFormatters as $column => $format) {
+ if (null !== $format) {
+ $value = is_callable($format) ? $format($insertedEntities, $obj) : $format;
+
+ if (isset($metadata['fields'][$column]) ||
+ isset($metadata['referencesOne'][$column])) {
+ $obj->set($column, $value);
+ }
+
+ if (isset($metadata['referencesMany'][$column])) {
+ $adder = 'add'.ucfirst($column);
+ $obj->$adder($value);
+ }
+ }
+ }
+ $mandango->persist($obj);
+
+ return $obj;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Mandango/Populator.php b/vendor/fzaninotto/faker/src/Faker/ORM/Mandango/Populator.php
new file mode 100644
index 000000000..26736dc4d
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Mandango/Populator.php
@@ -0,0 +1,65 @@
+generator = $generator;
+ $this->mandango = $mandango;
+ }
+
+ /**
+ * Add an order for the generation of $number records for $entity.
+ *
+ * @param mixed $entity A Propel ActiveRecord classname, or a \Faker\ORM\Propel\EntityPopulator instance
+ * @param int $number The number of entities to populate
+ */
+ public function addEntity($entity, $number, $customColumnFormatters = array())
+ {
+ if (!$entity instanceof \Faker\ORM\Mandango\EntityPopulator) {
+ $entity = new \Faker\ORM\Mandango\EntityPopulator($entity);
+ }
+ $entity->setColumnFormatters($entity->guessColumnFormatters($this->generator, $this->mandango));
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+ $class = $entity->getClass();
+ $this->entities[$class] = $entity;
+ $this->quantities[$class] = $number;
+ }
+
+ /**
+ * Populate the database using all the Entity classes previously added.
+ *
+ * @return array A list of the inserted entities.
+ */
+ public function execute()
+ {
+ $insertedEntities = array();
+ foreach ($this->quantities as $class => $number) {
+ for ($i=0; $i < $number; $i++) {
+ $insertedEntities[$class][]= $this->entities[$class]->execute($this->mandango, $insertedEntities);
+ }
+ }
+ $this->mandango->flush();
+
+ return $insertedEntities;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Propel/ColumnTypeGuesser.php b/vendor/fzaninotto/faker/src/Faker/ORM/Propel/ColumnTypeGuesser.php
new file mode 100644
index 000000000..1df704946
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Propel/ColumnTypeGuesser.php
@@ -0,0 +1,107 @@
+generator = $generator;
+ }
+
+ /**
+ * @param ColumnMap $column
+ * @return \Closure|null
+ */
+ public function guessFormat(ColumnMap $column)
+ {
+ $generator = $this->generator;
+ if ($column->isTemporal()) {
+ if ($column->isEpochTemporal()) {
+ return function () use ($generator) {
+ return $generator->dateTime;
+ };
+ }
+
+ return function () use ($generator) {
+ return $generator->dateTimeAD;
+ };
+ }
+ $type = $column->getType();
+ switch ($type) {
+ case PropelColumnTypes::BOOLEAN:
+ case PropelColumnTypes::BOOLEAN_EMU:
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case PropelColumnTypes::NUMERIC:
+ case PropelColumnTypes::DECIMAL:
+ $size = $column->getSize();
+
+ return function () use ($generator, $size) {
+ return $generator->randomNumber($size + 2) / 100;
+ };
+ case PropelColumnTypes::TINYINT:
+ return function () {
+ return mt_rand(0, 127);
+ };
+ case PropelColumnTypes::SMALLINT:
+ return function () {
+ return mt_rand(0, 32767);
+ };
+ case PropelColumnTypes::INTEGER:
+ return function () {
+ return mt_rand(0, intval('2147483647'));
+ };
+ case PropelColumnTypes::BIGINT:
+ return function () {
+ return mt_rand(0, intval('9223372036854775807'));
+ };
+ case PropelColumnTypes::FLOAT:
+ return function () {
+ return mt_rand(0, intval('2147483647'))/mt_rand(1, intval('2147483647'));
+ };
+ case PropelColumnTypes::DOUBLE:
+ case PropelColumnTypes::REAL:
+ return function () {
+ return mt_rand(0, intval('9223372036854775807'))/mt_rand(1, intval('9223372036854775807'));
+ };
+ case PropelColumnTypes::CHAR:
+ case PropelColumnTypes::VARCHAR:
+ case PropelColumnTypes::BINARY:
+ case PropelColumnTypes::VARBINARY:
+ $size = $column->getSize();
+
+ return function () use ($generator, $size) {
+ return $generator->text($size);
+ };
+ case PropelColumnTypes::LONGVARCHAR:
+ case PropelColumnTypes::LONGVARBINARY:
+ case PropelColumnTypes::CLOB:
+ case PropelColumnTypes::CLOB_EMU:
+ case PropelColumnTypes::BLOB:
+ return function () use ($generator) {
+ return $generator->text;
+ };
+ case PropelColumnTypes::ENUM:
+ $valueSet = $column->getValueSet();
+
+ return function () use ($generator, $valueSet) {
+ return $generator->randomElement($valueSet);
+ };
+ case PropelColumnTypes::OBJECT:
+ case PropelColumnTypes::PHP_ARRAY:
+ default:
+ // no smart way to guess what the user expects here
+ return null;
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Propel/EntityPopulator.php b/vendor/fzaninotto/faker/src/Faker/ORM/Propel/EntityPopulator.php
new file mode 100644
index 000000000..1976a403e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Propel/EntityPopulator.php
@@ -0,0 +1,191 @@
+class = $class;
+ }
+
+ /**
+ * @return string
+ */
+ public function getClass()
+ {
+ return $this->class;
+ }
+
+ public function setColumnFormatters($columnFormatters)
+ {
+ $this->columnFormatters = $columnFormatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function getColumnFormatters()
+ {
+ return $this->columnFormatters;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @return array
+ */
+ public function guessColumnFormatters(\Faker\Generator $generator)
+ {
+ $formatters = array();
+ $class = $this->class;
+ $peerClass = $class::PEER;
+ $tableMap = $peerClass::getTableMap();
+ $nameGuesser = new \Faker\Guesser\Name($generator);
+ $columnTypeGuesser = new \Faker\ORM\Propel\ColumnTypeGuesser($generator);
+ foreach ($tableMap->getColumns() as $columnMap) {
+ // skip behavior columns, handled by modifiers
+ if ($this->isColumnBehavior($columnMap)) {
+ continue;
+ }
+ if ($columnMap->isForeignKey()) {
+ $relatedClass = $columnMap->getRelation()->getForeignTable()->getClassname();
+ $formatters[$columnMap->getPhpName()] = function ($inserted) use ($relatedClass) {
+ return isset($inserted[$relatedClass]) ? $inserted[$relatedClass][mt_rand(0, count($inserted[$relatedClass]) - 1)] : null;
+ };
+ continue;
+ }
+ if ($columnMap->isPrimaryKey()) {
+ continue;
+ }
+ if ($formatter = $nameGuesser->guessFormat($columnMap->getPhpName(), $columnMap->getSize())) {
+ $formatters[$columnMap->getPhpName()] = $formatter;
+ continue;
+ }
+ if ($formatter = $columnTypeGuesser->guessFormat($columnMap)) {
+ $formatters[$columnMap->getPhpName()] = $formatter;
+ continue;
+ }
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * @param ColumnMap $columnMap
+ * @return bool
+ */
+ protected function isColumnBehavior(ColumnMap $columnMap)
+ {
+ foreach ($columnMap->getTable()->getBehaviors() as $name => $params) {
+ $columnName = Base::toLower($columnMap->getName());
+ switch ($name) {
+ case 'nested_set':
+ $columnNames = array($params['left_column'], $params['right_column'], $params['level_column']);
+ if (in_array($columnName, $columnNames)) {
+ return true;
+ }
+ break;
+ case 'timestampable':
+ $columnNames = array($params['create_column'], $params['update_column']);
+ if (in_array($columnName, $columnNames)) {
+ return true;
+ }
+ break;
+ }
+ }
+
+ return false;
+ }
+
+ public function setModifiers($modifiers)
+ {
+ $this->modifiers = $modifiers;
+ }
+
+ /**
+ * @return array
+ */
+ public function getModifiers()
+ {
+ return $this->modifiers;
+ }
+
+ public function mergeModifiersWith($modifiers)
+ {
+ $this->modifiers = array_merge($this->modifiers, $modifiers);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @return array
+ */
+ public function guessModifiers(\Faker\Generator $generator)
+ {
+ $modifiers = array();
+ $class = $this->class;
+ $peerClass = $class::PEER;
+ $tableMap = $peerClass::getTableMap();
+ foreach ($tableMap->getBehaviors() as $name => $params) {
+ switch ($name) {
+ case 'nested_set':
+ $modifiers['nested_set'] = function ($obj, $inserted) use ($class, $generator) {
+ if (isset($inserted[$class])) {
+ $queryClass = $class . 'Query';
+ $parent = $queryClass::create()->findPk($generator->randomElement($inserted[$class]));
+ $obj->insertAsLastChildOf($parent);
+ } else {
+ $obj->makeRoot();
+ }
+ };
+ break;
+ case 'sortable':
+ $modifiers['sortable'] = function ($obj, $inserted) use ($class) {
+ $maxRank = isset($inserted[$class]) ? count($inserted[$class]) : 0;
+ $obj->insertAtRank(mt_rand(1, $maxRank + 1));
+ };
+ break;
+ }
+ }
+
+ return $modifiers;
+ }
+
+ /**
+ * Insert one new record using the Entity class.
+ */
+ public function execute($con, $insertedEntities)
+ {
+ $obj = new $this->class();
+ foreach ($this->getColumnFormatters() as $column => $format) {
+ if (null !== $format) {
+ $obj->setByName($column, is_callable($format) ? $format($insertedEntities, $obj) : $format);
+ }
+ }
+ foreach ($this->getModifiers() as $modifier) {
+ $modifier($obj, $insertedEntities);
+ }
+ $obj->save($con);
+
+ return $obj->getPrimaryKey();
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Propel/Populator.php b/vendor/fzaninotto/faker/src/Faker/ORM/Propel/Populator.php
new file mode 100644
index 000000000..428572780
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Propel/Populator.php
@@ -0,0 +1,89 @@
+generator = $generator;
+ }
+
+ /**
+ * Add an order for the generation of $number records for $entity.
+ *
+ * @param mixed $entity A Propel ActiveRecord classname, or a \Faker\ORM\Propel\EntityPopulator instance
+ * @param int $number The number of entities to populate
+ */
+ public function addEntity($entity, $number, $customColumnFormatters = array(), $customModifiers = array())
+ {
+ if (!$entity instanceof \Faker\ORM\Propel\EntityPopulator) {
+ $entity = new \Faker\ORM\Propel\EntityPopulator($entity);
+ }
+ $entity->setColumnFormatters($entity->guessColumnFormatters($this->generator));
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+ $entity->setModifiers($entity->guessModifiers($this->generator));
+ if ($customModifiers) {
+ $entity->mergeModifiersWith($customModifiers);
+ }
+ $class = $entity->getClass();
+ $this->entities[$class] = $entity;
+ $this->quantities[$class] = $number;
+ }
+
+ /**
+ * Populate the database using all the Entity classes previously added.
+ *
+ * @param PropelPDO $con A Propel connection object
+ *
+ * @return array A list of the inserted PKs
+ */
+ public function execute($con = null)
+ {
+ if (null === $con) {
+ $con = $this->getConnection();
+ }
+ $isInstancePoolingEnabled = \Propel::isInstancePoolingEnabled();
+ \Propel::disableInstancePooling();
+ $insertedEntities = array();
+ $con->beginTransaction();
+ foreach ($this->quantities as $class => $number) {
+ for ($i=0; $i < $number; $i++) {
+ $insertedEntities[$class][]= $this->entities[$class]->execute($con, $insertedEntities);
+ }
+ }
+ $con->commit();
+ if ($isInstancePoolingEnabled) {
+ \Propel::enableInstancePooling();
+ }
+
+ return $insertedEntities;
+ }
+
+ protected function getConnection()
+ {
+ // use the first connection available
+ $class = key($this->entities);
+
+ if (!$class) {
+ throw new \RuntimeException('No class found from entities. Did you add entities to the Populator ?');
+ }
+
+ $peer = $class::PEER;
+
+ return \Propel::getConnection($peer::DATABASE_NAME, \Propel::CONNECTION_WRITE);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Propel2/ColumnTypeGuesser.php b/vendor/fzaninotto/faker/src/Faker/ORM/Propel2/ColumnTypeGuesser.php
new file mode 100644
index 000000000..024965a72
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Propel2/ColumnTypeGuesser.php
@@ -0,0 +1,107 @@
+generator = $generator;
+ }
+
+ /**
+ * @param ColumnMap $column
+ * @return \Closure|null
+ */
+ public function guessFormat(ColumnMap $column)
+ {
+ $generator = $this->generator;
+ if ($column->isTemporal()) {
+ if ($column->getType() == PropelTypes::BU_DATE || $column->getType() == PropelTypes::BU_TIMESTAMP) {
+ return function () use ($generator) {
+ return $generator->dateTime;
+ };
+ }
+
+ return function () use ($generator) {
+ return $generator->dateTimeAD;
+ };
+ }
+ $type = $column->getType();
+ switch ($type) {
+ case PropelTypes::BOOLEAN:
+ case PropelTypes::BOOLEAN_EMU:
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case PropelTypes::NUMERIC:
+ case PropelTypes::DECIMAL:
+ $size = $column->getSize();
+
+ return function () use ($generator, $size) {
+ return $generator->randomNumber($size + 2) / 100;
+ };
+ case PropelTypes::TINYINT:
+ return function () {
+ return mt_rand(0, 127);
+ };
+ case PropelTypes::SMALLINT:
+ return function () {
+ return mt_rand(0, 32767);
+ };
+ case PropelTypes::INTEGER:
+ return function () {
+ return mt_rand(0, intval('2147483647'));
+ };
+ case PropelTypes::BIGINT:
+ return function () {
+ return mt_rand(0, intval('9223372036854775807'));
+ };
+ case PropelTypes::FLOAT:
+ return function () {
+ return mt_rand(0, intval('2147483647'))/mt_rand(1, intval('2147483647'));
+ };
+ case PropelTypes::DOUBLE:
+ case PropelTypes::REAL:
+ return function () {
+ return mt_rand(0, intval('9223372036854775807'))/mt_rand(1, intval('9223372036854775807'));
+ };
+ case PropelTypes::CHAR:
+ case PropelTypes::VARCHAR:
+ case PropelTypes::BINARY:
+ case PropelTypes::VARBINARY:
+ $size = $column->getSize();
+
+ return function () use ($generator, $size) {
+ return $generator->text($size);
+ };
+ case PropelTypes::LONGVARCHAR:
+ case PropelTypes::LONGVARBINARY:
+ case PropelTypes::CLOB:
+ case PropelTypes::CLOB_EMU:
+ case PropelTypes::BLOB:
+ return function () use ($generator) {
+ return $generator->text;
+ };
+ case PropelTypes::ENUM:
+ $valueSet = $column->getValueSet();
+
+ return function () use ($generator, $valueSet) {
+ return $generator->randomElement($valueSet);
+ };
+ case PropelTypes::OBJECT:
+ case PropelTypes::PHP_ARRAY:
+ default:
+ // no smart way to guess what the user expects here
+ return null;
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Propel2/EntityPopulator.php b/vendor/fzaninotto/faker/src/Faker/ORM/Propel2/EntityPopulator.php
new file mode 100644
index 000000000..df5b6710b
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Propel2/EntityPopulator.php
@@ -0,0 +1,192 @@
+class = $class;
+ }
+
+ /**
+ * @return string
+ */
+ public function getClass()
+ {
+ return $this->class;
+ }
+
+ public function setColumnFormatters($columnFormatters)
+ {
+ $this->columnFormatters = $columnFormatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function getColumnFormatters()
+ {
+ return $this->columnFormatters;
+ }
+
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @return array
+ */
+ public function guessColumnFormatters(\Faker\Generator $generator)
+ {
+ $formatters = array();
+ $class = $this->class;
+ $peerClass = $class::TABLE_MAP;
+ $tableMap = $peerClass::getTableMap();
+ $nameGuesser = new \Faker\Guesser\Name($generator);
+ $columnTypeGuesser = new \Faker\ORM\Propel2\ColumnTypeGuesser($generator);
+ foreach ($tableMap->getColumns() as $columnMap) {
+ // skip behavior columns, handled by modifiers
+ if ($this->isColumnBehavior($columnMap)) {
+ continue;
+ }
+ if ($columnMap->isForeignKey()) {
+ $relatedClass = $columnMap->getRelation()->getForeignTable()->getClassname();
+ $formatters[$columnMap->getPhpName()] = function ($inserted) use ($relatedClass) {
+ $relatedClass = trim($relatedClass, "\\");
+ return isset($inserted[$relatedClass]) ? $inserted[$relatedClass][mt_rand(0, count($inserted[$relatedClass]) - 1)] : null;
+ };
+ continue;
+ }
+ if ($columnMap->isPrimaryKey()) {
+ continue;
+ }
+ if ($formatter = $nameGuesser->guessFormat($columnMap->getPhpName(), $columnMap->getSize())) {
+ $formatters[$columnMap->getPhpName()] = $formatter;
+ continue;
+ }
+ if ($formatter = $columnTypeGuesser->guessFormat($columnMap)) {
+ $formatters[$columnMap->getPhpName()] = $formatter;
+ continue;
+ }
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * @param ColumnMap $columnMap
+ * @return bool
+ */
+ protected function isColumnBehavior(ColumnMap $columnMap)
+ {
+ foreach ($columnMap->getTable()->getBehaviors() as $name => $params) {
+ $columnName = Base::toLower($columnMap->getName());
+ switch ($name) {
+ case 'nested_set':
+ $columnNames = array($params['left_column'], $params['right_column'], $params['level_column']);
+ if (in_array($columnName, $columnNames)) {
+ return true;
+ }
+ break;
+ case 'timestampable':
+ $columnNames = array($params['create_column'], $params['update_column']);
+ if (in_array($columnName, $columnNames)) {
+ return true;
+ }
+ break;
+ }
+ }
+
+ return false;
+ }
+
+ public function setModifiers($modifiers)
+ {
+ $this->modifiers = $modifiers;
+ }
+
+ /**
+ * @return array
+ */
+ public function getModifiers()
+ {
+ return $this->modifiers;
+ }
+
+ public function mergeModifiersWith($modifiers)
+ {
+ $this->modifiers = array_merge($this->modifiers, $modifiers);
+ }
+
+ /**
+ * @param \Faker\Generator $generator
+ * @return array
+ */
+ public function guessModifiers(\Faker\Generator $generator)
+ {
+ $modifiers = array();
+ $class = $this->class;
+ $peerClass = $class::TABLE_MAP;
+ $tableMap = $peerClass::getTableMap();
+ foreach ($tableMap->getBehaviors() as $name => $params) {
+ switch ($name) {
+ case 'nested_set':
+ $modifiers['nested_set'] = function ($obj, $inserted) use ($class, $generator) {
+ if (isset($inserted[$class])) {
+ $queryClass = $class . 'Query';
+ $parent = $queryClass::create()->findPk($generator->randomElement($inserted[$class]));
+ $obj->insertAsLastChildOf($parent);
+ } else {
+ $obj->makeRoot();
+ }
+ };
+ break;
+ case 'sortable':
+ $modifiers['sortable'] = function ($obj, $inserted) use ($class) {
+ $maxRank = isset($inserted[$class]) ? count($inserted[$class]) : 0;
+ $obj->insertAtRank(mt_rand(1, $maxRank + 1));
+ };
+ break;
+ }
+ }
+
+ return $modifiers;
+ }
+
+ /**
+ * Insert one new record using the Entity class.
+ */
+ public function execute($con, $insertedEntities)
+ {
+ $obj = new $this->class();
+ foreach ($this->getColumnFormatters() as $column => $format) {
+ if (null !== $format) {
+ $obj->setByName($column, is_callable($format) ? $format($insertedEntities, $obj) : $format);
+ }
+ }
+ foreach ($this->getModifiers() as $modifier) {
+ $modifier($obj, $insertedEntities);
+ }
+ $obj->save($con);
+
+ return $obj->getPrimaryKey();
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Propel2/Populator.php b/vendor/fzaninotto/faker/src/Faker/ORM/Propel2/Populator.php
new file mode 100644
index 000000000..c0efe3b82
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Propel2/Populator.php
@@ -0,0 +1,92 @@
+generator = $generator;
+ }
+
+ /**
+ * Add an order for the generation of $number records for $entity.
+ *
+ * @param mixed $entity A Propel ActiveRecord classname, or a \Faker\ORM\Propel2\EntityPopulator instance
+ * @param int $number The number of entities to populate
+ */
+ public function addEntity($entity, $number, $customColumnFormatters = array(), $customModifiers = array())
+ {
+ if (!$entity instanceof \Faker\ORM\Propel2\EntityPopulator) {
+ $entity = new \Faker\ORM\Propel2\EntityPopulator($entity);
+ }
+ $entity->setColumnFormatters($entity->guessColumnFormatters($this->generator));
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+ $entity->setModifiers($entity->guessModifiers($this->generator));
+ if ($customModifiers) {
+ $entity->mergeModifiersWith($customModifiers);
+ }
+ $class = $entity->getClass();
+ $this->entities[$class] = $entity;
+ $this->quantities[$class] = $number;
+ }
+
+ /**
+ * Populate the database using all the Entity classes previously added.
+ *
+ * @param PropelPDO $con A Propel connection object
+ *
+ * @return array A list of the inserted PKs
+ */
+ public function execute($con = null)
+ {
+ if (null === $con) {
+ $con = $this->getConnection();
+ }
+ $isInstancePoolingEnabled = Propel::isInstancePoolingEnabled();
+ Propel::disableInstancePooling();
+ $insertedEntities = array();
+ $con->beginTransaction();
+ foreach ($this->quantities as $class => $number) {
+ for ($i=0; $i < $number; $i++) {
+ $insertedEntities[$class][]= $this->entities[$class]->execute($con, $insertedEntities);
+ }
+ }
+ $con->commit();
+ if ($isInstancePoolingEnabled) {
+ Propel::enableInstancePooling();
+ }
+
+ return $insertedEntities;
+ }
+
+ protected function getConnection()
+ {
+ // use the first connection available
+ $class = key($this->entities);
+
+ if (!$class) {
+ throw new \RuntimeException('No class found from entities. Did you add entities to the Populator ?');
+ }
+
+ $peer = $class::TABLE_MAP;
+
+ return Propel::getConnection($peer::DATABASE_NAME, ServiceContainerInterface::CONNECTION_WRITE);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Spot/ColumnTypeGuesser.php b/vendor/fzaninotto/faker/src/Faker/ORM/Spot/ColumnTypeGuesser.php
new file mode 100644
index 000000000..716a9f282
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Spot/ColumnTypeGuesser.php
@@ -0,0 +1,77 @@
+generator = $generator;
+ }
+
+ /**
+ * @param array $field
+ * @return \Closure|null
+ */
+ public function guessFormat(array $field)
+ {
+ $generator = $this->generator;
+ $type = $field['type'];
+ switch ($type) {
+ case 'boolean':
+ return function () use ($generator) {
+ return $generator->boolean;
+ };
+ case 'decimal':
+ $size = isset($field['precision']) ? $field['precision'] : 2;
+
+ return function () use ($generator, $size) {
+ return $generator->randomNumber($size + 2) / 100;
+ };
+ case 'smallint':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, 65535);
+ };
+ case 'integer':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, intval('2147483647'));
+ };
+ case 'bigint':
+ return function () use ($generator) {
+ return $generator->numberBetween(0, intval('18446744073709551615'));
+ };
+ case 'float':
+ return function () use ($generator) {
+ return $generator->randomFloat(null, 0, intval('4294967295'));
+ };
+ case 'string':
+ $size = isset($field['length']) ? $field['length'] : 255;
+
+ return function () use ($generator, $size) {
+ return $generator->text($size);
+ };
+ case 'text':
+ return function () use ($generator) {
+ return $generator->text;
+ };
+ case 'datetime':
+ case 'date':
+ case 'time':
+ return function () use ($generator) {
+ return $generator->datetime;
+ };
+ default:
+ // no smart way to guess what the user expects here
+ return null;
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Spot/EntityPopulator.php b/vendor/fzaninotto/faker/src/Faker/ORM/Spot/EntityPopulator.php
new file mode 100644
index 000000000..bc27e7b0b
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Spot/EntityPopulator.php
@@ -0,0 +1,219 @@
+mapper = $mapper;
+ $this->locator = $locator;
+ $this->useExistingData = $useExistingData;
+ }
+
+ /**
+ * @return string
+ */
+ public function getMapper()
+ {
+ return $this->mapper;
+ }
+
+ /**
+ * @param $columnFormatters
+ */
+ public function setColumnFormatters($columnFormatters)
+ {
+ $this->columnFormatters = $columnFormatters;
+ }
+
+ /**
+ * @return array
+ */
+ public function getColumnFormatters()
+ {
+ return $this->columnFormatters;
+ }
+
+ /**
+ * @param $columnFormatters
+ */
+ public function mergeColumnFormattersWith($columnFormatters)
+ {
+ $this->columnFormatters = array_merge($this->columnFormatters, $columnFormatters);
+ }
+
+ /**
+ * @param array $modifiers
+ */
+ public function setModifiers(array $modifiers)
+ {
+ $this->modifiers = $modifiers;
+ }
+
+ /**
+ * @return array
+ */
+ public function getModifiers()
+ {
+ return $this->modifiers;
+ }
+
+ /**
+ * @param array $modifiers
+ */
+ public function mergeModifiersWith(array $modifiers)
+ {
+ $this->modifiers = array_merge($this->modifiers, $modifiers);
+ }
+
+ /**
+ * @param Generator $generator
+ * @return array
+ */
+ public function guessColumnFormatters(Generator $generator)
+ {
+ $formatters = array();
+ $nameGuesser = new Name($generator);
+ $columnTypeGuesser = new ColumnTypeGuesser($generator);
+ $fields = $this->mapper->fields();
+ foreach ($fields as $fieldName => $field) {
+ if ($field['primary'] === true) {
+ continue;
+ }
+ if ($formatter = $nameGuesser->guessFormat($fieldName)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ if ($formatter = $columnTypeGuesser->guessFormat($field)) {
+ $formatters[$fieldName] = $formatter;
+ continue;
+ }
+ }
+ $entityName = $this->mapper->entity();
+ $entity = $this->mapper->build([]);
+ $relations = $entityName::relations($this->mapper, $entity);
+ foreach ($relations as $relation) {
+ // We don't need any other relation here.
+ if ($relation instanceof BelongsTo) {
+ $fieldName = $relation->localKey();
+ $entityName = $relation->entityName();
+ $field = $fields[$fieldName];
+ $required = $field['required'];
+
+ $locator = $this->locator;
+
+ $formatters[$fieldName] = function ($inserted) use ($required, $entityName, $locator) {
+ if (!empty($inserted[$entityName])) {
+ return $inserted[$entityName][mt_rand(0, count($inserted[$entityName]) - 1)]->get('id');
+ }
+
+ if ($required && $this->useExistingData) {
+ // We did not add anything like this, but it's required,
+ // So let's find something existing in DB.
+ $mapper = $locator->mapper($entityName);
+ $records = $mapper->all()->limit(self::RELATED_FETCH_COUNT)->toArray();
+ if (empty($records)) {
+ return null;
+ }
+
+ return $records[mt_rand(0, count($records) - 1)]['id'];
+ }
+
+ return null;
+ };
+ }
+ }
+
+ return $formatters;
+ }
+
+ /**
+ * Insert one new record using the Entity class.
+ *
+ * @param $insertedEntities
+ * @return string
+ */
+ public function execute($insertedEntities)
+ {
+ $obj = $this->mapper->build([]);
+
+ $this->fillColumns($obj, $insertedEntities);
+ $this->callMethods($obj, $insertedEntities);
+
+ $this->mapper->insert($obj);
+
+
+ return $obj;
+ }
+
+ /**
+ * @param $obj
+ * @param $insertedEntities
+ */
+ private function fillColumns($obj, $insertedEntities)
+ {
+ foreach ($this->columnFormatters as $field => $format) {
+ if (null !== $format) {
+ $value = is_callable($format) ? $format($insertedEntities, $obj) : $format;
+ $obj->set($field, $value);
+ }
+ }
+ }
+
+ /**
+ * @param $obj
+ * @param $insertedEntities
+ */
+ private function callMethods($obj, $insertedEntities)
+ {
+ foreach ($this->getModifiers() as $modifier) {
+ $modifier($obj, $insertedEntities);
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ORM/Spot/Populator.php b/vendor/fzaninotto/faker/src/Faker/ORM/Spot/Populator.php
new file mode 100644
index 000000000..c834b04c8
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ORM/Spot/Populator.php
@@ -0,0 +1,88 @@
+generator = $generator;
+ $this->locator = $locator;
+ }
+
+ /**
+ * Add an order for the generation of $number records for $entity.
+ *
+ * @param $entityName string Name of Entity object to generate
+ * @param $number int The number of entities to populate
+ * @param $customColumnFormatters array
+ * @param $customModifiers array
+ * @param $useExistingData bool Should we use existing rows (e.g. roles) to populate relations?
+ */
+ public function addEntity(
+ $entityName,
+ $number,
+ $customColumnFormatters = array(),
+ $customModifiers = array(),
+ $useExistingData = false
+ ) {
+ $mapper = $this->locator->mapper($entityName);
+ if (null === $mapper) {
+ throw new \InvalidArgumentException("No mapper can be found for entity " . $entityName);
+ }
+ $entity = new EntityPopulator($mapper, $this->locator, $useExistingData);
+
+ $entity->setColumnFormatters($entity->guessColumnFormatters($this->generator));
+ if ($customColumnFormatters) {
+ $entity->mergeColumnFormattersWith($customColumnFormatters);
+ }
+ $entity->mergeModifiersWith($customModifiers);
+
+ $this->entities[$entityName] = $entity;
+ $this->quantities[$entityName] = $number;
+ }
+
+ /**
+ * Populate the database using all the Entity classes previously added.
+ *
+ * @param Locator $locator A Spot locator
+ *
+ * @return array A list of the inserted PKs
+ */
+ public function execute($locator = null)
+ {
+ if (null === $locator) {
+ $locator = $this->locator;
+ }
+ if (null === $locator) {
+ throw new \InvalidArgumentException("No entity manager passed to Spot Populator.");
+ }
+
+ $insertedEntities = array();
+ foreach ($this->quantities as $entityName => $number) {
+ for ($i = 0; $i < $number; $i++) {
+ $insertedEntities[$entityName][] = $this->entities[$entityName]->execute(
+ $insertedEntities
+ );
+ }
+ }
+
+ return $insertedEntities;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/Address.php
new file mode 100644
index 000000000..24f538af4
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/Address.php
@@ -0,0 +1,139 @@
+generator->parse($format);
+ }
+
+ /**
+ * @example 'Crist Parks'
+ */
+ public function streetName()
+ {
+ $format = static::randomElement(static::$streetNameFormats);
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * @example '791 Crist Parks'
+ */
+ public function streetAddress()
+ {
+ $format = static::randomElement(static::$streetAddressFormats);
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * @example 86039-9874
+ */
+ public static function postcode()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$postcode)));
+ }
+
+ /**
+ * @example '791 Crist Parks, Sashabury, IL 86039-9874'
+ */
+ public function address()
+ {
+ $format = static::randomElement(static::$addressFormats);
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * @example 'Japan'
+ */
+ public static function country()
+ {
+ return static::randomElement(static::$country);
+ }
+
+ /**
+ * @example '77.147489'
+ * @param float|int $min
+ * @param float|int $max
+ * @return float Uses signed degrees format (returns a float number between -90 and 90)
+ */
+ public static function latitude($min = -90, $max = 90)
+ {
+ return static::randomFloat(6, $min, $max);
+ }
+
+ /**
+ * @example '86.211205'
+ * @param float|int $min
+ * @param float|int $max
+ * @return float Uses signed degrees format (returns a float number between -180 and 180)
+ */
+ public static function longitude($min = -180, $max = 180)
+ {
+ return static::randomFloat(6, $min, $max);
+ }
+
+ /**
+ * @example array('77.147489', '86.211205')
+ * @return array | latitude, longitude
+ */
+ public static function localCoordinates()
+ {
+ return array(
+ 'latitude' => static::latitude(),
+ 'longitude' => static::longitude()
+ );
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/Barcode.php b/vendor/fzaninotto/faker/src/Faker/Provider/Barcode.php
new file mode 100644
index 000000000..05759a343
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/Barcode.php
@@ -0,0 +1,114 @@
+ $digit) {
+ $sums += $digit * $sequence[$n % 2];
+ }
+ return (10 - $sums % 10) % 10;
+ }
+
+ /**
+ * ISBN-10 check digit
+ * @link http://en.wikipedia.org/wiki/International_Standard_Book_Number#ISBN-10_check_digits
+ *
+ * @param string $input ISBN without check-digit
+ * @throws \LengthException When wrong input length passed
+ *
+ * @return integer Check digit
+ */
+ protected static function isbnChecksum($input)
+ {
+ // We're calculating check digit for ISBN-10
+ // so, the length of the input should be 9
+ $length = 9;
+
+ if (strlen($input) !== $length) {
+ throw new \LengthException(sprintf('Input length should be equal to %d', $length));
+ }
+
+ $digits = str_split($input);
+ array_walk(
+ $digits,
+ function (&$digit, $position) {
+ $digit = (10 - $position) * $digit;
+ }
+ );
+ $result = (11 - array_sum($digits) % 11) % 11;
+
+ // 10 is replaced by X
+ return ($result < 10)?$result:'X';
+ }
+
+ /**
+ * Get a random EAN13 barcode.
+ * @return string
+ * @example '4006381333931'
+ */
+ public function ean13()
+ {
+ return $this->ean(13);
+ }
+
+ /**
+ * Get a random EAN8 barcode.
+ * @return string
+ * @example '73513537'
+ */
+ public function ean8()
+ {
+ return $this->ean(8);
+ }
+
+ /**
+ * Get a random ISBN-10 code
+ * @link http://en.wikipedia.org/wiki/International_Standard_Book_Number
+ *
+ * @return string
+ * @example '4881416324'
+ */
+ public function isbn10()
+ {
+ $code = static::numerify(str_repeat('#', 9));
+
+ return $code . static::isbnChecksum($code);
+ }
+
+ /**
+ * Get a random ISBN-13 code
+ * @link http://en.wikipedia.org/wiki/International_Standard_Book_Number
+ *
+ * @return string
+ * @example '9790404436093'
+ */
+ public function isbn13()
+ {
+ $code = '97' . static::numberBetween(8, 9) . static::numerify(str_repeat('#', 9));
+
+ return $code . static::eanChecksum($code);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/Base.php b/vendor/fzaninotto/faker/src/Faker/Provider/Base.php
new file mode 100644
index 000000000..6765c805d
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/Base.php
@@ -0,0 +1,612 @@
+generator = $generator;
+ }
+
+ /**
+ * Returns a random number between 0 and 9
+ *
+ * @return integer
+ */
+ public static function randomDigit()
+ {
+ return mt_rand(0, 9);
+ }
+
+ /**
+ * Returns a random number between 1 and 9
+ *
+ * @return integer
+ */
+ public static function randomDigitNotNull()
+ {
+ return mt_rand(1, 9);
+ }
+
+ /**
+ * Generates a random digit, which cannot be $except
+ *
+ * @param int $except
+ * @return int
+ */
+ public static function randomDigitNot($except)
+ {
+ $result = self::numberBetween(0, 8);
+ if ($result >= $except) {
+ $result++;
+ }
+ return $result;
+ }
+
+ /**
+ * Returns a random integer with 0 to $nbDigits digits.
+ *
+ * The maximum value returned is mt_getrandmax()
+ *
+ * @param integer $nbDigits Defaults to a random number between 1 and 9
+ * @param boolean $strict Whether the returned number should have exactly $nbDigits
+ * @example 79907610
+ *
+ * @return integer
+ */
+ public static function randomNumber($nbDigits = null, $strict = false)
+ {
+ if (!is_bool($strict)) {
+ throw new \InvalidArgumentException('randomNumber() generates numbers of fixed width. To generate numbers between two boundaries, use numberBetween() instead.');
+ }
+ if (null === $nbDigits) {
+ $nbDigits = static::randomDigitNotNull();
+ }
+ $max = pow(10, $nbDigits) - 1;
+ if ($max > mt_getrandmax()) {
+ throw new \InvalidArgumentException('randomNumber() can only generate numbers up to mt_getrandmax()');
+ }
+ if ($strict) {
+ return mt_rand(pow(10, $nbDigits - 1), $max);
+ }
+
+ return mt_rand(0, $max);
+ }
+
+ /**
+ * Return a random float number
+ *
+ * @param int $nbMaxDecimals
+ * @param int|float $min
+ * @param int|float $max
+ * @example 48.8932
+ *
+ * @return float
+ */
+ public static function randomFloat($nbMaxDecimals = null, $min = 0, $max = null)
+ {
+ if (null === $nbMaxDecimals) {
+ $nbMaxDecimals = static::randomDigit();
+ }
+
+ if (null === $max) {
+ $max = static::randomNumber();
+ if ($min > $max) {
+ $max = $min;
+ }
+ }
+
+ if ($min > $max) {
+ $tmp = $min;
+ $min = $max;
+ $max = $tmp;
+ }
+
+ return round($min + mt_rand() / mt_getrandmax() * ($max - $min), $nbMaxDecimals);
+ }
+
+ /**
+ * Returns a random number between $int1 and $int2 (any order)
+ *
+ * @param integer $int1 default to 0
+ * @param integer $int2 defaults to 32 bit max integer, ie 2147483647
+ * @example 79907610
+ *
+ * @return integer
+ */
+ public static function numberBetween($int1 = 0, $int2 = 2147483647)
+ {
+ $min = $int1 < $int2 ? $int1 : $int2;
+ $max = $int1 < $int2 ? $int2 : $int1;
+ return mt_rand($min, $max);
+ }
+
+ /**
+ * Returns the passed value
+ *
+ * @param mixed $value
+ *
+ * @return mixed
+ */
+ public static function passthrough($value)
+ {
+ return $value;
+ }
+
+ /**
+ * Returns a random letter from a to z
+ *
+ * @return string
+ */
+ public static function randomLetter()
+ {
+ return chr(mt_rand(97, 122));
+ }
+
+ /**
+ * Returns a random ASCII character (excluding accents and special chars)
+ */
+ public static function randomAscii()
+ {
+ return chr(mt_rand(33, 126));
+ }
+
+ /**
+ * Returns randomly ordered subsequence of $count elements from a provided array
+ *
+ * @param array $array Array to take elements from. Defaults to a-c
+ * @param integer $count Number of elements to take.
+ * @param boolean $allowDuplicates Allow elements to be picked several times. Defaults to false
+ * @throws \LengthException When requesting more elements than provided
+ *
+ * @return array New array with $count elements from $array
+ */
+ public static function randomElements($array = array('a', 'b', 'c'), $count = 1, $allowDuplicates = false)
+ {
+ $traversables = array();
+
+ if ($array instanceof \Traversable) {
+ foreach ($array as $element) {
+ $traversables[] = $element;
+ }
+ }
+
+ $arr = count($traversables) ? $traversables : $array;
+
+ $allKeys = array_keys($arr);
+ $numKeys = count($allKeys);
+
+ if (!$allowDuplicates && $numKeys < $count) {
+ throw new \LengthException(sprintf('Cannot get %d elements, only %d in array', $count, $numKeys));
+ }
+
+ $highKey = $numKeys - 1;
+ $keys = $elements = array();
+ $numElements = 0;
+
+ while ($numElements < $count) {
+ $num = mt_rand(0, $highKey);
+
+ if (!$allowDuplicates) {
+ if (isset($keys[$num])) {
+ continue;
+ }
+ $keys[$num] = true;
+ }
+
+ $elements[] = $arr[$allKeys[$num]];
+ $numElements++;
+ }
+
+ return $elements;
+ }
+
+ /**
+ * Returns a random element from a passed array
+ *
+ * @param array $array
+ * @return mixed
+ */
+ public static function randomElement($array = array('a', 'b', 'c'))
+ {
+ if (!$array || ($array instanceof \Traversable && !count($array))) {
+ return null;
+ }
+ $elements = static::randomElements($array, 1);
+
+ return $elements[0];
+ }
+
+ /**
+ * Returns a random key from a passed associative array
+ *
+ * @param array $array
+ * @return int|string|null
+ */
+ public static function randomKey($array = array())
+ {
+ if (!$array) {
+ return null;
+ }
+ $keys = array_keys($array);
+ $key = $keys[mt_rand(0, count($keys) - 1)];
+
+ return $key;
+ }
+
+ /**
+ * Returns a shuffled version of the argument.
+ *
+ * This function accepts either an array, or a string.
+ *
+ * @example $faker->shuffle([1, 2, 3]); // [2, 1, 3]
+ * @example $faker->shuffle('hello, world'); // 'rlo,h eold!lw'
+ *
+ * @see shuffleArray()
+ * @see shuffleString()
+ *
+ * @param array|string $arg The set to shuffle
+ * @return array|string The shuffled set
+ */
+ public static function shuffle($arg = '')
+ {
+ if (is_array($arg)) {
+ return static::shuffleArray($arg);
+ }
+ if (is_string($arg)) {
+ return static::shuffleString($arg);
+ }
+ throw new \InvalidArgumentException('shuffle() only supports strings or arrays');
+ }
+
+ /**
+ * Returns a shuffled version of the array.
+ *
+ * This function does not mutate the original array. It uses the
+ * Fisher–Yates algorithm, which is unbiased, together with a Mersenne
+ * twister random generator. This function is therefore more random than
+ * PHP's shuffle() function, and it is seedable.
+ *
+ * @link http://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle
+ *
+ * @example $faker->shuffleArray([1, 2, 3]); // [2, 1, 3]
+ *
+ * @param array $array The set to shuffle
+ * @return array The shuffled set
+ */
+ public static function shuffleArray($array = array())
+ {
+ $shuffledArray = array();
+ $i = 0;
+ reset($array);
+ foreach ($array as $key => $value) {
+ if ($i == 0) {
+ $j = 0;
+ } else {
+ $j = mt_rand(0, $i);
+ }
+ if ($j == $i) {
+ $shuffledArray[]= $value;
+ } else {
+ $shuffledArray[]= $shuffledArray[$j];
+ $shuffledArray[$j] = $value;
+ }
+ $i++;
+ }
+ return $shuffledArray;
+ }
+
+ /**
+ * Returns a shuffled version of the string.
+ *
+ * This function does not mutate the original string. It uses the
+ * Fisher–Yates algorithm, which is unbiased, together with a Mersenne
+ * twister random generator. This function is therefore more random than
+ * PHP's shuffle() function, and it is seedable. Additionally, it is
+ * UTF8 safe if the mb extension is available.
+ *
+ * @link http://en.wikipedia.org/wiki/Fisher%E2%80%93Yates_shuffle
+ *
+ * @example $faker->shuffleString('hello, world'); // 'rlo,h eold!lw'
+ *
+ * @param string $string The set to shuffle
+ * @param string $encoding The string encoding (defaults to UTF-8)
+ * @return string The shuffled set
+ */
+ public static function shuffleString($string = '', $encoding = 'UTF-8')
+ {
+ if (function_exists('mb_strlen')) {
+ // UTF8-safe str_split()
+ $array = array();
+ $strlen = mb_strlen($string, $encoding);
+ for ($i = 0; $i < $strlen; $i++) {
+ $array []= mb_substr($string, $i, 1, $encoding);
+ }
+ } else {
+ $array = str_split($string, 1);
+ }
+ return implode('', static::shuffleArray($array));
+ }
+
+ private static function replaceWildcard($string, $wildcard = '#', $callback = 'static::randomDigit')
+ {
+ if (($pos = strpos($string, $wildcard)) === false) {
+ return $string;
+ }
+ for ($i = $pos, $last = strrpos($string, $wildcard, $pos) + 1; $i < $last; $i++) {
+ if ($string[$i] === $wildcard) {
+ $string[$i] = call_user_func($callback);
+ }
+ }
+ return $string;
+ }
+
+ /**
+ * Replaces all hash sign ('#') occurrences with a random number
+ * Replaces all percentage sign ('%') occurrences with a not null number
+ *
+ * @param string $string String that needs to bet parsed
+ * @return string
+ */
+ public static function numerify($string = '###')
+ {
+ // instead of using randomDigit() several times, which is slow,
+ // count the number of hashes and generate once a large number
+ $toReplace = array();
+ if (($pos = strpos($string, '#')) !== false) {
+ for ($i = $pos, $last = strrpos($string, '#', $pos) + 1; $i < $last; $i++) {
+ if ($string[$i] === '#') {
+ $toReplace[] = $i;
+ }
+ }
+ }
+ if ($nbReplacements = count($toReplace)) {
+ $maxAtOnce = strlen((string) mt_getrandmax()) - 1;
+ $numbers = '';
+ $i = 0;
+ while ($i < $nbReplacements) {
+ $size = min($nbReplacements - $i, $maxAtOnce);
+ $numbers .= str_pad(static::randomNumber($size), $size, '0', STR_PAD_LEFT);
+ $i += $size;
+ }
+ for ($i = 0; $i < $nbReplacements; $i++) {
+ $string[$toReplace[$i]] = $numbers[$i];
+ }
+ }
+ $string = self::replaceWildcard($string, '%', 'static::randomDigitNotNull');
+
+ return $string;
+ }
+
+ /**
+ * Replaces all question mark ('?') occurrences with a random letter
+ *
+ * @param string $string String that needs to bet parsed
+ * @return string
+ */
+ public static function lexify($string = '????')
+ {
+ return self::replaceWildcard($string, '?', 'static::randomLetter');
+ }
+
+ /**
+ * Replaces hash signs ('#') and question marks ('?') with random numbers and letters
+ * An asterisk ('*') is replaced with either a random number or a random letter
+ *
+ * @param string $string String that needs to bet parsed
+ * @return string
+ */
+ public static function bothify($string = '## ??')
+ {
+ $string = self::replaceWildcard($string, '*', function () {
+ return mt_rand(0, 1) ? '#' : '?';
+ });
+ return static::lexify(static::numerify($string));
+ }
+
+ /**
+ * Replaces * signs with random numbers and letters and special characters
+ *
+ * @example $faker->asciify(''********'); // "s5'G!uC3"
+ *
+ * @param string $string String that needs to bet parsed
+ * @return string
+ */
+ public static function asciify($string = '****')
+ {
+ return preg_replace_callback('/\*/u', 'static::randomAscii', $string);
+ }
+
+ /**
+ * Transforms a basic regular expression into a random string satisfying the expression.
+ *
+ * @example $faker->regexify('[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,4}'); // sm0@y8k96a.ej
+ *
+ * Regex delimiters '/.../' and begin/end markers '^...$' are ignored.
+ *
+ * Only supports a small subset of the regex syntax. For instance,
+ * unicode, negated classes, unbounded ranges, subpatterns, back references,
+ * assertions, recursive patterns, and comments are not supported. Escaping
+ * support is extremely fragile.
+ *
+ * This method is also VERY slow. Use it only when no other formatter
+ * can generate the fake data you want. For instance, prefer calling
+ * `$faker->email` rather than `regexify` with the previous regular
+ * expression.
+ *
+ * Also note than `bothify` can probably do most of what this method does,
+ * but much faster. For instance, for a dummy email generation, try
+ * `$faker->bothify('?????????@???.???')`.
+ *
+ * @see https://github.com/icomefromthenet/ReverseRegex for a more robust implementation
+ *
+ * @param string $regex A regular expression (delimiters are optional)
+ * @return string
+ */
+ public static function regexify($regex = '')
+ {
+ // ditch the anchors
+ $regex = preg_replace('/^\/?\^?/', '', $regex);
+ $regex = preg_replace('/\$?\/?$/', '', $regex);
+ // All {2} become {2,2}
+ $regex = preg_replace('/\{(\d+)\}/', '{\1,\1}', $regex);
+ // Single-letter quantifiers (?, *, +) become bracket quantifiers ({0,1}, {0,rand}, {1, rand})
+ $regex = preg_replace('/(? 0 && $weight < 1 && mt_rand() / mt_getrandmax() <= $weight) {
+ return $this->generator;
+ }
+
+ // new system with percentage
+ if (is_int($weight) && mt_rand(1, 100) <= $weight) {
+ return $this->generator;
+ }
+
+ return new DefaultGenerator($default);
+ }
+
+ /**
+ * Chainable method for making any formatter unique.
+ *
+ *
+ * // will never return twice the same value
+ * $faker->unique()->randomElement(array(1, 2, 3));
+ *
+ *
+ * @param boolean $reset If set to true, resets the list of existing values
+ * @param integer $maxRetries Maximum number of retries to find a unique value,
+ * After which an OverflowException is thrown.
+ * @throws \OverflowException When no unique value can be found by iterating $maxRetries times
+ *
+ * @return UniqueGenerator A proxy class returning only non-existing values
+ */
+ public function unique($reset = false, $maxRetries = 10000)
+ {
+ if ($reset || !$this->unique) {
+ $this->unique = new UniqueGenerator($this->generator, $maxRetries);
+ }
+
+ return $this->unique;
+ }
+
+ /**
+ * Chainable method for forcing any formatter to return only valid values.
+ *
+ * The value validity is determined by a function passed as first argument.
+ *
+ *
+ * $values = array();
+ * $evenValidator = function ($digit) {
+ * return $digit % 2 === 0;
+ * };
+ * for ($i=0; $i < 10; $i++) {
+ * $values []= $faker->valid($evenValidator)->randomDigit;
+ * }
+ * print_r($values); // [0, 4, 8, 4, 2, 6, 0, 8, 8, 6]
+ *
+ *
+ * @param Closure $validator A function returning true for valid values
+ * @param integer $maxRetries Maximum number of retries to find a unique value,
+ * After which an OverflowException is thrown.
+ * @throws \OverflowException When no valid value can be found by iterating $maxRetries times
+ *
+ * @return ValidGenerator A proxy class returning only valid values
+ */
+ public function valid($validator = null, $maxRetries = 10000)
+ {
+ return new ValidGenerator($this->generator, $validator, $maxRetries);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/Biased.php b/vendor/fzaninotto/faker/src/Faker/Provider/Biased.php
new file mode 100644
index 000000000..d37dceff4
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/Biased.php
@@ -0,0 +1,64 @@
+generator->parse($format);
+ }
+
+ /**
+ * @example 'Ltd'
+ *
+ * @return string
+ */
+ public static function companySuffix()
+ {
+ return static::randomElement(static::$companySuffix);
+ }
+
+ /**
+ * @example 'Job'
+ *
+ * @return string
+ */
+ public function jobTitle()
+ {
+ $format = static::randomElement(static::$jobTitleFormat);
+
+ return $this->generator->parse($format);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/DateTime.php b/vendor/fzaninotto/faker/src/Faker/Provider/DateTime.php
new file mode 100644
index 000000000..bde7f251e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/DateTime.php
@@ -0,0 +1,340 @@
+getTimestamp();
+ }
+
+ return strtotime(empty($max) ? 'now' : $max);
+ }
+
+ /**
+ * Get a timestamp between January 1, 1970 and now
+ *
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return int
+ *
+ * @example 1061306726
+ */
+ public static function unixTime($max = 'now')
+ {
+ return mt_rand(0, static::getMaxTimestamp($max));
+ }
+
+ /**
+ * Get a datetime object for a date between January 1, 1970 and now
+ *
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('2005-08-16 20:39:21')
+ * @return \DateTime
+ * @see http://php.net/manual/en/timezones.php
+ * @see http://php.net/manual/en/function.date-default-timezone-get.php
+ */
+ public static function dateTime($max = 'now', $timezone = null)
+ {
+ return static::setTimezone(
+ new \DateTime('@' . static::unixTime($max)),
+ $timezone
+ );
+ }
+
+ /**
+ * Get a datetime object for a date between January 1, 001 and now
+ *
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('1265-03-22 21:15:52')
+ * @return \DateTime
+ * @see http://php.net/manual/en/timezones.php
+ * @see http://php.net/manual/en/function.date-default-timezone-get.php
+ */
+ public static function dateTimeAD($max = 'now', $timezone = null)
+ {
+ $min = (PHP_INT_SIZE>4 ? -62135597361 : -PHP_INT_MAX);
+ return static::setTimezone(
+ new \DateTime('@' . mt_rand($min, static::getMaxTimestamp($max))),
+ $timezone
+ );
+ }
+
+ /**
+ * get a date string formatted with ISO8601
+ *
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '2003-10-21T16:05:52+0000'
+ */
+ public static function iso8601($max = 'now')
+ {
+ return static::date(\DateTime::ISO8601, $max);
+ }
+
+ /**
+ * Get a date string between January 1, 1970 and now
+ *
+ * @param string $format
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '2008-11-27'
+ */
+ public static function date($format = 'Y-m-d', $max = 'now')
+ {
+ return static::dateTime($max)->format($format);
+ }
+
+ /**
+ * Get a time string (24h format by default)
+ *
+ * @param string $format
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '15:02:34'
+ */
+ public static function time($format = 'H:i:s', $max = 'now')
+ {
+ return static::dateTime($max)->format($format);
+ }
+
+ /**
+ * Get a DateTime object based on a random date between two given dates.
+ * Accepts date strings that can be recognized by strtotime().
+ *
+ * @param \DateTime|string $startDate Defaults to 30 years ago
+ * @param \DateTime|string $endDate Defaults to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('1999-02-02 11:42:52')
+ * @return \DateTime
+ * @see http://php.net/manual/en/timezones.php
+ * @see http://php.net/manual/en/function.date-default-timezone-get.php
+ */
+ public static function dateTimeBetween($startDate = '-30 years', $endDate = 'now', $timezone = null)
+ {
+ $startTimestamp = $startDate instanceof \DateTime ? $startDate->getTimestamp() : strtotime($startDate);
+ $endTimestamp = static::getMaxTimestamp($endDate);
+
+ if ($startTimestamp > $endTimestamp) {
+ throw new \InvalidArgumentException('Start date must be anterior to end date.');
+ }
+
+ $timestamp = mt_rand($startTimestamp, $endTimestamp);
+
+ return static::setTimezone(
+ new \DateTime('@' . $timestamp),
+ $timezone
+ );
+ }
+
+ /**
+ * Get a DateTime object based on a random date between one given date and
+ * an interval
+ * Accepts date string that can be recognized by strtotime().
+ *
+ * @param \DateTime|string $date Defaults to 30 years ago
+ * @param string $interval Defaults to 5 days after
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example dateTimeInInterval('1999-02-02 11:42:52', '+ 5 days')
+ * @return \DateTime
+ * @see http://php.net/manual/en/timezones.php
+ * @see http://php.net/manual/en/function.date-default-timezone-get.php
+ */
+ public static function dateTimeInInterval($date = '-30 years', $interval = '+5 days', $timezone = null)
+ {
+ $intervalObject = \DateInterval::createFromDateString($interval);
+ $datetime = $date instanceof \DateTime ? $date : new \DateTime($date);
+ $otherDatetime = clone $datetime;
+ $otherDatetime->add($intervalObject);
+
+ $begin = $datetime > $otherDatetime ? $otherDatetime : $datetime;
+ $end = $datetime===$begin ? $otherDatetime : $datetime;
+
+ return static::dateTimeBetween(
+ $begin,
+ $end,
+ $timezone
+ );
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('1964-04-04 11:02:02')
+ * @return \DateTime
+ */
+ public static function dateTimeThisCentury($max = 'now', $timezone = null)
+ {
+ return static::dateTimeBetween('-100 year', $max, $timezone);
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('2010-03-10 05:18:58')
+ * @return \DateTime
+ */
+ public static function dateTimeThisDecade($max = 'now', $timezone = null)
+ {
+ return static::dateTimeBetween('-10 year', $max, $timezone);
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('2011-09-19 09:24:37')
+ * @return \DateTime
+ */
+ public static function dateTimeThisYear($max = 'now', $timezone = null)
+ {
+ return static::dateTimeBetween('-1 year', $max, $timezone);
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @param string|null $timezone time zone in which the date time should be set, default to DateTime::$defaultTimezone, if set, otherwise the result of `date_default_timezone_get`
+ * @example DateTime('2011-10-05 12:51:46')
+ * @return \DateTime
+ */
+ public static function dateTimeThisMonth($max = 'now', $timezone = null)
+ {
+ return static::dateTimeBetween('-1 month', $max, $timezone);
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example 'am'
+ */
+ public static function amPm($max = 'now')
+ {
+ return static::dateTime($max)->format('a');
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '22'
+ */
+ public static function dayOfMonth($max = 'now')
+ {
+ return static::dateTime($max)->format('d');
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example 'Tuesday'
+ */
+ public static function dayOfWeek($max = 'now')
+ {
+ return static::dateTime($max)->format('l');
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '7'
+ */
+ public static function month($max = 'now')
+ {
+ return static::dateTime($max)->format('m');
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example 'September'
+ */
+ public static function monthName($max = 'now')
+ {
+ return static::dateTime($max)->format('F');
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '1673'
+ */
+ public static function year($max = 'now')
+ {
+ return static::dateTime($max)->format('Y');
+ }
+
+ /**
+ * @return string
+ * @example 'XVII'
+ */
+ public static function century()
+ {
+ return static::randomElement(static::$century);
+ }
+
+ /**
+ * @return string
+ * @example 'Europe/Paris'
+ */
+ public static function timezone()
+ {
+ return static::randomElement(\DateTimeZone::listIdentifiers());
+ }
+
+ /**
+ * Internal method to set the time zone on a DateTime.
+ *
+ * @param \DateTime $dt
+ * @param string|null $timezone
+ *
+ * @return \DateTime
+ */
+ private static function setTimezone(\DateTime $dt, $timezone)
+ {
+ return $dt->setTimezone(new \DateTimeZone(static::resolveTimezone($timezone)));
+ }
+
+ /**
+ * Sets default time zone.
+ *
+ * @param string $timezone
+ *
+ * @return void
+ */
+ public static function setDefaultTimezone($timezone = null)
+ {
+ static::$defaultTimezone = $timezone;
+ }
+
+ /**
+ * Gets default time zone.
+ *
+ * @return string|null
+ */
+ public static function getDefaultTimezone()
+ {
+ return static::$defaultTimezone;
+ }
+
+ /**
+ * @param string|null $timezone
+ * @return null|string
+ */
+ private static function resolveTimezone($timezone)
+ {
+ return ((null === $timezone) ? ((null === static::$defaultTimezone) ? date_default_timezone_get() : static::$defaultTimezone) : $timezone);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/File.php b/vendor/fzaninotto/faker/src/Faker/Provider/File.php
new file mode 100644
index 000000000..ba015946e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/File.php
@@ -0,0 +1,606 @@
+ file extension(s)
+ * @link http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types
+ */
+ protected static $mimeTypes = array(
+ 'application/atom+xml' => 'atom',
+ 'application/ecmascript' => 'ecma',
+ 'application/emma+xml' => 'emma',
+ 'application/epub+zip' => 'epub',
+ 'application/java-archive' => 'jar',
+ 'application/java-vm' => 'class',
+ 'application/javascript' => 'js',
+ 'application/json' => 'json',
+ 'application/jsonml+json' => 'jsonml',
+ 'application/lost+xml' => 'lostxml',
+ 'application/mathml+xml' => 'mathml',
+ 'application/mets+xml' => 'mets',
+ 'application/mods+xml' => 'mods',
+ 'application/mp4' => 'mp4s',
+ 'application/msword' => array('doc', 'dot'),
+ 'application/octet-stream' => array(
+ 'bin',
+ 'dms',
+ 'lrf',
+ 'mar',
+ 'so',
+ 'dist',
+ 'distz',
+ 'pkg',
+ 'bpk',
+ 'dump',
+ 'elc',
+ 'deploy'
+ ),
+ 'application/ogg' => 'ogx',
+ 'application/omdoc+xml' => 'omdoc',
+ 'application/pdf' => 'pdf',
+ 'application/pgp-encrypted' => 'pgp',
+ 'application/pgp-signature' => array('asc', 'sig'),
+ 'application/pkix-pkipath' => 'pkipath',
+ 'application/pkixcmp' => 'pki',
+ 'application/pls+xml' => 'pls',
+ 'application/postscript' => array('ai', 'eps', 'ps'),
+ 'application/pskc+xml' => 'pskcxml',
+ 'application/rdf+xml' => 'rdf',
+ 'application/reginfo+xml' => 'rif',
+ 'application/rss+xml' => 'rss',
+ 'application/rtf' => 'rtf',
+ 'application/sbml+xml' => 'sbml',
+ 'application/vnd.adobe.air-application-installer-package+zip' => 'air',
+ 'application/vnd.adobe.xdp+xml' => 'xdp',
+ 'application/vnd.adobe.xfdf' => 'xfdf',
+ 'application/vnd.ahead.space' => 'ahead',
+ 'application/vnd.dart' => 'dart',
+ 'application/vnd.data-vision.rdz' => 'rdz',
+ 'application/vnd.dece.data' => array('uvf', 'uvvf', 'uvd', 'uvvd'),
+ 'application/vnd.dece.ttml+xml' => array('uvt', 'uvvt'),
+ 'application/vnd.dece.unspecified' => array('uvx', 'uvvx'),
+ 'application/vnd.dece.zip' => array('uvz', 'uvvz'),
+ 'application/vnd.denovo.fcselayout-link' => 'fe_launch',
+ 'application/vnd.dna' => 'dna',
+ 'application/vnd.dolby.mlp' => 'mlp',
+ 'application/vnd.dpgraph' => 'dpg',
+ 'application/vnd.dreamfactory' => 'dfac',
+ 'application/vnd.ds-keypoint' => 'kpxx',
+ 'application/vnd.dvb.ait' => 'ait',
+ 'application/vnd.dvb.service' => 'svc',
+ 'application/vnd.dynageo' => 'geo',
+ 'application/vnd.ecowin.chart' => 'mag',
+ 'application/vnd.enliven' => 'nml',
+ 'application/vnd.epson.esf' => 'esf',
+ 'application/vnd.epson.msf' => 'msf',
+ 'application/vnd.epson.quickanime' => 'qam',
+ 'application/vnd.epson.salt' => 'slt',
+ 'application/vnd.epson.ssf' => 'ssf',
+ 'application/vnd.ezpix-album' => 'ez2',
+ 'application/vnd.ezpix-package' => 'ez3',
+ 'application/vnd.fdf' => 'fdf',
+ 'application/vnd.fdsn.mseed' => 'mseed',
+ 'application/vnd.fdsn.seed' => array('seed', 'dataless'),
+ 'application/vnd.flographit' => 'gph',
+ 'application/vnd.fluxtime.clip' => 'ftc',
+ 'application/vnd.hal+xml' => 'hal',
+ 'application/vnd.hydrostatix.sof-data' => 'sfd-hdstx',
+ 'application/vnd.ibm.minipay' => 'mpy',
+ 'application/vnd.ibm.secure-container' => 'sc',
+ 'application/vnd.iccprofile' => array('icc', 'icm'),
+ 'application/vnd.igloader' => 'igl',
+ 'application/vnd.immervision-ivp' => 'ivp',
+ 'application/vnd.kde.karbon' => 'karbon',
+ 'application/vnd.kde.kchart' => 'chrt',
+ 'application/vnd.kde.kformula' => 'kfo',
+ 'application/vnd.kde.kivio' => 'flw',
+ 'application/vnd.kde.kontour' => 'kon',
+ 'application/vnd.kde.kpresenter' => array('kpr', 'kpt'),
+ 'application/vnd.kde.kspread' => 'ksp',
+ 'application/vnd.kde.kword' => array('kwd', 'kwt'),
+ 'application/vnd.kenameaapp' => 'htke',
+ 'application/vnd.kidspiration' => 'kia',
+ 'application/vnd.kinar' => array('kne', 'knp'),
+ 'application/vnd.koan' => array('skp', 'skd', 'skt', 'skm'),
+ 'application/vnd.kodak-descriptor' => 'sse',
+ 'application/vnd.las.las+xml' => 'lasxml',
+ 'application/vnd.llamagraphics.life-balance.desktop' => 'lbd',
+ 'application/vnd.llamagraphics.life-balance.exchange+xml' => 'lbe',
+ 'application/vnd.lotus-1-2-3' => '123',
+ 'application/vnd.lotus-approach' => 'apr',
+ 'application/vnd.lotus-freelance' => 'pre',
+ 'application/vnd.lotus-notes' => 'nsf',
+ 'application/vnd.lotus-organizer' => 'org',
+ 'application/vnd.lotus-screencam' => 'scm',
+ 'application/vnd.mozilla.xul+xml' => 'xul',
+ 'application/vnd.ms-artgalry' => 'cil',
+ 'application/vnd.ms-cab-compressed' => 'cab',
+ 'application/vnd.ms-excel' => array(
+ 'xls',
+ 'xlm',
+ 'xla',
+ 'xlc',
+ 'xlt',
+ 'xlw'
+ ),
+ 'application/vnd.ms-excel.addin.macroenabled.12' => 'xlam',
+ 'application/vnd.ms-excel.sheet.binary.macroenabled.12' => 'xlsb',
+ 'application/vnd.ms-excel.sheet.macroenabled.12' => 'xlsm',
+ 'application/vnd.ms-excel.template.macroenabled.12' => 'xltm',
+ 'application/vnd.ms-fontobject' => 'eot',
+ 'application/vnd.ms-htmlhelp' => 'chm',
+ 'application/vnd.ms-ims' => 'ims',
+ 'application/vnd.ms-lrm' => 'lrm',
+ 'application/vnd.ms-officetheme' => 'thmx',
+ 'application/vnd.ms-pki.seccat' => 'cat',
+ 'application/vnd.ms-pki.stl' => 'stl',
+ 'application/vnd.ms-powerpoint' => array('ppt', 'pps', 'pot'),
+ 'application/vnd.ms-powerpoint.addin.macroenabled.12' => 'ppam',
+ 'application/vnd.ms-powerpoint.presentation.macroenabled.12' => 'pptm',
+ 'application/vnd.ms-powerpoint.slide.macroenabled.12' => 'sldm',
+ 'application/vnd.ms-powerpoint.slideshow.macroenabled.12' => 'ppsm',
+ 'application/vnd.ms-powerpoint.template.macroenabled.12' => 'potm',
+ 'application/vnd.ms-project' => array('mpp', 'mpt'),
+ 'application/vnd.ms-word.document.macroenabled.12' => 'docm',
+ 'application/vnd.ms-word.template.macroenabled.12' => 'dotm',
+ 'application/vnd.ms-works' => array('wps', 'wks', 'wcm', 'wdb'),
+ 'application/vnd.ms-wpl' => 'wpl',
+ 'application/vnd.ms-xpsdocument' => 'xps',
+ 'application/vnd.mseq' => 'mseq',
+ 'application/vnd.musician' => 'mus',
+ 'application/vnd.oasis.opendocument.chart' => 'odc',
+ 'application/vnd.oasis.opendocument.chart-template' => 'otc',
+ 'application/vnd.oasis.opendocument.database' => 'odb',
+ 'application/vnd.oasis.opendocument.formula' => 'odf',
+ 'application/vnd.oasis.opendocument.formula-template' => 'odft',
+ 'application/vnd.oasis.opendocument.graphics' => 'odg',
+ 'application/vnd.oasis.opendocument.graphics-template' => 'otg',
+ 'application/vnd.oasis.opendocument.image' => 'odi',
+ 'application/vnd.oasis.opendocument.image-template' => 'oti',
+ 'application/vnd.oasis.opendocument.presentation' => 'odp',
+ 'application/vnd.oasis.opendocument.presentation-template' => 'otp',
+ 'application/vnd.oasis.opendocument.spreadsheet' => 'ods',
+ 'application/vnd.oasis.opendocument.spreadsheet-template' => 'ots',
+ 'application/vnd.oasis.opendocument.text' => 'odt',
+ 'application/vnd.oasis.opendocument.text-master' => 'odm',
+ 'application/vnd.oasis.opendocument.text-template' => 'ott',
+ 'application/vnd.oasis.opendocument.text-web' => 'oth',
+ 'application/vnd.olpc-sugar' => 'xo',
+ 'application/vnd.oma.dd2+xml' => 'dd2',
+ 'application/vnd.openofficeorg.extension' => 'oxt',
+ 'application/vnd.openxmlformats-officedocument.presentationml.presentation' => 'pptx',
+ 'application/vnd.openxmlformats-officedocument.presentationml.slide' => 'sldx',
+ 'application/vnd.openxmlformats-officedocument.presentationml.slideshow' => 'ppsx',
+ 'application/vnd.openxmlformats-officedocument.presentationml.template' => 'potx',
+ 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' => 'xlsx',
+ 'application/vnd.openxmlformats-officedocument.spreadsheetml.template' => 'xltx',
+ 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' => 'docx',
+ 'application/vnd.openxmlformats-officedocument.wordprocessingml.template' => 'dotx',
+ 'application/vnd.pvi.ptid1' => 'ptid',
+ 'application/vnd.quark.quarkxpress' => array(
+ 'qxd',
+ 'qxt',
+ 'qwd',
+ 'qwt',
+ 'qxl',
+ 'qxb'
+ ),
+ 'application/vnd.realvnc.bed' => 'bed',
+ 'application/vnd.recordare.musicxml' => 'mxl',
+ 'application/vnd.recordare.musicxml+xml' => 'musicxml',
+ 'application/vnd.rig.cryptonote' => 'cryptonote',
+ 'application/vnd.rim.cod' => 'cod',
+ 'application/vnd.rn-realmedia' => 'rm',
+ 'application/vnd.rn-realmedia-vbr' => 'rmvb',
+ 'application/vnd.route66.link66+xml' => 'link66',
+ 'application/vnd.sailingtracker.track' => 'st',
+ 'application/vnd.seemail' => 'see',
+ 'application/vnd.sema' => 'sema',
+ 'application/vnd.semd' => 'semd',
+ 'application/vnd.semf' => 'semf',
+ 'application/vnd.shana.informed.formdata' => 'ifm',
+ 'application/vnd.shana.informed.formtemplate' => 'itp',
+ 'application/vnd.shana.informed.interchange' => 'iif',
+ 'application/vnd.shana.informed.package' => 'ipk',
+ 'application/vnd.simtech-mindmapper' => array('twd', 'twds'),
+ 'application/vnd.smaf' => 'mmf',
+ 'application/vnd.stepmania.stepchart' => 'sm',
+ 'application/vnd.sun.xml.calc' => 'sxc',
+ 'application/vnd.sun.xml.calc.template' => 'stc',
+ 'application/vnd.sun.xml.draw' => 'sxd',
+ 'application/vnd.sun.xml.draw.template' => 'std',
+ 'application/vnd.sun.xml.impress' => 'sxi',
+ 'application/vnd.sun.xml.impress.template' => 'sti',
+ 'application/vnd.sun.xml.math' => 'sxm',
+ 'application/vnd.sun.xml.writer' => 'sxw',
+ 'application/vnd.sun.xml.writer.global' => 'sxg',
+ 'application/vnd.sun.xml.writer.template' => 'stw',
+ 'application/vnd.sus-calendar' => array('sus', 'susp'),
+ 'application/vnd.svd' => 'svd',
+ 'application/vnd.symbian.install' => array('sis', 'sisx'),
+ 'application/vnd.syncml+xml' => 'xsm',
+ 'application/vnd.syncml.dm+wbxml' => 'bdm',
+ 'application/vnd.syncml.dm+xml' => 'xdm',
+ 'application/vnd.tao.intent-module-archive' => 'tao',
+ 'application/vnd.tcpdump.pcap' => array('pcap', 'cap', 'dmp'),
+ 'application/vnd.tmobile-livetv' => 'tmo',
+ 'application/vnd.trid.tpt' => 'tpt',
+ 'application/vnd.triscape.mxs' => 'mxs',
+ 'application/vnd.trueapp' => 'tra',
+ 'application/vnd.ufdl' => array('ufd', 'ufdl'),
+ 'application/vnd.uiq.theme' => 'utz',
+ 'application/vnd.umajin' => 'umj',
+ 'application/vnd.unity' => 'unityweb',
+ 'application/vnd.uoml+xml' => 'uoml',
+ 'application/vnd.vcx' => 'vcx',
+ 'application/vnd.visio' => array('vsd', 'vst', 'vss', 'vsw'),
+ 'application/vnd.visionary' => 'vis',
+ 'application/vnd.vsf' => 'vsf',
+ 'application/vnd.wap.wbxml' => 'wbxml',
+ 'application/vnd.wap.wmlc' => 'wmlc',
+ 'application/vnd.wap.wmlscriptc' => 'wmlsc',
+ 'application/vnd.webturbo' => 'wtb',
+ 'application/vnd.wolfram.player' => 'nbp',
+ 'application/vnd.wordperfect' => 'wpd',
+ 'application/vnd.wqd' => 'wqd',
+ 'application/vnd.wt.stf' => 'stf',
+ 'application/vnd.xara' => 'xar',
+ 'application/vnd.xfdl' => 'xfdl',
+ 'application/voicexml+xml' => 'vxml',
+ 'application/widget' => 'wgt',
+ 'application/winhlp' => 'hlp',
+ 'application/wsdl+xml' => 'wsdl',
+ 'application/wspolicy+xml' => 'wspolicy',
+ 'application/x-7z-compressed' => '7z',
+ 'application/x-bittorrent' => 'torrent',
+ 'application/x-blorb' => array('blb', 'blorb'),
+ 'application/x-bzip' => 'bz',
+ 'application/x-cdlink' => 'vcd',
+ 'application/x-cfs-compressed' => 'cfs',
+ 'application/x-chat' => 'chat',
+ 'application/x-chess-pgn' => 'pgn',
+ 'application/x-conference' => 'nsc',
+ 'application/x-cpio' => 'cpio',
+ 'application/x-csh' => 'csh',
+ 'application/x-debian-package' => array('deb', 'udeb'),
+ 'application/x-dgc-compressed' => 'dgc',
+ 'application/x-director' => array(
+ 'dir',
+ 'dcr',
+ 'dxr',
+ 'cst',
+ 'cct',
+ 'cxt',
+ 'w3d',
+ 'fgd',
+ 'swa'
+ ),
+ 'application/x-font-ttf' => array('ttf', 'ttc'),
+ 'application/x-font-type1' => array('pfa', 'pfb', 'pfm', 'afm'),
+ 'application/x-font-woff' => 'woff',
+ 'application/x-freearc' => 'arc',
+ 'application/x-futuresplash' => 'spl',
+ 'application/x-gca-compressed' => 'gca',
+ 'application/x-glulx' => 'ulx',
+ 'application/x-gnumeric' => 'gnumeric',
+ 'application/x-gramps-xml' => 'gramps',
+ 'application/x-gtar' => 'gtar',
+ 'application/x-hdf' => 'hdf',
+ 'application/x-install-instructions' => 'install',
+ 'application/x-iso9660-image' => 'iso',
+ 'application/x-java-jnlp-file' => 'jnlp',
+ 'application/x-latex' => 'latex',
+ 'application/x-lzh-compressed' => array('lzh', 'lha'),
+ 'application/x-mie' => 'mie',
+ 'application/x-mobipocket-ebook' => array('prc', 'mobi'),
+ 'application/x-ms-application' => 'application',
+ 'application/x-ms-shortcut' => 'lnk',
+ 'application/x-ms-wmd' => 'wmd',
+ 'application/x-ms-wmz' => 'wmz',
+ 'application/x-ms-xbap' => 'xbap',
+ 'application/x-msaccess' => 'mdb',
+ 'application/x-msbinder' => 'obd',
+ 'application/x-mscardfile' => 'crd',
+ 'application/x-msclip' => 'clp',
+ 'application/x-msdownload' => array('exe', 'dll', 'com', 'bat', 'msi'),
+ 'application/x-msmediaview' => array(
+ 'mvb',
+ 'm13',
+ 'm14'
+ ),
+ 'application/x-msmetafile' => array('wmf', 'wmz', 'emf', 'emz'),
+ 'application/x-rar-compressed' => 'rar',
+ 'application/x-research-info-systems' => 'ris',
+ 'application/x-sh' => 'sh',
+ 'application/x-shar' => 'shar',
+ 'application/x-shockwave-flash' => 'swf',
+ 'application/x-silverlight-app' => 'xap',
+ 'application/x-sql' => 'sql',
+ 'application/x-stuffit' => 'sit',
+ 'application/x-stuffitx' => 'sitx',
+ 'application/x-subrip' => 'srt',
+ 'application/x-sv4cpio' => 'sv4cpio',
+ 'application/x-sv4crc' => 'sv4crc',
+ 'application/x-t3vm-image' => 't3',
+ 'application/x-tads' => 'gam',
+ 'application/x-tar' => 'tar',
+ 'application/x-tcl' => 'tcl',
+ 'application/x-tex' => 'tex',
+ 'application/x-tex-tfm' => 'tfm',
+ 'application/x-texinfo' => array('texinfo', 'texi'),
+ 'application/x-tgif' => 'obj',
+ 'application/x-ustar' => 'ustar',
+ 'application/x-wais-source' => 'src',
+ 'application/x-x509-ca-cert' => array('der', 'crt'),
+ 'application/x-xfig' => 'fig',
+ 'application/x-xliff+xml' => 'xlf',
+ 'application/x-xpinstall' => 'xpi',
+ 'application/x-xz' => 'xz',
+ 'application/x-zmachine' => 'z1',
+ 'application/xaml+xml' => 'xaml',
+ 'application/xcap-diff+xml' => 'xdf',
+ 'application/xenc+xml' => 'xenc',
+ 'application/xhtml+xml' => array('xhtml', 'xht'),
+ 'application/xml' => array('xml', 'xsl'),
+ 'application/xml-dtd' => 'dtd',
+ 'application/xop+xml' => 'xop',
+ 'application/xproc+xml' => 'xpl',
+ 'application/xslt+xml' => 'xslt',
+ 'application/xspf+xml' => 'xspf',
+ 'application/xv+xml' => array('mxml', 'xhvml', 'xvml', 'xvm'),
+ 'application/yang' => 'yang',
+ 'application/yin+xml' => 'yin',
+ 'application/zip' => 'zip',
+ 'audio/adpcm' => 'adp',
+ 'audio/basic' => array('au', 'snd'),
+ 'audio/midi' => array('mid', 'midi', 'kar', 'rmi'),
+ 'audio/mp4' => 'mp4a',
+ 'audio/mpeg' => array(
+ 'mpga',
+ 'mp2',
+ 'mp2a',
+ 'mp3',
+ 'm2a',
+ 'm3a'
+ ),
+ 'audio/ogg' => array('oga', 'ogg', 'spx'),
+ 'audio/vnd.dece.audio' => array('uva', 'uvva'),
+ 'audio/vnd.rip' => 'rip',
+ 'audio/webm' => 'weba',
+ 'audio/x-aac' => 'aac',
+ 'audio/x-aiff' => array('aif', 'aiff', 'aifc'),
+ 'audio/x-caf' => 'caf',
+ 'audio/x-flac' => 'flac',
+ 'audio/x-matroska' => 'mka',
+ 'audio/x-mpegurl' => 'm3u',
+ 'audio/x-ms-wax' => 'wax',
+ 'audio/x-ms-wma' => 'wma',
+ 'audio/x-pn-realaudio' => array('ram', 'ra'),
+ 'audio/x-pn-realaudio-plugin' => 'rmp',
+ 'audio/x-wav' => 'wav',
+ 'audio/xm' => 'xm',
+ 'image/bmp' => 'bmp',
+ 'image/cgm' => 'cgm',
+ 'image/g3fax' => 'g3',
+ 'image/gif' => 'gif',
+ 'image/ief' => 'ief',
+ 'image/jpeg' => array('jpeg', 'jpg', 'jpe'),
+ 'image/ktx' => 'ktx',
+ 'image/png' => 'png',
+ 'image/prs.btif' => 'btif',
+ 'image/sgi' => 'sgi',
+ 'image/svg+xml' => array('svg', 'svgz'),
+ 'image/tiff' => array('tiff', 'tif'),
+ 'image/vnd.adobe.photoshop' => 'psd',
+ 'image/vnd.dece.graphic' => array('uvi', 'uvvi', 'uvg', 'uvvg'),
+ 'image/vnd.dvb.subtitle' => 'sub',
+ 'image/vnd.djvu' => array('djvu', 'djv'),
+ 'image/vnd.dwg' => 'dwg',
+ 'image/vnd.dxf' => 'dxf',
+ 'image/vnd.fastbidsheet' => 'fbs',
+ 'image/vnd.fpx' => 'fpx',
+ 'image/vnd.fst' => 'fst',
+ 'image/vnd.fujixerox.edmics-mmr' => 'mmr',
+ 'image/vnd.fujixerox.edmics-rlc' => 'rlc',
+ 'image/vnd.ms-modi' => 'mdi',
+ 'image/vnd.ms-photo' => 'wdp',
+ 'image/vnd.net-fpx' => 'npx',
+ 'image/vnd.wap.wbmp' => 'wbmp',
+ 'image/vnd.xiff' => 'xif',
+ 'image/webp' => 'webp',
+ 'image/x-3ds' => '3ds',
+ 'image/x-cmu-raster' => 'ras',
+ 'image/x-cmx' => 'cmx',
+ 'image/x-freehand' => array('fh', 'fhc', 'fh4', 'fh5', 'fh7'),
+ 'image/x-icon' => 'ico',
+ 'image/x-mrsid-image' => 'sid',
+ 'image/x-pcx' => 'pcx',
+ 'image/x-pict' => array('pic', 'pct'),
+ 'image/x-portable-anymap' => 'pnm',
+ 'image/x-portable-bitmap' => 'pbm',
+ 'image/x-portable-graymap' => 'pgm',
+ 'image/x-portable-pixmap' => 'ppm',
+ 'image/x-rgb' => 'rgb',
+ 'image/x-tga' => 'tga',
+ 'image/x-xbitmap' => 'xbm',
+ 'image/x-xpixmap' => 'xpm',
+ 'image/x-xwindowdump' => 'xwd',
+ 'message/rfc822' => array('eml', 'mime'),
+ 'model/iges' => array('igs', 'iges'),
+ 'model/mesh' => array('msh', 'mesh', 'silo'),
+ 'model/vnd.collada+xml' => 'dae',
+ 'model/vnd.dwf' => 'dwf',
+ 'model/vnd.gdl' => 'gdl',
+ 'model/vnd.gtw' => 'gtw',
+ 'model/vnd.mts' => 'mts',
+ 'model/vnd.vtu' => 'vtu',
+ 'model/vrml' => array('wrl', 'vrml'),
+ 'model/x3d+binary' => 'x3db',
+ 'model/x3d+vrml' => 'x3dv',
+ 'model/x3d+xml' => 'x3d',
+ 'text/cache-manifest' => 'appcache',
+ 'text/calendar' => array('ics', 'ifb'),
+ 'text/css' => 'css',
+ 'text/csv' => 'csv',
+ 'text/html' => array('html', 'htm'),
+ 'text/n3' => 'n3',
+ 'text/plain' => array(
+ 'txt',
+ 'text',
+ 'conf',
+ 'def',
+ 'list',
+ 'log',
+ 'in'
+ ),
+ 'text/prs.lines.tag' => 'dsc',
+ 'text/richtext' => 'rtx',
+ 'text/sgml' => array('sgml', 'sgm'),
+ 'text/tab-separated-values' => 'tsv',
+ 'text/troff' => array(
+ 't',
+ 'tr',
+ 'roff',
+ 'man',
+ 'me',
+ 'ms'
+ ),
+ 'text/turtle' => 'ttl',
+ 'text/uri-list' => array('uri', 'uris', 'urls'),
+ 'text/vcard' => 'vcard',
+ 'text/vnd.curl' => 'curl',
+ 'text/vnd.curl.dcurl' => 'dcurl',
+ 'text/vnd.curl.scurl' => 'scurl',
+ 'text/vnd.curl.mcurl' => 'mcurl',
+ 'text/vnd.dvb.subtitle' => 'sub',
+ 'text/vnd.fly' => 'fly',
+ 'text/vnd.fmi.flexstor' => 'flx',
+ 'text/vnd.graphviz' => 'gv',
+ 'text/vnd.in3d.3dml' => '3dml',
+ 'text/vnd.in3d.spot' => 'spot',
+ 'text/vnd.sun.j2me.app-descriptor' => 'jad',
+ 'text/vnd.wap.wml' => 'wml',
+ 'text/vnd.wap.wmlscript' => 'wmls',
+ 'text/x-asm' => array('s', 'asm'),
+ 'text/x-fortran' => array('f', 'for', 'f77', 'f90'),
+ 'text/x-java-source' => 'java',
+ 'text/x-opml' => 'opml',
+ 'text/x-pascal' => array('p', 'pas'),
+ 'text/x-nfo' => 'nfo',
+ 'text/x-setext' => 'etx',
+ 'text/x-sfv' => 'sfv',
+ 'text/x-uuencode' => 'uu',
+ 'text/x-vcalendar' => 'vcs',
+ 'text/x-vcard' => 'vcf',
+ 'video/3gpp' => '3gp',
+ 'video/3gpp2' => '3g2',
+ 'video/h261' => 'h261',
+ 'video/h263' => 'h263',
+ 'video/h264' => 'h264',
+ 'video/jpeg' => 'jpgv',
+ 'video/jpm' => array('jpm', 'jpgm'),
+ 'video/mj2' => 'mj2',
+ 'video/mp4' => 'mp4',
+ 'video/mpeg' => array('mpeg', 'mpg', 'mpe', 'm1v', 'm2v'),
+ 'video/ogg' => 'ogv',
+ 'video/quicktime' => array('qt', 'mov'),
+ 'video/vnd.dece.hd' => array('uvh', 'uvvh'),
+ 'video/vnd.dece.mobile' => array('uvm', 'uvvm'),
+ 'video/vnd.dece.pd' => array('uvp', 'uvvp'),
+ 'video/vnd.dece.sd' => array('uvs', 'uvvs'),
+ 'video/vnd.dece.video' => array('uvv', 'uvvv'),
+ 'video/vnd.dvb.file' => 'dvb',
+ 'video/vnd.fvt' => 'fvt',
+ 'video/vnd.mpegurl' => array('mxu', 'm4u'),
+ 'video/vnd.ms-playready.media.pyv' => 'pyv',
+ 'video/vnd.uvvu.mp4' => array('uvu', 'uvvu'),
+ 'video/vnd.vivo' => 'viv',
+ 'video/webm' => 'webm',
+ 'video/x-f4v' => 'f4v',
+ 'video/x-fli' => 'fli',
+ 'video/x-flv' => 'flv',
+ 'video/x-m4v' => 'm4v',
+ 'video/x-matroska' => array('mkv', 'mk3d', 'mks'),
+ 'video/x-mng' => 'mng',
+ 'video/x-ms-asf' => array('asf', 'asx'),
+ 'video/x-ms-vob' => 'vob',
+ 'video/x-ms-wm' => 'wm',
+ 'video/x-ms-wmv' => 'wmv',
+ 'video/x-ms-wmx' => 'wmx',
+ 'video/x-ms-wvx' => 'wvx',
+ 'video/x-msvideo' => 'avi',
+ 'video/x-sgi-movie' => 'movie',
+ );
+
+ /**
+ * Get a random MIME type
+ *
+ * @return string
+ * @example 'video/avi'
+ */
+ public static function mimeType()
+ {
+ return static::randomElement(array_keys(static::$mimeTypes));
+ }
+
+ /**
+ * Get a random file extension (without a dot)
+ *
+ * @example avi
+ * @return string
+ */
+ public static function fileExtension()
+ {
+ $random_extension = static::randomElement(array_values(static::$mimeTypes));
+
+ return is_array($random_extension) ? static::randomElement($random_extension) : $random_extension;
+ }
+
+ /**
+ * Copy a random file from the source directory to the target directory and returns the filename/fullpath
+ *
+ * @param string $sourceDirectory The directory to look for random file taking
+ * @param string $targetDirectory
+ * @param boolean $fullPath Whether to have the full path or just the filename
+ * @return string
+ */
+ public static function file($sourceDirectory = '/tmp', $targetDirectory = '/tmp', $fullPath = true)
+ {
+ if (!is_dir($sourceDirectory)) {
+ throw new \InvalidArgumentException(sprintf('Source directory %s does not exist or is not a directory.', $sourceDirectory));
+ }
+
+ if (!is_dir($targetDirectory)) {
+ throw new \InvalidArgumentException(sprintf('Target directory %s does not exist or is not a directory.', $targetDirectory));
+ }
+
+ if ($sourceDirectory == $targetDirectory) {
+ throw new \InvalidArgumentException('Source and target directories must differ.');
+ }
+
+ // Drop . and .. and reset array keys
+ $files = array_filter(array_values(array_diff(scandir($sourceDirectory), array('.', '..'))), function ($file) use ($sourceDirectory) {
+ return is_file($sourceDirectory . DIRECTORY_SEPARATOR . $file) && is_readable($sourceDirectory . DIRECTORY_SEPARATOR . $file);
+ });
+
+ if (empty($files)) {
+ throw new \InvalidArgumentException(sprintf('Source directory %s is empty.', $sourceDirectory));
+ }
+
+ $sourceFullPath = $sourceDirectory . DIRECTORY_SEPARATOR . static::randomElement($files);
+
+ $destinationFile = Uuid::uuid() . '.' . pathinfo($sourceFullPath, PATHINFO_EXTENSION);
+ $destinationFullPath = $targetDirectory . DIRECTORY_SEPARATOR . $destinationFile;
+
+ if (false === copy($sourceFullPath, $destinationFullPath)) {
+ return false;
+ }
+
+ return $fullPath ? $destinationFullPath : $destinationFile;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/HtmlLorem.php b/vendor/fzaninotto/faker/src/Faker/Provider/HtmlLorem.php
new file mode 100644
index 000000000..6219bc899
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/HtmlLorem.php
@@ -0,0 +1,276 @@
+addProvider(new Lorem($generator));
+ $generator->addProvider(new Internet($generator));
+ }
+
+ /**
+ * @param integer $maxDepth
+ * @param integer $maxWidth
+ *
+ * @return string
+ */
+ public function randomHtml($maxDepth = 4, $maxWidth = 4)
+ {
+ $document = new \DOMDocument();
+ $this->idGenerator = new UniqueGenerator($this->generator);
+
+ $head = $document->createElement("head");
+ $this->addRandomTitle($head);
+
+ $body = $document->createElement("body");
+ $this->addLoginForm($body);
+ $this->addRandomSubTree($body, $maxDepth, $maxWidth);
+
+ $html = $document->createElement("html");
+ $html->appendChild($head);
+ $html->appendChild($body);
+
+ $document->appendChild($html);
+ return $document->saveHTML();
+ }
+
+ private function addRandomSubTree(\DOMElement $root, $maxDepth, $maxWidth)
+ {
+ $maxDepth--;
+ if ($maxDepth <= 0) {
+ return $root;
+ }
+
+ $siblings = mt_rand(1, $maxWidth);
+ for ($i = 0; $i < $siblings; $i++) {
+ if ($maxDepth == 1) {
+ $this->addRandomLeaf($root);
+ } else {
+ $sibling = $root->ownerDocument->createElement("div");
+ $root->appendChild($sibling);
+ $this->addRandomAttribute($sibling);
+ $this->addRandomSubTree($sibling, mt_rand(0, $maxDepth), $maxWidth);
+ }
+ }
+ return $root;
+ }
+
+ private function addRandomLeaf(\DOMElement $node)
+ {
+ $rand = mt_rand(1, 10);
+ switch ($rand) {
+ case 1:
+ $this->addRandomP($node);
+ break;
+ case 2:
+ $this->addRandomA($node);
+ break;
+ case 3:
+ $this->addRandomSpan($node);
+ break;
+ case 4:
+ $this->addRandomUL($node);
+ break;
+ case 5:
+ $this->addRandomH($node);
+ break;
+ case 6:
+ $this->addRandomB($node);
+ break;
+ case 7:
+ $this->addRandomI($node);
+ break;
+ case 8:
+ $this->addRandomTable($node);
+ break;
+ default:
+ $this->addRandomText($node);
+ break;
+ }
+ }
+
+ private function addRandomAttribute(\DOMElement $node)
+ {
+ $rand = mt_rand(1, 2);
+ switch ($rand) {
+ case 1:
+ $node->setAttribute("class", $this->generator->word);
+ break;
+ case 2:
+ $node->setAttribute("id", (string)$this->idGenerator->randomNumber(5));
+ break;
+ }
+ }
+
+ private function addRandomP(\DOMElement $element, $maxLength = 10)
+ {
+
+ $node = $element->ownerDocument->createElement(static::P_TAG);
+ $node->textContent = $this->generator->sentence(mt_rand(1, $maxLength));
+ $element->appendChild($node);
+ }
+
+ private function addRandomText(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(mt_rand(1, $maxLength)));
+ $element->appendChild($text);
+ }
+
+ private function addRandomA(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(mt_rand(1, $maxLength)));
+ $node = $element->ownerDocument->createElement(static::A_TAG);
+ $node->setAttribute("href", $this->generator->safeEmailDomain);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addRandomTitle(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(mt_rand(1, $maxLength)));
+ $node = $element->ownerDocument->createElement(static::TITLE_TAG);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addRandomH(\DOMElement $element, $maxLength = 10)
+ {
+ $h = static::H_TAG . (string)mt_rand(1, 3);
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(mt_rand(1, $maxLength)));
+ $node = $element->ownerDocument->createElement($h);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addRandomB(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(mt_rand(1, $maxLength)));
+ $node = $element->ownerDocument->createElement(static::B_TAG);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addRandomI(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(mt_rand(1, $maxLength)));
+ $node = $element->ownerDocument->createElement(static::I_TAG);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addRandomSpan(\DOMElement $element, $maxLength = 10)
+ {
+ $text = $element->ownerDocument->createTextNode($this->generator->sentence(mt_rand(1, $maxLength)));
+ $node = $element->ownerDocument->createElement(static::SPAN_TAG);
+ $node->appendChild($text);
+ $element->appendChild($node);
+ }
+
+ private function addLoginForm(\DOMElement $element)
+ {
+
+ $textInput = $element->ownerDocument->createElement(static::INPUT_TAG);
+ $textInput->setAttribute("type", "text");
+ $textInput->setAttribute("id", "username");
+
+ $textLabel = $element->ownerDocument->createElement(static::LABEL_TAG);
+ $textLabel->setAttribute("for", "username");
+ $textLabel->textContent = $this->generator->word;
+
+ $passwordInput = $element->ownerDocument->createElement(static::INPUT_TAG);
+ $passwordInput->setAttribute("type", "password");
+ $passwordInput->setAttribute("id", "password");
+
+ $passwordLabel = $element->ownerDocument->createElement(static::LABEL_TAG);
+ $passwordLabel->setAttribute("for", "password");
+ $passwordLabel->textContent = $this->generator->word;
+
+ $submit = $element->ownerDocument->createElement(static::INPUT_TAG);
+ $submit->setAttribute("type", "submit");
+ $submit->setAttribute("value", $this->generator->word);
+
+ $submit = $element->ownerDocument->createElement(static::FORM_TAG);
+ $submit->setAttribute("action", $this->generator->safeEmailDomain);
+ $submit->setAttribute("method", "POST");
+ $submit->appendChild($textLabel);
+ $submit->appendChild($textInput);
+ $submit->appendChild($passwordLabel);
+ $submit->appendChild($passwordInput);
+ $element->appendChild($submit);
+ }
+
+ private function addRandomTable(\DOMElement $element, $maxRows = 10, $maxCols = 6, $maxTitle = 4, $maxLength = 10)
+ {
+ $rows = mt_rand(1, $maxRows);
+ $cols = mt_rand(1, $maxCols);
+
+ $table = $element->ownerDocument->createElement(static::TABLE_TAG);
+ $thead = $element->ownerDocument->createElement(static::THEAD_TAG);
+ $tbody = $element->ownerDocument->createElement(static::TBODY_TAG);
+
+ $table->appendChild($thead);
+ $table->appendChild($tbody);
+
+ $tr = $element->ownerDocument->createElement(static::TR_TAG);
+ $thead->appendChild($tr);
+ for ($i = 0; $i < $cols; $i++) {
+ $th = $element->ownerDocument->createElement(static::TH_TAG);
+ $th->textContent = $this->generator->sentence(mt_rand(1, $maxTitle));
+ $tr->appendChild($th);
+ }
+ for ($i = 0; $i < $rows; $i++) {
+ $tr = $element->ownerDocument->createElement(static::TR_TAG);
+ $tbody->appendChild($tr);
+ for ($j = 0; $j < $cols; $j++) {
+ $th = $element->ownerDocument->createElement(static::TD_TAG);
+ $th->textContent = $this->generator->sentence(mt_rand(1, $maxLength));
+ $tr->appendChild($th);
+ }
+ }
+ $element->appendChild($table);
+ }
+
+ private function addRandomUL(\DOMElement $element, $maxItems = 11, $maxLength = 4)
+ {
+ $num = mt_rand(1, $maxItems);
+ $ul = $element->ownerDocument->createElement(static::UL_TAG);
+ for ($i = 0; $i < $num; $i++) {
+ $li = $element->ownerDocument->createElement(static::LI_TAG);
+ $li->textContent = $this->generator->sentence(mt_rand(1, $maxLength));
+ $ul->appendChild($li);
+ }
+ $element->appendChild($ul);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/Image.php b/vendor/fzaninotto/faker/src/Faker/Provider/Image.php
new file mode 100644
index 000000000..14f1b3970
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/Image.php
@@ -0,0 +1,105 @@
+generator->parse($format);
+ }
+
+ /**
+ * @example 'jdoe@example.com'
+ */
+ final public function safeEmail()
+ {
+ return preg_replace('/\s/u', '', $this->userName() . '@' . static::safeEmailDomain());
+ }
+
+ /**
+ * @example 'jdoe@gmail.com'
+ */
+ public function freeEmail()
+ {
+ return preg_replace('/\s/u', '', $this->userName() . '@' . static::freeEmailDomain());
+ }
+
+ /**
+ * @example 'jdoe@dawson.com'
+ */
+ public function companyEmail()
+ {
+ return preg_replace('/\s/u', '', $this->userName() . '@' . $this->domainName());
+ }
+
+ /**
+ * @example 'gmail.com'
+ */
+ public static function freeEmailDomain()
+ {
+ return static::randomElement(static::$freeEmailDomain);
+ }
+
+ /**
+ * @example 'example.org'
+ */
+ final public static function safeEmailDomain()
+ {
+ $domains = array(
+ 'example.com',
+ 'example.org',
+ 'example.net'
+ );
+
+ return static::randomElement($domains);
+ }
+ /**
+ * @example 'jdoe'
+ */
+ public function userName()
+ {
+ $format = static::randomElement(static::$userNameFormats);
+ $username = static::bothify($this->generator->parse($format));
+
+ $username = strtolower(static::transliterate($username));
+
+ // check if transliterate() didn't support the language and removed all letters
+ if (trim($username, '._') === '') {
+ throw new \Exception('userName failed with the selected locale. Try a different locale or activate the "intl" PHP extension.');
+ }
+
+ // clean possible trailing dots from first/last names
+ $username = str_replace('..', '.', $username);
+ $username = rtrim($username, '.');
+
+ return $username;
+ }
+ /**
+ * @example 'fY4èHdZv68'
+ */
+ public function password($minLength = 6, $maxLength = 20)
+ {
+ $pattern = str_repeat('*', $this->numberBetween($minLength, $maxLength));
+
+ return $this->asciify($pattern);
+ }
+
+ /**
+ * @example 'tiramisu.com'
+ */
+ public function domainName()
+ {
+ return $this->domainWord() . '.' . $this->tld();
+ }
+
+ /**
+ * @example 'faber'
+ */
+ public function domainWord()
+ {
+ $lastName = $this->generator->format('lastName');
+
+ $lastName = strtolower(static::transliterate($lastName));
+
+ // check if transliterate() didn't support the language and removed all letters
+ if (trim($lastName, '._') === '') {
+ throw new \Exception('domainWord failed with the selected locale. Try a different locale or activate the "intl" PHP extension.');
+ }
+
+ // clean possible trailing dot from last name
+ $lastName = rtrim($lastName, '.');
+
+ return $lastName;
+ }
+
+ /**
+ * @example 'com'
+ */
+ public function tld()
+ {
+ return static::randomElement(static::$tld);
+ }
+
+ /**
+ * @example 'http://www.runolfsdottir.com/'
+ */
+ public function url()
+ {
+ $format = static::randomElement(static::$urlFormats);
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * @example 'aut-repellat-commodi-vel-itaque-nihil-id-saepe-nostrum'
+ */
+ public function slug($nbWords = 6, $variableNbWords = true)
+ {
+ if ($nbWords <= 0) {
+ return '';
+ }
+ if ($variableNbWords) {
+ $nbWords = (int) ($nbWords * mt_rand(60, 140) / 100) + 1;
+ }
+ $words = $this->generator->words($nbWords);
+
+ return join('-', $words);
+ }
+
+ /**
+ * @example '237.149.115.38'
+ */
+ public function ipv4()
+ {
+ return long2ip(mt_rand(0, 1) == 0 ? mt_rand(-2147483648, -2) : mt_rand(16777216, 2147483647));
+ }
+
+ /**
+ * @example '35cd:186d:3e23:2986:ef9f:5b41:42a4:e6f1'
+ */
+ public function ipv6()
+ {
+ $res = array();
+ for ($i=0; $i < 8; $i++) {
+ $res []= dechex(mt_rand(0, "65535"));
+ }
+
+ return join(':', $res);
+ }
+
+ /**
+ * @example '10.1.1.17'
+ */
+ public static function localIpv4()
+ {
+ if (static::numberBetween(0, 1) === 0) {
+ // 10.x.x.x range
+ return long2ip(static::numberBetween(ip2long("10.0.0.0"), ip2long("10.255.255.255")));
+ }
+
+ // 192.168.x.x range
+ return long2ip(static::numberBetween(ip2long("192.168.0.0"), ip2long("192.168.255.255")));
+ }
+
+ /**
+ * @example '32:F1:39:2F:D6:18'
+ */
+ public static function macAddress()
+ {
+ for ($i=0; $i<6; $i++) {
+ $mac[] = sprintf('%02X', static::numberBetween(0, 0xff));
+ }
+ $mac = implode(':', $mac);
+
+ return $mac;
+ }
+
+ protected static function transliterate($string)
+ {
+ if (0 === preg_match('/[^A-Za-z0-9_.]/', $string)) {
+ return $string;
+ }
+
+ $transId = 'Any-Latin; Latin-ASCII; NFD; [:Nonspacing Mark:] Remove; NFC;';
+ if (class_exists('Transliterator', false) && $transliterator = \Transliterator::create($transId)) {
+ $transString = $transliterator->transliterate($string);
+ } else {
+ $transString = static::toAscii($string);
+ }
+
+ return preg_replace('/[^A-Za-z0-9_.]/u', '', $transString);
+ }
+
+ protected static function toAscii($string)
+ {
+ static $arrayFrom, $arrayTo;
+
+ if (empty($arrayFrom)) {
+ $transliterationTable = array(
+ 'IJ'=>'I', 'Ö'=>'O', 'Œ'=>'O', 'Ü'=>'U', 'ä'=>'a', 'æ'=>'a',
+ 'ij'=>'i', 'ö'=>'o', 'œ'=>'o', 'ü'=>'u', 'ß'=>'s', 'ſ'=>'s',
+ 'À'=>'A', 'Ã'=>'A', 'Â'=>'A', 'Ã'=>'A', 'Ä'=>'A', 'Ã…'=>'A',
+ 'Æ'=>'A', 'Ā'=>'A', 'Ą'=>'A', 'Ă'=>'A', 'Ç'=>'C', 'Ć'=>'C',
+ 'ÄŒ'=>'C', 'Ĉ'=>'C', 'ÄŠ'=>'C', 'ÄŽ'=>'D', 'Ä'=>'D', 'È'=>'E',
+ 'É'=>'E', 'Ê'=>'E', 'Ë'=>'E', 'Ē'=>'E', 'Ę'=>'E', 'Ě'=>'E',
+ 'Ä”'=>'E', 'Ä–'=>'E', 'Äœ'=>'G', 'Äž'=>'G', 'Ä '=>'G', 'Ä¢'=>'G',
+ 'Ĥ'=>'H', 'Ħ'=>'H', 'ÃŒ'=>'I', 'Ã'=>'I', 'ÃŽ'=>'I', 'Ã'=>'I',
+ 'Ī'=>'I', 'Ĩ'=>'I', 'Ĭ'=>'I', 'Į'=>'I', 'İ'=>'I', 'Ĵ'=>'J',
+ 'Ķ'=>'K', 'Ľ'=>'K', 'Ĺ'=>'K', 'Ä»'=>'K', 'Ä¿'=>'K', 'Å'=>'L',
+ 'Ñ'=>'N', 'Ń'=>'N', 'Ň'=>'N', 'Ņ'=>'N', 'Ŋ'=>'N', 'Ò'=>'O',
+ 'Ó'=>'O', 'Ô'=>'O', 'Õ'=>'O', 'Ø'=>'O', 'ÅŒ'=>'O', 'Å'=>'O',
+ 'Ŏ'=>'O', 'Ŕ'=>'R', 'Ř'=>'R', 'Ŗ'=>'R', 'Ś'=>'S', 'Ş'=>'S',
+ 'Ŝ'=>'S', 'Ș'=>'S', 'Š'=>'S', 'Ť'=>'T', 'Ţ'=>'T', 'Ŧ'=>'T',
+ 'Ț'=>'T', 'Ù'=>'U', 'Ú'=>'U', 'Û'=>'U', 'Ū'=>'U', 'Ů'=>'U',
+ 'Ű'=>'U', 'Ŭ'=>'U', 'Ũ'=>'U', 'Ų'=>'U', 'Ŵ'=>'W', 'Ŷ'=>'Y',
+ 'Ÿ'=>'Y', 'Ã'=>'Y', 'Ź'=>'Z', 'Å»'=>'Z', 'Ž'=>'Z', 'à '=>'a',
+ 'á'=>'a', 'â'=>'a', 'ã'=>'a', 'Ä'=>'a', 'Ä…'=>'a', 'ă'=>'a',
+ 'Ã¥'=>'a', 'ç'=>'c', 'ć'=>'c', 'Ä'=>'c', 'ĉ'=>'c', 'Ä‹'=>'c',
+ 'Ä'=>'d', 'Ä‘'=>'d', 'è'=>'e', 'é'=>'e', 'ê'=>'e', 'ë'=>'e',
+ 'Ä“'=>'e', 'Ä™'=>'e', 'Ä›'=>'e', 'Ä•'=>'e', 'Ä—'=>'e', 'Æ’'=>'f',
+ 'Ä'=>'g', 'ÄŸ'=>'g', 'Ä¡'=>'g', 'Ä£'=>'g', 'Ä¥'=>'h', 'ħ'=>'h',
+ 'ì'=>'i', 'Ã'=>'i', 'î'=>'i', 'ï'=>'i', 'Ä«'=>'i', 'Ä©'=>'i',
+ 'Ä'=>'i', 'į'=>'i', 'ı'=>'i', 'ĵ'=>'j', 'Ä·'=>'k', 'ĸ'=>'k',
+ 'ł'=>'l', 'ľ'=>'l', 'ĺ'=>'l', 'ļ'=>'l', 'ŀ'=>'l', 'ñ'=>'n',
+ 'ń'=>'n', 'ň'=>'n', 'ņ'=>'n', 'ʼn'=>'n', 'ŋ'=>'n', 'ò'=>'o',
+ 'ó'=>'o', 'ô'=>'o', 'õ'=>'o', 'ø'=>'o', 'Å'=>'o', 'Å‘'=>'o',
+ 'Å'=>'o', 'Å•'=>'r', 'Å™'=>'r', 'Å—'=>'r', 'Å›'=>'s', 'Å¡'=>'s',
+ 'ť'=>'t', 'ù'=>'u', 'ú'=>'u', 'û'=>'u', 'ū'=>'u', 'ů'=>'u',
+ 'ű'=>'u', 'Å'=>'u', 'Å©'=>'u', 'ų'=>'u', 'ŵ'=>'w', 'ÿ'=>'y',
+ 'ý'=>'y', 'ŷ'=>'y', 'ż'=>'z', 'ź'=>'z', 'ž'=>'z', 'Α'=>'A',
+ 'Ά'=>'A', 'Ἀ'=>'A', 'Ἁ'=>'A', 'Ἂ'=>'A', 'Ἃ'=>'A', 'Ἄ'=>'A',
+ 'á¼'=>'A', 'Ἆ'=>'A', 'á¼'=>'A', 'ᾈ'=>'A', 'ᾉ'=>'A', 'ᾊ'=>'A',
+ 'ᾋ'=>'A', 'ᾌ'=>'A', 'á¾'=>'A', 'ᾎ'=>'A', 'á¾'=>'A', 'Ᾰ'=>'A',
+ 'Ᾱ'=>'A', 'Ὰ'=>'A', 'ᾼ'=>'A', 'Β'=>'B', 'Γ'=>'G', 'Δ'=>'D',
+ 'Ε'=>'E', 'Έ'=>'E', 'Ἐ'=>'E', 'Ἑ'=>'E', 'Ἒ'=>'E', 'Ἓ'=>'E',
+ 'Ἔ'=>'E', 'á¼'=>'E', 'Ὲ'=>'E', 'Ζ'=>'Z', 'Η'=>'I', 'Ή'=>'I',
+ 'Ἠ'=>'I', 'Ἡ'=>'I', 'Ἢ'=>'I', 'Ἣ'=>'I', 'Ἤ'=>'I', 'á¼'=>'I',
+ 'Ἦ'=>'I', 'Ἧ'=>'I', 'ᾘ'=>'I', 'ᾙ'=>'I', 'ᾚ'=>'I', 'ᾛ'=>'I',
+ 'ᾜ'=>'I', 'á¾'=>'I', 'ᾞ'=>'I', 'ᾟ'=>'I', 'Ὴ'=>'I', 'ῌ'=>'I',
+ 'Θ'=>'T', 'Ι'=>'I', 'Ί'=>'I', 'Ϊ'=>'I', 'Ἰ'=>'I', 'Ἱ'=>'I',
+ 'Ἲ'=>'I', 'Ἳ'=>'I', 'Ἴ'=>'I', 'Ἵ'=>'I', 'Ἶ'=>'I', 'Ἷ'=>'I',
+ 'Ῐ'=>'I', 'Ῑ'=>'I', 'Ὶ'=>'I', 'Κ'=>'K', 'Λ'=>'L', 'Μ'=>'M',
+ 'Î'=>'N', 'Ξ'=>'K', 'Ο'=>'O', 'ÎŒ'=>'O', 'Ὀ'=>'O', 'Ὁ'=>'O',
+ 'Ὂ'=>'O', 'Ὃ'=>'O', 'Ὄ'=>'O', 'á½'=>'O', 'Ὸ'=>'O', 'Î '=>'P',
+ 'Ρ'=>'R', 'Ῥ'=>'R', 'Σ'=>'S', 'Τ'=>'T', 'Υ'=>'Y', 'Ύ'=>'Y',
+ 'Ϋ'=>'Y', 'á½™'=>'Y', 'á½›'=>'Y', 'á½'=>'Y', 'Ὗ'=>'Y', 'Ῠ'=>'Y',
+ 'Ῡ'=>'Y', 'Ὺ'=>'Y', 'Φ'=>'F', 'Χ'=>'X', 'Ψ'=>'P', 'Ω'=>'O',
+ 'Î'=>'O', 'Ὠ'=>'O', 'Ὡ'=>'O', 'Ὢ'=>'O', 'Ὣ'=>'O', 'Ὤ'=>'O',
+ 'á½'=>'O', 'á½®'=>'O', 'Ὧ'=>'O', 'ᾨ'=>'O', 'ᾩ'=>'O', 'ᾪ'=>'O',
+ 'ᾫ'=>'O', 'ᾬ'=>'O', 'á¾'=>'O', 'á¾®'=>'O', 'ᾯ'=>'O', 'Ὼ'=>'O',
+ 'ῼ'=>'O', 'α'=>'a', 'ά'=>'a', 'á¼€'=>'a', 'á¼'=>'a', 'ἂ'=>'a',
+ 'ἃ'=>'a', 'ἄ'=>'a', 'ἅ'=>'a', 'ἆ'=>'a', 'ἇ'=>'a', 'ᾀ'=>'a',
+ 'á¾'=>'a', 'ᾂ'=>'a', 'ᾃ'=>'a', 'ᾄ'=>'a', 'á¾…'=>'a', 'ᾆ'=>'a',
+ 'ᾇ'=>'a', 'ὰ'=>'a', 'ᾰ'=>'a', 'ᾱ'=>'a', 'ᾲ'=>'a', 'ᾳ'=>'a',
+ 'ᾴ'=>'a', 'ᾶ'=>'a', 'ᾷ'=>'a', 'β'=>'b', 'γ'=>'g', 'δ'=>'d',
+ 'ε'=>'e', 'Î'=>'e', 'á¼'=>'e', 'ἑ'=>'e', 'á¼’'=>'e', 'ἓ'=>'e',
+ 'ἔ'=>'e', 'ἕ'=>'e', 'ὲ'=>'e', 'ζ'=>'z', 'η'=>'i', 'ή'=>'i',
+ 'ἠ'=>'i', 'ἡ'=>'i', 'ἢ'=>'i', 'ἣ'=>'i', 'ἤ'=>'i', 'ἥ'=>'i',
+ 'ἦ'=>'i', 'á¼§'=>'i', 'á¾'=>'i', 'ᾑ'=>'i', 'á¾’'=>'i', 'ᾓ'=>'i',
+ 'ᾔ'=>'i', 'ᾕ'=>'i', 'ᾖ'=>'i', 'ᾗ'=>'i', 'ὴ'=>'i', 'ῂ'=>'i',
+ 'ῃ'=>'i', 'ῄ'=>'i', 'ῆ'=>'i', 'ῇ'=>'i', 'θ'=>'t', 'ι'=>'i',
+ 'ί'=>'i', 'ÏŠ'=>'i', 'Î'=>'i', 'á¼°'=>'i', 'á¼±'=>'i', 'á¼²'=>'i',
+ 'á¼³'=>'i', 'á¼´'=>'i', 'á¼µ'=>'i', 'á¼¶'=>'i', 'á¼·'=>'i', 'á½¶'=>'i',
+ 'á¿'=>'i', 'á¿‘'=>'i', 'á¿’'=>'i', 'á¿–'=>'i', 'á¿—'=>'i', 'κ'=>'k',
+ 'λ'=>'l', 'μ'=>'m', 'ν'=>'n', 'ξ'=>'k', 'ο'=>'o', 'ό'=>'o',
+ 'á½€'=>'o', 'á½'=>'o', 'ὂ'=>'o', 'ὃ'=>'o', 'ὄ'=>'o', 'á½…'=>'o',
+ 'ὸ'=>'o', 'Ï€'=>'p', 'Ï'=>'r', 'ῤ'=>'r', 'á¿¥'=>'r', 'σ'=>'s',
+ 'Ï‚'=>'s', 'Ï„'=>'t', 'Ï…'=>'y', 'Ï'=>'y', 'Ï‹'=>'y', 'ΰ'=>'y',
+ 'á½'=>'y', 'ὑ'=>'y', 'á½’'=>'y', 'ὓ'=>'y', 'á½”'=>'y', 'ὕ'=>'y',
+ 'ὖ'=>'y', 'ὗ'=>'y', 'ὺ'=>'y', 'ῠ'=>'y', 'ῡ'=>'y', 'ῢ'=>'y',
+ 'ῦ'=>'y', 'ῧ'=>'y', 'φ'=>'f', 'χ'=>'x', 'ψ'=>'p', 'ω'=>'o',
+ 'ώ'=>'o', 'ὠ'=>'o', 'ὡ'=>'o', 'ὢ'=>'o', 'ὣ'=>'o', 'ὤ'=>'o',
+ 'ὥ'=>'o', 'ὦ'=>'o', 'ὧ'=>'o', 'ᾠ'=>'o', 'ᾡ'=>'o', 'ᾢ'=>'o',
+ 'ᾣ'=>'o', 'ᾤ'=>'o', 'ᾥ'=>'o', 'ᾦ'=>'o', 'ᾧ'=>'o', 'ὼ'=>'o',
+ 'ῲ'=>'o', 'ῳ'=>'o', 'á¿´'=>'o', 'á¿¶'=>'o', 'á¿·'=>'o', 'Ð'=>'A',
+ 'Б'=>'B', 'Ð’'=>'V', 'Г'=>'G', 'Д'=>'D', 'Е'=>'E', 'Ð'=>'E',
+ 'Ж'=>'Z', 'З'=>'Z', 'И'=>'I', 'Й'=>'I', 'К'=>'K', 'Л'=>'L',
+ 'М'=>'M', 'Ð'=>'N', 'О'=>'O', 'П'=>'P', 'Ð '=>'R', 'С'=>'S',
+ 'Т'=>'T', 'У'=>'U', 'Ф'=>'F', 'Х'=>'K', 'Ц'=>'T', 'Ч'=>'C',
+ 'Ш'=>'S', 'Щ'=>'S', 'Ы'=>'Y', 'Ð'=>'E', 'Ю'=>'Y', 'Я'=>'Y',
+ 'а'=>'A', 'б'=>'B', 'в'=>'V', 'г'=>'G', 'д'=>'D', 'е'=>'E',
+ 'ё'=>'E', 'ж'=>'Z', 'з'=>'Z', 'и'=>'I', 'й'=>'I', 'к'=>'K',
+ 'л'=>'L', 'м'=>'M', 'н'=>'N', 'о'=>'O', 'п'=>'P', 'р'=>'R',
+ 'Ñ'=>'S', 'Ñ‚'=>'T', 'у'=>'U', 'Ñ„'=>'F', 'Ñ…'=>'K', 'ц'=>'T',
+ 'ч'=>'C', 'ш'=>'S', 'щ'=>'S', 'Ñ‹'=>'Y', 'Ñ'=>'E', 'ÑŽ'=>'Y',
+ 'Ñ'=>'Y', 'ð'=>'d', 'Ã'=>'D', 'þ'=>'t', 'Þ'=>'T', 'áƒ'=>'a',
+ 'ბ'=>'b', 'გ'=>'g', 'დ'=>'d', 'ე'=>'e', 'ვ'=>'v', 'ზ'=>'z',
+ 'თ'=>'t', 'ი'=>'i', 'კ'=>'k', 'ლ'=>'l', 'მ'=>'m', 'ნ'=>'n',
+ 'áƒ'=>'o', 'პ'=>'p', 'ჟ'=>'z', 'რ'=>'r', 'ს'=>'s', 'ტ'=>'t',
+ 'უ'=>'u', 'ფ'=>'p', 'ქ'=>'k', 'ღ'=>'g', 'ყ'=>'q', 'შ'=>'s',
+ 'ჩ'=>'c', 'ც'=>'t', 'ძ'=>'d', 'წ'=>'t', 'áƒ'=>'c', 'ხ'=>'k',
+ 'ჯ'=>'j', 'ჰ'=>'h', 'ţ'=>'t', 'ʼ'=>"'", '̧'=>'', 'ḩ'=>'h',
+ '‘'=>"'", '’'=>"'", 'ừ'=>'u', '/'=>'', 'ế'=>'e', 'ả'=>'a',
+ 'ị'=>'i', 'áº'=>'a', 'ệ'=>'e', 'ỉ'=>'i', 'ồ'=>'o', 'á»'=>'e',
+ 'ơ'=>'o', 'ạ'=>'a', 'ẵ'=>'a', 'ư'=>'u', 'ằ'=>'a', 'ầ'=>'a',
+ 'ḑ'=>'d', 'Ḩ'=>'H', 'á¸'=>'D', 'È™'=>'s', 'È›'=>'t', 'á»™'=>'o',
+ 'ắ'=>'a', 'ş'=>'s', "'"=>'', 'ու'=>'u', 'ա'=>'a', 'բ'=>'b',
+ 'Õ£'=>'g', 'Õ¤'=>'d', 'Õ¥'=>'e', 'Õ¦'=>'z', 'Õ§'=>'e', 'Õ¨'=>'y',
+ 'Õ©'=>'t', 'Õª'=>'zh', 'Õ«'=>'i', 'Õ¬'=>'l', 'Õ'=>'kh', 'Õ®'=>'ts',
+ 'Õ¯'=>'k', 'Õ°'=>'h', 'Õ±'=>'dz', 'Õ²'=>'gh', 'Õ³'=>'ch', 'Õ´'=>'m',
+ 'Õµ'=>'y', 'Õ¶'=>'n', 'Õ·'=>'sh', 'Õ¸'=>'o', 'Õ¹'=>'ch', 'Õº'=>'p',
+ 'Õ»'=>'j', 'Õ¼'=>'r', 'Õ½'=>'s', 'Õ¾'=>'v', 'Õ¿'=>'t', 'Ö€'=>'r',
+ 'Ö'=>'ts', 'Öƒ'=>'p', 'Ö„'=>'q', 'Ö‡'=>'ev', 'Ö…'=>'o', 'Ö†'=>'f',
+ );
+ $arrayFrom = array_keys($transliterationTable);
+ $arrayTo = array_values($transliterationTable);
+ }
+
+ return str_replace($arrayFrom, $arrayTo, $string);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/Lorem.php b/vendor/fzaninotto/faker/src/Faker/Provider/Lorem.php
new file mode 100644
index 000000000..b8c6dac2f
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/Lorem.php
@@ -0,0 +1,203 @@
+ array(
+ "4539###########",
+ "4556###########",
+ "4916###########",
+ "4532###########",
+ "4929###########",
+ "40240071#######",
+ "4485###########",
+ "4716###########",
+ "4##############"
+ ),
+ 'Visa Retired' => array(
+ "4539########",
+ "4556########",
+ "4916########",
+ "4532########",
+ "4929########",
+ "40240071####",
+ "4485########",
+ "4716########",
+ "4###########",
+ ),
+ 'MasterCard' => array(
+ "2221###########",
+ "23#############",
+ "24#############",
+ "25#############",
+ "26#############",
+ "2720###########",
+ "51#############",
+ "52#############",
+ "53#############",
+ "54#############",
+ "55#############"
+ ),
+ 'American Express' => array(
+ "34############",
+ "37############"
+ ),
+ 'Discover Card' => array(
+ "6011###########"
+ ),
+ );
+
+ /**
+ * @var array list of IBAN formats, source: @link https://www.swift.com/standards/data-standards/iban
+ */
+ protected static $ibanFormats = array(
+ 'AD' => array(array('n', 4), array('n', 4), array('c', 12)),
+ 'AE' => array(array('n', 3), array('n', 16)),
+ 'AL' => array(array('n', 8), array('c', 16)),
+ 'AT' => array(array('n', 5), array('n', 11)),
+ 'AZ' => array(array('a', 4), array('c', 20)),
+ 'BA' => array(array('n', 3), array('n', 3), array('n', 8), array('n', 2)),
+ 'BE' => array(array('n', 3), array('n', 7), array('n', 2)),
+ 'BG' => array(array('a', 4), array('n', 4), array('n', 2), array('c', 8)),
+ 'BH' => array(array('a', 4), array('c', 14)),
+ 'BR' => array(array('n', 8), array('n', 5), array('n', 10), array('a', 1), array('c', 1)),
+ 'CH' => array(array('n', 5), array('c', 12)),
+ 'CR' => array(array('n', 3), array('n', 14)),
+ 'CY' => array(array('n', 3), array('n', 5), array('c', 16)),
+ 'CZ' => array(array('n', 4), array('n', 6), array('n', 10)),
+ 'DE' => array(array('n', 8), array('n', 10)),
+ 'DK' => array(array('n', 4), array('n', 9), array('n', 1)),
+ 'DO' => array(array('c', 4), array('n', 20)),
+ 'EE' => array(array('n', 2), array('n', 2), array('n', 11), array('n', 1)),
+ 'ES' => array(array('n', 4), array('n', 4), array('n', 1), array('n', 1), array('n', 10)),
+ 'FI' => array(array('n', 6), array('n', 7), array('n', 1)),
+ 'FR' => array(array('n', 5), array('n', 5), array('c', 11), array('n', 2)),
+ 'GB' => array(array('a', 4), array('n', 6), array('n', 8)),
+ 'GE' => array(array('a', 2), array('n', 16)),
+ 'GI' => array(array('a', 4), array('c', 15)),
+ 'GR' => array(array('n', 3), array('n', 4), array('c', 16)),
+ 'GT' => array(array('c', 4), array('c', 20)),
+ 'HR' => array(array('n', 7), array('n', 10)),
+ 'HU' => array(array('n', 3), array('n', 4), array('n', 1), array('n', 15), array('n', 1)),
+ 'IE' => array(array('a', 4), array('n', 6), array('n', 8)),
+ 'IL' => array(array('n', 3), array('n', 3), array('n', 13)),
+ 'IS' => array(array('n', 4), array('n', 2), array('n', 6), array('n', 10)),
+ 'IT' => array(array('a', 1), array('n', 5), array('n', 5), array('c', 12)),
+ 'KW' => array(array('a', 4), array('n', 22)),
+ 'KZ' => array(array('n', 3), array('c', 13)),
+ 'LB' => array(array('n', 4), array('c', 20)),
+ 'LI' => array(array('n', 5), array('c', 12)),
+ 'LT' => array(array('n', 5), array('n', 11)),
+ 'LU' => array(array('n', 3), array('c', 13)),
+ 'LV' => array(array('a', 4), array('c', 13)),
+ 'MC' => array(array('n', 5), array('n', 5), array('c', 11), array('n', 2)),
+ 'MD' => array(array('c', 2), array('c', 18)),
+ 'ME' => array(array('n', 3), array('n', 13), array('n', 2)),
+ 'MK' => array(array('n', 3), array('c', 10), array('n', 2)),
+ 'MR' => array(array('n', 5), array('n', 5), array('n', 11), array('n', 2)),
+ 'MT' => array(array('a', 4), array('n', 5), array('c', 18)),
+ 'MU' => array(array('a', 4), array('n', 2), array('n', 2), array('n', 12), array('n', 3), array('a', 3)),
+ 'NL' => array(array('a', 4), array('n', 10)),
+ 'NO' => array(array('n', 4), array('n', 6), array('n', 1)),
+ 'PK' => array(array('a', 4), array('c', 16)),
+ 'PL' => array(array('n', 8), array('n', 16)),
+ 'PS' => array(array('a', 4), array('c', 21)),
+ 'PT' => array(array('n', 4), array('n', 4), array('n', 11), array('n', 2)),
+ 'RO' => array(array('a', 4), array('c', 16)),
+ 'RS' => array(array('n', 3), array('n', 13), array('n', 2)),
+ 'SA' => array(array('n', 2), array('c', 18)),
+ 'SE' => array(array('n', 3), array('n', 16), array('n', 1)),
+ 'SI' => array(array('n', 5), array('n', 8), array('n', 2)),
+ 'SK' => array(array('n', 4), array('n', 6), array('n', 10)),
+ 'SM' => array(array('a', 1), array('n', 5), array('n', 5), array('c', 12)),
+ 'TN' => array(array('n', 2), array('n', 3), array('n', 13), array('n', 2)),
+ 'TR' => array(array('n', 5), array('n', 1), array('c', 16)),
+ 'VG' => array(array('a', 4), array('n', 16)),
+ );
+
+ /**
+ * @return string Returns a credit card vendor name
+ *
+ * @example 'MasterCard'
+ */
+ public static function creditCardType()
+ {
+ return static::randomElement(static::$cardVendors);
+ }
+
+ /**
+ * Returns the String of a credit card number.
+ *
+ * @param string $type Supporting any of 'Visa', 'MasterCard', 'American Express', and 'Discover'
+ * @param boolean $formatted Set to true if the output string should contain one separator every 4 digits
+ * @param string $separator Separator string for formatting card number. Defaults to dash (-).
+ * @return string
+ *
+ * @example '4485480221084675'
+ */
+ public static function creditCardNumber($type = null, $formatted = false, $separator = '-')
+ {
+ if (is_null($type)) {
+ $type = static::creditCardType();
+ }
+ $mask = static::randomElement(static::$cardParams[$type]);
+
+ $number = static::numerify($mask);
+ $number .= Luhn::computeCheckDigit($number);
+
+ if ($formatted) {
+ $p1 = substr($number, 0, 4);
+ $p2 = substr($number, 4, 4);
+ $p3 = substr($number, 8, 4);
+ $p4 = substr($number, 12);
+ $number = $p1 . $separator . $p2 . $separator . $p3 . $separator . $p4;
+ }
+
+ return $number;
+ }
+
+ /**
+ * @param boolean $valid True (by default) to get a valid expiration date, false to get a maybe valid date
+ * @return \DateTime
+ * @example 04/13
+ */
+ public function creditCardExpirationDate($valid = true)
+ {
+ if ($valid) {
+ return $this->generator->dateTimeBetween('now', '36 months');
+ }
+
+ return $this->generator->dateTimeBetween('-36 months', '36 months');
+ }
+
+ /**
+ * @param boolean $valid True (by default) to get a valid expiration date, false to get a maybe valid date
+ * @param string $expirationDateFormat
+ * @return string
+ * @example '04/13'
+ */
+ public function creditCardExpirationDateString($valid = true, $expirationDateFormat = null)
+ {
+ return $this->creditCardExpirationDate($valid)->format(is_null($expirationDateFormat) ? static::$expirationDateFormat : $expirationDateFormat);
+ }
+
+ /**
+ * @param boolean $valid True (by default) to get a valid expiration date, false to get a maybe valid date
+ * @return array
+ */
+ public function creditCardDetails($valid = true)
+ {
+ $type = static::creditCardType();
+
+ return array(
+ 'type' => $type,
+ 'number' => static::creditCardNumber($type),
+ 'name' => $this->generator->name(),
+ 'expirationDate' => $this->creditCardExpirationDateString($valid)
+ );
+ }
+
+ /**
+ * International Bank Account Number (IBAN)
+ *
+ * @link http://en.wikipedia.org/wiki/International_Bank_Account_Number
+ * @param string $countryCode ISO 3166-1 alpha-2 country code
+ * @param string $prefix for generating bank account number of a specific bank
+ * @param integer $length total length without country code and 2 check digits
+ * @return string
+ */
+ public static function iban($countryCode = null, $prefix = '', $length = null)
+ {
+ $countryCode = is_null($countryCode) ? self::randomKey(self::$ibanFormats) : strtoupper($countryCode);
+
+ $format = !isset(static::$ibanFormats[$countryCode]) ? null : static::$ibanFormats[$countryCode];
+ if ($length === null) {
+ if ($format === null) {
+ $length = 24;
+ } else {
+ $length = 0;
+ foreach ($format as $part) {
+ list($class, $groupCount) = $part;
+ $length += $groupCount;
+ }
+ }
+ }
+ if ($format === null) {
+ $format = array(array('n', $length));
+ }
+
+ $expandedFormat = '';
+ foreach ($format as $item) {
+ list($class, $length) = $item;
+ $expandedFormat .= str_repeat($class, $length);
+ }
+
+ $result = $prefix;
+ $expandedFormat = substr($expandedFormat, strlen($result));
+ foreach (str_split($expandedFormat) as $class) {
+ switch ($class) {
+ default:
+ case 'c':
+ $result .= mt_rand(0, 100) <= 50 ? static::randomDigit() : strtoupper(static::randomLetter());
+ break;
+ case 'a':
+ $result .= strtoupper(static::randomLetter());
+ break;
+ case 'n':
+ $result .= static::randomDigit();
+ break;
+ }
+ }
+
+ $checksum = Iban::checksum($countryCode . '00' . $result);
+
+ return $countryCode . $checksum . $result;
+ }
+
+ /**
+ * Return the String of a SWIFT/BIC number
+ *
+ * @example 'RZTIAT22263'
+ * @link http://en.wikipedia.org/wiki/ISO_9362
+ * @return string Swift/Bic number
+ */
+ public static function swiftBicNumber()
+ {
+ return self::regexify("^([A-Z]){4}([A-Z]){2}([0-9A-Z]){2}([0-9A-Z]{3})?$");
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/Person.php b/vendor/fzaninotto/faker/src/Faker/Provider/Person.php
new file mode 100644
index 000000000..9d875b661
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/Person.php
@@ -0,0 +1,126 @@
+generator->parse($format);
+ }
+
+ /**
+ * @param string|null $gender 'male', 'female' or null for any
+ * @return string
+ * @example 'John'
+ */
+ public function firstName($gender = null)
+ {
+ if ($gender === static::GENDER_MALE) {
+ return static::firstNameMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return static::firstNameFemale();
+ }
+
+ return $this->generator->parse(static::randomElement(static::$firstNameFormat));
+ }
+
+ public static function firstNameMale()
+ {
+ return static::randomElement(static::$firstNameMale);
+ }
+
+ public static function firstNameFemale()
+ {
+ return static::randomElement(static::$firstNameFemale);
+ }
+
+ /**
+ * @example 'Doe'
+ * @return string
+ */
+ public function lastName()
+ {
+ return static::randomElement(static::$lastName);
+ }
+
+ /**
+ * @example 'Mrs.'
+ * @param string|null $gender 'male', 'female' or null for any
+ * @return string
+ */
+ public function title($gender = null)
+ {
+ if ($gender === static::GENDER_MALE) {
+ return static::titleMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return static::titleFemale();
+ }
+
+ return $this->generator->parse(static::randomElement(static::$titleFormat));
+ }
+
+ /**
+ * @example 'Mr.'
+ */
+ public static function titleMale()
+ {
+ return static::randomElement(static::$titleMale);
+ }
+
+ /**
+ * @example 'Mrs.'
+ */
+ public static function titleFemale()
+ {
+ return static::randomElement(static::$titleFemale);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/PhoneNumber.php
new file mode 100644
index 000000000..d9d1f6bb2
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/PhoneNumber.php
@@ -0,0 +1,43 @@
+generator->parse(static::randomElement(static::$formats)));
+ }
+
+ /**
+ * @example +27113456789
+ * @return string
+ */
+ public function e164PhoneNumber()
+ {
+ $formats = array('+%############');
+ return static::numerify($this->generator->parse(static::randomElement($formats)));
+ }
+
+ /**
+ * International Mobile Equipment Identity (IMEI)
+ *
+ * @link http://en.wikipedia.org/wiki/International_Mobile_Station_Equipment_Identity
+ * @link http://imei-number.com/imei-validation-check/
+ * @example '720084494799532'
+ * @return int $imei
+ */
+ public function imei()
+ {
+ $imei = (string) static::numerify('##############');
+ $imei .= Luhn::computeCheckDigit($imei);
+ return $imei;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/Text.php b/vendor/fzaninotto/faker/src/Faker/Provider/Text.php
new file mode 100644
index 000000000..80aa02fc8
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/Text.php
@@ -0,0 +1,141 @@
+ 5) {
+ throw new \InvalidArgumentException('indexSize must be at most 5');
+ }
+
+ $words = $this->getConsecutiveWords($indexSize);
+ $result = array();
+ $resultLength = 0;
+ // take a random starting point
+ $next = static::randomKey($words);
+ while ($resultLength < $maxNbChars && isset($words[$next])) {
+ // fetch a random word to append
+ $word = static::randomElement($words[$next]);
+
+ // calculate next index
+ $currentWords = static::explode($next);
+ $currentWords[] = $word;
+ array_shift($currentWords);
+ $next = static::implode($currentWords);
+
+ // ensure text starts with an uppercase letter
+ if ($resultLength == 0 && !static::validStart($word)) {
+ continue;
+ }
+
+ // append the element
+ $result[] = $word;
+ $resultLength += static::strlen($word) + static::$separatorLen;
+ }
+
+ // remove the element that caused the text to overflow
+ array_pop($result);
+
+ // build result
+ $result = static::implode($result);
+
+ return static::appendEnd($result);
+ }
+
+ protected function getConsecutiveWords($indexSize)
+ {
+ if (!isset($this->consecutiveWords[$indexSize])) {
+ $parts = $this->getExplodedText();
+ $words = array();
+ $index = array();
+ for ($i = 0; $i < $indexSize; $i++) {
+ $index[] = array_shift($parts);
+ }
+
+ for ($i = 0, $count = count($parts); $i < $count; $i++) {
+ $stringIndex = static::implode($index);
+ if (!isset($words[$stringIndex])) {
+ $words[$stringIndex] = array();
+ }
+ $word = $parts[$i];
+ $words[$stringIndex][] = $word;
+ array_shift($index);
+ $index[] = $word;
+ }
+ // cache look up words for performance
+ $this->consecutiveWords[$indexSize] = $words;
+ }
+
+ return $this->consecutiveWords[$indexSize];
+ }
+
+ protected function getExplodedText()
+ {
+ if ($this->explodedText === null) {
+ $this->explodedText = static::explode(preg_replace('/\s+/u', ' ', static::$baseText));
+ }
+
+ return $this->explodedText;
+ }
+
+ protected static function explode($text)
+ {
+ return explode(static::$separator, $text);
+ }
+
+ protected static function implode($words)
+ {
+ return implode(static::$separator, $words);
+ }
+
+ protected static function strlen($text)
+ {
+ return function_exists('mb_strlen') ? mb_strlen($text, 'UTF-8') : strlen($text);
+ }
+
+ protected static function validStart($word)
+ {
+ $isValid = true;
+ if (static::$textStartsWithUppercase) {
+ $isValid = preg_match('/^\p{Lu}/u', $word);
+ }
+ return $isValid;
+ }
+
+ protected static function appendEnd($text)
+ {
+ return preg_replace("/([ ,-:;\x{2013}\x{2014}]+$)/us", '', $text).'.';
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/UserAgent.php b/vendor/fzaninotto/faker/src/Faker/Provider/UserAgent.php
new file mode 100644
index 000000000..d659f4bbf
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/UserAgent.php
@@ -0,0 +1,165 @@
+> 8) | (($tLo & 0xff000000) >> 24);
+ $tMi = (($tMi & 0x00ff) << 8) | (($tMi & 0xff00) >> 8);
+ $tHi = (($tHi & 0x00ff) << 8) | (($tHi & 0xff00) >> 8);
+ }
+
+ // apply version number
+ $tHi &= 0x0fff;
+ $tHi |= (3 << 12);
+
+ // cast to string
+ $uuid = sprintf(
+ '%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x',
+ $tLo,
+ $tMi,
+ $tHi,
+ $csHi,
+ $csLo,
+ $byte[10],
+ $byte[11],
+ $byte[12],
+ $byte[13],
+ $byte[14],
+ $byte[15]
+ );
+
+ return $uuid;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Address.php
new file mode 100644
index 000000000..6f4f258d2
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Address.php
@@ -0,0 +1,152 @@
+generator->parse($format));
+ }
+
+ /**
+ * @example 'wewebit.jo'
+ */
+ public function domainName()
+ {
+ return static::randomElement(static::$lastNameAscii) . '.' . $this->tld();
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Person.php b/vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Person.php
new file mode 100644
index 000000000..7fcadb3a1
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ar_JO/Person.php
@@ -0,0 +1,108 @@
+generator->parse($format));
+ }
+
+ /**
+ * @example 'wewebit.jo'
+ */
+ public function domainName()
+ {
+ return static::randomElement(static::$lastNameAscii) . '.' . $this->tld();
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ar_SA/Payment.php b/vendor/fzaninotto/faker/src/Faker/Provider/ar_SA/Payment.php
new file mode 100644
index 000000000..d69b5d629
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ar_SA/Payment.php
@@ -0,0 +1,19 @@
+generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/bg_BG/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/bg_BG/PhoneNumber.php
new file mode 100644
index 000000000..e5ec04222
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/bg_BG/PhoneNumber.php
@@ -0,0 +1,20 @@
+generator->parse($format));
+ }
+
+ /**
+ * Generates valid czech IÄŒO
+ *
+ * @see http://phpfashion.com/jak-overit-platne-ic-a-rodne-cislo
+ * @return string
+ */
+ public function ico()
+ {
+ $ico = static::numerify('#######');
+ $split = str_split($ico);
+ $prod = 0;
+ foreach (array(8, 7, 6, 5, 4, 3, 2) as $i => $p) {
+ $prod += $p * $split[$i];
+ }
+ $mod = $prod % 11;
+ if ($mod === 0 || $mod === 10) {
+ return "{$ico}1";
+ } elseif ($mod === 1) {
+ return "{$ico}0";
+ }
+
+ return $ico . (11 - $mod);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/DateTime.php b/vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/DateTime.php
new file mode 100644
index 000000000..4bd150886
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/DateTime.php
@@ -0,0 +1,61 @@
+format('w')];
+ }
+
+ /**
+ * @param \DateTime|int|string $max maximum timestamp used as random end limit, default to "now"
+ * @return string
+ * @example '2'
+ */
+ public static function dayOfMonth($max = 'now')
+ {
+ return static::dateTime($max)->format('j');
+ }
+
+ /**
+ * Full date with inflected month
+ * @return string
+ * @example '16. listopadu 2003'
+ */
+ public function formattedDate()
+ {
+ $format = static::randomElement(static::$formattedDateFormat);
+
+ return $this->generator->parse($format);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/Internet.php
new file mode 100644
index 000000000..d0d993d40
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/Internet.php
@@ -0,0 +1,9 @@
+generator->boolean() ? static::GENDER_MALE : static::GENDER_FEMALE;
+ }
+
+ $startTimestamp = strtotime("-${maxAge} year");
+ $endTimestamp = strtotime("-${minAge} year");
+ $randTimestamp = static::numberBetween($startTimestamp, $endTimestamp);
+
+ $year = intval(date('Y', $randTimestamp));
+ $month = intval(date('n', $randTimestamp));
+ $day = intval(date('j', $randTimestamp));
+ $suffix = static::numberBetween(0, 999);
+
+ // women has +50 to month
+ if ($gender == static::GENDER_FEMALE) {
+ $month += 50;
+ }
+ // from year 2004 everyone has +20 to month when birth numbers in one day are exhausted
+ if ($year >= 2004 && $this->generator->boolean(10)) {
+ $month += 20;
+ }
+
+ $birthNumber = sprintf('%02d%02d%02d%03d', $year % 100, $month, $day, $suffix);
+
+ // from year 1954 birth number includes CRC
+ if ($year >= 1954) {
+ $crc = intval($birthNumber, 10) % 11;
+ if ($crc == 10) {
+ $crc = 0;
+ }
+ $birthNumber .= sprintf('%d', $crc);
+ }
+
+ // add slash
+ if ($this->generator->boolean($slashProbability)) {
+ $birthNumber = substr($birthNumber, 0, 6) . '/' . substr($birthNumber, 6);
+ }
+
+ return $birthNumber;
+ }
+
+ public static function birthNumberMale()
+ {
+ return static::birthNumber(static::GENDER_MALE);
+ }
+
+ public static function birthNumberFemale()
+ {
+ return static::birthNumber(static::GENDER_FEMALE);
+ }
+
+ public function title($gender = null)
+ {
+ return static::titleMale();
+ }
+
+ /**
+ * replaced by specific unisex Czech title
+ */
+ public static function titleMale()
+ {
+ return static::randomElement(static::$title);
+ }
+
+ /**
+ * replaced by specific unisex Czech title
+ */
+ public static function titleFemale()
+ {
+ return static::titleMale();
+ }
+
+ /**
+ * @param string|null $gender 'male', 'female' or null for any
+ * @example 'Albrecht'
+ */
+ public function lastName($gender = null)
+ {
+ if ($gender === static::GENDER_MALE) {
+ return static::lastNameMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return static::lastNameFemale();
+ }
+
+ return $this->generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/PhoneNumber.php
new file mode 100644
index 000000000..49ab429e3
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/cs_CZ/PhoneNumber.php
@@ -0,0 +1,14 @@
+
+ */
+class Address extends \Faker\Provider\Address
+{
+ /**
+ * @var array Danish city suffixes.
+ */
+ protected static $citySuffix = array(
+ 'sted', 'bjerg', 'borg', 'rød', 'lund', 'by',
+ );
+
+ /**
+ * @var array Danish street suffixes.
+ */
+ protected static $streetSuffix = array(
+ 'vej', 'gade', 'skov', 'shaven',
+ );
+
+ /**
+ * @var array Danish street word suffixes.
+ */
+ protected static $streetSuffixWord = array(
+ 'Vej', 'Gade', 'Allé', 'Boulevard', 'Plads', 'Have',
+ );
+
+ /**
+ * @var array Danish building numbers.
+ */
+ protected static $buildingNumber = array(
+ '%##', '%#', '%#', '%', '%', '%', '%?', '% ?',
+ );
+
+ /**
+ * @var array Danish building level.
+ */
+ protected static $buildingLevel = array(
+ 'st.', '%.', '%. sal.',
+ );
+
+ /**
+ * @var array Danish building sides.
+ */
+ protected static $buildingSide = array(
+ 'tv.', 'th.',
+ );
+
+ /**
+ * @var array Danish zip code.
+ */
+ protected static $postcode = array(
+ '%###'
+ );
+
+ /**
+ * @var array Danish cities.
+ */
+ protected static $cityNames = array(
+ 'Aabenraa', 'Aabybro', 'Aakirkeby', 'Aalborg', 'Aalestrup', 'Aars', 'Aarup', 'Agedrup', 'Agerbæk', 'Agerskov',
+ 'Albertslund', 'Allerød', 'Allinge', 'Allingåbro', 'Almind', 'Anholt', 'Ansager', 'Arden', 'Asaa', 'Askeby',
+ 'Asnæs', 'Asperup', 'Assens', 'Augustenborg', 'Aulum', 'Auning', 'Bagenkop', 'Bagsværd', 'Balle', 'Ballerup',
+ 'Bandholm', 'Barrit', 'Beder', 'Bedsted', 'Bevtoft', 'Billum', 'Billund', 'Bindslev', 'Birkerød', 'Bjerringbro',
+ 'Bjert', 'Bjæverskov', 'Blokhus', 'Blommenslyst', 'Blåvand', 'Boeslunde', 'Bogense', 'Bogø', 'Bolderslev', 'Bording',
+ 'Borre', 'Borup', 'Brøndby', 'Brabrand', 'Bramming', 'Brande', 'Branderup', 'Bredebro', 'Bredsten', 'Brenderup',
+ 'Broager', 'Broby', 'Brovst', 'Bryrup', 'Brædstrup', 'Strand', 'Brønderslev', 'Brønshøj', 'Brørup', 'Bække',
+ 'Bækmarksbro', 'Bælum', 'Børkop', 'Bøvlingbjerg', 'Charlottenlund', 'Christiansfeld', 'Dalby', 'Dalmose',
+ 'Dannemare', 'Daugård', 'Dianalund', 'Dragør', 'Dronninglund', 'Dronningmølle', 'Dybvad', 'Dyssegård', 'Ebberup',
+ 'Ebeltoft', 'Egernsund', 'Egtved', 'Egå', 'Ejby', 'Ejstrupholm', 'Engesvang', 'Errindlev', 'Erslev', 'Esbjerg',
+ 'Eskebjerg', 'Eskilstrup', 'Espergærde', 'Faaborg', 'Fanø', 'Farsø', 'Farum', 'Faxe', 'Ladeplads', 'Fejø',
+ 'Ferritslev', 'Fjenneslev', 'Fjerritslev', 'Flemming', 'Fredensborg', 'Fredericia', 'Frederiksberg',
+ 'Frederikshavn', 'Frederikssund', 'Frederiksværk', 'Frørup', 'Frøstrup', 'Fuglebjerg', 'Føllenslev', 'Føvling',
+ 'FÃ¥revejle', 'FÃ¥rup', 'FÃ¥rvang', 'Gadbjerg', 'Gadstrup', 'Galten', 'Gandrup', 'Gedser', 'Gedsted', 'Gedved', 'Gelsted',
+ 'Gentofte', 'Gesten', 'Gilleleje', 'Gislev', 'Gislinge', 'Gistrup', 'Give', 'Gjerlev', 'Gjern', 'Glamsbjerg',
+ 'Glejbjerg', 'Glesborg', 'Glostrup', 'Glumsø', 'Gram', 'Gredstedbro', 'Grenaa', 'Greve', 'Grevinge', 'Grindsted',
+ 'Græsted', 'Gråsten', 'Gudbjerg', 'Sydfyn', 'Gudhjem', 'Gudme', 'Guldborg', 'Gørding', 'Gørlev', 'Gørløse',
+ 'Haderslev', 'Haderup', 'Hadsten', 'Hadsund', 'Hals', 'Hammel', 'Hampen', 'Hanstholm', 'Harboøre', 'Harlev', 'Harndrup',
+ 'Harpelunde', 'Hasle', 'Haslev', 'Hasselager', 'Havdrup', 'Havndal', 'Hedehusene', 'Hedensted', 'Hejls', 'Hejnsvig',
+ 'Hellebæk', 'Hellerup', 'Helsinge', 'Helsingør', 'Hemmet', 'Henne', 'Herfølge', 'Herlev', 'Herlufmagle', 'Herning',
+ 'Hesselager', 'Hillerød', 'Hinnerup', 'Hirtshals', 'Hjallerup', 'Hjerm', 'Hjortshøj', 'Hjørring', 'Hobro', 'Holbæk',
+ 'Holeby', 'Holmegaard', 'Holstebro', 'Holsted', 'Holte', 'Horbelev', 'Hornbæk', 'Hornslet', 'Hornsyld', 'Horsens',
+ 'Horslunde', 'Hovborg', 'Hovedgård', 'Humble', 'Humlebæk', 'Hundested', 'Hundslund', 'Hurup', 'Hvalsø', 'Hvide',
+ 'Sande', 'Hvidovre', 'Højbjerg', 'Højby', 'Højer', 'Højslev', 'Høng', 'Hørning', 'Hørsholm', 'Hørve', 'Hårlev',
+ 'Idestrup', 'Ikast', 'Ishøj', 'Janderup', 'Vestj', 'Jelling', 'Jerslev', 'Sjælland', 'Jerup', 'Jordrup', 'Juelsminde',
+ 'Jyderup', 'Jyllinge', 'Jystrup', 'Midtsj', 'Jægerspris', 'Kalundborg', 'Kalvehave', 'Karby', 'Karise', 'Karlslunde',
+ 'Karrebæksminde', 'Karup', 'Kastrup', 'Kerteminde', 'Kettinge', 'Kibæk', 'Kirke', 'Hyllinge', 'Såby', 'Kjellerup',
+ 'Klampenborg', 'Klarup', 'Klemensker', 'Klippinge', 'Klovborg', 'Knebel', 'Kokkedal', 'Kolding', 'Kolind', 'Kongens',
+ 'Lyngby', 'Kongerslev', 'Korsør', 'Kruså', 'Kvistgård', 'Kværndrup', 'København', 'Køge', 'Langebæk', 'Langeskov',
+ 'Langå', 'Lejre', 'Lemming', 'Lemvig', 'Lille', 'Skensved', 'Lintrup', 'Liseleje', 'Lundby', 'Lunderskov', 'Lynge',
+ 'Lystrup', 'Læsø', 'Løgstrup', 'Løgstør', 'Løgumkloster', 'Løkken', 'Løsning', 'Låsby', 'Malling', 'Mariager',
+ 'Maribo', 'Marslev', 'Marstal', 'Martofte', 'Melby', 'Mern', 'Mesinge', 'Middelfart', 'Millinge', 'Morud', 'Munke',
+ 'Bjergby', 'Munkebo', 'Møldrup', 'Mørke', 'Mørkøv', 'Måløv', 'Mårslet', 'Nakskov', 'Nexø', 'Nibe', 'Nimtofte',
+ 'Nordborg', 'Nyborg', 'Nykøbing', 'Nyrup', 'Nysted', 'Nærum', 'Næstved', 'Nørager', 'Nørre', 'Aaby', 'Alslev',
+ 'Asmindrup', 'Nebel', 'Snede', 'Nørreballe', 'Nørresundby', 'Odder', 'Odense', 'Oksbøl', 'Otterup', 'Oure', 'Outrup',
+ 'Padborg', 'Pandrup', 'Præstø', 'Randbøl', 'Randers', 'Ranum', 'Rask', 'Mølle', 'Redsted', 'Regstrup', 'Ribe', 'Ringe',
+ 'Ringkøbing', 'Ringsted', 'Risskov', 'Roskilde', 'Roslev', 'Rude', 'Rudkøbing', 'Ruds', 'Vedby', 'Rungsted', 'Kyst',
+ 'Rynkeby', 'Ryomgård', 'Ryslinge', 'Rødby', 'Rødding', 'Rødekro', 'Rødkærsbro', 'Rødovre', 'Rødvig', 'Stevns',
+ 'Rønde', 'Rønne', 'Rønnede', 'Rørvig', 'Sabro', 'Sakskøbing', 'Saltum', 'Samsø', 'Sandved', 'Sejerø', 'Silkeborg',
+ 'Sindal', 'Sjællands', 'Odde', 'Sjølund', 'Skagen', 'Skals', 'Skamby', 'Skanderborg', 'Skibby', 'Skive', 'Skjern',
+ 'Skodsborg', 'Skovlunde', 'Skælskør', 'Skærbæk', 'Skævinge', 'Skødstrup', 'Skørping', 'Skårup', 'Slagelse',
+ 'Slangerup', 'Smørum', 'Snedsted', 'Snekkersten', 'Snertinge', 'Solbjerg', 'Solrød', 'Sommersted', 'Sorring', 'Sorø',
+ 'Spentrup', 'Spjald', 'Sporup', 'Spøttrup', 'Stakroge', 'Stege', 'Stenderup', 'Stenlille', 'Stenløse', 'Stenstrup',
+ 'Stensved', 'Stoholm', 'Jyll', 'Stokkemarke', 'Store', 'Fuglede', 'Heddinge', 'Merløse', 'Storvorde', 'Stouby',
+ 'Strandby', 'Struer', 'Strøby', 'Stubbekøbing', 'Støvring', 'Suldrup', 'Sulsted', 'Sunds', 'Svaneke', 'Svebølle',
+ 'Svendborg', 'Svenstrup', 'Svinninge', 'Sydals', 'Sæby', 'Søborg', 'Søby', 'Ærø', 'Søllested', 'Sønder', 'Felding',
+ 'Sønderborg', 'Søndersø', 'Sørvad', 'Taastrup', 'Tappernøje', 'Tarm', 'Terndrup', 'Them', 'Thisted', 'Thorsø',
+ 'Thyborøn', 'Thyholm', 'Tikøb', 'Tilst', 'Tinglev', 'Tistrup', 'Tisvildeleje', 'Tjele', 'Tjæreborg', 'Toftlund',
+ 'Tommerup', 'Toreby', 'Torrig', 'Tranbjerg', 'Tranekær', 'Trige', 'Trustrup', 'Tune', 'Tureby', 'Tylstrup', 'Tølløse',
+ 'Tønder', 'Tørring', 'Tårs', 'Ugerløse', 'Uldum', 'Ulfborg', 'Ullerslev', 'Ulstrup', 'Vadum', 'Valby', 'Vallensbæk',
+ 'Vamdrup', 'Vandel', 'Vanløse', 'Varde', 'Vedbæk', 'Veflinge', 'Vejby', 'Vejen', 'Vejers', 'Vejle', 'Vejstrup',
+ 'Veksø', 'Vemb', 'Vemmelev', 'Vesløs', 'Vestbjerg', 'Vester', 'Skerninge', 'Vesterborg', 'Vestervig', 'Viborg', 'Viby',
+ 'Videbæk', 'Vildbjerg', 'Vils', 'Vinderup', 'Vipperød', 'Virum', 'Vissenbjerg', 'Viuf', 'Vodskov', 'Vojens', 'Vonge',
+ 'Vorbasse', 'Vordingborg', 'Væggerløse', 'Værløse', 'Ærøskøbing', 'Ølgod', 'Ølsted', 'Ølstykke', 'Ørbæk',
+ 'Ørnhøj', 'Ørsted', 'Djurs', 'Østbirk', 'Øster', 'Assels', 'Ulslev', 'Østermarie', 'Østervrå', 'Åbyhøj',
+ 'Ålbæk', 'Ålsgårde', 'Århus', 'Årre', 'Årslev', 'Haarby', 'Nivå', 'Rømø', 'Omme', 'Vrå', 'Ørum',
+ );
+
+ /**
+ * @var array Danish municipalities, called 'kommuner' in danish.
+ */
+ protected static $kommuneNames = array(
+ 'København', 'Frederiksberg', 'Ballerup', 'Brøndby', 'Dragør', 'Gentofte', 'Gladsaxe', 'Glostrup', 'Herlev',
+ 'Albertslund', 'Hvidovre', 'Høje Taastrup', 'Lyngby-Taarbæk', 'Rødovre', 'Ishøj', 'Tårnby', 'Vallensbæk',
+ 'Allerød', 'Fredensborg', 'Helsingør', 'Hillerød', 'Hørsholm', 'Rudersdal', 'Egedal', 'Frederikssund', 'Greve',
+ 'Halsnæs', 'Roskilde', 'Solrød', 'Gribskov', 'Odsherred', 'Holbæk', 'Faxe', 'Kalundborg', 'Ringsted', 'Slagelse',
+ 'Stevns', 'Sorø', 'Lejre', 'Lolland', 'Næstved', 'Guldborgsund', 'Vordingborg', 'Bornholm', 'Middelfart',
+ 'Christiansø', 'Assens', 'Faaborg-Midtfyn', 'Kerteminde', 'Nyborg', 'Odense', 'Svendborg', 'Nordfyns', 'Langeland',
+ 'Ærø', 'Haderslev', 'Billund', 'Sønderborg', 'Tønder', 'Esbjerg', 'Fanø', 'Varde', 'Vejen', 'Aabenraa',
+ 'Fredericia', 'Horsens', 'Kolding', 'Vejle', 'Herning', 'Holstebro', 'Lemvig', 'Struer', 'Syddjurs', 'Furesø',
+ 'Norddjurs', 'Favrskov', 'Odder', 'Randers', 'Silkeborg', 'Samsø', 'Skanderborg', 'Aarhus', 'Ikast-Brande',
+ 'Ringkøbing-Skjern', 'Hedensted', 'Morsø', 'Skive', 'Thisted', 'Viborg', 'Brønderslev', 'Frederikshavn',
+ 'Vesthimmerlands', 'Læsø', 'Rebild', 'Mariagerfjord', 'Jammerbugt', 'Aalborg', 'Hjørring', 'Køge',
+ );
+
+ /**
+ * @var array Danish regions.
+ */
+ protected static $regionNames = array(
+ 'Region Nordjylland', 'Region Midtjylland', 'Region Syddanmark', 'Region Hovedstaden', 'Region Sjælland',
+ );
+
+ /**
+ * @link https://github.com/umpirsky/country-list/blob/master/country/cldr/da_DK/country.php
+ *
+ * @var array Some countries in danish.
+ */
+ protected static $country = array(
+ 'Andorra', 'Forenede Arabiske Emirater', 'Afghanistan', 'Antigua og Barbuda', 'Anguilla', 'Albanien', 'Armenien',
+ 'Hollandske Antiller', 'Angola', 'Antarktis', 'Argentina', 'Amerikansk Samoa', 'Østrig', 'Australien', 'Aruba',
+ 'Ã…land', 'Aserbajdsjan', 'Bosnien-Hercegovina', 'Barbados', 'Bangladesh', 'Belgien', 'Burkina Faso', 'Bulgarien',
+ 'Bahrain', 'Burundi', 'Benin', 'Saint Barthélemy', 'Bermuda', 'Brunei Darussalam', 'Bolivia', 'Brasilien', 'Bahamas',
+ 'Bhutan', 'Bouvetø', 'Botswana', 'Hviderusland', 'Belize', 'Canada', 'Cocosøerne', 'Congo-Kinshasa',
+ 'Centralafrikanske Republik', 'Congo', 'Schweiz', 'Elfenbenskysten', 'Cook-øerne', 'Chile', 'Cameroun', 'Kina',
+ 'Colombia', 'Costa Rica', 'Serbien og Montenegro', 'Cuba', 'Kap Verde', 'Juleøen', 'Cypern', 'Tjekkiet', 'Tyskland',
+ 'Djibouti', 'Danmark', 'Dominica', 'Den Dominikanske Republik', 'Algeriet', 'Ecuador', 'Estland', 'Egypten',
+ 'Vestsahara', 'Eritrea', 'Spanien', 'Etiopien', 'Finland', 'Fiji-øerne', 'Falklandsøerne',
+ 'Mikronesiens Forenede Stater', 'Færøerne', 'Frankrig', 'Gabon', 'Storbritannien', 'Grenada', 'Georgien',
+ 'Fransk Guyana', 'Guernsey', 'Ghana', 'Gibraltar', 'Grønland', 'Gambia', 'Guinea', 'Guadeloupe', 'Ækvatorialguinea',
+ 'Grækenland', 'South Georgia og De Sydlige Sandwichøer', 'Guatemala', 'Guam', 'Guinea-Bissau', 'Guyana',
+ 'SAR Hongkong', 'Heard- og McDonald-øerne', 'Honduras', 'Kroatien', 'Haiti', 'Ungarn', 'Indonesien', 'Irland',
+ 'Israel', 'Isle of Man', 'Indien', 'Det Britiske Territorium i Det Indiske Ocean', 'Irak', 'Iran', 'Island',
+ 'Italien', 'Jersey', 'Jamaica', 'Jordan', 'Japan', 'Kenya', 'Kirgisistan', 'Cambodja', 'Kiribati', 'Comorerne',
+ 'Saint Kitts og Nevis', 'Nordkorea', 'Sydkorea', 'Kuwait', 'Caymanøerne', 'Kasakhstan', 'Laos', 'Libanon',
+ 'Saint Lucia', 'Liechtenstein', 'Sri Lanka', 'Liberia', 'Lesotho', 'Litauen', 'Luxembourg', 'Letland', 'Libyen',
+ 'Marokko', 'Monaco', 'Republikken Moldova', 'Montenegro', 'Saint Martin', 'Madagaskar', 'Marshalløerne',
+ 'Republikken Makedonien', 'Mali', 'Myanmar', 'Mongoliet', 'SAR Macao', 'Nordmarianerne', 'Martinique',
+ 'Mauretanien', 'Montserrat', 'Malta', 'Mauritius', 'Maldiverne', 'Malawi', 'Mexico', 'Malaysia', 'Mozambique',
+ 'Namibia', 'Ny Caledonien', 'Niger', 'Norfolk Island', 'Nigeria', 'Nicaragua', 'Holland', 'Norge', 'Nepal', 'Nauru',
+ 'Niue', 'New Zealand', 'Oman', 'Panama', 'Peru', 'Fransk Polynesien', 'Papua Ny Guinea', 'Filippinerne', 'Pakistan',
+ 'Polen', 'Saint Pierre og Miquelon', 'Pitcairn', 'Puerto Rico', 'De palæstinensiske områder', 'Portugal', 'Palau',
+ 'Paraguay', 'Qatar', 'Reunion', 'Rumænien', 'Serbien', 'Rusland', 'Rwanda', 'Saudi-Arabien', 'Salomonøerne',
+ 'Seychellerne', 'Sudan', 'Sverige', 'Singapore', 'St. Helena', 'Slovenien', 'Svalbard og Jan Mayen', 'Slovakiet',
+ 'Sierra Leone', 'San Marino', 'Senegal', 'Somalia', 'Surinam', 'Sao Tome og Principe', 'El Salvador', 'Syrien',
+ 'Swaziland', 'Turks- og Caicosøerne', 'Tchad', 'Franske Besiddelser i Det Sydlige Indiske Ocean', 'Togo',
+ 'Thailand', 'Tadsjikistan', 'Tokelau', 'Timor-Leste', 'Turkmenistan', 'Tunesien', 'Tonga', 'Tyrkiet',
+ 'Trinidad og Tobago', 'Tuvalu', 'Taiwan', 'Tanzania', 'Ukraine', 'Uganda', 'De Mindre Amerikanske Oversøiske Øer',
+ 'USA', 'Uruguay', 'Usbekistan', 'Vatikanstaten', 'St. Vincent og Grenadinerne', 'Venezuela',
+ 'De britiske jomfruøer', 'De amerikanske jomfruøer', 'Vietnam', 'Vanuatu', 'Wallis og Futunaøerne', 'Samoa',
+ 'Yemen', 'Mayotte', 'Sydafrika', 'Zambia', 'Zimbabwe',
+ );
+
+ /**
+ * @var array Danish city format.
+ */
+ protected static $cityFormats = array(
+ '{{cityName}}',
+ );
+
+ /**
+ * @var array Danish street's name formats.
+ */
+ protected static $streetNameFormats = array(
+ '{{lastName}}{{streetSuffix}}',
+ '{{middleName}}{{streetSuffix}}',
+ '{{lastName}} {{streetSuffixWord}}',
+ '{{middleName}} {{streetSuffixWord}}',
+ );
+
+ /**
+ * @var array Danish street's address formats.
+ */
+ protected static $streetAddressFormats = array(
+ '{{streetName}} {{buildingNumber}}',
+ '{{streetName}} {{buildingNumber}}, {{buildingLevel}}',
+ '{{streetName}} {{buildingNumber}}, {{buildingLevel}} {{buildingSide}}',
+ );
+
+ /**
+ * @var array Danish address format.
+ */
+ protected static $addressFormats = array(
+ "{{streetAddress}}\n{{postcode}} {{city}}",
+ );
+
+ /**
+ * Randomly return a real city name.
+ *
+ * @return string
+ */
+ public static function cityName()
+ {
+ return static::randomElement(static::$cityNames);
+ }
+
+ /**
+ * Randomly return a suffix word.
+ *
+ * @return string
+ */
+ public static function streetSuffixWord()
+ {
+ return static::randomElement(static::$streetSuffixWord);
+ }
+
+ /**
+ * Randomly return a building number.
+ *
+ * @return string
+ */
+ public static function buildingNumber()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$buildingNumber)));
+ }
+
+ /**
+ * Randomly return a building level.
+ *
+ * @return string
+ */
+ public static function buildingLevel()
+ {
+ return static::numerify(static::randomElement(static::$buildingLevel));
+ }
+
+ /**
+ * Randomly return a side of the building.
+ *
+ * @return string
+ */
+ public static function buildingSide()
+ {
+ return static::randomElement(static::$buildingSide);
+ }
+
+ /**
+ * Randomly return a real municipality name, called 'kommune' in danish.
+ *
+ * @return string
+ */
+ public static function kommune()
+ {
+ return static::randomElement(static::$kommuneNames);
+ }
+
+ /**
+ * Randomly return a real region name.
+ *
+ * @return string
+ */
+ public static function region()
+ {
+ return static::randomElement(static::$regionNames);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Company.php
new file mode 100644
index 000000000..b9f289cca
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Company.php
@@ -0,0 +1,70 @@
+
+ */
+class Company extends \Faker\Provider\Company
+{
+ /**
+ * @var array Danish company name formats.
+ */
+ protected static $formats = array(
+ '{{lastName}} {{companySuffix}}',
+ '{{lastName}} {{companySuffix}}',
+ '{{lastName}} {{companySuffix}}',
+ '{{firstname}} {{lastName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{firstname}} {{middleName}} {{companySuffix}}',
+ '{{lastName}} & {{lastName}} {{companySuffix}}',
+ '{{lastName}} og {{lastName}} {{companySuffix}}',
+ '{{lastName}} & {{lastName}} {{companySuffix}}',
+ '{{lastName}} og {{lastName}} {{companySuffix}}',
+ '{{middleName}} & {{middleName}} {{companySuffix}}',
+ '{{middleName}} og {{middleName}} {{companySuffix}}',
+ '{{middleName}} & {{lastName}}',
+ '{{middleName}} og {{lastName}}',
+ );
+
+ /**
+ * @var array Company suffixes.
+ */
+ protected static $companySuffix = array('ApS', 'A/S', 'I/S', 'K/S');
+
+ /**
+ * @link http://cvr.dk/Site/Forms/CMS/DisplayPage.aspx?pageid=60
+ *
+ * @var string CVR number format.
+ */
+ protected static $cvrFormat = '%#######';
+
+ /**
+ * @link http://cvr.dk/Site/Forms/CMS/DisplayPage.aspx?pageid=60
+ *
+ * @var string P number (production number) format.
+ */
+ protected static $pFormat = '%#########';
+
+ /**
+ * Generates a CVR number (8 digits).
+ *
+ * @return string
+ */
+ public static function cvr()
+ {
+ return static::numerify(static::$cvrFormat);
+ }
+
+ /**
+ * Generates a P entity number (10 digits).
+ *
+ * @return string
+ */
+ public static function p()
+ {
+ return static::numerify(static::$pFormat);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Internet.php
new file mode 100644
index 000000000..1f778defd
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Internet.php
@@ -0,0 +1,30 @@
+
+ */
+class Internet extends \Faker\Provider\Internet
+{
+ /**
+ * @var array Some safe email TLD.
+ */
+ protected static $safeEmailTld = array(
+ 'org', 'com', 'net', 'dk', 'dk', 'dk',
+ );
+
+ /**
+ * @var array Some email domains in Denmark.
+ */
+ protected static $freeEmailDomain = array(
+ 'gmail.com', 'yahoo.com', 'yahoo.dk', 'hotmail.com', 'hotmail.dk', 'mail.dk', 'live.dk'
+ );
+
+ /**
+ * @var array Some TLD.
+ */
+ protected static $tld = array(
+ 'com', 'com', 'com', 'biz', 'info', 'net', 'org', 'dk', 'dk', 'dk',
+ );
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Payment.php b/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Payment.php
new file mode 100644
index 000000000..6a5b6a842
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/Payment.php
@@ -0,0 +1,19 @@
+
+ */
+class Person extends \Faker\Provider\Person
+{
+ /**
+ * @var array Danish person name formats.
+ */
+ protected static $maleNameFormats = array(
+ '{{firstNameMale}} {{lastName}}',
+ '{{firstNameMale}} {{lastName}}',
+ '{{firstNameMale}} {{lastName}}',
+ '{{firstNameMale}} {{middleName}} {{lastName}}',
+ '{{firstNameMale}} {{middleName}} {{lastName}}',
+ '{{firstNameMale}} {{middleName}}-{{middleName}} {{lastName}}',
+ '{{firstNameMale}} {{middleName}} {{middleName}}-{{lastName}}',
+ );
+
+ protected static $femaleNameFormats = array(
+ '{{firstNameFemale}} {{lastName}}',
+ '{{firstNameFemale}} {{lastName}}',
+ '{{firstNameFemale}} {{lastName}}',
+ '{{firstNameFemale}} {{middleName}} {{lastName}}',
+ '{{firstNameFemale}} {{middleName}} {{lastName}}',
+ '{{firstNameFemale}} {{middleName}}-{{middleName}} {{lastName}}',
+ '{{firstNameFemale}} {{middleName}} {{middleName}}-{{lastName}}',
+ );
+
+ /**
+ * @var array Danish first names.
+ */
+ protected static $firstNameMale = array(
+ 'Aage', 'Adam', 'Adolf', 'Ahmad', 'Ahmed', 'Aksel', 'Albert', 'Alex', 'Alexander', 'Alf', 'Alfred', 'Ali', 'Allan',
+ 'Anders', 'Andreas', 'Anker', 'Anton', 'Arne', 'Arnold', 'Arthur', 'Asbjørn', 'Asger', 'August', 'Axel', 'Benjamin',
+ 'Benny', 'Bent', 'Bernhard', 'Birger', 'Bjarne', 'Bjørn', 'Bo', 'Brian', 'Bruno', 'Børge', 'Carl', 'Carlo',
+ 'Carsten', 'Casper', 'Charles', 'Chris', 'Christian', 'Christoffer', 'Christopher', 'Claus', 'Dan', 'Daniel', 'David', 'Dennis',
+ 'Ebbe', 'Edmund', 'Edvard', 'Egon', 'Einar', 'Ejvind', 'Elias', 'Emanuel', 'Emil', 'Erik', 'Erland', 'Erling',
+ 'Ernst', 'Esben', 'Ferdinand', 'Finn', 'Flemming', 'Frank', 'Freddy', 'Frederik', 'Frits', 'Fritz', 'Frode', 'Georg',
+ 'Gerhard', 'Gert', 'Gunnar', 'Gustav', 'Hans', 'Harald', 'Harry', 'Hassan', 'Heine', 'Heinrich', 'Helge', 'Helmer',
+ 'Helmuth', 'Henning', 'Henrik', 'Henry', 'Herman', 'Hermann', 'Holger', 'Hugo', 'Ib', 'Ibrahim', 'Ivan', 'Jack',
+ 'Jacob', 'Jakob', 'Jan', 'Janne', 'Jens', 'Jeppe', 'Jesper', 'Jimmi', 'Jimmy', 'Joachim', 'Johan', 'Johannes',
+ 'John', 'Johnny', 'Jon', 'Jonas', 'Jonathan', 'Josef', 'Jul', 'Julius', 'Jørgen', 'Jørn', 'Kai', 'Kaj',
+ 'Karl', 'Karlo', 'Karsten', 'Kasper', 'Kenneth', 'Kent', 'Kevin', 'Kjeld', 'Klaus', 'Knud', 'Kristian', 'Kristoffer',
+ 'Kurt', 'Lars', 'Lasse', 'Leif', 'Lennart', 'Leo', 'Leon', 'Louis', 'Lucas', 'Lukas', 'Mads', 'Magnus',
+ 'Malthe', 'Marc', 'Marcus', 'Marinus', 'Marius', 'Mark', 'Markus', 'Martin', 'Martinus', 'Mathias', 'Max', 'Michael',
+ 'Mikael', 'Mike', 'Mikkel', 'Mogens', 'Mohamad', 'Mohamed', 'Mohammad', 'Morten', 'Nick', 'Nicklas', 'Nicolai', 'Nicolaj',
+ 'Niels', 'Niklas', 'Nikolaj', 'Nils', 'Olaf', 'Olav', 'Ole', 'Oliver', 'Oscar', 'Oskar', 'Otto', 'Ove',
+ 'Palle', 'Patrick', 'Paul', 'Peder', 'Per', 'Peter', 'Philip', 'Poul', 'Preben', 'Rasmus', 'Rene', 'René',
+ 'Richard', 'Robert', 'Rolf', 'Rudolf', 'Rune', 'Sebastian', 'Sigurd', 'Simon', 'Simone', 'Steen', 'Stefan', 'Steffen',
+ 'Sten', 'Stig', 'Sune', 'Sven', 'Svend', 'Søren', 'Tage', 'Theodor', 'Thomas', 'Thor', 'Thorvald', 'Tim',
+ 'Tobias', 'Tom', 'Tommy', 'Tonny', 'Torben', 'Troels', 'Uffe', 'Ulrik', 'Vagn', 'Vagner', 'Valdemar', 'Vang',
+ 'Verner', 'Victor', 'Viktor', 'Villy', 'Walther', 'Werner', 'Wilhelm', 'William', 'Willy', 'Ã…ge', 'Bendt', 'Bjarke',
+ 'Chr', 'Eigil', 'Ejgil', 'Ejler', 'Ejnar', 'Ejner', 'Evald', 'Folmer', 'Gunner', 'Gurli', 'Hartvig', 'Herluf', 'Hjalmar',
+ 'Ingemann', 'Ingolf', 'Ingvard', 'Keld', 'Kresten', 'Laurids', 'Laurits', 'Lauritz', 'Ludvig', 'Lynge', 'Oluf', 'Osvald',
+ 'Povl', 'Richardt', 'Sigfred', 'Sofus', 'Thorkild', 'Viggo', 'Vilhelm', 'Villiam',
+ );
+
+ protected static $firstNameFemale = array(
+ 'Aase', 'Agathe', 'Agnes', 'Alberte', 'Alexandra', 'Alice', 'Alma', 'Amalie', 'Amanda', 'Andrea', 'Ane', 'Anette', 'Anita',
+ 'Anja', 'Ann', 'Anna', 'Annalise', 'Anne', 'Anne-Lise', 'Anne-Marie', 'Anne-Mette', 'Annelise', 'Annette', 'Anni', 'Annie',
+ 'Annika', 'Anny', 'Asta', 'Astrid', 'Augusta', 'Benedikte', 'Bente', 'Berit', 'Bertha', 'Betina', 'Bettina', 'Betty',
+ 'Birgit', 'Birgitte', 'Birte', 'Birthe', 'Bitten', 'Bodil', 'Britt', 'Britta', 'Camilla', 'Carina', 'Carla', 'Caroline',
+ 'Cathrine', 'Cecilie', 'Charlotte', 'Christa', 'Christen', 'Christiane', 'Christina', 'Christine', 'Clara', 'Conni', 'Connie', 'Conny',
+ 'Dagmar', 'Dagny', 'Diana', 'Ditte', 'Dora', 'Doris', 'Dorte', 'Dorthe', 'Ebba', 'Edel', 'Edith', 'Eleonora',
+ 'Eli', 'Elin', 'Eline', 'Elinor', 'Elisa', 'Elisabeth', 'Elise', 'Ella', 'Ellen', 'Ellinor', 'Elly', 'Elna',
+ 'Elsa', 'Else', 'Elsebeth', 'Elvira', 'Emilie', 'Emma', 'Emmy', 'Erna', 'Ester', 'Esther', 'Eva', 'Evelyn',
+ 'Frede', 'Frederikke', 'Freja', 'Frida', 'Gerda', 'Gertrud', 'Gitte', 'Grete', 'Grethe', 'Gudrun', 'Hanna', 'Hanne',
+ 'Hardy', 'Harriet', 'Hedvig', 'Heidi', 'Helen', 'Helena', 'Helene', 'Helga', 'Helle', 'Henny', 'Henriette', 'Herdis',
+ 'Hilda', 'Iben', 'Ida', 'Ilse', 'Ina', 'Inga', 'Inge', 'Ingeborg', 'Ingelise', 'Inger', 'Ingrid', 'Irene',
+ 'Iris', 'Irma', 'Isabella', 'Jane', 'Janni', 'Jannie', 'Jeanette', 'Jeanne', 'Jenny', 'Jes', 'Jette', 'Joan',
+ 'Johanna', 'Johanne', 'Jonna', 'Josefine', 'Josephine', 'Juliane', 'Julie', 'Jytte', 'Kaja', 'Kamilla', 'Karen', 'Karin',
+ 'Karina', 'Karla', 'Karoline', 'Kate', 'Kathrine', 'Katja', 'Katrine', 'Ketty', 'Kim', 'Kirsten', 'Kirstine', 'Klara',
+ 'Krista', 'Kristen', 'Kristina', 'Kristine', 'Laila', 'Laura', 'Laurine', 'Lea', 'Lena', 'Lene', 'Lilian', 'Lilli',
+ 'Lillian', 'Lilly', 'Linda', 'Line', 'Lis', 'Lisa', 'Lisbet', 'Lisbeth', 'Lise', 'Liselotte', 'Lissi', 'Lissy',
+ 'Liv', 'Lizzie', 'Lone', 'Lotte', 'Louise', 'Lydia', 'Lykke', 'Lærke', 'Magda', 'Magdalene', 'Mai', 'Maiken',
+ 'Maj', 'Maja', 'Majbritt', 'Malene', 'Maren', 'Margit', 'Margrethe', 'Maria', 'Mariane', 'Marianne', 'Marie', 'Marlene',
+ 'Martha', 'Martine', 'Mary', 'Mathilde', 'Matilde', 'Merete', 'Merethe', 'Meta', 'Mette', 'Mia', 'Michelle', 'Mie',
+ 'Mille', 'Minna', 'Mona', 'Monica', 'Nadia', 'Nancy', 'Nanna', 'Nicoline', 'Nikoline', 'Nina', 'Ninna', 'Oda',
+ 'Olga', 'Olivia', 'Orla', 'Paula', 'Pauline', 'Pernille', 'Petra', 'Pia', 'Poula', 'Ragnhild', 'Randi', 'Rasmine',
+ 'Rebecca', 'Rebekka', 'Rigmor', 'Rikke', 'Rita', 'Rosa', 'Rose', 'Ruth', 'Sabrina', 'Sandra', 'Sanne', 'Sara',
+ 'Sarah', 'Selma', 'Severin', 'Sidsel', 'Signe', 'Sigrid', 'Sine', 'Sofia', 'Sofie', 'Solveig', 'Solvejg', 'Sonja',
+ 'Sophie', 'Stephanie', 'Stine', 'Susan', 'Susanne', 'Tanja', 'Thea', 'Theodora', 'Therese', 'Thi', 'Thyra', 'Tina',
+ 'Tine', 'Tove', 'Trine', 'Ulla', 'Vera', 'Vibeke', 'Victoria', 'Viktoria', 'Viola', 'Vita', 'Vivi', 'Vivian',
+ 'Winnie', 'Yrsa', 'Yvonne', 'Agnete', 'Agnethe', 'Alfrida', 'Alvilda', 'Anine', 'Bolette', 'Dorthea', 'Gunhild',
+ 'Hansine', 'Inge-Lise', 'Jensine', 'Juel', 'Jørgine', 'Kamma', 'Kristiane', 'Maj-Britt', 'Margrete', 'Metha', 'Nielsine',
+ 'Oline', 'Petrea', 'Petrine', 'Pouline', 'Ragna', 'Sørine', 'Thora', 'Valborg', 'Vilhelmine',
+ );
+
+ /**
+ * @var array Danish middle names.
+ */
+ protected static $middleName = array(
+ 'Møller', 'Lund', 'Holm', 'Jensen', 'Juul', 'Nielsen', 'Kjær', 'Hansen', 'Skov', 'Østergaard', 'Vestergaard',
+ 'Nørgaard', 'Dahl', 'Bach', 'Friis', 'Søndergaard', 'Andersen', 'Bech', 'Pedersen', 'Bruun', 'Nygaard', 'Winther',
+ 'Bang', 'Krogh', 'Schmidt', 'Christensen', 'Hedegaard', 'Toft', 'Damgaard', 'Holst', 'Sørensen', 'Juhl', 'Munk',
+ 'Skovgaard', 'Søgaard', 'Aagaard', 'Berg', 'Dam', 'Petersen', 'Lind', 'Overgaard', 'Brandt', 'Larsen', 'Bak', 'Schou',
+ 'Vinther', 'Bjerregaard', 'Riis', 'Bundgaard', 'Kruse', 'Mølgaard', 'Hjorth', 'Ravn', 'Madsen', 'Rasmussen',
+ 'Jørgensen', 'Kristensen', 'Bonde', 'Bay', 'Hougaard', 'Dalsgaard', 'Kjærgaard', 'Haugaard', 'Munch', 'Bjerre', 'Due',
+ 'Sloth', 'Leth', 'Kofoed', 'Thomsen', 'Kragh', 'Højgaard', 'Dalgaard', 'Hjort', 'Kirkegaard', 'Bøgh', 'Beck', 'Nissen',
+ 'Rask', 'Høj', 'Brix', 'Storm', 'Buch', 'Bisgaard', 'Birch', 'Gade', 'Kjærsgaard', 'Hald', 'Lindberg', 'Høgh', 'Falk',
+ 'Koch', 'Thorup', 'Borup', 'Knudsen', 'Vedel', 'Poulsen', 'Bøgelund', 'Juel', 'Frost', 'Hvid', 'Bjerg', 'Bæk', 'Elkjær',
+ 'Hartmann', 'Kirk', 'Sand', 'Sommer', 'Skou', 'Nedergaard', 'Meldgaard', 'Brink', 'Lindegaard', 'Fischer', 'Rye',
+ 'Hoffmann', 'Daugaard', 'Gram', 'Johansen', 'Meyer', 'Schultz', 'Fogh', 'Bloch', 'Lundgaard', 'Brøndum', 'Jessen',
+ 'Busk', 'Holmgaard', 'Lindholm', 'Krog', 'Egelund', 'Engelbrecht', 'Buus', 'Korsgaard', 'Ellegaard', 'Tang', 'Steen',
+ 'Kvist', 'Olsen', 'Nørregaard', 'Fuglsang', 'Wulff', 'Damsgaard', 'Hauge', 'Sonne', 'Skytte', 'Brun', 'Kronborg',
+ 'Abildgaard', 'Fabricius', 'Bille', 'Skaarup', 'Rahbek', 'Borg', 'Torp', 'Klitgaard', 'Nørskov', 'Greve', 'Hviid',
+ 'Mørch', 'Buhl', 'Rohde', 'Mørk', 'Vendelbo', 'Bjørn', 'Laursen', 'Egede', 'Rytter', 'Lehmann', 'Guldberg', 'Rosendahl',
+ 'Krarup', 'Krogsgaard', 'Westergaard', 'Rosendal', 'Fisker', 'Højer', 'Rosenberg', 'Svane', 'Storgaard', 'Pihl',
+ 'Mohamed', 'Bülow', 'Birk', 'Hammer', 'Bro', 'Kaas', 'Clausen', 'Nymann', 'Egholm', 'Ingemann', 'Haahr', 'Olesen',
+ 'Nøhr', 'Brinch', 'Bjerring', 'Christiansen', 'Schrøder', 'Guldager', 'Skjødt', 'Højlund', 'Ørum', 'Weber',
+ 'Bødker', 'Bruhn', 'Stampe', 'Astrup', 'Schack', 'Mikkelsen', 'Høyer', 'Husted', 'Skriver', 'Lindgaard', 'Yde',
+ 'Sylvest', 'Lykkegaard', 'Ploug', 'Gammelgaard', 'Pilgaard', 'Brogaard', 'Degn', 'Kaae', 'Kofod', 'Grønbæk',
+ 'Lundsgaard', 'Bagge', 'Lyng', 'Rømer', 'Kjeldgaard', 'Hovgaard', 'Groth', 'Hyldgaard', 'Ladefoged', 'Jacobsen',
+ 'Linde', 'Lange', 'Stokholm', 'Bredahl', 'Hein', 'Mose', 'Bækgaard', 'Sandberg', 'Klarskov', 'Kamp', 'Green',
+ 'Iversen', 'Riber', 'Smedegaard', 'Nyholm', 'Vad', 'Balle', 'Kjeldsen', 'Strøm', 'Borch', 'Lerche', 'Grønlund',
+ 'Vestergård', 'Østergård', 'Nyborg', 'Qvist', 'Damkjær', 'Kold', 'Sønderskov', 'Bank',
+ );
+
+ /**
+ * @var array Danish last names.
+ */
+ protected static $lastName = array(
+ 'Jensen', 'Nielsen', 'Hansen', 'Pedersen', 'Andersen', 'Christensen', 'Larsen', 'Sørensen', 'Rasmussen', 'Petersen',
+ 'Jørgensen', 'Madsen', 'Kristensen', 'Olsen', 'Christiansen', 'Thomsen', 'Poulsen', 'Johansen', 'Knudsen', 'Mortensen',
+ 'Møller', 'Jacobsen', 'Jakobsen', 'Olesen', 'Frederiksen', 'Mikkelsen', 'Henriksen', 'Laursen', 'Lund', 'Schmidt',
+ 'Eriksen', 'Holm', 'Kristiansen', 'Clausen', 'Simonsen', 'Svendsen', 'Andreasen', 'Iversen', 'Jeppesen', 'Mogensen',
+ 'Jespersen', 'Nissen', 'Lauridsen', 'Frandsen', 'Østergaard', 'Jepsen', 'Kjær', 'Carlsen', 'Vestergaard', 'Jessen',
+ 'Nørgaard', 'Dahl', 'Christoffersen', 'Skov', 'Søndergaard', 'Bertelsen', 'Bruun', 'Lassen', 'Bach', 'Gregersen',
+ 'Friis', 'Johnsen', 'Steffensen', 'Kjeldsen', 'Bech', 'Krogh', 'Lauritsen', 'Danielsen', 'Mathiesen', 'Andresen',
+ 'Brandt', 'Winther', 'Toft', 'Ravn', 'Mathiasen', 'Dam', 'Holst', 'Nilsson', 'Lind', 'Berg', 'Schou', 'Overgaard',
+ 'Kristoffersen', 'Schultz', 'Klausen', 'Karlsen', 'Paulsen', 'Hermansen', 'Thorsen', 'Koch', 'Thygesen', 'Bak', 'Kruse',
+ 'Bang', 'Juhl', 'Davidsen', 'Berthelsen', 'Nygaard', 'Lorentzen', 'Villadsen', 'Lorenzen', 'Damgaard', 'Bjerregaard',
+ 'Lange', 'Hedegaard', 'Bendtsen', 'Lauritzen', 'Svensson', 'Justesen', 'Juul', 'Hald', 'Beck', 'Kofoed', 'Søgaard',
+ 'Meyer', 'Kjærgaard', 'Riis', 'Johannsen', 'Carstensen', 'Bonde', 'Ibsen', 'Fischer', 'Andersson', 'Bundgaard',
+ 'Johannesen', 'Eskildsen', 'Hemmingsen', 'Andreassen', 'Thomassen', 'Schrøder', 'Persson', 'Hjorth', 'Enevoldsen',
+ 'Nguyen', 'Henningsen', 'Jønsson', 'Olsson', 'Asmussen', 'Michelsen', 'Vinther', 'Markussen', 'Kragh', 'Thøgersen',
+ 'Johansson', 'Dalsgaard', 'Gade', 'Bjerre', 'Ali', 'Laustsen', 'Buch', 'Ludvigsen', 'Hougaard', 'Kirkegaard', 'Marcussen',
+ 'Mølgaard', 'Ipsen', 'Sommer', 'Ottosen', 'Müller', 'Krog', 'Hoffmann', 'Clemmensen', 'Nikolajsen', 'Brodersen',
+ 'Therkildsen', 'Leth', 'Michaelsen', 'Graversen', 'Frost', 'Dalgaard', 'Albertsen', 'Laugesen', 'Due', 'Ebbesen',
+ 'Munch', 'Svenningsen', 'Ottesen', 'Fisker', 'Albrechtsen', 'Axelsen', 'Erichsen', 'Sloth', 'Bentsen', 'Westergaard',
+ 'Bisgaard', 'Nicolaisen', 'Magnussen', 'Thuesen', 'Povlsen', 'Thorup', 'Høj', 'Bentzen', 'Johannessen', 'Vilhelmsen',
+ 'Isaksen', 'Bendixen', 'Ovesen', 'Villumsen', 'Lindberg', 'Thomasen', 'Kjærsgaard', 'Buhl', 'Kofod', 'Ahmed', 'Smith',
+ 'Storm', 'Christophersen', 'Bruhn', 'Matthiesen', 'Wagner', 'Bjerg', 'Gram', 'Nedergaard', 'Dinesen', 'Mouritsen',
+ 'Boesen', 'Borup', 'Abrahamsen', 'Wulff', 'Gravesen', 'Rask', 'Pallesen', 'Greve', 'Korsgaard', 'Haugaard', 'Josefsen',
+ 'Bæk', 'Espersen', 'Thrane', 'Mørch', 'Frank', 'Lynge', 'Rohde', 'Larsson', 'Hammer', 'Torp', 'Sonne', 'Boysen', 'Bay',
+ 'Pihl', 'Fabricius', 'Høyer', 'Birch', 'Skou', 'Kirk', 'Antonsen', 'Høgh', 'Damsgaard', 'Dall', 'Truelsen', 'Daugaard',
+ 'Fuglsang', 'Martinsen', 'Therkelsen', 'Jansen', 'Karlsson', 'Caspersen', 'Steen', 'Callesen', 'Balle', 'Bloch', 'Smidt',
+ 'Rahbek', 'Hjort', 'Bjørn', 'Skaarup', 'Sand', 'Storgaard', 'Willumsen', 'Busk', 'Hartmann', 'Ladefoged', 'Skovgaard',
+ 'Philipsen', 'Damm', 'Haagensen', 'Hviid', 'Duus', 'Kvist', 'Adamsen', 'Mathiassen', 'Degn', 'Borg', 'Brix', 'Troelsen',
+ 'Ditlevsen', 'Brøndum', 'Svane', 'Mohamed', 'Birk', 'Brink', 'Hassan', 'Vester', 'Elkjær', 'Lykke', 'Nørregaard',
+ 'Meldgaard', 'Mørk', 'Hvid', 'Abildgaard', 'Nicolajsen', 'Bengtsson', 'Stokholm', 'Ahmad', 'Wind', 'Rømer', 'Gundersen',
+ 'Carlsson', 'Grøn', 'Khan', 'Skytte', 'Bagger', 'Hendriksen', 'Rosenberg', 'Jonassen', 'Severinsen', 'Jürgensen',
+ 'Boisen', 'Groth', 'Bager', 'Fogh', 'Hussain', 'Samuelsen', 'Pilgaard', 'Bødker', 'Dideriksen', 'Brogaard', 'Lundberg',
+ 'Hansson', 'Schwartz', 'Tran', 'Skriver', 'Klitgaard', 'Hauge', 'Højgaard', 'Qvist', 'Voss', 'Strøm', 'Wolff', 'Krarup',
+ 'Green', 'Odgaard', 'Tønnesen', 'Blom', 'Gammelgaard', 'Jæger', 'Kramer', 'Astrup', 'Würtz', 'Lehmann', 'Koefoed',
+ 'Skøtt', 'Lundsgaard', 'Bøgh', 'Vang', 'Martinussen', 'Sandberg', 'Weber', 'Holmgaard', 'Bidstrup', 'Meier', 'Drejer',
+ 'Schneider', 'Joensen', 'Dupont', 'Lorentsen', 'Bro', 'Bagge', 'Terkelsen', 'Kaspersen', 'Keller', 'Eliasen', 'Lyberth',
+ 'Husted', 'Mouritzen', 'Krag', 'Kragelund', 'Nørskov', 'Vad', 'Jochumsen', 'Hein', 'Krogsgaard', 'Kaas', 'Tolstrup',
+ 'Ernst', 'Hermann', 'Børgesen', 'Skjødt', 'Holt', 'Buus', 'Gotfredsen', 'Kjeldgaard', 'Broberg', 'Roed', 'Sivertsen',
+ 'Bergmann', 'Bjerrum', 'Petersson', 'Smed', 'Jeremiassen', 'Nyborg', 'Borch', 'Foged', 'Terp', 'Mark', 'Busch',
+ 'Lundgaard', 'Boye', 'Yde', 'Hinrichsen', 'Matzen', 'Esbensen', 'Hertz', 'Westh', 'Holmberg', 'Geertsen', 'Raun',
+ 'Aagaard', 'Kock', 'Falk', 'Munk',
+ );
+
+ /**
+ * Randomly return a danish name.
+ *
+ * @return string
+ */
+ public static function middleName()
+ {
+ return static::randomElement(static::$middleName);
+ }
+
+ /**
+ * Randomly return a danish CPR number (Personnal identification number) format.
+ *
+ * @link http://cpr.dk/cpr/site.aspx?p=16
+ * @link http://en.wikipedia.org/wiki/Personal_identification_number_%28Denmark%29
+ *
+ * @return string
+ */
+ public static function cpr()
+ {
+ $birthdate = new \DateTime('@' . mt_rand(0, time()));
+
+ return sprintf('%s-%s', $birthdate->format('dmy'), static::numerify('%###'));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/PhoneNumber.php
new file mode 100644
index 000000000..af96d3f44
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/da_DK/PhoneNumber.php
@@ -0,0 +1,21 @@
+
+ */
+class PhoneNumber extends \Faker\Provider\PhoneNumber
+{
+ /**
+ * @var array Danish phonenumber formats.
+ */
+ protected static $formats = array(
+ '+45 ## ## ## ##',
+ '+45 #### ####',
+ '+45########',
+ '## ## ## ##',
+ '#### ####',
+ '########',
+ );
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/de_AT/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/de_AT/Address.php
new file mode 100644
index 000000000..4a2272ca4
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/de_AT/Address.php
@@ -0,0 +1,127 @@
+ 'Aargau'),
+ array('AI' => 'Appenzell Innerrhoden'),
+ array('AR' => 'Appenzell Ausserrhoden'),
+ array('BE' => 'Bern'),
+ array('BL' => 'Basel-Landschaft'),
+ array('BS' => 'Basel-Stadt'),
+ array('FR' => 'Freiburg'),
+ array('GE' => 'Genf'),
+ array('GL' => 'Glarus'),
+ array('GR' => 'Graubünden'),
+ array('JU' => 'Jura',),
+ array('LU' => 'Luzern'),
+ array('NE' => 'Neuenburg'),
+ array('NW' => 'Nidwalden'),
+ array('OW' => 'Obwalden'),
+ array('SG' => 'St. Gallen'),
+ array('SH' => 'Schaffhausen'),
+ array('SO' => 'Solothurn'),
+ array('SZ' => 'Schwyz'),
+ array('TG' => 'Thurgau'),
+ array('TI' => 'Tessin'),
+ array('UR' => 'Uri'),
+ array('VD' => 'Waadt'),
+ array('VS' => 'Wallis'),
+ array('ZG' => 'Zug'),
+ array('ZH' => 'Zürich')
+ );
+
+ protected static $country = array(
+ 'Afghanistan', 'Alandinseln', 'Albanien', 'Algerien', 'Amerikanisch-Ozeanien', 'Amerikanisch-Samoa', 'Amerikanische Jungferninseln', 'Andorra', 'Angola', 'Anguilla', 'Antarktis', 'Antigua und Barbuda', 'Argentinien', 'Armenien', 'Aruba', 'Aserbaidschan', 'Australien', 'Ägypten', 'Äquatorialguinea', 'Äthiopien', 'Äusseres Ozeanien',
+ 'Bahamas', 'Bahrain', 'Bangladesch', 'Barbados', 'Belarus', 'Belgien', 'Belize', 'Benin', 'Bermuda', 'Bhutan', 'Bolivien', 'Bosnien und Herzegowina', 'Botsuana', 'Bouvetinsel', 'Brasilien', 'Britische Jungferninseln', 'Britisches Territorium im Indischen Ozean', 'Brunei Darussalam', 'Bulgarien', 'Burkina Faso', 'Burundi',
+ 'Chile', 'China', 'Cookinseln', 'Costa Rica', 'Côte d’Ivoire',
+ 'Demokratische Republik Kongo', 'Demokratische Volksrepublik Korea', 'Deutschland', 'Dominica', 'Dominikanische Republik', 'Dschibuti', 'Dänemark',
+ 'Ecuador', 'El Salvador', 'Eritrea', 'Estland', 'Europäische Union',
+ 'Falklandinseln', 'Fidschi', 'Finnland', 'Frankreich', 'Französisch-Guayana', 'Französisch-Polynesien', 'Französische Süd- und Antarktisgebiete', 'Färöer',
+ 'Gabun', 'Gambia', 'Georgien', 'Ghana', 'Gibraltar', 'Grenada', 'Griechenland', 'Grönland', 'Guadeloupe', 'Guam', 'Guatemala', 'Guernsey', 'Guinea', 'Guinea-Bissau', 'Guyana',
+ 'Haiti', 'Heard- und McDonald-Inseln', 'Honduras',
+ 'Indien', 'Indonesien', 'Irak', 'Iran', 'Irland', 'Island', 'Isle of Man', 'Israel', 'Italien',
+ 'Jamaika', 'Japan', 'Jemen', 'Jersey', 'Jordanien',
+ 'Kaimaninseln', 'Kambodscha', 'Kamerun', 'Kanada', 'Kap Verde', 'Kasachstan', 'Katar', 'Kenia', 'Kirgisistan', 'Kiribati', 'Kokosinseln', 'Kolumbien', 'Komoren', 'Kongo', 'Kroatien', 'Kuba', 'Kuwait',
+ 'Laos', 'Lesotho', 'Lettland', 'Libanon', 'Liberia', 'Libyen', 'Liechtenstein', 'Litauen', 'Luxemburg',
+ 'Madagaskar', 'Malawi', 'Malaysia', 'Malediven', 'Mali', 'Malta', 'Marokko', 'Marshallinseln', 'Martinique', 'Mauretanien', 'Mauritius', 'Mayotte', 'Mazedonien', 'Mexiko', 'Mikronesien', 'Monaco', 'Mongolei', 'Montenegro', 'Montserrat', 'Mosambik', 'Myanmar',
+ 'Namibia', 'Nauru', 'Nepal', 'Neukaledonien', 'Neuseeland', 'Nicaragua', 'Niederlande', 'Niederländische Antillen', 'Niger', 'Nigeria', 'Niue', 'Norfolkinsel', 'Norwegen', 'Nördliche Marianen',
+ 'Oman', 'Osttimor', 'Österreich',
+ 'Pakistan', 'Palau', 'Palästinensische Gebiete', 'Panama', 'Papua-Neuguinea', 'Paraguay', 'Peru', 'Philippinen', 'Pitcairn', 'Polen', 'Portugal', 'Puerto Rico',
+ 'Republik Korea', 'Republik Moldau', 'Ruanda', 'Rumänien', 'Russische Föderation', 'Réunion',
+ 'Salomonen', 'Sambia', 'Samoa', 'San Marino', 'Saudi-Arabien', 'Schweden', 'Schweiz', 'Senegal', 'Serbien', 'Serbien und Montenegro', 'Seychellen', 'Sierra Leone', 'Simbabwe', 'Singapur', 'Slowakei', 'Slowenien', 'Somalia', 'Sonderverwaltungszone Hongkong', 'Sonderverwaltungszone Macao', 'Spanien', 'Sri Lanka', 'St. Barthélemy', 'St. Helena', 'St. Kitts und Nevis', 'St. Lucia', 'St. Martin', 'St. Pierre und Miquelon', 'St. Vincent und die Grenadinen', 'Sudan', 'Suriname', 'Svalbard und Jan Mayen', 'Swasiland', 'Syrien', 'São Tomé und PrÃncipe', 'Südafrika', 'Südgeorgien und die Südlichen Sandwichinseln',
+ 'Tadschikistan', 'Taiwan', 'Tansania', 'Thailand', 'Togo', 'Tokelau', 'Tonga', 'Trinidad und Tobago', 'Tschad', 'Tschechische Republik', 'Tunesien', 'Turkmenistan', 'Turks- und Caicosinseln', 'Tuvalu', 'Türkei',
+ 'Uganda', 'Ukraine', 'Unbekannte oder ungültige Region', 'Ungarn', 'Uruguay', 'Usbekistan',
+ 'Vanuatu', 'Vatikanstadt', 'Venezuela', 'Vereinigte Arabische Emirate', 'Vereinigte Staaten', 'Vereinigtes Königreich', 'Vietnam',
+ 'Wallis und Futuna', 'Weihnachtsinsel', 'Westsahara',
+ 'Zentralafrikanische Republik', 'Zypern',
+ );
+
+ protected static $cityFormats = array(
+ '{{cityName}}',
+ );
+
+ protected static $streetNameFormats = array(
+ '{{lastName}}{{streetSuffixShort}}',
+ '{{cityName}}{{streetSuffixShort}}',
+ '{{firstName}}-{{lastName}}-{{streetSuffixLong}}'
+ );
+
+ protected static $streetAddressFormats = array(
+ '{{streetName}} {{buildingNumber}}',
+ );
+ protected static $addressFormats = array(
+ "{{streetAddress}}\n{{postcode}} {{city}}",
+ );
+
+ /**
+ * Returns a random city name.
+ * @example Luzern
+ * @return string
+ */
+ public function cityName()
+ {
+ return static::randomElement(static::$cityNames);
+ }
+
+ /**
+ * Returns a random street suffix.
+ * @example str.
+ * @return string
+ */
+ public function streetSuffixShort()
+ {
+ return static::randomElement(static::$streetSuffixShort);
+ }
+
+ /**
+ * Returns a random street suffix.
+ * @example Strasse
+ * @return string
+ */
+ public function streetSuffixLong()
+ {
+ return static::randomElement(static::$streetSuffixLong);
+ }
+
+ /**
+ * Returns a canton
+ * @example array('BE' => 'Bern')
+ * @return array
+ */
+ public static function canton()
+ {
+ return static::randomElement(static::$canton);
+ }
+
+ /**
+ * Returns the abbreviation of a canton.
+ * @return string
+ */
+ public static function cantonShort()
+ {
+ $canton = static::canton();
+ return key($canton);
+ }
+
+ /**
+ * Returns the name of canton.
+ * @return string
+ */
+ public static function cantonName()
+ {
+ $canton = static::canton();
+ return current($canton);
+ }
+
+ public static function buildingNumber()
+ {
+ return static::regexify(self::numerify(static::randomElement(static::$buildingNumber)));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/de_CH/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/de_CH/Company.php
new file mode 100644
index 000000000..604ec5ae8
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/de_CH/Company.php
@@ -0,0 +1,15 @@
+generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ /**
+ * @example 'ΘεωδωÏόπουλος'
+ */
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ /**
+ * @example 'Κοκκίνου'
+ */
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/el_GR/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/el_GR/PhoneNumber.php
new file mode 100644
index 000000000..f8cf8b384
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/el_GR/PhoneNumber.php
@@ -0,0 +1,85 @@
+generator->parse(static::randomElement(static::$towns));
+ }
+
+ public function syllable()
+ {
+ return static::randomElement(static::$syllables);
+ }
+
+ public function direction()
+ {
+ return static::randomElement(static::$directions);
+ }
+
+ public function englishStreetName()
+ {
+ return static::randomElement(static::$englishStreetNames);
+ }
+
+ public function villageSuffix()
+ {
+ return static::randomElement(static::$villageSuffixes);
+ }
+
+ public function estateSuffix()
+ {
+ return static::randomElement(static::$estateSuffixes);
+ }
+
+ public function village()
+ {
+ return $this->generator->parse(static::randomElement(static::$villageNameFormats));
+ }
+
+ public function estate()
+ {
+ return $this->generator->parse(static::randomElement(static::$estateNameFormats));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/en_HK/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/en_HK/Internet.php
new file mode 100644
index 000000000..4d82d93a1
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/en_HK/Internet.php
@@ -0,0 +1,14 @@
+generator->parse(static::randomElement(static::$societyNameFormat));
+ }
+ /**
+ * @example Mumbai
+ */
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+ /**
+ * @example Vaishali Nagar
+ */
+ public function locality()
+ {
+ return $this->generator->parse(static::randomElement(static::$localityFormats));
+ }
+ /*
+ * @example Kharadi
+ */
+ public function localityName()
+ {
+ return $this->generator->parse(static::randomElement(static::$localityName));
+ }
+ /**
+ * @example Nagar
+ */
+ public function areaSuffix()
+ {
+ return static::randomElement(static::$areaSuffix);
+ }
+
+ /**
+ * @example 'Delhi'
+ */
+ public static function state()
+ {
+ return static::randomElement(static::$state);
+ }
+
+ /**
+ * @example 'DL'
+ */
+ public static function stateAbbr()
+ {
+ return static::randomElement(static::$stateAbbr);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/en_IN/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/en_IN/Internet.php
new file mode 100644
index 000000000..6ec16710a
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/en_IN/Internet.php
@@ -0,0 +1,9 @@
+generator->parse($format));
+ }
+
+ public function fixedLineNumber()
+ {
+ $format = static::randomElement(static::$fixedLineNumberFormats);
+
+ return static::numerify($this->generator->parse($format));
+ }
+
+ public function voipNumber()
+ {
+ $format = static::randomElement(static::$voipNumber);
+
+ return $this->generator->parse($format);
+ }
+
+ public function internationalCodePrefix()
+ {
+ $format = static::randomElement(static::$internationalCodePrefix);
+
+ return $this->generator->parse($format);
+ }
+
+ public function zeroToEight()
+ {
+ return static::randomElement(static::$zeroToEight);
+ }
+
+ public function oneToEight()
+ {
+ return static::randomElement(static::$oneToEight);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/en_UG/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/en_UG/Address.php
new file mode 100644
index 000000000..eb817e3a9
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/en_UG/Address.php
@@ -0,0 +1,101 @@
+generator->parse($format));
+ }
+
+ /**
+ * NPA-format area code
+ *
+ * @see https://en.wikipedia.org/wiki/North_American_Numbering_Plan#Numbering_system
+ *
+ * @return string
+ */
+ public static function areaCode()
+ {
+ $digits[] = self::numberBetween(2, 9);
+ $digits[] = self::randomDigit();
+ $digits[] = self::randomDigitNot($digits[1]);
+
+ return join('', $digits);
+ }
+
+ /**
+ * NXX-format central office exchange code
+ *
+ * @see https://en.wikipedia.org/wiki/North_American_Numbering_Plan#Numbering_system
+ *
+ * @return string
+ */
+ public static function exchangeCode()
+ {
+ $digits[] = self::numberBetween(2, 9);
+ $digits[] = self::randomDigit();
+
+ if ($digits[1] === 1) {
+ $digits[] = self::randomDigitNot(1);
+ } else {
+ $digits[] = self::randomDigit();
+ }
+
+ return join('', $digits);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/en_US/Text.php b/vendor/fzaninotto/faker/src/Faker/Provider/en_US/Text.php
new file mode 100644
index 000000000..b3c52582f
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/en_US/Text.php
@@ -0,0 +1,3720 @@
+format('Y'),
+ static::randomNumber(6, true),
+ static::randomElement(static::$legalEntities)
+ );
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/Internet.php
new file mode 100644
index 000000000..0c5c5f406
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/Internet.php
@@ -0,0 +1,18 @@
+generator->dateTimeThisCentury();
+ }
+ $birthDateString = $birthdate->format('ymd');
+ switch (strtolower($gender)) {
+ case static::GENDER_FEMALE:
+ $genderDigit = self::numberBetween(0, 4);
+ break;
+ case static::GENDER_MALE:
+ $genderDigit = self::numberBetween(5, 9);
+ break;
+ default:
+ $genderDigit = self::numberBetween(0, 9);
+ }
+ $sequenceDigits = str_pad(self::randomNumber(3), 3, 0, STR_PAD_BOTH);
+ $citizenDigit = ($citizen === true) ? '0' : '1';
+ $raceDigit = self::numberBetween(8, 9);
+
+ $partialIdNumber = $birthDateString . $genderDigit . $sequenceDigits . $citizenDigit . $raceDigit;
+
+ return $partialIdNumber . Luhn::computeCheckDigit($partialIdNumber);
+ }
+
+ /**
+ * @see https://en.wikipedia.org/wiki/Driving_licence_in_South_Africa
+ *
+ * @return string
+ */
+ public function licenceCode()
+ {
+ return static::randomElement(static::$licenceCodes);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/PhoneNumber.php
new file mode 100644
index 000000000..02a364d1b
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/en_ZA/PhoneNumber.php
@@ -0,0 +1,100 @@
+generator->parse($format));
+ }
+
+ public function tollFreeNumber()
+ {
+ $format = static::randomElement(static::$specialFormats);
+
+ return self::numerify($this->generator->parse($format));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/es_AR/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/es_AR/Address.php
new file mode 100644
index 000000000..70f503f07
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/es_AR/Address.php
@@ -0,0 +1,68 @@
+numberBetween(10000, 100000000);
+ }
+
+ return $id . $separator . $this->numberBetween(80000000, 100000000);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/es_VE/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/es_VE/PhoneNumber.php
new file mode 100644
index 000000000..74caecce5
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/es_VE/PhoneNumber.php
@@ -0,0 +1,29 @@
+
+ */
+class Person extends \Faker\Provider\Person
+{
+ /**
+ * @link https://news.err.ee/114745/most-popular-baby-names-of-2014
+ * @link https://www.stat.ee/public/apps/nimed/TOP
+ */
+ protected static $firstNameMale = array(
+ "Andrei", "Aleksei", "Andres", "Alexander", "Aivar", "Aleksander", "Artur", "Andrus", "Ants", "Artjom", "Anatoli", "Anton", "Arvo", "Aare", "Ain", "Aleksandr",
+ "Dmitri", "Daniil", "Daniel",
+ "Eduard", "Erik", "Enn",
+ "Fjodorov",
+ "Gennadi",
+ "Heino", "Henri", "Hugo",
+ "Igor", "Indrek", "Ivan", "Ilja",
+ "Jüri", "Jaan", "Jevgeni", "Jaanus", "Janek", "Jaak",
+ "Kristjan", "Kalev", "Karl", "Kalle", "Kaido", "Kevin", "Konstantin", "Kaspar", "Kirill", "Kristo", "Kalju", "Kristofer",
+ "Lauri", "Lembit", "Laur",
+ "Martin", "Margus", "Maksim", "Marko", "Mati", "Meelis", "Mihhail", "Marek", "Mihkel", "Mart", "Madis", "Markus", "Mark", "Marten",
+ "Nikolai", "Nikita", "Nikolay",
+ "Oleg", "Oliver", "Oskar",
+ "Peeter", "Priit", "Pavel",
+ "Rein", "Roman", "Raivo", "Rasmus", "Raul", "Robert", "Riho", "Robin", "Romet",
+ "Sergei", "Sander", "Sergey", "Siim", "Silver", "Sebastian",
+ "Toomas", "Tarmo", "Tõnu", "Tiit", "Tanel", "Taavi", "Toivo", "Tõnis",
+ "Urmas", "Ülo",
+ "Vladimir", "Viktor", "Valeri", "Vello", "Vadim", "Vitali", "Vladislav", "Vjatšeslav", "Victor",
+ );
+
+ /**
+ * @link https://news.err.ee/114745/most-popular-baby-names-of-2014
+ * @link https://www.stat.ee/public/apps/nimed/TOP
+ */
+ protected static $firstNameFemale = array(
+ "Aino", "Aleksandra", "Alisa", "Anastasia", "Anna", "Anne", "Anneli", "Anu", "Arina", "Annika", "Anastassia", "Alla", "Aili", "Alina", "Aime", "Antonina",
+ "Darja", "Diana",
+ "Elena", "Eliise", "Elisabeth", "Emma", "Ene", "Eve", "Eha", "Evi",
+ "Galina",
+ "Hanna", "Helen", "Heli", "Helle", "Helgi",
+ "Irina", "Inna", "Ingrid",
+ "Jekaterina", "Jelena", "Julia", "Jana",
+ "Kadri", "Katrin", "Kristi", "Kristiina", "Kristina", "Karin", "Kersti", "Kristel", "Kaja", "Külli", "Kätlin", "Krista",
+ "Laura", "Lenna", "Liisa", "Linda", "Lisandra", "Ljubov", "Ljudmila", "Liina", "Ljudmilla", "Larissa", "Liis", "Lea", "Laine", "Liudmila",
+ "Maie", "Malle", "Mare", "Maria", "Marina", "Marleen", "Marta", "Merike", "Mia", "Milana", "Mirtel", "Marika", "Merle", "Margit", "Milvi", "Maire", "Margarita", "Mari", "Maarja",
+ "Natalia", "Niina", "Nora", "Natalja", "Nadežda", "Nina",
+ "Olga", "Oksana",
+ "Piret", "Polina", "Pille",
+ "Reet", "Riina",
+ "Sandra", "Sirje", "Sofia", "Svetlana", "Silvi",
+ "Tamara", "Tatiana", "Tiina", "Tiiu", "Triin", "Tatjana", "Tiia",
+ "Ülle", "Urve",
+ "Valentina", "Viktoria", "Veera", "Veronika", "Vaike",
+ "Zinaida",
+ );
+
+ /**
+ * @link https://en.wikipedia.org/wiki/Category:Estonian-language_surnames
+ * @link https://www.stat.ee/public/apps/nimed/pere/TOP
+ */
+ protected static $lastName = array(
+ "Aleksejev", "Andrejev", "Allik", "Aas", "Aleksandrov", "Aare", "Aarma", "Aas", "Aasmäe", "Aav", "Aavik", "Allik", "Alver", "Andrejeva", "Aleksejeva", "Aleksandrova", "Allik", "Aas",
+ "Bogdanova", "Bogdanov",
+ "Eenpalu", "Eskola",
+ "Fjodorov", "Fjodorov", "Fjodorova", "Fjodorova",
+ "Grigorjev", "Grigorjeva",
+ "Hunt", "Hein", "Hein", "Härma",
+ "Ivanov", "Ilves", "Ilves", "Ivanov", "Ivanova", "Ivanova", "Ilves",
+ "Jõgi", "Jakobson", "Jakovlev", "Jürgenson", "Jegorov", "Järv", "Johanson", "Järve", "Jakobson", "Jänes", "Järve", "Järvis", "Jõgi", "Jõgi", "Johanson", "Jürgenson", "Järv", "Jakovleva", "Jegorova", "Järve", "Jakobson",
+ "Kuzmina", "Kalda", "Kozlova", "Kruus", "Kask", "Kukk", "Kuznetsov", "Koppel", "Kaasik", "Kuusk", "Karu", "Kütt", "Kallas", "Kivi", "Kangur", "Kuusik", "Kõiv", "Kozlov", "Kull", "Kuzmin", "Kalda", "Kaaleste", "Kaasik", "Käbin", "Kalda", "Kaljulaid", "Kaljurand", "Kallas", "Kallaste", "Kangro", "Kangur", "Kapp", "Kärner", "Karu", "Kask", "Käsper", "Kass", "Keres", "Keskküla", "Kesküla", "Kikkas", "Kingsepp", "Kirs", "Kirsipuu", "Kivi", "Klavan", "Kõiv", "Kokk", "Kontaveit", "Koppel", "Korjus", "Kotkas", "Kreek", "Kross", "Kruus", "Kukk", "Kull", "Kütt", "Kuusik", "Kuusk", "Kuznetsov", "Kuznetsova", "Kask", "Kukk", "Kuznetsova", "Koppel", "Kaasik", "Kuusk", "Karu", "Kütt", "Kallas", "Kivi", "Kuusik", "Kangur", "Kõiv", "Kull",
+ "Luik", "Lepik", "Lepp", "Lõhmus", "Liiv", "Laur", "Leppik", "Lebedev", "Laas", "Laar", "Laht", "Lass", "Laur", "Laurits", "Lemsalu", "Lepik", "Lepmets", "Lepp", "Leppik", "Levandi", "Liiv", "Lill", "Lindmaa", "Linna", "Lipp", "Lippmaa", "Lõhmus", "Loo", "Lõoke", "Luik", "Luts", "Luik", "Lepik", "Lepp", "Lõhmus", "Laur", "Liiv", "Leppik", "Lebedeva", "Laas",
+ "Männik", "Mänd", "Mitt", "Makarova", "Mägi", "Mets", "Mihhailov", "Mölder", "Morozov", "Mitt", "Männik", "Mõttus", "Mänd", "Makarov", "Mägi", "Mälk", "Mänd", "Männik", "Margiste", "Mark", "Masing", "Mets", "Mihhailov", "Mihhailova", "Mölder", "Must", "Mägi", "Mets", "Mihhailova", "Mölder", "Morozova",
+ "Nikolajev", "Nõmm", "Nikitin", "Novikov", "Nõmmik", "Nurme", "Nurmsalu", "Nõmm", "Nikitina", "Nikolajeva",
+ "Orlova", "Orav", "Oja", "Ots", "Orav", "Orlov", "Oja", "Olesk", "Öpik", "Orav", "Ots", "Oja", "Ots",
+ "Petrov", "Pärn", "Põder", "Pavlov", "Popov", "Peterson", "Puusepp", "Paju", "Põld", "Pukk", "Paas", "Palm", "Pääsuke", "Padar", "Pärn", "Pavlov", "Pavlova", "Peebo", "Peetre", "Peterson", "Petrov", "Petrova", "Pihlak", "Piho", "Piip", "Põder", "Põld", "Popov", "Popova", "Poska", "Puhvel", "Pütsep", "Puusepp", "Petrova", "Pärn", "Pavlova", "Põder", "Peterson", "Popova", "Puusepp", "Paas", "Paju", "Pukk", "Parts", "Palm", "Põld",
+ "Romanova", "Rand", "Roos", "Rebane", "Raudsepp", "Raud", "Rand", "Roos", "Rätsep", "Raag", "Raud", "Raudsepp", "Rebane", "Reek", "Reinsalu", "Rooba", "Roolaid", "Rootare", "Rummo", "Rüütel", "Rüütli", "Rebane", "Raudsepp", "Raud",
+ "Saar", "Sepp", "Smirnov", "Stepanov", "Semjonov", "Sokolov", "Sild", "Sarapuu", "Saks", "Saar", "Salumäe", "Semjonov", "Sepp", "Sibul", "Siimar", "Simm", "Sirel", "Sisask", "Smirnov", "Smirnova", "Sokk", "Sokolov", "Soosaar", "Stepanov", "Stepanova", "Susi", "Saar", "Sepp", "Smirnova", "Stepanova", "Sokolova", "Saks", "Sarapuu", "Sild", "Semjonova",
+ "Tamme", "Tomson", "Tamm", "Teder", "Toom", "Tomson", "Tamme", "Talts", "Tamm", "Tamme", "Tarvas", "Teder", "Toom", "Toome", "Toots", "Tamm", "Teder", "Toom",
+ "Uibo", "Uibo",
+ "Vassiljev", "Vaher", "Volkov", "Valk", "Vaher", "Vahtra", "Vaino", "Vainola", "Välbe", "Valdma", "Väljas", "Valk", "Vassiljev", "Vassiljeva", "Vesik", "Veski", "Viiding", "Vitsut", "Võigemast", "Volkov", "Volkova", "Võsu", "Vassiljeva", "Vaher", "Volkova",
+ );
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Address.php
new file mode 100644
index 000000000..f22091384
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Address.php
@@ -0,0 +1,100 @@
+generator->parse($format);
+ }
+
+ /**
+ * @example 'کد پستی'
+ */
+ public static function postcodePrefix()
+ {
+ return static::randomElement(static::$postcodePrefix);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Company.php
new file mode 100644
index 000000000..0de47b351
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Company.php
@@ -0,0 +1,57 @@
+generator->parse($format));
+ }
+
+ /**
+ * @example 'ahmad.ir'
+ */
+ public function domainName()
+ {
+ return static::randomElement(static::$lastNameAscii) . '.' . $this->tld();
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Person.php b/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Person.php
new file mode 100644
index 000000000..e332968d8
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/Person.php
@@ -0,0 +1,201 @@
+ 1; $i--) {
+ $sum += $subNationalCodeString[$count] * ($i);
+ $count++;
+ }
+
+ if (($sum % 11) < 2) {
+ return $sum % 11;
+ }
+ return 11 - ($sum % 11);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/PhoneNumber.php
new file mode 100644
index 000000000..fb80b1d22
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fa_IR/PhoneNumber.php
@@ -0,0 +1,75 @@
+ 5) {
+ throw new \InvalidArgumentException('indexSize must be at most 5');
+ }
+
+ $words = $this->getConsecutiveWords($indexSize);
+ $result = array();
+ $resultLength = 0;
+ // take a random starting point
+ $next = static::randomKey($words);
+ while ($resultLength < $maxNbChars && isset($words[$next])) {
+ // fetch a random word to append
+ $word = static::randomElement($words[$next]);
+
+ // calculate next index
+ $currentWords = explode(' ', $next);
+
+ $currentWords[] = $word;
+ array_shift($currentWords);
+ $next = implode(' ', $currentWords);
+
+ if ($resultLength == 0 && !preg_match('/^[\x{0600}-\x{06FF}]/u', $word)) {
+ continue;
+ }
+ // append the element
+ $result[] = $word;
+ $resultLength += strlen($word) + 1;
+ }
+
+ // remove the element that caused the text to overflow
+ array_pop($result);
+
+ // build result
+ $result = implode(' ', $result);
+
+ return $result.'.';
+ }
+
+ /**
+ * License: Creative Commons Attribution-ShareAlike License
+ *
+ * Title: مدیر مدرسه
+ * Author: جلال آل‌اØÙ…د
+ * Language: Persian
+ *
+ * @see http://fa.wikisource.org/wiki/%D9%85%D8%AF%DB%8C%D8%B1_%D9%85%D8%AF%D8%B1%D8%B3%D9%87
+ * @var string
+ */
+ protected static $baseText = <<<'EOT'
+از در Ú©Ù‡ وارد شدم سیگارم دستم بود. زورم آمد سلام کنم. همین طوری دنگم Ú¯Ø±ÙØªÙ‡ بود قد باشم. رئیس ÙØ±Ù‡Ù†Ú¯ Ú©Ù‡ اجازه‌ی نشستن داد، نگاهش Ù„ØØ¸Ù‡â€ŒØ§ÛŒ روی دستم Ù…Ú©Ø« کرد Ùˆ بعد چیزی را Ú©Ù‡ می‌نوشت، تمام کرد Ùˆ می‌خواست متوجه من بشود Ú©Ù‡ رونویس ØÚ©Ù… را روی میزش گذاشته بودم. ØØ±ÙÛŒ نزدیم. رونویس را با کاغذهای ضمیمه‌اش زیر Ùˆ رو کرد Ùˆ بعد غبغب انداخت Ùˆ آرام Ùˆ مثلاً خالی از عصبانیت Ú¯ÙØª:
+
+- جا نداریم آقا. این Ú©Ù‡ نمی‌شه! هر روز یه ØÚ©Ù… می‌دند دست یکی Ù…ÛŒâ€ŒÙØ±Ø³ØªÙ†Ø´ سراغ من... دیروز به آقای مدیر Ú©Ù„...
+
+ØÙˆØµÙ„ه‌ی این اباطیل را نداشتم. ØØ±ÙØ´ را بریدم Ú©Ù‡:
+
+- ممکنه خواهش کنم زیر همین ورقه مرقوم Ø¨ÙØ±Ù…ایید؟
+
+Ùˆ سیگارم را توی زیرسیگاری براق روی میزش تکاندم. روی میز، پاک Ùˆ مرتب بود. درست مثل اتاق همان مهمان‌خانه‌ی تازه‌عروس‌ها. هر چیز به جای خود Ùˆ نه یک ذره گرد. Ùقط خاکستر سیگار من زیادی بود. مثل تÙÛŒ در صورت تازه تراشیده‌ای.... قلم را برداشت Ùˆ زیر ØÚ©Ù… چیزی نوشت Ùˆ امضا کرد Ùˆ من از در آمده بودم بیرون. خلاص. تØÙ…Ù„ این یکی را نداشتم. با اداهایش. پیدا بود Ú©Ù‡ تازه رئیس شده. زورکی غبغب می‌انداخت Ùˆ ØØ±ÙØ´ را آهسته توی چشم آدم می‌زد. انگار برای شنیدنش گوش لازم نیست. صد Ùˆ پنجاه تومان در کارگزینی Ú©Ù„ مایه گذاشته بودم تا این ØÚ©Ù… را به امضا رسانده بودم. توصیه هم برده بودم Ùˆ تازه دو ماه هم دویده بودم. مو، لای درزش Ù†Ù…ÛŒâ€ŒØ±ÙØª. می‌دانستم Ú©Ù‡ Ú†Ù‡ او بپذیرد، Ú†Ù‡ نپذیرد، کار تمام است. خودش هم می‌دانست. ØØªÙ…اً هم دستگیرش شد Ú©Ù‡ با این Ù†Ú© Ùˆ نالی Ú©Ù‡ می‌کرد، خودش را کن٠کرده. ولی کاری بود Ùˆ شده بود. در کارگزینی Ú©Ù„ØŒ Ø³ÙØ§Ø±Ø´ کرده بودند Ú©Ù‡ برای خالی نبودن عریضه رونویس را به رؤیت رئیس ÙØ±Ù‡Ù†Ú¯ هم برسانم تازه این طور شد. Ùˆ گر نه بالی ØÚ©Ù… کارگزینی Ú©Ù„ Ú†Ù‡ کسی می‌توانست ØØ±ÙÛŒ بزند؟ یک وزارت خانه بود Ùˆ یک کارگزینی! شوخی Ú©Ù‡ نبود. ته دلم قرص‌تر از این‌ها بود Ú©Ù‡ Ù…ØØªØ§Ø¬ به این استدلال‌ها باشم. اما به نظرم همه‌ی این تقصیرها از این سیگار لعنتی بود Ú©Ù‡ به خیال خودم خواسته بودم خرجش را از Ù…ØÙ„ اضاÙÙ‡ ØÙ‚وق شغل جدیدم در بیاورم. البته از معلمی، هم اÙقم نشسته بود. ده سال «الÙ.ب.» درس دادن Ùˆ قیاÙه‌های بهت‌زده‌ی بچه‌های مردم برای مزخرÙ‌ترین چرندی Ú©Ù‡ می‌گویی... Ùˆ استغناء با غین Ùˆ استقراء با قا٠و خراسانی Ùˆ هندی Ùˆ قدیمی‌ترین شعر دری Ùˆ صنعت ارسال مثل Ùˆ ردالعجز... Ùˆ از این Ù…Ø²Ø®Ø±ÙØ§Øª! دیدم دارم خر می‌شوم. Ú¯ÙØªÙ… مدیر بشوم. مدیر دبستان! دیگر نه درس خواهم داد Ùˆ نه مجبور خواهم بود برای ÙØ±Ø§Ø± از اتلا٠وقت، در Ø§Ù…ØªØØ§Ù† تجدیدی به هر اØÙ…Ù‚ بی‌شعوری Ù‡ÙØª بدهم تا ایام آخر تابستانم را Ú©Ù‡ لذیذترین تکه‌ی تعطیلات است، نجات داده باشم. این بود Ú©Ù‡ راه Ø§ÙØªØ§Ø¯Ù…. Ø±ÙØªÙ… Ùˆ از اهلش پرسیدم. از یک کار چاق Ú©Ù†. دستم را توی دست کارگزینی گذاشت Ùˆ قول Ùˆ قرار Ùˆ طرÙین خوش Ùˆ خرم Ùˆ یک روز هم نشانی مدرسه را دستم دادند Ú©Ù‡ بروم وارسی، Ú©Ù‡ باب میلم هست یا نه.
+
+Ùˆ Ø±ÙØªÙ…. مدرسه دو طبقه بود Ùˆ نوساز بود Ùˆ در دامنه‌ی کوه تنها Ø§ÙØªØ§Ø¯Ù‡ بود Ùˆ Ø¢ÙØªØ§Ø¨â€ŒØ±Ùˆ بود. یک ÙØ±Ù‡Ù†Ú¯â€ŒØ¯ÙˆØ³Øª خرپول، عمارتش را وسط زمین خودش ساخته بود Ùˆ بیست Ùˆ پنج سال هم در اختیار ÙØ±Ù‡Ù†Ú¯ گذاشته بود Ú©Ù‡ مدرسه‌اش کنند Ùˆ Ø±ÙØª Ùˆ آمد بشود Ùˆ جاده‌ها کوبیده بشود Ùˆ این قدر ازین بشودها بشود، تا دل ننه باباها بسوزد Ùˆ برای این‌که راه بچه‌هاشان را کوتاه بکنند، بیایند همان اطرا٠مدرسه را بخرند Ùˆ خانه بسازند Ùˆ زمین یارو از متری یک عباسی بشود صد تومان. یارو اسمش را هم روی دیوار مدرسه کاشی‌کاری کرده بود. هنوز در Ùˆ همسایه پیدا نکرده بودند Ú©Ù‡ ØØ±Ù‌شان بشود Ùˆ لنگ Ùˆ پاچه‌ی سعدی Ùˆ باباطاهر را بکشند میان Ùˆ یک ورق دیگر از تاریخ‌الشعرا را بکوبند روی نبش دیوار کوچه‌شان. تابلوی مدرسه هم ØØ³Ø§Ø¨ÛŒ Ùˆ بزرگ Ùˆ خوانا. از صد متری داد می‌زد Ú©Ù‡ توانا بود هر.... هر Ú†Ù‡ دلتان بخواهد! با شیر Ùˆ خورشیدش Ú©Ù‡ آن بالا سر، سه پا ایستاده بود Ùˆ زورکی تعادل خودش را ØÙظ می‌کرد Ùˆ خورشید خانم روی کولش با ابروهای پیوسته Ùˆ قمچیلی Ú©Ù‡ به دست داشت Ùˆ تا سه تیر پرتاب، اطرا٠مدرسه بیابان بود. درندشت Ùˆ بی آب Ùˆ آبادانی Ùˆ آن ته رو به شمال، ردی٠کاج‌های درهم ÙØ±Ùˆ Ø±ÙØªÙ‡â€ŒØ§ÛŒ Ú©Ù‡ از سر دیوار Ú¯Ù„ÛŒ یک باغ پیدا بود روی آسمان لکه‌ی دراز Ùˆ تیره‌ای زده بود. ØØªÙ…اً تا بیست Ùˆ پنج سال دیگر همه‌ی این اطرا٠پر می‌شد Ùˆ بوق ماشین Ùˆ ونگ ونگ بچه‌ها Ùˆ ÙØ±ÛŒØ§Ø¯ لبویی Ùˆ زنگ Ø±ÙˆØ²Ù†Ø§Ù…Ù‡â€ŒÙØ±ÙˆØ´ÛŒ Ùˆ عربده‌ی Ú¯Ù„ به سر دارم خیار! نان یارو توی روغن بود.
+
+- راستی شاید متری ده دوازده شاهی بیشتر نخریده باشد؟ شاید هم زمین‌ها را همین جوری به ثبت داده باشد؟ هان؟
+
+- اØÙ…Ù‚ به توچه؟!...
+
+بله این Ùکرها را همان روزی کردم Ú©Ù‡ ناشناس به مدرسه سر زدم Ùˆ آخر سر هم به این نتیجه رسیدم Ú©Ù‡ مردم ØÙ‚ دارند جایی بخوابند Ú©Ù‡ آب زیرشان نرود.
+
+- تو اگر مردی، عرضه داشته باش مدیر همین مدرسه هم بشو.
+
+Ùˆ Ø±ÙØªÙ‡ بودم Ùˆ دنبال کار را Ú¯Ø±ÙØªÙ‡ بودم تا رسیده بودم به این‌جا. همان روز وارسی Ùهمیده بودم Ú©Ù‡ مدیر قبلی مدرسه زندانی است. لابد کله‌اش بوی قرمه‌سبزی می‌داده Ùˆ باز لابد ØØ§Ù„ا دارد Ú©ÙØ§Ø±Ù‡â€ŒÛŒ گناهانی را می‌دهد Ú©Ù‡ یا خودش نکرده یا آهنگری در بلخ کرده. جزو پر قیچی‌های رئیس ÙØ±Ù‡Ù†Ú¯ هم کسی نبود Ú©Ù‡ با مدیرشان، اضاÙÙ‡ ØÙ‚وقی نصیبش بشود Ùˆ ناچار سر Ùˆ دستی برای این کار بشکند. خارج از مرکز هم نداشت. این معلومات را توی کارگزینی به دست آورده بودم. هنوز «گه خوردم نامه‌نویسی» هم مد نشده بود Ú©Ù‡ بگویم یارو به این زودی‌ها از سولدونی در خواهد آمد. Ùکر نمی‌کردم Ú©Ù‡ دیگری هم برای این وسط بیابان دلش Ù„Ú© زده باشد با زمستان سختش Ùˆ با Ø±ÙØª Ùˆ آمد دشوارش.
+
+این بود Ú©Ù‡ خیالم Ø±Ø§ØØª بود. از همه‌ی این‌ها گذشته کارگزینی Ú©Ù„ مواÙقت کرده بود! دست است Ú©Ù‡ پیش از بلند شدن بوی اسکناس، آن جا هم دو سه تا عیب شرعی Ùˆ عرÙÛŒ Ú¯Ø±ÙØªÙ‡ بودند Ùˆ مثلاً Ú¯ÙØªÙ‡ بودن لابد کاسه‌ای زیر نیم کاسه است Ú©Ù‡ Ùلانی یعنی من، با ده سال سابقه‌ی تدریس، می‌خواهد مدیر دبستان بشود! غرض‌شان این بود Ú©Ù‡ لابد خل شدم Ú©Ù‡ از شغل مهم Ùˆ Ù…ØØªØ±Ù… دبیری دست می‌شویم. ماهی صد Ùˆ پنجاه تومان ØÙ‚ مقام در آن روزها پولی نبود Ú©Ù‡ بتوانم نادیده بگیرم. Ùˆ تازه اگر ندیده Ù…ÛŒâ€ŒÚ¯Ø±ÙØªÙ… چه؟ باز باید بر می‌گشتم به این کلاس‌ها Ùˆ این جور ØÙ…اقت‌ها. این بود Ú©Ù‡ پیش رئیس ÙØ±Ù‡Ù†Ú¯ØŒ صا٠برگشتم به کارگزینی Ú©Ù„ØŒ سراغ آن Ú©Ù‡ بÙهمی Ù†Ùهمی، دلال کارم بود. Ùˆ رونویس ØÚ©Ù… را گذاشتم Ùˆ Ú¯ÙØªÙ… Ú©Ù‡ Ú†Ù‡ طور شد Ùˆ آمدم بیرون.
+
+دو روز بعد Ø±ÙØªÙ… سراغش. معلوم شد Ú©Ù‡ ØØ¯Ø³Ù… درست بوده است Ùˆ رئیس ÙØ±Ù‡Ù†Ú¯ Ú¯ÙØªÙ‡ بوده: «من از این لیسانسه‌های پر Ø§ÙØ§Ø¯Ù‡ نمی‌خواهم Ú©Ù‡ سیگار به دست توی هر اتاقی سر می‌کنند.»
+
+Ùˆ یارو برایش Ú¯ÙØªÙ‡ بود Ú©Ù‡ اصلاً وابدا..! Ùلانی همچین Ùˆ همچون است Ùˆ مثقالی Ù‡ÙØª صنار با دیگران ÙØ±Ù‚ دارد Ùˆ این هندوانه‌ها Ùˆ خیال من Ø±Ø§ØØª باشد Ùˆ پنج‌شنبه یک Ù‡ÙØªÙ‡â€ŒÛŒ دیگر خودم بروم پهلوی او... Ùˆ این کار را کردم. این بار رئیس ÙØ±Ù‡Ù†Ú¯ جلوی پایم بلند شد Ú©Ù‡: «ای آقا... چرا اول Ù†ÙØ±Ù…ودید؟!...» Ùˆ از کارمندهایش گله کرد Ùˆ به قول خودش، مرا «در جریان موقعیت Ù…ØÙ„» گذاشت Ùˆ بعد با ماشین خودش مرا به مدرسه رساند Ùˆ Ú¯ÙØª زنگ را زودتر از موعد زدند Ùˆ در ØØ¶ÙˆØ± معلم‌ها Ùˆ ناظم، نطق غرایی در خصائل مدیر جدید – Ú©Ù‡ من باشم – کرد Ùˆ بعد هم مرا گذاشت Ùˆ Ø±ÙØª با یک مدرسه‌ی شش کلاسه‌ی «نوبنیاد» Ùˆ یک ناظم Ùˆ Ù‡ÙØª تا معلم Ùˆ دویست Ùˆ سی Ùˆ پنج تا شاگرد. دیگر ØØ³Ø§Ø¨ÛŒ مدیر مدرسه شده بودم!
+
+ناظم، جوان رشیدی بود Ú©Ù‡ بلند ØØ±Ù می‌زد Ùˆ به Ø±Ø§ØØªÛŒ امر Ùˆ نهی می‌کرد Ùˆ بیا Ùˆ برویی داشت Ùˆ با شاگردهای درشت، روی هم ریخته بود Ú©Ù‡ خودشان ترتیب کارها را می‌دادند Ùˆ پیدا بود Ú©Ù‡ به سر خر Ø§ØØªÛŒØ§Ø¬ÛŒ ندارد Ùˆ بی‌مدیر هم می‌تواند گلیم مدرسه را از آب بکشد. معلم کلاس چهار خیلی گنده بود. دو تای یک آدم ØØ³Ø§Ø¨ÛŒ. توی Ø¯ÙØªØ±ØŒ اولین چیزی Ú©Ù‡ به چشم می‌آمد. از آن‌هایی Ú©Ù‡ اگر توی Ú©ÙˆÚ†Ù‡ ببینی، خیال می‌کنی مدیر Ú©Ù„ است. Ù„ÙØ¸ قلم ØØ±Ù می‌زد Ùˆ شاید به همین دلیل بود Ú©Ù‡ وقتی رئیس ÙØ±Ù‡Ù†Ú¯ Ø±ÙØª Ùˆ ØªØ´Ø±ÛŒÙØ§Øª را با خودش برد، از طر٠همکارانش تبریک ورود Ú¯ÙØª Ùˆ اشاره کرد به اینکه «ان‌شاءالله زیر سایه‌ی سرکار، سال دیگر کلاس‌های دبیرستان را هم خواهیم داشت.» پیدا بود Ú©Ù‡ این هیکل کم‌کم دارد از سر دبستان زیادی می‌کند! وقتی ØØ±Ù می‌زد همه‌اش درین Ùکر بودم Ú©Ù‡ با نان آقا معلمی Ú†Ù‡ طور می‌شد چنین هیکلی به هم زد Ùˆ چنین سر Ùˆ تیپی داشت؟ Ùˆ راستش تصمیم Ú¯Ø±ÙØªÙ… Ú©Ù‡ از ÙØ±Ø¯Ø§ ØµØ¨Ø Ø¨Ù‡ ØµØ¨Ø Ø±ÛŒØ´Ù… را بتراشم Ùˆ یخه‌ام تمیز باشد Ùˆ اتوی شلوارم تیز.
+
+معلم کلاس اول باریکه‌ای بود، سیاه سوخته. با ته ریشی Ùˆ سر ماشین کرده‌ای Ùˆ یخه‌ی بسته. بی‌کراوات. شبیه میرزابنویس‌های دم پست‌خانه. ØØªÛŒ نوکر باب می‌نمود. Ùˆ من آن روز نتوانستم بÙهمم وقتی ØØ±Ù می‌زند کجا را نگاه می‌کند. با هر جیغ کوتاهی Ú©Ù‡ می‌زد هرهر می‌خندید. با این قضیه نمی‌شد کاری کرد. معلم کلاس سه، یک جوان ترکه‌ای بود؛ بلند Ùˆ با صورت استخوانی Ùˆ ریش از ته تراشیده Ùˆ یخه‌ی بلند آهاردار. مثل ÙØ±Ùره می‌جنبید. چشم‌هایش برق عجیبی می‌زد Ú©Ù‡ Ùقط از هوش نبود، چیزی از ناسلامتی در برق چشم‌هایش بود Ú©Ù‡ مرا واداشت از ناظم بپرسم مبادا مسلول باشد. البته مسلول نبود، تنها بود Ùˆ در دانشگاه درس می‌خواند. کلاس‌های پنجم Ùˆ ششم را دو Ù†ÙØ± با هم اداره می‌کردند. یکی ÙØ§Ø±Ø³ÛŒ Ùˆ شرعیات Ùˆ تاریخ، جغراÙÛŒ Ùˆ کاردستی Ùˆ این جور سرگرمی‌ها را Ù…ÛŒâ€ŒÚ¯ÙØªØŒ Ú©Ù‡ جوانکی بود بریانتین زده، با شلوار پاچه تنگ Ùˆ پوشت Ùˆ کراوات زرد Ùˆ پهنی Ú©Ù‡ نعش یک لنگر بزرگ آن را روی سینه‌اش Ù†Ú¯Ù‡ داشته بود Ùˆ دائماً دستش ØÙ…ایل موهای سرش بود Ùˆ دم به دم توی شیشه‌ها نگاه می‌کرد. Ùˆ آن دیگری Ú©Ù‡ ØØ³Ø§Ø¨ Ùˆ مرابØÙ‡ Ùˆ چیزهای دیگر Ù…ÛŒâ€ŒÚ¯ÙØªØŒ جوانی بود موقر Ùˆ سنگین مازندرانی به نظر می‌آمد Ùˆ به خودش اطمینان داشت. غیر از این‌ها، یک معلم ورزش هم داشتیم Ú©Ù‡ دو Ù‡ÙØªÙ‡ بعد دیدمش Ùˆ اصÙهانی بود Ùˆ از آن قاچاق‌ها.
+
+رئیس ÙØ±Ù‡Ù†Ú¯ Ú©Ù‡ Ø±ÙØªØŒ گرم Ùˆ نرم از همه‌شان ØØ§Ù„ Ùˆ اØÙˆØ§Ù„ پرسیدم. بعد به همه سیگار تعار٠کردم. سراپا همکاری Ùˆ همدردی بود. از کار Ùˆ بار هر کدامشان پرسیدم. Ùقط همان معلم کلاس سه، دانشگاه Ù…ÛŒâ€ŒØ±ÙØª. آن Ú©Ù‡ لنگر به سینه انداخته بود، شب‌ها انگلیسی می‌خواند Ú©Ù‡ برود آمریکا. چای Ùˆ بساطی در کار نبود Ùˆ ربع ساعت‌های ØªÙØ±ÛŒØØŒ Ùقط توی Ø¯ÙØªØ± جمع می‌شدند Ùˆ دوباره از نو. Ùˆ این نمی‌شد. باید همه‌ی سنن را رعایت کرد. دست کردم Ùˆ یک پنج تومانی روی میز گذاشتم Ùˆ قرار شد قبل Ùˆ منقلی تهیه کنند Ùˆ خودشان چای را راه بیندازند.
+
+بعد از زنگ قرار شد من سر ص٠نطقی بکنم. ناظم قضیه را در دو سه کلمه برای بچه‌ها Ú¯ÙØª Ú©Ù‡ من رسیدم Ùˆ همه دست زدند. چیزی نداشتم برایشان بگویم. Ùقط یادم است اشاره‌ای به این کردم Ú©Ù‡ مدیر خیلی دلش می‌خواست یکی از شما را به جای ÙØ±Ø²Ù†Ø¯ داشته باشد Ùˆ ØØ§Ù„ا نمی‌داند با این همه ÙØ±Ø²Ù†Ø¯ Ú†Ù‡ بکند؟! Ú©Ù‡ بی‌صدا خندیدند Ùˆ در میان صÙ‌های عقب یکی Ù¾Ú©ÛŒ زد به خنده. واهمه برم داشت Ú©Ù‡ «نه بابا. کار ساده‌ای هم نیست!» قبلاً Ùکر کرده بودم Ú©Ù‡ می‌روم Ùˆ ÙØ§Ø±Øº از دردسر اداره‌ی کلاس، در اتاق را روی خودم می‌بندم Ùˆ کار خودم را می‌کنم. اما ØØ§Ù„ا می‌دیدم به این سادگی‌ها هم نیست. اگر ÙØ±Ø¯Ø§ یکی‌شان زد سر اون یکی را شکست، اگر یکی زیر ماشین Ø±ÙØªØ› اگر یکی از ایوان Ø§ÙØªØ§Ø¯Ø› Ú†Ù‡ خاکی به سرم خواهم ریخت؟
+
+ØØ§Ù„ا من مانده بودم Ùˆ ناظم Ú©Ù‡ چیزی از لای در آهسته خزید تو. کسی بود؛ ÙØ±Ø§Ø´ مدرسه با قیاÙه‌ای دهاتی Ùˆ ریش نتراشیده Ùˆ قدی کوتاه Ùˆ گشاد گشاد راه Ù…ÛŒâ€ŒØ±ÙØª Ùˆ دست‌هایش را دور از بدن Ù†Ú¯Ù‡ می‌داشت. آمد Ùˆ همان کنار در ایستاد. صا٠توی چشمم نگاه می‌کرد. ØØ§Ù„ او را هم پرسیدم. هر Ú†Ù‡ بود او هم می‌توانست یک گوشه‌ی این بار را بگیرد. در یک دقیقه همه‌ی درد دل‌هایش را کرد Ùˆ التماس دعاهایش Ú©Ù‡ تمام شد، ÙØ±Ø³ØªØ§Ø¯Ù…Ø´ برایم چای درست کند Ùˆ بیاورد. بعد از آن من به ناظم پرداختم. سال پیش، از دانشسرای مقدماتی در آمده بود. یک سال گرمسار Ùˆ کرج کار کرده بود Ùˆ امسال آمده بود این‌جا. پدرش دو تا زن داشته. از اولی دو تا پسر Ú©Ù‡ هر دو تا چاقوکش از آب در آمده‌اند Ùˆ از دومی Ùقط او مانده بود Ú©Ù‡ درس‌خوان شده Ùˆ سرشناس Ùˆ نان مادرش را می‌دهد Ú©Ù‡ مریض است Ùˆ از پدر سال‌هاست Ú©Ù‡ خبری نیست Ùˆ... یک اتاق Ú¯Ø±ÙØªÙ‡â€ŒØ§Ù†Ø¯ به پنجاه تومان Ùˆ صد Ùˆ پنجاه تومان ØÙ‚وق به جایی نمی‌رسد Ùˆ تازه زور Ú©Ù‡ بزند سه سال دیگر می‌تواند از ØÙ‚ ÙÙ†ÛŒ نظامت مدرسه Ø§Ø³ØªÙØ§Ø¯Ù‡ کند
+
+... بعد بلند شدیم Ú©Ù‡ به کلاس‌ها سرکشی کنیم. بعد با ناظم به تک تک کلاس‌ها سر زدیم در این میان من به یاد دوران دبستان خودم Ø§ÙØªØ§Ø¯Ù…. در کلاس ششم را باز کردیم «... ت بی پدرو مادر» جوانک بریانتین زده خورد توی صورت‌مان. یکی از بچه‌ها صورتش مثل چغندر قرمز بود. لابد بزک ÙØØ´ هنوز باقی بود. قرائت ÙØ§Ø±Ø³ÛŒ داشتند. معلم دستهایش توی جیبش بود Ùˆ سینه‌اش را پیش داده بود Ùˆ زبان به شکایت باز کرد:
+
+- آقای مدیر! اصلاً دوستی سرشون نمی‌شه. تو سَری می‌خوان. Ù…Ù„Ø§ØØ¸Ù‡ کنید بنده با Ú†Ù‡ صمیمیتی...
+
+ØØ±ÙØ´ را در تشدید «ایت» بریدم Ú©Ù‡:
+
+- صØÛŒØ Ù…ÛŒâ€ŒÙØ±Ù…ایید. این بار به من ببخشید.
+
+Ùˆ از در آمدیم بیرون. بعد از آن به اطاقی Ú©Ù‡ در آینده مال من بود سر زدیم. بهتر از این نمی‌شد. بی سر Ùˆ صدا، Ø¢ÙØªØ§Ø¨â€ŒØ±ÙˆØŒ دور Ø§ÙØªØ§Ø¯Ù‡.
+
+وسط ØÛŒØ§Ø·ØŒ یک ØÙˆØ¶ بزرگ بود Ùˆ کم‌عمق. تنها قسمت ساختمان بود Ú©Ù‡ رعایت ØØ§Ù„ بچه‌های قد Ùˆ نیم قد در آن شده بود. دور ØÛŒØ§Ø· دیوار بلندی بود درست مثل دیوار چین. سد Ù…Ø±ØªÙØ¹ÛŒ در مقابل ÙØ±Ø§Ø± Ø§ØØªÙ…الی ÙØ±Ù‡Ù†Ú¯ Ùˆ ته ØÛŒØ§Ø· Ù…Ø³ØªØ±Ø§Ø Ùˆ اتاق ÙØ±Ø§Ø´ بغلش Ùˆ انبار زغال Ùˆ بعد هم یک کلاس. به Ù…Ø³ØªØ±Ø§Ø Ù‡Ù… سر کشیدیم. همه بی در Ùˆ سق٠و تیغه‌ای میان آن‌ها. نگاهی به ناظم کردم Ú©Ù‡ پا به پایم می‌آمد. Ú¯ÙØª:
+
+- دردسر عجیبی شده آقا. تا ØØ§Ù„ا صد تا کاغذ به Ø§Ø¯Ø§Ø±ÙØ±Ø¯Ø§ ØµØ¨Ø Ø±ÙØªÙ… مدرسه. بچه‌ها با صÙ‌هاشان به طر٠کلاس‌ها Ù…ÛŒâ€ŒØ±ÙØªÙ†Ø¯ Ùˆ ناظم چوب به دست توی ایوان ایستاده بود Ùˆ توی Ø¯ÙØªØ± دو تا از معلم‌ها بودند. معلوم شد کار هر روزه‌شان است. ناظم را هم ÙØ±Ø³ØªØ§Ø¯Ù… سر یک کلاس دیگر Ùˆ خودم آمدم دم در مدرسه به قدم زدن؛ Ùکر کردم از هر طر٠که بیایند مرا این ته، دم در مدرسه خواهند دید Ùˆ تمام طول راه در این خجالت خواهند ماند Ùˆ دیگر دیر نخواهند آمد. یک سیاهی از ته جاده‌ی جنوبی پیداشد. جوانک بریانتین زده بود. مسلماً او هم مرا می‌دید، ولی آهسته‌تر از آن می‌آمد Ú©Ù‡ یک معلم تأخیر کرده جلوی مدیرش می‌آمد. جلوتر Ú©Ù‡ آمد ØØªÛŒ شنیدم Ú©Ù‡ سوت می‌زد. اما بی‌انصا٠چنان سلانه سلانه می‌آمد Ú©Ù‡ دیدم هیچ جای گذشت نیست. اصلاً Ù…ØÙ„ سگ به من نمی‌گذاشت. داشتم از کوره در Ù…ÛŒâ€ŒØ±ÙØªÙ… Ú©Ù‡ یک مرتبه Ø§ØØ³Ø§Ø³ کردم تغییری در Ø±ÙØªØ§Ø± خود داد Ùˆ تند کرد.
+
+به خیر گذشت Ùˆ گرنه خدا عالم است Ú†Ù‡ Ø§ØªÙØ§Ù‚ÛŒ Ù…ÛŒâ€ŒØ§ÙØªØ§Ø¯. سلام Ú©Ù‡ کرد مثل این Ú©Ù‡ می‌خواست چیزی بگوید Ú©Ù‡ پیش دستی کردم:
+
+- Ø¨ÙØ±Ù…ایید آقا. Ø¨ÙØ±Ù…ایید، بچه‌ها منتظرند.
+
+واقعاً به خیر گذشت. شاید اتوبوسش دیر کرده. شاید راه‌بندان بوده؛ جاده قرق بوده Ùˆ باز یک Ú¯Ø±Ø¯Ù†â€ŒÚ©Ù„ÙØªÛŒ از اقصای عالم می‌آمده Ú©Ù‡ ازین Ø³ÙØ±Ù‡â€ŒÛŒ مرتضی علی بی‌نصیب نماند. به هر صورت در دل بخشیدمش. Ú†Ù‡ خوب شد Ú©Ù‡ بد Ùˆ بی‌راهی Ù†Ú¯ÙØªÛŒ! Ú©Ù‡ از دور علم Ø§ÙØ±Ø§Ø´ØªÙ‡â€ŒÛŒ هیکل معلم کلاس چهارم نمایان شد. از همان ته مرا دیده بود. تقریباً می‌دوید. تØÙ…Ù„ این یکی را نداشتم. «بدکاری می‌کنی. اول بسم‌الله Ùˆ مته به خشخاش!» Ø±ÙØªÙ… Ùˆ توی Ø¯ÙØªØ± نشستم Ùˆ خودم را به کاری مشغول کردم Ú©Ù‡ هن هن کنان رسید. چنان عرق از پیشانی‌اش می‌ریخت Ú©Ù‡ راستی خجالت کشیدم. یک لیوان آب از کوه به دستش دادم Ùˆ مسخ‌شده‌ی خنده‌اش را با آب به خوردش دادم Ùˆ بلند Ú©Ù‡ شد برود، Ú¯ÙØªÙ…:
+
+- عوضش دو کیلو لاغر شدید.
+
+برگشت نگاهی کرد Ùˆ خنده‌ای Ùˆ Ø±ÙØª. ناگهان ناظم از در وارد شد Ùˆ از را Ù‡ نرسیده Ú¯ÙØª:
+
+- دیدید آقا! این جوری می‌آند مدرسه. اون قرتی که عین خیالش هم نبود آقا! اما این یکی...
+
+از او پرسیدم:
+
+- انگار هنوز دو تا از کلاس‌ها ولند؟
+
+- بله آقا. کلاس سه ورزش دارند. Ú¯ÙØªÙ… بنشینند دیکته بنویسند آقا. معلم ØØ³Ø§Ø¨ پنج Ùˆ شش هم Ú©Ù‡ نیومده آقا.
+
+در همین ØÛŒÙ† یکی از عکس‌های بزرگ دخمه‌های هخامنشی را Ú©Ù‡ به دیوار کوبیده بود پس زد Ùˆ:
+
+- نگاه کنید آقا...
+
+روی گچ دیوار با مداد قرمز و نه چندان درشت، به عجله و ناشیانه علامت داس کشیده بودند. همچنین دنبال کرد:
+
+- از آثار دوره‌ی اوناست آقا. کارشون همین چیزها بود. روزنومه Ø¨ÙØ±ÙˆØ´Ù†Ø¯. تبلیغات کنند Ùˆ داس Ú†Ú©Ø´ بکشند آقا. رئیس‌شون رو Ú©Ù‡ Ú¯Ø±ÙØªÙ†Ø¯ Ú†Ù‡ جونی کندم آقا تا ØØ§Ù„ی‌شون کنم Ú©Ù‡ دست ور دارند آقا. Ùˆ از روی میز پرید پایین.
+
+- Ú¯ÙØªÙ… Ù…Ú¯Ù‡ باز هم هستند؟
+
+- آره آقا، پس چی! یکی همین آقازاده که هنوز نیومده آقا. هر روز نیم ساعت تأخیر داره آقا. یکی هم مثل کلاس سه.
+
+- خوب چرا تا ØØ§Ù„ا پاکش نکردی؟
+
+- به! آخه آدم درد دلشو واسه‌ی Ú©ÛŒ بگه؟ آخه آقا در میان تو روی آدم می‌گند جاسوس، مأمور! باهاش ØØ±ÙÙ… شده آقا. کتک Ùˆ کتک‌کاری!
+
+Ùˆ بعد یک سخنرانی Ú©Ù‡ Ú†Ù‡ طور مدرسه را خراب کرده‌اند Ùˆ اعتماد اهل Ù…ØÙ„Ù‡ را Ú†Ù‡ طور از بین برده‌اند Ú©Ù‡ نه انجمنی، نه Ú©Ù…Ú©ÛŒ به بی‌بضاعت‌ها؛ Ùˆ از این ØØ±Ù ها.
+
+بعد از سخنرانی آقای ناظم دستمالم را دادم Ú©Ù‡ آن عکس‌ها را پاک کند Ùˆ بعد هم راه Ø§ÙØªØ§Ø¯Ù… Ú©Ù‡ بروم سراغ اتاق خودم. در اتاقم را Ú©Ù‡ باز کردم، داشتم دماغم با بوی خاک نم کشیده‌اش اخت می‌کرد Ú©Ù‡ آخرین معلم هم آمد. آمدم توی ایوان Ùˆ با صدای بلند، جوری Ú©Ù‡ در تمام مدرسه بشنوند، ناظم را صدا زدم Ùˆ Ú¯ÙØªÙ… با قلم قرمز برای آقا یک ساعت تأخیر بگذارند.ه‌ی ساختمان نوشتیم آقا. می‌گند نمی‌شه پول دولت رو تو ملک دیگرون خرج کرد.
+
+- Ú¯ÙØªÙ… راست می‌گند.
+
+دیگه کاÙÛŒ بود. آمدیم بیرون. همان توی ØÛŒØ§Ø· تا Ù†ÙØ³ÛŒ تازه کنیم وضع مالی Ùˆ بودجه Ùˆ ازین ØØ±Ù‌های مدرسه را پرسیدم. هر اتاق ماهی پانزده ریال ØÙ‚ Ù†Ø¸Ø§ÙØª داشت. Ù„ÙˆØ§Ø²Ù…â€ŒØ§Ù„ØªØØ±ÛŒØ± Ùˆ Ø¯ÙØªØ±Ù‡Ø§ را هم اداره‌ی ÙØ±Ù‡Ù†Ú¯ می‌داد. ماهی بیست Ùˆ پنج تومان هم برای آب خوردن داشتند Ú©Ù‡ هنوز وصول نشده بود. برای نصب هر بخاری سالی سه تومان. ماهی سی تومان هم تنخواه‌گردان مدرسه بود Ú©Ù‡ مثل پول آب سوخت شده بود Ùˆ ØØ§Ù„ا هم ماه دوم سال بود. اواخر آبان. ØØ§Ù„یش کردم Ú©Ù‡ ØÙˆØµÙ„ه‌ی این کارها را ندارم Ùˆ غرضم را از مدیر شدن برایش خلاصه کردم Ùˆ Ú¯ÙØªÙ… ØØ§Ø¶Ø±Ù… همه‌ی اختیارات را به او بدهم. «اصلاً انگار Ú©Ù‡ هنوز مدیر نیامده.» مهر مدرسه هم پهلوی خودش باشد. البته او را هنوز نمی‌شناختم. شنیده بودم Ú©Ù‡ مدیرها قبلاً ناظم خودشان را انتخاب می‌کنند، اما من نه کسی را سراغ داشتم Ùˆ نه ØÙˆØµÙ„ه‌اش را. ØÚ©Ù… خودم را هم به زور Ú¯Ø±ÙØªÙ‡ بودم. سنگ‌هامان را وا کندیم Ùˆ به Ø¯ÙØªØ± Ø±ÙØªÛŒÙ… Ùˆ چایی را Ú©Ù‡ ÙØ±Ø§Ø´ از بساط خانه‌اش درست کرده بود، خوردیم تا زنگ را زدند Ùˆ باز هم زدند Ùˆ من نگاهی به پرونده‌های شاگردها کردم Ú©Ù‡ هر کدام عبارت بود از دو برگ کاغذ. از همین دو سه برگ کاغذ دانستم Ú©Ù‡ اولیای بچه‌ها اغلب زارع Ùˆ باغبان Ùˆ اویارند Ùˆ قبل از این‌که زنگ آخر را بزنند Ùˆ مدرسه تعطیل بشود بیرون آمدم. برای روز اول خیلی زیاد بود.
+
+ÙØ±Ø¯Ø§ ØµØ¨Ø Ø±ÙØªÙ… مدرسه. بچه‌ها با صÙ‌هاشان به طر٠کلاس‌ها Ù…ÛŒâ€ŒØ±ÙØªÙ†Ø¯ Ùˆ ناظم چوب به دست توی ایوان ایستاده بود Ùˆ توی Ø¯ÙØªØ± دو تا از معلم‌ها بودند. معلوم شد کار هر روزه‌شان است. ناظم را هم ÙØ±Ø³ØªØ§Ø¯Ù… سر یک کلاس دیگر Ùˆ خودم آمدم دم در مدرسه به قدم زدن؛ Ùکر کردم از هر طر٠که بیایند مرا این ته، دم در مدرسه خواهند دید Ùˆ تمام طول راه در این خجالت خواهند ماند Ùˆ دیگر دیر نخواهند آمد. یک سیاهی از ته جاده‌ی جنوبی پیداشد. جوانک بریانتین زده بود. مسلماً او هم مرا می‌دید، ولی آهسته‌تر از آن می‌آمد Ú©Ù‡ یک معلم تأخیر کرده جلوی مدیرش می‌آمد. جلوتر Ú©Ù‡ آمد ØØªÛŒ شنیدم Ú©Ù‡ سوت می‌زد. اما بی‌انصا٠چنان سلانه سلانه می‌آمد Ú©Ù‡ دیدم هیچ جای گذشت نیست. اصلاً Ù…ØÙ„ سگ به من نمی‌گذاشت. داشتم از کوره در Ù…ÛŒâ€ŒØ±ÙØªÙ… Ú©Ù‡ یک مرتبه Ø§ØØ³Ø§Ø³ کردم تغییری در Ø±ÙØªØ§Ø± خود داد Ùˆ تند کرد.
+
+به خیر گذشت Ùˆ گرنه خدا عالم است Ú†Ù‡ Ø§ØªÙØ§Ù‚ÛŒ Ù…ÛŒâ€ŒØ§ÙØªØ§Ø¯. سلام Ú©Ù‡ کرد مثل این Ú©Ù‡ می‌خواست چیزی بگوید Ú©Ù‡ پیش دستی کردم:
+
+- Ø¨ÙØ±Ù…ایید آقا. Ø¨ÙØ±Ù…ایید، بچه‌ها منتظرند.
+
+واقعاً به خیر گذشت. شاید اتوبوسش دیر کرده. شاید راه‌بندان بوده؛ جاده قرق بوده Ùˆ باز یک Ú¯Ø±Ø¯Ù†â€ŒÚ©Ù„ÙØªÛŒ از اقصای عالم می‌آمده Ú©Ù‡ ازین Ø³ÙØ±Ù‡â€ŒÛŒ مرتضی علی بی‌نصیب نماند. به هر صورت در دل بخشیدمش. Ú†Ù‡ خوب شد Ú©Ù‡ بد Ùˆ بی‌راهی Ù†Ú¯ÙØªÛŒ! Ú©Ù‡ از دور علم Ø§ÙØ±Ø§Ø´ØªÙ‡â€ŒÛŒ هیکل معلم کلاس چهارم نمایان شد. از همان ته مرا دیده بود. تقریباً می‌دوید. تØÙ…Ù„ این یکی را نداشتم. «بدکاری می‌کنی. اول بسم‌الله Ùˆ مته به خشخاش!» Ø±ÙØªÙ… Ùˆ توی Ø¯ÙØªØ± نشستم Ùˆ خودم را به کاری مشغول کردم Ú©Ù‡ هن هن کنان رسید. چنان عرق از پیشانی‌اش می‌ریخت Ú©Ù‡ راستی خجالت کشیدم. یک لیوان آب از کوه به دستش دادم Ùˆ مسخ‌شده‌ی خنده‌اش را با آب به خوردش دادم Ùˆ بلند Ú©Ù‡ شد برود، Ú¯ÙØªÙ…:
+
+- عوضش دو کیلو لاغر شدید.
+
+برگشت نگاهی کرد Ùˆ خنده‌ای Ùˆ Ø±ÙØª. ناگهان ناظم از در وارد شد Ùˆ از را Ù‡ نرسیده Ú¯ÙØª:
+
+- دیدید آقا! این جوری می‌آند مدرسه. اون قرتی که عین خیالش هم نبود آقا! اما این یکی...
+
+از او پرسیدم:
+
+- انگار هنوز دو تا از کلاس‌ها ولند؟
+
+- بله آقا. کلاس سه ورزش دارند. Ú¯ÙØªÙ… بنشینند دیکته بنویسند آقا. معلم ØØ³Ø§Ø¨ پنج Ùˆ شش هم Ú©Ù‡ نیومده آقا.
+
+در همین ØÛŒÙ† یکی از عکس‌های بزرگ دخمه‌های هخامنشی را Ú©Ù‡ به دیوار کوبیده بود پس زد Ùˆ:
+
+- نگاه کنید آقا...
+
+روی گچ دیوار با مداد قرمز و نه چندان درشت، به عجله و ناشیانه علامت داس کشیده بودند. همچنین دنبال کرد:
+
+- از آثار دوره‌ی اوناست آقا. کارشون همین چیزها بود. روزنومه Ø¨ÙØ±ÙˆØ´Ù†Ø¯. تبلیغات کنند Ùˆ داس Ú†Ú©Ø´ بکشند آقا. رئیس‌شون رو Ú©Ù‡ Ú¯Ø±ÙØªÙ†Ø¯ Ú†Ù‡ جونی کندم آقا تا ØØ§Ù„ی‌شون کنم Ú©Ù‡ دست ور دارند آقا. Ùˆ از روی میز پرید پایین.
+
+- Ú¯ÙØªÙ… Ù…Ú¯Ù‡ باز هم هستند؟
+
+- آره آقا، پس چی! یکی همین آقازاده که هنوز نیومده آقا. هر روز نیم ساعت تأخیر داره آقا. یکی هم مثل کلاس سه.
+
+- خوب چرا تا ØØ§Ù„ا پاکش نکردی؟
+
+- به! آخه آدم درد دلشو واسه‌ی Ú©ÛŒ بگه؟ آخه آقا در میان تو روی آدم می‌گند جاسوس، مأمور! باهاش ØØ±ÙÙ… شده آقا. کتک Ùˆ کتک‌کاری!
+
+Ùˆ بعد یک سخنرانی Ú©Ù‡ Ú†Ù‡ طور مدرسه را خراب کرده‌اند Ùˆ اعتماد اهل Ù…ØÙ„Ù‡ را Ú†Ù‡ طور از بین برده‌اند Ú©Ù‡ نه انجمنی، نه Ú©Ù…Ú©ÛŒ به بی‌بضاعت‌ها؛ Ùˆ از این ØØ±Ù ها.
+
+بعد از سخنرانی آقای ناظم دستمالم را دادم Ú©Ù‡ آن عکس‌ها را پاک کند Ùˆ بعد هم راه Ø§ÙØªØ§Ø¯Ù… Ú©Ù‡ بروم سراغ اتاق خودم. در اتاقم را Ú©Ù‡ باز کردم، داشتم دماغم با بوی خاک نم کشیده‌اش اخت می‌کرد Ú©Ù‡ آخرین معلم هم آمد. آمدم توی ایوان Ùˆ با صدای بلند، جوری Ú©Ù‡ در تمام مدرسه بشنوند، ناظم را صدا زدم Ùˆ Ú¯ÙØªÙ… با قلم قرمز برای آقا یک ساعت تأخیر بگذارند.
+
+روز سوم باز اول وقت مدرسه بودم. هنوز از پشت دیوار نپیچیده بودم Ú©Ù‡ صدای سوز Ùˆ بریز بچه‌ها به پیشبازم آمد. تند کردم. پنج تا از بچه‌ها توی ایوان به خودشان می‌پیچیدند Ùˆ ناظم ترکه‌ای به دست داشت Ùˆ به نوبت به ک٠دست‌شان می‌زد. بچه‌ها التماس می‌کردند؛ گریه می‌کردند؛ اما دستشان را هم دراز می‌کردند. نزدیک بود داد بزنم یا با لگد بزنم Ùˆ ناظم را پرت کنم آن طرÙ. پشتش به من بود Ùˆ من را نمی‌دید. ناگهان زمزمه‌ای توی صÙ‌ها Ø§ÙØªØ§Ø¯ Ú©Ù‡ یک مرتبه مرا به ØµØ±Ø§ÙØª انداخت Ú©Ù‡ در مقام مدیریت مدرسه، به سختی می‌شود ناظم را کتک زد. این بود Ú©Ù‡ خشمم را ÙØ±Ùˆ خوردم Ùˆ آرام از پله‌ها Ø±ÙØªÙ… بالا. ناظم، تازه متوجه من شده بود در همین ØÛŒÙ† دخالتم را کردم Ùˆ خواهش کردم این بار همه‌شان را به من ببخشند.
+
+نمی‌دانم Ú†Ù‡ کار خطایی از آنها سر زده بود Ú©Ù‡ ناظم را تا این ØØ¯ عصبانی کرده بود. بچه‌ها سکسکه‌کنان Ø±ÙØªÙ†Ø¯ توی صÙ‌ها Ùˆ بعد زنگ را زدند Ùˆ صÙ‌ها Ø±ÙØªÙ†Ø¯ به کلاس‌ها Ùˆ دنبالشان هم معلم‌ها Ú©Ù‡ همه سر وقت ØØ§Ø¶Ø± بودند. نگاهی به ناظم انداختم Ú©Ù‡ تازه ØØ§Ù„Ø´ سر جا آمده بود Ùˆ Ú¯ÙØªÙ… در آن ØØ§Ù„ÛŒ Ú©Ù‡ داشت، ممکن بود گردن یک کدامشان را بشکند. Ú©Ù‡ مرتبه براق شد:
+
+- اگه یک روز جلوشونو نگیرید سوارتون می‌شند آقا. نمی‌دونید چه قاطرهای چموشی شده‌اند آقا.
+
+مثل بچه مدرسه‌ای‌ها آقا آقا می‌کرد. موضوع را برگرداندم Ùˆ اØÙˆØ§Ù„ مادرش را پرسیدم. خنده، صورتش را از هم باز کرد Ùˆ صدا زد ÙØ±Ø§Ø´ برایش آب بیاورد. یادم هست آن روز نیم ساعتی برای آقای ناظم ØµØØ¨Øª کردم. پیرانه. Ùˆ او جوان بود Ùˆ زود می‌شد رامش کرد. بعد ازش خواستم Ú©Ù‡ ترکه‌ها را بشکند Ùˆ آن وقت من Ø±ÙØªÙ… سراغ اتاق خودم.
+
+در همان Ù‡ÙØªÙ‡â€ŒÛŒ اول به کارها وارد شدم. ÙØ±Ø¯Ø§ÛŒ زمستان Ùˆ نه تا بخاری زغال سنگی Ùˆ روزی چهار بار آب آوردن Ùˆ آب Ùˆ جاروی اتاق‌ها با یک ÙØ±Ø§Ø´ جور در نمی‌آید. یک ÙØ±Ø§Ø´ دیگر از اداره ÛŒ ÙØ±Ù‡Ù†Ú¯ خواستم Ú©Ù‡ هر روز منتظر ورودش بودیم. بعد از ظهرها را Ù†Ù…ÛŒâ€ŒØ±ÙØªÙ…. روزهای اول با دست Ùˆ دل لرزان، ولی سه چهار روزه جرأت پیدا کردم. Ø§ØØ³Ø§Ø³ می‌کردم Ú©Ù‡ مدرسه زیاد هم Ù…ØØ¶ خاطر من نمی‌گردد. کلاس اول هم یکسره بود Ùˆ به خاطر بچه‌های جغله دلهره‌ای نداشتم. در بیابان‌های اطرا٠مدرسه هم ماشینی آمد Ùˆ Ø±ÙØª نداشت Ùˆ گرچه پست Ùˆ بلند بود اما به هر صورت از ØÛŒØ§Ø· مدرسه Ú©Ù‡ بزرگ‌تر بود. معلم ها هم، هر بعد از ظهری دو تاشان به نوبت Ù…ÛŒâ€ŒØ±ÙØªÙ†Ø¯ یک جوری باهم کنار آمده بودند. Ùˆ ترسی هم از این نبود Ú©Ù‡ بچه‌ها از علم Ùˆ ÙØ±Ù‡Ù†Ú¯ ثقل سرد بکنند. یک روز هم بازرس آمد Ùˆ نیم ساعتی پیزر لای پالان هم گذاشتیم Ùˆ چای Ùˆ Ø§ØØªØ±Ø§Ù…ات متقابل! Ùˆ در Ø¯ÙØªØ± بازرسی تصدیق کرد Ú©Ù‡ مدرسه «با وجود عدم وسایل» بسیار خوب اداره می‌شود.
+
+بچه‌ها مدام در مدرسه زمین می‌خوردند، بازی می‌کردند، زمین می‌خوردند. مثل اینکه تاتوله خورده بودند. ساده‌ترین Ø´Ú©Ù„ بازی‌هایشان در ربع ساعت‌های ØªÙØ±ÛŒØØŒ دعوا بود. Ùکر می‌کردم علت این همه زمین خوردن شاید این باشد Ú©Ù‡ بیش‌ترشان Ú©ÙØ´ ØØ³Ø§Ø¨ÛŒ ندارند. آن‌ها هم Ú©Ù‡ داشتند، بچه‌ننه بودند Ùˆ بلد نبودند بدوند Ùˆ ØØªÛŒ راه بروند. این بود Ú©Ù‡ روزی دو سه بار، دست Ùˆ پایی خراش بر می‌داشت. پرونده‌ی برق Ùˆ تلÙÙ† مدرسه را از بایگانی بسیار Ù…ØÙ‚ر مدرسه بیرون کشیده بودم Ùˆ خوانده بودم. اگر یک خرده می‌دویدی تا دو سه سال دیگر هم برق مدرسه درست می‌شد Ùˆ هم تلÙنش. دوباره سری به اداره ساختمان زدم Ùˆ موضوع را تازه کردم Ùˆ به رÙقایی Ú©Ù‡ دورادور در اداره‌ی برق Ùˆ تلÙÙ† داشتم، یکی دو بار رو انداختم Ú©Ù‡ اول خیال می‌کردند کار خودم را می‌خواهم به اسم مدرسه راه بیندازم Ùˆ ناچار رها کردم. این قدر بود Ú©Ù‡ ادای وظیÙه‌ای می‌کرد. مدرسه آب نداشت. نه آب خوراکی Ùˆ نه آب جاری. با هرزاب بهاره، آب انبار زیر ØÙˆØ¶ را می‌انباشتند Ú©Ù‡ تلمبه‌ای سرش بود Ùˆ ØÙˆØ¶ را با همان پر می‌کردند Ùˆ خود بچه‌ها. اما برای آب خوردن دو تا منبع صد لیتری داشتیم از آهن سÙید Ú©Ù‡ مثل امامزاده‌ای یا سقاخانه‌ای دو قلو، روی چهار پایه کنار ØÛŒØ§Ø· بود Ùˆ روزی دو بار پر Ùˆ خالی می‌شد. این آب را از همان باغی می‌آوردیم Ú©Ù‡ ردی٠کاج‌هایش روی آسمان، لکه‌ی دراز سیاه انداخته بود. البته ÙØ±Ø§Ø´ می‌آورد. با یک سطل بزرگ Ùˆ یک آب‌پاش Ú©Ù‡ سوراخ بود Ùˆ تا به مدرسه می‌رسید، نص٠شده بود. هر دو را از جیب خودم دادم تعمیر کردند.
+
+یک روز هم مالک مدرسه آمد. پیرمردی موقر Ùˆ سنگین Ú©Ù‡ خیال می‌کرد برای سرکشی به خانه‌ی مستأجرنشینش آمده. از در وارد نشده ÙØ±ÛŒØ§Ø¯Ø´ بلند شد Ùˆ ÙØØ´ را کشید به ÙØ±Ø§Ø´ Ùˆ به ÙØ±Ù‡Ù†Ú¯ Ú©Ù‡ چرا بچه‌ها دیوار مدرسه را با زغال سیاه کرده‌اند واز همین توپ Ùˆ تشرش شناختمش. Ú©Ù„ÛŒ با او ØµØØ¨Øª کردیم البته او دو برابر سن من را داشت. برایش چای هم آوردیم Ùˆ با معلم‌ها آشنا شد Ùˆ قول‌ها داد Ùˆ Ø±ÙØª. کنه‌ای بود. درست یک پیرمرد. یک ساعت Ùˆ نیم درست نشست. ماهی یک بار هم این برنامه را داشتند Ú©Ù‡ بایست پیه‌اش را به تن می‌مالیدم.
+
+اما معلم‌ها. هر کدام یک ابلاغ بیست Ùˆ چهار ساعته در دست داشتند، ولی در برنامه به هر کدام‌شان بیست ساعت درس بیشتر نرسیده بود. Ú©Ù… Ú©Ù… قرار شد Ú©Ù‡ یک معلم از ÙØ±Ù‡Ù†Ú¯ بخواهیم Ùˆ به هر کدام‌شان هجده ساعت درس بدهیم، به شرط آن‌که هیچ بعد از ظهری مدرسه تعطیل نباشد. ØØªÛŒ آن Ú©Ù‡ دانشگاه Ù…ÛŒâ€ŒØ±ÙØª می‌توانست با Ù‡ÙØªÙ‡â€ŒØ§ÛŒ هجده ساعت درس بسازد. Ùˆ دشوارترین کار همین بود Ú©Ù‡ با کدخدامنشی ØÙ„ شد Ùˆ من یک معلم دیگر از ÙØ±Ù‡Ù†Ú¯ خواستم.
+
+اواخر Ù‡ÙØªÙ‡â€ŒÛŒ دوم، ÙØ±Ø§Ø´ جدید آمد. مرد پنجاه ساله‌ای باریک Ùˆ زبر Ùˆ زرنگ Ú©Ù‡ شب‌کلاه می‌گذاشت Ùˆ لباس آبی می‌پوشید Ùˆ ØªØ³Ø¨ÛŒØ Ù…ÛŒâ€ŒÚ¯Ø±Ø¯Ø§Ù†Ø¯ Ùˆ از هر کاری سر رشته داشت. آب خوردن را نوبتی می‌آوردند. مدرسه تر Ùˆ تمیز شد Ùˆ رونقی Ú¯Ø±ÙØª. ÙØ±Ø§Ø´ جدید سرش توی ØØ³Ø§Ø¨ بود. هر دو مستخدم با هم تمام بخاری‌ها را راه انداختند Ùˆ یک کارگر هم برای Ú©Ù…Ú© به آن‌ها آمد. ÙØ±Ø§Ø´ قدیمی را چهار روز پشت سر هم، سر ظهر Ù…ÛŒâ€ŒÙØ±Ø³ØªØ§Ø¯ÛŒÙ… اداره‌ی ÙØ±Ù‡Ù†Ú¯ Ùˆ هر آن منتظر زغال بودیم. هنوز یک Ù‡ÙØªÙ‡ از آمدن ÙØ±Ø§Ø´ جدید نگذشته بود Ú©Ù‡ صدای همه‌ی معلم‌ها در آمده بود. نه به هیچ کدامشان سلام می‌کرد Ùˆ نه به دنبال خرده ÙØ±Ù…ایش‌هایشان Ù…ÛŒâ€ŒØ±ÙØª. درست است Ú©Ù‡ به من سلام می‌کرد، اما معلم‌ها هم، لابد هر کدام در ØØ¯ÙˆØ¯ من ØµØ§ØØ¨ ÙØ¶Ø§ÛŒÙ„ Ùˆ عنوان Ùˆ معلومات بودند Ú©Ù‡ از یک ÙØ±Ø§Ø´ مدرسه توقع سلام داشته باشند. اما انگار نه انگار.
+
+بدتر از همه این Ú©Ù‡ سر خر معلم‌ها بود. من Ú©Ù‡ از همان اول، خرجم را سوا کرده بودم Ùˆ آن‌ها را آزاد گذاشته بودم Ú©Ù‡ در مواقع بیکاری در Ø¯ÙØªØ± را روی خودشان ببندند Ùˆ هر Ú†Ù‡ می‌خواهند بگویند Ùˆ هر کاری می‌خواهند بکنند. اما او در ÙØ§ØµÙ„ه‌ی ساعات درس، همچه Ú©Ù‡ معلم‌ها می‌آمدند، می‌آمد توی Ø¯ÙØªØ± Ùˆ همین طوری گوشه‌ی اتاق می‌ایستاد Ùˆ معلم‌ها کلاÙÙ‡ می‌شدند. نه می‌توانستند شلکلک‌های معلمی‌شان را در ØØ¶ÙˆØ± او کنار بگذارند Ùˆ نه جرأت می‌کردند به او چیزی بگویند. بدزبان بود Ùˆ از عهده‌ی همه‌شان بر می‌آمد. یکی دوبار دنبال نخود سیاه ÙØ±Ø³ØªØ§Ø¯Ù‡ بودندش. اما زرنگ بود Ùˆ Ùوری کار را انجام می‌داد Ùˆ بر می‌گشت. ØØ³Ø§Ø¨ÛŒ موی دماغ شده بود. ده سال تجربه این ØØ¯Ø§Ù‚Ù„ را به من آموخته بود Ú©Ù‡ اگر معلم‌ها در ربع ساعت‌های ØªÙØ±ÛŒØ نتوانند بخندند، سر کلاس، بچه‌های مردم را کتک خواهند زد. این بود Ú©Ù‡ دخالت کردم. یک روز ÙØ±Ø§Ø´ جدید را صدا زدم. اول ØØ§Ù„ Ùˆ اØÙˆØ§Ù„پرسی Ùˆ بعد چند سال سابقه دارد Ùˆ چند تا بچه Ùˆ Ú†Ù‡ قدر می‌گیرد... Ú©Ù‡ قضیه ØÙ„ شد. سی صد Ùˆ خرده‌ای ØÙ‚وق Ù…ÛŒâ€ŒÚ¯Ø±ÙØª. با بیست Ùˆ پنج سال سابقه. کار از همین جا خراب بود. پیدا بود Ú©Ù‡ معلم‌ها ØÙ‚ دارند او را غریبه بدانند. نه دیپلمی، نه کاغذپاره‌ای، هر Ú†Ù‡ باشد یک ÙØ±Ø§Ø´ Ú©Ù‡ بیشتر نبود! Ùˆ تازه قلدر هم بود Ùˆ ØÙ‚ هم داشت. اول به اشاره Ùˆ کنایه Ùˆ بعد با ØµØ±Ø§ØØª بهش Ùهماندم Ú©Ù‡ گر Ú†Ù‡ معلم جماعت اجر دنیایی ندارد، اما از او Ú©Ù‡ آدم متدین Ùˆ Ùهمیده‌ای است بعید است Ùˆ از این ØØ±Ù‌ها... Ú©Ù‡ یک مرتبه پرید توی ØØ±ÙÙ… Ú©Ù‡:
+
+- ای آقا! Ú†Ù‡ Ù…ÛŒâ€ŒÙØ±Ù…ایید؟ شما نه خودتون این کاره‌اید Ùˆ نه اینارو می‌شناسید. امروز می‌خواند سیگار براشون بخرم، ÙØ±Ø¯Ø§ Ù…ÛŒâ€ŒÙØ±Ø³ØªÙ†Ù… سراغ عرق. من این‌ها رو می‌شناسم.
+
+راست Ù…ÛŒâ€ŒÚ¯ÙØª. زودتر از همه، او دندان‌های مرا شمرده بود. Ùهمیده بود Ú©Ù‡ در مدرسه هیچ‌کاره‌ام. می‌خواستم کوتاه بیایم، ولی مدیر مدرسه بودن Ùˆ در مقابل یک ÙØ±Ø§Ø´ پررو ساکت ماندن!... Ú©Ù‡ خر خر کامیون زغال به دادم رسید. ترمز Ú©Ù‡ کرد Ùˆ صدا خوابید Ú¯ÙØªÙ…:
+
+- این ØØ±Ù‌ها Ù‚Ø¨Ø§ØØª داره. معلم جماعت کجا پولش به عرق می‌رسه؟ ØØ§Ù„ا بدو زغال آورده‌اند.
+
+Ùˆ همین طور Ú©Ù‡ داشت بیرون Ù…ÛŒâ€ŒØ±ÙØªØŒ Ø§ÙØ²ÙˆØ¯Ù…:
+
+- دو روز دیگه Ú©Ù‡ Ù…ØØªØ§Ø¬Øª شدند Ùˆ ازت قرض خواستند با هم رÙیق می‌شید.
+
+Ùˆ آمدم توی ایوان. در بزرگ آهنی مدرسه را باز کرده بودند Ùˆ کامیون آمده بود تو Ùˆ داشتند بارش را جلوی انبار ته ØÛŒØ§Ø· خالی می‌کردند Ùˆ راننده، کاغذی به دست ناظم داد Ú©Ù‡ نگاهی به آن انداخت Ùˆ مرا نشان داد Ú©Ù‡ در ایوان بالا ایستاده بودم Ùˆ ÙØ±Ø³ØªØ§Ø¯Ø´ بالا. کاغذش را با سلام به دستم داد. بیجک زغال بود. رسید رسمی اداره‌ی ÙØ±Ù‡Ù†Ú¯ بود در سه نسخه Ùˆ روی آن ورقه‌ی ماشین شده‌ی «باسکول» Ú©Ù‡ Ù…ÛŒâ€ŒÚ¯ÙØª کامیون Ùˆ Ù…ØØªÙˆÛŒØ§ØªØ´ جمعاً دوازده خروار است. اما رسیدهای رسمی اداری ÙØ±Ù‡Ù†Ú¯ ساکت بودند. جای مقدار زغالی Ú©Ù‡ تØÙˆÛŒÙ„ مدرسه داده شده بود، در هر سه نسخه خالی بود. پیدا بود Ú©Ù‡ تØÙˆÛŒÙ„ گیرنده باید پرشان کند. همین کار را کردم. اوراق را بردم توی اتاق Ùˆ با خودنویسم عدد را روی هر سه ورق نوشتم Ùˆ امضا کردم Ùˆ به دست راننده دادم Ú©Ù‡ راه Ø§ÙØªØ§Ø¯ Ùˆ از همان بالا به ناظم Ú¯ÙØªÙ…:
+
+- اگر مهر هم بایست زد، خودت بزن بابا.
+
+Ùˆ Ø±ÙØªÙ… سراغ کارم Ú©Ù‡ ناگهان در باز شد Ùˆ ناظم آمد تو؛ بیجک زغال دستش بود Ùˆ:
+
+- Ù…Ú¯Ù‡ Ù†Ùهمیدین آقا؟ مخصوصاً جاش رو خالی گذاشته بودند آقا...
+
+Ù†Ùهمیده بودم. اما اگر هم Ùهمیده بودم، ÙØ±Ù‚ÛŒ نمی‌کرد Ùˆ به هر صورت از چنین کودنی نا به هنگام از جا در Ø±ÙØªÙ… Ùˆ به شدت Ú¯ÙØªÙ…:
+
+- خوب؟
+
+- هیچ چی آقا.... رسم‌شون همینه آقا. اگه باهاشون کنار نیایید کارمونو لنگ می‌گذارند آقا...
+
+Ú©Ù‡ از جا در Ø±ÙØªÙ…. به چنین ØµØ±Ø§ØØªÛŒ مرا Ú©Ù‡ مدیر مدرسه بودم در معامله شرکت می‌داد. Ùˆ ÙØ±ÛŒØ§Ø¯ زدم:
+
+- عجب! ØØ§Ù„ا سرکار برای من تکلی٠هم معین می‌کنید؟... خاک بر سر این ÙØ±Ù‡Ù†Ú¯ با مدیرش Ú©Ù‡ من باشم! برو ورقه رو بده دست‌شون، گورشون رو Ú¯Ù… کنند. پدر سوخته‌ها...
+
+چنان ÙØ±ÛŒØ§Ø¯ زده بودم Ú©Ù‡ هیچ کس در مدرسه انتظار نداشت. مدیر سر به زیر Ùˆ پا به راهی بودم Ú©Ù‡ از همه خواهش می‌کردم Ùˆ ØØ§Ù„ا ناظم مدرسه، داشت به من یاد می‌داد Ú©Ù‡ به جای نه خروار زغال مثلا هجده خروار تØÙˆÛŒÙ„ بگیرم Ùˆ بعد با اداره‌ی ÙØ±Ù‡Ù†Ú¯ کنار بیایم. Ù‡ÛŒ Ù‡ÛŒ!.... تا ظهر هیچ کاری نتوانستم بکنم، جز این‌که چند بار متن Ø§Ø³ØªØ¹ÙØ§Ù†Ø§Ù…ه‌ام را بنویسم Ùˆ پاره کنم... قدم اول را این جور جلوی پای آدم می‌گذارند.
+
+بارندگی Ú©Ù‡ شروع شد دستور دادم بخاری‌ها را از Ù‡ÙØª ØµØ¨Ø Ø¨Ø³ÙˆØ²Ø§Ù†Ù†Ø¯. بچه‌ها همیشه زود می‌آمدند. ØØªÛŒ روزهای بارانی. مثل این‌که اول Ø¢ÙØªØ§Ø¨ از خانه بیرون‌شان می‌کنند. یا ناهارنخورده. خیلی سعی کردم یک روز زودتر از بچه‌ها مدرسه باشم. اما عاقبت نشد Ú©Ù‡ مدرسه را خالی از Ù†ÙØ³Ù به علم‌آلوده‌ی بچه‌ها استنشاق کنم. از راه Ú©Ù‡ می‌رسیدند دور بخاری جمع می‌شدند Ùˆ گیوه‌هاشان را خشک می‌کردند. Ùˆ خیلی زود Ùهمیدم Ú©Ù‡ ظهر در مدرسه ماندن هم مسأله Ú©ÙØ´ بود. هر Ú©Ù‡ داشت نمی‌ماند.این قاعده در مورد معلم‌ها هم صدق می‌کرد اقلاً یک پول واکس جلو بودند. وقتی Ú©Ù‡ باران می‌بارید تمام کوهپایه Ùˆ بدتر از آن تمام ØÛŒØ§Ø· مدرسه Ú¯Ù„ می‌شد. بازی Ùˆ دویدن متوق٠شده بود. مدرسه سوت Ùˆ کور بود. این جا هم مسأله Ú©ÙØ´ بود. چشم اغلبشان هم قرمز بود. پیدا بود باز آن روز ØµØ¨Ø ÛŒÚ© ÙØµÙ„ گریه کرده‌اند Ùˆ در خانه‌شان علم صراطی بوده است.
+
+مدرسه داشت تخته می‌شد. عده‌ی غایب‌های ØµØ¨Ø Ø¯Ù‡ برابر شده بود Ùˆ ساعت اول هیچ معلمی نمی‌توانست درس بدهد. دست‌های ورم‌کرده Ùˆ سرمازده کار نمی‌کرد. ØØªÛŒ معلم کلاس اولمان هم می‌دانست Ú©Ù‡ ÙØ±Ù‡Ù†Ú¯ Ùˆ معلومات مدارس ما ØµØ±ÙØ§Ù‹ تابع تمرین است. مشق Ùˆ تمرین. ده بار بیست بار. دست یخ‌کرده بیل Ùˆ رنده را هم نمی‌تواند به کار بگیرد Ú©Ù‡ خیلی هم زمخت‌اند Ùˆ دست پر Ú©Ù†. این بود Ú©Ù‡ به Ùکر Ø§ÙØªØ§Ø¯ÛŒÙ…. ÙØ±Ø§Ø´ جدید واردتر از همه‌ی ما بود. یک روز در اتاق Ø¯ÙØªØ±ØŒ شورامانندی داشتیم Ú©Ù‡ البته او هم بود. خودش را کم‌کم تØÙ…یل کرده بود. Ú¯ÙØª ØØ§Ø¶Ø± است یکی از دÙÙ…â€ŒÚ©Ù„ÙØªâ€ŒÙ‡Ø§ÛŒ همسایه‌ی مدرسه را وادارد Ú©Ù‡ شن برایمان Ø¨ÙØ±Ø³ØªØ¯ به شرط آن Ú©Ù‡ ما هم برویم Ùˆ از انجمن Ù…ØÙ„ÛŒ برای بچه‌ها Ú©ÙØ´ Ùˆ لباس بخواهیم. قرار شد خودش قضیه را دنبال کند Ú©Ù‡ Ù‡ÙØªÙ‡â€ŒÛŒ آینده جلسه‌شان کجاست Ùˆ ØØªÛŒ بخواهد Ú©Ù‡ دعوت‌مانندی از ما بکنند. دو روز بعد سه تا کامیون شن آمد. دوتایش را توی ØÛŒØ§Ø· مدرسه، خالی کردیم Ùˆ سومی را دم در مدرسه، Ùˆ خود بچه‌ها نیم ساعته پهنش کردند. با پا Ùˆ بیل Ùˆ هر Ú†Ù‡ Ú©Ù‡ به دست می‌رسید.
+
+عصر همان روز ما را به انجمن دعوت کردند. خود من Ùˆ ناظم باید Ù…ÛŒâ€ŒØ±ÙØªÛŒÙ…. معلم کلاس چهارم را هم با خودمان بردیم. خانه‌ای Ú©Ù‡ Ù…ØÙ„ جلسه‌ی آن شب انجمن بود، درست مثل مدرسه، دور Ø§ÙØªØ§Ø¯Ù‡ Ùˆ تنها بود. قالی‌ها Ùˆ کناره‌ها را به ÙØ±Ù‡Ù†Ú¯ می‌آلودیم Ùˆ Ù…ÛŒâ€ŒØ±ÙØªÛŒÙ…. مثل این‌که سه تا سه تا روی هم انداخته بودند. اولی Ú©Ù‡ کثی٠شد دومی. به بالا Ú©Ù‡ رسیدیم یک ØØ§Ø¬ÛŒ آقا در ØØ§Ù„ نماز خواندن بود. Ùˆ ØµØ§ØØ¨â€ŒØ®Ø§Ù†Ù‡ با لهجه‌ی غلیظ یزدی به استقبال‌مان آمد. همراهانم را معرÙÛŒ کردم Ùˆ لابد خودش Ùهمید مدیر کیست. برای ما چای آوردند. سیگارم را چاق کردم Ùˆ با ØµØ§ØØ¨â€ŒØ®Ø§Ù†Ù‡ از قالی‌هایش ØØ±Ù زدیم. ناظم به بچه‌هایی می‌ماند Ú©Ù‡ در مجلس بزرگترها خوابشان می‌گیرد Ùˆ دل‌شان هم نمی‌خواست دست به سر شوند. سر اعضای انجمن باز شده بود. ØØ§Ø¬ÛŒ آقا صندوقدار بود. من Ùˆ ناظم عین دو Ø·Ùلان مسلم بودیم Ùˆ معلم کلاس چهارم عین خولی وسطمان نشسته. اغلب اعضای انجمن به زبان Ù…ØÙ„ÛŒ ØµØØ¨Øª می‌کردند Ùˆ Ø±ÙØªØ§Ø± ناشی داشتند. ØØªÛŒ یک کدامشان نمی‌دانستند Ú©Ù‡ دست Ùˆ پاهای خود را Ú†Ù‡ جور ضبط Ùˆ ربط کنند. بلند بلند ØØ±Ù می‌زدند. درست مثل این‌که وزارتخانه‌ی دواب سه تا ØÛŒÙˆØ§Ù† تازه برای باغ ÙˆØØ´ Ù…ØÙ„ه‌شان وارد کرده. جلسه Ú©Ù‡ رسمی شد، ØµØ§ØØ¨Ø®Ø§Ù†Ù‡ معرÙی‌مان کرد Ùˆ شروع کردند. مدام از خودشان ØµØØ¨Øª می‌کردند از این‌که دزد دیشب Ùلان جا را Ú¯Ø±ÙØªÙ‡ Ùˆ باید درخواست پاسبان شبانه کنیم Ùˆ...
+
+همین طور یک ساعت ØØ±Ù زدند Ùˆ به مهام امور رسیدگی کردند Ùˆ من Ùˆ معلم کلاس چهارم سیگار کشیدیم. انگار نه انگار Ú©Ù‡ ما هم بودیم. نوکرشان Ú©Ù‡ آمد استکان‌ها را جمع کند، چیزی روی جلد اشنو نوشتم Ùˆ برای ØµØ§ØØ¨Ø®Ø§Ù†Ù‡ ÙØ±Ø³ØªØ§Ø¯Ù… Ú©Ù‡ یک مرتبه به ØµØ±Ø§ÙØª ما Ø§ÙØªØ§Ø¯ Ùˆ اجازه خواست Ùˆ:
+
+- آقایان عرضی دارند. بهتر است کارهای خودمان را بگذاریم برای بعد.
+
+مثلاً می‌خواست بÙهماند Ú©Ù‡ نباید همه‌ی ØØ±Ù‌ها را در ØØ¶ÙˆØ± ما زده باشند. Ùˆ اجازه دادند معلم کلاس چهار شروع کرد به نطق Ùˆ او هم شروع کرد Ú©Ù‡ هر Ú†Ù‡ باشد ما زیر سایه‌ی آقایانیم Ùˆ خوش‌آیند نیست Ú©Ù‡ بچه‌هایی باشند Ú©Ù‡ نه لباس داشته باشند Ùˆ نه Ú©ÙØ´ درست Ùˆ ØØ³Ø§Ø¨ÛŒ Ùˆ از این ØØ±Ù‌ها Ùˆ مدام ØØ±Ù می‌زد. ناظم هم از Ú†ÙØ±Øª در آمد چیزهایی را Ú©Ù‡ از ØÙظ کرده بود Ú¯ÙØª Ùˆ التماس دعا Ùˆ کار را خراب کرد.تشری به ناظم زدم Ú©Ù‡ گدابازی را بگذارد کنار Ùˆ ØØ§Ù„ی‌شان کردم Ú©Ù‡ ØµØØ¨Øª از تقاضا نیست Ùˆ گدایی. بلکه مدرسه دور Ø§ÙØªØ§Ø¯Ù‡ است Ùˆ Ù…Ø³ØªØ±Ø§Ø Ø¨ÛŒ در Ùˆ پیکر Ùˆ از این اباطیل... Ú†Ù‡ خوب شد Ú©Ù‡ عصبانی نشدم. Ùˆ قرار شد Ú©Ù‡ پنج Ù†ÙØ±Ø´Ø§Ù† ÙØ±Ø¯Ø§ عصر بیایند Ú©Ù‡ مدرسه را وارسی کنند Ùˆ تشکر Ùˆ اظهار Ø®ÙˆØ´ØØ§Ù„ÛŒ Ùˆ در آمدیم.
+
+در تاریکی بیابان Ù‡ÙØª تا سواری پشت در خانه ردی٠بودند Ùˆ راننده‌ها توی یکی از آن‌ها جمع شده بودند Ùˆ اسرار ارباب‌هاشان را به هم Ù…ÛŒâ€ŒÚ¯ÙØªÙ†Ø¯. در این ØÛŒÙ† من مدام به خودم Ù…ÛŒâ€ŒÚ¯ÙØªÙ… من چرا Ø±ÙØªÙ…ØŸ به من چه؟ مگر من در بی Ú©ÙØ´ Ùˆ کلاهی‌شان مقصر بودم؟ می‌بینی اØÙ…ق؟ مدیر مدرسه هم Ú©Ù‡ باشی باید شخصیت Ùˆ غرورت را لای زرورق بپیچی Ùˆ طاق کلاهت بگذاری Ú©Ù‡ اقلاً نپوسد. ØØªÛŒ اگر بخواهی یک معلم Ú©ÙˆÙØªÛŒ باشی، نه چرا دور می‌زنی؟ ØØªÛŒ اگر یک ÙØ±Ø§Ø´ ماهی نود تومانی باشی، باید تا خرخره توی لجن ÙØ±Ùˆ بروی.در همین ØÛŒÙ† Ú©Ù‡ من در Ùکر بودم ناظم Ú¯ÙØª:
+
+- دیدید آقا Ú†Ù‡ طور باهامون Ø±ÙØªØ§Ø± کردند؟ با یکی از قالی‌هاشون آقا تمام مدرسه رو می‌خرید.
+
+Ú¯ÙØªÙ…:
+
+- تا سر Ùˆ کارت با الÙ.ب است به‌پا قیاس Ù†Ú©Ù†ÛŒ. خودخوری می‌آره.
+
+Ùˆ معلم کلاس چهار Ú¯ÙØª:
+
+- اگه ÙØØ´Ù…ÙˆÙ† هم می‌دادند من باز هم راضی بودم، باید واقع‌بین بود. خدا کنه پشیمون نشند.
+
+بعد هم مدتی درد دل کردیم و تا اتوبوس برسد و سوار بشیم، معلوم شد که معلم کلاس چهار با زنش متارکه کرده و مادر ناظم را سرطانی تشخیص دادند. و بعد هم شب بخیر...
+
+دو روز تمام مدرسه Ù†Ø±ÙØªÙ…. خجالت می‌کشیدم توی صورت یک کدام‌شان نگاه کنم. Ùˆ در همین دو روز ØØ§Ø¬ÛŒ آقا با دو Ù†ÙØ± آمده بودند، مدرسه را وارسی Ùˆ صورت‌برداری Ùˆ ناظم Ù…ÛŒâ€ŒÚ¯ÙØª Ú©Ù‡ ØØªÛŒ بچه‌هایی هم Ú©Ù‡ Ú©ÙØ´ Ùˆ کلاهی داشتند پاره Ùˆ پوره آمده بودند. Ùˆ برای بچه‌ها Ú©ÙØ´ Ùˆ لباس خریدند. روزهای بعد Ø§ØØ³Ø§Ø³ کردم زن‌هایی Ú©Ù‡ سر راهم لب جوی آب ظر٠می‌شستند، سلام می‌کنند Ùˆ یک بار هم دعای خیر یکی‌شان را از عقب سر شنیدم.اما چنان از خودم بدم آمده بود Ú©Ù‡ رغبتم نمی‌شد به Ú©ÙØ´ Ùˆ لباس‌هاشان نگاه کنم. قربان همان گیوه‌های پاره! بله، نان گدایی ÙØ±Ù‡Ù†Ú¯ را نو نوار کرده بود.
+
+تازه از دردسرهای اول کار مدرسه ÙØ§Ø±Øº شده بودم Ú©Ù‡ شنیدم Ú©Ù‡ یک روز ØµØ¨ØØŒ یکی از اولیای Ø§Ø·ÙØ§Ù„ آمد. بعد از سلام Ùˆ اØÙˆØ§Ù„پرسی دست کرد توی جیبش Ùˆ شش تا عکس در آورد، گذاشت روی میزم. شش تا عکس زن لخت. لخت لخت Ùˆ هر کدام به یک ØØ§Ù„ت. یعنی چه؟ نگاه تندی به او کردم. آدم مرتبی بود. اداری مانند. کسر شأن خودم می‌دانستم Ú©Ù‡ این گوشه‌ی از زندگی را طبق دستور عکاس‌باشی Ùلان جنده‌خانه‌ی بندری ببینم. اما ØØ§Ù„ا یک مرد اتو کشیده‌ی مرتب آمده بود Ùˆ شش تا از همین عکس‌ها را روی میزم پهن کرده بود Ùˆ به انتظار آن Ú©Ù‡ ÙˆÙ‚Ø§ØØª عکس‌ها چشم‌هایم را پر کند داشت سیگار چاق می‌کرد.
+
+ØØ³Ø§Ø¨ÛŒ غاÙلگیر شده بودم... ØØªÙ…اً تا هر شش تای عکس‌ها را ببینم، بیش از یک دقیقه طول کشید. همه از یک Ù†ÙØ± بود. به این Ùکر گریختم Ú©Ù‡ الان هزار ها یا میلیون ها نسخه‌ی آن، توی جیب Ú†Ù‡ جور آدم‌هایی است Ùˆ در کجاها Ùˆ Ú†Ù‡ قدر خوب بود Ú©Ù‡ همه‌ی این آدم‌ها را می‌شناختم یا می‌دیدم. بیش ازین نمی‌شد گریخت. یارو به تمام وزنه ÙˆÙ‚Ø§ØØªØ´ØŒ جلوی رویم نشسته بود. سیگاری آتش زدم Ùˆ چشم به او دوختم. کلاÙÙ‡ بود Ùˆ پیدا بود برای کتک‌کاری هم آماده باشد. سرخ شده بود Ùˆ داشت در دود سیگارش تکیه‌گاهی برای جسارتی Ú©Ù‡ می‌خواست به خرج بدهد می‌جست. عکس‌ها را با یک ورقه از اباطیلی Ú©Ù‡ همان روز سیاه کرده بودم، پوشاندم Ùˆ بعد با Ù„ØÙ†ÛŒ Ú©Ù‡ دعوا را با آن شروع می‌کنند؛ پرسیدم:
+
+- خوب، غرض؟
+
+Ùˆ صدایم توی اتاق پیچید. ØØ±Ú©ØªÛŒ از روی بیچارگی به خودش داد Ùˆ همه‌ی جسارت‌ها را با دستش توی جیبش کرد Ùˆ آرام‌تر از آن چیزی Ú©Ù‡ با خودش تو آورده بود، Ú¯ÙØª:
+
+- چه عرض کنم؟... از معلم کلاس پنج تون بپرسید.
+
+Ú©Ù‡ Ø±Ø§ØØª شدم Ùˆ او شروع کرد به این Ú©Ù‡ «این Ú†Ù‡ ÙØ±Ù‡Ù†Ú¯ÛŒ است؟ خراب بشود. پس بچه‌های مردم با Ú†Ù‡ اطمینانی به مدرسه بیایند؟
+
+Ùˆ از این ØØ±Ù‌ها...
+
+خلاصه این آقا معلم کاردستی کلاس پنجم، این عکس‌ها را داده به پسر آقا تا آن‌ها را روی تخته سه لایی بچسباند Ùˆ دورش را سمباده بکشد Ùˆ بیاورد. به هر صورت معلم کلاس پنج بی‌گدار به آب زده. Ùˆ ØØ§Ù„ا من Ú†Ù‡ بکنم؟ به او Ú†Ù‡ جوابی بدهم؟ بگویم معلم را اخراج می‌کنم؟ Ú©Ù‡ نه می‌توانم Ùˆ نه لزومی دارد. او Ú†Ù‡ بکند؟ ØØªÙ…اً در این شهر کسی را ندارد Ú©Ù‡ به این عکس‌ها دلخوش کرده. ولی آخر چرا این جور؟ یعنی این قدر اØÙ…Ù‚ است Ú©Ù‡ ØØªÛŒ شاگردهایش را نمی‌شناسد؟... پاشدم ناظم را صدا بزنم Ú©Ù‡ خودش آمده بود بالا، توی ایوان منتظر ایستاده بود. من آخرین کسی بودم Ú©Ù‡ از هر Ø§ØªÙØ§Ù‚ÛŒ در مدرسه خبردار می‌شدم. ØØ¶ÙˆØ± این ولی Ø·ÙÙ„ گیجم کرده بود Ú©Ù‡ چنین عکس‌هایی را از توی جیب پسرش، Ùˆ لابد به همین ÙˆÙ‚Ø§ØØªÛŒ Ú©Ù‡ آن‌ها را روی میز من ریخت، در آورده بوده. وقتی Ùهمید هر دو در مانده‌ایم سوار بر اسب شد Ú©Ù‡ اله می‌کنم Ùˆ بله می‌کنم، در مدرسه را می‌بندم، Ùˆ از این جÙنگیات....
+
+ØØªÙ…اً نمی‌دانست Ú©Ù‡ اگر در هر مدرسه بسته بشود، در یک اداره بسته شده است. اما من تا او بود نمی‌توانستم Ùکرم را جمع کنم. می‌خواست پسرش را بخواهیم تا شهادت بدهد Ùˆ Ú†Ù‡ جانی کندیم تا ØØ§Ù„یش کنیم Ú©Ù‡ پسرش هر Ú†Ù‡ Ø®ÙØª کشیده، بس است Ùˆ وعده‌ها دادیم Ú©Ù‡ معلمش را دم خورشید کباب کنیم Ùˆ از نان خوردن بیندازیم. یعنی اول ناظم شروع کرد Ú©Ù‡ از دست او دل پری داشت Ùˆ من هم دنبالش را Ú¯Ø±ÙØªÙ…. برای دک کردن او چاره‌ای جز این نبود. Ùˆ بعد Ø±ÙØªØŒ ما دو Ù†ÙØ±ÛŒ ماندیم با شش تا عکس زن لخت. ØÙˆØ§Ø³Ù… Ú©Ù‡ جمع شد به ناظم سپردم صدایش را در نیاورد Ùˆ یک Ù‡ÙØªÙ‡â€ŒÛŒ تمام مطلب را با عکس‌ها، توی کشوی میزم Ù‚ÙÙ„ کردم Ùˆ بعد پسرک را صدا زدم. نه Ø¹Ø²ÛŒØ²Ø¯ÙØ±Ø¯Ø§Ù†Ù‡ می‌نمود Ùˆ نه هیچ جور دیگر. داد می‌زد Ú©Ù‡ از خانواده‌ی عیال‌واری است. کم‌خونی Ùˆ Ùقر. دیدم معلمش زیاد هم بد تشخیص نداده. یعنی زیاد بی‌گدار به آب نزده. Ú¯ÙØªÙ…:
+
+- خواهر برادر هم داری؟
+
+- آ... آ...آقا داریم آقا.
+
+- چند تا؟
+
+- آ... آقا چهار تا آقا.
+
+- عکس‌ها رو خودت به بابات نشون دادی؟
+
+- نه به خدا آقا... به خدا قسم...
+
+- پس چه طور شد؟
+
+و دیدم از ترس دارد قالب تهی می‌کند. گرچه چوب‌های ناظم شکسته بود، اما ترس او از من که مدیر باشم و از ناظم و از مدرسه و از تنبیه سالم مانده بود.
+
+- نترس بابا. کاریت نداریم. تقصیر آقا معلمه Ú©Ù‡ عکس‌ها رو داده... تو کار بدی نکردی بابا جان. Ùهمیدی؟ اما می‌خواهم ببینم Ú†Ù‡ طور شد Ú©Ù‡ عکس‌ها دست بابات Ø§ÙØªØ§Ø¯.
+
+- آ.. آ... آخه آقا... آخه...
+
+می‌دانستم Ú©Ù‡ باید Ú©Ù…Ú©Ø´ کنم تا به ØØ±Ù بیاید.
+
+Ú¯ÙØªÙ…:
+
+- می‌دونی بابا؟ عکس‌هام چیز بدی نبود. تو خودت Ùهمیدی Ú†ÛŒ بود؟
+
+- آخه آقا...نه آقا.... خواهرم آقا... خواهرم Ù…ÛŒâ€ŒÚ¯ÙØª...
+
+- خواهرت؟ از تو کوچک‌تره؟
+
+- نه آقا. بزرگ‌تره. Ù…ÛŒâ€ŒÚ¯ÙØªØ´ Ú©Ù‡ آقا... Ù…ÛŒâ€ŒÚ¯ÙØªØ´ Ú©Ù‡ آقا... هیچ Ú†ÛŒ سر عکس‌ها دعوامون شد.
+
+دیگر تمام بود. عکس‌ها را به خواهرش نشان داده بود Ú©Ù‡ لای Ø¯ÙØªØ±Ú†Ù‡ پر بوده از عکس آرتیست‌ها. به او پز داده بوده. اما ØØ§Ø¶Ø± نبوده، ØØªÛŒ یکی از آن‌ها را به خواهرش بدهد. آدم مورد اعتماد معلم باشد Ùˆ چنین خبطی بکند؟ Ùˆ تازه جواب معلم را Ú†Ù‡ بدهد؟ ناچار خواهر او را لو داده بوده. بعد از او معلم را Ø§ØØ¶Ø§Ø± کردم. علت Ø§ØØ¶Ø§Ø± را می‌دانست. Ùˆ داد می‌زد Ú©Ù‡ چیزی ندارد بگوید. پس از یک Ù‡ÙØªÙ‡ مهلت، هنوز از ÙˆÙ‚Ø§ØØªÛŒ Ú©Ù‡ من پیدا کرده بودم، تا از آدم خلع سلاØâ€ŒØ´Ø¯Ù‡â€ŒØ§ÛŒ مثل او، دست بر ندارم، در تعجب بود. به او سیگار تعار٠کردم Ùˆ این قصه را برایش تعری٠کردم Ú©Ù‡ در اوایل تأسیس وزارت Ù…Ø¹Ø§Ø±ÙØŒ یک روز به وزیر خبر می‌دهند Ú©Ù‡ Ùلان معلم با Ùلان بچه روابطی دارد. وزیر Ùوراً او را می‌خواهد Ùˆ ØØ§Ù„ Ùˆ اØÙˆØ§Ù„ او را می‌پرسد Ùˆ این‌که چرا تا به ØØ§Ù„ زن Ù†Ú¯Ø±ÙØªÙ‡ Ùˆ ناچار تقصیر گردن بی‌پولی Ù…ÛŒâ€ŒØ§ÙØªØ¯ Ùˆ دستور Ú©Ù‡ Ùلان قدر به او Ú©Ù…Ú© کنند تا عروسی راه بیندازد Ùˆ خود او هم دعوت بشود Ùˆ قضیه به همین سادگی تمام می‌شود. Ùˆ بعد Ú¯ÙØªÙ… Ú©Ù‡ خیلی جوان‌ها هستند Ú©Ù‡ نمی‌توانند زن بگیرند Ùˆ وزرای ÙØ±Ù‡Ù†Ú¯ هم این روزها Ú¯Ø±ÙØªØ§Ø± Ù…ØµØ§ØØ¨Ù‡â€ŒÙ‡Ø§ÛŒ روزنامه‌ای Ùˆ رادیویی هستند. اما در نجیب‌خانه‌ها Ú©Ù‡ باز است Ùˆ ازین Ù…Ø²Ø®Ø±ÙØ§Øª... Ùˆ هم‌دردی Ùˆ نگذاشتم یک کلمه ØØ±Ù بزند. بعد هم عکس را Ú©Ù‡ توی پاکت گذاشته بودم، به دستش دادم Ùˆ ÙˆÙ‚Ø§ØØª را با این جمله به ØØ¯ اعلا رساندم Ú©Ù‡:
+
+- اگر به تخته نچسبونید، ضررشون کم‌تره.
+
+تا ØÙ‚وقم به لیست اداره‌ی ÙØ±Ù‡Ù†Ú¯ برسه، سه ماه طول کشید. ÙØ±Ù‡Ù†Ú¯ÛŒâ€ŒÙ‡Ø§ÛŒ گداگشنه Ùˆ خزانه‌ی خالی Ùˆ دست‌های از پا درازتر! اما خوبیش این بود Ú©Ù‡ در مدرسه‌ی ما ÙØ±Ø§Ø´ جدیدمان پولدار بود Ùˆ به همه‌شان قرض داد. Ú©Ù… Ú©Ù… بانک مدرسه شده بود. از سیصد Ùˆ خرده‌ای تومان Ú©Ù‡ Ù…ÛŒâ€ŒÚ¯Ø±ÙØªØŒ پنجاه تومان را هم خرج نمی‌کرد. نه سیگار می‌کشید Ùˆ نه اهل سینما بود Ùˆ نه برج دیگری داشت. از این گذشته، باغبان یکی از Ø¯Ù…â€ŒÚ©Ù„ÙØªâ€ŒÙ‡Ø§ÛŒ همان اطرا٠بود Ùˆ باغی Ùˆ دستگاهی Ùˆ سور Ùˆ ساتی Ùˆ لابد آشپزخانه‌ی مرتبی. خیلی زود معلم‌ها Ùهمیدند Ú©Ù‡ یک ÙØ±Ø§Ø´ پولدار خیلی بیش‌تر به درد می‌خورد تا یک مدیر بی‌بو Ùˆ خاصیت.
+
+این از معلم‌ها. ØÙ‚وق مرا هم هنوز از مرکز می‌دادند. با ØÙ‚وق ماه بعد هم اسم مرا هم به لیست اداره منتقل کردند. درین مدت خودم برای خودم ورقه انجام کار می‌نوشتم Ùˆ امضا می‌کردم Ùˆ Ù…ÛŒâ€ŒØ±ÙØªÙ… از مدرسه‌ای Ú©Ù‡ قبلاً در آن درس می‌دادم، ØÙ‚وقم را Ù…ÛŒâ€ŒÚ¯Ø±ÙØªÙ…. سر Ùˆ صدای ØÙ‚وق Ú©Ù‡ بلند می‌شد معلم‌ها مرتب می‌شدند Ùˆ کلاس ماهی سه چهار روز کاملاً دایر بود. تا ورقه‌ی انجام کار به دستشان بدهم. غیر از همان یک بار - در اوایل کار- Ú©Ù‡ برای معلم ØØ³Ø§Ø¨ پنج Ùˆ شش قرمز توی Ø¯ÙØªØ± گذاشتیم، دیگر با مداد قرمز کاری نداشتیم Ùˆ خیال همه‌شان Ø±Ø§ØØª بود. وقتی برای Ú¯Ø±ÙØªÙ† ØÙ‚وقم به اداره Ø±ÙØªÙ…ØŒ چنان شلوغی بود Ú©Ù‡ به خودم Ú¯ÙØªÙ… کاش اصلاً ØÙ‚وقم را منتقل نکرده بودم. نه می‌توانستم سر ص٠بایستم Ùˆ نه می‌توانستم از ØÙ‚وقم بگذرم. تازه مگر مواجب‌بگیر دولت چیزی جز یک انبان گشاده‌ی پای صندوق است؟..... Ùˆ اگر هم می‌ماندی با آن شلوغی باید تا دو بعداز ظهر سر پا بایستی. همه‌ی جیره‌خوارهای اداره بو برده بودند Ú©Ù‡ مدیرم. Ùˆ لابد آن‌قدر ساده Ù„ÙˆØ Ø¨ÙˆØ¯Ù†Ø¯ Ú©Ù‡ Ùکر کنند روزی گذارشان به مدرسه‌ی ما Ø¨ÛŒÙØªØ¯. دنبال Ø³ÙØªÙ‡â€ŒÙ‡Ø§ می‌گشتند، به ØØ³Ø§Ø¨Ø¯Ø§Ø± قبلی ÙØØ´ می‌دادند، التماس می‌کردند Ú©Ù‡ این ماه را ندیده بگیرید Ùˆ همه‌ی ØÙ‚ Ùˆ ØØ³Ø§Ø¨â€ŒØ¯Ø§Ù† شده بودند Ùˆ یکی Ú©Ù‡ زودتر از نوبت پولش را Ù…ÛŒâ€ŒÚ¯Ø±ÙØª صدای همه در می‌آمد. در لیست مدرسه، بزرگ‌ترین رقم مال من بود. درست مثل بزرگ‌ترین گناه در نامه‌ی عمل. دو برابر ÙØ±Ø§Ø´ جدیدمان ØÙ‚وق Ù…ÛŒâ€ŒÚ¯Ø±ÙØªÙ…. از دیدن رقم‌های مردنی ØÙ‚وق دیگران چنان خجالت کشیدم Ú©Ù‡ انگار مال آن‌ها را دزدیده‌ام. Ùˆ تازه خلوت Ú©Ù‡ شد Ùˆ ده پانزده تا امضا Ú©Ù‡ کردم، صندوق‌دار چشمش به من Ø§ÙØªØ§Ø¯ Ùˆ با یک معذرت، شش صد تومان پول دزدی را گذاشت ک٠دستم... مرده شور!
+
+هنوز بر٠اول نباریده بود Ú©Ù‡ یک روز عصر، معلم کلاس چهار Ø±ÙØª زیر ماشین. زیر یک سواری. مثل همه‌ی عصرها من مدرسه نبودم. دم غروب بود Ú©Ù‡ ÙØ±Ø§Ø´ قدیمی مدرسه دم در خونه‌مون، خبرش را آورد. Ú©Ù‡ دویدم به طر٠لباسم Ùˆ تا ØØ§Ø¶Ø± بشوم، می‌شنیدم Ú©Ù‡ دارد قضیه را برای زنم تعری٠می‌کند. ماشین برای یکی از آمریکایی‌ها بوده. باقیش را از خانه Ú©Ù‡ در آمدیم برایم تعری٠کرد. گویا یارو خودش پشت ÙØ±Ù…ون بوده Ùˆ بعد هم هول شده Ùˆ در Ø±ÙØªÙ‡. بچه‌ها خبر را به مدرسه برگردانده‌اند Ùˆ تا ÙØ±Ø§Ø´ Ùˆ زنش برسند، جمعیت Ùˆ پاسبان‌ها سوارش کرده بودند Ùˆ ÙØ±Ø³ØªØ§Ø¯Ù‡ بوده‌اند مریض‌خانه. به اتوبوس Ú©Ù‡ رسیدم، دیدم لاک پشت است. ÙØ±Ø§Ø´ را مرخص کردم Ùˆ پریدم توی تاکسی. اول Ø±ÙØªÙ… سراغ پاسگاه جدید کلانتری. تعاری٠تکه Ùˆ پاره‌ای از پرونده مطلع بود. اما پرونده تصریØÛŒ نداشت Ú©Ù‡ راننده Ú©Ù‡ بوده. اما هیچ کس نمی‌دانست عاقبت Ú†Ù‡ بلایی بر سر معلم کلاس چهار ما آمده است. کشیک پاسگاه همین قدر مطلع بود Ú©Ù‡ درین جور موارد «طبق جریان اداری» اول می‌روند سرکلانتری، بعد دایره‌ی ØªØµØ§Ø¯ÙØ§Øª Ùˆ بعد بیمارستان. اگر آشنا در نمی‌آمدیم، کشیک پاسگاه مسلماً نمی‌گذاشت به پرونده نگاه Ú†Ù¾ بکنم. Ø§ØØ³Ø§Ø³ کردم میان اهل Ù…ØÙ„ کم‌کم دارم سرشناس می‌شوم. Ùˆ از این Ø§ØØ³Ø§Ø³ خنده‌ام Ú¯Ø±ÙØª.
+
+ساعت Û¸ دم در بیمارستان بودم، اگر سالم هم بود ØØªÙ…اً یه چیزیش شده بود. همان طور Ú©Ù‡ من یه چیزیم می‌شد. روی در بیمارستان نوشته شده بود: «از ساعت Û· به بعد ورود ممنوع». در زدم. از پشت در کسی همین آیه را صادر کرد. دیدم ÙØ§ÛŒØ¯Ù‡ ندارد Ùˆ باید از یک چیزی Ú©Ù…Ú© بگیرم. از قدرتی، از مقامی، از هیکلی، از یک چیزی. صدایم را Ú©Ù„ÙØª کردم Ùˆ Ú¯ÙØªÙ…:« من...» می‌خواستم بگویم من مدیر مدرسه‌ام. ولی Ùوراً پشیمان شدم. یارو لابد Ù…ÛŒâ€ŒÚ¯ÙØª مدیر مدرسه کدام سگی است؟ این بود با Ú©Ù…ÛŒ Ù…Ú©Ø« Ùˆ طمطراق ÙØ±Ø§ÙˆØ§Ù† جمله‌ام را این طور تمام کردم:
+
+- ...بازرس وزارت ÙØ±Ù‡Ù†Ú¯Ù….
+
+Ú©Ù‡ کلون صدایی کرد Ùˆ لای در باز شد. یارو با چشم‌هایش سلام کرد. Ø±ÙØªÙ… تو Ùˆ با همان صدا پرسیدم:
+
+- این معلمه مدرسه که تصاد٠کرده...
+
+تا آخرش را خواند. یکی را صدا زد Ùˆ دنبالم ÙØ±Ø³ØªØ§Ø¯ Ú©Ù‡ طبقه‌ی Ùلان، اتاق Ùلان. از ØÛŒØ§Ø· به راهرو Ùˆ باز به ØÛŒØ§Ø· دیگر Ú©Ù‡ Ù†ØµÙØ´ را بر٠پوشانده بود Ùˆ من چنان می‌دویدم Ú©Ù‡ یارو از عقب سرم هن هن می‌کرد. طبقه‌ی اول Ùˆ دوم Ùˆ چهارم. چهار تا پله یکی. راهرو تاریک بود Ùˆ پر از بوهای مخصوص بود. هن هن کنان دری را نشان داد Ú©Ù‡ هل دادم Ùˆ Ø±ÙØªÙ… تو. بو تندتر بود Ùˆ تاریکی بیشتر. تالاری بود پر از تخت Ùˆ جیرجیر Ú©ÙØ´ Ùˆ خرخر یک Ù†ÙØ±. دور یک تخت چهار Ù†ÙØ± ایستاده بودند. ØØªÙ…اً خودش بود. پای تخت Ú©Ù‡ رسیدم، Ø§ØØ³Ø§Ø³ کردم همه‌ی آنچه از خشونت Ùˆ تظاهر Ùˆ ابهت به Ú©Ù…Ú© خواسته بودم آب شد Ùˆ بر سر Ùˆ صورتم راه Ø§ÙØªØ§Ø¯. Ùˆ این معلم کلاس چهارم مدرسه‌ام بود. سنگین Ùˆ با Ø´Ú©Ù… بر آمده دراز کشیده بود. خیلی کوتاه‌تر از زمانی Ú©Ù‡ سر پا بود به نظرم آمد. صورت Ùˆ سینه‌اش از روپوش Ú†Ø±Ú©â€ŒÙ…ÙØ±Ø¯ بیرون بود. صورتش را Ú©Ù‡ شسته بودند کبود کبود بود، درست به رنگ جای سیلی روی صورت بچه‌ها. مرا Ú©Ù‡ دید، لبخند Ùˆ Ú†Ù‡ لبخندی! شاید می‌خواست بگوید مدرسه‌ای Ú©Ù‡ مدیرش عصرها سر کار نباشد، باید همین جورها هم باشد. خنده توی صورت او همین طور لرزید Ùˆ لرزید تا یخ زد.
+
+«آخر چرا تصاد٠کردی؟...»
+
+مثل این Ú©Ù‡ سوال را ازو کردم. اما وقتی Ú©Ù‡ دیدم نمی‌تواند ØØ±Ù بزند Ùˆ به جای هر جوابی همان خنده‌ی یخ‌بسته را روی صورت دارد، خودم را به عنوان او دم Ú†Ú© Ú¯Ø±ÙØªÙ…. «آخه چرا؟ چرا این هیکل مدیر Ú©Ù„ÛŒ را با خودت این قد این ور Ùˆ آن ور می‌بری تا بزنندت؟ تا زیرت کنند؟ مگر نمی‌دانستی Ú©Ù‡ معلم ØÙ‚ ندارد این قدر خوش‌هیکل باشد؟ آخر چرا تصاد٠کردی؟» به چنان عتاب Ùˆ خطابی این‌ها را Ù…ÛŒâ€ŒÚ¯ÙØªÙ… Ú©Ù‡ هیچ مطمئن نیستم بلند بلند به خودش Ù†Ú¯ÙØªÙ‡ باشم. Ùˆ یک مرتبه به کله‌ام زد Ú©Ù‡ «مبادا خودت چشمش زده باشی؟» Ùˆ بعد: «اØÙ…Ù‚ خاک بر سر! بعد از سی Ùˆ چند سال عمر، تازه Ø®Ø±Ø§ÙØ§ØªÛŒ شدی!» Ùˆ چنان از خودم بیزاریم Ú¯Ø±ÙØª Ú©Ù‡ می‌خواستم به یکی ÙØØ´ بدهم، کسی را بزنم. Ú©Ù‡ چشمم به دکتر کشیک Ø§ÙØªØ§Ø¯.
+
+- مرده شور این مملکتو ببره. ساعت چهار تا ØØ§Ù„ا از تن این مرد خون می‌ره. ØÛŒÙتون نیومد؟...
+
+دستی روی شانه‌ام نشست Ùˆ ÙØ±ÛŒØ§Ø¯Ù… را خواباند. برگشتم پدرش بود. او هم می‌خندید. دو Ù†ÙØ± دیگر هم با او بودند. همه دهاتی‌وار؛ همه خوش قد Ùˆ قواره. ØØ¸ کردم! آن دو تا پسرهایش بودند یا برادرزاده‌هایش یا کسان دیگرش. تازه داشت Ú¯Ù„ از گلم Ù…ÛŒâ€ŒØ´Ú©ÙØª Ú©Ù‡ شنیدم:
+
+- آقا کی باشند؟
+
+این راهم دکتر کشیک Ú¯ÙØª Ú©Ù‡ من باز سوار شدم:
+
+- مرا می‌گید آقا؟ من هیشکی. یک آقا مدیر Ú©ÙˆÙØªÛŒ. این هم معلمم.
+
+Ú©Ù‡ یک مرتبه عقل Ù‡ÛŒ زد Ùˆ «پسر Ø®ÙÙ‡ شو» Ùˆ Ø®ÙÙ‡ شدم. بغض توی گلویم بود. دلم می‌خواست یک کلمه دیگر بگوید. یک کنایه بزند... نسبت به مهارت هیچ دکتری تا کنون نتوانسته‌ام قسم بخورم. دستش را دراز کرد Ú©Ù‡ به اکراه ÙØ´Ø§Ø± دادم Ùˆ بعد شیشه‌ی بزرگی را نشانم داد Ú©Ù‡ وارونه بالای تخت آویزان بود Ùˆ خرÙهمم کرد Ú©Ù‡ این جوری غذا به او می‌رسانند Ùˆ عکس هم Ú¯Ø±ÙØªÙ‡â€ŒØ§Ù†Ø¯ Ùˆ تا ÙØ±Ø¯Ø§ ØµØ¨Ø Ø§Ú¯Ø± زخم‌ها چرک نکند، جا خواهند انداخت Ùˆ Ú¯Ú† خواهند کرد. Ú©Ù‡ یکی دیگر از راه رسید. گوشی به دست Ùˆ سÙید پوش Ùˆ معطر. با ØØ±Ú©Ø§ØªÛŒ مثل آرتیست سینما. سلامم کرد. صدایش در ته ذهنم چیزی را مختصر تکانی داد. اما Ø§ØØªÛŒØ§Ø¬ÛŒ به کنجکاوی نبود. یکی از شاگردهای نمی‌دانم چند سال پیشم بود. خودش خودش را معرÙÛŒ کرد. آقای دکتر...! عجب روزگاری! هر تکه از وجودت را با مزخرÙÛŒ از انبان Ù…Ø²Ø®Ø±ÙØ§ØªØªØŒ مثل ذره‌ای روزی در خاکی ریخته‌ای Ú©Ù‡ ØØ§Ù„ا سبز کرده. چشم داری اØÙ…Ù‚. این تویی Ú©Ù‡ روی تخت دراز کشیده‌ای. ده سال آزگار از پلکان ساعات Ùˆ دقایق عمرت هر Ù„ØØ¸Ù‡ یکی بالا Ø±ÙØªÙ‡ Ùˆ تو Ùقط خستگی این بار را هنوز در تن داری. این جوجه‌ÙÚ©Ù„ÛŒ Ùˆ جوجه‌های دیگر Ú©Ù‡ نمی‌شناسی‌شان، همه از تخمی سر در آورده‌اند Ú©Ù‡ روزی ØØµØ§Ø± جوانی تو بوده Ùˆ ØØ§Ù„ا شکسته Ùˆ خالی مانده. دستش را Ú¯Ø±ÙØªÙ… Ùˆ کشیدمش کناری Ùˆ در گوشش هر Ú†Ù‡ بد Ùˆ بی‌راه می‌دانستم، به او Ùˆ همکارش Ùˆ شغلش دادم. مثلاً می‌خواستم Ø³ÙØ§Ø±Ø´ معلم کلاس چهار مدرسه‌ام را کرده باشم. بعد هم سری برای پدر تکان دادم Ùˆ گریختم. از در Ú©Ù‡ بیرون آمدم، ØÛŒØ§Ø· بود Ùˆ هوای بارانی. از در بزرگ Ú©Ù‡ بیرون آمدم به این Ùکر می‌کردم Ú©Ù‡ «اصلا به تو چه؟ اصلاً چرا آمدی؟ می‌خواستی کنجکاوی‌ات را سیرکنی؟» Ùˆ دست آخر به این نتیجه رسیدم Ú©Ù‡ «طعمه‌ای برای میزنشین‌های شهربانی Ùˆ دادگستری به دست آمده Ùˆ تو نه می‌توانی این طعمه را از دستشان بیرون بیاوری Ùˆ نه هیچ کار دیگری می‌توانی بکنی...»
+
+Ùˆ داشتم سوار تاکسی می‌شدم تا برگردم خانه Ú©Ù‡ یک Ø¯ÙØ¹Ù‡ به ØµØ±Ø§ÙØª Ø§ÙØªØ§Ø¯Ù… Ú©Ù‡ اقلاً چرا نپرسیدی Ú†Ù‡ بلایی به سرش آمده؟» خواستم عقب‌گرد کنم، اما هیکل کبود معلم کلاس چهارم روی تخت بود Ùˆ دیدم نمی‌توانم. خجالت می‌کشیدم Ùˆ یا می‌ترسیدم. آن شب تا ساعت دو بیدار بودم Ùˆ ÙØ±Ø¯Ø§ یک گزارش Ù…ÙØµÙ„ به امضای مدیر مدرسه Ùˆ شهادت همه‌ی معلم‌ها برای اداره‌ی ÙØ±Ù‡Ù†Ú¯ Ùˆ کلانتری Ù…ØÙ„ Ùˆ بعد هم دوندگی در اداره‌ی بیمه Ùˆ قرار بر این Ú©Ù‡ روزی نه تومان بودجه برای خرج بیمارستان او بدهند Ùˆ عصر پس از مدتی Ø±ÙØªÙ… مدرسه Ùˆ کلاس‌ها را تعطیل کردم Ùˆ معلم‌ها Ùˆ بچه‌های ششم را ÙØ±Ø³ØªØ§Ø¯Ù… عیادتش Ùˆ دسته Ú¯Ù„ Ùˆ ازین بازی‌ها... Ùˆ یک ساعتی در مدرسه تنها ماندم Ùˆ ÙØ§Ø±Øº از همه چیز برای خودم خیال Ø¨Ø§ÙØªÙ….... Ùˆ ÙØ±Ø¯Ø§ ØµØ¨Ø Ù¾Ø¯Ø±Ø´ آمد سلام Ùˆ اØÙˆØ§Ù„پرسی Ùˆ Ú¯ÙØª یک دست Ùˆ یک پایش شکسته Ùˆ Ú©Ù…ÛŒ خونریزی داخل مغز Ùˆ از طر٠یارو آمریکاییه آمده‌اند عیادتش Ùˆ وعده Ùˆ وعید Ú©Ù‡ وقتی خوب شد، در اصل چهار استخدامش کنند Ùˆ با زبان بی‌زبانی ØØ§Ù„یم کرد Ú©Ù‡ گزارش را بیخود داده‌ام Ùˆ ØØ§Ù„ا هم داده‌ام، دنبالش نکنم Ùˆ رضایت طرÙین Ùˆ کاسه‌ی از آش داغ‌تر Ùˆ از این ØØ±Ù‌ها... خاک بر سر مملکت.
+
+اوایل امر توجهی به بچه‌ها نداشتم. خیال می‌کردم اختلا٠سÙÙ†ÛŒ میان‌مان آن قدر هست Ú©Ù‡ کاری به کار همدیگر نداشته باشیم. همیشه سرم به کار خودم بود. در Ø¯ÙØªØ± را می‌بستم Ùˆ در گرمای بخاری دولت قلم صد تا یک غاز می‌زدم. اما این کار مرتب سه چهار Ù‡ÙØªÙ‡ بیش‌تر دوام نکرد. خسته شدم. ناچار به مدرسه بیشتر می‌رسیدم. یاد روزهای قدیمی با دوستان قدیمی به خیر Ú†Ù‡ آدم‌های پاک Ùˆ بی‌آلایشی بودند، Ú†Ù‡ شخصیت‌های بی‌نام Ùˆ نشانی Ùˆ هر کدام با Ú†Ù‡ زبانی Ùˆ با Ú†Ù‡ ادا Ùˆ اطوارهای مخصوص به خودشان Ùˆ این جوان‌های Ú†Ù„ÙØªÙ‡â€ŒØ§ÛŒ. Ú†Ù‡ مقلدهای بی‌دردسری برای ÙØ±Ù‡Ù†Ú¯ÛŒâ€ŒÙ…ابی! نه خبری از دیروزشان داشتند Ùˆ نه از املاک تازه‌ای Ú©Ù‡ با Ù‡ÙØªØ§Ø¯ واسطه به دست‌شان داده بودند، چیزی سرشان می‌شد. بدتر از همه بی‌دست Ùˆ پایی‌شان بود. آرام Ùˆ مرتب درست مثل واگن شاه عبدالعظیم می‌آمدند Ùˆ Ù…ÛŒâ€ŒØ±ÙØªÙ†Ø¯. Ùقط بلد بودند روزی ده دقیقه دیرتر بیایند Ùˆ همین. Ùˆ از این هم بدتر تنگ‌نظری‌شان بود.
+
+سه بار شاهد دعواهایی بودم Ú©Ù‡ سر یک گلدان میخک یا شمعدانی بود. بچه‌باغبان‌ها زیاد بودند Ùˆ هر کدام‌شان ØØ¯Ø§Ù‚Ù„ ماهی یک گلدان میخک یا شمعدانی می‌آوردند Ú©Ù‡ در آن بر٠و سرما نعمتی بود. اول تصمیم Ú¯Ø±ÙØªÙ…ØŒ مدرسه را با آن‌ها زینت دهم. ولی Ú†Ù‡ ÙØ§ÛŒØ¯Ù‡ØŸ نه کسی آب‌شان می‌داد Ùˆ نه مواظبتی. Ùˆ باز بدتر از همه‌ی این‌ها، بی‌شخصیتی معلم‌ها بود Ú©Ù‡ درمانده‌ام کرده بود. دو کلمه نمی‌توانستند ØØ±Ù بزنند. عجب هیچ‌کاره‌هایی بودند! Ø§ØØ³Ø§Ø³ کردم Ú©Ù‡ روز به روز در کلاس‌ها معلم‌ها به جای دانش‌آموزان Ø¬Ø§Ø§ÙØªØ§Ø¯Ù‡â€ŒØªØ± می‌شوند. در نتیجه Ú¯ÙØªÙ… بیش‌تر متوجه بچه‌ها باشم.
+
+آن‌ها Ú©Ù‡ تنها با ناظم سر Ùˆ کار داشتند Ùˆ مثل این بود Ú©Ù‡ به من Ùقط یک سلام نیمه‌جویده بدهکارند. با این همه نومیدکننده نبودند. توی Ú©ÙˆÚ†Ù‡ مواظب‌شان بودم. می‌خواستم ØØ±Ù Ùˆ سخن‌ها Ùˆ درد دل‌ها Ùˆ اÙکارشان را از یک ÙØØ´ نیمه‌کاره یا از یک ادای نیمه‌تمام ØØ¯Ø³ بزنم، Ú©Ù‡ سلام‌نکرده در Ù…ÛŒâ€ŒØ±ÙØªÙ†Ø¯. خیلی Ú©Ù… تنها به مدرسه می‌آمدند. پیدا بود Ú©Ù‡ سر راه همدیگر می‌ایستند یا در خانه‌ی یکدیگر می‌روند. سه چهار Ù†ÙØ±Ø´Ø§Ù† هم با اسکورت می‌آمدند. از بیست سی Ù†ÙØ±ÛŒ Ú©Ù‡ ناهار می‌ماندند، Ùقط دو Ù†ÙØ±Ø´Ø§Ù† چلو خورش می‌آوردند؛ ÙØ±Ø§Ø´ اولی مدرسه برایم خبر می‌آورد. بقیه گوشت‌کوبیده، پنیر گردوئی، دم پختکی Ùˆ از این جور چیزها. دو Ù†ÙØ±Ø´Ø§Ù† هم بودند Ú©Ù‡ نان سنگک خالی می‌آوردند. برادر بودند. پنجم Ùˆ سوم. ØµØ¨Ø Ú©Ù‡ می‌آمدند، جیب‌هاشان باد کرده بود. سنگک را نص٠می‌کردند Ùˆ توی جیب‌هاشان می‌تپاندند Ùˆ ظهر می‌شد، مثل آن‌هایی Ú©Ù‡ ناهارشان را در خانه می‌خورند، Ù…ÛŒâ€ŒØ±ÙØªÙ†Ø¯ بیرون. من Ùقط بیرون Ø±ÙØªÙ†â€ŒØ´Ø§Ù† را می‌دیدم. اما ØØªÛŒ همین‌ها هر کدام روزی، یکی دو قران از ÙØ±Ø§Ø´ مدرسه خرت Ùˆ خورت می‌خریدند. از همان ÙØ±Ø§Ø´ قدیمی مدرسه Ú©Ù‡ ماهی پنج تومان سرایداریش را وصول کرده بودم. هر روز Ú©Ù‡ وارد اتاقم می‌شدم پشت سر من می‌آمد بارانی‌ام را بر می‌داشت Ùˆ شروع می‌کرد به گزارش دادن، Ú©Ù‡ دیروز باز دو Ù†ÙØ± از معلم‌ها سر یک گلدان دعوا کرده‌اند یا مأمور ÙØ±Ù…اندار نظامی آمده یا Ø¯ÙØªØ±Ø¯Ø§Ø± عوض شده Ùˆ از این اباطیل... پیدا بود Ú©Ù‡ ÙØ±Ø§Ø´ جدید هم در مطالبی Ú©Ù‡ او Ù…ÛŒâ€ŒÚ¯ÙØªØŒ سهمی دارد.
+
+یک روز در ØÛŒÙ† گزارش دادن، اشاره‌ای کرد به این مطلب Ú©Ù‡ دیروز عصر یکی از بچه‌های کلاس چهار دو تا کله قند به او ÙØ±ÙˆØ®ØªÙ‡ است. درست مثل اینکه سر کلا٠را به دستم داده باشد پرسیدم:
+
+- چند؟
+
+- دو تومنش دادم آقا.
+
+- زØÙ…ت کشیدی. Ù†Ú¯ÙØªÛŒ از کجا آورده؟
+
+- من که ضامن بهشت و جهنمش نبودم آقا.
+
+بعد پرسیدم:
+
+- چرا به آقای ناظم خبر ندادی؟
+
+می‌دانستم Ú©Ù‡ هم او Ùˆ هم ÙØ±Ø§Ø´ جدید، ناظم را هووی خودشان می‌دانند Ùˆ خیلی چیزهاشان از او مخÙÛŒ بود. این بود Ú©Ù‡ میان من Ùˆ ناظم خاصه‌خرجی می‌کردند. در جوابم همین طور مردد مانده بود Ú©Ù‡ در باز شد Ùˆ ÙØ±Ø§Ø´ جدید آمد تو. Ú©Ù‡:
+
+- اگه خبرش می‌کرد آقا بایست سهمش رو می‌داد...
+
+اخمم را درهم کشیدم Ùˆ Ú¯ÙØªÙ…:
+
+- تو باز Ø±ÙØªÛŒ تو Ú©ÙˆÚ© مردم! اونم این جوری سر نزده Ú©Ù‡ نمی‌آیند تو اتاق کسی، پیرمرد!
+
+Ùˆ بعد اسم پسرک را ازشان پرسیدم Ùˆ ØØ§Ù„ی‌شان کردم Ú©Ù‡ چندان مهم نیست Ùˆ ÙØ±Ø³ØªØ§Ø¯Ù…شان برایم چای بیاورند. بعد کارم را زودتر تمام کردم Ùˆ Ø±ÙØªÙ… به اتاق Ø¯ÙØªØ± اØÙˆØ§Ù„ÛŒ از مادر ناظم پرسیدم Ùˆ به هوای ورق زدن پرونده‌ها Ùهمیدم Ú©Ù‡ پسرک شاگرد دوساله است Ùˆ پدرش تاجر بازار. بعد برگشتم به اتاقم. یادداشتی برای پدر نوشتم Ú©Ù‡ پس ÙØ±Ø¯Ø§ ØµØ¨ØØŒ بیاید مدرسه Ùˆ دادم دست ÙØ±Ø§Ø´ جدید Ú©Ù‡ خودش برساند Ùˆ رسیدش را بیاورد.
+
+Ùˆ پس ÙØ±Ø¯Ø§ ØµØ¨Ø ÛŒØ§Ø±Ùˆ آمد. باید مدیر مدرسه بود تا دانست Ú©Ù‡ اولیای Ø§Ø·ÙØ§Ù„ Ú†Ù‡ Ø±Ø§ØØª تن به کوچک‌ترین Ø®Ø±Ø¯Ù‡â€ŒÙØ±Ù…ایش‌های مدرسه می‌دهند. ØØªÙ… دارم Ú©Ù‡ اگر از اجرای ثبت هم دنبال‌شان Ø¨ÙØ±Ø³ØªÛŒ به این زودی‌ها Ø¢ÙØªØ§Ø¨ÛŒ نشوند. چهل Ùˆ پنج ساله مردی بود با یخه‌ی بسته بی‌کراوات Ùˆ پالتویی Ú©Ù‡ بیش‌تر به قبا می‌ماند. Ùˆ خجالتی می‌نمود. هنوز ننشسته، پرسیدم:
+
+- شما دو تا زن دارید آقا؟
+
+درباره‌ی پسرش برای خودم پیش‌گویی‌هایی کرده بودم Ùˆ Ú¯ÙØªÙ… این طوری به او رودست می‌زنم. پیدا بود Ú©Ù‡ از سؤالم زیاد یکه نخورده است. Ú¯ÙØªÙ… برایش چای آوردند Ùˆ سیگاری ØªØ¹Ø§Ø±ÙØ´ کردم Ú©Ù‡ ناشیانه دود کرد از ترس این Ú©Ù‡ مبادا جلویم در بیاید Ú©Ù‡ - به شما Ú†Ù‡ مربوط است Ùˆ از این اعتراض‌ها - امانش ندادم Ùˆ سؤالم را این جور دنبال کردم:
+
+- البته می‌بخشید. چون لابد به همین علت بچه شما دو سال در یک کلاس مانده.
+
+شروع کرده بودم برایش یک میتینگ بدهم Ú©Ù‡ پرید وسط ØØ±ÙÙ…:
+
+- به سر شما قسم، روزی چهار زار پول تو جیبی داره آقا. پدرسوخته‌ی نمک به ØØ±ÙˆÙ…...!
+
+ØØ§Ù„یش کردم Ú©Ù‡ علت، پول تو جیبی نیست Ùˆ خواستم Ú©Ù‡ عصبانی نشود Ùˆ قول Ú¯Ø±ÙØªÙ… Ú©Ù‡ اصلاً به روی پسرش هم نیاورد Ùˆ آن وقت میتینگم را برایش دادم Ú©Ù‡ لابد پسر در خانه مهر Ùˆ Ù…ØØ¨ØªÛŒ نمی‌بیند Ùˆ غیب‌گویی‌های دیگر... تا عاقبت یارو خجالتش ریخت Ùˆ سر٠درد دلش باز شد Ú©Ù‡ Ø¹ÙØ±ÛŒØªÙ‡ زن اولش همچه بوده Ùˆ همچون بوده Ùˆ پسرش هم به خودش برده Ùˆ Ú©ÛŒ طلاقش داده Ùˆ از زن دومش چند تا بچه دارد Ùˆ این نره‌خر ØØ§Ù„ا باید برای خودش نان‌آور شده باشد Ùˆ زنش ØÙ‚ دارد Ú©Ù‡ با دو تا بچه‌ی خرده‌پا به او نرسد... من هم Ú©Ù„ÛŒ برایش ØµØØ¨Øª کردم. چایی دومش را هم سر کشید Ùˆ قول‌هایش را Ú©Ù‡ داد Ùˆ Ø±ÙØªØŒ من به این Ùکر Ø§ÙØªØ§Ø¯Ù… Ú©Ù‡ «نکند علمای تعلیم Ùˆ تربیت هم، همین جورها تخم دوزرده می‌کنند!»
+
+یک روز ØµØ¨Ø Ú©Ù‡ رسیدم، ناظم هنوز نیامده بود. از این Ø§ØªÙØ§Ù‚‌ها Ú©Ù… Ù…ÛŒâ€ŒØ§ÙØªØ§Ø¯. ده دقیقه‌ای از زنگ می‌گذشت Ùˆ معلم‌ها در Ø¯ÙØªØ± سرگرم اختلاط بودند. خودم هم وقتی معلم بودم به این مرض دچار بودم. اما وقتی مدیر شدم تازه Ùهمیدم Ú©Ù‡ معلم‌ها Ú†Ù‡ لذتی می‌برند. ØÙ‚ هم داشتند. آدم وقتی مجبور باشد Ø´Ú©Ù„Ú©ÛŒ را به صورت بگذارد Ú©Ù‡ نه دیگران از آن می‌خندند Ùˆ نه خود آدم لذتی می‌برد، پیداست Ú©Ù‡ Ø±ÙØ¹ تکلی٠می‌کند. زنگ را Ú¯ÙØªÙ… زدند Ùˆ بچه‌ها سر کلاس Ø±ÙØªÙ†Ø¯. دو تا از کلاس‌ها بی‌معلم بود. یکی از ششمی‌ها را ÙØ±Ø³ØªØ§Ø¯Ù… سر کلاس سوم Ú©Ù‡ برای‌شان دیکته بگوید Ùˆ خودم Ø±ÙØªÙ… سر کلاس چهار. مدیر هم Ú©Ù‡ باشی، باز باید تمرین Ú©Ù†ÛŒ Ú©Ù‡ مبادا Ùوت Ùˆ ÙÙ† معلمی از یادت برود. در ØØ§Ù„ ØµØØ¨Øª با بچه‌ها بودم Ú©Ù‡ ÙØ±Ø§Ø´ خبر آورد Ú©Ù‡ خانمی توی Ø¯ÙØªØ± منتظرم است. خیال کردم لابد همان زنکه‌ی بیکاره‌ای است Ú©Ù‡ Ù‡ÙØªÙ‡â€ŒØ§ÛŒ یک بار به هوای سرکشی، به وضع درس Ùˆ مشق بچه‌اش سری می‌زند. زن سÙیدرویی بود با چشم‌های درشت Ù…ØØ²ÙˆÙ† Ùˆ موی بور. بیست Ùˆ پنج ساله هم نمی‌نمود. اما بچه‌اش کلاس سوم بود. روز اول Ú©Ù‡ دیدمش لباس نارنجی به تن داشت Ùˆ تن بزک کرده بود. از زیارت من خیلی Ø®ÙˆØ´ØØ§Ù„ شد Ùˆ از مراتب ÙØ¶Ù„ Ùˆ ادبم خبر داشت.
+
+خیلی ساده آمده بود تا با دو تا مرد ØØ±ÙÛŒ زده باشد. آن طور Ú©Ù‡ ناظم خبر می‌داد، یک سالی طلاق Ú¯Ø±ÙØªÙ‡ بود Ùˆ روی هم Ø±ÙØªÙ‡ آمد Ùˆ Ø±ÙØªÙ†Ø´ به مدرسه باعث دردسر بود. وسط بیابان Ùˆ مدرسه‌ای پر از معلم‌های عزب Ùˆ بی‌دست Ùˆ پا Ùˆ یک زن زیبا... ناچار جور در نمی‌آمد. این بود Ú©Ù‡ Ø¯ÙØ¹Ø§Øª بعد دست به سرش می‌کردم، اما از رو Ù†Ù…ÛŒâ€ŒØ±ÙØª. سراغ ناظم Ùˆ اتاق Ø¯ÙØªØ± را Ù…ÛŒâ€ŒÚ¯Ø±ÙØª Ùˆ صبر می‌کرد تا زنگ را بزنند Ùˆ معلم‌ها جمع بشوند Ùˆ لابد ØØ±Ù Ùˆ سخنی Ùˆ خنده‌ای Ùˆ بعد از معلم کلاس سوم سراغ کار Ùˆ بار Ùˆ بچه‌اش را Ù…ÛŒâ€ŒÚ¯Ø±ÙØª Ùˆ زنگ بعد را Ú©Ù‡ می‌زدند، Ø®Ø¯Ø§ØØ§Ùظی می‌کرد Ùˆ Ù…ÛŒâ€ŒØ±ÙØª. آزاری نداشت. با چشم‌هایش Ù†ÙØ³ معلم‌ها را می‌برید. Ùˆ ØØ§Ù„ا باز هم همان زن بود Ùˆ آمده بود Ùˆ من تا از پلکان پایین بروم در ذهنم جملات زننده‌ای ردی٠می‌کردم، تا پایش را از مدرسه ببرد Ú©Ù‡ در را باز کردم Ùˆ سلام...
+
+عجب! او نبود. دخترک یکی دو ساله‌ای بود با دهان گشاد Ùˆ موهای زبرش را به زØÙ…ت عقب سرش گلوله کرده بود Ùˆ بÙهمی Ù†Ùهمی دستی توی صورتش برده بود. روی هم Ø±ÙØªÙ‡ زشت نبود. اما داد می‌زد Ú©Ù‡ معلم است. Ú¯ÙØªÙ… Ú©Ù‡ مدیر مدرسه‌ام Ùˆ ØÚ©Ù…Ø´ را داد دستم Ú©Ù‡ دانشسرا دیده بود Ùˆ تازه استخدام شده بود. برایمان معلم ÙØ±Ø³ØªØ§Ø¯Ù‡ بودند. خواستم بگویم «مگر رئیس ÙØ±Ù‡Ù†Ú¯ نمی‌داند Ú©Ù‡ این جا بیش از ØØ¯ مرد است» ولی دیدم لزومی ندارد Ùˆ Ùکر کردم این هم خودش تنوعی است.
+
+به هر صورت زنی بود Ùˆ می‌توانست Ù…ØÛŒØ· خشن مدرسه را Ú©Ù‡ به طرز ناشیانه‌ای پسرانه بود، Ù„Ø·Ø§ÙØªÛŒ بدهد Ùˆ خوش‌آمد Ú¯ÙØªÙ… Ùˆ چای آوردند Ú©Ù‡ نخورد Ùˆ بردمش کلاس‌های سوم Ùˆ چهارم را نشانش دادم Ú©Ù‡ هر کدام را مایل است، قبول کند Ùˆ ØµØØ¨Øª از هجده ساعت درس Ú©Ù‡ در انتظار او بود Ùˆ برگشتیم به Ø¯ÙØªØ± .پرسید غیر از او هم، معلم زن داریم. Ú¯ÙØªÙ…:
+
+- Ù…ØªØ£Ø³ÙØ§Ù†Ù‡ راه مدرسه‌ی ما را برای پاشنه‌ی Ú©ÙØ´ خانم‌ها نساخته‌اند.
+
+Ú©Ù‡ خندید Ùˆ Ø§ØØ³Ø§Ø³ کردم زورکی می‌خندد. بعد Ú©Ù…ÛŒ این دست Ùˆ آن دست کرد Ùˆ عاقبت:
+
+- آخه من شنیده بودم شما با معلماتون خیلی خوب تا می‌کنید.
+
+صدای جذابی داشت. Ùکر کردم ØÛŒÙ Ú©Ù‡ این صدا را پای تخته سیاه خراب خواهد کرد. Ùˆ Ú¯ÙØªÙ…:
+
+- اما نه این قدر Ú©Ù‡ مدرسه تعطیل بشود خانم! Ùˆ لابد به عرض‌تون رسیده Ú©Ù‡ همکارهای شما، خودشون نشسته‌اند Ùˆ تصمیم Ú¯Ø±ÙØªÙ‡â€ŒØ§Ù†Ø¯ Ú©Ù‡ هجده ساعت درس بدهند. بنده هیچ‌کاره‌ام.
+
+- اختیار دارید.
+
+Ùˆ Ù†Ùهمیدم با این «اختیار دارید» Ú†Ù‡ می‌خواست بگوید. اما پیدا بود Ú©Ù‡ Ø¨ØØ« سر ساعات درس نیست. آناً تصمیم Ú¯Ø±ÙØªÙ…ØŒ Ø§Ù…ØªØØ§Ù†ÛŒ بکنم:
+
+- این را هم اطلاع داشته باشید Ú©Ù‡ Ùقط دو تا از معلم‌های ما متأهل‌اند.
+
+Ú©Ù‡ قرمز شد Ùˆ برای این Ú©Ù‡ کار دیگری نکرده باشد، برخاست Ùˆ ØÚ©Ù…Ø´ را از روی میز برداشت. پا به پا می‌شد Ú©Ù‡ دیدم باید به دادش برسم. ساعت را از او پرسیدم. وقت زنگ بود. ÙØ±Ø§Ø´ را صدا کردم Ú©Ù‡ زنگ را بزند Ùˆ بعد به او Ú¯ÙØªÙ…ØŒ بهتر است مشورت دیگری هم با رئیس ÙØ±Ù‡Ù†Ú¯ بکند Ùˆ ما به هر صورت Ø®ÙˆØ´ØØ§Ù„ خواهیم شد Ú©Ù‡ Ø§ÙØªØ®Ø§Ø± همکاری با خانمی مثل ایشان را داشته باشیم Ùˆ Ø®Ø¯Ø§ØØ§Ùظ شما. از در Ø¯ÙØªØ± Ú©Ù‡ بیرون Ø±ÙØªØŒ صدای زنگ برخاست Ùˆ معلم‌ها انگار موشان را آتش زده‌اند، به عجله رسیدند Ùˆ هر کدام از پشت سر، آن قدر او را پاییدند تا از در بزرگ آهنی مدرسه بیرون Ø±ÙØª.
+
+ÙØ±Ø¯Ø§ ØµØ¨Ø Ù…Ø¹Ù„ÙˆÙ… شد Ú©Ù‡ ناظم، دنبال کار مادرش بوده است Ú©Ù‡ قرار بود بستری شود، تا جای سرطان Ú¯Ø±ÙØªÙ‡ را یک دوره برق بگذارند. Ú©Ù„ کار بیمارستان را من به Ú©Ù…Ú© دوستانم انجام دادم Ùˆ موقع آن رسیده بود Ú©Ù‡ مادرش برود بیمارستان اما ÙˆØØ´ØªØ´ Ú¯Ø±ÙØªÙ‡ بود Ùˆ ØØ§Ø¶Ø± نبود به بیمارستان برود. Ùˆ ناظم می‌خواست رسماً دخالت کنم Ùˆ با هم برویم خانه‌شان Ùˆ با زبان چرب Ùˆ نرمی Ú©Ù‡ به قول ناظم داشتم مادرش را راضی کنم. چاره‌ای نبود. مدرسه را به معلم‌ها سپردیم Ùˆ راه Ø§ÙØªØ§Ø¯ÛŒÙ…. بالاخره به خانه‌ی آن‌ها رسیدیم. خانه‌ای بسیار Ú©ÙˆÚ†Ú© Ùˆ اجاره‌ای. مادر با چشم‌های گود نشسته Ùˆ انگار زغال به صورت مالیده! سیاه نبود اما رنگش چنان تیره بود Ú©Ù‡ ÙˆØØ´ØªÙ… Ú¯Ø±ÙØª. اصلاً صورت نبود. زخم سیاه شده‌ای بود Ú©Ù‡ انگار از جای چشم‌ها Ùˆ دهان سر باز کرده است. Ú©Ù„ÛŒ با مادرش ØµØØ¨Øª کردم. از پسرش Ùˆ Ú©Ù„ÛŒ دروغ Ùˆ دونگ، Ùˆ چادرش را روی چارقدش انداختیم Ùˆ علی... Ùˆ خلاصه در بیمارستان بستری شدند.
+
+ÙØ±Ø¯Ø§ Ú©Ù‡ به مدرسه آمدم، ناظم Ø³Ø±ØØ§Ù„ بود Ùˆ پیدا بود Ú©Ù‡ از شر چیزی خلاص شده است Ùˆ خبر داد Ú©Ù‡ معلم کلاس سه را Ú¯Ø±ÙØªÙ‡â€ŒØ§Ù†Ø¯. یک ماه Ùˆ خرده‌ای می‌شد Ú©Ù‡ مخÙÛŒ بود Ùˆ ما ورقه‌ی انجام کارش را به جانشین غیر رسمی‌اش داده بودیم Ùˆ ØÙ‚وقش لنگ نشده بود Ùˆ تا خبر رسمی بشنود Ùˆ در روزنامه‌ای بیابد Ùˆ قضیه به اداره‌ی ÙØ±Ù‡Ù†Ú¯ Ùˆ لیست ØÙ‚وق بکشد، باز هم می‌دادیم. اما خبر Ú©Ù‡ رسمی شد، جانشین واجد شرایط هم نمی‌توانست Ø¨ÙØ±Ø³ØªØ¯ Ùˆ باید طبق مقررات Ø±ÙØªØ§Ø± می‌کردیم Ùˆ بدیش همین بود. Ú©Ù… Ú©Ù… Ø§ØØ³Ø§Ø³ کردم Ú©Ù‡ مدرسه خلوت شده است Ùˆ کلاس‌ها اغلب اوقات بی‌کارند. جانشین معلم کلاس چهار هنوز سر Ùˆ صورتی به کارش نداده بود Ùˆ ØØ§Ù„ا یک کلاس دیگر هم بی‌معلم شد. این بود Ú©Ù‡ باز هم به سراغ رئیس ÙØ±Ù‡Ù†Ú¯ Ø±ÙØªÙ…. معلوم شد آن دخترک ترسیده Ùˆ «نرسیده متلک پیچش کرده‌اید» رئیس ÙØ±Ù‡Ù†Ú¯ این طور Ù…ÛŒâ€ŒÚ¯ÙØª. Ùˆ ØªØ±Ø¬ÛŒØ Ø¯Ø§Ø¯Ù‡ بود همان زیر نظر خودش Ø¯ÙØªØ±Ø¯Ø§Ø±ÛŒ کند. Ùˆ بعد قول Ùˆ قرار Ùˆ ÙØ±Ø¯Ø§ Ùˆ پس ÙØ±Ø¯Ø§ Ùˆ عاقبت چهار روز دوندگی تا دو تا معلم Ú¯Ø±ÙØªÙ…. یکی جوانکی رشتی Ú©Ù‡ گذاشتیمش کلاس چهار Ùˆ دیگری باز یکی ازین آقاپسرهای بریانتین‌زده Ú©Ù‡ هر روز کراوات عوض می‌کرد، با نقش‌ها Ùˆ طرØâ€ŒÙ‡Ø§ÛŒ عجیب. عجب ÙØ±Ù‡Ù†Ú¯ را با قرتی‌ها در آمیخته بودند! باداباد. او را هم گذاشتیم سر کلاس سه. اواخر بهمن، یک روز ناظم آمد اتاقم Ú©Ù‡ بودجه‌ی مدرسه را زنده کرده است. Ú¯ÙØªÙ…:
+
+- مبارکه، Ú†Ù‡ قدر Ú¯Ø±ÙØªÛŒØŸ
+
+- هنوز هیچ Ú†ÛŒ آقا. قراره ÙØ±Ø¯Ø§ سر ظهر بیاند این جا آقا Ùˆ همین جا قالش رو بکنند.
+
+Ùˆ ÙØ±Ø¯Ø§ اصلاً مدرسه Ù†Ø±ÙØªÙ…. ØØªÙ…اً می‌خواست من هم باشم Ùˆ در بده بستان ماهی پانزده قران، ØÙ‚ Ù†Ø¸Ø§ÙØª هر اتاق نظارت کنم Ùˆ از مدیریتم مایه بگذارم تا تنخواه‌گردان مدرسه Ùˆ ØÙ‚ آب Ùˆ دیگر پول‌های Ø¹Ù‚Ø¨â€ŒØ§ÙØªØ§Ø¯Ù‡ وصول بشود... ÙØ±Ø¯Ø§ سه Ù†ÙØ±ÛŒ آمده بودند مدرسه. ناهار هم به خرج ناظم خورده بودند. Ùˆ قرار دیگری برای یک سور ØØ³Ø§Ø¨ÛŒ گذاشته بودند Ùˆ Ø±ÙØªÙ‡ بودند Ùˆ ناظم با زبان بی‌زبانی ØØ§Ù„یم کرد Ú©Ù‡ این بار ØØªÙ…اً باید باشم Ùˆ آن طور Ú©Ù‡ Ù…ÛŒâ€ŒÚ¯ÙØªØŒ جای شکرش باقی بود Ú©Ù‡ مراعات کرده بودند Ùˆ ØÙ‚ بوقی نخواسته بودند. اولین باری بود Ú©Ù‡ چنین اهمیتی پیدا می‌کردم. این هم یک مزیت دیگر مدیری مدرسه بود! سی صد تومان از بودجه‌ی دولت بسته به این بود Ú©Ù‡ به Ùلان مجلس بروی یا نروی. تا سه روز دیگر موعد سور بود، اصلاً یادم نیست Ú†Ù‡ کردم. اما همه‌اش در این Ùکر بودم Ú©Ù‡ بروم یا نروم؟ یک بار دیگر Ø§Ø³ØªØ¹ÙØ§Ù†Ø§Ù…ه‌ام را توی جیبم گذاشتم Ùˆ بی این Ú©Ù‡ صدایش را در بیاورم، روز سور هم Ù†Ø±ÙØªÙ….
+
+بعد دیدم این طور Ú©Ù‡ نمی‌شود. Ú¯ÙØªÙ… بروم قضایا را برای رئیس ÙØ±Ù‡Ù†Ú¯ بگویم. Ùˆ Ø±ÙØªÙ…. سلام Ùˆ اØÙˆØ§Ù„پرسی نشستم. اما Ú†Ù‡ بگویم؟ بگویم چون نمی‌خواستم در خوردن سور شرکت کنم، Ø§Ø³ØªØ¹ÙØ§ می‌دهم؟... دیدم چیزی ندارم Ú©Ù‡ بگویم. Ùˆ از این گذشته Ø®ÙØªâ€ŒØ¢ÙˆØ± نبود Ú©Ù‡ به خاطر سیصد تومان جا بزنم Ùˆ Ø§Ø³ØªØ¹ÙØ§ بدهم؟ Ùˆ Â«Ø®Ø¯Ø§ØØ§Ùظ؛ Ùقط آمده بودم سلام عرض کنم.» Ùˆ از این دروغ‌ها Ùˆ Ø§Ø³ØªØ¹ÙØ§Ù†Ø§Ù…ه‌ام را توی جوی آب انداختم. اما ناظم؛ یک Ù‡ÙØªÙ‡â€ŒØ§ÛŒ مثل سگ بود. عصبانی، پر سر Ùˆ صدا Ùˆ شارت Ùˆ شورت! ØØªÛŒ Ù†Ø±ÙØªÙ… اØÙˆØ§Ù„ مادرش را بپرسم. یک Ù‡ÙØªÙ‡â€ŒÛŒ تمام Ù…ÛŒâ€ŒØ±ÙØªÙ… Ùˆ در اتاقم را می‌بستم Ùˆ سوراخ‌های گوشم را Ù…ÛŒâ€ŒÚ¯Ø±ÙØªÙ… Ùˆ تا Ø§ÙØ² Ùˆ Ú†ÙØ²Ù‘ بچه‌ها بخوابد، از این سر تا آن سر اتاق را می‌کوبیدم. ده روز تمام، قلب من Ùˆ بچه‌ها با هم Ùˆ به یک اندازه از ترس Ùˆ ÙˆØØ´Øª تپید. تا عاقبت پول‌ها وصول شد. منتها به جای سیصد Ùˆ خرده‌ای، Ùقط صد Ùˆ پنجاه تومان. علت هم این بود Ú©Ù‡ در تنظیم صورت ØØ³Ø§Ø¨â€ŒÙ‡Ø§ اشتباهاتی رخ داده بود Ú©Ù‡ ناچار Ø§ØµÙ„Ø§ØØ´ کرده بودند!
+
+غیر از آن زنی Ú©Ù‡ Ù‡ÙØªÙ‡â€ŒØ§ÛŒ یک بار به مدرسه سری می‌زد، از اولیای Ø§Ø·ÙØ§Ù„ دو سه Ù†ÙØ± دیگر هم بودند Ú©Ù‡ مرتب بودند. یکی همان پاسبانی Ú©Ù‡ با کمربند، پاهای پسرش را بست Ùˆ ÙÙ„Ú© کرد. یکی هم کارمند پست Ùˆ تلگراÙÛŒ بود Ú©Ù‡ ده روزی یک بار می‌آمد Ùˆ پدر همان بچه‌ی شیطان. Ùˆ یک استاد نجار Ú©Ù‡ پسرش کلاس اول بود Ùˆ خودش سواد داشت Ùˆ به آن می‌بالید Ùˆ کارآمد می‌نمود. یک مقنی هم بود درشت استخوان Ùˆ بلندقد Ú©Ù‡ بچه‌اش کلاس سوم بود Ùˆ Ù‡ÙØªÙ‡â€ŒØ§ÛŒ یک بار می‌آمد Ùˆ همان توی ØÛŒØ§Ø·ØŒ ده پانزده دقیقه‌ای با ÙØ±Ø§Ø´â€ŒÙ‡Ø§ اختلاط می‌کرد Ùˆ بی سر Ùˆ صدا Ù…ÛŒâ€ŒØ±ÙØª. نه کاری داشت، نه چیزی از آدم می‌خواست Ùˆ همان طور Ú©Ù‡ آمده بود چند دقیقه‌ای را با ÙØ±Ø§Ø´ ØµØØ¨Øª می‌کرد Ùˆ بعد Ù…ÛŒ Ø±ÙØª. Ùقط یک روز نمی‌دانم چرا Ø±ÙØªÙ‡ بود بالای دیوار مدرسه. البته اول Ùکر کردم مأمور اداره برق است ولی بعد متوجه شدم Ú©Ù‡ همان مرد مقنی است. بچه‌ها جیغ Ùˆ ÙØ±ÛŒØ§Ø¯ می‌کردند Ùˆ من همه‌اش درین Ùکر بودم Ú©Ù‡ Ú†Ù‡ طور به سر دیوار Ø±ÙØªÙ‡ است؟ Ù…Ø§ØØµÙ„ داد Ùˆ ÙØ±ÛŒØ§Ø¯Ø´ این بود Ú©Ù‡ چرا اسم پسر او را برای Ú¯Ø±ÙØªÙ† Ú©ÙØ´ Ùˆ لباس به انجمن ندادیم. وقتی به او رسیدم نگاهی به او انداختم Ùˆ بعد تشری به ناظم Ùˆ معلم ها زدم Ú©Ù‡ ولش کردند Ùˆ بچه‌ها Ø±ÙØªÙ†Ø¯ سر کلاس Ùˆ بعد بی این Ú©Ù‡ نگاهی به او بکنم، Ú¯ÙØªÙ…:
+
+- خسته نباشی اوستا.
+
+Ùˆ همان طور Ú©Ù‡ به Ø·Ø±Ù Ø¯ÙØªØ± Ù…ÛŒâ€ŒØ±ÙØªÙ… رو به ناظم Ùˆ معلم‌ها Ø§ÙØ²ÙˆØ¯Ù…:
+
+- لابد جواب درست Ùˆ ØØ³Ø§Ø¨ÛŒ نشنیده Ú©Ù‡ Ø±ÙØªÙ‡ سر دیوار.
+
+Ú©Ù‡ پشت سرم گرپ صدایی آمد Ùˆ از در Ø¯ÙØªØ± Ú©Ù‡ Ø±ÙØªÙ… تو، او Ùˆ ناظم با هم وارد شدند. Ú¯ÙØªÙ… نشست. Ùˆ به جای این‌که ØØ±ÙÛŒ بزند به گریه Ø§ÙØªØ§Ø¯. هرگز گمان نمی‌کردم از چنان قد Ùˆ قامتی صدای گریه در بیاید. این بود Ú©Ù‡ از اتاق بیرون آمدم Ùˆ ÙØ±Ø§Ø´ را صدا زدم Ú©Ù‡ آب برایش بیاورد Ùˆ ØØ§Ù„Ø´ Ú©Ù‡ جا آمد، بیاوردش پهلوی من. اما دیگر از او خبری نشد Ú©Ù‡ نشد. نه آن روز Ùˆ نه هیچ روز دیگر. آن روز چند دقیقه‌ای بعد از شیشه‌ی اتاق خودم دیدمش Ú©Ù‡ دمش را لای پایش گذاشته بود از در مدرسه بیرون Ù…ÛŒâ€ŒØ±ÙØª Ùˆ ÙØ±Ø§Ø´ جدید آمد Ú©Ù‡ بله Ù…ÛŒâ€ŒÚ¯ÙØªÙ†Ø¯ از پسرش پنج تومان خواسته بودند تا اسمش را برای Ú©ÙØ´ Ùˆ لباس به انجمن بدهند. پیدا بود باز توی Ú©ÙˆÚ© ناظم Ø±ÙØªÙ‡ است. مرخصش کردم Ùˆ ناظم را خواستم. معلوم شد می‌خواسته ناظم را بزند. همین جوری Ùˆ بی‌مقدمه.
+
+اواخر بهمن بود Ú©Ù‡ یکی از روزهای برÙÛŒ با یکی دیگر از اولیای Ø§Ø·ÙØ§Ù„ آشنا شدم. یارو مرد بسیار کوتاهی بود؛ ÙØ±Ù†Ú¯ مآب Ùˆ بزک کرده Ùˆ اتو کشیده Ú©Ù‡ ننشسته از ØªØØµÛŒÙ„اتش Ùˆ از Ø³ÙØ±Ù‡Ø§ÛŒ ÙØ±Ù†Ú¯Ø´ ØØ±Ù زد. می‌خواست پسرش را آن وقت سال از مدرسه‌ی دیگر به آن جا بیاورد. پسرش از آن بچه‌هایی بود Ú©Ù‡ شیر Ùˆ مربای ØµØ¨ØØ§Ù†Ù‡â€ŒØ§Ø´ را با قربان صدقه توی ØÙ„قشان می‌تپانند. کلاس دوم بود Ùˆ ثلث اول دو تا تجدید آورده بود. Ù…ÛŒâ€ŒÚ¯ÙØª در باغ ییلاقی‌اش Ú©Ù‡ نزدیک مدرسه است، باغبانی دارند Ú©Ù‡ پسرش شاگرد ماست Ùˆ درس‌خوان است Ùˆ پیدا است Ú©Ù‡ بچه‌ها زیر سایه شما خوب Ù¾ÛŒØ´Ø±ÙØª می‌کنند. Ùˆ از این پیزرها. Ùˆ ØØ§Ù„ به خاطر همین بچه، توی این بر٠و سرما، آمده‌اند ساکن باغ ییلاقی شده‌اند. بلند شدم ناظم را صدا کردم Ùˆ دست او Ùˆ بچه‌اش را توی دست ناظم گذاشتم Ùˆ Ø®Ø¯Ø§ØØ§Ùظ شما... Ùˆ نیم ساعت بعد ناظم برگشت Ú©Ù‡ یارو خانه‌ی شهرش را به یک دبیرستان اجاره داده، به ماهی سه هزار Ùˆ دویست تومان، Ùˆ التماس دعا داشته، یعنی معلم سرخانه می‌خواسته Ùˆ ØØªÛŒ بدش نمی‌آمده است Ú©Ù‡ خود مدیر زØÙ…ت بکشند Ùˆ ازین گنده‌گوزی‌ها... Ø§ØØ³Ø§Ø³ کردم Ú©Ù‡ ناظم دهانش آب Ø§ÙØªØ§Ø¯Ù‡ است. Ùˆ من به ناظم ØØ§Ù„ÛŒ کردم خودش برود بهتر است Ùˆ Ùقط کاری بکند Ú©Ù‡ نه صدای معلم‌ها در بیاید Ùˆ نه آخر سال، برای یک معدل ده Ø§ØØªÛŒØ§Ø¬ÛŒ به من بمیرم Ùˆ تو بمیری پیدا کند. همان روز عصر ناظم Ø±ÙØªÙ‡ بود Ùˆ قرار Ùˆ مدار برای هر روز عصر یک ساعت به ماهی صد Ùˆ پنجاه تومان.
+
+دیگر دنیا به کام ناظم بود. ØØ§Ù„ مادرش هم بهتر بود Ùˆ از بیمارستان مرخصش کرده بودند Ùˆ به Ùکر زن Ú¯Ø±ÙØªÙ† Ø§ÙØªØ§Ø¯Ù‡ بود. Ùˆ هر روز هم برای یک Ù†ÙØ± نقشه می‌کشید ØØªÛŒ برای من هم. یک روز در آمد Ú©Ù‡ چرا ما خودمان «انجمن خانه Ùˆ مدرسه» نداشته باشیم؟ نشسته بود Ùˆ ØØ³Ø§Ø¨Ø´ را کرده بود دیده بود Ú©Ù‡ پنجاه شصت Ù†ÙØ±ÛŒ از اولیای مدرسه دستشان به دهان‌شان می‌رسد Ùˆ از آن هم Ú©Ù‡ به پسرش درس خصوصی می‌داد قول مساعد Ú¯Ø±ÙØªÙ‡ بود. ØØ§Ù„یش کردم Ú©Ù‡ مواظب ØØ±Ù Ùˆ سخن اداره‌ای باشد Ùˆ هر کار دلش می‌خواهد بکند. کاغذ دعوت را هم برایش نوشتم با آب Ùˆ تاب Ùˆ خودش برای اداره‌ی ÙØ±Ù‡Ù†Ú¯ØŒ داد ماشین کردند Ùˆ به وسیله‌ی خود بچه‌ها ÙØ±Ø³ØªØ§Ø¯. Ùˆ جلسه با ØØ¶ÙˆØ± بیست Ùˆ چند Ù†ÙØ±ÛŒ از اولیای بچه‌ها رسمی شد. خوبیش این بود Ú©Ù‡ پاسبان کشیک پاسگاه هم آمده بود Ùˆ دم در برای همه، پاشنه‌هایش را به هم می‌کوبید Ùˆ معلم‌ها گوش تا گوش نشسته بودند Ùˆ مجلس ابهتی داشت Ùˆ ناظم، چای Ùˆ شیرینی تهیه کرده بود Ùˆ چراغ زنبوری کرایه کرده بود Ùˆ باران هم گذاشت پشتش Ùˆ سالون برای اولین بار در عمرش به نوایی رسید.
+
+یک سرهنگ بود Ú©Ù‡ رئیسش کردیم Ùˆ آن زن را Ú©Ù‡ Ù‡ÙØªÙ‡â€ŒØ§ÛŒ یک بار می‌آمد نایب رئیس. آن Ú©Ù‡ ناظم به پسرش درس خصوصی می‌داد نیامده بود. اما پاکت سربسته‌ای به اسم مدیر ÙØ±Ø³ØªØ§Ø¯Ù‡ بود Ú©Ù‡ Ùی‌المجلس بازش کردیم. عذرخواهی از این‌که نتوانسته بود بیاید Ùˆ وجه ناقابلی جو٠پاکت. صد Ùˆ پنجاه تومان. Ùˆ پول را روی میز صندوق‌دار گذاشتیم Ú©Ù‡ ضبط Ùˆ ربط کند. نائب رئیس بزک کرده Ùˆ معطر شیرینی تعار٠می‌کرد Ùˆ معلم‌ها با هر بار Ú©Ù‡ شیرینی بر می‌داشتند، یک بار تا بناگوش سرخ می‌شدند Ùˆ ÙØ±Ø§Ø´â€ŒÙ‡Ø§ دست به دست چای می‌آوردند.
+
+در Ùکر بودم Ú©Ù‡ یک مرتبه Ø§ØØ³Ø§Ø³ کردم، سیصد چهارصد تومان پول نقد، روی میز است Ùˆ هشت صد تومان هم تعهد کرده بودند. پیرزن صندوقدار Ú©Ù‡ کی٠پولش را همراهش نیاورده بود ناچار ØØ¶Ø§Ø± تصویب کردند Ú©Ù‡ پول‌ها ÙØ¹Ù„اً پیش ناظم باشد. Ùˆ صورت مجلس مرتب شد Ùˆ امضاها ردی٠پای آن Ùˆ ÙØ±Ø¯Ø§ Ùهمیدم Ú©Ù‡ ناظم همان شب روی خشت نشسته بوده Ùˆ به معلم‌ها سور داده بوده است. اولین کاری Ú©Ù‡ کردم رونوشت مجلس آن شب را برای اداره‌ی ÙØ±Ù‡Ù†Ú¯ ÙØ±Ø³ØªØ§Ø¯Ù…. Ùˆ بعد همان استاد نجار را صدا کردم Ùˆ دستور دادم برای مستراØâ€ŒÙ‡Ø§ دو روزه در بسازد Ú©Ù‡ ناظم خیلی به سختی پولش را داد. Ùˆ بعد در کوچه‌ی مدرسه درخت کاشتیم. تور والیبال را تعویض Ùˆ تعدادی توپ در اختیار بچه‌ها گذاشتیم برای تمرین در بعد از ظهرها Ùˆ آمادگی برای مسابقه با دیگر مدارس Ùˆ در همین ØÛŒÙ† سر Ùˆ کله‌ی بازرس تربیت بدنی هم پیدا شد Ùˆ هر روز سرکشی Ùˆ بیا Ùˆ برو. تا یک روز Ú©Ù‡ به مدرسه رسیدم شنیدم Ú©Ù‡ از سالون سر Ùˆ صدا می‌آید. صدای هالتر بود. ناظم سر خود Ø±ÙØªÙ‡ بود Ùˆ سرخود دویست سیصد تومان داده بود Ùˆ هالتر خریده بود Ùˆ بچه‌های لاغر زیر بار آن گردن خود را خرد می‌کردند. من در این میان ØØ±ÙÛŒ نزدم. می‌توانستم ØØ±ÙÛŒ بزنم؟ من چیکاره بودم؟ اصلاً به من Ú†Ù‡ ربطی داشت؟ هر کار Ú©Ù‡ دلشان می‌خواهد بکنند. مهم این بود Ú©Ù‡ سالون مدرسه رونقی Ú¯Ø±ÙØªÙ‡ بود. ناظم هم راضی بود Ùˆ معلم‌ها هم. چون نه خبر از ØØ³Ø§Ø¯ØªÛŒ بود Ùˆ نه ØØ±Ù Ùˆ سخنی پیش آمد. Ùقط می‌بایست به ناظم Ø³ÙØ§Ø±Ø´ Ù…ÛŒ کردم Ú©Ù‡ Ùکر ÙØ±Ø§Ø´â€ŒÙ‡Ø§ هم باشد.
+
+Ú©Ù… Ú©Ù… خودمان را برای Ø§Ù…ØªØØ§Ù†â€ŒÙ‡Ø§ÛŒ ثلث دوم آماده می‌کردیم. این بود Ú©Ù‡ اوایل اسÙند، یک روز معلم‌ها را صدا زدم Ùˆ در شورا مانندی Ú©Ù‡ کردیم بی‌مقدمه برایشان داستان یکی از همکاران سابقم را Ú¯ÙØªÙ… Ú©Ù‡ هر وقت بیست می‌داد تا دو روز تب داشت. البته معلم‌ها خندیدند. ناچار تشویق شدم Ùˆ داستان آخوندی را Ú¯ÙØªÙ… Ú©Ù‡ در بچگی معلم شرعیاتمان بود Ùˆ زیر عبایش نمره می‌داد Ùˆ دستش چنان می‌لرزید Ú©Ù‡ عبا تکان می‌خورد Ùˆ درست ده دقیقه طول می‌کشید. Ùˆ تازه چند؟ بهترین شاگردها دوازده. Ùˆ البته باز هم خندیدند. Ú©Ù‡ این بار کلاÙه‌ام کرد. Ùˆ بعد ØØ§Ù„یشان کردم Ú©Ù‡ بد نیست در Ø·Ø±Ø Ø³Ø¤Ø§Ù„â€ŒÙ‡Ø§ مشورت کنیم Ùˆ از این ØØ±Ù‌ها...
+
+Ùˆ از شنبه‌ی بعد، Ø§Ù…ØªØØ§Ù†Ø§Øª شروع شد. درست از نیمه‌ی دوم اسÙند. سؤال‌ها را سه Ù†ÙØ±ÛŒ می‌دیدیم. خودم با معلم هر کلاس Ùˆ ناظم. در سالون میزها را چیده بودیم البته از وقتی هالتردار شده بود خیلی زیباتر شده بود. در سالون کاردستی‌های بچه‌ها در همه جا به چشم می‌خورد. هر کسی هر چیزی را به عنوان کاردستی درست کرده بودند Ùˆ آورده بودند. Ú©Ù‡ برای این کاردستی‌ها Ú†Ù‡ پول‌ها Ú©Ù‡ خرج نشده بود Ùˆ Ú†Ù‡ دست‌ها Ú©Ù‡ نبریده بود Ùˆ Ú†Ù‡ دعواها Ú©Ù‡ نشده بود Ùˆ Ú†Ù‡ عرق‌ها Ú©Ù‡ ریخته نشده بود. پیش از هر Ø§Ù…ØªØØ§Ù† Ú©Ù‡ می‌شد، خودم یک میتینگ برای بچه‌ها می‌دادم Ú©Ù‡ ترس از معلم Ùˆ Ø§Ù…ØªØØ§Ù† بی‌جا است Ùˆ باید اعتماد به Ù†ÙØ³ داشت Ùˆ ازین Ù…Ø²Ø®Ø±ÙØ§Øª....ولی مگر ØØ±Ù به گوش کسی Ù…ÛŒâ€ŒØ±ÙØªØŸ از در Ú©Ù‡ وارد می‌شدند، چنان هجومی می‌بردند Ú©Ù‡ Ù†Ú¯Ùˆ! به جاهای دور از نظر. یک بار چنان بود Ú©Ù‡ Ø§ØØ³Ø§Ø³ کردم مثل این‌که از ترس، لذت می‌برند. اگر معلم نبودی یا مدیر، به Ø±Ø§ØØªÛŒ می‌توانستی ØØ¯Ø³ بزنی Ú©Ù‡ کی‌ها با هم قرار Ùˆ مداری دارند Ùˆ کدام یک پهلو دست کدام یک خواهد نشست. یکی دو بار کوشیدم بالای دست یکی‌شان بایستم Ùˆ ببینم Ú†Ù‡ می‌نویسد. ولی چنان مضطرب می‌شدند Ùˆ دستشان به لرزه Ù…ÛŒâ€ŒØ§ÙØªØ§Ø¯ Ú©Ù‡ از نوشتن باز می‌ماندند. می‌دیدم Ú©Ù‡ این مردان آینده، درین کلاس‌ها Ùˆ Ø§Ù…ØªØØ§Ù†â€ŒÙ‡Ø§ آن قدر خواهند ترسید Ú©Ù‡ وقتی دیپلمه بشوند یا لیسانسه، اصلاً آدم نوع جدیدی خواهند شد. آدمی انباشته از ÙˆØØ´ØªØŒ انبانی از ترس Ùˆ دلهره. به این ترتیب یک روز بیشتر دوام نیاوردم. چون دیدم نمی‌توانم قلب بچگانه‌ای داشته باشم تا با آن ترس Ùˆ ÙˆØØ´Øª بچه‌ها را درک کنم Ùˆ هم‌دردی نشان بدهم.این جور بود Ú©Ù‡ می‌دیدم Ú©Ù‡ معلم مدرسه هم نمی‌توانم باشم.
+
+دو روز قبل از عید کارنامه‌ها آماده بود Ùˆ منتظر امضای مدیر. دویست Ùˆ سی Ùˆ شش تا امضا اقلاً تا ظهر طول می‌کشید. پیش از آن هم تا می‌توانستم از امضای Ø¯ÙØªØ±Ù‡Ø§ÛŒ ØØ¶ÙˆØ± Ùˆ غیاب می‌گریختم. خیلی از جیره‌خورهای دولت در ادارات دیگر یا در میان همکارانم دیده بودم Ú©Ù‡ در مواقع بیکاری تمرین امضا می‌کنند. پیش از آن نمی‌توانستم بÙهمم Ú†Ù‡ طور از مدیری یک مدرسه یا کارمندی ساده یک اداره می‌شود به وزارت رسید. یا اصلاً آرزویش را داشت. نیم‌قراضه امضای آماده Ùˆ هر کدام معر٠یک شخصیت، بعد نیم‌ذرع زبان چرب Ùˆ نرم Ú©Ù‡ با آن، مار را از سوراخ بیرون بکشی، یا همه جا را بلیسی Ùˆ یک دست هم قیاÙÙ‡. نه یک جور. دوازده جور.
+
+در این Ùکرها بودم Ú©Ù‡ ناگهان در میان کارنامه‌ها چشمم به یک اسم آشنا Ø§ÙØªØ§Ø¯. به اسم پسران جناب سرهنگ Ú©Ù‡ رئیس انجمن بود. Ø±ÙØªÙ… توی نخ نمراتش. همه متوسط بود Ùˆ جای ایرادی نبود. Ùˆ یک مرتبه به ØµØ±Ø§ÙØª Ø§ÙØªØ§Ø¯Ù… Ú©Ù‡ از اول سال تا به ØØ§Ù„ بچه‌های مدرسه را Ùقط به اعتبار وضع مالی پدرشان قضاوت کرده‌ام. درست مثل این پسر سرهنگ Ú©Ù‡ به اعتبار کیابیای پدرش درس نمی‌خواند. دیدم هر کدام Ú©Ù‡ پدرشان Ùقیرتر است به نظر من باهوش‌تر می‌آمده‌اند. البته ناظم با این ØØ±Ù‌ها کاری نداشت. مر قانونی را عمل می‌کرد. از یکی چشم می‌پوشید به دیگری سخت Ù…ÛŒâ€ŒÚ¯Ø±ÙØª.
+
+اما من مثل این Ú©Ù‡ قضاوتم را درباره‌ی بچه‌ها از پیش کرده باشم Ùˆ Ú†Ù‡ خوب بود Ú©Ù‡ نمره‌ها در اختیار من نبود Ùˆ آن یکی هم «انظباط» مال آخر سال بود. مسخره‌ترین کارها آن است Ú©Ù‡ کسی به Ø§ØµÙ„Ø§Ø ÙˆØ¶Ø¹ÛŒ دست بزند، اما در قلمروی Ú©Ù‡ تا سر دماغش بیشتر نیست. Ùˆ تازه مدرسه‌ی من، این قلمروی ÙØ¹Ø§Ù„یت من، تا سر دماغم هم نبود. به همان توی ذهنم ختم می‌شد. وضعی را Ú©Ù‡ دیگران ترتیب داده بودند. به این ترتیب بعد از پنج شش ماه، می‌Ùهمیدم Ú©Ù‡ ØØ³Ø§Ø¨Ù… یک ØØ³Ø§Ø¨ عقلایی نبوده است. Ø§ØØ³Ø§Ø³Ø§ØªÛŒ بوده است. ضعÙ‌های Ø§ØØ³Ø§Ø³Ø§ØªÛŒ مرا خشونت‌های عملی ناظم جبران می‌کرد Ùˆ این بود Ú©Ù‡ جمعاً نمی‌توانستم ازو بگذرم. مرد عمل بود. کار را می‌برید Ùˆ پیش Ù…ÛŒâ€ŒØ±ÙØª. در زندگی Ùˆ در هر کاری، هر قدمی بر می‌داشت، برایش هد٠بود. Ùˆ چشم از وجوه دیگر قضیه می‌پوشید. این بود Ú©Ù‡ برش داشت. Ùˆ من نمی‌توانستم. چرا Ú©Ù‡ اصلاً مدیر نبودم. خلاص...
+
+Ùˆ کارنامه‌ی پسر سرهنگ را Ú©Ù‡ زیر دستم عرق کرده بود، به دقت Ùˆ Ø§ØØªÛŒØ§Ø¬ خشک کردم Ùˆ امضایی زیر آن گذاشتم به قدری بد خط Ùˆ مسخره بود Ú©Ù‡ به یاد امضای ÙØ±Ø§Ø´ جدیدمان Ø§ÙØªØ§Ø¯Ù…. ØØªÙ…اً جناب سرهنگ کلاÙÙ‡ می‌شد Ú©Ù‡ چرا چنین آدم بی‌سوادی را با این خط Ùˆ ربط امضا مدیر مدرسه کرده‌اند. آخر یک جناب سرهنگ هم می‌داند Ú©Ù‡ امضای آدم معر٠شخصیت آدم است.
+
+اواخر تعطیلات نوروز Ø±ÙØªÙ… به ملاقات معلم ترکه‌ای کلاس سوم. ناظم Ú©Ù‡ با او میانه‌ی خوشی نداشت. ناچار با معلم ØØ³Ø§Ø¨ کلاس پنج Ùˆ شش قرار Ùˆ مداری گذاشته بودم Ú©Ù‡ مختصری علاقه‌ای هم به آن ØØ±Ù Ùˆ سخن‌ها داشت. هم به وسیله‌ی او بود Ú©Ù‡ می‌دانستم نشانی‌اش کجا است Ùˆ توی کدام زندان است. در راه قبل از هر چیز خبر داد Ú©Ù‡ رئیس ÙØ±Ù‡Ù†Ú¯ عوض شده Ùˆ این طور Ú©Ù‡ شایع است یکی از هم دوره‌ای‌های من، جایش آمده. Ú¯ÙØªÙ…:
+
+- عجب! چرا؟ مگه رئیس قبلی چپش کم بود؟
+
+- Ú†Ù‡ عرض کنم. می‌گند پا تو Ú©ÙØ´ یکی از نماینده‌ها کرده. شما خبر ندارید؟
+
+- چه طور؟ از کجا خبر داشته باشم؟
+
+- هیچ Ú†ÛŒ... Ù…ÛŒ گند دو تا از کارچاق‌کن‌های انتخاباتی یارو از صندوق ÙØ±Ù‡Ù†Ú¯ ØÙ‚وق Ù…ÛŒâ€ŒÚ¯Ø±ÙØªÙ‡â€ŒØ§Ù†Ø¯Ø› شب عیدی رئیس ÙØ±Ù‡Ù†Ú¯ ØÙ‚وق‌شون رو زده.
+
+- عجب! پس اونم می‌خواسته Ø§ØµÙ„Ø§ØØ§Øª کنه! بیچاره.
+
+Ùˆ بعد از این ØØ±Ù زدیم Ú©Ù‡ الØÙ…دالله مدرسه مرتب است Ùˆ آرام Ùˆ معلم‌ها همکاری می‌کنند Ùˆ ناظم بیش از اندازه همه‌کاره شده است. Ùˆ من Ùهمیدم Ú©Ù‡ باز لابد مشتری خصوصی تازه‌ای پیدا شده است Ú©Ù‡ سر Ùˆ صدای همه همکارها بلند شده. دم در زندان شلوغ بود. کلاه مخملی‌ها، عم‌قزی گل‌بته‌ها، خاله خانباجی‌ها Ùˆ... اسم نوشتیم Ùˆ نوبت Ú¯Ø±ÙØªÛŒÙ… Ùˆ به جای پاها، دست‌هامان زیر بار Ú©ÙˆÚ†Ú©ÛŒ Ú©Ù‡ داشتیم، خسته شد Ùˆ خواب Ø±ÙØª تا نوبتمان شد. از این اتاق به آن اتاق Ùˆ عاقبت نرده‌های آهنی Ùˆ پشت آن معلم کلاس سه Ùˆ... عجب چاق شده بود!درست مثل یک آدم ØØ³Ø§Ø¨ÛŒ شده بود. Ø®ÙˆØ´ØØ§Ù„ شدیم Ùˆ اØÙˆØ§Ù„پرسی Ùˆ تشکر؛ Ùˆ دیگر Ú†Ù‡ بگویم؟ بگویم چرا خودت را به دردسر انداختی؟ پیدا بود از مدرسه Ùˆ کلاس به او خوش‌تر می‌گذرد. ایمانی بود Ùˆ او آن را داشت Ùˆ خوشبخت بود Ùˆ دردسری نمی‌دید Ùˆ زندان ØØ¯Ø§Ù‚Ù„ برایش کلاس درس بود. عاقبت پرسیدم:
+
+- پرونده‌ای هم برات درست کردند یا هنوز بلاتکلیÙی؟
+
+- Ø§Ù…ØªØØ§Ù†Ù…Ùˆ دادم آقا مدیر، بد از آب در نیومد.
+
+- یعنی چه؟
+
+- یعنی بی‌تکلی٠نیستم. چون اسمم تو لیست جیره‌ی زندون Ø±ÙØªÙ‡. خیالم Ø±Ø§ØØªÙ‡. چون سختی‌هاش گذشته.
+
+دیگر Ú†Ù‡ بگویم. دیدم چیزی ندارم Ø®Ø¯Ø§ØØ§Ùظی کردم Ùˆ او را با معلم ØØ³Ø§Ø¨ تنها گذاشتم Ùˆ آمدم بیرون Ùˆ تا مدت ملاقات تمام بشود، دم در زندان قدم زدم Ùˆ به زندانی Ùکر کردم Ú©Ù‡ برای خودم ساخته بودم. یعنی آن خرپول ÙØ±Ù‡Ù†Ú¯â€ŒØ¯ÙˆØ³Øª ساخته بود. Ùˆ من به میل Ùˆ رغبت خودم را در آن زندانی کرده بودم. این یکی را به ضرب دگنک این جا آورده بودند. ناچار ØÙ‚ داشت Ú©Ù‡ خیالش Ø±Ø§ØØª باشد. اما من به میل Ùˆ رغبت Ø±ÙØªÙ‡ بودم Ùˆ Ú†Ù‡ بکنم؟ ناظم Ú†Ù‡ طور؟ راستی اگر رئیس ÙØ±Ù‡Ù†Ú¯ از هم دوره‌ای‌های خودم باشد؛ Ú†Ù‡ طور است بروم Ùˆ ازو بخواهم Ú©Ù‡ ناظم را جای من بگذارد، یا همین معلم ØØ³Ø§Ø¨ را؟... Ú©Ù‡ معلم ØØ³Ø§Ø¨ در آمد Ùˆ راه Ø§ÙØªØ§Ø¯ÛŒÙ…. با او هم دیگر ØØ±ÙÛŒ نداشتم. سر پیچ Ø®Ø¯Ø§ØØ§Ùظ شما Ùˆ تاکسی Ú¯Ø±ÙØªÙ… Ùˆ یک سر به اداره‌ی ÙØ±Ù‡Ù†Ú¯ زدم. گرچه دهم عید بود، اما هنوز Ø±ÙØª Ùˆ آمد سال نو تمام نشده بود. برو Ùˆ بیا Ùˆ شیرینی Ùˆ چای دو جانبه. Ø±ÙØªÙ… تو. سلام Ùˆ تبریک Ùˆ همین ØªØ¹Ø§Ø±ÙØ§Øª را پراندم.
+
+بله خودش بود. یکی از پخمه‌های کلاس. Ú©Ù‡ آخر سال سوم کشتیارش شدم دو بیت شعر را ØÙظ کند، نتوانست Ú©Ù‡ نتوانست. Ùˆ ØØ§Ù„ا او رئیس بود Ùˆ من آقا مدیر. راستی ØÛŒÙ از من، Ú©Ù‡ ØØªÛŒ وزیر چنین رئیس ÙØ±Ù‡Ù†Ú¯â€ŒÙ‡Ø§ÛŒÛŒ باشم! میز همان طور پاک بود Ùˆ Ø±ÙØªÙ‡. اما زیرسیگاری انباشته از خاکستر Ùˆ ته سیگار. بلند شد Ùˆ چلپ Ùˆ چولوپ روبوسی کردیم Ùˆ پهلوی خودش جا باز کرد Ùˆ گوش تا گوش جیره‌خورهای ÙØ±Ù‡Ù†Ú¯ تبریکات صمیمانه Ùˆ بدگویی از ماسبق Ùˆ هندوانه Ùˆ پیزرها! Ùˆ دو Ù†ÙØ± Ú©Ù‡ قد Ùˆ قواره‌شان به درد گود زورخانه می‌خورد یا پای صندوق انتخابات شیرینی به مردم می‌دادند. نزدیک بود شیرینی را توی Ø¸Ø±ÙØ´ بیندازم Ú©Ù‡ دیدم بسیار اØÙ…قانه است. سیگارم Ú©Ù‡ تمام شد قضیه‌ی رئیس ÙØ±Ù‡Ù†Ú¯ قبلی Ùˆ آن دو Ù†ÙØ± را در گوشی ازش پرسیدم، ØØ±ÙÛŒ نزد. Ùقط نگاهی می‌کرد Ú©Ù‡ شبیه التماس بود Ùˆ من ÙØ±ØµØª جستم تا وضع معلم کلاس سوم را برایش روشن کنم Ùˆ از او بخواهم تا آن جا Ú©Ù‡ می‌تواند جلوی ØÙ‚وقش را نگیرد. Ùˆ از در Ú©Ù‡ آمدم بیرون، تازه یادم آمد Ú©Ù‡ برای کار دیگری پیش رئیس ÙØ±Ù‡Ù†Ú¯ بودم.
+
+باز دیروز Ø§ÙØªØ¶Ø§ØÛŒ به پا شد. معقول یک ماهه‌ی ÙØ±ÙˆØ±Ø¯ÛŒÙ† Ø±Ø§ØØª بودیم. اول اردیبهشت ماه جلالی Ùˆ کوس رسوایی سر دیوار مدرسه. نزدیک آخر وقت یک Ø¬ÙØª پدر Ùˆ مادر، بچه‌شان در میان، وارد اتاق شدند. یکی بر Ø§ÙØ±ÙˆØ®ØªÙ‡ Ùˆ دیگری رنگ Ùˆ رو باخته Ùˆ بچه‌شان عیناً مثل این عروسک‌های Ú©ÙˆÚ©ÛŒ. سلام Ùˆ علیک Ùˆ نشستند. خدایا دیگر Ú†Ù‡ Ø§ØªÙØ§Ù‚ÛŒ Ø§ÙØªØ§Ø¯Ù‡ است؟
+
+- Ú†Ù‡ خبر شده Ú©Ù‡ با خانوم Ø³Ø±Ø§ÙØ±Ø§Ø²Ù…ون کردید؟
+
+مرد اشاره‌ای به زنش کرد Ú©Ù‡ بلند شد Ùˆ دست بچه را Ú¯Ø±ÙØª Ùˆ Ø±ÙØª بیرون Ùˆ من ماندم Ùˆ پدر. اما ØØ±Ù نمی‌زد. به خودش ÙØ±ØµØª می‌داد تا عصبانیتش بپزد. سیگارم را در آوردم Ùˆ ØªØ¹Ø§Ø±ÙØ´ کردم. مثل این Ú©Ù‡ مگس مزاØÙ…ÛŒ را از روی دماغش بپراند، سیگار را رد کرد Ùˆ من Ú©Ù‡ سیگارم را آتش می‌زدم، Ùکر کردم لابد دردی دارد Ú©Ù‡ چنین دست Ùˆ پا بسته Ùˆ چنین متکی به خانواده به مدرسه آمده. باز پرسیدم:
+
+- خوب، ØØ§Ù„ا Ú†Ù‡ ÙØ±Ù…ایش داشتید؟
+
+که یک مرتبه ترکید:
+
+- اگه من مدیر مدرسه بودم Ùˆ هم‌چه Ø§ØªÙØ§Ù‚ÛŒ Ù…ÛŒâ€ŒØ§ÙØªØ§Ø¯ØŒ شیکم خودمو پاره می‌کردم. خجالت بکش مرد! برو Ø§Ø³ØªØ¹ÙØ§ بده. تا اهل Ù…ØÙ„ نریختن تیکه تیکه‌ات کنند، دو تا گوشتو وردار Ùˆ دررو. بچه‌های مردم می‌آن این جا درس بخونن Ùˆ ØØ³Ù† اخلاق. نمی‌آن Ú©Ù‡...
+
+- این Ù…Ø²Ø®Ø±ÙØ§Øª کدومه آقا! ØØ±Ù ØØ³Ø§Ø¨ سرکار چیه؟
+
+Ùˆ ØØ±Ú©ØªÛŒ کردم Ú©Ù‡ او را از در بیندازم بیرون. اما آخر باید می‌Ùهمیدم Ú†Ù‡ مرگش است. «ولی آخر با من Ú†Ù‡ کار دارد؟»
+
+- آبروی من Ø±ÙØªÙ‡. آبروی صد ساله‌ی خونواده‌ام Ø±ÙØªÙ‡. اگه در مدرسه‌ی تو رو تخته نکنم، تخم بابام نیستم. آخه من دیگه با این بچه Ú†ÛŒ کار کنم؟ تو این مدرسه ناموس مردم در خطره. کلانتری Ùهمیده؛ پزشک قانونی Ùهمیده؛ یک پرونده درست شده پنجاه ورق؛ تازه می‌گی ØØ±Ù ØØ³Ø§Ø¨Ù… چیه؟ ØØ±Ù ØØ³Ø§Ø¨Ù… اینه Ú©Ù‡ صندلی Ùˆ این مقام از سر تو زیاده. ØØ±Ù ØØ³Ø§Ø¨Ù… اینه Ú©Ù‡ می‌دم Ù…ØØ§Ú©Ù…ه‌ات کنند Ùˆ از نون خوردن بندازنت...
+
+او Ù…ÛŒâ€ŒÚ¯ÙØª Ùˆ من گوش می‌کردم Ùˆ مثل دو تا سگ هار به جان هم Ø§ÙØªØ§Ø¯Ù‡ بودیم Ú©Ù‡ در باز شد Ùˆ ناظم آمد تو. به دادم رسید. در همان ØØ§Ù„ Ú©Ù‡ من Ùˆ پدر بچه در ØØ§Ù„ دعوا بودیم زن Ùˆ بچه همان آقا Ø±ÙØªÙ‡ بودند Ùˆ قضایا را برای ناظم تعری٠کرده بودند Ùˆ او ÙØ±Ø³ØªØ§Ø¯Ù‡ بوده ÙØ§Ø¹Ù„ را از کلاس کشیده بودند بیرون... Ùˆ Ú¯ÙØª Ú†Ù‡ طور است زنگ بزنیم Ùˆ جلوی بچه‌ها ادبش کنیم Ùˆ کردیم. یعنی این بار خود من Ø±ÙØªÙ… میدان. پسرک نره‌خری بود از پنجمی‌ها با لباس مرتب Ùˆ صورت سرخ Ùˆ سÙید Ùˆ سالکی به گونه. جلوی روی بچه‌ها کشیدمش زیر مشت Ùˆ لگد Ùˆ بعد سه تا از ترکه‌ها را Ú©Ù‡ ÙØ±Ø§Ø´ جدید Ùوری از باغ همسایه آورده بود، به سر Ùˆ صورتش خرد کردم. چنان ÙˆØØ´ÛŒ شده بودم Ú©Ù‡ اگر ترکه‌ها نمی‌رسید، پسرک را کشته بودم. این هم بود Ú©Ù‡ ناظم به دادش رسید Ùˆ وساطت کرد Ùˆ لاشه‌اش را توی Ø¯ÙØªØ± بردند Ùˆ بچه‌ها را مرخص کردند Ùˆ من به اتاقم برگشتم Ùˆ با ØØ§Ù„ÛŒ زار روی صندلی Ø§ÙØªØ§Ø¯Ù…ØŒ نه از پدر خبری بود Ùˆ نه از مادر Ùˆ نه از عروسک‌های کوکی‌شان Ú©Ù‡ ناموسش دست کاری شده بود. Ùˆ تازه Ø§ØØ³Ø§Ø³ کردم Ú©Ù‡ این کتک‌کاری را باید به او می‌زدم. خیس عرق بودم Ùˆ دهانم تلخ بود. تمام ÙØØ´â€ŒÙ‡Ø§ÛŒÛŒ Ú©Ù‡ می‌بایست به آن مردکه‌ی دبنگ می‌دادم Ùˆ نداده بودم، در دهانم رسوب کرده بود Ùˆ مثل دم مار تلخ شده بود. اصلاً چرا زدمش؟ چرا نگذاشتم مثل همیشه ناظم میدان‌داری کند Ú©Ù‡ هم کارکشته‌تر بود Ùˆ هم خونسردتر. لابد پسرک با دخترعمه‌اش هم نمی‌تواند بازی کند. لابد توی خانواده‌شان، دخترها سر ده دوازده سالگی باید از پسرهای هم سن رو بگیرند. نکند عیبی کرده باشد؟ Ùˆ یک مرتبه به ØµØ±Ø§ÙØª Ø§ÙØªØ§Ø¯Ù… Ú©Ù‡ بروم ببینم Ú†Ù‡ بلایی به سرش آورده‌ام. بلند شدم Ùˆ یکی از ÙØ±Ø§Ø´â€ŒÙ‡Ø§ را صدا کردم Ú©Ù‡ Ùهمیدم روانه‌اش کرده‌اند. آبی آورد Ú©Ù‡ روی دستم می‌ریخت Ùˆ صورتم را می‌شستم Ùˆ می‌کوشیدم Ú©Ù‡ لرزش دست‌هایم را نبیند. Ùˆ در گوشم آهسته Ú¯ÙØª Ú©Ù‡ پسر مدیر شرکت اتوبوسرانی است Ùˆ بدجوری کتک خورده Ùˆ آن‌ها خیلی سعی کرده‌اند Ú©Ù‡ تر Ùˆ تمیزش کنند...
+
+اØÙ…Ù‚ مثلا داشت توی دل مرا خالی می‌کرد. نمی‌دانست Ú©Ù‡ من اول تصمیم را Ú¯Ø±ÙØªÙ…ØŒ بعد مثل سگ هار شدم. Ùˆ تازه می‌Ùهمیدم کسی را زده‌ام Ú©Ù‡ لیاقتش را داشته. ØØªÙ…اً از این Ø§ØªÙØ§Ù‚‌ها جای دیگر هم Ù…ÛŒâ€ŒØ§ÙØªØ¯. آدم بردارد پایین تنه بچه‌ی خودش را، یا به قول خودش ناموسش را بگذارد سر گذر Ú©Ù‡ کلانتر Ù…ØÙ„ Ùˆ پزشک معاینه کنند! تا پرونده درست کنند؟ با این پدرو مادرها بچه‌ها ØÙ‚ دارند Ú©Ù‡ قرتی Ùˆ دزد Ùˆ دروغگو از آب در بیایند. این مدرسه‌ها را اول برای پدر Ùˆ مادرها باز کنند...
+
+با این اÙکار به خانه رسیدم. زنم در را Ú©Ù‡ باز کرد؛ چشم‌هایش گرد شد. همیشه وقتی می‌ترسد این طور می‌شود. برای اینکه خیال نکند آدم کشته‌ام، زود قضایا را برایش Ú¯ÙØªÙ…. Ùˆ دیدم Ú©Ù‡ در ماند. یعنی ساکت ماند. آب سرد، عرق بیدمشک، سیگار پشت سیگار ÙØ§ÛŒØ¯Ù‡ نداشت، لقمه از گلویم پایین Ù†Ù…ÛŒâ€ŒØ±ÙØª Ùˆ دست‌ها هنوز می‌لرزید. هر کدام به اندازه‌ی یک ماه ÙØ¹Ø§Ù„یت کرده بودند. با سیگار چهارم شروع کردم:
+
+- می‌دانی زن؟ بابای یارو پول‌داره. مسلماً کار به دادگستری Ùˆ این جور خنس‌ها می‌کشه. مدیریت Ú©Ù‡ Ø§Ù„ÙØ§ØªØÙ‡. اما خیلی دلم می‌خواد قضیه به دادگاه برسه. یک سال آزگار رو دل کشیده‌ام Ùˆ دیگه خسته شده‌ام. دلم می‌خواد یکی بپرسه چرا بچه‌ی مردم رو این طوری زدی، چرا تنبیه بدنی کردی! آخه یک مدیر مدرسه هم ØØ±Ù‌هایی داره Ú©Ù‡ باید یک جایی بزنه...
+
+Ú©Ù‡ بلند شد Ùˆ Ø±ÙØª سراغ تلÙÙ†. دو سه تا از دوستانم را Ú©Ù‡ در دادگستری کاره‌ای بودند، Ú¯Ø±ÙØª Ùˆ خودم قضیه را برایشان Ú¯ÙØªÙ… Ú©Ù‡ مواظب باشند. ÙØ±Ø¯Ø§ پسرک ÙØ§Ø¹Ù„ به مدرسه نیامده بود. Ùˆ ناظم برایم Ú¯ÙØª Ú©Ù‡ قضیه ازین قرار بوده است Ú©Ù‡ دوتایی به هوای دیدن مجموعه تمبرهای ÙØ§Ø¹Ù„ با هم به خانه‌ای می‌روند Ùˆ قضایا همان جا Ø§ØªÙØ§Ù‚ Ù…ÛŒâ€ŒØ§ÙØªØ¯ Ùˆ داد Ùˆ هوار Ùˆ دخالت پدر Ùˆ مادرهای طرÙین Ùˆ خط Ùˆ نشان Ùˆ شبانه کلانتری؛ Ùˆ تمام اهل Ù…ØÙ„ خبر دارند. او هم نظرش این بود Ú©Ù‡ کار به دادگستری خواهد کشید.
+
+Ùˆ من یک Ù‡ÙØªÙ‡â€ŒÛŒ تمام به انتظار اخطاریه‌ی دادگستری ØµØ¨Ø Ùˆ عصر به مدرسه Ø±ÙØªÙ… Ùˆ مثل بخت‌النصر پشت پنجره ایستادم. اما در تمام این مدت نه از ÙØ§Ø¹Ù„ خبری شد، نه از Ù…ÙØ¹ÙˆÙ„ Ùˆ نه از پدر Ùˆ مادر ناموس‌پرست Ùˆ نه از مدیر شرکت اتوبوسرانی. انگار نه انگار Ú©Ù‡ Ø§ØªÙØ§Ù‚ÛŒ Ø§ÙØªØ§Ø¯Ù‡. بچه‌ها می‌آمدند Ùˆ Ù…ÛŒâ€ŒØ±ÙØªÙ†Ø¯Ø› برای آب خوردن عجله می‌کردند؛ به جای بازی کتک‌کاری می‌کردند Ùˆ همه چیز مثل قبل بود. Ùقط من ماندم Ùˆ یک دنیا ØØ±Ù Ùˆ انتظار. تا عاقبت رسید.... Ø§ØØ¶Ø§Ø±ÛŒÙ‡â€ŒØ§ÛŒ با تعیین وقت قبلی برای دو روز بعد، در Ùلان شعبه Ùˆ پیش Ùلان بازپرس دادگستری. آخر کسی پیدا شده بود Ú©Ù‡ به ØØ±ÙÙ… گوش کند.
+
+تا دو روز بعد Ú©Ù‡ موعد Ø§ØØ¶Ø§Ø± بود، اصلاً از خانه در نیامدم. نشستم Ùˆ Ù…Ø§ØØµÙ„ ØØ±Ù‌هایم را روی کاغذ آوردم. ØØ±Ù‌هایی Ú©Ù‡ با همه‌ی چرندی هر وزیر ÙØ±Ù‡Ù†Ú¯ÛŒ می‌توانست با آن یک برنامه‌ی Ù‡ÙØª ساله برای کارش بریزد. Ùˆ سر ساعت معین Ø±ÙØªÙ… دادگستری. اتاق معین Ùˆ بازپرس معین. در را باز کردم Ùˆ سلام، Ùˆ تا آمدم خودم را معرÙÛŒ کنم Ùˆ Ø§ØØ¶Ø§Ø±ÛŒÙ‡ را در بیاورم، یارو پیش‌دستی کرد Ùˆ صندلی آورد Ùˆ چای Ø³ÙØ§Ø±Ø´ داد Ùˆ Â«Ø§ØØªÛŒØ§Ø¬ÛŒ به این ØØ±Ù‌ها نیست Ùˆ قضیه‌ی Ú©ÙˆÚ†Ú© بود Ùˆ ØÙ„ شد Ùˆ راضی به زØÙ…ت شما نبودیم...»
+
+Ú©Ù‡ عرق سرد بر بدن من نشست. چایی‌ام را Ú©Ù‡ خوردم، روی همان کاغذ نشان‌دار دادگستری Ø§Ø³ØªØ¹ÙØ§Ù†Ø§Ù…ه‌ام را نوشتم Ùˆ به نام هم‌کلاسی پخمه‌ام Ú©Ù‡ تازه رئیس شده بود، دم در پست کردم.
+EOT;
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/Address.php
new file mode 100644
index 000000000..8e0829ead
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/Address.php
@@ -0,0 +1,85 @@
+format('dmy');
+
+ switch ((int)($birthdate->format('Y')/100)) {
+ case 18:
+ $centurySign = '+';
+ break;
+ case 19:
+ $centurySign = '-';
+ break;
+ case 20:
+ $centurySign = 'A';
+ break;
+ default:
+ throw new \InvalidArgumentException('Year must be between 1800 and 2099 inclusive.');
+ }
+
+ $randomDigits = self::numberBetween(0, 89);
+ if ($gender && $gender == static::GENDER_MALE) {
+ if ($randomDigits === 0) {
+ $randomDigits .= static::randomElement(array(3,5,7,9));
+ } else {
+ $randomDigits .= static::randomElement(array(1,3,5,7,9));
+ }
+ } elseif ($gender && $gender == static::GENDER_FEMALE) {
+ if ($randomDigits === 0) {
+ $randomDigits .= static::randomElement(array(2,4,6,8));
+ } else {
+ $randomDigits .= static::randomElement(array(0,2,4,6,8));
+ }
+ } else {
+ if ($randomDigits === 0) {
+ $randomDigits .= self::numberBetween(2, 9);
+ } else {
+ $randomDigits .= (string)static::numerify('#');
+ }
+ }
+ $randomDigits = str_pad($randomDigits, 3, '0', STR_PAD_LEFT);
+
+ $checksum = $checksumCharacters[(int)($datePart . $randomDigits) % strlen($checksumCharacters)];
+
+ return $datePart . $centurySign . $randomDigits . $checksum;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/PhoneNumber.php
new file mode 100644
index 000000000..a3230740e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fi_FI/PhoneNumber.php
@@ -0,0 +1,99 @@
+ 'Argovie'),
+ array('AI' => 'Appenzell Rhodes-Intérieures'),
+ array('AR' => 'Appenzell Rhodes-Extérieures'),
+ array('BE' => 'Berne'),
+ array('BL' => 'Bâle-Campagne'),
+ array('BS' => 'Bâle-Ville'),
+ array('FR' => 'Fribourg'),
+ array('GE' => 'Genève'),
+ array('GL' => 'Glaris'),
+ array('GR' => 'Grisons'),
+ array('JU' => 'Jura'),
+ array('LU' => 'Lucerne'),
+ array('NE' => 'Neuchâtel'),
+ array('NW' => 'Nidwald'),
+ array('OW' => 'Obwald'),
+ array('SG' => 'Saint-Gall'),
+ array('SH' => 'Schaffhouse'),
+ array('SO' => 'Soleure'),
+ array('SZ' => 'Schwytz'),
+ array('TG' => 'Thurgovie'),
+ array('TI' => 'Tessin'),
+ array('UR' => 'Uri'),
+ array('VD' => 'Vaud'),
+ array('VS' => 'Valais'),
+ array('ZG' => 'Zoug'),
+ array('ZH' => 'Zurich')
+ );
+
+ protected static $cityFormats = array(
+ '{{cityName}}',
+ );
+
+ protected static $streetNameFormats = array(
+ '{{streetPrefix}} {{lastName}}',
+ '{{streetPrefix}} de {{cityName}}',
+ '{{streetPrefix}} de {{lastName}}'
+ );
+
+ protected static $streetAddressFormats = array(
+ '{{streetName}} {{buildingNumber}}',
+ );
+ protected static $addressFormats = array(
+ "{{streetAddress}}\n{{postcode}} {{city}}",
+ );
+
+ /**
+ * Returns a random street prefix
+ * @example Rue
+ * @return string
+ */
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ /**
+ * Returns a random city name.
+ * @example Luzern
+ * @return string
+ */
+ public function cityName()
+ {
+ return static::randomElement(static::$cityNames);
+ }
+
+ /**
+ * Returns a canton
+ * @example array('BE' => 'Bern')
+ * @return array
+ */
+ public static function canton()
+ {
+ return static::randomElement(static::$canton);
+ }
+
+ /**
+ * Returns the abbreviation of a canton.
+ * @return string
+ */
+ public static function cantonShort()
+ {
+ $canton = static::canton();
+ return key($canton);
+ }
+
+ /**
+ * Returns the name of canton.
+ * @return string
+ */
+ public static function cantonName()
+ {
+ $canton = static::canton();
+ return current($canton);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fr_CH/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/fr_CH/Company.php
new file mode 100644
index 000000000..a4e91eaf0
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fr_CH/Company.php
@@ -0,0 +1,15 @@
+ 'Ain'), array('02' => 'Aisne'), array('03' => 'Allier'), array('04' => 'Alpes-de-Haute-Provence'), array('05' => 'Hautes-Alpes'),
+ array('06' => 'Alpes-Maritimes'), array('07' => 'Ardèche'), array('08' => 'Ardennes'), array('09' => 'Ariège'), array('10' => 'Aube'),
+ array('11' => 'Aude'), array('12' => 'Aveyron'), array('13' => 'Bouches-du-Rhône'), array('14' => 'Calvados'), array('15' => 'Cantal'),
+ array('16' => 'Charente'), array('17' => 'Charente-Maritime'), array('18' => 'Cher'), array('19' => 'Corrèze'), array('2A' => 'Corse-du-Sud'),
+ array('2B' => 'Haute-Corse'), array('21' => "Côte-d'Or"), array('22' => "Côtes-d'Armor"), array('23' => 'Creuse'), array('24' => 'Dordogne'),
+ array('25' => 'Doubs'), array('26' => 'Drôme'), array('27' => 'Eure'), array('28' => 'Eure-et-Loir'), array('29' => 'Finistère'), array('30' => 'Gard'),
+ array('31' => 'Haute-Garonne'), array('32' => 'Gers'), array('33' => 'Gironde'), array('34' => 'Hérault'), array('35' => 'Ille-et-Vilaine'),
+ array('36' => 'Indre'), array('37' => 'Indre-et-Loire'), array('38' => 'Isère'), array('39' => 'Jura'), array('40' => 'Landes'), array('41' => 'Loir-et-Cher'),
+ array('42' => 'Loire'), array('43' => 'Haute-Loire'), array('44' => 'Loire-Atlantique'), array('45' => 'Loiret'), array('46' => 'Lot'),
+ array('47' => 'Lot-et-Garonne'), array('48' => 'Lozère'), array('49' => 'Maine-et-Loire'), array('50' => 'Manche'), array('51' => 'Marne'),
+ array('52' => 'Haute-Marne'), array('53' => 'Mayenne'), array('54' => 'Meurthe-et-Moselle'), array('55' => 'Meuse'), array('56' => 'Morbihan'),
+ array('57' => 'Moselle'), array('58' => 'Nièvre'), array('59' => 'Nord'), array('60' => 'Oise'), array('61' => 'Orne'), array('62' => 'Pas-de-Calais'),
+ array('63' => 'Puy-de-Dôme'), array('64' => 'Pyrénées-Atlantiques'), array('65' => 'Hautes-Pyrénées'), array('66' => 'Pyrénées-Orientales'),
+ array('67' => 'Bas-Rhin'), array('68' => 'Haut-Rhin'), array('69' => 'Rhône'), array('70' => 'Haute-Saône'), array('71' => 'Saône-et-Loire'),
+ array('72' => 'Sarthe'), array('73' => 'Savoie'), array('74' => 'Haute-Savoie'), array('75' => 'Paris'), array('76' => 'Seine-Maritime'),
+ array('77' => 'Seine-et-Marne'), array('78' => 'Yvelines'), array('79' => 'Deux-Sèvres'), array('80' => 'Somme'), array('81' => 'Tarn'),
+ array('82' => 'Tarn-et-Garonne'), array('83' => 'Var'), array('84' => 'Vaucluse'), array('85' => 'Vendée'), array('86' => 'Vienne'),
+ array('87' => 'Haute-Vienne'), array('88' => 'Vosges'), array('89' => 'Yonne'), array('90' => 'Territoire de Belfort'), array('91' => 'Essonne'),
+ array('92' => 'Hauts-de-Seine'), array('93' => 'Seine-Saint-Denis'), array('94' => 'Val-de-Marne'), array('95' => "Val-d'Oise"),
+ array('971' => 'Guadeloupe'), array('972' => 'Martinique'), array('973' => 'Guyane'), array('974' => 'La Réunion'), array('976' => 'Mayotte')
+ );
+
+ protected static $secondaryAddressFormats = array('Apt. ###', 'Suite ###', 'Étage ###', "Bât. ###", "Chambre ###");
+
+ /**
+ * @example 'Appt. 350'
+ */
+ public static function secondaryAddress()
+ {
+ return static::numerify(static::randomElement(static::$secondaryAddressFormats));
+ }
+
+ /**
+ * @example 'rue'
+ */
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ /**
+ * Randomly returns a french region.
+ *
+ * @example 'Guadeloupe'
+ *
+ * @return string
+ */
+ public static function region()
+ {
+ return static::randomElement(static::$regions);
+ }
+
+ /**
+ * Randomly returns a french department ('departmentNumber' => 'departmentName').
+ *
+ * @example array('2B' => 'Haute-Corse')
+ *
+ * @return array
+ */
+ public static function department()
+ {
+ return static::randomElement(static::$departments);
+ }
+
+ /**
+ * Randomly returns a french department name.
+ *
+ * @example 'Ardèche'
+ *
+ * @return string
+ */
+ public static function departmentName()
+ {
+ $randomDepartmentName = array_values(static::department());
+
+ return $randomDepartmentName[0];
+ }
+
+ /**
+ * Randomly returns a french department number.
+ *
+ * @example '59'
+ *
+ * @return string
+ */
+ public static function departmentNumber()
+ {
+ $randomDepartmentNumber = array_keys(static::department());
+
+ return $randomDepartmentNumber[0];
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Company.php
new file mode 100644
index 000000000..9112802c5
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Company.php
@@ -0,0 +1,476 @@
+generator->parse($format));
+
+ if ($this->isCatchPhraseValid($catchPhrase)) {
+ break;
+ }
+ } while (true);
+
+ return $catchPhrase;
+ }
+
+ /**
+ * Generates a siret number (14 digits) that passes the Luhn check.
+ *
+ * @see http://fr.wikipedia.org/wiki/Syst%C3%A8me_d'identification_du_r%C3%A9pertoire_des_%C3%A9tablissements
+ * @return string
+ */
+ public function siret($formatted = true)
+ {
+ $siret = self::siren(false);
+ $nicFormat = static::randomElement(static::$siretNicFormats);
+ $siret .= $this->numerify($nicFormat);
+ $siret .= Luhn::computeCheckDigit($siret);
+ if ($formatted) {
+ $siret = substr($siret, 0, 3) . ' ' . substr($siret, 3, 3) . ' ' . substr($siret, 6, 3) . ' ' . substr($siret, 9, 5);
+ }
+
+ return $siret;
+ }
+
+ /**
+ * Generates a siren number (9 digits) that passes the Luhn check.
+ *
+ * @see http://fr.wikipedia.org/wiki/Syst%C3%A8me_d%27identification_du_r%C3%A9pertoire_des_entreprises
+ * @return string
+ */
+ public static function siren($formatted = true)
+ {
+ $siren = self::numerify('%#######');
+ $siren .= Luhn::computeCheckDigit($siren);
+ if ($formatted) {
+ $siren = substr($siren, 0, 3) . ' ' . substr($siren, 3, 3) . ' ' . substr($siren, 6, 3);
+ }
+
+ return $siren;
+ }
+
+ /**
+ * @var array An array containing string which should not appear twice in a catch phrase.
+ */
+ protected static $wordsWhichShouldNotAppearTwice = array('sécurité', 'simpl');
+
+ /**
+ * Validates a french catch phrase.
+ *
+ * @param string $catchPhrase The catch phrase to validate.
+ *
+ * @return boolean (true if valid, false otherwise)
+ */
+ protected static function isCatchPhraseValid($catchPhrase)
+ {
+ foreach (static::$wordsWhichShouldNotAppearTwice as $word) {
+ // Fastest way to check if a piece of word does not appear twice.
+ $beginPos = strpos($catchPhrase, $word);
+ $endPos = strrpos($catchPhrase, $word);
+
+ if ($beginPos !== false && $beginPos != $endPos) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * @link http://www.pole-emploi.fr/candidat/le-code-rome-et-les-fiches-metiers-@/article.jspz?id=60702
+ * @note Randomly took 300 from this list
+ */
+ protected static $jobTitleFormat = array(
+ 'Agent d\'accueil',
+ 'Agent d\'enquêtes',
+ 'Agent d\'entreposage',
+ 'Agent de curage',
+ 'Agro-économiste',
+ 'Aide couvreur',
+ 'Aide à domicile',
+ 'Aide-déménageur',
+ 'Ambassadeur',
+ 'Analyste télématique',
+ 'Animateur d\'écomusée',
+ 'Animateur web',
+ 'Appareilleur-gazier',
+ 'Archéologue',
+ 'Armurier d\'art',
+ 'Armurier spectacle',
+ 'Artificier spectacle',
+ 'Artiste dramatique',
+ 'Aspigiculteur',
+ 'Assistant de justice',
+ 'Assistant des ventes',
+ 'Assistant logistique',
+ 'Assistant styliste',
+ 'Assurance',
+ 'Auteur-adaptateur',
+ 'Billettiste voyages',
+ 'Brigadier',
+ 'Bruiteur',
+ 'Bâtonnier d\'art',
+ 'Bûcheron',
+ 'Cameraman',
+ 'Capitaine de pêche',
+ 'Carrier',
+ 'Caviste',
+ 'Chansonnier',
+ 'Chanteur',
+ 'Chargé de recherche',
+ 'Chasseur-bagagiste',
+ 'Chef de fabrication',
+ 'Chef de scierie',
+ 'Chef des ventes',
+ 'Chef du personnel',
+ 'Chef géographe',
+ 'Chef monteur son',
+ 'Chef porion',
+ 'Chiropraticien',
+ 'Choréologue',
+ 'Chromiste',
+ 'Cintrier-machiniste',
+ 'Clerc hors rang',
+ 'Coach sportif',
+ 'Coffreur béton armé',
+ 'Coffreur-ferrailleur',
+ 'Commandant de police',
+ 'Commandant marine',
+ 'Commis de coupe',
+ 'Comptable unique',
+ 'Conception et études',
+ 'Conducteur de jumbo',
+ 'Conseiller culinaire',
+ 'Conseiller funéraire',
+ 'Conseiller relooking',
+ 'Consultant ergonome',
+ 'Contrebassiste',
+ 'Convoyeur garde',
+ 'Copiste offset',
+ 'Corniste',
+ 'Costumier-habilleur',
+ 'Coutelier d\'art',
+ 'Cueilleur de cerises',
+ 'Céramiste concepteur',
+ 'Danse',
+ 'Danseur',
+ 'Data manager',
+ 'Dee-jay',
+ 'Designer produit',
+ 'Diététicien conseil',
+ 'Diététique',
+ 'Doreur sur métaux',
+ 'Décorateur-costumier',
+ 'Défloqueur d\'amiante',
+ 'Dégustateur',
+ 'Délégué vétérinaire',
+ 'Délégué à la tutelle',
+ 'Désamianteur',
+ 'Détective',
+ 'Développeur web',
+ 'Ecotoxicologue',
+ 'Elagueur-botteur',
+ 'Elagueur-grimpeur',
+ 'Elastiqueur',
+ 'Eleveur d\'insectes',
+ 'Eleveur de chats',
+ 'Eleveur de volailles',
+ 'Embouteilleur',
+ 'Employé d\'accueil',
+ 'Employé d\'étage',
+ 'Employé de snack-bar',
+ 'Endivier',
+ 'Endocrinologue',
+ 'Epithésiste',
+ 'Essayeur-retoucheur',
+ 'Etainier',
+ 'Etancheur',
+ 'Etancheur-bardeur',
+ 'Etiqueteur',
+ 'Expert back-office',
+ 'Exploitant de tennis',
+ 'Extraction',
+ 'Facteur',
+ 'Facteur de clavecins',
+ 'Facteur de secteur',
+ 'Fantaisiste',
+ 'Façadier-bardeur',
+ 'Façadier-ravaleur',
+ 'Feutier',
+ 'Finance',
+ 'Flaconneur',
+ 'Foreur pétrole',
+ 'Formateur d\'italien',
+ 'Fossoyeur',
+ 'Fraiseur',
+ 'Fraiseur mouliste',
+ 'Frigoriste maritime',
+ 'Fromager',
+ 'Galeriste',
+ 'Gardien de résidence',
+ 'Garçon de chenil',
+ 'Garçon de hall',
+ 'Gendarme mobile',
+ 'Guitariste',
+ 'Gynécologue',
+ 'Géodésien',
+ 'Géologue prospecteur',
+ 'Géomètre',
+ 'Géomètre du cadastre',
+ 'Gérant d\'hôtel',
+ 'Gérant de tutelle',
+ 'Gériatre',
+ 'Hydrothérapie',
+ 'Hématologue',
+ 'Hôte de caisse',
+ 'Ingénieur bâtiment',
+ 'Ingénieur du son',
+ 'Ingénieur géologue',
+ 'Ingénieur géomètre',
+ 'Ingénieur halieute',
+ 'Ingénieur logistique',
+ 'Instituteur',
+ 'Jointeur de placage',
+ 'Juge des enfants',
+ 'Juriste financier',
+ 'Kiwiculteur',
+ 'Lexicographe',
+ 'Liftier',
+ 'Litigeur transport',
+ 'Logistique',
+ 'Logopède',
+ 'Magicien',
+ 'Manager d\'artiste',
+ 'Mannequin détail',
+ 'Maquilleur spectacle',
+ 'Marbrier-poseur',
+ 'Marin grande pêche',
+ 'Matelassier',
+ 'Maçon',
+ 'Maçon-fumiste',
+ 'Maçonnerie',
+ 'Maître de ballet',
+ 'Maïeuticien',
+ 'Menuisier',
+ 'Miroitier',
+ 'Modéliste industriel',
+ 'Moellonneur',
+ 'Moniteur de sport',
+ 'Monteur audiovisuel',
+ 'Monteur de fermettes',
+ 'Monteur de palettes',
+ 'Monteur en siège',
+ 'Monteur prototypiste',
+ 'Monteur-frigoriste',
+ 'Monteur-truquiste',
+ 'Mouleur sable',
+ 'Mouliste drapeur',
+ 'Mécanicien-armurier',
+ 'Médecin du sport',
+ 'Médecin scolaire',
+ 'Médiateur judiciaire',
+ 'Médiathécaire',
+ 'Net surfeur surfeuse',
+ 'Oenologue',
+ 'Opérateur de plateau',
+ 'Opérateur du son',
+ 'Opérateur géomètre',
+ 'Opérateur piquage',
+ 'Opérateur vidéo',
+ 'Ouvrier d\'abattoir',
+ 'Ouvrier serriste',
+ 'Ouvrier sidérurgiste',
+ 'Palefrenier',
+ 'Paléontologue',
+ 'Pareur en abattoir',
+ 'Parfumeur',
+ 'Parqueteur',
+ 'Percepteur',
+ 'Photographe d\'art',
+ 'Pilote automobile',
+ 'Pilote de soutireuse',
+ 'Pilote fluvial',
+ 'Piqueur en ganterie',
+ 'Pisteur secouriste',
+ 'Pizzaïolo',
+ 'Plaquiste enduiseur',
+ 'Plasticien',
+ 'Plisseur',
+ 'Poissonnier-traiteur',
+ 'Pontonnier',
+ 'Porion',
+ 'Porteur de hottes',
+ 'Porteur de journaux',
+ 'Portier',
+ 'Poseur de granit',
+ 'Posticheur spectacle',
+ 'Potier',
+ 'Praticien dentaire',
+ 'Praticiens médicaux',
+ 'Premier clerc',
+ 'Preneur de son',
+ 'Primeuriste',
+ 'Professeur d\'italien',
+ 'Projeteur béton armé',
+ 'Promotion des ventes',
+ 'Présentateur radio',
+ 'Pyrotechnicien',
+ 'Pédicure pour bovin',
+ 'Pédologue',
+ 'Pédopsychiatre',
+ 'Quincaillier',
+ 'Radio chargeur',
+ 'Ramasseur d\'asperges',
+ 'Ramasseur d\'endives',
+ 'Ravaleur-ragréeur',
+ 'Recherche',
+ 'Recuiseur',
+ 'Relieur-doreur',
+ 'Responsable de salle',
+ 'Responsable télécoms',
+ 'Revenue Manager',
+ 'Rippeur spectacle',
+ 'Rogneur',
+ 'Récupérateur',
+ 'Rédacteur des débats',
+ 'Régleur funéraire',
+ 'Régleur sur tour',
+ 'Sapeur-pompier',
+ 'Scannériste',
+ 'Scripte télévision',
+ 'Sculpteur sur verre',
+ 'Scénariste',
+ 'Second de cuisine',
+ 'Secrétaire juridique',
+ 'Semencier',
+ 'Sertisseur',
+ 'Services funéraires',
+ 'Solier-moquettiste',
+ 'Sommelier',
+ 'Sophrologue',
+ 'Staffeur',
+ 'Story boarder',
+ 'Stratifieur',
+ 'Stucateur',
+ 'Styliste graphiste',
+ 'Surjeteur-raseur',
+ 'Séismologue',
+ 'Technicien agricole',
+ 'Technicien bovin',
+ 'Technicien géomètre',
+ 'Technicien plateau',
+ 'Technicien énergie',
+ 'Terminologue',
+ 'Testeur informatique',
+ 'Toiliste',
+ 'Topographe',
+ 'Toréro',
+ 'Traducteur d\'édition',
+ 'Traffic manager',
+ 'Trieur de métaux',
+ 'Turbinier',
+ 'Téléconseiller',
+ 'Tôlier-traceur',
+ 'Vendeur carreau',
+ 'Vendeur en lingerie',
+ 'Vendeur en meubles',
+ 'Vendeur en épicerie',
+ 'Verrier d\'art',
+ 'Verrier à la calotte',
+ 'Verrier à la main',
+ 'Verrier à main levée',
+ 'Vidéo-jockey',
+ 'Vitrier',
+ );
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Internet.php
new file mode 100644
index 000000000..8e3024bf7
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Internet.php
@@ -0,0 +1,9 @@
+numberBetween(1, 2);
+ }
+
+ $nir .=
+ // Year of birth (aa)
+ $this->numerify('##') .
+ // Mont of birth (mm)
+ sprintf('%02d', $this->numberBetween(1, 12));
+
+ // Department
+ $department = key(Address::department());
+ $nir .= $department;
+
+ // Town number, depends on department length
+ if (strlen($department) === 2) {
+ $nir .= $this->numerify('###');
+ } elseif (strlen($department) === 3) {
+ $nir .= $this->numerify('##');
+ }
+
+ // Born number (depending of town and month of birth)
+ $nir .= $this->numerify('###');
+
+ /**
+ * The key for a given NIR is `97 - 97 % NIR`
+ * NIR has to be an integer, so we have to do a little replacment
+ * for departments 2A and 2B
+ */
+ if ($department === '2A') {
+ $nirInteger = str_replace('2A', '19', $nir);
+ } elseif ($department === '2B') {
+ $nirInteger = str_replace('2B', '18', $nir);
+ } else {
+ $nirInteger = $nir;
+ }
+ $nir .= sprintf('%02d', 97 - $nirInteger % 97);
+
+ // Format is x xx xx xx xxx xxx xx
+ if ($formatted) {
+ $nir = substr($nir, 0, 1) . ' ' . substr($nir, 1, 2) . ' ' . substr($nir, 3, 2) . ' ' . substr($nir, 5, 2) . ' ' . substr($nir, 7, 3). ' ' . substr($nir, 10, 3). ' ' . substr($nir, 13, 2);
+ }
+
+ return $nir;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/PhoneNumber.php
new file mode 100644
index 000000000..7c0bd9d5e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/PhoneNumber.php
@@ -0,0 +1,141 @@
+phoneNumber07WithSeparator();
+ $phoneNumber = str_replace(' ', '', $phoneNumber);
+ return $phoneNumber;
+ }
+
+ /**
+ * Only 073 to 079 are acceptable prefixes with 07
+ *
+ * @see http://www.arcep.fr/index.php?id=8146
+ */
+ public function phoneNumber07WithSeparator()
+ {
+ $phoneNumber = $this->generator->numberBetween(3, 9);
+ $phoneNumber .= $this->numerify('# ## ## ##');
+ return $phoneNumber;
+ }
+
+ public function phoneNumber08()
+ {
+ $phoneNumber = $this->phoneNumber08WithSeparator();
+ $phoneNumber = str_replace(' ', '', $phoneNumber);
+ return $phoneNumber;
+ }
+
+ /**
+ * Valid formats for 08:
+ *
+ * 0# ## ## ##
+ * 1# ## ## ##
+ * 2# ## ## ##
+ * 91 ## ## ##
+ * 92 ## ## ##
+ * 93 ## ## ##
+ * 97 ## ## ##
+ * 98 ## ## ##
+ * 99 ## ## ##
+ *
+ * Formats 089(4|6)## ## ## are valid, but will be
+ * attributed when other 089 resource ranges are exhausted.
+ *
+ * @see https://www.arcep.fr/index.php?id=8146#c9625
+ * @see https://issuetracker.google.com/u/1/issues/73269839
+ */
+ public function phoneNumber08WithSeparator()
+ {
+ $regex = '([012]{1}\d{1}|(9[1-357-9])( \d{2}){3}';
+ return $this->regexify($regex);
+ }
+
+ /**
+ * @example '0601020304'
+ */
+ public function mobileNumber()
+ {
+ $format = static::randomElement(static::$mobileFormats);
+
+ return static::numerify($this->generator->parse($format));
+ }
+ /**
+ * @example '0891951357'
+ */
+ public function serviceNumber()
+ {
+ $format = static::randomElement(static::$serviceFormats);
+
+ return static::numerify($this->generator->parse($format));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Text.php b/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Text.php
new file mode 100644
index 000000000..9403f1685
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/fr_FR/Text.php
@@ -0,0 +1,15531 @@
+ static::latitude(46.262740, 47.564721),
+ 'longitude' => static::longitude(17.077949, 20.604560)
+ );
+ }
+
+ /* ----------- DATA -------------------- */
+
+ protected static $streetSuffix = array(
+ 'árok', 'átjáró', 'dűlÅ‘sor', 'dűlőút', 'erdÅ‘sor', 'fasor', 'forduló', 'gát', 'határsor', 'határút', 'hÃd', 'játszótér', 'kert', 'körönd', 'körtér', 'körút', 'köz', 'lakótelep', 'lejáró', 'lejtÅ‘', 'lépcsÅ‘', 'liget', 'mélyút', 'orom', 'országút', 'ösvény', 'park', 'part', 'pincesor', 'rakpart', 'sétány', 'sétaút', 'sor', 'sugárút', 'tér', 'tere', 'turistaút', 'udvar', 'út', 'útja', 'utca', 'üdülÅ‘part'
+ );
+ protected static $postcode = array('####');
+ protected static $state = array(
+ 'Budapest', 'Bács-Kiskun', 'Baranya', 'Békés', 'Borsod-Abaúj-Zemplén', 'Csongrád', 'Fejér', 'Győr-Moson-Sopron', 'Hajdú-Bihar', 'Heves', 'Jász-Nagykun-Szolnok', 'Komárom-Esztergom', 'Nógrád', 'Pest', 'Somogy', 'Szabolcs-Szatmár-Bereg', 'Tolna', 'Vas', 'Veszprém', 'Zala'
+ );
+ protected static $country = array(
+ 'Afganisztán', 'Albánia', 'Algéria', 'Amerikai Egyesült Ãllamok', 'Andorra', 'Angola', 'Antigua és Barbuda', 'ArgentÃna', 'Ausztria', 'Ausztrália', 'Azerbajdzsán',
+ 'Bahama-szigetek', 'Bahrein', 'Banglades', 'Barbados', 'Belgium', 'Belize', 'Benin', 'Bhután', 'BolÃvia', 'Bosznia-Hercegovina', 'Botswana', 'BrazÃlia', 'Brunei', 'Bulgária', 'Burkina Faso', 'Burma', 'Burundi',
+ 'Chile', 'Ciprus', 'Costa Rica', 'Csehország', 'Csád',
+ 'Dominikai Köztársaság', 'Dominikai Közösség', 'Dzsibuti', 'Dánia', 'Dél-Afrika', 'Dél-Korea', 'Dél-Szudán',
+ 'Ecuador', 'EgyenlÃtÅ‘i-Guinea', 'Egyesült Arab EmÃrségek', 'Egyesült Királyság', 'Egyiptom', 'Elefántcsontpart', 'Eritrea', 'Etiópia',
+ 'Fehéroroszország', 'Fidzsi-szigetek', 'Finnország', 'Franciaország', 'Fülöp-szigetek',
+ 'Gabon', 'Gambia', 'Ghána', 'Grenada', 'Grúzia', 'Guatemala', 'Guinea', 'Guyana', 'Görögország',
+ 'Haiti', 'Hollandia', 'Horvátország',
+ 'India', 'Indonézia', 'Irak', 'Irán', 'Izland', 'Izrael',
+ 'Japán', 'Jemen', 'Jordánia',
+ 'Kambodzsa', 'Kamerun', 'Kanada', 'Katar', 'Kazahsztán', 'Kelet-Timor', 'Kenya', 'Kirgizisztán', 'Kiribati', 'Kolumbia', 'Kongói Demokratikus Köztársaság', 'Kongói Köztársaság', 'Kuba', 'Kuvait', 'KÃna', 'Közép-Afrika',
+ 'Laosz', 'Lengyelország', 'Lesotho', 'Lettország', 'Libanon', 'Libéria', 'Liechtenstein', 'Litvánia', 'Luxemburg', 'LÃbia',
+ 'Macedónia', 'Madagaszkár', 'Magyarország', 'Malawi', 'MaldÃv-szigetek', 'Mali', 'Malájzia', 'Marokkó', 'Marshall-szigetek', 'Mauritánia', 'Mexikó', 'Mikronézia', 'Moldova', 'Monaco', 'Mongólia', 'Montenegró', 'Mozambik', 'Málta',
+ 'NamÃbia', 'Nauru', 'Nepál', 'Nicaragua', 'Niger', 'Nigéria', 'Norvégia', 'Németország',
+ 'Olaszország', 'Omán', 'Oroszország',
+ 'Pakisztán', 'Palau', 'Panama', 'Paraguay', 'Peru', 'Portugália', 'Pápua Új-Guinea',
+ 'Románia', 'Ruanda',
+ 'Saint Kitts és Nevis', 'Saint Vincent', 'Salamon-szigetek', 'Salvador', 'San Marino', 'Seychelle-szigetek', 'Spanyolország', 'Srà Lanka', 'Suriname', 'Svájc', 'Svédország', 'Szamoa', 'Szaúd-Arábia', 'Szenegál', 'Szerbia', 'Szingapúr', 'Szlovákia', 'Szlovénia', 'Szomália', 'Szudán', 'Szváziföld', 'SzÃria', 'São Tomé és PrÃncipe',
+ 'Tadzsikisztán', 'Tanzánia', 'Thaiföld', 'Togo', 'Tonga', 'Trinidad és Tobago', 'Tunézia', 'Tuvalu', 'Törökország', 'Türkmenisztán',
+ 'Uganda', 'Ukrajna', 'Uruguay',
+ 'Vanuatu', 'Venezuela', 'Vietnám',
+ 'Zambia', 'Zimbabwe', 'Zöld-foki-szigetek',
+ 'Észak-Korea', 'Észtország', 'Ãrország', 'Örményország', 'Új-Zéland', 'Üzbegisztán'
+ );
+
+ /**
+ * Source: https://hu.wikipedia.org/wiki/Magyarorsz%C3%A1g_v%C3%A1rosainak_list%C3%A1ja
+ */
+ protected static $capitals = array('Budapest');
+ protected static $bigCities = array(
+ 'Békéscsaba', 'Debrecen', 'Dunaújváros', 'Eger', 'Érd', 'GyÅ‘r', 'HódmezÅ‘vásárhely', 'Kaposvár', 'Kecskemét', 'Miskolc', 'Nagykanizsa', 'NyÃregyháza', 'Pécs', 'Salgótarján', 'Sopron', 'Szeged', 'Székesfehérvár', 'Szekszárd', 'Szolnok', 'Szombathely', 'Tatabánya', 'Veszprém', 'Zalaegerszeg'
+ );
+ protected static $smallerCities = array(
+ 'Ajka', 'Aszód', 'Bácsalmás',
+ 'Baja', 'Baktalórántháza', 'Balassagyarmat', 'Balatonalmádi', 'Balatonfüred', 'Balmazújváros', 'Barcs', 'Bátonyterenye', 'Békés', 'Bélapátfalva', 'Berettyóújfalu', 'Bicske', 'Bóly', 'Bonyhád', 'Budakeszi',
+ 'Cegléd', 'Celldömölk', 'Cigánd', 'Csenger', 'Csongrád', 'Csorna', 'Csurgó',
+ 'Dabas', 'Derecske', 'Devecser', 'Dombóvár', 'Dunakeszi',
+ 'Edelény', 'Encs', 'Enying', 'Esztergom',
+ 'Fehérgyarmat', 'Fonyód', 'Füzesabony',
+ 'Gárdony', 'Gödöllő', 'Gönc', 'Gyál', 'Gyomaendrőd', 'Gyöngyös', 'Gyula',
+ 'Hajdúböszörmény', 'Hajdúhadház', 'Hajdúnánás', 'Hajdúszoboszló', 'Hatvan', 'Heves',
+ 'Ibrány',
+ 'Jánoshalma', 'Jászapáti', 'Jászberény',
+ 'Kalocsa', 'Kapuvár', 'Karcag', 'Kazincbarcika', 'Kemecse', 'Keszthely', 'Kisbér', 'Kiskőrös', 'Kiskunfélegyháza', 'Kiskunhalas', 'Kiskunmajsa', 'Kistelek', 'Kisvárda', 'Komárom', 'Komló', 'Körmend', 'Kőszeg', 'Kunhegyes', 'Kunszentmárton', 'Kunszentmiklós',
+ 'Lenti', 'Letenye',
+ 'Makó', 'Marcali', 'Martonvásár', 'Mátészalka', 'Mezőcsát', 'Mezőkovácsháza', 'Mezőkövesd', 'Mezőtúr', 'Mohács', 'Monor', 'Mór', 'Mórahalom', 'Mosonmagyaróvár',
+ 'Nagyatád', 'Nagykálló', 'Nagykáta', 'NagykÅ‘rös', 'NyÃradony', 'NyÃrbátor',
+ 'Orosháza', 'Oroszlány', 'Ózd',
+ 'Paks', 'Pannonhalma', 'Pápa', 'Pásztó', 'Pécsvárad', 'Pétervására', 'Pilisvörösvár', 'Polgárdi', 'Püspökladány', 'Putnok',
+ 'Ráckeve', 'Rétság',
+ 'Sárbogárd', 'Sarkad', 'Sárospatak', 'Sárvár', 'Sásd', 'Sátoraljaújhely', 'Sellye', 'Siklós', 'Siófok', 'Sümeg', 'Szarvas', 'Szécsény', 'Szeghalom', 'Szentendre', 'Szentes', 'Szentgotthárd', 'Szentlőrinc', 'Szerencs', 'Szigetszentmiklós', 'Szigetvár', 'Szikszó', 'Szob',
+ 'Tab', 'Tamási', 'Tapolca', 'Tata', 'Tét', 'Tiszafüred', 'Tiszakécske', 'Tiszaújváros', 'Tiszavasvári', 'Tokaj', 'Tolna', 'Törökszentmiklós',
+ 'Vác', 'Várpalota', 'Vásárosnamény', 'Vasvár', 'Vecsés',
+ 'Záhony', 'Zalaszentgrót', 'Zirc'
+ );
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/hu_HU/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/hu_HU/Company.php
new file mode 100644
index 000000000..713165429
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/hu_HU/Company.php
@@ -0,0 +1,13 @@
+generator->parse($format);
+ }
+
+ public static function country()
+ {
+ return static::randomElement(static::$country);
+ }
+
+ public static function postcode()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$postcode)));
+ }
+
+ public static function regionSuffix()
+ {
+ return static::randomElement(static::$regionSuffix);
+ }
+
+ public static function region()
+ {
+ return static::randomElement(static::$region);
+ }
+
+ public static function cityPrefix()
+ {
+ return static::randomElement(static::$cityPrefix);
+ }
+
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ public function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ public static function street()
+ {
+ return static::randomElement(static::$street);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/hy_AM/Color.php b/vendor/fzaninotto/faker/src/Faker/Provider/hy_AM/Color.php
new file mode 100644
index 000000000..16b68d8b2
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/hy_AM/Color.php
@@ -0,0 +1,12 @@
+generator->parse(static::randomElement(static::$formats)));
+ }
+
+ public function code()
+ {
+ return static::randomElement(static::$codes);
+ }
+
+ /**
+ * @return mixed
+ */
+ public function numberFormat()
+ {
+ return static::randomElement(static::$numberFormats);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Address.php
new file mode 100644
index 000000000..49fd1a7a6
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Address.php
@@ -0,0 +1,316 @@
+generator->parse($format);
+ }
+
+ public static function street()
+ {
+ return static::randomElement(static::$street);
+ }
+
+ public static function buildingNumber()
+ {
+ return static::numberBetween(1, 999);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Color.php b/vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Color.php
new file mode 100644
index 000000000..bb1444da2
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/id_ID/Color.php
@@ -0,0 +1,41 @@
+generator->parse($lastNameRandomElement);
+ }
+
+ /**
+ * Return last name for male
+ *
+ * @access public
+ * @return string last name
+ */
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ /**
+ * Return last name for female
+ *
+ * @access public
+ * @return string last name
+ */
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+
+ /**
+ * For academic title
+ *
+ * @access public
+ * @return string suffix
+ */
+ public static function suffix()
+ {
+ return static::randomElement(static::$suffix);
+ }
+
+ /**
+ * Generates Nomor Induk Kependudukan (NIK)
+ *
+ * @link https://en.wikipedia.org/wiki/National_identification_number#Indonesia
+ *
+ * @param null|string $gender
+ * @param null|\DateTime $birthDate
+ * @return string
+ */
+ public function nik($gender = null, $birthDate = null)
+ {
+ # generate first numbers (region data)
+ $nik = $this->birthPlaceCode();
+ $nik .= $this->generator->numerify('##');
+
+ if (!$birthDate) {
+ $birthDate = $this->generator->dateTimeBetween();
+ }
+
+ if (!$gender) {
+ $gender = $this->generator->randomElement(array(self::GENDER_MALE, self::GENDER_FEMALE));
+ }
+
+ # if gender is female, add 40 to days
+ if ($gender == self::GENDER_FEMALE) {
+ $nik .= $birthDate->format('d') + 40;
+ } else {
+ $nik .= $birthDate->format('d');
+ }
+
+ $nik .= $birthDate->format('my');
+
+ # add last random digits
+ $nik .= $this->generator->numerify('####');
+
+ return $nik;
+ }
+
+ /**
+ * Generates birth place code for NIK
+ *
+ * @link https://id.wikipedia.org/wiki/Nomor_Induk_Kependudukan
+ * @link http://informasipedia.com/wilayah-indonesia/daftar-kabupaten-kota-di-indonesia/
+ */
+ protected function birthPlaceCode()
+ {
+ return static::randomElement(static::$birthPlaceCode);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/id_ID/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/id_ID/PhoneNumber.php
new file mode 100644
index 000000000..de5c9696e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/id_ID/PhoneNumber.php
@@ -0,0 +1,55 @@
+
+ */
+class Address extends \Faker\Provider\Address
+{
+ /**
+ * @var array Countries in icelandic
+ */
+ protected static $country = array(
+ 'Afganistan', 'AlbanÃa', 'AlsÃr', 'Andorra', 'Angóla', 'Angvilla', 'AntÃgva og Barbúda', 'ArgentÃna',
+ 'ArmenÃa', 'Arúba', 'AserbaÃdsjan', 'Austur-Kongó', 'AusturrÃki', 'Austur-TÃmor', 'Ãlandseyjar',
+ 'ÃstralÃa', 'Bahamaeyjar', 'BandarÃkin', 'BandarÃska Samóa', 'Bangladess', 'Barbados', 'Barein',
+ 'BelgÃa', 'BelÃs', 'BenÃn', 'Bermúdaeyjar', 'BosnÃa og HersegóvÃna', 'Botsvana', 'Bouvet-eyja', 'BólivÃa',
+ 'BrasilÃa', 'Bresku Indlandshafseyjar', 'Bretland', 'Brúnei', 'BúlgarÃa', 'BúrkÃna Fasó', 'BúrúndÃ', 'Bútan',
+ 'Cayman-eyjar', 'Chile', 'Cooks-eyjar', 'Danmörk', 'DjÃbútÃ', 'DóminÃka', 'DóminÃska lýðveldið', 'Egyptaland',
+ 'Eistland', 'Ekvador', 'El Salvador', 'England', 'ErÃtrea', 'EþÃópÃa', 'Falklandseyjar', 'Filippseyjar',
+ 'Finnland', 'FÃdjieyjar', 'FÃlabeinsströndin', 'Frakkland', 'Franska Gvæjana', 'Franska PólýnesÃa',
+ 'Frönsku suðlægu landsvæðin', 'Færeyjar', 'Gabon', 'GambÃa', 'Gana', 'GeorgÃa', 'GÃbraltar', 'GÃnea',
+ 'GÃnea-Bissá', 'Grenada', 'Grikkland', 'Grænhöfðaeyjar', 'Grænland', 'Gvadelúpeyjar', 'Gvam', 'Gvatemala',
+ 'Gvæjana', 'HaÃtÃ', 'Heard og McDonalds-eyjar', 'Holland', 'Hollensku Antillur', 'Hondúras', 'Hong Kong',
+ 'HvÃta-Rússland', 'Indland', 'IndónesÃa', 'Ãrak', 'Ãran', 'Ãrland', 'Ãsland', 'Ãsrael', 'ÃtalÃa', 'JamaÃka',
+ 'Japan', 'Jemen', 'Jólaey', 'Jómfrúaeyjar', 'JórdanÃa', 'KambódÃa', 'Kamerún', 'Kanada', 'Kasakstan', 'Katar',
+ 'KenÃa', 'Kirgisistan', 'KÃna', 'KÃribatÃ', 'Kongó', 'Austur-Kongó', 'Vestur-Kongó', 'KostarÃka', 'Kókoseyjar',
+ 'KólumbÃa', 'Kómoreyjar', 'Kórea', 'Norður-Kórea;', 'Suður-Kórea', 'KróatÃa', 'Kúba', 'Kúveit', 'Kýpur',
+ 'Laos', 'Lesótó', 'Lettland', 'Liechtenstein', 'Litháen', 'LÃbanon', 'LÃberÃa', 'LÃbÃa', 'Lúxemborg',
+ 'Madagaskar', 'Makaó', 'MakedónÃa', 'MalasÃa', 'MalavÃ', 'MaldÃveyjar', 'MalÃ', 'Malta', 'Marokkó',
+ 'Marshall-eyjar', 'MartinÃk', 'Mayotte', 'MáritanÃa', 'MáritÃus', 'MexÃkó', 'Mið-AfrÃkulýðveldið',
+ 'Miðbaugs-GÃnea', 'MÃkrónesÃa', 'Mjanmar', 'Moldóva', 'MongólÃa', 'Montserrat', 'Mónakó', 'MósambÃk',
+ 'NamibÃa', 'Nárú', 'Nepal', 'Niue', 'NÃger', 'NÃgerÃa', 'NÃkaragva', 'Norður-Ãrland', 'Norður-Kórea',
+ 'Norður-MarÃanaeyjar', 'Noregur', 'Norfolkeyja', 'Nýja-KaledónÃa', 'Nýja-Sjáland', 'Óman', 'Pakistan',
+ 'Palá', 'PalestÃna', 'Panama', 'Papúa Nýja-GÃnea', 'Paragvæ', 'Páfagarður', 'Perú', 'Pitcairn', 'Portúgal',
+ 'Pólland', 'Púertó RÃkó', 'Réunion', 'Rúanda', 'RúmenÃa', 'Rússland', 'Salómonseyjar', 'SambÃa',
+ 'Sameinuðu arabÃsku furstadæmin', 'Samóa', 'San MarÃnó', 'Sankti Helena', 'Sankti Kristófer og Nevis',
+ 'Sankti LúsÃa', 'Sankti Pierre og Miquelon', 'Sankti Vinsent og GrenadÃneyjar', 'Saó Tóme og PrinsÃpe',
+ 'Sádi-ArabÃa', 'Senegal', 'SerbÃa', 'Seychelles-eyjar', 'Simbabve', 'Singapúr', 'SÃerra Leóne', 'Skotland',
+ 'SlóvakÃa', 'SlóvenÃa', 'Smáeyjar BandarÃkjanna', 'SómalÃa', 'Spánn', 'Srà Lanka', 'Suður-AfrÃka',
+ 'Suður-GeorgÃa og Suður-SandvÃkureyjar', 'Suður-Kórea', 'Suðurskautslandið', 'Súdan', 'SúrÃnam', 'Jan Mayen',
+ 'Svartfjallaland', 'SvasÃland', 'Sviss', 'SvÃþjóð', 'Sýrland', 'Tadsjikistan', 'TaÃland', 'TaÃvan', 'TansanÃa',
+ 'Tékkland', 'Tonga', 'Tógó', 'Tókelá', 'TrÃnidad og Tóbagó', 'Tsjad', 'TsjetsjenÃa', 'Turks- og Caicos-eyjar',
+ 'Túnis', 'Túrkmenistan', 'Túvalú', 'Tyrkland', 'Ungverjaland', 'Úganda', 'ÚkraÃna', 'Úrúgvæ', 'Úsbekistan',
+ 'Vanúatú', 'Venesúela', 'Vestur-Kongó', 'Vestur-Sahara', 'VÃetnam', 'Wales', 'Wallis- og Fútúnaeyjar', 'Þýskaland'
+ );
+
+ /**
+ * @var array Icelandic cities.
+ */
+ protected static $cityNames = array(
+ 'ReykjavÃk', 'Seltjarnarnes', 'Vogar', 'Kópavogur', 'Garðabær', 'Hafnarfjörður', 'Reykjanesbær', 'GrindavÃk',
+ 'Sandgerði', 'Garður', 'Reykjanesbær', 'Mosfellsbær', 'Akranes', 'Borgarnes', 'Reykholt', 'Stykkishólmur',
+ 'Flatey', 'Grundarfjörður', 'ÓlafsvÃk', 'Snæfellsbær', 'Hellissandur', 'Búðardalur', 'Reykhólahreppur',
+ 'Ãsafjörður', 'HnÃfsdalur', 'BolungarvÃk', 'SúðavÃk', 'Flateyri', 'Suðureyri', 'Patreksfjörður',
+ 'Tálknafjörður', 'BÃldudalur', 'Þingeyri', 'Staður', 'HólmavÃk', 'Drangsnes', 'Ãrneshreppur', 'Hvammstangi',
+ 'Blönduós', 'Skagaströnd', 'Sauðárkrókur', 'VarmahlÃð', 'Hofsós', 'Fljót', 'Siglufjörður', 'Akureyri',
+ 'GrenivÃk', 'GrÃmsey', 'DalvÃk', 'Ólafsfjörður', 'HrÃsey', 'HúsavÃk', 'Fosshóll', 'Laugar', 'Mývatn',
+ 'Kópasker', 'Raufarhöfn', 'Þórshöfn', 'Bakkafjörður', 'Vopnafjörður', 'Egilsstaðir', 'Seyðisfjörður',
+ 'Mjóifjörður', 'Borgarfjörður', 'Reyðarfjörður', 'Eskifjörður', 'Neskaupstaður', 'Fáskrúðsfjörður',
+ 'Stöðvarfjörður', 'BreiðdalsvÃk', 'Djúpivogur', 'Höfn', 'Selfoss', 'Hveragerði', 'Þorlákshöfn', 'Ölfus',
+ 'Eyrarbakki', 'Stokkseyri', 'Laugarvatn', 'Flúðir', 'Hella', 'Hvolsvöllur', 'VÃk', 'Kirkjubæjarklaustur',
+ 'Vestmannaeyjar'
+ );
+
+ /**
+ * @var array Street name suffix.
+ */
+ protected static $streetSuffix = array(
+ 'ás', 'bakki', 'braut', 'bær', 'brún', 'berg', 'fold', 'gata', 'gróf',
+ 'garðar', 'höfði', 'heimar', 'hamar', 'hólar', 'háls', 'kvÃsl', 'lækur',
+ 'leiti', 'land', 'múli', 'nes', 'rimi', 'stÃgur', 'stræti', 'stekkur',
+ 'slóð', 'skógar', 'sel', 'teigur', 'tún', 'vangur', 'vegur', 'vogur',
+ 'vað'
+ );
+
+ /**
+ * @var array Street name prefix.
+ */
+ protected static $streetPrefix = array(
+ 'Aðal', 'Austur', 'Bakka', 'Braga', 'Báru', 'Brunn', 'Fiski', 'Leifs',
+ 'Týs', 'Birki', 'Suður', 'Norður', 'Vestur', 'Austur', 'Sanda', 'Skógar',
+ 'Stór', 'Sunnu', 'Tungu', 'Tangar', 'Úlfarfells', 'Vagn', 'Vind', 'Ysti',
+ 'Þing', 'Hamra', 'Hóla', 'KrÃu', 'Iðu', 'Spóa', 'Starra', 'Uglu', 'Vals'
+ );
+
+ /**
+ * @var Icelandic zip code.
+ **/
+ protected static $postcode = array(
+ '%##'
+ );
+
+ /**
+ * @var array Icelandic regions.
+ */
+ protected static $regionNames = array(
+ 'Höfuðborgarsvæðið', 'Norðurland', 'Suðurland', 'Vesturland', 'Vestfirðir', 'Austurland', 'Suðurnes'
+ );
+
+ /**
+ * @var array Icelandic building numbers.
+ */
+ protected static $buildingNumber = array(
+ '%##', '%#', '%#', '%', '%', '%', '%?', '% ?',
+ );
+
+ /**
+ * @var array Icelandic city format.
+ */
+ protected static $cityFormats = array(
+ '{{cityName}}',
+ );
+
+ /**
+ * @var array Icelandic street's name formats.
+ */
+ protected static $streetNameFormats = array(
+ '{{streetPrefix}}{{streetSuffix}}',
+ '{{streetPrefix}}{{streetSuffix}}',
+ '{{firstNameMale}}{{streetSuffix}}',
+ '{{firstNameFemale}}{{streetSuffix}}'
+ );
+
+ /**
+ * @var array Icelandic street's address formats.
+ */
+ protected static $streetAddressFormats = array(
+ '{{streetName}} {{buildingNumber}}'
+ );
+
+ /**
+ * @var array Icelandic address format.
+ */
+ protected static $addressFormats = array(
+ "{{streetAddress}}\n{{postcode}} {{city}}",
+ );
+
+ /**
+ * Randomly return a real city name.
+ *
+ * @return string
+ */
+ public static function cityName()
+ {
+ return static::randomElement(static::$cityNames);
+ }
+
+ /**
+ * Randomly return a street prefix.
+ *
+ * @return string
+ */
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ /**
+ * Randomly return a building number.
+ *
+ * @return string
+ */
+ public static function buildingNumber()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$buildingNumber)));
+ }
+
+ /**
+ * Randomly return a real region name.
+ *
+ * @return string
+ */
+ public static function region()
+ {
+ return static::randomElement(static::$regionNames);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Company.php
new file mode 100644
index 000000000..6b934519a
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Company.php
@@ -0,0 +1,53 @@
+
+ */
+class Company extends \Faker\Provider\Company
+{
+ /**
+ * @var array Danish company name formats.
+ */
+ protected static $formats = array(
+ '{{lastName}} {{companySuffix}}',
+ '{{lastName}} {{companySuffix}}',
+ '{{lastName}} {{companySuffix}}',
+ '{{firstname}} {{lastName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{middleName}} {{companySuffix}}',
+ '{{firstname}} {{middleName}} {{companySuffix}}',
+ '{{lastName}} & {{lastName}} {{companySuffix}}',
+ '{{lastName}} og {{lastName}} {{companySuffix}}',
+ '{{lastName}} & {{lastName}} {{companySuffix}}',
+ '{{lastName}} og {{lastName}} {{companySuffix}}',
+ '{{middleName}} & {{middleName}} {{companySuffix}}',
+ '{{middleName}} og {{middleName}} {{companySuffix}}',
+ '{{middleName}} & {{lastName}}',
+ '{{middleName}} og {{lastName}}',
+ );
+
+ /**
+ * @var array Company suffixes.
+ */
+ protected static $companySuffix = array('ehf.', 'hf.', 'sf.');
+
+ /**
+ * @link http://www.rsk.is/atvinnurekstur/virdisaukaskattur/
+ *
+ * @var string VSK number format.
+ */
+ protected static $vskFormat = '%####';
+
+ /**
+ * Generates a VSK number (5 digits).
+ *
+ * @return string
+ */
+ public static function vsk()
+ {
+ return static::numerify(static::$vskFormat);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Internet.php
new file mode 100644
index 000000000..a265da61e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Internet.php
@@ -0,0 +1,23 @@
+
+ */
+class Internet extends \Faker\Provider\Internet
+{
+ /**
+ * @var array Some email domains in Denmark.
+ */
+ protected static $freeEmailDomain = array(
+ 'gmail.com', 'yahoo.com', 'hotmail.com', 'visir.is', 'simnet.is', 'internet.is'
+ );
+
+ /**
+ * @var array Some TLD.
+ */
+ protected static $tld = array(
+ 'com', 'com', 'com', 'net', 'is', 'is', 'is',
+ );
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Payment.php b/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Payment.php
new file mode 100644
index 000000000..c119c382f
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/Payment.php
@@ -0,0 +1,19 @@
+
+ */
+class Person extends \Faker\Provider\Person
+{
+ /**
+ * @var array Icelandic person name formats.
+ */
+ protected static $maleNameFormats = array(
+ '{{firstNameMale}} {{lastNameMale}}',
+ '{{firstNameMale}} {{lastNameMale}}',
+ '{{firstNameMale}} {{middleName}} {{lastNameMale}}',
+ '{{firstNameMale}} {{middleName}} {{lastNameMale}}',
+ );
+
+ protected static $femaleNameFormats = array(
+ '{{firstNameFemale}} {{lastNameFemale}}',
+ '{{firstNameFemale}} {{lastNameFemale}}',
+ '{{firstNameFemale}} {{middleName}} {{lastNameFemale}}',
+ '{{firstNameFemale}} {{middleName}} {{lastNameFemale}}',
+ );
+
+ /**
+ * @var string Icelandic women names.
+ */
+ protected static $firstNameFemale = array('Aagot', 'Abela', 'Abigael', 'Ada', 'Adda', 'Addý', 'Adela', 'AdelÃa', 'AdrÃana', 'Aðalbjörg', 'Aðalbjört', 'Aðalborg', 'AðaldÃs', 'AðalfrÃður', 'Aðalheiður', 'Aðalrós', 'Aðalsteina', 'Aðalsteinunn', 'Aðalveig', 'Agata', 'Agatha', 'Agða', 'Agla', 'Agnea', 'Agnes', 'Agneta', 'Alanta', 'Alba', 'Alberta', 'AlbÃna', 'Alda', 'AldÃs', 'Aldný', 'Aleta', 'Aletta', 'Alexa', 'Alexandra', 'AlexandrÃa', 'Alexis', 'AlexÃa', 'Alfa', 'AlfÃfa', 'Alice', 'Alida', 'AlÃda', 'AlÃna', 'AlÃs', 'AlÃsa', 'Alla', 'Allý', 'Alma', 'Alrún', 'Alva', 'Alvilda', 'Amadea', 'Amal', 'AmalÃa', 'Amanda', 'AmelÃa', 'AmilÃa', 'AmÃra', 'Amy', 'Amý', 'AnalÃa', 'AnastasÃa', 'Andra', 'Andrá', 'Andrea', 'Anetta', 'Angela', 'AngelÃka', 'Anika', 'Anita', 'AnÃka', 'AnÃna', 'AnÃta', 'Anja', 'Ann', 'Anna', 'Annabella', 'AnnalÃsa', 'Anne', 'AnnelÃ', 'Annetta', 'Anney', 'Annika', 'AnnÃa', 'Anný', 'AntonÃa', 'AprÃl', 'ArdÃs', 'Arey', 'Arinbjörg', 'Aris', 'Arisa', 'ArÃa', 'ArÃanna', 'ArÃella', 'ArÃn', 'ArÃna', 'ArÃs', 'ArmenÃa', 'Arna', 'Arnbjörg', 'Arnborg', 'ArndÃs', 'Arney', 'Arnfinna', 'ArnfrÃður', 'Arngerður', 'Arngunnur', 'Arnheiður', 'Arnhildur', 'Arnika', 'Arnkatla', 'Arnlaug', 'Arnleif', 'ArnlÃn', 'Arnljót', 'Arnóra', 'Arnrós', 'Arnrún', 'Arnþóra', 'Arnþrúður', 'AsÃrÃ', 'Askja', 'Assa', 'Astrid', 'AtalÃa', 'Atena', 'Athena', 'Atla', 'Atlanta', 'Auðbjörg', 'Auðbjört', 'AuðdÃs', 'AuðlÃn', 'Auðna', 'Auðný', 'Auðrún', 'Auður', 'Aurora', 'AxelÃa', 'Axelma', 'Aþena', 'Ãgústa', 'ÃgústÃna', 'ÃlfdÃs', 'Ãlfey', 'Ãlfgerður', 'Ãlfheiður', 'Ãlfhildur', 'Ãlfrós', 'Ãlfrún', 'Ãlfsól', 'Ãrbjörg', 'Ãrbjört', 'ÃrdÃs', 'ÃrelÃa', 'Ãrlaug', 'Ãrmey', 'Ãrna', 'ÃrndÃs', 'Ãrney', 'Ãrnheiður', 'ÃrnÃna', 'Ãrný', 'Ãróra', 'Ãrsól', 'Ãrsæl', 'Ãrún', 'Ãrveig', 'Ãrvök', 'Ãrþóra', 'Ãsa', 'Ãsbjörg', 'Ãsborg', 'ÃsdÃs', 'ÃsfrÃður', 'Ãsgerður', 'Ãshildur', 'Ãskatla', 'Ãsla', 'Ãslaug', 'Ãsleif', 'Ãsný', 'Ãsrós', 'Ãsrún', 'Ãst', 'Ãsta', 'Ãstbjörg', 'Ãstbjört', 'ÃstdÃs', 'ÃstfrÃður', 'Ãstgerður', 'Ãstheiður', 'Ãsthildur', 'ÃstrÃður', 'Ãstrós', 'Ãstrún', 'Ãstveig', 'Ãstþóra', 'Ãstþrúður', 'Ãsvör', 'Baldey', 'Baldrún', 'Baldvina', 'Barbara', 'Barbára', 'BassÃ', 'Bára', 'Bebba', 'Begga', 'Belinda', 'Bella', 'Benedikta', 'Bengta', 'Benidikta', 'BenÃa', 'BenÃta', 'Benna', 'Benney', 'Benný', 'Benta', 'Bentey', 'BentÃna', 'Bera', 'BergdÃs', 'Bergey', 'BergfrÃður', 'Bergheiður', 'Berghildur', 'Berglaug', 'Berglind', 'BerglÃn', 'Bergljót', 'BergmannÃa', 'Bergný', 'Bergrán', 'BergrÃn', 'Bergrós', 'Bergrún', 'Bergþóra', 'Berit', 'BernódÃa', 'Berta', 'Bertha', 'BessÃ', 'Bestla', 'Beta', 'BetanÃa', 'Betsý', 'Bettý', 'Bil', 'Birgit', 'Birgitta', 'Birna', 'Birta', 'Birtna', 'BÃbÃ', 'BÃna', 'BjargdÃs', 'Bjargey', 'Bjargheiður', 'Bjarghildur', 'Bjarglind', 'Bjarkey', 'Bjarklind', 'Bjarma', 'BjarndÃs', 'Bjarney', 'BjarnfrÃður', 'Bjarngerður', 'Bjarnheiður', 'Bjarnhildur', 'Bjarnlaug', 'Bjarnrún', 'Bjarnveig', 'Bjarný', 'Bjarnþóra', 'Bjarnþrúður', 'Bjartey', 'Bjartmey', 'Björg', 'Björgey', 'Björgheiður', 'Björghildur', 'Björk', 'Björney', 'BjörnfrÃður', 'Björt', 'Bláey', 'BlÃða', 'BlÃn', 'Blómey', 'BlædÃs', 'Blær', 'Bobba', 'Boga', 'BogdÃs', 'Bogey', 'Bogga', 'Boghildur', 'Borg', 'BorgdÃs', 'Borghildur', 'Borgný', 'Borgrún', 'Borgþóra', 'BotnÃa', 'Bóel', 'Bót', 'Bóthildur', 'Braga', 'Braghildur', 'BranddÃs', 'Brá', 'Brák', 'Brigitta', 'BrimdÃs', 'Brimhildur', 'Brimrún', 'Brit', 'Britt', 'Britta', 'BrÃana', 'BrÃanna', 'BrÃet', 'BryndÃs', 'BrynfrÃður', 'Bryngerður', 'Brynheiður', 'Brynhildur', 'Brynja', 'Brynný', 'Burkney', 'Bylgja', 'Camilla', 'Carla', 'Carmen', 'Cecilia', 'CecilÃa', 'Charlotta', 'Charlotte', 'Christina', 'Christine', 'Clara', 'Daðey', 'DaðÃna', 'Dagbjörg', 'Dagbjört', 'DagfrÃður', 'Daggrós', 'Dagheiður', 'Dagmar', 'Dagmey', 'Dagný', 'Dagrún', 'DaldÃs', 'Daley', 'DalÃa', 'Dalla', 'Dallilja', 'Dalrós', 'Dana', 'Daney', 'DanfrÃður', 'Danheiður', 'Danhildur', 'DanÃa', 'DanÃela', 'DanÃella', 'Dara', 'Debora', 'Debóra', 'Dendý', 'Didda', 'Dilja', 'Diljá', 'Dimmblá', 'Dimmey', 'DÃa', 'DÃana', 'DÃanna', 'DÃma', 'DÃs', 'DÃsa', 'DÃsella', 'Donna', 'Doris', 'Dorothea', 'Dóa', 'Dómhildur', 'Dóra', 'Dórey', 'Dóris', 'Dórothea', 'Dórótea', 'Dóróthea', 'Drauma', 'Draumey', 'DrÃfa', 'Droplaug', 'Drótt', 'Dröfn', 'Dúa', 'Dúfa', 'Dúna', 'Dýrborg', 'Dýrfinna', 'Dýrleif', 'Dýrley', 'Dýrunn', 'Dæja', 'Dögg', 'Dögun', 'Ebba', 'Ebonney', 'Edda', 'Edel', 'Edil', 'Edit', 'Edith', 'Eðna', 'EfemÃa', 'EgedÃa', 'Eggrún', 'Egla', 'Eiðný', 'Eiðunn', 'Eik', 'Einbjörg', 'EindÃs', 'Einey', 'EinfrÃður', 'Einhildur', 'EinÃna', 'Einrún', 'Eir', 'EirdÃs', 'Eirfinna', 'EirÃka', 'Eirný', 'Eirún', 'Elba', 'Eldbjörg', 'Eldey', 'Eldlilja', 'Eldrún', 'Eleina', 'Elektra', 'Elena', 'Elenborg', 'Elfa', 'Elfur', 'Elina', 'Elinborg', 'Elisabeth', 'ElÃa', 'ElÃana', 'ElÃn', 'ElÃna', 'ElÃná', 'ElÃnbet', 'ElÃnbjörg', 'ElÃnbjört', 'ElÃnborg', 'ElÃndÃs', 'ElÃngunnur', 'ElÃnheiður', 'ElÃnrós', 'ElÃrós', 'ElÃsa', 'ElÃsabet', 'ElÃsabeth', 'Elka', 'Ella', 'Ellen', 'Elley', 'Ellisif', 'EllÃn', 'Elly', 'Ellý', 'Elma', 'Elna', 'Elsa', 'Elsabet', 'Elsie', 'ElsÃ', 'Elsý', 'Elva', 'Elvi', 'ElvÃra', 'Elvý', 'Embla', 'EmelÃa', 'EmelÃana', 'EmelÃna', 'Emeralda', 'EmilÃa', 'EmilÃana', 'EmilÃanna', 'Emilý', 'Emma', 'Emmý', 'Emý', 'Enea', 'Eneka', 'Engilbjört', 'Engilráð', 'Engilrós', 'Engla', 'Enika', 'Enja', 'Enóla', 'Eres', 'Erika', 'Erin', 'Erla', 'Erlen', 'ErlÃn', 'Erna', 'Esja', 'Esmeralda', 'Ester', 'Esther', 'Estiva', 'Ethel', 'Etna', 'EufemÃa', 'Eva', 'Evelyn', 'Evey', 'EvfemÃa', 'EvgenÃa', 'EvÃta', 'EvlalÃa', 'Ey', 'Eybjörg', 'Eybjört', 'EydÃs', 'EyfrÃður', 'Eygerður', 'Eygló', 'Eyhildur', 'Eyja', 'EyjalÃn', 'Eyleif', 'EylÃn', 'Eyrós', 'Eyrún', 'Eyveig', 'Eyvör', 'Eyþóra', 'Eyþrúður', 'FanndÃs', 'Fanney', 'Fannlaug', 'Fanny', 'Fanný', 'Febrún', 'Fema', 'FilipÃa', 'Filippa', 'FilippÃa', 'Finna', 'Finnbjörg', 'Finnbjörk', 'Finnboga', 'Finnborg', 'FinndÃs', 'Finney', 'FinnfrÃður', 'Finnlaug', 'Finnrós', 'FÃa', 'FÃdes', 'FÃfa', 'FjalldÃs', 'Fjóla', 'Flóra', 'Folda', 'Fransiska', 'Franziska', 'Frán', 'Fregn', 'FreydÃs', 'Freygerður', 'Freyja', 'Freylaug', 'Freyleif', 'Friðbjörg', 'Friðbjört', 'Friðborg', 'FriðdÃs', 'Friðdóra', 'Friðey', 'Friðfinna', 'Friðgerður', 'Friðjóna', 'Friðlaug', 'Friðleif', 'FriðlÃn', 'Friðmey', 'Friðný', 'Friðrika', 'Friðrikka', 'Friðrós', 'Friðrún', 'Friðsemd', 'Friðveig', 'Friðþóra', 'Frigg', 'FrÃða', 'FrÃður', 'Frostrós', 'Fróðný', 'Fura', 'Fönn', 'GabrÃela', 'GabrÃella', 'Gauja', 'Gauthildur', 'Gefjun', 'Gefn', 'Geira', 'Geirbjörg', 'GeirdÃs', 'Geirfinna', 'GeirfrÃður', 'Geirhildur', 'Geirlaug', 'Geirlöð', 'Geirný', 'GeirrÃður', 'Geirrún', 'Geirþrúður', 'GeorgÃa', 'Gerða', 'Gerður', 'Gestheiður', 'Gestný', 'Gestrún', 'Gillý', 'Gilslaug', 'Gissunn', 'GÃa', 'GÃgja', 'GÃsela', 'GÃsla', 'GÃsley', 'GÃslÃna', 'GÃslný', 'GÃslrún', 'GÃslunn', 'GÃta', 'Gjaflaug', 'GlorÃa', 'Gló', 'Glóa', 'Glóbjört', 'GlódÃs', 'Glóð', 'Glóey', 'Gná', 'Góa', 'Gógó', 'Grein', 'Gret', 'Greta', 'Grélöð', 'Grét', 'Gréta', 'GrÃma', 'GrÃmey', 'GrÃmheiður', 'GrÃmhildur', 'Gróa', 'Guðbjörg', 'Guðbjört', 'Guðborg', 'GuðdÃs', 'Guðfinna', 'GuðfrÃður', 'Guðjóna', 'Guðlaug', 'Guðleif', 'GuðlÃn', 'Guðmey', 'Guðmunda', 'GuðmundÃna', 'Guðný', 'GuðrÃður', 'Guðrún', 'Guðsteina', 'Guðveig', 'Gullbrá', 'Gullveig', 'Gullý', 'Gumma', 'Gunnbjörg', 'Gunnbjört', 'Gunnborg', 'GunndÃs', 'Gunndóra', 'Gunnella', 'Gunnfinna', 'GunnfrÃður', 'Gunnharða', 'Gunnheiður', 'Gunnhildur', 'Gunnjóna', 'Gunnlaug', 'Gunnleif', 'Gunnlöð', 'Gunnrún', 'Gunnur', 'Gunnveig', 'Gunnvör', 'Gunný', 'Gunnþóra', 'Gunnþórunn', 'Gurrý', 'Gúa', 'Gyða', 'Gyðja', 'GyðrÃður', 'Gytta', 'Gæfa', 'Gæflaug', 'Hadda', 'Haddý', 'Hafbjörg', 'Hafborg', 'HafdÃs', 'Hafey', 'Hafliða', 'HaflÃna', 'Hafný', 'Hafrós', 'Hafrún', 'Hafsteina', 'Hafþóra', 'Halla', 'Hallbera', 'Hallbjörg', 'Hallborg', 'HalldÃs', 'Halldóra', 'Halley', 'HallfrÃður', 'Hallgerður', 'Hallgunnur', 'Hallkatla', 'Hallný', 'Hallrún', 'Hallveig', 'Hallvör', 'Hanna', 'Hanney', 'Hansa', 'HansÃna', 'Harpa', 'Hauður', 'HákonÃa', 'Heba', 'Hedda', 'HedÃ', 'Heiða', 'Heiðbjörg', 'Heiðbjörk', 'Heiðbjört', 'Heiðbrá', 'HeiðdÃs', 'Heiðlaug', 'Heiðlóa', 'Heiðný', 'Heiðrós', 'Heiðrún', 'Heiður', 'Heiðveig', 'Hekla', 'Helen', 'Helena', 'Helga', 'Hella', 'Helma', 'Hendrikka', 'Henný', 'Henrietta', 'Henrika', 'HenrÃetta', 'Hera', 'Herbjörg', 'Herbjört', 'Herborg', 'HerdÃs', 'HerfrÃður', 'Hergerður', 'Herlaug', 'HermÃna', 'HersilÃa', 'Herta', 'Hertha', 'Hervör', 'Herþrúður', 'Hilda', 'Hildegard', 'Hildibjörg', 'Hildigerður', 'Hildigunnur', 'HildirÃður', 'Hildisif', 'Hildur', 'Hilma', 'Himinbjörg', 'Hind', 'Hinrika', 'Hinrikka', 'Hjalta', 'Hjaltey', 'HjálmdÃs', 'Hjálmey', 'HjálmfrÃður', 'Hjálmgerður', 'Hjálmrós', 'Hjálmrún', 'Hjálmveig', 'HjördÃs', 'HjörfrÃður', 'Hjörleif', 'Hjörný', 'HjörtfrÃður', 'Hlaðgerður', 'HlédÃs', 'HlÃf', 'HlÃn', 'Hlökk', 'Hólmbjörg', 'HólmdÃs', 'HólmfrÃður', 'Hrafna', 'Hrafnborg', 'HrafndÃs', 'Hrafney', 'Hrafngerður', 'Hrafnheiður', 'Hrafnhildur', 'Hrafnkatla', 'Hrafnlaug', 'Hrafntinna', 'HraundÃs', 'Hrefna', 'HreindÃs', 'Hróðný', 'HrólfdÃs', 'Hrund', 'Hrönn', 'Hugbjörg', 'Hugbjört', 'Hugborg', 'HugdÃs', 'Hugljúf', 'Hugrún', 'Huld', 'Hulda', 'HuldÃs', 'Huldrún', 'Húnbjörg', 'HúndÃs', 'Húngerður', 'Hvönn', 'Hödd', 'Högna', 'Hörn', 'Ida', 'Idda', 'Iða', 'Iðunn', 'Ilmur', 'Immý', 'Ina', 'Inda', 'India', 'Indiana', 'IndÃa', 'IndÃana', 'IndÃra', 'Indra', 'Inga', 'IngdÃs', 'Ingeborg', 'Inger', 'Ingey', 'Ingheiður', 'Inghildur', 'Ingibjörg', 'Ingibjört', 'Ingiborg', 'Ingifinna', 'IngifrÃður', 'Ingigerður', 'Ingilaug', 'Ingileif', 'IngilÃn', 'IngimarÃa', 'Ingimunda', 'IngirÃður', 'Ingirós', 'Ingisól', 'Ingiveig', 'Ingrid', 'Ingrún', 'Ingunn', 'Ingveldur', 'Inna', 'Irena', 'Irene', 'Irja', 'Irma', 'Irmý', 'Irpa', 'Isabel', 'Isabella', 'Ãda', 'Ãma', 'Ãna', 'Ãr', 'Ãren', 'Ãrena', 'Ãris', 'Ãrunn', 'Ãsabel', 'Ãsabella', 'Ãsadóra', 'Ãsafold', 'Ãsalind', 'Ãsbjörg', 'ÃsdÃs', 'Ãsey', 'Ãsfold', 'Ãsgerður', 'Ãshildur', 'Ãsis', 'Ãslaug', 'Ãsleif', 'Ãsmey', 'Ãsold', 'Ãsól', 'Ãsrún', 'Ãssól', 'Ãsveig', 'Ãunn', 'Ãva', 'JakobÃna', 'Jana', 'Jane', 'Janetta', 'Jannika', 'Jara', 'Jarún', 'Jarþrúður', 'JasmÃn', 'Járnbrá', 'Járngerður', 'Jenetta', 'Jenna', 'Jenný', 'JensÃna', 'Jessý', 'Jovina', 'Jóa', 'Jóanna', 'JódÃs', 'JófrÃður', 'Jóhanna', 'JólÃn', 'Jóna', 'Jónanna', 'JónasÃna', 'Jónbjörg', 'Jónbjört', 'JóndÃs', 'Jóndóra', 'Jóney', 'JónfrÃður', 'Jóngerð', 'Jónheiður', 'Jónhildur', 'Jóninna', 'JónÃda', 'JónÃna', 'Jónný', 'Jóný', 'Jóra', 'JórÃður', 'Jórlaug', 'Jórunn', 'JósebÃna', 'JósefÃn', 'JósefÃna', 'Judith', 'Júdea', 'Júdit', 'JúlÃa', 'JúlÃana', 'JúlÃanna', 'JúlÃetta', 'JúlÃrós', 'JúnÃa', 'JúnÃana', 'Jökla', 'Jökulrós', 'JörgÃna', 'KaðlÃn', 'Kaja', 'Kalla', 'Kamilla', 'KamÃ', 'Kamma', 'Kapitola', 'KapÃtóla', 'Kara', 'Karen', 'Karin', 'Karitas', 'KarÃ', 'KarÃn', 'KarÃna', 'KarÃtas', 'Karla', 'Karlinna', 'KarlÃna', 'Karlotta', 'KarolÃna', 'Karó', 'KarólÃn', 'KarólÃna', 'Kassandra', 'Kata', 'KatarÃna', 'KaterÃna', 'Katharina', 'Kathinka', 'Katinka', 'Katla', 'KatrÃn', 'KatrÃna', 'Katý', 'Kára', 'Kellý', 'Kendra', 'Ketilbjörg', 'KetilfrÃður', 'KetilrÃður', 'Kiddý', 'Kira', 'Kirsten', 'KirstÃn', 'Kittý', 'Kjalvör', 'Klara', 'KládÃa', 'KlementÃna', 'Kleópatra', 'Kolbjörg', 'Kolbrá', 'Kolbrún', 'KoldÃs', 'Kolfinna', 'Kolfreyja', 'KolgrÃma', 'Kolka', 'KonkordÃa', 'Konný', 'Korka', 'Kormlöð', 'KornelÃa', 'Kókó', 'Krista', 'Kristbjörg', 'Kristborg', 'Kristel', 'Kristensa', 'Kristey', 'KristfrÃður', 'Kristgerður', 'Kristin', 'Kristine', 'KristÃana', 'KristÃanna', 'KristÃn', 'KristÃna', 'Kristjana', 'Kristjóna', 'Kristlaug', 'Kristlind', 'KristlÃn', 'Kristný', 'KristólÃna', 'Kristrós', 'Kristrún', 'Kristveig', 'Kristvina', 'Kristþóra', 'KrÃa', 'Kæja', 'Laila', 'LaÃla', 'Lana', 'Lara', 'Laufey', 'Laufheiður', 'Laufhildur', 'Lauga', 'Laugey', 'Laugheiður', 'Lára', 'LárensÃna', 'Láretta', 'Lárey', 'Lea', 'Leikný', 'Leila', 'Lena', 'Leonóra', 'Leóna', 'Leónóra', 'Lilja', 'Liljá', 'Liljurós', 'Lill', 'Lilla', 'Lillian', 'Lillý', 'Lily', 'Lilý', 'Lind', 'Linda', 'LinddÃs', 'Lingný', 'Lisbeth', 'ListalÃn', 'Liv', 'LÃba', 'LÃf', 'LÃfdÃs', 'LÃn', 'LÃna', 'LÃnbjörg', 'LÃndÃs', 'LÃneik', 'LÃney', 'LÃnhildur', 'LÃsa', 'LÃsabet', 'LÃsandra', 'LÃsbet', 'LÃsebet', 'LÃv', 'Ljósbjörg', 'Ljósbrá', 'Ljótunn', 'Lofn', 'Loftveig', 'Logey', 'Lokbrá', 'Lotta', 'Louisa', 'Lousie', 'LovÃsa', 'Lóa', 'Lóreley', 'Lukka', 'LúcÃa', 'LúðvÃka', 'LúÃsa', 'Lúna', 'Lúsinda', 'LúsÃa', 'LúvÃsa', 'Lydia', 'LydÃa', 'Lyngheiður', 'LýdÃa', 'Læla', 'Maddý', 'Magda', 'Magdalena', 'Magðalena', 'Magga', 'Maggey', 'Maggý', 'Magna', 'MagndÃs', 'Magnea', 'Magnes', 'Magney', 'MagnfrÃður', 'Magnheiður', 'Magnhildur', 'MagnúsÃna', 'Magný', 'Magnþóra', 'MaÃa', 'MaÃdÃs', 'MaÃsól', 'Maj', 'Maja', 'Malen', 'Malena', 'MalÃa', 'MalÃn', 'Malla', 'Manda', 'Manúela', 'Mara', 'MardÃs', 'Marela', 'Marella', 'Maren', 'Marey', 'MarfrÃður', 'Margit', 'Margot', 'Margret', 'Margrét', 'Margrjet', 'Margunnur', 'Marheiður', 'Maria', 'Marie', 'Marikó', 'Marinella', 'Marit', 'MarÃ', 'MarÃa', 'MarÃam', 'MarÃan', 'MarÃana', 'MarÃanna', 'MarÃn', 'MarÃna', 'MarÃnella', 'MarÃon', 'MarÃsa', 'MarÃsól', 'MarÃt', 'MarÃuerla', 'Marja', 'Markrún', 'Marlaug', 'Marlena', 'MarlÃn', 'MarlÃs', 'MarólÃna', 'Marsa', 'MarselÃa', 'MarselÃna', 'Marsibil', 'MarsilÃa', 'Marsý', 'Marta', 'Martha', 'MartÃna', 'Mary', 'Marý', 'Matta', 'Mattea', 'Matthea', 'Matthilda', 'Matthildur', 'MatthÃa', 'MattÃana', 'MattÃna', 'Mattý', 'Maxima', 'Mábil', 'MálfrÃður', 'Málhildur', 'MálmfrÃður', 'MánadÃs', 'Máney', 'Mára', 'Meda', 'Mekkin', 'MekkÃn', 'Melinda', 'Melissa', 'Melkorka', 'Melrós', 'MessÃana', 'Metta', 'Mey', 'Mikaela', 'MikaelÃna', 'MikkalÃna', 'Milda', 'MildrÃður', 'Milla', 'Millý', 'Minerva', 'Minna', 'Minney', 'Minný', 'Miriam', 'Mirja', 'Mirjam', 'Mirra', 'Mist', 'MÃa', 'MÃnerva', 'MÃra', 'MÃranda', 'MÃtra', 'Mjaðveig', 'MjalldÃs', 'MjallhvÃt', 'Mjöll', 'Mona', 'Monika', 'MódÃs', 'Móeiður', 'Móey', 'Móheiður', 'Móna', 'Mónika', 'MónÃka', 'Munda', 'Mundheiður', 'Mundhildur', 'MundÃna', 'Myrra', 'Mýr', 'Mýra', 'Mýrún', 'Mörk', 'Nadia', 'NadÃa', 'Nadja', 'Nana', 'Nanna', 'Nanný', 'Nansý', 'NaomÃ', 'NaómÃ', 'Natalie', 'NatalÃa', 'Náttsól', 'Nella', 'Nellý', 'Nenna', 'Nicole', 'Niðbjörg', 'NikÃta', 'Nikoletta', 'NikólÃna', 'Ninja', 'Ninna', 'NÃna', 'NÃnÃ', 'Njála', 'Njóla', 'Norma', 'Nóa', 'Nóra', 'Nótt', 'Nýbjörg', 'Odda', 'Oddbjörg', 'Oddfreyja', 'OddfrÃður', 'Oddgerður', 'Oddhildur', 'Oddlaug', 'Oddleif', 'Oddný', 'Oddrún', 'Oddveig', 'Oddvör', 'OktavÃa', 'OktóvÃa', 'Olga', 'Ollý', 'Ora', 'Orka', 'Ormheiður', 'Ormhildur', 'Otkatla', 'Otta', 'Óda', 'ÓfelÃa', 'Óla', 'ÓlafÃa', 'ÓlafÃna', 'ÓlavÃa', 'ÓlivÃa', 'ÓlÃna', 'Ólöf', 'Ósa', 'Ósk', 'Ótta', 'Pamela', 'ParÃs', 'Patricia', 'PatrisÃa', 'Pála', 'PáldÃs', 'Páley', 'PálfrÃður', 'Pálhanna', 'Pálheiður', 'Pálhildur', 'PálÃn', 'PálÃna', 'Pálmey', 'PálmfrÃður', 'Pálrún', 'Perla', 'Peta', 'Petra', 'Petrea', 'PetrÃna', 'Petronella', 'Petrónella', 'Petrós', 'Petrún', 'Petrúnella', 'PétrÃna', 'Pétrún', 'PÃa', 'Polly', 'Pollý', 'PrÃa', 'Rafney', 'Rafnhildur', 'Ragna', 'Ragnbjörg', 'Ragney', 'RagnfrÃður', 'Ragnheiður', 'Ragnhildur', 'Rakel', 'Ramóna', 'RandalÃn', 'RandÃður', 'Randý', 'Ranka', 'Rannva', 'Rannveig', 'Ráðhildur', 'Rán', 'Rebekka', 'Reginbjörg', 'RegÃna', 'Rein', 'Renata', 'Reyn', 'ReyndÃs', 'Reynheiður', 'Reynhildur', 'Rikka', 'Ripley', 'Rita', 'RÃkey', 'RÃn', 'RÃta', 'Ronja', 'RorÃ', 'Roxanna', 'Róberta', 'Róbjörg', 'Rós', 'Rósa', 'Rósalind', 'Rósanna', 'Rósbjörg', 'Rósborg', 'RóselÃa', 'Rósey', 'RósfrÃður', 'Róshildur', 'Rósinkara', 'Rósinkransa', 'Róska', 'Róslaug', 'Róslind', 'Róslinda', 'RóslÃn', 'Rósmary', 'Rósmarý', 'Rósmunda', 'Rósný', 'Runný', 'Rut', 'Ruth', 'Rúbý', 'Rún', 'Rúna', 'RúndÃs', 'Rúnhildur', 'RúrÃ', 'Röfn', 'Rögn', 'Röskva', 'SabÃna', 'SabrÃna', 'Saga', 'Salbjörg', 'SaldÃs', 'Salgerður', 'SalÃn', 'SalÃna', 'Salka', 'Salma', 'Salný', 'Salome', 'Salóme', 'Salvör', 'Sandra', 'Sanna', 'SantÃa', 'Sara', 'SarÃna', 'SefanÃa', 'Selja', 'Selka', 'Selma', 'SenÃa', 'SeptÃma', 'Sera', 'Serena', 'SeselÃa', 'SesilÃa', 'SesselÃa', 'Sesselja', 'SessilÃa', 'Sif', 'SigdÃs', 'Sigdóra', 'SigfrÃð', 'SigfrÃður', 'Sigga', 'Siggerður', 'Sigmunda', 'Signa', 'Signhildur', 'Signý', 'SigrÃður', 'Sigrún', 'Sigurást', 'Sigurásta', 'Sigurbára', 'Sigurbirna', 'Sigurbjörg', 'Sigurbjört', 'Sigurborg', 'SigurdÃs', 'Sigurdóra', 'SigurdrÃf', 'SigurdrÃfa', 'Sigurða', 'Sigurey', 'Sigurfinna', 'Sigurfljóð', 'Sigurgeira', 'Sigurhanna', 'Sigurhelga', 'Sigurhildur', 'Sigurjóna', 'Sigurlaug', 'Sigurleif', 'Sigurlilja', 'Sigurlinn', 'SigurlÃn', 'SigurlÃna', 'Sigurmunda', 'Sigurnanna', 'Sigurósk', 'Sigurrós', 'Sigursteina', 'Sigurunn', 'Sigurveig', 'Sigurvina', 'Sigurþóra', 'Sigyn', 'Sigþóra', 'Sigþrúður', 'Silfa', 'Silfá', 'Silfrún', 'Silja', 'Silka', 'Silla', 'Silva', 'Silvana', 'SilvÃa', 'Sirra', 'Sirrý', 'Siv', 'SÃa', 'SÃmonÃa', 'SÃsÃ', 'SÃta', 'Sjöfn', 'Skarpheiður', 'Skugga', 'Skuld', 'Skúla', 'SkúlÃna', 'SnjáfrÃður', 'Snjáka', 'SnjófrÃður', 'Snjólaug', 'Snorra', 'Snót', 'Snæbjörg', 'Snæbjört', 'Snæborg', 'Snæbrá', 'SnædÃs', 'SnæfrÃður', 'Snælaug', 'Snærós', 'Snærún', 'SoffÃa', 'Sofie', 'SofÃa', 'Solveig', 'Sonja', 'Sonný', 'Sophia', 'Sophie', 'Sól', 'Sóla', 'Sólbjörg', 'Sólbjört', 'Sólborg', 'Sólbrá', 'Sólbrún', 'SóldÃs', 'Sóldögg', 'Sóley', 'SólfrÃður', 'Sólgerður', 'Sólhildur', 'SólÃn', 'Sólkatla', 'Sóllilja', 'Sólný', 'Sólrós', 'Sólrún', 'Sólveig', 'Sólvör', 'Sónata', 'Stefana', 'StefanÃa', 'Stefánný', 'Steina', 'Steinbjörg', 'Steinborg', 'SteindÃs', 'Steindóra', 'Steiney', 'SteinfrÃður', 'Steingerður', 'Steinhildur', 'Steinlaug', 'Steinrós', 'Steinrún', 'Steinunn', 'Steinvör', 'Steinþóra', 'Stella', 'StÃgheiður', 'StÃgrún', 'StÃna', 'Stjarna', 'Styrgerður', 'SumarlÃna', 'Sumarrós', 'Sunna', 'Sunnefa', 'Sunneva', 'Sunniva', 'SunnÃva', 'Susan', 'Súla', 'Súsan', 'Súsanna', 'Svafa', 'Svala', 'Svalrún', 'Svana', 'Svanbjörg', 'Svanbjört', 'Svanborg', 'SvandÃs', 'Svaney', 'SvanfrÃður', 'Svanheiður', 'Svanhildur', 'SvanhvÃt', 'Svanlaug', 'Svanrós', 'Svanþrúður', 'Svava', 'Svea', 'Sveina', 'Sveinbjörg', 'Sveinborg', 'SveindÃs', 'Sveiney', 'SveinfrÃður', 'Sveingerður', 'Sveinhildur', 'Sveinlaug', 'Sveinrós', 'Sveinrún', 'SveinsÃna', 'Sveinveig', 'Sylgja', 'Sylva', 'SylvÃa', 'Sæbjörg', 'Sæbjört', 'Sæborg', 'SædÃs', 'Sæfinna', 'SæfrÃður', 'Sæhildur', 'Sælaug', 'Sæmunda', 'Sæný', 'Særós', 'Særún', 'Sæsól', 'Sæunn', 'Sævör', 'Sölva', 'Sölvey', 'SölvÃna', 'Tala', 'TalÃa', 'Tamar', 'Tamara', 'TanÃa', 'Tanja', 'Tanya', 'Tanya', 'Tara', 'Tea', 'Teitný', 'Tekla', 'Telma', 'Tera', 'Teresa', 'TeresÃa', 'Thea', 'Thelma', 'Theodóra', 'Theódóra', 'Theresa', 'Tindra', 'Tinna', 'Tirsa', 'TÃa', 'TÃbrá', 'TÃna', 'Todda', 'Torbjörg', 'Torfey', 'Torfheiður', 'Torfhildur', 'Tóbý', 'Tóka', 'Tóta', 'Tristana', 'Trú', 'Tryggva', 'TryggvÃna', 'Týra', 'Ugla', 'Una', 'UndÃna', 'Unna', 'Unnbjörg', 'UnndÃs', 'Unnur', 'Urður', 'Úa', 'Úlfa', 'ÚlfdÃs', 'Úlfey', 'Úlfheiður', 'Úlfhildur', 'Úlfrún', 'Úlla', 'Úna', 'ÚndÃna', 'ÚranÃa', 'Úrsúla', 'Vagna', 'Vagnbjörg', 'VagnfrÃður', 'Vaka', 'Vala', 'Valbjörg', 'Valbjörk', 'Valbjört', 'Valborg', 'Valdheiður', 'ValdÃs', 'ValentÃna', 'ValerÃa', 'Valey', 'ValfrÃður', 'Valgerða', 'Valgerður', 'Valhildur', 'Valka', 'Vallý', 'Valný', 'Valrós', 'Valrún', 'Valva', 'Valý', 'Valþrúður', 'Vanda', 'Vár', 'Veig', 'Veiga', 'Venus', 'Vera', 'Veronika', 'Verónika', 'VerónÃka', 'Vetrarrós', 'Vébjörg', 'VédÃs', 'Végerður', 'Vélaug', 'Véný', 'Vibeka', 'VictorÃa', 'Viðja', 'VigdÃs', 'Vigný', 'Viktoria', 'ViktorÃa', 'Vilborg', 'VildÃs', 'VilfrÃður', 'Vilgerður', 'VilhelmÃna', 'Villa', 'Villimey', 'Vilma', 'Vilný', 'Vinbjörg', 'Vinný', 'Vinsý', 'VirginÃa', 'VÃbekka', 'VÃf', 'VÃgdögg', 'VÃggunnur', 'VÃóla', 'VÃóletta', 'VÃsa', 'Von', 'Von', 'Voney', 'VordÃs', 'Ylfa', 'Ylfur', 'Ylja', 'Ylva', 'Ynja', 'Yrja', 'Yrsa', 'Ãja', 'Ãma', 'Ãr', 'Ãrr', 'ÞalÃa', 'Þeba', 'ÞeódÃs', 'Þeódóra', 'Þjóðbjörg', 'Þjóðhildur', 'Þoka', 'Þorbjörg', 'Þorfinna', 'Þorgerður', 'ÞorgrÃma', 'Þorkatla', 'Þorlaug', 'Þorleif', 'Þorsteina', 'ÞorstÃna', 'Þóra', 'Þóranna', 'Þórarna', 'Þórbjörg', 'ÞórdÃs', 'Þórða', 'Þórelfa', 'Þórelfur', 'Þórey', 'ÞórfrÃður', 'Þórgunna', 'Þórgunnur', 'Þórhalla', 'Þórhanna', 'Þórheiður', 'Þórhildur', 'Þórkatla', 'Þórlaug', 'Þórleif', 'Þórný', 'Þórodda', 'Þórsteina', 'Þórsteinunn', 'ÞórstÃna', 'Þórunn', 'Þórveig', 'Þórvör', 'Þrá', 'Þrúða', 'Þrúður', 'Þula', 'Þura', 'ÞurÃ', 'ÞurÃður', 'Þurý', 'Þúfa', 'Þyri', 'ÞyrÃ', 'Þöll', 'Ægileif', 'Æsa', 'Æsgerður', 'Ögmunda', 'Ögn', 'Ölrún', 'Ölveig', 'Örbrún', 'Örk', 'Ösp');
+
+ /**
+ * @var string Icelandic men names.
+ */
+ protected static $firstNameMale = array('Aage', 'Abel', 'Abraham', 'Adam', 'Addi', 'Adel', 'AdÃel', 'Adólf', 'AdrÃan', 'AdrÃel', 'Aðalberg', 'Aðalbergur', 'Aðalbert', 'Aðalbjörn', 'Aðalborgar', 'Aðalgeir', 'Aðalmundur', 'Aðalráður', 'Aðalsteinn', 'Aðólf', 'Agnar', 'Agni', 'Albert', 'Aldar', 'Alex', 'Alexander', 'AlexÃus', 'Alfons', 'Alfred', 'Alfreð', 'Ali', 'Allan', 'Alli', 'Almar', 'Alrekur', 'Alvar', 'Alvin', 'AmÃr', 'Amos', 'Anders', 'Andreas', 'André', 'Andrés', 'Andri', 'Anes', 'Anfinn', 'Angantýr', 'Angi', 'Annar', 'Annarr', 'Annas', 'Annel', 'Annes', 'Anthony', 'Anton', 'AntonÃus', 'Aran', 'Arent', 'Ares', 'Ari', 'ArilÃus', 'Arinbjörn', 'ArÃel', 'ArÃus', 'Arnald', 'Arnaldur', 'Arnar', 'Arnberg', 'Arnbergur', 'Arnbjörn', 'Arndór', 'Arnes', 'Arnfinnur', 'Arnfreyr', 'Arngeir', 'Arngils', 'ArngrÃmur', 'Arnkell', 'Arnlaugur', 'Arnleifur', 'Arnljótur', 'Arnmóður', 'Arnmundur', 'Arnoddur', 'Arnold', 'Arnór', 'Arnsteinn', 'Arnúlfur', 'Arnviður', 'Arnþór', 'Aron', 'Arthur', 'Arthúr', 'Artúr', 'Asael', 'Askur', 'Aspar', 'Atlas', 'Atli', 'Auðbergur', 'Auðbert', 'Auðbjörn', 'Auðgeir', 'Auðkell', 'Auðmundur', 'Auðólfur', 'Auðun', 'Auðunn', 'Austar', 'Austmann', 'Austmar', 'Austri', 'Axel', 'Ãgúst', 'Ãki', 'Ãlfar', 'Ãlfgeir', 'ÃlfgrÃmur', 'Ãlfur', 'Ãlfþór', 'Ãmundi', 'Ãrbjartur', 'Ãrbjörn', 'ÃrelÃus', 'Ãrgeir', 'Ãrgils', 'Ãrmann', 'Ãrni', 'Ãrsæll', 'Ãs', 'Ãsberg', 'Ãsbergur', 'Ãsbjörn', 'Ãsgautur', 'Ãsgeir', 'Ãsgils', 'ÃsgrÃmur', 'Ãsi', 'Ãskell', 'Ãslaugur', 'Ãslákur', 'Ãsmar', 'Ãsmundur', 'Ãsólfur', 'Ãsröður', 'Ãstbjörn', 'Ãstgeir', 'Ãstmar', 'Ãstmundur', 'Ãstráður', 'ÃstrÃkur', 'Ãstvald', 'Ãstvaldur', 'Ãstvar', 'Ãstvin', 'Ãstþór', 'Ãsvaldur', 'Ãsvarður', 'Ãsþór', 'Baldur', 'Baldvin', 'Baldwin', 'Baltasar', 'Bambi', 'Barði', 'Barri', 'Bassi', 'BastÃan', 'Baugur', 'Bárður', 'Beinir', 'Beinteinn', 'Beitir', 'Bekan', 'Benedikt', 'Benidikt', 'BenjamÃn', 'Benoný', 'BenónÃ', 'Benóný', 'Bent', 'Berent', 'Berg', 'Bergfinnur', 'Berghreinn', 'Bergjón', 'Bergmann', 'Bergmar', 'Bergmundur', 'Bergsteinn', 'Bergsveinn', 'Bergur', 'Bergvin', 'Bergþór', 'Bernhard', 'Bernharð', 'Bernharður', 'Berni', 'Bernódus', 'Bersi', 'Bertel', 'Bertram', 'Bessi', 'Betúel', 'Bill', 'Birgir', 'Birkir', 'Birnir', 'Birtingur', 'Birtir', 'Bjargar', 'Bjargmundur', 'Bjargþór', 'Bjarkan', 'Bjarkar', 'Bjarki', 'Bjarmar', 'Bjarmi', 'Bjarnar', 'Bjarnfinnur', 'Bjarnfreður', 'Bjarnharður', 'Bjarnhéðinn', 'Bjarni', 'Bjarnlaugur', 'Bjarnleifur', 'Bjarnólfur', 'Bjarnsteinn', 'Bjarnþór', 'Bjartmann', 'Bjartmar', 'Bjartur', 'Bjartþór', 'Bjólan', 'Bjólfur', 'Björgmundur', 'Björgólfur', 'Björgúlfur', 'Björgvin', 'Björn', 'Björnólfur', 'Blængur', 'Blær', 'Blævar', 'Boði', 'Bogi', 'Bolli', 'Borgar', 'Borgúlfur', 'Borgþór', 'Bóas', 'Bói', 'Bótólfur', 'Bragi', 'Brandur', 'Breki', 'Bresi', 'Brestir', 'Brimar', 'Brimi', 'Brimir', 'BrÃmi', 'Brjánn', 'Broddi', 'Bruno', 'Bryngeir', 'Brynjar', 'Brynjólfur', 'Brynjúlfur', 'Brynleifur', 'Brynsteinn', 'Bryntýr', 'Brynþór', 'Burkni', 'Búi', 'Búri', 'Bæring', 'Bæringur', 'Bæron', 'Böðvar', 'Börkur', 'Carl', 'Cecil', 'Christian', 'Christopher', 'Cýrus', 'Daði', 'Dagbjartur', 'Dagfari', 'Dagfinnur', 'Daggeir', 'Dagmann', 'Dagnýr', 'Dagur', 'Dagþór', 'Dalbert', 'Dalli', 'Dalmann', 'Dalmar', 'Dalvin', 'Damjan', 'Dan', 'DanelÃus', 'Daniel', 'Danival', 'DanÃel', 'DanÃval', 'Dante', 'DarÃus', 'Darri', 'DavÃð', 'Demus', 'DenÃel', 'Dennis', 'Diðrik', 'DÃómedes', 'Dofri', 'Dolli', 'Dominik', 'Dómald', 'Dómaldi', 'Dómaldur', 'Dónald', 'Dónaldur', 'Dór', 'Dóri', 'Dósóþeus', 'Draupnir', 'Dreki', 'Drengur', 'Dufgus', 'Dufþakur', 'Dugfús', 'Dúi', 'Dúnn', 'Dvalinn', 'Dýri', 'Dýrmundur', 'Ebbi', 'Ebeneser', 'Ebenezer', 'Eberg', 'Edgar', 'Edilon', 'EdÃlon', 'Edvard', 'Edvin', 'Edward', 'Eðvald', 'Eðvar', 'Eðvarð', 'EfraÃm', 'Eggert', 'Eggþór', 'Egill', 'Eiðar', 'Eiður', 'Eikar', 'EilÃfur', 'Einar', 'Einir', 'Einvarður', 'Einþór', 'EirÃkur', 'Eivin', 'Elberg', 'Elbert', 'Eldar', 'EldgrÃmur', 'Eldjárn', 'Eldmar', 'Eldon', 'Eldór', 'Eldur', 'ElentÃnus', 'Elfar', 'Elfráður', 'Elimar', 'Elinór', 'Elis', 'ElÃ', 'ElÃas', 'ElÃeser', 'ElÃmar', 'ElÃnbergur', 'ElÃnmundur', 'ElÃnór', 'ElÃs', 'Ellert', 'Elli', 'Elliði', 'EllÃs', 'Elmar', 'Elvar', 'Elvin', 'Elvis', 'Emanúel', 'Embrek', 'Emerald', 'Emil', 'Emmanúel', 'Engilbert', 'Engilbjartur', 'Engiljón', 'Engill', 'Enok', 'Eric', 'Erik', 'Erlar', 'Erlendur', 'Erling', 'Erlingur', 'Ernestó', 'Ernir', 'Ernst', 'Eron', 'Erpur', 'EsekÃel', 'Esjar', 'Esra', 'Estefan', 'Evald', 'Evan', 'Evert', 'Eyberg', 'Eyjólfur', 'Eylaugur', 'Eyleifur', 'Eymar', 'Eymundur', 'EyrÃkur', 'Eysteinn', 'Eyvar', 'Eyvindur', 'Eyþór', 'FabrisÃus', 'Falgeir', 'Falur', 'Fannar', 'Fannberg', 'Fanngeir', 'Fáfnir', 'Fálki', 'Felix', 'Fengur', 'Fenrir', 'Ferdinand', 'FerdÃnand', 'Fertram', 'Feykir', 'Filip', 'Filippus', 'Finn', 'Finnbjörn', 'Finnbogi', 'Finngeir', 'Finnjón', 'Finnlaugur', 'Finnur', 'Finnvarður', 'FÃfill', 'Fjalar', 'Fjarki', 'Fjólar', 'Fjólmundur', 'Fjölnir', 'Fjölvar', 'Fjörnir', 'Flemming', 'Flosi', 'Flóki', 'Flórent', 'Flóvent', 'Forni', 'Fossmar', 'Fólki', 'Francis', 'Frank', 'FranklÃn', 'Frans', 'Franz', 'Fránn', 'Frár', 'Freybjörn', 'Freygarður', 'Freymar', 'Freymóður', 'Freymundur', 'Freyr', 'Freysteinn', 'Freyviður', 'Freyþór', 'Friðberg', 'Friðbergur', 'Friðbert', 'Friðbjörn', 'Friðfinnur', 'Friðgeir', 'Friðjón', 'Friðlaugur', 'Friðleifur', 'Friðmann', 'Friðmar', 'Friðmundur', 'Friðrik', 'Friðsteinn', 'Friður', 'Friðvin', 'Friðþjófur', 'Friðþór', 'Friedrich', 'Fritz', 'FrÃmann', 'Frosti', 'Fróði', 'Fróðmar', 'Funi', 'Fúsi', 'Fylkir', 'Gabriel', 'GabrÃel', 'Gael', 'Galdur', 'GamalÃel', 'Garðar', 'Garibaldi', 'Garpur', 'Garri', 'Gaui', 'Gaukur', 'Gauti', 'Gautrekur', 'Gautur', 'Gautviður', 'Geir', 'Geirarður', 'Geirfinnur', 'Geirharður', 'Geirhjörtur', 'Geirhvatur', 'Geiri', 'Geirlaugur', 'Geirleifur', 'Geirmundur', 'Geirólfur', 'Geirröður', 'Geirtryggur', 'Geirvaldur', 'Geirþjófur', 'Geisli', 'Gellir', 'Georg', 'Gerald', 'Gerðar', 'Geri', 'Gestur', 'Gilbert', 'Gilmar', 'Gils', 'Gissur', 'Gizur', 'GÃdeon', 'GÃgjar', 'GÃsli', 'Gjúki', 'Glói', 'Glúmur', 'Gneisti', 'Gnúpur', 'Gnýr', 'Goði', 'Goðmundur', 'Gottskálk', 'Gottsveinn', 'Gói', 'Grani', 'Grankell', 'Gregor', 'Greipur', 'Greppur', 'Gretar', 'Grettir', 'Grétar', 'GrÃmar', 'GrÃmkell', 'GrÃmlaugur', 'GrÃmnir', 'GrÃmólfur', 'GrÃmur', 'GrÃmúlfur', 'Guðberg', 'Guðbergur', 'Guðbjarni', 'Guðbjartur', 'Guðbjörn', 'Guðbrandur', 'Guðfinnur', 'Guðfreður', 'Guðgeir', 'Guðjón', 'Guðlaugur', 'Guðleifur', 'Guðleikur', 'Guðmann', 'Guðmar', 'Guðmon', 'Guðmundur', 'Guðni', 'Guðráður', 'Guðröður', 'Guðsteinn', 'Guðvarður', 'Guðveigur', 'Guðvin', 'Guðþór', 'Gumi', 'Gunnar', 'Gunnberg', 'Gunnbjörn', 'Gunndór', 'Gunngeir', 'Gunnhallur', 'Gunnlaugur', 'Gunnleifur', 'Gunnólfur', 'Gunnóli', 'Gunnröður', 'Gunnsteinn', 'Gunnvaldur', 'Gunnþór', 'Gustav', 'Gutti', 'Guttormur', 'Gústaf', 'Gústav', 'Gylfi', 'Gyrðir', 'Gýgjar', 'Gýmir', 'Haddi', 'Haddur', 'Hafberg', 'HafgrÃmur', 'Hafliði', 'Hafnar', 'Hafni', 'Hafsteinn', 'Hafþór', 'HagalÃn', 'Hagbarður', 'Hagbert', 'Haki', 'Hallberg', 'Hallbjörn', 'Halldór', 'Hallfreður', 'Hallgarður', 'Hallgeir', 'Hallgils', 'HallgrÃmur', 'Hallkell', 'Hallmann', 'Hallmar', 'Hallmundur', 'Hallsteinn', 'Hallur', 'Hallvarður', 'Hallþór', 'Hamar', 'Hannes', 'Hannibal', 'Hans', 'Harald', 'Haraldur', 'Harri', 'Harry', 'Harrý', 'Hartmann', 'Hartvig', 'Hauksteinn', 'Haukur', 'Haukvaldur', 'Hákon', 'Háleygur', 'Hálfdan', 'Hálfdán', 'Hámundur', 'Hárekur', 'Hárlaugur', 'Hásteinn', 'Hávar', 'Hávarður', 'Hávarr', 'Hávarr', 'Heiðar', 'Heiðarr', 'Heiðberg', 'Heiðbert', 'Heiðlindur', 'Heiðmann', 'Heiðmar', 'Heiðmundur', 'Heiðrekur', 'Heikir', 'Heilmóður', 'Heimir', 'Heinrekur', 'Heisi', 'Hektor', 'Helgi', 'Helmút', 'Hemmert', 'Hendrik', 'Henning', 'Henrik', 'Henry', 'Henrý', 'Herbert', 'Herbjörn', 'Herfinnur', 'Hergeir', 'Hergill', 'Hergils', 'Herjólfur', 'Herlaugur', 'Herleifur', 'Herluf', 'Hermann', 'Hermóður', 'Hermundur', 'Hersir', 'Hersteinn', 'Hersveinn', 'Hervar', 'Hervarður', 'Hervin', 'Héðinn', 'HilarÃus', 'Hilbert', 'Hildar', 'Hildibergur', 'Hildibrandur', 'Hildigeir', 'Hildiglúmur', 'Hildimar', 'Hildimundur', 'Hildingur', 'Hildir', 'Hildiþór', 'Hilmar', 'Hilmir', 'Himri', 'Hinrik', 'HÃram', 'Hjallkár', 'Hjalti', 'Hjarnar', 'Hjálmar', 'Hjálmgeir', 'Hjálmtýr', 'Hjálmur', 'Hjálmþór', 'Hjörleifur', 'Hjörtur', 'Hjörtþór', 'Hjörvar', 'Hleiðar', 'Hlégestur', 'Hlér', 'Hlini', 'HlÃðar', 'HlÃðberg', 'HlÃfar', 'Hljómur', 'Hlynur', 'Hlöðmundur', 'Hlöður', 'Hlöðvarður', 'Hlöðver', 'Hnefill', 'Hnikar', 'Hnikarr', 'Holgeir', 'Holger', 'Holti', 'Hólm', 'Hólmar', 'Hólmbert', 'Hólmfastur', 'Hólmgeir', 'HólmgrÃmur', 'Hólmkell', 'Hólmsteinn', 'Hólmþór', 'Hóseas', 'Hrafn', 'Hrafnar', 'Hrafnbergur', 'Hrafnkell', 'Hrafntýr', 'Hrannar', 'Hrappur', 'Hraunar', 'Hreggviður', 'Hreiðar', 'Hreiðmar', 'Hreimur', 'Hreinn', 'Hringur', 'HrÃmnir', 'Hrollaugur', 'Hrolleifur', 'Hróaldur', 'Hróar', 'Hróbjartur', 'Hróðgeir', 'Hróðmar', 'Hróðólfur', 'Hróðvar', 'Hrói', 'Hrólfur', 'Hrómundur', 'Hrútur', 'Hrærekur', 'Hugberg', 'Hugi', 'Huginn', 'Hugleikur', 'Hugo', 'Hugó', 'Huldar', 'Huxley', 'Húbert', 'Húgó', 'Húmi', 'Húnbogi', 'Húni', 'Húnn', 'Húnröður', 'Hvannar', 'Hyltir', 'Hylur', 'Hængur', 'Hænir', 'Höður', 'Högni', 'Hörður', 'Höskuldur', 'Illugi', 'Immanúel', 'Indriði', 'Ingberg', 'Ingi', 'Ingiberg', 'Ingibergur', 'Ingibert', 'Ingibjartur', 'Ingibjörn', 'Ingileifur', 'Ingimagn', 'Ingimar', 'Ingimundur', 'Ingivaldur', 'Ingiþór', 'Ingjaldur', 'Ingmar', 'Ingólfur', 'Ingvaldur', 'Ingvar', 'Ingvi', 'Ingþór', 'Ismael', 'Issi', 'Ãan', 'Ãgor', 'Ãmi', 'Ãsak', 'Ãsar', 'Ãsarr', 'Ãsbjörn', 'Ãseldur', 'Ãsgeir', 'Ãsidór', 'Ãsleifur', 'Ãsmael', 'Ãsmar', 'Ãsólfur', 'Ãsrael', 'Ãvan', 'Ãvar', 'Jack', 'Jafet', 'Jaki', 'Jakob', 'Jakop', 'Jamil', 'Jan', 'Janus', 'Jarl', 'Jason', 'JárngrÃmur', 'Játgeir', 'Játmundur', 'Játvarður', 'Jenni', 'Jens', 'JeremÃas', 'Jes', 'Jesper', 'Jochum', 'Johan', 'John', 'Joshua', 'Jóakim', 'Jóann', 'Jóel', 'Jóhann', 'Jóhannes', 'Jói', 'Jómar', 'Jómundur', 'Jón', 'Jónar', 'Jónas', 'Jónatan', 'Jónbjörn', 'Jóndór', 'Jóngeir', 'Jónmundur', 'Jónsteinn', 'Jónþór', 'Jósafat', 'Jósavin', 'Jósef', 'Jósep', 'Jósteinn', 'Jósúa', 'Jóvin', 'Julian', 'JúlÃ', 'JúlÃan', 'JúlÃus', 'JúnÃ', 'JúnÃus', 'Júrek', 'Jökull', 'Jörfi', 'Jörgen', 'Jörmundur', 'Jörri', 'Jörundur', 'Jörvar', 'Jörvi', 'Kaj', 'Kakali', 'Kaktus', 'Kaldi', 'Kaleb', 'Kali', 'Kalman', 'Kalmann', 'Kalmar', 'KaprasÃus', 'Karel', 'Karim', 'Karkur', 'Karl', 'Karles', 'Karli', 'Karvel', 'Kaspar', 'Kasper', 'KastÃel', 'KatarÃnus', 'Kató', 'Kár', 'Kári', 'Keran', 'Ketilbjörn', 'Ketill', 'KilÃan', 'Kiljan', 'Kjalar', 'Kjallakur', 'Kjaran', 'Kjartan', 'Kjarval', 'Kjárr', 'Kjói', 'Klemens', 'Klemenz', 'Klængur', 'Knútur', 'Knörr', 'Koðrán', 'Koggi', 'Kolbeinn', 'Kolbjörn', 'Kolfinnur', 'KolgrÃmur', 'Kolmar', 'Kolskeggur', 'Kolur', 'Kolviður', 'Konráð', 'KonstantÃnus', 'Kormákur', 'KornelÃus', 'Kort', 'Kópur', 'Kraki', 'Kris', 'Kristall', 'Kristberg', 'Kristbergur', 'Kristbjörn', 'Kristdór', 'Kristens', 'Krister', 'Kristfinnur', 'Kristgeir', 'Kristian', 'Kristinn', 'Kristján', 'Kristjón', 'Kristlaugur', 'Kristleifur', 'Kristmann', 'Kristmar', 'Kristmundur', 'Kristofer', 'Kristófer', 'Kristvaldur', 'Kristvarður', 'Kristvin', 'Kristþór', 'Krummi', 'Kveldúlfur', 'Lambert', 'Lars', 'Laufar', 'Laugi', 'Lauritz', 'Lár', 'Lárent', 'LárentÃus', 'Lárus', 'Leiðólfur', 'Leif', 'Leifur', 'Leiknir', 'Leo', 'Leon', 'Leonard', 'Leonhard', 'Leó', 'Leópold', 'LevÃ', 'Lér', 'Liljar', 'Lindar', 'Lindberg', 'LÃnberg', 'LÃni', 'Ljósálfur', 'Ljótur', 'Ljúfur', 'Loðmundur', 'Loftur', 'Logi', 'Loki', 'Lórens', 'Lórenz', 'Ludvig', 'Lundi', 'LúðvÃg', 'LúðvÃk', 'Lúkas', 'Lúter', 'Lúther', 'Lyngar', 'Lýður', 'Lýtingur', 'Maggi', 'Magngeir', 'Magni', 'Magnús', 'Magnþór', 'Makan', 'Manfred', 'Manfreð', 'Manúel', 'Mar', 'Marbjörn', 'Marel', 'Margeir', 'MargrÃmur', 'Mari', 'Marijón', 'Marinó', 'MarÃas', 'MarÃnó', 'MarÃs', 'MarÃus', 'Marjón', 'Markó', 'Markús', 'Markþór', 'Maron', 'Marri', 'Mars', 'MarsellÃus', 'Marteinn', 'Marten', 'Marthen', 'Martin', 'Marvin', 'MathÃas', 'MatthÃas', 'Matti', 'MattÃas', 'Max', 'Maximus', 'Máni', 'Már', 'Márus', 'Mekkinó', 'MelkÃor', 'Melkólmur', 'Melrakki', 'Mensalder', 'Merkúr', 'Methúsalem', 'Metúsalem', 'Meyvant', 'Michael', 'Mikael', 'Mikjáll', 'Mikkael', 'Mikkel', 'Mildinberg', 'MÃas', 'MÃmir', 'MÃó', 'MÃr', 'Mjöllnir', 'Mjölnir', 'Moli', 'Morgan', 'Moritz', 'Mosi', 'Móði', 'Móri', 'Mórits', 'Móses', 'Muggur', 'Muni', 'Muninn', 'Múli', 'Myrkvi', 'Mýrkjartan', 'Mörður', 'Narfi', 'Natan', 'Natanael', 'NatanÃel', 'Náttmörður', 'Náttúlfur', 'Neisti', 'Nenni', 'Neptúnus', 'Nicolas', 'Nikanor', 'Nikolai', 'Nikolas', 'Nikulás', 'Nils', 'NÃels', 'NÃls', 'Njáll', 'Njörður', 'Nonni', 'Norbert', 'Norðmann', 'Normann', 'Nóam', 'Nóel', 'Nói', 'Nóni', 'Nóri', 'Nóvember', 'Númi', 'Nývarð', 'Nökkvi', 'Oddbergur', 'Oddbjörn', 'Oddfreyr', 'Oddgeir', 'Oddi', 'Oddkell', 'Oddleifur', 'Oddmar', 'Oddsteinn', 'Oddur', 'Oddvar', 'Oddþór', 'OktavÃus', 'Októ', 'OktóvÃus', 'Olaf', 'Olav', 'Olgeir', 'Oliver', 'Olivert', 'Orfeus', 'Ormar', 'Ormur', 'Orri', 'Orvar', 'Otkell', 'Otri', 'Otti', 'Ottó', 'Otur', 'Óðinn', 'Ófeigur', 'Ólafur', 'Óli', 'Óliver', 'ÓlÃver', 'Ómar', 'Ómi', 'Óskar', 'Ósvald', 'Ósvaldur', 'ÓsvÃfur', 'Óttar', 'Óttarr', 'Parmes', 'Patrek', 'Patrekur', 'Patrick', 'Patrik', 'Páll', 'Pálmar', 'Pálmi', 'Pedró', 'Per', 'Peter', 'Pétur', 'Pjetur', 'PrÃor', 'Rafael', 'Rafn', 'Rafnar', 'Rafnkell', 'Ragnar', 'Ragúel', 'Randver', 'Rannver', 'Rasmus', 'Ráðgeir', 'Ráðvarður', 'Refur', 'Reginbaldur', 'Reginn', 'Reidar', 'Reifnir', 'Reimar', 'Reinar', 'Reinhart', 'Reinhold', 'Reynald', 'Reynar', 'Reynir', 'Reyr', 'Richard', 'Rikharð', 'Rikharður', 'RÃkarður', 'RÃkharð', 'RÃkharður', 'RÃó', 'Robert', 'Rolf', 'Ronald', 'Róbert', 'Rólant', 'Róman', 'Rómeó', 'Rósant', 'Rósar', 'Rósberg', 'Rósenberg', 'Rósi', 'Rósinberg', 'Rósinkar', 'Rósinkrans', 'Rósmann', 'Rósmundur', 'Rudolf', 'Runi', 'Runólfur', 'Rúbar', 'Rúben', 'Rúdólf', 'Rúnar', 'Rúrik', 'Rútur', 'Röðull', 'Rögnvald', 'Rögnvaldur', 'Rögnvar', 'Rökkvi', 'SafÃr', 'SakarÃas', 'Salmann', 'Salmar', 'Salómon', 'Salvar', 'Samson', 'Samúel', 'Sandel', 'Sandri', 'Sandur', 'Saxi', 'Sebastian', 'SebastÃan', 'Seifur', 'Seimur', 'Sesar', 'Sesil', 'Sigbergur', 'Sigbert', 'Sigbjartur', 'Sigbjörn', 'Sigdór', 'Sigfastur', 'Sigfinnur', 'Sigfreður', 'Sigfús', 'Siggeir', 'Sighvatur', 'Sigjón', 'Siglaugur', 'Sigmann', 'Sigmar', 'Sigmundur', 'Signar', 'Sigri', 'SigrÃkur', 'Sigsteinn', 'Sigtryggur', 'Sigtýr', 'Sigur', 'Sigurbaldur', 'Sigurberg', 'Sigurbergur', 'Sigurbjarni', 'Sigurbjartur', 'Sigurbjörn', 'Sigurbrandur', 'Sigurdór', 'Sigurður', 'Sigurfinnur', 'Sigurgeir', 'Sigurgestur', 'SigurgÃsli', 'SigurgrÃmur', 'Sigurhans', 'Sigurhjörtur', 'Sigurjón', 'Sigurkarl', 'Sigurlaugur', 'Sigurlás', 'Sigurleifur', 'Sigurliði', 'Sigurlinni', 'Sigurmann', 'Sigurmar', 'Sigurmon', 'Sigurmundur', 'Sigurnýas', 'Sigurnýjas', 'Siguroddur', 'Siguróli', 'Sigurpáll', 'Sigursteinn', 'Sigursveinn', 'Sigurvaldi', 'Sigurvin', 'Sigurþór', 'Sigvaldi', 'Sigvarður', 'Sigþór', 'Silli', 'Sindri', 'SÃmon', 'SÃrnir', 'SÃrus', 'SÃvar', 'Sjafnar', 'Skafti', 'Skapti', 'Skarphéðinn', 'Skefill', 'Skeggi', 'SkÃði', 'SkÃrnir', 'Skjöldur', 'Skorri', 'Skuggi', 'Skúli', 'Skúta', 'Skær', 'Skæringur', 'Smári', 'Smiður', 'Smyrill', 'Snjóki', 'Snjólaugur', 'Snjólfur', 'Snorri', 'Snæbjartur', 'Snæbjörn', 'Snæhólm', 'Snælaugur', 'Snær', 'Snæringur', 'Snævar', 'Snævarr', 'Snæþór', 'SoffanÃas', 'SophanÃas', 'Sophus', 'SófónÃas', 'Sófus', 'Sókrates', 'Sólberg', 'Sólbergur', 'Sólbjartur', 'Sólbjörn', 'Sólimann', 'Sólmar', 'Sólmundur', 'Sólon', 'Sólver', 'Sólvin', 'Spartakus', 'Sporði', 'Spói', 'Stanley', 'Stapi', 'Starkaður', 'Starri', 'Stefan', 'Stefán', 'Stefnir', 'Steinar', 'Steinarr', 'Steinberg', 'Steinbergur', 'Steinbjörn', 'Steindór', 'Steinfinnur', 'SteingrÃmur', 'Steini', 'Steinkell', 'Steinmann', 'Steinmar', 'Steinmóður', 'Steinn', 'Steinólfur', 'Steinröður', 'Steinvarður', 'Steinþór', 'Stirnir', 'StÃgur', 'Stormur', 'Stórólfur', 'Sturla', 'Sturlaugur', 'Sturri', 'Styr', 'Styrbjörn', 'Styrkár', 'Styrmir', 'Styrr', 'Sumarliði', 'Svafar', 'Svali', 'Svan', 'Svanberg', 'Svanbergur', 'Svanbjörn', 'Svangeir', 'Svanhólm', 'Svani', 'Svanlaugur', 'Svanmundur', 'Svanur', 'Svanþór', 'Svavar', 'Sváfnir', 'Sveinar', 'Sveinberg', 'Sveinbjartur', 'Sveinbjörn', 'Sveinjón', 'Sveinlaugur', 'Sveinmar', 'Sveinn', 'Sveinungi', 'Sveinþór', 'Svend', 'Sverre', 'Sverrir', 'Svölnir', 'Svörfuður', 'Sýrus', 'Sæberg', 'Sæbergur', 'Sæbjörn', 'Sæi', 'Sælaugur', 'Sæmann', 'Sæmundur', 'Sær', 'Sævald', 'Sævaldur', 'Sævar', 'Sævarr', 'Sævin', 'Sæþór', 'Sölmundur', 'Sölvar', 'Sölvi', 'Sören', 'Sörli', 'Tandri', 'Tarfur', 'Teitur', 'Theodór', 'Theódór', 'Thomas', 'Thor', 'Thorberg', 'Thór', 'Tindar', 'Tindri', 'Tindur', 'Tinni', 'TÃmi', 'TÃmon', 'TÃmoteus', 'TÃmóteus', 'TÃstran', 'Tjaldur', 'Tjörfi', 'Tjörvi', 'TobÃas', 'Tolli', 'Tonni', 'Torfi', 'TóbÃas', 'Tói', 'Tóki', 'Tómas', 'Tór', 'Trausti', 'Tristan', 'Trostan', 'Trúmann', 'Tryggvi', 'Tumas', 'Tumi', 'Tyrfingur', 'Týr', 'Ubbi', 'Uggi', 'Ulrich', 'Uni', 'Unnar', 'Unnbjörn', 'Unndór', 'Unnsteinn', 'Unnþór', 'Urðar', 'Uxi', 'Úddi', 'Úlfar', 'Úlfgeir', 'Úlfhéðinn', 'Úlfkell', 'Úlfljótur', 'Úlftýr', 'Úlfur', 'Úlrik', 'Úranus', 'Vagn', 'Vakur', 'Valberg', 'Valbergur', 'Valbjörn', 'Valbrandur', 'Valdemar', 'Valdi', 'Valdimar', 'Valdór', 'ValentÃn', 'ValentÃnus', 'Valgarð', 'Valgarður', 'Valgeir', 'ValÃant', 'Vallaður', 'Valmar', 'Valmundur', 'Valsteinn', 'Valter', 'Valtýr', 'Valur', 'Valves', 'Valþór', 'Varmar', 'Vatnar', 'Váli', 'Vápni', 'Veigar', 'Veigur', 'Ver', 'Vermundur', 'Vernharð', 'Vernharður', 'Vestar', 'Vestmar', 'Veturliði', 'Vébjörn', 'Végeir', 'Vékell', 'Vélaugur', 'Vémundur', 'Vésteinn', 'Victor', 'Viðar', 'Vigfús', 'Viggó', 'Vignir', 'Vigri', 'Vigtýr', 'Vigur', 'Vikar', 'Viktor', 'Vilberg', 'Vilbergur', 'Vilbert', 'Vilbjörn', 'Vilbogi', 'Vilbrandur', 'Vilgeir', 'Vilhelm', 'Vilhjálmur', 'Vili', 'Viljar', 'Vilji', 'Villi', 'Vilmar', 'Vilmundur', 'Vincent', 'Vinjar', 'Virgill', 'VÃðar', 'VÃðir', 'VÃfill', 'VÃglundur', 'VÃgmar', 'VÃgmundur', 'VÃgsteinn', 'VÃgþór', 'VÃkingur', 'Vopni', 'Vorm', 'Vöggur', 'Völundur', 'Vörður', 'Vöttur', 'Walter', 'Werner', 'Wilhelm', 'Willard', 'William', 'Willum', 'Ylur', 'Ymir', 'Yngvar', 'Yngvi', 'Yrkill', 'Ãmir', 'Ãrar', 'ZakarÃa', 'ZakarÃas', 'ZophanÃas', 'ZophonÃas', 'ZóphanÃas', 'ZóphonÃas', 'Þangbrandur', 'Þengill', 'Þeyr', 'Þiðrandi', 'Þiðrik', 'Þinur', 'Þjálfi', 'Þjóðann', 'Þjóðbjörn', 'Þjóðgeir', 'Þjóðleifur', 'Þjóðmar', 'Þjóðólfur', 'Þjóðrekur', 'Þjóðvarður', 'Þjóstar', 'Þjóstólfur', 'Þorberg', 'Þorbergur', 'Þorbjörn', 'Þorbrandur', 'Þorfinnur', 'Þorgarður', 'Þorgautur', 'Þorgeir', 'Þorgestur', 'Þorgils', 'ÞorgÃsl', 'Þorgnýr', 'ÞorgrÃmur', 'Þorkell', 'Þorlaugur', 'Þorlákur', 'Þorleifur', 'Þorleikur', 'Þormar', 'Þormóður', 'Þormundur', 'Þorri', 'Þorsteinn', 'Þorvaldur', 'Þorvar', 'Þorvarður', 'Þór', 'Þórar', 'Þórarinn', 'Þórbergur', 'Þórbjörn', 'Þórður', 'Þórgnýr', 'ÞórgrÃmur', 'Þórhaddur', 'Þórhalli', 'Þórhallur', 'Þórir', 'Þórlaugur', 'Þórleifur', 'Þórlindur', 'Þórmar', 'Þórmundur', 'Þóroddur', 'Þórormur', 'Þórólfur', 'Þórsteinn', 'Þórörn', 'Þrastar', 'Þráinn', 'Þrándur', 'Þróttur', 'Þrúðmar', 'Þrymur', 'Þröstur', 'Þyrnir', 'Ægir', 'Æsir', 'Ævar', 'Ævarr', 'Ögmundur', 'Ögri', 'Ölnir', 'Ölver', 'Ölvir', 'Öndólfur', 'Önundur', 'Örlaugur', 'Örlygur', 'Örn', 'Örnólfur', 'Örvar', 'Össur', 'Öxar');
+
+ /**
+ * @var string Icelandic middle names.
+ */
+ protected static $middleName = array(
+ 'Aðaldal', 'Aldan', 'Arnberg', 'Arnfjörð', 'Austan', 'Austdal', 'Austfjörð', 'Ãss', 'Bakkdal', 'Bakkmann', 'Bald', 'Ben', 'Bergholt', 'Bergland', 'BÃldsfells', 'Bjarg', 'Bjarndal', 'Bjarnfjörð', 'Bláfeld', 'Blómkvist', 'Borgdal', 'Brekkmann', 'Brim', 'Brúnsteð', 'Dalhoff', 'Dan', 'Diljan', 'Ektavon', 'Eldberg', 'ElÃsberg', 'Elvan', 'EspólÃn', 'EyhlÃð', 'EyvÃk', 'Falk', 'Finndal', 'Fossberg', 'Freydal', 'Friðhólm', 'Giljan', 'Gilsfjörð', 'Gnarr', 'Gnurr', 'Grendal', 'GrindvÃk', 'Gull', 'Haffjörð', 'Hafnes', 'Hafnfjörð', 'Har', 'Heimdal', 'Heimsberg', 'Helgfell', 'Herberg', 'Hildiberg', 'Hjaltdal', 'HlÃðkvist', 'Hnappdal', 'HnÃfsdal', 'Hofland', 'Hofteig', 'Hornfjörð', 'Hólmberg', 'Hrafnan', 'Hrafndal', 'Hraunberg', 'Hreinberg', 'Hreindal', 'Hrútfjörð', 'Hvammdal', 'HvÃtfeld', 'Höfðdal', 'Hörðdal', 'Ãshólm', 'Júl', 'Kjarrval', 'Knaran', 'Knarran', 'Krossdal', 'Laufkvist', 'Laufland', 'Laugdal', 'Laxfoss', 'Liljan', 'Linddal', 'LÃnberg', 'Ljós', 'Loðmfjörð', 'Lyngberg', 'Magdal', 'Magg', 'Matt', 'Miðdal', 'MiðvÃk', 'Mjófjörð', 'Móberg', 'Mýrmann', 'Nesmann', 'Norðland', 'Núpdal', 'Ólfjörð', 'Ósland', 'Ósmann', 'Reginbald', 'Reykfell', 'Reykfjörð', 'Reynholt', 'Salberg', 'Sandhólm', 'Seljan', 'Sigurhólm', 'SkagalÃn', 'SkÃðdal', 'Snæberg', 'Snædahl', 'Sólan', 'Stardal', 'Stein', 'Steinbekk', 'Steinberg', 'Storm', 'Straumberg', 'Svanhild', 'Svarfdal', 'Sædal', 'Val', 'Valagils', 'Vald', 'Varmdal', 'Vatnsfjörð', 'Vattar', 'Vattnes', 'Viðfjörð', 'VÃdalÃn', 'VÃking', 'Vopnfjörð', 'Yngling', 'Þor', 'Önfjörð', 'Örbekk', 'Öxdal', 'Öxndal'
+ );
+
+ /**
+ * Randomly return a icelandic middle name.
+ *
+ * @return string
+ */
+ public static function middleName()
+ {
+ return static::randomElement(static::$middleName);
+ }
+
+ /**
+ * Generate prepared last name for further processing
+ *
+ * @return string
+ */
+ public function lastName()
+ {
+ $name = static::firstNameMale();
+
+ if (substr($name, -2) === 'ur') {
+ $name = substr($name, 0, strlen($name) - 2);
+ }
+
+ if (substr($name, -1) !== 's') {
+ $name .= 's';
+ }
+
+ return $name;
+ }
+
+ /**
+ * Randomly return a icelandic last name for woman.
+ *
+ * @return string
+ */
+ public function lastNameMale()
+ {
+ return $this->lastName().'son';
+ }
+
+ /**
+ * Randomly return a icelandic last name for man.
+ *
+ * @return string
+ */
+ public function lastNameFemale()
+ {
+ return $this->lastName().'dóttir';
+ }
+
+ /**
+ * Randomly return a icelandic Kennitala (Social Security number) format.
+ *
+ * @link http://en.wikipedia.org/wiki/Kennitala
+ *
+ * @return string
+ */
+ public static function ssn()
+ {
+ // random birth date
+ $birthdate = new \DateTime('@' . mt_rand(0, time()));
+
+ // last four buffer
+ $lastFour = null;
+
+ // security variable reference
+ $ref = '32765432';
+
+ // valid flag
+ $valid = false;
+
+ while (! $valid) {
+ // make two random numbers
+ $rand = static::randomDigit().static::randomDigit();
+
+ // 8 char string with birth date and two random numbers
+ $tmp = $birthdate->format('dmy').$rand;
+
+ // loop through temp string
+ for ($i = 7, $sum = 0; $i >= 0; $i--) {
+ // calculate security variable
+ $sum += ($tmp[$i] * $ref[$i]);
+ }
+
+ // subtract 11 if not 11
+ $chk = ($sum % 11 === 0) ? 0 : (11 - ($sum % 11));
+
+ if ($chk < 10) {
+ $lastFour = $rand.$chk.substr($birthdate->format('Y'), 1, 1);
+
+ $valid = true;
+ }
+ }
+
+ return sprintf('%s-%s', $birthdate->format('dmy'), $lastFour);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/PhoneNumber.php
new file mode 100644
index 000000000..de91f7428
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/is_IS/PhoneNumber.php
@@ -0,0 +1,20 @@
+
+ */
+class PhoneNumber extends \Faker\Provider\PhoneNumber
+{
+ /**
+ * @var array Icelandic phone number formats.
+ */
+ protected static $formats = array(
+ '+354 ### ####',
+ '+354 #######',
+ '+354#######',
+ '### ####',
+ '#######',
+ );
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Address.php
new file mode 100644
index 000000000..1eee3b6de
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Address.php
@@ -0,0 +1,139 @@
+ 'Argovia'),
+ array('AI' => 'Appenzello Interno'),
+ array('AR' => 'Appenzello Esterno'),
+ array('BE' => 'Berna'),
+ array('BL' => 'Basilea Campagna'),
+ array('BS' => 'Basilea Città '),
+ array('FR' => 'Friburgo'),
+ array('GE' => 'Ginevra'),
+ array('GL' => 'Glarona'),
+ array('GR' => 'Grigioni'),
+ array('JU' => 'Giura'),
+ array('LU' => 'Lucerna'),
+ array('NE' => 'Neuchâtel'),
+ array('NW' => 'Nidvaldo'),
+ array('OW' => 'Obvaldo'),
+ array('SG' => 'San Gallo'),
+ array('SH' => 'Sciaffusa'),
+ array('SO' => 'Soletta'),
+ array('SZ' => 'Svitto'),
+ array('TG' => 'Turgovia'),
+ array('TI' => 'Ticino'),
+ array('UR' => 'Uri'),
+ array('VD' => 'Vaud'),
+ array('VS' => 'Vallese'),
+ array('ZG' => 'Zugo'),
+ array('ZH' => 'Zurigo')
+ );
+
+ protected static $cityFormats = array(
+ '{{cityName}}',
+ );
+
+ protected static $streetNameFormats = array(
+ '{{streetSuffix}} {{firstName}}',
+ '{{streetSuffix}} {{lastName}}'
+ );
+
+ protected static $streetAddressFormats = array(
+ '{{streetName}} {{buildingNumber}}',
+ );
+ protected static $addressFormats = array(
+ "{{streetAddress}}\n{{postcode}} {{city}}",
+ );
+
+ /**
+ * Returns a random street prefix
+ * @example Via
+ * @return string
+ */
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ /**
+ * Returns a random city name.
+ * @example Luzern
+ * @return string
+ */
+ public function cityName()
+ {
+ return static::randomElement(static::$cityNames);
+ }
+
+ /**
+ * Returns a canton
+ * @example array('BE' => 'Bern')
+ * @return array
+ */
+ public static function canton()
+ {
+ return static::randomElement(static::$canton);
+ }
+
+ /**
+ * Returns the abbreviation of a canton.
+ * @return string
+ */
+ public static function cantonShort()
+ {
+ $canton = static::canton();
+ return key($canton);
+ }
+
+ /**
+ * Returns the name of canton.
+ * @return string
+ */
+ public static function cantonName()
+ {
+ $canton = static::canton();
+ return current($canton);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Company.php
new file mode 100644
index 000000000..9a42b1c3f
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/it_CH/Company.php
@@ -0,0 +1,15 @@
+generator->parse($format);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Company.php
new file mode 100644
index 000000000..937f375f2
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Company.php
@@ -0,0 +1,17 @@
+generator->parse($format));
+ }
+
+ /**
+ * @example 'yamada.jp'
+ */
+ public function domainName()
+ {
+ return static::randomElement(static::$lastNameAscii) . '.' . $this->tld();
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Person.php b/vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Person.php
new file mode 100644
index 000000000..0db2db0bb
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/Person.php
@@ -0,0 +1,141 @@
+generator->parse($format);
+ }
+
+ /**
+ * @param string|null $gender 'male', 'female' or null for any
+ * @return string
+ * @example 'ã‚¢ã‚ラ'
+ */
+ public function firstKanaName($gender = null)
+ {
+ if ($gender === static::GENDER_MALE) {
+ return static::firstKanaNameMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return static::firstKanaNameFemale();
+ }
+
+ return $this->generator->parse(static::randomElement(static::$firstKanaNameFormat));
+ }
+
+ /**
+ * @example 'ã‚¢ã‚ラ'
+ */
+ public static function firstKanaNameMale()
+ {
+ return static::randomElement(static::$firstKanaNameMale);
+ }
+
+ /**
+ * @example 'アケミ'
+ */
+ public static function firstKanaNameFemale()
+ {
+ return static::randomElement(static::$firstKanaNameFemale);
+ }
+
+ /**
+ * @example 'アオタ'
+ */
+ public static function lastKanaName()
+ {
+ return static::randomElement(static::$lastKanaName);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/PhoneNumber.php
new file mode 100644
index 000000000..9f03c565c
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ja_JP/PhoneNumber.php
@@ -0,0 +1,19 @@
+generator->parse($format);
+ }
+
+ public static function companyPrefix()
+ {
+ return static::randomElement(static::$companyPrefixes);
+ }
+
+ public static function companyNameElement()
+ {
+ return static::randomElement(static::$companyElements);
+ }
+
+ public static function companyNameSuffix()
+ {
+ return static::randomElement(static::$companyNameSuffixes);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/DateTime.php b/vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/DateTime.php
new file mode 100644
index 000000000..1a1a4dd41
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/DateTime.php
@@ -0,0 +1,42 @@
+ 'კვირáƒ',
+ 'Monday' => 'áƒáƒ შáƒáƒ‘áƒáƒ—ი',
+ 'Tuesday' => 'სáƒáƒ›áƒ¨áƒáƒ‘áƒáƒ—ი',
+ 'Wednesday' => 'áƒáƒ—ხშáƒáƒ‘áƒáƒ—ი',
+ 'Thursday' => 'ხუთშáƒáƒ‘áƒáƒ—ი',
+ 'Friday' => 'პáƒáƒ áƒáƒ¡áƒ™áƒ”ვი',
+ 'Saturday' => 'შáƒáƒ‘áƒáƒ—ი',
+ );
+ $week = static::dateTime($max)->format('l');
+ return isset($map[$week]) ? $map[$week] : $week;
+ }
+
+ public static function monthName($max = 'now')
+ {
+ $map = array(
+ 'January' => 'იáƒáƒœáƒ•áƒáƒ ი',
+ 'February' => 'თებერვáƒáƒšáƒ˜',
+ 'March' => 'მáƒáƒ ტი',
+ 'April' => 'áƒáƒžáƒ ილი',
+ 'May' => 'მáƒáƒ˜áƒ¡áƒ˜',
+ 'June' => 'ივნისი',
+ 'July' => 'ივლისი',
+ 'August' => 'áƒáƒ’ვისტáƒ',
+ 'September' => 'სექტემბერი',
+ 'October' => 'áƒáƒ¥áƒ¢áƒáƒ›áƒ‘ერი',
+ 'November' => 'ნáƒáƒ”მბერი',
+ 'December' => 'დეკემბერი',
+ );
+ $month = static::dateTime($max)->format('F');
+ return isset($map[$month]) ? $map[$month] : $month;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/Internet.php
new file mode 100644
index 000000000..01b15c773
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ka_GE/Internet.php
@@ -0,0 +1,15 @@
+generator->parse($format);
+ }
+
+ public static function companyPrefix()
+ {
+ return static::randomElement(static::$companyPrefixes);
+ }
+
+ public static function companyNameElement()
+ {
+ return static::randomElement(static::$companyElements);
+ }
+
+ public static function companyNameSuffix()
+ {
+ return static::randomElement(static::$companyNameSuffixes);
+ }
+
+ /**
+ * National Business Identification Numbers
+ *
+ * @link http://egov.kz/wps/portal/Content?contentPath=%2Fegovcontent%2Fbus_business%2Ffor_businessmen%2Farticle%2Fbusiness_identification_number&lang=en
+ * @param \DateTime $registrationDate
+ * @return string 12 digits, like 150140000019
+ */
+ public static function businessIdentificationNumber(\DateTime $registrationDate = null)
+ {
+ if (!$registrationDate) {
+ $registrationDate = \Faker\Provider\DateTime::dateTimeThisYear();
+ }
+
+ $dateAsString = $registrationDate->format('ym');
+ $legalEntityType = (string) static::numberBetween(4, 6);
+ $legalEntityAdditionalType = (string) static::numberBetween(0, 3);
+ $randomDigits = (string) static::numerify('######');
+
+ return $dateAsString . $legalEntityType . $legalEntityAdditionalType . $randomDigits;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/Internet.php
new file mode 100644
index 000000000..75999c2e8
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/Internet.php
@@ -0,0 +1,9 @@
+ array(
+ self::CENTURY_19TH => self::MALE_CENTURY_19TH,
+ self::CENTURY_20TH => self::MALE_CENTURY_20TH,
+ self::CENTURY_21ST => self::MALE_CENTURY_21ST,
+ ),
+ self::GENDER_FEMALE => array(
+ self::CENTURY_19TH => self::FEMALE_CENTURY_19TH,
+ self::CENTURY_20TH => self::FEMALE_CENTURY_20TH,
+ self::CENTURY_21ST => self::FEMALE_CENTURY_21ST,
+ ),
+ );
+
+ /**
+ * @see https://ru.wikipedia.org/wiki/%D0%9A%D0%B0%D0%B7%D0%B0%D1%85%D1%81%D0%BA%D0%B0%D1%8F_%D1%84%D0%B0%D0%BC%D0%B8%D0%BB%D0%B8%D1%8F
+ *
+ * @var array
+ */
+ protected static $maleNameFormats = array(
+ '{{lastName}}ұлы {{firstNameMale}}',
+ );
+
+ /**
+ * @see https://ru.wikipedia.org/wiki/%D0%9A%D0%B0%D0%B7%D0%B0%D1%85%D1%81%D0%BA%D0%B0%D1%8F_%D1%84%D0%B0%D0%BC%D0%B8%D0%BB%D0%B8%D1%8F
+ *
+ * @var array
+ */
+ protected static $femaleNameFormats = array(
+ '{{lastName}}қызы {{firstNameFemale}}',
+ );
+
+ /**
+ * @see http://koshpendi.kz/index.php/nomad/imena/
+ *
+ * @var array
+ */
+ protected static $firstNameMale = array(
+ 'Ðылғазы',
+ 'Әбдіқадыр',
+ 'Бабағожа',
+ 'ҒайÑа',
+ 'Дәмен',
+ 'Егізбек',
+ 'Жазылбек',
+ 'Зұлпықар',
+ 'ИгіÑін',
+ 'Кәдіржан',
+ 'Қадырқан',
+ 'Латиф',
+ 'Мағаз',
+ 'Ðармағамбет',
+ 'Оңалбай',
+ 'ӨндіріÑ',
+ 'Пердебек',
+ 'Рақат',
+ 'Сағындық',
+ 'Танабай',
+ 'УайыÑ',
+ 'Ұйықбай',
+ 'Үрімбай',
+ 'Файзрахман',
+ 'Хангелді',
+ 'Шаттық',
+ 'ЫÑтамбақы',
+ 'Ібни',
+ );
+
+ /**
+ * @see http://koshpendi.kz/index.php/nomad/imena/
+ *
+ * @var array
+ */
+ protected static $firstNameFemale = array(
+ 'ÐÑылтаÑ',
+ 'Әужа',
+ 'Бүлдіршін',
+ 'Гүлшаш',
+ 'Ғафура',
+ 'Ділдә',
+ 'Еркежан',
+ 'Жібек',
+ 'Зылиқа',
+ 'Ирада',
+ 'КүнÑұлу',
+ 'Қырмызы',
+ 'Ләтипа',
+ 'Мүштәри',
+ 'Ðұршара',
+ 'Орынша',
+ 'ӨрзиÑ',
+ 'Перизат',
+ 'РухиÑ',
+ 'Сындыбала',
+ 'ТұрÑынай',
+ 'УәÑима',
+ 'ҰрқиÑ',
+ 'ҮриÑ',
+ 'Фируза',
+ 'Хафиза',
+ 'Шырынгүл',
+ 'ЫрыÑты',
+ 'Іңкәр',
+ );
+
+ /**
+ * @see http://koshpendi.kz/index.php/nomad/imena/
+ * @see https://ru.wikipedia.org/wiki/%D0%9A%D0%B0%D0%B7%D0%B0%D1%85%D1%81%D0%BA%D0%B0%D1%8F_%D1%84%D0%B0%D0%BC%D0%B8%D0%BB%D0%B8%D1%8F
+ *
+ * @var array
+ */
+ protected static $lastName = array(
+ 'Ðдырбай',
+ 'Әжібай',
+ 'Байбөрі',
+ 'Ғизат',
+ 'Ділдабек',
+ 'Ешмұхамбет',
+ 'Жігер',
+ 'ЗікіриÑ',
+ 'ИÑа',
+ 'Кунту',
+ 'Қыдыр',
+ 'Лұқпан',
+ 'Мышырбай',
+ 'ÐÑ‹Ñынбай',
+ 'Ошақбай',
+ 'Өтетілеу',
+ 'Пірәлі',
+ 'Ð Ò¯Ñтем',
+ 'Сырмұхамбет',
+ 'ТілеміÑ',
+ 'Уәлі',
+ 'Ұлықбек',
+ 'Ò®Ñтем',
+ 'Фахир',
+ 'Ð¥Ò±Ñайын',
+ 'Шілдебай',
+ 'ЫÑтамбақы',
+ 'ІÑмет',
+ );
+
+ /**
+ * @param integer $year
+ *
+ * @return integer|null
+ */
+ private static function getCenturyByYear($year)
+ {
+ if ($year >= 2000 && $year <= DateTime::year()) {
+ return self::CENTURY_21ST;
+ } elseif ($year >= 1900) {
+ return self::CENTURY_20TH;
+ } elseif ($year >= 1800) {
+ return self::CENTURY_19TH;
+ }
+ }
+
+ /**
+ * National Individual Identification Numbers
+ *
+ * @link http://egov.kz/wps/portal/Content?contentPath=%2Fegovcontent%2Fcitizen_migration%2Fpassport_id_card%2Farticle%2Fiin_info&lang=en
+ * @link https://ru.wikipedia.org/wiki/%D0%98%D0%BD%D0%B4%D0%B8%D0%B2%D0%B8%D0%B4%D1%83%D0%B0%D0%BB%D1%8C%D0%BD%D1%8B%D0%B9_%D0%B8%D0%B4%D0%B5%D0%BD%D1%82%D0%B8%D1%84%D0%B8%D0%BA%D0%B0%D1%86%D0%B8%D0%BE%D0%BD%D0%BD%D1%8B%D0%B9_%D0%BD%D0%BE%D0%BC%D0%B5%D1%80
+ *
+ * @param \DateTime $birthDate
+ * @param integer $gender
+ *
+ * @return string 12 digits, like 780322300455
+ */
+ public static function individualIdentificationNumber(\DateTime $birthDate = null, $gender = self::GENDER_MALE)
+ {
+ if (!$birthDate) {
+ $birthDate = DateTime::dateTimeBetween();
+ }
+
+ do {
+ $population = mt_rand(1000, 2000);
+ $century = self::getCenturyByYear((int) $birthDate->format('Y'));
+
+ $iin = $birthDate->format('ymd');
+ $iin .= (string) self::$genderCenturyMap[$gender][$century];
+ $iin .= (string) $population;
+ $checksum = self::checkSum($iin);
+ } while ($checksum === 10);
+
+ return $iin . (string) $checksum;
+ }
+
+ /**
+ * @param string $iinValue
+ *
+ * @return integer
+ */
+ public static function checkSum($iinValue)
+ {
+ $controlDigit = self::getControlDigit($iinValue, self::$firstSequenceBitWeights);
+
+ if ($controlDigit === 10) {
+ return self::getControlDigit($iinValue, self::$secondSequenceBitWeights);
+ }
+
+ return $controlDigit;
+ }
+
+ /**
+ * @param string $iinValue
+ * @param array $sequence
+ *
+ * @return integer
+ */
+ protected static function getControlDigit($iinValue, $sequence)
+ {
+ $sum = 0;
+
+ for ($i = 0; $i <= 10; $i++) {
+ $sum += (int) $iinValue[$i] * $sequence[$i];
+ }
+
+ return $sum % 11;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/PhoneNumber.php
new file mode 100644
index 000000000..edb38dd5f
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/kk_KZ/PhoneNumber.php
@@ -0,0 +1,16 @@
+generator->parse($format));
+ }
+
+ /**
+ * @example 'kim.kr'
+ */
+ public function domainName()
+ {
+ return static::randomElement(static::$lastNameAscii) . '.' . $this->tld();
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Person.php b/vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Person.php
new file mode 100644
index 000000000..92d858f54
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Person.php
@@ -0,0 +1,55 @@
+generator->parse($format));
+ }
+
+
+
+ public function cellPhoneNumber()
+ {
+ $format = self::randomElement(array_slice(static::$formats, 6, 1));
+
+ return self::numerify($this->generator->parse($format));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Text.php b/vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Text.php
new file mode 100644
index 000000000..5f5148e5e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ko_KR/Text.php
@@ -0,0 +1,1723 @@
+ì— ë‚˜ì˜¤ëŠ” ìš”ê·€ì˜ ë¶ˆë¹› 모양으로 í‘¸ë¥´ë¬´ë ˆ 하게 í—ˆê³µì„ ë¹„ì¶”ì˜¤. ë™ê²½ì˜ 불바다는 ë‚´ 마ìŒì„ ë”ìš± ìŒì¹¨í•˜ê²Œ 하였소.
+ì´ ë•Œì— ë’¤ì—서,
+"모시모시(여보세요)."
+하는 소리가 ë“¤ë ¸ì†Œ. ê·¸ê²ƒì€ í° ì €ê³ ë¦¬ë¥¼ ìž…ì€ í˜¸í…” ë³´ì´ì˜€ì†Œ.
+"왜?"
+í•˜ê³ ë‚˜ëŠ” ê³ ê°œë§Œ ëŒë ¸ì†Œ.
+"ì†ë‹˜ì´ 오셨습니다."
+"ì†ë‹˜?"
+í•˜ê³ ë‚˜ëŠ” ë³´ì´ì—게로 한 ê±¸ìŒ ê°€ê¹Œì´ ê°”ì†Œ. 나를 ì°¾ì„ ì†ë‹˜ì´ ì–´ë”” 있나 í•˜ê³ ë‚˜ëŠ” 놀란 것ì´ì˜¤.
+"따님께서 오셨습니다. 방으로 모셨습니다."
+í•˜ê³ ë³´ì´ëŠ” 들어가 ë²„ë¦¬ê³ ë§ì•˜ì†Œ.
+"따님?"
+í•˜ê³ ë‚˜ëŠ” ë”ìš± 놀ëžì†Œ. 순임ì´ê°€ 서울서 나를 ë”°ë¼ì™”나? ê·¸ê²ƒì€ ì•ˆ ë ë§ì´ì˜¤. 순임ì´ê°€ ë‚´ 뒤를 ë”°ë¼ ë– ë‚¬ë”ë¼ë„ 아무리 빨리 ì™€ë„ ë‚´ì¼ì´ 아니면 못 ì™”ì„ ê²ƒì´ì˜¤. 그러면 누군가. ì •ìž„ì¸ê°€. ì •ìž„ì´ê°€ 병ì›ì—서 뛰어온 것ì¸ê°€.
+나는 ë‘근거리는 ê°€ìŠ´ì„ ì–µì§€ë¡œ ì§„ì •í•˜ë©´ì„œ ë‚´ ë°©ë¬¸ì„ ì—´ì—ˆì†Œ.
+ê·¸ê²ƒì€ ì •ìž„ì´ì—ˆì†Œ. ì •ìž„ì€ ë‚´ê°€ 쓰다가 ë‘” 편지를 ë³´ê³ ìžˆë‹¤ê°€ 벌떡 ì¼ì–´ë‚˜ 내게 ë‹¬ë ¤ë“¤ì–´ 안겨 ë²„ë ¸ì†Œ. 나는 ì–¼ë¹ ì§„ ë“¯ì´ ì •ìž„ì´ê°€ 하ë¼ëŠ” 대로 ë‚´ë²„ë ¤ë‘었소. ê·¸ 편지는 ë¶€ì¹˜ë ¤ê³ ì“´ ê²ƒë„ ì•„ë‹Œë° ê·¸ 편지를 ì •ìž„ì´ê°€ 본 ê²ƒì´ ì•ˆë˜ì—ˆë‹¤ê³ ìƒê°í•˜ì˜€ì†Œ.
+형! 나를 ì±…ë§í•˜ì‹œì˜¤. 심히 ë¶€ë„러운 ë§ì´ì§€ë§ˆëŠ” 나는 ì •ìž„ì„ íž˜ê» ê»´ì•ˆì•„ ì£¼ê³ ì‹¶ì—ˆì†Œ. 나는 몇 번ì´ë‚˜ ì •ìž„ì˜ ë“±ì„ êµ½ì–´ 보면서 ë‚´ íŒ”ì— íž˜ì„ ë„£ìœ¼ë ¤ê³ í•˜ì˜€ì†Œ. ì •ìž„ì€ ì‹¬ížˆ ê·€ì—¬ì› ì†Œ. ì •ìž„ì´ê°€ 그처럼 나를 사모하는 ê²ƒì´ ì‹¬ížˆ 기뻤소. 나는 ê°ì •ì´ ìž¬ìš°ì³ì„œ ëˆˆì´ ì•ˆ ë³´ì´ê³ ì •ì‹ ì´ ëª½ë¡±í•˜ì—¬ì§ì„ 깨달았소. 나는 ì•„í”„ê³ ì“°ë¦° 듯한 기ì¨ì„ 깨달았소. ì˜ì–´ë¡œ 엑스터시ë¼ë“ ì§€, 한문으로 ë¬´ì•„ì˜ ê²½ì§€ëž€ ì´ëŸ° ê²ƒì´ ì•„ë‹Œê°€ 하였소. 나는 ì‚¬ì‹ í‰ìƒì— ì´ëŸ¬í•œ ê²½í—˜ì„ ì²˜ìŒ í•œ 것ì´ì˜¤.
+형! í˜•ì´ ì•„ì‹œë‹¤ì‹œí”¼ 나는 ë‚´ ì•„ë‚´ ì´ì™¸ì— ì Šì€ ì—¬ì„±ì—게 ì´ë ‡ê²Œ 안겨 본 ì¼ì´ 없소. ë¬¼ë¡ ì•ˆì•„ 본 ì¼ë„ 없소.
+그러나 형! 나는 나를 ëˆŒë €ì†Œ. ë‚´ 타오르는 ì• ìš•ì„ ì°¨ë””ì°¬ ì´ì§€ì˜ 입김으로 불어서 ë„ë ¤ê³ ì• ë¥¼ ì¼ì†Œ.
+"글쎄 웬ì¼ì´ëƒ. 앓는 ê²ƒì´ ì´ ë°¤ì¤‘ì— ë¹„ë¥¼ ë§žê³ ì™œ 나온단 ë§ì´ëƒ. ì² ì—†ëŠ” 것 같으니."
+í•˜ê³ ë‚˜ëŠ” ì•„ë²„ì§€ì˜ ìœ„ì—„ìœ¼ë¡œ ì •ìž„ì˜ ë‘ ì–´ê¹¨ë¥¼ 붙들어 ì•”ì²´ì–´ì— ì•‰í˜”ì†Œ. ê·¸ë¦¬ê³ ë‚˜ë„ í…Œì´ë¸”ì„ í•˜ë‚˜ 세워 ë‘ê³ ë§žì€íŽ¸ì— ì•‰ì•˜ì†Œ.
+ì •ìž„ì€ ë¶€ë„러운 ë“¯ì´ ë‘ ì†ìœ¼ë¡œ ë‚¯ì„ ê°€ë¦¬ìš°ê³ ì œ ë¬´ë¦Žì— ì—Žë“œë ¤ 울기를 시작하오.
+ì •ìž„ì€ ëˆ„ëŸ° ê°ˆìƒ‰ì˜ ì™¸íˆ¬ë¥¼ 입었소. ë¬´ì—‡ì„ íƒ€ê³ ì™”ëŠ”ì§€ 모르지마는 구ë‘ì—는 꽤 ë§Žì´ ë¬¼ì´ ë¬»ê³ ëª¨ìžì—는 빗방울 ì–¼ë£©ì´ ë³´ì´ì˜¤.
+"네가 ì´ëŸ¬ë‹¤ê°€ 다시 ë³‘ì´ ë”치면 어찌한단 ë§ì´ëƒ. ì•„ì´ê°€ 왜 ê·¸ë ‡ê²Œ ì² ì´ ì—†ë‹ˆ?"
+í•˜ê³ ë‚˜ëŠ” ë”ìš± ëƒ‰ì •í•œ 어조로 ì±…ë§í•˜ê³ ë°ìŠ¤í¬ ìœ„ì— ë†“ì¸ ë‚´ 편지 초를 ì§‘ì–´ ë°•ë°• 찢어 ë²„ë ¸ì†Œ. ì¢…ì´ ì°¢ëŠ” ì†Œë¦¬ì— ì •ìž„ì€ ìž ê¹ ê³ ê°œë¥¼ 들어서 처ìŒì—는 ë‚´ ì†ì„ ë³´ê³ ë‹¤ìŒì—는 ë‚´ ì–¼êµ´ì„ ë³´ì•˜ì†Œ. 그러나 나는 모르는 ì²´í•˜ê³ ë„로 êµì˜ì— ëŒì•„와 앉아서 가만히 ëˆˆì„ ê°ì•˜ì†Œ. ê·¸ë¦¬ê³ ë„무지 í¥ë¶„ë˜ì§€ 아니한 ëª¨ì–‘ì„ ê¾¸ëª„ì†Œ.
+형! 어떻게나 힘드는 ì¼ì´ì˜¤? 참으면 ì°¸ì„ìˆ˜ë¡ ë‚´ ì´ë¹¨ì´ 마주 ë¶€ë”ªê³ , ì–¼êµ´ì˜ ê·¼ìœ¡ì€ ì”°ë£©ê±°ë¦¬ê³ ì†ì€ 불ëˆë¶ˆëˆ ì¥ì–´ì§€ì˜¤.
+"ì •ë§ ë‚´ì¼ ê°€ì„¸ìš”?"
+í•˜ê³ ì•„ë§ˆ 오 ë¶„ ë™ì•ˆì´ë‚˜ ì¹¨ë¬µì„ ì§€í‚¤ë‹¤ê°€ ì •ìž„ì´ê°€ ê³ ê°œë¥¼ ë“¤ê³ ë¬¼ì—ˆì†Œ.
+"그럼, 가야지."
+í•˜ê³ ë‚˜ëŠ” ë¹™ê·¸ë ˆ 웃어 보였소.
+"ì €ë„ ë°ë¦¬ê³ 가세요!"
+하는 ì •ìž„ì˜ ë§ì€ 마치 ì„œë¦¿ë°œì´ ë‚ ë¦¬ëŠ” ì¹¼ë‚ ê³¼ 같았소. 나는 ê¹œì§ ë†€ë¼ì„œ ì •ìž„ì„ ë°”ë¼ë³´ì•˜ì†Œ. ê·¸ì˜ ëˆˆì€ ë¹›ë‚˜ê³ ìž…ì€ ê¼ ë‹¤ë¬¼ê³ ì–¼êµ´ì˜ ê·¼ìœ¡ì€ íŒ½íŒ½í•˜ê²Œ 켕겼소. ì •ìž„ì˜ ì–¼êµ´ì—는 ì°¬ë°”ëžŒì´ ë„는 무서운 ê¸°ìš´ì´ ìžˆì—ˆì†Œ.
+나는 즉ê°ì 으로 죽기를 결심한 ì—¬ìžì˜ 모양ì´ë¼ê³ ìƒê°í•˜ì˜€ì†Œ. ì—´ì •ìœ¼ë¡œ 불ë©ì–´ë¦¬ê°€ ë˜ì—ˆë˜ ì •ìž„ì€ ë‚´ê°€ ë³´ì´ëŠ” 냉ëží•œ 태ë„로 ë§ë¯¸ì•”ì•„ ê°‘ìžê¸° 얼어 버린 것 같았소.
+"어디를?"
+í•˜ê³ ë‚˜ëŠ” ì •ìž„ì˜ `ì €ë„ ë°ë¦¬ê³ 가세요.' 하는 담대한 ë§ì— 놀ë¼ë©´ì„œ 물었소.
+"ì–´ë””ë“ ì§€, 아버지 가시는 ë°ë©´ ì–´ë””ë“ ì§€ ì €ë¥¼ ë°ë¦¬ê³ 가세요. ì €ëŠ” 아버지를 ë– ë‚˜ì„œëŠ” 혼ìžì„œëŠ” 못 ì‚´ ê²ƒì„ ì§€ë‚˜ê°„ ë°˜ 달 ë™ì•ˆì— 잘 알았습니다. 아까 아버지 오셨다 ê°€ì‹ ë’¤ì— ìƒê°í•´ ë³´ë‹ˆê¹ ì•”ë§Œí•´ë„ ì•„ë²„ì§€ëŠ” 다시 ì €ì—게 와 보시지 ì•„ë‹ˆí•˜ê³ ê°€ì‹¤ 것만 ê°™ì• ìš”. ê·¸ë¦¬ê³ ì €ë¡œ 해서 아버지께서는 무슨 í° íƒ€ê²©ì„ ë‹¹í•˜ì‹ ê²ƒë§Œ 같으셔요. ì²˜ìŒ ëµˆì˜¬ ì ì— ë²Œì¨ ê°€ìŠ´ì´ ëœ¨ë”했습니다. ê·¸ë¦¬ê³ ì—¬í–‰ì„ ë– ë‚˜ì‹ ë‹¤ëŠ” ë§ì”€ì„ ë“£ê³ ëŠ” 반드시 무슨 í°ì¼ì´ 나셨ëŠë‹ˆë¼ê³ ë§Œ ìƒê°í–ˆìŠµë‹ˆë‹¤. ê·¸ë¦¬ê³ ì €ì–´, ì €ë¡œ 해서 ê·¸ëŸ¬ì‹ ê²ƒë§Œ ê°™ê³ , ì €ë¥¼ ë²„ë¦¬ì‹œê³ í˜¼ìž ê°€ì‹œë ¤ëŠ” 것만 ê°™ê³ , 그래서 ë‹¬ë ¤ì™”ë”니 여기 ì¨ ë†“ìœ¼ì‹ íŽ¸ì§€ë¥¼ ë³´ê³ ê·¸ íŽ¸ì§€ì— ë‹¤ë¥¸ ë§ì”€ì€ ì–´ì°Œ ëë“ ì§€, 네 ì¼ê¸°ë¥¼ 보았다 í•˜ì‹ ë§ì”€ì„ ë³´ê³ ëŠ” 다 알았습니다. ì €ì™€ 한 ë°©ì— ìžˆëŠ” ì• ê°€ ì•”ë§Œí•´ë„ ì–´ë¨¸ë‹ˆ 스파ì¸ê°€ë´ìš”. ì œê°€ ìž…ì›í•˜ê¸° ì „ì—ë„ ì œ 눈치를 슬슬 ë³´ê³ ë˜ ì±…ìƒ ì„œëžë„ 뒤지는 눈치가 ë³´ì´ê¸¸ëž˜ ì¼ê¸°ì±…ì€ ëŠ˜ ì‡ ìž ê·¸ëŠ” 서ëžì— 넣어 ë‘ì—ˆëŠ”ë° ì•„ë§ˆ ì œê°€ ì •ì‹ ì—†ì´ ì•“ê³ ëˆ„ì› ëŠ” ë™ì•ˆì— ì œ 핸드백ì—서 쇳대를 í›”ì³ ê°”ë˜ê°€ë´ìš”. 그래서는 ê·¸ ì¼ê¸°ì±…ì„ êº¼ë‚´ì„œ 서울로 보냈나ë´ìš”. 그걸루 해서 아버지께서는 불명예스러운 ëˆ„ëª…ì„ ì“°ì‹œê³ í•™êµì¼ë„ 내놓으시게 ë˜ê³ ì§‘ë„ ë– ë‚˜ì‹œê²Œ ë˜ì…¨ë‚˜ë´ìš”. 다시는 ì§‘ì— ì•ˆ ëŒì•„오실 양으로 ê²°ì‹¬ì„ í•˜ì…¨ë‚˜ë´ìš”. 아까 병ì›ì—ì„œë„ í•˜ì‹œëŠ” ë§ì”€ì´ ëª¨ë‘ ìœ ì–¸í•˜ì‹œëŠ” 것만 같아서 í½ ì˜ì‹¬ì„ ê°€ì¡Œì—ˆëŠ”ë° ì§€ê¸ˆ ê·¸ ì“°ì‹œë˜ íŽ¸ì§€ë¥¼ ë³´ê³ ëŠ” 다 알았습니다. ê·¸ë ‡ì§€ë§Œ ê·¸ë ‡ì§€ë§Œ."
+í•˜ê³ ì›…ë³€ìœ¼ë¡œ ë‚´ë ¤ ë§í•˜ë˜ ì •ìž„ì€ ê°‘ìžê¸° 복받치는 ì—´ì •ì„ ì´ê¸°ì§€ 못하는 듯ì´, 한 번 í•œìˆ¨ì„ ì§€ìš°ê³ ,
+"ê·¸ë ‡ì§€ë§Œ ì €ëŠ” 아버지를 ë”°ë¼ê°€ìš”. ì ˆë£¨ 해서 아버지께서는 ì§‘ë„ ìžƒìœ¼ì‹œê³ ëª…ì˜ˆë„ ìžƒìœ¼ì‹œê³ ì‚¬ì—…ë„ ìžƒìœ¼ì‹œê³ ì¸ìƒì˜ ëª¨ë“ ê²ƒì„ ë‹¤ 잃으셨으니 ì €ëŠ” 아버지를 ë”°ë¼ê°€ìš”. 어디를 ê°€ì‹œë“ ì§€ ì €ëŠ” 어린 딸로 아버지를 ë”°ë¼ë‹¤ë‹ˆë‹¤ê°€ 아버지께서 ë¨¼ì € ëŒì•„가시면 ì €ë„ ë”°ë¼ ì£½ì–´ì„œ 아버지 ë°œ ë°‘ì— ë¬»íž í…Œì•¼ìš”. ì œê°€ ë¨¼ì € ì£½ê±°ë“ ì œê°€ ë³‘ì´ ìžˆìœ¼ë‹ˆê¹ ë¬¼ë¡ ì œê°€ ë¨¼ì € 죽지요. ì£½ì–´ë„ ì¢‹ìŠµë‹ˆë‹¤. 병ì›ì—서 앓다가 í˜¼ìž ì£½ëŠ” ê±´ ì‹«ì–´ìš”. 아버지 ê³ì—서 죽으면 아버지께서, 오 ë‚´ 딸 ì •ìž„ì•„ í•˜ì‹œê³ ê·€í•´ ì£¼ì‹œê³ ë¶ˆìŒížˆ 여겨 ì£¼ì‹œê² ì§€ìš”. ê·¸ë¦¬ê³ ì œ ëª¸ì„ ì–´ë””ë“ ì§€ ë•…ì— ë¬»ìœ¼ì‹œê³ `사랑하는 ë‚´ 딸 ì •ìž„ì˜ ë¬´ë¤'ì´ë¼ê³ 패ë¼ë„ ì†ìˆ˜ 쓰셔서 세워 주시지 ì•Šê² ìŠµë‹ˆê¹Œ."
+í•˜ê³ ì •ìž„ì€ ë¹„ì‰ë¹„ì‰í•˜ë‹¤ê°€ 그만 무릎 ìœ„ì— ì—Žë”ì ¸ ìš¸ê³ ë§ˆì˜¤.
+나는 다만 ì£½ì€ ì‚¬ëžŒ 모양으로 반쯤 ëˆˆì„ ê°ê³ 앉아 있었소. 가슴 ì†ì—는 ì •ìž„ì˜ ê³ì—서 지지 않는 ì—´ì •ì„ í’ˆìœ¼ë©´ì„œë„ ì •ìž„ì˜ ë§ëŒ€ë¡œ ì •ìž„ì„ ë°ë¦¬ê³ ì•„ë¬´ë„ ëª¨ë¥´ëŠ” 곳으로 ê°€ ë²„ë¦¬ê³ ì‹¶ìœ¼ë©´ì„œë„ ë‚˜ëŠ” ì´ ì—´ì •ì˜ ë¶ˆê¸¸ì„ ë‚´ 입김으로 꺼 버리지 아니하면 아니 ë˜ëŠ” 것ì´ì—ˆì†Œ.
+"ì•„ì•„, ì œê°€ 왜 났어요? 왜 하나님께서 ì €ë¥¼ 세ìƒì— 보내셨어요? ì•„ë²„ì§€ì˜ ì¼ìƒì„ íŒŒë©¸ì‹œí‚¤ë ¤ 난 것ì´ì§€ìš”? ì œê°€ 지금 죽어 ë²„ë ¤ì„œ ì•„ë²„ì§€ì˜ ëª…ì˜ˆë¥¼ íšŒë³µí• ìˆ˜ 있다면 ì €ëŠ” 죽어 버릴 í„°ì´ì•¼ìš”. 기ì˜ê²Œ 죽어 ë²„ë¦¬ê² ìŠµë‹ˆë‹¤. ì œê°€ ì—¬ëŸ ì‚´ë¶€í„° ì˜¤ëŠ˜ë‚ ê¹Œì§€ ë°›ì€ ì€í˜œë¥¼ ì œ 목숨 하나로 ê°šì„ ìˆ˜ê°€ 있다면 ì €ëŠ” 지금으로 죽어 ë²„ë¦¬ê² ìŠµë‹ˆë‹¤. ê·¸ë ‡ì§€ë§Œ ê·¸ë ‡ì§€ë§Œâ€¦â€¦.
+ê·¸ë ‡ì§€ë§Œ ê·¸ë ‡ì§€ë§Œ ì €ëŠ” 다만 얼마ë¼ë„ 다만 하루ë¼ë„ 아버지 ê³ì—서 ì‚´ê³ ì‹¶ì–´ìš” 다만 하루만ì´ë¼ë„, 아버지! ì œê°€ 왜 ì´ë ‡ìŠµë‹ˆê¹Œ, 네? ì œê°€ ì–´ë ¤ì„œ ì´ë ‡ìŠµë‹ˆê¹Œ. 미친 ë…„ì´ ë˜ì–´ì„œ ì´ë ‡ìŠµë‹ˆê¹Œ. 아버지께서는 아실 테니 ë§ì”€í•´ 주세요. 하루만ì´ë¼ë„ 아버지를 ëª¨ì‹œê³ ì•„ë²„ì§€ ê³ì—서 살았으면 ì£½ì–´ë„ í•œì´ ì—†ê² ìŠµë‹ˆë‹¤. ì œ ìƒê°ì´ 잘못ì´ì•¼ìš”? ì œ ìƒê°ì´ 죄야요? 왜 죄입니까? 아버지, ì €ë¥¼ ë²„ë¦¬ì‹œê³ í˜¼ìž ê°€ì‹œì§€ 마세요, 네? `ì •ìž„ì•„, 너를 ë°ë¦¬ê³ 가마.' í•˜ê³ ì•½ì†í•´ 주세요, 네."
+ì •ìž„ì€ ì•„ì£¼ 담대하게 ì œê°€ í•˜ê³ ìž í•˜ëŠ” ë§ì„ 다 하오. ê·¸ ì–Œì „í•œ, ìˆ˜ì‚½í•œì •ìž„ì˜ ì†ì— ì–´ë”” 그러한 용기가 있었ë˜ê°€, ì°¸ ì´ìƒí•œ ì¼ì´ì˜¤. 나는 귀여운 어린 ê³„ì§‘ì• ì •ìž„ì˜ ì†ì— ì—‰í¼í•œ ì—¬ìžê°€ ë“¤ì–´ì•‰ì€ ê²ƒì„ ë°œê²¬í•˜ì˜€ì†Œ. 그가 몇 가지 재료(ë‚´ê°€ ì—¬í–‰ì„ ë– ë‚œë‹¤ëŠ” 것과 ì œ ì¼ê¸°ë¥¼ 보았다는 것)를 종합하여 나와 ì €ì™€ì˜ ìƒˆì—, ë˜ ê·¸ ë•Œë¬¸ì— ì–´ë– í•œ ì¼ì´ ì¼ì–´ë‚œ ê²ƒì„ ì¶”ì¸¡í•˜ëŠ” ê·¸ ìƒìƒë ¥ë„ 놀ëžê±°ë‹ˆì™€ ê·¸ë ‡ê²Œ ë‚´ 앞ì—서는 별로 ìž…ë„ ë²Œë¦¬ì§€ ì•„ë‹ˆí•˜ë˜ ê·¸ê°€ ì´ì²˜ëŸ¼ 담대하게 ì œ ì†ì— 있는 ë§ì„ ê±°ë¦¬ë‚Œì—†ì´ ë‹¤ í•´ 버리는 용기를 아니 놀랄 수 없었소. ë‚´ê°€, 사내요 ì–´ë¥¸ì¸ ë‚´ê°€ ë„리어 ì •ìž„ì—게 리드를 ë°›ê³ ë†€ë¦¼ì„ ë°›ìŒì„ 깨달았소.
+그러나 ì •ìž„ì„ ìœ„í•´ì„œë“ ì§€, 중년 남ìžì˜ ìœ„ì‹ ì„ ìœ„í•´ì„œë“ ì§€ 나는 ì˜ì§€ë ¥ìœ¼ë¡œ, ë„ë•ë ¥ìœ¼ë¡œ, ì •ìž„ì„ ëˆ„ë¥´ê³ í›ˆê³„í•˜ì§€ 아니하면 아니 ë˜ê² ë‹¤ê³ ìƒê°í•˜ì˜€ì†Œ.
+"ì •ìž„ì•„."
+í•˜ê³ ë‚˜ëŠ” 비로소 ìž…ì„ ì—´ì–´ì„œ ë¶ˆë €ì†Œ. ë‚´ ì–´ì„±ì€ ìž¥ì¤‘í•˜ì˜€ì†Œ. 나는 í• ìˆ˜ 있는 ìœ„ì—„ì„ ë‹¤í•˜ì—¬ `ì •ìž„ì•„.' í•˜ê³ ë¶€ë¥¸ 것ì´ì˜¤.
+"ì •ìž„ì•„, 네 ì†ì€ 다 알았다. 네 ë§ˆìŒ ë„¤ ëœ»ì€ ê·¸ë§Œí•˜ë©´ 다 알았다. 네가 나를 그처럼 ìƒê°í•´ 주는 ê²ƒì„ ê³ ë§™ê²Œ ìƒê°í•œë‹¤. 기ì˜ê²Œë„ ìƒê°í•œë‹¤. 그러나 ì •ìž„ì•„."
+í•˜ê³ ë‚˜ëŠ” ì¼ì¸µ 태ë„와 소리를 엄숙하게 하여,
+"네가 ì²í•˜ëŠ” ë§ì€ ì ˆëŒ€ë¡œ ë“¤ì„ ìˆ˜ 없는 ë§ì´ë‹¤. ë‚´ê°€ 너를 ì¹œë”¸ê°™ì´ ì‚¬ëž‘í•˜ê¸° ë•Œë¬¸ì— ë‚˜ëŠ” 너를 ë°ë¦¬ê³ 가지 못하는 것ì´ë‹¤. 나는 세ìƒì—서 ì£½ê³ ì¡°ì„ ì—서 죽ë”ë¼ë„ 너는 죽어서 아니 ëœë‹¤. 차마 너까지는 죽ì´ê³ ì‹¶ì§€ 아니하단 ë§ì´ë‹¤. ë‚´ê°€ ì–´ë”” 가서 ì—†ì–´ì ¸ 버리면 세ìƒì€ 네게 씌운 ëˆ„ëª…ì´ ì• ë§¤í•œ ì¤„ì„ ì•Œê²Œ ë ê²ƒì´ ì•„ë‹ˆëƒ. 그리ë˜ë©´ 너는 ì¡°ì„ ì˜ ì¢‹ì€ ì¼ê¾¼ì´ ë˜ì–´ì„œ ì¼ë„ ë§Žì´ í•˜ê³ ë˜ ì‚¬ëž‘í•˜ëŠ” ë‚¨íŽ¸ì„ ë§žì•„ì„œ í–‰ë³µëœ ìƒí™œë„ í• ìˆ˜ ìžˆì„ ê²ƒì´ ì•„ë‹ˆëƒ. ê·¸ê²ƒì´ ë‚´ê°€ 네게 ë°”ë¼ëŠ” 것ì´ë‹¤. ë‚´ê°€ ì–´ë”” ê°€ ìžˆë“ ì§€, ë‚´ê°€ ì‚´ì•„ 있는 ë™ì•ˆ 나는 네가 잘ë˜ëŠ” 것만, 행복ë˜ê²Œ 사는 것만 ë°”ë¼ë³´ê³ í˜¼ìž ê¸°ë»í• ê²ƒì´ ì•„ë‹ˆëƒ.
+네가 다 옳게 알았다. 나는 네 ë§ëŒ€ë¡œ ì¡°ì„ ì„ ì˜ì›ížˆ ë– ë‚˜ê¸°ë¡œ 하였다. ê·¸ë ‡ì§€ë§ˆëŠ” 나는 ì´ë ‡ê²Œ ëœ ê²ƒì„ ì¡°ê¸ˆë„ ìŠ¬í¼í•˜ì§€ 아니한다. 너를 위해서 ë‚´ê°€ 무슨 í¬ìƒì„ í•œë‹¤ê³ í•˜ë©´ 내게는 ê·¸ê²ƒì´ í° ê¸°ì¨ì´ë‹¤. ê·¸ë¿ ì•„ë‹ˆë¼, 나는 ì¸ì œëŠ” 세ìƒì´ 싫어졌다. ë” ì‚´ê¸°ê°€ 싫어졌다. ë‚´ê°€ ì‹ì—¬ ë…„ ë™ì•ˆ ì „ìƒëª…ì„ ë°”ì³ì„œ êµìœ¡í•œ í•™ìƒë“¤ì—게까지 ë°°ì²™ì„ ë°›ì„ ë•Œì—는 나는 지금까지 살아온 ê²ƒì„ ìƒê°ë§Œ í•˜ì—¬ë„ ì§„ì €ë¦¬ê°€ 난다. ê·¸ë ‡ì§€ë§ˆëŠ” 나는 ì´ê²ƒì´ 다 ë‚´ê°€ 부족한 ë•Œë¬¸ì¸ ì¤„ì„ ìž˜ 안다. 나는 ì¡°ì„ ì„ ì›ë§í•œë‹¤ë“ ê°€, ë‚´ ë™í¬ë¥¼ ì›ë§í•œë‹¤ë“ ê°€, 그럴 ìƒê°ì€ 없다. ì›ë§ì„ 한다면 나 ìžì‹ ì˜ ë¶€ì¡±ì„ ì›ë§í• ë¿ì´ë‹¤. ë‚´ê°€ ì›ì²´ êµìœ¡ì„ í•œë‹¤ë“ ì§€ ë‚¨ì˜ ì§€ë„ìžê°€ ëœë‹¤ë“ ì§€ í• ìžê²©ì´ ì—†ìŒì„ ì›ë§í•œë‹¤ë©´ ì›ë§í• 까, ë‚´ê°€ 어떻게 ì¡°ì„ ì´ë‚˜ ì¡°ì„ ì‚¬ëžŒì„ ì›ë§í•˜ëŠëƒ. 그러니까 ì¸ì œ 내게 ë‚¨ì€ ì¼ì€ 나를 ì¡°ì„ ì—서 ì—†ì• ë²„ë¦¬ëŠ” 것ì´ë‹¤. ê°ížˆ ì‹ì—¬ ë…„ ê°„ êµìœ¡ê°€ë¼ê³ ìžì²˜í•´ ì˜¤ë˜ ê±°ì§“ë˜ê³ ì™¸ëžŒëœ ìƒí™œì„ ëŠì–´ 버리는 것ì´ë‹¤. 남편 ë…¸ë¦‡ë„ ëª» í•˜ê³ ì•„ë²„ì§€ ë…¸ë¦‡ë„ ëª» 하는 ì‚¬ëžŒì´ ë‚¨ì˜ ìŠ¤ìŠ¹ì€ ì–´ë–»ê²Œ ë˜ê³ ì§€ë„ìžëŠ” 어떻게 ë˜ëŠëƒ. 하니까 나는 ì´ì œ 세ìƒì„ ë– ë‚˜ 버리는 ê²ƒì´ ì¡°ê¸ˆë„ ìŠ¬í”„ì§€ ì•„ë‹ˆí•˜ê³ ë„리어 ëª¸ì´ ê°€ëœ¬í•˜ê³ ìœ ì¾Œí•´ì§€ëŠ” 것 같다.
+ì˜¤ì§ í•˜ë‚˜ 마ìŒì— 걸리는 ê²ƒì€ ë‚´ ì„ ë°°ìš” 사랑하는 ë™ì§€ì´ë˜ 남 ì„ ìƒì˜ ìœ ì¼í•œ 혈육ì´ë˜ 네게다가 ëˆ„ëª…ì„ ì”Œìš°ê³ ê°€ëŠ” 것ì´ë‹¤."
+"그게 어디 아버지 잘못입니까?"
+í•˜ê³ ì •ìž„ì€ ìž…ìˆ ì„ ê¹¨ë¬¼ì—ˆì†Œ.
+"ëª¨ë‘ ì œê°€ ì² ì´ ì—†ì–´ì„œ ì € 때문ì—……."
+í•˜ê³ ì •ìž„ì€ ëª¸ì„ ë–¨ê³ ìš¸ì—ˆì†Œ.
+"아니! ê·¸ë ‡ê²Œ ìƒê°í•˜ì§€ 마ë¼. ë‚´ê°€ 지금 세ìƒì„ 버릴 ë•Œì— ë¬´ìŠ¨ 기ì¨ì´ 한 가지 남는 ê²ƒì´ ìžˆë‹¤ê³ í•˜ë©´ 너 하나가, ì´ ì„¸ìƒì—서 ì˜¤ì§ ë„ˆ 하나가 나를 ë”°ë¼ ì£¼ëŠ” 것ì´ë‹¤. 아마 ë„ˆë„ ë‚˜ë¥¼ 잘못 ì•Œê³ ë”°ë¼ ì£¼ëŠ” 것ì´ê² 지마는 세ìƒì´ 다 나를 ë²„ë¦¬ê³ , 처ìžê¹Œì§€ë„ 다 나를 버릴 ë•Œì— ì˜¤ì§ ë„ˆ 하나가 나를 소중히 알아 주니 ì–´ì°Œ ê³ ë§™ì§€ ì•Šê² ëŠëƒ. 그러니까 ì •ìž„ì•„ 너는 ëª¸ì„ ì¡°ì‹¬í•˜ì—¬ì„œ ê±´ê°•ì„ íšŒë³µí•˜ì—¬ì„œ 오래 잘 ì‚´ê³ , ê·¸ë¦¬ê³ ë‚˜ë¥¼ ìƒê°í•´ 다오."
+í•˜ê³ ë‚˜ë„ ìš¸ì—ˆì†Œ.
+형! ë‚´ê°€ ì •ìž„ì—게 ì´ëŸ° ë§ì„ 한 ê²ƒì´ ìž˜ëª»ì´ì§€ìš”. 그러나 나는 ê·¸ ë•Œì— ì´ëŸ° ë§ì„ 아니 í• ìˆ˜ 없었소. 왜 ê·¸ëŸ°ê³ í•˜ë‹ˆ, ê·¸ê²ƒì´ ë‚´ ì§„ì •ì´ë‹ˆê¹Œ. ë‚˜ë„ í•™êµ ì„ ìƒìœ¼ë¡œ, êµìž¥ìœ¼ë¡œ, ë˜ ì£¼ì œë„˜ê²Œ ì§€ì‚¬ë¡œì˜ ì¼ìƒì„ ë³´ë‚´ë…¸ë¼ê³ 마치 ì˜¤ì§ ì–¼ìŒ ê°™ì€ ì˜ì§€ë ¥ë§Œ 가진 사람 모양으로 ì‚¬ì‹ í‰ìƒì„ ì‚´ì•„ 왔지마는 ë‚´ ì†ì—ë„ ì—´ì •ì€ ìžˆì—ˆë˜ ê²ƒì´ì˜¤. 다만 ê·¸ ì—´ì •ì„ ëˆ„ë¥´ê³ ì£½ì´ê³ ìžˆì—ˆì„ ë¿ì´ì˜¤. ë¬¼ë¡ ë‚˜ëŠ” 아마 ì¼ìƒì— ì´ ì—´ì •ì˜ ê³ ì‚를 놓아 줄 ë‚ ì´ ì—†ê² ì§€ìš”. ë§Œì¼ ë‚´ê°€ ì´ ì—´ì •ì˜ ê³ ì‚를 놓아서 ìžìœ 로 달리게 í•œë‹¤ê³ í•˜ë©´ 나는 ì´ ê²½ìš°ì— ì •ìž„ì„ ì•ˆê³ , ë‚´ ì—´ì •ìœ¼ë¡œ ì •ìž„ì„ íƒœì›Œ ë²„ë ¸ì„ëŠ”ì§€ë„ ëª¨ë¥´ì˜¤. 그러나 나는 ì •ìž„ì´ê°€ ì—´ì •ìœ¼ë¡œ íƒˆìˆ˜ë¡ ë‚˜ëŠ” ë‚´ ì—´ì •ì˜ ê³ ì‚를 ë‘ ì†ìœ¼ë¡œ 꽉 ë¶™ë“¤ê³ ì´ë¥¼ ì•…ë¬¼ê³ ë§¤ë‹¬ë¦´ ê²°ì‹¬ì„ í•œ 것ì´ì˜¤.
+열한 시!
+"ì •ìž„ì•„. ì¸ì œ 병ì›ìœ¼ë¡œ 가거ë¼."
+í•˜ê³ ë‚˜ëŠ” 엄연하게 ëª…ë ¹í•˜ì˜€ì†Œ.
+"ë‚´ì¼ ì €ë¥¼ ë³´ì‹œê³ ë– ë‚˜ì‹œì§€ìš”?"
+í•˜ê³ ì •ìž„ì€ ëˆˆë¬¼ì„ ì”»ê³ ë¬¼ì—ˆì†Œ.
+"그럼, Jì¡°êµìˆ˜ë„ ë§Œë‚˜ê³ ë„ˆë„ ë³´ê³ ë– ë‚˜ì§€."
+í•˜ê³ ë‚˜ëŠ” ê±°ì§“ë§ì„ 하였소. ì´ ê²½ìš°ì— ë‚´ê°€ ê±°ì§“ë§ìŸì´ë¼ëŠ” í° ì£„ì¸ì´ ë˜ëŠ” ê²ƒì´ ì •ìž„ì—게 대하여 ì •ìž„ì„ ìœ„í•˜ì—¬ 가장 ì˜³ì€ ì¼ì´ë¼ê³ ìƒê°í•œ 까ë‹ì´ì˜¤.
+ì •ìž„ì€, 무서운 ì§ê°ë ¥ê³¼ ìƒìƒë ¥ì„ 가진 ì •ìž„ì€ ë‚´ ë§ì˜ ì§„ì‹¤ì„±ì„ ì˜ì‹¬í•˜ëŠ” ë“¯ì´ ë‚˜ë¥¼ 뚫어지게 ë°”ë¼ë³´ì•˜ì†Œ. 나는 차마 ì •ìž„ì˜ ì‹œì„ ì„ ë§ˆì£¼ ë³´ì§€ 못하여 외면하여 ë²„ë ¸ì†Œ.
+ì •ìž„ì€ ìˆ˜ê±´ìœ¼ë¡œ ëˆˆë¬¼ì„ ì”»ê³ ì²´ê²½ ì•žì— ê°€ì„œ í™”ìž¥ì„ ê³ ì¹˜ê³ ê·¸ë¦¬ê³ ,
+"ì €ëŠ” 가요."
+í•˜ê³ ë‚´ ì•žì— í—ˆë¦¬ë¥¼ 굽혀서 작별 ì¸ì‚¬ë¥¼ 하였소.
+"오, ê°€ ìžê±°ë¼."
+í•˜ê³ ë‚˜ëŠ” 극히 범연하게 대답하였소. 나는 ìžë¦¬ì˜·ì„ 입었기 ë•Œë¬¸ì— í˜„ê´€ê¹Œì§€ ìž‘ë³„í• ìˆ˜ë„ ì—†ì–´ì„œ ë³´ì´ë¥¼ 불러 ìžë™ì°¨ë¥¼ 하나 준비하ë¼ê³ ëª…í•˜ê³ ë‚´ ë°©ì—서 ìž‘ë³„í• ìƒê°ì„ 하였소.
+"ë‚´ì¼ ë³‘ì›ì— 오세요?"
+í•˜ê³ ì •ìž„ì€ ê³ ê°œë¥¼ 숙ì´ê³ 낙루하였소.
+"오, 가마."
+í•˜ê³ ë‚˜ëŠ” ë˜ ê±°ì§“ë§ì„ 하였소. 세ìƒì„ 버리기로 결심한 ì‚¬ëžŒì˜ ê±°ì§“ë§ì€ í•˜ë‚˜ë‹˜ê»˜ì„œë„ ìš©ì„œí•˜ì‹œê² ì§€ìš”. 설사 ë‚´ê°€ ê±°ì§“ë§ì„ 한 죄로 ì§€ì˜¥ì— ê°„ë‹¤ 하ë”ë¼ë„ ì´ ê²½ìš°ì— ì •ìž„ì„ ìœ„í•˜ì—¬ ê±°ì§“ë§ì„ 아니 í• ìˆ˜ê°€ 없지 않소? ë‚´ê°€ ê±°ì§“ë§ì„ 아니 하면 ì •ìž„ì€ ì•„ë‹ˆ ê°ˆ ê²ƒì´ ë¶„ëª…í•˜ì˜€ì†Œ.
+"ì „ 가요."
+í•˜ê³ ì •ìž„ì€ ë˜ í•œ 번 ì ˆì„ í•˜ì˜€ìœ¼ë‚˜ 소리를 내어서 울었소.
+"울지 마ë¼! 몸 ìƒí•œë‹¤."
+í•˜ê³ ë‚˜ëŠ” ì •ìž„ì—게 대한 ìµœí›„ì˜ ì¹œì ˆì„ ì •ìž„ì˜ ê³ì— 한 ê±¸ìŒ ê°€ê¹Œì´ ê°€ì„œ 어깨를 ë˜ë‹¥ë˜ë‹¥í•˜ì—¬ ì£¼ê³ , 외투를 입혀 주었소.
+"안녕히 주무세요."
+í•˜ê³ ì •ìž„ì€ ë¬¸ì„ ì—´ê³ ë‚˜ê°€ ë²„ë ¸ì†Œ.
+ì •ìž„ì˜ ê±¸ì–´ê°€ëŠ” 소리가 차차 멀어졌소.
+나는 ì–¼ë¹ ì§„ 사람 모양으로 ê·¸ ìžë¦¬ì— ìš°ë‘커니 서 있었소.
+ì°½ì— ë¶€ë”ªížˆëŠ” ë¹—ë°œ 소리가 ë“¤ë¦¬ê³ ìžë™ì°¨ 소리가 먼 나ë¼ì—서 오는 ê²ƒê°™ì´ ë“¤ë¦¬ì˜¤. ì´ê²ƒì´ ì •ìž„ì´ê°€ íƒ€ê³ ê°€ëŠ” ìžë™ì°¨ 소리ì¸ê°€. 나는 ì •ìž„ì„ ë”°ë¼ê°€ì„œ 붙들어 ì˜¤ê³ ì‹¶ì—ˆì†Œ. ë‚´ 몸과 마ìŒì€ ì •ìž„ì„ ë”°ë¼ì„œ í—ˆê³µì— ë– ê°€ëŠ” 것 같았소.
+ì•„ì•„ ì´ë ‡ê²Œ 나는 ì •ìž„ì„ ê³ì— ë‘ê³ ì‹¶ì„까. ì´ë ‡ê²Œ ë‚´ê°€ ì •ìž„ì˜ ê³ì— ìžˆê³ ì‹¶ì„까. 그러하건마는 나는 ì •ìž„ì„ ë–¼ì–´ ë²„ë¦¬ê³ ê°€ì§€ 아니하면 아니 ëœë‹¤! ê·¸ê²ƒì€ ì• ë“는 ì¼ì´ë‹¤. 기막히는 ì¼ì´ë‹¤! 그러나 ë‚´ ë„ë•ì ì±…ìž„ì€ ì—„ì •í•˜ê²Œ ê·¸ë ‡ê²Œ ëª…ë ¹í•˜ì§€ 않ëŠëƒ. 나는 ì´ ë„ë•ì ì±…ìž„ì˜ ëª…ë ¹ ê·¸ê²ƒì€ ë”위가 없는 ëª…ë ¹ì´ë‹¤ ì„ í„¸ë만치ë¼ë„ 휘어서는 아니 ëœë‹¤.
+그러나 ì •ìž„ì´ê°€ 호텔 현관까지 ìžë™ì°¨ë¥¼ 타기 ì „ì— í•œ 번만 ë” ë°”ë¼ë³´ëŠ” ê²ƒë„ ëª» í• ì¼ì¼ê¹Œ. 한 번만, ìž ê¹ë§Œ ë” ë°”ë¼ë³´ëŠ” ê²ƒë„ ëª» í• ì¼ì¼ê¹Œ. ìž ê¹ë§Œ ì¼ ë¶„ë§Œ 아니 ì¼ ì´ˆë§Œ 한 시그마ë¼ëŠ” 극히 ì§§ì€ ë™ì•ˆë§Œ ë°”ë¼ë³´ëŠ” ê²ƒë„ ëª» í• ì¼ì¼ê¹Œ. 아니, ì •ìž„ì„ í•œ 시그마 ë™ì•ˆë§Œ ë” ë³´ê³ ì‹¶ë‹¤ 나는 ì´ë ‡ê²Œ ìƒê°í•˜ê³ 벌떡 ì¼ì–´ë‚˜ì„œ ë„ì–´ì˜ í•¸ë“¤ì— ì†ì„ 대었소.
+`안 ëœë‹¤! 옳잖다!'
+í•˜ê³ ë‚˜ëŠ” ë‚´ ì†ŒíŒŒì— ëŒì•„와서 í„¸ì© ëª¸ì„ ë˜ì¡Œì†Œ.
+`ìµœí›„ì˜ ìˆœê°„ì´ ì•„ë‹ˆëƒ. ìµœí›„ì˜ ìˆœê°„ì— ìš©ê°ížˆ ì´ê²¨ì•¼ í• ê²ƒì´ ì•„ë‹ˆëƒ. 아서ë¼! 아서ë¼!'
+í•˜ê³ ë‚˜ëŠ” í˜¼ìž ì£¼ë¨¹ì„ ë¶ˆëˆë¶ˆëˆ ì¥ì—ˆì†Œ.
+ì´ ë•Œì— ì§œë°•ì§œë°• í•˜ê³ ê±¸ì–´ì˜¤ëŠ” 소리가 들리오. ë‚´ ê°€ìŠ´ì€ ìŒë°©ë§ì´ë¡œ ë‘들기는 ê²ƒê°™ì´ ë›°ì—ˆì†Œ.
+`설마 ì •ìž„ì¼ê¹Œ.'
+í•˜ë©´ì„œë„ ë‚˜ëŠ” ìˆ¨ì„ ì£½ì´ê³ 귀를 기울였소.
+ê·¸ ë°œìžêµ 소리는 분명 ë‚´ 문 ë°–ì— ì™€ì„œ 그쳤소. ê·¸ë¦¬ê³ ëŠ” 소리가 없었소.
+`ë‚´ ê·€ì˜ í™˜ê°ì¸ê°€.'
+í•˜ê³ ë‚˜ëŠ” í•œìˆ¨ì„ ë‚´ì‰¬ì—ˆì†Œ.
+그러나 ë‹¤ìŒ ìˆœê°„ ë˜ ë‘ì–´ 번 ë¬¸ì„ ë‘드리는 소리가 ë“¤ë ¸ì†Œ.
+"ì´ì—스."
+í•˜ê³ ë‚˜ëŠ” ëŒ€ë‹µí•˜ê³ ë¬¸ì„ ë°”ë¼ë³´ì•˜ì†Œ.
+ë¬¸ì´ ì—´ë ¸ì†Œ.
+들어오는 ì´ëŠ” ì •ìž„ì´ì—ˆì†Œ.
+"웬ì¼ì´ëƒ."
+í•˜ê³ ë‚˜ëŠ” 엄숙한 태ë„를 지었소. 그것으로 ì¼ ì´ˆì˜ ì¼ì²œë¶„ì§€ ì¼ì´ë¼ë„ 다시 한 번 ë³´ê³ ì‹¶ë˜ ì •ìž„ì„ ë³´ê³ ê¸°ì¨ì„ 카무플ë¼ì£¼í•œ 것ì´ì˜¤.
+ì •ìž„ì€ ì„œìŠ´ì§€ ì•Šê³ ë‚´ ë’¤ì— ì™€ì„œ ë‚´ êµì˜ì— ëª¸ì„ ê¸°ëŒ€ë©°,
+"ì•”ë§Œí•´ë„ ì˜¤ëŠ˜ì´ ë§ˆì§€ë§‰ì¸ ê²ƒë§Œ 같아서, 다시 뵈올 ê¸°ì•½ì€ ì—†ëŠ” 것만 같아서 가다가 ë„로 왔습니다. 한 번만 ë” ëµ™ê³ ê°ˆ 양으로요. 그래 ë„로 ì™€ì„œë„ ë“¤ì–´ì˜¬ê¹Œ ë§ê¹Œ í•˜ê³ ì£¼ì €ì£¼ì €í•˜ë‹¤ê°€ ì´ê²ƒì´ 마지막ì¸ë° í•˜ê³ ìš©ê¸°ë¥¼ 내어서 들어왔습니다. ë‚´ì¼ ì €ë¥¼ ë³´ì‹œê³ ê°€ì‹ ë‹¤ëŠ” ê²ƒì´ ë¶€ëŸ¬ í•˜ì‹ ë§ì”€ë§Œ ê°™ê³ , 마지막 ëµˆì˜µê³ , ëµˆì˜¨ëŒ€ë„ ê·¸ëž˜ë„ í•œ 번 ë” ëµˆì˜µê¸°ë§Œ í•´ë„……."
+í•˜ê³ ì •ìž„ì˜ ë§ì€ ëì„ ì•„ë¬¼ì§€ 못하였소. 그는 ë‚´ 등 ë’¤ì— ì„œ 있기 ë•Œë¬¸ì— ê·¸ê°€ ì–´ë– í•œ í‘œì •ì„ í•˜ê³ ìžˆëŠ”ì§€ëŠ” ë³¼ 수가 없었소. 나는 다만 ì•„ë²„ì§€ì˜ ìœ„ì—„ìœ¼ë¡œ ì •ë©´ì„ ë°”ë¼ë³´ê³ ìžˆì—ˆì„ ë¿ì´ì˜¤.
+`ì •ìž„ì•„, ë‚˜ë„ ë„¤ê°€ ë³´ê³ ì‹¶ì—ˆë‹¤. 네 뒤를 ë”°ë¼ê°€ê³ 싶었다. ë‚´ 몸과 마ìŒì€ 네 뒤를 ë”°ë¼ì„œ 허공으로 ë‚ ì•˜ë‹¤. 나는 너를 한 ì´ˆë¼ë„ 한 ì´ˆì˜ ì²œë¶„ì§€ ì¼ ë™ì•ˆì´ë¼ë„ 한 번 ë” ë³´ê³ ì‹¶ì—ˆë‹¤. ì •ìž„ì•„, ë‚´ ì§„ì •ì€ ë„ˆë¥¼ ì–¸ì œë“ ì§€ ë‚´ ê³ì— ë‘ê³ ì‹¶ë‹¤. ì •ìž„ì•„, 지금 ë‚´ ìƒëª…ì´ ê°€ì§„ ê²ƒì€ ì˜¤ì§ ë„ˆë¿ì´ë‹¤.'
+ì´ëŸ° ë§ì´ë¼ë„ í•˜ê³ ì‹¶ì—ˆì†Œ. 그러나 ì´ëŸ° ë§ì„ 하여서는 아니 ë˜ì˜¤! ë§Œì¼ ë‚´ê°€ ì´ëŸ° ë§ì„ 하여 준다면 ì •ìž„ì´ê°€ 기ë»í•˜ê² 지요. 그러나 나는 ì •ìž„ì´ì—게 ì´ëŸ° 기ì¨ì„ 주어서는 아니 ë˜ì˜¤!
+나는 ì–´ë””ê¹Œì§€ë“ ì§€ ì•„ë²„ì§€ì˜ ìœ„ì—„, ì•„ë²„ì§€ì˜ ëƒ‰ì •í•¨ì„ ì•„ë‹ˆ 지켜서는 아니 ë˜ì˜¤.
+ê·¸ë ‡ì§€ë§ˆëŠ” ë‚´ ê°€ìŠ´ì— íƒ€ì˜¤ë¥´ëŠ” ì´ë¦„ì§€ì„ ìˆ˜ 없는 ì—´ì •ì˜ ë¶ˆê¸¸ì€ ë‚´ ì´ì„±ê³¼ ì˜ì§€ë ¥ì„ 태워 ë²„ë¦¬ë ¤ 하오. 나는 ëˆˆì´ ì•„ëœ©ì•„ëœ©í•¨ì„ ê¹¨ë‹«ì†Œ. 나는 ë‚´ ìƒëª…ì˜ ë¶ˆê¸¸ì´ ê¹œë°•ê¹œë°•í•¨ì„ ê¹¨ë‹«ì†Œ.
+ê·¸ë ‡ì§€ë§ˆëŠ”! ì•„ì•„ ê·¸ë ‡ì§€ë§ˆëŠ” 나는 ì´ ë„ë•ì ì±…ìž„ì˜ ë¬´ìƒ ëª…ë ¹ì˜ ë°œë ¹ìžì¸ ì“´ ìž”ì„ ë§ˆì‹œì§€ 아니하여서는 아니 ë˜ëŠ” 것ì´ì˜¤.
+`산! 바위!'
+나는 ì •ì‹ ì„ ê°€ë‹¤ë“¬ì–´ì„œ ì´ê²ƒì„ 염하였소.
+그러나 ì—´ì •ì˜ íŒŒë„ê°€ 치는 ê³³ì— ì‚°ì€ ì›€ì§ì´ì§€ 아니하오? 바위는 í”들리지 아니하오? 태산과 ë°˜ì„ì´ ê·¸ í° ë¶ˆê¸¸ì— íƒ€ì„œ 재가 ë˜ì§€ëŠ” 아니하오? ì¸ìƒì˜ ëª¨ë“ íž˜ ê°€ìš´ë° ì—´ì •ë³´ë‹¤ ë” íë ¥ì ì¸ ê²ƒì´ ì–´ë”” 있소? ì•„ë§ˆë„ ìš°ì£¼ì˜ ëª¨ë“ íž˜ ê°€ìš´ë° ì‚¬ëžŒì˜ ì—´ì •ê³¼ ê°™ì´ íë ¥ì , 불가í•ë ¥ì ì¸ ê²ƒì€ ì—†ìœ¼ë¦¬ë¼. 뇌성, ë²½ë ¥, 글쎄 그것ì—나 비길까. ì°¨ë¼ë¦¬ 천체와 천체가 수학ì 으로 ê³„ì‚°í• ìˆ˜ 없는 비ìƒí•œ ì†ë ¥ì„ ê°€ì§€ê³ ë§ˆì£¼ ë‹¬ë ¤ë“¤ì–´ì„œ ìš°ë¦¬ì˜ ê·€ë¡œ ë“¤ì„ ìˆ˜ 없는 í° ì†Œë¦¬ì™€ 우리가 êµ³ë‹¤ê³ ì¼ì»«ëŠ” 금강ì„ì´ë¼ë„ ì¦ê¸°ë¥¼ ë§Œë“¤ê³ ì•¼ ë§ ë§Œí•œ ì—´ì„ ë°œí•˜ëŠ” ì¶©ëŒì˜ 순간ì—나 비길까. 형. 사람ì´ë¼ëŠ” 존재가 ìš°ì£¼ì˜ ëª¨ë“ ì¡´ìž¬ ì¤‘ì— ê°€ìž¥ 비ìƒí•œ ì¡´ìž¬ì¸ ê²ƒ 모양으로 ì‚¬ëžŒì˜ ì—´ì •ì˜ íž˜ì€ ìš°ì£¼ì˜ ëª¨ë“ ì‹ ë¹„í•œ 힘 ê°€ìš´ë° ê°€ìž¥ ì‹ ë¹„í•œ íž˜ì´ ì•„ë‹ˆê² ì†Œ? 대체 ìš°ì£¼ì˜ ëª¨ë“ íž˜ì€ ê·¸ê²ƒì´ ì•„ë¬´ë¦¬ í° íž˜ì´ë¼ê³ 하ë”ë¼ë„ ì € ìžì‹ ì„ ê¹¨ëœ¨ë¦¬ëŠ” ê²ƒì€ ì—†ì†Œ. ê·¸ë ‡ì§€ë§ˆëŠ” 사람ì´ë¼ëŠ” ì¡´ìž¬ì˜ ì—´ì •ì€ ëŠ¥ížˆ ì œ ìƒëª…ì„ ê¹¨ëœ¨ë ¤ 가루를 ë§Œë“¤ê³ ì œ ìƒëª…ì„ ì‚´ë¼ì„œ 소지를 올리지 아니하오? 여보, 대체 ì´ì—서 ë” íë ¥ì´ìš”, ì‹ ë¹„ì ì¸ ê²ƒì´ ì–´ë”” 있단 ë§ì´ì˜¤.
+ì´ ë•Œ ë‚´ ìƒíƒœ, 어깨 ë’¤ì—서 ì—´ì •ìœ¼ë¡œ íƒ€ê³ ì„°ëŠ” ì •ìž„ì„ ëŠë¼ëŠ” ë‚´ ìƒíƒœëŠ” 바야í로 대íë°œ, 대충ëŒì„ 기다리는 아슬아슬한 때가 아니었소. ë§Œì¼ ì¡°ê¸ˆë§Œì´ë¼ë„ ë‚´ê°€ ë‚´ ì—´ì •ì˜ ê³ ì‚ì— ëŠ¦ì¶¤ì„ ì¤€ë‹¤ê³ í•˜ë©´ 무서운 대íë°œì´ ì¼ì–´ë‚¬ì„ 것ì´ì˜¤.
+"ì •ìž„ì•„!"
+í•˜ê³ ë‚˜ëŠ” 충분히 마ìŒì„ ì§„ì •í•´ ê°€ì§€ê³ ê³ ê°œë¥¼ 옆으로 ëŒë ¤ ì •ìž„ì˜ ì–¼êµ´ì„ ì°¾ì•˜ì†Œ.
+"네ì—."
+í•˜ê³ ì •ìž„ì€ ìž…ì„ ì•½ê°„ ë‚´ ê·€ 가까ì´ë¡œ ê°€ì ¸ì™€ì„œ ê·¸ 씨근거리는 소리가 분명히 ë‚´ ê·€ì— ë“¤ë¦¬ê³ ê·¸ 후ëˆí›„ëˆí•˜ëŠ” 뜨거운 ìž…ê¹€ì´ ë‚´ 목과 ëº¨ì— ê°ê°ë˜ì—ˆì†Œ.
+억지로 ì§„ì •í•˜ì˜€ë˜ ë‚´ ê°€ìŠ´ì€ ë‹¤ì‹œ ì„¤ë ˆê¸°ë¥¼ 시작하였소. ê·¸ 불규칙한 숨소리와 뜨거운 ìž…ê¹€ 때문ì´ì—ˆì„까.
+"시간 늦는다. 어서 가거ë¼. ì´ ì•„ë²„ì§€ëŠ” ì–¸ì œê¹Œì§€ë“ ì§€ 너를 사랑하는 딸 로 소중히 소중히 ê°€ìŠ´ì— í’ˆê³ ìžˆìœ¼ë§ˆ. ë˜ í›„ì¼ì— 다시 ë§Œë‚ ë•Œë„ ìžˆì„ì§€ ì•„ëŠëƒ. 설사 다시 ë§Œë‚ ë•Œê°€ 없다기로니 ê·¸ê²ƒì´ ë¬´ì—‡ì´ ê·¸ë¦¬ 대수ëƒ. ë‚˜ì´ ë§Žì€ ì‚¬ëžŒì€ ë¨¼ì € ì£½ê³ ì Šì€ ì‚¬ëžŒì€ ì˜¤ëž˜ 살아서 ì¸ìƒì˜ ì¼ì„ ë§Žì´ í•˜ëŠ” ê²ƒì´ ìˆœì„œê°€ 아니ëƒ. 너는 ëª¸ì´ ì•„ì§ ì•½í•˜ë‹ˆ 마ìŒì„ 잘 ì•ˆì •í•´ì„œ 어서 ê±´ê°•ì„ íšŒë³µí•˜ì—¬ë¼. ê·¸ë¦¬ê³ êµ³ì„¸ê²Œ 굳세게, 힘있게 힘있게 ì‚´ì•„ 다오. ì¡°ì„ ì€ ì‚¬ëžŒì„ êµ¬í•œë‹¤. 나 ê°™ì€ ì‚¬ëžŒì€ ì¸ì œ ì¡°ì„ ì„œ ë” ì¼í• ìžê²©ì„ 잃어버린 사람ì´ì§€ë§ˆëŠ” 네야 ì–´ë– ëƒ. 설사 누가 무슨 ë§ì„ 해서 í•™êµì—서 학비를 아니 ì¤€ë‹¤ê±°ë“ ë‚´ê°€ 네게 준 ìž¬ì‚°ì„ ê°€ì§€ê³ ë„¤ 마ìŒëŒ€ë¡œ 공부를 í•˜ë ¤ë¬´ë‚˜. 네가 ê·¸ë ‡ê²Œ í•´ 주어야 나를 위하는 것ì´ë‹¤. ìž ì¸ì œ 가거ë¼. 네 ì•žê¸¸ì´ ì–‘ì–‘í•˜ì§€ 아니하ëƒ. ìž ì¸ì œ 가거ë¼. 나는 ë‚´ì¼ ì•„ì¹¨ ë™ê²½ì„ ë– ë‚ ëž€ë‹¤. ìž ì–´ì„œ."
+í•˜ê³ ë‚˜ëŠ” í™”í‰í•˜ê²Œ 웃는 낯으로 ì¼ì–´ì„°ì†Œ.
+ì •ìž„ì€ ìš¸ë¨¹ìš¸ë¨¹í•˜ê³ ê³ ê°œë¥¼ 숙ì´ì˜¤.
+ë°–ì—서는 ë°”ëžŒì´ ì ì ê°•í•´ì ¸ì„œ 소리를 í•˜ê³ ìœ ë¦¬ì°½ì„ í”드오.
+"그럼, ì „ 가요."
+í•˜ê³ ì •ìž„ì€ ê³ ê°œë¥¼ 들었소.
+"그래. 어서 가거ë¼. ë²Œì¨ ì—´í•œì‹œ ë°˜ì´ë‹¤. ë³‘ì› ë¬¸ì€ ì•„ë‹ˆ 닫니!"
+ì •ìž„ì€ ëŒ€ë‹µì´ ì—†ì†Œ.
+"어서!"
+í•˜ê³ ë‚˜ëŠ” ë³´ì´ë¥¼ 불러 ìžë™ì°¨ë¥¼ 하나 준비하ë¼ê³ ì¼ë €ì†Œ.
+"ê°ˆëžë‹ˆë‹¤."
+í•˜ê³ ì •ìž„ì€ ê³ ê°œë¥¼ 숙여서 내게 ì¸ì‚¬ë¥¼ í•˜ê³ ë¬¸ì„ í–¥í•˜ì—¬ 한 ê±¸ìŒ ê±·ë‹¤ê°€ ìž ê¹ ì£¼ì €í•˜ë”니, 다시 ëŒì•„서서,
+"ì €ë¥¼ 한 번만 안아 주셔요. 아버지가 어린 ë”¸ì„ ì•ˆë“¯ì´ í•œ 번만 안아 주셔요."
+í•˜ê³ ë‚´ 앞으로 ê°€ê¹Œì´ ì™€ 서오.
+나는 íŒ”ì„ ë²Œë ¤ 주었소. ì •ìž„ì€ ë‚´ ê°€ìŠ´ì„ í–¥í•˜ê³ ëª¸ì„ ë˜ì¡Œì†Œ. ê·¸ë¦¬ê³ ì œ ì´ëº¨ ì €ëº¨ì„ ë‚´ ê°€ìŠ´ì— ëŒ€ê³ ë¹„ë³ì†Œ. 나는 ë‘ íŒ”ì„ ì •ìž„ì˜ ì–´ê¹¨ ìœ„ì— ê°€ë²¼ì´ ë†“ì•˜ì†Œ.
+ì´ëŸ¬í•œ ì§€ 몇 ë¶„ì´ ì§€ë‚¬ì†Œ. 아마 ì¼ ë¶„ë„ ë‹¤ 못 ë˜ì—ˆëŠ”ì§€ 모르오.
+ì •ìž„ì€ ë‚´ 가슴ì—서 ê³ ê°œë¥¼ 들어 나를 뚫어지게 우러러보ë”니, 다시 ë‚´ ê°€ìŠ´ì— ë‚¯ì„ ëŒ€ë”니 아마 ë‚´ ì‹¬ìž¥ì´ ë¬´ì„게 뛰는 소리를 ì •ìž„ì€ ë“¤ì—ˆì„ ê²ƒì´ì˜¤ ì •ìž„ì€ ë‹¤ì‹œ ê³ ê°œë¥¼ ë“¤ê³ ,
+"어디를 ê°€ì‹œë“ ì§€ 편지나 주셔요."
+í•˜ê³ êµµì€ ëˆˆë¬¼ì„ ë–¨êµ¬ê³ ëŠ” 내게서 물러서서 ë˜ í•œ 번 ì ˆí•˜ê³ ,
+"안녕히 가셔요. ë§Œì£¼ë“ ì§€ ì•„ë ¹ì´ë“ ì§€ ì¡°ì„ ì‚¬ëžŒ ë§Žì´ ì‚¬ëŠ” ê³³ì— ê°€ì…”ì„œ ì¼í•˜ê³ 사셔요. ëŒì•„가실 ìƒê°ì€ 마셔요. ì œê°€, 아버지 ë§ì”€ëŒ€ë¡œ í˜¼ìž ë–¨ì–´ì ¸ 있으니 ì•„ë²„ì§€ë„ ì œ ë§ì”€ëŒ€ë¡œ ëŒì•„가실 ìƒê°ì€ 마셔요, 네, ê·¸ë ‡ë‹¤ê³ ëŒ€ë‹µí•˜ì…”ìš”!"
+í•˜ê³ ëŠ” ë˜ í•œ 번 ë‚´ ê°€ìŠ´ì— ëª¸ì„ ê¸°ëŒ€ì˜¤.
+죽기를 결심한 나는 `오ëƒ, 그러마.' 하는 ëŒ€ë‹µì„ í• ìˆ˜ëŠ” 없었소. 그래서,
+"오, ë‚´ ì‚´ë„ë¡ íž˜ì“°ë§ˆ."
+하는 약ì†ì„ 주어서 ì •ìž„ì„ ëŒë ¤ë³´ëƒˆì†Œ.
+ì •ìž„ì˜ ë°œìžêµ 소리가 안 들리게 ëœ ë•Œì— ë‚˜ëŠ” ë¹ ë¥¸ 걸ìŒìœ¼ë¡œ ì˜¥ìƒ ì •ì›ìœ¼ë¡œ 나갔소. 비가 막 뿌리오.
+나는 ì •ìž„ì´ê°€ íƒ€ê³ ë‚˜ê°€ëŠ” ìžë™ì°¨ë¼ë„ ë³¼ 양으로 호텔 현관 ì•žì´ ë³´ì´ëŠ” ê¼ëŒ€ê¸°ë¡œ 올ë¼ê°”소. í˜„ê´€ì„ ë– ë‚œ ìžë™ì°¨ 하나가 ì „ì°»ê¸¸ë¡œ 나서서는 ë¶ì„ í–¥í•˜ê³ ë‹¬ì•„ë‚˜ì„œ 순ì‹ê°„ì— ê·¸ ê½ë¬´ë‹ˆì— 달린 ë¶‰ì€ ë¶ˆì¡°ì°¨ ìŠ¤ëŸ¬ì ¸ ë²„ë¦¬ê³ ë§ì•˜ì†Œ.
+나는 미친 사람 모양으로,
+"ì •ìž„ì•„, ì •ìž„ì•„!"
+í•˜ê³ ìˆ˜ì—†ì´ ë¶ˆë €ì†Œ. 나는 사 층ì´ë‚˜ ë˜ëŠ” ì´ ê¼ëŒ€ê¸°ì—서 ë›°ì–´ë‚´ë ¤ì„œ ì •ìž„ì´ê°€ íƒ€ê³ ê°„ ìžë™ì°¨ì˜ 뒤를 ë”°ë¥´ê³ ì‹¶ì—ˆì†Œ.
+"ì•„ì•„ ì˜ì›í•œ ì¸ìƒì˜ ì´ë³„!"
+나는 ê·¸ 옥ìƒì— 얼마나 오래 ì„°ë˜ì§€ë¥¼ 모르오. ë‚´ 머리와 낯과 배스로브ì—서는 ë¬¼ì´ í르오. ë°©ì— ë“¤ì–´ì˜¤ë‹ˆ ì •ìž„ì´ê°€ ë¼ì¹˜ê³ ê°„ 향기와 추억만 남았소.
+나는 ë°© 안 구ì„구ì„ì— ì •ìž„ì˜ ëª¨ì–‘ì´ ë³´ì´ëŠ” ê²ƒì„ ê¹¨ë‹¬ì•˜ì†Œ. 특별히 ì •ìž„ì´ê°€ ê³ ê°œë¥¼ 숙ì´ê³ 서 ìžˆë˜ ë‚´ êµì˜ ë’¤ì—는 분명히 갈색 외투를 ìž…ì€ ì •ìž„ì˜ ëª¨ì–‘ì´ ì™„ì—°í•˜ì˜¤.
+"ì •ìž„ì•„!"
+í•˜ê³ ë‚˜ëŠ” ê·¸ 곳으로 ë”°ë¼ê°€ì˜¤. 그러나 가면 거기는 ì •ìž„ì€ ì—†ì†Œ.
+나는 êµì˜ì— 앉소. 그러면 ì •ìž„ì˜ ì”¨ê·¼ì”¨ê·¼í•˜ëŠ” 숨소리와 ë”ìš´ ìž…ê¹€ì´ ë¶„ëª… ë‚´ ì˜¤ë¥¸íŽ¸ì— ê°ê°ì´ ë˜ì˜¤. ì•„ì•„ 무서운 환ê°ì´ì—¬!
+나는 ìžë¦¬ì— 눕소. ê·¸ë¦¬ê³ ì •ìž„ì˜ í™˜ê°ì„ í”¼í•˜ë ¤ê³ ë¶ˆì„ ë„오. 그러면 ì •ìž„ì´ê°€ 내게 ì•ˆê¸°ë˜ ìžë¦¬ì¯¤ì— 환하게 ì •ìž„ì˜ ëª¨ì–‘ì´ ë‚˜íƒ€ë‚˜ì˜¤.
+나는 ë¶ˆì„ ì¼œì˜¤. ë˜ ë¶ˆì„ ë„오.
+ë‚ ì´ ë°ìž 나는 비가 ê° ê²ƒì„ ë‹¤í–‰ìœ¼ë¡œ ë¹„í–‰ìž¥ì— ë‹¬ë ¤ê°€ì„œ 비행기를 얻어 탔소.
+나는 다시 ì¡°ì„ ì˜ í•˜ëŠ˜ì„ í†µê³¼í•˜ê¸°ê°€ 싫어서 ë¶ê°•ì—서 비행기ì—서 ë‚´ë ¤ì„œ ë¬¸ì‚¬ì— ì™€ì„œ ëŒ€ë ¨ìœ¼ë¡œ 가는 배를 탔소.
+나는 ëŒ€ë ¨ì—서 ë‚´ë ¤ì„œ í•˜ë£»ë°¤ì„ ì—¬ê´€ì—서 ìžê³ 는 ê³§ 장춘 가는 ê¸‰í–‰ì„ íƒ”ì†Œ. ë¬¼ë¡ ì•„ë¬´ì—ê²Œë„ ì—½ì„œ 한 장 한 ì¼ ì—†ì—ˆì†Œ. ê·¸ê²ƒì€ ì¸ì—°ì„ ëŠì€ 세ìƒì— 대하여 연연한 마ìŒì„ 가지는 ê²ƒì„ ë¶€ë„럽게 ìƒê°í•œ 까ë‹ì´ì˜¤.
+차가 ì˜›ë‚ ì—는 우리 ì¡°ìƒë„¤ê°€ ì‚´ê³ ë¬¸í™”ë¥¼ ì§“ë˜ ì˜› í„°ì „ì¸ ë§Œì£¼ì˜ ë²ŒíŒì„ 달릴 때ì—는 ê°íšŒë„ 없지 아니하였소. 그러나 나는 지금 그런 한가한 ê°ìƒì„ 쓸 ê²¨ë¥¼ì´ ì—†ì†Œ.
+ë‚´ê°€ ë¯¿ê³ ê°€ëŠ” ê³³ì€ í•˜ì–¼ë¹ˆì— ìžˆëŠ” ì–´ë–¤ 친구요. 그는 Rë¼ëŠ” 사람으로서 ê²½ìˆ ë…„ì— A씨 ë“±ì˜ ë§ëª…ê°ì„ ë”°ë¼ ë‚˜ê°”ë‹¤ê°€ ì•„ë¼ì‚¬ì—서 무관 í•™êµë¥¼ ì¡¸ì—…í•˜ê³ ì•„ë¼ì‚¬ 사관으로서 구주 ëŒ€ì „ì—ë„ ì¶œì •ì„ í•˜ì˜€ë‹¤ê°€, í˜ëª… 후ì—ë„ ì´ë‚´ ì ìœ„êµ°ì— ë¨¸ë¬¼ëŸ¬ì„œ 지금까지 소비ì—트 장êµë¡œ 있는 사람ì´ì˜¤. ì§€ê¸ˆì€ ìœ¡êµ° 소장ì´ë¼ë˜ê°€.
+나는 í•˜ì–¼ë¹ˆì— ê·¸ ì‚¬ëžŒì„ ì°¾ì•„ê°€ëŠ” 것ì´ì˜¤. ê·¸ ì‚¬ëžŒì„ ì°¾ì•„ì•¼ ì•„ë¼ì‚¬ì— 들어갈 ì—¬í–‰ê¶Œì„ ì–»ì„ ê²ƒì´ìš”, ì—¬í–‰ê¶Œì„ ì–»ì–´ì•¼ ë‚´ê°€ í‰ì†Œì— ì´ìƒí•˜ê²Œë„ ê·¸ë¦¬ì›Œí•˜ë˜ ë°”ì´ì¹¼ 호를 ë³¼ 것ì´ì˜¤.
+í•˜ì–¼ë¹ˆì— ë‚´ë¦° ê²ƒì€ í•´ê°€ 뉘엿뉘엿 넘어가는 ì„ì–‘ì´ì—ˆì†Œ.
+나는 ì•ˆì¤‘ê·¼ì´ ì´ë“±ë°•문(ä¼Šè—¤åšæ–‡:ì´í† 히로부미)ì„ ìœ ê³³ì´ ì–´ë”˜ê°€ í•˜ê³ ë²ŒíŒê³¼ ê°™ì´ ë„“ì€ í”Œëž«í¼ì— ë‚´ë ¸ì†Œ. 과연 êµì œ ë„ì‹œë¼ ì„œì–‘ 사람, ì¤‘êµ ì‚¬ëžŒ, ì¼ë³¸ ì‚¬ëžŒì´ ê°ê¸° ì œ ë§ë¡œ 지껄ì´ì˜¤. ì•„ì•„ ì¡°ì„ ì‚¬ëžŒë„ ìžˆì„ ê²ƒì´ì˜¤ë§ˆëŠ” 다들 ì–‘ë³µì„ ìž…ê±°ë‚˜ ì²ë³µì„ 입거나 í•˜ê³ ë˜ ì‚¬ëžŒì´ ë§Žì€ ê³³ì—서는 ë§ë„ 잘 하지 아니하여 ì•„ë¬´ìª¼ë¡ ì¡°ì„ ì‚¬ëžŒì¸ ê²ƒì„ í‘œì‹œí•˜ì§€ 아니하는 íŒì´ë¼ ê·¸ 골격과 í‘œì •ì„ ì‚´í”¼ê¸° ì „ì—는 ì–´ëŠ ê²ƒì´ ì¡°ì„ ì‚¬ëžŒì¸ì§€ 알 ê¸¸ì´ ì—†ì†Œ. 아마 허름하게 ì°¨ë¦¬ê³ ê¸°ìš´ ì—†ì´, 비창한 ë¹›ì„ ë ê³ ì‚¬ëžŒì˜ ëˆˆì„ ìŠ¬ìŠ¬ 피하는 ì € 순하게 ìƒê¸´ ì‚¬ëžŒë“¤ì´ ì¡°ì„ ì‚¬ëžŒì´ê² 지요. ì–¸ì œë‚˜ 한 번 가는 곳마다 ë™ì–‘ì´ë“ ì§€, 서양ì´ë“ ì§€,
+`나는 ì¡°ì„ ì‚¬ëžŒì´ì˜¤!'
+í•˜ê³ ë½ë‚´ê³ ë‹¤ë‹ ë‚ ì´ ìžˆì„까 하면 ëˆˆë¬¼ì´ ë‚˜ì˜¤. ë”구나, 하얼빈과 ê°™ì€ ê°ìƒ‰ ì¸ì¢…ì´ ëª¨ì—¬ì„œ ìƒì¡´ ê²½ìŸì„ 하는 ë§ˆë‹¹ì— ì„œì„œ ì´ëŸ° 비ê°ì´ ê°„ì ˆí•˜ì˜¤. ì•„ì•„ ì´ ë¶ˆìŒí•œ ìœ ëž‘ì˜ ë¬´ë¦¬ ì¤‘ì— ë‚˜ë„ í•˜ë‚˜ë¥¼ ë” ë³´íƒœëŠ”ê°€ 하면 ëˆˆë¬¼ì„ ì”»ì§€ ì•„ë‹ˆí• ìˆ˜ 없었소.
+나는 ì—ì—서 나와서 ì–´ë–¤ ì•„ë¼ì‚¬ ë³‘ì • 하나를 ë¶™ë“¤ê³ Rì˜ ì•„ë¼ì‚¬ ì´ë¦„ì„ ë¶ˆë €ì†Œ. ê·¸ë¦¬ê³ ì•„ëŠëƒê³ ì˜ì–´ë¡œ 물었소.
+ê·¸ ë³‘ì •ì€ ë‚´ ë§ì„ 잘못 알아들었는지, ë˜ëŠ” R를 모르는지 무엇ì´ë¼ê³ ì•„ë¼ì‚¬ë§ë¡œ 지껄ì´ëŠ” 모양ì´ë‚˜ 나는 ë¬¼ë¡ ê·¸ê²ƒì„ ì•Œì•„ë“¤ì„ ìˆ˜ê°€ 없었소. 그러나 나는 ê·¸ ë³‘ì •ì˜ í‘œì •ì—서 내게 호ì˜ë¥¼ 가진 ê²ƒì„ ì§ìž‘í•˜ê³ í•œ 번 ë” ë¶„ëª…ížˆ,
+"ìš”ì‹ ì•Œë ‰ì‚°ë“œë¡œë¹„ì¹˜ 리가ì´."
+ë¼ê³ 불러 보았소.
+ê·¸ ë³‘ì •ì€ ë¹™ê·¸ë ˆ ì›ƒê³ ê³ ê°œë¥¼ í”드오. ì´ ë‘ ì™¸êµ ì‚¬ëžŒì˜ ì´ìƒí•œ êµì„ì— í¥ë¯¸ë¥¼ ê°€ì§€ê³ ì—¬ëŸ¬ ì•„ë¼ì‚¬ ë³‘ì •ê³¼ ë™ì–‘ ì‚¬ëžŒë“¤ì´ ì‹ì—¬ ì¸ì´ë‚˜ 우리 ì£¼ìœ„ì— ëª¨ì—¬ë“œì˜¤.
+ê·¸ ë³‘ì •ì´ ë‚˜ë¥¼ ë°”ë¼ë³´ê³ ë˜ í•œ 번 ê·¸ ì´ë¦„ì„ ë¶ˆëŸ¬ ë³´ë¼ëŠ” 모양 같기로 나는 ì´ë²ˆì—는 Rì˜ ì•„ë¼ì‚¬ ì´ë¦„ì— `ì œë„ˆëŸ´'ì´ë¼ëŠ” ë§ì„ 붙여 불러 보았소.
+그랬ë”니 ì–´ë–¤ 다른 ë³‘ì •ì´ ë›°ì–´ë“¤ë©°,
+"게네ë¼ìš° 리가ì´!"
+í•˜ê³ ì•ˆë‹¤ëŠ” í‘œì •ì„ í•˜ì˜¤. `게네ë¼ìš°'ë¼ëŠ” ê²ƒì´ ì•„ë§ˆ ì•„ë¼ì‚¬ë§ë¡œ 장군ì´ëž€ ë§ì¸ê°€ 하였소.
+"예스. 예스."
+í•˜ê³ ë‚˜ëŠ” 기ì˜ê²Œ 대답하였소. ê·¸ë¦¬ê³ ëŠ” ì•„ë¼ì‚¬ ë³‘ì •ë“¤ë¼ë¦¬ 무ì—ë¼ê³ 지껄ì´ë”니, ê·¸ ì¤‘ì— í•œ ë³‘ì •ì´ ë‚˜ì„œë©´ì„œ ê³ ê°œë¥¼ ë„ë•ë„ë•í•˜ê³ , ì œê°€ 마차 하나를 불러서 나를 íƒœìš°ê³ ì €ë„ íƒ€ê³ ì–´ë””ë¡œ ë‹¬ë ¤ê°€ì˜¤.
+ê·¸ ì•„ë¼ì‚¬ ë³‘ì •ì€ ì¹œì ˆížˆ ì•Œì§€ë„ ëª»í•˜ëŠ” ë§ë¡œ ì´ê²ƒì €ê²ƒì„ 가리키면서 ì„¤ëª…ì„ í•˜ë”니 ë‚´ê°€ 못 알아듣는 ì¤„ì„ ìƒê°í•˜ê³ ë‚´ 어깨를 íˆ ì¹˜ê³ ì›ƒì†Œ. ì–´ë¦°ì• ì™€ ê°™ì´ ìˆœí•œ 사람들ì´êµ¬ë‚˜ í•˜ê³ ë‚˜ëŠ” ê³ ë§™ë‹¤ëŠ” 표로 ê³ ê°œë§Œ ë„ë•ë„ë•하였소.
+어디로 어떻게 가는지 서양 시가로 ë‹¬ë ¤ê°€ë‹¤ê°€ ì–´ë–¤ í° ì €íƒ ì•žì— ì´ë¥´ëŸ¬ì„œ 마차를 ê·¸ 현관 앞으로 들ì´ëª°ì•˜ì†Œ.
+현관ì—서는 ì¢…ì¡¸ì´ ë‚˜ì™”ì†Œ. ë‚´ê°€ ëª…í•¨ì„ ë“¤ì—¬ë³´ëƒˆë”니 ë¶€ê´€ì¸ ë“¯í•œ ì•„ë¼ì‚¬ 장êµê°€ 나와서 나를 으리으리한 ì‘ì ‘ì‹¤ë¡œ ì¸ë„하였소. 얼마 있노ë¼ë‹ˆ ì¤‘ë…„ì´ ë„˜ì€ ì–´ë–¤ ëŒ€ìž¥ì´ ë‚˜ì˜¤ëŠ”ë° êµ°ë³µì— ì¹¼ëˆë§Œ 늘였소.
+"ì´ê²Œ 누구요."
+í•˜ê³ ê·¸ ëŒ€ìž¥ì€ ë‹¬ë ¤ë“¤ì–´ì„œ 나를 껴안았소. ì´ì‹ì˜¤ ë…„ ë§Œì— ë§Œë‚˜ëŠ” 우리는 서로 알아본 것ì´ì˜¤.
+ì´ìœ½ê³ 나는 ê·¸ì˜ ë¶€ì¸ê³¼ ìžë…€ë“¤ë„ 만났소. ê·¸ë“¤ì€ ë‹¤ ì•„ë¼ì‚¬ 사람ì´ì˜¤.
+ì €ë…ì´ ë난 ë’¤ì— ë‚˜ëŠ” Rì˜ ë¶€ì¸ê³¼ ë”¸ì˜ ìŒì•…ê³¼ 그림 구경과 ê¸°íƒ€ì˜ ê´€ëŒ€ë¥¼ ë°›ê³ ë‹¨ë‘˜ì´ ì´ì•¼ê¸°í• 기회를 얻었소. ê²½ìˆ ë…„ 당시 ì´ì•¼ê¸°ë„ ë‚˜ì˜¤ê³ , Aì”¨ì˜ ì´ì•¼ê¸°ë„ ë‚˜ì˜¤ê³ , Rì˜ ì‹ ì„¸ íƒ€ë ¹ë„ ë‚˜ì˜¤ê³ , ë‚´ ì´ì‹ì˜¤ ë…„ ê°„ì˜ ìƒí™œ ì´ì•¼ê¸°ë„ ë‚˜ì˜¤ê³ , 소비ì—트 í˜ëª… ì´ì•¼ê¸°ë„ ë‚˜ì˜¤ê³ , 하얼빈 ì´ì•¼ê¸°ë„ ë‚˜ì˜¤ê³ , 우리네가 ì–´ë ¤ì„œ 서로 ì‚¬ê·€ë˜ íšŒêµ¬ë‹´ë„ ë‚˜ì˜¤ê³ ì´ì•¼ê¸°ê°€ ê·¸ì¹ ë°”ë¥¼ 몰ëžì†Œ. "ì¡°ì„ ì€ ê·¸ë¦½ì§€ 않ì€ê°€."
+하는 ë‚´ ë§ì— ì¾Œí™œí•˜ë˜ R는 ê³ ê°œë¥¼ 숙ì´ê³ 추연한 ë¹›ì„ ë³´ì˜€ì†Œ.
+나는 Rì˜ ì¶”ì—°í•œ 태ë„를 아마 ê³ êµì„ 그리워하는 것으로만 여겼소. 그래서 나는 그리 침ìŒí•˜ëŠ” ê²ƒì„ ë³´ê³ ,
+"얼마나 ê³ êµì´ ê·¸ë¦½ê² ë‚˜. 나는 ê³ êµì„ ë– ë‚œ 지가 ì¼ ì£¼ì¼ë„ 안 ë˜ê±´ë§ˆëŠ” 못 견디게 그리운ë°."
+í•˜ê³ ë™ì •하는 ë§ì„ 하였소.
+í–ˆë”니, ì´ ë§ ë³´ì‹œì˜¤. 그는 침ìŒì„ ê¹¨ëœ¨ë¦¬ê³ ê³ ê°œë¥¼ ë²ˆì© ë“¤ë©°,
+"아니! 나는 ê³ êµì´ ì¡°ê¸ˆë„ ê·¸ë¦½ì§€ 아니하ì´. ë‚´ê°€ 지금 ìƒê°í•œ ê²ƒì€ ìžë„¤ ë§ì„ ë“£ê³ ê³ êµì´ 그리운가 ê·¸ë¦¬ì›Œí• ê²ƒì´ ìžˆëŠ”ê°€ë¥¼ ìƒê°í•´ 본 것ì¼ì„¸. 그랬ë”니 아무리 ìƒê°í•˜ì—¬ë„ 나는 ê³ êµì´ 그립다는 ìƒê°ì„ 가질 수가 없어. 그야 ì–´ë ¤ì„œ ìžë¼ë‚ ë•Œì— ë³´ë˜ ê°•ì‚°ì´ë¼ë“ ì§€ ë‚´ ê¸°ì–µì— ë‚¨ì€ ì•„ëŠ” 사람들ì´ë¼ë“ ì§€, ë³´ê³ ì‹¶ë‹¤ 하는 ìƒê°ë„ 없지 아니하지마는 ê·¸ê²ƒì´ ê³ êµì´ 그리운 것ì´ë¼ê³ í• ìˆ˜ê°€ 있ì„까. ê·¸ ë°–ì—는 나는 아무리 ìƒê°í•˜ì—¬ë„ ê³ êµì´ 그리운 ê²ƒì„ ì°¾ì„ ê¸¸ì´ ì—†ë„¤. ë‚˜ë„ ì§€ê¸ˆ ìžë„¤ë¥¼ ë³´ê³ ë˜ ìžë„¤ ë§ì„ ë“£ê³ ì˜¤ëž˜ ìžŠì–´ë²„ë ¸ë˜ ê³ êµì„ 좀 그립게, 그립다 하게 ìƒê°í•˜ë ¤ê³ í•´ 보았지마는 ë„무지 나는 ê³ êµì´ 그립다는 ìƒê°ì´ 나지 않네."
+ì´ ë§ì— 나는 ê¹œì§ ë†€ëžì†Œ. 몸서리치게 ë¬´ì„œì› ì†Œ. 나는 í•´ì™¸ì— ì˜¤ëž˜ 표랑하는 ì‚¬ëžŒì€ ìœ¼ë ˆ ê³ êµì„ ê·¸ë¦¬ì›Œí• ê²ƒìœ¼ë¡œ ë¯¿ê³ ìžˆì—ˆì†Œ. ê·¸ëŸ°ë° ì´ ì‚¬ëžŒì´, ì¼ì°ì€ ê³ êµì„ 사랑하여 ëª©ìˆ¨ê¹Œì§€ë„ ë°”ì¹˜ë ¤ë˜ ì´ ì‚¬ëžŒì´ ë„무지 ì´ì²˜ëŸ¼ ê³ êµì„ 잊어버린다는 ê²ƒì€ ë†€ë¼ìš´ ì •ë„를 지나서 괘씸하기 그지없었소. ë‚˜ë„ ë¹„ë¡ ì¡°ì„ ì„ ë– ë‚œë‹¤ê³ , ì˜ì›ížˆ ë²„ë¦°ë‹¤ê³ ë‚˜ì„œê¸°ëŠ” 했지마는 나로는 죽기 ì „ì—는 아니 ë¹„ë¡ ì£½ë”ë¼ë„ 잊어버리지 ëª»í• ê³ êµì„ 잊어버린 Rì˜ ì‹¬ì‚¬ê°€ ë‚œì¸¡í•˜ê³ ì›ë§ìŠ¤ëŸ¬ì› ì†Œ.
+"ê³ êµì´ 그립지가 않아?"
+í•˜ê³ Rì—게 묻는 ë‚´ 어성ì—는 격분한 ë¹›ì´ ìžˆì—ˆì†Œ.
+"ì´ìƒí•˜ê²Œ ìƒê°í•˜ì‹œê² ì§€. 하지만 ê³ êµì— 무슨 그리울 ê²ƒì´ ìžˆë‹¨ ë§ì¸ê°€. ê·¸ 빈대 ë“는 오막살ì´ê°€ 그립단 ë§ì¸ê°€. 나무 한 ê°œ 없는 ì‚°ì´ ê·¸ë¦½ë‹¨ ë§ì¸ê°€. ë¬¼ë³´ë‹¤ë„ ëª¨ëž˜ê°€ ë§Žì€ ë‹¤ ëŠ™ì–´ë¹ ì§„ ê°œì²œì´ ê·¸ë¦½ë‹¨ ë§ì¸ê°€. ê·¸ ë¬´ê¸°ë ¥í•˜ê³ ê°€ë‚œí•œ, 시기 ë§Žê³ ì‹¸ìš°ê³ í•˜ëŠ” ê·¸ ë°±ì„±ì„ ê·¸ë¦¬ì›Œí•œë‹¨ ë§ì¸ê°€. ê·¸ë ‡ì§€ 아니하면 무슨 ê·¸ë¦¬ì›Œí• ìŒì•…ì´ ìžˆë‹¨ ë§ì¸ê°€, ë¯¸ìˆ ì´ ìžˆë‹¨ ë§ì¸ê°€, ë¬¸í•™ì´ ìžˆë‹¨ ë§ì¸ê°€, 사ìƒì´ 있단 ë§ì¸ê°€, ì‚¬ëª¨í• ë§Œí•œ ì¸ë¬¼ì´ 있단 ë§ì¸ê°€! ë‚ ë”러 ê³ êµì˜ ë¬´ì—‡ì„ ê·¸ë¦¬ì›Œí•˜ëž€ ë§ì¸ê°€. 나는 ì¡°êµì´ 없는 사람ì¼ì„¸. ë‚´ê°€ 소비ì—트 êµ°ì¸ìœ¼ë¡œ 있으니 소비ì—트가 ë‚´ ì¡°êµì´ê² ì§€. 그러나 진심으로 ë‚´ ì¡°êµì´ë¼ëŠ” ìƒê°ì€ 나지 아니하네."
+í•˜ê³ ì €ë… ë¨¹ì„ ë•Œì— ì•½ê°„ ë¶‰ì—ˆë˜ Rì˜ ì–¼êµ´ì€ ì´ìƒí•œ í¥ë¶„으로 ë”ìš± 붉어지오.ìœ ì •ìœ ì •
+R는 ë¨¹ë˜ ë‹´ë°°ë¥¼ 화나는 ë“¯ì´ ìž¬ë–¨ì´ì— ì§‘ì–´ë˜ì§€ë©°,
+"ë‚´ê°€ í•˜ì–¼ë¹ˆì— ì˜¨ 지가 ì¸ì œ 겨우 삼사 ë…„ë°–ì— ì•ˆ ë˜ì§€ë§ˆëŠ” ì¡°ì„ ì‚¬ëžŒ ë•Œë¬¸ì— ë‚˜ëŠ” 견딜 수가 없어. 와서 달ë¼ëŠ” ê²ƒë„ ë‹¬ë¼ëŠ” 것ì´ì§€ë§ˆëŠ” ì¡°ì„ ì‚¬ëžŒì´ ë˜ ì–´ì°Œí•˜ì˜€ëŠë‹ˆ ë˜ ì–´ì°Œí•˜ì˜€ëŠë‹ˆ 하는 불명예한 ë§ì„ ë“¤ì„ ë•Œì—는 나는 ê¸ˆì‹œì— ì£½ì–´ ë²„ë¦¬ê³ ì‹¶ë‹¨ ë§ì¼ì„¸. 내게 가장 불쾌한 ê²ƒì´ ìžˆë‹¤ê³ í•˜ë©´ ê·¸ê²ƒì€ ê³ êµì´ë¼ëŠ” 기억과 ì¡°ì„ ì‚¬ëžŒì˜ ì¡´ìž´ì„¸. ë‚´ê°€ ë§Œì¼ ì–´ëŠ ë‚˜ë¼ì˜ ë…재ìžê°€ ëœë‹¤ê³ 하면 나는 첫째로 ì¡°ì„ ì¸ ìž…êµ ê¸ˆì§€ë¥¼ ë‹¨í–‰í•˜ë ¤ë„¤. ë§Œì¼ ì¡°ì„ ì´ë¼ëŠ” ê²ƒì„ ìžŠì–´ë²„ë¦´ ì•½ì´ ìžˆë‹¤ê³ í•˜ë©´ 나는 ìƒëª…ê³¼ 바꾸어서ë¼ë„ 사 ë¨¹ê³ ì‹¶ì–´."
+í•˜ê³ R는 약간 í¥ë¶„ëœ ì–´ì¡°ë¥¼ 늦추어서,
+"ë‚˜ë„ ëª¨ìŠ¤í¬ë°”ì— ìžˆë‹¤ê°€ ì²˜ìŒ ì›ë™ì— ë‚˜ì™”ì„ ì ì—는 ê¸¸ì„ ë‹¤ë…€ë„ í˜¹ì‹œ ë™í¬ê°€ ëˆˆì— ëœ¨ì´ì§€ë‚˜ 아니하나 í•˜ê³ ì°¾ì•˜ë„¤. 그래서 ì–´ë””ì„œë“ ì§€ ë™í¬ë¥¼ 만나면 ë°˜ê°€ì´ ì†ì„ 잡았지. 했지만 ì ì ê·¸ë“¤ì€ ì˜¤ì§ ê·€ì°®ì€ ì¡´ìž¬ì— ì§€ë‚˜ì§€ 못하다는 ê²ƒì„ ì•Œì•˜ë‹¨ ë§ì¼ì„¸. ì¸ì œëŠ” ì¡°ì„ ì‚¬ëžŒì´ë¼ê³ ë§Œ 하면 만나기가 무ì„ê³ ë”ì°ë”ì°í•˜ê³ ì§„ì €ë¦¬ê°€ 나는 걸 어떡허나. ìžë„¤ ëª…í•¨ì´ ë“¤ì–´ì˜¨ 때ì—ë„ ì¡°ì„ ì‚¬ëžŒì¸ê°€ í•˜ê³ ê°€ìŠ´ì´ ëœ¨ë”했네."
+í•˜ê³ R는 ì›ƒì§€ë„ ì•„ë‹ˆí•˜ì˜¤. ê·¸ì˜ ì–¼êµ´ì—는, êµ°ì¸ë‹¤ìš´ 기운찬 얼굴ì—는 ì¦ì˜¤ì™€ ë¶„ë…¸ì˜ ë¹›ì´ ë„˜ì³¤ì†Œ.
+"ë‚˜ë„ ìžë„¤ ì§‘ì— í™˜ì˜ë°›ëŠ” 나그네는 ì•„ë‹ì„¸ê·¸ë ¤."
+í•˜ê³ ë‚˜ëŠ” ì´ ê²¬ë””ê¸° ì–´ë ¤ìš´ ë¶ˆì¾Œí•˜ê³ ë¬´ì„œìš´ 공기를 완화하기 위하여 ë†ë‹´ì‚¼ì•„ 한 마디를 ë˜ì§€ê³ 웃었소.
+나는 Rì˜ ë§ì´ ê³¼ê²©í•¨ì— ë†€ëžì§€ë§ˆëŠ”, ë˜ ìƒê°í•˜ë©´ Rê°€ 한 ë§ ê°€ìš´ë°ëŠ” ë“¤ì„ ë§Œí•œ ì´ìœ ë„ ì—†ì§€ 아니하오. ê·¸ê²ƒì„ ìƒê°í• ë•Œì— ë‚˜ëŠ” R를 괘씸하게 ìƒê°í•˜ê¸° ì „ì— ë‚´ê°€ 버린다는 ì¡°ì„ ì„ ìœ„í•˜ì—¬ì„œ ê°€ìŠ´ì´ ì•„íŒ ì†Œ. ê·¸ë ‡ì§€ë§Œ ì´ì œ 나 따위가 ê°€ìŠ´ì„ ì•„íŒŒí•œëŒ€ì•¼ 무슨 ì†Œìš©ì´ ìžˆì†Œ. ì¡°ì„ ì— ë‚¨ì•„ ê³„ì‹ í˜•ì´ë‚˜ Rì˜ ë§ì„ ì°¸ê³ ì‚¼ì•„ 쓰시기 ë°”ë¼ì˜¤. 어쨌으나 나는 Rì—게서 목ì 한 ì—¬í–‰ê¶Œì„ ì–»ì—ˆì†Œ. Rì—게는 다만,
+`나는 피곤한 ëª¸ì„ ì¢€ ì •ì–‘í•˜ê³ ì‹¶ë‹¤. 나는 ë‚´ê°€ í‰ì†Œì— ì¦ê²¨í•˜ëŠ” ë°”ì´ì¹¼ 호반ì—서 눈과 ì–¼ìŒì˜ í•œê²¨ìš¸ì„ ì§€ë‚´ê³ ì‹¶ë‹¤.'
+는 ê²ƒì„ ì—¬í–‰ì˜ ì´ìœ 로 삼았소.
+R는 ë‚˜ì˜ ì´ˆì·Œí•œ ëª¨ì–‘ì„ ì§ìž‘í•˜ê³ ë‚´ 핑계를 그럴듯하게 아는 모양ì´ì—ˆì†Œ. ê·¸ë¦¬ê³ ë‚˜ë”러, `ì´ì™• ì •ì–‘í•˜ë ¤ê±°ë“ ì¹´í”„ì¹´ 지방으로 가거ë¼. 거기는 기후 í’ê²½ë„ ì¢‹ê³ ë˜ ìš”ì–‘ì›ì˜ ì„¤ë¹„ë„ ìžˆë‹¤.'는 ê²ƒì„ ë§í•˜ì˜€ì†Œ. ë‚˜ë„ í†¨ìŠ¤í† ì´ì˜ 소설ì—서, ê¸°íƒ€ì˜ ì—¬í–‰ê¸° 등ì†ì—서 ì´ ì§€ë°©ì— ê´€í•œ ë§ì„ 못 ë“¤ì€ ê²ƒì´ ì•„ë‹ˆë‚˜ 지금 ë‚´ 처지ì—는 그런 ë”°ëœ»í•˜ê³ ê²½ì¹˜ ì¢‹ì€ ì§€ë°©ì„ ê°€ë¦´ ì—¬ìœ ë„ ì—†ê³ ë˜ ê·¸ëŸ¬í•œ ì§€ë°©ë³´ë‹¤ë„ ëˆˆê³¼ ì–¼ìŒê³¼ ë°”ëžŒì˜ ì‹œë² ë¦¬ì•„ì˜ ê²¨ìš¸ì´ í•©ë‹¹í•œ 듯하였소.
+그러나 나는 Rì˜ í˜¸ì˜ë¥¼ êµ³ì´ ì‚¬ì–‘í• í•„ìš”ë„ ì—†ì–´ì„œ 그가 ì¨ ì£¼ëŠ” 대로 ì†Œê°œìž¥ì„ ë‹¤ 받아 넣었소. 그는 나를 처남 매부 ê°„ì´ë¼ê³ 소개해 주었소.
+나는 모스í¬ë°” 가는 ë‹¤ìŒ ê¸‰í–‰ì„ ê¸°ë‹¤ë¦¬ëŠ” ì‚¬í˜ ë™ì•ˆ Rì˜ ì§‘ì˜ ì†ì´ ë˜ì–´ì„œ Rë¶€ì²˜ì˜ ì¹œì ˆí•œ 대우를 받았소.
+ê·¸ 후ì—는 나는 R와 ì¡°ì„ ì— ê´€í•œ í† ë¡ ì„ í•œ ì¼ì€ 없지마는 Rê°€ ì´ë¦„지어 ë§ì„ í• ë•Œì—는 ì¡°ì„ ì„ ìžŠì—ˆë…¸ë¼, ê·¸ë¦¬ì›Œí• ê²ƒì´ ì—†ë…¸ë¼, 하지마는 무ì˜ì‹ì 으로 ë§ì„ í• ë•Œì—는 ì¡°ì„ ì„ ëª» ìžŠê³ ë˜ ì¡°ì„ ì„ ì—¬ëŸ¬ ì 으로 그리워하는 ì–‘ì„ ë³´ì•˜ì†Œ. 나는 ê·¸ê²ƒìœ¼ë¡œì¨ ë§Œì¡±í•˜ê²Œ 여겼소.
+나는 ê¸ˆìš”ì¼ ì˜¤í›„ 세시 모스í¬ë°” 가는 급행으로 í•˜ì–¼ë¹ˆì„ ë– ë‚¬ì†Œ. ì—ë‘ì—는 R와 Rì˜ ê°€ì¡±ì´ ë‚˜ì™€ì„œ 꽃과 ê³¼ì¼ê³¼ 여러 가지 ì„ ë¬¼ë¡œ 나를 ì „ì†¡í•˜ì˜€ì†Œ. R와 Rì˜ ê°€ì¡±ì€ ë‚˜ë¥¼ ì •ë§ í˜•ì œì˜ ì˜ˆë¡œ 대우하여 차가 ë– ë‚˜ë ¤ í• ë•Œì— í¬ì˜¹ê³¼ 키스로 작별하여 주었소.
+ì´ ë‚ ì€ í½ ë”°ëœ»í•˜ê³ ì¼ê¸°ê°€ ì¢‹ì€ ë‚ ì´ì—ˆì†Œ. í•˜ëŠ˜ì— êµ¬ë¦„ 한 ì , ë•…ì— ë°”ëžŒ 한 ì ì—†ì´ ë§ˆì¹˜ ëŠ¦ì€ ë´„ë‚ ê³¼ ê°™ì´ ë”°ëœ»í•œ ë‚ ì´ì—ˆì†Œ.
+차는 ë– ë‚¬ì†Œ. íŒë‹¤ëŠ” ë‘¥ 안 íŒë‹¤ëŠ” ë‘¥ ë§ì½ ë§Žì€ ë™ì¤‘로(ì§€ê¸ˆì€ ë¶ë§Œ ì² ë¡œë¼ê³ 하오.)ì˜ êµì œ ì—´ì°¨ì— ëª¸ì„ ì˜íƒí•œ 것ì´ì˜¤.
+송화강(æ¾èŠ±æ±Ÿ:쑹화 ê°•)ì˜ ì² êµë¥¼ 건너오. ì•„ì•„ ê·¸ë¦¬ë„ ë‚¯ìµì€ 송화강! ì†¡í™”ê°•ì´ ì™œ ë‚¯ì´ ìµì†Œ. ì´ ì†¡í™”ê°•ì€ ë¶ˆí•¨ì‚°(장백산)ì— ê·¼ì›ì„ 발하여 광막한 ë¶ë§Œì£¼ì˜ ì‚¬ëžŒë„ ì—†ëŠ” 벌íŒì„ í˜¼ìž ì†Œë¦¬ë„ ì—†ì´ í˜ëŸ¬ê°€ëŠ” ê²ƒì´ ë‚´ ì‹ ì„¸ì™€ 같소. ì´ ë¶ë§Œì£¼ì˜ 벌íŒì„ ë§Œë“ ìžê°€ 송화강ì´ì§€ë§ˆëŠ” 나는 그만한 íž˜ì´ ì—†ëŠ” ê²ƒì´ ë¶€ë„러울 ë¿ì´ì˜¤. ì´ ê´‘ë§‰í•œ ë¶ë§Œì˜ 벌íŒì„ ë‚´ ì†ìœ¼ë¡œ 개척하여서 ì¡°ì„ ì‚¬ëžŒì˜ ë‚™ì›ì„ ë§Œë“¤ìž í•˜ê³ ë½ë‚´ì–´ 볼까. ê·¸ê²ƒì€ í˜•ì´ í•˜ì‹œì˜¤. ë‚´ ì–´ë¦°ê²ƒì´ ìžë¼ê±°ë“ 그놈ì—게나 그러한 ìƒê°ì„ 넣어 주시오.
+ë™ì–‘ì˜ êµì œì ê´´ë¬¼ì¸ í•˜ì–¼ë¹ˆ ì‹œê°€ë„ ê¹Œë§£ê²Œ 안개ì—서 ìŠ¤ëŸ¬ì ¸ ë²„ë¦¬ê³ ë§ì•˜ì†Œ. 그러나 ê·¸ 시가를 싼 까만 ê¸°ìš´ì´ êµì œì í’ìš´ì„ í¬ìž¥í•œ 것ì´ë¼ê³ í• ê¹Œìš”.
+ê°€ë„ê°€ë„ ë²ŒíŒ. ì„œë¦¬ë§žì€ ë§ˆë¥¸ 풀바다. 실개천 í•˜ë‚˜ë„ ì—†ëŠ” 메마른 사막. 어디를 ë³´ì•„ë„ ì‚° 하나 없으니 하늘과 ë•…ì´ ì°© 달ë¼ë¶™ì€ 듯한 천지. 구름 한 ì ì—†ê±´ë§Œë„ ê·¸ í° íƒœì–‘ ê°€ì§€ê³ ë„ ë¯¸ì²˜ 다 비추지 못하여 ì§€í‰ì„ 호를 그린 ì§€í‰ì„ 위ì—는 í•ìƒ í™©í˜¼ì´ ë– ë„는 듯한 세계. ì´ ì†ìœ¼ë¡œ ë‚´ê°€ ëª¸ì„ ë‹´ì€ ì—´ì°¨ëŠ” 서쪽으로 서쪽으로 í•´ê°€ 가는 걸ìŒì„ ë”°ë¼ì„œ ë‹¬ë¦¬ê³ ìžˆì†Œ. 열차가 달리는 바퀴 ì†Œë¦¬ë„ ë°˜í–¥í• ê³³ì´ ì—†ì–´ 힘없는 í•œìˆ¨ê°™ì´ ìŠ¤ëŸ¬ì§€ê³ ë§ˆì˜¤.
+ê¸°ì¨ ê°€ì§„ ì‚¬ëžŒì´ ì§€ë£¨í•´ì„œ 못 견딜 ì´ í’ê²½ì€ ë‚˜ê°™ì´ ìˆ˜ì‹¬ 가진 사람ì—게는 가장 ê³µìƒì˜ ë§ì„ ë‹¬ë¦¬ê¸°ì— í•©ë‹¹í•œ ê³³ì´ì˜¤.
+ì´ ê³³ì—ë„ ì‚°ë„ ìžˆê³ ëƒ‡ë¬¼ë„ ìžˆê³ ì‚¼ë¦¼ë„ ìžˆê³ ê½ƒë„ í”¼ê³ ë‚ ì§ìй, 길ì§ìŠ¹ì´ ë‚ ê³ ê¸°ë˜ ë•Œë„ ìžˆì—ˆê² ì§€ìš”. ê·¸ëŸ¬ë˜ ê²ƒì´ ëª‡ë§Œ ë…„ 지나는 ë™ì•ˆì— ì‚°ì€ ë‚®ì•„ì§€ê³ ê³¨ì€ ë†’ì•„ì ¸ì„œ 마침내 ì´ ê¼´ì´ ëœ ê²ƒì¸ê°€ 하오. ë§Œì¼ í° íž˜ì´ ìžˆì–´ ì´ ê´‘ì•¼ë¥¼ 파낸다 하면 물 íë¥´ê³ ê³ ê¸° ë†€ë˜ ê°•ê³¼, ìš¸ê³ ì›ƒë˜ ìƒë¬¼ì´ ì‚´ë˜ ìžì·¨ê°€ ìžˆì„ ê²ƒì´ì˜¤. ì•„ì•„ ì´ ëª¨ë“ ê¸°ì–µì„ ê½‰ í’ˆê³ ì£½ì€ ë“¯ì´ ìž ìž í•œ 광야ì—!
+ë‚´ê°€ 탄 차가 Fì—ì— ë„ì°©í•˜ì˜€ì„ ë•Œì—는 ë¶ë§Œì£¼ ê´‘ì•¼ì˜ ì„ì–‘ì˜ ì•„ë¦„ë‹¤ì›€ì€ ê·¸ ê·¹ë„ì— ë‹¬í•œ 것 같았소. 둥긋한 ì§€í‰ì„ ìœ„ì— ê±°ì˜ ê±¸ë¦° 커다란 í•´! 아마 ê·¸ ì‹ ë¹„í•˜ê³ ìž¥ì—„í•¨ì´ ë‚´ 경험으로는 ì´ ê³³ì—서밖ì—는 ë³¼ 수 없는 것ì´ë¼ê³ ìƒê°í•˜ì˜¤. ì´ê¸€ì´ê¸€ ì´ê¸€ì´ê¸€ ê·¸ëŸ¬ë©´ì„œë„ ë‘¥ê¸€ë‹¤ëŠ” 체모를 변치 아니하는 ê·¸ 지는 í•´!
+게다가 먼 ì§€í‰ì„ 으로부터 기어드는 í™©í˜¼ì€ ì¸ì œëŠ” 대지를 ê±°ì˜ ë‹¤ ë®ì–´ ë²„ë ¤ì„œ 마른 풀로 ëœ ì§€ë©´ì€ ê°€ë‡ê°€ë‡í•œ ë¹›ì„ ë ê³ ì‚¬ë§‰ì˜ ê°€ëŠ” 모래를 ë¨¸ê¸ˆì€ ì§€ëŠ” í•´ì˜ ê´‘ì„ ì„ ë°˜ì‚¬í•˜ì—¬ì„œ 대기는 ì§™ì€ ìžì¤ë¹›ì„ 바탕으로 한 가지ê°ìƒ‰ì˜ ëª…ì•”ì„ ê°€ì§„, ì˜¤ìƒ‰ì´ ì˜ë¡±í•œ, ë„무지 ë‚´ê°€ ì¼ì° 경험해 ë³´ì§€ 못한 ìƒ‰ì±„ì˜ ì„¸ê³„ë¥¼ ì´ë£¨ì—ˆì†Œ. ì•„ 좋다!
+ê·¸ ì†ì— 수ì€ê°™ì´ 빛나는, 수없는 ìž‘ê³ í° í˜¸ìˆ˜ë“¤ì˜ ë¹›! ê·¸ ì†ìœ¼ë¡œ ë‚ ì•„ì˜¤ëŠ” ìˆ˜ì—†ê³ ì´ë¦„ 모를 ìƒˆë“¤ì˜ ë–¼ë„ ì´ ì„¸ìƒì˜ 것ì´ë¼ê³ 는 ìƒê°í•˜ì§€ 아니하오.
+나는 ê±°ì˜ ë¬´ì˜ì‹ì 으로 ì°¨ì—서 ë›°ì–´ë‚´ë ¸ì†Œ. ê±°ì˜ ë– ë‚ ì‹œê°„ì´ ë‹¤ ë˜ì–´ì„œ ì§ì˜ ì¼ë¶€ë¶„ì€ ë¯¸ì²˜ ê°€ì§€ì§€ë„ ëª»í•˜ê³ ë›°ì–´ë‚´ë ¸ì†Œ. 반쯤 미친 것ì´ì˜¤.
+ì •ê±°ìž¥ 앞 조그마한 ì•„ë¼ì‚¬ ì‚¬ëžŒì˜ ì—¬ê´€ì—다가 ì§ì„ 맡겨 ë²„ë¦¬ê³ ë‚˜ëŠ” ë‹¨ìž¥ì„ ëŒê³ ì² ë„ ì„ ë¡œë¥¼ ë›°ì–´ 건너서 í˜¸ìˆ˜ì˜ ìˆ˜ì€ë¹› 나는 ê³³ì„ ì°¾ì•„ì„œ 지향 ì—†ì´ ê±¸ì—ˆì†Œ.
+한 호수를 가서 ë³´ë©´ ë˜ ì € 편 호수가 ë” ì•„ë¦„ë‹¤ì›Œ ë³´ì´ì˜¤. ì›ì»¨ëŒ€ ì € 지는 í•´ê°€ 다 지기 ì „ì— ì´ ê´‘ì•¼ì— ìžˆëŠ” 호수를 다 ëŒì•„ë³´ê³ ì‹¶ì†Œ.
+ë‚´ê°€ 호숫 ê°€ì— ì„°ì„ ë•Œì— ê·¸ ê±°ìš¸ê°™ì´ ìž”ìž”í•œ í˜¸ìˆ˜ë©´ì— ë¹„ì¹˜ëŠ” ë‚´ 그림ìžì˜ 외로움ì´ì—¬, 그러나 아름다움ì´ì—¬! ê·¸ 호수는 ì˜ì›í•œ ìš°ì£¼ì˜ ì‹ ë¹„ë¥¼ í’ˆê³ í•˜ëŠ˜ì´ ì˜¤ë©´ 하늘ì„, 새가 오면 새를, êµ¬ë¦„ì´ ì˜¤ë©´ 구름ì„, ê·¸ë¦¬ê³ ë‚´ê°€ 오면 나를 비추지 아니하오. 나는 호수가 ë˜ê³ 싶소. 그러나 형! 나는 ì´ í˜¸ìˆ˜ë©´ì—서 얼마나 ì •ìž„ì˜ ì–¼êµ´ì„ ì°¾ì•˜ê² ì†Œ. ê·¸ê²ƒì€ ë¬¼ë¦¬í•™ì 으로 불가능한 ì¼ì´ê² 지요. ë™ê²½ì˜ ë³‘ì‹¤ì— ëˆ„ì›Œ 있는 ì •ìž„ì˜ ëª¨ì–‘ì´ ëª½ê³ ì‚¬ë§‰ì˜ í˜¸ìˆ˜ë©´ì— ë¹„ì¹ ë¦¬ì•¼ ìžˆê² ì†Œ. ì—†ê² ì§€ë§ˆëŠ” 나는 호수마다 ì •ìž„ì˜ ê·¸ë¦¼ìžë¥¼ 찾았소. 그러나 ë³´ì´ëŠ” ê²ƒì€ ì™¸ë¡œìš´ ë‚´ 그림ìžë¿ì´ì˜¤.
+`ê°€ìž. ë없는 사막으로 í•œì—†ì´ ê°€ìž. 가다가 ë‚´ ê¸°ìš´ì´ ì§„í•˜ëŠ” ìžë¦¬ì— 나는 ë‚´ ì†ìœ¼ë¡œ 모래를 íŒŒê³ ê·¸ ì†ì— ë‚´ ëª¸ì„ ë¬»ê³ ì£½ì–´ 버리ìž. 살아서 다시 ë³¼ 수 없는 ì •ìž„ì˜ ã€Œì´ë°ì•„ã€ë¥¼ ì•ˆê³ ì´ ê¹¨ë—한 광야ì—서 죽어 버리 ìž.'
+í•˜ê³ ë‚˜ëŠ” 지는 해를 í–¥í•˜ê³ í•œì • ì—†ì´ ê±¸ì—ˆì†Œ. ì‚¬ë§‰ì´ ë°›ì•˜ë˜ ë”°ëœ»í•œ ê¸°ìš´ì€ ì•„ì§ë„ 다 ì‹ì§€ëŠ” 아니하였소. 사막ì—는 바람 한 ì ë„ ì—†ì†Œ. 소리 í•˜ë‚˜ë„ ì—†ì†Œ. ë°œìžêµ ë°‘ì—서 우는 마른 풀과 ëª¨ëž˜ì˜ ë°”ìŠ¤ë½ê±°ë¦¬ëŠ” 소리가 들릴 ë¿ì´ì˜¤.
+나는 허리를 ì§€í‰ì„ ì— ê±¸ì—ˆì†Œ. ê·¸ ì‹ ë¹„í•œ ê´‘ì„ ì€ ë‚´ 가슴으로부터 위ì—ë§Œì„ ë¹„ì¶”ê³ ìžˆì†Œ.
+ë¬¸ë“ ë‚˜ëŠ” 해를 ë”°ë¼ê°€ëŠ” 별 ë‘ ê°œë¥¼ 보았소. 하나는 ì•žì„ ì„œê³ í•˜ë‚˜ëŠ” 뒤를 섰소. ì•žì˜ ë³„ì€ ì¢€ í¬ê³ ë’¤ì˜ ë³„ì€ ì¢€ 작소. ì´ëŸ° ë³„ë“¤ì€ ì‚° ë§Žì€ ë‚˜ë¼ ë‹¤ì‹œ ë§í•˜ë©´ 서쪽 ì§€í‰ì„ ì„ ë³´ê¸° ì–´ë ¤ìš´ 나ë¼ì—서만 ìƒìž¥í•œ 나로서는 ë³´ì§€ ëª»í•˜ë˜ ë³„ì´ì˜¤. 나는 ê·¸ ë³„ì˜ ì´ë¦„ì„ ëª¨ë¥´ì˜¤. `ë‘ ë³„'ì´ì˜¤.
+í•´ê°€ ì§€í‰ì„ ì—서 ëš ë–¨ì–´ì§€ìž ëŒ€ê¸°ì˜ ìžì¤ë¹›ì€ 남빛으로 변하였소. ì˜¤ì§ í•´ê°€ 금시 들어간 ìžë¦¬ì—ë§Œ 주í™ë¹›ì˜ ì—¬ê´‘ì´ ìžˆì„ ë¿ì´ì˜¤. ë‚´ 눈앞ì—서는 남빛 안개가 피어오르는 듯하였소. ì•žì— ë³´ì´ëŠ” í˜¸ìˆ˜ë§Œì´ ìœ ë‚œížˆ 빛나오. ë˜ í•œ ë–¼ì˜ ì´ë¦„ 모를 ìƒˆë“¤ì´ ìˆ˜ë©´ì„ ìŠ¤ì¹˜ë©° ë‚ ì €ë¬¸ ê²ƒì„ ë†€ë¼ëŠ” ë“¯ì´ ì–´ì§€ëŸ¬ì´ ë‚ ì•„ 지나가오. ê·¸ë“¤ì€ ì†Œë¦¬ë„ ì•„ë‹ˆ 하오. ë‚ ê°œì¹˜ëŠ” ì†Œë¦¬ë„ ì•„ë‹ˆ 들리오. ê·¸ê²ƒë“¤ì€ ì‚¬ë§‰ì˜ í™©í˜¼ì˜ í—ˆê¹¨ë¹„ì¸ ê²ƒ 같소.
+나는 ìžê¾¸ 걷소. 해를 ë”°ë¥´ë˜ ë‚˜ëŠ” ë‘ ë³„ì„ ë”°ë¼ì„œ ìžê¾¸ 걷소.
+ë³„ë“¤ì€ ì§„ 해를 ë”°ë¼ì„œ ë°”ì‚ ê±·ëŠ” ê²ƒë„ ê°™ê³ , 헤매는 나를 ì–´ë–¤ 나ë¼ë¡œ ë„는 ê²ƒë„ ê°™ì†Œ.
+아니 ë‘ ë³„ ì¤‘ì— ì•žì„ ë³„ì´ í•œ 번 ë°˜ì§í•˜ê³ 는 최후로 한 번 ë°˜ì§í•˜ê³ 는 ì§€í‰ì„ ë°‘ì— ìˆ¨ì–´ ë²„ë¦¬ê³ ë§ˆì˜¤. ë’¤ì— ë‚¨ì€ ì™¸ë³„ì˜ ì™¸ë¡œì›€ì´ì—¬! 나는 ìš¸ê³ ì‹¶ì—ˆì†Œ. 그러나 나는 하나만 ë‚¨ì€ ìž‘ì€ ë³„ 외로운 ìž‘ì€ ë³„ì„ ë”°ë¼ì„œ ë” ë¹¨ë¦¬ 걸ìŒì„ 걸었소. ê·¸ 한 ë³„ë§ˆì € 넘어가 버리면 나는 어찌하오.
+ë‚´ê°€ 웬ì¼ì´ì˜¤. 나는 시ì¸ë„ 아니요, ì˜ˆìˆ ê°€ë„ ì•„ë‹ˆì˜¤. 나는 ì •ìœ¼ë¡œ í–‰ë™í•œ ì¼ì€ ì—†ë‹¤ê³ ë¯¿ëŠ” 사람ì´ì˜¤. 그러나 형! ì´ ë•Œì— ë¯¸ì¹œ ê²ƒì´ ì•„ë‹ˆìš”, ë‚´ 가슴ì—는 무엇ì¸ì§€ 모를 ê²ƒì„ ë”°ë¥¼ 요샛ë§ë¡œ ì´ë¥¸ë°” ë™ê²½ìœ¼ë¡œ 찼소.
+`ì•„ì•„ ì € ìž‘ì€ ë³„!'
+ê·¸ê²ƒë„ ì§€í‰ì„ ì— ë‹¿ì•˜ì†Œ.
+`ì•„ì•„ ì € ìž‘ì€ ë³„. ì €ê²ƒë§ˆì € 넘어가면 나는 어찌하나.'
+ì¸ì œëŠ” 어둡소. ê´‘ì•¼ì˜ í™©í˜¼ì€ ëª…ìƒ‰ë¿ì´ìš”, 순ì‹ê°„ì´ìš”, í•´ì§€ìž ì‹ ë¹„í•˜ë‹¤ê³ í• ë§Œí•œ 극히 ì§§ì€ ë™ì•ˆì— 아름다운 í™©í˜¼ì„ ì¡°ê¸ˆ ë³´ì´ê³ 는 ê³§ ì¹ ê³¼ ê°™ì€ ì•”í‘ì´ì˜¤. í˜¸ìˆ˜ì˜ ë¬¼ë§Œì´ ì–´ë””ì„œ ì€ë¹›ì„ 받았는지 뿌옇게 ë‚˜ë§Œì´ ìœ ì¼í•œ 존재다, ë‚˜ë§Œì´ ìœ ì¼í•œ ë¹›ì´ë‹¤ 하는 ë“¯ì´ ì¸ì œëŠ” 수ì€ë¹›ì´ ì•„ë‹ˆë¼ ë‚¨ë¹›ì„ ë°œí•˜ê³ ìžˆì„ ë¿ì´ì˜¤.
+나는 ê·¸ 중 ë¹›ì„ ë§Žì´ ë°›ì€, ê·¸ 중 환해 ë³´ì´ëŠ” í˜¸ìˆ˜ë©´ì„ ì°¾ì•„ ë‘리번거리며, 그러나 ë¹ ë¥¸ 걸ìŒìœ¼ë¡œ 헤매었소. 그러나 ë‚´ê°€ ì¢€ë” ë§‘ì€ í˜¸ìˆ˜ë©´ì„ ì°¾ëŠ” ë™ì•ˆì— ì´ ê´‘ì•¼ì˜ ì–´ë‘ ì€ ë”ìš±ë”ìš± 짙어지오.
+나는 ì–´ë–¤ 조그마한 호숫 ê°€ì— íŽ„ì© ì•‰ì•˜ì†Œ. ë‚´ 앞ì—는 ì§™ì€ ë‚¨ë¹›ì˜ ìˆ˜ë©´ì— ì¡°ê·¸ë§ˆí•œ 거울만한 ë°ì€ ë°ê°€ 있소. 마치 ë‚´ 눈ì—서 무슨 ë¹›ì´ ë‚˜ì™€ì„œ, 아마 ì •ìž„ì„ ê·¸ë¦¬ì›Œí•˜ëŠ” ë¹›ì´ ë‚˜ì™€ì„œ ê·¸ ìˆ˜ë©´ì— ë°˜ì‚¬í•˜ëŠ” 듯ì´. 나는 í—ˆê²ì§€ê² ê·¸ 빤한 ìˆ˜ë©´ì„ ë“¤ì—¬ë‹¤ë³´ì•˜ì†Œ. 혹시나 ì •ìž„ì˜ ëª¨ì–‘ì´ ê±°ê¸° 나타나지나 ì•„ë‹ˆí• ê¹Œ í•˜ê³ . 세ìƒì—는 그러한 기ì ë„ ìžˆì§€ 아니한가 í•˜ê³ .
+물ì—는 ì •ìž„ì˜ ì–¼êµ´ì´ ì–´ë¥¸ê±°ë¦¬ëŠ” 것 같았소. ì´ë”°ê¸ˆ ì •ìž„ì˜ ëˆˆë„ ì–´ë¥¸ê±°ë¦¬ê³ ì½”ë„ ë²ˆëœ»ê±°ë¦¬ê³ ìž…ë„ ë²ˆëœ»ê±°ë¦¬ëŠ” 것 같소. 그러나 ìˆ˜ë©´ì€ ì ì ì–´ë‘워 가서 ê·¸ 환ì˜ì¡°ì°¨ ë”ìš± í¬ë¯¸í•´ì§€ì˜¤.
+나는 í˜¸ìˆ˜ë©´ì— ë¹¤í•˜ë˜ í•œ ì¡°ê°ì¡°ì°¨ 캄캄해지는 ê²ƒì„ ë³´ê³ ìˆ¨ì´ ë§‰íž ë“¯í•¨ì„ ê¹¨ë‹¬ìœ¼ë©´ì„œ ê³ ê°œë¥¼ 들었소.
+ê³ ê°œë¥¼ ë“¤ë ¤ê³ í• ë•Œì—, 형ì´ì—¬, ì´ìƒí•œ ì¼ë„ 다 있소. ê·¸ ìˆ˜ë©´ì— ì •ìž„ì˜ ëª¨ì–‘ì´, 얼굴만 아니ë¼, ê·¸ 몸 ì˜¨í†µì´ ê·¸ 어깨, 가슴, 팔, 다리까지ë„, ê·¸ 눈과 입까지ë„, ê·¸ ì–¼êµ´ì˜ í° ê²ƒê³¼ ìž…ìˆ ì´ ë¶ˆê·¸ë ˆí•œ 것까지ë„, 마치 환한 ëŒ€ë‚®ì— ì‹¤ë¬¼ì„ ëŒ€í•œ 모양으로 소ìƒí•˜ê²Œ 나타났소.
+"ì •ìž„ì´!"
+í•˜ê³ ë‚˜ëŠ” 소리를 지르며 물로 ë›°ì–´ë“¤ë ¤ 하였소. 그러나 형, ê·¸ ìˆœê°„ì— ì •ìž„ì˜ ëª¨ì–‘ì€ ì‚¬ë¼ì ¸ ë²„ë¦¬ê³ ë§ì•˜ì†Œ.
+나는 ì´ ì–´ë‘ ì†ì— ì–´ë”” ì •ìž„ì´ê°€ 나를 ë”°ë¼ì˜¨ ê²ƒê°™ì´ ìƒê°í–ˆì†Œ. 혹시나 ì •ìž„ì´ê°€ 죽어서 ê·¸ ëª¸ì€ ë™ê²½ì˜ 대학 병ì›ì— ë²—ì–´ ë‚´ì–´ë˜ì§€ê³ í˜¼ì´ ë¹ ì ¸ 나와서 ë¬¼ì— ë¹„ì¹˜ì—ˆë˜ ê²ƒì´ ì•„ë‹ê¹Œ, 나는 ê°€ìŠ´ì´ ìš¸ë ê±°ë¦¼ì„ ì§„ì •ì¹˜ 못하면서 호숫 ê°€ì—서 벌떡 ì¼ì–´ë‚˜ì„œ ì–´ë‘ ì†ì— ì •ìž„ì„ ë§Œì ¸ë³´ë ¤ëŠ” 듯ì´, ì–´ë‘워서 ëˆˆì— ë³´ì§€ëŠ” 못하ë”ë¼ë„ ìžê¾¸ 헤매노ë¼ë©´ ëª¸ì— ë¶€ë”ªížˆê¸°ë¼ë„ í• ê²ƒ 같아서 함부로 헤매었소. ê·¸ë¦¬ê³ ëŠ” ëˆˆì•žì— ë²ˆëœ»ê±°ë¦¬ëŠ” ì •ìž„ì˜ í™˜ì˜ì„ íŒ”ì„ ë²Œë ¤ì„œ ì•ˆê³ ì†Œë¦¬ë¥¼ 내어서 ë¶ˆë €ì†Œ.
+"ì •ìž„ì´, ì •ìž„ì´."
+í•˜ê³ ë‚˜ëŠ” ìˆ˜ì—†ì´ ì •ìž„ì„ ë¶€ë¥´ë©´ì„œ 헤매었소.
+그러나 형, ì´ê²ƒë„ 죄지요. ì´ê²ƒë„ 하나님께서 금하시는 ì¼ì´ì§€ìš”. 그러길래 ê´‘ì•¼ì— ì•„ì£¼ ì–´ë‘ ì´ ë®ì´ê³ 새까만 í•˜ëŠ˜ì— ë³„ì´ ì´ì´í•˜ê²Œ ë‚˜ê³ ëŠ” ì˜ ì •ìž„ì˜ í—›ê·¸ë¦¼ìžì¡°ì°¨ 아니 ë³´ì´ì§€ìš”. 나는 죄를 피해서 ì •ìž„ì„ ë– ë‚˜ì„œ 멀리 온 것ì´ë‹ˆ ì •ìž„ì˜ í—›ê·¸ë¦¼ìžë¥¼ ë”°ë¼ë‹¤ë‹ˆëŠ” ê²ƒë„ ì˜³ì§€ 않지요.
+ê·¸ë ‡ì§€ë§Œ ë‚´ê°€ ì´ë ‡ê²Œ 혼ìžì„œ ì •ìž„ì„ ìƒê°ë§Œ 하는 것ì´ì•¼ 무슨 죄 ë ê²ƒì´ ìžˆì„까요. ë‚´ê°€ ì •ìž„ì„ ë§Œ 리나 ë– ë‚˜ì„œ ì´ë ‡ê²Œ 헛그림ìžë‚˜ 그리며 그리워하는 것ì´ì•¼ 무슨 죄가 ë 까요. 설사 죄가 ë˜ê¸°ë¡œì„œë‹ˆ 낸들 ì´ê²ƒê¹Œì§€ì•¼ 어찌하오. ë‚´ê°€ ë‚´ í˜¼ì„ ì£½ì—¬ 버리기 ì „ì—야 ë‚´ 힘으로 어찌하오. 설사 죄가 ë˜ì–´ì„œ ë‚´ê°€ ì§€ì˜¥ì˜ êº¼ì§€ì§€ 않는 ìœ í™©ë¶ˆ ì†ì—서 ì˜ì›í•œ í˜•ë²Œì„ ë°›ê²Œ ë˜ê¸°ë¡œì„œë‹ˆ ê·¸ê²ƒì„ ì–´ì°Œí•˜ì˜¤. 형, ì´ê²ƒ, ì´ê²ƒë„ ë§ì•„야 옳ì€ê°€ìš”. ì •ìž„ì˜ í—›ê·¸ë¦¼ìžê¹Œì§€ë„ ëŠì–´ ë²„ë ¤ì•¼ 옳ì€ê°€ìš”.
+ì´ ë•Œìš”. 바로 ì´ ë•Œìš”. ë‚´ 앞 ìˆ˜ì‹ ë³´ë‚˜ ë 까(캄캄한 ë°¤ì´ë¼ 먼지 가까운지 분명히 알 수 없지마는) 하는 ê³³ì— ë‚œë°ì—†ëŠ” 등불 하나가 나서오. 나는 ê¹œì§ ë†€ë¼ì„œ ìš°ëš ì„°ì†Œ. ì´ ë¬´ì¸ì§€ê²½, ì´ ë°¤ì¤‘ì— ê°‘ìžê¸° ë³´ì´ëŠ” 등불 ê·¸ê²ƒì€ ë§ˆì¹˜ ì´ ì„¸ìƒ ê°™ì§€ 아니하였소.
+ì € ë“±ë¶ˆì´ ì–´ë–¤ 등불ì¼ê¹Œ, ê·¸ ë“±ë¶ˆì´ ëª‡ ê±¸ìŒ ê°€ê¹Œì´ ì˜¤ë‹ˆ, ê·¸ 등불 ë’¤ì— ì‚¬ëžŒì˜ ë‹¤ë¦¬ê°€ ë³´ì´ì˜¤.
+"누구요?"
+하는 ê²ƒì€ ê·€ì— ìµì€ ì¡°ì„ ë§ì´ì˜¤. 어떻게 ì´ ëª½ê³ ì˜ ê´‘ì•¼ì—서 ì¡°ì„ ë§ì„ 들ì„까 í•˜ê³ ë‚˜ëŠ” ë“±ë¶ˆì„ ì²˜ìŒ ë³¼ 때보다 ë”ìš± 놀ëžì†Œ.
+"나는 ì§€ë‚˜ê°€ë˜ ì‚¬ëžŒì´ì˜¤."
+í•˜ê³ ë‚˜ë„ ë“±ë¶ˆì„ í–¥í•˜ì—¬ 마주 걸어갔소.
+ê·¸ ì‚¬ëžŒì€ ë“±ë¶ˆì„ ë“¤ì–´ì„œ ë‚´ ì–¼êµ´ì„ ë¹„ì¶”ì–´ ë³´ë”니,
+"ë‹¹ì‹ ì¡°ì„ ì‚¬ëžŒì´ì˜¤?"
+í•˜ê³ ë¬»ì†Œ.
+"네, 나는 ì¡°ì„ ì‚¬ëžŒì´ì˜¤. ë‹¹ì‹ ë„ ìŒì„±ì„ 들으니 ì¡°ì„ ì‚¬ëžŒì¸ë°, 어떻게 ì´ëŸ° 광야ì—, 아닌 밤중ì—, 여기 계시단 ë§ì´ì˜¤."
+í•˜ê³ ë‚˜ëŠ” 놀ë¼ëŠ” í‘œì • 그대로 대답하였소.
+"나는 ì´ ê·¼ë°©ì— ì‚¬ëŠ” 사람ì´ë‹ˆê¹Œ 여기 오는 ê²ƒë„ ìžˆì„ ì¼ì´ì§€ë§ˆëŠ” ë‹¹ì‹ ì´ì•¼ë§ë¡œ ì´ ì•„ë‹Œ 밤중ì—."
+í•˜ê³ ìœ¡í˜ˆí¬ë¥¼ ì§‘ì–´ë„£ê³ , ì†ì„ 내밀어서 내게 악수를 구하오.
+나는 반갑게 ê·¸ì˜ ì†ì„ 잡았소. 그러나 나는 `ì£½ì„ ì§€ê²½ì— ì–´ë–»ê²Œ 오셨단 ë§ì´ì˜¤.' í•˜ê³ , 그가 ë‚´ê°€ 무슨 ì•…ì˜ë¥¼ 가진 í‰í•œì´ 아닌 ì¤„ì„ ì•Œê³ ì†ì— ë¹¼ì–´ë“¤ì—ˆë˜ ìœ¡í˜ˆí¬ë¡œ 시기를 ìž ê¹ì´ë¼ë„ 노린 ê²ƒì„ ë¶ˆì¾Œí•˜ê²Œ ìƒê°í•˜ì˜€ë˜ 것ì´ì˜¤.
+ê·¸ë„ ë‚´ ì´ë¦„ë„ ë¬»ì§€ ì•„ë‹ˆí•˜ê³ ë˜ ë‚˜ë„ ê·¸ì˜ ì´ë¦„ì„ ë¬»ì§€ ì•„ë‹ˆí•˜ê³ ë‚˜ëŠ” ê·¸ì—게 ëŒë ¤ì„œ 그가 ì¸ë„하는 곳으로 갔소. ê·¸ ê³³ì´ëž€ ê²ƒì€ ì•„ê¹Œ ë“±ë¶ˆì´ ì²˜ìŒ ë‚˜íƒ€ë‚˜ë˜ ê³³ì¸ ë“¯í•œë°, 거기서 ë˜ í•œ 번 놀란 ê²ƒì€ ì–´ë–¤ ë¶€ì¸ì´ 있는 것ì´ì˜¤. 남ìžëŠ” ì•„ë¼ì‚¬ì‹ ì–‘ë³µì„ ìž…ì—ˆìœ¼ë‚˜ ë¶€ì¸ì€ ì¤‘êµ ì˜· 비슷한 ì˜·ì„ ìž…ì—ˆì†Œ. 남ìžëŠ” 나를 ëŒì–´ì„œ ê·¸ ë¶€ì¸ì—게 ì¸ì‚¬í•˜ê²Œ í•˜ê³ ,
+"ì´ëŠ” ë‚´ ì•„ë‚´ìš”."
+í•˜ê³ ë˜ ê·¸ ì•„ë‚´ë¼ëŠ” ë¶€ì¸ì—게는,
+"ì´ ì´ëŠ” ì¡°ì„ ì–‘ë°˜ì´ì˜¤. ì„±í•¨ì´ ë‰˜ì‹œì£ ?"
+í•˜ê³ ê·¸ëŠ” 나를 ë°”ë¼ë³´ì˜¤. 나는,
+"최ì„입니다."
+í•˜ê³ ë°”ë¡œ 대답하였소.
+"ìµœì„ ì”¨?"
+í•˜ê³ ê·¸ 남ìžëŠ” ì†Œê°œí•˜ë˜ ê²ƒë„ ìžŠì–´ë²„ë¦¬ê³ ë‚´ ì–¼êµ´ì„ ë“¤ì—¬ë‹¤ë³´ì˜¤.
+"네, 최ì„입니다."
+"ì•„ â—â—í•™êµ êµìž¥ìœ¼ë¡œ ê³„ì‹ ìµœì„ ì”¨."
+í•˜ê³ ê·¸ 남ìžëŠ” ë”ìš± 놀ë¼ì˜¤.
+"네, 어떻게 ë‚´ ì´ë¦„ì„ ì•„ì„¸ìš”?"
+í•˜ê³ ë‚˜ë„ ê·¸ê°€ 혹시 아는 사람ì´ë‚˜ 아닌가 í•˜ê³ ë“±ë¶ˆ ë¹›ì— ì–¼êµ´ì„ ë“¤ì—¬ë‹¤ 보았으나 ë„무지 ê·¸ ì–¼êµ´ì´ ë³¸ ê¸°ì–µì´ ì—†ì†Œ.
+"최 ì„ ìƒì„ ë‚´ê°€ 압니다. 남 ì„ ìƒí•œí…Œ ë§ì”€ì„ ë§Žì´ ë“¤ì—ˆì§€ìš”. ê·¸ëŸ°ë° ë‚¨ ì„ ìƒë„ ëŒì•„ê°€ì‹ ì§€ê°€ ë²Œì¨ ëª‡ 핸가."
+í•˜ê³ ê°ê°œë¬´ëŸ‰í•œ ë“¯ì´ ê·¸ 아내를 ëŒì•„보오.
+"ì‹ì˜¤ ë…„ì´ì§€ìš”."
+í•˜ê³ ê³ì— ì„°ë˜ ë¶€ì¸ì´ ë§í•˜ì˜¤.
+"ë²Œì¨ ì‹ì˜¤ ë…„ì¸ê°€."
+í•˜ê³ ê·¸ 남ìžëŠ” 나를 ë³´ê³ ,
+"ì •ìž„ì´ ìž˜ ìžëžë‹ˆê¹Œ? ë²Œì¨ ì´ì‹ì´ 넘었지."
+í•˜ê³ ë˜ ë¶€ì¸ì„ ëŒì•„보오.
+"스물세 ì‚´ì´ì§€."
+í•˜ê³ ë¶€ì¸ì´ 확실치 아니한 ë“¯ì´ ëŒ€ë‹µí•˜ì˜¤.
+"네, 스물세 살입니다. 지금 ë™ê²½ì— 있습니다. ë³‘ì´ ë‚˜ì„œ ìž…ì›í•œ ê²ƒì„ ë³´ê³ ì™”ëŠ”ë°."
+í•˜ê³ ë‚˜ëŠ” ë²ˆê°œê°™ì´ ì •ìž„ì˜ ë³‘ì‹¤ê³¼ ì •ìž„ì˜ í˜¸í…” 장면 ë“±ì„ ìƒê°í•˜ê³ ê°€ìŠ´ì´ ì„¤ë ˜ì„ ê¹¨ë‹¬ì•˜ì†Œ. ì˜ì™¸ì¸ ê³³ì—서 ì˜ì™¸ì¸ ì‚¬ëžŒë“¤ì„ ë§Œë‚˜ì„œ ì •ìž„ì˜ ë§ì„ 하게 ëœ ê²ƒì„ ê¸°ë»í•˜ì˜€ì†Œ.
+"무슨 병입니까. ì •ìž„ì´ê°€ 본래 ëª¸ì´ ì•½í•´ì„œ."
+í•˜ê³ ë¶€ì¸ì´ ì§ì ‘ 내게 묻소.
+"네. ëª¸ì´ ì¢€ 약합니다. ë³‘ì´ ì¢€ ë‚˜ì€ ê²ƒì„ ë³´ê³ ë– ë‚¬ìŠµë‹ˆë‹¤ë§ˆëŠ” ì—¼ë ¤ê°€ ë©ë‹ˆë‹¤."
+í•˜ê³ ë‚˜ëŠ” 무ì˜ì‹ì¤‘ì— ê³ ê°œë¥¼ ë™ê²½ì´ 있는 방향으로 ëŒë ¸ì†Œ. 마치 ê³ ê°œë¥¼ ë™ìœ¼ë¡œ ëŒë¦¬ë©´ ì •ìž„ì´ê°€ ë³´ì´ê¸°ë‚˜ í• ê²ƒê°™ì´.
+"ìž, 우리 집으로 갑시다."
+í•˜ê³ ë‚˜ëŠ” ì•„ì§ ê·¸ì˜ ì„±ëª…ë„ ëª¨ë¥´ëŠ” 남ìžëŠ”, ê·¸ì˜ ì•„ë‚´ë¥¼ 재촉하ë”니,
+"우리가 ì¡°ì„ ë™í¬ë¥¼ 만난 ê²ƒì´ ì‹ì—¬ ë…„ ë§Œì´ì˜¤. ê·¸ëŸ°ë° ìµœ ì„ ìƒ, ì´ê²ƒì„ 좀 ë³´ì‹œê³ ê°€ì‹œì§€ìš”."
+í•˜ê³ ê·¸ëŠ” ë¹™ê·¸ë ˆ 웃으면서 나를 서너 ê±¸ìŒ ëŒê³ 가오. 거기는 조그마한 무ë¤ì´ ìžˆê³ ê·¸ 앞ì—는 ì„ ìž ë†’ì´ë‚˜ ë˜ëŠ” 목패를 ì„¸ì› ëŠ”ë° ê·¸ 목패ì—는 `ë‘ ë³„ 무ë¤'ì´ë¼ëŠ” 넉 ìžë¥¼ ì¼ì†Œ.
+ë‚´ê°€ ì´ìƒí•œ 눈으로 ê·¸ 무ë¤ê³¼ 목패를 ë³´ê³ ìžˆëŠ” ê²ƒì„ ë³´ê³ ê·¸ëŠ”,
+"ì´ê²Œ 무슨 무ë¤ì¸ì§€ ì•„ì‹ë‹ˆê¹Œ?"
+í•˜ê³ ìœ ì¾Œí•˜ê²Œ 묻소.
+"ë‘ ë³„ 무ë¤ì´ë¼ë‹ˆ 무슨 뜻ì¸ê°€ìš”?"
+í•˜ê³ ë‚˜ë„ ê·¸ì˜ ìœ ì¾Œí•œ í‘œì •ì— ì „ì—¼ì´ ë˜ì–´ì„œ ì›ƒê³ ë¬¼ì—ˆì†Œ.
+"ì´ê²ƒì€ 우리 ë‘˜ì˜ ë¬´ë¤ì´ì™¸ë‹¤."
+í•˜ê³ ê·¸ëŠ” ì•„ë‚´ì˜ ì–´ê¹¨ë¥¼ 치며 ìœ ì¾Œí•˜ê²Œ 웃었소. ë¶€ì¸ì€ ë¶€ë„러운 ë“¯ì´ ì›ƒê³ ê³ ê°œë¥¼ 숙ì´ì˜¤.
+ë„무지 ëª¨ë‘ ê¿ˆ ê°™ê³ í™˜ì˜ ê°™ì†Œ.
+"ìž ê°‘ì‹œë‹¤. ìžì„¸í•œ ë§ì€ 우리 ì§‘ì— ê°€ì„œ 합시다."
+í•˜ê³ ì„œë„ˆ ê±¸ìŒ ì–´ë–¤ 방향으로 걸어가니 거기는 ë§ì„ 세 í•„ì´ë‚˜ 맨 마차가 있소. ëª½ê³ ì‚¬ëžŒë“¤ì´ ê°€ì¡±ì„ ì‹£ê³ ìˆ˜ì´ˆë¥¼ ë”°ë¼ ëŒì•„다니는 그러한 마차요. ì‚¿ìžë¦¬ë¡œ í™ì˜ˆí˜•ì˜ ì§€ë¶•ì„ ë§Œë“¤ê³ ê·¸ ì†ì— 들어가 앉게 ë˜ì—ˆì†Œ. ê·¸ì˜ ë¶€ì¸ê³¼ 나와는 ì´ ì§€ë¶• ì†ì— ë“¤ì–´ì•‰ê³ ê·¸ëŠ” ì†ìˆ˜ ì–´ìžëŒ€ì— 앉아서 입으로 쮸쮸쮸쮸 í•˜ê³ ë§ì„ 모오. ë“±ë¶ˆë„ êº¼ ë²„ë¦¬ê³ ìº„ìº„í•œ ì†ìœ¼ë¡œ 달리오.
+"ë¶ˆì´ ìžˆìœ¼ë©´ 군대ì—서 ì˜ì‹¬ì„ 하지요. ë„ì ë†ˆì´ ì—¿ë³´ì§€ìš”. 게다가 ë¶ˆì´ ìžˆìœ¼ë©´ ë„리어 ì•žì´ ì•ˆ ë³´ì¸ë‹¨ ë§ìš”. 쯧쯧쯧쯧!"
+하는 소리가 들리오.
+대체 ì´ ì‚¬ëžŒì€ ë¬´ìŠ¨ 사람ì¸ê°€. ë˜ ì´ ë¶€ì¸ì€ 무슨 사람ì¸ê°€ í•˜ê³ ë‚˜ëŠ” ì–´ë‘ìš´ ì†ì—서 í˜¼ìž ìƒê°í•˜ì˜€ì†Œ. 다만 ìž ì‹œ 본 ì¸ìƒìœ¼ë¡œ 보아서 ê·¸ë“¤ì€ í–‰ë³µëœ ë¶€ë¶€ì¸ ê²ƒ 같았소. ê·¸ë“¤ì´ ë¬´ì—‡ 하러 ì´ ì•„ë‹Œ ë°¤ì¤‘ì— ê´‘ì•¼ì— ë‚˜ì™”ë˜ê°€. ë˜ ê·¸ ì´ìƒì•¼ë¦‡í•œ ë‘ ë³„ 무ë¤ì´ëž€ 무엇ì¸ê°€.
+나는 불현듯 ì§‘ì„ ìƒê°í•˜ì˜€ì†Œ. ë‚´ 아내와 ì–´ë¦°ê²ƒë“¤ì„ ìƒê°í•˜ì˜€ì†Œ. ê°€ì •ê³¼ 사회ì—서 쫓겨난 ë‚´ê°€ 아니오. 쫓겨난 ìžì˜ ìƒê°ì€ ì–¸ì œë‚˜ 슬픔ë¿ì´ì—ˆì†Œ.
+나는 ë‚´ 아내를 ì›ë§ì¹˜ 아니하오. 그는 ê²°ì½” 악한 ì—¬ìžê°€ 아니오. 다만 보통 ì—¬ìžìš”. 그는 질투 ë•Œë¬¸ì— ì´ì„±ì˜ íž˜ì„ ìžƒì€ ê²ƒì´ì˜¤. ì—¬ìžê°€ 질투 ë•Œë¬¸ì— ì´ì„±ì„ 잃는 ê²ƒì´ ì²œì§ì´ ì•„ë‹ê¹Œìš”. 그가 나를 사랑하길래 나를 위해서 질투를 가지는 ê²ƒì´ ì•„ë‹ˆì˜¤.
+설사 질투가 그로 하여금 ì¹¼ì„ ë“¤ì–´ ë‚´ ê°€ìŠ´ì„ ì°Œë¥´ê²Œ 하였다 하ë”ë¼ë„ 나는 ê°ì‚¬í•œ ìƒê°ì„ ê°€ì§€ê³ ëˆˆì„ ê°ì„ 것ì´ì˜¤. 사랑하는 ìžëŠ” ì§ˆíˆ¬í•œë‹¤ê³ í•˜ì˜¤. 질투를 누르는 ê²ƒë„ ì•„ë¦„ë‹¤ìš´ ì¼ì´ì§€ë§ˆëŠ” ì§ˆíˆ¬ì— íƒ€ëŠ” ê²ƒë„ ì•„ë¦„ë‹¤ìš´ ì¼ì´ ì•„ë‹ê¹Œìš”.
+ëœí¬ëŸëœí¬ëŸ í•˜ê³ ì°¨ë°”í€´ê°€ ì² ë¡œê¸¸ì„ ë„˜ì–´ê°€ëŠ” 소리가 나ë”니 ì´ìœ½ê³ 마차는 섰소.
+ì•žì— ë¹¨ê°›ê²Œ ë¶ˆì´ ë¹„ì¹˜ì˜¤.
+"ìž ì´ê²Œ 우리 ì§‘ì´ì˜¤."
+í•˜ê³ ê·¸ê°€ 마차ì—서 뛰어내리는 ì–‘ì´ ë³´ì´ì˜¤. ë‚´ë ¤ 보니까 ë‹¬ì´ ì˜¬ë¼ì˜¤ì˜¤. 굉장히 í° ë‹¬ì´, ë¶‰ì€ ë‹¬ì´ ì§€í‰ì„ 으로서 넘ì„í•˜ê³ ì˜¬ë¼ì˜¤ì˜¤.
+ë‹¬ë¹›ì— ë¹„ì¶”ì¸ ë°”ë¥¼ ë³´ë©´ 네모나게 ë‹´ ë‹´ì´ë¼ê¸°ë³´ë‹¤ëŠ” ì„±ì„ ë‘˜ëŸ¬ìŒ“ì€ ë‹¬ 뜨는 곳으로 열린 ëŒ€ë¬¸ì„ ë“¤ì–´ì„œì„œ ë„“ì€ ë§ˆë‹¹ì— ë‚´ë¦° ê²ƒì„ ë°œê²¬í•˜ì˜€ì†Œ.
+"아버지!"
+"엄마!"
+í•˜ê³ ì•„ì´ë“¤ì´ 뛰어나오오. ë§ë§Œí¼ì´ë‚˜ í° ê°œê°€ 네 놈ì´ë‚˜ 꼬리를 ì¹˜ê³ ë‚˜ì˜¤ì˜¤. ê·¸ë†ˆë“¤ì´ ì£¼ì¸ì§‘ 마차 소리를 ì•Œì•„ë“£ê³ ì§–ì§€ 아니한 모양ì´ì˜¤.
+í° ì•„ì´ëŠ” ê³„ì§‘ì• ë¡œ ì—¬ë‚¨ì€ ì‚´, ìž‘ì€ ì•„ì´ëŠ” 사내로 ìœ¡ì¹ ì„¸, ëª¨ë‘ ì¤‘êµ ì˜·ì„ ìž…ì—ˆì†Œ.
+우리는 방으로 들어갔소. ë°©ì€ ì•„ë¼ì‚¬ì‹ ì ˆë°˜, 중êµì‹ ì ˆë°˜ìœ¼ë¡œ ì„¸ê°„ì´ ë†“ì—¬ ìžˆê³ ë²½ì—는 ì¡°ì„ ì§€ë„와 ë‹¨êµ°ì˜ ì´ˆìƒì´ ê±¸ë ¤ 있소.
+그들 부처는 ì§€ë„와 단군 ì´ˆìƒ ì•žì— í—ˆë¦¬ë¥¼ 굽혀 배례하오. ë‚˜ë„ ë¬´ì˜ì‹ì 으로 그대로 하였소.
+그는 차를 마시며 ì´ë ‡ê²Œ ë§í•˜ì˜¤.
+"우리는 ìžì‹ë“¤ì„ ì´ í¥ì•ˆë ¹ 가까운 무변 광야ì—서 기르는 것으로 ë‚™ì„ ì‚¼ê³ ìžˆì§€ìš”. ì¡°ì„ ì‚¬ëžŒë“¤ì€ í•˜ë„ ë§ˆìŒì´ 작아서 ê±±ì •ì´ë‹ˆ ì´ëŸ° 호호탕탕한 ë„“ì€ ë²ŒíŒì—서 길러나면 마ìŒì´ 좀 커질까 하지요. ë˜ í¥ì•ˆë ¹ ë°‘ì—서 지나 중ì›ì„ 통ì¼í•œ ì œì™•ì´ ë§Žì´ ë‚¬ìœ¼ë‹ˆ 혹시나 ê·¸ ì •ê¸°ê°€ 남아 있ì„까 하지요. 우리 ë¶€ì²˜ì˜ ìžì†ì´ 몇 대를 ë‘ê³ í¼ì§€ëŠ” ë™ì•ˆì—는 행여나 ë§ˆìŒ í° ì¸ë¬¼ì´ 하나 둘 ë‚ ëŠ”ì§€ ì•Œê² ì–´ìš”, 하하하하."
+í•˜ê³ ê·¸ëŠ” ì œ ë§ì„ ì œê°€ 비웃는 ë“¯ì´ í•œë°”íƒ• ì›ƒê³ ë‚˜ì„œ,
+"그러나 ì´ê±´ ë‚´ ì§„ì •ì´ì™¸ë‹¤. ìš°ë¦¬ë„ ì´ë ‡ê²Œ ê³ êµì„ ë– ë‚˜ 있지마는 ê·¸ëž˜ë„ ê³ êµ ì†Œì‹ì´ ê¶ê¸ˆí•´ì„œ ì‹ ë¬¸ 하나는 늘 보지요. 하지만 ì–´ë”” 시ì›í•œ 소ì‹ì´ 있어요. ê·¸ì € 조리복소니가 ë˜ì–´ê°€ëŠ” ê²ƒì´ ì•„ë‹ˆë©´ 조그마한 ìƒê°ì„ ê°€ì§€ê³ , 눈곱만한 ì•¼ì‹¬ì„ ê°€ì§€ê³ , 서 푼어치 안 ë˜ëŠ” ì´ìƒì„ ê°€ì§€ê³ ì°§ê³ ê¹Œë¶ˆê³ ì‹¸ìš°ê³ í•˜ëŠ” ê²ƒë°–ì— ì•ˆ ë³´ì´ë‹ˆ ì´ê±° ì–´ë”” ì‚´ 수가 있나. 그래서 나는 ë§ˆìŒ í° ìžì†ì„ 낳아서 길러 볼까 í•˜ê³ ì´ë¥¼í…Œë©´ 새 ë¯¼ì¡±ì„ í•˜ë‚˜ 만들어 볼까 í•˜ê³ , 둘째 단군, 둘째 아브ë¼í•¨ì´ë‚˜ 하나 낳아 볼까 í•˜ê³ í•˜í•˜í•˜í•˜ì•—í•˜."
+í•˜ê³ ìœ ì¾Œí•˜ê²Œ, 그러나 비통하게 웃소.
+나는 ì €ë…ì„ êµ¶ì–´ì„œ ë°°ê°€ ê³ í”„ê³ , ë°¤ê¸¸ì„ ê±¸ì–´ì„œ ëª¸ì´ ê³¤í•œ ê²ƒë„ ìžŠê³ ê·¸ì˜ ë§ì„ 들었소.
+ë¶€ì¸ì´ ê¹€ì´ ë¬´ëŸë¬´ëŸ 나는 í˜¸ë–¡ì„ í° ëšë°°ê¸°ì— ë‹´ê³ ê¹€ì¹˜ë¥¼ ìž‘ì€ ëšë°°ê¸°ì— ë‹´ê³ , ë˜ ë¼ì§€ê³ 기 ì‚¶ì€ ê²ƒì„ í•œ ì ‘ì‹œ 담아다가 íƒìž ìœ„ì— ë†“ì†Œ.
+건넌방ì´ë¼ê³ í• ë§Œí•œ ë°©ì—서 ì –ë¨¹ì´ ìš°ëŠ” 소리가 들리오. ë¶€ì¸ì€ 삼ì‹ì´ë‚˜ ë˜ì—ˆì„까, ë‚¨íŽ¸ì€ ì„œë¥¸ëŒ“ ë˜ì—ˆì„ 듯한 키가 í›¨ì© í¬ê³ 눈과 코가 í¬ê³ ì†ë„ í° ê±´ìž¥í•œ 대장부요, ìŒì„±ì´ 부드러운 ê²ƒì´ ì²´ê²©ì— ì–´ìš¸ë¦¬ì§€ 아니하나 ê·¸ê²ƒì´ ì•„ë§ˆ ê·¸ì˜ ì •ì‹ ìƒí™œì´ ë†’ì€ í‘œê² ì§€ìš”.
+"ì‹ ë¬¸ì—서 최 ì„ ìƒì´ í•™êµë¥¼ ê³ ë§Œë‘시게 ë˜ì—ˆë‹¤ëŠ” ë§ë„ 보았지요. 그러나 나는 ê·¸ê²ƒì´ ë‹¤ 최 ì„ ìƒì—게 대한 중ìƒì¸ ì¤„ì„ ì§ìž‘í•˜ì˜€ê³ , ë˜ ì˜¤ëŠ˜ ì´ë ‡ê²Œ 만나 보니까 ë”구나 ê·¸ê²ƒì´ ë‹¤ 중ìƒì¸ ì¤„ì„ ì•Œì§€ìš”."
+í•˜ê³ ê·¸ëŠ” í™•ì‹ ìžˆëŠ” 어조로 ë§í•˜ì˜¤.
+"ê³ ë§™ìŠµë‹ˆë‹¤."
+나는 ì´ë ‡ê²Œë°–ì— ëŒ€ë‹µí• ë§ì´ 없었소.
+"ì•„, 머, ê³ ë§™ë‹¤ê³ í•˜ì‹¤ ê²ƒë„ ì—†ì§€ìš”."
+í•˜ê³ ê·¸ëŠ” 머리를 뒤로 ì –ížˆê³ í•œì°¸ì´ë‚˜ ìƒê°ì„ 하ë”니 ìš°ì„ ê»„ê»„ 한바탕 ì›ƒê³ ë‚˜ì„œ,
+"ë‚´ê°€ 최 ì„ ìƒì´ ë‹¹í•˜ì‹ ê²½ìš°ì™€ ê¼ ê°™ì€ ê²½ìš°ë¥¼ ë‹¹í•˜ì˜€ê±°ë“ ìš”. ì´ë¥¼í…Œë©´ 과부 ì„¤ì›€ì€ ë™ë¬´ 과부가 안다는 것ì´ì§€ìš”."
+í•˜ê³ ê·¸ëŠ” ìžê¸°ì˜ ë‚´ë ¥ì„ ë§í•˜ê¸° 시작하오.
+"ë‚´ ì§‘ì€ ë³¸ëž˜ 서울입니다. ë‚´ê°€ ì–´ë ¸ì„ ì ì— ë‚´ ì„ ì¹œê»˜ì„œ 시êµì— 대해서 불í‰ì„ í’ˆê³ ë‹¹ì‹ ì‚¼ í˜•ì œì˜ ê°€ì¡±ì„ ëŒê³ ìž¬ì‚°ì„ ëª¨ë‘ íŒ”ì•„ ê°€ì§€ê³ ê°„ë„ì—를 건너오셨지요. ê°„ë„ì— ë§¨ ë¨¼ì € â—â—í•™êµë¥¼ 세운 ì´ê°€ ë‚´ ì„ ì¹œì´ì§€ìš”."
+여기까지 하는 ë§ì„ ë“£ê³ ë‚˜ëŠ” 그가 누구ì¸ì§€ë¥¼ 알았소. 그는 R씨ë¼ê³ ê°„ë„ ê°œì²™ìžìš”, ê°„ë„ì— ì¡°ì„ ì¸ ë¬¸í™”ë¥¼ 세운 ì´ë¡œ ìœ ëª…í•œ ì´ì˜ ì•„ë“¤ì¸ ê²ƒì´ ë¶„ëª…í•˜ì˜¤. 나는 ê·¸ì˜ ì´ë¦„ì´ ëˆ„êµ¬ì¸ì§€ë„ 물어 ë³¼ 것 ì—†ì´ ì•Œì•˜ì†Œ.
+"ì•„ 그러ì‹ë‹ˆê¹Œ. 네, 그러세요."
+í•˜ê³ ë‚˜ëŠ” ê°íƒ„하였소.
+"네, ë‚´ ì„ ì¹œì„ í˜¹ 아실는지요. ì„ ì¹œì˜ ë§ì”€ì´ ë…¸ ê·¸ëŸ¬ì‹ ë‹¨ ë§ì”€ì•¼ìš”. ì¡°ì„ ì‚¬ëžŒì€ ì†ì´ ì¢ì•„서 ëª»ì“´ë‹¤ê³ <ì •ê°ë¡>ì—ë„ ê·¸ëŸ° ë§ì´ ìžˆë‹¤ê³ ì¡°ì„ ì€ ì‚°ì´ ë§Žê³ ë“¤ì´ ì¢ì•„서 ì‚¬ëžŒì˜ ë§ˆìŒì´ 작아서 í°ì¼í•˜ê¸°ê°€ ì–´ë µê³ , í°ì‚¬ëžŒì´ 나기가 ì–´ë µë‹¤ê³ . 웬만치 í°ì‚¬ëžŒì´ 나면 서로 시기해서 í°ì¼í• 새가 ì—†ì´ í•œë‹¤ê³ ê·¸ë ‡ê²Œ <ì •ê°ë¡>ì—ë„ ìžˆë‹¤ë”êµ°ìš”. 그래서 ì„ ì¹œê»˜ì„œ ìžì†ì—게나 í¬ë§ì„ ë¶™ì´ê³ ê°„ë„로 ì˜¤ì‹ ëª¨ì–‘ì´ì§€ìš”. 거기서 ìžë¼ë‚¬ë‹¤ëŠ” ê²ƒì´ ë‚´ 꼴입니다마는, 아하하.
+ë‚´ê°€ ìžë¼ì„œ 아버지께서 ì„¸ìš°ì‹ K여학êµì˜ êµì‚¬ë¡œ ìžˆì„ ë•Œ ì¼ìž…니다. 지금 ë‚´ 아내는 ê·¸ 때 í•™ìƒìœ¼ë¡œ 있었구. ê·¸ëŸ¬ìž ë‚´ 아버지께서 ìž¬ì‚°ì´ ë‹¤ ì—†ì–´ì ¸ì„œ í•™êµë¥¼ ë…담하실 수가 ì—†ê³ , ë˜ ì–¼ë§ˆ 아니해서 아버지께서 ëŒì•„ê°€ì‹œê³ ë³´ë‹ˆ í•™êµì—는 ì„¸ë ¥ ë‹¤íˆ¼ì´ ìƒê²¨ì„œ ì•„ë²„ì§€ì˜ í›„ê³„ìžë¡œ ì¶”ì •ë˜ëŠ” 나를 배척하게 ë˜ì—ˆë‹¨ ë§ì”€ì´ì˜¤. 거기서 나를 배척하는 ìžë£Œë¥¼ ì‚¼ì€ ê²ƒì´ ë‚˜ì™€ 지금 ë‚´ ì•„ë‚´ê°€ ëœ í•™ìƒì˜ 관계란 것ì¸ë° ì´ê²ƒì€ ì „ì—° ë¬´ê·¼ì§€ì„¤ì¸ ê²ƒì€ ë§í• ê²ƒë„ ì—†ì†Œ. ë‚˜ë„ ì´ê°ì´ìš”, 그는 처녀니까 혼ì¸ì„ 하ìžë©´ 못 í• ê²ƒë„ ì—†ì§€ë§ˆëŠ” ê·¸ê²ƒì´ ì‚¬ì œ 관계ë¼ë©´ 중대 ë¬¸ì œê±°ë“ . 그래서 나는 단연히 사ì§ì„ í•˜ê³ ë‚´ê°€ 사ì§í•œ ê²ƒì€ ì œ 죄를 승ì¸í•œ 것ì´ë¼ 하여서 ê·¸ í•™ìƒ ì§€ê¸ˆ ë‚´ ì•„ë‚´ë„ ì¶œêµ ì²˜ë¶„ì„ ë‹¹í•œ 것ì´ì˜¤. ê·¸ëŸ¬ê³ ë³´ë‹ˆ, ê·¸ ì—¬ìžì˜ 아버지 ë‚´ 장ì¸ì´ì§€ìš” ê·¸ ì—¬ìžì˜ 아버지는 나를 ì£½ì¼ ë†ˆê°™ì´ ì›ë§ì„ í•˜ê³ ê·¸ ë”¸ì„ ì£½ì¼ ë…„ì´ë¼ê³ ê°ê¸ˆì„ í•˜ê³ ì–´ì¨Œìœ¼ë‚˜ 조그마한 ê°„ë„ ì‚¬íšŒì—서 í° íŒŒë¬¸ì„ ì¼ìœ¼ì¼°ë‹¨ ë§ì´ì˜¤.
+ì´ ë¬¸ì œë¥¼ ë” í¬ê²Œ ë§Œë“ ê²ƒì€ ì§€ê¸ˆ ë‚´ ì•„ë‚´ì¸, ê·¸ ë”¸ì˜ ìžë°±ì´ì˜¤. 무어ë¼ê³ í–ˆëŠ”ê³ í•˜ë‹ˆ, 나는 ê·¸ ì‚¬ëžŒì„ ì‚¬ëž‘í•˜ì˜¤, ê·¸ 사람한테가 아니면 ì‹œì§‘ì„ ì•ˆ 가오, í•˜ê³ ë»—ëŒ”ë‹¨ ë§ìš”.
+나는 ì´ ì—¬ìžê°€ ì´ë ‡ê²Œ 나를 ìƒê°í•˜ëŠ”ê°€ í• ë•Œ ì˜ë¶„ì‹¬ì´ ë‚˜ì„œ 나는 어떻게 í•´ì„œë“ ì§€ ì´ ì—¬ìžì™€ 혼ì¸í•˜ë¦¬ë¼ê³ ê²°ì‹¬ì„ í•˜ì˜€ì†Œ. 나는 마침내 ì •ì‹ìœ¼ë¡œ K장로ë¼ëŠ” ë‚´ 장ì¸ì—게 ì²í˜¼ì„ 하였으나 ë‹¨ë°•ì— ê±°ì ˆì„ ë‹¹í•˜ê³ ë§ì•˜ì§€ìš”. K장로는 ê·¸ ë”¸ì„ ê°„ë„ì— ë‘는 ê²ƒì´ ì˜³ì§€ ì•Šë‹¤ê³ í•´ì„œ 서울로 보내기로 하였단 ë§ì„ 들었소. 그래서 나는 ìµœí›„ì˜ ê²°ì‹¬ìœ¼ë¡œ ê·¸ ì—¬ìž ì§€ê¸ˆ ë‚´ ì•„ë‚´ ëœ ì‚¬ëžŒì„ ë°ë¦¬ê³ ê°„ë„ì—서 ë„ë§í•˜ì˜€ì†Œ. 하하하하. ë°¤ì¤‘ì— ë‹¨ë‘˜ì´ì„œ.
+지금 같으면야 ì‚¬ì œê°„ì— ê²°í˜¼ì„ í•˜ê¸°ë¡œ 그리 í° ë¬¸ì œê°€ ë ê²ƒì´ ì—†ì§€ë§ˆëŠ” ê·¸ ë•Œì— ì–´ë”” 그랬나요. ì‚¬ì œê°„ì— í˜¼ì¸ì´ëž€ ê²ƒì€ ë¶€ë…€ê°„ì— í˜¼ì¸í•œë‹¤ëŠ” 것과 ê°™ì´ ìƒê°í•˜ì˜€ì§€ìš”. ë”구나 ê·¸ 때 ê°„ë„ ì‚¬íšŒì—는 ì²êµë„ì 사ìƒê³¼ ì—´ë ¬í•œ ì• êµì‹¬ì´ 있어서 ë„ë• í‘œì¤€ì´ ì—¬ê°„ 높지 아니하였지요. 그런 시대니까 ë‚´ê°€ ë‚´ ì œìžì¸ 여학ìƒì„ ë°ë¦¬ê³ 달아난다는 ê²ƒì€ ì‚´ì¸ ê°•ë„를 하는 ì´ìƒìœ¼ë¡œ 무서운 ì¼ì´ì—ˆì§€ìš”. ì§€ê¸ˆë„ ë‚˜ëŠ” ê·¸ë ‡ê²Œ ìƒê°í•©ë‹ˆë‹¤ë§ˆëŠ”.
+그래서 우리 ë‘ ì‚¬ëžŒì€ ìš°ë¦¬ ë‘ ì‚¬ëžŒì´ë¼ëŠ” ê²ƒë³´ë‹¤ë„ ë‚´ ìƒê°ì—는 어찌하였으나 나를 위해서 ì œ ëª©ìˆ¨ì„ ë²„ë¦¬ë ¤ëŠ” ê·¸ì—게 사실 ë‚˜ë„ ë§ˆìŒ ì†ìœ¼ë¡œëŠ” 그를 사랑하였지요. 다만 ì‚¬ì œê°„ì´ë‹ˆê¹Œ ì˜ì›ížˆ ë‹¬í• ìˆ˜ëŠ” 없는 사랑ì´ë¼ê³ 단ë…í•˜ì˜€ì„ ë¿ì´ì§€ìš”. 그러니까 ë¹„ë¡ ë¶€ì²˜ ìƒí™œì€ 못 하ë”ë¼ë„ ë‚´ê°€ ê·¸ì˜ ì‚¬ëž‘ì„ ì•ˆë‹¤ëŠ” 것과 ë‚˜ë„ ê·¸ë¥¼ ì´ë§Œí¼ 사랑한다는 ê²ƒë§Œì„ ë³´ì—¬ 주ìžëŠ” 것ì´ì§€ìš”.
+때는 마침 ê°€ì„ì´ì§€ë§ˆëŠ”, ëª¸ì— ì§€ë‹Œ ëˆë„ 얼마 ì—†ê³ ì²œì‹ ë§Œê³ ë¡œ 길림까지를 나와 ê°€ì§€ê³ ëŠ” 배를 íƒ€ê³ ì†¡í™”ê°•ì„ ë‚´ë ¤ì„œ í•˜ì–¼ë¹ˆì— ê°€ ê°€ì§€ê³ ê±° 기서 ê°„ì‹ ížˆ ì¹˜íƒ€ê¹Œì§€ì˜ ì—¬ë¹„ì™€ ì—¬í–‰ê¶Œì„ ì–»ì–´ ê°€ì§€ê³ ì°¨ë¥¼ íƒ€ê³ ë– ë‚˜ì§€ 않았어요. ê·¸ê²ƒì´ ë°”ë¡œ ì‹ì—¬ ë…„ ì „ 오늘ì´ëž€ ë§ì´ì˜¤."
+ì´ ë•Œì— ë¶€ì¸ì´ 옥수수로 ë§Œë“ êµìˆ˜ì™€ ê°ìž ì‚¶ì€ ê²ƒì„ ê°€ì§€ê³ ë“¤ì–´ì˜¤ì˜¤.
+나는 Rì˜ ë§ì„ ë“£ë˜ ëì´ë¼ ìœ ì‹¬ížˆ ë¶€ì¸ì„ ë°”ë¼ë³´ì•˜ì†Œ. 그는 중키나 ë˜ëŠ” 둥근 ì–¼êµ´ì´ í˜ˆìƒ‰ì´ ì¢‹ê³ í†µí†µí•˜ì—¬ 미ì¸ì´ë¼ê¸°ë³´ë‹¤ëŠ” 씩씩한 ì—¬ìžìš”. 그런 ì¤‘ì— ì¡°ì„ ì—¬ìžë§Œì´ 가지는 ì•„ë‹´í•˜ê³ ì ìž–ì€ ë§›ì´ ìžˆì†Œ.
+"앉으시지요. 지금 ë‘ ë¶„ê»˜ì„œ ì²˜ìŒ ì‚¬ëž‘í•˜ì‹œë˜ ë§ì”€ì„ ë“£ê³ ìžˆìŠµë‹ˆë‹¤."
+í•˜ê³ ë‚˜ëŠ” ë¶€ì¸ì—게 êµì˜ë¥¼ 권하였소.
+"ì•„ì´, 그런 ë§ì”€ì€ 왜 하시오."
+í•˜ê³ ë¶€ì¸ì€ ê°‘ìžê¸° ì‹ ë…„ì´ë‚˜ ì–´ë ¤ì§€ëŠ” 모양으로 수삽한 ë¹›ì„ ë³´ì´ê³ ê³ ê°œë¥¼ 숙ì´ê³ 달아나오.
+"그래서요. 그래 ì˜¤ëŠ˜ì´ ê¸°ë…ì¼ì´ì™¸ë‹¤ê·¸ë ¤."
+í•˜ê³ ë‚˜ë„ ì›ƒì—ˆì†Œ.
+"ê·¸ë ‡ì§€ìš”. 우리는 해마다 ì˜¤ëŠ˜ì´ ì˜¤ë©´ 우리 무ë¤ì— 성묘를 가서 í•˜ë£»ë°¤ì„ ìƒˆìš°ì§€ìš”. ì˜¤ëŠ˜ì€ ì†ë‹˜ì´ 오셔서 ì¤‘ê°„ì— ëŒì•„왔지만, 하하하하."
+í•˜ê³ ê·¸ëŠ” ìœ ì¾Œí•˜ê²Œ 웃소.
+"성묘ë¼ë‹ˆ?"
+í•˜ê³ ë‚˜ëŠ” 물었소.
+"아까 ë³´ì‹ ë‘ ë³„ ë¬´ë¤ ë§ì´ì˜¤. ê·¸ê²ƒì´ ìš°ë¦¬ ë‚´ì™¸ì˜ ë¬´ë¤ì´ì§€ìš”. 하하하하."
+"…………."
+나는 ì˜ë¬¸ì„ ëª¨ë¥´ê³ ê°€ë§Œížˆ 앉았소.
+"ë‚´ ì´ì•¼ê¸°ë¥¼ 들으시지요. 그래 둘ì´ì„œ 차를 íƒ€ê³ ì˜¤ì§€ ì•Šì•˜ê² ì–´ìš”. ë¬¼ë¡ ì—¬ì „ížˆ ì„ ìƒë‹˜ê³¼ ì œìžì§€ìš”. ê·¸ë ‡ì§€ë§Œ 워낙 여러 ë‚ ë‹¨ë‘˜ì´ì„œ ê°™ì´ ê³ ìƒì„ í•˜ê³ ì—¬í–‰ì„ í–ˆìœ¼ë‹ˆ ì‚¬ëž‘ì˜ ë¶ˆê¸¸ì´ íƒˆ 것ì´ì•¼ ë¬¼ë¡ ì•„ë‹ˆê² ì–´ìš”. 다만 ì‚¬ì œë¼ëŠ” êµ³ì€ ì˜ë¦¬ê°€ ê·¸ê²ƒì„ ê²‰ì— ë‚˜ì˜¤ì§€ 못하ë„ë¡ ëˆ„ë¥¸ 것ì´ì§€ìš”. â€¦â€¦ê·¸ëŸ°ë° ê¼ ì˜¤ëŠ˜ê°™ì´ ì¢‹ì€ ë‚ ì¸ë° 여기는 대개 ì¼ê¸°ê°€ ì¼ì •합니다. 좀체로 비가 오는 ì¼ë„ ì—†ê³ í리는 ë‚ ë„ ì—†ì§€ìš”. í—Œë° Fì—ì—를 오니까 ì°¸ ì„ì–‘ 경치가 좋단 ë§ì´ì˜¤. ê·¸ ë•Œì— ë¶ˆí˜„ë“¯, ì—ë¼ ì—¬ê¸°ì„œ ë‚´ë ¤ì„œ ì´ ì„ì–‘ ì†ì— ì € 호숫 ê°€ì— ë‘˜ì´ì„œ 헤매다가 깨ë—ì´ ì‚¬ì œì˜ ëª¸ìœ¼ë¡œ ì´ ê¹¨ë—한 ê´‘ì•¼ì— ë¬»í˜€ ë²„ë¦¬ìž í•˜ëŠ” ìƒê°ì´ ë‚˜ê² ì§€ìš”. 그래 ê·¸ 때 ë§ì„ ë‚´ ì•„ë‚´ ê·¸ 때ì—는 ì•„ì§ ì•„ë‚´ê°€ 아니지요 ë‚´ ì•„ë‚´ì—게 그런 ë§ì„ 하였ë”니 ì°¸ ì¢‹ë‹¤ê³ ë°•ìž¥ì„ í•˜ê³ ë‚´ ì–´ê¹¨ì— ë§¤ë‹¬ë¦¬ëŠ”êµ¬ë ¤. 그래서 우리 ë‘˜ì€ ì°¨ê°€ ê±°ì˜ ë– ë‚ ìž„ë°•í•´ì„œ ì°¨ì—서 ë›°ì–´ë‚´ë ¸ì§€ìš”."
+í•˜ê³ ê·¸ëŠ” 그때 ê´‘ê²½ì„ ëˆˆì•žì— ê·¸ë¦¬ëŠ” 모양으로 ë§ì„ ëŠê³ ìš°ë‘커니 í—ˆê³µì„ ë°”ë¼ë³´ì˜¤. 그러나 ê·¸ì˜ ìž… ì–¸ì €ë¦¬ì—는 ìœ ì¾Œí•œ íšŒê³ ì—서 나오는 웃ìŒì´ì—ˆì†Œ.
+"ì´ì•¼ê¸° 다 ë났어요?"
+í•˜ê³ ë¶€ì¸ì´ í¬ë°”스ë¼ëŠ” ì²ëŸ‰ ìŒë£Œë¥¼ ë“¤ê³ ë“¤ì–´ì˜¤ì˜¤.
+"아니오. ì´ì œë¶€í„°ê°€ ì •í†µì´ë‹ˆ ë‹¹ì‹ ë„ ê±°ê¸° 앉으시오. 지금 ì°¨ì—서 내린 ë°ê¹Œì§€ ì™”ëŠ”ë° ë‹¹ì‹ ë„ ì•‰ì•„ì„œ 한 파트를 맡으시오."
+í•˜ê³ R는 ë¶€ì¸ì˜ ì†ì„ 잡아서 ìžë¦¬ì— 앉히오. ë¶€ì¸ë„ 웃으면서 앉소.
+"최 ì„ ìƒ ì²˜ì§€ê°€ ê¼ ë‚˜ì™€ 같단 ë§ìš”. ì •ìž„ì˜ ì²˜ì§€ê°€ ë‹¹ì‹ ê³¼ ê°™ê³ ."
+í•˜ê³ ê·¸ëŠ” ë§ì„ 계ì†í•˜ì˜¤.
+"그래 ì°¨ì—서 ë‚´ë ¤ì„œ 나는 ì´ ì–‘ë°˜í•˜ê³ ë¬¼ì„ ì°¾ì•„ 헤매었지요. ì•„ë”°, ì„ì–‘ì´ ì–´ë–»ê²Œ 좋ì€ì§€ ì´ ì–‘ë°˜ì€ ë°•ìž¥ì„ í•˜ê³ ë…¸ëž˜ë¥¼ ë¶€ë¥´ê³ ìš°ë¦¬ ë‘˜ì€ ë§ˆì¹˜ ìœ ì¾Œí•˜ê²Œ 산보하는 사람 같았지요."
+"ì°¸ 좋았어요. ê·¸ 때ì—는 ì°¸ 좋았어요. ê·¸ ì„ì–‘ì— ë¹„ì¹œ 광야와 호수ë¼ëŠ” ê±´ 어떻게 좋ì€ì§€ ê·¸ ìˆ˜ì€ ê°™ì€ ë¬¼ ì†ì— 텀벙 ë›°ì–´ë“¤ê³ ì‹¶ì—ˆì–´ìš”. ê·¸ 후엔 해마다 ë³´ì•„ë„ ê·¸ë§Œ 못해."
+í•˜ê³ ë¶€ì¸ì´ ì°¸ê²¬ì„ í•˜ì˜¤.
+ì•„ì´ë“¤ì€ 다 ìžëŠ” 모양ì´ì˜¤.
+"그래 ì§€í–¥ì—†ì´ í—¤ë§¤ëŠ”ë° í•´ëŠ” 뉘엿뉘엿 넘어가구, ì–´ìŠ¤ë¦„ì€ ê¸°ì–´ë“¤ê³ ê·¸ 때 마침 하늘ì—는 별 ë‘˜ì´ ë‚˜íƒ€ë‚¬ë‹¨ ë§ì´ì•¼. ê·¸ê²ƒì„ ì´ ì—¬í•™ìƒì´ ë¨¼ì € ë³´ê³ ì„œ ê°‘ìžê¸° 추연해지면서 ì„ ìƒë‹˜ ì € 별 보셔요, ì•žì„ í° ë³„ì€ ì„ ìƒë‹˜ì´ 구 ë”°ë¼ê°€ëŠ” ìž‘ì€ ë³„ì€ ì €ì•¼ìš”, í•˜ê² ì§€ìš”. ê·¸ ë§ì´, ë˜ ê·¸ 태ë„ê°€ 어떻게 ê°€ë ¨í•œì§€. 그래서 나는 í•˜ëŠ˜ì„ ë°”ë¼ë³´ë‹ˆê¹ 과연 별 ë‘ ê°œê°€ 지는 해를 따르는 ë“¯ì´ ë”°ë¼ê°„다 ë§ìš”. ë§ì„ ë“£ê³ ë³´ë‹ˆ 과연 우리 ì‹ ì„¸ì™€ë„ ê°™ì§€ 않아요?
+ê·¸ë¦¬ê³ ëŠ” ì´ ì‚¬ëžŒì´ ë˜ ì´ëŸ½ë‹ˆë‹¤ê·¸ë ¤ `ì„ ìƒë‹˜, ì•žì„ í° ë³„ì€ ì•„ë¬´ë¦¬ ë”°ë¼ë„ ì € ìž‘ì€ ë³„ì€ ì˜ì›ížˆ ë”°ë¼ìž¡ì§€ ëª»í•˜ê² ì§€ìš”. ì˜ì›ížˆ ì˜ì›ížˆ ë”°ë¼ê°€ë‹¤ê°€ ë”°ë¼ê°€ë‹¤ê°€ 못 해서 마침내는 ì € ìž‘ì€ ë³„ì€ ì£½ì–´ì„œ ê²€ì€ ìž¬ê°€ ë˜ê³ ë§ê² 지요? ì € ìž‘ì€ ë³„ì´ ì œ ì‹ ì„¸ì™€ 어쩌면 그리 ê°™ì„까.' í•˜ê³ í•œíƒ„ì„ í•˜ê² ì§€ìš”. ê·¸ ë•Œì— í•œíƒ„ì„ í•˜ê³ ëˆˆë¬¼ì„ í˜ë¦¬ê³ 섰는 어린 ì²˜ë…€ì˜ ì„ì–‘ë¹›ì— ë¹„ì·¬ ëª¨ì–‘ì„ ìƒìƒí•´ 보세요, 하하하하. ê·¸ 때ì—는 ë‹¹ì‹ ë„ ë¯¸ì¸ì´ì—ˆì†Œ. 하하하하."
+í•˜ê³ ë‚´ì™¸ê°€ ìœ ì¾Œí•˜ê²Œ 웃는 ê²ƒì„ ë³´ë‹ˆ 나는 ë”ìš± ì 막하여ì§ì„ 깨달았소. 어쩌면 ê·¸ ì„ì–‘, ê·¸ ë‘ ë³„ì´ ì´ë“¤ì—게와 내게 ê¼ ê°™ì€ ì¸ìƒì„ 주었ì„까 하니 참으로 ì´ìƒí•˜ë‹¤ 하였소.
+"그래 ì¸ì œ."
+í•˜ê³ R는 다시 ì´ì•¼ê¸°ë¥¼ 계ì†í•˜ì˜¤.
+"그래 ì¸ì œ 둘ì´ì„œ 그야ë§ë¡œ ê°ê°œë¬´ëŸ‰í•˜ê²Œ ë‘ ë³„ì„ ë°”ë¼ë³´ë©° 걸었지요. 그러다가 í•´ê°€ ë„˜ì–´ê°€ê³ ì•žì„ í° ë³„ì´ ë„˜ì–´ê°€ê³ ê·¸ë¦¬ê³ ëŠ” 혼ìžì„œ ê¹œë¹¡ê¹œë¹¡í•˜ê³ ê°€ë˜ ìž‘ì€ ë³„ì´ ë„˜ì–´ê°€ë‹ˆ 우리는 그만 ë•…ì— ì£¼ì €ì•‰ì•˜ì†Œ. 거기가 ì–´ë”˜ê³ í•˜ë‹ˆ ê·¸ ë‘ ë³„ 무ë¤ì´ 있는 ê³³ì´ì§€ìš”. `ì„ ìƒë‹˜ ì €ë¥¼ 여기다가 파묻어 ì£¼ì‹œê³ ê°€ì…”ìš”. ì„ ìƒë‹˜ ì†ìˆ˜ ì €ë¥¼ 여기다가 묻어 ë†“ê³ ê°€ 주셔요.' í•˜ê³ ì´ ì‚¬ëžŒì´ ì¡°ë¥´ì§€ìš”."
+하는 ê²ƒì„ ë¶€ì¸ì€,
+"ë‚´ê°€ ì–¸ì œ."
+í•˜ê³ ë‚¨íŽ¸ì„ í˜ê²¨ë³´ì˜¤.
+"그럼 무ì—ë¼ê³ 했소? ì–´ë”” 본ì¸ì´ 한 번 옮겨 보오."
+í•˜ê³ Rê°€ ë§ì„ ëŠì†Œ.
+"ê°„ë„를 ë– ë‚œ 지가 한 ë‹¬ì´ ë˜ë„ë¡ ë‹¨ë‘˜ì´ ë‹¤ë…€ë„ ìš”ë§Œí¼ë„ 귀해 주는 ì ì´ ì•ˆ 뵈니 그럼 파묻어 달ë¼ê³ 안 í•´ìš”?"
+í•˜ê³ ë¶€ì¸ì€ 웃소.
+"í¥í¥."
+í•˜ê³ R는 ë¶€ì¸ì˜ ë§ì— ì›ƒê³ ë‚˜ì„œ,
+"ê·¸ ìžë¦¬ì— 묻어 달란 ë§ì„ 들으니까, 어떻게 측ì€í•œì§€, 그럼 ë‚˜ë„ í•¨ê»˜ 묻히ìžê³ 그랬지요. 나는 ê·¸ ë•Œì— ì°¸ë§ ê·¸ ìžë¦¬ì— 함께 ë¬»ížˆê³ ì‹¶ì—ˆì–´ìš”. 그래서 나는 ì†ìœ¼ë¡œ ê³§ 구ë©ì´ë¥¼ íŒ ì§€ìš”. 떡가루 ê°™ì€ ëª¨ëž˜íŒì´ë‹ˆê¹Œ 파기는 íž˜ì´ ì•„ë‹ˆ ë“¤ê² ì§€ìš”. ì´ì´ë„ 물ë„러미 ë‚´ê°€ ë•…ì„ íŒŒëŠ” ê²ƒì„ ë³´ê³ ì„°ë”니만 ìžê¸°ë„ 파기를 ì‹œìž‘í•˜ê² ì§€ìš”."
+í•˜ê³ ë‚´ì™¸ê°€ 다 웃소.
+"그래 순ì‹ê°„ì—……."
+í•˜ê³ R는 ì´ì•¼ê¸°ë¥¼ 계ì†í•˜ì˜¤.
+"순ì‹ê°„ì— ë‘˜ì´ ë“œëŸ¬ëˆ„ìš¸ 만한 구ë©ì´ë¥¼ 아마 ë‘ ìž ê¹Šì´ë‚˜ ë˜ê²Œ, 네모나게 파 ë†“ê³ ëŠ” ë‚´ê°€ 들어가 누워 ë³´ê³ ê·¸ëŸ¬ê³ ëŠ” ë˜ íŒŒê³ í•˜ì—¬ 아주 편안한 구ë©ì´ë¥¼ íŒŒê³ ë‚˜ì„œëŠ” 나는 아주 세ìƒì„ 하ì§í• 셈으로 ì‚¬ë°©ì„ ë‘˜ëŸ¬ë³´ ê³ ì‚¬ë°©ì´ëž˜ì•¼ 컴컴한 ì–´ë‘ ë°–ì— ì—†ì§€ë§Œ ì‚¬ë°©ì„ ë‘˜ëŸ¬ë³´ê³ , ì´ë¥¼í…Œë©´ 세ìƒê³¼ ìž‘ë³„ì„ í•˜ê³ ë“œëŸ¬ëˆ„ì› ì§€ìš”. 지금 ì´ë ‡ê²Œ íšŒê³ ë‹´ì„ í• ë•Œì—는 ìš°ìŠµê¸°ë„ í•˜ì§€ë§ˆëŠ” ê·¸ 때ì—는 참으로 종êµì ì´ë¼ í• ë§Œí•œ 엄숙ì´ì—ˆì†Œ. 그때 우리 ë‘˜ì˜ ì²˜ì§€ëŠ” ì•žë„ ì ˆë²½, ë’¤ë„ ì ˆë²½ì´ì–´ì„œ 죽는 ê¸¸ë°–ì— ì—†ì—ˆì§€ìš”. ë˜ ê·¸ë¿ ì•„ë‹ˆë¼ ì¸ìƒì˜ 가장 깨ë—í•˜ê³ ê°€ìž¥ ì‚¬ëž‘ì˜ ë§‘ì€ ì •ì´ íƒ€ê³ ê°€ìž¥ 기ì˜ê³ ë„ ìŠ¬í”„ê³ ë„ ì´ë¥¼í…Œë©´ ëª¨ë“ ê°ì •ì´ ì ˆì •ì— ë‹¬í•˜ê³ , 그러한 ìˆœê°„ì— ëª©ìˆ¨ì„ ëŠì–´ 버리는 ê²ƒì´ ê°€ìž¥ ì¢‹ì€ ì¼ì´ìš”, 가장 마땅한 ì¼ê°™ì´ ìƒê°í•˜ì˜€ì§€ìš”. ê´‘ì•¼ì— ì•„ë¦„ë‹¤ìš´ í™©í˜¼ì´ ìˆœê°„ì— ìŠ¤ëŸ¬ì§€ëŠ” 모양으로 우리 ë‘ ìƒëª…ì˜ ì•„ë¦„ë‹¤ì›€ë„ ìˆœê°„ì— ìŠ¤ëŸ¬ì§€ìžëŠ” 우리는 ì² í•™ìžë„ 시ì¸ë„ 아니지마는 ìš°ë¦¬ë“¤ì˜ í™˜ê²½ì´ ìš°ë¦¬ 둘ì—게 그러한 ìƒê°ì„ 넣어 준 것ì´ì§€ìš”.
+그래서 ë‚´ê°€ 가만히 드러누워 있는 ê²ƒì„ ì €ì´ê°€ 물ë„러미 ë³´ê³ ìžˆë”니 ìžê¸°ë„ ë‚´ ê³ì— 들어와 ëˆ•ê² ì§€ìš”. 그런 ë’¤ì—는 í™©í˜¼ì— ë‚¨ì€ ë¹›ë„ ë‹¤ ìŠ¤ëŸ¬ì§€ê³ ì•„ì£¼ 캄캄한 ì•”í‘ ì„¸ê³„ê°€ ë˜ì–´ ë²„ë ¸ì§€ìš”. í•˜ëŠ˜ì— ì–´ë–»ê²Œ ê·¸ë ‡ê²Œ ë³„ì´ ë§Žì€ì§€. 가만히 í•˜ëŠ˜ì„ ë°”ë¼ë³´ë…¸ë¼ë©´ ì°¸ ë³„ì´ ë§Žì•„ìš”. 우주란 ì°¸ 커요. ê·¸ëŸ°ë° ì´ ëì—†ì´ í° ìš°ì£¼ì— í•œì—†ì´ ë§Žì€ ë³„ë“¤ì´ ë‹¤ ì œìžë¦¬ë¥¼ ì§€í‚¤ê³ ì œ ê¸¸ì„ ì§€ì¼œì„œ 서로 ë¶€ë”ªì§€ë„ ì•„ë‹ˆí•˜ê³ ëì—†ì´ ê¸´ ì‹œê°„ì— ì§ˆì„œë¥¼ ìœ ì§€í•˜ê³ ìžˆëŠ” ê²ƒì„ ë³´ë©´ 우주ì—는 ì–´ë–¤ 주재하는 뜻, ì„리하는 ëœ»ì´ ìžˆë‹¤ 하는 ìƒê°ì´ ë‚˜ê² ì§€ìš”. ë‚˜ë„ ì˜ˆìˆ˜êµì¸ì˜ ê°€ì •ì—서 ìžë¼ë‚¬ì§€ë§ˆëŠ” ì´ ë•Œì²˜ëŸ¼ 하나님ì´ë¼ í• ê¹Œ ì´ë¦„ì€ ë¬´ì—‡ì´ë¼ê³ í•˜ë“ ì§€ ê°„ì— ìš°ì£¼ì˜ ì„리ìžì˜ 존재를 ê°•ë ¬í•˜ê²Œ ì˜ì‹í•œ ì¼ì€ 없었지요.
+ê·¸ë ‡ì§€ë§Œ `ì‚¬ëžŒì˜ ë§ˆìŒì— 비기면 ì €ê¹Œì§“ ë³„ë“¤ì´ ë‹¤ 무엇ì´ì˜¤?' í•˜ê³ ê·¸ë•Œ 겨우 ì—´ì—¬ëŸ ì‚´ë°–ì— ì•ˆ ëœ ì´ì´ê°€ ë‚´ ê·€ì— ìž…ì„ ëŒ€ê³ ë§í• 때ì—는 ë‚˜ë„ ì°¸ìœ¼ë¡œ 놀ëžìŠµë‹ˆë‹¤. 나ì´ëŠ” 나보다 오륙 ë…„ ìƒê´€ë°–ì— ì•ˆ ë˜ì§€ë§ˆëŠ” ì´ì‹ 세 ë‚´ì™¸ì— ì˜¤ë¥™ ë…„ ìƒê´€ì´ ì ì€ ê²ƒì¸ê°€ìš”? 게다가 나는 ì„ ìƒì´ìš” ìžê¸°ëŠ” í•™ìƒì´ë‹ˆê¹Œ ì–´ë¦°ì• ë¡œë§Œ ì•Œì•˜ë˜ ê²ƒì´ ê·¸ëŸ° ë§ì„ 하니 놀ëžì§€ 않아요? 어째서 ì‚¬ëžŒì˜ ë§ˆìŒì´ í•˜ëŠ˜ë³´ë‹¤ë„ ë” ì´ìƒí• 까 í•˜ê³ ë‚´ê°€ 물으니까, ê·¸ ëŒ€ë‹µì´ `나는 무엇ì´ë¼ê³ ì„¤ëª…í• ìˆ˜ê°€ 없지마는 ë‚´ ë§ˆìŒ ì†ì— ì¼ì–´ë‚˜ëŠ” ê²ƒì´ í•˜ëŠ˜ì´ë‚˜ ë•…ì— ì¼ì–´ë‚˜ëŠ” ëª¨ë“ ê²ƒë³´ë‹¤ë„ ë” ì•„ë¦„ë‹µê³ ë” ì•Œ 수 ì—†ê³ ë” ëœ¨ê²ê³ 그런 것 같아요.' ê·¸ëŸ¬ê² ì§€ìš”. ìƒëª…ì´ëž€ ëª¨ë“ ì•„ë¦„ë‹¤ìš´ 것 ì¤‘ì— ê°€ìž¥ 아름다운 것ì´ë¼ëŠ” ê²ƒì„ ë‚˜ëŠ” 깨달았어요. ê·¸ ë§ì—, `ê·¸ë ‡ë‹¤ 하면 ì´ ì•„ë¦„ë‹µê³ ì‹ ë¹„í•œ ìƒëª…ì„ ë‚´ëŠ” 우주는 ë” ì•„ë¦„ë‹¤ìš´ ê²ƒì´ ì•„ë‹ˆì˜¤?' í•˜ê³ ë‚´ê°€ 반문하니까, ë‹¹ì‹ (ë¶€ì¸ì„ 향하여) ë§ì´, `ì „ ëª¨ë¥´ê² ì–´ìš”, 어쨌으나 ì „ 행복합니다. ì €ëŠ” ì´ í–‰ë³µì„ ê¹¨ëœ¨ë¦¬ê³ ì‹¶ì§€ 않습니다. ë†“ì³ ë²„ë¦¬ê³ ì‹¶ì§€ 않습니다. ì´ í–‰ë³µ ì„ ìƒë‹˜ ê³ì— 있는 ì´ í–‰ë³µì„ ê½‰ ì•ˆê³ ì£½ê³ ì‹¶ì–´ìš”.' 그러지 않았소?"
+"누가 그랬어요? ì•„ì´ ë‚œ 다 ìžŠì–´ë²„ë ¸ì–´ìš”."
+í•˜ê³ ë¶€ì¸ì€ 차를 따르오. R는 ì¸ì œëŠ” 하하하 하는 웃ìŒì¡°ì°¨ ìžŠì–´ë²„ë¦¬ê³ , ë¶€ì¸ì—게 ë†ë‹´ì„ ë¶™ì´ëŠ” 것조차 ìžŠì–´ë²„ë¦¬ê³ , 그야ë§ë¡œ 종êµì 엄숙 그대로ë§ì„ ì´ì–´,
+"`ìž ì €ëŠ” ì•½ì„ ë¨¹ì–´ìš”.' í•˜ê³ ì†ì„ 입으로 ê°€ì ¸ê°€ëŠ” ë™ìž‘ì´ ê°í–‰ë˜ê² 지요. 약ì´ëž€ ê²ƒì€ í•˜ì–¼ë¹ˆì—서 준비한 아편ì´ì§€ìš”. 하얼빈서 치타까지 가는 ë™ì•ˆì— í¥ì•ˆë ¹ì´ë‚˜ ì–´ëŠ ì‚¼ë¦¼ì§€ëŒ€ë‚˜ 어디서나 ì£½ì„ ìžë¦¬ë¥¼ ì°¾ìžê³ 준비한 것ì´ë‹ˆê¹Œ. 나는 ìž… 근처로 가는 ê·¸ì˜ ì†ì„ 붙들었어요. 붙들면서 나는 `ìž ê¹ë§Œ 기다리오. 오늘 ë°¤ 안으로 ê·¸ ì•½ì„ ë¨¹ìœ¼ë©´ ê³ ë§Œì´ ì•„ë‹ˆì˜¤? ì´ í–‰ë³µëœ ìˆœê°„ì„ ìž ê¹ì´ë¼ë„ 늘립시다. 달 올ë¼ì˜¬ 때까지만.' 나는 ì´ë ‡ê²Œ ë§í–ˆì§€ìš”. `ì„ ìƒë‹˜ë„ 행복ë˜ì…”ìš”? ì„ ìƒë‹˜ì€ 불행ì´ì‹œì§€. ì € ë•Œë¬¸ì— ë¶ˆí–‰ì´ì‹œì§€. ì €ë§Œ ì´ê³³ì— 묻어 주시구는 ì„ ìƒë‹˜ì€ 세ìƒì— ëŒì•„ê°€ 사셔요, 오래오래 사셔요, ì¼ ë§Žì´ í•˜ê³ ì‚¬ì…”ìš”.' í•˜ê³ ìš¸ì§€ ì•Šê² ì–´ìš”. 나는 ê·¸ ë•Œì— ë‚´ ì•„ë‚´ê°€ í•˜ë˜ ë§ì„ 한 ë§ˆë””ë„ ìžŠì§€ 아니합니다. ê·¸ ë§ì„ ë“£ë˜ ë•Œì˜ ë‚´ ì¸ìƒì€ 아마 ì¼ìƒ ë‘ê³ ìžŠížˆì§€ ì•„ë‹ˆí•˜ê² ì§€ìš”.
+나는 ìžë°±í•©ë‹ˆë‹¤. ê·¸ ìˆœê°„ì— ë‚˜ëŠ” 처ìŒìœ¼ë¡œ ë‚´ 아내를 ì•ˆê³ í‚¤ìŠ¤ë¥¼ 하였지요. ë‚´ ì†ì— ëˆŒë¦¬ê³ ëˆŒë¦¬ê³ ìŒ“ì´ê³ í•˜ì˜€ë˜ ì—´ì •ì´ ê·¸ë§Œ ì¼ì‹œì— íë°œë˜ì—ˆë˜ 것ì´ì˜¤. ì•„ì•„ ì´ê²ƒì´ ìµœì´ˆì˜ ê²ƒì´ìš”, ë™ì‹œì— ìµœí›„ì˜ ê²ƒì´ë¡œêµ¬ë‚˜ í• ë•Œì— ë‚´ 눈ì—서는 ë“는 듯한 ëˆˆë¬¼ì´ í˜ë €ì†Œì´ë‹¤. ë‘ ì‚¬ëžŒì˜ ì‹¬ìž¥ì´ ë›°ëŠ” 소리, ë‘ ì‚¬ëžŒì˜ í’€ë¬´ 불길 ê°™ì€ ìˆ¨ì†Œë¦¬.
+ì´ìœ½ê³ ë‹¬ì´ ë– ì˜¬ë¼ ì™”ìŠµë‹ˆë‹¤. ê°€ì´ì—†ëŠ” 벌íŒì´ë‹ˆê¹Œ ë‹¬ì´ ëœ¨ë‹ˆê¹Œ ê°‘ìžê¸° 천지가 í™˜í•´ì§€ê³ ìš°ë¦¬ ë‘˜ì´ ì†ìœ¼ë¡œ 파서 쌓아 ë†“ì€ í™ë¬´ë”기가 ì´ ì‚° 없는 세ìƒì— ì‚°ì´ë‚˜ ë˜ëŠ” ê²ƒê°™ì´ ì¡°ê·¸ë§ˆí•œ ê²€ì€ ê·¸ë¦¼ìžë¥¼ ì§€ê³ ìžˆê² ì§€ìš”. `ìž ìš°ë¦¬ ë‹¬ë¹›ì„ ë ê³ ì¢€ ëŒì•„다ë‹ê¹Œ.' í•˜ê³ ë‚˜ëŠ” 아내를 안아 ì¼ìœ¼ì¼°ì§€ìš”. ë‚´ íŒ”ì— ì•ˆê²¨ì„œ ê³ ê°œë¥¼ 뒤로 ì –ížŒ ë‚´ ì•„ë‚´ì˜ ì–¼êµ´ì´ ë‹¬ë¹›ì— ë¹„ì¹œ ì–‘ì„ ë‚˜ëŠ” 잘 기억합니다. ì‹¤ì‹ í•œ 듯한, 만족한 듯한, ê·¸ë¦¬ê³ ë„ ì ˆë§í•œ 듯한 ê·¸ í‘œì •ì„ ë¬´ì—‡ìœ¼ë¡œ 그릴지 모릅니다. ê·¸ë¦¼ë„ ê·¸ë¦´ 줄 ëª¨ë¥´ê³ ì¡°ê°ë„ í• ì¤„ ëª¨ë¥´ê³ ê¸€ë„ ì“¸ 줄 모르는 ë‚´ê°€ ê·¸ê²ƒì„ ì–´ë–»ê²Œ 그립니까. ê·¸ì € 가슴 ì†ì— í’ˆê³ ì´ë ‡ê²Œ ì˜¤ëŠ˜ì˜ ë‚´ 아내를 ë°”ë¼ë³¼ ë¿ì´ì§€ìš”.
+나는 ë‚´ 아내를 íŒ”ì— ê±¸ê³ ë„¤, ê±¸ì—ˆë‹¤ê³ í•˜ëŠ” ê²ƒì´ ê°€ìž¥ 합당하지 ìš” ì´ë ‡ê²Œ 팔ì—다 ê±¸ê³ ë‹¬ë¹›ì„ ë°›ì€ í™©ëŸ‰í•œ 벌íŒ, 아무리 í•˜ì—¬ë„ í™˜í•˜ê²Œ ë°ì•„지지는 아니하는 벌íŒì„ 헤매었습니다. ì´ë”°ê¸ˆ ë‚´ ì•„ë‚´ê°€, `어서 ì£½ê³ ì‹¶ì–´ìš”, ì „ ì£½ê³ ë§Œ ì‹¶ì–´ìš”.' 하는 ë§ì—는 ëŒ€ë‹µë„ ì•„ë‹ˆ í•˜ê³ . ì£½ê³ ì‹¶ë‹¤ëŠ” ê·¸ ë§ì€ ë¬¼ë¡ ì§„ì •ì¼ ê²ƒì´ì§€ìš”. 아무리 ë§‘ì€ ì¼ê¸°ë¼ 하ë”ë¼ë„ 오후가 ë˜ë©´ íë ¤ì§€ëŠ” 법ì´ë‹ˆê¹Œ 오래 살아가는 ë™ì•ˆì— 늘 한 모양으로 ì´ ìˆœê°„ê°™ì´ ê¹¨ë—í•˜ê³ ëœ¨ê±°ìš´ 기분으로 ê°ˆ 수는 없지 않아요? 불쾌한 ì¼ë„ ìƒê¸°ê³ , 보기 í‰í•œ ì¼ë„ ìƒê¸¸ëŠ”ì§€ ëª¨ë¥´ê±°ë“ . 그러니까 ì´ ì™„ì „í•œ 깨ë—ê³¼ ì™„ì „í•œ 사랑과 ì™„ì „í•œ 행복 ì†ì— 죽어 버리ìžëŠ” ëœ»ì„ ë‚˜ëŠ” 잘 알지요. ë”구나 ìš°ë¦¬ë“¤ì´ ì‚´ì•„ 남는대야 ì•žê¸¸ì´ ê¸°êµ¬í•˜ì§€ í‰íƒ„í• ë¦¬ëŠ” 없지 아니해요? 그래서 나는 `죽지, 우리 ì´ ë‹¬ë°¤ì— ì‹¤ì»· ëŒì•„다니다가, ë” ëŒì•„다니기가 ì‹«ê±°ë“ ê·¸ 구ë©ì— ëŒì•„가서 ì•½ì„ ë¨¹ì시다.' ì´ë ‡ê²Œ ë§í•˜ê³ 우리 ë‘˜ì€ í—¤ë§¸ì§€ìš”. ë‚®ì— ë³´ë©´ 어디까지나 í‰í‰í•œ 벌íŒì¸ 것만 같지마는 ë‹¬ë°¤ì— ë³´ë©´ ì´ ì‚¬ë§‰ì—ë„ ì•„ì§ ì±„ 스러지지 아니한 ì‚°ì˜ í˜•ì ì´ ë‚¨ì•„ 있어서 êµ°ë°êµ°ë° ê±°ë‡ê±°ë‡í•œ 그림ìžê°€ ìžˆê² ì§€ìš”. ê·¸ ê·¸ë¦¼ìž ì†ì—는 걸어 들어가면 ì–´ë–¤ ë°ëŠ” 우리 í—ˆë¦¬ë§Œí¼ ê·¸ë¦¼ìžì— ê°€ë¦¬ìš°ê³ ì–´ë–¤ ë°ëŠ” 우리 ë‘˜ì„ ë‹¤ 가리워 버리는 ë°ë„ 있단 ë§ì•¼ìš”. 죽ìŒì˜ 그림ìžë¼ëŠ” ìƒê°ì´ 나면 ê·¸ëž˜ë„ ëª¸ì— ì†Œë¦„ì´ ë¼ì³ìš”.
+차차 ë‹¬ì´ ë†’ì•„ì§€ê³ ì¶”ìœ„ê°€ ì‹¬í•´ì ¸ì„œ ë°”ëžŒê²°ì´ ì§€ë‚˜ê°ˆ 때ì—는 눈ì—서 ëˆˆë¬¼ì´ ë‚ ì§€ê²½ì´ì§€ìš”. ì›ì²´ 대기 ì¤‘ì— ìˆ˜ë¶„ì´ ì 으니까 ì„œë¦¬ë„ ë§Žì§€ 않지마는, ê·¸ëž˜ë„ ëŒ€ê¸° ì¤‘ì— ìžˆëŠ” ìˆ˜ë¶„ì€ ë‹¤ 얼어 ë²„ë ¤ì„œ ì–¼ìŒê°€ë£¨ê°€ ë˜ì—ˆëŠ” 게지요. 공중ì—는 ë°˜ì§ë°˜ì§í•˜ëŠ” ìˆ˜ì •ê°€ë£¨ ê°™ì€ ê²ƒì´ ë³´ìž…ë‹ˆë‹¤. ë‚®ì—는 ë•€ì´ íë¥´ë¦¬ë§Œí¼ ë¥ë˜ ì‚¬ë§‰ë„ ë°¤ì´ ë˜ë©´ ì´ë ‡ê²Œ ê¸°ì˜¨ì´ ë‚´ë ¤ê°€ì§€ìš”. ì¶¥ë‹¤ê³ ìƒê°ì€ í•˜ë©´ì„œë„ ì¶¥ë‹¤ëŠ” ë§ì€ 아니 í•˜ê³ ìš°ë¦¬ëŠ” ì–´ë–¤ 때ì—는 ë‹¬ì„ ë”°ë¼ì„œ, ì–´ë–¤ 때ì—는 ë‹¬ì„ ë“±ì§€ê³ , ì–´ë–¤ 때ì—는 í˜¸ìˆ˜ì— ë¹„ì¹œ ë‹¬ì„ êµ½ì–´ë³´ê³ , ì´ ëª¨ì–‘ìœ¼ë¡œ í•œì—†ì´ ë§ë„ ì—†ì´ ëŒì•„다녔지요. ì´ ì„¸ìƒ ìƒëª…ì˜ ë§ˆì§€ë§‰ ìˆœê°„ì„ íž˜ê» ì˜ì‹í•˜ë ¤ëŠ” 듯ì´.
+마침내 `나는 ë” ëª» 걸어요.' í•˜ê³ ì´ì´ê°€ ë‚´ ì–´ê¹¨ì— ë§¤ë‹¬ë ¤ ë²„ë¦¬ê³ ë§ì•˜ì§€ìš”."
+í•˜ê³ Rê°€ ë¶€ì¸ì„ ëŒì•„보니 ë¶€ì¸ì€ íŽ¸ë¬¼í•˜ë˜ ì†ì„ ì‰¬ê³ ,
+"다리가 아픈 ì¤„ì€ ëª¨ë¥´ê² ëŠ”ë° ë‹¤ë¦¬ê°€ ì´ë¦¬ 뉘구 ì €ë¦¬ 뉘구 해서 걸ìŒì„ ê±¸ì„ ìˆ˜ê°€ 없었어요. 춥기는 하구."
+í•˜ê³ ì†Œë¦¬ë¥¼ 내어서 웃소.
+"그럴 ë§Œë„ í•˜ì§€."
+í•˜ê³ R는 긴장한 í‘œì •ì„ ì•½ê°„ í’€ê³ ì•‰ì€ ìžì„¸ë¥¼ ìž ê¹ ê³ ì¹˜ë©°,
+"ê·¸ í›„ì— ê·¸ ë‚ ë°¤ ëŒì•„다닌 ê³³ì„ ë”듬어 보니까, ìžì„¸ížˆëŠ” 알 수 없지마는 ì‚¼ì‹ ë¦¬ëŠ” ë” ë˜ëŠ” 것 ê°™ê±°ë“ . 다리가 아프지 ì•„ë‹ˆí• ë¦¬ê°€ 있나."
+í•˜ê³ ì°¨ë¥¼ 한 모금 ë§ˆì‹œê³ ë‚˜ì„œ ë§ì„ 계ì†í•˜ì˜¤.
+"그래서 나는 ë‚´ 외투를 벗어서, ì´ì´(ë¶€ì¸)를 싸서 ì–´ë¦°ì• ì•ˆë“¯ì´ ì•ˆê³ ê±¸ì—ˆì§€ìš”. 외투로 쌌으니 ìžê¸°ë„ 춥지 않구, 나는 ë˜ ë¬´ê±°ìš´ ì§ì„ 안았으니 ë•€ì´ ë‚ ì§€ê²½ì´êµ¬, ê·¸ë¿ ì•„ë‹ˆë¼ ë‚´ê°€ ì œê²Œ 주는 ìµœí›„ì˜ ì„œë¹„ìŠ¤ë¼ í•˜ë‹ˆ 기ì˜ê³ , ë§í•˜ìžë©´ ì¼ê±° 삼ë“ì´ì§€ìš”. 하하하하. 지난 ì¼ì´ë‹ˆ 웃지마는 ê·¸ 때 ì‚¬ì •ì„ ìƒê°í•´ 보세요, ì–´ë– í–ˆê² ë‚˜."
+í•˜ê³ R는 약간 처참한 ë¹›ì„ ë 면서,
+"그러니 ê·¸ 구ë©ì´ë¥¼ ì–´ë”” ì°¾ì„ ìˆ˜ê°€ 있나. 얼마를 찾아 ëŒì•„다니다가 아무 ë°ì„œë‚˜ ì£½ì„ ìƒê°ë„ í•´ 보았지마는 몸뚱ì´ë¥¼ 그냥 벌íŒì— ë‚´ë†“ê³ ì£½ê³ ì‹¶ì§€ëŠ” ì•„ë‹ˆí•˜ê³ ë˜ ê·¸ 구ë©ì´ê°€ 우리 ë‘ ì‚¬ëžŒì—게 특별한 ì˜ë¯¸ê°€ 있는 것 같아서 기어코 ê·¸ê²ƒì„ ì°¾ì•„ ë‚´ê³ ì•¼ ë§ì•˜ì§€ìš”. ê·¸ 때는 ë²Œì¨ ìƒˆë²½ì´ ê°€ê¹Œì› ë˜ ëª¨ì–‘ì´ì˜¤. ì—´ 시나 넘어서 뜬 í•˜í˜„ë‹¬ì´ ë‚®ì´ ê¸°ìš¸ì—ˆìœ¼ë‹ˆ ê·¸ë ‡ì§€ ì•Šê² ì–´ìš”. ê·¸ 구ë©ì´ì— 와서 우리는 한 번 ë” í•˜ëŠ˜ê³¼ 달과 별과, ê·¸ë¦¬ê³ ë§ˆìŒ ì†ì— ë– ì˜¤ë¥¸ 사람들과 하ì§í•˜ê³ 약 ë¨¹ì„ ì¤€ë¹„ë¥¼ 했지요.
+ì•½ì„ ê²€ì€ ê³ ì•½ê³¼ ê°™ì€ ì•„íŽ¸ì„ ë§›ì´ ì“°ë‹¤ëŠ” ì•„íŽ¸ì„ ë¬¼ë„ ì—†ì´ ë¨¹ìœ¼ë ¤ 들었지요.
+우리 ë‘˜ì€ ì•„ê¹Œ 모양으로 가지런히 누워서 í•˜ëŠ˜ì„ ë°”ë¼ë³´ì•˜ëŠ”ë° ë‹¬ì´ ë°ìœ¼ë‹ˆê¹Œ ë³´ì´ë˜ 별들 ì¤‘ì— ìˆ¨ì€ ë³„ì´ ë§Žê³ ë˜ ë³„ë“¤ì˜ ìœ„ì¹˜ 우리ì—게 낯ìµì€ ë¶ë‘ì¹ ì„± ìžë¦¬ë„ ë³€í–ˆì„ ê²ƒ 아니야요. ì´ìƒí•œ ìƒê°ì´ 나요. 우리가 벌íŒìœ¼ë¡œ 헤매는 ë™ì•ˆì— 천지가 ëª¨ë‘ ë³€í•œ 것 같아요. 사실 변하였지요. ê·¸ 변한 ê²ƒì´ ìš°ìŠ¤ì›Œì„œ 나는 껄껄 웃었지요. 워낙 ë‚´ê°€ 웃ìŒì´ 좀 헤프지만 ì´ ë•Œì²˜ëŸ¼ 헤프게 실컷 웃어 본 ì¼ì€ 없습니다.
+왜 웃ëŠëƒê³ ì•„ë‚´ê°€ 좀 ì„±ì„ ë‚¸ ë“¯ì´ ë¬»ê¸°ë¡œ, `천지와 ì¸ìƒì´ 변하는 ê²ƒì´ ìš°ìŠ¤ì›Œì„œ 웃었소.' 그랬지요. 그랬ë”니, `천지와 ì¸ìƒì€ ë³€í• ëŠ”ì§€ 몰ë¼ë„ ë‚´ 마ìŒì€ 안 변해요!' í•˜ê³ ì†Œë¦¬ë¥¼ ì§€ë¥´ê² ì§€ìš”. í½ ë¶„ê°œí–ˆë˜ ëª¨ì–‘ì´ì•¼."
+í•˜ê³ R는 ê·¸ 아내를 보오.
+"그럼 ë¶„ê°œ 안 í•´ìš”? ë‚¨ì€ ì£½ì„ ê²°ì‹¬ì„ í•˜ê³ ë°œë°œ 떨구 ìžˆëŠ”ë° ê³ì—서 ê»„ê»„ê±°ë¦¬ê³ ì›ƒìœ¼ë‹ˆ, 어째 분하지가 않아요. 나는 분해서 ë‹¬ì•„ë‚˜ë ¤ê³ í–ˆì–´ìš”."
+í•˜ê³ ë¶€ì¸ì€ ì•„ì§ë„ ë¶„í•¨ì´ ë‚¨ì€ ê²ƒê°™ì´ ë§í•˜ì˜¤.
+"그래 달아나지 않았소?"
+í•˜ê³ R는 ë¶€ì¸ì´ 벌떡 ì¼ì–´ë‚˜ì„œ ë¹„í‹€ê±°ë¦¬ê³ ë‹¬ì•„ë‚˜ëŠ” í‰ë‚´ë¥¼ 팔과 다리로 ë‚´ê³ ë‚˜ì„œ,
+"ì´ëž˜ì„œ 죽는 ì‹œê°„ì´ ì§€ì²´ê°€ ë˜ì—ˆì§€ìš”. 그래서 ë‚´ê°€ ë¹Œê³ ë‹¬ëž˜ê³ í•´ì„œ 가까스로 ì•ˆì •ì„ ì‹œí‚¤ê³ ë‚˜ë‹ˆ ì†ì— ì¥ì—ˆë˜ ì•„íŽ¸ì´ ë•€ì— í‘¹ ì –ì—ˆê² ì§€ìš”. ë‚´ê°€ ì›ƒì€ ê²ƒì€ ì£½ê¸° ì „ 한 번 천지와 ì¸ìƒì„ 웃어 버린 것ì¸ë° ê·¸ë ‡ê²Œ 야단ì´ë‹ˆâ€¦â€¦ 하하하하."
+R는 ì‹ì€ 차를 한 모금 ë” ë§ˆì‹œë©°,
+"ì°¸ ëª©ë„ ë§ˆë¥´ê¸°ë„ í•˜ë”니. ìž…ì—는 침 한 방울 ì—†ê³ . 그러나 ëª»ë¬¼ì„ ë¨¹ì„ ìƒê°ë„ ì—†ê³ . 나중ì—는 ë§ì„ í•˜ë ¤ê³ í•´ë„ í˜€ê°€ 안 ëŒì•„ê°€ê² ì§€ìš”.
+ì´ëŸ¬ëŠ” ë™ì•ˆì— ë‹¬ë¹›ì´ í¬ë¯¸í•´ì§€ê¸¸ëž˜ 웬ì¼ì¸ê°€ í•˜ê³ ê³ ê°œë¥¼ ë²ˆì© ë“¤ì—ˆë”니 í•´ê°€ ë– ì˜¤ë¦…ë‹ˆë‹¤ê·¸ë ¤. 어떻게 ë¶‰ê³ ë‘¥ê¸€ê³ ì”©ì”©í•œì§€. `ì € í•´ 보오.' í•˜ê³ ë‚˜ëŠ” 기계ì 으로 벌떡 ì¼ì–´ë‚˜ì„œ 구ë©ì´ì—서 뛰어나왔지요."
+í•˜ê³ ë¹™ê·¸ë ˆ 웃소. Rì˜ ë¹™ê·¸ë ˆ 웃는 ì–‘ì´ ì°¸ 좋았소.
+"ë‚´ê°€ 뛰어나오는 ê²ƒì„ ë³´ê³ ì´ì´ë„ 뿌시시 ì¼ì–´ë‚¬ì§€ìš”. ê·¸ í•´! ê·¸ í•´ì˜ ìƒˆ ë¹›ì„ ë°›ëŠ” 하늘과 ë•…ì˜ ë¹›! 나는 ê·¸ê²ƒì„ í˜•ìš©í• ë§ì„ 가지지 못합니다. 다만 íž˜ê» ì†Œë¦¬ì¹˜ê³ ì‹¶ê³ ê¸°ìš´ê» ë‹¬ìŒë°•ì§ˆì¹˜ê³ ì‹¶ì€ ìƒê°ì´ ë‚ ë¿ì´ì–´ìš”.
+`우리 삽시다, 죽지 ë§ê³ 삽시다, 살아서 새 세ìƒì„ 하나 만들어 봅시다.' ì´ë ‡ê²Œ ë§í•˜ì˜€ì§€ìš”. 하니까 ì´ì´ê°€ 처ìŒì—는 ê¹œì§ ë†€ë¼ëŠ” 것 같아요. 그러나 마침내 ì•„ë‚´ë„ ì£½ì„ ëœ»ì„ ë³€í•˜ì˜€ì§€ìš”. 그래서 남 ì„ ìƒì„ ì²í•˜ì—¬ë‹¤ê°€ ê·¸ ë§ì”€ì„ ì—¬ìˆì—ˆë”니 남 ì„ ìƒê»˜ì„œ ê³ ê°œë¥¼ ë„ë•ë„ë•í•˜ì‹œê³ ìš°ë¦¬ ë‘˜ì˜ í˜¼ì¸ ì£¼ë¡€ë¥¼ 하셨지요. ê·¸ 후 ì‹ì—¬ ë…„ì— ìš°ë¦¬ëŠ” ë° ê°ˆê³ ì•„ì´ ê¸°ë¥´ê³ ì´ëŸ° ìƒí™œì„ í•˜ê³ ìžˆëŠ”ë° ì–¸ì œë‚˜ 여기 새 ë¯¼ì¡±ì´ ìƒê¸°ê³ 누가 새 ë‹¨êµ°ì´ ë 는지요. 하하하하, 아하하하. í”¼ê³¤í•˜ì‹œê² ìŠµë‹ˆë‹¤. ì´ì•¼ê¸°ê°€ 너무 길어서."
+í•˜ê³ R는 ë§ì„ ëŠì†Œ.
+나는 R부처가 만류하는 ê²ƒë„ ë‹¤ ë¿Œë¦¬ì¹˜ê³ ì—¬ê´€ìœ¼ë¡œ ëŒì•„왔소. R와 함께 달빛 ì†, ê°œ 짖는 소리 ì†ì„ 지나서 ì•„ë¼ì‚¬ ì‚¬ëžŒì˜ ì¡°ê·¸ë§ˆí•œ 여관으로 ëŒì•„왔소. 여관 주ì¸ë„ R를 아는 모양ì´ì–´ì„œ 반갑게 ì¸ì‚¬í•˜ê³ ë˜ ë‚´ê²Œ 대한 ë¶€íƒë„ 하는 모양ì¸ê°€ 보오.
+R는 ë‚´ ë°©ì— ì˜¬ë¼ì™€ì„œ ë‚´ì¼ í•˜ë£¨ ì§€ë‚ ì¼ë„ ì´ì•¼ê¸°í•˜ê³ ë˜ ë‚¨ ì„ ìƒê³¼ ì •ìž„ì—게 관한 ì´ì•¼ê¸°ë„ 하였으나, 나는 그가 무슨 ì´ì•¼ê¸°ë¥¼ 하는지 잘 ë“¤ì„ ë§Œí•œ 마ìŒì˜ ì—¬ìœ ë„ ì—†ì–´ì„œ ë§ˆìŒ ì—†ëŠ” ëŒ€ë‹µì„ í• ë¿ì´ì—ˆì†Œ.
+Rê°€ ëŒì•„ê°„ ë’¤ì— ë‚˜ëŠ” ì˜·ë„ ë²—ì§€ ì•„ë‹ˆí•˜ê³ ì¹¨ëŒ€ì— ë“œëŸ¬ëˆ„ì› ì†Œ. 페치카를 때기는 한 모양ì´ë‚˜ ë°©ì´ ì¨ëŠ˜í•˜ê¸° 그지없소.
+`ê·¸ ë‘ ë³„ 무ë¤ì´ ì •ë§ R와 ê·¸ 여학ìƒê³¼ ë‘ ì‚¬ëžŒì´ ì˜ì›ížˆ 달치 ëª»í• ê¿ˆì„ ì•ˆì€ ì±„ë¡œ 깨ë—하게 죽어서 묻힌 무ë¤ì´ì—ˆìœ¼ë©´ 얼마나 좋ì„까. ë§Œì¼ ê·¸ë ‡ë‹¤ 하면 ë‚´ì¼ í•œ 번 ë” ê°€ì„œ ë³´í† ë¼ë„ í•˜ê³ ì˜¤ë ¨ë§ˆëŠ”.'
+í•˜ê³ ë‚˜ëŠ” Rë¶€ì²˜ì˜ ìƒí™œì— 대하여 ì¼ì¢…ì˜ ë¶ˆë§Œê³¼ í™˜ë©¸ì„ ëŠê¼ˆì†Œ.
+ê·¸ë¦¬ê³ ë‚´ê°€ ì •ìž„ì„ ì—¬ê¸°ë‚˜ ì‹œë² ë¦¬ì•„ë‚˜ ì–´ë–¤ 곳으로 불러다가 ë§Œì¼ R와 ê°™ì€ í‰ë‚´ë¥¼ 낸다 하면, í•˜ê³ ìƒê°í•´ ë³´ê³ ëŠ” 나는 ì§„ì €ë¦¬ë¥¼ 쳤소. 나는 내머리 ì†ì— 다시 그러한 ìƒê°ì´ 한 ì¡°ê°ì´ë¼ë„ 들어올 ê²ƒì„ ë‘ë ¤ì›Œí•˜ì˜€ì†Œ.
+ê¸‰í–‰ì„ ê¸°ë‹¤ë¦¬ìžë©´ ë˜ ì‚¬í˜ì„ 기다리지 아니하면 아니 ë˜ê¸°ë¡œ 나는 ì´íŠ¿ë‚ ìƒˆë²½ì— ë– ë‚˜ëŠ” 구간차를 íƒ€ê³ Fì—ì„ ë– ë‚˜ ë²„ë ¸ì†Œ. Rì—게는 ê³ ë§™ë‹¤ëŠ” 편지 한 ìž¥ë§Œì„ ì¨ ë†“ê³ . 나는 R를 ë” ë³´ê¸°ë¥¼ ì›ì¹˜ 아니하였소. ê·¸ê²ƒì€ ë°˜ë“œì‹œ R를 죄ì¸ìœ¼ë¡œ 보아서 그런 ê²ƒì€ ì•„ë‹ˆì˜¤ë§ˆëŠ” ê·¸ì € 나는 다시 R를 대면하기를 ì›ì¹˜ 아니한 것ì´ì˜¤.
+나는 차가 Rì˜ ì§‘ ì•žì„ ì§€ë‚ ë•Œì—ë„ Rì˜ ì§‘ì— ëŒ€í•˜ì—¬ì„œëŠ” 외면하였소.
+ì´ ëª¨ì–‘ìœ¼ë¡œ 나는 í¥ì•ˆë ¹ì„ ë„˜ê³ , 하ì¼ë¼ë¥´ì˜ 솔ë°ì„ 지나서 마침내 ì´ ê³³ì— ì˜¨ 것ì´ì˜¤.
+형! 나는 ì¸ì œëŠ” ì´ íŽ¸ì§€ë¥¼ ë내오. ë” ì“¸ ë§ë„ 없거니와 ì¸ì œëŠ” ì´ê²ƒì„ ì“°ê¸°ë„ ì‹«ì¦ì´ 났소.
+ì´ íŽ¸ì§€ë¥¼ 쓰기 ì‹œìž‘í• ë•Œì—는 ë°”ì´ì¹¼ì— ë¬¼ê²°ì´ í‰ìš©í•˜ë”니 ì´ íŽ¸ì§€ë¥¼ ë내는 지금ì—는 ê°€ì˜ ê°€ê¹Œìš´ 물ì—는 ì–¼ìŒì´ 얼었소. ê·¸ë¦¬ê³ ì € 멀리 푸른 ë¬¼ì´ ëŠ ì‹¤ëŠ ì‹¤ 하얗게 눈 ë®ì¸ ì‚° 빛과 어울리게 ë˜ì—ˆì†Œ.
+사í˜ì´ë‚˜ ì´ì–´ì„œ ì˜¤ë˜ ëˆˆì´ ë°¤ìƒˆì— ê°œê³ ì˜¤ëŠ˜ 아침ì—는 ì¹¼ë‚ ê°™ì€ ë°”ëžŒì´ ëˆˆì„ ë‚ ë¦¬ê³ ìžˆì†Œ.
+나는 ì´ ì–¼ìŒ ìœ„ë¡œ 걸어서 ì € 푸른 물 있는 곳까지 ê°€ê³ ì‹¶ì€ ìœ í˜¹ì„ ê¸ˆí• ìˆ˜ 없소. ë”구나 ì´ íŽ¸ì§€ë„ ë‹¤ ì“°ê³ ë‚˜ë‹ˆ, ì¸ì œëŠ” ë‚´ê°€ ì´ ì„¸ìƒì—서 í• ë§ˆì§€ë§‰ ì¼ê¹Œì§€ 다 한 것 같소.
+ë‚´ê°€ ì´ ì•žì— ì–´ë””ë¡œ 가서 ì–´ì°Œ ë 는지는 ë‚˜ë„ ëª¨ë¥´ì§€ë§ˆëŠ” í¬ë¯¸í•œ 소ì›ì„ ë§í•˜ë©´ 눈 ë®ì¸ ì‹œë² ë¦¬ì•„ì˜ ì¸ì 없는 삼림 지대로 í•œì • ì—†ì´ í—¤ë§¤ë‹¤ê°€ 기운 진하는 ê³³ì—서 ì´ ëª©ìˆ¨ì„ ë§ˆì¹˜ê³ ì‹¶ì†Œ.
+ìµœì„ êµ°ì€ `ë'ì´ë¼ëŠ” 글ìžë¥¼ ì¼ë‹¤ê°€ 지워 ë²„ë¦¬ê³ ë”´ 종ì´ì—다가 ì´ëŸ° ë§ì„ ì¼ë‹¤
+다 ì“°ê³ ë‚˜ë‹ˆ ì´ëŸ° íŽ¸ì§€ë„ ë‹¤ 부질없는 ì¼ì´ì˜¤. ë‚´ê°€ ì´ëŸ° ë§ì„ 한대야 세ìƒì´ 믿어 줄 ë¦¬ë„ ì—†ì§€ 않소. ë§ì´ëž€ 소용 없는 것ì´ì˜¤. ë‚´ê°€ 아무리 ë‚´ ì•„ë‚´ì—게 ë§ì„ í–ˆì–´ë„ ì•„ë‹ˆ ë¯¿ì—ˆê±°ë“ ë‚´ ì•„ë‚´ë„ ë‚´ ë§ì„ 아니 ë¯¿ì—ˆê±°ë“ í•˜ë¬¼ë©° 세ìƒì´ ë‚´ ë§ì„ ë¯¿ì„ ë¦¬ê°€ 있소. 믿지 ì•„ë‹ˆí• ë¿ ì•„ë‹ˆë¼ ë‚´ ë§ ì¤‘ì—서 ìžê¸°ë„¤ 목ì ì— í•„ìš”í•œ ë¶€ë¶„ë§Œì€ ë¯¿ê³ , ë˜ ìžê¸°ë„¤ 목ì ì— í•„ìš”í•œ ë¶€ë¶„ì€ ë§ˆìŒëŒ€ë¡œ ê³ ì¹˜ê³ ë’¤ì§‘ê³ ë³´íƒœê³ í• ê²ƒì´ë‹ˆê¹Œ, 나는 ì´ íŽ¸ì§€ë¥¼ ì“´ ê²ƒì´ í•œ 무ìµí•˜ê³ 어리ì„ì€ ì¼ì¸ ì¤„ì„ ê¹¨ë‹¬ì•˜ì†Œ.
+형ì´ì•¼ ì´ íŽ¸ì§€ë¥¼ 아니 보기로니 나를 안 ë¯¿ê² ì†Œ? ê·¸ 중ì—는 혹 í˜•ì´ ì§€ê¸ˆê¹Œì§€ ëª¨ë¥´ë˜ ìžë£Œë„ 없지 아니하니, 형만 í˜¼ìž ë³´ì‹œê³ í˜•ë§Œ í˜¼ìž ë‚´ ì‚¬ì •ì„ ì•Œì•„ 주시면 다행ì´ê² 소. 세ìƒì— 한 믿는 친구를 가지는 ê²ƒì´ ì €ë§ˆë‹¤ 하는 ì¼ì´ê² 소?
+나는 ì´ ì“¸ë°ì—†ëŠ” 편지를 몇 번ì´ë‚˜ ë¶ˆì‚´ë¼ ë²„ë¦¬ë ¤ê³ í•˜ì˜€ìœ¼ë‚˜ ê·¸ëž˜ë„ ê±°ê¸°ë„ ì¼ì¢…ì˜ ì• ì°©ì‹¬ì´ ìƒê¸°ê³ ë¯¸ë ¨ì´ ìƒê¸°ëŠ”êµ¬ë ¤. 형 한 ë¶„ì´ë¼ë„ ë³´ì—¬ ë“œë¦¬ê³ ì‹¶ì€ ë§ˆìŒì´ ìƒê¸°ëŠ”êµ¬ë ¤. ë‚´ê°€ Sí˜•ë¬´ì†Œì— ìž…ê°í•´ ìžˆì„ ì ì— í˜•ë¬´ì†Œ ë²½ì— ì£„ìˆ˜ê°€ ì†í†±ìœ¼ë¡œ ì„±ëª…ì„ ìƒˆê¸´ ê²ƒì„ ë³´ì•˜ì†Œ. ë’¤ì— ë¬¼ì—ˆë”니 ê·¸ê²ƒì€ í”히 사형수가 하는 ì§“ì´ë¼ê³ . 사형수가 êµìˆ˜ëŒ€ì— ëŒë ¤ 나가기 바로 ì „ì— í”히 ì†í†±ìœ¼ë¡œ ë‹´ë²¼ë½ì´ë‚˜ ë§ˆë£»ë°”ë‹¥ì— ì œ ì´ë¦„ì„ ìƒˆê¸°ëŠ” ì¼ì´ ìžˆë‹¤ê³ í•˜ëŠ” ë§ì„ 들었소. ë‚´ê°€ 형ì—게 쓰는 ì´ íŽ¸ì§€ë„ ê·¸ 심리와 비슷한 것ì¼ê¹Œìš”?
+형! 나는 보통 사람보다는, ì •ë³´ë‹¤ëŠ” 지로, ìƒì‹ë³´ë‹¤ëŠ” ì´ë¡ 으로, ì´í•´ë³´ë‹¤ëŠ” ì˜ë¦¬ë¡œ ì‚´ì•„ ì™”ë‹¤ê³ ìžì‹ 하오. ì´ë¥¼í…Œë©´ 논리학ì 으로 윤리학ì 으로 살아온 것ì´ë¼ê³ í• ê¹Œ. 나는 엄격한 êµì‚¬ìš”, êµìž¥ì´ì—ˆì†Œ. 내게는 ì˜ì§€ë ¥ê³¼ ì´ì§€ë ¥ë°–ì— ì—†ëŠ” 것 같았소. 그러한 ìƒí™œì„ ìˆ˜ì‹ ë…„ í•´ 오지 아니하였소? 나는 ì´ ì•žì— ëª‡ì‹ ë…„ì„ ë” ì‚´ë”ë¼ë„ ë‚´ ì´ ì„±ê²©ì´ë‚˜ ìƒí™œ 태ë„ì—는 ë³€í•¨ì´ ì—†ìœ¼ë¦¬ë¼ê³ ìžì‹ 하였소. ë¶ˆí˜¹ì§€ë…„ì´ ì§€ë‚¬ìœ¼ë‹ˆ ê·¸ë ‡ê²Œ ìƒê°í•˜ì˜€ì„ ê²ƒì´ ì•„ë‹ˆì˜¤?
+ê·¸ëŸ°ë° í˜•! ì°¸ ì´ìƒí•œ ì¼ì´ 있소. ê·¸ê²ƒì€ ë‚´ê°€ 지금까지 처해 ìžˆë˜ í™˜ê²½ì„벗어나서 호호 탕탕하게 ë„“ì€ ì„¸ê³„ì— ì•Œëª¸ì„ ë‚´ì–´ë˜ì§ì„ 당하니 ë‚´ ë§ˆìŒ ì†ì—는 무서운 여러 가지 변화가 ì¼ì–´ë‚˜ëŠ”êµ¬ë ¤. 나는 ì´ ë§ë„ 형ì—게 아니 í•˜ë ¤ê³ ìƒê°í•˜ì˜€ì†Œ. 노여워하지 마시오, ë‚´ê²Œê¹Œì§€ë„ ìˆ¨ê¸°ëŠëƒê³ . 그런 ê²ƒì´ ì•„ë‹ˆì˜¤, 형ì€ì»¤ë…• 나 ìžì‹ ì—ê²Œê¹Œì§€ë„ ìˆ¨ê¸°ë ¤ê³ í•˜ì˜€ë˜ ê²ƒì´ì˜¤. 혹시 그런 기다리지 아니 í•˜ì˜€ë˜ ì›, 그런 ìƒê°ì´ ë‚´ 마ìŒì˜ í•˜ëŠ˜ì— ì¼ì–´ë‚˜ë¦¬ë¼ê³ ìƒìƒë„ 아니하였ë˜, 그런 ìƒê°ì´ ì¼ì–´ë‚ 때ì—는 나는 스스로 놀ë¼ê³ 스스로 슬í¼í•˜ì˜€ì†Œ. 그래서 스스로 숨기기로 하였소.
+ê·¸ 숨긴다는 ê²ƒì´ ë¬´ì—‡ì´ëƒ 하면 ê·¸ê²ƒì€ ì—´ì •ì´ìš”, ì •ì˜ ë¶ˆê¸¸ì´ìš”, ì •ì˜ ê´‘í’ì´ìš”, ì •ì˜ ë¬¼ê²°ì´ì˜¤. ë§Œì¼ ë‚´ ì˜ì‹ì´ 세계를 í‰í™”로운 í’€ ìžˆê³ , 꽃 ìžˆê³ , 나무 있는 벌íŒì´ë¼ê³ 하면 거기 난ë°ì—†ëŠ” 미친 ì§ìŠ¹ë“¤ì´ ë¶ˆì„ ë¿œê³ ì†Œë¦¬ë¥¼ ì§€ë¥´ê³ ì‹¸ìš°ê³ , ì˜ê°ì„ í•˜ê³ ë‚ ì³ì„œ, ì´ ë™ì‚°ì˜ í‰í™”ì˜ í™”ì´ˆë¥¼ 다 ì§“ë°Ÿì•„ ë²„ë¦¬ê³ ë§ˆëŠ” 그러한 모양과 같소.
+형! ê·¸ ì´ìƒì•¼ë¦‡í•œ ì§ìŠ¹ë“¤ì´ ì—¬íƒœê», ì‚¬ì‹ ë…„ ê°„ì„ ì–´ëŠ êµ¬ì„ì— ìˆ¨ì–´ 있었소? 그러다가 ì¸ì œ 뛰어나와 ê°ê° ì œ 권리를 주장하오?
+지금 ë‚´ 가슴 ì†ì€ ë“소. ë‚´ ëª¸ì€ ë°”ì§ ì—¬ìœ„ì—ˆì†Œ. ê·¸ê²ƒì€ ìƒë¦¬í•™ì 으로나 심리학ì 으로나 타는 것ì´ìš”, 연소하는 것ì´ì˜¤. 그래서 다만 ë‚´ ëª¸ì˜ ì§€ë°©ë§Œì´ íƒ€ëŠ” ê²ƒì´ ì•„ë‹ˆë¼, 골수까지 íƒ€ê³ , ëª¸ì´ íƒˆ ë¿ì´ ì•„ë‹ˆë¼ ìƒëª… ê·¸ ë¬¼ê±´ì´ íƒ€ê³ ìžˆëŠ” 것ì´ì˜¤. 그러면 ì–´ì°Œí• ê¹Œ.
+지위, 명성, 습관, 시대 사조 등등으로 ì¼ìƒì— ëˆŒë¦¬ê³ ëˆŒë ¸ë˜ ë‚´ ìžì•„ì˜ ì¼ë¶€ë¶„ì´ í˜ëª…ì„ ì¼ìœ¼í‚¨ 것ì´ì˜¤? 한 ë²ˆë„ ìžìœ 로 권세를 ë¶€ë ¤ ë³´ì§€ 못한 본능과 ê°ì •ë“¤ì´ ë‚´ ìƒëª…ì´ ë나기 ì „ì— í•œ 번 ë‚ ë›°ì–´ ë³´ë ¤ëŠ” 것ì´ì˜¤. ì´ê²ƒì´ ì„ ì´ì˜¤? ì•…ì´ì˜¤?
+ê·¸ë“¤ì€ ë‚´ê°€ 지금까지 ì˜³ë‹¤ê³ ì—¬ê¸°ê³ ì‹ ì„±í•˜ë‹¤ê³ ì—¬ê¸°ë˜ ëª¨ë“ ê¶Œìœ„ë¥¼ 모조리 ë‘˜ëŸ¬ì—Žìœ¼ë ¤ê³ ë“œì˜¤. 그러나 형! 나는 ë„ì €ížˆ ì´ í˜ëª…ì„ ìš©ì¸í• 수가 없소. 나는 죽기까지 버티기로 ê²°ì •ì„ í•˜ì˜€ì†Œ. ë‚´ ì†ì—서 ë‘ ì„¸ë ¥ì´ ì‹¸ìš°ë‹¤ê°€ 싸우다가 승부가 ê²°ì •ì´ ëª» ëœë‹¤ë©´ 나는 ìŠ¹ë¶€ì˜ ê²°ì •ì„ ê¸°ë‹¤ë¦¬ì§€ ì•„ë‹ˆí•˜ê³ ì‚´ê¸°ë¥¼ 그만ë‘ë ¤ì˜¤.
+나는 눈 ë®ì¸ 삼림 ì†ìœ¼ë¡œ ë“¤ì–´ê°€ë ¤ì˜¤. 나는 Vë¼ëŠ” 대삼림 지대가 ì–´ë””ì¸ ì¤„ë„ ì•Œê³ ê±°ê¸°ë¥¼ ê°€ë ¤ë©´ ì–´ëŠ ì •ê±°ìž¥ì—서 내릴 ê²ƒë„ ë‹¤ 알아 놓았소.
+ë§Œì¼ ë‹¨ìˆœížˆ 죽는다 하면 구태여 멀리 찾아갈 í•„ìš”ë„ ì—†ì§€ë§ˆëŠ” ê·¸ëž˜ë„ ë‚˜ 혼ìžë¡œëŠ” ë‚´ 사ìƒê³¼ ê°ì •ì˜ ì²ì‚°ì„ í•˜ê³ ì‹¶ì†Œ. ì‚´ 수 있는 ë‚ ê¹Œì§€ 세ìƒì„ ë– ë‚œ ê³³ì—서 살다가 ì™„ì „í•œ í•´ê²°ì„ ì–»ëŠ” ë‚ ë‚˜ëŠ” í˜¹ì€ ìŠ¹ë¦¬ì˜, í˜¹ì€ íŒ¨ë°°ì˜ ì¢…ë§‰ì„ ë‹«ì¹ ê²ƒì´ì˜¤. ë§Œì¼ í•´ê²°ì´ ì•ˆ ë˜ë©´ 안 ë˜ëŠ” 대로 그치면 그만ì´ì§€ìš”.
+나는 ì´ ë¶“ì„ ë†“ê¸° ì „ì— ì–´ì ¯ë°¤ì— ê¾¼ 꿈 ì´ì•¼ê¸° 하나는 í•˜ë ¤ì˜¤. ê¿ˆì´ í•˜ë„ ìˆ˜ìƒí•´ì„œ 마치 ë‚´ ì „ë„ì— ëŒ€í•œ ì‹ ì˜ ê³„ì‹œì™€ë„ ê°™ê¸°ë¡œ 하는 ë§ì´ì˜¤. ê·¸ ê¿ˆì€ ì´ëŸ¬í•˜ì˜€ì†Œ.
+ë‚´ê°€ ê½ì´ê¹¨(꼬ì´ê¹Œë¼ëŠ” ì•„ë¼ì‚¬ë§ë¡œ 침대ë¼ëŠ” ë§ì´ ì¡°ì„ ë™í¬ì˜ 입으로 변한 ë§ì´ì˜¤.) ì§ì„ ì§€ê³ ì‚½ì„ ë©”ê³ ëˆˆì´ ë®ì¸ 삼림 ì†ì„ í˜¼ìž ê±¸ì—ˆì†Œ. ì´ ê½ì´ê¹¨ ì§ì´ëž€ ê²ƒì€ ê¸ˆì ê¾¼ë“¤ì´ ê·¸ 여행 ì¤‘ì— ì†Œìš©í’ˆ, 마른 ë¹µ, 소금, ë‚´ë³µ 등ì†ì„ 침대 ë§¤íŠ¸ë¦¬ìŠ¤ì— ë„£ì–´ì„œ ì§€ê³ ë‹¤ë‹ˆëŠ” 것ì´ì˜¤. ì´ ì§í•˜ê³ 삽 한 ê°œ, ë„ë¼ í•œ ê°œ, ê·¸ê²ƒì´ ì‹œë² ë¦¬ì•„ë¡œ ê¸ˆì„ ì°¾ì•„ 헤매는 ì¡°ì„ ë™í¬ë“¤ì˜ 행색ì´ì˜¤. ë‚´ê°€ ì´ë¥´ì¿ ì¸ í¬ì—서 ì´ëŸ¬í•œ ë™í¬ë¥¼ ë§Œë‚¬ë˜ ê²ƒì´ ê¿ˆìœ¼ë¡œ ë˜ì–´ 나온 모양ì´ì˜¤.
+나는 꿈ì—는 세ìƒì„ 다 잊어버린, 아주 깨ë—í•˜ê³ ì¹¨ì°©í•œ 사람으로 ì´ ê½ì´ê¹¨ ì§ì„ ì§€ê³ ì‚½ì„ ë©”ê³ ë°¤ì¸ì§€ ë‚®ì¸ì§€ 알 수 없으나 ë•…ì€ ëˆˆë¹›ìœ¼ë¡œ í¬ê³ , í•˜ëŠ˜ì€ êµ¬ë¦„ë¹›ìœ¼ë¡œ íšŒìƒ‰ì¸ ì‚¼ë¦¼ 지대를 í—ˆë•í—ˆë• ê±¸ì—ˆì†Œ. ê¸¸ë„ ì—†ëŠ” ë°ë¥¼, ì¸ì ë„ ì—†ëŠ” ë°ë¥¼.
+꿈ì—ë„ ë‚´ ëª¸ì€ í½ í”¼ê³¤í•´ì„œ 쉴 ìžë¦¬ë¥¼ 찾는 마ìŒì´ì—ˆì†Œ.
+나는 마침내 ì–´ë–¤ ì–¸ë• ë°‘ 한 êµ°ë°ë¥¼ 골ëžì†Œ. ê·¸ë¦¬ê³ ìƒì‹œì— ì´ì•¼ê¸°ì—서 ë“¤ì€ ëŒ€ë¡œ 삽으로 ë‚´ê°€ 누울 ìžë¦¬ë§Œí•œ ëˆˆì„ ì¹˜ê³ , ê·¸ë¦¬ê³ ëŠ” ë„ë¼ë¡œ ê³ì— ì„ ë‚˜ë¬´ 몇 개를 ì°ì–´ 누ì´ê³ 거기다가 ë¶ˆì„ ë†“ê³ ê·¸ ë¶ˆê¹€ì— ë…¹ì€ ë•…ì„ ë‘ì–´ ìžë‚˜ íŒŒë‚´ê³ ê·¸ ì†ì— ë“œëŸ¬ëˆ„ì› ì†Œ. 훈훈한 ê²ƒì´ ì•„ì£¼ 편안하였소.
+하늘ì—는 ë³„ì´ ë°˜ì§ê±°ë ¸ì†Œ. Fì—ì—서 ë³´ë˜ ë°”ì™€ ê°™ì´ í° ë³„ ìž‘ì€ ë³„ë„ ë³´ì´ê³ í‰ì‹œì— ë³´ì§€ ëª»í•˜ë˜ ë¶‰ì€ ë³„, 푸른 별 ë“¤ë„ ë³´ì˜€ì†Œ. 나는 ì´ ì´ìƒí•œ 하늘, ì´ìƒí•œ ë³„ë“¤ì´ ìžˆëŠ” í•˜ëŠ˜ì„ ë³´ê³ ë“œëŸ¬ëˆ„ì›Œ 있노ë¼ë‹ˆê¹Œ ë¬¸ë“ ì–´ë””ì„œ ë°œìžêµ 소리가 ë“¤ë ¸ì†Œ. í‰í‰í‰í‰ 우루루루…… 나는 벌떡 ì¼ì–´ë‚˜ë ¤ 하였으나 ëª¸ì´ ì²œ ê·¼ì´ë‚˜ ë˜ì–´ì„œ 움ì§ì¼ 수가 없었소. 가까스로 ê³ ê°œë¥¼ 조금 ë“¤ê³ ë³´ë‹ˆ ë¿”ì´ ê¸¸ë‹¤ëž—ê³ ëˆˆì´ ë¶ˆê°™ì´ ë¶‰ì€ ì‚¬ìŠ´ì˜ ë–¼ê°€ ë¬´ì—‡ì— ë†€ëžëŠ”ì§€ 껑충껑충 ë›°ì–´ 지나가오. ì´ê²ƒì€ 아마 í¬ë¡œí¬íŠ¸í‚¨ì˜ <ìƒí˜¸ ë¶€ì¡°ë¡ > ì†ì— ë§í•œ ì‹œë² ë¦¬ì•„ì˜ ì‚¬ìŠ´ì˜ ë–¼ê°€ ê¿ˆì´ ë˜ì–´ 나온 모양ì´ì˜¤.
+그러ë”니 ê·¸ ì‚¬ìŠ´ì˜ ë–¼ê°€ 다 지나간 ë’¤ì—, ê·¸ ì‚¬ìŠ´ì˜ ë–¼ê°€ ì˜¤ë˜ ë°©í–¥ìœ¼ë¡œì„œ ì •ìž„ì´ê°€ 걸어오는 ê²ƒì´ ì•„ë‹ˆë¼ ìŠ¤ë¥´ë¥µ í•˜ê³ ë¯¸ë„ëŸ¬ì ¸ 오오. 마치 ì¸í˜•ì„ ë°€ì–´ 주는 것같ì´.
+"ì •ìž„ì•„!"
+í•˜ê³ ë‚˜ëŠ” 소리를 ì¹˜ê³ ëª¸ì„ ì¼ìœ¼í‚¤ë ¤ 하였소.
+ì •ìž„ì˜ ëª¨ì–‘ì€ ë‚˜ë¥¼ ìž ê¹ ë³´ê³ ëŠ” 미ë„러지는 ë“¯ì´ í˜ëŸ¬ê°€ 버리오.
+나는 ì •ìž„ì•„, ì •ìž„ì•„ë¥¼ ë¶€ë¥´ê³ íŒ”ë‹¤ë¦¬ë¥¼ ë¶€ë‘¥ê±°ë ¸ì†Œ. 그러다가 마침내 ë‚´ ëª¸ì´ ë²ˆì© ì¼ìœ¼ì¼œì§ì„ 깨달았소. 나는 ì •ìž„ì˜ ë’¤ë¥¼ ë”°ëžì†Œ.
+나는 눈 위로 삼림 ì†ìœ¼ë¡œ ì •ìž„ì˜ ê·¸ë¦¼ìžë¥¼ ë”°ëžì†Œ. ë³´ì¼ ë“¯ 안 ë³´ì¼ ë“¯, ìž¡íž ë“¯ 안 ìž¡íž ë“¯, 나는 무거운 다리를 ëŒê³ ì •ìž„ì„ ë”°ëžì†Œ.
+ì •ìž„ì€ ì´ ì¶”ìš´ ë‚ ì´ì–¸ë§Œ 눈과 ê°™ì´ í° ì˜·ì„ ìž…ì—ˆì†Œ. ê·¸ ì˜·ì€ ì˜›ë‚ ë¡œë§ˆ ì—¬ì¸ì˜ 옷과 ê°™ì´ ë°”ëžŒê²°ì— íŽ„ë ê±°ë ¸ì†Œ.
+"오지 마세요. ì €ë¥¼ ë”°ë¼ì˜¤ì§€ 못하ì‹ë‹ˆë‹¤."
+í•˜ê³ ì •ìž„ì€ ëˆˆë³´ë¼ ì†ì— 가리워 ë²„ë¦¬ê³ ë§ì•˜ì†Œ. 암만 ë¶ˆëŸ¬ë„ ëŒ€ë‹µì´ ì—†ê³ ëˆˆë³´ë¼ê°€ 다 지나간 ë’¤ì—ë„ ë¶‰ì€ ë³„, 푸른 별과 ë¿” 긴 ì‚¬ìŠ´ì˜ ë–¼ë¿ì´ì˜¤. ì •ìž„ì€ ë³´ì´ì§€ 아니하였소. 나는 ë¯¸ì¹ ë“¯ì´ ì •ìž„ì„ ì°¾ê³ ë¶€ë¥´ë‹¤ê°€ ìž ì„ ê¹¨ì—ˆì†Œ.
+ê¿ˆì€ ì´ê²ƒë¿ì´ì˜¤. ê¿ˆì„ ê¹¨ì–´ì„œ ì°½ ë°–ì„ ë°”ë¼ë³´ë‹ˆ ì–¼ìŒê³¼ ëˆˆì— ë®ì¸ ë°”ì´ì¹¼í˜¸ 위ì—는 ìƒˆë²½ì˜ ê²¨ìš¸ ë‹¬ì´ ë¹„ì¹˜ì–´ 있었소. ì € 멀리 검푸르게 ë³´ì´ëŠ” ê²ƒì´ ì±„ 얼어붙지 아니한 물ì´ê² 지요. 오늘 ë°¤ì— ë°”ëžŒì´ ì—†ê³ ê¸°ì˜¨ì´ ë‚´ë¦¬ë©´ ê·¸ê²ƒë§ˆì € 얼어붙ì„는지 모르지요. ë²Œì¨ ì‚´ì–¼ìŒì´ ìž¡í˜”ëŠ”ì§€ë„ ëª¨ë¥´ì§€ìš”. ì•„ì•„, ê·¸ ì†ì€ 얼마나 깊ì„까. 나는 ë°”ì´ì¹¼ì˜ 물 ì†ì´ ê´€ì‹¬ì´ ë˜ì–´ì„œ 못 ê²¬ë””ê² ì†Œ.
+형! 나는 ìžë°±í•˜ì§€ ì•„ë‹ˆí• ìˆ˜ 없소. ì´ ê¿ˆì€ ë‚´ 마ìŒì˜ ì–´ë–¤ ë¶€ë¶„ì„ ì„¤ëª…í•œ 것ì´ë¼ê³ . 그러나 형! 나는 ì´ê²ƒì„ ë¶€ì •í•˜ë ¤ì˜¤. 굳세게 ë¶€ì •í•˜ë ¤ì˜¤. 나는 ì´ ê¿ˆì„ ë¶€ì •í•˜ë ¤ì˜¤. 억지로ë¼ë„ ë¶€ì •í•˜ë ¤ì˜¤. 나는 ê²°ì½” ë‚´ ì†ì— ì¼ì–´ë‚œ í˜ëª…ì„ ìš©ì¸í•˜ì§€ ì•„ë‹ˆí•˜ë ¤ì˜¤. 나는 ê·¸ê²ƒì„ í˜ëª…으로 ì¸ì •하지 ì•„ë‹ˆí•˜ë ¤ì˜¤. 아니오! 아니오! ê·¸ê²ƒì€ ë°˜ëž€ì´ì˜¤! ë‚´ ì¸ê²©ì˜ 통ì¼ì— 대한 반란ì´ì˜¤. 단연코 무단ì 으로 ì§„ì •í•˜ì§€ 아니하면 아니 ë 반란ì´ì˜¤. 보시오! 나는 굳게 서서 한 걸ìŒë„ 뒤로 물러서지 ì•„ë‹ˆí• ê²ƒì´ì˜¤. ë§Œì¼ì— í˜•ì´ ê´‘ì•¼ì— êµ¬ë¥´ëŠ” ë‚´ 시체나 í•´ê³¨ì„ ë³¸ë‹¤ë“ ì§€, ë˜ëŠ” 무슨 ì¸ì—°ìœ¼ë¡œ ë‚´ 무ë¤ì„ 발견하는 ë‚ ì´ ìžˆë‹¤ê³ í•˜ë©´ ê·¸ ë•Œì— í˜•ì€ ë‚´ê°€ ì´ ëª¨ë“ ë°˜ëž€ì„ ì§„ì •í•œ ê°œì„ ì˜ êµ°ì£¼ë¡œ ì£½ì€ ê²ƒì„ ì•Œì•„ 주시오.
+ì¸ì œ ë°”ì´ì¹¼ì— ê²¨ìš¸ì˜ ì„ì–‘ì´ ë¹„ì¹˜ì—ˆì†Œ. ëˆˆì„ ì¸ ë‚˜ì§€ë§‰í•œ ì‚°ë“¤ì´ ì§€ëŠ” í–‡ë¹›ì— ìžì¤ë¹›ì„ ë°œí•˜ê³ ìžˆì†Œ. 극히 깨ë—í•˜ê³ ì‹¸ëŠ˜í•œ ê´‘ê²½ì´ì˜¤. ì•„ë””ìœ !
+ì´ íŽ¸ì§€ë¥¼ ìš°íŽ¸ì— ë¶€ì¹˜ê³ ëŠ” 나는 ìµœí›„ì˜ ë°©ëž‘ì˜ ê¸¸ì„ ë– ë‚˜ì˜¤. ì°¾ì„ ìˆ˜ë„ ì—†ê³ , 편지 ë°›ì„ ìˆ˜ë„ ì—†ëŠ” 곳으로.
+부디 í‰ì•ˆížˆ 계시오. ì¼ ë§Žì´ í•˜ì‹œì˜¤. ë¶€ì¸ê»˜ 문안 드리오. ë‚´ 가족과 ì •ìž„ì˜ ì¼ ë§¡ê¸°ì˜¤. ì•„ë””ìœ !
+ì´ê²ƒìœ¼ë¡œ ìµœì„ êµ°ì˜ íŽ¸ì§€ëŠ” ë났다.
+나는 ì´ íŽ¸ì§€ë¥¼ ë°›ê³ ìš¸ì—ˆë‹¤. ì´ê²ƒì´ ì¼ íŽ¸ì˜ ì†Œì„¤ì´ë¼ 하ë”ë¼ë„ 슬픈 ì¼ì´ì–´ë“ , 하물며 ë‚´ê°€ 가장 ë¯¿ê³ ì‚¬ëž‘í•˜ëŠ” ì¹œêµ¬ì˜ ì¼ìž„ì—야.
+ì´ íŽ¸ì§€ë¥¼ ë°›ê³ ë‚˜ëŠ” ê³§ ìµœì„ êµ°ì˜ ì§‘ì„ ì°¾ì•˜ë‹¤. 주ì¸ì„ ìžƒì€ ì´ ì§‘ì—서는아ì´ë“¤ì´ 마당ì—서 ë– ë“¤ê³ ìžˆì—ˆë‹¤.
+"삼ì²ë™ ì•„ìžì”¨ 오셨수. 어머니, 삼ì²ë™ ì•„ìžì”¨."
+í•˜ê³ ìµœì„ êµ°ì˜ ìž‘ì€ë”¸ì´ 나를 ë³´ê³ ë›°ì–´ë“¤ì–´ê°”ë‹¤.
+최ì„ì˜ ë¶€ì¸ì´ 나와 나를 맞았다.
+ë¶€ì¸ì€ ë¨¸ë¦¬ë„ ë¹—ì§€ ì•„ë‹ˆí•˜ê³ , 얼굴ì—는 ì¡°ê¸ˆë„ í™”ìž¥ì„ ì•„ë‹ˆí•˜ê³ , ë§¤ë¬´ì‹œë„ í˜ëŸ¬ë‚´ë¦´ 지경으로 ì •ëˆë˜ì§€ 못하였다. ì¼ ì£¼ì¼ì´ë‚˜ 못 만난 ë™ì•ˆì— ë¶€ì¸ì˜ ëª¨ì–‘ì€ ë”ìš± 초췌하였다.
+"ë…¸ì„헌테서 무슨 기별ì´ë‚˜ 있습니까."
+í•˜ê³ ë‚˜ëŠ” 무슨 ë§ë¡œ ë§ì„ ì‹œìž‘í• ì§€ 몰ë¼ì„œ ì´ëŸ° ë§ì„ 하였다.
+"아니오. 왜 ê·¸ì´ê°€ ì§‘ì— íŽ¸ì§€í•˜ë‚˜ìš”?"
+í•˜ê³ ë¶€ì¸ì€ 성난 ë¹›ì„ ë³´ì´ë©°,
+"ì§‘ì„ ë– ë‚œ 지가 ê·¼ ì‚¬ì‹ ì¼ì´ ë˜ê±´ë§Œ 엽서 한 장 있나요. 집안 ì‹êµ¬ê°€ 다 죽기로 눈ì´ë‚˜ 깜ì§í• ì¸ê°€ìš”. ê·¸ì € ì •ìž„ì´í—Œí…Œë§Œ 미ì³ì„œ 죽ì„ì§€ 살지를 모르지요."
+í•˜ê³ ìš¸ë¨¹ìš¸ë¨¹í•œë‹¤.
+"잘못 ì•„ì‹ë‹ˆë‹¤. ë¶€ì¸ê»˜ì„œ ë…¸ì„ì˜ ë§ˆìŒì„ 잘못 ì•„ì‹ë‹ˆë‹¤. 그런 ê²ƒì´ ì•„ë‹™ë‹ˆë‹¤."
+í•˜ê³ ë‚˜ëŠ” í™•ì‹ ìžˆëŠ” ë“¯ì´ ë§ì„ 시작하였다.
+"ë…¸ì„ì˜ ìƒê°ì„ ë¶€ì¸ê»˜ì„œ ì˜¤í•´í•˜ì‹ ì¤„ì€ ë²Œì¨ë¶€í„° 알았지마는 오늘 ë…¸ì„ì˜ íŽ¸ì§€ë¥¼ ë°›ì•„ë³´ê³ ë”ìš± 분명히 알았습니다."
+í•˜ê³ ë‚˜ëŠ” ë¶€ì¸ì˜ í‘œì •ì˜ ë³€í™”ë¥¼ 엿보았다.
+"편지가 왔어요?"
+í•˜ê³ ë¶€ì¸ì€ 놀ë¼ë©´ì„œ,
+"지금 ì–´ë”” 있어요? ì¼ë³¸ 있지요?"
+í•˜ê³ ì§ˆíˆ¬ì˜ ë¶ˆê¸¸ì„ ëˆˆìœ¼ë¡œ í† í•˜ì˜€ë‹¤.
+"ì¼ë³¸ì´ 아닙니다. ë…¸ì„ì€ ì§€ê¸ˆ ì•„ë¼ì‚¬ì— 있습니다."
+"ì•„ë¼ì‚¬ìš”?"
+í•˜ê³ ë¶€ì¸ì€ 놀ë¼ëŠ” ë¹›ì„ ë³´ì´ë”니,
+"그럼 ì •ìž„ì´ë¥¼ ë°ë¦¬ê³ 아주 ì•„ë¼ì‚¬ë¡œ 가케오치를 하였군요."
+í•˜ê³ ížˆìŠ¤í…Œë¦¬ì»¬í•œ 웃ìŒì„ ë³´ì´ê³ 는 ëª¸ì„ í•œ 번 떨었다.
+ë¶€ì¸ì€ 남편과 ì •ìž„ì˜ ê´€ê³„ë¥¼ ë§í• 때마다 ì´ë ‡ê²Œ ê²½ë ¨ì ì¸ ì›ƒìŒì„ ì›ƒê³ ëª¸ì„ ë– ëŠ” ê²ƒì´ ë²„ë¦‡ì´ì—ˆë‹¤.
+"아닙니다. ë…¸ì„ì€ í˜¼ìž ê°€ 있습니다. ê·¸ë ‡ê²Œ 오해를 마세요."
+í•˜ê³ ë‚˜ëŠ” ë³´ì— ì‹¼ 최ì„ì˜ íŽ¸ì§€ë¥¼ 내어서 ë¶€ì¸ì˜ 앞으로 밀어 놓으며,
+"ì´ê²ƒì„ 보시면 다 아실 줄 압니다. 어쨌으나 ë…¸ì„ì€ ê²°ì½” ì •ìž„ì´ë¥¼ ë°ë¦¬ê³ ê°„ ê²ƒì´ ì•„ë‹ˆìš”, ë„리어 ì •ìž„ì´ë¥¼ 멀리 ë– ë‚˜ì„œ ê°„ 것입니다. 그러나 ê·¸ë³´ë‹¤ë„ ì¤‘ëŒ€ ë¬¸ì œê°€ 있습니다. ë…¸ì„ì€ ì´ íŽ¸ì§€ë¥¼ ë³´ë©´ ì£½ì„ ê²°ì‹¬ì„ í•œ 모양입니다."
+í•˜ê³ ë¶€ì¸ì˜ 주ì˜ë¥¼ 질투로부터 ê·¸ 남편ì—게 대한 ë™ì •ì— ëŒì–´ ë³´ë ¤ 하였다.
+"í¥. 왜요? 시체 ì •ì‚¬ë¥¼ 하나요? ì¢‹ê² ìŠµë‹ˆë‹¤. 머리가 허연 ê²ƒì´ ë”¸ìžì‹ ê°™ì€ ê³„ì§‘ì• í—ˆêµ¬ ì •ì‚¬ë¥¼ 한다면 ê·¸ ê¼´ ì¢‹ê² ìŠµë‹ˆë‹¤. 죽으ë¼ì§€ìš”. 죽으래요. 죽는 ê²ƒì´ ë‚«ì§€ìš”. 그리구 살아서 무엇 í•´ìš”?"
+ë‚´ ëœ»ì€ í‹€ë ¤ ë²„ë ¸ë‹¤. ë¶€ì¸ì˜ í‘œì •ê³¼ ë§ì—서는 ë”ìš±ë”ìš± ë…한 ì§ˆíˆ¬ì˜ ì•ˆê°œì™€ 싸늘한 ì–¼ìŒê°€ë£¨ê°€ ë‚ ì•˜ë‹¤.
+나는 ë¶€ì¸ì˜ ì´ íƒœë„ì— ë°˜ê°ì„ ëŠê¼ˆë‹¤. 아무리 ì§ˆíˆ¬ì˜ ê°ì •ì´ ê°•í•˜ë‹¤ 하기로, ì‚¬ëžŒì˜ ìƒëª…ì´ ì œ ë‚¨íŽ¸ì˜ ìƒëª…ì´ ìœ„íƒœí•¨ì—ë„ ë¶ˆêµ¬í•˜ê³ ì˜¤ì§ ì œ ì§ˆíˆ¬ì˜ ê°ì •ì—ë§Œ ì¶©ì‹¤í•˜ë ¤ 하는 ê·¸ 태ë„ê°€ 불쾌하였다. 그래서 나는,
+"나는 ê·¸ë§Œí¼ ë§ì”€í•´ ë“œë ¸ìœ¼ë‹ˆ ë” í• ë§ì”€ì€ 없습니다. ì•„ë¬´ë ¤ë‚˜ ì¢€ë” ëƒ‰ì •í•˜ê²Œ ìƒê°í•´ 보세요. ê·¸ë¦¬ê³ ì´ê²ƒì„ ì½ì–´ 보세요."
+í•˜ê³ ì¼ì–´ë‚˜ì„œ 집으로 ëŒì•„와 ë²„ë¦¬ê³ ë§ì•˜ë‹¤.
+ë„무지 불쾌하기 그지없는 ë‚ ì´ë‹¤. 최ì„ì˜ íƒœë„ê¹Œì§€ë„ ë¶ˆì¾Œí•˜ë‹¤. 달아나긴 왜 달아나? 죽기는 왜 죽어? 못난 것! 기운 없는 것! í•˜ê³ ë‚˜ëŠ” 최ì„ì´ê°€ ê³ì— 섰기나 한 것처럼 ëˆˆì„ í˜ê¸°ê³ ì¤‘ì–¼ê±°ë ¸ë‹¤.
+최ì„ì˜ ë§ëŒ€ë¡œ 최ì„ì˜ ë¶€ì¸ì€ 악한 ì‚¬ëžŒì´ ì•„ë‹ˆìš”, ê·¸ì € ë³´í†µì¸ ì—¬ì„±ì¼ëŠ”ì§€ 모른다. ê·¸ë ‡ë‹¤ 하면 ì—¬ìžì˜ 마ìŒì´ëž€ ë„ˆë¬´ë„ ì§ˆíˆ¬ì˜ ì¢…ì´ ì•„ë‹ê¹Œ. 설사 남편 ë˜ëŠ” 최ì„ì˜ ì‚¬ëž‘ì´ ì•„ë‚´ë¡œë¶€í„° ì •ìž„ì—게로 옮아 ê°”ë‹¤ê³ í•˜ë”ë¼ë„ ê·¸ê²ƒì„ ì§ˆíˆ¬ë¡œ íšŒë³µí•˜ë ¤ëŠ” ê²ƒì€ ì–´ë¦¬ì„ì€ ì¼ì´ë‹¤. ì´ë¯¸ ì‚¬ëž‘ì´ ë– ë‚œ ë‚¨íŽ¸ì„ ë„¤ 마ìŒëŒ€ë¡œ ê°€ê±°ë¼ í•˜ê³ ìžë°œì 으로 내어버릴 것ì´ì§€ë§ˆëŠ” ê·¸ê²ƒì„ ëª» í• ì‚¬ì •ì´ ìžˆë‹¤ê³ í•˜ë©´ 모르는 ì²´í•˜ê³ ë‚´ë²„ë ¤ 둘 ê²ƒì´ ì•„ë‹Œê°€. ê·¸ëž˜ë„ ì´ê²ƒì€ 우리네 남ìžì˜ ì´ë¡ ì´ìš”, ì—¬ìžë¡œëŠ” ì´ëŸ° ê²½ìš°ì— ì§ˆíˆ¬ë¼ëŠ” ë°˜ì‘ë°–ì— ì—†ë„ë¡ ìƒê¸´ 것ì¼ê¹Œ 나는 ì´ëŸ° ìƒê°ì„ í•˜ê³ ìžˆì—ˆë‹¤.
+시계가 아홉시를 친다.
+남대문 ë°– ì •ê±°ìž¥ì„ ë– ë‚˜ëŠ” ì—´ì°¨ì˜ ê¸°ì 소리가 들린다.
+나는 만주를 ìƒê°í•˜ê³ , ì‹œë² ë¦¬ì•„ë¥¼ ìƒê°í•˜ê³ 최ì„ì„ ìƒê°í•˜ì˜€ë‹¤. 마ìŒìœ¼ë¡œëŠ” ì •ìž„ì„ ì‚¬ëž‘í•˜ë©´ì„œ ê·¸ ì‚¬ëž‘ì„ ë°œí‘œí• ìˆ˜ 없어서 ì‹œë² ë¦¬ì•„ì˜ ëˆˆ ë®ì¸ 삼림 ì†ìœ¼ë¡œ 방황하는 최ì„ì˜ ëª¨ì–‘ì´ ìµœì„ì˜ ê¿ˆ ì´ì•¼ê¸°ì— 있는 대로 ëˆˆì•žì— ì„ í•˜ê²Œ ë– ë‚˜ì˜¨ë‹¤.
+`ì‚¬ëž‘ì€ ëª©ìˆ¨ì„ ë¹¼ì•—ëŠ”ë‹¤.'
+í•˜ê³ ë‚˜ëŠ” 사랑ì¼ëž˜ ì¼ì–´ë‚˜ëŠ” ì¸ìƒì˜ ë¹„ê·¹ì„ ìƒê°í•˜ì˜€ë‹¤. 그러나 최ì„ì˜ ê²½ìš°ëŠ” 보통 있는 ê³µì‹ê³¼ëŠ” 달ë¼ì„œ ì‚¬ëž‘ì„ ì£½ì´ê¸° 위해서 ì œ ëª©ìˆ¨ì„ ì£½ì´ëŠ” 것ì´ì—ˆë‹¤. ê·¸ë ‡ë‹¤ 하ë”ë¼ë„,
+`ì‚¬ëž‘ì€ ëª©ìˆ¨ì„ ë¹¼ì•—ëŠ”ë‹¤.'
+는 ë°ì—는 ë‹¤ë¦„ì´ ì—†ë‹¤.
+나는 ë¶ˆì¾Œë„ í•˜ê³ ëª¸ë„ ìœ¼ìŠ¤ìŠ¤í•˜ì—¬ 얼른 ìžë¦¬ì— ëˆ„ì› ë‹¤. ë©°ëŠë¦¬ê°€ 들어온 뒤부터 사랑 ìƒí™œì„ 하는 지가 ë²Œì¨ ì˜¤ ë…„ì´ë‚˜ ë˜ì—ˆë‹¤. 우리 부처란 ì¸ì œëŠ” 한 ì—사ì 존재요, 윤리ì ê´€ê³„ì— ë¶ˆê³¼í•˜ì˜€ë‹¤. 오래 사귄 친구와 ê°™ì€ ìµìˆ™í•¨ì´ ìžˆê³ , ì§‘ì— ì—†ì§€ ëª»í• ì‚¬ëžŒì´ë¼ëŠ” í•„ìš”ê°ë„ 있지마는 ì Šì€ ë¶€ì²˜ê°€ 가지는 듯한 그런 ì •ì€ ë²Œì¨ ì—†ëŠ” ì§€ 오래였다. ì•„ë‚´ë„ ë‚˜ë¥¼ 대하면 본체만체, ë‚˜ë„ ì•„ë‚´ë¥¼ 대하면 본체만체, 무슨 필요가 있어서 ë§ì„ ë¶™ì´ë”ë¼ë„ ì•„ë¬´ìª¼ë¡ ë“£ê¸° 싫기를 ì›í•˜ëŠ” ë“¯ì´ í†¡í†¡ ë‚´ë˜ì¡Œë‹¤. ì•„ë‚´ë„ ê·¼ëž˜ì— ì™€ì„œëŠ” ì˜·ë„ ì•„ë¬´ë ‡ê²Œë‚˜, ë¨¸ë¦¬ë„ ì•„ë¬´ë ‡ê²Œë‚˜, ì–´ë”” ì¶œìž…í• ë•Œë°–ì—는 ë„무지 í™”ìž¥ì„ ì•„ë‹ˆ 하였다.
+그러나 ê·¸ë ‡ë‹¤ê³ ìš°ë¦¬ ë¶€ì²˜ì˜ ìƒˆê°€ 좋지 못한 ê²ƒë„ ì•„ë‹ˆì—ˆë‹¤. 서로 소중히 여기는 마ìŒë„ 있었다. ì•„ë‚´ê°€ ì•ˆì— ìžˆë‹¤ê³ ìƒê°í•˜ë©´ 마ìŒì´ ë“ ë“ í•˜ê³ ë˜ ì•„ë‚´ì˜ ë§ì— ì˜í•˜ê±´ëŒ€ ë‚´ê°€ ì‚¬ëž‘ì— ìžˆê±°ë‹ˆ 하면 마ìŒì´ ë“ ë“ í•˜ë‹¤ê³ í•œë‹¤.
+우리 ë¶€ì²˜ì˜ ê´€ê³„ëŠ” ì´ëŸ¬í•œ 관계다.
+나는 한 ë°©ì—서 í˜¼ìž ìž ì„ ìžëŠ” ê²ƒì´ ìŠµê´€ì´ ë˜ì–´ì„œ 누가 ê³ì— 있으면 ìž ì´ ìž˜ 들지 아니하였다. 혹시 ì–´ë¦°ê²ƒë“¤ì´ ë§¤ë¥¼ ì–»ì–´ë§žê³ ì‚¬ëž‘ìœ¼ë¡œ í”¼ë‚œì„ ì™€ì„œ 울다가 ë‚´ ìžë¦¬ì—서 ìž ì´ ë“¤ë©´ 귀엽기는 ê·€ì—¬ì›Œë„ ìž ìžë¦¬ëŠ” 편안치 아니하였다. 나는 ì±…ì„ ë³´ê³ ê¸€ì„ ì“°ê³ ê³µìƒì„ í•˜ê³ ìžˆìœ¼ë©´ 족하였다. 내게는 아무 ì• ìš•ì ìš”êµ¬ë„ ì—†ì—ˆë‹¤. ì´ê²ƒì€ ë‚´ ì •ë ¥ì´ ì‡ ëª¨í•œ 까ë‹ì¸ì§€ 모른다.
+그러나 최ì„ì˜ íŽ¸ì§€ë¥¼ 본 ê·¸ ë‚ ë°¤ì—는 ë„무지 ìž ì´ ìž˜ 들지 아니하였다. 최ì„ì˜ íŽ¸ì§€ê°€ 최ì„ì˜ ê³ ë¯¼ì´ ë‚´ ì¡¸ë˜ ì˜ì‹ì— 무슨 ìžê·¹ì„ 준 듯하였다. ì 막한 듯하였다. í—ˆì „í•œ 듯하였다. 무엇ì¸ì§€ 모르나 그리운 ê²ƒì´ ìžˆëŠ” 것 같았다.
+"ì–´, ì´ê±° 안ë˜ì—ˆêµ°."
+í•˜ê³ ë‚˜ëŠ” 벌떡 ì¼ì–´ë‚˜ 담배를 피워 물었다.
+"나으리 주무셔 곕시오?"
+í•˜ê³ ì•„ë²”ì´ ì „ë³´ë¥¼ ê°€ì§€ê³ ì™”ë‹¤.
+"명조 경성 ì°© ë‚¨ì •ìž„"
+ì´ë¼ëŠ” 것ì´ì—ˆë‹¤.
+"ì •ìž„ì´ê°€ 와?"
+í•˜ê³ ë‚˜ëŠ” ì „ë³´ë¥¼ 다시 ì½ì—ˆë‹¤.
+최ì„ì˜ ê·¸ 편지를 ë³´ë©´ ìµœì„ ë¶€ì¸ì—게는 ì–´ë–¤ ë°˜ì‘ì´ ì¼ì–´ë‚˜ê³ ì •ìž„ì—게는 ì–´ë–¤ ë°˜ì‘ì´ ì¼ì–´ë‚ 까, í•˜ê³ ìƒê°í•˜ë©´ ìžëª» 마ìŒì´ 편하지 못하였다.
+ì´íŠ¿ë‚ ì•„ì¹¨ì— ë‚˜ëŠ” 부산서 오는 차를 ë§žìœ¼ë ¤ê³ ì •ê±°ìž¥ì—를 나갔다.
+차는 ì œ ì‹œê°„ì— ë“¤ì–´ì™”ë‹¤. ë‚¨ì •ìž„ì€ ìŠˆíŠ¸ì¼€ì´ìФ 하나를 ë“¤ê³ ì°¨ì—서 ë‚´ë ¸ë‹¤. ê²€ì€ ì™¸íˆ¬ì— ê²€ì€ ëª¨ìžë¥¼ ì“´ ê·¸ì˜ ì–¼êµ´ì€ ë”ìš± 해쓱해 보였다.
+"ì„ ìƒë‹˜!"
+í•˜ê³ ì •ìž„ì€ ë‚˜ë¥¼ ë³´ê³ ì†ì— ë“¤ì—ˆë˜ ì§ì„ ë•…ë°”ë‹¥ì— ë‚´ë ¤ë†“ê³ , ë‚´ 앞으로 왔다.
+"í’ëž‘ì´ë‚˜ 없었나?"
+í•˜ê³ ë‚˜ëŠ” ë‚´ ì†ì— 잡힌 ì •ìž„ì˜ ì†ì´ 싸늘한 ê²ƒì„ ê·¼ì‹¬í•˜ì˜€ë‹¤.
+"네. 아주 잔잔했습니다. ì €ê°™ì´ ì•½í•œ ì‚¬ëžŒë„ ë°–ì— ë‚˜ì™€ì„œ 바다 경치를 구경하였습니다."
+í•˜ê³ ì •ìž„ì€ ì‚¬êµì ì¸ ì›ƒìŒì„ 웃었다. 그러나 ê·¸ì˜ ëˆˆì—는 ëˆˆë¬¼ì´ ìžˆëŠ” 것 같았다.
+"최 ì„ ìƒë‹˜ ì–´ë”” ê³„ì‹ ì§€ 아세요?"
+í•˜ê³ ì •ìž„ì€ ë‚˜ë¥¼ ë”°ë¼ ì„œë©´ì„œ 물었다.
+"ë‚˜ë„ ì§€ê¸ˆê¹Œì§€ 몰ëžëŠ”ë° ì–´ì œ 편지를 하나 받았지."
+하는 ê²ƒì´ ë‚´ 대답ì´ì—ˆë‹¤.
+"네? 편지 받으셨어요? ì–´ë”” 계ì‹ë‹ˆê¹Œ?"
+í•˜ê³ ì •ìž„ì€ ê±¸ìŒì„ 멈추었다.
+"ë‚˜ë„ ëª°ë¼."
+í•˜ê³ ë‚˜ë„ ì •ìž„ê³¼ ê°™ì´ ê±¸ìŒì„ ë©ˆì¶”ê³ ,
+"ê·¸ 편지를 ì“´ ê³³ë„ ì•Œê³ ë¶€ì¹œ ê³³ë„ ì•Œì§€ë§ˆëŠ” 지금 어디로 갔는지 ê·¸ê²ƒì€ ëª¨ë¥´ì§€. ì°¾ì„ ìƒê°ë„ ë§ê³ íŽ¸ì§€í• ìƒê°ë„ ë§ë¼ê³ 했으니까."
+í•˜ê³ ì‚¬ì‹¤ëŒ€ë¡œ 대답하였다.
+"어디야요? ê·¸ 편지 ë¶€ì¹˜ì‹ ê³³ì´ ì–´ë””ì•¼ìš”? ì € ì´ ì°¨ë¡œ ë”°ë¼ê°ˆ 테야요."
+í•˜ê³ ì •ìž„ì€ ì¡°ê¸‰í•˜ì˜€ë‹¤.
+"ê°ˆ 때ì—는 ê°€ë”ë¼ë„ ì´ ì°¨ì—야 ê°ˆ 수가 있나."
+í•˜ê³ ë‚˜ëŠ” 겨우 ì •ìž„ì„ ëŒê³ 들어왔다.
+ì •ìž„ì„ ì§‘ìœ¼ë¡œ ë°ë¦¬ê³ 와서 대강 ë§ì„ í•˜ê³ , ì´íŠ¿ë‚ ìƒˆë²½ 차로 ë– ë‚œë‹¤ëŠ” 것ì„,
+"가만 있어. 어떻게 계íšì„ 세워 ê°€ì§€ê³ í•´ì•¼ì§€."
+하여 가까스로 붙들어 놓았다.
+ì•„ì¹¨ì„ ë¨¹ê³ ë‚˜ì„œ ìµœì„ ì§‘ì—를 ê°€ ë³´ë ¤ê³ í• ì¦ˆìŒì— 순임ì´ê°€ 와서 마루 ëì— ì„ ì±„ë¡œ,
+"ì„ ìƒë‹˜, 어머니가 ìž ê¹ë§Œ 오ì‹ì‹œì‚¬êµ¬ìš”."
+하였다.
+"ì •ìž„ì´ê°€ 왔다."
+í•˜ê³ ë‚´ê°€ 그러니까,
+"ì •ìž„ì´ê°€ìš”?"
+í•˜ê³ ìˆœìž„ì€ ê¹œì§ ë†€ë¼ë©´ì„œ,
+"ì •ìž„ì´ëŠ” 아버지 ê³„ì‹ ë°ë¥¼ 알아요?"
+í•˜ê³ ë¬¼ì—ˆë‹¤.
+"ì •ìž„ì´ë„ 모른단다. 너 아버지는 ì‹œë² ë¦¬ì•„ì— ê³„ì‹œê³ ì •ìž„ì´ëŠ” ë™ê²½ 있다가 ì™”ëŠ”ë° ì•Œ 리가 있니?"
+í•˜ê³ ë‚˜ëŠ” ìˆœìž„ì˜ ìƒê°ì„ ê¹¨ëœ¨ë¦¬ë ¤ 하였다. 순임ì€,
+"ì •ìž„ì´ê°€ ì–´ë”” 있어요?"
+í•˜ê³ ë°©ë“¤ 있는 ê³³ì„ ë‘˜ëŸ¬ë³´ë©°,
+"ì–¸ì œ 왔어요?"
+í•˜ê³ ëŠ” ê·¸ì œì•¼ ì •ìž„ì—게 대한 반가운 ì •ì´ ë°œí•˜ëŠ” 듯ì´,
+"ì •ìž„ì•„!"
+í•˜ê³ ë¶ˆëŸ¬ 본다.
+"언니요? 여기 있수."
+í•˜ê³ ì •ìž„ì´ê°€ 머릿방 ë¬¸ì„ ì—´ê³ ì˜·ì„ ê°ˆì•„ìž…ë˜ ì±„ë¡œ ê³ ê°œë¥¼ 내어민다.
+ìˆœìž„ì€ êµ¬ë‘를 ì°¨ë‚´ë²„ë¦¬ë“¯ì´ ë²—ì–´ ë†“ê³ ì •ìž„ì˜ ë°©ìœ¼ë¡œ 뛰어들어간다.
+나는 최ì„ì˜ ì§‘ì—를 ê°€ëŠë¼ê³ 외투를 ìž…ê³ ëª¨ìžë¥¼ ì“°ê³ ì •ìž„ì˜ ë°©ë¬¸ì„ ì—´ì–´ 보았다. ë‘ ì²˜ë…€ëŠ” ìš¸ê³ ìžˆì—ˆë‹¤.
+"ì •ìž„ì´ë„ 가지. 아주머니 뵈러 안 ê°€?"
+í•˜ê³ ë‚˜ëŠ” ì •ìž„ì„ ìž¬ì´‰í•˜ì˜€ë‹¤.
+"ì„ ìƒë‹˜ ë¨¼ì € ê°€ 계셔요."
+í•˜ê³ ìˆœìž„ì´ê°€ ëˆˆë¬¼ì„ ì”»ê³ ì¼ì–´ë‚˜ë©´ì„œ,
+"ì´ë”°ê°€ ì œê°€ ì •ìž„ì´í—ˆêµ¬ 갑니다."
+í•˜ê³ ë‚´ê²Œ ëˆˆì„ ë”ì©ê±°ë ¤ 보였다. ê°‘ìžê¸° ì •ìž„ì´ê°€ 가면 어머니와 ì •ìž„ì´ì™€ 사ì´ì— ì–´ë– í•œ íŒŒëž€ì´ ì¼ì–´ë‚˜ì§€ë‚˜ ì•„ë‹ˆí• ê¹Œ í•˜ê³ ìˆœìž„ì´ê°€ ì—¼ë ¤í•˜ëŠ” 것ì´ì—ˆë‹¤. ìˆœìž„ë„ ì¸ì œëŠ” ë…¸ì„±í•˜ì—¬ì¡Œë‹¤ê³ ë‚˜ëŠ” ìƒê°í•˜ì˜€ë‹¤.
+"ì„ ìƒë‹˜ ì´ íŽ¸ì§€ê°€ 다 ì°¸ë§ì¼ê¹Œìš”?"
+í•˜ê³ ë‚˜ë¥¼ 보는 길로 ìµœì„ ë¶€ì¸ì´ 물었다. ìµœì„ ë¶€ì¸ì€ 히스테리를 ì¼ìœ¼í‚¨ 사람 모양으로 머리와 ì†ì„ 떨었다.
+나는 ì°¸ë§ì´ëƒ 하는 ê²ƒì´ ë¬´ì—‡ì„ ê°€ë¦¬í‚¤ëŠ” ë§ì¸ì§€ 분명하지 아니하여서,
+"ë…¸ì„ì´ ê±°ì§“ë§í• 사람입니까?"
+í•˜ê³ ëŒ€ì²´ë¡ ìœ¼ë¡œ 대답하였다.
+"앉으ì‹ì‡¼. 앉으시란 ë§ì”€ë„ 안 í•˜ê³ ."
+í•˜ê³ ë¶€ì¸ì€ 침착한 ëª¨ì–‘ì„ ë³´ì´ë ¤ê³ ë¹™ê·¸ë ˆ 웃었으나, ê·¸ê²ƒì€ ì‹¤íŒ¨ì˜€ë‹¤.
+"그게 ì°¸ë§ì¼ê¹Œìš”? ì •ìž„ì´ê°€ 아기를 ë—€ ê²ƒì´ ì•„ë‹ˆë¼, íê°€ ë‚˜ë¹ ì„œ 피를 í† í•˜ê³ ìž…ì›í•˜ì˜€ë‹¤ëŠ” 것ì´?"
+í•˜ê³ ë¶€ì¸ì€ 중대하다는 í‘œì •ì„ ê°€ì§€ê³ ë¬»ëŠ”ë‹¤.
+"그럼 ê·¸ê²ƒì´ ì°¸ë§ì´ 아니구요. ì•„ì§ë„ 그런 ì˜ì‹¬ì„ ê°€ì§€ê³ ê³„ì‹ë‹ˆê¹Œ. ì •ìž„ì´ì™€ 한 ë°©ì— ìžˆëŠ” í•™ìƒì´ 모함한 것ì´ë¼ê³ 안 그랬어요? 그게 ë§ì´ ë©ë‹ˆê¹Œ."
+í•˜ê³ ì–¸ì„±ì„ ë†’ì—¬ì„œ 대답하였다.
+"그럼 왜 ì •ìž„ì´ê°€ 호텔ì—서 왜 아버지한테 한 번 안아 달ë¼ê³ 그래요? ê·¸ íŽ¸ì§€ì— ì“´ 대로 한 번 안아만 보았ì„까요?"
+ì´ê²ƒì€ ë¶€ì¸ì˜ 둘째 물ìŒì´ì—ˆë‹¤.
+"나는 ê·¸ë¿ì´ë¼ê³ 믿습니다. ê·¸ê²ƒì´ ë„리어 깨ë—하다는 표ë¼ê³ 믿습니다. 안 ê·¸ë ‡ìŠµë‹ˆê¹Œ?"
+í•˜ê³ ë‚˜ëŠ” 딱하다는 í‘œì •ì„ í•˜ì˜€ë‹¤.
+"글쎄요."
+í•˜ê³ ë¶€ì¸ì€ 한참ì´ë‚˜ ìƒê°í•˜ê³ 있다가,
+"ì •ë§ ì• ì•„ë²„ì§€ê°€ í˜¼ìž ë‹¬ì•„ë‚¬ì„까요? ì •ìž„ì´ë¥¼ ë°ë¦¬ê³ 가케오치한 ê²ƒì´ ì•„ë‹ê¹Œìš”? ê¼ ê·¸ëž¬ì„ ê²ƒë§Œ ê°™ì€ë°."
+í•˜ê³ ë¶€ì¸ì€ 괴로운 í‘œì •ì„ ê°ì¶”ë ¤ëŠ” ë“¯ì´ ê³ ê°œë¥¼ 숙ì¸ë‹¤.
+나는 남편ì—게 대한 ì•„ë‚´ì˜ ì˜ì‹¬ì´ 어떻게 깊ì€ê°€ì— 아니 놀랄 수가 없어서,
+"í—ˆ."
+í•˜ê³ í•œ 마디 ì›ƒê³ ,
+"ê·¸ë ‡ê²Œ ìˆ˜ì‹ ë…„ ë™ì•ˆ 부부 ìƒí™œì„ í•˜ì‹œê³ ë„ ê·¸ë ‡ê²Œ ë…¸ì„ì˜ ì¸ê²©ì„ ëª°ë¼ ì£¼ì‹ë‹ˆê¹Œ. 나는 ë¶€ì¸ê»˜ì„œ 하시는 ë§ì”€ì´ 부러 하시는 ë†ë‹´ìœ¼ë¡œë°–ì— ì•„ë‹ˆ 들립니다. ì •ìž„ì´ê°€ 지금 서울 있습니다."
+í•˜ê³ ë˜ í•œ 번 웃었다. ì •ë§ ê¸°ë§‰ížŒ 웃ìŒì´ì—ˆë‹¤.
+"ì •ìž„ì´ê°€ 서울 있어요?"
+í•˜ê³ ë¶€ì¸ì€ íŽ„ì© ë›°ë©´ì„œ,
+"ì–´ë”” 있다가 ì–¸ì œ 왔습니까? 그게 ì •ë§ìž…니까?"
+í•˜ê³ ì˜ì•„한 ë¹›ì„ ë³´ì¸ë‹¤. ê¼ ìµœì„ì´í•˜ê³ 함께 ë‹¬ì•„ë‚¬ì„ ì •ìž„ì´ê°€ ì„œìš¸ì— ìžˆì„ ë¦¬ê°€ 없는 것ì´ì—ˆë‹¤.
+"ë™ê²½ì„œ 오늘 ì•„ì¹¨ì— ì™”ìŠµë‹ˆë‹¤. 지금 우리 ì§‘ì—서 순임ì´í—ˆêµ¬ ì´ì•¼ê¸°ë¥¼ í•˜ê³ ìžˆìœ¼ë‹ˆê¹Œ 조금 있으면 뵈오러 올 것입니다."
+í•˜ê³ ë‚˜ëŠ” ì •ìž„ì´ê°€ 분명히 서울 있는 ê²ƒì„ ì¼ì¼ì´ ì¦ê±°ë¥¼ 들어서 ì¦ëª…하였다. ê·¸ë¦¬ê³ ìš°ìŠ¤ìš´ ê²ƒì„ ì†ìœ¼ë¡œ 참았다. 그러나 ë‹¤ìŒ ìˆœê°„ì—는 ì´ ë³‘ë“¤ê³ ëŠ™ì€ ì•„ë‚´ì˜ ì§ˆíˆ¬ì™€ ì˜ì‹¬ìœ¼ë¡œ 괴로워서 ëœëœëœëœ ë–¨ê³ ì•‰ì•˜ëŠ” ê²ƒì„ ê°€ì—¾ê²Œ ìƒê°í•˜ì˜€ë‹¤.
+ì •ìž„ì´ê°€ 지금 ì„œìš¸ì— ìžˆëŠ” ê²ƒì´ ë” ì˜ì‹¬í• 여지가 없는 ì‚¬ì‹¤ìž„ì´ íŒëª…ë˜ë§¤, ë¶€ì¸ì€ ë„리어 ë‚™ë§í•˜ëŠ” 듯하였다. 그가 ì œ 마ìŒëŒ€ë¡œ ê·¸ë ¤ ë†“ê³ ë¯¿ê³ í•˜ë˜ ëª¨ë“ ì² í•™ì˜ ê³„í†µì´ ë¬´ë„ˆì§„ 것ì´ì—ˆë‹¤.
+한참ì´ë‚˜ í©ì–´ì§„ ì •ì‹ ì„ ëª» 수습하는 ë“¯ì´ ì•‰ì•„ 있ë”니 아주 기운 없는 어조로,
+"ì„ ìƒë‹˜ ì• ì•„ë²„ì§€ê°€ ì •ë§ ì£½ì„까요? ì •ë§ ì˜ì˜ ì§‘ì—를 안 ëŒì•„올까요?"
+í•˜ê³ ë¬»ëŠ”ë‹¤. ê·¸ 눈ì—는 ë²Œì¨ ëˆˆë¬¼ì´ ì–´ë¦¬ì—ˆë‹¤.
+"글쎄요. ë‚´ ìƒê° 같아서는 다시는 ì§‘ì— ëŒì•„오지 ì•„ë‹ˆí• ê²ƒ 같습니다. ë˜ ê·¸ë§Œì¹˜ ë§ì‹ ì„ í–ˆìœ¼ë‹ˆ, ì´ì œ 무슨 낯으로 ëŒì•„옵니까. ë‚´ë¼ë„ 다시 ì§‘ì— ëŒì•„올 ìƒê°ì€ 아니 ë‚´ê² ìŠµë‹ˆë‹¤."
+í•˜ê³ ë‚˜ëŠ” ì˜ì‹ì 으로 ì•…ì˜ë¥¼ ê°€ì§€ê³ ë¶€ì¸ì˜ ê°€ìŠ´ì— ì¹¼ì„ í•˜ë‚˜ 박았다.
+ê·¸ ì¹¼ì€ ë¶„ëª…ížˆ ë¶€ì¸ì˜ ê°€ìŠ´ì— ì•„í”„ê²Œ 박힌 모양ì´ì—ˆë‹¤.
+"ì„ ìƒë‹˜. 어떡하면 좋습니까. ì• ì•„ë²„ì§€ê°€ 죽지 않게 í•´ 주세요. ê·¸ë ‡ì§€ ì•Šì•„ë„ ìˆœìž„ì´ë…„ì´ ì œê°€ ê±” 아버지를 달아나게나 한 것처럼 ì›ë§ì„ 하는ë°ìš”. 그러다가 ì •ë…• 죽으면 어떻게 합니까. ì œì¼ ë”´ ìžì‹ë“¤ì˜ ì›ë§ì„ 들ì„ê¹Œë´ ê²ì´ 납니다. ì„ ìƒë‹˜, 어떻게 ì• ì•„ë²„ì§€ë¥¼ 붙들어다 주세요."
+í•˜ê³ ë§ˆì¹¨ë‚´ ì°¸ì„ ìˆ˜ ì—†ì´ ìš¸ì—ˆë‹¤. ë§ì€ ë¹„ë¡ ìžì‹ë“¤ì˜ ì›ë§ì´ ë‘ë µë‹¤ê³ í•˜ì§€ë§ˆëŠ” ì§ˆíˆ¬ì˜ ê°ì •ì´ ìŠ¤ëŸ¬ì§ˆ ë•Œì— ê·¸ì—게는 남편ì—게 대한 ì•„ë‚´ì˜ ì• ì •ì´ ë§‰í˜”ë˜ ë¬¼ê³¼ ê°™ì´ í„°ì ¸ 나온 것ì´ë¼ê³ 나는 í•´ì„하였다.
+"글쎄, ì–´ë”” 있는 줄 ì•Œê³ ì°¾ìŠµë‹ˆê¹Œ. ë…¸ì„ì˜ ì„±ë¯¸ì— í•œë²ˆ 아니 í•œë‹¤ê³ í–ˆìœ¼ë©´ 다시 íŽ¸ì§€í• ë¦¬ëŠ” ë§Œë¬´í•˜ë‹¤ê³ ë¯¿ìŠµë‹ˆë‹¤."
+하여 나는 ë¶€ì¸ì˜ ê°€ìŠ´ì— ë‘˜ì§¸ ì¹¼ë‚ ì„ ë°•ì•˜ë‹¤.
+나는 ë¹„ë¡ ìµœì„ì˜ ë¶€ì¸ì´ ì²í•˜ì§€ 아니하ë”ë¼ë„ 최ì„ì„ ì°¾ìœ¼ëŸ¬ ë– ë‚˜ì§€ 아니하면 아니 ë ì˜ë¬´ë¥¼ 진다. ì‚° 최ì„ì„ ëª» ì°¾ë”ë¼ë„ 최ì„ì˜ ì‹œì²´ë¼ë„, 무ë¤ì´ë¼ë„, ì£½ì€ ìžë¦¬ë¼ë„, 마지막 ìžˆë˜ ê³³ì´ë¼ë„ 찾아보지 아니하면 아니 ë ì˜ë¬´ë¥¼ 깨닫는다.
+그러나 시êµì´ 변하여 ê·¸ 때ì—는 ì•„ë¼ì‚¬ì— 가는 ê²ƒì€ ì—¬ê°„ 곤란한 ì¼ì´ 아니었다. ê·¸ 때ì—는 ë¶ë§Œì˜ í’ìš´ì´ ê¸‰ë°•í•˜ì—¬ 만주리를 통과하기는 ì‚¬ì‹¤ìƒ ë¶ˆê°€ëŠ¥ì— ê°€ê¹Œì› ë‹¤. 마ì ì‚°(馬å å±±) ì¼íŒŒì˜ 군대가 í¥ì•ˆë ¹, 하ì¼ë¼ë¥´ ë“±ì§€ì— ì›…ê±°í•˜ì—¬ ì–¸ì œ 대충ëŒì´ íë°œë 는지 ëª¨ë¥´ë˜ ë•Œì˜€ë‹¤. ì´ ë•Œë¬¸ì— ì‹œë² ë¦¬ì•„ì— ë“¤ì–´ê°€ê¸°ëŠ” ê±°ì˜ ì ˆë§ ìƒíƒœë¼ê³ í•˜ê² ê³ , ë˜ ê´€í—Œë„ ì•„ë¼ì‚¬ì— 들어가는 ì—¬í–‰ê¶Œì„ ìž˜ êµë¶€í• 것 같지 아니하였다.
+ë¶€ì¸ì€ ìš¸ê³ , 나는 ì´ëŸ° ìƒê° ì €ëŸ° ìƒê° í•˜ê³ ìžˆëŠ” ë™ì•ˆì— 문 ë°–ì—는 순임ì´, ì •ìž„ì´ê°€ 들어오는 소리가 ë“¤ë ¸ë‹¤.
+"ì•„ì´, ì •ìž„ì´ëƒ."
+í•˜ê³ ë¶€ì¸ì€ 반갑게 허리 굽혀 ì¸ì‚¬í•˜ëŠ” ì •ìž„ì˜ ì–´ê¹¨ì— ì†ì„ ëŒ€ê³ ,
+"ìž ì•‰ì•„ë¼. 그래 ì¸ì œ ë³‘ì´ ì¢€ 나으ëƒâ€¦â€¦ 수척했구나. ë” ë…¸ì„±í•´ì§€êµ¬ ë°˜ ë…„ë„ ëª» ë˜ì—ˆëŠ”ë°."
+í•˜ê³ ì •ìž„ì—게 대하여 ì• ì •ì„ í‘œí•˜ëŠ” ê²ƒì„ ë³´ê³ ë‚˜ëŠ” ì˜ì™¸ì§€ë§ˆëŠ” 다행으로 ìƒê°í•˜ì˜€ë‹¤. 나는 ì •ìž„ì´ê°€ 오면 보기 ì‹«ì€ í•œ ì‹ ì„ ì—°ì¶œí•˜ì§€ 않나 í•˜ê³ ê·¼ì‹¬í•˜ì˜€ë˜ ê²ƒì´ë‹¤.
+"í¬ ìž˜ ìžë¼ìš”?"
+í•˜ê³ ì •ìž„ì€ í•œì°¸ì´ë‚˜ 있다가 비로소 ìž…ì„ ì—´ì—ˆë‹¤.
+"ì‘, 잘 있단다. 컸나 ê°€ ë³´ì•„ë¼."
+í•˜ê³ ë¶€ì¸ì€ ë”ìš± 반가운 í‘œì •ì„ ë³´ì¸ë‹¤.
+"ì–´ëŠ ë°©ì´ì•¼?"
+í•˜ê³ ì •ìž„ì€ ì„ ë¬¼ ë³´í‰ì´ë¥¼ ë“¤ê³ ìˆœìž„ê³¼ 함께 나가 버린다. ì—¬ìžì¸ ì •ìž„ì€ í¬ì™€ 순임과 ë¶€ì¸ê³¼ ë˜ ìˆœìž„ì˜ ë‹¤ë¥¸ ë™ìƒì—게 ì„ ë¬¼ 사 오는 ê²ƒì„ ìžŠì–´ë²„ë¦¬ì§€ 아니하였다.
+ì •ìž„ê³¼ ìˆœìž„ì€ í•œ ì´ì‚¼ ë¶„ 있다가 ëŒì•„왔다. ë°–ì—서 í¬ê°€ 무엇ì´ë¼ê³ ì§€ì ˆëŒ€ëŠ” 소리가 들린다. 아마 ì •ìž„ì´ê°€ 사다 준 ì„ ë¬¼ì„ ë°›ê³ ì¢‹ì•„í•˜ëŠ” 모양ì´ë‹¤.
+ì •ìž„ì€ ë“¤ê³ ì˜¨ ë³´í‰ì´ì—서 ì—¬ìžìš© 배스로브 하나를 내어서 ë¶€ì¸ì—게주며,
+"맞으실까?"
+하였다.
+"ì•„ì´ ê·¸ê±´ 무어ë¼ê³ 사 왔니?"
+í•˜ê³ ë¶€ì¸ì€ 좋아ë¼ê³ ìž…ì–´ ë³´ê³ , ì´ë¦¬ ë³´ê³ ì €ë¦¬ ë³´ê³ í•˜ë©´ì„œ,
+"난 ì´ëŸ° ê±° ì²˜ìŒ ìž…ì–´ 본다."
+í•˜ê³ ìžê¾¸ ëˆì„ ë™ì—¬ë§¨ë‹¤.
+"ì •ìž„ì´ê°€ 난 파ìžë§ˆë¥¼ 사다 주었어."
+í•˜ê³ ìˆœìž„ì€ ë”°ë¡œ ìŒŒë˜ êµµì€ ì¤„ 있는 융 파ìžë§ˆë¥¼ 내어서 경매장 사람 모양으로 í”들어 ë³´ì´ë©°,
+"어머니 ê·¸ 배스로브 나 주우. 어머닌 늙ì€ì´ê°€ 그건 입어서 무엇 하우?"
+í•˜ê³ ë¶€ì¸ì´ ìž…ì€ ë°°ìŠ¤ë¡œë¸Œë¥¼ 벗겨서 ì œê°€ ìž…ê³ ë‘ í˜¸ì£¼ë¨¸ë‹ˆì— ì†ì„ ë„£ê³ ì–´ê¸°ì£½ì–´ê¸°ì£½í•˜ê³ ì„œì–‘ ë¶€ì¸ë„¤ í‰ë‚´ë¥¼ 낸다.
+"ì €ëŸ° ë§ê´„량ì´ê°€ ë„ˆë„ ì •ìž„ì´ì²˜ëŸ¼ 좀 ì–Œì „í•´ ë³´ì•„ë¼."
+í•˜ê³ ë¶€ì¸ì€ ìˆœìž„ì„ í–¥í•˜ì—¬ ëˆˆì„ í˜ê¸´ë‹¤.
+ì´ ëª¨ì–‘ìœ¼ë¡œ ë¶€ì¸ê³¼ ì •ìž„ê³¼ì˜ ëŒ€ë©´ì€ ê°€ìž¥ ì›ë§Œí•˜ê²Œ ë˜ì—ˆë‹¤.
+그러나 ë¶€ì¸ì€ ì •ìž„ì—게 최ì„ì˜ íŽ¸ì§€ë¥¼ ë³´ì´ê¸°ë¥¼ ì›ì¹˜ 아니하였다. 편지가 왔다는 ë§ì¡°ì°¨ ìž… ë°–ì— ë‚´ì§€ 아니하였다. 그러나 순임ì´ê°€ ì •ìž„ì—게 대하여 표하는 ì• ì •ì€ ì—¬ê°„ 깊지 아니하였다. ê·¸ ë‘˜ì€ í•˜ë£¨ ì¢…ì¼ ê°™ì´ ìžˆì—ˆë‹¤. ì •ìž„ì€ ê·¸ ë‚ ì €ë…ì— ë‚˜ë¥¼ ë³´ê³ ,
+"순임ì´í—Œí…Œ 최 ì„ ìƒë‹˜ 편지 ì‚¬ì—°ì€ ë‹¤ 들었어요. 순임ì´ê°€ ê·¸ 편지를 í›”ì³ë‹¤ê°€ 얼른얼른 몇 êµ°ë° ì½ì–´ë„ 보았습니다. 순임ì´ê°€ ì €ë¥¼ í½ ë™ì •하면서 ì ˆë”러 최 ì„ ìƒì„ ë”°ë¼ê°€ ë³´ë¼ê³ 그래요. í˜¼ìž ê°€ê¸°ê°€ ì–´ë ¤ìš°ë©´ ìžê¸°í—ˆêµ¬ ê°™ì´ ê°€ìžê³ . 가서 최 ì„ ìƒì„ ë°ë¦¬ê³ 오ìžê³ . 어머니가 못 가게 í•˜ê±°ë“ ëª°ëž˜ ë‘˜ì´ ë„ë§í•´ ê°€ìžê³ . 그래서 그러ìžê³ 그랬습니다. 안ë지요. ì„ ìƒë‹˜?"
+í•˜ê³ ì €í¬ë¼ë¦¬ ìž‘ì •ì€ ë‹¤ í•´ ë†“ê³ ëŠ” ìŠ¬ì© ë‚´ ì˜í–¥ì„ 물었다.
+"ì Šì€ ì—¬ìž ë‹¨ë‘˜ì´ì„œ 먼 ì—¬í–‰ì„ ì–´ë–»ê²Œ 한단 ë§ì´ëƒ? 게다가 지금 ë¶ë§Œì£¼ 형세가 대단히 위급한 모양ì¸ë°. ë˜ ì •ìž„ì´ëŠ” ê·¸ ê±´ê°• ê°€ì§€ê³ ì–´ë””ë¥¼ ê°€, ì´ ì¶”ìš´ 겨울ì—?"
+í•˜ê³ ë‚˜ëŠ” ì´ëŸ° ë§ì´ 다 쓸ë°ì—†ëŠ” ë§ì¸ 줄 ì•Œë©´ì„œë„ ì–´ë¥¸ìœ¼ë¡œì„œ 한 마디 안 í• ìˆ˜ 없어서 하였다. ì •ìž„ì€ ë” ì œ ëœ»ì„ ì£¼ìž¥í•˜ì§€ë„ ì•„ë‹ˆí•˜ì˜€ë‹¤.
+ê·¸ ë‚ ì €ë…ì— ì •ìž„ì€ ìˆœìž„ì˜ ì§‘ì—서 잤는지 ì§‘ì— ì˜¤ì§€ë¥¼ 아니하였다.
+나는 ì´ ì¼ì„ 어찌하면 좋ì€ê°€, ì´ ë‘ ì—¬ìžì˜ í–‰ë™ì„ 어찌하면 좋ì€ê°€ í•˜ê³ í˜¼ìž ë™ë™ ìƒê°í•˜ê³ 있었다.
+ì´íŠ¿ë‚ ë‚˜ëŠ” ê¶ê¸ˆí•´ì„œ 최ì„ì˜ ì§‘ì—를 ê°”ë”니 ë¶€ì¸ì´,
+"우리 ìˆœìž„ì´ ëŒì— 갔어요?"
+í•˜ê³ ì˜ì™¸ì˜ ì§ˆë¬¸ì„ í•˜ì˜€ë‹¤.
+"아니오."
+í•˜ê³ ë‚˜ëŠ” 놀ëžë‹¤.
+"그럼, ì´ê²ƒë“¤ì´ 어딜 갔어요? 난 ì •ìž„ì´í—ˆêµ¬ ëŒì—서 ìž” 줄만 알았는ë°."
+í•˜ê³ ë¶€ì¸ì€ 무슨 불길한 것ì´ë‚˜ 본 ë“¯ì´ ëª¸ì„ ë–¤ë‹¤. 히스테리가 ì¼ì–´ë‚œ 것ì´ì—ˆë‹¤.
+나는 ìž…ë§›ì„ ë‹¤ì‹œì—ˆë‹¤. 분명히 ì´ ë‘ ì—¬ìžê°€ ì‹œë² ë¦¬ì•„ë¥¼ í–¥í•˜ê³ ë– ë‚¬êµ¬ë‚˜ 하였다.
+ê·¸ ë‚ ì€ ì†Œì‹ì´ ì—†ì´ ì§€ë‚¬ë‹¤. ê·¸ ì´íŠ¿ë‚ ë„ ì†Œì‹ì´ ì—†ì´ ì§€ë‚¬ë‹¤.
+ìµœì„ ë¶€ì¸ì€ 딸까지 ìžƒì–´ë²„ë¦¬ê³ ë¯¸ì¹œ ë“¯ì´ ìš¸ê³ ì• í†µí•˜ë‹¤ê°€ 머리를 ì‹¸ë§¤ê³ ëˆ„ì›Œ ë²„ë¦¬ê³ ë§ì•˜ë‹¤.
+ì •ìž„ì´ì™€ 순임ì´ê°€ 없어진 ì§€ ì‚¬í˜ ë§Œì— ì•„ì¹¨ ìš°íŽ¸ì— íŽ¸ì§€ 한 ìž¥ì„ ë°›ì•˜ë‹¤. ê·¸ 봉투는 봉천 ì•¼ë§ˆë„ í˜¸í…” 것ì´ì—ˆë‹¤. ê·¸ ì†ì—는 편지 ë‘ ìž¥ì´ ë“¤ì–´ 있었다. 한 ìž¥ì€ ,
+ì„ ìƒë‹˜! ì €ëŠ” 아버지를 위하여, ì •ìž„ì„ ìœ„í•˜ì—¬ ì •ìž„ê³¼ ê°™ì´ ì§‘ì„ ë– ë‚¬ìŠµë‹ˆë‹¤.
+어머님께서 슬í¼í•˜ì‹¤ ì¤„ì€ ì•Œì§€ë§ˆëŠ” ì €í¬ë“¤ì´ 다행히 아버지를 찾아서 ëª¨ì‹œê³ ì˜¤ë©´ ì–´ë¨¸ë‹ˆê»˜ì„œë„ ê¸°ë»í•˜ì‹¤ ê²ƒì„ ë¯¿ìŠµë‹ˆë‹¤. ì €í¬ë“¤ì´ 가지 ì•„ë‹ˆí•˜ê³ ëŠ” 아버지는 살아서 ëŒì•„오실 것 같지 아니합니다. 아버지를 ì´ì²˜ëŸ¼ 불행하시게 한 죄는 ì ˆë°˜ì€ ì–´ë¨¸ë‹ˆê»˜ ìžˆê³ , ì ˆë°˜ì€ ì œê²Œ 있습니다. ì €ëŠ” 아버지 ì¼ì„ ìƒê°í•˜ë©´ ê°€ìŠ´ì´ ë¯¸ì–´ì§€ê³ ì´ê°€ 갈립니다. ì €ëŠ” 아무리 해서ë¼ë„ 아버지를 ì°¾ì•„ë‚´ì–´ì•¼ê² ìŠµë‹ˆë‹¤.
+ì €ëŠ” ì •ìž„ì„ ë¬´í•œížˆ ë™ì •합니다. ì €ëŠ” ì–´ë ¤ì„œ ì •ìž„ì„ ë¯¸ì›Œí•˜ê³ ì•„ë²„ì§€ë¥¼ 미워하였지마는 ì§€ê¸ˆì€ ì•„ë²„ì§€ì˜ ë§ˆìŒê³¼ ì •ìž„ì˜ ë§ˆìŒì„ 알아볼 만치 ìžëžìŠµë‹ˆë‹¤.
+ì„ ìƒë‹˜! ì €í¬ë“¤ì€ ë‘˜ì´ ì†ì„ ìž¡ê³ ì–´ë””ë¥¼ ê°€ì„œë“ ì§€ 아버지를 ì°¾ì•„ë‚´ê² ìŠµë‹ˆë‹¤. í•˜ë‚˜ë‹˜ì˜ ì‚¬ìžê°€ ë‚®ì—는 êµ¬ë¦„ì´ ë˜ê³ ë°¤ì—는 ë³„ì´ ë˜ì–´ì„œ 반드시 ì €í¬ë“¤ì˜ ì•žê¸¸ì„ ì¸ë„í• ì¤„ 믿습니다.
+ì„ ìƒë‹˜, ì €í¬ ì–´ë¦°ê²ƒë“¤ì˜ ëœ»ì„ ë¶ˆìŒížˆ 여기셔서 ëˆ ì²œ ì›ë§Œ ì „ë³´ë¡œ ë³´ë‚´ 주시기를 ë°”ëžë‹ˆë‹¤.
+ë§Œì¼ ë§Œì£¼ë¦¬ë¡œ 가는 ê¸¸ì´ ëŠì–´ì§€ë©´ ëª½ê³ ë¡œ ìžë™ì°¨ë¡œë¼ë„ ê°€ë ¤ê³ í•©ë‹ˆë‹¤. 아버지 íŽ¸ì§€ì— ì 힌 Fì—ì˜ R씨를 ì°¾ê³ , ê·¸ë¦¬ê³ ë°”ì´ì¹¼ í˜¸ë°˜ì˜ ë°”ì´ì¹¼ë¦¬ìŠ¤ì½”ì—를 찾아, ì´ ëª¨ì–‘ìœ¼ë¡œ 찾으면 반드시 아버지를 찾아 ë‚´ê³ ì•¼ ë§ ê²ƒì„ ë¯¿ìŠµë‹ˆë‹¤.
+ì„ ìƒë‹˜, ëˆ ì²œ ì›ë§Œ 봉천 ì•¼ë§ˆë„ í˜¸í…” 최순임 ì´ë¦„으로 ë¶€ì³ ì£¼ì„¸ìš”. ê·¸ë¦¬ê³ ì–´ë¨¸ë‹ˆí—Œí…ŒëŠ” ì•„ì§ ë§ì”€ ë§ì•„ 주세요.
+ì„ ìƒë‹˜. ì´ë ‡ê²Œ ê±±ì •í•˜ì‹œê²Œ 해서 미안합니다. 용서하세요.
+순임 ìƒì„œ
+ì´ë ‡ê²Œ ì¨ ìžˆë‹¤. ë˜ í•œ 장ì—는,
+ì„ ìƒë‹˜! ì €ëŠ” 마침내 ëŒì•„오지 ëª»í• ê¸¸ì„ ë– ë‚˜ë‚˜ì´ë‹¤. ì–´ë””ë“ ì§€ 최 ì„ ìƒë‹˜ì„ 뵈옵는 ê³³ì—서 ì´ ëª¸ì„ ë¬»ì–´ ë²„ë¦¬ë ¤ 하나ì´ë‹¤. 지금 ë˜ ëª¸ì— ì—´ì´ ë‚˜ëŠ” 모양ì´ìš”, í˜ˆë‹´ë„ ë³´ì´ì˜¤ë‚˜ 최 ì„ ìƒì„ 뵈올 때까지는 아무리 하여서ë¼ë„ ì´ ëª©ìˆ¨ì„ ë¶€ì§€í•˜ë ¤ 하오며, 최 ì„ ìƒì„ ëµˆì˜µê³ ì œê°€ ì§„ ì€í˜œë¥¼ ê°ì‚¬í•˜ëŠ” 한 ë§ì”€ë§Œ 사뢰면 ê³ ëŒ€ ì£½ì‚¬ì™€ë„ ì—¬í•œì´ ì—†ì„까 하나ì´ë‹¤.
+순임 언니가 ì œê²Œ 주시는 사랑과 ë™ì •ì€ ì˜¤ì§ ëˆˆë¬¼ê³¼ ê°ê²©ë°–ì— ë” í‘œí• ë§ì”€ì´ 없나ì´ë‹¤. 순임 언니가 ì €ë¥¼ 보호하여 주니 마ìŒì´ ë“ ë“ í•˜ì—¬ì´ë‹¤â€¦â€¦.
+ì´ë¼ê³ 하였다.
+편지를 보아야 별로 놀랄 ê²ƒì€ ì—†ì—ˆë‹¤. 다만 ë§ê´„량ì´ë¡œë§Œ ì•Œì•˜ë˜ ìˆœìž„ì˜ ì†ì— ì–´ëŠìƒˆì— 그러한 ê°ì •ì´ ë°œë‹¬í•˜ì˜€ë‚˜ 하는 ê²ƒì„ ë†€ëž„ ë¿ì´ì—ˆë‹¤.
+그러나 ê±±ì •ì€ ì´ê²ƒì´ë‹¤. 순임ì´ë‚˜ ì •ìž„ì´ë‚˜ 다 ë‚´ê°€ ê°ë…해야 í• ì²˜ì§€ì— ìžˆê±°ëŠ˜ ê·¸ë“¤ì´ ë§Œë¦¬ 긴 ì—¬í–‰ì„ ë– ë‚œë‹¤ê³ í•˜ë‹ˆ ê°ë…ìžì¸ ë‚´ 태ë„를 어떻게 í• ê¹Œ 하는 것ì´ë‹¤.
+나는 편지를 받는 길로 ìš°ì„ ëˆ ì²œ ì›ì„ ì€í–‰ì— 가서 찾아다 놓았다.
+ì•”ë§Œí•´ë„ ë‚´ê°€ ì„œìš¸ì— ê°€ë§Œížˆ 앉아서 ë‘ ì•„ì´ì—게 ëˆë§Œ ë¶€ì³ ì£¼ëŠ” ê²ƒì´ ì¸ì •ì— ì–´ê·¸ëŸ¬ì§€ëŠ” 것 같아서 나는 여러 가지로 ì£¼ì„ ì„ í•˜ì—¬ì„œ ì—¬í–‰ì˜ ì–‘í•´ë¥¼ 얻어 ê°€ì§€ê³ ë´‰ì²œì„ í–¥í•˜ì—¬ ë– ë‚¬ë‹¤.
+ë‚´ê°€ ë´‰ì²œì— ë„착한 ê²ƒì€ ë°¤ 열시가 지나서였다. 순임과 ì •ìž„ì€ ìžë¦¬ì˜· 바람으로 ë‚´ 방으로 ë‹¬ë ¤ì™€ì„œ 반가워하였다. ê·¸ë“¤ì´ ë°˜ê°€ì›Œí•˜ëŠ” ì–‘ì€ ì‹¤ë¡œ ëˆˆë¬¼ì´ í를 만하였다.
+"ì•„ì´êµ¬ ì„ ìƒë‹˜!"
+"ì•„ì´êµ¬ 어쩌면!"
+하는 ê²ƒì´ ê·¸ë“¤ì˜ ë‚´ê²Œ 대한 ì¸ì‚¬ì˜ ì „ë¶€ì˜€ë‹¤.
+"ì •ìž„ì´ ì–´ë– ì˜¤?"
+í•˜ê³ ë‚˜ëŠ” ìˆœìž„ì˜ íŽ¸ì§€ì— ì •ìž„ì´ê°€ ì—´ì´ ìžˆë‹¨ ë§ì„ ìƒê°í•˜ì˜€ë‹¤.
+"무어요. 괜찮습니다."
+í•˜ê³ ì •ìž„ì€ ì›ƒì—ˆë‹¤.
+ì „ë“±ë¹›ì— ë³´ì´ëŠ” ì •ìž„ì˜ ì–¼êµ´ì€ ê·¸ì•¼ë§ë¡œ 대리ì„으로 ê¹Žì€ ë“¯í•˜ì˜€ë‹¤. ì—¬ìœ„ê³ í•기가 없는 ê²ƒì´ ë”ìš± ì •ìž„ì˜ ìš©ëª¨ì— ì—„ìˆ™í•œ ë§›ì„ ì£¼ì—ˆë‹¤.
+"ëˆ ê°€ì ¸ì˜¤ì…¨ì–´ìš”?"
+í•˜ê³ ìˆœìž„ì´ê°€ 어리광 ì ˆë°˜ìœ¼ë¡œ 묻다가 ë‚´ê°€ ì›ƒê³ ëŒ€ë‹µì´ ì—†ìŒì„ ë³´ê³ ,
+"우리를 붙들러 오셨어요?"
+í•˜ê³ ì„±ë‚´ëŠ” ì–‘ì„ ë³´ì¸ë‹¤.
+"그래 둘ì´ì„œë“¤ 간다니 어떻게 간단 ë§ì¸ê°€. ì‹œë² ë¦¬ì•„ê°€ ì–´ë–¤ ê³³ì— ë¶™ì—ˆëŠ”ì§€ ì•Œì§€ë„ ëª»í•˜ë©´ì„œ."
+í•˜ê³ ë‚˜ëŠ” ë‘ ì‚¬ëžŒì´ ê·¸ë¦¬ 슬í¼í•˜ì§€ 아니하는 ìˆœê°„ì„ ë³´ëŠ” ê²ƒì´ ë‹¤í–‰í•˜ì—¬ì„œ ë†ë‹´ì‚¼ì•„ 물었다.
+"왜 몰ë¼ìš”? ì‹œë² ë¦¬ì•„ê°€ ì €ê¸° 아니야요?"
+í•˜ê³ ìˆœìž„ì´ê°€ ì‚°í•´ê´€ ìª½ì„ ê°€ë¦¬í‚¤ë©°,
+"ìš°ë¦¬ë„ ì§€ë¦¬ì—서 배워서 다 알아요. ì–´ì €ê»˜ 하루 ì¢…ì¼ ì§€ë„를 사다 ë†“ê³ ì—°êµ¬ë¥¼ 하였답니다. 봉천서 ì‹ ê²½, ì‹ ê²½ì„œ 하얼빈, 하얼빈ì—서 만주리, 만주리ì—서 ì´ë¥´ì¿ ì¸ í¬, 보세요, 잘 알지 않습니까. ë˜ ë§Œì¼ ì¤‘ë™ ì² ë„ê°€ 불통ì´ë©´ 어떻게 ê°€ëŠ”ê³ í•˜ë‹ˆ 여기서 ì‚°í•´ê´€ì„ ê°€ê³ , 산해관서 ë¶ê²½ì„ 가지요. ê·¸ë¦¬ê³ ëŠ” ë¶ê²½ì„œ 장가구를 가지 않습니까. 장가구서 ìžë™ì°¨ë¥¼ íƒ€ê³ ëª½ê³ ë¥¼ 통과해서 ê°€ê±°ë“ ìš”. 잘 알지 않습니까."
+í•˜ê³ ì •ìž„ì˜ í—ˆë¦¬ë¥¼ 안으며,
+"ê·¸ë ‡ì§€ì´?"
+í•˜ê³ ìžì‹ 있는 ë“¯ì´ ì›ƒëŠ”ë‹¤.
+"ë˜ ëª½ê³ ë¡œë„ ëª» 가게 ë˜ì–´ì„œ 구ë¼íŒŒë¥¼ ëŒê²Œ ë˜ë©´?"
+í•˜ê³ ë‚˜ëŠ” êµì‚¬ê°€ ìƒë„ì—게 묻는 모양으로 물었다.
+"네, ì € ì¸ë„양으로 해서 지중해로 해서 프랑스로 해서 ê·¸ë ‡ê²Œ 가지요."
+"허, 잘 아는구나."
+í•˜ê³ ë‚˜ëŠ” 웃었다.
+"ê·¸ë ‡ê²Œë§Œ 알아요? ë˜ í•´ì‚¼ìœ„ë¡œ 해서 가는 ê¸¸ë„ ì•Œì•„ìš”. ì €í¬ë¥¼ ì–´ë¦°ì• ë¡œ 아시네."
+"잘못했소."
+"하하."
+"후후."
+사실 ê·¸ë“¤ì€ ë²Œì¨ ì–´ë¦°ì• ë“¤ì€ ì•„ë‹ˆì—ˆë‹¤. ìˆœìž„ë„ ë²Œì¨ ê·¸ ì•„ë²„ì§€ì˜ ë§í• 수 없는 ì‚¬ì •ì— ë™ì •í• ë‚˜ì´ê°€ ë˜ì—ˆë‹¤. 순임ì´ê°€ 기어다닌 ê²ƒì€ ë³¸ 나로는 ì´ê²ƒë„ ì´ìƒí•˜ê²Œ 보였다. 나는 ë²Œì¨ ë‚˜ì´ ë§Žì•˜êµ¬ë‚˜ 하는 ìƒê°ì´ 나지 ì•„ë‹ˆí• ìˆ˜ 없었다.
+나는 ìž ì•ˆ 드는 í•˜ë£»ë°¤ì„ ì§€ë‚´ë©´ì„œ 옆방ì—서 ì •ìž„ì´ê°€ ê¸°ì¹¨ì„ ì§“ëŠ” 소리를 들었다. ê·¸ 소리는 ë‚´ ê°€ìŠ´ì„ ì•„í”„ê²Œ 하였다.
+ì´íŠ¿ë‚ ë‚˜ëŠ” ë‘ ì‚¬ëžŒì—게 ëˆ ì²œ ì›ì„ 주어서 ì‹ ê²½ 가는 급행차를 태워 주었다. ëŒ€ë¥™ì˜ ì´ ê±´ì¡°í•˜ê³ ì¶”ìš´ ê¸°í›„ì— ì •ìž„ì˜ ë³‘ë“ íê°€ 견디어 ë‚ ê¹Œ í•˜ê³ ë§ˆìŒì´ 놓ì´ì§€ 아니하였다. 그러나 나는 ê·¸ë“¤ì„ ê°€ë¼ê³ ê¶Œí• ìˆ˜ëŠ” ìžˆì–´ë„ ê°€ì§€ ë§ë¼ê³ 붙들 수는 없었다. 다만 ì œ 아버지, ì œ ì• ì¸ì„ 죽기 ì „ì— ë§Œë‚ ìˆ˜ 있기만 빌 ë¿ì´ì—ˆë‹¤.
+나는 ë‘ ì•„ì´ë¥¼ ë¶ìª½ìœ¼ë¡œ ë– ë‚˜ ë³´ë‚´ê³ í˜¼ìž ì—¬ê´€ì— ë“¤ì–´ì™€ì„œ ë„무지 ì •ì‹ ì„ ì§„ì •í•˜ì§€ 못하여 ìˆ ì„ ë¨¹ê³ ìžŠìœ¼ë ¤ 하였다. 그러다가 ê·¸ ë‚ ë°¤ì°¨ë¡œ 서울로 ëŒì•„왔다.
+ì´íŠ¿ë‚ ì•„ì¹¨ì— ë‚˜ëŠ” ìµœì„ ë¶€ì¸ì„ 찾아서 순임과 ì •ìž„ì´ê°€ ì‹œë² ë¦¬ì•„ë¡œ 갔단 ë§ì„ ì „í•˜ì˜€ë‹¤.
+ê·¸ ë•Œì— ìµœ ë¶€ì¸ì€ ê±°ì˜ ì•„ë¬´ ì •ì‹ ì´ ì—†ëŠ” 듯하였다. 아무 ë§ë„ 하지 ì•„ë‹ˆí•˜ê³ ìš¸ê³ ë§Œ 있었다.
+얼마 있다가 ë¶€ì¸ì€,
+"ê·¸ê²ƒë“¤ì´ ì €í¬ë“¤ë¼ë¦¬ 가서 괜찮ì„까요?"
+하는 한 마디를 í• ë¿ì´ì—ˆë‹¤.
+ë©°ì¹ í›„ì— ìˆœìž„ì—게서 편지가 왔다. ê·¸ê²ƒì€ í•˜ì–¼ë¹ˆì—서 부친 것ì´ì—ˆë‹¤.
+í•˜ì–¼ë¹ˆì„ ì˜¤ëŠ˜ ë– ë‚©ë‹ˆë‹¤. í•˜ì–¼ë¹ˆì— ì™€ì„œ 아버지 친구 ë˜ì‹œëŠ” Rì†Œìž¥ì„ ë§Œë‚˜ëµˆì˜µê³ ì•„ë²„ì§€ ì¼ì„ 물어 보았습니다. ê·¸ë¦¬ê³ ì €í¬ ë‘˜ì´ì„œ 찾아 ë– ë‚¬ë‹¤ëŠ” ë§ì”€ì„ 하였ë”니 Rì†Œìž¥ì´ ëŒ€ë‹¨ížˆ ë™ì •하여서 ì—¬í–‰ê¶Œë„ ì¤€ë¹„í•´ 주시기로 ì €í¬ëŠ” 아버지를 찾아서 오늘 오후 모스í¬ë°” 가는 급행으로 ë– ë‚©ë‹ˆë‹¤. 가다가 Fì—ì— ë‚´ë¦¬ê¸°ëŠ” ì–´ë ¤ìš¸ 듯합니다. ì •ìž„ì˜ ê±´ê°•ì´ ëŒ€ë‹¨ížˆ 좋지 못합니다. ì¼ê¸°ê°€ ê°‘ìžê¸° 추워지는 관계ì¸ì§€ ì •ìž„ì˜ ì‹ ì—´ì´ ì˜¤í›„ë©´ 삼ì‹íŒ” ë„를 ë„˜ê³ ê¸°ì¹¨ë„ ëŒ€ë‹¨í•©ë‹ˆë‹¤. ì €ëŠ” ì—¼ë ¤ê°€ ë˜ì–´ì„œ ì •ìž„ë”러 하얼빈ì—서 ìž…ì›í•˜ì—¬ 조리를 하ë¼ê³ 권하였지마는 ë„무지 듣지를 아니합니다. ì–´ë””ê¹Œì§€ë“ ì§€ 가는 대로 가다가 ë” ëª» 가게 ë˜ë©´ ê·¸ ê³³ì—서 ì£½ëŠ”ë‹¤ê³ í•©ë‹ˆë‹¤.
+ì €ëŠ” ê·¸ ë™ì•ˆ ë©°ì¹ ì •ìž„ê³¼ ê°™ì´ ìžˆëŠ” ì¤‘ì— ì •ìž„ì´ê°€ 어떻게 ì•„ë¦„ë‹µê³ ë†’ê³ êµ³ì„¸ê²Œ 깨ë—한 ì—¬ìžì¸ ê²ƒì„ ë°œê²¬í•˜ì˜€ìŠµë‹ˆë‹¤. ì €ëŠ” 지금까지 ì •ìž„ì„ ëª°ë¼ë³¸ ê²ƒì„ ë¶€ë„럽게 ìƒê°í•©ë‹ˆë‹¤. ê·¸ë¦¬ê³ ë˜ ì œ 아버지께서 어떻게 갸륵한 어른ì´ì‹ ê²ƒì„ ì¸ì œì•¼ 깨달았습니다. ìžì‹ ëœ ì €ê¹Œì§€ë„ ì•„ë²„ì§€ì™€ ì •ìž„ê³¼ì˜ ê´€ê³„ë¥¼ ì˜ì‹¬í•˜ì˜€ìŠµë‹ˆë‹¤. ì˜ì‹¬í•˜ëŠ” 것보다는 세ìƒì—서 ë§í•˜ëŠ” 대로 ë¯¿ê³ ìžˆì—ˆìŠµë‹ˆë‹¤. 그러나 ì •ìž„ì„ ë§Œë‚˜ ë³´ê³ ì •ìž„ì˜ ë§ì„ ë“£ê³ ì•„ë²„ì§€ê»˜ì„œ ì„ ìƒë‹˜ê»˜ 드린 편지가 ëª¨ë‘ ì°¸ì¸ ê²ƒì„ ê¹¨ë‹¬ì•˜ìŠµë‹ˆë‹¤. 아버지께서는 ì¹œêµ¬ì˜ ì˜ì§€ 없는 ë”¸ì¸ ì •ìž„ì„ ë‹¹ì‹ ì˜ ì¹œí˜ˆìœ¡ì¸ ì €ì™€ ê¼ ê°™ì´ ì‚¬ëž‘í•˜ë ¤ê³ í•˜ì‹ ê²ƒì´ì—ˆìŠµë‹ˆë‹¤. ê·¸ê²ƒì´ ì–¼ë§ˆë‚˜ 갸륵한 ì¼ìž…니까. ê·¸ëŸ°ë° ì œ 어머니와 ì €ëŠ” ê·¸ ê°¸ë¥µí•˜ì‹ ì •ì‹ ì„ ëª°ë¼ë³´ê³ 오해하였습니다. 어머니는 ì§ˆíˆ¬í•˜ì‹œê³ ì €ëŠ” 시기하였습니다. ì´ê²ƒì´ 얼마나 아버지를 ê·¸ë ‡ê²Œ ê°¸ë¥µí•˜ì‹ ì•„ë²„ì§€ë¥¼ 몰ë¼ëµˆì˜¨ 것입니다. ì´ê²ƒì´ 얼마나 ë¶€ë„ëŸ½ê³ ì›í†µí•œ ì¼ìž…니까.
+ì„ ìƒë‹˜ê»˜ì„œë„ 여러 번 ì•„ë²„ì§€ì˜ ì¸ê²©ì´ 높다는 ê²ƒì„ ì €í¬ ëª¨ë…€ì—게 설명해 주셨습니다마는 마ìŒì´ 막힌 ì €ëŠ” ì„ ìƒë‹˜ì˜ ë§ì”€ë„ 믿지 아니하였습니다.
+ì„ ìƒë‹˜, ì •ìž„ì€ ì°¸ìœ¼ë¡œ 아버지를 사랑합니다. ì •ìž„ì—게는 ì´ ì„¸ìƒì— 아버지밖ì—는 사랑하는 ì•„ë¬´ê²ƒë„ ì—†ì´, ê·¸ë ‡ê²Œ 외â—으로, ê·¸ë ‡ê²Œ ì—´ë ¬í•˜ê²Œ 아버지를 ì‚¬ëª¨í•˜ê³ ì‚¬ëž‘í•©ë‹ˆë‹¤. ì €ëŠ” 잘 압니다. ì •ìž„ì´ê°€ 처ìŒì—는 아버지로 ì‚¬ëž‘í•˜ì˜€ë˜ ê²ƒì„, 그러나 ì–´ëŠ ìƒˆì— ì •ìž„ì˜ ì•„ë²„ì§€ì—게 대한 ì‚¬ëž‘ì´ ë¬´ì—‡ì¸ì§€ 모를 사랑으로 변한 것ì„, ê·¸ê²ƒì´ ì—°ì• ëƒ í•˜ê³ ë¬¼ìœ¼ë©´ ì •ìž„ì€ ì•„ë‹ˆë¼ê³ í• ê²ƒìž…ë‹ˆë‹¤. ì •ìž„ì˜ ê·¸ ëŒ€ë‹µì€ ê²°ì½” ê±°ì§“ì´ ì•„ë‹™ë‹ˆë‹¤. ì •ìž„ì€ ìˆ™ì„±í•˜ì§€ë§ˆëŠ” ì•„ì§ë„ 극히 순결합니다. ì •ìž„ì€ ë¶€ëª¨ë¥¼ ìžƒì€ í›„ì— ì•„ë²„ì§€ë°–ì— ì‚¬ëž‘í•œ ì‚¬ëžŒì´ ì—†ìŠµë‹ˆë‹¤. ë˜ ì•„ë²„ì§€ì—ê²Œë°–ì— ì‚¬ëž‘ë°›ë˜ ì¼ë„ 없습니다. ê·¸ëŸ¬ë‹ˆê¹ ì •ìž„ì€ ì•„ë²„ì§€ë¥¼ ê·¸ì € 사랑합니다 ì „ì 으로 사랑합니다. ì„ ìƒë‹˜, ì •ìž„ì˜ ì‚¬ëž‘ì—는 ì•„ë²„ì§€ì— ëŒ€í•œ ìžì‹ì˜ 사랑, 오ë¼ë¹„ì— ëŒ€í•œ 누ì´ì˜ 사랑, 사내 ì¹œêµ¬ì— ëŒ€í•œ ì—¬ìž ì¹œêµ¬ì˜ ì‚¬ëž‘, ì• ì¸ì— 대한 ì• ì¸ì˜ 사랑, ì´ ë°–ì— ì¡´ê²½í•˜ê³ ìˆë°°í•˜ëŠ” ì„ ìƒì— 대한 ì œìžì˜ 사랑까지, ì‚¬ëž‘ì˜ ëª¨ë“ ì¢…ë¥˜ê°€ í¬í•¨ë˜ì–´ 있는 ê²ƒì„ ì €ëŠ” 발견하였습니다.
+ì„ ìƒë‹˜, ì •ìž„ì˜ ì •ìƒì€ 차마 ë³¼ 수가 없습니다. ì•„ë²„ì§€ì˜ ì•ˆë¶€ë¥¼ 근심하는 ì–‘ì€ ì œ ëª‡ì‹ ë°°ë‚˜ ë˜ëŠ”ì§€ 모르게 ê°„ì ˆí•©ë‹ˆë‹¤. ì •ìž„ì€ ì € ë•Œë¬¸ì— ì•„ë²„ì§€ê°€ 불행하게 ë˜ì…¨ë‹¤ê³ 해서 차마 ë³¼ 수 없게 ì• í†µí•˜ê³ ìžˆìŠµë‹ˆë‹¤. ì§„ì •ì„ ë§ì”€í•˜ì˜¤ë©´ ì €ëŠ” 지금 ì•„ë²„ì§€ë³´ë‹¤ë„ ì–´ë¨¸ë‹ˆë³´ë‹¤ë„ ì •ìž„ì—게 가장 ë™ì •ì´ ëŒë¦½ë‹ˆë‹¤. ì„ ìƒë‹˜, ì €ëŠ” 아버지를 찾아가는 ê²ƒì´ ì•„ë‹ˆë¼ ì •ìž„ì„ ë•기 위하여 간호하기 위하여 가는 것 같습니다.
+ì„ ìƒë‹˜, ì €ëŠ” ì•„ì§ ì‚¬ëž‘ì´ëž€ ê²ƒì´ ë¬´ì—‡ì¸ì§€ë¥¼ 모릅니다. 그러나 ì •ìž„ì„ ë³´ê³ ì‚¬ëž‘ì´ëž€ ê²ƒì´ ì–´ë–»ê²Œ ì‹ ë¹„í•˜ê³ ì—´ë ¬í•˜ê³ ë†€ë¼ìš´ 것ì¸ê°€ë¥¼ 안 것 같습니다.
+ìˆœìž„ì˜ íŽ¸ì§€ëŠ” 계ì†ëœë‹¤.
+ì„ ìƒë‹˜, í•˜ì–¼ë¹ˆì— ì˜¤ëŠ” ê¸¸ì— ì†¡í™”ê°• êµ½ì´ë¥¼ ë³¼ 때ì—는 ì •ìž„ì´ê°€ 어떻게나 울었는지, ê·¸ê²ƒì€ ì°¨ë§ˆ ë³¼ 수가 없었습니다. 아버지께서 ì†¡í™”ê°•ì„ ë³´ì‹œê³ ê°ìƒì´ 깊으셨ë”란 ê²ƒì„ ìƒê°í•œ 것입니다. 무ì¸ì§€ê²½ìœ¼ë¡œ, 허옇게 ëˆˆì´ ë®ì¸ 벌íŒìœ¼ë¡œ í˜ëŸ¬ê°€ëŠ” 송화강 êµ½ì´, ê·¸ê²ƒì€ ìŠ¬í”ˆ í’경입니다. 아버지께서 여기를 지나실 때ì—는 마른 풀만 있는 ê´‘ì•¼ì˜€ì„ ê²ƒì´ë‹ˆ ê·¸ 때ì—는 ë”ìš± í™©ëŸ‰í•˜ì˜€ì„ ê²ƒì´ë¼ê³ ì •ìž„ì€ ë§í•˜ê³ ì›ë‹ˆë‹¤.
+ì •ìž„ì€ ì œê°€ 아버지를 아는 것보다 아버지를 잘 아는 것 같습니다. í‰ì†Œì— 아버지와는 그리 ì ‘ì´‰ì´ ì—†ê±´ë§ˆëŠ” ì •ìž„ì€ ì•„ë²„ì§€ì˜ ì˜ì§€ë ¥, ì•„ë²„ì§€ì˜ ìˆ¨ì€ ì—´ì •, ì•„ë²„ì§€ì˜ ì„±ë¯¸ê¹Œì§€ 잘 압니다. ì €ëŠ” ì •ìž„ì˜ ë§ì„ ë“£ê³ ì•¼ 비로소 ì°¸ 그래, 하는 ê°íƒ„ì„ ë°œí•œ ì¼ì´ 여러 번 있습니다.
+ì •ìž„ì˜ ë§ì„ ë“£ê³ ì•¼ 비로소 아버지가 남보다 ë›°ì–´ë‚˜ì‹ ì¸ë¬¼ì¸ ê²ƒì„ ê¹¨ë‹¬ì•˜ìŠµë‹ˆë‹¤. 아버지는 ì •ì˜ê°ì´ êµ³ì„¸ê³ ê²‰ìœ¼ë¡œëŠ” 싸늘하ë„ë¡ ì´ì§€ì ì´ì§€ë§ˆëŠ” ì†ì—는 불 ê°™ì€ ì—´ì •ì´ ìžˆìœ¼ì‹œê³ , 아버지는 ì‡ ê°™ì€ ì˜ì§€ë ¥ê³¼ ì¹¼ë‚ ê°™ì€ íŒë‹¨ë ¥ì´ 있어서 ì–¸ì œë‚˜ ì£¼ì €í•˜ì‹¬ì´ ì—†ê³ ë˜ í”ë“¤ë¦¬ì‹¬ì´ ì—†ë‹¤ëŠ” 것, 아버지께서는 ëª¨ë“ ê²ƒì„ ìš©ì„œí•˜ê³ ëª¨ë“ ê²ƒì„ í˜¸ì˜ë¡œ í•´ì„하여서 누구를 미워하거나 ì›ë§í•˜ì‹¬ì´ 없는 등, ì •ìž„ì€ ì•„ë²„ì§€ì˜ ë§ˆìŒì˜ 목ë¡ê³¼ 설명서를 따로 외우는 것처럼 ì•„ë²„ì§€ì˜ ì„±ê²©ì„ ì„¤ëª…í•©ë‹ˆë‹¤. ë“£ê³ ë³´ì•„ì„œ 비로소 ì•„ë²„ì§€ì˜ ë”¸ì¸ ì €ëŠ” ë‚´ 아버지가 ì–´ë–¤ 아버지ì¸ê°€ë¥¼ 알았습니다.
+ì„ ìƒë‹˜, ì´í•´ê°€ ì‚¬ëž‘ì„ ë‚³ëŠ”ë‹¨ ë§ì”€ì´ 있지마는 ì €ëŠ” ì •ìž„ì„ ë³´ì•„ì„œ ì‚¬ëž‘ì´ ì´í•´ë¥¼ 낳는 ê²ƒì´ ì•„ë‹Œê°€ 합니다.
+어쩌면 어머니와 ì €ëŠ” í‰ìƒì„ 아버지를 ëª¨ì‹œê³ ìžˆìœ¼ë©´ì„œë„ ì•„ë²„ì§€ë¥¼ 몰ëžìŠµë‹ˆê¹Œ. ì´ì„±ì´ ë¬´ë””ê³ ì–‘ì‹¬ì´ íë ¤ì„œ 그랬습니까. ì •ìž„ì€ ì§„ì‹¤ë¡œ ì¡´ê²½í• ì—¬ìžìž…니다. ì œê°€ 남ìžë¼ 하ë”ë¼ë„ ì •ìž„ì„ ì•„ë‹ˆ ì‚¬ëž‘í•˜ê³ ëŠ” 못 ê²¬ë””ê² ìŠµë‹ˆë‹¤.
+아버지는 분명 ì •ìž„ì„ ì‚¬ëž‘í•˜ì‹ ê²ƒìž…ë‹ˆë‹¤. 처ìŒì—는 ì¹œêµ¬ì˜ ë”¸ë¡œ, 다ìŒì—는 친딸과 ê°™ì´, ë˜ ë‹¤ìŒì—는 무엇ì¸ì§€ 모르게 뜨거운 ì‚¬ëž‘ì´ ìƒê²¼ìœ¼ë¦¬ë¼ê³ 믿습니다. ê·¸ê²ƒì„ ì•„ë²„ì§€ëŠ” ì£½ì¸ ê²ƒìž…ë‹ˆë‹¤. ê·¸ê²ƒì„ ì£½ì´ë ¤ê³ ì´ ë‹¬í• ìˆ˜ 없는 ì‚¬ëž‘ì„ ì£½ì´ë ¤ê³ ì‹œë² ë¦¬ì•„ë¡œ ë‹¬ì•„ë‚˜ì‹ ê²ƒìž…ë‹ˆë‹¤. ì¸ì œì•¼ 아버지께서 ì„ ìƒë‹˜ê»˜ í•˜ì‹ íŽ¸ì§€ì˜ ëœ»ì´ ì•Œì•„ì§„ 것 같습니다. ë°±ì„¤ì´ ë®ì¸ ì‹œë² ë¦¬ì•„ì˜ ì‚¼ë¦¼ ì†ìœ¼ë¡œ í˜¼ìž í—¤ë§¤ë©° ì •ìž„ì—게로 향하는 ì‚¬ëž‘ì„ ì£½ì´ë ¤ê³ 무진 ì• ë¥¼ 쓰시는 ê·¸ ì‹¬ì •ì´ ì•Œì•„ì§€ëŠ” 것 같습니다.
+ì„ ìƒë‹˜ ì´ê²ƒì´ 얼마나 비참한 ì¼ìž…니까. ì €ëŠ” ì •ìž„ì˜ ì§ì— ì§€ë‹ˆê³ ì˜¨ ì¼ê¸°ë¥¼ 보다가 ì´ëŸ¬í•œ êµ¬ì ˆì„ ë°œê²¬í•˜ì˜€ìŠµë‹ˆë‹¤.
+ì„ ìƒë‹˜. ì €ëŠ” 세ì¸íЏ ì˜¤ê±°ìŠ¤í‹´ì˜ <참회ë¡>ì„ ì ˆë°˜ì´ë‚˜ 다 ë³´ê³ ë‚˜ë„ ìž ì´ ë“¤ì§€ 아니합니다. ìž ì´ ë“¤ê¸° ì „ì— ì œê°€ í•ìƒ ì¦ê²¨í•˜ëŠ” ì•„ë² ë§ˆë¦¬ì•„ì˜ ë…¸ëž˜ë¥¼ ìœ ì„±ê¸°ë¡œ ë“£ê³ ë‚˜ì„œ 오늘 ì¼ê¸°ë¥¼ ì“°ë ¤ê³ í•˜ë‹ˆ 슬픈 소리만 나옵니다.
+사랑하는 어른ì´ì—¬. ì €ëŠ” 멀리서 ë‹¹ì‹ ì„ ì¡´ê²½í•˜ê³ ì‹ ë¢°í•˜ëŠ” 마ìŒì—서만 살아야 í• ê²ƒì„ ìž˜ 압니다. 여기ì—서 ì˜ì›í•œ ì •ì§€ë¥¼ 하지 아니하면 아니 ë©ë‹ˆë‹¤. ë¹„ë¡ ì œ ìƒëª…ì´ ê´´ë¡œì›€ìœ¼ë¡œ ëŠì–´ì§€ê³ ì œ í˜¼ì´ í”¼ì–´ ë³´ì§€ ëª»í•˜ê³ ìŠ¤ëŸ¬ì ¸ 버리ë”ë¼ë„ ì €ëŠ” ì´ ë©€ë¦¬ì„œ ë°”ë¼ë³´ëŠ” 존경과 ì‹ ë¢°ì˜ ì‹¬ê²½ì—서 한 ë°œìžêµì´ë¼ë„ 옮기지 않아야 í• ê²ƒì„ ìž˜ 압니다. 나를 위하여 놓여진 ìƒì˜ 궤ë„는 ë‚˜ì˜ ìƒëª…ì„ ë¶€ì¸í•˜ëŠ” ì–µì§€ì˜ ê¸¸ìž…ë‹ˆë‹¤. ì œê°€ 몇 ë…„ ì „ 기숙사 ë² ë“œì—서 ì´ëŸ° ë°¤ì— ë‚´ë‹¤ë³´ë©´ ì¦ê²ê³ ì•„ë¦„ë‹µë˜ ë‚´ ìƒì˜ ê¿ˆì€ ë‹¤ 깨어졌습니다.
+ì œ ì˜í˜¼ì˜ 한 ì¡°ê°ì´ 먼 ì„¸ìƒ ì•Œì§€ ëª»í• ì„¸ê³„ë¡œ ë– ë‹¤ë‹ˆê³ ìžˆìŠµë‹ˆë‹¤. 잃어버린 ë§ˆìŒ ì¡°ê° ì–´ì°Œí•˜ë‹¤ê°€ ì œê°€ ì´ë ‡ê²Œ ë˜ì—ˆëŠ”ì§€ 모릅니다.
+피어 오르는 ìƒëª…ì˜ ê´‘ì±„ë¥¼ 스스로 ì‚¬í˜•ì— ì²˜í•˜ì§€ 아니하면 아니 ë 때 ì–´ì°Œ ìŠ¬í””ì´ ì—†ê² ìŠµë‹ˆê¹Œ. ì´ê²ƒì€ 현실로 ì‚¬ëžŒì˜ ìƒëª…ì„ ì£½ì´ëŠ” 것보다 ë” ë¬´ì„œìš´ 죄가 아니오리까. ë‚˜ì˜ ì„¸ê³„ì—서 처ìŒì´ìš” 마지막으로 발견한 ë¹›ì„ ì–´ë‘ ì†ì— 소멸해 버리ë¼ëŠ” ì´ ì¼ì´ 얼마나 떨리는 ì§ë¬´ì˜¤ë¦¬ê¹Œ. ì´ í—ˆê¹¨ë¹„ì˜ í˜•ì˜ ì‚¬ëžŒì´ ì‚´ê¸° 위하여 ë‚´ ì†ìœ¼ë¡œ ì¹¼ì„ ë“¤ì–´ ë‚´ ì˜í˜¼ì˜ 환í¬ë¥¼ ì³ì•¼ 옳습니까. ì €ëŠ” í•˜ë‚˜ë‹˜ì„ ì›ë§í•©ë‹ˆë‹¤.
+ì´ë ‡ê²Œ 씌어 있습니다. ì„ ìƒë‹˜ ì´ê²ƒì´ 얼마나 피 í르는 ê³ ë°±ìž…ë‹ˆê¹Œ.
+ì„ ìƒë‹˜, ì €ëŠ” ì •ìž„ì˜ ì´ ê³ ë°±ì„ ë³´ê³ ë¬´ì¡°ê±´ìœ¼ë¡œ ì •ìž„ì˜ ì‚¬ëž‘ì„ ì‹œì¸í•©ë‹ˆë‹¤. ì„ ìƒë‹˜, ì œ ëª©ìˆ¨ì„ ë°”ì³ì„œ 하는 ì¼ì— 누가 시비를 í•˜ê² ìŠµë‹ˆê¹Œ. ë”구나 ê·¸ ë™ê¸°ì— í‹°ëŒë§Œí¼ë„ 불순한 ê²ƒì´ ì—†ìŒì—야 무조건으로 시ì¸í•˜ì§€ ì•„ë‹ˆí•˜ê³ ì–´ì°Œí•©ë‹ˆê¹Œ.
+ë°”ë¼ê¸°ëŠ” ì •ìž„ì˜ ë³‘ì´ í¬ê²Œ ë˜ì§€ ì•„ë‹ˆí•˜ê³ ì•„ë²„ì§€ê»˜ì„œ 무사히 계셔서 ì†ížˆ 만나뵙게 ë˜ëŠ” 것입니다마는 ì•žê¸¸ì´ ë§ë§í•˜ì—¬ ê°€ìŠ´ì´ ë‘ê·¼ê±°ë¦¼ì„ ê¸ˆì¹˜ 못합니다. 게다가 ì˜¤ëŠ˜ì€ í•¨ë°•ëˆˆì´ í¼ë¶€ì–´ì„œ 천지가 온통 회색으로 한 ë¹›ì´ ë˜ì—ˆìœ¼ë‹ˆ ë”ìš± ì „ë„ê°€ 막막합니다. 그러나 ì„ ìƒë‹˜ ì €ëŠ” 앓는 ì •ìž„ì„ ë°ë¦¬ê³ ìš©ê°í•˜ê²Œ ì‹œë² ë¦¬ì•„ ê¸¸ì„ ë– ë‚©ë‹ˆë‹¤.
+한 ì¼ ì£¼ì¼ í›„ì— ë˜ íŽ¸ì§€ 한 ìž¥ì´ ì™”ë‹¤. ê·¸ê²ƒë„ ìˆœìž„ì˜ íŽ¸ì§€ì—¬ì„œ ì´ëŸ¬í•œ ë§ì´ 있었다.
+……오늘 ìƒˆë²½ì— í¥ì•ˆë ¹ì„ 지났습니다. 플랫í¼ì˜ 한란계는 ì˜í•˜ ì´ì‹ì‚¼ ë„를 가리켰습니다. ì‚¬ëžŒë“¤ì˜ ì–¼êµ´ì€ ì†œí„¸ì— ì„±ì—ê°€ 슬어서 남녀 노소 í• ê²ƒ ì—†ì´ í•˜ì–—ê²Œ ë¶„ì„ ë°”ë¥¸ 것 같습니다. ìœ ë¦¬ì— ë¹„ì¹œ ë‚´ ì–¼êµ´ë„ ê·¸ì™€ ê°™ì´ í° ê²ƒì„ ë³´ê³ ë†€ëžìŠµë‹ˆë‹¤. ìˆ¨ì„ ë“¤ì´ì‰´ 때ì—는 ì½”í„¸ì´ ì–¼ì–´ì„œ ìˆ¨ì´ ëŠê¸°ê³ ë°”ëžŒê²°ì´ ì§€ë‚˜ê°€ë©´ ëˆˆë¬¼ì´ ì–¼ì–´ì„œ 눈ì¹ì´ 마주 붙습니다. ì‚¬ëžŒë“¤ì€ í„¸ê³¼ ê°€ì£½ì— ì‹¸ì—¬ì„œ ê³°ê°™ì´ ë³´ìž…ë‹ˆë‹¤.
+ë˜ ì´ëŸ° ë§ë„ 있었다.
+ì•„ë¼ì‚¬ ê³„ì§‘ì• ë“¤ì´ ìš°ìœ ë³‘ë“¤ì„ í’ˆì— í’ˆê³ ì„œì„œ ì†ë‹˜ì´ 사기를 ê¸°ë‹¤ë¦¬ê³ ìžˆìŠµë‹ˆë‹¤. ì €ë„ ë‘ ë³‘ì„ ì‚¬ì„œ ì •ìž„ì´ì™€ 나누어 먹었습니다. ìš°ìœ ëŠ” 따뜻합니다. ê·¸ê²ƒì„ ì‹ížˆì§€ ì•„ë‹ˆí• ì–‘ìœ¼ë¡œ í’ˆì— í’ˆê³ ì„°ë˜ ê²ƒìž…ë‹ˆë‹¤.
+ë˜ ì´ëŸ¬í•œ êµ¬ì ˆë„ ìžˆì—ˆë‹¤.
+ì •ê±°ìž¥ì— ë‹¿ì„ ë•Œë§ˆë‹¤ ì €í¬ë“¤ì€ ë°–ì„ ë‚´ë‹¤ë´…ë‹ˆë‹¤. 행여나 아버지가 거기 계시지나 ì•„ë‹ˆí• ê¹Œ í•˜ê³ ìš”. 차가 어길 때ì—는 ë”구나 마ìŒì´ 조입니다. 아버지가 ê·¸ 차를 íƒ€ê³ ì§€ë‚˜ê°€ì‹œì§€ë‚˜ 아니하는가 í•˜ê³ ìš”. ê·¸ë¦¬ê³ ëŠ” ì •ìž„ì€ ì›ë‹ˆë‹¤. ê¼ ëµˆì˜¬ ì–´ë¥¸ì„ ë†“ì³ë‚˜ 버린 듯ì´.
+ê·¸ë¦¬ê³ ëŠ” ì´ ì£¼ì¼ ë™ì•ˆì´ë‚˜ 소ì‹ì´ 없다가 편지 한 ìž¥ì´ ì™”ë‹¤. ê·¸ê²ƒì€ ì •ìž„ì˜ ê¸€ì”¨ì˜€ë‹¤.
+ì„ ìƒë‹˜, ì €ëŠ” 지금 최 ì„ ìƒê»˜ì„œ ê³„ì‹œë˜ ë°”ì´ì¹¼ í˜¸ë°˜ì˜ ê·¸ ì§‘ì— ì™€ì„œ 홀로 ëˆ„ì› ìŠµë‹ˆë‹¤. ìˆœìž„ì€ ì£¼ì¸ ë…¸íŒŒì™€ 함께 Fì—으로 최 ì„ ìƒì„ 찾아서 오늘 ì•„ì¹¨ì— ë– ë‚˜ê³ ë³‘ë“ ì €ë§Œ í˜¼ìž ëˆ„ì›Œì„œ ì–¼ìŒì— ì‹¸ì¸ ë°”ì´ì¹¼ í˜¸ì˜ ëˆˆë³´ë¼ì¹˜ëŠ” 바람 소리를 ë“£ê³ ìžˆìŠµë‹ˆë‹¤. ì—´ì€ ì‚¼ì‹íŒ” ë„로부터 구 ë„ ì‚¬ì´ë¥¼ ì˜¤ë¥´ë‚´ë¦¬ê³ ê¸°ì¹¨ì€ ë‚˜ê³ ëª¸ì˜ ê´´ë¡œì›€ì„ ê²¬ë”œ 수 없습니다. 그러하오나 ì„ ìƒë‹˜, ì €ëŠ” í•˜ë‚˜ë‹˜ì„ ë¶ˆëŸ¬ì„œ ì¶•ì›í•©ë‹ˆë‹¤. ì´ ì‹¤ë‚± ê°™ì€ ìƒëª…ì´ ë‹¤ 타 버리기 ì „ì— ìµœ ì„ ìƒì˜ ë‚¯ì„ ë‹¤ë§Œ ì¼ ì´ˆ ë™ì•ˆì´ë¼ë„ 보여지ì´ë¼ê³ . 그러하오나 ì„ ìƒë‹˜, ì´ ì¶•ì›ì´ ì´ë£¨ì–´ì§€ê² 습니까.
+ì €ëŠ” 한사코 Fì—까지 ê°€ë ¤ 하였사오나 순임 í˜•ì´ ìš¸ê³ ë§‰ì‚¬ì˜¤ë©° ë˜ ì£¼ì¸ ë…¸íŒŒê°€ 본래 ë¯¸êµ ì‚¬ëžŒê³¼ ì‚´ë˜ ì‚¬ëžŒìœ¼ë¡œ ì˜ì–´ë¥¼ 알아서 순임 í˜•ì˜ ë„ì›€ì´ ë˜ê² 기로 ì €ëŠ” ì´ ê³³ì— ëˆ„ì›Œ 있습니다. 순임 í˜•ì€ ê¸°ì–´ì½” 아버지를 찾아 ëª¨ì‹œê³ ì˜¤ë§ˆê³ ì•½ì†í•˜ì˜€ì‚¬ì˜¤ë‚˜ ì´ ë„“ì€ ì‹œë² ë¦¬ì•„ì—서 ì–´ë”” 가서 ì°¾ê² ìŠµë‹ˆê¹Œ.
+ì„ ìƒë‹˜, ì €ëŠ” 죽ìŒì„ 봅니다. 죽ìŒì´ 바로 ì œ ì•žì— ì™€ì„œ ì„ ê²ƒì„ ë´…ë‹ˆë‹¤. ê·¸ì˜ ì†ì€ ì œ 여윈 ì†ì„ ìž¡ìœ¼ë ¤ê³ ë“¤ë¨¹ê±°ë¦¼ì„ ë´…ë‹ˆë‹¤.
+ì„ ìƒë‹˜, ì£½ì€ ë’¤ì—ë„ ì˜ì‹ì´ 남습니까. ë§Œì¼ ì˜ì‹ì´ 남는다 하면 ì£½ì€ ë’¤ì—ë„ ì´ ì•„í””ê³¼ ê´´ë¡œì›€ì„ ê³„ì†í•˜ì§€ 아니하면 아니 ë©ë‹ˆê¹Œ. ì£½ì€ ë’¤ì—는 ì˜¤ì§ ì˜ì›í•œ ì–´ë‘ ê³¼ ìžŠì–´ë²„ë¦¼ì´ ìžˆìŠµë‹ˆê¹Œ. ì£½ì€ ë’¤ì—는 혹시나 ìƒì „ì— ë¨¹ì—ˆë˜ ë§ˆìŒì„ ìžìœ 로 펼 ë„리가 있습니까. ì´ ì„¸ìƒì—서 ê·¸ë¦½ê³ ì‚¬ëª¨í•˜ë˜ ì´ë¥¼ ì£½ì€ ë’¤ì—는 ìžìœ 로 만나 ë³´ê³ ì–¸ì œë‚˜ 마ìŒê» ê°™ì´í• 수가 있습니까. 그런 ì¼ë„ 있습니까. ì´ëŸ° ì¼ì„ ë°”ë¼ëŠ” ê²ƒë„ ì£„ê°€ ë©ë‹ˆê¹Œ.
+ì •ìž„ì˜ íŽ¸ì§€ëŠ” ë”ìš± ì ˆë§ì ì¸ ì–´ì¡°ë¡œ 찬다.
+ì €ëŠ” ì²˜ìŒ ë³‘ì´ ë‚¬ì„ ë•Œì—는 죽는 ê²ƒì´ ì‹«ê³ ë¬´ì„œì› ìŠµë‹ˆë‹¤. 그러나 ì§€ê¸ˆì€ ì£½ëŠ” ê²ƒì´ ì¡°ê¸ˆë„ ë¬´ì„ì§€ 아니합니다. 다만 차마 죽지 못하는 ê²ƒì´ í•œ.
+í•˜ê³ ëŠ” `다만 차마' ì´í•˜ë¥¼ ë°•ë°• 지워 ë²„ë ¸ë‹¤. ê·¸ë¦¬ê³ ëŠ” 새로 시작하여 나와내 가족ì—게 대한 ë¬¸ì•ˆì„ í•˜ê³ ëŠ” ëì„ ë§‰ì•˜ë‹¤.
+나는 ì´ íŽ¸ì§€ë¥¼ ë°›ê³ ìš¸ì—ˆë‹¤. 무슨 í° ë¹„ê·¹ì´ ê°€ê¹Œìš´ ê²ƒì„ ì˜ˆìƒí•˜ê²Œ 하였다.
+ê·¸ 후 한 ì‹ì—¬ ì¼ì´ë‚˜ 지나서 ì „ë³´ê°€ 왔다. ê·¸ê²ƒì€ ì˜ë¬¸ìœ¼ë¡œ 씌었는ë°,
+"아버지 ë³‘ì´ ê¸‰í•˜ë‹¤. 나로는 ì–´ì©” 수 없다. ëˆ ê°€ì§€ê³ ê³§ 오기를 바란다."
+í•˜ê³ ê·¸ ëì— B호텔ì´ë¼ê³ 주소를 ì 었다. ì „ë³´ ë°œì‹ êµì´ ì´ë¥´ì¿ ì¸ í¬ì¸ ê²ƒì„ ë³´ë‹ˆ B호텔ì´ë¼ í•¨ì€ ì´ë¥´ì¿ ì¸ í¬ì¸ ê²ƒì´ ë¶„ëª…í•˜ì˜€ë‹¤.
+나는 ìµœì„ ë¶€ì¸ì—게 최ì„ì´ê°€ ì•„ì§ ì‚´ì•„ 있다는 ê²ƒì„ ì „í•˜ê³ ê³§ 여행권 수ì†ì„ 하였다. ì ˆë§ìœ¼ë¡œ ì•Œì•˜ë˜ ì—¬í–‰ê¶Œì€ ì‚¬ì •ì´ ì‚¬ì •ì¸ë§Œí¼ ê³§ 발부ë˜ì—ˆë‹¤.
+나는 비행기로 ì—¬ì˜ë„를 ë– ë‚¬ë‹¤. ë°±ì„¤ì— ê°œê°œí•œ ë•…ì„, 남빛으로 푸른 바다를 굽어보는 ë™ì•ˆì— ëŒ€ë ¨ì„ ë“¤ëŸ¬ 거기서 다른 비행기를 ê°ˆì•„íƒ€ê³ ë´‰ì²œ, ì‹ ê²½, í•˜ì–¼ë¹ˆì„ ê±°ì³, ì¹˜ì¹˜í•˜ì–¼ì— ë“¤ë €ë‹¤ê°€ 만주리로 급행하였다.
+웅대한 ëŒ€ë¥™ì˜ ì„¤ê²½ë„ ë‚˜ì—게 아무러한 ì¸ìƒë„ 주지 못하였다. 다만 푸른 하늘과 í¬ê³ í‰í‰í•œ ë•…ê³¼ì˜ ì‚¬ì´ë¡œ 한량 ì—†ì´ í—ˆê³µì„ ë‚ ì•„ê°„ë‹¤ëŠ” ìƒê°ë°–ì— ì—†ì—ˆë‹¤. ê·¸ê²ƒì€ ì‚¬ëž‘í•˜ëŠ” ë‘ ì¹œêµ¬ê°€ ëª©ìˆ¨ì´ ê²½ê°ì— 달린 ê²ƒì„ ìƒê°í• ë•Œì— ë§ˆìŒì— 아무 ì—¬ìœ ë„ ì—†ëŠ” 까ë‹ì´ì—ˆë‹¤.
+만주리ì—ì„œë„ ë¹„í–‰ê¸°ë¥¼ íƒ€ë ¤ 하였으나 소비ì—트 ê´€í—Œì´ í—ˆë½ì„ 아니 하여 열차로 ê°ˆ ìˆ˜ë°–ì— ì—†ì—ˆë‹¤.
+초조한 몇 ë°¤ì„ ì§€ë‚˜ê³ ì´ë¥´ì¿ ì¸ í¬ì— 내린 ê²ƒì´ ì˜¤ì „ ë‘시. 나는 B호텔로 ì´ìŠ¤ë³´ìŠ¤ì¹˜ì¹´ë¼ëŠ” 마차를 몰았다. 죽ìŒê³¼ ê°™ì´ ê³ ìš”í•˜ê²Œ 눈 ì†ì— ìžëŠ” 시간ì—는 ì—¬ê¸°ì €ê¸° ì „ë“±ì´ ë°˜ì§ê±°ë¦´ ë¿, ì´ë”°ê¸ˆ ë°¤ì˜ ì‹œê°€ë¥¼ 경계하는 ë³‘ì •ë“¤ì˜ ëˆˆì´ ë¬´ì„게 빛나는 ê²ƒì´ ë³´ì˜€ë‹¤.
+B호텔ì—서 미스 ì´ˆì´(최 ì–‘)를 찾았으나 ìˆœìž„ì€ ì—†ê³ ì–´ë–¤ 서양 노파가 나와서,
+"ìœ ë¯¸ìŠ¤í„° Y?"
+í•˜ê³ ì˜ì‹¬ìŠ¤ëŸ¬ìš´ 눈으로 나를 보았다.
+ê·¸ë ‡ë‹¤ëŠ” ë‚´ ëŒ€ë‹µì„ ë“£ê³ ëŠ” 노파는 반갑게 ì†ì„ 내밀어서 ë‚´ ì†ì„ 잡았다.
+나는 넉넉하지 못한 ì˜ì–´ë¡œ ê·¸ 노파ì—게서 최ì„ì´ê°€ ì•„ì§ ì‚´ì•˜ë‹¤ëŠ” ë§ê³¼ ì •ìž„ì˜ ì†Œì‹ì€ ë“¤ì€ ì§€ 오래ë¼ëŠ” ë§ê³¼ 최ì„ê³¼ ìˆœìž„ì€ ì—¬ê¸°ì„œ ì‚¼ì‹ ë§ˆì¼ì´ë‚˜ 떨어진 Fì—ì—ì„œë„ ì°ë§¤ë¡œ ë” ê°€ëŠ” 삼림 ì†ì— 있다는 ë§ì„ 들었다.
+나는 ê·¸ ë°¤ì„ ì—¬ê¸°ì„œ ì§€ë‚´ê³ ì´íŠ¿ë‚ ì•„ì¹¨ì— ë– ë‚˜ëŠ” 완행차로 ê·¸ 노파와 함께 ì´ë¥´ì¿ ì¸ í¬ë¥¼ ë– ë‚¬ë‹¤.
+ì´ ë‚ ë„ ì²œì§€ëŠ” ì˜¤ì§ ëˆˆë¿ì´ì—ˆë‹¤. 차는 ê°€ë” ì‚¼ë¦¼ 중으로 가는 모양ì´ë‚˜ ëª¨ë‘ íšŒìƒ‰ë¹›ì— ê°€ë¦¬ì›Œì„œ 분명히 ë³´ì´ì§€ë¥¼ 아니하였다.
+Fì—ì´ë¼ëŠ” ê²ƒì€ ì‚¼ë¦¼ ì†ì— 있는 조그마한 ì •ê±°ìž¥ìœ¼ë¡œ ì§‘ì´ë¼ê³ 는 ì •ê±°ìž¥ ì§‘ë°–ì— ì—†ì—ˆë‹¤. ì—ë¶€ ë‘ì—‡ì´ í„¸ì˜·ì— í•˜ì–—ê²Œ ëˆˆì„ ë’¤ì“°ê³ ì¡¸ë¦¬ëŠ” ë“¯ì´ ì˜¤ë½ê°€ë½í• ë¿ì´ì—ˆë‹¤.
+우리는 ì°ë§¤ 하나를 얻어 íƒ€ê³ ì–´ë””ê°€ 길ì¸ì§€ ë¶„ëª…ì¹˜ë„ ì•„ë‹ˆí•œ 눈 ì†ìœ¼ë¡œ ë§ì„ 몰았다.
+ë°”ëžŒì€ ì—†ëŠ” 듯하지마는 ê·¸ëž˜ë„ ëˆˆë°œì„ í•œíŽ¸ìœ¼ë¡œ 비ë¼ëŠ” 모양ì´ì–´ì„œ 아름드리 ë‚˜ë¬´ë“¤ì˜ í•œìª½ì€ í•˜ì–—ê²Œ 눈으로 쌓ì´ê³ í•œìª½ì€ ê²€ì€ ë¹›ì´ ë”ìš± ë‹ë³´ì˜€ë‹¤. ë°± ì²™ì€ ë„˜ì„ ë“¯í•œ 꼿꼿한 침엽수(ì „ë‚˜ë¬´ 따윈가)ë“¤ì´ ì–´ë””ê¹Œì§€ë“ ì§€, 하늘ì—서 ê³§ ë‚´ë ¤ë°•ì€ ëª» 모양으로, ìˆ˜ì—†ì´ ì„œ 있는 사ì´ë¡œ 우리 ì°ë§¤ëŠ” 간다. ë•…ì— ë®ì¸ ëˆˆì€ ìƒˆë¡œ 피워 ë†“ì€ ì†œê°™ì´ í¬ì§€ë§ˆëŠ” 하늘ì—서 내리는 ëˆˆì€ êµ¬ë¦„ë¹›ê³¼ 공기빛과 ì–´ìš¸ë ¤ì„œ ë°¥ ìž¦íž ë•Œì— êµ´ëšì—서 나오는 연기와 ê°™ì´ ì—°íšŒìƒ‰ì´ë‹¤.
+ë°”ëžŒë„ ë¶ˆì§€ ì•„ë‹ˆí•˜ê³ ìƒˆë„ ë‚ ì§€ 아니하건마는 나무 ë†’ì€ ê°€ì§€ì— ìŒ“ì¸ ëˆˆì´ ì´ë”°ê¸ˆ ë©ì¹˜ë¡œ ë–¨ì–´ì ¸ì„œëŠ” ê³ ìš”í•œ 수풀 ì†ì— ìž‘ì€ ë™ìš”를 ì¼ìœ¼í‚¨ë‹¤.
+우리 ì°ë§¤ê°€ 가는 ê¸¸ì´ ìžì—°ìŠ¤ëŸ¬ìš´ 복잡한 커브를 ë„는 ê²ƒì„ ë³´ë©´ 필시 ì–¼ìŒ ì–¸ 개천 위로 달리는 모양ì´ì—ˆë‹¤.
+한 시간ì´ë‚˜ 달린 ë’¤ì— ìš°ë¦¬ ì°ë§¤ëŠ” ëŠ¦ì€ ê²½ì‚¬ì§€ë¥¼ 올ëžë‹¤. ë§ì„ 어거하는 ì•„ë¼ì‚¬ ì‚¬ëžŒì€ ìˆìˆìˆìˆ, 후르르 í•˜ê³ ì£¼ë¬¸ì„ ì™¸ìš°ë“¯ì´ ìž…ìœ¼ë¡œ ë§ì„ ìž¬ì´‰í•˜ê³ ê³ ì‚를 ì´ë¦¬ ë“¤ê³ ì €ë¦¬ 들어 ë§ì—게 ë°©í–¥ì„ ê°€ë¦¬í‚¬ ë¿ì´ìš”, 채ì°ì€ ë³´ì´ê¸°ë§Œí•˜ê³ 한 ë²ˆë„ ì“°ì§€ 아니하였다. 그와 ë§ê³¼ëŠ” ì™„ì „ížˆ 뜻과 ì •ì´ ë§žëŠ” ë™ì§€ì¸ 듯하였다.
+처ìŒì—는 몰ëžìœ¼ë‚˜ 차차 추워ì§ì„ 깨달았다. 발과 무르íŒì´ ì‹œë ¸ë‹¤.
+"얼마나 머오?"
+í•˜ê³ ë‚˜ëŠ” ì˜¤ëž˜ê°„ë§Œì— ìž…ì„ ì—´ì–´ì„œ 노파ì—게 물었다. 노파는 털수건으로 머리를 ì‹¸ë§¤ê³ ê¹Šìˆ™í•œ 눈만 남겨 ê°€ì§€ê³ ì‹¤ì‹ í•œ 사람 모양으로 허공만 ë°”ë¼ë³´ê³ 있다가, ë‚´ê°€ 묻는 ë§ì— 비로소 ìž ì´ë‚˜ 깬 듯ì´,
+"멀지 않소. ì¸ì 한 ì‹ì˜¤ 마ì¼."
+í•˜ê³ ëŠ” 나를 ë°”ë¼ë³´ì•˜ë‹¤. ê·¸ ëˆˆì€ ì•„ë§ˆ 웃는 모양ì´ì—ˆë‹¤.
+ê·¸ 얼굴, ê·¸ 눈, ê·¸ ìŒì„±ì´ ëª¨ë‘ ì´ ë…¸íŒŒê°€ ì¸ìƒ í’íŒŒì˜ ìŠ¬í”ˆ ì¼ ê´´ë¡œìš´ ì¼ì— 부대ë¼ê³ 지친 ê²ƒì„ í‘œí•˜ì˜€ë‹¤. ê·¸ë¦¬ê³ ì£½ëŠ” ë‚ ê¹Œì§€ 살아간다 하는 듯하였다.
+경사지를 올ë¼ì„œì„œ 보니 ê·¸ê²ƒì€ í•œ 산등성ì´ì˜€ë‹¤. ë°©í–¥ì€ ì•Œ 수 없으나 우리가 가는 ë°©í–¥ì—는 ë” ë†’ì€ ë“±ì„±ì´ê°€ 있는 모양ì´ë‚˜ 다른 ê³³ì€ ë‹¤ ì´ë³´ë‹¤ ë‚®ì€ ê²ƒ 같아서 하얀 눈바다가 ëì—†ì´ ë³´ì´ëŠ” 듯하였다. ê·¸ 눈보ë¼ëŠ” ë“¤ì‘¹ë‚ ì‘¹ì´ ìžˆëŠ” ê²ƒì„ ë³´ë©´ ì‚¼ë¦¼ì˜ ê¼ëŒ€ê¸°ì¸ ê²ƒì´ ë¶„ëª…í•˜ì˜€ë‹¤. ë”구나 ì—¬ê¸°ì €ê¸° 뾰족뾰족 ëˆˆì†¡ì´ ë¶™ì„ ìˆ˜ 없는 마른 나ë‡ê°€ì§€ê°€ ê±°ë‡ê±°ë‡ ë³´ì´ëŠ” ê²ƒì„ ë³´ì•„ì„œ 그러하였다. ë§Œì¼ ëˆˆì´ ê±·í˜€ 주었으면 얼마나 안계가 넓으랴, ìµœì„ êµ°ì´ ê³ ë¯¼í•˜ëŠ” ê°€ìŠ´ì„ ì•ˆê³ ì´ë¦¬ë¡œ 헤매었구나 하면서 나는 ëª©ì„ ë‘˜ëŸ¬ì„œ ì‚¬ë°©ì„ ë°”ë¼ë³´ì•˜ë‹¤.
+우리는 ê·¸ 등성ì´ë¥¼ ë‚´ë ¤ê°”ë‹¤. ë§ì´ 미처 ë°œì„ ë•…ì— ë†“ì„ ìˆ˜ê°€ 없는 ì •ë„로 빨리 ë‚´ë ¤ê°”ë‹¤. 여기는 ì‚°ë¶ˆì´ ë‚¬ë˜ ìžë¦¬ì¸ 듯하여 ê±°ë‡ê±°ë‡ 불탄 ìžêµ 있는 마른 ë‚˜ë¬´ë“¤ì´ ë“œë¬¸ë“œë¬¸ 서 있었다. ê·¸ ë‚˜ë¬´ë“¤ì€ ì°ì–´ 가는 ì‚¬ëžŒë„ ì—†ìœ¼ë§¤ ì €ì ˆë¡œ ì©ì–´ì„œ 없어지기를 기다릴 ìˆ˜ë°–ì— ì—†ì—ˆë‹¤. ê·¸ë“¤ì€ ë‚˜ì„œ 아주 ì©ì–´ 버리기까지 천 ë…„ ì´ìƒì€ ê±¸ë¦°ë‹¤ê³ í•˜ë‹ˆ ë˜í•œ 장한 ì¼ì´ë‹¤.
+ì´ ëŒ€ì‚¼ë¦¼ì— ë¶ˆì´ ë¶™ëŠ”ë‹¤ 하면 ê·¸ê²ƒì€ ìž¥ê´€ì¼ ê²ƒì´ë‹¤. ë‹¬ë°¤ì— ë†’ì€ ê³³ì—서 ì´ ê²½ì¹˜ë¥¼ ë‚´ë ¤ë‹¤ë³¸ë‹¤ 하면 ê·¸ë„ ìž¥ê´€ì¼ ê²ƒì´ìš”, ì—¬ë¦„ì— í•œì°½ ê¸°ìš´ì„ íŽ¼ ë•Œë„ ìž¥ê´€ì¼ ê²ƒì´ë‹¤. 나는 ì˜¤ë‰´ì›”ê²½ì— ì‹œë² ë¦¬ì•„ë¥¼ 여행하는 ì´ë“¤ì´ ë없는 꽃바다를 보았다는 기ë¡ì„ ìƒê°í•˜ì˜€ë‹¤.
+"ì €ê¸°ìš”!"
+하는 ë…¸íŒŒì˜ ë§ì— 나는 ìƒê°ì˜ ì¤„ì„ ëŠì—ˆë‹¤. ì €ê¸°ë¼ê³ 가리키는 ê³³ì„ ë³´ë‹ˆ 거기는 ì§‘ì´ë¼ê³ ìƒê°ë˜ëŠ” ë¬¼ê±´ì´ ë‚˜ë¬´ 사ì´ë¡œ 보였다. ì°½ì´ ìžˆìœ¼ë‹ˆ 분명 ì§‘ì´ì—ˆë‹¤.
+우리 ì´ìŠ¤ë³´ìŠ¤ì¹˜ì¹´ê°€ ê°€ê¹Œì´ ì˜¤ëŠ” ê²ƒì„ ë³´ì•˜ëŠ”ì§€, ê·¸ ì§‘ ê°™ì€ ë¬¼ê±´ì˜ ë¬¸ ê°™ì€ ê²ƒì´ ì—´ë¦¬ë©° ê²€ì€ ì™¸íˆ¬ ìž…ì€ ì—¬ìž í•˜ë‚˜ê°€ íŒ”ì„ í—ˆìš°ì 거리며 뛰어나온다. 아마 ì†Œë¦¬ë„ ì¹˜ëŠ” 모양ì´ê² 지마는 ê·¸ 소리는 아니 ë“¤ë ¸ë‹¤. 나는 ê·¸ê²ƒì´ ìˆœìž„ì¸ ì¤„ì„ ì–¼ë¥¸ 알았다. ë˜ ìˆœìž„ì´ë°–ì— ë ì‚¬ëžŒë„ ì—†ì—ˆë‹¤.
+ìˆœìž„ì€ í•œì°¸ 달ìŒë°•질로 오다가 ëˆˆì´ ê¹Šì–´ì„œ 걸ìŒì„ 걷기가 íž˜ì´ ë“œëŠ”ì§€ 멈칫 섰다. ê·¸ì˜ ê²€ì€ ì™¸íˆ¬ëŠ” ì–´ëŠë§ í° ì 으로 ì–¼ë ¤ì ¸ ê°€ì§€ê³ ì–´ê¹¨ëŠ” í¬ê²Œ ë˜ëŠ” ê²ƒì´ ë³´ì˜€ë‹¤.
+ìˆœìž„ì˜ ê°¸ë¦„í•œ ì–¼êµ´ì´ ë³´ì˜€ë‹¤.
+"ì„ ìƒë‹˜!"
+í•˜ê³ ìˆœìž„ë„ ë‚˜ë¥¼ ì•Œì•„ë³´ê³ ëŠ” ë˜ íŒ”ì„ í—ˆìš°ì 거리며 소리를 ì§ˆë €ë‹¤.
+ë‚˜ë„ ë°˜ê°€ì›Œì„œ 모ìžë¥¼ ë²—ì–´ ë‘˜ë €ë‹¤.
+"ì•„ì´ ì„ ìƒë‹˜!"
+í•˜ê³ ìˆœìž„ì€ ë‚´ê°€ ì°ë§¤ì—서 ì¼ì–´ì„œê¸°ë„ ì „ì— ë‚´ê²Œ 와서 매달리며 울었다.
+"아버지 ì–´ë– ì‹œëƒ?"
+í•˜ê³ ë‚˜ëŠ” ìˆœìž„ì˜ ë“±ì„ ë‘ë“œë ¸ë‹¤. 나는 다리가 마비가 ë˜ì–´ì„œ ê³§ ì¼ì–´ì„¤ 수가 없었다.
+"아버지 ì–´ë– ì‹œëƒ?"
+í•˜ê³ ë‚˜ëŠ” 한 번 ë” ë¬¼ì—ˆë‹¤.
+ìˆœìž„ì€ ë²Œë–¡ ì¼ì–´ë‚˜ ë‘ ì£¼ë¨¹ìœ¼ë¡œ í르는 ëˆˆë¬¼ì„ ì³ë‚´ 버리며,
+"대단하셔요."
+í•˜ê³ ë„ ìš¸ìŒì„ 금치 못하였다.
+노파는 ë²Œì¨ ì°ë§¤ì—서 ë‚´ë ¤ì„œ 기운 없는 걸ìŒìœ¼ë¡œ 비틀비틀 걷기를 시작하였다.
+나는 ìˆœìž„ì„ ë”°ë¼ì„œ ì–¸ë•ì„ ì˜¤ë¥´ë©°,
+"그래 무슨 병환ì´ì‹œëƒ?"
+í•˜ê³ ë¬¼ì—ˆë‹¤.
+"몰ë¼ìš”. ì‹ ì—´ì´ ëŒ€ë‹¨í•˜ì…”ìš”."
+"ì •ì‹ ì€ ì°¨ë¦¬ì‹œë“ ?"
+"ì²˜ìŒ ì œê°€ 여기 ì™”ì„ ì ì—는 ê·¸ë ‡ì§€ 않ë”니 요새ì—는 ê°€ë” í˜¼ìˆ˜ ìƒíƒœì— ë¹ ì§€ì‹œëŠ” 모양ì´ì•¼ìš”."
+ì´ë§Œí•œ ì§€ì‹ì„ ê°€ì§€ê³ ë‚˜ëŠ” 최ì„ì´ê°€ 누워 있는 ì§‘ ì•žì— ë‹¤ë‹¤ëžë‹¤.
+ì´ ì§‘ì€ í†µë‚˜ë¬´ë¥¼ 댓 ê°œ 우물 ì •ìžë¡œ ê°€ë¡œë†“ê³ ì§€ë¶•ì€ ë¬´ì—‡ìœ¼ë¡œ 했는지 모르나 ëˆˆì´ ë®ì´ê³ , 문 하나 ì°½ 하나를 ë‚´ì—ˆëŠ”ë° ë¬¸ì€ ë‚˜ë¬´ê»ì§ˆì¸ 모양ì´ë‚˜ ì°½ì€ ì –ë¹› 나는 ìœ ë¦¬ì°½ì¸ ì¤„ 알았ë”니 ë’¤ì— ì•Œì•„ë³¸ì¦‰ ê·¸ê²ƒì€ ìœ ë¦¬ê°€ 아니요, ì–‘ëª©ì„ ë°”ë¥´ê³ ë¬¼ì„ ë¿œì–´ì„œ ì–¼ë ¤ ë†“ì€ ê²ƒì´ì—ˆë‹¤. ê·¸ë¦¬ê³ í†µë‚˜ë¬´ì™€ 통나무 틈바구니ì—는 ì‡ í„¸ê³¼ ê°™ì€ ë§ˆë¥¸ í’€ì„ ê¼ê¼ 박아서 ë°”ëžŒì„ ë§‰ì•˜ë‹¤.
+ë¬¸ì„ ì—´ê³ ë“¤ì–´ì„œë‹ˆ ë¶€ì—Œì— ë“¤ì–´ì„œëŠ” 모양으로 ì‘¥ ë¹ ì¡ŒëŠ”ë° í™”ëˆí™”ëˆí•˜ëŠ” ê²ƒì´ í•œì¦ê³¼ 같다. ê·¸ë ‡ì§€ ì•Šì•„ë„ ì¹¨ì¹¨í•œ ë‚ ì— ì–¸ 눈으로 ê´‘ì„ ë¶€ì¡±í•œ ë°©ì— ë“¤ì–´ì˜¤ë‹ˆ, 캄캄 ì ˆë²½ì´ì–´ì„œ ì•„ë¬´ê²ƒë„ ë³´ì´ì§€ 아니하였다.
+순임ì´ê°€ 앞서서 ì–‘ì´ˆì— ë¶ˆì„ ì¼ ë‹¤. 촛불 ë¹›ì€ ë°© 한편 쪽 침대ë¼ê³ í• ë§Œí•œ ë†’ì€ ê³³ì— ë‹´ìš”ë¥¼ ë®ê³ 누운 최ì„ì˜ ì‹œì²´ì™€ ê°™ì€ í° ì–¼êµ´ì„ ë¹„ì¶˜ë‹¤.
+"아버지, 아버지 ìƒŒì „ ì•„ì €ì”¨ 오셨어요."
+í•˜ê³ ìˆœìž„ì€ ìµœì„ì˜ ê·€ì— ìž…ì„ ëŒ€ê³ ê°€ë§Œížˆ ë¶ˆë €ë‹¤.
+그러나 ëŒ€ë‹µì´ ì—†ì—ˆë‹¤.
+나는 최ì„ì˜ ì´ë§ˆë¥¼ ë§Œì ¸ 보았다. 축축하게 ë•€ì´ í˜ë €ë‹¤. 그러나 그리 ë”ìš´ ì¤„ì€ ëª°ëžë‹¤.
+ë°© ì•ˆì˜ ê³µê¸°ëŠ” ìˆ¨ì´ ë§‰íž ë“¯í•˜ì˜€ë‹¤. ê·¸ 난방 장치는 ì‚¼êµ¿ì˜ ì›ë¦¬ë¥¼ ì´ìš©í•œ 것ì´ì—ˆë‹¤. ëŒë©©ì´ë¡œ ì•„ê¶ì´ë¥¼ ìŒ“ê³ ê·¸ ìœ„ì— í° ëŒë©©ì´ë“¤ì„ ë§Žì´ ìŒ“ê³ ê±°ê¸°ë‹¤ê°€ ë¶ˆì„ ë•Œì–´ì„œ 달게 한 ë’¤ì— ê±°ê¸° ëˆˆì„ ë¶€ì–´ 뜨거운 ì¦ê¸°ë¥¼ 발하는 것ì´ì—ˆë‹¤.
+ì´ ê±´ì¶•ë²•ì€ ì¡°ì„ ë™í¬ë“¤ì´ ì‹œë² ë¦¬ì•„ë¡œ ê¸ˆê´‘ì„ ì°¾ì•„ë‹¤ë‹ˆë©´ì„œ 하는 법ì´ëž€ ë§ì„ 들었으나 최ì„ì´ê°€ 누구ì—게서 배워 ê°€ì§€ê³ ì–´ë–¤ 모양으로 지었는지는 최ì„ì˜ ë§ì„ 듣기 ì „ì—는 알 수 없는 ì¼ì´ë‹¤.
+나는 ë‚´ íž˜ì´ ë¯¸ì¹˜ëŠ” ë°ê¹Œì§€ 최ì„ì˜ ë³‘ ì¹˜ë£Œì— ëŒ€í•œ ì†ì„ ì“°ê³ ì–´ë–»ê²Œ í•´ì„œë“ ì§€ ì´ë¥´ì¿ ì¸ í¬ì˜ 병ì›ìœ¼ë¡œ 최ì„ì„ ë°ë ¤ë‹¤ê°€ ìž…ì›ì‹œí‚¬ ë„리를 ê¶ë¦¬í•˜ì˜€ë‹¤. 그러나 ëƒ‰ì •í•˜ê²Œ ìƒê°í•˜ë©´ 최ì„ì€ ì‚´ì•„ë‚ ê°€ë§ì´ 없는 것만 같았다.
+ë‚´ê°€ ê°„ ì§€ ì‚¬í˜ ë§Œì— ìµœì„ì€ ì²˜ìŒìœ¼ë¡œ ì •ì‹ ì„ ì°¨ë ¤ì„œ ëˆˆì„ ëœ¨ê³ ë‚˜ë¥¼ 알아보았다.
+그는 반가운 í‘œì •ì„ í•˜ê³ ë¹™ê·¸ë ˆ 웃기까지 하였다.
+"다 ì¼ì—†ë‚˜?"
+ì´ëŸ° ë§ë„ ì•Œì•„ë“¤ì„ ìˆ˜ê°€ 있었다.
+그러나 심히 ê¸°ìš´ì´ ì—†ëŠ” 모양ì´ê¸°ë¡œ 나는 ë§Žì´ ë§ì„ 하지 아니하였다.
+최ì„ì€ í•œì°¸ì´ë‚˜ ëˆˆì„ ê°ê³ 있ë”니,
+"ì •ìž„ì´ ì†Œì‹ ë“¤ì—ˆë‚˜?"
+하였다.
+"괜찮대요."
+í•˜ê³ ê³ì—서 순임ì´ê°€ ë§í•˜ì˜€ë‹¤.
+ê·¸ë¦¬ê³ ëŠ” ë˜ í˜¼ëª½í•˜ëŠ” 듯하였다.
+ê·¸ ë‚ ë˜ í•œ 번 최ì„ì€ ì •ì‹ ì„ ì°¨ë¦¬ê³ ìˆœìž„ë”러는 ì €ë¦¬ë¡œ ê°€ë¼ëŠ” ëœ»ì„ í‘œí•˜ê³ ë‚˜ë”러 귀를 ê°€ê¹Œì´ ëŒ€ë¼ëŠ” ëœ»ì„ ë³´ì´ê¸°ë¡œ 그대로 하였ë”니,
+"ë‚´ 가방 ì†ì— ì¼ê¸°ê°€ 있으니 그걸 ìžë„¤ë§Œ ë³´ê³ ëŠ” ë¶ˆì‚´ë¼ ë²„ë ¤. ë‚´ê°€ ì£½ì€ ë’¤ì—ë¼ë„ ê·¸ê²ƒì´ ì„¸ìƒ ì‚¬ëžŒì˜ ëˆˆì— ë“¤ë©´ 안 ë˜ì§€. 순임ì´ê°€ 볼까 ê±±ì •ì´ ë˜ì§€ë§ˆëŠ” ë‚´ê°€ ëª¸ì„ ê¼¼ì§í• 수가 있나."
+하는 ëœ»ì„ ë§í•˜ì˜€ë‹¤.
+"그러지."
+í•˜ê³ ë‚˜ëŠ” ê³ ê°œë¥¼ ë„ë•ì—¬ 보였다.
+ê·¸ëŸ¬ê³ ë‚œ ë’¤ì— ë‚˜ëŠ” 최ì„ì´ê°€ 시킨 대로 ê°€ë°©ì„ ì—´ê³ ì±…ë“¤ì„ ë’¤ì ¸ì„œ ê·¸ ì¼ê¸°ì±…ì´ë¼ëŠ” ê³µì±…ì„ êº¼ë‚´ì—ˆë‹¤.
+"ìˆœìž„ì´ ë„ˆ ì´ê±° 보았니?"
+í•˜ê³ ë‚˜ëŠ” ê³ì—서 ë‚´ê°€ ì±… 찾는 ê²ƒì„ ë³´ê³ ì„°ë˜ ìˆœìž„ì—게 물었다.
+"아니오. 그게 무어여요?"
+í•˜ê³ ìˆœìž„ì€ ë‚´ ì†ì— ë“ ì±…ì„ ë¹¼ì•—ìœ¼ë ¤ëŠ” ë“¯ì´ ì†ì„ 내밀었다.
+나는 ìˆœìž„ì˜ ì†ì´ ë‹¿ì§€ 않ë„ë¡ ì±…ì„ í•œíŽ¸ìœ¼ë¡œ 비키며,
+"ì´ê²ƒì´ 네 아버지 ì¼ê¸°ì¸ 모양ì¸ë° 너는 ë³´ì´ì§€ ë§ê³ 나만 ë³´ë¼ê³ 하셨다. 네 아버지가 네가 ì´ê²ƒì„ 보았ì„까 해서 ì—¼ë ¤ë¥¼ í•˜ì‹œëŠ”ë° ì•ˆ 보았으면 다행ì´ë‹¤."
+í•˜ê³ ë‚˜ëŠ” ê·¸ ì±…ì„ ë“¤ê³ ë°–ìœ¼ë¡œ 나왔다.
+ë‚ ì´ ë°ë‹¤. 해는 ì¤‘ì²œì— ìžˆë‹¤. 중천ì´ëž˜ì•¼ ì € 남쪽 ì§€í‰ì„ 가까운 ë°ë‹¤. ë°¤ì´ ì—´ì—¬ëŸ ì‹œê°„, ë‚®ì´ ëŒ€ì—¬ì„¯ ì‹œê°„ë°–ì— ì•ˆ ë˜ëŠ” ë¶ìª½ 나ë¼ë‹¤. 멀건 햇빛ì´ë‹¤.
+나는 ë³•ì´ ìž˜ 드는 ê³³ì„ ê³¨ë¼ì„œ ë‚˜ë¬´ì— ëª¸ì„ ê¸°ëŒ€ê³ ìµœì„ì˜ ì¼ê¸°ë¥¼ ì½ê¸° 시작하였다. ì½ì€ 중ì—서 몇 êµ¬ì ˆì„ ê³¨ë¼ ë³¼ê¹Œ.
+"ì§‘ì´ ë‹¤ ë˜ì—ˆë‹¤. ì´ ì§‘ì€ ë‚´ê°€ ìƒì „ ì‚´ê³ ê·¸ ì†ì—서 ì´ ì„¸ìƒì„ ë§ˆì¹ ì§‘ì´ë‹¤. 마ìŒì´ 기ì˜ë‹¤. 시ë„러운 세ìƒì€ 여기서 멀지 아니하ëƒ. ë‚´ê°€ 여기 홀로 있기로 누가 ì°¾ì„ ì‚¬ëžŒë„ ì—†ì„ ê²ƒì´ë‹¤. ë‚´ê°€ 여기서 죽기로 누가 슬í¼í•´ 줄 ì‚¬ëžŒë„ ì—†ì„ ê²ƒì´ë‹¤. 때로 ê³°ì´ë‚˜ 찾아올까. ì§€ë‚˜ê°€ë˜ ì‚¬ìŠ´ì´ë‚˜ 들여다볼까.
+ì´ê²ƒì´ ë‚´ 소ì›ì´ 아니ëƒ. 세ìƒì˜ 시ë„ëŸ¬ì›€ì„ ë– ë‚˜ëŠ” ê²ƒì´ ë‚´ 소ì›ì´ 아니ëƒ. ì´ ì†ì—서 나는 나를 ì´ê¸°ê¸°ë¥¼ 공부하ìž."
+ì²«ë‚ ì€ ì´ëŸ° í‰ë²”한 소리를 ì¼ë‹¤.
+ê·¸ ì´íŠ¿ë‚ ì—는.
+"어떻게나 나는 약한 사람ì¸ê³ . ì œ 마ìŒì„ ì œê°€ 지배하지 못하는 사람ì¸ê³ . 밤새ë„ë¡ ë‚˜ëŠ” ì •ìž„ì„ ìƒê°í•˜ì˜€ë‹¤. ì–´ë‘ìš´ í—ˆê³µì„ í–¥í•˜ì—¬ ì •ìž„ì„ ë¶ˆë €ë‹¤. ì •ìž„ì´ê°€ 나를 찾아서 ë™ê²½ì„ ë– ë‚˜ì„œ ì´ë¦¬ë¡œ 오지나 아니하나 í•˜ê³ ìƒê°í•˜ì˜€ë‹¤. 어떻게나 ë¶€ë„러운 ì¼ì¸ê³ ? 어떻게나 ê°€ì¦í•œ ì¼ì¸ê³ ?
+나는 아내를 ìƒê°í•˜ë ¤ 하였다. ì•„ì´ë“¤ì„ ìƒê°í•˜ë ¤ 하였다. 아내와 ì•„ì´ë“¤ì„ ìƒê°í•¨ìœ¼ë¡œ ì •ìž„ì˜ ìƒê°ì„ ì´ê¸°ë ¤ 하였다.
+최ì„ì•„, 너는 ë‚¨íŽ¸ì´ ì•„ë‹ˆëƒ. 아버지가 아니ëƒ. ì •ìž„ì€ ë„¤ ë”¸ì´ ì•„ë‹ˆëƒ. ì´ëŸ° ìƒê°ì„ 하였다.
+ê·¸ëž˜ë„ ì •ìž„ì˜ ì¼ë¥˜ì „ì€ ì•„ë‚´ì™€ ì•„ì´ë“¤ì˜ ìƒê°ì„ ë°€ì¹˜ê³ ë‹¬ë ¤ì˜¤ëŠ” ì ˆëŒ€ ìœ„ë ¥ì„ ê°€ì§„ 듯하였다.
+ì•„, 나는 어떻게나 íŒŒë ´ì¹˜í•œ 사람ì¸ê³ . ë‚˜ì´ ì‚¬ì‹ì´ 넘어 오ì‹ì„ ë°”ë¼ë³´ëŠ” ë†ˆì´ ì•„ë‹ˆëƒ. 사ì‹ì— 불혹ì´ë¼ê³ 아니 하ëŠëƒ. êµìœ¡ê°€ë¡œ 깨ë—한 êµì¸ìœ¼ë¡œ ì¼ìƒì„ ì‚´ì•„ ì™”ë‹¤ê³ ìžì²˜í•˜ëŠ” ë‚´ê°€ ì•„ë‹ˆëƒ í•˜ê³ ë‚˜ëŠ” ë‚´ 입으로 ë‚´ ì†ê°€ë½ì„ 물어서 ë‘ êµ°ë°ë‚˜ 피를 내었다."
+최ì„ì˜ ë‘˜ì§¸ ë‚ ì¼ê¸°ëŠ” 계ì†ëœë‹¤.
+"ë‚´ ì†ê°€ë½ì—서 피가 ë‚ ë•Œì— ë‚˜ëŠ” ìœ ì¾Œí•˜ì˜€ë‹¤. 나는 ìŠ¹ì²©ì˜ ê¸°ì¨ì„ 깨달았다.
+그러나 ì•„ì•„ 그러나 ê·¸ 빨간, ì°¸íšŒì˜ í•방울 ì†ì—ì„œë„ ì• ìš•ì˜ ë¶ˆê¸¸ì´ ì¼ì§€ 아니하는가. 나는 마침내 ì œë„í• ìˆ˜ 없는 ì¸ìƒì¸ê°€."
+ì´ ì§‘ì— ë“ ì§€ ë‘˜ì§¸ë‚ ì— ë²Œì¨ ì´ëŸ¬í•œ 비관ì ë§ì„ 하였다.
+ë˜ ë©°ì¹ ì„ ì§€ë‚œ ë’¤ ì¼ê¸°ì—,
+"나는 ë™ê²½ìœ¼ë¡œ ëŒì•„ê°€ê³ ì‹¶ë‹¤. ì •ìž„ì˜ ê³ìœ¼ë¡œ ê°€ê³ ì‹¶ë‹¤. ì‹œë² ë¦¬ì•„ì˜ê´‘ì•¼ì˜ ìœ í˜¹ë„ ì•„ë¬´ íž˜ì´ ì—†ë‹¤. ì–´ì ¯ë°¤ì€ ì‚¼ë¦¼ì˜ ì¢‹ì€ ë‹¬ì„ ë³´ì•˜ìœ¼ë‚˜ ê·¸ ë‹¬ì„ ì•„ë¦„ë‹µê²Œ ë³´ë ¤ 하였으나 아무리 í•˜ì—¬ë„ ì•„ë¦„ë‹µê²Œ ë³´ì´ì§€ë¥¼ 아니하였다.
+하늘ì´ë‚˜ 달ì´ë‚˜ 삼림ì´ë‚˜ ëª¨ë‘ ë¬´ì˜ë¯¸í•œ 존재다. ì´ì²˜ëŸ¼ 무ì˜ë¯¸í•œ 존재를 나는 경험한 ì¼ì´ 없다. ê·¸ê²ƒì€ ë‹¤ë§Œ 기ì¨ì„ ìžì•„ë‚´ì§€ ì•„ë‹ˆí• ë¿ë”러 ìŠ¬í””ë„ ìžì•„ë‚´ì§€ 못하였다. ê·¸ê²ƒì€ ìž¿ë”미였다. ì•„ë¬´ë„ ë“£ëŠ” ì´ ì—†ëŠ” ë°ì„œ ë‚´ ì§„ì •ì„ ë§í•˜ë¼ë©´ ê·¸ê²ƒì€ ì´ ì²œì§€ì— ë‚´ê²Œ ì˜ë¯¸ 있는 ê²ƒì€ ì •ìž„ì´ë°–ì— ì—†ë‹¤ëŠ” 것ì´ë‹¤.
+나는 ì •ìž„ì˜ ê³ì— ìžˆê³ ì‹¶ë‹¤. ì •ìž„ì„ ë‚´ ê³ì— ë‘ê³ ì‹¶ë‹¤. 왜? ê·¸ê²ƒì€ ë‚˜ë„ ëª¨ë¥¸ë‹¤.
+ë§Œì¼ ì´ ì›€ ì†ì—ë¼ë„ ì •ìž„ì´ê°€ 있다 하면 얼마나 ì´ê²ƒì´ ì¦ê±°ìš´ ê³³ì´ ë 까.
+그러나 ì´ê²ƒì€ 불가능한 ì¼ì´ë‹¤. ì´ ì¼ì´ 있어서는 아니 ëœë‹¤. 나는 ì´ ìƒê°ì„ 죽여야 한다. 다시 ê±°ë‘를 못 하ë„ë¡ ëª©ìˆ¨ì„ ëŠì–´ ë²„ë ¤ì•¼ 한다.
+ì´ê²ƒì„ 나는 ì›í•œë‹¤. ì›í•˜ì§€ë§ˆëŠ” 내게는 ê·¸ íž˜ì´ ì—†ëŠ” 모양ì´ë‹¤.
+나는 종êµë¥¼ ìƒê°í•˜ì—¬ 본다. ì² í•™ì„ ìƒê°í•˜ì—¬ 본다. ì¸ë¥˜ë¥¼ ìƒê°í•˜ì—¬ 본다. 나ë¼ë¥¼ ìƒê°í•˜ì—¬ 본다. ì´ê²ƒì„ ê°€ì§€ê³ ë‚´ ì• ìš•ê³¼ ë°”ê¾¸ë ¤ê³ ì• ì¨ ë³¸ë‹¤. ê·¸ë ‡ì§€ë§ˆëŠ” 내게 그러한 íž˜ì´ ì—†ë‹¤. 나는 ì™„ì „ížˆ í—¬í”Œë¦¬ìŠ¤í•¨ì„ ê¹¨ë‹«ëŠ”ë‹¤.
+ì•„ì•„ 나는 ì–´ì°Œí• ê¼¬?
+나는 못ìƒê¸´ 사람ì´ë‹¤. 그까짓 ê²ƒì„ ëª» ì´ê²¨? 그까짓 ê²ƒì„ ëª» ì´ê²¨?
+나는 ì˜ˆìˆ˜ì˜ ê´‘ì•¼ì—ì„œì˜ ìœ í˜¹ì„ ìƒê°í•œë‹¤. 천하를 주마 하는 ìœ í˜¹ì„ ìƒê°í•œë‹¤. 나는 싯다르타 태ìžê°€ 왕ê¶ì„ ë²„ë¦¬ê³ ë‚˜ì˜¨ ê²ƒì„ ìƒê°í•˜ê³ , ë˜ ìŠ¤í† ì•„ ì² í•™ìžì˜ ì˜ì§€ë ¥ì„ ìƒê°í•˜ì˜€ë‹¤.
+그러나 나는 그러한 ìƒê°ìœ¼ë¡œë„ ì´ ìƒê°ì„ ì´ê¸¸ 수가 없는 것 같다.
+나는 í˜ëª…가를 ìƒê°í•˜ì˜€ë‹¤. ëª¨ë“ ê²ƒ ì‚¬ëž‘ë„ ëª©ìˆ¨ë„ ë‹¤ í—Œì‹ ì§ê°™ì´ ì§‘ì–´ë˜ì§€ê³ 피 í르는 마당으로 뛰어나가는 용사를 ìƒê°í•˜ì˜€ë‹¤. 나는 ì´ë없는 삼림 ì†ìœ¼ë¡œ í˜ëª…ì˜ ìš©ì‚¬ 모양으로 달ìŒë°•질치다가 ê¸°ìš´ì´ ì§„í•œ ê³³ì—서 죽어 버리는 ê²ƒì´ ì†Œì›ì´ì—ˆë‹¤. 그러나 ê±°ê¸°ê¹Œì§€ë„ ì´ ìƒê°ì€ 따르지 ì•„ë‹ˆí• ê¹Œ.
+나는 지금 ê³§ 죽어 버릴까. 나는 육혈í¬ë¥¼ ì†ì— 들어 보았다. ì´ ë°©ì•„ì‡ ë¥¼ 한 번만 튕기면 ë‚´ ìƒëª…ì€ ì—†ì–´ì§€ëŠ” ê²ƒì´ ì•„ë‹Œê°€. 그리 ë˜ë©´ ëª¨ë“ ì´ ë§ˆìŒì˜ 움ì§ìž„ì€ ì†Œë©¸ë˜ëŠ” ê²ƒì´ ì•„ë‹Œê°€. ì´ê²ƒìœ¼ë¡œ 만사가 í•´ê²°ë˜ëŠ” ê²ƒì´ ì•„ë‹Œê°€.
+ì•„ 하나님ì´ì‹œì—¬, íž˜ì„ ì£¼ì‹œì˜µì†Œì„œ. 천하를 ì´ê¸°ëŠ” íž˜ë³´ë‹¤ë„ ë‚˜ ìžì‹ ì„ ì´ê¸°ëŠ” íž˜ì„ ì£¼ì‹œì˜µì†Œì„œ. ì´ ì£„ì¸ìœ¼ë¡œ 하여금 í•˜ë‚˜ë‹˜ì˜ ëˆˆì— ì˜ë¡ê³ 깨ë—한 사람으로 ì´ ì¼ìƒì„ 마치게 하여 주시옵소서, ì´ë ‡ê²Œ 나는 기ë„를 한다.
+그러나 하나님께서는 나를 버리셨다. 하나님께서는 내게 íž˜ì„ ì£¼ì‹œì§€ 아니하시었다. 나를 ì´ ë¹„ì°¸í•œ ìžë¦¬ì—서 ì©ì–´ì ¸ 죽게 하시었다."
+최ì„ì€ ì–´ë–¤ ë‚ ì¼ê¸°ì— ë˜ ì´ëŸ° ê²ƒë„ ì¼ë‹¤. ê·¸ê²ƒì€ ì˜ˆì „ 내게 보낸 íŽ¸ì§€ì— ìžˆë˜ ê¿ˆ ì´ì•¼ê¸°ë¥¼ ì—°ìƒì‹œí‚¤ëŠ” 것ì´ì—ˆë‹¤. ê·¸ê²ƒì€ ì´ëŸ¬í•˜ë‹¤.
+"오늘 ë°¤ì€ ë‹¬ì´ ì¢‹ë‹¤. ì‹œë² ë¦¬ì•„ì˜ ê²¨ìš¸ 해는 ì°¸ 못ìƒê¸´ ì‚¬ëžŒê³¼ë„ ê°™ì´ ê¸°ìš´ì´ ì—†ì§€ë§ˆëŠ” 하얀 ë•…, 검푸른 í•˜ëŠ˜ì— ì €ìª½ ì§€í‰ì„ ì„ í–¥í•˜ê³ í˜ëŸ¬ê°€ëŠ” ë°˜ë‹¬ì€ ì°¸ìœ¼ë¡œ ë§‘ìŒ ê·¸ê²ƒì´ì—ˆë‹¤.
+나는 í‰ìƒ ì²˜ìŒ ì‹œ 비슷한 ê²ƒì„ ì§€ì—ˆë‹¤.
+임과 ì´ë³„í•˜ë˜ ë‚ ë°¤ì—는 남쪽 나ë¼ì— 바람비가 쳤네
+ìž„ íƒ€ì‹ ìžë™ì°¨ì˜ ë’·ë¶ˆì´ ë¹¨ê°„ ë’·ë¶ˆì´ ë¹—ë°œì— ì°¢ê²¼ë„¤
+ìž„ ë– ë‚˜ í˜¼ìž í—¤ë§¤ëŠ” ì‹œë² ë¦¬ì•„ì˜ ì˜¤ëŠ˜ ë°¤ì—는
+ì§€ë ¤ëŠ” ìª½ë‹¬ì´ ëˆˆ ë®ì¸ ì‚¼ë¦¼ì— ê±¸ë ¸êµ¬ë‚˜
+ì•„ì•„ ì € 쪽달ì´ì—¬
+억지로 ë°˜ì„ ê°ˆê²¨ì§„ ê²ƒë„ ê°™ì•„ë¼
+ì•„ì•„ ì € 쪽달ì´ì—¬
+잃어진 ì§ì„ 찾아
+차디찬 허공 ì†ì„ ì˜ì›ížˆ 헤매는 ê²ƒë„ ê°™êµ¬ë‚˜
+ë‚˜ë„ ì € 달과 ê°™ì´ ìžƒì–´ë²„ë¦° ë°˜ìª½ì„ ì°¾ì•„ 무ê¶í•œ 시간과 공간ì—서 헤매는 것만 같다.
+ì—ìµ. ë‚´ê°€ 왜 ì´ë¦¬ 약한가. 어찌하여 í¬ë‚˜í° ë§Žì€ ì¼ì„ ëŒì•„ë³´ì§€ ëª»í•˜ê³ ìš”ë§Œí•œ ì• ìš•ì˜ í¬ë¡œê°€ ë˜ëŠ”ê°€.
+그러나 나는 차마 ê·¸ ë‹¬ì„ ë²„ë¦¬ê³ ë“¤ì–´ì˜¬ 수가 없었다. ë‚´ê°€ 왜 ì´ë ‡ê²Œ 센티멘털하게 ë˜ì—ˆëŠ”ê³ . ë‚´ ì‡ ê°™ì€ ì˜ì§€ë ¥ì´ 어디로 ê°”ëŠ”ê³ . ë‚´ 누를 수 없는 ìžì¡´ì‹¬ì´ 어디로 ê°”ëŠ”ê³ . 나는 마치 ìœ ëª¨ì˜ ì†ì— 달린 ì –ë¨¹ì´ì™€ë„ 같다. ë‚´ ì¼ì‹ ì€ ë„시 ì• ìš• ë©ì–´ë¦¬ë¡œ 화해 버린 것 같다.
+ì´ë¥¸ë°” 사랑 사랑ì´ëž€ ë§ì€ 종êµì ì˜ë¯¸ì¸ 것 ì´ì™¸ì—ë„ ìž…ì— ë‹´ê¸°ë„ ì‹«ì–´í•˜ë˜ ë§ì´ë‹¤ ì´ëŸ° ê²ƒì€ ë‚´ ì˜ì§€ë ¥ê³¼ ìžì¡´ì‹¬ì„ 녹여 ë²„ë ¸ëŠ”ê°€. ë˜ ì´ ë¶€ìžì—°í•œ ê³ ë…ì˜ ìƒí™œì´ 나를 ì´ë ‡ê²Œ ë‚´ ì¸ê²©ì„ ì´ë ‡ê²Œ 파괴하였는가.
+ê·¸ë ‡ì§€ 아니하면 ë‚´ ìžì¡´ì‹¬ì´ë¼ëŠ” 것ì´ë‚˜, ì˜ì§€ë ¥ì´ë¼ëŠ” 것ì´ë‚˜, ì¸ê²©ì´ë¼ëŠ” ê²ƒì´ ëª¨ë‘ ì„¸ìƒì˜ 습관과 ì‚¬ì¡°ì— íœ©ì“¸ë¦¬ë˜ ê²ƒì¸ê°€. ë‚¨ë“¤ì´ ê·¸ëŸ¬ë‹ˆê¹Œ ë‚¨ë“¤ì´ ì˜³ë‹¤ë‹ˆê¹Œ ë‚¨ë“¤ì´ ë¬´ì„œìš°ë‹ˆê¹Œ ì´ ì• ìš•ì˜ ë¬´ë¤ì— 회를 ë°œëžë˜ 것ì¸ê°€. 그러다가 ê³ ë…ê³¼ ë°˜ì„±ì˜ ê¸°íšŒë¥¼ 얻으매 ëª¨ë“ íšŒì¹ ê³¼ ê°€ë©´ì„ ë–¼ì–´ ë²„ë¦¬ê³ ë¹¨ê°€ë²—ì€ ì• ìš•ì˜ ë‰í……ì´ê°€ 나온 것ì¸ê°€.
+ê·¸ë ‡ë‹¤ 하면, ì´ê²ƒì´ ì°¸ëœ ë‚˜ì¸ê°€. ì´ê²ƒì´ 하나님께서 지어 ì£¼ì‹ ëŒ€ë¡œì˜ ë‚˜ì¸ê°€. ê°€ìŠ´ì— íƒ€ì˜¤ë¥´ëŠ” ì• ìš•ì˜ ë¶ˆê¸¸ ì´ ë¶ˆê¸¸ì´ ê³§ ë‚´ ì˜í˜¼ì˜ 불길ì¸ê°€.
+어쩌면 ê·¸ ëª¨ë“ ë†’ì€ ì´ìƒë“¤ ì¸ë¥˜ì— 대한, ë¯¼ì¡±ì— ëŒ€í•œ, ë„ë•ì— ëŒ€í•œ, ì‹ ì•™ì— ëŒ€í•œ ê·¸ ë†’ì€ ì´ìƒë“¤ì´ ì´ë ‡ê²Œë„ 만만하게 마치 ë°”ëžŒì— ë¶ˆë¦¬ëŠ” 재 모양으로 ìžì·¨ë„ ì—†ì´ í©ì–´ì ¸ ë²„ë¦¬ê³ ë§ê¹Œ. ê·¸ë¦¬ê³ ê·¸ ë’¤ì—는 í‰ì†Œì—ê·¸ë ‡ê²Œë„ ë¯¸ì›Œí•˜ê³ ì²œížˆ ì—¬ê¸°ë˜ ì• ìš•ì˜ ê²€ì€ í™ë§Œ ë‚¨ê³ ë§ê¹Œ.
+ì•„ì•„ ì € 눈 ë®ì¸ ë•…ì´ì—¬, ì°¨ê³ ë§‘ì€ ë‹¬ì´ì—¬, 허공ì´ì—¬! 나는 너í¬ë“¤ì„ 부러워하노ë¼.
+불êµë„ë“¤ì˜ í•´íƒˆì´ë¼ëŠ” ê²ƒì´ ì´ëŸ¬í•œ ì• ìš•ì´ ë¶ˆë¶™ëŠ” 지옥ì—서 눈과 ê°™ì´ ì‹¸ëŠ˜í•˜ê³ í—ˆê³µê³¼ ê°™ì´ ë¹ˆ 곳으로 들어ê°ì„ ì´ë¦„ì¸ê°€.
+ì„ê°€ì˜ íŒ” ë…„ ê°„ 설산 ê³ í–‰ì´ ì´ ì• ìš•ì˜ ë¿Œë¦¬ë¥¼ ëŠìœ¼ë ¤ 함ì´ë¼ í•˜ê³ ì˜ˆìˆ˜ì˜ ì‚¬ì‹ ì¼ ê´‘ì•¼ì˜ ê³ í–‰ê³¼ ê²Ÿì„¸ë§ˆë„¤ì˜ ê³ ë¯¼ë„ ì´ ì• ìš•ì˜ ë¿Œë¦¬ 때문ì´ì—ˆë˜ê°€.
+그러나 ê·¸ê²ƒì„ ì´ê¸°ì–´ 낸 ì‚¬ëžŒì´ ì²œì§€ 개벽 ì´ëž˜ì— 몇몇ì´ë‚˜ ë˜ì—ˆëŠ”ê³ ? 나 ê°™ì€ ê²ƒì´ ê·¸ ì¤‘ì— í•œ 사람 ë˜ê¸°ë¥¼ 바랄 수가 있ì„까.
+나 같아서는 마침내 ì´ ì• ìš•ì˜ ë¶ˆê¸¸ì— ë‹¤ 타서 재가 ë˜ì–´ 버릴 것만 같다. ì•„ì•„ 어떻게나 íž˜ìžˆê³ ë¬´ì„œìš´ 불길ì¸ê³ ."
+ì´ëŸ¬í•œ ê³ ë¯¼ì˜ ìžë°±ë„ 있었다.
+ë˜ ì–´ë–¤ ë‚ ì¼ê¸°ì—는 최ì„ì€ ì´ëŸ° ë§ì„ ì¼ë‹¤.
+"나는 단연히 ë™ê²½ìœ¼ë¡œ ëŒì•„가기를 결심하였다."
+ê·¸ë¦¬ê³ ëŠ” ê·¸ ì´íŠ¿ë‚ ì€,
+"나는 단연히 ë™ê²½ìœ¼ë¡œ ëŒì•„가리란 ê²°ì‹¬ì„ í•œ ê²ƒì„ êµ³ì„¸ê²Œ 취소한다. 나는 ì´ëŸ¬í•œ ê²°ì‹¬ì„ í•˜ëŠ” 나 ìžì‹ ì„ êµ³ì„¸ê²Œ ë¶€ì¸í•œë‹¤."
+ë˜ ì´ëŸ° ë§ë„ 있다.
+"나는 ì •ìž„ì„ ì‹œë² ë¦¬ì•„ë¡œ ë¶€ë¥´ë ¨ë‹¤."
+ë˜ ê·¸ 다ìŒì—는,
+"ì•„ì•„ 나는 í•˜ë£¨ë°”ì‚ ì£½ì–´ì•¼ 한다. ì´ ëª©ìˆ¨ì„ ì—°ìž¥í•˜ì˜€ë‹¤ê°€ëŠ” 무슨 ì¼ì„ ì €ì§€ë¥¼ëŠ”ì§€ 모른다. 나는 깨ë—하게 나를 ì´ê¸°ëŠ” ë„ë•ì ì¸ê²©ìœ¼ë¡œ ì´ ì¼ìƒì„ 마ì³ì•¼ 한다. ì´ ë°–ì— ë‚´ ì‚¬ì—…ì´ ë¬´ì—‡ì´ëƒ."
+ë˜ ì–´ë–¤ ê³³ì—는,
+"ì•„ì•„ 무서운 하룻밤ì´ì—ˆë‹¤. 나는 지난 í•˜ë£»ë°¤ì„ ëˆ„ë¥¼ 수 없는 ì• ìš•ì˜ ë¶ˆê¸¸ì— íƒ”ë‹¤. 나는 ë‚´ 주먹으로 ë‚´ ê°€ìŠ´ì„ ë‘ë“œë¦¬ê³ ë¨¸ë¦¬ë¥¼ ë²½ì— ë¶€ë”ªì³¤ë‹¤. 나는 주먹으로 ë‹´ë²½ì„ ë‘ë“œë ¤ ì†ë“±ì´ í„°ì ¸ì„œ 피가 í˜ë €ë‹¤. 나는 ë‚´ 머리카ë½ì„ ì¥ì–´ëœ¯ì—ˆë‹¤. 나는 ìˆ˜ì—†ì´ ë°œì„ êµ´ë €ë‹¤. 나는 ì´ ë¬´ì„œìš´ ìœ í˜¹ì„ ì´ê¸°ë ¤ê³ ë‚´ ëª¸ì„ ì•„í”„ê²Œ 하였다. 나는 견디다 못하여 ë¬¸ì„ ë°•ì°¨ê³ ë›°ì–´ë‚˜ê°”ë‹¤. ë°–ì—는 ë‹¬ì´ ìžˆê³ ëˆˆì´ ìžˆì—ˆë‹¤. 그러나 ëˆˆì€ í•ë¹›ì´ìš”, ë‹¬ì€ ì°Œê·¸ëŸ¬ì§„ 것 같았다. 나는 눈 ì†ìœ¼ë¡œ 달ìŒë°•질쳤다. ë‹¬ì„ ë”°ë¼ì„œ 엎드러지며 ìžë¹ 지며 달ìŒì§ˆì³¤ë‹¤. 나는 소리를 ì§ˆë €ë‹¤. 나는 미친 사람 같았다."
+ê·¸ëŸ¬ê³ ëŠ” 어디까지 갔다가 ì–´ëŠ ë•Œì— ì–´ë– í•œ ì‹¬ê²½ì˜ ë³€í™”ë¥¼ 얻어 ê°€ì§€ê³ ëŒì•„왔다는 ë§ì€ ì“°ì´ì§€ 아니하였으나 최ì„ì˜ ë³‘ì˜ ì›ì¸ì„ 설명하는 것 같았다.
+"ì—´ì´ ë‚˜ê³ ê¸°ì¹¨ì´ ë‚œë‹¤. ê°€ìŠ´ì´ ì•„í”„ë‹¤. ì´ê²ƒì´ íë ´ì´ ë˜ì–´ì„œ í˜¼ìž ê¹¨ë—하게 ì´ ìƒëª…ì„ ë§ˆì¹˜ê²Œ 하여 주소서 í•˜ê³ ë¹ˆë‹¤. 나는 오늘부터 ë¨¹ê³ ë§ˆì‹œê¸°ë¥¼ ê·¸ì¹˜ë ¨ë‹¤."
+ì´ëŸ¬í•œ ë§ì„ ì¼ë‹¤. ê·¸ëŸ¬ê³ ëŠ”,
+"ì •ìž„, ì •ìž„, ì •ìž„, ì •ìž„."
+í•˜ê³ ì •ìž„ì˜ ì´ë¦„ì„ ìˆ˜ì—†ì´ ì“´ ê²ƒë„ ìžˆê³ , ì–´ë–¤ ë°ëŠ”,
+"Overcome, Overcome."
+í•˜ê³ ì˜ì–´ë¡œ ì“´ ê²ƒë„ ìžˆì—ˆë‹¤.
+ê·¸ë¦¬ê³ ë§ˆì§€ë§‰ì—,
+"나는 죽ìŒê³¼ 대면하였다. 사í˜ì§¸ êµ¶ê³ ì•“ì€ ì˜¤ëŠ˜ì— ë‚˜ëŠ” 극히 ë§‘ê³ ì¹¨ì°©í•œ ì •ì‹ ìœ¼ë¡œ 죽ìŒê³¼ 대면하였다. 죽ìŒì€ ê²€ì€ ì˜·ì„ ìž…ì—ˆìœ¼ë‚˜ ê·¸ 얼굴ì—는 ìžë¹„ì˜ í‘œì •ì´ ìžˆì—ˆë‹¤. 죽ìŒì€ ê³§ ê²€ì€ ì˜·ì„ ìž…ì€ êµ¬ì›ì˜ ì†ì´ì—ˆë‹¤. 죽ìŒì€ 아름다운 그림ìžì˜€ë‹¤. 죽ìŒì€ 반가운 ì• ì¸ì´ìš”, ê²°ì½” 무서운 ì›ìˆ˜ê°€ 아니었다. 나는 죽ìŒì˜ ì†ì„ 잡노ë¼. ê°ì‚¬í•˜ëŠ” 마ìŒìœ¼ë¡œ 죽ìŒì˜ í’ˆì— ì•ˆê¸°ë…¸ë¼. 아멘."
+ì´ê²ƒì„ ì“´ ë’¤ì—는 다시는 ì¼ê¸°ê°€ 없었다. ì´ê²ƒìœ¼ë¡œ 최ì„ì´ê°€ ê·¸ ë™ì•ˆ 지난 ì¼ì„ ì ì–´ë„ ì‹¬ë¦¬ì ë³€í™”ë§Œì€ ëŒ€ê°• ì¶”ì¸¡í• ìˆ˜ê°€ 있었다.
+다행히 최ì„ì˜ ë³‘ì€ ì ì ëŒë¦¬ëŠ” 듯하였다. ì—´ë„ ë‚´ë¦¬ê³ ì‹ì€ë•€ë„ ëœ í˜ë ¸ë‹¤. 안 ë¨¹ëŠ”ë‹¤ê³ ê³ ì§‘í•˜ë˜ ìŒì‹ë„ 먹기를 시작하였다.
+ì •ìž„ì—게로 ê°”ë˜ ë…¸íŒŒì—게서는 ì •ìž„ë„ ì—´ì´ ë‚´ë¦¬ê³ ì¼ì–´ë‚˜ ì•‰ì„ ë§Œí•˜ë‹¤ëŠ” 편지가 왔다.
+나는 ë…¸íŒŒì˜ íŽ¸ì§€ë¥¼ 최ì„ì—게 ì½ì–´ 주었다. 최ì„ì€ ê·¸ 편지를 ë“£ê³ ë§¤ìš° í¥ë¶„하는 모양ì´ì—ˆìœ¼ë‚˜ ê³§ 안심하는 ë¹›ì„ ë³´ì˜€ë‹¤.
+나는 최ì„ì˜ ë³‘ì´ ëŒë¦¬ëŠ” ê²ƒì„ ë³´ê³ ì •ìž„ì„ ì°¾ì•„ë³¼ 양으로 ë– ë‚˜ë ¤ 하였으나 순임ì´ê°€ 듣지 아니하였다. 혼ìžì„œ 앓는 아버지를 ë§¡ì•„ ê°€ì§€ê³ ìžˆì„ ìˆ˜ëŠ” 없다는 것ì´ì—ˆë‹¤. 그래서 노파가 오기를 기다리기로 하였다.
+나는 최ì„ì´ê°€ ë¨¹ì„ ìŒì‹ë„ ì‚´ 겸 우편êµì—ë„ ë“¤ë¥¼ 겸 시가까지 가기로 í•˜ê³ ì´ ê³³ 온 ì§€ ì¼ ì£¼ì¼ì´ë‚˜ 지나서 처ìŒìœ¼ë¡œ ì‚°ì—서 나왔다.
+나는 ì´ë¥´ì¿ ì¸ í¬ì— 가서 최ì„ì„ ìœ„í•˜ì—¬ 약품과 ë¨¹ì„ ê²ƒì„ ì‚¬ê³ ë˜ ìˆœìž„ì„ ìœ„í•´ì„œë„ ë¨¹ì„ ê²ƒê³¼ ì˜ë³µê³¼ ë˜ í•˜ëª¨ë‹ˆì¹´ì™€ ì†í’ê¸ˆë„ ì‚¬ ê°€ì§€ê³ ì •ê±°ìž¥ì— ë‚˜ì™€ì„œ ëŒì•„올 차를 ê¸°ë‹¤ë¦¬ê³ ìžˆì—ˆë‹¤.
+나는 순후해 ë³´ì´ëŠ” ì•„ë¼ì‚¬ ì‚¬ëžŒë“¤ì´ ì •ê±°ìž¥ì—서 오ë½ê°€ë½í•˜ëŠ” ê²ƒì„ ë³´ê³ ì†ìœ¼ë¡œëŠ” 최ì„ì´ê°€ ë³‘ì´ ì¢€ ë‚˜ì€ ê²ƒì„ ë‹¤í–‰ìœ¼ë¡œ ìƒê°í•˜ê³ , ë˜ ìµœì„ê³¼ ì •ìž„ì˜ ìž¥ëž˜ê°€ ì–´ì°Œ ë 까 하는 ê²ƒë„ ìƒê°í•˜ë©´ì„œ 뷔페(ì‹ë‹¹)ì—서 뜨거운 ì°¨ì´(ì°¨)를 ë§ˆì‹œê³ ìžˆì—ˆë‹¤.
+ì´ ë•Œì— ë°–ì„ ë°”ë¼ë³´ê³ ìžˆë˜ ë‚´ ëˆˆì€ ë¬¸ë“ ì´ìƒí•œ ê²ƒì„ ë³´ì•˜ë‹¤. ê·¸ê²ƒì€ ê·¸ 노파가 ì´ë¦¬ë¡œ í–¥í•˜ê³ ê±¸ì–´ì˜¤ëŠ” 것ì¸ë° ê·¸ 노파와 íŒ”ì„ ê±¸ì€ ì Šì€ ì—¬ìžê°€ 있는 것ì´ë‹¤. 머리를 ê²€ì€ ìˆ˜ê±´ìœ¼ë¡œ ì‹¸ë§¤ê³ ìž…ê³¼ 코를 ê°€ë¦¬ì› ìœ¼ë‹ˆ 분명히 알 수 없으나 í˜¹ì€ ì •ìž„ì´ë‚˜ 아닌가 í• ìˆ˜ë°–ì— ì—†ì—ˆë‹¤. ì •ìž„ì´ê°€ 몸만 기ë™í•˜ê²Œ ë˜ë©´ 최ì„ì„ ë³´ëŸ¬ 올 ê²ƒì€ ì •ìž„ì˜ ì—´ì •ì ì¸ ì„±ê²©ìœ¼ë¡œ 보아서 당연한 ì¼ì´ê¸° 때문ì´ì—ˆë‹¤.
+나는 반쯤 ë¨¹ë˜ ì°¨ë¥¼ ë†“ê³ ë·”íŽ˜ 밖으로 뛰어나갔다.
+"오 미시즈 체스터필드?"
+í•˜ê³ ë‚˜ëŠ” 노파 ì•žì— ì†ì„ 내어밀었다. 노파는 체스터필드ë¼ëŠ” ë¯¸êµ ë‚¨íŽ¸ì˜ ì„±ì„ ë”°ë¼ì„œ 부르는 ê²ƒì„ ê¸°ì–µí•˜ì˜€ë‹¤.
+"ì„ ìƒë‹˜!"
+하는 ê²ƒì€ ì •ìž„ì´ì—ˆë‹¤. ê·¸ ì†Œë¦¬ë§Œì€ ë³€ì¹˜ 아니하였다. 나는 ê²€ì€ ìž¥ê°‘ì„ ë‚€ ì •ìž„ì˜ ì†ì„ 잡았다. 나는 여러 ë§ ì•„ë‹ˆí•˜ê³ ë…¸íŒŒì™€ ì •ìž„ì„ ë·”íŽ˜ë¡œ ëŒê³ 들어왔다.
+ëŠ™ì€ ë·”íŽ˜ ë³´ì´ëŠ” 번ì©ë²ˆì©í•˜ëŠ” 사모바르ì—서 ì°¨ ë‘ ìž”ì„ ë”°ë¼ë‹¤ê°€ 노파와 ì •ìž„ì˜ ì•žì— ë†“ì•˜ë‹¤.
+노파는 ì–´ë¦°ì• ì—게 하는 모양으로 ì •ìž„ì˜ ìˆ˜ê±´ì„ ë²—ê²¨ 주었다. ê·¸ ì†ì—서는 해쓱하게 여윈 ì •ìž„ì˜ ì–¼êµ´ì´ ë‚˜ì™”ë‹¤. ë‘ ë³¼ì— ë¶ˆê·¸ë ˆí•˜ê²Œ í™í›ˆì´ ë„는 ê²ƒë„ ë³‘ 때문ì¸ê°€.
+"어때? ì‹ ì—´ì€ ì—†ë‚˜?"
+í•˜ê³ ë‚˜ëŠ” ì •ìž„ì—게 물었다.
+"괜찮아요."
+í•˜ê³ ì •ìž„ì€ ì›ƒìœ¼ë©°,
+"최 ì„ ìƒë‹˜ê»˜ì„œëŠ” ì–´ë– ì„¸ìš”?"
+í•˜ê³ ë¬»ëŠ”ë‹¤.
+"좀 ë‚˜ìœ¼ì‹ ëª¨ì–‘ì´ì•¼. 그래서 나는 오늘 ì •ìž„ì„ ì¢€ 보러 ê°€ë ¤ê³ í–ˆëŠ”ë° ì´ ì²´ìŠ¤í„°í•„ë“œ ë¶€ì¸ê»˜ì„œ 아니 오시면 순임ì´ê°€ í˜¼ìž ìžˆì„ ìˆ˜ê°€ ì—†ë‹¤ê³ í•´ì„œ, 그래 ì´ë ‡ê²Œ 최 ì„ ìƒ ìžì‹¤ ê²ƒì„ ì‚¬ ê°€ì§€ê³ ê°€ëŠ” 길ì´ì•¼."
+í•˜ê³ ë§ì„ í•˜ë©´ì„œë„ ë‚˜ëŠ” ì •ìž„ì˜ ëˆˆê³¼ ìž…ê³¼ 목ì—서 ê·¸ì˜ ë³‘ê³¼ 마ìŒì„ ì•Œì•„ë³´ë ¤ê³ ì• ë¥¼ ì¼ë‹¤.
+ì¤‘ë³‘ì„ ì•“ì€ ê¹ í•´ì„œëŠ” 한 달 ì „ 남대문서 ë³¼ 때보다 얼마 ë” ì´ˆì·Œí•œ 것 같지는 아니하였다.
+"네ì—."
+í•˜ê³ ì •ìž„ì€ ê³ ê°œë¥¼ 숙였다. ê·¸ì˜ ì•ˆê²½ì•Œì—는 ì´ìŠ¬ì´ ë§ºí˜”ë‹¤.
+"ì„ ìƒë‹˜ ëŒì€ 다 안녕하셔요?"
+"ì‘, ë‚´ê°€ ë– ë‚ ë•Œì—는 괜찮았어."
+"최 ì„ ìƒë‹˜ ëŒë„?"
+"ì‘."
+"ì„ ìƒë‹˜ í½ì€ ì• ë¥¼ 쓰셨어요."
+í•˜ê³ ì •ìž„ì€ ìš¸ìŒì¸ì§€ 웃ìŒì¸ì§€ 모를 웃ìŒì„ 웃는다.
+ë§ì„ 모르는 노파는 우리가 하는 ë§ì„ 눈치나 ì±„ë ¤ëŠ” ë“¯ì´ ë©€ê±°ë‹ˆ ë³´ê³ ìžˆë‹¤ê°€ 서투른 ì˜ì–´ë¡œ,
+"ì•„ì§ ë¯¸ìŠ¤ ë‚¨ì€ ì‹ ì—´ì´ ìžˆë‹µë‹ˆë‹¤. ê·¸ëž˜ë„ ê°€ ë³¸ë‹¤ê³ , ì£½ì–´ë„ ê°€ ë³¸ë‹¤ê³ ë‚´ ë§ì„ 안 ë“£ê³ ë”°ë¼ì™”지요."
+í•˜ê³ ì •ìž„ì—게 ì• ì • 있는 눈í˜ê¹€ì„ 주며,
+"ìœ ë…¸í‹° ì°¨ì¼ë“œ(ë§ì½ê¾¼ì´)."
+í•˜ê³ ìž…ì„ ì”°ë£©í•˜ë©° ì •ìž„ì„ ì•ˆê²½ 위로 본다.
+"니체워, 마뚜슈까(괜찮아요, 어머니)."
+í•˜ê³ ì •ìž„ì€ ë…¸íŒŒë¥¼ ë³´ê³ ì›ƒì—ˆë‹¤. ì •ìž„ì˜ ì„œì–‘ 사람ì—게 대한 í–‰ë™ì€ 서양ì‹ìœ¼ë¡œ ì§¸ì—ˆë‹¤ê³ ìƒê°í•˜ì˜€ë‹¤.
+ì •ìž„ì€ ë„리어 ìœ ì¾Œí•œ ë¹›ì„ ë³´ì˜€ë‹¤. 다만 ê·¸ì˜ ë¶‰ì€ë¹› ë¤ ëˆˆê³¼ 마른 ìž…ìˆ ì´ ê·¸ì˜ ëª¸ì— ì—´ì´ ìžˆìŒì„ 보였다. 나는 ê·¸ì˜ ì†ëê³¼ ë°œëì´ ì‹¸ëŠ˜í•˜ê²Œ ì–¼ì—ˆì„ ê²ƒì„ ìƒìƒí•˜ì˜€ë‹¤.
+마침 ì´ ë‚ ì€ ë‚ ì´ ì˜¨í™”í•˜ì˜€ë‹¤. ì—·ì€ í–‡ë¹›ë„ ì˜¤ëŠ˜ì€ ë‘꺼워진 듯하였다.
+우리 세 ì‚¬ëžŒì€ Fì—ì—서 ë‚´ë ¤ì„œ ì°ë§¤ 하나를 얻어 íƒ€ê³ ì‚°ìœ¼ë¡œ 향하였다. ì‚°ë„ ì•„ë‹ˆì§€ë§ˆëŠ” ì‚° 있는 나ë¼ì—서 ì‚´ë˜ ìš°ë¦¬ëŠ” 최ì„ì´ê°€ 사는 ê³³ì„ ì‚°ì´ë¼ê³ 부르는 ìŠµê´€ì„ ì§€ì—ˆë‹¤. ì‚¼ë¦¼ì´ ìžˆìœ¼ë‹ˆ ì‚°ê°™ì´ ìƒê°ëœ 까ë‹ì´ì—ˆë‹¤.
+노파가 오른편 ëì— ì•‰ê³ , 가운ë°ë‹¤ê°€ ì •ìž„ì„ ì•‰ížˆê³ ì™¼íŽ¸ ëì— ë‚´ê°€ 앉았다.
+쩟쩟쩟 하는 ì†Œë¦¬ì— ë§ì€ 달리기 시작하였다. 한 í•„ì€ í‚¤ í° ë§ì´ìš”, 한 í•„ì€ í‚¤ê°€ ìž‘ì€ ë§ì¸ë° 키 í° ë§ì€ 아마 ëŠ™ì€ êµ°ë§ˆ 퇴물ì¸ê°€ 싶게 허우대는 좋으나 ëª¸ì´ ì—¬ìœ„ê³ í„¸ì—는 ìœ¤ì´ ì—†ì—ˆë‹¤. 조금만 올ë¼ê°€ëŠ” ê¸¸ì´ ë˜ì–´ë„ ê³ ê°œë¥¼ 숙ì´ê³ ì• ë¥¼ ì¼ë‹¤. ìž‘ì€ ë§ì€ 까불어서 ê°€ë” ì±„ì°ìœ¼ë¡œ 얻어맞았다.
+"ì•„ì´ ì‚¼ë¦¼ì´ ì¢‹ì•„ìš”."
+í•˜ê³ ì •ìž„ì€ ì •ë§ ê¸°ìœ ë“¯ì´ ë‚˜ë¥¼ ëŒì•„보았다.
+"좋아?"
+í•˜ê³ ë‚˜ëŠ” ë©‹ì—†ì´ ëŒ€ê¾¸í•˜ê³ ë‚˜ì„œ, 후회ë˜ëŠ” 듯ì´,
+"밤낮 삼림 ì†ì—서만 사니까 지루한ë°."
+하는 ë§ì„ 붙였다.
+"ì €ëŠ” ì € 눈 있는 삼림 ì†ìœ¼ë¡œ í•œì • ì—†ì´ ê°€ê³ ì‹¶ì–´ìš”. 그러나 ì €ëŠ” ì¸ì œ ê¸°ìš´ì´ ì—†ìœ¼ë‹ˆê¹ ì›¬ê±¸ 그래 ë³´ê² ì–´ìš”?"
+í•˜ê³ í•œìˆ¨ì„ ì‰¬ì—ˆë‹¤.
+"왜 그런 소릴 í•´. ì¸ì œ 나ì„걸."
+í•˜ê³ ë‚˜ëŠ” ì •ìž„ì˜ ëˆˆì„ ë“¤ì—¬ë‹¤ë³´ì•˜ë‹¤. 마치 슬픈 눈물 방울ì´ë‚˜ ì°¾ìœ¼ë ¤ëŠ” 듯ì´.
+"ì œê°€ ì§€ê¸ˆë„ ì—´ì´ ì‚¼ì‹íŒ” ë„ê°€ 넘습니다. ì •ì‹ ì´ í릿해지는 ê²ƒì„ ë³´ë‹ˆê¹Œ 아마 ë” ì˜¬ë¼ê°€ë‚˜ ë´ìš”. ê·¸ëž˜ë„ ê´œì°®ì•„ìš”. 오늘 하루야 못 ì‚´ë¼ê³ ìš”. 오늘 하루만 ì‚´ë©´ 괜찮아요. 최 ì„ ìƒë‹˜ë§Œ 한 번 ëµ™ê³ ì£½ìœ¼ë©´ 괜찮아요."
+"왜 그런 소릴 해?"
+í•˜ê³ ë‚˜ëŠ” ì±…ë§í•˜ëŠ” ë“¯ì´ ì–¸ì„±ì„ ë†’ì˜€ë‹¤.
+ì •ìž„ì€ ê¸°ì¹¨ì„ ì‹œìž‘í•˜ì˜€ë‹¤. 한바탕 ê¸°ì¹¨ì„ í•˜ê³ ëŠ” ê¸°ìš´ì´ ì§„í•œ ë“¯ì´ ë…¸íŒŒì—게 기대며 ì¡°ì„ ë§ë¡œ,
+"추워요."
+하였다. ì´ ì—¬í–‰ì´ ì–´ë–»ê²Œ ì •ìž„ì˜ ë³‘ì— ì¢‹ì§€ ëª»í• ê²ƒì€ ì˜ì‚¬ê°€ 아닌 ë‚˜ë¡œë„ ì§ìž‘í• ìˆ˜ê°€ 있었다. 그러나 나로는 ë” ì–´ì°Œí• ìˆ˜ê°€ 없었다.
+나는 외투를 벗어서 ì •ìž„ì—게 입혀 ì£¼ê³ ë…¸íŒŒëŠ” ì •ìž„ì„ ì•ˆì•„ì„œ ëª¸ì´ ëœ í”들리ë„ë¡ ë˜ ì¶¥ì§€ 않ë„ë¡ í•˜ì˜€ë‹¤.
+나는 ì •ìž„ì˜ ëª¨ì–‘ì„ ì• ì²˜ë¡œì›Œì„œ 차마 ë³¼ 수가 없었다. 그러나 ì´ê²ƒì€ 하나님밖ì—는 ì–´ì°Œí• ë„리가 없는 ì¼ì´ì—ˆë‹¤.
+얼마를 지나서 ì •ìž„ì€ ê°‘ìžê¸° ê³ ê°œë¥¼ ë“¤ê³ ì¼ì–´ë‚˜ë©°,
+"ì¸ì œ ëª¸ì´ ì¢€ 녹았습니다. ì„ ìƒë‹˜ ì¶”ìš°ì‹œê² ì–´ìš”. ì´ ì™¸íˆ¬ 입으셔요."
+í•˜ê³ ê·¸ì˜ ìž…ë§Œ 웃는 웃ìŒì„ 웃었다.
+"난 춥지 않아. 어서 ìž…ê³ ìžˆì–´."
+í•˜ê³ ë‚˜ëŠ” ì •ìž„ì´ê°€ 외투를 벗는 ê²ƒì„ ë§‰ì•˜ë‹¤. ì •ìž„ì€ ë” ê³ ì§‘í•˜ë ¤ê³ ë„ ì•„ë‹ˆí•˜ê³ ,
+"ì„ ìƒë‹˜ ì‹œë² ë¦¬ì•„ì˜ ì‚¼ë¦¼ì€ ì°¸ 좋아요. 눈 ë®ì¸ ê²ƒì´ ë” ì¢‹ì€ ê²ƒ 같아요. ì €ëŠ” ì´ ì¸ì ì—†ê³ ìžìœ 로운 삼림 ì†ìœ¼ë¡œ 헤매어 ë³´ê³ ì‹¶ì–´ìš”."
+í•˜ê³ ì•„ê¹Œ í•˜ë˜ ê²ƒê³¼ ê°™ì€ ë§ì„ ë˜ í•˜ì˜€ë‹¤.
+"ë©°ì¹ ìž˜ ì •ì–‘í•˜ì—¬ì„œ, ë‚ ì´ë‚˜ ë”°ëœ»í•˜ê±°ë“ í•œ 번 산보나 í•´ ë³´ì§€."
+í•˜ê³ ë‚˜ëŠ” ì •ìž„ì˜ ë§ ëœ»ì´ ë‹¤ë¥¸ ë° ìžˆëŠ” ì¤„ì„ ì•Œë©´ì„œë„ ë¶€ëŸ¬ í‰ë²”하게 대답하였다.
+ì •ìž„ì€ ëŒ€ë‹µì´ ì—†ì—ˆë‹¤.
+"ì—¬ê¸°ì„œë„ ì•„ì§ ë©€ì–´ìš”?"
+í•˜ê³ ì •ìž„ì€ ëª¸ì´ í”들리는 ê²ƒì„ ì‹¬ížˆ 괴로워하는 모양으로 ë‘ ì†ì„ ìžë¦¬ì— ì§šì–´ ëª¸ì„ ë²„í‹°ë©´ì„œ ë§í•˜ì˜€ë‹¤.
+"ê³ ëŒ€ì•¼, 최 ì„ ìƒì´ ë°˜ê°€ì›Œí• í„°ì´ì§€. 오죽ì´ë‚˜ ë°˜ê°‘ê² ë‚˜."
+í•˜ê³ ë‚˜ëŠ” ì •ìž„ì„ ìœ„ë¡œí•˜ëŠ” 뜻으로 ë§í•˜ì˜€ë‹¤.
+"ì•„ì´ ì°¸ 미안해요. ì œê°€ 죄ì¸ì´ì•¼ìš”. ì € ë•Œë¬¸ì— ì• ë§¤í•œ ëˆ„ëª…ì„ ì“°ì‹œê³ ì €ë ‡ê²Œ ì‚¬ì—…ë„ ë²„ë¦¬ì‹œê³ ë³‘í™˜ê¹Œì§€ 나시니 ì €ëŠ” 어떡허면 ì´ ì£„ë¥¼ 씻습니까?"
+í•˜ê³ ëˆˆë¬¼ ê³ ì¸ ëˆˆìœ¼ë¡œ ì •ìž„ì€ ë‚˜ë¥¼ ì³ë‹¤ë³´ì•˜ë‹¤.
+나는 ì •ìž„ê³¼ 최ì„ì„ ì´ ìžìœ 로운 ì‹œë² ë¦¬ì•„ì˜ ì‚¼ë¦¼ ì†ì— ë‹¨ë‘˜ì´ ì‚´ê²Œ í•˜ê³ ì‹¶ì—ˆë‹¤. 그러나 최ì„ì€ ì‚´ì•„ë‚˜ê°€ê² ì§€ë§ˆëŠ” ì •ìž„ì´ê°€ ì‚´ì•„ë‚ ìˆ˜ê°€ 있ì„까, í•˜ê³ ë‚˜ëŠ” ì •ìž„ì˜ ì–´ê¹¨ë¥¼ ë°”ë¼ë³´ì•˜ë‹¤. ê·¸ì˜ ëª©ìˆ¨ì€ ì‹¤ë‚± ê°™ì€ ê²ƒ 같았다. 바람받ì´ì— ë†“ì¸ ë“±ìž”ë¶ˆê³¼ë§Œ ê°™ì€ ê²ƒ 같았다. ì´ ëª©ìˆ¨ì´ ëŠì–´ì§€ê¸° ì „ì— ì‚¬ëž‘í•˜ëŠ” ì´ì˜ ì–¼êµ´ì„ í•œ 번 ëŒ€í•˜ê² ë‹¤ëŠ” ê²ƒë°–ì— ì•„ë¬´ 소ì›ì´ 없는 ì •ìž„ì€ ì°¸ìœ¼ë¡œ 가엾어서 ê°€ìŠ´ì´ ë¯¸ì–´ì§€ëŠ” 것 같았다.
+"ì—¼ë ¤ ë§ì–´. 무슨 ê±±ì •ì´ì•¼? 최 ì„ ìƒë„ ë³‘ì´ ëŒë¦¬ê³ ì •ìž„ë„ ì¸ì œ 얼마 ì •ì–‘í•˜ë©´ ë‚˜ì„ ê²ƒ 아닌가. 아무 ì—¼ë ¤ ë§ì•„ìš”."
+í•˜ê³ ë‚˜ëŠ” ë”ìš± 최ì„ê³¼ ì •ìž„ê³¼ ë‘ ì‚¬ëžŒì˜ ì‚¬ëž‘ì„ ë‹¬í•˜ê²Œ í• ê²°ì‹¬ì„ í•˜ì˜€ë‹¤. 하나님께서 계시다면 ì´ ê°€ì—¾ì€ ê°„ì ˆí•œ ë‘ ì‚¬ëžŒì˜ ë§ˆìŒì„ 가슴 미어지게 아니 ìƒê°í• 리가 ì—†ë‹¤ê³ ìƒê°í•˜ì˜€ë‹¤. ìš°ì£¼ì˜ ëª¨ë“ ì¼ ì¤‘ì— ì •ìž„ì˜ ì •ê²½ë³´ë‹¤ ë” ìŠ¬í”„ê³ ë¶ˆìŒí•œ ì •ê²½ì´ ë˜ ìžˆì„까 하였다. 차디찬 눈으로 ë®ì¸ ì‹œë² ë¦¬ì•„ì˜ ê´‘ì•¼ì— ë³‘ë“ ì •ìž„ì˜ ì‚¬ëž‘ìœ¼ë¡œ 타는 불똥과 ê°™ì´ ë‚ ì•„ê°€ëŠ” ì´ ì •ê²½ì€ ì¸ìƒì´ 가질 수 있는 최대한 ë¹„ê·¹ì¸ ê²ƒ 같았다.
+ì •ìž„ì€ ì§€ì³ì„œ ê³ ê°œë¥¼ 숙ì´ê³ ìžˆë‹¤ê°€ë„ ê°€ë” ê³ ê°œë¥¼ 들어서는 기운 나는 ì–‘ì„ ë³´ì´ë ¤ê³ , ìœ ì¾Œí•œ ì–‘ì„ ë³´ì´ë ¤ê³ ì• ë¥¼ ì¼ë‹¤.
+"ì € 나무 보셔요. 오백 ë…„ì€ ì‚´ì•˜ê² ì§€ìš”?"
+ì´ëŸ° ë§ë„ 하였다. 그러나 ê·¸ê²ƒì€ ë‹¤ 억지로 지어서 하는 것ì´ì—ˆë‹¤. 그러다가는 ë˜ ê¸°ìš´ì´ ì§€ì³ì„œëŠ” ê³ ê°œë¥¼ 숙ì´ê³ , í˜¹ì€ ë…¸íŒŒì˜ ì–´ê¹¨ì— í˜¹ì€ ë‚´ ì–´ê¹¨ì— ì“°ëŸ¬ì¡Œë‹¤.
+마침내 우리가 í–¥í•˜ê³ ê°€ëŠ” ì›€ì§‘ì´ ë³´ì˜€ë‹¤.
+"ì •ìž„ì´, ì €ê¸°ì•¼."
+í•˜ê³ ë‚˜ëŠ” ì›€ì§‘ì„ ê°€ë¦¬ì¼°ë‹¤.
+"네�"
+í•˜ê³ ì •ìž„ì€ ë‚´ ì†ê°€ë½ 가는 ê³³ì„ ë³´ê³ ë‹¤ìŒì—는 ë‚´ ì–¼êµ´ì„ ë³´ì•˜ë‹¤. 잘 ë³´ì´ì§€ 않는 모양ì´ë‹¤.
+"ì €ê¸° ì €ê²ƒ ë§ì•¼. ì €ê¸° ì € ê³ ìž‘ í° ì „ë‚˜ë¬´ ë‘ ê°œê°€ 있지 않아? ê·¸ 사ì´ë¡œ ë³´ì´ëŠ” ì €, ì €ê±° ë§ì•¼. 옳지 옳지, ìˆœìž„ì´ ì§€ê¸ˆ 나오지 않아?"
+하였다.
+순임ì´ê°€ ë¬´ì—‡ì„ ê°€ì§€ëŸ¬ 나오는지 ë¬¸ì„ ì—´ê³ ë‚˜ì™€ì„œëŠ” ë°¥ ì§“ëŠë¼ê³ 지어 ë†“ì€ ì´ë¥¼í…Œë©´ 부엌ì—를 들어갔다가 나오는 ê¸¸ì— ì´ ìª½ì„ ë°”ë¼ë³´ë‹¤ê°€ 우리를 발견하였는지 몇 ê±¸ìŒ ë¹¨ë¦¬ 오다가는 서서 ë³´ê³ ì˜¤ë‹¤ê°€ëŠ” 서서 ë³´ë”니 ë‚´ê°€ 모ìžë¥¼ ë‚´ë‘르는 ê²ƒì„ ë³´ê³ ì•¼ 우리 ì¼í–‰ì¸ ê²ƒì„ í™•ì‹¤ížˆ ì•Œê³ ë‹¬ìŒë°•ì§ˆì„ ì³ì„œ 나온다.
+우리 ì°ë§¤ë¥¼ 만나ìž,
+"ì •ìž„ì´ì•¼? 어쩌면 ì´ ì¶”ìš´ë°."
+í•˜ê³ ìˆœìž„ì€ ì •ìž„ì„ ì•ˆê³ ê·¸ 안경으로 ì •ìž„ì˜ ëˆˆì„ ë“¤ì—¬ë‹¤ë³¸ë‹¤.
+"어쩌면 앓으면서 ì´ë ‡ê²Œ 와?"
+í•˜ê³ ìˆœìž„ì€ ë…¸íŒŒì™€ 나를 ì±…ë§í•˜ëŠ” ë“¯ì´ ëŒì•„보았다.
+"아버지 ì–´ë– ì‹œëƒ?"
+í•˜ê³ ë‚˜ëŠ” ì§ì„ ë“¤ê³ ì•žì„œì„œ 오면서 뒤따르는 순임ì—게 물었다.
+"아버지요?"
+í•˜ê³ ìˆœìž„ì€ ì–´ë¥¸ì—게 대한 ê²½ì˜ë¥¼ 표하노ë¼ê³ ë‚´ ê³ì— 와서 걸으며,
+"아버지께서 ì˜¤ëŠ˜ì€ ë§ì”€ì„ ë§Žì´ í•˜ì…¨ì–´ìš”. 순임ì´ê°€ ê³ ìƒí•˜ëŠ”êµ¬ë‚˜ ê³ ë§™ë‹¤, ì´ëŸ° ë§ì”€ë„ í•˜ì‹œê³ , 지금 같아서는 ì¼ì–´ë‚ ê²ƒë„ ê°™ì€ë° ê¸°ìš´ì´ ì—†ì–´ì„œ, ì´ëŸ° ë§ì”€ë„ í•˜ì‹œê³ , ë˜ ì„ ìƒë‹˜ì´ ì´ë¥´ì¿ ì¸ í¬ì—를 들어가셨으니 ë¬´ì—‡ì„ ì‚¬ 오실 듯싶으ëƒ, 알아맞혀 ë³´ì•„ë¼, ì´ëŸ° ë†ë‹´ë„ í•˜ì‹œê³ , ì •ìž„ì´ê°€ 어떤가 한 번 보았으면, ì´ëŸ° ë§ì”€ë„ í•˜ì‹œê² ì§€ìš”. ë˜ ìˆœìž„ì•„, ë‚´ê°€ 죽ë”ë¼ë„ ì •ìž„ì„ ë„¤ 친ë™ìƒìœ¼ë¡œ 알아서 부디 잘 사랑해 주어ë¼, ì •ìž„ì€ ë¶ˆìŒí•œ ì• ë‹¤, ì°¸ ì •ìž„ì€ ë¶ˆìŒí•´! ì´ëŸ° ë§ì”€ë„ í•˜ì‹œê² ì§€ìš”. ê·¸ë ‡ê²Œ 여러 가지 ë§ì”€ì„ ë§Žì´ í•˜ì‹œë”니, 순임아 ë‚´ê°€ ì£½ê±°ë“ ì„ ìƒë‹˜ì„ 아버지로 ì•Œê³ ê·¸ ì§€ë„를 받아ë¼, 그러시길래 ì œê°€ 아버지 안 ëŒì•„가셔요! 그랬ë”니 아버지께서 웃으시면서, 죽지 ë§ê¹Œ, í•˜ì‹œê³ ëŠ” 어째 ê°€ìŠ´ì´ ì¢€ ê±°ë¶í•œê°€, 하시ë”니 ìž ì´ ë“œì…¨ì–´ìš”. 한 시간ì´ë‚˜ ë˜ì—ˆì„까, 온."
+ì§‘ ì•žì— ê±°ì˜ ë‹¤ 가서는 ìˆœìž„ì€ ì •ìž„ì˜ íŒ”ì„ ê¼ˆë˜ ê²ƒì„ ë†“ê³ ë¹¨ë¦¬ 집으로 뛰어들어갔다.
+치마íì„ íŽ„ëŸê±°ë¦¬ê³ 뛰는 ì–‘ì—는 ì–´ë ¸ì„ ì ë§ê´„ëŸ‰ì´ ìˆœìž„ì˜ ëª¨ìŠµì´ ë‚¨ì•„ 있어서 나는 í˜¼ìž ì›ƒì—ˆë‹¤. ìˆœìž„ì€ ì •ìž„ì´ê°€ 왔다는 ê¸°ìœ ì†Œì‹ì„ 한 시ê°ì´ë¼ë„ 빨리 아버지께 ì „í•˜ê³ ì‹¶ì—ˆë˜ ê²ƒì´ë‹¤.
+"아버지, 주무시우? ì •ìž„ì´ê°€ 왔어요. ì •ìž„ì´ê°€ 왔습니다."
+í•˜ê³ ë¶€ë¥´ëŠ” 소리가 ë°–ì—ì„œë„ ë“¤ë ¸ë‹¤.
+ë‚˜ë„ ë°©ì— ë“¤ì–´ì„œê³ , ì •ìž„ë„ ë’¤ë”°ë¼ ë“¤ì–´ì„œê³ , 노파는 부엌으로 ë¬¼ê±´ì„ ë‘러 들어갔다.
+ë°©ì€ ì ˆë²½ê°™ì´ ì–´ë‘ì› ë‹¤.
+"순임아, ë¶ˆì„ ì¢€ ì¼œë ¤ë¬´ë‚˜."
+í•˜ê³ ìµœì„ì˜ ì–¼êµ´ì„ ì°¾ëŠë¼ê³ ëˆˆì„ í¬ê²Œ ëœ¨ê³ ê³ ê°œë¥¼ 숙ì´ë©°,
+"ìžë‚˜? ì •ìž„ì´ê°€ 왔네."
+í•˜ê³ ë¶ˆë €ë‹¤.
+ì •ìž„ë„ ê³ì— 와서 ì„ ë‹¤.
+최ì„ì€ ëŒ€ë‹µì´ ì—†ì—ˆë‹¤.
+순임ì´ê°€ ì´›ë¶ˆì„ ì¼œìž ìµœì„ì˜ ì–¼êµ´ì´ í™˜í•˜ê²Œ 보였다.
+"여보게, ì—¬ë´. ìžë‚˜?"
+í•˜ê³ ë‚˜ëŠ” 무서운 예ê°ì„ 가지면서 최ì„ì˜ ì–´ê¹¨ë¥¼ í”들었다.
+ê·¸ê²ƒì´ ë¬´ì—‡ì¸ì§€ 모르지마는 최ì„ì€ ì‹œì²´ë¼ í•˜ëŠ” ê²ƒì„ ë‚˜ëŠ” ë‚´ ì†ì„ 통해서 깨달았다.
+나는 ê¹œì§ ë†€ë¼ì„œ ì´ë¶ˆì„ ë²—ê¸°ê³ ìµœì„ì˜ íŒ”ì„ ìž¡ì•„ ë§¥ì„ ì§šì–´ 보았다. 거기는 ë§¥ì´ ì—†ì—ˆë‹¤.
+나는 최ì„ì˜ ìžë¦¬ì˜· ê°€ìŠ´ì„ í—¤ì¹˜ê³ ê·€ë¥¼ ê°€ìŠ´ì— ëŒ€ì—ˆë‹¤. ê·¸ ì‚´ì€ ì–¼ìŒê³¼ ê°™ì´ ì°¨ê³ ê·¸ ê°€ìŠ´ì€ ê³ ìš”í•˜ì˜€ë‹¤. ì‹¬ìž¥ì€ ë›°ê¸°ë¥¼ 그친 것ì´ì—ˆë‹¤.
+나는 최ì„ì˜ ê°€ìŠ´ì—서 귀를 ë–¼ê³ ì¼ì–´ì„œë©´ì„œ,
+"네 아버지는 ëŒì•„가셨다. 네 ì†ìœ¼ë¡œ 눈ì´ë‚˜ ê°ê²¨ ë“œë ¤ë¼."
+하였다. ë‚´ 눈ì—서는 ëˆˆë¬¼ì´ í˜ë €ë‹¤.
+"ì„ ìƒë‹˜!"
+í•˜ê³ ì •ìž„ì€ ì „ì—°ížˆ ì ˆì œí• íž˜ì„ ìžƒì–´ë²„ë¦° ë“¯ì´ ìµœì„ì˜ ê°€ìŠ´ì— ì—Žì–´ì¡Œë‹¤. ê·¸ëŸ¬ê³ ëŠ” 소리를 ë‚´ì–´ 울었다. 순임ì€,
+"아버지, 아버지!"
+í•˜ê³ ìµœì„ì˜ ë² ê°œ ê³ì— ì´ë§ˆë¥¼ ëŒ€ê³ ìš¸ì—ˆë‹¤.
+ì•„ë¼ì‚¬ ë…¸íŒŒë„ ìš¸ì—ˆë‹¤.
+ë°© 안ì—는 ì˜¤ì§ ìš¸ìŒ ì†Œë¦¬ë¿ì´ìš”, ë§ì´ 없었다. 최ì„ì€ ë²Œì¨ ì´ ìŠ¬í”ˆ ê´‘ê²½ë„ ëª°ë¼ë³´ëŠ” 사람ì´ì—ˆë‹¤.
+최ì„ì´ê°€ ìžê¸°ì˜ ì‹¸ì›€ì„ ì´ê¸°ê³ 죽었는지, ë˜ëŠ” ë까지 지다가 죽었는지 ê·¸ê²ƒì€ ì˜ì›í•œ 비밀ì´ì–´ì„œ 알 ë„리가 없었다. 그러나 ì´ê²ƒë§Œì€ 확실하다 ê·¸ì˜ ì˜ì‹ì´ 마지막으로 ë나는 ìˆœê°„ì— ê·¸ì˜ ì˜ì‹ê¸°ì— ë– ì˜¤ë¥´ë˜ ì˜¤ì§ í•˜ë‚˜ê°€ ì •ìž„ì´ì—ˆìœ¼ë¦¬ë¼ëŠ” 것만ì€.
+지금 ì •ìž„ì´ê°€ ê·¸ì˜ ê°€ìŠ´ì— ì—Žì–´ì ¸ 울지마는, ì •ìž„ì˜ ëœ¨ê±°ìš´ ëˆˆë¬¼ì´ ê·¸ì˜ ê°€ìŠ´ì„ ì 시건마는 최ì„ì˜ ê°€ìŠ´ì€ ë›¸ ì¤„ì„ ëª¨ë¥¸ë‹¤. ì´ê²ƒì´ 죽ìŒì´ëž€ 것ì´ë‹¤.
+ë’¤ì— ê²½ì°°ì˜ê°€ 와서 검사한 ê²°ê³¼ì— ì˜í•˜ë©´, 최ì„ì€ íë ´ìœ¼ë¡œ ì•“ë˜ ê²°ê³¼ë¡œ 심장마비를 ì¼ìœ¼í‚¨ 것ì´ë¼ê³ 하였다.
+나는 최ì„ì˜ ìž¥ë¡€ë¥¼ ëë‚´ê³ ìˆœìž„ê³¼ ì •ìž„ì„ ë°ë¦¬ê³ ì˜¤ë ¤ 하였으나 ì •ìž„ì€ ë“£ì§€ ì•„ë‹ˆí•˜ê³ ë…¸íŒŒì™€ ê°™ì´ ë°”ì´ì¹¼ 촌으로 ê°€ ë²„ë ¸ë‹¤.
+그런 뒤로는 ì •ìž„ì—게서는 ì¼ì²´ ìŒì‹ ì´ ì—†ë‹¤. 때때로 노파ì—게서 편지가 ì˜¤ëŠ”ë° ì •ìž„ì€ ìµœì„ì´ê°€ ìžˆë˜ ë°©ì— ê°€ë§Œížˆ ìžˆë‹¤ê³ ë§Œ 하였다.
+서투른 ì˜ì–´ê°€ ëœ»ì„ ì¶©ë¶„ížˆ 발표하지 못하는 것ì´ì—ˆë‹¤.
+나는 ì •ìž„ì—게 ì•ˆì‹¬í•˜ê³ ë³‘ì„ ì¹˜ë£Œí•˜ë¼ëŠ” íŽ¸ì§€ë„ í•˜ê³ ëˆì´ í•„ìš”í•˜ê±°ë“ ì²êµ¬í•˜ë¼ëŠ” íŽ¸ì§€ë„ í•˜ë‚˜ ì˜ ë‹µìž¥ì´ ì—†ë‹¤.
+ë§Œì¼ ì •ìž„ì´ê°€ 죽었다는 ê¸°ë³„ì´ ì˜¤ë©´ 나는 한 번 ë” ì‹œë² ë¦¬ì•„ì— ê°€ì„œ ë‘˜ì„ ê°€ì§€ëŸ°ížˆ ë¬»ê³ `ë‘ ë³„ 무ë¤'ì´ë¼ëŠ” 비를 세워 줄 ìƒê°ì´ë‹¤. 그러나 나는 ì •ìž„ì´ê°€ ì¡°ì„ ìœ¼ë¡œ 오기를 바란다.
+ì—¬ëŸ¬ë¶„ì€ ìµœì„ê³¼ ì •ìž„ì—게 대한 ì´ ê¸°ë¡ì„ ë¯¿ê³ ê·¸ ë‘ ì‚¬ëžŒì—게 대한 오해를 í’€ë¼.
+EOT;
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Address.php
new file mode 100644
index 000000000..5f446408c
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Address.php
@@ -0,0 +1,131 @@
+generator->parse($format);
+ }
+
+ public static function country()
+ {
+ return static::randomElement(static::$country);
+ }
+
+ public static function postcode()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$postcode)));
+ }
+
+ public static function regionSuffix()
+ {
+ return static::randomElement(static::$regionSuffix);
+ }
+
+ public static function region()
+ {
+ return static::randomElement(static::$region);
+ }
+
+ public static function citySuffix()
+ {
+ return static::randomElement(static::$citySuffix);
+ }
+
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ public static function streetSuffix()
+ {
+ return static::randomElement(static::$streetSuffix);
+ }
+
+ public static function street()
+ {
+ return static::randomElement(static::$street);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Company.php
new file mode 100644
index 000000000..4a110c2c4
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/Company.php
@@ -0,0 +1,15 @@
+generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ /**
+ * Return male last name
+ * @return string
+ * @example 'Vasiliauskas'
+ */
+ public function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ /**
+ * Return female last name
+ * @return string
+ * @example 'Žukauskaitė'
+ */
+ public function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+
+ /**
+ * Return driver license number
+ * @return string
+ * @example 12345678
+ */
+ public function driverLicence()
+ {
+ return $this->bothify("########");
+ }
+
+ /**
+ * Return passport number
+ * @return string
+ * @example 12345678
+ */
+ public function passportNumber()
+ {
+ return $this->bothify("########");
+ }
+
+ /**
+ * National Personal Identity number (asmens kodas)
+ * @link https://en.wikipedia.org/wiki/National_identification_number#Lithuania
+ * @link https://lt.wikipedia.org/wiki/Asmens_kodas
+ * @param string [male|female]
+ * @param \DateTime $birthdate
+ * @param string $randomNumber three integers
+ * @return string on format XXXXXXXXXXX
+ */
+ public function personalIdentityNumber($gender = 'male', \DateTime $birthdate = null, $randomNumber = '')
+ {
+ if (!$birthdate) {
+ $birthdate = \Faker\Provider\DateTime::dateTimeThisCentury();
+ }
+
+ $genderNumber = ($gender == 'male') ? 1 : 0;
+ $firstNumber = (int) floor($birthdate->format('Y') / 100) * 2 - 34 - $genderNumber;
+
+ $datePart = $birthdate->format('ymd');
+ $randomDigits = (string) ( ! $randomNumber || strlen($randomNumber) < 3) ? static::numerify('###') : substr($randomNumber, 0, 3);
+ $partOfPerosnalCode = $firstNumber . $datePart . $randomDigits;
+
+ $sum = self::calculateSum($partOfPerosnalCode, 1);
+ $liekana = $sum % 11;
+
+ if ($liekana !== 10) {
+ $lastNumber = $liekana;
+ return $firstNumber . $datePart . $randomDigits . $lastNumber;
+ }
+
+ $sum = self::calculateSum($partOfPerosnalCode, 2);
+ $liekana = $sum % 11;
+
+ $lastNumber = ($liekana !== 10) ? $liekana : 0;
+ return $firstNumber . $datePart . $randomDigits . $lastNumber;
+ }
+
+ /**
+ * Calculate the sum of personal code
+ * @link https://en.wikipedia.org/wiki/National_identification_number#Lithuania
+ * @link https://lt.wikipedia.org/wiki/Asmens_kodas
+ * @param string $numbers
+ * @param int $time [1|2]
+ * @return int
+ */
+ private static function calculateSum($numbers, $time = 1)
+ {
+ if ($time == 1) {
+ $multipliers = array(1, 2, 3, 4, 5, 6, 7, 8, 9, 1 );
+ } else {
+ $multipliers = array(3, 4, 5, 6, 7, 8, 9, 1, 2, 3 );
+ }
+
+ $sum = 0;
+ for ($i=1; $i <= 10; $i++) {
+ $sum += $numbers[$i-1] * $multipliers[$i-1];
+ }
+
+ return (int) $sum;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/PhoneNumber.php
new file mode 100644
index 000000000..752eb78b9
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/lt_LT/PhoneNumber.php
@@ -0,0 +1,17 @@
+generator->parse($format);
+ }
+
+ public static function country()
+ {
+ return static::randomElement(static::$country);
+ }
+
+ public static function postcode()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$postcode)));
+ }
+
+ public static function regionSuffix()
+ {
+ return static::randomElement(static::$regionSuffix);
+ }
+
+ public static function region()
+ {
+ return static::randomElement(static::$region);
+ }
+
+ public static function cityPrefix()
+ {
+ return static::randomElement(static::$cityPrefix);
+ }
+
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ public static function street()
+ {
+ return static::randomElement(static::$street);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/Color.php b/vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/Color.php
new file mode 100644
index 000000000..99e681b7a
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/Color.php
@@ -0,0 +1,19 @@
+format('dmy');
+ $randomDigits = (string) static::numerify('####');
+
+ $checksum = Luhn::computeCheckDigit($datePart . $randomDigits);
+
+ return $datePart . '-' . $randomDigits . $checksum;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/PhoneNumber.php
new file mode 100644
index 000000000..29c19f635
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/lv_LV/PhoneNumber.php
@@ -0,0 +1,15 @@
+ static::latitude(42.43, 42.45),
+ 'longitude' => static::longitude(19.16, 19.27)
+ );
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/me_ME/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/me_ME/Company.php
new file mode 100644
index 000000000..1f8031278
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/me_ME/Company.php
@@ -0,0 +1,49 @@
+generator->parse(static::$idNumberFormat));
+ }
+
+ /**
+ * @return string
+ * @example 'Ф'
+ */
+ public function alphabet()
+ {
+ return static::randomElement(static::$alphabet);
+ }
+
+ /**
+ * @return string
+ * @example 'Ð'
+ */
+ public function namePrefix()
+ {
+ return static::randomElement(static::$namePrefix);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/mn_MN/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/mn_MN/PhoneNumber.php
new file mode 100644
index 000000000..dd0bb4aba
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/mn_MN/PhoneNumber.php
@@ -0,0 +1,13 @@
+ Townships
+ * @link https://en.wikipedia.org/wiki/Template:Johor > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Kedah > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Kelantan > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Melaka > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Negeri_Sembilan > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Perak > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Penang > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Selangor > Townships
+ * @link https://en.wikipedia.org/wiki/Template:Terengganu > Townships
+ */
+ protected static $townshipPrefix = array(
+ 'Alam','Apartment','Ara',
+ 'Bandar','Bandar','Bandar','Bandar','Bandar','Bandar',
+ 'Bandar Bukit','Bandar Seri','Bandar Sri','Bandar Baru','Batu','Bukit',
+ 'Desa','Damansara',
+ 'Kampung','Kampung Baru','Kampung Baru','Kondominium','Kota',
+ 'Laman','Lembah',
+ 'Medan',
+ 'Pandan','Pangsapuri','Petaling','Puncak',
+ 'Seri','Sri',
+ 'Taman','Taman','Taman','Taman','Taman','Taman',
+ 'Taman Desa',
+ );
+ protected static $townshipSuffix = array(
+ 'Aman','Amanjaya','Anggerik','Angkasa','Antarabangsa','Awan',
+ 'Bahagia','Bangsar','Baru','Belakong','Bendahara','Bestari','Bintang','Brickfields',
+ 'Casa','Changkat','Country Heights',
+ 'Damansara','Damai','Dato Harun','Delima','Duta',
+ 'Flora',
+ 'Gembira','Genting',
+ 'Harmoni','Hartamas',
+ 'Impian','Indah','Intan',
+ 'Jasa','Jaya',
+ 'Keramat','Kerinchi','Kiara','Kinrara','Kuchai',
+ 'Laksamana',
+ 'Mahkota','Maluri','Manggis','Maxwell','Medan','Melawati','Menjalara','Meru','Mulia','Mutiara',
+ 'Pahlawan','Perdana','Pertama','Permai','Pelangi','Petaling','Pinang','Puchong','Puteri','Putra',
+ 'Rahman','Rahmat','Raya','Razak','Ria',
+ 'Saujana','Segambut','Selamat','Selatan','Semarak','Sentosa','Seputeh','Setapak','Setia Jaya','Sinar','Sungai Besi','Sungai Buaya','Sungai Long','Suria',
+ 'Tasik Puteri','Tengah','Timur','Tinggi','Tropika','Tun Hussein Onn','Tun Perak','Tunku',
+ 'Ulu','Utama','Utara',
+ 'Wangi',
+ );
+
+ /**
+ * @link https://en.wikipedia.org/wiki/Template:Greater_Kuala_Lumpur
+ * @link https://en.wikipedia.org/wiki/Template:Johor
+ * @link https://en.wikipedia.org/wiki/Template:Kedah
+ * @link https://en.wikipedia.org/wiki/Template:Kelantan
+ * @link https://en.wikipedia.org/wiki/Template:Labuan
+ * @link https://en.wikipedia.org/wiki/Template:Melaka
+ * @link https://en.wikipedia.org/wiki/Template:Negeri_Sembilan
+ * @link https://en.wikipedia.org/wiki/Template:Pahang
+ * @link https://en.wikipedia.org/wiki/Template:Perak
+ * @link https://en.wikipedia.org/wiki/Template:Perlis
+ * @link https://en.wikipedia.org/wiki/Template:Penang
+ * @link https://en.wikipedia.org/wiki/Template:Sabah
+ * @link https://en.wikipedia.org/wiki/Template:Sarawak
+ * @link https://en.wikipedia.org/wiki/Template:Selangor
+ * @link https://en.wikipedia.org/wiki/Template:Terengganu
+ */
+ protected static $towns = array(
+ 'johor' => array(
+ 'Ayer Hitam',
+ 'Batu Pahat','Bukit Gambir','Bukit Kepong','Bukit Naning',
+ 'Desaru',
+ 'Endau',
+ 'Gelang Patah','Gemas Baharu',
+ 'Iskandar Puteri',
+ 'Jementah','Johor Lama','Johor Bahru',
+ 'Kempas','Kluang','Kota Iskandar','Kota Tinggi','Kukup','Kulai',
+ 'Labis ','Larkin','Layang-Layang',
+ 'Mersing','Muar',
+ 'Pagoh','Paloh','Parit Jawa','Pasir Gudang','Pekan Nanas','Permas Jaya','Pontian Kechil',
+ 'Renggam',
+ 'Segamat','Senai','Simpang Renggam','Skudai','Sri Gading',
+ 'Tangkak','Tebrau',
+ 'Ulu Tiram',
+ 'Yong Peng',
+ ),
+ 'kedah' => array(
+ 'Alor Setar',
+ 'Baling','Bukit Kayu Hitam',
+ 'Changlun',
+ 'Durian Burung',
+ 'Gurun',
+ 'Jitra',
+ 'Kepala Batas','Kuah','Kuala Kedah','Kuala Ketil','Kulim',
+ 'Langgar','Lunas',
+ 'Merbok',
+ 'Padang Serai','Pendang',
+ 'Serdang','Sintok','Sungai Petani',
+ 'Tawar, Baling',
+ 'Yan',
+ ),
+ 'kelantan' => array(
+ 'Bachok','Bunut Payong',
+ 'Dabong',
+ 'Gua Musang',
+ 'Jeli',
+ 'Ketereh','Kota Bharu','Kuala Krai',
+ 'Lojing',
+ 'Machang',
+ 'Pasir Mas','Pasir Puteh',
+ 'Rantau Panjang',
+ 'Salor',
+ 'Tok Bali',
+ 'Wakaf Bharu','Wakaf Che Yeh',
+ ),
+ 'kl' => array(
+ 'Ampang',
+ 'Bandar Tasik Selatan','Bandar Tun Razak','Bangsar','Batu','Brickfields','Bukit Bintang','Bukit Jalil','Bukit Tunku',
+ 'Cheras','Chow Kit',
+ 'Damansara Town Centre','Dang Wangi','Desa Petaling','Desa Tun Hussein Onn',
+ 'Jinjang',
+ 'Kampung Baru','Kampung Kasipillay','Kampung Pandan','Kampung Sungai Penchala','Kepong','KLCC','Kuchai Lama',
+ 'Lake Gardens','Lembah Pantai',
+ 'Medan Tuanku','Mid Valley City','Mont Kiara',
+ 'Pantai Dalam','Pudu',
+ 'Salak South','Segambut','Semarak','Sentul','Setapak','Setiawangsa','Seputeh','Sri Hartamas','Sri Petaling','Sungai Besi',
+ 'Taman Desa','Taman Melawati','Taman OUG','Taman Tun Dr Ismail','Taman U-Thant','Taman Wahyu','Titiwangsa','Tun Razak Exchange',
+ 'Wangsa Maju',
+ ),
+ 'labuan' => array(
+ 'Batu Manikar',
+ 'Kiamsam',
+ 'Layang-Layang',
+ 'Rancha-Rancha'
+ ),
+ 'melaka' => array(
+ 'Alor Gajah',
+ 'Bandaraya Melaka','Batu Berendam','Bukit Beruang','Bukit Katil',
+ 'Cheng',
+ 'Durian Tunggal',
+ 'Hang Tuah Jaya',
+ 'Jasin',
+ 'Klebang',
+ 'Lubuk China',
+ 'Masjid Tanah',
+ 'Naning',
+ 'Pekan Asahan',
+ 'Ramuan China',
+ 'Simpang Ampat',
+ 'Tanjung Bidara','Telok Mas',
+ 'Umbai',
+ ),
+ 'nsembilan' => array(
+ 'Ayer Kuning','Ampangan',
+ 'Bahau','Batang Benar',
+ 'Chembong',
+ 'Dangi',
+ 'Gemas',
+ 'Juasseh',
+ 'Kuala Pilah',
+ 'Labu','Lenggeng','Linggi',
+ 'Mantin',
+ 'Nilai',
+ 'Pajam','Pedas','Pengkalan Kempas','Port Dickson',
+ 'Rantau','Rompin',
+ 'Senawang','Seremban','Sungai Gadut',
+ 'Tampin','Tiroi',
+ ),
+ 'pahang' => array(
+ 'Bandar Tun Razak','Bentong','Brinchang','Bukit Fraser','Bukit Tinggi',
+ 'Chendor',
+ 'Gambang','Genting Highlands','Genting Sempah',
+ 'Jerantut',
+ 'Karak','Kemayan','Kota Shahbandar','Kuala Lipis','Kuala Pahang','Kuala Rompin','Kuantan',
+ 'Lanchang','Lubuk Paku',
+ 'Maran','Mengkuang','Mentakab',
+ 'Nenasi',
+ 'Panching',
+ 'Pekan','Penor',
+ 'Raub',
+ 'Sebertak','Sungai Lembing',
+ 'Tanah Rata','Tanjung Sepat','Tasik Chini','Temerloh','Teriang','Tringkap',
+ ),
+ 'penang' => array(
+ 'Air Itam',
+ 'Balik Pulau','Batu Ferringhi','Batu Kawan','Bayan Lepas','Bukit Mertajam','Butterworth',
+ 'Gelugor','George Town',
+ 'Jelutong',
+ 'Kepala Batas',
+ 'Nibong Tebal',
+ 'Permatang Pauh','Pulau Tikus',
+ 'Simpang Ampat',
+ 'Tanjung Bungah','Tanjung Tokong',
+ ),
+ 'perak' => array(
+ 'Ayer Tawar',
+ 'Bagan Serai','Batu Gajah','Behrang','Bidor','Bukit Gantang','Bukit Merah',
+ 'Changkat Jering','Chemor','Chenderiang',
+ 'Damar Laut',
+ 'Gerik','Gopeng','Gua Tempurung',
+ 'Hutan Melintang',
+ 'Ipoh',
+ 'Jelapang',
+ 'Kamunting','Kampar','Kuala Kangsar',
+ 'Lekir','Lenggong','Lumut',
+ 'Malim Nawar','Manong','Menglembu',
+ 'Pantai Remis','Parit','Parit Buntar','Pasir Salak','Proton City',
+ 'Simpang Pulai','Sitiawan','Slim River','Sungai Siput','Sungkai',
+ 'Taiping','Tambun','Tanjung Malim','Tanjung Rambutan','Tapah','Teluk Intan',
+ 'Ulu Bernam',
+ ),
+ 'perlis' => array(
+ 'Arau',
+ 'Beseri',
+ 'Chuping',
+ 'Kaki Bukit','Kangar','Kuala Perlis',
+ 'Mata Ayer',
+ 'Padang Besar',
+ 'Sanglang','Simpang Empat',
+ 'Wang Kelian',
+ ),
+ 'putrajaya' => array(
+ 'Precinct 1','Precinct 4','Precinct 5',
+ 'Precinct 6','Precinct 8','Precinct 10',
+ 'Precinct 11','Precinct 12','Precinct 13',
+ 'Precinct 16','Precinct 18','Precinct 19',
+ ),
+ 'sabah' => array(
+ 'Beaufort','Bingkor',
+ 'Donggongon',
+ 'Inanam',
+ 'Kinabatangan','Kota Belud','Kota Kinabalu','Kuala Penyu','Kimanis','Kundasang',
+ 'Lahad Datu','Likas','Lok Kawi',
+ 'Manggatal',
+ 'Nabawan',
+ 'Papar','Pitas',
+ 'Ranau',
+ 'Sandakan','Sapulut','Semporna','Sepanggar',
+ 'Tambunan','Tanjung Aru','Tawau','Tenom','Tuaran',
+ 'Weston',
+ ),
+ 'sarawak' => array(
+ 'Asajaya',
+ 'Ba\'kelalan','Bario','Batu Kawa','Batu Niah','Betong','Bintulu',
+ 'Dalat','Daro',
+ 'Engkilili',
+ 'Julau',
+ 'Kapit','Kota Samarahan','Kuching',
+ 'Lawas','Limbang','Lubok Antu',
+ 'Marudi','Matu','Miri',
+ 'Oya',
+ 'Pakan',
+ 'Sadong Jaya','Sematan','Sibu','Siburan','Song','Sri Aman','Sungai Tujoh',
+ 'Tanjung Kidurong','Tanjung Manis','Tatau',
+ ),
+ 'selangor' => array(
+ 'Ampang','Assam Jawa',
+ 'Balakong','Bandar Baru Bangi','Bandar Baru Selayang','Bandar Sunway','Bangi','Banting','Batang Kali','Batu Caves','Bestari Jaya','Bukit Lanjan',
+ 'Cheras','Cyberjaya',
+ 'Damansara','Dengkil',
+ 'Ijok',
+ 'Jenjarom',
+ 'Kajang','Kelana Jaya','Klang','Kuala Kubu Bharu','Kuala Selangor','Kuang',
+ 'Lagong',
+ 'Morib',
+ 'Pandamaran','Paya Jaras','Petaling Jaya','Port Klang','Puchong',
+ 'Rasa','Rawang',
+ 'Salak Tinggi','Sekinchan','Selayang','Semenyih','Sepang','Serendah','Seri Kembangan','Shah Alam','Subang','Subang Jaya','Sungai Buloh',
+ 'Tanjung Karang','Tanjung Sepat',
+ 'Ulu Klang','Ulu Yam',
+ ),
+ 'terengganu' => array(
+ 'Ajil',
+ 'Bandar Ketengah Jaya','Bandar Permaisuri','Bukit Besi','Bukit Payong',
+ 'Chukai',
+ 'Jerteh',
+ 'Kampung Raja','Kerteh','Kijal','Kuala Besut','Kuala Berang','Kuala Dungun','Kuala Terengganu',
+ 'Marang','Merchang',
+ 'Pasir Raja',
+ 'Rantau Abang',
+ 'Teluk Kalung',
+ 'Wakaf Tapai',
+ )
+ );
+
+ /**
+ * @link https://en.wikipedia.org/wiki/States_and_federal_territories_of_Malaysia
+ */
+ protected static $states = array(
+ 'johor' => array(
+ 'Johor Darul Ta\'zim',
+ 'Johor'
+ ),
+ 'kedah' => array(
+ 'Kedah Darul Aman',
+ 'Kedah'
+ ),
+ 'kelantan' => array(
+ 'Kelantan Darul Naim',
+ 'Kelantan'
+ ),
+ 'kl' => array(
+ 'KL',
+ 'Kuala Lumpur',
+ 'WP Kuala Lumpur'
+ ),
+ 'labuan' => array(
+ 'Labuan'
+ ),
+ 'melaka' => array(
+ 'Malacca',
+ 'Melaka'
+ ),
+ 'nsembilan' => array(
+ 'Negeri Sembilan Darul Khusus',
+ 'Negeri Sembilan'
+ ),
+ 'pahang' => array(
+ 'Pahang Darul Makmur',
+ 'Pahang'
+ ),
+ 'penang' => array(
+ 'Penang',
+ 'Pulau Pinang'
+ ),
+ 'perak' => array(
+ 'Perak Darul Ridzuan',
+ 'Perak'
+ ),
+ 'perlis' => array(
+ 'Perlis Indera Kayangan',
+ 'Perlis'
+ ),
+ 'putrajaya' => array(
+ 'Putrajaya'
+ ),
+ 'sabah' => array(
+ 'Sabah'
+ ),
+ 'sarawak' => array(
+ 'Sarawak'
+ ),
+ 'selangor' => array(
+ 'Selangor Darul Ehsan',
+ 'Selangor'
+ ),
+ 'terengganu' => array(
+ 'Terengganu Darul Iman',
+ 'Terengganu'
+ )
+ );
+
+ /**
+ * @link https://ms.wikipedia.org/wiki/Senarai_negara_berdaulat
+ */
+ protected static $country = array(
+ 'Abkhazia','Afghanistan','Afrika Selatan','Republik Afrika Tengah','Akrotiri dan Dhekelia','Albania','Algeria','Amerika Syarikat','Andorra','Angola','Antigua dan Barbuda','Arab Saudi','Argentina','Armenia','Australia','Austria','Azerbaijan',
+ 'Bahamas','Bahrain','Bangladesh','Barbados','Belanda','Belarus','Belgium','Belize','Benin','Bhutan','Bolivia','Bonaire','Bosnia dan Herzegovina','Botswana','Brazil','Brunei Darussalam','Bulgaria','Burkina Faso','Burundi',
+ 'Cameroon','Chad','Chile','Republik Rakyat China','Republik China di Taiwan','Colombia','Comoros','Republik Demokratik Congo','Republik Congo','Kepulauan Cook','Costa Rica','Côte d\'Ivoire (Ivory Coast)','Croatia','Cuba','Curaçao','Cyprus','Republik Turki Cyprus Utara','Republik Czech',
+ 'Denmark','Djibouti','Dominika','Republik Dominika',
+ 'Ecuador','El Salvador','Emiriah Arab Bersatu','Eritrea','Estonia',
+ 'Kepulauan Faroe','Fiji','Filipina','Finland',
+ 'Gabon','Gambia','Georgia','Ghana','Grenada','Greece (Yunani)','Guatemala','Guinea','Guinea-Bissau','Guinea Khatulistiwa','Guiana Perancis','Guyana',
+ 'Habsyah (Etiopia)','Haiti','Honduras','Hungary',
+ 'Iceland','India','Indonesia','Iran','Iraq','Ireland','Israel','Itali',
+ 'Jamaika','Jepun','Jerman','Jordan',
+ 'Kanada','Kazakhstan','Kemboja','Kenya','Kiribati','Korea Selatan','Korea Utara','Kosovo','Kuwait','Kyrgyzstan',
+ 'Laos','Latvia','Lesotho','Liberia','Libya','Liechtenstein','Lithuania','Lubnan','Luxembourg',
+ 'Macedonia','Madagaskar','Maghribi','Malawi','Malaysia','Maldives','Mali','Malta','Kepulauan Marshall','Mauritania','Mauritius','Mesir','Mexico','Persekutuan Micronesia','Moldova','Monaco','Montenegro','Mongolia','Mozambique','Myanmar',
+ 'Namibia','Nauru','Nepal','New Zealand','Nicaragua','Niger','Nigeria','Niue','Norway',
+ 'Oman','Ossetia Selatan',
+ 'Pakistan','Palau','Palestin','Panama','Papua New Guinea','Paraguay','Perancis','Peru','Poland','Portugal',
+ 'Qatar',
+ 'Romania','Russia','Rwanda',
+ 'Sahara Barat','Saint Kitts dan Nevis','Saint Lucia','Saint Vincent dan Grenadines','Samoa','San Marino','São Tomé dan PrÃncipe','Scotland','Senegal','Sepanyol','Serbia','Seychelles','Sierra Leone','Singapura','Slovakia','Slovenia','Kepulauan Solomon','Somalia','Somaliland','Sri Lanka','Sudan','Sudan Selatan','Suriname','Swaziland','Sweden','Switzerland','Syria',
+ 'Tajikistan','Tanjung Verde','Tanzania','Thailand','Timor Leste','Togo','Tonga','Transnistria','Trinidad dan Tobago','Tunisia','Turki','Turkmenistan','Tuvalu',
+ 'Uganda','Ukraine','United Kingdom','Uruguay','Uzbekistan',
+ 'Vanuatu','Kota Vatican','Venezuela','Vietnam',
+ 'Yaman',
+ 'Zambia','Zimbabwe',
+ );
+
+ /**
+ * Return a building prefix
+ *
+ * @example 'No.'
+ *
+ * @return @string
+ */
+ public static function buildingPrefix()
+ {
+ return static::randomElement(static::$buildingPrefix);
+ }
+
+ /**
+ * Return a building number
+ *
+ * @example '123'
+ *
+ * @return @string
+ */
+ public static function buildingNumber()
+ {
+ return static::toUpper(static::lexify(static::numerify(static::randomElement(static::$buildingNumber))));
+ }
+
+ /**
+ * Return a street prefix
+ *
+ * @example 'Jalan'
+ */
+ public function streetPrefix()
+ {
+ $format = static::randomElement(static::$streetPrefix);
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * Return a complete streename
+ *
+ * @example 'Jalan Utama 7'
+ *
+ * @return @string
+ */
+ public function streetName()
+ {
+ $format = static::toUpper(static::lexify(static::numerify(static::randomElement(static::$streetNameFormats))));
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * Return a randown township
+ *
+ * @example Taman Bahagia
+ *
+ * @return @string
+ */
+ public function township()
+ {
+ $format = static::toUpper(static::lexify(static::numerify(static::randomElement(static::$townshipFormats))));
+
+ return $this->generator->parse($format);
+ }
+
+ /**
+ * Return a township prefix abbreviation
+ *
+ * @example 'USJ'
+ *
+ * @return @string
+ */
+ public function townshipPrefixAbbr()
+ {
+ return static::randomElement(static::$townshipPrefixAbbr);
+ }
+
+ /**
+ * Return a township prefix
+ *
+ * @example 'Taman'
+ *
+ * @return @string
+ */
+ public function townshipPrefix()
+ {
+ return static::randomElement(static::$townshipPrefix);
+ }
+
+ /**
+ * Return a township suffix
+ *
+ * @example 'Bahagia'
+ */
+ public function townshipSuffix()
+ {
+ return static::randomElement(static::$townshipSuffix);
+ }
+
+ /**
+ * Return a postcode based on state
+ *
+ * @example '55100'
+ * @link https://en.wikipedia.org/wiki/Postal_codes_in_Malaysia#States
+ *
+ * @param null|string $state 'state' or null
+ *
+ * @return @string
+ */
+ public static function postcode($state = null)
+ {
+ $format = array(
+ 'perlis' => array( // (01000 - 02800)
+ '0' . mt_rand(1000, 2800)
+ ),
+ 'kedah' => array( // (05000 - 09810)
+ '0' . mt_rand(5000, 9810)
+ ),
+ 'penang' => array( // (10000 - 14400)
+ mt_rand(10000, 14400)
+ ),
+ 'kelantan' => array( // (15000 - 18500)
+ mt_rand(15000, 18500)
+ ),
+ 'terengganu' => array( // (20000 - 24300)
+ mt_rand(20000, 24300)
+ ),
+ 'pahang' => array( // (25000 - 28800 | 39000 - 39200 | 49000, 69000)
+ mt_rand(25000, 28800),
+ mt_rand(39000, 39200),
+ mt_rand(49000, 69000)
+ ),
+ 'perak' => array( // (30000 - 36810)
+ mt_rand(30000, 36810)
+ ),
+ 'selangor' => array( // (40000 - 48300 | 63000 - 68100)
+ mt_rand(40000, 48300),
+ mt_rand(63000, 68100)
+ ),
+ 'kl' => array( // (50000 - 60000)
+ mt_rand(50000, 60000),
+ ),
+ 'putrajaya' => array( // (62000 - 62988)
+ mt_rand(62000, 62988)
+ ),
+ 'nsembilan' => array( // (70000 - 73509)
+ mt_rand(70000, 73509)
+ ),
+ 'melaka' => array( // (75000 - 78309)
+ mt_rand(75000, 78309)
+ ),
+ 'johor' => array( // (79000 - 86900)
+ mt_rand(79000, 86900)
+ ),
+ 'labuan' => array( // (87000 - 87033)
+ mt_rand(87000, 87033)
+ ),
+ 'sabah' => array( // (88000 - 91309)
+ mt_rand(88000, 91309)
+ ),
+ 'sarawak' => array( // (93000 - 98859)
+ mt_rand(93000, 98859)
+ )
+ );
+
+ $postcode = is_null($state) ? static::randomElement($format) : $format[$state];
+ return (string)static::randomElement($postcode);
+ }
+
+ /**
+ * Return the complete town address with matching postcode and state
+ *
+ * @example 55100 Bukit Bintang, Kuala Lumpur
+ *
+ * @return @string
+ */
+ public function townState()
+ {
+ $state = static::randomElement(array_keys(static::$states));
+ $postcode = static::postcode($state);
+ $town = static::randomElement(static::$towns[$state]);
+ $state = static::randomElement(static::$states[$state]);
+
+ return $postcode . ' ' . $town . ', ' . $state;
+ }
+
+ /**
+ * Return a random city (town)
+ *
+ * @example 'Ampang'
+ *
+ * @return @string
+ */
+ public function city()
+ {
+ $state = static::randomElement(array_keys(static::$towns));
+ return static::randomElement(static::$towns[$state]);
+ }
+
+ /**
+ * Return a random state
+ *
+ * @example 'Johor'
+ *
+ * @return @string
+ */
+ public function state()
+ {
+ $state = static::randomElement(array_keys(static::$states));
+ return static::randomElement(static::$states[$state]);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Company.php b/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Company.php
new file mode 100644
index 000000000..0e681330e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Company.php
@@ -0,0 +1,105 @@
+generator->parse($formats);
+ }
+
+ /**
+ * Return Peninsular prefix alphabet
+ *
+ * @example 'W'
+ *
+ * @return @string
+ */
+ public static function peninsularPrefix()
+ {
+ return static::randomElement(static::$peninsularPrefix);
+ }
+
+ /**
+ * Return Sarawak state prefix alphabet
+ *
+ * @example 'QA'
+ *
+ * @return @string
+ */
+ public static function sarawakPrefix()
+ {
+ return static::randomElement(static::$sarawakPrefix);
+ }
+
+ /**
+ * Return Sabah state prefix alphabet
+ *
+ * @example 'SA'
+ *
+ * @return @string
+ */
+ public static function sabahPrefix()
+ {
+ return static::randomElement(static::$sabahPrefix);
+ }
+
+ /**
+ * Return specialty licence plate prefix
+ *
+ * @example 'G1M'
+ *
+ * @return @string
+ */
+ public static function specialPrefix()
+ {
+ return static::randomElement(static::$specialPrefix);
+ }
+
+ /**
+ * Return a valid license plate alphabet
+ *
+ * @example 'A'
+ *
+ * @return @string
+ */
+ public static function validAlphabet()
+ {
+ return static::randomElement(static::$validAlphabets);
+ }
+
+ /**
+ * Return a valid number sequence between 1 and 9999
+ *
+ * @example '1234'
+ *
+ * @return @integer
+ */
+ public static function numberSequence()
+ {
+ return mt_rand(1, 9999);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Payment.php b/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Payment.php
new file mode 100644
index 000000000..4a46af163
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Payment.php
@@ -0,0 +1,244 @@
+generator->parse($formats);
+ }
+
+ /**
+ * Return a Malaysian Bank account number
+ *
+ * @example '1234567890123456'
+ *
+ * @return @string
+ */
+ public function bankAccountNumber()
+ {
+ $formats = static::randomElement(static::$bankAccountNumberFormats);
+
+ return static::numerify($formats);
+ }
+
+ /**
+ * Return a Malaysian Local Bank
+ *
+ * @example 'Public Bank'
+ *
+ * @return @string
+ */
+ public static function localBank()
+ {
+ return static::randomElement(static::$localBanks);
+ }
+
+ /**
+ * Return a Malaysian Foreign Bank
+ *
+ * @example 'Citibank Berhad'
+ *
+ * @return @string
+ */
+ public static function foreignBank()
+ {
+ return static::randomElement(static::$foreignBanks);
+ }
+
+ /**
+ * Return a Malaysian Government Bank
+ *
+ * @example 'Bank Simpanan Nasional'
+ *
+ * @return @string
+ */
+ public static function governmentBank()
+ {
+ return static::randomElement(static::$governmentBanks);
+ }
+
+ /**
+ * Return a Malaysian insurance company
+ *
+ * @example 'AIA Malaysia'
+ *
+ * @return @string
+ */
+ public static function insurance()
+ {
+ return static::randomElement(static::$insuranceCompanies);
+ }
+
+ /**
+ * Return a Malaysian Bank SWIFT Code
+ *
+ * @example 'MBBEMYKLXXX'
+ *
+ * @return @string
+ */
+ public static function swiftCode()
+ {
+ return static::toUpper(static::lexify(static::randomElement(static::$swiftCodes)));
+ }
+
+ /**
+ * Return the Malaysian currency symbol
+ *
+ * @example 'RM'
+ *
+ * @return @string
+ */
+ public static function currencySymbol()
+ {
+ return static::randomElement(static::$currencySymbol);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Person.php b/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Person.php
new file mode 100644
index 000000000..28d1092a4
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/Person.php
@@ -0,0 +1,813 @@
+generator->parse(static::randomElement($formats));
+ }
+
+ /**
+ * Return a Malaysian I.C. No.
+ *
+ * @example '890123-45-6789'
+ *
+ * @link https://en.wikipedia.org/wiki/Malaysian_identity_card#Structure_of_the_National_Registration_Identity_Card_Number_(NRIC)
+ *
+ * @param string|null $gender 'male', 'female' or null for any
+ * @param bool|string|null $hyphen true, false, or any separator characters
+ *
+ * @return string
+ */
+ public static function myKadNumber($gender = null, $hyphen = false)
+ {
+ // year of birth
+ $yy = mt_rand(0, 99);
+
+ // month of birth
+ $mm = DateTime::month();
+
+ // day of birth
+ $dd = DateTime::dayOfMonth();
+
+ // place of birth (1-59 except 17-20)
+ while (in_array($pb = mt_rand(1, 59), array(17, 18, 19, 20))) {
+ }
+
+ // random number
+ $nnn = mt_rand(0, 999);
+
+ // gender digit. Odd = MALE, Even = FEMALE
+ $g = mt_rand(0, 9);
+ //Credit: https://gist.github.com/mauris/3629548
+ if ($gender === static::GENDER_MALE) {
+ $g = $g | 1;
+ } elseif ($gender === static::GENDER_FEMALE) {
+ $g = $g & ~1;
+ }
+
+ // formatting with hyphen
+ if ($hyphen === true) {
+ $hyphen = "-";
+ } elseif ($hyphen === false) {
+ $hyphen = "";
+ }
+
+ return sprintf("%02d%02d%02d%s%02d%s%03d%01d", $yy, $mm, $dd, $hyphen, $pb, $hyphen, $nnn, $g);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/PhoneNumber.php
new file mode 100644
index 000000000..f89111d9d
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ms_MY/PhoneNumber.php
@@ -0,0 +1,217 @@
+generator->parse($format));
+ } else {
+ return static::numerify($this->generator->parse($format));
+ }
+ }
+
+ /**
+ * Return prefix digits for 011 numbers
+ *
+ * @example '10'
+ *
+ * @return string
+ */
+ public static function zeroOneOnePrefix()
+ {
+ return static::numerify(static::randomElement(static::$zeroOneOnePrefix));
+ }
+
+ /**
+ * Return prefix digits for 014 numbers
+ *
+ * @example '2'
+ *
+ * @return string
+ */
+ public static function zeroOneFourPrefix()
+ {
+ return static::numerify(static::randomElement(static::$zeroOneFourPrefix));
+ }
+
+ /**
+ * Return prefix digits for 015 numbers
+ *
+ * @example '1'
+ *
+ * @return string
+ */
+ public static function zeroOneFivePrefix()
+ {
+ return static::numerify(static::randomElement(static::$zeroOneFivePrefix));
+ }
+
+ /**
+ * Return a Malaysian Fixed Line Phone Number.
+ *
+ * @example '+603-4567-8912'
+ *
+ * @param bool $countryCodePrefix true, false
+ * @param bool $formatting true, false
+ *
+ * @return string
+ */
+ public function fixedLineNumber($countryCodePrefix = true, $formatting = true)
+ {
+ if ($formatting) {
+ $format = static::randomElement(static::$fixedLineNumberFormatsWithFormatting);
+ } else {
+ $format = static::randomElement(static::$fixedLineNumberFormats);
+ }
+
+ if ($countryCodePrefix) {
+ return static::countryCodePrefix($formatting) . static::numerify($this->generator->parse($format));
+ } else {
+ return static::numerify($this->generator->parse($format));
+ }
+ }
+
+ /**
+ * Return a Malaysian VoIP Phone Number.
+ *
+ * @example '+6015-678-9234'
+ *
+ * @param bool $countryCodePrefix true, false
+ * @param bool $formatting true, false
+ *
+ * @return string
+ */
+ public function voipNumber($countryCodePrefix = true, $formatting = true)
+ {
+ if ($formatting) {
+ $format = static::randomElement(static::$voipNumberWithFormatting);
+ } else {
+ $format = static::randomElement(static::$voipNumber);
+ }
+
+ if ($countryCodePrefix) {
+ return static::countryCodePrefix($formatting) . static::numerify($this->generator->parse($format));
+ } else {
+ return static::numerify($this->generator->parse($format));
+ }
+ }
+
+ /**
+ * Return a Malaysian Country Code Prefix.
+ *
+ * @example '+6'
+ *
+ * @param bool $formatting true, false
+ *
+ * @return string
+ */
+ public static function countryCodePrefix($formatting = true)
+ {
+ if ($formatting) {
+ return static::randomElement(static::$plusSymbol) . static::randomElement(static::$countryCodePrefix);
+ } else {
+ return static::randomElement(static::$countryCodePrefix);
+ }
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/Address.php
new file mode 100644
index 000000000..d1d8c9e41
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/Address.php
@@ -0,0 +1,195 @@
+format('dmy');
+
+ /**
+ * @todo These number should be random based on birth year
+ * @link http://no.wikipedia.org/wiki/F%C3%B8dselsnummer
+ */
+ $randomDigits = (string)static::numerify('##');
+
+ switch ($gender) {
+ case static::GENDER_MALE:
+ $genderDigit = static::randomElement(array(1,3,5,7,9));
+ break;
+ case static::GENDER_FEMALE:
+ $genderDigit = static::randomElement(array(0,2,4,6,8));
+ break;
+ default:
+ $genderDigit = (string)static::numerify('#');
+ }
+
+
+ $digits = $datePart.$randomDigits.$genderDigit;
+
+ /**
+ * @todo Calculate modulo 11 of $digits
+ * @link http://no.wikipedia.org/wiki/F%C3%B8dselsnummer
+ */
+ $checksum = (string)static::numerify('##');
+
+
+ return $digits.$checksum;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/PhoneNumber.php
new file mode 100644
index 000000000..c97e720af
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/nb_NO/PhoneNumber.php
@@ -0,0 +1,41 @@
+generator->parse($format));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ne_NP/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/ne_NP/Address.php
new file mode 100644
index 000000000..ee81af28e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ne_NP/Address.php
@@ -0,0 +1,129 @@
+format('ymd'));
+ $help = $date->format('Y') >= 2000 ? 2 : null;
+
+ $check = intval($help.$dob.$middle);
+ $rest = sprintf('%02d', 97 - ($check % 97));
+
+ return $dob.$middle.$rest;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/nl_BE/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/nl_BE/PhoneNumber.php
new file mode 100644
index 000000000..ac17f1b18
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/nl_BE/PhoneNumber.php
@@ -0,0 +1,20 @@
+generator->lastName;
+ break;
+ }
+
+ if (0 !== static::numberBetween(0, 1)) {
+ return $companyName . ' ' . static::randomElement(static::$companySuffix);
+ }
+
+ return $companyName;
+ }
+
+ /**
+ * Belasting Toegevoegde Waarde (BTW) = VAT
+ *
+ * @example 'NL123456789B01'
+ *
+ * @see http://www.belastingdienst.nl/wps/wcm/connect/bldcontentnl/belastingdienst/zakelijk/btw/administratie_bijhouden/btw_nummers_controleren/uw_btw_nummer
+ *
+ * @return string VAT Number
+ */
+ public static function vat()
+ {
+ return sprintf("%s%d%s%d", 'NL', self::randomNumber(9, true), 'B', self::randomNumber(2, true));
+ }
+
+ /**
+ * Alias dutch vat number format
+ *
+ * @return string
+ */
+ public static function btw()
+ {
+ return self::vat();
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/Internet.php
new file mode 100644
index 000000000..8203b3b85
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/Internet.php
@@ -0,0 +1,9 @@
+ 9) {
+ if ($nr[1] > 0) {
+ $nr[0] = 8;
+ $nr[1]--;
+ } else {
+ $nr[0] = 1;
+ $nr[1]++;
+ }
+ }
+ return implode('', array_reverse($nr));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/PhoneNumber.php
new file mode 100644
index 000000000..c27fe9b23
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/nl_NL/PhoneNumber.php
@@ -0,0 +1,39 @@
+ 'Narodowy Bank Polski',
+ '102' => 'Powszechna Kasa Oszczędności Bank Polski SA',
+ '103' => 'Bank Handlowy w Warszawie SA',
+ '105' => 'ING Bank ÅšlÄ…ski SA',
+ '106' => 'Bank BPH SA',
+ '109' => 'Bank Zachodni WBK SA',
+ '113' => 'Bank Gospodarstwa Krajowego',
+ '114' => 'mBank SA',
+ '116' => 'Bank Millennium SA',
+ '122' => 'Bank Handlowo-Kredytowy Spółka Akcyjna w Katowicach w likwidacji',
+ '124' => 'Bank Polska Kasa Opieki SA',
+ '128' => 'HSBC Bank Polska SA',
+ '132' => 'Bank Pocztowy SA',
+ '147' => 'Euro Bank SA',
+ '154' => 'Bank Ochrony Åšrodowiska SA',
+ '158' => 'Mercedes-Benz Bank Polska SA',
+ '161' => 'SGB-Bank SA',
+ '167' => 'RBS Bank (Polska) SA',
+ '168' => 'PLUS BANK SA',
+ '175' => 'Raiffeisen Bank Polska SA',
+ '184' => 'Societe Generale SA Oddział w Polsce',
+ '187' => 'Nest Bank S.A.',
+ '189' => 'Pekao Bank Hipoteczny SA',
+ '191' => 'Deutsche Bank Polska SA',
+ '193' => 'BANK POLSKIEJ SPÓÅDZIELCZOÅšCI SA',
+ '194' => 'Credit Agricole Bank Polska SA',
+ '195' => 'Idea Bank SA',
+ '203' => 'Bank BGÅ» BNP Paribas SA',
+ '212' => 'Santander Consumer Bank SA',
+ '213' => 'VOLKSWAGEN BANK POLSKA SA',
+ '214' => 'FCA-Group Bank Polska SA',
+ '215' => 'mBank Hipoteczny SA',
+ '216' => 'Toyota Bank Polska SA',
+ '219' => 'DNB Bank Polska SA',
+ '224' => 'Banque PSA Finance SA Oddział w Polsce',
+ '225' => 'Svenska Handelsbanken AB SA Oddział w Polsce',
+ '229' => 'BPI Bank Polskich Inwestycji SA',
+ '232' => 'Nykredit Realkredit A/S SA - Oddział w Polsce',
+ '235' => 'BNP PARIBAS SA Oddział w Polsce',
+ '236' => 'Danske Bank A/S SA Oddział w Polsce',
+ '237' => 'Skandinaviska Enskilda Banken AB (SA) - Oddział w Polsce',
+ '239' => 'CAIXABANK, S.A. (SPÓÅKA AKCYJNA)ODDZIAÅ W POLSCE',
+ '241' => 'Elavon Financial Services Designated Activity Company (spółka z o.o. o wyznaczonym przedmiocie działalności) Oddział w Polsce',
+ '243' => 'BNP Paribas Securities Services SKA Oddział w Polsce',
+ '247' => 'HAITONG BANK, S.A. Spółka Akcyjna Oddział w Polsce',
+ '248' => 'Getin Noble Bank SA',
+ '249' => 'Alior Bank SA',
+ '251' => 'Aareal Bank Aktiengesellschaft (Spółka Akcyjna) - Oddział w Polsce',
+ '254' => 'Citibank Europe plc (Publiczna Spółka Akcyjna) Oddział w Polsce',
+ '255' => 'Ikano Bank AB (publ) Spółka Akcyjna Oddział w Polsce',
+ '256' => 'Nordea Bank AB SA Oddział w Polsce',
+ '257' => 'UBS Limited (spółka z ograniczoną odpowiedzialnością) Oddział w Polsce',
+ '258' => 'J.P. Morgan Europe Limited Sp. z o.o. Oddział w Polsce',
+ '260' => 'Bank of China (Luxembourg) S.A. Spółka Akcyjna Oddział w Polsce',
+ '262' => 'Industrial and Commercial Bank of China (Europe) S.A. (Spółka Akcyjna) Oddział w Polsce',
+ '263' => 'Saxo Bank A/S Spółka Akcyjna Oddział w Polsce w likwidacji',
+ '264' => 'RCI Banque Spółka Akcyjna Oddział w Polsce',
+ '265' => 'EUROCLEAR Bank SA/NV (Spółka Akcyjna) - Oddział w Polsce',
+ '266' => 'Intesa Sanpaolo S.p.A. Spółka Akcyjna Oddział w Polsce',
+ '267' => 'Western Union International Bank GmbH, Sp. z o.o. Oddział w Polsce',
+ '269' => 'PKO Bank Hipoteczny SA',
+ '270' => 'TF BANK AB (Spółka z ograniczoną odpowiedzialnością) Oddział w Polsce',
+ '271' => 'FCE Bank Spółka Akcyjna Oddział w Polsce',
+ '272' => 'AS Inbank Spółka Akcyjna - Oddział w Polsce',
+ '273' => 'China Construction Bank (Europe) S.A. (Spółka Akcyjna) Oddział w Polsce',
+ '274' => 'MUFG Bank (Europe) N.V. S.A. Oddział w Polsce',
+ '275' => 'John Deere Bank S.A. Spółka Akcyjna Oddział w Polsce',
+ );
+
+ /**
+ * @example 'Euro Bank SA'
+ */
+ public static function bank()
+ {
+ return static::randomElement(static::$banks);
+ }
+
+ /**
+ * International Bank Account Number (IBAN)
+ * @link http://en.wikipedia.org/wiki/International_Bank_Account_Number
+ * @param string $prefix for generating bank account number of a specific bank
+ * @param string $countryCode ISO 3166-1 alpha-2 country code
+ * @param integer $length total length without country code and 2 check digits
+ * @return string
+ */
+ public static function bankAccountNumber($prefix = '', $countryCode = 'PL', $length = null)
+ {
+ return static::iban($countryCode, $prefix, $length);
+ }
+
+ protected static function addBankCodeChecksum($iban, $countryCode = 'PL')
+ {
+ if ($countryCode != 'PL' || strlen($iban) <= 8) {
+ return $iban;
+ }
+ $checksum = 0;
+ $weights = array(7, 1, 3, 9, 7, 1, 3);
+ for ($i = 0; $i < 7; $i++) {
+ $checksum += $weights[$i] * (int) $iban[$i];
+ }
+ $checksum = $checksum % 10;
+
+ return substr($iban, 0, 7) . $checksum . substr($iban, 8);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/Person.php b/vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/Person.php
new file mode 100644
index 000000000..380f4d9f7
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/Person.php
@@ -0,0 +1,227 @@
+generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+
+ public function title($gender = null)
+ {
+ return static::randomElement(static::$title);
+ }
+
+ /**
+ * replaced by specific unisex Polish title
+ */
+ public static function titleMale()
+ {
+ return static::title();
+ }
+
+ /**
+ * replaced by specific unisex Polish title
+ */
+ public static function titleFemale()
+ {
+ return static::title();
+ }
+
+ /**
+ * PESEL - Universal Electronic System for Registration of the Population
+ * @link http://en.wikipedia.org/wiki/PESEL
+ * @param DateTime $birthdate
+ * @param string $sex M for male or F for female
+ * @return string 11 digit number, like 44051401358
+ */
+ public static function pesel($birthdate = null, $sex = null)
+ {
+ if ($birthdate === null) {
+ $birthdate = \Faker\Provider\DateTime::dateTimeThisCentury();
+ }
+
+ $weights = array(1, 3, 7, 9, 1, 3, 7, 9, 1, 3);
+ $length = count($weights);
+
+ $fullYear = (int) $birthdate->format('Y');
+ $year = (int) $birthdate->format('y');
+ $month = $birthdate->format('m') + (((int) ($fullYear/100) - 14) % 5) * 20;
+ $day = $birthdate->format('d');
+
+ $result = array((int) ($year / 10), $year % 10, (int) ($month / 10), $month % 10, (int) ($day / 10), $day % 10);
+
+ for ($i = 6; $i < $length; $i++) {
+ $result[$i] = static::randomDigit();
+ }
+
+ $result[$length - 1] |= 1;
+ if ($sex == "F") {
+ $result[$length - 1] -= 1;
+ }
+
+ $checksum = 0;
+ for ($i = 0; $i < $length; $i++) {
+ $checksum += $weights[$i] * $result[$i];
+ }
+ $checksum = (10 - ($checksum % 10)) % 10;
+ $result[] = $checksum;
+
+ return implode('', $result);
+ }
+
+ /**
+ * National Identity Card number
+ * @link http://en.wikipedia.org/wiki/Polish_National_Identity_Card
+ * @return string 3 letters and 6 digits, like ABA300000
+ */
+ public static function personalIdentityNumber()
+ {
+ $range = str_split("ABCDEFGHIJKLMNPRSTUVWXYZ");
+ $low = array("A", static::randomElement($range), static::randomElement($range));
+ $high = array(static::randomDigit(), static::randomDigit(), static::randomDigit(), static::randomDigit(), static::randomDigit());
+ $weights = array(7, 3, 1, 7, 3, 1, 7, 3);
+ $checksum = 0;
+ for ($i = 0, $size = count($low); $i < $size; $i++) {
+ $checksum += $weights[$i] * (ord($low[$i]) - 55);
+ }
+ for ($i = 0, $size = count($high); $i < $size; $i++) {
+ $checksum += $weights[$i+3] * $high[$i];
+ }
+ $checksum %= 10;
+
+ return implode('', $low).$checksum.implode('', $high);
+ }
+
+ /**
+ * Taxpayer Identification Number (NIP in Polish)
+ * @link http://en.wikipedia.org/wiki/PESEL#Other_identifiers
+ * @link http://pl.wikipedia.org/wiki/NIP
+ * @return string 10 digit number
+ */
+ public static function taxpayerIdentificationNumber()
+ {
+ $weights = array(6, 5, 7, 2, 3, 4, 5, 6, 7);
+ $result = array();
+ do {
+ $result = array(
+ static::randomDigitNotNull(), static::randomDigitNotNull(), static::randomDigitNotNull(),
+ static::randomDigit(), static::randomDigit(), static::randomDigit(),
+ static::randomDigit(), static::randomDigit(), static::randomDigit(),
+ );
+ $checksum = 0;
+ for ($i = 0, $size = count($result); $i < $size; $i++) {
+ $checksum += $weights[$i] * $result[$i];
+ }
+ $checksum %= 11;
+ } while ($checksum == 10);
+ $result[] = $checksum;
+
+ return implode('', $result);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/PhoneNumber.php
new file mode 100644
index 000000000..65bc5c0e0
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/pl_PL/PhoneNumber.php
@@ -0,0 +1,18 @@
+
+
+ Prof. Hart will answer or forward your message.
+
+ We would prefer to send you information by email.
+
+
+ **The Legal Small Print**
+
+
+ (Three Pages)
+
+ ***START**THE SMALL PRINT!**FOR PUBLIC DOMAIN EBOOKS**START***
+ Why is this "Small Print!" statement here? You know: lawyers.
+ They tell us you might sue us if there is something wrong with
+ your copy of this eBook, even if you got it for free from
+ someone other than us, and even if what's wrong is not our
+ fault. So, among other things, this "Small Print!" statement
+ disclaims most of our liability to you. It also tells you how
+ you may distribute copies of this eBook if you want to.
+
+ *BEFORE!* YOU USE OR READ THIS EBOOK
+ By using or reading any part of this PROJECT GUTENBERG-tm
+ eBook, you indicate that you understand, agree to and accept
+ this "Small Print!" statement. If you do not, you can receive
+ a refund of the money (if any) you paid for this eBook by
+ sending a request within 30 days of receiving it to the person
+ you got it from. If you received this eBook on a physical
+ medium (such as a disk), you must return it with your request.
+
+ ABOUT PROJECT GUTENBERG-TM EBOOKS
+ This PROJECT GUTENBERG-tm eBook, like most PROJECT GUTENBERG-tm eBooks,
+ is a "public domain" work distributed by Professor Michael S. Hart
+ through the Project Gutenberg Association (the "Project").
+ Among other things, this means that no one owns a United States copyright
+ on or for this work, so the Project (and you!) can copy and
+ distribute it in the United States without permission and
+ without paying copyright royalties. Special rules, set forth
+ below, apply if you wish to copy and distribute this eBook
+ under the "PROJECT GUTENBERG" trademark.
+
+ Please do not use the "PROJECT GUTENBERG" trademark to market
+ any commercial products without permission.
+
+ To create these eBooks, the Project expends considerable
+ efforts to identify, transcribe and proofread public domain
+ works. Despite these efforts, the Project's eBooks and any
+ medium they may be on may contain "Defects". Among other
+ things, Defects may take the form of incomplete, inaccurate or
+ corrupt data, transcription errors, a copyright or other
+ intellectual property infringement, a defective or damaged
+ disk or other eBook medium, a computer virus, or computer
+ codes that damage or cannot be read by your equipment.
+
+ LIMITED WARRANTY; DISCLAIMER OF DAMAGES
+ But for the "Right of Replacement or Refund" described below,
+ [1] Michael Hart and the Foundation (and any other party you may
+ receive this eBook from as a PROJECT GUTENBERG-tm eBook) disclaims
+ all liability to you for damages, costs and expenses, including
+ legal fees, and [2] YOU HAVE NO REMEDIES FOR NEGLIGENCE OR
+ UNDER STRICT LIABILITY, OR FOR BREACH OF WARRANTY OR CONTRACT,
+ INCLUDING BUT NOT LIMITED TO INDIRECT, CONSEQUENTIAL, PUNITIVE
+ OR INCIDENTAL DAMAGES, EVEN IF YOU GIVE NOTICE OF THE
+ POSSIBILITY OF SUCH DAMAGES.
+
+ If you discover a Defect in this eBook within 90 days of
+ receiving it, you can receive a refund of the money (if any)
+ you paid for it by sending an explanatory note within that
+ time to the person you received it from. If you received it
+ on a physical medium, you must return it with your note, and
+ such person may choose to alternatively give you a replacement
+ copy. If you received it electronically, such person may
+ choose to alternatively give you a second opportunity to
+ receive it electronically.
+
+ THIS EBOOK IS OTHERWISE PROVIDED TO YOU "AS-IS". NO OTHER
+ WARRANTIES OF ANY KIND, EXPRESS OR IMPLIED, ARE MADE TO YOU AS
+ TO THE EBOOK OR ANY MEDIUM IT MAY BE ON, INCLUDING BUT NOT
+ LIMITED TO WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A
+ PARTICULAR PURPOSE.
+
+ Some states do not allow disclaimers of implied warranties or
+ the exclusion or limitation of consequential damages, so the
+ above disclaimers and exclusions may not apply to you, and you
+ may have other legal rights.
+
+ INDEMNITY
+ You will indemnify and hold Michael Hart, the Foundation,
+ and its trustees and agents, and any volunteers associated
+ with the production and distribution of Project Gutenberg-tm
+ texts harmless, from all liability, cost and expense, including
+ legal fees, that arise directly or indirectly from any of the
+ following that you do or cause: [1] distribution of this eBook,
+ [2] alteration, modification, or addition to the eBook,
+ or [3] any Defect.
+
+ DISTRIBUTION UNDER "PROJECT GUTENBERG-tm"
+ You may distribute copies of this eBook electronically, or by
+ disk, book or any other medium if you either delete this
+ "Small Print!" and all other references to Project Gutenberg,
+ or:
+
+ [1] Only give exact copies of it. Among other things, this
+ requires that you do not remove, alter or modify the
+ eBook or this "small print!" statement. You may however,
+ if you wish, distribute this eBook in machine readable
+ binary, compressed, mark-up, or proprietary form,
+ including any form resulting from conversion by word
+ processing or hypertext software, but only so long as
+ *EITHER*:
+
+ [*] The eBook, when displayed, is clearly readable, and
+ does *not* contain characters other than those
+ intended by the author of the work, although tilde
+ (~), asterisk (*) and underline (_) characters may
+ be used to convey punctuation intended by the
+ author, and additional characters may be used to
+ indicate hypertext links; OR
+
+ [*] The eBook may be readily converted by the reader at
+ no expense into plain ASCII, EBCDIC or equivalent
+ form by the program that displays the eBook (as is
+ the case, for instance, with most word processors);
+ OR
+
+ [*] You provide, or agree to also provide on request at
+ no additional cost, fee or expense, a copy of the
+ eBook in its original plain ASCII form (or in EBCDIC
+ or other equivalent proprietary form).
+
+ [2] Honor the eBook refund and replacement provisions of this
+ "Small Print!" statement.
+
+ [3] Pay a trademark license fee to the Foundation of 20% of the
+ gross profits you derive calculated using the method you
+ already use to calculate your applicable taxes. If you
+ don't derive profits, no royalty is due. Royalties are
+ payable to "Project Gutenberg Literary Archive Foundation"
+ the 60 days following each date you prepare (or were
+ legally required to prepare) your annual (or equivalent
+ periodic) tax return. Please contact us beforehand to
+ let us know your plans and to work out the details.
+
+ WHAT IF YOU *WANT* TO SEND MONEY EVEN IF YOU DON'T HAVE TO?
+ Project Gutenberg is dedicated to increasing the number of
+ public domain and licensed works that can be freely distributed
+ in machine readable form.
+
+ The Project gratefully accepts contributions of money, time,
+ public domain materials, or royalty free copyright licenses.
+ Money should be paid to the:
+ "Project Gutenberg Literary Archive Foundation."
+
+ If you are interested in contributing scanning equipment or
+ software or other items, please contact Michael Hart at:
+ hart@pobox.com
+
+ [Portions of this eBook's header and trailer may be reprinted only
+ when distributed free of all fees. Copyright (C) 2001, 2002 by
+ Michael S. Hart. Project Gutenberg is a TradeMark and may not be
+ used in any sales of Project Gutenberg eBooks or other materials be
+ they hardware or software or any other related product without
+ express permission.]
+
+ *END THE SMALL PRINT! FOR PUBLIC DOMAIN EBOOKS*Ver.02/11/02*END*
+
+ */
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Address.php
new file mode 100644
index 000000000..68b6df077
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Address.php
@@ -0,0 +1,154 @@
+generator->numerify('########0001');
+ $n .= check_digit($n);
+ $n .= check_digit($n);
+
+ return $formatted? vsprintf('%d%d.%d%d%d.%d%d%d/%d%d%d%d-%d%d', str_split($n)) : $n;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Internet.php
new file mode 100644
index 000000000..7481a6f5c
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Internet.php
@@ -0,0 +1,9 @@
+ array(
+ "4##############"
+ ),
+ 'MasterCard' => array(
+ "5##############"
+ ),
+ 'American Express' => array(
+ "34############",
+ "37############"
+ ),
+ 'Discover Card' => array(
+ "6011###########",
+ "622############",
+ "64#############",
+ "65#############"
+ ),
+ 'Diners' => array(
+ "301############",
+ "301##########",
+ "305############",
+ "305##########",
+ "36#############",
+ "36###########",
+ "38#############",
+ "38###########",
+ ),
+ 'Elo' => array(
+ "636368#########",
+ "438935#########",
+ "504175#########",
+ "451416#########",
+ "636297#########",
+ "5067###########",
+ "4576###########",
+ "4011###########",
+ ),
+ 'Hipercard' => array(
+ "38#############",
+ "60#############",
+ ),
+ "Aura" => array(
+ "50#############"
+ )
+ );
+
+ /**
+ * International Bank Account Number (IBAN)
+ * @link http://en.wikipedia.org/wiki/International_Bank_Account_Number
+ * @param string $prefix for generating bank account number of a specific bank
+ * @param string $countryCode ISO 3166-1 alpha-2 country code
+ * @param integer $length total length without country code and 2 check digits
+ * @return string
+ */
+ public static function bankAccountNumber($prefix = '', $countryCode = 'BR', $length = null)
+ {
+ return static::iban($countryCode, $prefix, $length);
+ }
+
+
+ /**
+ * @see list of Brazilians banks (2018-02-15), source: https://pt.wikipedia.org/wiki/Lista_de_bancos_do_Brasil
+ */
+ protected static $banks = array(
+ 'BADESUL Desenvolvimento S.A. – Agência de Fomento/RS',
+ 'Banco Central do Brasil',
+ 'Banco da Amazônia',
+ 'Banco de BrasÃlia',
+ 'Banco de Desenvolvimento de Minas Gerais',
+ 'Banco de Desenvolvimento do EspÃrito Santo',
+ 'Banco de Desenvolvimento do Paraná',
+ 'Banco do Brasil',
+ 'Banco do Estado de Sergipe Banese Estadual',
+ 'Banco do Estado do EspÃrito Santo Banestes',
+ 'Banco do Estado do Pará',
+ 'Banco do Estado do Rio Grande do Sul',
+ 'Banco do Nordeste do Brasil',
+ 'Banco Nacional de Desenvolvimento Econômico e Social',
+ 'Banco Regional de Desenvolvimento do Extremo Sul',
+ 'Caixa Econômica Federal',
+ 'Banco ABN Amro S.A.',
+ 'Banco Alfa',
+ 'Banco Banif',
+ 'Banco BBM',
+ 'Banco BMG',
+ 'Banco Bonsucesso',
+ 'Banco BTG Pactual',
+ 'Banco Cacique',
+ 'Banco Caixa Geral - Brasil',
+ 'Banco Citibank',
+ 'Banco Credibel',
+ 'Banco Credit Suisse',
+ 'Góis Monteiro & Co',
+ 'Banco Fator',
+ 'Banco Fibra',
+ 'Agibank',
+ 'Banco Guanabara',
+ 'Banco Industrial do Brasil',
+ 'Banco Industrial e Comercial',
+ 'Banco Indusval',
+ 'Banco Inter',
+ 'Banco Itaú BBA',
+ 'Banco ItaúBank',
+ 'Banco Itaucred Financiamentos',
+ 'Banco Mercantil do Brasil',
+ 'Banco Modal Modal',
+ 'Banco Morada',
+ 'Banco Pan',
+ 'Banco Paulista',
+ 'Banco Pine',
+ 'Banco Renner',
+ 'Banco Ribeirão Preto',
+ 'Banco Safra',
+ 'Banco Santander',
+ 'Banco Sofisa',
+ 'Banco Topázio',
+ 'Banco Votorantim',
+ 'Bradesco Bradesco',
+ 'Itaú Unibanco',
+ 'Banco Original',
+ 'Banco Neon',
+ 'Nu Pagamentos S.A',
+ 'XP Investimentos Corretora de Câmbio TÃtulos e Valores Mobiliários S.A',
+ );
+
+ /**
+ * @example 'Banco Neon'
+ */
+ public static function bank()
+ {
+ return static::randomElement(static::$banks);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Person.php b/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Person.php
new file mode 100644
index 000000000..be39a2e70
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/Person.php
@@ -0,0 +1,133 @@
+generator->numerify('#########');
+ $n .= check_digit($n);
+ $n .= check_digit($n);
+
+ return $formatted? vsprintf('%d%d%d.%d%d%d.%d%d%d-%d%d', str_split($n)) : $n;
+ }
+
+ /**
+ * A random RG number, following Sao Paulo state's rules.
+ * @link http://pt.wikipedia.org/wiki/C%C3%A9dula_de_identidade
+ * @param bool $formatted If the number should have dots/dashes or not.
+ * @return string
+ */
+ public function rg($formatted = true)
+ {
+ $n = $this->generator->numerify('########');
+ $n .= check_digit($n);
+
+ return $formatted? vsprintf('%d%d.%d%d%d.%d%d%d-%s', str_split($n)) : $n;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/PhoneNumber.php
new file mode 100644
index 000000000..4949eef39
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/PhoneNumber.php
@@ -0,0 +1,137 @@
+ ''));
+ }
+
+ return $number;
+ }
+
+ /**
+ * Generates an 9-digit landline number without formatting characters.
+ * @param bool $formatted [def: true] If it should return a formatted number or not.
+ * @return string
+ */
+ public static function landline($formatted = true)
+ {
+ $number = static::numerify(static::randomElement(static::$landlineFormats));
+
+ if (!$formatted) {
+ $number = strtr($number, array('-' => ''));
+ }
+
+ return $number;
+ }
+
+ /**
+ * Randomizes between cellphone and landline numbers.
+ * @param bool $formatted [def: true] If it should return a formatted number or not.
+ * @return mixed
+ */
+ public static function phone($formatted = true)
+ {
+ $options = static::randomElement(array(
+ array('cellphone', false),
+ array('cellphone', true),
+ array('landline', null),
+ ));
+
+ return call_user_func("static::{$options[0]}", $formatted, $options[1]);
+ }
+
+ /**
+ * Generates a complete phone number.
+ * @param string $type [def: landline] One of "landline" or "cellphone". Defaults to "landline" on invalid values.
+ * @param bool $formatted [def: true] If the number should be formatted or not.
+ * @return string
+ */
+ protected static function anyPhoneNumber($type, $formatted = true)
+ {
+ $area = static::areaCode();
+ $number = ($type == 'cellphone')?
+ static::cellphone($formatted) :
+ static::landline($formatted);
+
+ return $formatted? "($area) $number" : $area.$number;
+ }
+
+ /**
+ * Concatenates {@link areaCode} and {@link cellphone} into a national cellphone number.
+ * @param bool $formatted [def: true] If it should return a formatted number or not.
+ * @return string
+ */
+ public static function cellphoneNumber($formatted = true)
+ {
+ return static::anyPhoneNumber('cellphone', $formatted);
+ }
+
+ /**
+ * Concatenates {@link areaCode} and {@link landline} into a national landline number.
+ * @param bool $formatted [def: true] If it should return a formatted number or not.
+ * @return string
+ */
+ public static function landlineNumber($formatted = true)
+ {
+ return static::anyPhoneNumber('landline', $formatted);
+ }
+
+ /**
+ * Randomizes between complete cellphone and landline numbers.
+ * @return mixed
+ */
+ public function phoneNumber()
+ {
+ $method = static::randomElement(array('cellphoneNumber', 'landlineNumber'));
+ return call_user_func("static::$method", true);
+ }
+
+ /**
+ * Randomizes between complete cellphone and landline numbers, cleared from formatting symbols.
+ * @return mixed
+ */
+ public static function phoneNumberCleared()
+ {
+ $method = static::randomElement(array('cellphoneNumber', 'landlineNumber'));
+ return call_user_func("static::$method", false);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/check_digit.php b/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/check_digit.php
new file mode 100644
index 000000000..ab67db9df
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/pt_BR/check_digit.php
@@ -0,0 +1,35 @@
+= 12;
+ $verifier = 0;
+
+ for ($i = 1; $i <= $length; $i++) {
+ if (!$second_algorithm) {
+ $multiplier = $i+1;
+ } else {
+ $multiplier = ($i >= 9)? $i-7 : $i+1;
+ }
+ $verifier += $numbers[$length-$i] * $multiplier;
+ }
+
+ $verifier = 11 - ($verifier % 11);
+ if ($verifier >= 10) {
+ $verifier = 0;
+ }
+
+ return $verifier;
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/Address.php
new file mode 100644
index 000000000..d804ff2c6
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/Address.php
@@ -0,0 +1,124 @@
+ 0; $i--) {
+ $numbers[$i] = substr($number, $i - 1, 1);
+ $partial[$i] = $numbers[$i] * $factor;
+ $sum += $partial[$i];
+ if ($factor == $base) {
+ $factor = 1;
+ }
+ $factor++;
+ }
+ $res = $sum % 11;
+
+ if ($res == 0 || $res == 1) {
+ $digit = 0;
+ } else {
+ $digit = 11 - $res;
+ }
+
+ return $digit;
+ }
+
+ /**
+ *
+ * @link http://nomesportugueses.blogspot.pt/2012/01/lista-dos-cem-nomes-mais-usados-em.html
+ */
+
+ protected static $firstNameMale = array(
+ 'Rodrigo', 'João', 'Martim', 'Afonso', 'Tomás', 'Gonçalo', 'Francisco', 'Tiago',
+ 'Diogo', 'Guilherme', 'Pedro', 'Miguel', 'Rafael', 'Gabriel', 'Santiago', 'Dinis',
+ 'David', 'Duarte', 'José', 'Simão', 'Daniel', 'Lucas', 'Gustavo', 'André', 'Denis',
+ 'Salvador', 'António', 'Vasco', 'Henrique', 'Lourenço', 'Manuel', 'Eduardo', 'Bernardo',
+ 'Leandro', 'LuÃs', 'Diego', 'Leonardo', 'Alexandre', 'Rúben', 'Mateus', 'Ricardo',
+ 'Vicente', 'Filipe', 'Bruno', 'Nuno', 'Carlos', 'Rui', 'Hugo', 'Samuel', 'Ãlvaro',
+ 'Matias', 'Fábio', 'Ivo', 'Paulo', 'Jorge', 'Xavier', 'Marco', 'Isaac', 'Raúl','Benjamim',
+ 'Renato', 'Artur', 'Mário', 'Frederico', 'Cristiano', 'Ivan', 'Sérgio', 'Micael',
+ 'VÃtor', 'Edgar', 'Kevin', 'Joaquim', 'Igor', 'Ângelo', 'Enzo', 'Valentim', 'Flávio',
+ 'Joel', 'Fernando', 'Sebastião', 'Tomé', 'César', 'Cláudio', 'Nelson', 'Lisandro', 'Jaime',
+ 'Gil', 'Mauro', 'Sandro', 'Hélder', 'Matheus', 'William', 'Gaspar', 'Márcio',
+ 'Martinho', 'Emanuel', 'Marcos', 'Telmo', 'Davi', 'Wilson'
+ );
+
+ protected static $firstNameFemale = array(
+ 'Maria', 'Leonor', 'Matilde', 'Mariana', 'Ana', 'Beatriz', 'Inês', 'Lara', 'Carolina', 'Margarida',
+ 'Joana', 'Sofia', 'Diana', 'Francisca', 'Laura', 'Sara', 'Madalena', 'Rita', 'Mafalda', 'Catarina',
+ 'Luana', 'Marta', 'Ãris', 'Alice', 'Bianca', 'Constança', 'Gabriela', 'Eva', 'Clara', 'Bruna', 'Daniela',
+ 'Iara', 'Filipa', 'Vitória', 'Ariana', 'LetÃcia', 'Bárbara', 'Camila', 'Rafaela', 'Carlota', 'Yara',
+ 'Núria', 'Raquel', 'Ema', 'Helena', 'Benedita', 'Érica', 'Isabel', 'Nicole', 'Lia', 'AlÃcia', 'Mara',
+ 'Jéssica', 'Soraia', 'Júlia', 'Luna', 'Victória', 'LuÃsa', 'Teresa', 'Miriam', 'Adriana', 'Melissa',
+ 'Andreia', 'Juliana', 'Alexandra', 'Yasmin', 'Tatiana', 'Leticia', 'Luciana', 'Eduarda', 'Cláudia',
+ 'Débora', 'Fabiana', 'Renata', 'Kyara', 'Kelly', 'Irina', 'Mélanie', 'Nádia', 'Cristiana', 'Liliana',
+ 'PatrÃcia', 'Vera', 'Doriana', 'Ângela', 'Mia', 'Erica', 'Mónica', 'Isabela', 'Salomé', 'Cátia',
+ 'Verónica', 'Violeta', 'Lorena', 'Érika', 'Vanessa', 'Iris', 'Anna', 'Viviane', 'Rebeca', 'Neuza',
+ );
+
+ protected static $lastName = array(
+ 'Abreu', 'Almeida', 'Alves', 'Amaral', 'Amorim', 'Andrade', 'Anjos', 'Antunes', 'Araújo', 'Assunção',
+ 'Azevedo', 'Baptista', 'Barbosa', 'Barros', 'Batista', 'Borges', 'Branco', 'Brito', 'Campos', 'Cardoso',
+ 'Carneiro', 'Carvalho', 'Castro', 'Coelho', 'Correia', 'Costa', 'Cruz', 'Cunha', 'Domingues', 'Esteves',
+ 'Faria', 'Fernandes', 'Ferreira', 'Figueiredo', 'Fonseca', 'Freitas', 'Garcia', 'Gaspar', 'Gomes',
+ 'Gonçalves', 'Guerreiro', 'Henriques', 'Jesus', 'Leal', 'Leite', 'Lima', 'Lopes', 'Loureiro', 'Lourenço',
+ 'Macedo', 'Machado', 'Magalhães', 'Maia', 'Marques', 'Martins', 'Matias', 'Matos', 'Melo', 'Mendes',
+ 'Miranda', 'Monteiro', 'Morais', 'Moreira', 'Mota', 'Moura', 'Nascimento', 'Neto', 'Neves', 'Nogueira',
+ 'Nunes', 'Oliveira', 'Pacheco', 'Paiva', 'Pereira', 'Pinheiro', 'Pinho', 'Pinto', 'Pires', 'Ramos',
+ 'Reis', 'Ribeiro', 'Rocha', 'Rodrigues', 'Santos', 'Silva', 'Simões', 'Soares', 'Sousa',
+ 'Sá', 'Tavares', 'Teixeira', 'Torres', 'Valente', 'Vaz', 'Vicente', 'Vieira',
+ );
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/PhoneNumber.php
new file mode 100644
index 000000000..618a01c66
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/pt_PT/PhoneNumber.php
@@ -0,0 +1,50 @@
+generator->parse($format);
+ }
+
+ public function address()
+ {
+ $format = static::randomElement(static::$addressFormats);
+
+ return $this->generator->parse($format);
+ }
+
+ public function streetAddress()
+ {
+ $format = static::randomElement(static::$streetAddressFormats);
+
+ return $this->generator->parse($format);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ro_MD/Payment.php b/vendor/fzaninotto/faker/src/Faker/Provider/ro_MD/Payment.php
new file mode 100644
index 000000000..5fb9543f5
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ro_MD/Payment.php
@@ -0,0 +1,19 @@
+generator->parse($format);
+ }
+
+ /**
+ * @example 'Cluj'
+ */
+ public function county()
+ {
+ return static::randomElement(static::$counties);
+ }
+
+ public function address()
+ {
+ $format = static::randomElement(static::$addressFormats);
+
+ return $this->generator->parse($format);
+ }
+
+ public function streetAddress()
+ {
+ $format = static::randomElement(static::$streetAddressFormats);
+
+ return $this->generator->parse($format);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/Payment.php b/vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/Payment.php
new file mode 100644
index 000000000..980e8bb99
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/Payment.php
@@ -0,0 +1,19 @@
+ '01', 'AR' => '02', 'AG' => '03', 'B' => '40', 'BC' => '04', 'BH' => '05',
+ 'BN' => '06', 'BT' => '07', 'BV' => '08', 'BR' => '09', 'BZ' => '10', 'CS' => '11',
+ 'CL' => '51', 'CJ' => '12', 'CT' => '13', 'CV' => '14', 'DB' => '15', 'DJ' => '16',
+ 'GL' => '17', 'GR' => '52', 'GJ' => '18', 'HR' => '19', 'HD' => '20', 'IL' => '21',
+ 'IS' => '22', 'IF' => '23', 'MM' => '24', 'MH' => '25', 'MS' => '26', 'NT' => '27',
+ 'OT' => '28', 'PH' => '29', 'SM' => '30', 'SJ' => '31', 'SB' => '32', 'SV' => '33',
+ 'TR' => '34', 'TM' => '35', 'TL' => '36', 'VS' => '37', 'VL' => '38', 'VN' => '39',
+
+ 'B1' => '41', 'B2' => '42', 'B3' => '43', 'B4' => '44', 'B5' => '45', 'B6' => '46'
+ );
+
+ /**
+ * Personal Numerical Code (CNP)
+ *
+ * @link http://ro.wikipedia.org/wiki/Cod_numeric_personal
+ * @example 1111111111118
+ *
+ * @param null|string $gender Person::GENDER_MALE or Person::GENDER_FEMALE
+ * @param null|string $dateOfBirth (1800-2099) 'Y-m-d', 'Y-m', 'Y' I.E. '1981-06-16', '2085-03', '1900'
+ * @param null|string $county county code where the CNP was issued
+ * @param null|bool $isResident flag if the person resides in Romania
+ * @return string 13 digits CNP code
+ */
+ public function cnp($gender = null, $dateOfBirth = null, $county = null, $isResident = true)
+ {
+ $genders = array(Person::GENDER_MALE, Person::GENDER_FEMALE);
+ if (empty($gender)) {
+ $gender = static::randomElement($genders);
+ } elseif (!in_array($gender, $genders)) {
+ throw new \InvalidArgumentException("Gender must be '{Person::GENDER_MALE}' or '{Person::GENDER_FEMALE}'");
+ }
+
+ $date = $this->getDateOfBirth($dateOfBirth);
+
+ if (is_null($county)) {
+ $countyCode = static::randomElement(array_values(static::$cnpCountyCodes));
+ } elseif (!array_key_exists($county, static::$cnpCountyCodes)) {
+ throw new \InvalidArgumentException("Invalid county code '{$county}' received");
+ } else {
+ $countyCode = static::$cnpCountyCodes[$county];
+ }
+
+ $cnp = (string)$this->getGenderDigit($date, $gender, $isResident)
+ . $date->format('ymd')
+ . $countyCode
+ . static::numerify('##%')
+ ;
+
+ $checksum = $this->getChecksumDigit($cnp);
+
+ return $cnp.$checksum;
+ }
+
+ /**
+ * @param $dateOfBirth
+ * @return \DateTime
+ */
+ protected function getDateOfBirth($dateOfBirth)
+ {
+ if (empty($dateOfBirth)) {
+ $dateOfBirthParts = array(static::numberBetween(1800, 2099));
+ } else {
+ $dateOfBirthParts = explode('-', $dateOfBirth);
+ }
+ $baseDate = \Faker\Provider\DateTime::dateTimeBetween("first day of {$dateOfBirthParts[0]}", "last day of {$dateOfBirthParts[0]}");
+
+ switch (count($dateOfBirthParts)) {
+ case 1:
+ $dateOfBirthParts[] = $baseDate->format('m');
+ //don't break, we need the day also
+ case 2:
+ $dateOfBirthParts[] = $baseDate->format('d');
+ //don't break, next line will
+ case 3:
+ break;
+ default:
+ throw new \InvalidArgumentException("Invalid date of birth - must be null or in the 'Y-m-d', 'Y-m', 'Y' format");
+ }
+
+ if ($dateOfBirthParts[0] < 1800 || $dateOfBirthParts[0] > 2099) {
+ throw new \InvalidArgumentException("Invalid date of birth - year must be between 1900 and 2099, '{$dateOfBirthParts[0]}' received");
+ }
+
+ $dateOfBirthFinal = implode('-', $dateOfBirthParts);
+ $date = \DateTime::createFromFormat('Y-m-d', $dateOfBirthFinal);
+ //a full (invalid) date might have been supplied, check if it converts
+ if ($date->format('Y-m-d') !== $dateOfBirthFinal) {
+ throw new \InvalidArgumentException("Invalid date of birth - '{$date->format('Y-m-d')}' generated based on '{$dateOfBirth}' received");
+ }
+
+ return $date;
+ }
+
+ /**
+ *
+ * https://ro.wikipedia.org/wiki/Cod_numeric_personal#S
+ *
+ * @param \DateTime $dateOfBirth
+ * @param bool $isResident
+ * @param string $gender
+ * @return int
+ */
+ protected static function getGenderDigit(\DateTime $dateOfBirth, $gender, $isResident)
+ {
+ if (!$isResident) {
+ return 9;
+ }
+
+ if ($dateOfBirth->format('Y') < 1900) {
+ if ($gender == Person::GENDER_MALE) {
+ return 3;
+ }
+ return 4;
+ }
+
+ if ($dateOfBirth->format('Y') < 2000) {
+ if ($gender == Person::GENDER_MALE) {
+ return 1;
+ }
+ return 2;
+ }
+
+ if ($gender == Person::GENDER_MALE) {
+ return 5;
+ }
+ return 6;
+ }
+
+ /**
+ * Calculates a checksum for the Personal Numerical Code (CNP).
+ *
+ * @param string $value 12 digit CNP
+ * @return int checksum digit
+ */
+ protected function getChecksumDigit($value)
+ {
+ $checkNumber = 279146358279;
+
+ $checksum = 0;
+ foreach (range(0, 11) as $digit) {
+ $checksum += (int)substr($value, $digit, 1) * (int)substr($checkNumber, $digit, 1);
+ }
+ $checksum = $checksum % 11;
+
+ return $checksum == 10 ? 1 : $checksum;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/PhoneNumber.php
new file mode 100644
index 000000000..377e22455
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/PhoneNumber.php
@@ -0,0 +1,66 @@
+ array(
+ '021#######', // Bucharest
+ '023#######',
+ '024#######',
+ '025#######',
+ '026#######',
+ '027#######', // non-geographic
+ '031#######', // Bucharest
+ '033#######',
+ '034#######',
+ '035#######',
+ '036#######',
+ '037#######', // non-geographic
+ ),
+ 'mobile' => array(
+ '07########',
+ )
+ );
+
+ protected static $specialFormats = array(
+ 'toll-free' => array(
+ '0800######',
+ '0801######', // shared-cost numbers
+ '0802######', // personal numbering
+ '0806######', // virtual cards
+ '0807######', // pre-paid cards
+ '0870######', // internet dial-up
+ ),
+ 'premium-rate' => array(
+ '0900######',
+ '0903######', // financial information
+ '0906######', // adult entertainment
+ )
+ );
+
+ /**
+ * @link http://en.wikipedia.org/wiki/Telephone_numbers_in_Romania#Last_years
+ */
+ public function phoneNumber()
+ {
+ $type = static::randomElement(array_keys(static::$normalFormats));
+
+ return static::numerify(static::randomElement(static::$normalFormats[$type]));
+ }
+
+ public static function tollFreePhoneNumber()
+ {
+ $number = static::numerify(static::randomElement(static::$specialFormats['toll-free']));
+
+ return $number;
+ }
+
+ public static function premiumRatePhoneNumber()
+ {
+ $number = static::numerify(static::randomElement(static::$specialFormats['premium-rate']));
+
+ return $number;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/Text.php b/vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/Text.php
new file mode 100644
index 000000000..410c6f9b3
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ro_RO/Text.php
@@ -0,0 +1,154 @@
+generator->parse($format);
+ }
+
+ public static function country()
+ {
+ return static::randomElement(static::$country);
+ }
+
+ public static function postcode()
+ {
+ return static::toUpper(static::bothify(static::randomElement(static::$postcode)));
+ }
+
+ public static function regionSuffix()
+ {
+ return static::randomElement(static::$regionSuffix);
+ }
+
+ public static function region()
+ {
+ return static::randomElement(static::$region);
+ }
+
+ public static function cityPrefix()
+ {
+ return static::randomElement(static::$cityPrefix);
+ }
+
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+
+ public static function street()
+ {
+ return static::randomElement(static::$street);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Color.php b/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Color.php
new file mode 100644
index 000000000..e1af033f0
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Color.php
@@ -0,0 +1,23 @@
+generator->parse($format);
+ }
+
+ public static function companyPrefix()
+ {
+ return static::randomElement(static::$companyPrefixes);
+ }
+
+ public static function companyNameElement()
+ {
+ return static::randomElement(static::$companyElements);
+ }
+
+ public static function companyNameSuffix()
+ {
+ return static::randomElement(static::$companyNameSuffixes);
+ }
+
+ public static function inn($area_code = "")
+ {
+ if ($area_code === "" || intval($area_code) == 0) {
+ //Simple generation code for areas in Russian without check for valid
+ $area_code = static::numberBetween(1, 91);
+ } else {
+ $area_code = intval($area_code);
+ }
+ $area_code = str_pad($area_code, 2, '0', STR_PAD_LEFT);
+ $inn_base = $area_code . static::numerify('#######');
+ return $inn_base . \Faker\Calculator\Inn::checksum($inn_base);
+ }
+
+ public static function kpp($inn = "")
+ {
+ if ($inn == "" || strlen($inn) < 4) {
+ $inn = static::inn();
+ }
+ return substr($inn, 0, 4) . "01001";
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Internet.php
new file mode 100644
index 000000000..53870ee31
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Internet.php
@@ -0,0 +1,9 @@
+.*<' | \
+ * sed -r 's/—//' | sed -r 's/[\<\>]//g' | sed -r "s/(^|$)/'/g" | sed -r 's/$/,/' | sed -r 's/\&(laquo|raquo);/"/g' | \
+ * sed -r 's/\s+/ /g'"
+ */
+ protected static $banks = array(
+ 'Ðовый Промышленный Банк',
+ 'Ðовый Символ',
+ 'ÐокÑÑбанк',
+ 'ÐооÑфера',
+ 'Ðордеа Банк',
+ 'Ðота-Банк',
+ 'ÐС Банк',
+ 'ÐСТ-Банк',
+ 'ÐÑклиÑ-Банк',
+ 'Образование',
+ 'Объединенный Банк Промышленных ИнвеÑтиций',
+ 'Объединенный Банк РеÑпублики',
+ 'Объединенный Капитал',
+ 'Объединенный Кредитный Банк',
+ 'Объединенный Кредитный Банк МоÑковÑкий филиал',
+ 'Объединенный Ðациональный Банк',
+ 'Объединенный Резервный Банк',
+ 'Океан Банк',
+ 'ОЛМÐ-Банк',
+ 'Онего',
+ 'Оней Банк',
+ 'ОПМ-Банк',
+ 'Оргбанк',
+ 'Оренбург',
+ 'ОТП Банк',
+ 'ОФК Банк',
+ 'Охабанк',
+ 'Первобанк',
+ 'ПервомайÑкий',
+ 'ПервоуральÑкбанк',
+ 'Первый ДортранÑбанк',
+ 'Первый ИнвеÑтиционный банк',
+ 'Первый КлиентÑкий Банк',
+ 'Первый ЧешÑко-РоÑÑийÑкий Банк',
+ 'ПереÑвет',
+ 'Пермь',
+ 'ПетербургÑкий Социальный КоммерчеÑкий Банк',
+ 'Петрокоммерц',
+ 'ПИРБанк',
+ 'Платина',
+ 'Плато-Банк',
+ 'ÐŸÐ»ÑŽÑ Ð‘Ð°Ð½Ðº',
+ 'Пойдем!',
+ 'Почтобанк',
+ 'Прайм ФинанÑ',
+ 'Преодоление',
+ 'Приморье',
+ 'ПримÑоцбанк',
+ 'Примтеркомбанк',
+ 'Прио-Внешторгбанк',
+ 'Приобье',
+ 'ПриполÑрный',
+ 'ПриÑко Капитал Банк',
+ 'ПробизнеÑбанк',
+ 'ПроинвеÑтбанк',
+ 'Прокоммерцбанк',
+ 'ПроминвеÑтбанк',
+ 'Промрегионбанк',
+ 'ПромÑвÑзьбанк',
+ 'ПромÑвÑзьинвеÑтбанк',
+ 'ПромÑельхозбанк',
+ 'ПромтранÑбанк',
+ 'Промышленно-ФинанÑовое СотрудничеÑтво',
+ 'ПромÑнергобанк',
+ 'ПрофеÑÑионал Банк',
+ 'Профит Банк',
+ 'Прохладный',
+ 'ÐŸÑƒÐ»ÑŒÑ Ð¡Ñ‚Ð¾Ð»Ð¸Ñ†Ñ‹',
+ 'Радиотехбанк',
+ 'Развитие',
+ 'Развитие-Столица',
+ 'Райффайзенбанк',
+ 'РаÑчетно-Кредитный Банк',
+ 'РаÑчетный Дом',
+ 'РБÐ',
+ 'Региональный Банк РазвитиÑ',
+ 'Региональный Банк Сбережений',
+ 'Региональный КоммерчеÑкий Банк',
+ 'Региональный Кредит',
+ 'РегионфинанÑбанк',
+ 'Регнум',
+ 'Резерв',
+ 'РенеÑÑанÑ',
+ 'РенеÑÑÐ°Ð½Ñ ÐšÑ€ÐµÐ´Ð¸Ñ‚',
+ 'Рента-Банк',
+ 'РЕСО Кредит',
+ 'РеÑпубликанÑкий Кредитный ÐльÑнÑ',
+ 'РеÑурÑ-ТраÑÑ‚',
+ 'Риабанк',
+ 'Риал-Кредит',
+ 'РинвеÑтбанк',
+ 'РинвеÑтбанк МоÑковÑкий офиÑ',
+ 'РИТ-Банк',
+ 'РРБанк',
+ 'РоÑавтобанк',
+ 'РоÑбанк',
+ 'РоÑбизнеÑбанк',
+ 'РоÑгоÑÑтрах Банк',
+ 'РоÑдорбанк',
+ 'РоÑЕвроБанк',
+ 'РоÑинтерБанк',
+ 'РоÑпромбанк',
+ 'РоÑÑельхозбанк',
+ 'РоÑÑийÑÐºÐ°Ñ Ð¤Ð¸Ð½Ð°Ð½ÑÐ¾Ð²Ð°Ñ ÐšÐ¾Ñ€Ð¿Ð¾Ñ€Ð°Ñ†Ð¸Ñ',
+ 'РоÑÑийÑкий Капитал',
+ 'РоÑÑийÑкий Кредит',
+ 'РоÑÑийÑкий Ðациональный КоммерчеÑкий Банк',
+ 'РоÑÑита-Банк',
+ 'РоÑÑиÑ',
+ 'РоÑÑ‚ Банк',
+ 'РоÑтфинанÑ',
+ 'РоÑÑкÑимбанк',
+ 'РоÑÑнергобанк',
+ 'РоÑл Кредит Банк',
+ 'РСКБ',
+ 'РТС-Банк',
+ 'РУБанк',
+ 'Рублев',
+ 'Руна-Банк',
+ 'РунÑтбанк',
+ 'РуÑкобанк',
+ 'РуÑнарбанк',
+ 'РуÑÑкий Банк Сбережений',
+ 'РуÑÑкий Ипотечный Банк',
+ 'РуÑÑкий Международный Банк',
+ 'РуÑÑкий Ðациональный Банк',
+ 'РуÑÑкий Стандарт',
+ 'РуÑÑкий Торговый Банк',
+ 'РуÑÑкий ТраÑтовый Банк',
+ 'РуÑÑкий ФинанÑовый ÐльÑнÑ',
+ 'РуÑÑкий Ðлитарный Банк',
+ 'РуÑÑлавбанк',
+ 'РуÑÑобанк',
+ 'РуÑÑтройбанк',
+ 'РуÑÑ„Ð¸Ð½Ð°Ð½Ñ Ð‘Ð°Ð½Ðº',
+ 'РуÑÑŒ',
+ 'РуÑьРегионБанк',
+ 'РуÑьуниверÑалбанк',
+ 'РуÑЮгбанк',
+ 'РФИ Банк',
+ 'Саммит Банк',
+ 'Санкт-ПетербургÑкий Банк ИнвеÑтиций',
+ 'Саратов',
+ 'СаровбизнеÑбанк',
+ 'Сбербанк РоÑÑии',
+ 'СвÑзной Банк',
+ 'СвÑзь-Банк',
+ 'СДМ-Банк',
+ 'СеваÑтопольÑкий МорÑкой банк',
+ 'Северный Кредит',
+ 'Северный Ðародный Банк',
+ 'Северо-ВоÑточный ÐльÑнÑ',
+ 'Северо-Западный 1 ÐльÑÐ½Ñ Ð‘Ð°Ð½Ðº',
+ 'СеверÑтройбанк',
+ 'СевзапинвеÑтпромбанк',
+ 'Сельмашбанк',
+ 'СервиÑ-Резерв',
+ 'Сетелем Банк',
+ 'СИÐБ',
+ 'СибирÑкий Банк РеконÑтрукции и РазвитиÑ',
+ 'Сибнефтебанк',
+ 'СибÑоцбанк',
+ 'СибÑÑ',
+ 'СибÑÑ ÐœÐ¾ÑковÑкий офиÑ',
+ 'СинергиÑ',
+ 'Синко-Банк',
+ 'СиÑтема',
+ 'Сити ИнвеÑÑ‚ Банк',
+ 'Ситибанк',
+ 'СКÐ-Банк',
+ 'СКБ-Банк',
+ 'СлавиÑ',
+ 'СлавÑнбанк',
+ 'СлавÑнÑкий Кредит',
+ 'Смартбанк',
+ 'СМБ-Банк',
+ 'Смолевич',
+ 'СМП Банк',
+ 'СнежинÑкий',
+ 'Собинбанк',
+ 'Соверен Банк',
+ 'СоветÑкий',
+ 'Совкомбанк',
+ 'Современные Стандарты БизнеÑа',
+ 'СодружеÑтво',
+ 'СоколовÑкий',
+ 'Солид Банк',
+ 'СолидарноÑть (МоÑква)',
+ 'СолидарноÑть (Самара)',
+ 'СоцинвеÑтбанк',
+ 'СоцинвеÑтбанк МоÑковÑкий филиал',
+ 'Социум-Банк',
+ 'Союз',
+ 'Союзный',
+ 'СпецÑтройбанк',
+ 'Спиритбанк',
+ 'Спурт Банк',
+ 'Спутник',
+ 'СтавропольпромÑтройбанк',
+ 'Сталь Банк',
+ 'Стандарт-Кредит',
+ 'Стар ÐльÑнÑ',
+ 'СтарБанк',
+ 'СтарооÑкольÑкий Ðгропромбанк',
+ 'Старый Кремль',
+ 'Стелла-Банк',
+ 'Столичный Кредит',
+ 'СтратегиÑ',
+ 'Строительно-КоммерчеÑкий Банк',
+ 'СтройлеÑбанк',
+ 'Сумитомо Мицуи',
+ 'Сургутнефтегазбанк',
+ 'СÐБ Банк',
+ 'Таатта',
+ 'ТавричеÑкий',
+ 'Таганрогбанк',
+ 'Тагилбанк',
+ 'Тайдон',
+ 'Тайм Банк',
+ 'Тальменка-Банк',
+ 'Тальменка-Банк МоÑковÑкий филиал',
+ 'Тамбовкредитпромбанк',
+ 'Татагропромбанк',
+ 'ТатÑоцбанк',
+ 'Татфондбанк',
+ 'Ð¢Ð°ÑƒÑ€ÑƒÑ Ð‘Ð°Ð½Ðº',
+ 'ТверьУниверÑалБанк',
+ 'ТекÑбанк',
+ 'Темпбанк',
+ 'Тендер-Банк',
+ 'Терра',
+ 'ТетраполиÑ',
+ 'Тимер Банк',
+ 'Тинькофф Банк',
+ 'ТихоокеанÑкий Внешторгбанк',
+ 'Тойота Банк',
+ 'ТольÑттихимбанк',
+ 'ТомÑкпромÑтройбанк',
+ 'Торгово-Промышленный Банк КитаÑ',
+ 'Торговый ГородÑкой Банк',
+ 'ТоржокуниверÑалбанк',
+ 'ТранÑкапиталбанк',
+ 'ТранÑнациональный Банк',
+ 'ТранÑпортный',
+ 'ТранÑÑтройбанк',
+ 'ТраÑÑ‚ Капитал Банк',
+ 'Тройка-Д Банк',
+ 'ТульÑкий Промышленник',
+ 'ТульÑкий Промышленник МоÑковÑкий офиÑ',
+ 'ТульÑкий РаÑчетный Центр',
+ 'Турбобанк',
+ 'ТуÑар',
+ 'ТÐМБР-Банк',
+ 'ТÐСТ',
+ 'Углеметбанк',
+ 'Уздан',
+ 'Унифин',
+ 'Унифондбанк',
+ 'Уралкапиталбанк',
+ 'Уралприватбанк',
+ 'Уралпромбанк',
+ 'УралÑиб',
+ 'УралтранÑбанк',
+ 'УралфинанÑ',
+ 'УральÑкий Банк РеконÑтрукции и РазвитиÑ',
+ 'УральÑкий Межрегиональный Банк',
+ 'УральÑкий ФинанÑовый Дом',
+ 'Ури Банк',
+ 'УÑÑури',
+ 'ФДБ',
+ 'ФИÐ-Банк',
+ 'Финам Банк',
+ 'Ð¤Ð¸Ð½Ð°Ð½Ñ Ð‘Ð¸Ð·Ð½ÐµÑ Ð‘Ð°Ð½Ðº',
+ 'ФинанÑово-Промышленный Капитал',
+ 'ФинанÑовый Капитал',
+ 'ФинанÑовый Стандарт',
+ 'Ð¤Ð¸Ð½Ð°Ñ€Ñ Ð‘Ð°Ð½Ðº',
+ 'Финпромбанк (ФПБ Банк)',
+ 'ФинтраÑтбанк',
+ 'ФК Открытие (бывш. ÐОМОС-Банк)',
+ 'Флора-МоÑква',
+ 'ФолькÑваген Банк РуÑ',
+ 'ФондÑервиÑбанк',
+ 'Фора-Банк',
+ 'Форбанк',
+ 'Ð¤Ð¾Ñ€ÑƒÑ Ð‘Ð°Ð½Ðº',
+ 'Форштадт',
+ 'Фьючер',
+ 'ХакаÑÑкий Муниципальный Банк',
+ 'Ханты-МанÑийÑкий банк Открытие',
+ 'Химик',
+ 'Хлынов',
+ 'ХованÑкий',
+ 'ХолдинвеÑтбанк',
+ 'ХолмÑк',
+ 'Хоум Кредит Банк',
+ 'Центр-инвеÑÑ‚',
+ 'Центрально-ÐзиатÑкий',
+ 'Центрально-ЕвропейÑкий Банк',
+ 'Центркомбанк',
+ 'ЦентроКредит',
+ 'Церих',
+ 'Чайна КонÑтракшн',
+ 'ЧайнаÑельхозбанк',
+ 'Челиндбанк',
+ 'ЧелÑбинвеÑтбанк',
+ 'ЧерноморÑкий банк Ñ€Ð°Ð·Ð²Ð¸Ñ‚Ð¸Ñ Ð¸ реконÑтрукции',
+ 'Чувашкредитпромбанк',
+ 'Ðйч-ÐÑ-Би-Си Банк (HSBC)',
+ 'Ðко-ИнвеÑÑ‚',
+ 'Ðкономбанк',
+ 'ÐкономикÑ-Банк',
+ 'ÐкÑи-Банк',
+ 'ÐкÑперт Банк',
+ 'ÐкÑпобанк',
+ 'ÐкÑпреÑÑ-Волга',
+ 'ÐкÑпреÑÑ-Кредит',
+ 'Ðл Банк',
+ 'Ðлита',
+ 'Ðльбин',
+ 'Ðнергобанк',
+ 'Ðнергомашбанк',
+ 'ÐнерготранÑбанк',
+ 'Ðно',
+ 'ÐнтузиаÑтбанк',
+ 'Ðргобанк',
+ 'Ю Би ÐÑ Ð‘Ð°Ð½Ðº',
+ 'ЮГ-ИнвеÑтбанк',
+ 'Югра',
+ 'Южный Региональный Банк',
+ 'ЮМК',
+ 'ЮниаÑтрум Банк',
+ 'ЮниКредит Банк',
+ 'ЮниÑтрим',
+ 'Япы Креди Банк МоÑква',
+ 'ЯР-Банк',
+ 'Яринтербанк',
+ 'ЯроÑлавич',
+ 'K2 Банк',
+ 'ÐББ',
+ 'ÐбÑолют Банк',
+ 'Ðвангард',
+ 'ÐверÑ',
+ 'Ðвтоградбанк',
+ 'ÐвтоКредитБанк',
+ 'Ðвтоторгбанк',
+ 'Ðгроинкомбанк',
+ 'Ðгропромкредит',
+ 'ÐгророÑ',
+ 'ÐгроÑоюз',
+ 'Ðдамон Банк',
+ 'Ðдамон Банк МоÑковÑкий филиал',
+ 'Ðделантбанк',
+ 'ÐдмиралтейÑкий',
+ 'ÐзиатÑко-ТихоокеанÑкий Банк',
+ 'Ðзимут',
+ 'ÐÐ·Ð¸Ñ Ð‘Ð°Ð½Ðº',
+ 'ÐзиÑ-ИнвеÑÑ‚ Банк',
+ 'Ðй-Си-Ðй-Си-Ðй Банк (ICICI)',
+ 'Ðйви Банк',
+ 'ÐйМаниБанк',
+ 'Ðк БарÑ',
+ 'Ðкибанк',
+ 'Ðккобанк',
+ 'Ðкрополь',
+ 'ÐкÑонбанк',
+ 'Ðктив Банк',
+ 'ÐктивКапитал Банк',
+ 'ÐктивКапитал Банк МоÑковÑкий филиал',
+ 'ÐктивКапитал Банк Санкт-ПетербургÑкий филиал',
+ 'Ðкцент',
+ 'Ðкцепт',
+ 'ÐкциÑ',
+ 'Ðлданзолотобанк',
+ 'ÐлекÑандровÑкий',
+ 'Ðлеф-Банк',
+ 'Ðлжан',
+ 'ÐлмазÑргиÑнбанк',
+ 'ÐлтайБизнеÑ-Банк',
+ 'Ðлтайкапиталбанк',
+ 'Ðлтынбанк',
+ 'Ðльба ÐльÑнÑ',
+ 'Ðльта-Банк',
+ 'Ðльтернатива',
+ 'Ðльфа-Банк',
+ 'ÐМБ Банк',
+ 'ÐмерикÑн ÐкÑпреÑÑ Ð‘Ð°Ð½Ðº',
+ 'Ðнелик РУ',
+ 'Ðнкор Банк',
+ 'Ðнталбанк',
+ 'Ðпабанк',
+ 'ÐреÑбанк',
+ 'ÐрзамаÑ',
+ 'ÐркÑбанк',
+ 'ÐÑ€Ñенал',
+ 'ÐÑпект',
+ 'ÐÑÑоциациÑ',
+ 'БайкалБанк',
+ 'БайкалИнвеÑтБанк',
+ 'Байкалкредобанк',
+ 'Балаково-Банк',
+ 'БалтийÑкий Банк',
+ 'Балтика',
+ 'БалтинвеÑтбанк',
+ 'Банк "Ðкцент" МоÑковÑкий филиал',
+ 'Банк "МБÐ-МоÑква"',
+ 'Банк "Санкт-Петербург"',
+ 'Банк ÐВБ',
+ 'Банк БКФ',
+ 'Банк БФÐ',
+ 'Банк БЦК-МоÑква',
+ 'Банк Город',
+ 'Банк Жилищного ФинанÑированиÑ',
+ 'Банк Инноваций и РазвитиÑ',
+ 'Банк Интеза',
+ 'Банк ИТБ',
+ 'Банк Казани',
+ 'Банк ÐšÐ¸Ñ‚Ð°Ñ (ÐлоÑ)',
+ 'Банк Кредит СвиÑÑ',
+ 'Банк МБФИ',
+ 'Банк МоÑквы',
+ 'Банк на КраÑных Воротах',
+ 'Банк Оранжевый (бывш. ПромÑервиÑбанк)',
+ 'Банк оф Токио-МицубиÑи',
+ 'Банк Премьер Кредит',
+ 'Банк ÐŸÐ¡Ð Ð¤Ð¸Ð½Ð°Ð½Ñ Ð ÑƒÑ',
+ 'Банк Ð Ð°Ð·Ð²Ð¸Ñ‚Ð¸Ñ Ð¢ÐµÑ…Ð½Ð¾Ð»Ð¾Ð³Ð¸Ð¹',
+ 'Банк РаÑчетов и Сбережений',
+ 'Банк Раунд',
+ 'Банк РСИ',
+ 'Банк Сберегательно-кредитного ÑервиÑа',
+ 'Банк СГБ',
+ 'Банк Торгового ФинанÑированиÑ',
+ 'Банк ФинÑервиÑ',
+ 'Банк ÐкономичеÑкий Союз',
+ 'БанкирÑкий Дом',
+ 'Ð‘Ð°Ð½ÐºÑ…Ð°ÑƒÑ Ðрбе',
+ 'БашкомÑнаббанк',
+ 'Башпромбанк',
+ 'ББРБанк',
+ 'БелгородÑоцбанк',
+ 'Бенифит-Банк',
+ 'Берейт',
+ 'БеÑÑ‚ ÐÑ„Ñ„Ð¾Ñ€Ñ‚Ñ Ð‘Ð°Ð½Ðº',
+ 'Ð‘Ð¸Ð·Ð½ÐµÑ Ð´Ð»Ñ Ð‘Ð¸Ð·Ð½ÐµÑа',
+ 'Бинбанк',
+ 'БИÐБÐÐК кредитные карты',
+ 'Бинбанк МурманÑк',
+ 'БКС ИнвеÑтиционный Банк',
+ 'БМВ Банк',
+ 'БÐП Париба Банк',
+ 'БогородÑкий',
+ 'БогородÑкий Муниципальный Банк',
+ 'БратÑкий ÐÐКБ',
+ 'БСТ-Банк',
+ 'Булгар Банк',
+ 'Бум-Банк',
+ 'Бумеранг',
+ 'БФГ-Кредит',
+ 'БыÑтроБанк',
+ 'Вакобанк',
+ 'Вега-Банк',
+ 'Век',
+ 'Великие Луки Банк',
+ 'Венец',
+ 'ВерхневолжÑкий',
+ 'ВерхневолжÑкий КрымÑкий филиал',
+ 'ВерхневолжÑкий МоÑковÑкий филиал',
+ 'ВерхневолжÑкий ÐевÑкий филиал',
+ 'ВерхневолжÑкий ТавричеÑкий филиал',
+ 'ВерхневолжÑкий ЯроÑлавÑкий филиал',
+ 'ВеÑта',
+ 'ВеÑтинтербанк',
+ 'ВзаимодейÑтвие',
+ 'Викинг',
+ 'Витабанк',
+ 'ВитÑзь',
+ 'Вкабанк',
+ 'ВладбизнеÑбанк',
+ 'Владпромбанк',
+ 'Внешпромбанк',
+ 'Внешфинбанк',
+ 'ВнешÑкономбанк',
+ 'Военно-Промышленный Банк',
+ 'Возрождение',
+ 'Вокбанк',
+ 'Вологдабанк',
+ 'Вологжанин',
+ 'Воронеж',
+ 'ВоÑточно-ЕвропейÑкий ТраÑтовый Банк',
+ 'ВоÑточный ÐкÑпреÑÑ Ð‘Ð°Ð½Ðº',
+ 'ВоÑтСибтранÑкомбанк',
+ 'ВРБ МоÑква',
+ 'Ð’ÑероÑÑийÑкий Банк Ð Ð°Ð·Ð²Ð¸Ñ‚Ð¸Ñ Ð ÐµÐ³Ð¸Ð¾Ð½Ð¾Ð²',
+ 'ВТБ',
+ 'ВТБ 24',
+ 'ВУЗ-Банк',
+ 'Выборг-Банк',
+ 'Выборг-Банк МоÑковÑкий филиал',
+ 'Ð’Ñлтон Банк',
+ 'Ð’Ñтич',
+ 'Ð’Ñтка-Банк',
+ 'ГагаринÑкий',
+ 'Газбанк',
+ 'Газнефтьбанк',
+ 'Газпромбанк',
+ 'ГазÑтройбанк',
+ 'ГазтранÑбанк',
+ 'ГазÑнергобанк',
+ 'Ганзакомбанк',
+ 'Гарант-ИнвеÑÑ‚',
+ 'Гаранти Банк МоÑква',
+ 'Геленджик-Банк',
+ 'Генбанк',
+ 'Геобанк',
+ 'ГефеÑÑ‚',
+ 'ГлобуÑ',
+ 'ГлобÑкÑ',
+ 'Голдман Ð¡Ð°ÐºÑ Ð‘Ð°Ð½Ðº',
+ 'Горбанк',
+ 'ГПБ-Ипотека',
+ 'Гранд ИнвеÑÑ‚ Банк',
+ 'Гринкомбанк',
+ 'Гринфилдбанк',
+ 'ГриÑ-Банк',
+ 'Гута-Банк',
+ 'Далена',
+ 'Далетбанк',
+ 'Далта-Банк',
+ 'ДальневоÑточный Банк',
+ 'ДанÑке Банк',
+ 'Девон-Кредит',
+ 'ДельтаКредит',
+ 'Денизбанк МоÑква',
+ 'Держава',
+ 'Дж. П. Морган Банк',
+ 'ДжаÑÑ‚ Банк',
+ 'Джей Ñнд Ти Банк',
+ 'Дил-Банк',
+ 'Динамичные СиÑтемы',
+ 'Дойче Банк',
+ 'ДолинÑк',
+ 'Дом-Банк',
+ 'Дон-ТекÑбанк',
+ 'Донкомбанк',
+ 'Донхлеббанк',
+ 'Ð”Ð¾Ñ€Ð¸Ñ Ð‘Ð°Ð½Ðº',
+ 'Дружба',
+ 'ЕÐТП Банк',
+ 'ЕвразийÑкий Банк',
+ 'ЕвроазиатÑкий ИнвеÑтиционный Банк',
+ 'ЕвроÐкÑÐ¸Ñ Ð‘Ð°Ð½Ðº',
+ 'ЕвроальÑнÑ',
+ 'Еврокапитал-ÐльÑнÑ',
+ 'Еврокоммерц',
+ 'Еврокредит',
+ 'Евромет',
+ 'ЕвропейÑкий Стандарт',
+ 'Европлан Банк',
+ 'ЕвроÑитиБанк',
+ 'Ð•Ð²Ñ€Ð¾Ñ„Ð¸Ð½Ð°Ð½Ñ ÐœÐ¾Ñнарбанк',
+ 'ЕдинÑтвенный',
+ 'Единый Строительный Банк',
+ 'Екатеринбург',
+ 'ЕкатерининÑкий',
+ 'ЕниÑей',
+ 'ЕниÑейÑкий Объединенный Банк',
+ 'Ермак',
+ 'Живаго-Банк',
+ 'Жилкредит',
+ 'ЖилÑтройбанк',
+ 'ЗапÑибкомбанк',
+ 'Заречье',
+ 'Заубер Банк',
+ 'Земкомбанк',
+ 'ЗемÑкий Банк',
+ 'Зенит',
+ 'Зенит Сочи',
+ 'Зернобанк',
+ 'Зираат Банк',
+ 'Златкомбанк',
+ 'И.Д.Е.Ð. Банк',
+ 'Иваново',
+ 'Идеалбанк',
+ 'Ижкомбанк',
+ 'ИК Банк',
+ 'Икано Банк',
+ 'Инбанк',
+ 'ИнвеÑÑ‚-Ðкобанк',
+ 'ИнвеÑтиционный Банк Кубани',
+ 'ИнвеÑтиционный РеÑпубликанÑкий Банк',
+ 'ИнвеÑтиционный Союз',
+ 'ИнвеÑткапиталбанк',
+ 'ИнвеÑÑ‚Ñоцбанк',
+ 'ИнвеÑтторгбанк',
+ 'ИÐГ Банк',
+ 'ИндуÑтриальный Сберегательный Банк',
+ 'Инкаробанк',
+ 'Интерактивный Банк',
+ 'Интеркоммерц Банк',
+ 'Интеркоопбанк',
+ 'Интеркредит',
+ 'Интернациональный Торговый Банк',
+ 'ИнтерпрогреÑÑбанк',
+ 'Интерпромбанк',
+ 'Интехбанк',
+ 'ИнформпрогреÑÑ',
+ 'Ипозембанк',
+ 'ИпоТек Банк',
+ 'Иронбанк',
+ 'ИРС',
+ 'Итуруп',
+ 'Ишбанк',
+ 'Йошкар-Ола',
+ 'Калуга',
+ 'КамÑкий Горизонт',
+ 'КамÑкий КоммерчеÑкий Банк',
+ 'Камчаткомагропромбанк',
+ 'КанÑкий',
+ 'Капитал',
+ 'Капиталбанк',
+ 'Кедр',
+ 'КемÑоцинбанк',
+ 'КетовÑкий КоммерчеÑкий Банк',
+ 'Киви Банк',
+ 'КлаÑÑик Ðконом Банк',
+ 'КлиентÑкий',
+ 'Кольцо Урала',
+ 'Коммерцбанк (ЕвразиÑ)',
+ 'КоммерчеÑкий Банк РазвитиÑ',
+ 'КоммерчеÑкий Индо Банк',
+ 'КонÑервативный КоммерчеÑкий Банк',
+ 'КонÑтанÑ-Банк',
+ 'Континенталь',
+ 'КонфидÑÐ½Ñ Ð‘Ð°Ð½Ðº',
+ 'Кор',
+ 'Кореа ÐкÑчендж Банк РуÑ',
+ 'КоролевÑкий Банк Шотландии',
+ 'КоÑмоÑ',
+ 'КоÑтромаÑелькомбанк',
+ 'Кошелев-Банк',
+ 'КрайинвеÑтбанк',
+ 'Кранбанк',
+ 'Креди Ðгриколь КИБ',
+ 'Кредит Европа Банк',
+ 'Кредит Урал Банк',
+ 'Кредит ÐкÑпреÑÑ',
+ 'Кредит-МоÑква',
+ 'КредитинвеÑÑ‚',
+ 'Кредо ФинанÑ',
+ 'Кредпромбанк',
+ 'КремлевÑкий',
+ 'КрокуÑ-Банк',
+ 'Крона-Банк',
+ 'КроÑна-Банк',
+ 'КроÑÑинвеÑтбанк',
+ 'КрыловÑкий',
+ 'КС Банк',
+ 'КубанÑкий УниверÑальный Банк',
+ 'Кубань Кредит',
+ 'Кубаньторгбанк',
+ 'КузбаÑÑхимбанк',
+ 'КузнецкбизнеÑбанк',
+ 'Кузнецкий',
+ 'Кузнецкий МоÑÑ‚',
+ 'Курган',
+ 'КурÑкпромбанк',
+ 'Лада-Кредит',
+ 'Лайтбанк',
+ 'Ланта-Банк',
+ 'Левобережный',
+ 'Легион',
+ 'Леноблбанк',
+ 'ЛеÑбанк',
+ 'Лето Банк',
+ 'Липецккомбанк',
+ 'ЛогоÑ',
+ 'Локо-Банк',
+ 'ЛÑнд-Банк',
+ 'М2М Прайвет Банк',
+ 'Майкопбанк',
+ 'МайÑкий',
+ 'МÐК-Банк',
+ 'МакÑима',
+ 'МакÑимум',
+ 'МÐСТ-Банк',
+ 'МаÑтер-Капитал',
+ 'МВС Банк',
+ 'МДМ Банк',
+ 'МегаполиÑ',
+ 'Международный Ðкционерный Банк',
+ 'Международный Банк РазвитиÑ',
+ 'Международный Банк Санкт-Петербурга (МБСП)',
+ 'Международный КоммерчеÑкий Банк',
+ 'Международный РаÑчетный Банк',
+ 'Международный Строительный Банк',
+ 'Международный ФинанÑовый Клуб',
+ 'МежотраÑÐ»ÐµÐ²Ð°Ñ Ð‘Ð°Ð½ÐºÐ¾Ð²ÑÐºÐ°Ñ ÐšÐ¾Ñ€Ð¿Ð¾Ñ€Ð°Ñ†Ð¸Ñ',
+ 'Межрегиональный Банк РеконÑтрукции',
+ 'Межрегиональный Клиринговый Банк',
+ 'Межрегиональный Почтовый Банк',
+ 'Межрегиональный промышленно-Ñтроительный банк',
+ 'Межрегионбанк',
+ 'МежтопÑнергобанк',
+ 'МежтраÑтбанк',
+ 'МерÑедеÑ-Бенц Банк РуÑ',
+ 'МеталлинвеÑтбанк',
+ 'Металлург',
+ 'Меткомбанк (КаменÑк-УральÑкий)',
+ 'Меткомбанк (Череповец)',
+ 'Метробанк',
+ 'Метрополь',
+ 'Мидзухо Банк',
+ 'Мико-Банк',
+ 'Милбанк',
+ 'Миллениум Банк',
+ 'Мир Ð‘Ð¸Ð·Ð½ÐµÑ Ð‘Ð°Ð½Ðº',
+ 'Мираф-Банк',
+ 'Мираф-Банк МоÑковÑкий филиал',
+ 'Миръ',
+ 'МихайловÑкий ПЖСБ',
+ 'Морган СтÑнли Банк',
+ 'МорÑкой Банк',
+ 'МоÑводоканалбанк',
+ 'МоÑква',
+ 'МоÑква-Сити',
+ 'МоÑковÑкий ВекÑельный Банк',
+ 'МоÑковÑкий ИндуÑтриальный Банк',
+ 'МоÑковÑкий КоммерчеÑкий Банк',
+ 'МоÑковÑкий Кредитный Банк',
+ 'МоÑковÑкий Ðациональный ИнвеÑтиционный Банк',
+ 'МоÑковÑкий ÐефтехимичеÑкий Банк',
+ 'МоÑковÑкий ОблаÑтной Банк',
+ 'МоÑковÑко-ПарижÑкий Банк',
+ 'МоÑковÑкое Ипотечное ÐгентÑтво',
+ 'МоÑкоммерцбанк',
+ 'МоÑÑтройÑкономбанк (М Банк)',
+ 'МоÑтранÑбанк',
+ 'МоÑуралбанк',
+ 'МС Банк РуÑ',
+ 'МСП Банк',
+ 'МТИ-Банк',
+ 'МТС Банк',
+ 'Муниципальный Камчатпрофитбанк',
+ 'МурманÑкий Социальный КоммерчеÑкий Банк',
+ 'МФБанк',
+ 'Ð-Банк',
+ 'Ðальчик',
+ 'Ðаратбанк',
+ 'Ðародный Банк',
+ 'Ðародный Банк РеÑпублики Тыва',
+ 'Ðародный Доверительный Банк',
+ 'Ðародный Земельно-Промышленный Банк',
+ 'Ðародный ИнвеÑтиционный Банк',
+ 'ÐатикÑÐ¸Ñ Ð‘Ð°Ð½Ðº',
+ 'ÐацинвеÑтпромбанк',
+ 'ÐÐ°Ñ†Ð¸Ð¾Ð½Ð°Ð»ÑŒÐ½Ð°Ñ Ð¤Ð°ÐºÑ‚Ð¾Ñ€Ð¸Ð½Ð³Ð¾Ð²Ð°Ñ ÐšÐ¾Ð¼Ð¿Ð°Ð½Ð¸Ñ',
+ 'Ðациональный Банк "ТраÑÑ‚"',
+ 'Ðациональный Банк Взаимного Кредита',
+ 'Ðациональный Банк Сбережений',
+ 'Ðациональный Залоговый Банк',
+ 'Ðациональный Клиринговый Банк',
+ 'Ðациональный Клиринговый Центр',
+ 'Ðациональный Корпоративный Банк',
+ 'Ðациональный Резервный Банк',
+ 'Ðациональный Стандарт',
+ 'Ðаш Дом',
+ 'ÐБД-Банк',
+ 'ÐБК-Банк',
+ 'ÐеваÑтройинвеÑÑ‚',
+ 'ÐевÑкий Банк',
+ 'Ðейва',
+ 'Ðерюнгрибанк',
+ 'Ðефтепромбанк',
+ 'ÐефтÑной ÐльÑнÑ',
+ 'ÐижневолжÑкий КоммерчеÑкий Банк',
+ 'Ðико-Банк',
+ 'ÐК Банк',
+ 'ÐоваховКапиталБанк',
+ 'ÐовациÑ',
+ 'Ðовикомбанк',
+ 'Ðовобанк',
+ 'Ðовое ВремÑ',
+ 'Ðовокиб',
+ 'ÐовопокровÑкий',
+ 'Ðовый Век',
+ 'Ðовый Кредитный Союз',
+ 'Ðовый МоÑковÑкий Банк',
+ );
+
+ /**
+ * @example 'Ðовый МоÑковÑкий Банк'
+ */
+ public static function bank()
+ {
+ return static::randomElement(static::$banks);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Person.php b/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Person.php
new file mode 100644
index 000000000..e02113d1a
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/Person.php
@@ -0,0 +1,179 @@
+middleNameMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return $this->middleNameFemale();
+ }
+
+ return $this->middleName(static::randomElement(array(
+ static::GENDER_MALE,
+ static::GENDER_FEMALE,
+ )));
+ }
+
+ /**
+ * Return last name for the specified gender.
+ *
+ * @param string|null $gender A gender of the last name should be generated
+ * for. If the argument is skipped a random gender will be used.
+ * @return string Last name
+ */
+ public function lastName($gender = null)
+ {
+ $lastName = static::randomElement(static::$lastName);
+
+ if (static::GENDER_FEMALE === $gender) {
+ return $lastName . 'a';
+ } elseif (static::GENDER_MALE === $gender) {
+ return $lastName;
+ }
+
+ return $lastName . static::randomElement(static::$lastNameSuffix);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/PhoneNumber.php
new file mode 100644
index 000000000..c7477d7e3
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/ru_RU/PhoneNumber.php
@@ -0,0 +1,14 @@
+generator->parse(static::randomElement(static::$lastNameFormat));
+ }
+
+ public static function lastNameMale()
+ {
+ return static::randomElement(static::$lastNameMale);
+ }
+
+ public static function lastNameFemale()
+ {
+ return static::randomElement(static::$lastNameFemale);
+ }
+
+ /**
+ * @example 'PhD'
+ */
+ public static function suffix()
+ {
+ return static::randomElement(static::$suffix);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/sk_SK/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/sk_SK/PhoneNumber.php
new file mode 100644
index 000000000..1baf7ccf3
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/sk_SK/PhoneNumber.php
@@ -0,0 +1,15 @@
+format('ymd');
+
+ if ($gender && $gender == static::GENDER_MALE) {
+ $randomDigits = (string)static::numerify('##') . static::randomElement(array(1,3,5,7,9));
+ } elseif ($gender && $gender == static::GENDER_FEMALE) {
+ $randomDigits = (string)static::numerify('##') . static::randomElement(array(0,2,4,6,8));
+ } else {
+ $randomDigits = (string)static::numerify('###');
+ }
+
+
+ $checksum = Luhn::computeCheckDigit($datePart . $randomDigits);
+
+ return $datePart . '-' . $randomDigits . $checksum;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/sv_SE/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/sv_SE/PhoneNumber.php
new file mode 100644
index 000000000..d15e5dd6f
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/sv_SE/PhoneNumber.php
@@ -0,0 +1,37 @@
+format('a') === 'am' ? 'öö' : 'ös';
+ }
+
+ public static function dayOfWeek($max = 'now')
+ {
+ $map = array(
+ 'Sunday' => 'Pazar',
+ 'Monday' => 'Pazartesi',
+ 'Tuesday' => 'Salı',
+ 'Wednesday' => 'Çarşamba',
+ 'Thursday' => 'PerÅŸembe',
+ 'Friday' => 'Cuma',
+ 'Saturday' => 'Cumartesi',
+ );
+ $week = static::dateTime($max)->format('l');
+ return isset($map[$week]) ? $map[$week] : $week;
+ }
+
+ public static function monthName($max = 'now')
+ {
+ $map = array(
+ 'January' => 'Ocak',
+ 'February' => 'Åžubat',
+ 'March' => 'Mart',
+ 'April' => 'Nisan',
+ 'May' => 'Mayıs',
+ 'June' => 'Haziran',
+ 'July' => 'Temmuz',
+ 'August' => 'AÄŸustos',
+ 'September' => 'Eylül',
+ 'October' => 'Ekim',
+ 'November' => 'Kasım',
+ 'December' => 'Aralık',
+ );
+ $month = static::dateTime($max)->format('F');
+ return isset($map[$month]) ? $map[$month] : $month;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/Internet.php
new file mode 100644
index 000000000..ef907d44f
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/tr_TR/Internet.php
@@ -0,0 +1,9 @@
+generator->parse($format);
+ }
+
+ public static function streetPrefix()
+ {
+ return static::randomElement(static::$streetPrefix);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Color.php b/vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Color.php
new file mode 100644
index 000000000..197cc3b65
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Color.php
@@ -0,0 +1,23 @@
+generator->parse($format);
+ }
+
+ public static function companyPrefix()
+ {
+ return static::randomElement(static::$companyPrefix);
+ }
+
+ public static function companyName()
+ {
+ return static::randomElement(static::$companyName);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Internet.php
new file mode 100644
index 000000000..33214d672
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/Internet.php
@@ -0,0 +1,9 @@
+middleNameMale();
+ } elseif ($gender === static::GENDER_FEMALE) {
+ return $this->middleNameFemale();
+ }
+
+ return $this->middleName(static::randomElement(array(
+ static::GENDER_MALE,
+ static::GENDER_FEMALE,
+ )));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/PhoneNumber.php
new file mode 100644
index 000000000..24187f332
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/uk_UA/PhoneNumber.php
@@ -0,0 +1,51 @@
+generator->parse($format));
+ }
+
+ public function hamletPrefix()
+ {
+ return static::randomElement(static::$hamletPrefix);
+ }
+
+ public function wardName()
+ {
+ $format = static::randomElement(static::$wardNameFormats);
+
+ return static::bothify($this->generator->parse($format));
+ }
+
+ public function wardPrefix()
+ {
+ return static::randomElement(static::$wardPrefix);
+ }
+
+ public function districtName()
+ {
+ $format = static::randomElement(static::$districtNameFormats);
+
+ return static::bothify($this->generator->parse($format));
+ }
+
+ public function districtPrefix()
+ {
+ return static::randomElement(static::$districtPrefix);
+ }
+
+ /**
+ * @example 'HÃ Ná»™i'
+ */
+ public function city()
+ {
+ return static::randomElement(static::$city);
+ }
+
+ /**
+ * @example 'Bắc Giang'
+ */
+ public static function province()
+ {
+ return static::randomElement(static::$province);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/Color.php b/vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/Color.php
new file mode 100644
index 000000000..4deaa2fb5
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/Color.php
@@ -0,0 +1,36 @@
+generator->parse(static::randomElement(static::$middleNameFormat));
+ }
+
+ public static function middleNameMale()
+ {
+ return static::randomElement(static::$middleNameMale);
+ }
+
+ public static function middleNameFemale()
+ {
+ return static::randomElement(static::$middleNameFemale);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/PhoneNumber.php
new file mode 100644
index 000000000..5f9f60a1e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/vi_VN/PhoneNumber.php
@@ -0,0 +1,61 @@
+ array(
+ '0[a] ### ####',
+ '(0[a]) ### ####',
+ '0[a]-###-####',
+ '(0[a])###-####',
+ '84-[a]-###-####',
+ '(84)([a])###-####',
+ '+84-[a]-###-####',
+ ),
+ '8' => array(
+ '0[a] #### ####',
+ '(0[a]) #### ####',
+ '0[a]-####-####',
+ '(0[a])####-####',
+ '84-[a]-####-####',
+ '(84)([a])####-####',
+ '+84-[a]-####-####',
+ ),
+ );
+
+ public function phoneNumber()
+ {
+ $areaCode = static::randomElement(static::$areaCodes);
+ $areaCodeLength = strlen($areaCode);
+ $digits = 7;
+
+ if ($areaCodeLength < 2) {
+ $digits = 8;
+ }
+
+ return static::numerify(str_replace('[a]', $areaCode, static::randomElement(static::$formats[$digits])));
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Address.php b/vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Address.php
new file mode 100644
index 000000000..19d1c9417
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Address.php
@@ -0,0 +1,149 @@
+city() . static::area();
+ }
+
+ public static function postcode()
+ {
+ $prefix = str_pad(mt_rand(1, 85), 2, 0, STR_PAD_LEFT);
+ $suffix = '00';
+
+ return $prefix . mt_rand(10, 88) . $suffix;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Color.php b/vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Color.php
new file mode 100644
index 000000000..12d29e321
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Color.php
@@ -0,0 +1,66 @@
+format('a') === 'am' ? '上åˆ' : '下åˆ';
+ }
+
+ public static function dayOfWeek($max = 'now')
+ {
+ $map = array(
+ 'Sunday' => '星期日',
+ 'Monday' => '星期一',
+ 'Tuesday' => '星期二',
+ 'Wednesday' => '星期三',
+ 'Thursday' => '星期四',
+ 'Friday' => '星期五',
+ 'Saturday' => '星期å…',
+ );
+ $week = static::dateTime($max)->format('l');
+ return isset($map[$week]) ? $map[$week] : $week;
+ }
+
+ public static function monthName($max = 'now')
+ {
+ $map = array(
+ 'January' => '一月',
+ 'February' => '二月',
+ 'March' => '三月',
+ 'April' => '四月',
+ 'May' => '五月',
+ 'June' => 'å…æœˆ',
+ 'July' => '七月',
+ 'August' => '八月',
+ 'September' => '乿œˆ',
+ 'October' => 'åæœˆ',
+ 'November' => 'å一月',
+ 'December' => 'å二月',
+ );
+ $month = static::dateTime($max)->format('F');
+ return isset($map[$month]) ? $map[$month] : $month;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Internet.php
new file mode 100644
index 000000000..ca10822c3
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/zh_CN/Internet.php
@@ -0,0 +1,24 @@
+ array(
+ 'æ¿æ©‹å€', '三é‡å€', 'ä¸å’Œå€', '永和å€',
+ '新莊å€', '新店å€', '樹林å€', '鶯æŒå€',
+ '三峽å€', 'æ·¡æ°´å€', 'æ±æ¢å€', '瑞芳å€',
+ '土城å€', '蘆洲å€', '五股å€', 'æ³°å±±å€',
+ 'æž—å£å€', 'æ·±å‘å€', '石碇å€', 'åªæž—å€',
+ '三èŠå€', '石門å€', '八里å€', '平溪å€',
+ '雙溪å€', '貢寮å€', '金山å€', 'è¬é‡Œå€',
+ 'çƒä¾†å€',
+ ),
+ '宜è˜ç¸£' => array(
+ '宜è˜å¸‚', 'ç¾…æ±éŽ®', '蘇澳鎮', 'é 城鎮', 'ç¤æºªé„‰',
+ '壯åœé„‰', '員山鄉', '冬山鄉', '五çµé„‰', '三星鄉',
+ '大åŒé„‰', 'å—æ¾³é„‰',
+ ),
+ '桃園市' => array(
+ '桃園å€', 'ä¸å£¢å€', '大溪å€', '楊梅å€', '蘆竹å€',
+ '大園å€', '龜山å€', 'å…«å¾·å€', '龿½å€', '平鎮å€',
+ '新屋å€', '觀音å€', '復興å€',
+ ),
+ '新竹縣' => array(
+ '竹北市', '竹æ±éŽ®', '新埔鎮', '關西鎮', 'æ¹–å£é„‰',
+ 'æ–°è±é„‰', '芎林鄉', '橫山鄉', '北埔鄉', '寶山鄉',
+ '峨眉鄉', '尖石鄉', '五峰鄉',
+ ),
+ 'è‹—æ —ç¸£' => array(
+ 'è‹—æ —å¸‚', '苑裡鎮', '通霄鎮', '竹å—鎮', 'é 份鎮',
+ '後é¾éŽ®', 'å“è˜éŽ®', '大湖鄉', '公館鄉', '銅鑼鄉',
+ 'å—庄鄉', 'é 屋鄉', '三義鄉', '西湖鄉', 'é€ æ©‹é„‰',
+ '三ç£é„‰', 'ç…æ½é„‰', '泰安鄉',
+ ),
+ '臺ä¸å¸‚' => array(
+ 'è±åŽŸå€', 'æ±å‹¢å€', '大甲å€', '清水å€', '沙鹿å€',
+ '梧棲å€', 'åŽé‡Œå€', '神岡å€', 'æ½åå€', '大雅å€',
+ '新社å€', '石岡å€', '外埔å€', '大安å€', 'çƒæ—¥å€',
+ '大肚å€', 'é¾äº•å€', '霧峰å€', '太平å€', '大里å€',
+ '和平å€', 'ä¸å€', 'æ±å€', 'å—å€', '西å€', '北å€',
+ '西屯å€', 'å—屯å€', '北屯å€',
+ ),
+ '彰化縣' => array(
+ '彰化市', '鹿港鎮', '和美鎮', '線西鄉', '伸港鄉',
+ 'ç¦èˆˆé„‰', '秀水鄉', '花壇鄉', '芬園鄉', '員林鎮',
+ '溪湖鎮', 'ç”°ä¸éŽ®', '大æ‘鄉', '埔鹽鄉', '埔心鄉',
+ 'æ°¸é–鄉', '社é 鄉', '二水鄉', '北斗鎮', '二林鎮',
+ '田尾鄉', '埤é 鄉', '芳苑鄉', '大城鄉', '竹塘鄉',
+ '溪州鄉',
+ ),
+ 'å—æŠ•ç¸£' => array(
+ '嗿Е参', '埔里鎮', 'è‰å±¯éŽ®', '竹山鎮', '集集鎮',
+ 'å間鄉', '鹿谷鄉', 'ä¸å¯®é„‰', 'éšæ± 鄉', '國姓鄉',
+ '水里鄉', '信義鄉', '仿„›é„‰',
+ ),
+ '雲林縣' => array(
+ 'æ–—å…市', 'æ–—å—鎮', '虎尾鎮', '西螺鎮', '土庫鎮',
+ '北港鎮', 'å¤å‘鄉', '大埤鄉', '莿æ¡é„‰', '林內鄉',
+ '二崙鄉', '崙背鄉', '麥寮鄉', 'æ±å‹¢é„‰', 'è¤’å¿ é„‰',
+ '臺西鄉', '元長鄉', '四湖鄉', '壿¹–鄉', '水林鄉',
+ ),
+ '嘉義縣' => array(
+ '太ä¿å¸‚', '朴å市', '布袋鎮', '大林鎮', '民雄鄉',
+ '溪å£é„‰', '新港鄉', 'å…腳鄉', 'æ±çŸ³é„‰', '義竹鄉',
+ '鹿è‰é„‰', '水上鄉', 'ä¸åŸ”鄉', '竹崎鄉', '梅山鄉',
+ '番路鄉', '大埔鄉', '阿里山鄉',
+ ),
+ '臺å—市' => array(
+ '新營å€', '鹽水å€', '白河å€', '柳營å€', '後å£å€',
+ 'æ±å±±å€', '麻豆å€', '下營å€', 'å…甲å€', '官田å€',
+ '大內å€', '佳里å€', 'å¸ç”²å€', '西港å€', '七股å€',
+ 'å°‡è»å€', '北門å€', '新化å€', '善化å€', '新市å€',
+ '安定å€', '山上å€', '玉井å€', 'æ¥ è¥¿å€', 'å—化å€',
+ '左鎮å€', 'ä»å¾·å€', 'æ¸ä»å€', '關廟å€', 'é¾å´Žå€',
+ '永康å€', 'æ±å€', 'å—å€', '西å€', '北å€', 'ä¸å€',
+ '安å—å€', '安平å€',
+ ),
+ '高雄市' => array(
+ '鳳山å€', '林園å€', '大寮å€', '大樹å€', '大社å€',
+ '仿¦å€', 'é³¥æ¾å€', '岡山å€', 'æ©‹é å€', '燕巢å€',
+ '田寮å€', '阿蓮å€', '路竹å€', 'æ¹–å…§å€', '茄è£å€',
+ '永安å€', '彌陀å€', '梓官å€', 'æ——å±±å€', '美濃å€',
+ 'å…龜å€', '甲仙å€', 'æ‰æž—å€', 'å…§é–€å€', '茂林å€',
+ '桃æºå€', '三民å€', '鹽埕å€', '鼓山å€', '左營å€',
+ 'æ¥ æ¢“å€', '三民å€', '新興å€', 'å‰é‡‘å€', 'è‹“é›…å€',
+ 'å‰éŽ®å€', 'æ——æ´¥å€', 'å°æ¸¯å€',
+ ),
+ '屿±ç¸£' => array(
+ '屿±å¸‚', '潮州鎮', 'æ±æ¸¯éŽ®', 'æ†æ˜¥éŽ®', 'è¬ä¸¹é„‰',
+ '長治鄉', '麟洛鄉', 'ä¹å¦‚鄉', '里港鄉', '鹽埔鄉',
+ '高樹鄉', 'è¬å·’鄉', '內埔鄉', '竹田鄉', '新埤鄉',
+ '枋寮鄉', '新園鄉', 'å´é ‚鄉', '林邊鄉', 'å—州鄉',
+ '佳冬鄉', 'ç‰çƒé„‰', '車城鄉', '滿州鄉', '枋山鄉',
+ '三地門鄉', '霧臺鄉', '瑪家鄉', 'æ³°æ¦é„‰', '來義鄉',
+ '春日鄉', 'ç…å鄉', '牡丹鄉',
+ ),
+ '臺æ±ç¸£' => array(
+ '臺æ±å¸‚', 'æˆåŠŸéŽ®', '關山鎮', 'å‘å—鄉', '鹿野鄉',
+ 'æ± ä¸Šé„‰', 'æ±æ²³é„‰', '長濱鄉', '太麻里鄉', '大æ¦é„‰',
+ 'ç¶ å³¶é„‰', '海端鄉', '延平鄉', '金峰鄉', 'é”ä»é„‰',
+ 'è˜å¶¼é„‰',
+ ),
+ '花蓮縣' => array(
+ '花蓮市', '鳳林鎮', '玉里鎮', '新城鄉', 'å‰å®‰é„‰',
+ '壽è±é„‰', '光復鄉', 'è±æ¿±é„‰', '瑞穗鄉', '富里鄉',
+ '秀林鄉', 'è¬æ¦®é„‰', '哿ºªé„‰',
+ ),
+ '澎湖縣' => array(
+ '馬公市', '湖西鄉', '白沙鄉', '西嶼鄉', '望安鄉',
+ '七美鄉',
+ ),
+ '基隆市' => array(
+ '䏿£å€', 'ä¸ƒå µå€', 'æš–æš–å€', '仿„›å€', 'ä¸å±±å€',
+ '安樂å€', '信義å€',
+ ),
+ '新竹市' => array(
+ 'æ±å€', '北å€', '香山å€',
+ ),
+ '嘉義市' => array(
+ 'æ±å€', '西å€',
+ ),
+ '臺北市' => array(
+ 'æ¾å±±å€', '信義å€', '大安å€', 'ä¸å±±å€', '䏿£å€',
+ '大åŒå€', 'è¬è¯å€', '文山å€', 'å—æ¸¯å€', 'å…§æ¹–å€',
+ '士林å€', '北投å€',
+ ),
+ '連江縣' => array(
+ 'å—竿鄉', '北竿鄉', '莒光鄉', 'æ±å¼•鄉',
+ ),
+ '金門縣' => array(
+ '金城鎮', '金沙鎮', '金湖鎮', '金寧鄉', '烈嶼鄉', 'çƒåµé„‰',
+ ),
+ );
+
+ /**
+ * @link http://terms.naer.edu.tw/download/287/
+ */
+ protected static $country = array(
+ 'ä¸ä¸¹', 'ä¸éž', '丹麥', '伊朗', '冰島', '剛果',
+ 'åŠ å½', '北韓', 'å—éž', 'å¡é”', 'å°å°¼', 'å°åº¦',
+ 'å¤å·´', '哥德', '埃åŠ', '多哥', '寮國', '尼日',
+ '巴曼', 'å·´æž—', 'å·´ç´', '巴西', '希臘', '帛ç‰',
+ '德國', '挪å¨', 'æ·å…‹', '教廷', 'æ–æ¿Ÿ', '日本',
+ '智利', 'æ±åŠ ', '查德', 'æ±¶èŠ', '法國', 'æ³¢è˜',
+ '波赫', '泰國', '海地', '瑞典', '瑞士', '祕é¯',
+ '秘é¯', 'ç´„æ—¦', 'ç´åŸƒ', '緬甸', '美國', 'è–å°¼',
+ 'è–æ™®', '肯亞', '芬è˜', '英國', 'è·è˜', '葉門',
+ '蘇丹', '諾é¯', 'è²å—', 'è¶Šå—', '迦å½',
+ '迦ç´', '阿曼', '阿è¯', '韓國', '馬利',
+ '以色列', '以色利', '伊拉克', '俄羅斯',
+ '利比亞', 'åŠ æ‹¿å¤§', '匈牙利', 'å—æ¥µæ´²',
+ 'å—蘇丹', '厄瓜多', 'å‰å¸ƒåœ°', 'å瓦é¯',
+ '哈撒克', '哈薩克', '喀麥隆', '喬治亞',
+ '土庫曼', '土耳其', 'å¡”å‰å…‹', '塞å¸çˆ¾',
+ '墨西哥', '大西洋', '奧地利', 'åŸåŠ æ‹‰',
+ '安哥拉', '安地å¡', '安é“爾', '尚比亞',
+ '尼伯爾', '尼泊爾', '巴哈馬', '巴拉åœ',
+ '巴拿馬', 'å·´è²å¤š', '幾內亞', '愛爾è˜',
+ '所在國', '摩洛哥', 'æ‘©ç´å“¥', 'æ•利亞',
+ '敘利亞', 'æ–°åŠ å¡', 'æ±å¸æ±¶', '柬埔寨',
+ '比利時', '波扎那', 'æ³¢æœé‚£', 'çƒå…‹è˜',
+ 'çƒå¹²é”', 'çƒæ‹‰åœ', 'ç‰™è²·åŠ ', 'ç…åå±±',
+ '甘比亞', '盧安é”', 'ç›§æ£®å ¡', 'ç§‘å¨ç‰¹',
+ '科索夫', '科索沃', 'ç«‹é™¶å®›', 'ç´è¥¿è˜',
+ 'ç¶å¾·è§’', '義大利', 'è–æ–‡æ£®', '艾塞亞',
+ 'è²å¾‹è³“', 'è¬é‚£æœ', 'è‘¡è„牙', '蒲隆地',
+ '蓋亞ç´', '薩摩亞', '蘇利å—', '西ç牙',
+ 'è²é‡Œæ–¯', '賴索托', '辛巴å¨', '阿富汗',
+ 'é˜¿æ ¹å»·', 'é¦¬å…¶é “', '馬拉å¨', '馬爾他',
+ '黎巴嫩', '亞塞拜然', '亞美尼亞', 'ä¿åŠ åˆ©äºž',
+ 'å—æ–¯æ‹‰å¤«', '厄利垂亞', 'å²ç“¦æ¿Ÿè˜', 'å‰çˆ¾å‰æ–¯',
+ 'å‰é‡Œå·´æ–¯', '哥倫比亞', 'å¦å°šå°¼äºž', 'å¡žå…§åŠ çˆ¾',
+ 'å¡žå†…åŠ çˆ¾', '塞爾ç¶äºž', 'å¤šæ˜Žå°¼åŠ ', '多米尼克',
+ '奈åŠåˆ©äºž', '委內瑞拉', 'å®éƒ½æ‹‰æ–¯', 'å°¼åŠ æ‹‰ç“œ',
+ '巴基斯å¦', '庫克群島', '愛沙尼亞', '拉脫ç¶äºž',
+ '摩爾多瓦', '摩里西斯', '斯洛ä¼å…‹', '斯里è˜å¡',
+ 'æ ¼ç‘žé‚£é”', '模里西斯', '波多黎å„', '澳大利亞',
+ 'çƒèŒ²åˆ¥å…‹', '玻利ç¶äºž', '瓜地馬拉', '白俄羅斯',
+ 'çªå°¼è¥¿äºž', 'ç´ç±³æ¯”亞', '索馬利亞', '索馬尼亞',
+ '羅馬尼亞', 'è–露西亞', 'è–馬利諾', '莫三比克',
+ '莫三鼻克', '葛摩è¯ç›Ÿ', '薩爾瓦多', '衣索比亞',
+ '西薩摩亞', '象牙海岸', '賴比瑞亞', '賽普勒斯',
+ '馬來西亞', '馬爾地夫', '克羅埃西亞',
+ '列支敦斯登', 'å“¥æ–¯å¤§é»ŽåŠ ', '布å‰ç´æ³•ç´¢',
+ '布å‰é‚£æ³•ç´¢', '幾內亞比索', '幾內亞比紹',
+ '斯洛ç¶å°¼äºž', '索羅門群島', '茅利塔尼亞',
+ '蒙特內哥羅', '赤é“幾內亞', '阿爾åŠåˆ©äºž',
+ '阿爾åŠå°¼äºž', '阿爾巴尼亞', '馬紹爾群島',
+ '馬é”åŠ æ–¯åŠ ', '密克羅尼西亞', 'æ²™çƒåœ°é˜¿æ‹‰ä¼¯',
+ 'åƒé‡Œé”åŠæ‰˜å·´å“¥',
+ );
+
+ protected static $postcode = array('###-##', '###');
+
+ public function street()
+ {
+ return static::randomElement(static::$street);
+ }
+
+ public static function randomChineseNumber()
+ {
+ $digits = array(
+ '', '一', '二', '三', 'å››', '五', 'å…', '七', 'å…«', 'ä¹',
+ );
+ return $digits[static::randomDigitNotNull()];
+ }
+
+ public static function randomNumber2()
+ {
+ return static::randomNumber(2) + 1;
+ }
+
+ public static function randomNumber3()
+ {
+ return static::randomNumber(3) + 1;
+ }
+
+ public static function localLatitude()
+ {
+ return number_format(mt_rand(22000000, 25000000)/1000000, 6);
+ }
+
+ public static function localLongitude()
+ {
+ return number_format(mt_rand(120000000, 122000000)/1000000, 6);
+ }
+
+ public function city()
+ {
+ $county = static::randomElement(array_keys(static::$city));
+ $city = static::randomElement(static::$city[$county]);
+ return $county.$city;
+ }
+
+ public function state()
+ {
+ return '臺ç£çœ';
+ }
+
+ public static function stateAbbr()
+ {
+ return '臺';
+ }
+
+ public static function cityPrefix()
+ {
+ return '';
+ }
+
+ public static function citySuffix()
+ {
+ return '';
+ }
+
+ public static function secondaryAddress()
+ {
+ return (static::randomNumber(2)+1).static::randomElement(static::$secondaryAddressSuffix);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Color.php b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Color.php
new file mode 100644
index 000000000..7be5953d6
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Color.php
@@ -0,0 +1,66 @@
+generator->parse($format);
+ }
+
+ public static function companyModifier()
+ {
+ return static::randomElement(static::$companyModifier);
+ }
+
+ public static function companyPrefix()
+ {
+ return static::randomElement(static::$companyPrefix);
+ }
+
+ public function catchPhrase()
+ {
+ return static::randomElement(static::$catchPhrase);
+ }
+
+ public function bs()
+ {
+ $result = '';
+ foreach (static::$bsWords as &$word) {
+ $result .= static::randomElement($word);
+ }
+ return $result;
+ }
+
+ /**
+ * return standard VAT / Tax ID / Uniform Serial Number
+ *
+ * @example 28263822
+ *
+ * @return int
+ */
+ public function VAT()
+ {
+ return static::randomNumber(8, true);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/DateTime.php b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/DateTime.php
new file mode 100644
index 000000000..6df5e928a
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/DateTime.php
@@ -0,0 +1,46 @@
+format('a') === 'am' ? '上åˆ' : '下åˆ';
+ }
+
+ public static function dayOfWeek($max = 'now')
+ {
+ $map = array(
+ 'Sunday' => '星期日',
+ 'Monday' => '星期一',
+ 'Tuesday' => '星期二',
+ 'Wednesday' => '星期三',
+ 'Thursday' => '星期四',
+ 'Friday' => '星期五',
+ 'Saturday' => '星期å…',
+ );
+ $week = static::dateTime($max)->format('l');
+ return isset($map[$week]) ? $map[$week] : $week;
+ }
+
+ public static function monthName($max = 'now')
+ {
+ $map = array(
+ 'January' => '一月',
+ 'February' => '二月',
+ 'March' => '三月',
+ 'April' => '四月',
+ 'May' => '五月',
+ 'June' => 'å…æœˆ',
+ 'July' => '七月',
+ 'August' => '八月',
+ 'September' => '乿œˆ',
+ 'October' => 'åæœˆ',
+ 'November' => 'å一月',
+ 'December' => 'å二月',
+ );
+ $month = static::dateTime($max)->format('F');
+ return isset($map[$month]) ? $map[$month] : $month;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Internet.php b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Internet.php
new file mode 100644
index 000000000..4035ea85e
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Internet.php
@@ -0,0 +1,16 @@
+userName();
+ }
+
+ public function domainWord()
+ {
+ return \Faker\Factory::create('en_US')->domainWord();
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Payment.php b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Payment.php
new file mode 100644
index 000000000..6b1a5829a
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Payment.php
@@ -0,0 +1,11 @@
+creditCardDetails($valid);
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Person.php b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Person.php
new file mode 100644
index 000000000..e0071befc
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/Person.php
@@ -0,0 +1,201 @@
+ 10,
+ 'B' => 11,
+ 'C' => 12,
+ 'D' => 13,
+ 'E' => 14,
+ 'F' => 15,
+ 'G' => 16,
+ 'H' => 17,
+ 'I' => 34,
+ 'J' => 18,
+ 'K' => 19,
+ 'M' => 21,
+ 'N' => 22,
+ 'O' => 35,
+ 'P' => 23,
+ 'Q' => 24,
+ 'T' => 27,
+ 'U' => 28,
+ 'V' => 29,
+ 'W' => 32,
+ 'X' => 30,
+ 'Z' => 33
+ );
+
+ /**
+ * @see https://zh.wikipedia.org/wiki/%E4%B8%AD%E8%8F%AF%E6%B0%91%E5%9C%8B%E5%9C%8B%E6%B0%91%E8%BA%AB%E5%88%86%E8%AD%89
+ */
+ public static $idDigitValidator = array(1, 9, 8, 7, 6, 5, 4, 3, 2, 1, 1);
+
+ protected static $maleNameFormats = array(
+ '{{lastName}}{{firstNameMale}}',
+ );
+
+ protected static $femaleNameFormats = array(
+ '{{lastName}}{{firstNameFemale}}',
+ );
+
+ protected static $titleMale = array('先生', 'åšå£«', '教授');
+ protected static $titleFemale = array('å°å§', '太太', 'åšå£«', '教授');
+
+ /**
+ * @link http://zh.wikipedia.org/wiki/%E7%99%BE%E5%AE%B6%E5%A7%93
+ */
+ protected static $lastName = array(
+ 'è¶™', '錢', 'å«', 'æŽ', '周', 'å³', 'é„', '王', '馮',
+ '陳', '褚', '衛', '蔣', '沈', '韓', '楊', '朱', '秦',
+ 'å°¤', '許', '何', 'å‘‚', 'æ–½', 'å¼µ', 'å”', '曹', 'åš´',
+ 'è¯', '金', 'é', 'é™¶', 'å§œ', '戚', 'è¬', 'é„’', 'å–»',
+ 'æŸ', 'æ°´', '竇', 'ç« ', '雲', '蘇', '潘', 'è‘›',
+ '奚', '范', 'å½', '郎', 'é¯', '韋', '昌', '馬',
+ 'è‹—', 'é³³', '花', 'æ–¹', '俞', 'ä»»', 'è¢', '柳',
+ 'é…†', '鮑', 'å²', 'å”', 'è²»', '廉', '岑', 'è–›',
+ '雷', '賀', '倪', '湯', '滕', '殷', '羅', '畢',
+ 'éƒ', 'é„”', '安', '常', '樂', '于', '時', 'å‚…',
+ 'çš®', 'åž', '齊', '康', 'ä¼', 'ä½™', 'å…ƒ', 'åœ',
+ 'é¡§', 'åŸ', 'å¹³', '黃', 'å’Œ', '穆', 'è•', 'å°¹',
+ 'å§š', '邵', 'æ¹›', '汪', 'ç¥', '毛', '禹', 'ç‹„',
+ 'ç±³', 'è²', '明', '臧', '計', 'ä¼', 'æˆ', '戴',
+ '談', '宋', '茅', 'é¾', '熊', 'ç´€', '舒', '屈',
+ 'é …', 'ç¥', 'è‘£', 'æ¢', 'æœ', '阮', 'è—', 'é–”',
+ 'å¸', 'å£', '麻', 'å¼·', '賈', 'è·¯', 'å©', 'å±',
+ '江', 'ç«¥', 'é¡', 'éƒ', '梅', 'ç››', 'æž—', 'åˆ',
+ 'é¾', 'å¾', '丘', 'é§±', '高', 'å¤', '蔡', 'ç”°',
+ '樊', '胡', '凌', 'éœ', '虞', 'è¬', '支', '柯',
+ 'æ˜', '管', 'ç›§', '莫', 'ç¶“', '房', '裘', '繆',
+ 'å¹²', 'è§£', '應', 'å®—', 'ä¸', '宣', 'è³', 'é„§',
+ 'éƒ', 'å–®', 'æ', 'æ´ª', '包', '諸', 'å·¦', '石',
+ 'å´”', 'å‰', '鈕', 'é¾”', '程', '嵇', 'é‚¢', '滑',
+ '裴', '陸', '榮', 'ç¿', 'è€', '羊', 'æ–¼', 'æƒ ',
+ '甄', '麴', 'å®¶', 'å°', '芮', '羿', '儲', 'é³',
+ 'æ±²', 'é‚´', '糜', 'æ¾', '井', '段', '富', 'å·«',
+ 'çƒ', '焦', 'å·´', '弓', '牧', 'éš—', 'å±±', 'è°·',
+ '車', '侯', '宓', '蓬', 'å…¨', '郗', 'ç', 'ä»°',
+ '秋', '仲', '伊', '宮', '甯', '仇', '欒', '暴',
+ '甘', '鈄', '厲', '戎', '祖', 'æ¦', '符', '劉',
+ '景', '詹', 'æŸ', 'é¾', '葉', '幸', 'å¸', '韶',
+ '郜', '黎', 'è–Š', 'è–„', 'å°', '宿', '白', '懷',
+ 'è’²', 'é‚°', '從', 'é„‚', 'ç´¢', 'å’¸', 'ç±', 'è³´',
+ 'å“', 'è—º', 'å± ', 'è’™', 'æ± ', 'å–¬', 'é™°', '鬱',
+ '胥', '能', 'è’¼', 'é›™', 'èž', '莘', '黨', '翟',
+ 'èš', 'è²¢', '勞', '逄', '姬', '申', '扶', 'å µ',
+ '冉', 'å®°', 'é…ˆ', 'é›', '郤', 'ç’©', 'æ¡‘', 'æ¡‚',
+ '濮', '牛', '壽', '通', '邊', '扈', '燕', '冀',
+ '郟', '浦', 'å°š', 'è¾²', '溫', '別', '莊', 'æ™',
+ '柴', '瞿', '閻', '充', '慕', '連', '茹', '習',
+ '宦', '艾', 'éš', '容', 'å‘', 'å¤', '易', 'æ…Ž',
+ '戈', 'å»–', '庾', '終', '暨', 'å±…', 'è¡¡', 'æ¥',
+ '都', '耿', '滿', '弘', '匡', '國', '文', '寇',
+ '廣', '祿', 'é—•', 'æ±', 'æ', '殳', '沃', '利',
+ '蔚', 'è¶Š', '夔', '隆', '師', 'éž', '厙', 'è¶',
+ 'æ™', '勾', 'æ•–', 'èž', '冷', '訾', 'è¾›', 'é—ž',
+ '那', '簡', '饒', '空', '曾', '毋', '沙', '乜',
+ '養', 'éž ', 'é ˆ', 'è±', 'å·¢', 'é—œ', 'è’¯', '相',
+ '查', 'åŽ', 'èŠ', 'ç´…', '游', '竺', '權', '逯',
+ 'è“‹', '益', 'æ¡“', 'å…¬', '万俟', 'å¸é¦¬', '上官',
+ 'æé™½', 'å¤ä¾¯', '諸葛', 'èžäºº', 'æ±æ–¹', '赫連',
+ '皇甫', 'å°‰é²', '公羊', '澹臺', '公冶', '宗政',
+ '濮陽', '淳于', '單于', '太å”', 'ç”³å± ', 'å…¬å«',
+ '仲å«', 'è»’è½…', '令ç‹', 'é¾é›¢', '宇文', 'é•·å«',
+ '慕容', '鮮于', 'é–丘', 'å¸å¾’', 'å¸ç©º', '亓官',
+ 'å¸å¯‡', '仉', 'ç£', 'å車', 'é¡“å«', '端木', '巫馬',
+ '公西', '漆雕', '樂æ£', '壤駟', '公良', 'æ‹“è·‹',
+ '夾谷', '宰父', 'ç©€æ¢', '晉', '楚', 'é–†', '法',
+ 'æ±', 'é„¢', 'æ¶‚', '欽', '段干', '百里', 'æ±éƒ',
+ 'å—é–€', '呼延', 'æ¸', 'æµ·', '羊舌', '微生', 'å²³',
+ '帥', 'ç·±', '亢', 'æ³', '後', '有', 'ç´', 'æ¢ä¸˜',
+ '左丘', 'æ±é–€', '西門', '商', '牟', '佘', 'ä½´',
+ '伯', '賞', 'å—å®®', '墨', '哈', 'è™', '笪', 'å¹´',
+ 'æ„›', '陽', '佟', '第五', '言', 'ç¦',
+ );
+
+ /**
+ * @link http://technology.chtsai.org/namefreq/
+ */
+ protected static $characterMale = array(
+ 'ä½³', '俊', 'ä¿¡', 'å‰', 'å‚‘', 'å† ', 'å›', '哲',
+ '嘉', 'å¨', '宇', '安', 'å®', 'å®—', '宜', 'å®¶',
+ 'åº', 'å»·', '建', 'å½¥', '心', 'å¿—', 'æ€', '承',
+ 'æ–‡', 'æŸ', '樺', 'ç‘‹', '穎', '美', 'ç¿°', 'è¯',
+ '詩', '豪', '賢', '軒', '銘', '霖',
+ );
+
+ protected static $characterFemale = array(
+ 'ä¼¶', '佩', 'ä½³', 'ä¾', 'å„€', 'å† ', 'å›', '嘉',
+ '如', '娟', '婉', 'å©·', '安', '宜', 'å®¶', 'åº',
+ '心', 'æ€', '怡', 'æƒ ', 'æ…§', 'æ–‡', '欣', 'æ¶µ',
+ 'æ·‘', '玲', 'çŠ', 'çª', 'ç¬', '瑜', '穎', 'ç‘',
+ 'ç±', '美', '芬', '芳', 'è¯', 'è', 'è±', '蓉',
+ 'è©©', '貞', 'éƒ', '鈺', 'é›…', '雯', 'éœ', '馨',
+ );
+
+ public static function randomName($pool, $n)
+ {
+ $name = '';
+ for ($i = 0; $i < $n; ++$i) {
+ $name .= static::randomElement($pool);
+ }
+ return $name;
+ }
+
+ public static function firstNameMale()
+ {
+ return static::randomName(static::$characterMale, mt_rand(1, 2));
+ }
+
+ public static function firstNameFemale()
+ {
+ return static::randomName(static::$characterFemale, mt_rand(1, 2));
+ }
+
+ public static function suffix()
+ {
+ return '';
+ }
+
+ /**
+ * @param string $gender Person::GENDER_MALE || Person::GENDER_FEMALE
+ *
+ * @see https://en.wikipedia.org/wiki/National_Identification_Card_(Republic_of_China)
+ *
+ * @return string Length 10 alphanumeric characters, begins with 1 latin character (birthplace),
+ * 1 number (gender) and then 8 numbers (the last one is check digit).
+ */
+ public function personalIdentityNumber($gender = null)
+ {
+ $birthPlace = self::randomKey(self::$idBirthplaceCode);
+ $birthPlaceCode = self::$idBirthplaceCode[$birthPlace];
+
+ $gender = ($gender != null) ? $gender : self::randomElement(array(self::GENDER_FEMALE, self::GENDER_MALE));
+ $genderCode = ($gender === self::GENDER_MALE) ? 1 : 2;
+
+ $randomNumberCode = self::randomNumber(7, true);
+
+ $codes = str_split($birthPlaceCode . $genderCode . $randomNumberCode);
+ $total = 0;
+
+ foreach ($codes as $key => $code) {
+ $total += $code * self::$idDigitValidator[$key];
+ }
+
+ $checkSumDigit = 10 - ($total % 10);
+
+ if ($checkSumDigit == 10) {
+ $checkSumDigit = 0;
+ }
+
+ $id = $birthPlace . $genderCode . $randomNumberCode . $checkSumDigit;
+
+ return $id;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/PhoneNumber.php b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/PhoneNumber.php
new file mode 100644
index 000000000..7c31a9791
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/Provider/zh_TW/PhoneNumber.php
@@ -0,0 +1,19 @@
+ 251:
+ $temp .= $chars[++$i];
+ // no break
+ case $ord > 247:
+ $temp .= $chars[++$i];
+ // no break
+ case $ord > 239:
+ $temp .= $chars[++$i];
+ // no break
+ case $ord > 223:
+ $temp .= $chars[++$i];
+ // no break
+ case $ord > 191:
+ $temp .= $chars[++$i];
+ // no break
+ }
+
+ $encoding[] = $temp;
+ }
+
+ return $encoding;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/UniqueGenerator.php b/vendor/fzaninotto/faker/src/Faker/UniqueGenerator.php
new file mode 100644
index 000000000..431f76531
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/UniqueGenerator.php
@@ -0,0 +1,58 @@
+unique()
+ */
+class UniqueGenerator
+{
+ protected $generator;
+ protected $maxRetries;
+ protected $uniques = array();
+
+ /**
+ * @param Generator $generator
+ * @param integer $maxRetries
+ */
+ public function __construct(Generator $generator, $maxRetries = 10000)
+ {
+ $this->generator = $generator;
+ $this->maxRetries = $maxRetries;
+ }
+
+ /**
+ * Catch and proxy all generator calls but return only unique values
+ * @param string $attribute
+ * @return mixed
+ */
+ public function __get($attribute)
+ {
+ return $this->__call($attribute, array());
+ }
+
+ /**
+ * Catch and proxy all generator calls with arguments but return only unique values
+ * @param string $name
+ * @param array $arguments
+ * @return mixed
+ */
+ public function __call($name, $arguments)
+ {
+ if (!isset($this->uniques[$name])) {
+ $this->uniques[$name] = array();
+ }
+ $i = 0;
+ do {
+ $res = call_user_func_array(array($this->generator, $name), $arguments);
+ $i++;
+ if ($i > $this->maxRetries) {
+ throw new \OverflowException(sprintf('Maximum retries of %d reached without finding a unique value', $this->maxRetries));
+ }
+ } while (array_key_exists(serialize($res), $this->uniques[$name]));
+ $this->uniques[$name][serialize($res)]= null;
+
+ return $res;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/Faker/ValidGenerator.php b/vendor/fzaninotto/faker/src/Faker/ValidGenerator.php
new file mode 100644
index 000000000..1352dfc00
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/Faker/ValidGenerator.php
@@ -0,0 +1,65 @@
+valid()
+ */
+class ValidGenerator
+{
+ protected $generator;
+ protected $validator;
+ protected $maxRetries;
+
+ /**
+ * @param Generator $generator
+ * @param callable|null $validator
+ * @param integer $maxRetries
+ */
+ public function __construct(Generator $generator, $validator = null, $maxRetries = 10000)
+ {
+ if (is_null($validator)) {
+ $validator = function () {
+ return true;
+ };
+ } elseif (!is_callable($validator)) {
+ throw new \InvalidArgumentException('valid() only accepts callables as first argument');
+ }
+ $this->generator = $generator;
+ $this->validator = $validator;
+ $this->maxRetries = $maxRetries;
+ }
+
+ /**
+ * Catch and proxy all generator calls but return only valid values
+ * @param string $attribute
+ *
+ * @return mixed
+ */
+ public function __get($attribute)
+ {
+ return $this->__call($attribute, array());
+ }
+
+ /**
+ * Catch and proxy all generator calls with arguments but return only valid values
+ * @param string $name
+ * @param array $arguments
+ *
+ * @return mixed
+ */
+ public function __call($name, $arguments)
+ {
+ $i = 0;
+ do {
+ $res = call_user_func_array(array($this->generator, $name), $arguments);
+ $i++;
+ if ($i > $this->maxRetries) {
+ throw new \OverflowException(sprintf('Maximum retries of %d reached without finding a valid value', $this->maxRetries));
+ }
+ } while (!call_user_func($this->validator, $res));
+
+ return $res;
+ }
+}
diff --git a/vendor/fzaninotto/faker/src/autoload.php b/vendor/fzaninotto/faker/src/autoload.php
new file mode 100644
index 000000000..f55914dee
--- /dev/null
+++ b/vendor/fzaninotto/faker/src/autoload.php
@@ -0,0 +1,26 @@
+ignoringCase());
+
+* Fixed Hamcrest_Core_IsInstanceOf to return false for native types.
+
+* Moved string-based matchers to Hamcrest_Text package.
+ StringContains, StringEndsWith, StringStartsWith, and SubstringMatcher
+
+* Hamcrest.php and Hamcrest_Matchers.php are now built from @factory doctags.
+ Added @factory doctag to every static factory method.
+
+* Hamcrest_Matchers and Hamcrest.php now import each matcher as-needed
+ and Hamcrest.php calls the matchers directly instead of Hamcrest_Matchers.
+
+
+== Version 0.3.0: Released Jul 26 2010 ==
+
+* Added running count to Hamcrest_MatcherAssert with methods to get and reset it.
+ This can be used by unit testing frameworks for reporting.
+
+* Added Hamcrest_Core_HasToString to assert return value of toString() or __toString().
+
+ assertThat($anObject, hasToString('foo'));
+
+* Added Hamcrest_Type_IsScalar to assert is_scalar().
+ Matches values of type bool, int, float, double, and string.
+
+ assertThat($count, scalarValue());
+ assertThat('foo', scalarValue());
+
+* Added Hamcrest_Collection package.
+
+ - IsEmptyTraversable
+ - IsTraversableWithSize
+
+ assertThat($iterator, emptyTraversable());
+ assertThat($iterator, traversableWithSize(5));
+
+* Added Hamcrest_Xml_HasXPath to assert XPath expressions or the content of nodes in an XML/HTML DOM.
+
+ assertThat($dom, hasXPath('books/book/title'));
+ assertThat($dom, hasXPath('books/book[contains(title, "Alice")]', 3));
+ assertThat($dom, hasXPath('books/book/title', 'Alice in Wonderland'));
+ assertThat($dom, hasXPath('count(books/book)', greaterThan(10)));
+
+* Added aliases to match the Java API.
+
+ hasEntry() -> hasKeyValuePair()
+ hasValue() -> hasItemInArray()
+ contains() -> arrayContaining()
+ containsInAnyOrder() -> arrayContainingInAnyOrder()
+
+* Added optional subtype to Hamcrest_TypeSafeMatcher to enforce object class or resource type.
+
+* Hamcrest_TypeSafeDiagnosingMatcher now extends Hamcrest_TypeSafeMatcher.
+
+
+== Version 0.2.0: Released Jul 14 2010 ==
+
+Issues Fixed: 109, 111, 114, 115
+
+* Description::appendValues() and appendValueList() accept Iterator and IteratorAggregate. [111]
+ BaseDescription::appendValue() handles IteratorAggregate.
+
+* assertThat() accepts a single boolean parameter and
+ wraps any non-Matcher third parameter with equalTo().
+
+* Removed null return value from assertThat(). [114]
+
+* Fixed wrong variable name in contains(). [109]
+
+* Added Hamcrest_Core_IsSet to assert isset().
+
+ assertThat(array('foo' => 'bar'), set('foo'));
+ assertThat(array('foo' => 'bar'), notSet('bar'));
+
+* Added Hamcrest_Core_IsTypeOf to assert built-in types with gettype(). [115]
+ Types: array, boolean, double, integer, null, object, resource, and string.
+ Note that gettype() returns "double" for float values.
+
+ assertThat($count, typeOf('integer'));
+ assertThat(3.14159, typeOf('double'));
+ assertThat(array('foo', 'bar'), typeOf('array'));
+ assertThat(new stdClass(), typeOf('object'));
+
+* Added type-specific matchers in new Hamcrest_Type package.
+
+ - IsArray
+ - IsBoolean
+ - IsDouble (includes float values)
+ - IsInteger
+ - IsObject
+ - IsResource
+ - IsString
+
+ assertThat($count, integerValue());
+ assertThat(3.14159, floatValue());
+ assertThat('foo', stringValue());
+
+* Added Hamcrest_Type_IsNumeric to assert is_numeric().
+ Matches values of type int and float/double or strings that are formatted as numbers.
+
+ assertThat(5, numericValue());
+ assertThat('-5e+3', numericValue());
+
+* Added Hamcrest_Type_IsCallable to assert is_callable().
+
+ assertThat('preg_match', callable());
+ assertThat(array('SomeClass', 'SomeMethod'), callable());
+ assertThat(array($object, 'SomeMethod'), callable());
+ assertThat($object, callable());
+ assertThat(function ($x, $y) { return $x + $y; }, callable());
+
+* Added Hamcrest_Text_MatchesPattern for regex matching with preg_match().
+
+ assertThat('foobar', matchesPattern('/o+b/'));
+
+* Added aliases:
+ - atLeast() for greaterThanOrEqualTo()
+ - atMost() for lessThanOrEqualTo()
+
+
+== Version 0.1.0: Released Jul 7 2010 ==
+
+* Created PEAR package
+
+* Core matchers
+
diff --git a/vendor/hamcrest/hamcrest-php/LICENSE.txt b/vendor/hamcrest/hamcrest-php/LICENSE.txt
new file mode 100644
index 000000000..91cd329a4
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/LICENSE.txt
@@ -0,0 +1,27 @@
+BSD License
+
+Copyright (c) 2000-2014, www.hamcrest.org
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions are met:
+
+Redistributions of source code must retain the above copyright notice, this list of
+conditions and the following disclaimer. Redistributions in binary form must reproduce
+the above copyright notice, this list of conditions and the following disclaimer in
+the documentation and/or other materials provided with the distribution.
+
+Neither the name of Hamcrest nor the names of its contributors may be used to endorse
+or promote products derived from this software without specific prior written
+permission.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
+EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
+SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
+TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
+WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
+DAMAGE.
diff --git a/vendor/hamcrest/hamcrest-php/README.md b/vendor/hamcrest/hamcrest-php/README.md
new file mode 100644
index 000000000..47c24f1fc
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/README.md
@@ -0,0 +1,51 @@
+This is the PHP port of Hamcrest Matchers
+=========================================
+
+[](https://scrutinizer-ci.com/g/hamcrest/hamcrest-php/)
+[](https://travis-ci.org/hamcrest/hamcrest-php)
+[](https://coveralls.io/r/hamcrest/hamcrest-php)
+
+Hamcrest is a matching library originally written for Java, but
+subsequently ported to many other languages. hamcrest-php is the
+official PHP port of Hamcrest and essentially follows a literal
+translation of the original Java API for Hamcrest, with a few
+Exceptions, mostly down to PHP language barriers:
+
+ 1. `instanceOf($theClass)` is actually `anInstanceOf($theClass)`
+
+ 2. `both(containsString('a'))->and(containsString('b'))`
+ is actually `both(containsString('a'))->andAlso(containsString('b'))`
+
+ 3. `either(containsString('a'))->or(containsString('b'))`
+ is actually `either(containsString('a'))->orElse(containsString('b'))`
+
+ 4. Unless it would be non-semantic for a matcher to do so, hamcrest-php
+ allows dynamic typing for it's input, in "the PHP way". Exception are
+ where semantics surrounding the type itself would suggest otherwise,
+ such as stringContains() and greaterThan().
+
+ 5. Several official matchers have not been ported because they don't
+ make sense or don't apply in PHP:
+
+ - `typeCompatibleWith($theClass)`
+ - `eventFrom($source)`
+ - `hasProperty($name)` **
+ - `samePropertyValuesAs($obj)` **
+
+ 6. When most of the collections matchers are finally ported, PHP-specific
+ aliases will probably be created due to a difference in naming
+ conventions between Java's Arrays, Collections, Sets and Maps compared
+ with PHP's Arrays.
+
+Usage
+-----
+
+Hamcrest matchers are easy to use as:
+
+```php
+Hamcrest_MatcherAssert::assertThat('a', Hamcrest_Matchers::equalToIgnoringCase('A'));
+```
+
+ ** [Unless we consider POPO's (Plain Old PHP Objects) akin to JavaBeans]
+ - The POPO thing is a joke. Java devs coin the term POJO's (Plain Old
+ Java Objects).
diff --git a/vendor/hamcrest/hamcrest-php/TODO.txt b/vendor/hamcrest/hamcrest-php/TODO.txt
new file mode 100644
index 000000000..92e1190d8
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/TODO.txt
@@ -0,0 +1,22 @@
+Still TODO Before Complete for PHP
+----------------------------------
+
+Port:
+
+ - Hamcrest_Collection_*
+ - IsCollectionWithSize
+ - IsEmptyCollection
+ - IsIn
+ - IsTraversableContainingInAnyOrder
+ - IsTraversableContainingInOrder
+ - IsMapContaining (aliases)
+
+Aliasing/Deprecation (questionable):
+
+ - Find and fix any factory methods that start with "is".
+
+Namespaces:
+
+ - Investigate adding PHP 5.3+ namespace support in a way that still permits
+ use in PHP 5.2.
+ - Other than a parallel codebase, I don't see how this could be possible.
diff --git a/vendor/hamcrest/hamcrest-php/composer.json b/vendor/hamcrest/hamcrest-php/composer.json
new file mode 100644
index 000000000..a1b48c1f6
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/composer.json
@@ -0,0 +1,32 @@
+{
+ "name": "hamcrest/hamcrest-php",
+ "type": "library",
+ "description": "This is the PHP port of Hamcrest Matchers",
+ "keywords": ["test"],
+ "license": "BSD",
+ "authors": [
+ ],
+
+ "autoload": {
+ "classmap": ["hamcrest"],
+ "files": ["hamcrest/Hamcrest.php"]
+ },
+ "autoload-dev": {
+ "classmap": ["tests", "generator"]
+ },
+
+ "require": {
+ "php": ">=5.3.2"
+ },
+
+ "require-dev": {
+ "satooshi/php-coveralls": "dev-master",
+ "phpunit/php-file-iterator": "1.3.3"
+ },
+
+ "replace": {
+ "kodova/hamcrest-php": "*",
+ "davedevelopment/hamcrest-php": "*",
+ "cordoval/hamcrest-php": "*"
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/FactoryCall.php b/vendor/hamcrest/hamcrest-php/generator/FactoryCall.php
new file mode 100644
index 000000000..83965b2ae
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/FactoryCall.php
@@ -0,0 +1,41 @@
+method = $method;
+ $this->name = $name;
+ }
+
+ public function getMethod()
+ {
+ return $this->method;
+ }
+
+ public function getName()
+ {
+ return $this->name;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/FactoryClass.php b/vendor/hamcrest/hamcrest-php/generator/FactoryClass.php
new file mode 100644
index 000000000..0c6bf78d7
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/FactoryClass.php
@@ -0,0 +1,72 @@
+file = $file;
+ $this->reflector = $class;
+ $this->extractFactoryMethods();
+ }
+
+ public function extractFactoryMethods()
+ {
+ $this->methods = array();
+ foreach ($this->getPublicStaticMethods() as $method) {
+ if ($method->isFactory()) {
+// echo $this->getName() . '::' . $method->getName() . ' : ' . count($method->getCalls()) . PHP_EOL;
+ $this->methods[] = $method;
+ }
+ }
+ }
+
+ public function getPublicStaticMethods()
+ {
+ $methods = array();
+ foreach ($this->reflector->getMethods(ReflectionMethod::IS_STATIC) as $method) {
+ if ($method->isPublic() && $method->getDeclaringClass() == $this->reflector) {
+ $methods[] = new FactoryMethod($this, $method);
+ }
+ }
+ return $methods;
+ }
+
+ public function getFile()
+ {
+ return $this->file;
+ }
+
+ public function getName()
+ {
+ return $this->reflector->name;
+ }
+
+ public function isFactory()
+ {
+ return !empty($this->methods);
+ }
+
+ public function getMethods()
+ {
+ return $this->methods;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/FactoryFile.php b/vendor/hamcrest/hamcrest-php/generator/FactoryFile.php
new file mode 100644
index 000000000..ac3d6c7d3
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/FactoryFile.php
@@ -0,0 +1,122 @@
+file = $file;
+ $this->indent = $indent;
+ }
+
+ abstract public function addCall(FactoryCall $call);
+
+ abstract public function build();
+
+ public function addFileHeader()
+ {
+ $this->code = '';
+ $this->addPart('file_header');
+ }
+
+ public function addPart($name)
+ {
+ $this->addCode($this->readPart($name));
+ }
+
+ public function addCode($code)
+ {
+ $this->code .= $code;
+ }
+
+ public function readPart($name)
+ {
+ return file_get_contents(__DIR__ . "/parts/$name.txt");
+ }
+
+ public function generateFactoryCall(FactoryCall $call)
+ {
+ $method = $call->getMethod();
+ $code = $method->getComment($this->indent) . PHP_EOL;
+ $code .= $this->generateDeclaration($call->getName(), $method);
+ // $code .= $this->generateImport($method);
+ $code .= $this->generateCall($method);
+ $code .= $this->generateClosing();
+ return $code;
+ }
+
+ public function generateDeclaration($name, FactoryMethod $method)
+ {
+ $code = $this->indent . $this->getDeclarationModifiers()
+ . 'function ' . $name . '('
+ . $this->generateDeclarationArguments($method)
+ . ')' . PHP_EOL . $this->indent . '{' . PHP_EOL;
+ return $code;
+ }
+
+ public function getDeclarationModifiers()
+ {
+ return '';
+ }
+
+ public function generateDeclarationArguments(FactoryMethod $method)
+ {
+ if ($method->acceptsVariableArguments()) {
+ return '/* args... */';
+ } else {
+ return $method->getParameterDeclarations();
+ }
+ }
+
+ public function generateImport(FactoryMethod $method)
+ {
+ return $this->indent . self::INDENT . "require_once '" . $method->getClass()->getFile() . "';" . PHP_EOL;
+ }
+
+ public function generateCall(FactoryMethod $method)
+ {
+ $code = '';
+ if ($method->acceptsVariableArguments()) {
+ $code .= $this->indent . self::INDENT . '$args = func_get_args();' . PHP_EOL;
+ }
+
+ $code .= $this->indent . self::INDENT . 'return ';
+ if ($method->acceptsVariableArguments()) {
+ $code .= 'call_user_func_array(array(\''
+ . '\\' . $method->getClassName() . '\', \''
+ . $method->getName() . '\'), $args);' . PHP_EOL;
+ } else {
+ $code .= '\\' . $method->getClassName() . '::'
+ . $method->getName() . '('
+ . $method->getParameterInvocations() . ');' . PHP_EOL;
+ }
+
+ return $code;
+ }
+
+ public function generateClosing()
+ {
+ return $this->indent . '}' . PHP_EOL;
+ }
+
+ public function write()
+ {
+ file_put_contents($this->file, $this->code);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/FactoryGenerator.php b/vendor/hamcrest/hamcrest-php/generator/FactoryGenerator.php
new file mode 100644
index 000000000..37f80b6e9
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/FactoryGenerator.php
@@ -0,0 +1,115 @@
+path = $path;
+ $this->factoryFiles = array();
+ }
+
+ public function addFactoryFile(FactoryFile $factoryFile)
+ {
+ $this->factoryFiles[] = $factoryFile;
+ }
+
+ public function generate()
+ {
+ $classes = $this->getClassesWithFactoryMethods();
+ foreach ($classes as $class) {
+ foreach ($class->getMethods() as $method) {
+ foreach ($method->getCalls() as $call) {
+ foreach ($this->factoryFiles as $file) {
+ $file->addCall($call);
+ }
+ }
+ }
+ }
+ }
+
+ public function write()
+ {
+ foreach ($this->factoryFiles as $file) {
+ $file->build();
+ $file->write();
+ }
+ }
+
+ public function getClassesWithFactoryMethods()
+ {
+ $classes = array();
+ $files = $this->getSortedFiles();
+ foreach ($files as $file) {
+ $class = $this->getFactoryClass($file);
+ if ($class !== null) {
+ $classes[] = $class;
+ }
+ }
+
+ return $classes;
+ }
+
+ public function getSortedFiles()
+ {
+ $iter = \File_Iterator_Factory::getFileIterator($this->path, '.php');
+ $files = array();
+ foreach ($iter as $file) {
+ $files[] = $file;
+ }
+ sort($files, SORT_STRING);
+
+ return $files;
+ }
+
+ public function getFactoryClass($file)
+ {
+ $name = $this->getFactoryClassName($file);
+ if ($name !== null) {
+ require_once $file;
+
+ if (class_exists($name)) {
+ $class = new FactoryClass(substr($file, strpos($file, 'Hamcrest/')), new ReflectionClass($name));
+ if ($class->isFactory()) {
+ return $class;
+ }
+ }
+ }
+
+ return null;
+ }
+
+ public function getFactoryClassName($file)
+ {
+ $content = file_get_contents($file);
+ if (preg_match('/namespace\s+(.+);/', $content, $namespace)
+ && preg_match('/\n\s*class\s+(\w+)\s+extends\b/', $content, $className)
+ && preg_match('/@factory\b/', $content)
+ ) {
+ return $namespace[1] . '\\' . $className[1];
+ }
+
+ return null;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/FactoryMethod.php b/vendor/hamcrest/hamcrest-php/generator/FactoryMethod.php
new file mode 100644
index 000000000..44f8dc510
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/FactoryMethod.php
@@ -0,0 +1,231 @@
+class = $class;
+ $this->reflector = $reflector;
+ $this->extractCommentWithoutLeadingShashesAndStars();
+ $this->extractFactoryNamesFromComment();
+ $this->extractParameters();
+ }
+
+ public function extractCommentWithoutLeadingShashesAndStars()
+ {
+ $this->comment = explode("\n", $this->reflector->getDocComment());
+ foreach ($this->comment as &$line) {
+ $line = preg_replace('#^\s*(/\\*+|\\*+/|\\*)\s?#', '', $line);
+ }
+ $this->trimLeadingBlankLinesFromComment();
+ $this->trimTrailingBlankLinesFromComment();
+ }
+
+ public function trimLeadingBlankLinesFromComment()
+ {
+ while (count($this->comment) > 0) {
+ $line = array_shift($this->comment);
+ if (trim($line) != '') {
+ array_unshift($this->comment, $line);
+ break;
+ }
+ }
+ }
+
+ public function trimTrailingBlankLinesFromComment()
+ {
+ while (count($this->comment) > 0) {
+ $line = array_pop($this->comment);
+ if (trim($line) != '') {
+ array_push($this->comment, $line);
+ break;
+ }
+ }
+ }
+
+ public function extractFactoryNamesFromComment()
+ {
+ $this->calls = array();
+ for ($i = 0; $i < count($this->comment); $i++) {
+ if ($this->extractFactoryNamesFromLine($this->comment[$i])) {
+ unset($this->comment[$i]);
+ }
+ }
+ $this->trimTrailingBlankLinesFromComment();
+ }
+
+ public function extractFactoryNamesFromLine($line)
+ {
+ if (preg_match('/^\s*@factory(\s+(.+))?$/', $line, $match)) {
+ $this->createCalls(
+ $this->extractFactoryNamesFromAnnotation(
+ isset($match[2]) ? trim($match[2]) : null
+ )
+ );
+ return true;
+ }
+ return false;
+ }
+
+ public function extractFactoryNamesFromAnnotation($value)
+ {
+ $primaryName = $this->reflector->getName();
+ if (empty($value)) {
+ return array($primaryName);
+ }
+ preg_match_all('/(\.{3}|-|[a-zA-Z_][a-zA-Z_0-9]*)/', $value, $match);
+ $names = $match[0];
+ if (in_array('...', $names)) {
+ $this->isVarArgs = true;
+ }
+ if (!in_array('-', $names) && !in_array($primaryName, $names)) {
+ array_unshift($names, $primaryName);
+ }
+ return $names;
+ }
+
+ public function createCalls(array $names)
+ {
+ $names = array_unique($names);
+ foreach ($names as $name) {
+ if ($name != '-' && $name != '...') {
+ $this->calls[] = new FactoryCall($this, $name);
+ }
+ }
+ }
+
+ public function extractParameters()
+ {
+ $this->parameters = array();
+ if (!$this->isVarArgs) {
+ foreach ($this->reflector->getParameters() as $parameter) {
+ $this->parameters[] = new FactoryParameter($this, $parameter);
+ }
+ }
+ }
+
+ public function getParameterDeclarations()
+ {
+ if ($this->isVarArgs || !$this->hasParameters()) {
+ return '';
+ }
+ $params = array();
+ foreach ($this->parameters as /** @var $parameter FactoryParameter */
+ $parameter) {
+ $params[] = $parameter->getDeclaration();
+ }
+ return implode(', ', $params);
+ }
+
+ public function getParameterInvocations()
+ {
+ if ($this->isVarArgs) {
+ return '';
+ }
+ $params = array();
+ foreach ($this->parameters as $parameter) {
+ $params[] = $parameter->getInvocation();
+ }
+ return implode(', ', $params);
+ }
+
+
+ public function getClass()
+ {
+ return $this->class;
+ }
+
+ public function getClassName()
+ {
+ return $this->class->getName();
+ }
+
+ public function getName()
+ {
+ return $this->reflector->name;
+ }
+
+ public function isFactory()
+ {
+ return count($this->calls) > 0;
+ }
+
+ public function getCalls()
+ {
+ return $this->calls;
+ }
+
+ public function acceptsVariableArguments()
+ {
+ return $this->isVarArgs;
+ }
+
+ public function hasParameters()
+ {
+ return !empty($this->parameters);
+ }
+
+ public function getParameters()
+ {
+ return $this->parameters;
+ }
+
+ public function getFullName()
+ {
+ return $this->getClassName() . '::' . $this->getName();
+ }
+
+ public function getCommentText()
+ {
+ return implode(PHP_EOL, $this->comment);
+ }
+
+ public function getComment($indent = '')
+ {
+ $comment = $indent . '/**';
+ foreach ($this->comment as $line) {
+ $comment .= PHP_EOL . rtrim($indent . ' * ' . $line);
+ }
+ $comment .= PHP_EOL . $indent . ' */';
+ return $comment;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/FactoryParameter.php b/vendor/hamcrest/hamcrest-php/generator/FactoryParameter.php
new file mode 100644
index 000000000..93a76b38d
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/FactoryParameter.php
@@ -0,0 +1,69 @@
+method = $method;
+ $this->reflector = $reflector;
+ }
+
+ public function getDeclaration()
+ {
+ if ($this->reflector->isArray()) {
+ $code = 'array ';
+ } else {
+ $class = $this->reflector->getClass();
+ if ($class !== null) {
+ $code = '\\' . $class->name . ' ';
+ } else {
+ $code = '';
+ }
+ }
+ $code .= '$' . $this->reflector->name;
+ if ($this->reflector->isOptional()) {
+ $default = $this->reflector->getDefaultValue();
+ if (is_null($default)) {
+ $default = 'null';
+ } elseif (is_bool($default)) {
+ $default = $default ? 'true' : 'false';
+ } elseif (is_string($default)) {
+ $default = "'" . $default . "'";
+ } elseif (is_numeric($default)) {
+ $default = strval($default);
+ } elseif (is_array($default)) {
+ $default = 'array()';
+ } else {
+ echo 'Warning: unknown default type for ' . $this->getMethod()->getFullName() . PHP_EOL;
+ var_dump($default);
+ $default = 'null';
+ }
+ $code .= ' = ' . $default;
+ }
+ return $code;
+ }
+
+ public function getInvocation()
+ {
+ return '$' . $this->reflector->name;
+ }
+
+ public function getMethod()
+ {
+ return $this->method;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/GlobalFunctionFile.php b/vendor/hamcrest/hamcrest-php/generator/GlobalFunctionFile.php
new file mode 100644
index 000000000..5ee1b69f0
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/GlobalFunctionFile.php
@@ -0,0 +1,42 @@
+functions = '';
+ }
+
+ public function addCall(FactoryCall $call)
+ {
+ $this->functions .= PHP_EOL . $this->generateFactoryCall($call);
+ }
+
+ public function build()
+ {
+ $this->addFileHeader();
+ $this->addPart('functions_imports');
+ $this->addPart('functions_header');
+ $this->addCode($this->functions);
+ $this->addPart('functions_footer');
+ }
+
+ public function generateFactoryCall(FactoryCall $call)
+ {
+ $code = "if (!function_exists('{$call->getName()}')) {";
+ $code.= parent::generateFactoryCall($call);
+ $code.= "}\n";
+
+ return $code;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/StaticMethodFile.php b/vendor/hamcrest/hamcrest-php/generator/StaticMethodFile.php
new file mode 100644
index 000000000..44cec02f0
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/StaticMethodFile.php
@@ -0,0 +1,38 @@
+methods = '';
+ }
+
+ public function addCall(FactoryCall $call)
+ {
+ $this->methods .= PHP_EOL . $this->generateFactoryCall($call);
+ }
+
+ public function getDeclarationModifiers()
+ {
+ return 'public static ';
+ }
+
+ public function build()
+ {
+ $this->addFileHeader();
+ $this->addPart('matchers_imports');
+ $this->addPart('matchers_header');
+ $this->addCode($this->methods);
+ $this->addPart('matchers_footer');
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/parts/file_header.txt b/vendor/hamcrest/hamcrest-php/generator/parts/file_header.txt
new file mode 100644
index 000000000..7b352e447
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/parts/file_header.txt
@@ -0,0 +1,7 @@
+
+ * //With an identifier
+ * assertThat("assertion identifier", $apple->flavour(), equalTo("tasty"));
+ * //Without an identifier
+ * assertThat($apple->flavour(), equalTo("tasty"));
+ * //Evaluating a boolean expression
+ * assertThat("some error", $a > $b);
+ *
+ */
+ function assertThat()
+ {
+ $args = func_get_args();
+ call_user_func_array(
+ array('Hamcrest\MatcherAssert', 'assertThat'),
+ $args
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/parts/functions_imports.txt b/vendor/hamcrest/hamcrest-php/generator/parts/functions_imports.txt
new file mode 100644
index 000000000..e69de29bb
diff --git a/vendor/hamcrest/hamcrest-php/generator/parts/matchers_footer.txt b/vendor/hamcrest/hamcrest-php/generator/parts/matchers_footer.txt
new file mode 100644
index 000000000..5c34318c2
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/parts/matchers_footer.txt
@@ -0,0 +1 @@
+}
diff --git a/vendor/hamcrest/hamcrest-php/generator/parts/matchers_header.txt b/vendor/hamcrest/hamcrest-php/generator/parts/matchers_header.txt
new file mode 100644
index 000000000..4f8bb2b7b
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/parts/matchers_header.txt
@@ -0,0 +1,7 @@
+
+
+/**
+ * A series of static factories for all hamcrest matchers.
+ */
+class Matchers
+{
diff --git a/vendor/hamcrest/hamcrest-php/generator/parts/matchers_imports.txt b/vendor/hamcrest/hamcrest-php/generator/parts/matchers_imports.txt
new file mode 100644
index 000000000..7dd684953
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/parts/matchers_imports.txt
@@ -0,0 +1,2 @@
+
+namespace Hamcrest;
\ No newline at end of file
diff --git a/vendor/hamcrest/hamcrest-php/generator/run.php b/vendor/hamcrest/hamcrest-php/generator/run.php
new file mode 100644
index 000000000..924d752ff
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/generator/run.php
@@ -0,0 +1,37 @@
+addFactoryFile(new StaticMethodFile(STATIC_MATCHERS_FILE));
+$generator->addFactoryFile(new GlobalFunctionFile(GLOBAL_FUNCTIONS_FILE));
+$generator->generate();
+$generator->write();
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest.php
new file mode 100644
index 000000000..8a719eb3a
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest.php
@@ -0,0 +1,805 @@
+
+ * //With an identifier
+ * assertThat("assertion identifier", $apple->flavour(), equalTo("tasty"));
+ * //Without an identifier
+ * assertThat($apple->flavour(), equalTo("tasty"));
+ * //Evaluating a boolean expression
+ * assertThat("some error", $a > $b);
+ *
+ */
+ function assertThat()
+ {
+ $args = func_get_args();
+ call_user_func_array(
+ array('Hamcrest\MatcherAssert', 'assertThat'),
+ $args
+ );
+ }
+}
+
+if (!function_exists('anArray')) { /**
+ * Evaluates to true only if each $matcher[$i] is satisfied by $array[$i].
+ */
+ function anArray(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Arrays\IsArray', 'anArray'), $args);
+ }
+}
+
+if (!function_exists('hasItemInArray')) { /**
+ * Evaluates to true if any item in an array satisfies the given matcher.
+ *
+ * @param mixed $item as a {@link Hamcrest\Matcher} or a value.
+ *
+ * @return \Hamcrest\Arrays\IsArrayContaining
+ */
+ function hasItemInArray($item)
+ {
+ return \Hamcrest\Arrays\IsArrayContaining::hasItemInArray($item);
+ }
+}
+
+if (!function_exists('hasValue')) { /**
+ * Evaluates to true if any item in an array satisfies the given matcher.
+ *
+ * @param mixed $item as a {@link Hamcrest\Matcher} or a value.
+ *
+ * @return \Hamcrest\Arrays\IsArrayContaining
+ */
+ function hasValue($item)
+ {
+ return \Hamcrest\Arrays\IsArrayContaining::hasItemInArray($item);
+ }
+}
+
+if (!function_exists('arrayContainingInAnyOrder')) { /**
+ * An array with elements that match the given matchers.
+ */
+ function arrayContainingInAnyOrder(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Arrays\IsArrayContainingInAnyOrder', 'arrayContainingInAnyOrder'), $args);
+ }
+}
+
+if (!function_exists('containsInAnyOrder')) { /**
+ * An array with elements that match the given matchers.
+ */
+ function containsInAnyOrder(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Arrays\IsArrayContainingInAnyOrder', 'arrayContainingInAnyOrder'), $args);
+ }
+}
+
+if (!function_exists('arrayContaining')) { /**
+ * An array with elements that match the given matchers in the same order.
+ */
+ function arrayContaining(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Arrays\IsArrayContainingInOrder', 'arrayContaining'), $args);
+ }
+}
+
+if (!function_exists('contains')) { /**
+ * An array with elements that match the given matchers in the same order.
+ */
+ function contains(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Arrays\IsArrayContainingInOrder', 'arrayContaining'), $args);
+ }
+}
+
+if (!function_exists('hasKeyInArray')) { /**
+ * Evaluates to true if any key in an array matches the given matcher.
+ *
+ * @param mixed $key as a {@link Hamcrest\Matcher} or a value.
+ *
+ * @return \Hamcrest\Arrays\IsArrayContainingKey
+ */
+ function hasKeyInArray($key)
+ {
+ return \Hamcrest\Arrays\IsArrayContainingKey::hasKeyInArray($key);
+ }
+}
+
+if (!function_exists('hasKey')) { /**
+ * Evaluates to true if any key in an array matches the given matcher.
+ *
+ * @param mixed $key as a {@link Hamcrest\Matcher} or a value.
+ *
+ * @return \Hamcrest\Arrays\IsArrayContainingKey
+ */
+ function hasKey($key)
+ {
+ return \Hamcrest\Arrays\IsArrayContainingKey::hasKeyInArray($key);
+ }
+}
+
+if (!function_exists('hasKeyValuePair')) { /**
+ * Test if an array has both an key and value in parity with each other.
+ */
+ function hasKeyValuePair($key, $value)
+ {
+ return \Hamcrest\Arrays\IsArrayContainingKeyValuePair::hasKeyValuePair($key, $value);
+ }
+}
+
+if (!function_exists('hasEntry')) { /**
+ * Test if an array has both an key and value in parity with each other.
+ */
+ function hasEntry($key, $value)
+ {
+ return \Hamcrest\Arrays\IsArrayContainingKeyValuePair::hasKeyValuePair($key, $value);
+ }
+}
+
+if (!function_exists('arrayWithSize')) { /**
+ * Does array size satisfy a given matcher?
+ *
+ * @param \Hamcrest\Matcher|int $size as a {@link Hamcrest\Matcher} or a value.
+ *
+ * @return \Hamcrest\Arrays\IsArrayWithSize
+ */
+ function arrayWithSize($size)
+ {
+ return \Hamcrest\Arrays\IsArrayWithSize::arrayWithSize($size);
+ }
+}
+
+if (!function_exists('emptyArray')) { /**
+ * Matches an empty array.
+ */
+ function emptyArray()
+ {
+ return \Hamcrest\Arrays\IsArrayWithSize::emptyArray();
+ }
+}
+
+if (!function_exists('nonEmptyArray')) { /**
+ * Matches an empty array.
+ */
+ function nonEmptyArray()
+ {
+ return \Hamcrest\Arrays\IsArrayWithSize::nonEmptyArray();
+ }
+}
+
+if (!function_exists('emptyTraversable')) { /**
+ * Returns true if traversable is empty.
+ */
+ function emptyTraversable()
+ {
+ return \Hamcrest\Collection\IsEmptyTraversable::emptyTraversable();
+ }
+}
+
+if (!function_exists('nonEmptyTraversable')) { /**
+ * Returns true if traversable is not empty.
+ */
+ function nonEmptyTraversable()
+ {
+ return \Hamcrest\Collection\IsEmptyTraversable::nonEmptyTraversable();
+ }
+}
+
+if (!function_exists('traversableWithSize')) { /**
+ * Does traversable size satisfy a given matcher?
+ */
+ function traversableWithSize($size)
+ {
+ return \Hamcrest\Collection\IsTraversableWithSize::traversableWithSize($size);
+ }
+}
+
+if (!function_exists('allOf')) { /**
+ * Evaluates to true only if ALL of the passed in matchers evaluate to true.
+ */
+ function allOf(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Core\AllOf', 'allOf'), $args);
+ }
+}
+
+if (!function_exists('anyOf')) { /**
+ * Evaluates to true if ANY of the passed in matchers evaluate to true.
+ */
+ function anyOf(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Core\AnyOf', 'anyOf'), $args);
+ }
+}
+
+if (!function_exists('noneOf')) { /**
+ * Evaluates to false if ANY of the passed in matchers evaluate to true.
+ */
+ function noneOf(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Core\AnyOf', 'noneOf'), $args);
+ }
+}
+
+if (!function_exists('both')) { /**
+ * This is useful for fluently combining matchers that must both pass.
+ * For example:
+ *
+ * assertThat($string, both(containsString("a"))->andAlso(containsString("b")));
+ *
+ */
+ function both(\Hamcrest\Matcher $matcher)
+ {
+ return \Hamcrest\Core\CombinableMatcher::both($matcher);
+ }
+}
+
+if (!function_exists('either')) { /**
+ * This is useful for fluently combining matchers where either may pass,
+ * for example:
+ *
+ * assertThat($string, either(containsString("a"))->orElse(containsString("b")));
+ *
+ */
+ function either(\Hamcrest\Matcher $matcher)
+ {
+ return \Hamcrest\Core\CombinableMatcher::either($matcher);
+ }
+}
+
+if (!function_exists('describedAs')) { /**
+ * Wraps an existing matcher and overrides the description when it fails.
+ */
+ function describedAs(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Core\DescribedAs', 'describedAs'), $args);
+ }
+}
+
+if (!function_exists('everyItem')) { /**
+ * @param Matcher $itemMatcher
+ * A matcher to apply to every element in an array.
+ *
+ * @return \Hamcrest\Core\Every
+ * Evaluates to TRUE for a collection in which every item matches $itemMatcher
+ */
+ function everyItem(\Hamcrest\Matcher $itemMatcher)
+ {
+ return \Hamcrest\Core\Every::everyItem($itemMatcher);
+ }
+}
+
+if (!function_exists('hasToString')) { /**
+ * Does array size satisfy a given matcher?
+ */
+ function hasToString($matcher)
+ {
+ return \Hamcrest\Core\HasToString::hasToString($matcher);
+ }
+}
+
+if (!function_exists('is')) { /**
+ * Decorates another Matcher, retaining the behavior but allowing tests
+ * to be slightly more expressive.
+ *
+ * For example: assertThat($cheese, equalTo($smelly))
+ * vs. assertThat($cheese, is(equalTo($smelly)))
+ */
+ function is($value)
+ {
+ return \Hamcrest\Core\Is::is($value);
+ }
+}
+
+if (!function_exists('anything')) { /**
+ * This matcher always evaluates to true.
+ *
+ * @param string $description A meaningful string used when describing itself.
+ *
+ * @return \Hamcrest\Core\IsAnything
+ */
+ function anything($description = 'ANYTHING')
+ {
+ return \Hamcrest\Core\IsAnything::anything($description);
+ }
+}
+
+if (!function_exists('hasItem')) { /**
+ * Test if the value is an array containing this matcher.
+ *
+ * Example:
+ *
+ * assertThat(array('a', 'b'), hasItem(equalTo('b')));
+ * //Convenience defaults to equalTo()
+ * assertThat(array('a', 'b'), hasItem('b'));
+ *
+ */
+ function hasItem(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Core\IsCollectionContaining', 'hasItem'), $args);
+ }
+}
+
+if (!function_exists('hasItems')) { /**
+ * Test if the value is an array containing elements that match all of these
+ * matchers.
+ *
+ * Example:
+ *
+ * assertThat(array('a', 'b', 'c'), hasItems(equalTo('a'), equalTo('b')));
+ *
+ */
+ function hasItems(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Core\IsCollectionContaining', 'hasItems'), $args);
+ }
+}
+
+if (!function_exists('equalTo')) { /**
+ * Is the value equal to another value, as tested by the use of the "=="
+ * comparison operator?
+ */
+ function equalTo($item)
+ {
+ return \Hamcrest\Core\IsEqual::equalTo($item);
+ }
+}
+
+if (!function_exists('identicalTo')) { /**
+ * Tests of the value is identical to $value as tested by the "===" operator.
+ */
+ function identicalTo($value)
+ {
+ return \Hamcrest\Core\IsIdentical::identicalTo($value);
+ }
+}
+
+if (!function_exists('anInstanceOf')) { /**
+ * Is the value an instance of a particular type?
+ * This version assumes no relationship between the required type and
+ * the signature of the method that sets it up, for example in
+ * assertThat($anObject, anInstanceOf('Thing'));
+ */
+ function anInstanceOf($theClass)
+ {
+ return \Hamcrest\Core\IsInstanceOf::anInstanceOf($theClass);
+ }
+}
+
+if (!function_exists('any')) { /**
+ * Is the value an instance of a particular type?
+ * This version assumes no relationship between the required type and
+ * the signature of the method that sets it up, for example in
+ * assertThat($anObject, anInstanceOf('Thing'));
+ */
+ function any($theClass)
+ {
+ return \Hamcrest\Core\IsInstanceOf::anInstanceOf($theClass);
+ }
+}
+
+if (!function_exists('not')) { /**
+ * Matches if value does not match $value.
+ */
+ function not($value)
+ {
+ return \Hamcrest\Core\IsNot::not($value);
+ }
+}
+
+if (!function_exists('nullValue')) { /**
+ * Matches if value is null.
+ */
+ function nullValue()
+ {
+ return \Hamcrest\Core\IsNull::nullValue();
+ }
+}
+
+if (!function_exists('notNullValue')) { /**
+ * Matches if value is not null.
+ */
+ function notNullValue()
+ {
+ return \Hamcrest\Core\IsNull::notNullValue();
+ }
+}
+
+if (!function_exists('sameInstance')) { /**
+ * Creates a new instance of IsSame.
+ *
+ * @param mixed $object
+ * The predicate evaluates to true only when the argument is
+ * this object.
+ *
+ * @return \Hamcrest\Core\IsSame
+ */
+ function sameInstance($object)
+ {
+ return \Hamcrest\Core\IsSame::sameInstance($object);
+ }
+}
+
+if (!function_exists('typeOf')) { /**
+ * Is the value a particular built-in type?
+ */
+ function typeOf($theType)
+ {
+ return \Hamcrest\Core\IsTypeOf::typeOf($theType);
+ }
+}
+
+if (!function_exists('set')) { /**
+ * Matches if value (class, object, or array) has named $property.
+ */
+ function set($property)
+ {
+ return \Hamcrest\Core\Set::set($property);
+ }
+}
+
+if (!function_exists('notSet')) { /**
+ * Matches if value (class, object, or array) does not have named $property.
+ */
+ function notSet($property)
+ {
+ return \Hamcrest\Core\Set::notSet($property);
+ }
+}
+
+if (!function_exists('closeTo')) { /**
+ * Matches if value is a number equal to $value within some range of
+ * acceptable error $delta.
+ */
+ function closeTo($value, $delta)
+ {
+ return \Hamcrest\Number\IsCloseTo::closeTo($value, $delta);
+ }
+}
+
+if (!function_exists('comparesEqualTo')) { /**
+ * The value is not > $value, nor < $value.
+ */
+ function comparesEqualTo($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::comparesEqualTo($value);
+ }
+}
+
+if (!function_exists('greaterThan')) { /**
+ * The value is > $value.
+ */
+ function greaterThan($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::greaterThan($value);
+ }
+}
+
+if (!function_exists('greaterThanOrEqualTo')) { /**
+ * The value is >= $value.
+ */
+ function greaterThanOrEqualTo($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::greaterThanOrEqualTo($value);
+ }
+}
+
+if (!function_exists('atLeast')) { /**
+ * The value is >= $value.
+ */
+ function atLeast($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::greaterThanOrEqualTo($value);
+ }
+}
+
+if (!function_exists('lessThan')) { /**
+ * The value is < $value.
+ */
+ function lessThan($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::lessThan($value);
+ }
+}
+
+if (!function_exists('lessThanOrEqualTo')) { /**
+ * The value is <= $value.
+ */
+ function lessThanOrEqualTo($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::lessThanOrEqualTo($value);
+ }
+}
+
+if (!function_exists('atMost')) { /**
+ * The value is <= $value.
+ */
+ function atMost($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::lessThanOrEqualTo($value);
+ }
+}
+
+if (!function_exists('isEmptyString')) { /**
+ * Matches if value is a zero-length string.
+ */
+ function isEmptyString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isEmptyString();
+ }
+}
+
+if (!function_exists('emptyString')) { /**
+ * Matches if value is a zero-length string.
+ */
+ function emptyString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isEmptyString();
+ }
+}
+
+if (!function_exists('isEmptyOrNullString')) { /**
+ * Matches if value is null or a zero-length string.
+ */
+ function isEmptyOrNullString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isEmptyOrNullString();
+ }
+}
+
+if (!function_exists('nullOrEmptyString')) { /**
+ * Matches if value is null or a zero-length string.
+ */
+ function nullOrEmptyString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isEmptyOrNullString();
+ }
+}
+
+if (!function_exists('isNonEmptyString')) { /**
+ * Matches if value is a non-zero-length string.
+ */
+ function isNonEmptyString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isNonEmptyString();
+ }
+}
+
+if (!function_exists('nonEmptyString')) { /**
+ * Matches if value is a non-zero-length string.
+ */
+ function nonEmptyString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isNonEmptyString();
+ }
+}
+
+if (!function_exists('equalToIgnoringCase')) { /**
+ * Matches if value is a string equal to $string, regardless of the case.
+ */
+ function equalToIgnoringCase($string)
+ {
+ return \Hamcrest\Text\IsEqualIgnoringCase::equalToIgnoringCase($string);
+ }
+}
+
+if (!function_exists('equalToIgnoringWhiteSpace')) { /**
+ * Matches if value is a string equal to $string, regardless of whitespace.
+ */
+ function equalToIgnoringWhiteSpace($string)
+ {
+ return \Hamcrest\Text\IsEqualIgnoringWhiteSpace::equalToIgnoringWhiteSpace($string);
+ }
+}
+
+if (!function_exists('matchesPattern')) { /**
+ * Matches if value is a string that matches regular expression $pattern.
+ */
+ function matchesPattern($pattern)
+ {
+ return \Hamcrest\Text\MatchesPattern::matchesPattern($pattern);
+ }
+}
+
+if (!function_exists('containsString')) { /**
+ * Matches if value is a string that contains $substring.
+ */
+ function containsString($substring)
+ {
+ return \Hamcrest\Text\StringContains::containsString($substring);
+ }
+}
+
+if (!function_exists('containsStringIgnoringCase')) { /**
+ * Matches if value is a string that contains $substring regardless of the case.
+ */
+ function containsStringIgnoringCase($substring)
+ {
+ return \Hamcrest\Text\StringContainsIgnoringCase::containsStringIgnoringCase($substring);
+ }
+}
+
+if (!function_exists('stringContainsInOrder')) { /**
+ * Matches if value contains $substrings in a constrained order.
+ */
+ function stringContainsInOrder(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Text\StringContainsInOrder', 'stringContainsInOrder'), $args);
+ }
+}
+
+if (!function_exists('endsWith')) { /**
+ * Matches if value is a string that ends with $substring.
+ */
+ function endsWith($substring)
+ {
+ return \Hamcrest\Text\StringEndsWith::endsWith($substring);
+ }
+}
+
+if (!function_exists('startsWith')) { /**
+ * Matches if value is a string that starts with $substring.
+ */
+ function startsWith($substring)
+ {
+ return \Hamcrest\Text\StringStartsWith::startsWith($substring);
+ }
+}
+
+if (!function_exists('arrayValue')) { /**
+ * Is the value an array?
+ */
+ function arrayValue()
+ {
+ return \Hamcrest\Type\IsArray::arrayValue();
+ }
+}
+
+if (!function_exists('booleanValue')) { /**
+ * Is the value a boolean?
+ */
+ function booleanValue()
+ {
+ return \Hamcrest\Type\IsBoolean::booleanValue();
+ }
+}
+
+if (!function_exists('boolValue')) { /**
+ * Is the value a boolean?
+ */
+ function boolValue()
+ {
+ return \Hamcrest\Type\IsBoolean::booleanValue();
+ }
+}
+
+if (!function_exists('callableValue')) { /**
+ * Is the value callable?
+ */
+ function callableValue()
+ {
+ return \Hamcrest\Type\IsCallable::callableValue();
+ }
+}
+
+if (!function_exists('doubleValue')) { /**
+ * Is the value a float/double?
+ */
+ function doubleValue()
+ {
+ return \Hamcrest\Type\IsDouble::doubleValue();
+ }
+}
+
+if (!function_exists('floatValue')) { /**
+ * Is the value a float/double?
+ */
+ function floatValue()
+ {
+ return \Hamcrest\Type\IsDouble::doubleValue();
+ }
+}
+
+if (!function_exists('integerValue')) { /**
+ * Is the value an integer?
+ */
+ function integerValue()
+ {
+ return \Hamcrest\Type\IsInteger::integerValue();
+ }
+}
+
+if (!function_exists('intValue')) { /**
+ * Is the value an integer?
+ */
+ function intValue()
+ {
+ return \Hamcrest\Type\IsInteger::integerValue();
+ }
+}
+
+if (!function_exists('numericValue')) { /**
+ * Is the value a numeric?
+ */
+ function numericValue()
+ {
+ return \Hamcrest\Type\IsNumeric::numericValue();
+ }
+}
+
+if (!function_exists('objectValue')) { /**
+ * Is the value an object?
+ */
+ function objectValue()
+ {
+ return \Hamcrest\Type\IsObject::objectValue();
+ }
+}
+
+if (!function_exists('anObject')) { /**
+ * Is the value an object?
+ */
+ function anObject()
+ {
+ return \Hamcrest\Type\IsObject::objectValue();
+ }
+}
+
+if (!function_exists('resourceValue')) { /**
+ * Is the value a resource?
+ */
+ function resourceValue()
+ {
+ return \Hamcrest\Type\IsResource::resourceValue();
+ }
+}
+
+if (!function_exists('scalarValue')) { /**
+ * Is the value a scalar (boolean, integer, double, or string)?
+ */
+ function scalarValue()
+ {
+ return \Hamcrest\Type\IsScalar::scalarValue();
+ }
+}
+
+if (!function_exists('stringValue')) { /**
+ * Is the value a string?
+ */
+ function stringValue()
+ {
+ return \Hamcrest\Type\IsString::stringValue();
+ }
+}
+
+if (!function_exists('hasXPath')) { /**
+ * Wraps $matcher
with {@link Hamcrest\Core\IsEqual)
+ * if it's not a matcher and the XPath in count()
+ * if it's an integer.
+ */
+ function hasXPath($xpath, $matcher = null)
+ {
+ return \Hamcrest\Xml\HasXPath::hasXPath($xpath, $matcher);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArray.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArray.php
new file mode 100644
index 000000000..9ea569703
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArray.php
@@ -0,0 +1,118 @@
+_elementMatchers = $elementMatchers;
+ }
+
+ protected function matchesSafely($array)
+ {
+ if (array_keys($array) != array_keys($this->_elementMatchers)) {
+ return false;
+ }
+
+ /** @var $matcher \Hamcrest\Matcher */
+ foreach ($this->_elementMatchers as $k => $matcher) {
+ if (!$matcher->matches($array[$k])) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ protected function describeMismatchSafely($actual, Description $mismatchDescription)
+ {
+ if (count($actual) != count($this->_elementMatchers)) {
+ $mismatchDescription->appendText('array length was ' . count($actual));
+
+ return;
+ } elseif (array_keys($actual) != array_keys($this->_elementMatchers)) {
+ $mismatchDescription->appendText('array keys were ')
+ ->appendValueList(
+ $this->descriptionStart(),
+ $this->descriptionSeparator(),
+ $this->descriptionEnd(),
+ array_keys($actual)
+ )
+ ;
+
+ return;
+ }
+
+ /** @var $matcher \Hamcrest\Matcher */
+ foreach ($this->_elementMatchers as $k => $matcher) {
+ if (!$matcher->matches($actual[$k])) {
+ $mismatchDescription->appendText('element ')->appendValue($k)
+ ->appendText(' was ')->appendValue($actual[$k]);
+
+ return;
+ }
+ }
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendList(
+ $this->descriptionStart(),
+ $this->descriptionSeparator(),
+ $this->descriptionEnd(),
+ $this->_elementMatchers
+ );
+ }
+
+ /**
+ * Evaluates to true only if each $matcher[$i] is satisfied by $array[$i].
+ *
+ * @factory ...
+ */
+ public static function anArray(/* args... */)
+ {
+ $args = func_get_args();
+
+ return new self(Util::createMatcherArray($args));
+ }
+
+ // -- Protected Methods
+
+ protected function descriptionStart()
+ {
+ return '[';
+ }
+
+ protected function descriptionSeparator()
+ {
+ return ', ';
+ }
+
+ protected function descriptionEnd()
+ {
+ return ']';
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContaining.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContaining.php
new file mode 100644
index 000000000..0e4a1eda9
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContaining.php
@@ -0,0 +1,63 @@
+_elementMatcher = $elementMatcher;
+ }
+
+ protected function matchesSafely($array)
+ {
+ foreach ($array as $element) {
+ if ($this->_elementMatcher->matches($element)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ protected function describeMismatchSafely($array, Description $mismatchDescription)
+ {
+ $mismatchDescription->appendText('was ')->appendValue($array);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description
+ ->appendText('an array containing ')
+ ->appendDescriptionOf($this->_elementMatcher)
+ ;
+ }
+
+ /**
+ * Evaluates to true if any item in an array satisfies the given matcher.
+ *
+ * @param mixed $item as a {@link Hamcrest\Matcher} or a value.
+ *
+ * @return \Hamcrest\Arrays\IsArrayContaining
+ * @factory hasValue
+ */
+ public static function hasItemInArray($item)
+ {
+ return new self(Util::wrapValueWithIsEqual($item));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInAnyOrder.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInAnyOrder.php
new file mode 100644
index 000000000..9009026b8
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInAnyOrder.php
@@ -0,0 +1,59 @@
+_elementMatchers = $elementMatchers;
+ }
+
+ protected function matchesSafelyWithDiagnosticDescription($array, Description $mismatchDescription)
+ {
+ $matching = new MatchingOnce($this->_elementMatchers, $mismatchDescription);
+
+ foreach ($array as $element) {
+ if (!$matching->matches($element)) {
+ return false;
+ }
+ }
+
+ return $matching->isFinished($array);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendList('[', ', ', ']', $this->_elementMatchers)
+ ->appendText(' in any order')
+ ;
+ }
+
+ /**
+ * An array with elements that match the given matchers.
+ *
+ * @factory containsInAnyOrder ...
+ */
+ public static function arrayContainingInAnyOrder(/* args... */)
+ {
+ $args = func_get_args();
+
+ return new self(Util::createMatcherArray($args));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInOrder.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInOrder.php
new file mode 100644
index 000000000..611574045
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingInOrder.php
@@ -0,0 +1,57 @@
+_elementMatchers = $elementMatchers;
+ }
+
+ protected function matchesSafelyWithDiagnosticDescription($array, Description $mismatchDescription)
+ {
+ $series = new SeriesMatchingOnce($this->_elementMatchers, $mismatchDescription);
+
+ foreach ($array as $element) {
+ if (!$series->matches($element)) {
+ return false;
+ }
+ }
+
+ return $series->isFinished();
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendList('[', ', ', ']', $this->_elementMatchers);
+ }
+
+ /**
+ * An array with elements that match the given matchers in the same order.
+ *
+ * @factory contains ...
+ */
+ public static function arrayContaining(/* args... */)
+ {
+ $args = func_get_args();
+
+ return new self(Util::createMatcherArray($args));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKey.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKey.php
new file mode 100644
index 000000000..523477e7b
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKey.php
@@ -0,0 +1,75 @@
+_keyMatcher = $keyMatcher;
+ }
+
+ protected function matchesSafely($array)
+ {
+ foreach ($array as $key => $element) {
+ if ($this->_keyMatcher->matches($key)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ protected function describeMismatchSafely($array, Description $mismatchDescription)
+ {
+ //Not using appendValueList() so that keys can be shown
+ $mismatchDescription->appendText('array was ')
+ ->appendText('[')
+ ;
+ $loop = false;
+ foreach ($array as $key => $value) {
+ if ($loop) {
+ $mismatchDescription->appendText(', ');
+ }
+ $mismatchDescription->appendValue($key)->appendText(' => ')->appendValue($value);
+ $loop = true;
+ }
+ $mismatchDescription->appendText(']');
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description
+ ->appendText('array with key ')
+ ->appendDescriptionOf($this->_keyMatcher)
+ ;
+ }
+
+ /**
+ * Evaluates to true if any key in an array matches the given matcher.
+ *
+ * @param mixed $key as a {@link Hamcrest\Matcher} or a value.
+ *
+ * @return \Hamcrest\Arrays\IsArrayContainingKey
+ * @factory hasKey
+ */
+ public static function hasKeyInArray($key)
+ {
+ return new self(Util::wrapValueWithIsEqual($key));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKeyValuePair.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKeyValuePair.php
new file mode 100644
index 000000000..9ac3eba80
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayContainingKeyValuePair.php
@@ -0,0 +1,80 @@
+_keyMatcher = $keyMatcher;
+ $this->_valueMatcher = $valueMatcher;
+ }
+
+ protected function matchesSafely($array)
+ {
+ foreach ($array as $key => $value) {
+ if ($this->_keyMatcher->matches($key) && $this->_valueMatcher->matches($value)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ protected function describeMismatchSafely($array, Description $mismatchDescription)
+ {
+ //Not using appendValueList() so that keys can be shown
+ $mismatchDescription->appendText('array was ')
+ ->appendText('[')
+ ;
+ $loop = false;
+ foreach ($array as $key => $value) {
+ if ($loop) {
+ $mismatchDescription->appendText(', ');
+ }
+ $mismatchDescription->appendValue($key)->appendText(' => ')->appendValue($value);
+ $loop = true;
+ }
+ $mismatchDescription->appendText(']');
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('array containing [')
+ ->appendDescriptionOf($this->_keyMatcher)
+ ->appendText(' => ')
+ ->appendDescriptionOf($this->_valueMatcher)
+ ->appendText(']')
+ ;
+ }
+
+ /**
+ * Test if an array has both an key and value in parity with each other.
+ *
+ * @factory hasEntry
+ */
+ public static function hasKeyValuePair($key, $value)
+ {
+ return new self(
+ Util::wrapValueWithIsEqual($key),
+ Util::wrapValueWithIsEqual($value)
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayWithSize.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayWithSize.php
new file mode 100644
index 000000000..074375ce1
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/IsArrayWithSize.php
@@ -0,0 +1,73 @@
+_elementMatchers = $elementMatchers;
+ $this->_mismatchDescription = $mismatchDescription;
+ }
+
+ public function matches($item)
+ {
+ return $this->_isNotSurplus($item) && $this->_isMatched($item);
+ }
+
+ public function isFinished($items)
+ {
+ if (empty($this->_elementMatchers)) {
+ return true;
+ }
+
+ $this->_mismatchDescription
+ ->appendText('No item matches: ')->appendList('', ', ', '', $this->_elementMatchers)
+ ->appendText(' in ')->appendValueList('[', ', ', ']', $items)
+ ;
+
+ return false;
+ }
+
+ // -- Private Methods
+
+ private function _isNotSurplus($item)
+ {
+ if (empty($this->_elementMatchers)) {
+ $this->_mismatchDescription->appendText('Not matched: ')->appendValue($item);
+
+ return false;
+ }
+
+ return true;
+ }
+
+ private function _isMatched($item)
+ {
+ /** @var $matcher \Hamcrest\Matcher */
+ foreach ($this->_elementMatchers as $i => $matcher) {
+ if ($matcher->matches($item)) {
+ unset($this->_elementMatchers[$i]);
+
+ return true;
+ }
+ }
+
+ $this->_mismatchDescription->appendText('Not matched: ')->appendValue($item);
+
+ return false;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/SeriesMatchingOnce.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/SeriesMatchingOnce.php
new file mode 100644
index 000000000..12a912d86
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Arrays/SeriesMatchingOnce.php
@@ -0,0 +1,75 @@
+_elementMatchers = $elementMatchers;
+ $this->_keys = array_keys($elementMatchers);
+ $this->_mismatchDescription = $mismatchDescription;
+ }
+
+ public function matches($item)
+ {
+ return $this->_isNotSurplus($item) && $this->_isMatched($item);
+ }
+
+ public function isFinished()
+ {
+ if (!empty($this->_elementMatchers)) {
+ $nextMatcher = current($this->_elementMatchers);
+ $this->_mismatchDescription->appendText('No item matched: ')->appendDescriptionOf($nextMatcher);
+
+ return false;
+ }
+
+ return true;
+ }
+
+ // -- Private Methods
+
+ private function _isNotSurplus($item)
+ {
+ if (empty($this->_elementMatchers)) {
+ $this->_mismatchDescription->appendText('Not matched: ')->appendValue($item);
+
+ return false;
+ }
+
+ return true;
+ }
+
+ private function _isMatched($item)
+ {
+ $this->_nextMatchKey = array_shift($this->_keys);
+ $nextMatcher = array_shift($this->_elementMatchers);
+
+ if (!$nextMatcher->matches($item)) {
+ $this->_describeMismatch($nextMatcher, $item);
+
+ return false;
+ }
+
+ return true;
+ }
+
+ private function _describeMismatch(Matcher $matcher, $item)
+ {
+ $this->_mismatchDescription->appendText('item with key ' . $this->_nextMatchKey . ': ');
+ $matcher->describeMismatch($item, $this->_mismatchDescription);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/AssertionError.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/AssertionError.php
new file mode 100644
index 000000000..3a2a0e7c2
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/AssertionError.php
@@ -0,0 +1,10 @@
+append($text);
+
+ return $this;
+ }
+
+ public function appendDescriptionOf(SelfDescribing $value)
+ {
+ $value->describeTo($this);
+
+ return $this;
+ }
+
+ public function appendValue($value)
+ {
+ if (is_null($value)) {
+ $this->append('null');
+ } elseif (is_string($value)) {
+ $this->_toPhpSyntax($value);
+ } elseif (is_float($value)) {
+ $this->append('<');
+ $this->append($value);
+ $this->append('F>');
+ } elseif (is_bool($value)) {
+ $this->append('<');
+ $this->append($value ? 'true' : 'false');
+ $this->append('>');
+ } elseif (is_array($value) || $value instanceof \Iterator || $value instanceof \IteratorAggregate) {
+ $this->appendValueList('[', ', ', ']', $value);
+ } elseif (is_object($value) && !method_exists($value, '__toString')) {
+ $this->append('<');
+ $this->append(get_class($value));
+ $this->append('>');
+ } else {
+ $this->append('<');
+ $this->append($value);
+ $this->append('>');
+ }
+
+ return $this;
+ }
+
+ public function appendValueList($start, $separator, $end, $values)
+ {
+ $list = array();
+ foreach ($values as $v) {
+ $list[] = new SelfDescribingValue($v);
+ }
+
+ $this->appendList($start, $separator, $end, $list);
+
+ return $this;
+ }
+
+ public function appendList($start, $separator, $end, $values)
+ {
+ $this->append($start);
+
+ $separate = false;
+
+ foreach ($values as $value) {
+ /*if (!($value instanceof Hamcrest\SelfDescribing)) {
+ $value = new Hamcrest\Internal\SelfDescribingValue($value);
+ }*/
+
+ if ($separate) {
+ $this->append($separator);
+ }
+
+ $this->appendDescriptionOf($value);
+
+ $separate = true;
+ }
+
+ $this->append($end);
+
+ return $this;
+ }
+
+ // -- Protected Methods
+
+ /**
+ * Append the String $str to the description.
+ */
+ abstract protected function append($str);
+
+ // -- Private Methods
+
+ private function _toPhpSyntax($value)
+ {
+ $str = '"';
+ for ($i = 0, $len = strlen($value); $i < $len; ++$i) {
+ switch ($value[$i]) {
+ case '"':
+ $str .= '\\"';
+ break;
+
+ case "\t":
+ $str .= '\\t';
+ break;
+
+ case "\r":
+ $str .= '\\r';
+ break;
+
+ case "\n":
+ $str .= '\\n';
+ break;
+
+ default:
+ $str .= $value[$i];
+ }
+ }
+ $str .= '"';
+ $this->append($str);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/BaseMatcher.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/BaseMatcher.php
new file mode 100644
index 000000000..286db3e17
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/BaseMatcher.php
@@ -0,0 +1,25 @@
+appendText('was ')->appendValue($item);
+ }
+
+ public function __toString()
+ {
+ return StringDescription::toString($this);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsEmptyTraversable.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsEmptyTraversable.php
new file mode 100644
index 000000000..8ab58ea5a
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsEmptyTraversable.php
@@ -0,0 +1,71 @@
+_empty = $empty;
+ }
+
+ public function matches($item)
+ {
+ if (!$item instanceof \Traversable) {
+ return false;
+ }
+
+ foreach ($item as $value) {
+ return !$this->_empty;
+ }
+
+ return $this->_empty;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText($this->_empty ? 'an empty traversable' : 'a non-empty traversable');
+ }
+
+ /**
+ * Returns true if traversable is empty.
+ *
+ * @factory
+ */
+ public static function emptyTraversable()
+ {
+ if (!self::$_INSTANCE) {
+ self::$_INSTANCE = new self;
+ }
+
+ return self::$_INSTANCE;
+ }
+
+ /**
+ * Returns true if traversable is not empty.
+ *
+ * @factory
+ */
+ public static function nonEmptyTraversable()
+ {
+ if (!self::$_NOT_INSTANCE) {
+ self::$_NOT_INSTANCE = new self(false);
+ }
+
+ return self::$_NOT_INSTANCE;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsTraversableWithSize.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsTraversableWithSize.php
new file mode 100644
index 000000000..c95edc5c3
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Collection/IsTraversableWithSize.php
@@ -0,0 +1,47 @@
+false.
+ */
+class AllOf extends DiagnosingMatcher
+{
+
+ private $_matchers;
+
+ public function __construct(array $matchers)
+ {
+ Util::checkAllAreMatchers($matchers);
+
+ $this->_matchers = $matchers;
+ }
+
+ public function matchesWithDiagnosticDescription($item, Description $mismatchDescription)
+ {
+ /** @var $matcher \Hamcrest\Matcher */
+ foreach ($this->_matchers as $matcher) {
+ if (!$matcher->matches($item)) {
+ $mismatchDescription->appendDescriptionOf($matcher)->appendText(' ');
+ $matcher->describeMismatch($item, $mismatchDescription);
+
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendList('(', ' and ', ')', $this->_matchers);
+ }
+
+ /**
+ * Evaluates to true only if ALL of the passed in matchers evaluate to true.
+ *
+ * @factory ...
+ */
+ public static function allOf(/* args... */)
+ {
+ $args = func_get_args();
+
+ return new self(Util::createMatcherArray($args));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/AnyOf.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/AnyOf.php
new file mode 100644
index 000000000..4504279f3
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/AnyOf.php
@@ -0,0 +1,58 @@
+true.
+ */
+class AnyOf extends ShortcutCombination
+{
+
+ public function __construct(array $matchers)
+ {
+ parent::__construct($matchers);
+ }
+
+ public function matches($item)
+ {
+ return $this->matchesWithShortcut($item, true);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $this->describeToWithOperator($description, 'or');
+ }
+
+ /**
+ * Evaluates to true if ANY of the passed in matchers evaluate to true.
+ *
+ * @factory ...
+ */
+ public static function anyOf(/* args... */)
+ {
+ $args = func_get_args();
+
+ return new self(Util::createMatcherArray($args));
+ }
+
+ /**
+ * Evaluates to false if ANY of the passed in matchers evaluate to true.
+ *
+ * @factory ...
+ */
+ public static function noneOf(/* args... */)
+ {
+ $args = func_get_args();
+
+ return IsNot::not(
+ new self(Util::createMatcherArray($args))
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/CombinableMatcher.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/CombinableMatcher.php
new file mode 100644
index 000000000..e3b4aa782
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/CombinableMatcher.php
@@ -0,0 +1,78 @@
+_matcher = $matcher;
+ }
+
+ public function matches($item)
+ {
+ return $this->_matcher->matches($item);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendDescriptionOf($this->_matcher);
+ }
+
+ /** Diversion from Hamcrest-Java... Logical "and" not permitted */
+ public function andAlso(Matcher $other)
+ {
+ return new self(new AllOf($this->_templatedListWith($other)));
+ }
+
+ /** Diversion from Hamcrest-Java... Logical "or" not permitted */
+ public function orElse(Matcher $other)
+ {
+ return new self(new AnyOf($this->_templatedListWith($other)));
+ }
+
+ /**
+ * This is useful for fluently combining matchers that must both pass.
+ * For example:
+ *
+ * assertThat($string, both(containsString("a"))->andAlso(containsString("b")));
+ *
+ *
+ * @factory
+ */
+ public static function both(Matcher $matcher)
+ {
+ return new self($matcher);
+ }
+
+ /**
+ * This is useful for fluently combining matchers where either may pass,
+ * for example:
+ *
+ * assertThat($string, either(containsString("a"))->orElse(containsString("b")));
+ *
+ *
+ * @factory
+ */
+ public static function either(Matcher $matcher)
+ {
+ return new self($matcher);
+ }
+
+ // -- Private Methods
+
+ private function _templatedListWith(Matcher $other)
+ {
+ return array($this->_matcher, $other);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/DescribedAs.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/DescribedAs.php
new file mode 100644
index 000000000..5b2583fa7
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/DescribedAs.php
@@ -0,0 +1,68 @@
+_descriptionTemplate = $descriptionTemplate;
+ $this->_matcher = $matcher;
+ $this->_values = $values;
+ }
+
+ public function matches($item)
+ {
+ return $this->_matcher->matches($item);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $textStart = 0;
+ while (preg_match(self::ARG_PATTERN, $this->_descriptionTemplate, $matches, PREG_OFFSET_CAPTURE, $textStart)) {
+ $text = $matches[0][0];
+ $index = $matches[1][0];
+ $offset = $matches[0][1];
+
+ $description->appendText(substr($this->_descriptionTemplate, $textStart, $offset - $textStart));
+ $description->appendValue($this->_values[$index]);
+
+ $textStart = $offset + strlen($text);
+ }
+
+ if ($textStart < strlen($this->_descriptionTemplate)) {
+ $description->appendText(substr($this->_descriptionTemplate, $textStart));
+ }
+ }
+
+ /**
+ * Wraps an existing matcher and overrides the description when it fails.
+ *
+ * @factory ...
+ */
+ public static function describedAs(/* $description, Hamcrest\Matcher $matcher, $values... */)
+ {
+ $args = func_get_args();
+ $description = array_shift($args);
+ $matcher = array_shift($args);
+ $values = $args;
+
+ return new self($description, $matcher, $values);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Every.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Every.php
new file mode 100644
index 000000000..d686f8dac
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Every.php
@@ -0,0 +1,56 @@
+_matcher = $matcher;
+ }
+
+ protected function matchesSafelyWithDiagnosticDescription($items, Description $mismatchDescription)
+ {
+ foreach ($items as $item) {
+ if (!$this->_matcher->matches($item)) {
+ $mismatchDescription->appendText('an item ');
+ $this->_matcher->describeMismatch($item, $mismatchDescription);
+
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('every item is ')->appendDescriptionOf($this->_matcher);
+ }
+
+ /**
+ * @param Matcher $itemMatcher
+ * A matcher to apply to every element in an array.
+ *
+ * @return \Hamcrest\Core\Every
+ * Evaluates to TRUE for a collection in which every item matches $itemMatcher
+ *
+ * @factory
+ */
+ public static function everyItem(Matcher $itemMatcher)
+ {
+ return new self($itemMatcher);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/HasToString.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/HasToString.php
new file mode 100644
index 000000000..45bd9102e
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/HasToString.php
@@ -0,0 +1,56 @@
+toString();
+ }
+
+ return (string) $actual;
+ }
+
+ /**
+ * Does array size satisfy a given matcher?
+ *
+ * @factory
+ */
+ public static function hasToString($matcher)
+ {
+ return new self(Util::wrapValueWithIsEqual($matcher));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Is.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Is.php
new file mode 100644
index 000000000..41266dc1f
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Is.php
@@ -0,0 +1,57 @@
+_matcher = $matcher;
+ }
+
+ public function matches($arg)
+ {
+ return $this->_matcher->matches($arg);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('is ')->appendDescriptionOf($this->_matcher);
+ }
+
+ public function describeMismatch($item, Description $mismatchDescription)
+ {
+ $this->_matcher->describeMismatch($item, $mismatchDescription);
+ }
+
+ /**
+ * Decorates another Matcher, retaining the behavior but allowing tests
+ * to be slightly more expressive.
+ *
+ * For example: assertThat($cheese, equalTo($smelly))
+ * vs. assertThat($cheese, is(equalTo($smelly)))
+ *
+ * @factory
+ */
+ public static function is($value)
+ {
+ return new self(Util::wrapValueWithIsEqual($value));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsAnything.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsAnything.php
new file mode 100644
index 000000000..f20e6c0dc
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsAnything.php
@@ -0,0 +1,45 @@
+true.
+ */
+class IsAnything extends BaseMatcher
+{
+
+ private $_message;
+
+ public function __construct($message = 'ANYTHING')
+ {
+ $this->_message = $message;
+ }
+
+ public function matches($item)
+ {
+ return true;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText($this->_message);
+ }
+
+ /**
+ * This matcher always evaluates to true.
+ *
+ * @param string $description A meaningful string used when describing itself.
+ *
+ * @return \Hamcrest\Core\IsAnything
+ * @factory
+ */
+ public static function anything($description = 'ANYTHING')
+ {
+ return new self($description);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsCollectionContaining.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsCollectionContaining.php
new file mode 100644
index 000000000..5e60426d1
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsCollectionContaining.php
@@ -0,0 +1,93 @@
+_elementMatcher = $elementMatcher;
+ }
+
+ protected function matchesSafely($items)
+ {
+ foreach ($items as $item) {
+ if ($this->_elementMatcher->matches($item)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ protected function describeMismatchSafely($items, Description $mismatchDescription)
+ {
+ $mismatchDescription->appendText('was ')->appendValue($items);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description
+ ->appendText('a collection containing ')
+ ->appendDescriptionOf($this->_elementMatcher)
+ ;
+ }
+
+ /**
+ * Test if the value is an array containing this matcher.
+ *
+ * Example:
+ *
+ * assertThat(array('a', 'b'), hasItem(equalTo('b')));
+ * //Convenience defaults to equalTo()
+ * assertThat(array('a', 'b'), hasItem('b'));
+ *
+ *
+ * @factory ...
+ */
+ public static function hasItem()
+ {
+ $args = func_get_args();
+ $firstArg = array_shift($args);
+
+ return new self(Util::wrapValueWithIsEqual($firstArg));
+ }
+
+ /**
+ * Test if the value is an array containing elements that match all of these
+ * matchers.
+ *
+ * Example:
+ *
+ * assertThat(array('a', 'b', 'c'), hasItems(equalTo('a'), equalTo('b')));
+ *
+ *
+ * @factory ...
+ */
+ public static function hasItems(/* args... */)
+ {
+ $args = func_get_args();
+ $matchers = array();
+
+ foreach ($args as $arg) {
+ $matchers[] = self::hasItem($arg);
+ }
+
+ return AllOf::allOf($matchers);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsEqual.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsEqual.php
new file mode 100644
index 000000000..523fba0b1
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsEqual.php
@@ -0,0 +1,44 @@
+_item = $item;
+ }
+
+ public function matches($arg)
+ {
+ return (($arg == $this->_item) && ($this->_item == $arg));
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendValue($this->_item);
+ }
+
+ /**
+ * Is the value equal to another value, as tested by the use of the "=="
+ * comparison operator?
+ *
+ * @factory
+ */
+ public static function equalTo($item)
+ {
+ return new self($item);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsIdentical.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsIdentical.php
new file mode 100644
index 000000000..28f7b36ea
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsIdentical.php
@@ -0,0 +1,38 @@
+_value = $value;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendValue($this->_value);
+ }
+
+ /**
+ * Tests of the value is identical to $value as tested by the "===" operator.
+ *
+ * @factory
+ */
+ public static function identicalTo($value)
+ {
+ return new self($value);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsInstanceOf.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsInstanceOf.php
new file mode 100644
index 000000000..7a5c92a6b
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsInstanceOf.php
@@ -0,0 +1,67 @@
+_theClass = $theClass;
+ }
+
+ protected function matchesWithDiagnosticDescription($item, Description $mismatchDescription)
+ {
+ if (!is_object($item)) {
+ $mismatchDescription->appendText('was ')->appendValue($item);
+
+ return false;
+ }
+
+ if (!($item instanceof $this->_theClass)) {
+ $mismatchDescription->appendText('[' . get_class($item) . '] ')
+ ->appendValue($item);
+
+ return false;
+ }
+
+ return true;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('an instance of ')
+ ->appendText($this->_theClass)
+ ;
+ }
+
+ /**
+ * Is the value an instance of a particular type?
+ * This version assumes no relationship between the required type and
+ * the signature of the method that sets it up, for example in
+ * assertThat($anObject, anInstanceOf('Thing'));
+ *
+ * @factory any
+ */
+ public static function anInstanceOf($theClass)
+ {
+ return new self($theClass);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNot.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNot.php
new file mode 100644
index 000000000..167f0d063
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNot.php
@@ -0,0 +1,44 @@
+_matcher = $matcher;
+ }
+
+ public function matches($arg)
+ {
+ return !$this->_matcher->matches($arg);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('not ')->appendDescriptionOf($this->_matcher);
+ }
+
+ /**
+ * Matches if value does not match $value.
+ *
+ * @factory
+ */
+ public static function not($value)
+ {
+ return new self(Util::wrapValueWithIsEqual($value));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNull.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNull.php
new file mode 100644
index 000000000..91a454c17
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsNull.php
@@ -0,0 +1,56 @@
+appendText('null');
+ }
+
+ /**
+ * Matches if value is null.
+ *
+ * @factory
+ */
+ public static function nullValue()
+ {
+ if (!self::$_INSTANCE) {
+ self::$_INSTANCE = new self();
+ }
+
+ return self::$_INSTANCE;
+ }
+
+ /**
+ * Matches if value is not null.
+ *
+ * @factory
+ */
+ public static function notNullValue()
+ {
+ if (!self::$_NOT_INSTANCE) {
+ self::$_NOT_INSTANCE = IsNot::not(self::nullValue());
+ }
+
+ return self::$_NOT_INSTANCE;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsSame.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsSame.php
new file mode 100644
index 000000000..810787050
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsSame.php
@@ -0,0 +1,51 @@
+_object = $object;
+ }
+
+ public function matches($object)
+ {
+ return ($object === $this->_object) && ($this->_object === $object);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('sameInstance(')
+ ->appendValue($this->_object)
+ ->appendText(')')
+ ;
+ }
+
+ /**
+ * Creates a new instance of IsSame.
+ *
+ * @param mixed $object
+ * The predicate evaluates to true only when the argument is
+ * this object.
+ *
+ * @return \Hamcrest\Core\IsSame
+ * @factory
+ */
+ public static function sameInstance($object)
+ {
+ return new self($object);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsTypeOf.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsTypeOf.php
new file mode 100644
index 000000000..d24f0f94c
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/IsTypeOf.php
@@ -0,0 +1,71 @@
+_theType = strtolower($theType);
+ }
+
+ public function matches($item)
+ {
+ return strtolower(gettype($item)) == $this->_theType;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText(self::getTypeDescription($this->_theType));
+ }
+
+ public function describeMismatch($item, Description $description)
+ {
+ if ($item === null) {
+ $description->appendText('was null');
+ } else {
+ $description->appendText('was ')
+ ->appendText(self::getTypeDescription(strtolower(gettype($item))))
+ ->appendText(' ')
+ ->appendValue($item)
+ ;
+ }
+ }
+
+ public static function getTypeDescription($type)
+ {
+ if ($type == 'null') {
+ return 'null';
+ }
+
+ return (strpos('aeiou', substr($type, 0, 1)) === false ? 'a ' : 'an ')
+ . $type;
+ }
+
+ /**
+ * Is the value a particular built-in type?
+ *
+ * @factory
+ */
+ public static function typeOf($theType)
+ {
+ return new self($theType);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Set.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Set.php
new file mode 100644
index 000000000..cdc45d538
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/Set.php
@@ -0,0 +1,95 @@
+
+ * assertThat(array('a', 'b'), set('b'));
+ * assertThat($foo, set('bar'));
+ * assertThat('Server', notSet('defaultPort'));
+ *
+ *
+ * @todo Replace $property with a matcher and iterate all property names.
+ */
+class Set extends BaseMatcher
+{
+
+ private $_property;
+ private $_not;
+
+ public function __construct($property, $not = false)
+ {
+ $this->_property = $property;
+ $this->_not = $not;
+ }
+
+ public function matches($item)
+ {
+ if ($item === null) {
+ return false;
+ }
+ $property = $this->_property;
+ if (is_array($item)) {
+ $result = isset($item[$property]);
+ } elseif (is_object($item)) {
+ $result = isset($item->$property);
+ } elseif (is_string($item)) {
+ $result = isset($item::$$property);
+ } else {
+ throw new \InvalidArgumentException('Must pass an object, array, or class name');
+ }
+
+ return $this->_not ? !$result : $result;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText($this->_not ? 'unset property ' : 'set property ')->appendText($this->_property);
+ }
+
+ public function describeMismatch($item, Description $description)
+ {
+ $value = '';
+ if (!$this->_not) {
+ $description->appendText('was not set');
+ } else {
+ $property = $this->_property;
+ if (is_array($item)) {
+ $value = $item[$property];
+ } elseif (is_object($item)) {
+ $value = $item->$property;
+ } elseif (is_string($item)) {
+ $value = $item::$$property;
+ }
+ parent::describeMismatch($value, $description);
+ }
+ }
+
+ /**
+ * Matches if value (class, object, or array) has named $property.
+ *
+ * @factory
+ */
+ public static function set($property)
+ {
+ return new self($property);
+ }
+
+ /**
+ * Matches if value (class, object, or array) does not have named $property.
+ *
+ * @factory
+ */
+ public static function notSet($property)
+ {
+ return new self($property, true);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/ShortcutCombination.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/ShortcutCombination.php
new file mode 100644
index 000000000..d93db74ff
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Core/ShortcutCombination.php
@@ -0,0 +1,43 @@
+
+ */
+ private $_matchers;
+
+ public function __construct(array $matchers)
+ {
+ Util::checkAllAreMatchers($matchers);
+
+ $this->_matchers = $matchers;
+ }
+
+ protected function matchesWithShortcut($item, $shortcut)
+ {
+ /** @var $matcher \Hamcrest\Matcher */
+ foreach ($this->_matchers as $matcher) {
+ if ($matcher->matches($item) == $shortcut) {
+ return $shortcut;
+ }
+ }
+
+ return !$shortcut;
+ }
+
+ public function describeToWithOperator(Description $description, $operator)
+ {
+ $description->appendList('(', ' ' . $operator . ' ', ')', $this->_matchers);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Description.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Description.php
new file mode 100644
index 000000000..9a482dbfc
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Description.php
@@ -0,0 +1,70 @@
+matchesWithDiagnosticDescription($item, new NullDescription());
+ }
+
+ public function describeMismatch($item, Description $mismatchDescription)
+ {
+ $this->matchesWithDiagnosticDescription($item, $mismatchDescription);
+ }
+
+ abstract protected function matchesWithDiagnosticDescription($item, Description $mismatchDescription);
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/FeatureMatcher.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/FeatureMatcher.php
new file mode 100644
index 000000000..59f6cc734
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/FeatureMatcher.php
@@ -0,0 +1,67 @@
+featureValueOf() in a subclass to pull out the feature to be
+ * matched against.
+ */
+abstract class FeatureMatcher extends TypeSafeDiagnosingMatcher
+{
+
+ private $_subMatcher;
+ private $_featureDescription;
+ private $_featureName;
+
+ /**
+ * Constructor.
+ *
+ * @param string $type
+ * @param string $subtype
+ * @param \Hamcrest\Matcher $subMatcher The matcher to apply to the feature
+ * @param string $featureDescription Descriptive text to use in describeTo
+ * @param string $featureName Identifying text for mismatch message
+ */
+ public function __construct($type, $subtype, Matcher $subMatcher, $featureDescription, $featureName)
+ {
+ parent::__construct($type, $subtype);
+
+ $this->_subMatcher = $subMatcher;
+ $this->_featureDescription = $featureDescription;
+ $this->_featureName = $featureName;
+ }
+
+ /**
+ * Implement this to extract the interesting feature.
+ *
+ * @param mixed $actual the target object
+ *
+ * @return mixed the feature to be matched
+ */
+ abstract protected function featureValueOf($actual);
+
+ public function matchesSafelyWithDiagnosticDescription($actual, Description $mismatchDescription)
+ {
+ $featureValue = $this->featureValueOf($actual);
+
+ if (!$this->_subMatcher->matches($featureValue)) {
+ $mismatchDescription->appendText($this->_featureName)
+ ->appendText(' was ')->appendValue($featureValue);
+
+ return false;
+ }
+
+ return true;
+ }
+
+ final public function describeTo(Description $description)
+ {
+ $description->appendText($this->_featureDescription)->appendText(' ')
+ ->appendDescriptionOf($this->_subMatcher)
+ ;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Internal/SelfDescribingValue.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Internal/SelfDescribingValue.php
new file mode 100644
index 000000000..995da71de
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Internal/SelfDescribingValue.php
@@ -0,0 +1,27 @@
+_value = $value;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendValue($this->_value);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matcher.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matcher.php
new file mode 100644
index 000000000..e5dcf0939
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matcher.php
@@ -0,0 +1,50 @@
+
+ * Matcher implementations should NOT directly implement this interface .
+ * Instead, extend the {@link Hamcrest\BaseMatcher} abstract class,
+ * which will ensure that the Matcher API can grow to support
+ * new features and remain compatible with all Matcher implementations.
+ *
+ * For easy access to common Matcher implementations, use the static factory
+ * methods in {@link Hamcrest\CoreMatchers}.
+ *
+ * @see Hamcrest\CoreMatchers
+ * @see Hamcrest\BaseMatcher
+ */
+interface Matcher extends SelfDescribing
+{
+
+ /**
+ * Evaluates the matcher for argument $item .
+ *
+ * @param mixed $item the object against which the matcher is evaluated.
+ *
+ * @return boolean true
if $item matches,
+ * otherwise false
.
+ *
+ * @see Hamcrest\BaseMatcher
+ */
+ public function matches($item);
+
+ /**
+ * Generate a description of why the matcher has not accepted the item.
+ * The description will be part of a larger description of why a matching
+ * failed, so it should be concise.
+ * This method assumes that matches($item)
is false, but
+ * will not check this.
+ *
+ * @param mixed $item The item that the Matcher has rejected.
+ * @param Description $description
+ * @return
+ */
+ public function describeMismatch($item, Description $description);
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/MatcherAssert.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/MatcherAssert.php
new file mode 100644
index 000000000..d546dbee6
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/MatcherAssert.php
@@ -0,0 +1,118 @@
+
+ * // With an identifier
+ * assertThat("apple flavour", $apple->flavour(), equalTo("tasty"));
+ * // Without an identifier
+ * assertThat($apple->flavour(), equalTo("tasty"));
+ * // Evaluating a boolean expression
+ * assertThat("some error", $a > $b);
+ * assertThat($a > $b);
+ *
+ */
+ public static function assertThat(/* $args ... */)
+ {
+ $args = func_get_args();
+ switch (count($args)) {
+ case 1:
+ self::$_count++;
+ if (!$args[0]) {
+ throw new AssertionError();
+ }
+ break;
+
+ case 2:
+ self::$_count++;
+ if ($args[1] instanceof Matcher) {
+ self::doAssert('', $args[0], $args[1]);
+ } elseif (!$args[1]) {
+ throw new AssertionError($args[0]);
+ }
+ break;
+
+ case 3:
+ self::$_count++;
+ self::doAssert(
+ $args[0],
+ $args[1],
+ Util::wrapValueWithIsEqual($args[2])
+ );
+ break;
+
+ default:
+ throw new \InvalidArgumentException('assertThat() requires one to three arguments');
+ }
+ }
+
+ /**
+ * Returns the number of assertions performed.
+ *
+ * @return int
+ */
+ public static function getCount()
+ {
+ return self::$_count;
+ }
+
+ /**
+ * Resets the number of assertions performed to zero.
+ */
+ public static function resetCount()
+ {
+ self::$_count = 0;
+ }
+
+ /**
+ * Performs the actual assertion logic.
+ *
+ * If $matcher
doesn't match $actual
,
+ * throws a {@link Hamcrest\AssertionError} with a description
+ * of the failure along with the optional $identifier
.
+ *
+ * @param string $identifier added to the message upon failure
+ * @param mixed $actual value to compare against $matcher
+ * @param \Hamcrest\Matcher $matcher applied to $actual
+ * @throws AssertionError
+ */
+ private static function doAssert($identifier, $actual, Matcher $matcher)
+ {
+ if (!$matcher->matches($actual)) {
+ $description = new StringDescription();
+ if (!empty($identifier)) {
+ $description->appendText($identifier . PHP_EOL);
+ }
+ $description->appendText('Expected: ')
+ ->appendDescriptionOf($matcher)
+ ->appendText(PHP_EOL . ' but: ');
+
+ $matcher->describeMismatch($actual, $description);
+
+ throw new AssertionError((string) $description);
+ }
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matchers.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matchers.php
new file mode 100644
index 000000000..23232e450
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Matchers.php
@@ -0,0 +1,713 @@
+
+ * assertThat($string, both(containsString("a"))->andAlso(containsString("b")));
+ *
+ */
+ public static function both(\Hamcrest\Matcher $matcher)
+ {
+ return \Hamcrest\Core\CombinableMatcher::both($matcher);
+ }
+
+ /**
+ * This is useful for fluently combining matchers where either may pass,
+ * for example:
+ *
+ * assertThat($string, either(containsString("a"))->orElse(containsString("b")));
+ *
+ */
+ public static function either(\Hamcrest\Matcher $matcher)
+ {
+ return \Hamcrest\Core\CombinableMatcher::either($matcher);
+ }
+
+ /**
+ * Wraps an existing matcher and overrides the description when it fails.
+ */
+ public static function describedAs(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Core\DescribedAs', 'describedAs'), $args);
+ }
+
+ /**
+ * @param Matcher $itemMatcher
+ * A matcher to apply to every element in an array.
+ *
+ * @return \Hamcrest\Core\Every
+ * Evaluates to TRUE for a collection in which every item matches $itemMatcher
+ */
+ public static function everyItem(\Hamcrest\Matcher $itemMatcher)
+ {
+ return \Hamcrest\Core\Every::everyItem($itemMatcher);
+ }
+
+ /**
+ * Does array size satisfy a given matcher?
+ */
+ public static function hasToString($matcher)
+ {
+ return \Hamcrest\Core\HasToString::hasToString($matcher);
+ }
+
+ /**
+ * Decorates another Matcher, retaining the behavior but allowing tests
+ * to be slightly more expressive.
+ *
+ * For example: assertThat($cheese, equalTo($smelly))
+ * vs. assertThat($cheese, is(equalTo($smelly)))
+ */
+ public static function is($value)
+ {
+ return \Hamcrest\Core\Is::is($value);
+ }
+
+ /**
+ * This matcher always evaluates to true.
+ *
+ * @param string $description A meaningful string used when describing itself.
+ *
+ * @return \Hamcrest\Core\IsAnything
+ */
+ public static function anything($description = 'ANYTHING')
+ {
+ return \Hamcrest\Core\IsAnything::anything($description);
+ }
+
+ /**
+ * Test if the value is an array containing this matcher.
+ *
+ * Example:
+ *
+ * assertThat(array('a', 'b'), hasItem(equalTo('b')));
+ * //Convenience defaults to equalTo()
+ * assertThat(array('a', 'b'), hasItem('b'));
+ *
+ */
+ public static function hasItem(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Core\IsCollectionContaining', 'hasItem'), $args);
+ }
+
+ /**
+ * Test if the value is an array containing elements that match all of these
+ * matchers.
+ *
+ * Example:
+ *
+ * assertThat(array('a', 'b', 'c'), hasItems(equalTo('a'), equalTo('b')));
+ *
+ */
+ public static function hasItems(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Core\IsCollectionContaining', 'hasItems'), $args);
+ }
+
+ /**
+ * Is the value equal to another value, as tested by the use of the "=="
+ * comparison operator?
+ */
+ public static function equalTo($item)
+ {
+ return \Hamcrest\Core\IsEqual::equalTo($item);
+ }
+
+ /**
+ * Tests of the value is identical to $value as tested by the "===" operator.
+ */
+ public static function identicalTo($value)
+ {
+ return \Hamcrest\Core\IsIdentical::identicalTo($value);
+ }
+
+ /**
+ * Is the value an instance of a particular type?
+ * This version assumes no relationship between the required type and
+ * the signature of the method that sets it up, for example in
+ * assertThat($anObject, anInstanceOf('Thing'));
+ */
+ public static function anInstanceOf($theClass)
+ {
+ return \Hamcrest\Core\IsInstanceOf::anInstanceOf($theClass);
+ }
+
+ /**
+ * Is the value an instance of a particular type?
+ * This version assumes no relationship between the required type and
+ * the signature of the method that sets it up, for example in
+ * assertThat($anObject, anInstanceOf('Thing'));
+ */
+ public static function any($theClass)
+ {
+ return \Hamcrest\Core\IsInstanceOf::anInstanceOf($theClass);
+ }
+
+ /**
+ * Matches if value does not match $value.
+ */
+ public static function not($value)
+ {
+ return \Hamcrest\Core\IsNot::not($value);
+ }
+
+ /**
+ * Matches if value is null.
+ */
+ public static function nullValue()
+ {
+ return \Hamcrest\Core\IsNull::nullValue();
+ }
+
+ /**
+ * Matches if value is not null.
+ */
+ public static function notNullValue()
+ {
+ return \Hamcrest\Core\IsNull::notNullValue();
+ }
+
+ /**
+ * Creates a new instance of IsSame.
+ *
+ * @param mixed $object
+ * The predicate evaluates to true only when the argument is
+ * this object.
+ *
+ * @return \Hamcrest\Core\IsSame
+ */
+ public static function sameInstance($object)
+ {
+ return \Hamcrest\Core\IsSame::sameInstance($object);
+ }
+
+ /**
+ * Is the value a particular built-in type?
+ */
+ public static function typeOf($theType)
+ {
+ return \Hamcrest\Core\IsTypeOf::typeOf($theType);
+ }
+
+ /**
+ * Matches if value (class, object, or array) has named $property.
+ */
+ public static function set($property)
+ {
+ return \Hamcrest\Core\Set::set($property);
+ }
+
+ /**
+ * Matches if value (class, object, or array) does not have named $property.
+ */
+ public static function notSet($property)
+ {
+ return \Hamcrest\Core\Set::notSet($property);
+ }
+
+ /**
+ * Matches if value is a number equal to $value within some range of
+ * acceptable error $delta.
+ */
+ public static function closeTo($value, $delta)
+ {
+ return \Hamcrest\Number\IsCloseTo::closeTo($value, $delta);
+ }
+
+ /**
+ * The value is not > $value, nor < $value.
+ */
+ public static function comparesEqualTo($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::comparesEqualTo($value);
+ }
+
+ /**
+ * The value is > $value.
+ */
+ public static function greaterThan($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::greaterThan($value);
+ }
+
+ /**
+ * The value is >= $value.
+ */
+ public static function greaterThanOrEqualTo($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::greaterThanOrEqualTo($value);
+ }
+
+ /**
+ * The value is >= $value.
+ */
+ public static function atLeast($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::greaterThanOrEqualTo($value);
+ }
+
+ /**
+ * The value is < $value.
+ */
+ public static function lessThan($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::lessThan($value);
+ }
+
+ /**
+ * The value is <= $value.
+ */
+ public static function lessThanOrEqualTo($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::lessThanOrEqualTo($value);
+ }
+
+ /**
+ * The value is <= $value.
+ */
+ public static function atMost($value)
+ {
+ return \Hamcrest\Number\OrderingComparison::lessThanOrEqualTo($value);
+ }
+
+ /**
+ * Matches if value is a zero-length string.
+ */
+ public static function isEmptyString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isEmptyString();
+ }
+
+ /**
+ * Matches if value is a zero-length string.
+ */
+ public static function emptyString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isEmptyString();
+ }
+
+ /**
+ * Matches if value is null or a zero-length string.
+ */
+ public static function isEmptyOrNullString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isEmptyOrNullString();
+ }
+
+ /**
+ * Matches if value is null or a zero-length string.
+ */
+ public static function nullOrEmptyString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isEmptyOrNullString();
+ }
+
+ /**
+ * Matches if value is a non-zero-length string.
+ */
+ public static function isNonEmptyString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isNonEmptyString();
+ }
+
+ /**
+ * Matches if value is a non-zero-length string.
+ */
+ public static function nonEmptyString()
+ {
+ return \Hamcrest\Text\IsEmptyString::isNonEmptyString();
+ }
+
+ /**
+ * Matches if value is a string equal to $string, regardless of the case.
+ */
+ public static function equalToIgnoringCase($string)
+ {
+ return \Hamcrest\Text\IsEqualIgnoringCase::equalToIgnoringCase($string);
+ }
+
+ /**
+ * Matches if value is a string equal to $string, regardless of whitespace.
+ */
+ public static function equalToIgnoringWhiteSpace($string)
+ {
+ return \Hamcrest\Text\IsEqualIgnoringWhiteSpace::equalToIgnoringWhiteSpace($string);
+ }
+
+ /**
+ * Matches if value is a string that matches regular expression $pattern.
+ */
+ public static function matchesPattern($pattern)
+ {
+ return \Hamcrest\Text\MatchesPattern::matchesPattern($pattern);
+ }
+
+ /**
+ * Matches if value is a string that contains $substring.
+ */
+ public static function containsString($substring)
+ {
+ return \Hamcrest\Text\StringContains::containsString($substring);
+ }
+
+ /**
+ * Matches if value is a string that contains $substring regardless of the case.
+ */
+ public static function containsStringIgnoringCase($substring)
+ {
+ return \Hamcrest\Text\StringContainsIgnoringCase::containsStringIgnoringCase($substring);
+ }
+
+ /**
+ * Matches if value contains $substrings in a constrained order.
+ */
+ public static function stringContainsInOrder(/* args... */)
+ {
+ $args = func_get_args();
+ return call_user_func_array(array('\Hamcrest\Text\StringContainsInOrder', 'stringContainsInOrder'), $args);
+ }
+
+ /**
+ * Matches if value is a string that ends with $substring.
+ */
+ public static function endsWith($substring)
+ {
+ return \Hamcrest\Text\StringEndsWith::endsWith($substring);
+ }
+
+ /**
+ * Matches if value is a string that starts with $substring.
+ */
+ public static function startsWith($substring)
+ {
+ return \Hamcrest\Text\StringStartsWith::startsWith($substring);
+ }
+
+ /**
+ * Is the value an array?
+ */
+ public static function arrayValue()
+ {
+ return \Hamcrest\Type\IsArray::arrayValue();
+ }
+
+ /**
+ * Is the value a boolean?
+ */
+ public static function booleanValue()
+ {
+ return \Hamcrest\Type\IsBoolean::booleanValue();
+ }
+
+ /**
+ * Is the value a boolean?
+ */
+ public static function boolValue()
+ {
+ return \Hamcrest\Type\IsBoolean::booleanValue();
+ }
+
+ /**
+ * Is the value callable?
+ */
+ public static function callableValue()
+ {
+ return \Hamcrest\Type\IsCallable::callableValue();
+ }
+
+ /**
+ * Is the value a float/double?
+ */
+ public static function doubleValue()
+ {
+ return \Hamcrest\Type\IsDouble::doubleValue();
+ }
+
+ /**
+ * Is the value a float/double?
+ */
+ public static function floatValue()
+ {
+ return \Hamcrest\Type\IsDouble::doubleValue();
+ }
+
+ /**
+ * Is the value an integer?
+ */
+ public static function integerValue()
+ {
+ return \Hamcrest\Type\IsInteger::integerValue();
+ }
+
+ /**
+ * Is the value an integer?
+ */
+ public static function intValue()
+ {
+ return \Hamcrest\Type\IsInteger::integerValue();
+ }
+
+ /**
+ * Is the value a numeric?
+ */
+ public static function numericValue()
+ {
+ return \Hamcrest\Type\IsNumeric::numericValue();
+ }
+
+ /**
+ * Is the value an object?
+ */
+ public static function objectValue()
+ {
+ return \Hamcrest\Type\IsObject::objectValue();
+ }
+
+ /**
+ * Is the value an object?
+ */
+ public static function anObject()
+ {
+ return \Hamcrest\Type\IsObject::objectValue();
+ }
+
+ /**
+ * Is the value a resource?
+ */
+ public static function resourceValue()
+ {
+ return \Hamcrest\Type\IsResource::resourceValue();
+ }
+
+ /**
+ * Is the value a scalar (boolean, integer, double, or string)?
+ */
+ public static function scalarValue()
+ {
+ return \Hamcrest\Type\IsScalar::scalarValue();
+ }
+
+ /**
+ * Is the value a string?
+ */
+ public static function stringValue()
+ {
+ return \Hamcrest\Type\IsString::stringValue();
+ }
+
+ /**
+ * Wraps $matcher
with {@link Hamcrest\Core\IsEqual)
+ * if it's not a matcher and the XPath in count()
+ * if it's an integer.
+ */
+ public static function hasXPath($xpath, $matcher = null)
+ {
+ return \Hamcrest\Xml\HasXPath::hasXPath($xpath, $matcher);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/NullDescription.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/NullDescription.php
new file mode 100644
index 000000000..aae8e4616
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/NullDescription.php
@@ -0,0 +1,43 @@
+_value = $value;
+ $this->_delta = $delta;
+ }
+
+ protected function matchesSafely($item)
+ {
+ return $this->_actualDelta($item) <= 0.0;
+ }
+
+ protected function describeMismatchSafely($item, Description $mismatchDescription)
+ {
+ $mismatchDescription->appendValue($item)
+ ->appendText(' differed by ')
+ ->appendValue($this->_actualDelta($item))
+ ;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('a numeric value within ')
+ ->appendValue($this->_delta)
+ ->appendText(' of ')
+ ->appendValue($this->_value)
+ ;
+ }
+
+ /**
+ * Matches if value is a number equal to $value within some range of
+ * acceptable error $delta.
+ *
+ * @factory
+ */
+ public static function closeTo($value, $delta)
+ {
+ return new self($value, $delta);
+ }
+
+ // -- Private Methods
+
+ private function _actualDelta($item)
+ {
+ return (abs(($item - $this->_value)) - $this->_delta);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Number/OrderingComparison.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Number/OrderingComparison.php
new file mode 100644
index 000000000..369d0cfa5
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Number/OrderingComparison.php
@@ -0,0 +1,132 @@
+_value = $value;
+ $this->_minCompare = $minCompare;
+ $this->_maxCompare = $maxCompare;
+ }
+
+ protected function matchesSafely($other)
+ {
+ $compare = $this->_compare($this->_value, $other);
+
+ return ($this->_minCompare <= $compare) && ($compare <= $this->_maxCompare);
+ }
+
+ protected function describeMismatchSafely($item, Description $mismatchDescription)
+ {
+ $mismatchDescription
+ ->appendValue($item)->appendText(' was ')
+ ->appendText($this->_comparison($this->_compare($this->_value, $item)))
+ ->appendText(' ')->appendValue($this->_value)
+ ;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('a value ')
+ ->appendText($this->_comparison($this->_minCompare))
+ ;
+ if ($this->_minCompare != $this->_maxCompare) {
+ $description->appendText(' or ')
+ ->appendText($this->_comparison($this->_maxCompare))
+ ;
+ }
+ $description->appendText(' ')->appendValue($this->_value);
+ }
+
+ /**
+ * The value is not > $value, nor < $value.
+ *
+ * @factory
+ */
+ public static function comparesEqualTo($value)
+ {
+ return new self($value, 0, 0);
+ }
+
+ /**
+ * The value is > $value.
+ *
+ * @factory
+ */
+ public static function greaterThan($value)
+ {
+ return new self($value, -1, -1);
+ }
+
+ /**
+ * The value is >= $value.
+ *
+ * @factory atLeast
+ */
+ public static function greaterThanOrEqualTo($value)
+ {
+ return new self($value, -1, 0);
+ }
+
+ /**
+ * The value is < $value.
+ *
+ * @factory
+ */
+ public static function lessThan($value)
+ {
+ return new self($value, 1, 1);
+ }
+
+ /**
+ * The value is <= $value.
+ *
+ * @factory atMost
+ */
+ public static function lessThanOrEqualTo($value)
+ {
+ return new self($value, 0, 1);
+ }
+
+ // -- Private Methods
+
+ private function _compare($left, $right)
+ {
+ $a = $left;
+ $b = $right;
+
+ if ($a < $b) {
+ return -1;
+ } elseif ($a == $b) {
+ return 0;
+ } else {
+ return 1;
+ }
+ }
+
+ private function _comparison($compare)
+ {
+ if ($compare > 0) {
+ return 'less than';
+ } elseif ($compare == 0) {
+ return 'equal to';
+ } else {
+ return 'greater than';
+ }
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/SelfDescribing.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/SelfDescribing.php
new file mode 100644
index 000000000..872fdf9c5
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/SelfDescribing.php
@@ -0,0 +1,23 @@
+_out = (string) $out;
+ }
+
+ public function __toString()
+ {
+ return $this->_out;
+ }
+
+ /**
+ * Return the description of a {@link Hamcrest\SelfDescribing} object as a
+ * String.
+ *
+ * @param \Hamcrest\SelfDescribing $selfDescribing
+ * The object to be described.
+ *
+ * @return string
+ * The description of the object.
+ */
+ public static function toString(SelfDescribing $selfDescribing)
+ {
+ $self = new self();
+
+ return (string) $self->appendDescriptionOf($selfDescribing);
+ }
+
+ /**
+ * Alias for {@link toString()}.
+ */
+ public static function asString(SelfDescribing $selfDescribing)
+ {
+ return self::toString($selfDescribing);
+ }
+
+ // -- Protected Methods
+
+ protected function append($str)
+ {
+ $this->_out .= $str;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEmptyString.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEmptyString.php
new file mode 100644
index 000000000..2ae61b96c
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEmptyString.php
@@ -0,0 +1,85 @@
+_empty = $empty;
+ }
+
+ public function matches($item)
+ {
+ return $this->_empty
+ ? ($item === '')
+ : is_string($item) && $item !== '';
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText($this->_empty ? 'an empty string' : 'a non-empty string');
+ }
+
+ /**
+ * Matches if value is a zero-length string.
+ *
+ * @factory emptyString
+ */
+ public static function isEmptyString()
+ {
+ if (!self::$_INSTANCE) {
+ self::$_INSTANCE = new self(true);
+ }
+
+ return self::$_INSTANCE;
+ }
+
+ /**
+ * Matches if value is null or a zero-length string.
+ *
+ * @factory nullOrEmptyString
+ */
+ public static function isEmptyOrNullString()
+ {
+ if (!self::$_NULL_OR_EMPTY_INSTANCE) {
+ self::$_NULL_OR_EMPTY_INSTANCE = AnyOf::anyOf(
+ IsNull::nullvalue(),
+ self::isEmptyString()
+ );
+ }
+
+ return self::$_NULL_OR_EMPTY_INSTANCE;
+ }
+
+ /**
+ * Matches if value is a non-zero-length string.
+ *
+ * @factory nonEmptyString
+ */
+ public static function isNonEmptyString()
+ {
+ if (!self::$_NOT_INSTANCE) {
+ self::$_NOT_INSTANCE = new self(false);
+ }
+
+ return self::$_NOT_INSTANCE;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringCase.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringCase.php
new file mode 100644
index 000000000..3836a8c37
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringCase.php
@@ -0,0 +1,52 @@
+_string = $string;
+ }
+
+ protected function matchesSafely($item)
+ {
+ return strtolower($this->_string) === strtolower($item);
+ }
+
+ protected function describeMismatchSafely($item, Description $mismatchDescription)
+ {
+ $mismatchDescription->appendText('was ')->appendText($item);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('equalToIgnoringCase(')
+ ->appendValue($this->_string)
+ ->appendText(')')
+ ;
+ }
+
+ /**
+ * Matches if value is a string equal to $string, regardless of the case.
+ *
+ * @factory
+ */
+ public static function equalToIgnoringCase($string)
+ {
+ return new self($string);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringWhiteSpace.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringWhiteSpace.php
new file mode 100644
index 000000000..853692b03
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/IsEqualIgnoringWhiteSpace.php
@@ -0,0 +1,66 @@
+_string = $string;
+ }
+
+ protected function matchesSafely($item)
+ {
+ return (strtolower($this->_stripSpace($item))
+ === strtolower($this->_stripSpace($this->_string)));
+ }
+
+ protected function describeMismatchSafely($item, Description $mismatchDescription)
+ {
+ $mismatchDescription->appendText('was ')->appendText($item);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('equalToIgnoringWhiteSpace(')
+ ->appendValue($this->_string)
+ ->appendText(')')
+ ;
+ }
+
+ /**
+ * Matches if value is a string equal to $string, regardless of whitespace.
+ *
+ * @factory
+ */
+ public static function equalToIgnoringWhiteSpace($string)
+ {
+ return new self($string);
+ }
+
+ // -- Private Methods
+
+ private function _stripSpace($string)
+ {
+ $parts = preg_split("/[\r\n\t ]+/", $string);
+ foreach ($parts as $i => $part) {
+ $parts[$i] = trim($part, " \r\n\t");
+ }
+
+ return trim(implode(' ', $parts), " \r\n\t");
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/MatchesPattern.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/MatchesPattern.php
new file mode 100644
index 000000000..fa0d68eea
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/MatchesPattern.php
@@ -0,0 +1,40 @@
+_substring, (string) $item) >= 1;
+ }
+
+ protected function relationship()
+ {
+ return 'matching';
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContains.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContains.php
new file mode 100644
index 000000000..b92786b60
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContains.php
@@ -0,0 +1,45 @@
+_substring);
+ }
+
+ /**
+ * Matches if value is a string that contains $substring.
+ *
+ * @factory
+ */
+ public static function containsString($substring)
+ {
+ return new self($substring);
+ }
+
+ // -- Protected Methods
+
+ protected function evalSubstringOf($item)
+ {
+ return (false !== strpos((string) $item, $this->_substring));
+ }
+
+ protected function relationship()
+ {
+ return 'containing';
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsIgnoringCase.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsIgnoringCase.php
new file mode 100644
index 000000000..69f37c258
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsIgnoringCase.php
@@ -0,0 +1,40 @@
+_substring));
+ }
+
+ protected function relationship()
+ {
+ return 'containing in any case';
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsInOrder.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsInOrder.php
new file mode 100644
index 000000000..e75de65d2
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringContainsInOrder.php
@@ -0,0 +1,66 @@
+_substrings = $substrings;
+ }
+
+ protected function matchesSafely($item)
+ {
+ $fromIndex = 0;
+
+ foreach ($this->_substrings as $substring) {
+ if (false === $fromIndex = strpos($item, $substring, $fromIndex)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ protected function describeMismatchSafely($item, Description $mismatchDescription)
+ {
+ $mismatchDescription->appendText('was ')->appendText($item);
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('a string containing ')
+ ->appendValueList('', ', ', '', $this->_substrings)
+ ->appendText(' in order')
+ ;
+ }
+
+ /**
+ * Matches if value contains $substrings in a constrained order.
+ *
+ * @factory ...
+ */
+ public static function stringContainsInOrder(/* args... */)
+ {
+ $args = func_get_args();
+
+ if (isset($args[0]) && is_array($args[0])) {
+ $args = $args[0];
+ }
+
+ return new self($args);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringEndsWith.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringEndsWith.php
new file mode 100644
index 000000000..f802ee4d1
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringEndsWith.php
@@ -0,0 +1,40 @@
+_substring))) === $this->_substring);
+ }
+
+ protected function relationship()
+ {
+ return 'ending with';
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringStartsWith.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringStartsWith.php
new file mode 100644
index 000000000..79c95656a
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/StringStartsWith.php
@@ -0,0 +1,40 @@
+_substring)) === $this->_substring);
+ }
+
+ protected function relationship()
+ {
+ return 'starting with';
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/SubstringMatcher.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/SubstringMatcher.php
new file mode 100644
index 000000000..e560ad627
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Text/SubstringMatcher.php
@@ -0,0 +1,45 @@
+_substring = $substring;
+ }
+
+ protected function matchesSafely($item)
+ {
+ return $this->evalSubstringOf($item);
+ }
+
+ protected function describeMismatchSafely($item, Description $mismatchDescription)
+ {
+ $mismatchDescription->appendText('was "')->appendText($item)->appendText('"');
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('a string ')
+ ->appendText($this->relationship())
+ ->appendText(' ')
+ ->appendValue($this->_substring)
+ ;
+ }
+
+ abstract protected function evalSubstringOf($string);
+
+ abstract protected function relationship();
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsArray.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsArray.php
new file mode 100644
index 000000000..9179102ff
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Type/IsArray.php
@@ -0,0 +1,32 @@
+matchesSafelyWithDiagnosticDescription($item, new NullDescription());
+ }
+
+ final public function describeMismatchSafely($item, Description $mismatchDescription)
+ {
+ $this->matchesSafelyWithDiagnosticDescription($item, $mismatchDescription);
+ }
+
+ // -- Protected Methods
+
+ /**
+ * Subclasses should implement these. The item will already have been checked for
+ * the specific type.
+ */
+ abstract protected function matchesSafelyWithDiagnosticDescription($item, Description $mismatchDescription);
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/TypeSafeMatcher.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/TypeSafeMatcher.php
new file mode 100644
index 000000000..56e299a9a
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/TypeSafeMatcher.php
@@ -0,0 +1,107 @@
+_expectedType = $expectedType;
+ $this->_expectedSubtype = $expectedSubtype;
+ }
+
+ final public function matches($item)
+ {
+ return $this->_isSafeType($item) && $this->matchesSafely($item);
+ }
+
+ final public function describeMismatch($item, Description $mismatchDescription)
+ {
+ if (!$this->_isSafeType($item)) {
+ parent::describeMismatch($item, $mismatchDescription);
+ } else {
+ $this->describeMismatchSafely($item, $mismatchDescription);
+ }
+ }
+
+ // -- Protected Methods
+
+ /**
+ * The item will already have been checked for the specific type and subtype.
+ */
+ abstract protected function matchesSafely($item);
+
+ /**
+ * The item will already have been checked for the specific type and subtype.
+ */
+ abstract protected function describeMismatchSafely($item, Description $mismatchDescription);
+
+ // -- Private Methods
+
+ private function _isSafeType($value)
+ {
+ switch ($this->_expectedType) {
+
+ case self::TYPE_ANY:
+ return true;
+
+ case self::TYPE_STRING:
+ return is_string($value) || is_numeric($value);
+
+ case self::TYPE_NUMERIC:
+ return is_numeric($value) || is_string($value);
+
+ case self::TYPE_ARRAY:
+ return is_array($value);
+
+ case self::TYPE_OBJECT:
+ return is_object($value)
+ && ($this->_expectedSubtype === null
+ || $value instanceof $this->_expectedSubtype);
+
+ case self::TYPE_RESOURCE:
+ return is_resource($value)
+ && ($this->_expectedSubtype === null
+ || get_resource_type($value) == $this->_expectedSubtype);
+
+ case self::TYPE_BOOLEAN:
+ return true;
+
+ default:
+ return true;
+
+ }
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Util.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Util.php
new file mode 100644
index 000000000..50f920176
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Util.php
@@ -0,0 +1,72 @@
+ all items are
+ */
+ public static function createMatcherArray(array $items)
+ {
+ //Extract single array item
+ if (count($items) == 1 && is_array($items[0])) {
+ $items = $items[0];
+ }
+
+ //Replace non-matchers
+ foreach ($items as &$item) {
+ if (!($item instanceof Matcher)) {
+ $item = Core\IsEqual::equalTo($item);
+ }
+ }
+
+ return $items;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Xml/HasXPath.php b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Xml/HasXPath.php
new file mode 100644
index 000000000..d9764e45f
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/hamcrest/Hamcrest/Xml/HasXPath.php
@@ -0,0 +1,195 @@
+_xpath = $xpath;
+ $this->_matcher = $matcher;
+ }
+
+ /**
+ * Matches if the XPath matches against the DOM node and the matcher.
+ *
+ * @param string|\DOMNode $actual
+ * @param Description $mismatchDescription
+ * @return bool
+ */
+ protected function matchesWithDiagnosticDescription($actual, Description $mismatchDescription)
+ {
+ if (is_string($actual)) {
+ $actual = $this->createDocument($actual);
+ } elseif (!$actual instanceof \DOMNode) {
+ $mismatchDescription->appendText('was ')->appendValue($actual);
+
+ return false;
+ }
+ $result = $this->evaluate($actual);
+ if ($result instanceof \DOMNodeList) {
+ return $this->matchesContent($result, $mismatchDescription);
+ } else {
+ return $this->matchesExpression($result, $mismatchDescription);
+ }
+ }
+
+ /**
+ * Creates and returns a DOMDocument
from the given
+ * XML or HTML string.
+ *
+ * @param string $text
+ * @return \DOMDocument built from $text
+ * @throws \InvalidArgumentException if the document is not valid
+ */
+ protected function createDocument($text)
+ {
+ $document = new \DOMDocument();
+ if (preg_match('/^\s*<\?xml/', $text)) {
+ if (!@$document->loadXML($text)) {
+ throw new \InvalidArgumentException('Must pass a valid XML document');
+ }
+ } else {
+ if (!@$document->loadHTML($text)) {
+ throw new \InvalidArgumentException('Must pass a valid HTML or XHTML document');
+ }
+ }
+
+ return $document;
+ }
+
+ /**
+ * Applies the configured XPath to the DOM node and returns either
+ * the result if it's an expression or the node list if it's a query.
+ *
+ * @param \DOMNode $node context from which to issue query
+ * @return mixed result of expression or DOMNodeList from query
+ */
+ protected function evaluate(\DOMNode $node)
+ {
+ if ($node instanceof \DOMDocument) {
+ $xpathDocument = new \DOMXPath($node);
+
+ return $xpathDocument->evaluate($this->_xpath);
+ } else {
+ $xpathDocument = new \DOMXPath($node->ownerDocument);
+
+ return $xpathDocument->evaluate($this->_xpath, $node);
+ }
+ }
+
+ /**
+ * Matches if the list of nodes is not empty and the content of at least
+ * one node matches the configured matcher, if supplied.
+ *
+ * @param \DOMNodeList $nodes selected by the XPath query
+ * @param Description $mismatchDescription
+ * @return bool
+ */
+ protected function matchesContent(\DOMNodeList $nodes, Description $mismatchDescription)
+ {
+ if ($nodes->length == 0) {
+ $mismatchDescription->appendText('XPath returned no results');
+ } elseif ($this->_matcher === null) {
+ return true;
+ } else {
+ foreach ($nodes as $node) {
+ if ($this->_matcher->matches($node->textContent)) {
+ return true;
+ }
+ }
+ $content = array();
+ foreach ($nodes as $node) {
+ $content[] = $node->textContent;
+ }
+ $mismatchDescription->appendText('XPath returned ')
+ ->appendValue($content);
+ }
+
+ return false;
+ }
+
+ /**
+ * Matches if the result of the XPath expression matches the configured
+ * matcher or evaluates to true
if there is none.
+ *
+ * @param mixed $result result of the XPath expression
+ * @param Description $mismatchDescription
+ * @return bool
+ */
+ protected function matchesExpression($result, Description $mismatchDescription)
+ {
+ if ($this->_matcher === null) {
+ if ($result) {
+ return true;
+ }
+ $mismatchDescription->appendText('XPath expression result was ')
+ ->appendValue($result);
+ } else {
+ if ($this->_matcher->matches($result)) {
+ return true;
+ }
+ $mismatchDescription->appendText('XPath expression result ');
+ $this->_matcher->describeMismatch($result, $mismatchDescription);
+ }
+
+ return false;
+ }
+
+ public function describeTo(Description $description)
+ {
+ $description->appendText('XML or HTML document with XPath "')
+ ->appendText($this->_xpath)
+ ->appendText('"');
+ if ($this->_matcher !== null) {
+ $description->appendText(' ');
+ $this->_matcher->describeTo($description);
+ }
+ }
+
+ /**
+ * Wraps $matcher
with {@link Hamcrest\Core\IsEqual)
+ * if it's not a matcher and the XPath in count()
+ * if it's an integer.
+ *
+ * @factory
+ */
+ public static function hasXPath($xpath, $matcher = null)
+ {
+ if ($matcher === null || $matcher instanceof Matcher) {
+ return new self($xpath, $matcher);
+ } elseif (is_int($matcher) && strpos($xpath, 'count(') !== 0) {
+ $xpath = 'count(' . $xpath . ')';
+ }
+
+ return new self($xpath, IsEqual::equalTo($matcher));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/AbstractMatcherTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/AbstractMatcherTest.php
new file mode 100644
index 000000000..6c52c0e5d
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/AbstractMatcherTest.php
@@ -0,0 +1,66 @@
+assertTrue($matcher->matches($arg), $message);
+ }
+
+ public function assertDoesNotMatch(\Hamcrest\Matcher $matcher, $arg, $message)
+ {
+ $this->assertFalse($matcher->matches($arg), $message);
+ }
+
+ public function assertDescription($expected, \Hamcrest\Matcher $matcher)
+ {
+ $description = new \Hamcrest\StringDescription();
+ $description->appendDescriptionOf($matcher);
+ $this->assertEquals($expected, (string) $description, 'Expected description');
+ }
+
+ public function assertMismatchDescription($expected, \Hamcrest\Matcher $matcher, $arg)
+ {
+ $description = new \Hamcrest\StringDescription();
+ $this->assertFalse(
+ $matcher->matches($arg),
+ 'Precondtion: Matcher should not match item'
+ );
+ $matcher->describeMismatch($arg, $description);
+ $this->assertEquals(
+ $expected,
+ (string) $description,
+ 'Expected mismatch description'
+ );
+ }
+
+ public function testIsNullSafe()
+ {
+ //Should not generate any notices
+ $this->createMatcher()->matches(null);
+ $this->createMatcher()->describeMismatch(
+ null,
+ new \Hamcrest\NullDescription()
+ );
+ }
+
+ public function testCopesWithUnknownTypes()
+ {
+ //Should not generate any notices
+ $this->createMatcher()->matches(new UnknownType());
+ $this->createMatcher()->describeMismatch(
+ new UnknownType(),
+ new NullDescription()
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingInAnyOrderTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingInAnyOrderTest.php
new file mode 100644
index 000000000..45d9f138a
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingInAnyOrderTest.php
@@ -0,0 +1,54 @@
+assertDescription('[<1>, <2>] in any order', containsInAnyOrder(array(1, 2)));
+ }
+
+ public function testMatchesItemsInAnyOrder()
+ {
+ $this->assertMatches(containsInAnyOrder(array(1, 2, 3)), array(1, 2, 3), 'in order');
+ $this->assertMatches(containsInAnyOrder(array(1, 2, 3)), array(3, 2, 1), 'out of order');
+ $this->assertMatches(containsInAnyOrder(array(1)), array(1), 'single');
+ }
+
+ public function testAppliesMatchersInAnyOrder()
+ {
+ $this->assertMatches(
+ containsInAnyOrder(array(1, 2, 3)),
+ array(1, 2, 3),
+ 'in order'
+ );
+ $this->assertMatches(
+ containsInAnyOrder(array(1, 2, 3)),
+ array(3, 2, 1),
+ 'out of order'
+ );
+ $this->assertMatches(
+ containsInAnyOrder(array(1)),
+ array(1),
+ 'single'
+ );
+ }
+
+ public function testMismatchesItemsInAnyOrder()
+ {
+ $matcher = containsInAnyOrder(array(1, 2, 3));
+
+ $this->assertMismatchDescription('was null', $matcher, null);
+ $this->assertMismatchDescription('No item matches: <1>, <2>, <3> in []', $matcher, array());
+ $this->assertMismatchDescription('No item matches: <2>, <3> in [<1>]', $matcher, array(1));
+ $this->assertMismatchDescription('Not matched: <4>', $matcher, array(4, 3, 2, 1));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingInOrderTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingInOrderTest.php
new file mode 100644
index 000000000..1868343fa
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingInOrderTest.php
@@ -0,0 +1,44 @@
+assertDescription('[<1>, <2>]', arrayContaining(array(1, 2)));
+ }
+
+ public function testMatchesItemsInOrder()
+ {
+ $this->assertMatches(arrayContaining(array(1, 2, 3)), array(1, 2, 3), 'in order');
+ $this->assertMatches(arrayContaining(array(1)), array(1), 'single');
+ }
+
+ public function testAppliesMatchersInOrder()
+ {
+ $this->assertMatches(
+ arrayContaining(array(1, 2, 3)),
+ array(1, 2, 3),
+ 'in order'
+ );
+ $this->assertMatches(arrayContaining(array(1)), array(1), 'single');
+ }
+
+ public function testMismatchesItemsInAnyOrder()
+ {
+ $matcher = arrayContaining(array(1, 2, 3));
+ $this->assertMismatchDescription('was null', $matcher, null);
+ $this->assertMismatchDescription('No item matched: <1>', $matcher, array());
+ $this->assertMismatchDescription('No item matched: <2>', $matcher, array(1));
+ $this->assertMismatchDescription('item with key 0: was <4>', $matcher, array(4, 3, 2, 1));
+ $this->assertMismatchDescription('item with key 2: was <4>', $matcher, array(1, 2, 4));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingKeyTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingKeyTest.php
new file mode 100644
index 000000000..31770d8dd
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingKeyTest.php
@@ -0,0 +1,62 @@
+1);
+
+ $this->assertMatches(hasKey('a'), $array, 'Matches single key');
+ }
+
+ public function testMatchesArrayContainingKey()
+ {
+ $array = array('a'=>1, 'b'=>2, 'c'=>3);
+
+ $this->assertMatches(hasKey('a'), $array, 'Matches a');
+ $this->assertMatches(hasKey('c'), $array, 'Matches c');
+ }
+
+ public function testMatchesArrayContainingKeyWithIntegerKeys()
+ {
+ $array = array(1=>'A', 2=>'B');
+
+ assertThat($array, hasKey(1));
+ }
+
+ public function testMatchesArrayContainingKeyWithNumberKeys()
+ {
+ $array = array(1=>'A', 2=>'B');
+
+ assertThat($array, hasKey(1));
+
+ // very ugly version!
+ assertThat($array, IsArrayContainingKey::hasKeyInArray(2));
+ }
+
+ public function testHasReadableDescription()
+ {
+ $this->assertDescription('array with key "a"', hasKey('a'));
+ }
+
+ public function testDoesNotMatchEmptyArray()
+ {
+ $this->assertMismatchDescription('array was []', hasKey('Foo'), array());
+ }
+
+ public function testDoesNotMatchArrayMissingKey()
+ {
+ $array = array('a'=>1, 'b'=>2, 'c'=>3);
+
+ $this->assertMismatchDescription('array was ["a" => <1>, "b" => <2>, "c" => <3>]', hasKey('d'), $array);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingKeyValuePairTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingKeyValuePairTest.php
new file mode 100644
index 000000000..a415f9f7a
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingKeyValuePairTest.php
@@ -0,0 +1,36 @@
+1, 'b'=>2);
+
+ $this->assertMatches(hasKeyValuePair(equalTo('a'), equalTo(1)), $array, 'matcherA');
+ $this->assertMatches(hasKeyValuePair(equalTo('b'), equalTo(2)), $array, 'matcherB');
+ $this->assertMismatchDescription(
+ 'array was ["a" => <1>, "b" => <2>]',
+ hasKeyValuePair(equalTo('c'), equalTo(3)),
+ $array
+ );
+ }
+
+ public function testDoesNotMatchNull()
+ {
+ $this->assertMismatchDescription('was null', hasKeyValuePair(anything(), anything()), null);
+ }
+
+ public function testHasReadableDescription()
+ {
+ $this->assertDescription('array containing ["a" => <2>]', hasKeyValuePair(equalTo('a'), equalTo(2)));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingTest.php
new file mode 100644
index 000000000..8d5bd8109
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayContainingTest.php
@@ -0,0 +1,50 @@
+assertMatches(
+ hasItemInArray('a'),
+ array('a', 'b', 'c'),
+ "should matches array that contains 'a'"
+ );
+ }
+
+ public function testDoesNotMatchAnArrayThatDoesntContainAnElementMatchingTheGivenMatcher()
+ {
+ $this->assertDoesNotMatch(
+ hasItemInArray('a'),
+ array('b', 'c'),
+ "should not matches array that doesn't contain 'a'"
+ );
+ $this->assertDoesNotMatch(
+ hasItemInArray('a'),
+ array(),
+ 'should not match empty array'
+ );
+ }
+
+ public function testDoesNotMatchNull()
+ {
+ $this->assertDoesNotMatch(
+ hasItemInArray('a'),
+ null,
+ 'should not match null'
+ );
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription('an array containing "a"', hasItemInArray('a'));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayTest.php
new file mode 100644
index 000000000..e4db53e79
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayTest.php
@@ -0,0 +1,89 @@
+assertMatches(
+ anArray(array(equalTo('a'), equalTo('b'), equalTo('c'))),
+ array('a', 'b', 'c'),
+ 'should match array with matching elements'
+ );
+ }
+
+ public function testDoesNotMatchAnArrayWhenElementsDoNotMatch()
+ {
+ $this->assertDoesNotMatch(
+ anArray(array(equalTo('a'), equalTo('b'))),
+ array('b', 'c'),
+ 'should not match array with different elements'
+ );
+ }
+
+ public function testDoesNotMatchAnArrayOfDifferentSize()
+ {
+ $this->assertDoesNotMatch(
+ anArray(array(equalTo('a'), equalTo('b'))),
+ array('a', 'b', 'c'),
+ 'should not match larger array'
+ );
+ $this->assertDoesNotMatch(
+ anArray(array(equalTo('a'), equalTo('b'))),
+ array('a'),
+ 'should not match smaller array'
+ );
+ }
+
+ public function testDoesNotMatchNull()
+ {
+ $this->assertDoesNotMatch(
+ anArray(array(equalTo('a'))),
+ null,
+ 'should not match null'
+ );
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription(
+ '["a", "b"]',
+ anArray(array(equalTo('a'), equalTo('b')))
+ );
+ }
+
+ public function testHasAReadableMismatchDescriptionWhenKeysDontMatch()
+ {
+ $this->assertMismatchDescription(
+ 'array keys were [<1>, <2>]',
+ anArray(array(equalTo('a'), equalTo('b'))),
+ array(1 => 'a', 2 => 'b')
+ );
+ }
+
+ public function testSupportsMatchesAssociativeArrays()
+ {
+ $this->assertMatches(
+ anArray(array('x'=>equalTo('a'), 'y'=>equalTo('b'), 'z'=>equalTo('c'))),
+ array('x'=>'a', 'y'=>'b', 'z'=>'c'),
+ 'should match associative array with matching elements'
+ );
+ }
+
+ public function testDoesNotMatchAnAssociativeArrayWhenKeysDoNotMatch()
+ {
+ $this->assertDoesNotMatch(
+ anArray(array('x'=>equalTo('a'), 'y'=>equalTo('b'))),
+ array('x'=>'b', 'z'=>'c'),
+ 'should not match array with different keys'
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayWithSizeTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayWithSizeTest.php
new file mode 100644
index 000000000..8413c896d
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Array/IsArrayWithSizeTest.php
@@ -0,0 +1,37 @@
+assertMatches(arrayWithSize(equalTo(3)), array(1, 2, 3), 'correct size');
+ $this->assertDoesNotMatch(arrayWithSize(equalTo(2)), array(1, 2, 3), 'incorrect size');
+ }
+
+ public function testProvidesConvenientShortcutForArrayWithSizeEqualTo()
+ {
+ $this->assertMatches(arrayWithSize(3), array(1, 2, 3), 'correct size');
+ $this->assertDoesNotMatch(arrayWithSize(2), array(1, 2, 3), 'incorrect size');
+ }
+
+ public function testEmptyArray()
+ {
+ $this->assertMatches(emptyArray(), array(), 'correct size');
+ $this->assertDoesNotMatch(emptyArray(), array(1), 'incorrect size');
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription('an array with size <3>', arrayWithSize(equalTo(3)));
+ $this->assertDescription('an empty array', emptyArray());
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/BaseMatcherTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/BaseMatcherTest.php
new file mode 100644
index 000000000..833e2c3ec
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/BaseMatcherTest.php
@@ -0,0 +1,23 @@
+appendText('SOME DESCRIPTION');
+ }
+
+ public function testDescribesItselfWithToStringMethod()
+ {
+ $someMatcher = new \Hamcrest\SomeMatcher();
+ $this->assertEquals('SOME DESCRIPTION', (string) $someMatcher);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Collection/IsEmptyTraversableTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Collection/IsEmptyTraversableTest.php
new file mode 100644
index 000000000..2f15fb499
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Collection/IsEmptyTraversableTest.php
@@ -0,0 +1,77 @@
+assertMatches(
+ emptyTraversable(),
+ new \ArrayObject(array()),
+ 'an empty traversable'
+ );
+ }
+
+ public function testEmptyMatcherDoesNotMatchWhenNotEmpty()
+ {
+ $this->assertDoesNotMatch(
+ emptyTraversable(),
+ new \ArrayObject(array(1, 2, 3)),
+ 'a non-empty traversable'
+ );
+ }
+
+ public function testEmptyMatcherDoesNotMatchNull()
+ {
+ $this->assertDoesNotMatch(
+ emptyTraversable(),
+ null,
+ 'should not match null'
+ );
+ }
+
+ public function testEmptyMatcherHasAReadableDescription()
+ {
+ $this->assertDescription('an empty traversable', emptyTraversable());
+ }
+
+ public function testNonEmptyDoesNotMatchNull()
+ {
+ $this->assertDoesNotMatch(
+ nonEmptyTraversable(),
+ null,
+ 'should not match null'
+ );
+ }
+
+ public function testNonEmptyDoesNotMatchWhenEmpty()
+ {
+ $this->assertDoesNotMatch(
+ nonEmptyTraversable(),
+ new \ArrayObject(array()),
+ 'an empty traversable'
+ );
+ }
+
+ public function testNonEmptyMatchesWhenNotEmpty()
+ {
+ $this->assertMatches(
+ nonEmptyTraversable(),
+ new \ArrayObject(array(1, 2, 3)),
+ 'a non-empty traversable'
+ );
+ }
+
+ public function testNonEmptyNonEmptyMatcherHasAReadableDescription()
+ {
+ $this->assertDescription('a non-empty traversable', nonEmptyTraversable());
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Collection/IsTraversableWithSizeTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Collection/IsTraversableWithSizeTest.php
new file mode 100644
index 000000000..c1c67a7a4
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Collection/IsTraversableWithSizeTest.php
@@ -0,0 +1,57 @@
+assertMatches(
+ traversableWithSize(equalTo(3)),
+ new \ArrayObject(array(1, 2, 3)),
+ 'correct size'
+ );
+ }
+
+ public function testDoesNotMatchWhenSizeIsIncorrect()
+ {
+ $this->assertDoesNotMatch(
+ traversableWithSize(equalTo(2)),
+ new \ArrayObject(array(1, 2, 3)),
+ 'incorrect size'
+ );
+ }
+
+ public function testDoesNotMatchNull()
+ {
+ $this->assertDoesNotMatch(
+ traversableWithSize(3),
+ null,
+ 'should not match null'
+ );
+ }
+
+ public function testProvidesConvenientShortcutForTraversableWithSizeEqualTo()
+ {
+ $this->assertMatches(
+ traversableWithSize(3),
+ new \ArrayObject(array(1, 2, 3)),
+ 'correct size'
+ );
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription(
+ 'a traversable with size <3>',
+ traversableWithSize(equalTo(3))
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/AllOfTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/AllOfTest.php
new file mode 100644
index 000000000..86b8c277f
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/AllOfTest.php
@@ -0,0 +1,56 @@
+assertDescription(
+ '("good" and "bad" and "ugly")',
+ allOf('good', 'bad', 'ugly')
+ );
+ }
+
+ public function testMismatchDescriptionDescribesFirstFailingMatch()
+ {
+ $this->assertMismatchDescription(
+ '"good" was "bad"',
+ allOf('bad', 'good'),
+ 'bad'
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/AnyOfTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/AnyOfTest.php
new file mode 100644
index 000000000..3d62b9350
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/AnyOfTest.php
@@ -0,0 +1,79 @@
+assertDescription(
+ '("good" or "bad" or "ugly")',
+ anyOf('good', 'bad', 'ugly')
+ );
+ }
+
+ public function testNoneOfEvaluatesToTheLogicalDisjunctionOfTwoOtherMatchers()
+ {
+ assertThat('good', not(noneOf('bad', 'good')));
+ assertThat('good', not(noneOf('good', 'good')));
+ assertThat('good', not(noneOf('good', 'bad')));
+
+ assertThat('good', noneOf('bad', startsWith('b')));
+ }
+
+ public function testNoneOfEvaluatesToTheLogicalDisjunctionOfManyOtherMatchers()
+ {
+ assertThat('good', not(noneOf('bad', 'good', 'bad', 'bad', 'bad')));
+ assertThat('good', noneOf('bad', 'bad', 'bad', 'bad', 'bad'));
+ }
+
+ public function testNoneOfSupportsMixedTypes()
+ {
+ $combined = noneOf(
+ equalTo(new \Hamcrest\Core\SampleBaseClass('good')),
+ equalTo(new \Hamcrest\Core\SampleBaseClass('ugly')),
+ equalTo(new \Hamcrest\Core\SampleSubClass('good'))
+ );
+
+ assertThat(new \Hamcrest\Core\SampleSubClass('bad'), $combined);
+ }
+
+ public function testNoneOfHasAReadableDescription()
+ {
+ $this->assertDescription(
+ 'not ("good" or "bad" or "ugly")',
+ noneOf('good', 'bad', 'ugly')
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/CombinableMatcherTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/CombinableMatcherTest.php
new file mode 100644
index 000000000..4c2261499
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/CombinableMatcherTest.php
@@ -0,0 +1,59 @@
+_either_3_or_4 = \Hamcrest\Core\CombinableMatcher::either(equalTo(3))->orElse(equalTo(4));
+ $this->_not_3_and_not_4 = \Hamcrest\Core\CombinableMatcher::both(not(equalTo(3)))->andAlso(not(equalTo(4)));
+ }
+
+ protected function createMatcher()
+ {
+ return \Hamcrest\Core\CombinableMatcher::either(equalTo('irrelevant'))->orElse(equalTo('ignored'));
+ }
+
+ public function testBothAcceptsAndRejects()
+ {
+ assertThat(2, $this->_not_3_and_not_4);
+ assertThat(3, not($this->_not_3_and_not_4));
+ }
+
+ public function testAcceptsAndRejectsThreeAnds()
+ {
+ $tripleAnd = $this->_not_3_and_not_4->andAlso(equalTo(2));
+ assertThat(2, $tripleAnd);
+ assertThat(3, not($tripleAnd));
+ }
+
+ public function testBothDescribesItself()
+ {
+ $this->assertEquals('(not <3> and not <4>)', (string) $this->_not_3_and_not_4);
+ $this->assertMismatchDescription('was <3>', $this->_not_3_and_not_4, 3);
+ }
+
+ public function testEitherAcceptsAndRejects()
+ {
+ assertThat(3, $this->_either_3_or_4);
+ assertThat(6, not($this->_either_3_or_4));
+ }
+
+ public function testAcceptsAndRejectsThreeOrs()
+ {
+ $orTriple = $this->_either_3_or_4->orElse(greaterThan(10));
+
+ assertThat(11, $orTriple);
+ assertThat(9, not($orTriple));
+ }
+
+ public function testEitherDescribesItself()
+ {
+ $this->assertEquals('(<3> or <4>)', (string) $this->_either_3_or_4);
+ $this->assertMismatchDescription('was <6>', $this->_either_3_or_4, 6);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/DescribedAsTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/DescribedAsTest.php
new file mode 100644
index 000000000..673ab41e1
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/DescribedAsTest.php
@@ -0,0 +1,36 @@
+assertDescription('m1 description', $m1);
+ $this->assertDescription('m2 description', $m2);
+ }
+
+ public function testAppendsValuesToDescription()
+ {
+ $m = describedAs('value 1 = %0, value 2 = %1', anything(), 33, 97);
+
+ $this->assertDescription('value 1 = <33>, value 2 = <97>', $m);
+ }
+
+ public function testDelegatesMatchingToAnotherMatcher()
+ {
+ $m1 = describedAs('irrelevant', anything());
+ $m2 = describedAs('irrelevant', not(anything()));
+
+ $this->assertTrue($m1->matches(new \stdClass()));
+ $this->assertFalse($m2->matches('hi'));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/EveryTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/EveryTest.php
new file mode 100644
index 000000000..5eb153c5e
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/EveryTest.php
@@ -0,0 +1,30 @@
+assertEquals('every item is a string containing "a"', (string) $each);
+
+ $this->assertMismatchDescription('an item was "BbB"', $each, array('BbB'));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/HasToStringTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/HasToStringTest.php
new file mode 100644
index 000000000..e2e136dcd
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/HasToStringTest.php
@@ -0,0 +1,108 @@
+assertMatches(
+ hasToString(equalTo('php')),
+ new \Hamcrest\Core\PhpForm(),
+ 'correct __toString'
+ );
+ $this->assertMatches(
+ hasToString(equalTo('java')),
+ new \Hamcrest\Core\JavaForm(),
+ 'correct toString'
+ );
+ }
+
+ public function testPicksJavaOverPhpToString()
+ {
+ $this->assertMatches(
+ hasToString(equalTo('java')),
+ new \Hamcrest\Core\BothForms(),
+ 'correct toString'
+ );
+ }
+
+ public function testDoesNotMatchWhenToStringDoesNotMatch()
+ {
+ $this->assertDoesNotMatch(
+ hasToString(equalTo('mismatch')),
+ new \Hamcrest\Core\PhpForm(),
+ 'incorrect __toString'
+ );
+ $this->assertDoesNotMatch(
+ hasToString(equalTo('mismatch')),
+ new \Hamcrest\Core\JavaForm(),
+ 'incorrect toString'
+ );
+ $this->assertDoesNotMatch(
+ hasToString(equalTo('mismatch')),
+ new \Hamcrest\Core\BothForms(),
+ 'incorrect __toString'
+ );
+ }
+
+ public function testDoesNotMatchNull()
+ {
+ $this->assertDoesNotMatch(
+ hasToString(equalTo('a')),
+ null,
+ 'should not match null'
+ );
+ }
+
+ public function testProvidesConvenientShortcutForTraversableWithSizeEqualTo()
+ {
+ $this->assertMatches(
+ hasToString(equalTo('php')),
+ new \Hamcrest\Core\PhpForm(),
+ 'correct __toString'
+ );
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription(
+ 'an object with toString() "php"',
+ hasToString(equalTo('php'))
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsAnythingTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsAnythingTest.php
new file mode 100644
index 000000000..f68032e53
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsAnythingTest.php
@@ -0,0 +1,29 @@
+assertDescription('ANYTHING', anything());
+ }
+
+ public function testCanOverrideDescription()
+ {
+ $description = 'description';
+ $this->assertDescription($description, anything($description));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsCollectionContainingTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsCollectionContainingTest.php
new file mode 100644
index 000000000..a3929b543
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsCollectionContainingTest.php
@@ -0,0 +1,91 @@
+assertMatches(
+ $itemMatcher,
+ array('a', 'b', 'c'),
+ "should match list that contains 'a'"
+ );
+ }
+
+ public function testDoesNotMatchCollectionThatDoesntContainAnElementMatchingTheGivenMatcher()
+ {
+ $matcher1 = hasItem(equalTo('a'));
+ $this->assertDoesNotMatch(
+ $matcher1,
+ array('b', 'c'),
+ "should not match list that doesn't contain 'a'"
+ );
+
+ $matcher2 = hasItem(equalTo('a'));
+ $this->assertDoesNotMatch(
+ $matcher2,
+ array(),
+ 'should not match the empty list'
+ );
+ }
+
+ public function testDoesNotMatchNull()
+ {
+ $this->assertDoesNotMatch(
+ hasItem(equalTo('a')),
+ null,
+ 'should not match null'
+ );
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription('a collection containing "a"', hasItem(equalTo('a')));
+ }
+
+ public function testMatchesAllItemsInCollection()
+ {
+ $matcher1 = hasItems(equalTo('a'), equalTo('b'), equalTo('c'));
+ $this->assertMatches(
+ $matcher1,
+ array('a', 'b', 'c'),
+ 'should match list containing all items'
+ );
+
+ $matcher2 = hasItems('a', 'b', 'c');
+ $this->assertMatches(
+ $matcher2,
+ array('a', 'b', 'c'),
+ 'should match list containing all items (without matchers)'
+ );
+
+ $matcher3 = hasItems(equalTo('a'), equalTo('b'), equalTo('c'));
+ $this->assertMatches(
+ $matcher3,
+ array('c', 'b', 'a'),
+ 'should match list containing all items in any order'
+ );
+
+ $matcher4 = hasItems(equalTo('a'), equalTo('b'), equalTo('c'));
+ $this->assertMatches(
+ $matcher4,
+ array('e', 'c', 'b', 'a', 'd'),
+ 'should match list containing all items plus others'
+ );
+
+ $matcher5 = hasItems(equalTo('a'), equalTo('b'), equalTo('c'));
+ $this->assertDoesNotMatch(
+ $matcher5,
+ array('e', 'c', 'b', 'd'), // 'a' missing
+ 'should not match list unless it contains all items'
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsEqualTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsEqualTest.php
new file mode 100644
index 000000000..73e3ff07e
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsEqualTest.php
@@ -0,0 +1,102 @@
+_arg = $arg;
+ }
+
+ public function __toString()
+ {
+ return $this->_arg;
+ }
+}
+
+class IsEqualTest extends \Hamcrest\AbstractMatcherTest
+{
+
+ protected function createMatcher()
+ {
+ return \Hamcrest\Core\IsEqual::equalTo('irrelevant');
+ }
+
+ public function testComparesObjectsUsingEqualityOperator()
+ {
+ assertThat("hi", equalTo("hi"));
+ assertThat("bye", not(equalTo("hi")));
+
+ assertThat(1, equalTo(1));
+ assertThat(1, not(equalTo(2)));
+
+ assertThat("2", equalTo(2));
+ }
+
+ public function testCanCompareNullValues()
+ {
+ assertThat(null, equalTo(null));
+
+ assertThat(null, not(equalTo('hi')));
+ assertThat('hi', not(equalTo(null)));
+ }
+
+ public function testComparesTheElementsOfAnArray()
+ {
+ $s1 = array('a', 'b');
+ $s2 = array('a', 'b');
+ $s3 = array('c', 'd');
+ $s4 = array('a', 'b', 'c', 'd');
+
+ assertThat($s1, equalTo($s1));
+ assertThat($s2, equalTo($s1));
+ assertThat($s3, not(equalTo($s1)));
+ assertThat($s4, not(equalTo($s1)));
+ }
+
+ public function testComparesTheElementsOfAnArrayOfPrimitiveTypes()
+ {
+ $i1 = array(1, 2);
+ $i2 = array(1, 2);
+ $i3 = array(3, 4);
+ $i4 = array(1, 2, 3, 4);
+
+ assertThat($i1, equalTo($i1));
+ assertThat($i2, equalTo($i1));
+ assertThat($i3, not(equalTo($i1)));
+ assertThat($i4, not(equalTo($i1)));
+ }
+
+ public function testRecursivelyTestsElementsOfArrays()
+ {
+ $i1 = array(array(1, 2), array(3, 4));
+ $i2 = array(array(1, 2), array(3, 4));
+ $i3 = array(array(5, 6), array(7, 8));
+ $i4 = array(array(1, 2, 3, 4), array(3, 4));
+
+ assertThat($i1, equalTo($i1));
+ assertThat($i2, equalTo($i1));
+ assertThat($i3, not(equalTo($i1)));
+ assertThat($i4, not(equalTo($i1)));
+ }
+
+ public function testIncludesTheResultOfCallingToStringOnItsArgumentInTheDescription()
+ {
+ $argumentDescription = 'ARGUMENT DESCRIPTION';
+ $argument = new \Hamcrest\Core\DummyToStringClass($argumentDescription);
+ $this->assertDescription('<' . $argumentDescription . '>', equalTo($argument));
+ }
+
+ public function testReturnsAnObviousDescriptionIfCreatedWithANestedMatcherByMistake()
+ {
+ $innerMatcher = equalTo('NestedMatcher');
+ $this->assertDescription('<' . (string) $innerMatcher . '>', equalTo($innerMatcher));
+ }
+
+ public function testReturnsGoodDescriptionIfCreatedWithNullReference()
+ {
+ $this->assertDescription('null', equalTo(null));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsIdenticalTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsIdenticalTest.php
new file mode 100644
index 000000000..9cc27946c
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsIdenticalTest.php
@@ -0,0 +1,30 @@
+assertDescription('"ARG"', identicalTo('ARG'));
+ }
+
+ public function testReturnsReadableDescriptionFromToStringWhenInitialisedWithNull()
+ {
+ $this->assertDescription('null', identicalTo(null));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsInstanceOfTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsInstanceOfTest.php
new file mode 100644
index 000000000..7a5f095a2
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsInstanceOfTest.php
@@ -0,0 +1,51 @@
+_baseClassInstance = new \Hamcrest\Core\SampleBaseClass('good');
+ $this->_subClassInstance = new \Hamcrest\Core\SampleSubClass('good');
+ }
+
+ protected function createMatcher()
+ {
+ return \Hamcrest\Core\IsInstanceOf::anInstanceOf('stdClass');
+ }
+
+ public function testEvaluatesToTrueIfArgumentIsInstanceOfASpecificClass()
+ {
+ assertThat($this->_baseClassInstance, anInstanceOf('Hamcrest\Core\SampleBaseClass'));
+ assertThat($this->_subClassInstance, anInstanceOf('Hamcrest\Core\SampleSubClass'));
+ assertThat(null, not(anInstanceOf('Hamcrest\Core\SampleBaseClass')));
+ assertThat(new \stdClass(), not(anInstanceOf('Hamcrest\Core\SampleBaseClass')));
+ }
+
+ public function testEvaluatesToFalseIfArgumentIsNotAnObject()
+ {
+ assertThat(null, not(anInstanceOf('Hamcrest\Core\SampleBaseClass')));
+ assertThat(false, not(anInstanceOf('Hamcrest\Core\SampleBaseClass')));
+ assertThat(5, not(anInstanceOf('Hamcrest\Core\SampleBaseClass')));
+ assertThat('foo', not(anInstanceOf('Hamcrest\Core\SampleBaseClass')));
+ assertThat(array(1, 2, 3), not(anInstanceOf('Hamcrest\Core\SampleBaseClass')));
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription('an instance of stdClass', anInstanceOf('stdClass'));
+ }
+
+ public function testDecribesActualClassInMismatchMessage()
+ {
+ $this->assertMismatchDescription(
+ '[Hamcrest\Core\SampleBaseClass] ',
+ anInstanceOf('Hamcrest\Core\SampleSubClass'),
+ $this->_baseClassInstance
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsNotTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsNotTest.php
new file mode 100644
index 000000000..09d4a652a
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsNotTest.php
@@ -0,0 +1,31 @@
+assertMatches(not(equalTo('A')), 'B', 'should match');
+ $this->assertDoesNotMatch(not(equalTo('B')), 'B', 'should not match');
+ }
+
+ public function testProvidesConvenientShortcutForNotEqualTo()
+ {
+ $this->assertMatches(not('A'), 'B', 'should match');
+ $this->assertMatches(not('B'), 'A', 'should match');
+ $this->assertDoesNotMatch(not('A'), 'A', 'should not match');
+ $this->assertDoesNotMatch(not('B'), 'B', 'should not match');
+ }
+
+ public function testUsesDescriptionOfNegatedMatcherWithPrefix()
+ {
+ $this->assertDescription('not a value greater than <2>', not(greaterThan(2)));
+ $this->assertDescription('not "A"', not('A'));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsNullTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsNullTest.php
new file mode 100644
index 000000000..bfa42554d
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsNullTest.php
@@ -0,0 +1,20 @@
+assertDescription('sameInstance("ARG")', sameInstance('ARG'));
+ }
+
+ public function testReturnsReadableDescriptionFromToStringWhenInitialisedWithNull()
+ {
+ $this->assertDescription('sameInstance(null)', sameInstance(null));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsTest.php
new file mode 100644
index 000000000..bbd848b9f
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsTest.php
@@ -0,0 +1,33 @@
+assertMatches(is(equalTo(true)), true, 'should match');
+ $this->assertMatches(is(equalTo(false)), false, 'should match');
+ $this->assertDoesNotMatch(is(equalTo(true)), false, 'should not match');
+ $this->assertDoesNotMatch(is(equalTo(false)), true, 'should not match');
+ }
+
+ public function testGeneratesIsPrefixInDescription()
+ {
+ $this->assertDescription('is ', is(equalTo(true)));
+ }
+
+ public function testProvidesConvenientShortcutForIsEqualTo()
+ {
+ $this->assertMatches(is('A'), 'A', 'should match');
+ $this->assertMatches(is('B'), 'B', 'should match');
+ $this->assertDoesNotMatch(is('A'), 'B', 'should not match');
+ $this->assertDoesNotMatch(is('B'), 'A', 'should not match');
+ $this->assertDescription('is "A"', is('A'));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsTypeOfTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsTypeOfTest.php
new file mode 100644
index 000000000..3f48dea70
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/IsTypeOfTest.php
@@ -0,0 +1,45 @@
+assertDescription('a double', typeOf('double'));
+ $this->assertDescription('an integer', typeOf('integer'));
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription('was null', typeOf('boolean'), null);
+ $this->assertMismatchDescription('was an integer <5>', typeOf('float'), 5);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/SampleBaseClass.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/SampleBaseClass.php
new file mode 100644
index 000000000..c953e7cd7
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/SampleBaseClass.php
@@ -0,0 +1,18 @@
+_arg = $arg;
+ }
+
+ public function __toString()
+ {
+ return $this->_arg;
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/SampleSubClass.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/SampleSubClass.php
new file mode 100644
index 000000000..822f1b641
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Core/SampleSubClass.php
@@ -0,0 +1,6 @@
+_instanceProperty);
+ }
+
+ protected function createMatcher()
+ {
+ return \Hamcrest\Core\Set::set('property_name');
+ }
+
+ public function testEvaluatesToTrueIfArrayPropertyIsSet()
+ {
+ assertThat(array('foo' => 'bar'), set('foo'));
+ }
+
+ public function testNegatedEvaluatesToFalseIfArrayPropertyIsSet()
+ {
+ assertThat(array('foo' => 'bar'), not(notSet('foo')));
+ }
+
+ public function testEvaluatesToTrueIfClassPropertyIsSet()
+ {
+ self::$_classProperty = 'bar';
+ assertThat('Hamcrest\Core\SetTest', set('_classProperty'));
+ }
+
+ public function testNegatedEvaluatesToFalseIfClassPropertyIsSet()
+ {
+ self::$_classProperty = 'bar';
+ assertThat('Hamcrest\Core\SetTest', not(notSet('_classProperty')));
+ }
+
+ public function testEvaluatesToTrueIfObjectPropertyIsSet()
+ {
+ $this->_instanceProperty = 'bar';
+ assertThat($this, set('_instanceProperty'));
+ }
+
+ public function testNegatedEvaluatesToFalseIfObjectPropertyIsSet()
+ {
+ $this->_instanceProperty = 'bar';
+ assertThat($this, not(notSet('_instanceProperty')));
+ }
+
+ public function testEvaluatesToFalseIfArrayPropertyIsNotSet()
+ {
+ assertThat(array('foo' => 'bar'), not(set('baz')));
+ }
+
+ public function testNegatedEvaluatesToTrueIfArrayPropertyIsNotSet()
+ {
+ assertThat(array('foo' => 'bar'), notSet('baz'));
+ }
+
+ public function testEvaluatesToFalseIfClassPropertyIsNotSet()
+ {
+ assertThat('Hamcrest\Core\SetTest', not(set('_classProperty')));
+ }
+
+ public function testNegatedEvaluatesToTrueIfClassPropertyIsNotSet()
+ {
+ assertThat('Hamcrest\Core\SetTest', notSet('_classProperty'));
+ }
+
+ public function testEvaluatesToFalseIfObjectPropertyIsNotSet()
+ {
+ assertThat($this, not(set('_instanceProperty')));
+ }
+
+ public function testNegatedEvaluatesToTrueIfObjectPropertyIsNotSet()
+ {
+ assertThat($this, notSet('_instanceProperty'));
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription('set property foo', set('foo'));
+ $this->assertDescription('unset property bar', notSet('bar'));
+ }
+
+ public function testDecribesPropertySettingInMismatchMessage()
+ {
+ $this->assertMismatchDescription(
+ 'was not set',
+ set('bar'),
+ array('foo' => 'bar')
+ );
+ $this->assertMismatchDescription(
+ 'was "bar"',
+ notSet('foo'),
+ array('foo' => 'bar')
+ );
+ self::$_classProperty = 'bar';
+ $this->assertMismatchDescription(
+ 'was "bar"',
+ notSet('_classProperty'),
+ 'Hamcrest\Core\SetTest'
+ );
+ $this->_instanceProperty = 'bar';
+ $this->assertMismatchDescription(
+ 'was "bar"',
+ notSet('_instanceProperty'),
+ $this
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/FeatureMatcherTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/FeatureMatcherTest.php
new file mode 100644
index 000000000..7543294ae
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/FeatureMatcherTest.php
@@ -0,0 +1,73 @@
+_result = $result;
+ }
+ public function getResult()
+ {
+ return $this->_result;
+ }
+}
+
+/* Test-specific subclass only */
+class ResultMatcher extends \Hamcrest\FeatureMatcher
+{
+ public function __construct()
+ {
+ parent::__construct(self::TYPE_ANY, null, equalTo('bar'), 'Thingy with result', 'result');
+ }
+ public function featureValueOf($actual)
+ {
+ if ($actual instanceof \Hamcrest\Thingy) {
+ return $actual->getResult();
+ }
+ }
+}
+
+class FeatureMatcherTest extends \Hamcrest\AbstractMatcherTest
+{
+
+ private $_resultMatcher;
+
+ public function setUp()
+ {
+ $this->_resultMatcher = $this->_resultMatcher();
+ }
+
+ protected function createMatcher()
+ {
+ return $this->_resultMatcher();
+ }
+
+ public function testMatchesPartOfAnObject()
+ {
+ $this->assertMatches($this->_resultMatcher, new \Hamcrest\Thingy('bar'), 'feature');
+ $this->assertDescription('Thingy with result "bar"', $this->_resultMatcher);
+ }
+
+ public function testMismatchesPartOfAnObject()
+ {
+ $this->assertMismatchDescription(
+ 'result was "foo"',
+ $this->_resultMatcher,
+ new \Hamcrest\Thingy('foo')
+ );
+ }
+
+ public function testDoesNotGenerateNoticesForNull()
+ {
+ $this->assertMismatchDescription('result was null', $this->_resultMatcher, null);
+ }
+
+ // -- Creation Methods
+
+ private function _resultMatcher()
+ {
+ return new \Hamcrest\ResultMatcher();
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/MatcherAssertTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/MatcherAssertTest.php
new file mode 100644
index 000000000..218371211
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/MatcherAssertTest.php
@@ -0,0 +1,190 @@
+getMessage());
+ }
+ try {
+ \Hamcrest\MatcherAssert::assertThat(null);
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('', $ex->getMessage());
+ }
+ try {
+ \Hamcrest\MatcherAssert::assertThat('');
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('', $ex->getMessage());
+ }
+ try {
+ \Hamcrest\MatcherAssert::assertThat(0);
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('', $ex->getMessage());
+ }
+ try {
+ \Hamcrest\MatcherAssert::assertThat(0.0);
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('', $ex->getMessage());
+ }
+ try {
+ \Hamcrest\MatcherAssert::assertThat(array());
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('', $ex->getMessage());
+ }
+ self::assertEquals(6, \Hamcrest\MatcherAssert::getCount(), 'assertion count');
+ }
+
+ public function testAssertThatWithIdentifierAndTrueArgPasses()
+ {
+ \Hamcrest\MatcherAssert::assertThat('identifier', true);
+ \Hamcrest\MatcherAssert::assertThat('identifier', 'non-empty');
+ \Hamcrest\MatcherAssert::assertThat('identifier', 1);
+ \Hamcrest\MatcherAssert::assertThat('identifier', 3.14159);
+ \Hamcrest\MatcherAssert::assertThat('identifier', array(true));
+ self::assertEquals(5, \Hamcrest\MatcherAssert::getCount(), 'assertion count');
+ }
+
+ public function testAssertThatWithIdentifierAndFalseArgFails()
+ {
+ try {
+ \Hamcrest\MatcherAssert::assertThat('identifier', false);
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('identifier', $ex->getMessage());
+ }
+ try {
+ \Hamcrest\MatcherAssert::assertThat('identifier', null);
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('identifier', $ex->getMessage());
+ }
+ try {
+ \Hamcrest\MatcherAssert::assertThat('identifier', '');
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('identifier', $ex->getMessage());
+ }
+ try {
+ \Hamcrest\MatcherAssert::assertThat('identifier', 0);
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('identifier', $ex->getMessage());
+ }
+ try {
+ \Hamcrest\MatcherAssert::assertThat('identifier', 0.0);
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('identifier', $ex->getMessage());
+ }
+ try {
+ \Hamcrest\MatcherAssert::assertThat('identifier', array());
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals('identifier', $ex->getMessage());
+ }
+ self::assertEquals(6, \Hamcrest\MatcherAssert::getCount(), 'assertion count');
+ }
+
+ public function testAssertThatWithActualValueAndMatcherArgsThatMatchPasses()
+ {
+ \Hamcrest\MatcherAssert::assertThat(true, is(true));
+ self::assertEquals(1, \Hamcrest\MatcherAssert::getCount(), 'assertion count');
+ }
+
+ public function testAssertThatWithActualValueAndMatcherArgsThatDontMatchFails()
+ {
+ $expected = 'expected';
+ $actual = 'actual';
+
+ $expectedMessage =
+ 'Expected: "expected"' . PHP_EOL .
+ ' but: was "actual"';
+
+ try {
+ \Hamcrest\MatcherAssert::assertThat($actual, equalTo($expected));
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals($expectedMessage, $ex->getMessage());
+ self::assertEquals(1, \Hamcrest\MatcherAssert::getCount(), 'assertion count');
+ }
+ }
+
+ public function testAssertThatWithIdentifierAndActualValueAndMatcherArgsThatMatchPasses()
+ {
+ \Hamcrest\MatcherAssert::assertThat('identifier', true, is(true));
+ self::assertEquals(1, \Hamcrest\MatcherAssert::getCount(), 'assertion count');
+ }
+
+ public function testAssertThatWithIdentifierAndActualValueAndMatcherArgsThatDontMatchFails()
+ {
+ $expected = 'expected';
+ $actual = 'actual';
+
+ $expectedMessage =
+ 'identifier' . PHP_EOL .
+ 'Expected: "expected"' . PHP_EOL .
+ ' but: was "actual"';
+
+ try {
+ \Hamcrest\MatcherAssert::assertThat('identifier', $actual, equalTo($expected));
+ self::fail('expected assertion failure');
+ } catch (\Hamcrest\AssertionError $ex) {
+ self::assertEquals($expectedMessage, $ex->getMessage());
+ self::assertEquals(1, \Hamcrest\MatcherAssert::getCount(), 'assertion count');
+ }
+ }
+
+ public function testAssertThatWithNoArgsThrowsErrorAndDoesntIncrementCount()
+ {
+ try {
+ \Hamcrest\MatcherAssert::assertThat();
+ self::fail('expected invalid argument exception');
+ } catch (\InvalidArgumentException $ex) {
+ self::assertEquals(0, \Hamcrest\MatcherAssert::getCount(), 'assertion count');
+ }
+ }
+
+ public function testAssertThatWithFourArgsThrowsErrorAndDoesntIncrementCount()
+ {
+ try {
+ \Hamcrest\MatcherAssert::assertThat(1, 2, 3, 4);
+ self::fail('expected invalid argument exception');
+ } catch (\InvalidArgumentException $ex) {
+ self::assertEquals(0, \Hamcrest\MatcherAssert::getCount(), 'assertion count');
+ }
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Number/IsCloseToTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Number/IsCloseToTest.php
new file mode 100644
index 000000000..987d55267
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Number/IsCloseToTest.php
@@ -0,0 +1,27 @@
+assertTrue($p->matches(1.0));
+ $this->assertTrue($p->matches(0.5));
+ $this->assertTrue($p->matches(1.5));
+
+ $this->assertDoesNotMatch($p, 2.0, 'too large');
+ $this->assertMismatchDescription('<2F> differed by <0.5F>', $p, 2.0);
+ $this->assertDoesNotMatch($p, 0.0, 'number too small');
+ $this->assertMismatchDescription('<0F> differed by <0.5F>', $p, 0.0);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Number/OrderingComparisonTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Number/OrderingComparisonTest.php
new file mode 100644
index 000000000..a4c94d373
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Number/OrderingComparisonTest.php
@@ -0,0 +1,41 @@
+_text = $text;
+ }
+
+ public function describeTo(\Hamcrest\Description $description)
+ {
+ $description->appendText($this->_text);
+ }
+}
+
+class StringDescriptionTest extends \PhpUnit_Framework_TestCase
+{
+
+ private $_description;
+
+ public function setUp()
+ {
+ $this->_description = new \Hamcrest\StringDescription();
+ }
+
+ public function testAppendTextAppendsTextInformation()
+ {
+ $this->_description->appendText('foo')->appendText('bar');
+ $this->assertEquals('foobar', (string) $this->_description);
+ }
+
+ public function testAppendValueCanAppendTextTypes()
+ {
+ $this->_description->appendValue('foo');
+ $this->assertEquals('"foo"', (string) $this->_description);
+ }
+
+ public function testSpecialCharactersAreEscapedForStringTypes()
+ {
+ $this->_description->appendValue("foo\\bar\"zip\r\n");
+ $this->assertEquals('"foo\\bar\\"zip\r\n"', (string) $this->_description);
+ }
+
+ public function testIntegerValuesCanBeAppended()
+ {
+ $this->_description->appendValue(42);
+ $this->assertEquals('<42>', (string) $this->_description);
+ }
+
+ public function testFloatValuesCanBeAppended()
+ {
+ $this->_description->appendValue(42.78);
+ $this->assertEquals('<42.78F>', (string) $this->_description);
+ }
+
+ public function testNullValuesCanBeAppended()
+ {
+ $this->_description->appendValue(null);
+ $this->assertEquals('null', (string) $this->_description);
+ }
+
+ public function testArraysCanBeAppended()
+ {
+ $this->_description->appendValue(array('foo', 42.78));
+ $this->assertEquals('["foo", <42.78F>]', (string) $this->_description);
+ }
+
+ public function testObjectsCanBeAppended()
+ {
+ $this->_description->appendValue(new \stdClass());
+ $this->assertEquals('', (string) $this->_description);
+ }
+
+ public function testBooleanValuesCanBeAppended()
+ {
+ $this->_description->appendValue(false);
+ $this->assertEquals('', (string) $this->_description);
+ }
+
+ public function testListsOfvaluesCanBeAppended()
+ {
+ $this->_description->appendValue(array('foo', 42.78));
+ $this->assertEquals('["foo", <42.78F>]', (string) $this->_description);
+ }
+
+ public function testIterableOfvaluesCanBeAppended()
+ {
+ $items = new \ArrayObject(array('foo', 42.78));
+ $this->_description->appendValue($items);
+ $this->assertEquals('["foo", <42.78F>]', (string) $this->_description);
+ }
+
+ public function testIteratorOfvaluesCanBeAppended()
+ {
+ $items = new \ArrayObject(array('foo', 42.78));
+ $this->_description->appendValue($items->getIterator());
+ $this->assertEquals('["foo", <42.78F>]', (string) $this->_description);
+ }
+
+ public function testListsOfvaluesCanBeAppendedManually()
+ {
+ $this->_description->appendValueList('@start@', '@sep@ ', '@end@', array('foo', 42.78));
+ $this->assertEquals('@start@"foo"@sep@ <42.78F>@end@', (string) $this->_description);
+ }
+
+ public function testIterableOfvaluesCanBeAppendedManually()
+ {
+ $items = new \ArrayObject(array('foo', 42.78));
+ $this->_description->appendValueList('@start@', '@sep@ ', '@end@', $items);
+ $this->assertEquals('@start@"foo"@sep@ <42.78F>@end@', (string) $this->_description);
+ }
+
+ public function testIteratorOfvaluesCanBeAppendedManually()
+ {
+ $items = new \ArrayObject(array('foo', 42.78));
+ $this->_description->appendValueList('@start@', '@sep@ ', '@end@', $items->getIterator());
+ $this->assertEquals('@start@"foo"@sep@ <42.78F>@end@', (string) $this->_description);
+ }
+
+ public function testSelfDescribingObjectsCanBeAppended()
+ {
+ $this->_description
+ ->appendDescriptionOf(new \Hamcrest\SampleSelfDescriber('foo'))
+ ->appendDescriptionOf(new \Hamcrest\SampleSelfDescriber('bar'))
+ ;
+ $this->assertEquals('foobar', (string) $this->_description);
+ }
+
+ public function testSelfDescribingObjectsCanBeAppendedAsLists()
+ {
+ $this->_description->appendList('@start@', '@sep@ ', '@end@', array(
+ new \Hamcrest\SampleSelfDescriber('foo'),
+ new \Hamcrest\SampleSelfDescriber('bar')
+ ));
+ $this->assertEquals('@start@foo@sep@ bar@end@', (string) $this->_description);
+ }
+
+ public function testSelfDescribingObjectsCanBeAppendedAsIteratedLists()
+ {
+ $items = new \ArrayObject(array(
+ new \Hamcrest\SampleSelfDescriber('foo'),
+ new \Hamcrest\SampleSelfDescriber('bar')
+ ));
+ $this->_description->appendList('@start@', '@sep@ ', '@end@', $items);
+ $this->assertEquals('@start@foo@sep@ bar@end@', (string) $this->_description);
+ }
+
+ public function testSelfDescribingObjectsCanBeAppendedAsIterators()
+ {
+ $items = new \ArrayObject(array(
+ new \Hamcrest\SampleSelfDescriber('foo'),
+ new \Hamcrest\SampleSelfDescriber('bar')
+ ));
+ $this->_description->appendList('@start@', '@sep@ ', '@end@', $items->getIterator());
+ $this->assertEquals('@start@foo@sep@ bar@end@', (string) $this->_description);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEmptyStringTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEmptyStringTest.php
new file mode 100644
index 000000000..8d5c56be1
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEmptyStringTest.php
@@ -0,0 +1,86 @@
+assertDoesNotMatch(emptyString(), null, 'null');
+ }
+
+ public function testEmptyDoesNotMatchZero()
+ {
+ $this->assertDoesNotMatch(emptyString(), 0, 'zero');
+ }
+
+ public function testEmptyDoesNotMatchFalse()
+ {
+ $this->assertDoesNotMatch(emptyString(), false, 'false');
+ }
+
+ public function testEmptyDoesNotMatchEmptyArray()
+ {
+ $this->assertDoesNotMatch(emptyString(), array(), 'empty array');
+ }
+
+ public function testEmptyMatchesEmptyString()
+ {
+ $this->assertMatches(emptyString(), '', 'empty string');
+ }
+
+ public function testEmptyDoesNotMatchNonEmptyString()
+ {
+ $this->assertDoesNotMatch(emptyString(), 'foo', 'non-empty string');
+ }
+
+ public function testEmptyHasAReadableDescription()
+ {
+ $this->assertDescription('an empty string', emptyString());
+ }
+
+ public function testEmptyOrNullMatchesNull()
+ {
+ $this->assertMatches(nullOrEmptyString(), null, 'null');
+ }
+
+ public function testEmptyOrNullMatchesEmptyString()
+ {
+ $this->assertMatches(nullOrEmptyString(), '', 'empty string');
+ }
+
+ public function testEmptyOrNullDoesNotMatchNonEmptyString()
+ {
+ $this->assertDoesNotMatch(nullOrEmptyString(), 'foo', 'non-empty string');
+ }
+
+ public function testEmptyOrNullHasAReadableDescription()
+ {
+ $this->assertDescription('(null or an empty string)', nullOrEmptyString());
+ }
+
+ public function testNonEmptyDoesNotMatchNull()
+ {
+ $this->assertDoesNotMatch(nonEmptyString(), null, 'null');
+ }
+
+ public function testNonEmptyDoesNotMatchEmptyString()
+ {
+ $this->assertDoesNotMatch(nonEmptyString(), '', 'empty string');
+ }
+
+ public function testNonEmptyMatchesNonEmptyString()
+ {
+ $this->assertMatches(nonEmptyString(), 'foo', 'non-empty string');
+ }
+
+ public function testNonEmptyHasAReadableDescription()
+ {
+ $this->assertDescription('a non-empty string', nonEmptyString());
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEqualIgnoringCaseTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEqualIgnoringCaseTest.php
new file mode 100644
index 000000000..0539fd5cb
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEqualIgnoringCaseTest.php
@@ -0,0 +1,40 @@
+assertDescription(
+ 'equalToIgnoringCase("heLLo")',
+ equalToIgnoringCase('heLLo')
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEqualIgnoringWhiteSpaceTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEqualIgnoringWhiteSpaceTest.php
new file mode 100644
index 000000000..6c2304f43
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/IsEqualIgnoringWhiteSpaceTest.php
@@ -0,0 +1,51 @@
+_matcher = \Hamcrest\Text\IsEqualIgnoringWhiteSpace::equalToIgnoringWhiteSpace(
+ "Hello World how\n are we? "
+ );
+ }
+
+ protected function createMatcher()
+ {
+ return $this->_matcher;
+ }
+
+ public function testPassesIfWordsAreSameButWhitespaceDiffers()
+ {
+ assertThat('Hello World how are we?', $this->_matcher);
+ assertThat(" Hello \rWorld \t how are\nwe?", $this->_matcher);
+ }
+
+ public function testFailsIfTextOtherThanWhitespaceDiffers()
+ {
+ assertThat('Hello PLANET how are we?', not($this->_matcher));
+ assertThat('Hello World how are we', not($this->_matcher));
+ }
+
+ public function testFailsIfWhitespaceIsAddedOrRemovedInMidWord()
+ {
+ assertThat('HelloWorld how are we?', not($this->_matcher));
+ assertThat('Hello Wo rld how are we?', not($this->_matcher));
+ }
+
+ public function testFailsIfMatchingAgainstNull()
+ {
+ assertThat(null, not($this->_matcher));
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription(
+ "equalToIgnoringWhiteSpace(\"Hello World how\\n are we? \")",
+ $this->_matcher
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/MatchesPatternTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/MatchesPatternTest.php
new file mode 100644
index 000000000..4891598f6
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/MatchesPatternTest.php
@@ -0,0 +1,30 @@
+assertDescription('a string matching "pattern"', matchesPattern('pattern'));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsIgnoringCaseTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsIgnoringCaseTest.php
new file mode 100644
index 000000000..3b5b08e3b
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsIgnoringCaseTest.php
@@ -0,0 +1,80 @@
+_stringContains = \Hamcrest\Text\StringContainsIgnoringCase::containsStringIgnoringCase(
+ strtolower(self::EXCERPT)
+ );
+ }
+
+ protected function createMatcher()
+ {
+ return $this->_stringContains;
+ }
+
+ public function testEvaluatesToTrueIfArgumentContainsSpecifiedSubstring()
+ {
+ $this->assertTrue(
+ $this->_stringContains->matches(self::EXCERPT . 'END'),
+ 'should be true if excerpt at beginning'
+ );
+ $this->assertTrue(
+ $this->_stringContains->matches('START' . self::EXCERPT),
+ 'should be true if excerpt at end'
+ );
+ $this->assertTrue(
+ $this->_stringContains->matches('START' . self::EXCERPT . 'END'),
+ 'should be true if excerpt in middle'
+ );
+ $this->assertTrue(
+ $this->_stringContains->matches(self::EXCERPT . self::EXCERPT),
+ 'should be true if excerpt is repeated'
+ );
+
+ $this->assertFalse(
+ $this->_stringContains->matches('Something else'),
+ 'should not be true if excerpt is not in string'
+ );
+ $this->assertFalse(
+ $this->_stringContains->matches(substr(self::EXCERPT, 1)),
+ 'should not be true if part of excerpt is in string'
+ );
+ }
+
+ public function testEvaluatesToTrueIfArgumentIsEqualToSubstring()
+ {
+ $this->assertTrue(
+ $this->_stringContains->matches(self::EXCERPT),
+ 'should be true if excerpt is entire string'
+ );
+ }
+
+ public function testEvaluatesToTrueIfArgumentContainsExactSubstring()
+ {
+ $this->assertTrue(
+ $this->_stringContains->matches(strtolower(self::EXCERPT)),
+ 'should be false if excerpt is entire string ignoring case'
+ );
+ $this->assertTrue(
+ $this->_stringContains->matches('START' . strtolower(self::EXCERPT) . 'END'),
+ 'should be false if excerpt is contained in string ignoring case'
+ );
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription(
+ 'a string containing in any case "'
+ . strtolower(self::EXCERPT) . '"',
+ $this->_stringContains
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsInOrderTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsInOrderTest.php
new file mode 100644
index 000000000..0be70629f
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsInOrderTest.php
@@ -0,0 +1,42 @@
+_m = \Hamcrest\Text\StringContainsInOrder::stringContainsInOrder(array('a', 'b', 'c'));
+ }
+
+ protected function createMatcher()
+ {
+ return $this->_m;
+ }
+
+ public function testMatchesOnlyIfStringContainsGivenSubstringsInTheSameOrder()
+ {
+ $this->assertMatches($this->_m, 'abc', 'substrings in order');
+ $this->assertMatches($this->_m, '1a2b3c4', 'substrings separated');
+
+ $this->assertDoesNotMatch($this->_m, 'cab', 'substrings out of order');
+ $this->assertDoesNotMatch($this->_m, 'xyz', 'no substrings in string');
+ $this->assertDoesNotMatch($this->_m, 'ac', 'substring missing');
+ $this->assertDoesNotMatch($this->_m, '', 'empty string');
+ }
+
+ public function testAcceptsVariableArguments()
+ {
+ $this->assertMatches(stringContainsInOrder('a', 'b', 'c'), 'abc', 'substrings as variable arguments');
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription(
+ 'a string containing "a", "b", "c" in order',
+ $this->_m
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsTest.php
new file mode 100644
index 000000000..203fd918d
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringContainsTest.php
@@ -0,0 +1,86 @@
+_stringContains = \Hamcrest\Text\StringContains::containsString(self::EXCERPT);
+ }
+
+ protected function createMatcher()
+ {
+ return $this->_stringContains;
+ }
+
+ public function testEvaluatesToTrueIfArgumentContainsSubstring()
+ {
+ $this->assertTrue(
+ $this->_stringContains->matches(self::EXCERPT . 'END'),
+ 'should be true if excerpt at beginning'
+ );
+ $this->assertTrue(
+ $this->_stringContains->matches('START' . self::EXCERPT),
+ 'should be true if excerpt at end'
+ );
+ $this->assertTrue(
+ $this->_stringContains->matches('START' . self::EXCERPT . 'END'),
+ 'should be true if excerpt in middle'
+ );
+ $this->assertTrue(
+ $this->_stringContains->matches(self::EXCERPT . self::EXCERPT),
+ 'should be true if excerpt is repeated'
+ );
+
+ $this->assertFalse(
+ $this->_stringContains->matches('Something else'),
+ 'should not be true if excerpt is not in string'
+ );
+ $this->assertFalse(
+ $this->_stringContains->matches(substr(self::EXCERPT, 1)),
+ 'should not be true if part of excerpt is in string'
+ );
+ }
+
+ public function testEvaluatesToTrueIfArgumentIsEqualToSubstring()
+ {
+ $this->assertTrue(
+ $this->_stringContains->matches(self::EXCERPT),
+ 'should be true if excerpt is entire string'
+ );
+ }
+
+ public function testEvaluatesToFalseIfArgumentContainsSubstringIgnoringCase()
+ {
+ $this->assertFalse(
+ $this->_stringContains->matches(strtolower(self::EXCERPT)),
+ 'should be false if excerpt is entire string ignoring case'
+ );
+ $this->assertFalse(
+ $this->_stringContains->matches('START' . strtolower(self::EXCERPT) . 'END'),
+ 'should be false if excerpt is contained in string ignoring case'
+ );
+ }
+
+ public function testIgnoringCaseReturnsCorrectMatcher()
+ {
+ $this->assertTrue(
+ $this->_stringContains->ignoringCase()->matches('EXceRpT'),
+ 'should be true if excerpt is entire string ignoring case'
+ );
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription(
+ 'a string containing "'
+ . self::EXCERPT . '"',
+ $this->_stringContains
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringEndsWithTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringEndsWithTest.php
new file mode 100644
index 000000000..fffa3c9cd
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringEndsWithTest.php
@@ -0,0 +1,62 @@
+_stringEndsWith = \Hamcrest\Text\StringEndsWith::endsWith(self::EXCERPT);
+ }
+
+ protected function createMatcher()
+ {
+ return $this->_stringEndsWith;
+ }
+
+ public function testEvaluatesToTrueIfArgumentContainsSpecifiedSubstring()
+ {
+ $this->assertFalse(
+ $this->_stringEndsWith->matches(self::EXCERPT . 'END'),
+ 'should be false if excerpt at beginning'
+ );
+ $this->assertTrue(
+ $this->_stringEndsWith->matches('START' . self::EXCERPT),
+ 'should be true if excerpt at end'
+ );
+ $this->assertFalse(
+ $this->_stringEndsWith->matches('START' . self::EXCERPT . 'END'),
+ 'should be false if excerpt in middle'
+ );
+ $this->assertTrue(
+ $this->_stringEndsWith->matches(self::EXCERPT . self::EXCERPT),
+ 'should be true if excerpt is at end and repeated'
+ );
+
+ $this->assertFalse(
+ $this->_stringEndsWith->matches('Something else'),
+ 'should be false if excerpt is not in string'
+ );
+ $this->assertFalse(
+ $this->_stringEndsWith->matches(substr(self::EXCERPT, 0, strlen(self::EXCERPT) - 2)),
+ 'should be false if part of excerpt is at end of string'
+ );
+ }
+
+ public function testEvaluatesToTrueIfArgumentIsEqualToSubstring()
+ {
+ $this->assertTrue(
+ $this->_stringEndsWith->matches(self::EXCERPT),
+ 'should be true if excerpt is entire string'
+ );
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription('a string ending with "EXCERPT"', $this->_stringEndsWith);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringStartsWithTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringStartsWithTest.php
new file mode 100644
index 000000000..fc3761bde
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Text/StringStartsWithTest.php
@@ -0,0 +1,62 @@
+_stringStartsWith = \Hamcrest\Text\StringStartsWith::startsWith(self::EXCERPT);
+ }
+
+ protected function createMatcher()
+ {
+ return $this->_stringStartsWith;
+ }
+
+ public function testEvaluatesToTrueIfArgumentContainsSpecifiedSubstring()
+ {
+ $this->assertTrue(
+ $this->_stringStartsWith->matches(self::EXCERPT . 'END'),
+ 'should be true if excerpt at beginning'
+ );
+ $this->assertFalse(
+ $this->_stringStartsWith->matches('START' . self::EXCERPT),
+ 'should be false if excerpt at end'
+ );
+ $this->assertFalse(
+ $this->_stringStartsWith->matches('START' . self::EXCERPT . 'END'),
+ 'should be false if excerpt in middle'
+ );
+ $this->assertTrue(
+ $this->_stringStartsWith->matches(self::EXCERPT . self::EXCERPT),
+ 'should be true if excerpt is at beginning and repeated'
+ );
+
+ $this->assertFalse(
+ $this->_stringStartsWith->matches('Something else'),
+ 'should be false if excerpt is not in string'
+ );
+ $this->assertFalse(
+ $this->_stringStartsWith->matches(substr(self::EXCERPT, 1)),
+ 'should be false if part of excerpt is at start of string'
+ );
+ }
+
+ public function testEvaluatesToTrueIfArgumentIsEqualToSubstring()
+ {
+ $this->assertTrue(
+ $this->_stringStartsWith->matches(self::EXCERPT),
+ 'should be true if excerpt is entire string'
+ );
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription('a string starting with "EXCERPT"', $this->_stringStartsWith);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsArrayTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsArrayTest.php
new file mode 100644
index 000000000..d13c24d2c
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsArrayTest.php
@@ -0,0 +1,35 @@
+assertDescription('an array', arrayValue());
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription('was null', arrayValue(), null);
+ $this->assertMismatchDescription('was a string "foo"', arrayValue(), 'foo');
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsBooleanTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsBooleanTest.php
new file mode 100644
index 000000000..24309fc09
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsBooleanTest.php
@@ -0,0 +1,35 @@
+assertDescription('a boolean', booleanValue());
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription('was null', booleanValue(), null);
+ $this->assertMismatchDescription('was a string "foo"', booleanValue(), 'foo');
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsCallableTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsCallableTest.php
new file mode 100644
index 000000000..5098e21ba
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsCallableTest.php
@@ -0,0 +1,103 @@
+=')) {
+ $this->markTestSkipped('Closures require php 5.3');
+ }
+ eval('assertThat(function () {}, callableValue());');
+ }
+
+ public function testEvaluatesToTrueIfArgumentImplementsInvoke()
+ {
+ if (!version_compare(PHP_VERSION, '5.3', '>=')) {
+ $this->markTestSkipped('Magic method __invoke() requires php 5.3');
+ }
+ assertThat($this, callableValue());
+ }
+
+ public function testEvaluatesToFalseIfArgumentIsInvalidFunctionName()
+ {
+ if (function_exists('not_a_Hamcrest_function')) {
+ $this->markTestSkipped('Function "not_a_Hamcrest_function" must not exist');
+ }
+
+ assertThat('not_a_Hamcrest_function', not(callableValue()));
+ }
+
+ public function testEvaluatesToFalseIfArgumentIsInvalidStaticMethodCallback()
+ {
+ assertThat(
+ array('Hamcrest\Type\IsCallableTest', 'noMethod'),
+ not(callableValue())
+ );
+ }
+
+ public function testEvaluatesToFalseIfArgumentIsInvalidInstanceMethodCallback()
+ {
+ assertThat(array($this, 'noMethod'), not(callableValue()));
+ }
+
+ public function testEvaluatesToFalseIfArgumentDoesntImplementInvoke()
+ {
+ assertThat(new \stdClass(), not(callableValue()));
+ }
+
+ public function testEvaluatesToFalseIfArgumentDoesntMatchType()
+ {
+ assertThat(false, not(callableValue()));
+ assertThat(5.2, not(callableValue()));
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription('a callable', callableValue());
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription(
+ 'was a string "invalid-function"',
+ callableValue(),
+ 'invalid-function'
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsDoubleTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsDoubleTest.php
new file mode 100644
index 000000000..85c2a963c
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsDoubleTest.php
@@ -0,0 +1,35 @@
+assertDescription('a double', doubleValue());
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription('was null', doubleValue(), null);
+ $this->assertMismatchDescription('was a string "foo"', doubleValue(), 'foo');
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsIntegerTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsIntegerTest.php
new file mode 100644
index 000000000..ce5a51a9f
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsIntegerTest.php
@@ -0,0 +1,36 @@
+assertDescription('an integer', integerValue());
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription('was null', integerValue(), null);
+ $this->assertMismatchDescription('was a string "foo"', integerValue(), 'foo');
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsNumericTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsNumericTest.php
new file mode 100644
index 000000000..e71848572
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsNumericTest.php
@@ -0,0 +1,49 @@
+assertDescription('a number', numericValue());
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription('was null', numericValue(), null);
+ $this->assertMismatchDescription('was a string "foo"', numericValue(), 'foo');
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsObjectTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsObjectTest.php
new file mode 100644
index 000000000..a3b617c20
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsObjectTest.php
@@ -0,0 +1,34 @@
+assertDescription('an object', objectValue());
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription('was null', objectValue(), null);
+ $this->assertMismatchDescription('was a string "foo"', objectValue(), 'foo');
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsResourceTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsResourceTest.php
new file mode 100644
index 000000000..d6ea53484
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsResourceTest.php
@@ -0,0 +1,34 @@
+assertDescription('a resource', resourceValue());
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription('was null', resourceValue(), null);
+ $this->assertMismatchDescription('was a string "foo"', resourceValue(), 'foo');
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsScalarTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsScalarTest.php
new file mode 100644
index 000000000..72a188d67
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsScalarTest.php
@@ -0,0 +1,39 @@
+assertDescription('a scalar', scalarValue());
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription('was null', scalarValue(), null);
+ $this->assertMismatchDescription('was an array ["foo"]', scalarValue(), array('foo'));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsStringTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsStringTest.php
new file mode 100644
index 000000000..557d5913a
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Type/IsStringTest.php
@@ -0,0 +1,35 @@
+assertDescription('a string', stringValue());
+ }
+
+ public function testDecribesActualTypeInMismatchMessage()
+ {
+ $this->assertMismatchDescription('was null', stringValue(), null);
+ $this->assertMismatchDescription('was a double <5.2F>', stringValue(), 5.2);
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/UtilTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/UtilTest.php
new file mode 100644
index 000000000..0c2cd0433
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/UtilTest.php
@@ -0,0 +1,80 @@
+assertSame($matcher, $newMatcher);
+ }
+
+ public function testWrapValueWithIsEqualWrapsPrimitive()
+ {
+ $matcher = \Hamcrest\Util::wrapValueWithIsEqual('foo');
+ $this->assertInstanceOf('Hamcrest\Core\IsEqual', $matcher);
+ $this->assertTrue($matcher->matches('foo'));
+ }
+
+ public function testCheckAllAreMatchersAcceptsMatchers()
+ {
+ \Hamcrest\Util::checkAllAreMatchers(array(
+ new \Hamcrest\Text\MatchesPattern('/fo+/'),
+ new \Hamcrest\Core\IsEqual('foo'),
+ ));
+ }
+
+ /**
+ * @expectedException InvalidArgumentException
+ */
+ public function testCheckAllAreMatchersFailsForPrimitive()
+ {
+ \Hamcrest\Util::checkAllAreMatchers(array(
+ new \Hamcrest\Text\MatchesPattern('/fo+/'),
+ 'foo',
+ ));
+ }
+
+ private function callAndAssertCreateMatcherArray($items)
+ {
+ $matchers = \Hamcrest\Util::createMatcherArray($items);
+ $this->assertInternalType('array', $matchers);
+ $this->assertSameSize($items, $matchers);
+ foreach ($matchers as $matcher) {
+ $this->assertInstanceOf('\Hamcrest\Matcher', $matcher);
+ }
+
+ return $matchers;
+ }
+
+ public function testCreateMatcherArrayLeavesMatchersUntouched()
+ {
+ $matcher = new \Hamcrest\Text\MatchesPattern('/fo+/');
+ $items = array($matcher);
+ $matchers = $this->callAndAssertCreateMatcherArray($items);
+ $this->assertSame($matcher, $matchers[0]);
+ }
+
+ public function testCreateMatcherArrayWrapsPrimitiveWithIsEqualMatcher()
+ {
+ $matchers = $this->callAndAssertCreateMatcherArray(array('foo'));
+ $this->assertInstanceOf('Hamcrest\Core\IsEqual', $matchers[0]);
+ $this->assertTrue($matchers[0]->matches('foo'));
+ }
+
+ public function testCreateMatcherArrayDoesntModifyOriginalArray()
+ {
+ $items = array('foo');
+ $this->callAndAssertCreateMatcherArray($items);
+ $this->assertSame('foo', $items[0]);
+ }
+
+ public function testCreateMatcherArrayUnwrapsSingleArrayElement()
+ {
+ $matchers = $this->callAndAssertCreateMatcherArray(array(array('foo')));
+ $this->assertInstanceOf('Hamcrest\Core\IsEqual', $matchers[0]);
+ $this->assertTrue($matchers[0]->matches('foo'));
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Xml/HasXPathTest.php b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Xml/HasXPathTest.php
new file mode 100644
index 000000000..677488716
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/Hamcrest/Xml/HasXPathTest.php
@@ -0,0 +1,198 @@
+
+
+
+ alice
+ Alice Frankel
+ admin
+
+
+ bob
+ Bob Frankel
+ user
+
+
+ charlie
+ Charlie Chan
+ user
+
+
+XML;
+ self::$doc = new \DOMDocument();
+ self::$doc->loadXML(self::$xml);
+
+ self::$html = <<
+
+ Home Page
+
+
+ Heading
+ Some text
+
+
+HTML;
+ }
+
+ protected function createMatcher()
+ {
+ return \Hamcrest\Xml\HasXPath::hasXPath('/users/user');
+ }
+
+ public function testMatchesWhenXPathIsFound()
+ {
+ assertThat('one match', self::$doc, hasXPath('user[id = "bob"]'));
+ assertThat('two matches', self::$doc, hasXPath('user[role = "user"]'));
+ }
+
+ public function testDoesNotMatchWhenXPathIsNotFound()
+ {
+ assertThat(
+ 'no match',
+ self::$doc,
+ not(hasXPath('user[contains(id, "frank")]'))
+ );
+ }
+
+ public function testMatchesWhenExpressionWithoutMatcherEvaluatesToTrue()
+ {
+ assertThat(
+ 'one match',
+ self::$doc,
+ hasXPath('count(user[id = "bob"])')
+ );
+ }
+
+ public function testDoesNotMatchWhenExpressionWithoutMatcherEvaluatesToFalse()
+ {
+ assertThat(
+ 'no matches',
+ self::$doc,
+ not(hasXPath('count(user[id = "frank"])'))
+ );
+ }
+
+ public function testMatchesWhenExpressionIsEqual()
+ {
+ assertThat(
+ 'one match',
+ self::$doc,
+ hasXPath('count(user[id = "bob"])', 1)
+ );
+ assertThat(
+ 'two matches',
+ self::$doc,
+ hasXPath('count(user[role = "user"])', 2)
+ );
+ }
+
+ public function testDoesNotMatchWhenExpressionIsNotEqual()
+ {
+ assertThat(
+ 'no match',
+ self::$doc,
+ not(hasXPath('count(user[id = "frank"])', 2))
+ );
+ assertThat(
+ 'one match',
+ self::$doc,
+ not(hasXPath('count(user[role = "admin"])', 2))
+ );
+ }
+
+ public function testMatchesWhenContentMatches()
+ {
+ assertThat(
+ 'one match',
+ self::$doc,
+ hasXPath('user/name', containsString('ice'))
+ );
+ assertThat(
+ 'two matches',
+ self::$doc,
+ hasXPath('user/role', equalTo('user'))
+ );
+ }
+
+ public function testDoesNotMatchWhenContentDoesNotMatch()
+ {
+ assertThat(
+ 'no match',
+ self::$doc,
+ not(hasXPath('user/name', containsString('Bobby')))
+ );
+ assertThat(
+ 'no matches',
+ self::$doc,
+ not(hasXPath('user/role', equalTo('owner')))
+ );
+ }
+
+ public function testProvidesConvenientShortcutForHasXPathEqualTo()
+ {
+ assertThat('matches', self::$doc, hasXPath('count(user)', 3));
+ assertThat('matches', self::$doc, hasXPath('user[2]/id', 'bob'));
+ }
+
+ public function testProvidesConvenientShortcutForHasXPathCountEqualTo()
+ {
+ assertThat('matches', self::$doc, hasXPath('user[id = "charlie"]', 1));
+ }
+
+ public function testMatchesAcceptsXmlString()
+ {
+ assertThat('accepts XML string', self::$xml, hasXPath('user'));
+ }
+
+ public function testMatchesAcceptsHtmlString()
+ {
+ assertThat('accepts HTML string', self::$html, hasXPath('body/h1', 'Heading'));
+ }
+
+ public function testHasAReadableDescription()
+ {
+ $this->assertDescription(
+ 'XML or HTML document with XPath "/users/user"',
+ hasXPath('/users/user')
+ );
+ $this->assertDescription(
+ 'XML or HTML document with XPath "count(/users/user)" <2>',
+ hasXPath('/users/user', 2)
+ );
+ $this->assertDescription(
+ 'XML or HTML document with XPath "/users/user/name"'
+ . ' a string starting with "Alice"',
+ hasXPath('/users/user/name', startsWith('Alice'))
+ );
+ }
+
+ public function testHasAReadableMismatchDescription()
+ {
+ $this->assertMismatchDescription(
+ 'XPath returned no results',
+ hasXPath('/users/name'),
+ self::$doc
+ );
+ $this->assertMismatchDescription(
+ 'XPath expression result was <3F>',
+ hasXPath('/users/user', 2),
+ self::$doc
+ );
+ $this->assertMismatchDescription(
+ 'XPath returned ["alice", "bob", "charlie"]',
+ hasXPath('/users/user/id', 'Frank'),
+ self::$doc
+ );
+ }
+}
diff --git a/vendor/hamcrest/hamcrest-php/tests/bootstrap.php b/vendor/hamcrest/hamcrest-php/tests/bootstrap.php
new file mode 100644
index 000000000..35a696cda
--- /dev/null
+++ b/vendor/hamcrest/hamcrest-php/tests/bootstrap.php
@@ -0,0 +1,18 @@
+
+
+
+ .
+
+
+
+
+
+ ../hamcrest
+
+
+
diff --git a/vendor/jakub-onderka/php-console-color/.gitignore b/vendor/jakub-onderka/php-console-color/.gitignore
new file mode 100644
index 000000000..05ab16b84
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-color/.gitignore
@@ -0,0 +1,3 @@
+build
+vendor
+composer.lock
diff --git a/vendor/jakub-onderka/php-console-color/.travis.yml b/vendor/jakub-onderka/php-console-color/.travis.yml
new file mode 100644
index 000000000..49175a996
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-color/.travis.yml
@@ -0,0 +1,24 @@
+language: php
+
+php:
+ - 5.4
+ - 5.5
+ - 5.6
+ - 7.0
+ - 7.1
+ - 7.2
+
+sudo: false
+
+cache:
+ directories:
+ - vendor
+ - $HOME/.composer/cache
+
+before_script:
+ - composer install --no-interaction --prefer-source
+
+script:
+ - ant phplint
+ - ant phpcs
+ - ant phpunit
diff --git a/vendor/jakub-onderka/php-console-color/LICENSE b/vendor/jakub-onderka/php-console-color/LICENSE
new file mode 100644
index 000000000..0954fc941
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-color/LICENSE
@@ -0,0 +1,27 @@
+Copyright (c) 2014-2018, Jakub Onderka
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions
+are met:
+
+ * Redistributions of source code must retain the above copyright
+ notice, this list of conditions and the following disclaimer.
+
+ * Redistributions in binary form must reproduce the above copyright
+ notice, this list of conditions and the following disclaimer in
+ the documentation and/or other materials provided with the
+ distribution.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
+ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGE.
diff --git a/vendor/jakub-onderka/php-console-color/README.md b/vendor/jakub-onderka/php-console-color/README.md
new file mode 100644
index 000000000..39e55d925
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-color/README.md
@@ -0,0 +1,10 @@
+PHP Console Color
+=================
+
+[](https://travis-ci.org/JakubOnderka/PHP-Console-Color)
+
+Simple library for creating colored console ouput.
+
+See `example.php` how to use this library.
+
+
\ No newline at end of file
diff --git a/vendor/jakub-onderka/php-console-color/build.xml b/vendor/jakub-onderka/php-console-color/build.xml
new file mode 100644
index 000000000..bb4ba66d8
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-color/build.xml
@@ -0,0 +1,93 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/vendor/jakub-onderka/php-console-color/composer.json b/vendor/jakub-onderka/php-console-color/composer.json
new file mode 100644
index 000000000..6481cb51d
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-color/composer.json
@@ -0,0 +1,23 @@
+{
+ "name": "jakub-onderka/php-console-color",
+ "license": "BSD-2-Clause",
+ "authors": [
+ {
+ "name": "Jakub Onderka",
+ "email": "jakub.onderka@gmail.com"
+ }
+ ],
+ "autoload": {
+ "psr-4": {"JakubOnderka\\PhpConsoleColor\\": "src/"}
+ },
+ "require": {
+ "php": ">=5.4.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.3",
+ "jakub-onderka/php-parallel-lint": "1.0",
+ "jakub-onderka/php-var-dump-check": "0.*",
+ "squizlabs/php_codesniffer": "1.*",
+ "jakub-onderka/php-code-style": "1.0"
+ }
+}
diff --git a/vendor/jakub-onderka/php-console-color/example.php b/vendor/jakub-onderka/php-console-color/example.php
new file mode 100644
index 000000000..5e698a24e
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-color/example.php
@@ -0,0 +1,38 @@
+isSupported() ? 'Yes' : 'No') . "\n";
+echo "256 colors are supported: " . ($consoleColor->are256ColorsSupported() ? 'Yes' : 'No') . "\n\n";
+
+if ($consoleColor->isSupported()) {
+ foreach ($consoleColor->getPossibleStyles() as $style) {
+ echo $consoleColor->apply($style, $style) . "\n";
+ }
+}
+
+echo "\n";
+
+if ($consoleColor->are256ColorsSupported()) {
+ echo "Foreground colors:\n";
+ for ($i = 1; $i <= 255; $i++) {
+ echo $consoleColor->apply("color_$i", str_pad($i, 6, ' ', STR_PAD_BOTH));
+
+ if ($i % 15 === 0) {
+ echo "\n";
+ }
+ }
+
+ echo "\nBackground colors:\n";
+
+ for ($i = 1; $i <= 255; $i++) {
+ echo $consoleColor->apply("bg_color_$i", str_pad($i, 6, ' ', STR_PAD_BOTH));
+
+ if ($i % 15 === 0) {
+ echo "\n";
+ }
+ }
+
+ echo "\n";
+}
diff --git a/vendor/jakub-onderka/php-console-color/phpunit.xml b/vendor/jakub-onderka/php-console-color/phpunit.xml
new file mode 100644
index 000000000..f1105cc4e
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-color/phpunit.xml
@@ -0,0 +1,16 @@
+
+
+
+
+ tests
+
+
+
+
+
+
+ vendor
+
+
+
diff --git a/vendor/jakub-onderka/php-console-color/src/ConsoleColor.php b/vendor/jakub-onderka/php-console-color/src/ConsoleColor.php
new file mode 100644
index 000000000..90fd12528
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-color/src/ConsoleColor.php
@@ -0,0 +1,287 @@
+ null,
+ 'bold' => '1',
+ 'dark' => '2',
+ 'italic' => '3',
+ 'underline' => '4',
+ 'blink' => '5',
+ 'reverse' => '7',
+ 'concealed' => '8',
+
+ 'default' => '39',
+ 'black' => '30',
+ 'red' => '31',
+ 'green' => '32',
+ 'yellow' => '33',
+ 'blue' => '34',
+ 'magenta' => '35',
+ 'cyan' => '36',
+ 'light_gray' => '37',
+
+ 'dark_gray' => '90',
+ 'light_red' => '91',
+ 'light_green' => '92',
+ 'light_yellow' => '93',
+ 'light_blue' => '94',
+ 'light_magenta' => '95',
+ 'light_cyan' => '96',
+ 'white' => '97',
+
+ 'bg_default' => '49',
+ 'bg_black' => '40',
+ 'bg_red' => '41',
+ 'bg_green' => '42',
+ 'bg_yellow' => '43',
+ 'bg_blue' => '44',
+ 'bg_magenta' => '45',
+ 'bg_cyan' => '46',
+ 'bg_light_gray' => '47',
+
+ 'bg_dark_gray' => '100',
+ 'bg_light_red' => '101',
+ 'bg_light_green' => '102',
+ 'bg_light_yellow' => '103',
+ 'bg_light_blue' => '104',
+ 'bg_light_magenta' => '105',
+ 'bg_light_cyan' => '106',
+ 'bg_white' => '107',
+ );
+
+ /** @var array */
+ private $themes = array();
+
+ public function __construct()
+ {
+ $this->isSupported = $this->isSupported();
+ }
+
+ /**
+ * @param string|array $style
+ * @param string $text
+ * @return string
+ * @throws InvalidStyleException
+ * @throws \InvalidArgumentException
+ */
+ public function apply($style, $text)
+ {
+ if (!$this->isStyleForced() && !$this->isSupported()) {
+ return $text;
+ }
+
+ if (is_string($style)) {
+ $style = array($style);
+ }
+ if (!is_array($style)) {
+ throw new \InvalidArgumentException("Style must be string or array.");
+ }
+
+ $sequences = array();
+
+ foreach ($style as $s) {
+ if (isset($this->themes[$s])) {
+ $sequences = array_merge($sequences, $this->themeSequence($s));
+ } else if ($this->isValidStyle($s)) {
+ $sequences[] = $this->styleSequence($s);
+ } else {
+ throw new InvalidStyleException($s);
+ }
+ }
+
+ $sequences = array_filter($sequences, function ($val) {
+ return $val !== null;
+ });
+
+ if (empty($sequences)) {
+ return $text;
+ }
+
+ return $this->escSequence(implode(';', $sequences)) . $text . $this->escSequence(self::RESET_STYLE);
+ }
+
+ /**
+ * @param bool $forceStyle
+ */
+ public function setForceStyle($forceStyle)
+ {
+ $this->forceStyle = (bool) $forceStyle;
+ }
+
+ /**
+ * @return bool
+ */
+ public function isStyleForced()
+ {
+ return $this->forceStyle;
+ }
+
+ /**
+ * @param array $themes
+ * @throws InvalidStyleException
+ * @throws \InvalidArgumentException
+ */
+ public function setThemes(array $themes)
+ {
+ $this->themes = array();
+ foreach ($themes as $name => $styles) {
+ $this->addTheme($name, $styles);
+ }
+ }
+
+ /**
+ * @param string $name
+ * @param array|string $styles
+ * @throws \InvalidArgumentException
+ * @throws InvalidStyleException
+ */
+ public function addTheme($name, $styles)
+ {
+ if (is_string($styles)) {
+ $styles = array($styles);
+ }
+ if (!is_array($styles)) {
+ throw new \InvalidArgumentException("Style must be string or array.");
+ }
+
+ foreach ($styles as $style) {
+ if (!$this->isValidStyle($style)) {
+ throw new InvalidStyleException($style);
+ }
+ }
+
+ $this->themes[$name] = $styles;
+ }
+
+ /**
+ * @return array
+ */
+ public function getThemes()
+ {
+ return $this->themes;
+ }
+
+ /**
+ * @param string $name
+ * @return bool
+ */
+ public function hasTheme($name)
+ {
+ return isset($this->themes[$name]);
+ }
+
+ /**
+ * @param string $name
+ */
+ public function removeTheme($name)
+ {
+ unset($this->themes[$name]);
+ }
+
+ /**
+ * @return bool
+ */
+ public function isSupported()
+ {
+ if (DIRECTORY_SEPARATOR === '\\') {
+ if (function_exists('sapi_windows_vt100_support') && @sapi_windows_vt100_support(STDOUT)) {
+ return true;
+ } elseif (getenv('ANSICON') !== false || getenv('ConEmuANSI') === 'ON') {
+ return true;
+ }
+ return false;
+ } else {
+ return function_exists('posix_isatty') && @posix_isatty(STDOUT);
+ }
+ }
+
+ /**
+ * @return bool
+ */
+ public function are256ColorsSupported()
+ {
+ if (DIRECTORY_SEPARATOR === '\\') {
+ return function_exists('sapi_windows_vt100_support') && @sapi_windows_vt100_support(STDOUT);
+ } else {
+ return strpos(getenv('TERM'), '256color') !== false;
+ }
+ }
+
+ /**
+ * @return array
+ */
+ public function getPossibleStyles()
+ {
+ return array_keys($this->styles);
+ }
+
+ /**
+ * @param string $name
+ * @return string[]
+ */
+ private function themeSequence($name)
+ {
+ $sequences = array();
+ foreach ($this->themes[$name] as $style) {
+ $sequences[] = $this->styleSequence($style);
+ }
+ return $sequences;
+ }
+
+ /**
+ * @param string $style
+ * @return string
+ */
+ private function styleSequence($style)
+ {
+ if (array_key_exists($style, $this->styles)) {
+ return $this->styles[$style];
+ }
+
+ if (!$this->are256ColorsSupported()) {
+ return null;
+ }
+
+ preg_match(self::COLOR256_REGEXP, $style, $matches);
+
+ $type = $matches[1] === 'bg_' ? self::BACKGROUND : self::FOREGROUND;
+ $value = $matches[2];
+
+ return "$type;5;$value";
+ }
+
+ /**
+ * @param string $style
+ * @return bool
+ */
+ private function isValidStyle($style)
+ {
+ return array_key_exists($style, $this->styles) || preg_match(self::COLOR256_REGEXP, $style);
+ }
+
+ /**
+ * @param string|int $value
+ * @return string
+ */
+ private function escSequence($value)
+ {
+ return "\033[{$value}m";
+ }
+}
diff --git a/vendor/jakub-onderka/php-console-color/src/InvalidStyleException.php b/vendor/jakub-onderka/php-console-color/src/InvalidStyleException.php
new file mode 100644
index 000000000..6f1586f62
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-color/src/InvalidStyleException.php
@@ -0,0 +1,10 @@
+isSupportedForce = $isSupported;
+ }
+
+ public function isSupported()
+ {
+ return $this->isSupportedForce;
+ }
+
+ public function setAre256ColorsSupported($are256ColorsSupported)
+ {
+ $this->are256ColorsSupportedForce = $are256ColorsSupported;
+ }
+
+ public function are256ColorsSupported()
+ {
+ return $this->are256ColorsSupportedForce;
+ }
+}
+
+class ConsoleColorTest extends \PHPUnit_Framework_TestCase
+{
+ /** @var ConsoleColorWithForceSupport */
+ private $uut;
+
+ protected function setUp()
+ {
+ $this->uut = new ConsoleColorWithForceSupport();
+ }
+
+ public function testNone()
+ {
+ $output = $this->uut->apply('none', 'text');
+ $this->assertEquals("text", $output);
+ }
+
+ public function testBold()
+ {
+ $output = $this->uut->apply('bold', 'text');
+ $this->assertEquals("\033[1mtext\033[0m", $output);
+ }
+
+ public function testBoldColorsAreNotSupported()
+ {
+ $this->uut->setIsSupported(false);
+
+ $output = $this->uut->apply('bold', 'text');
+ $this->assertEquals("text", $output);
+ }
+
+ public function testBoldColorsAreNotSupportedButAreForced()
+ {
+ $this->uut->setIsSupported(false);
+ $this->uut->setForceStyle(true);
+
+ $output = $this->uut->apply('bold', 'text');
+ $this->assertEquals("\033[1mtext\033[0m", $output);
+ }
+
+ public function testDark()
+ {
+ $output = $this->uut->apply('dark', 'text');
+ $this->assertEquals("\033[2mtext\033[0m", $output);
+ }
+
+ public function testBoldAndDark()
+ {
+ $output = $this->uut->apply(array('bold', 'dark'), 'text');
+ $this->assertEquals("\033[1;2mtext\033[0m", $output);
+ }
+
+ public function test256ColorForeground()
+ {
+ $output = $this->uut->apply('color_255', 'text');
+ $this->assertEquals("\033[38;5;255mtext\033[0m", $output);
+ }
+
+ public function test256ColorWithoutSupport()
+ {
+ $this->uut->setAre256ColorsSupported(false);
+
+ $output = $this->uut->apply('color_255', 'text');
+ $this->assertEquals("text", $output);
+ }
+
+ public function test256ColorBackground()
+ {
+ $output = $this->uut->apply('bg_color_255', 'text');
+ $this->assertEquals("\033[48;5;255mtext\033[0m", $output);
+ }
+
+ public function test256ColorForegroundAndBackground()
+ {
+ $output = $this->uut->apply(array('color_200', 'bg_color_255'), 'text');
+ $this->assertEquals("\033[38;5;200;48;5;255mtext\033[0m", $output);
+ }
+
+ public function testSetOwnTheme()
+ {
+ $this->uut->setThemes(array('bold_dark' => array('bold', 'dark')));
+ $output = $this->uut->apply(array('bold_dark'), 'text');
+ $this->assertEquals("\033[1;2mtext\033[0m", $output);
+ }
+
+ public function testAddOwnTheme()
+ {
+ $this->uut->addTheme('bold_own', 'bold');
+ $output = $this->uut->apply(array('bold_own'), 'text');
+ $this->assertEquals("\033[1mtext\033[0m", $output);
+ }
+
+ public function testAddOwnThemeArray()
+ {
+ $this->uut->addTheme('bold_dark', array('bold', 'dark'));
+ $output = $this->uut->apply(array('bold_dark'), 'text');
+ $this->assertEquals("\033[1;2mtext\033[0m", $output);
+ }
+
+ public function testOwnWithStyle()
+ {
+ $this->uut->addTheme('bold_dark', array('bold', 'dark'));
+ $output = $this->uut->apply(array('bold_dark', 'italic'), 'text');
+ $this->assertEquals("\033[1;2;3mtext\033[0m", $output);
+ }
+
+ public function testHasAndRemoveTheme()
+ {
+ $this->assertFalse($this->uut->hasTheme('bold_dark'));
+
+ $this->uut->addTheme('bold_dark', array('bold', 'dark'));
+ $this->assertTrue($this->uut->hasTheme('bold_dark'));
+
+ $this->uut->removeTheme('bold_dark');
+ $this->assertFalse($this->uut->hasTheme('bold_dark'));
+ }
+
+ public function testApplyInvalidArgument()
+ {
+ $this->setExpectedException('\InvalidArgumentException');
+ $this->uut->apply(new stdClass(), 'text');
+ }
+
+ public function testApplyInvalidStyleName()
+ {
+ $this->setExpectedException('\JakubOnderka\PhpConsoleColor\InvalidStyleException');
+ $this->uut->apply('invalid', 'text');
+ }
+
+ public function testApplyInvalid256Color()
+ {
+ $this->setExpectedException('\JakubOnderka\PhpConsoleColor\InvalidStyleException');
+ $this->uut->apply('color_2134', 'text');
+ }
+
+ public function testThemeInvalidStyle()
+ {
+ $this->setExpectedException('\JakubOnderka\PhpConsoleColor\InvalidStyleException');
+ $this->uut->addTheme('invalid', array('invalid'));
+ }
+
+ public function testForceStyle()
+ {
+ $this->assertFalse($this->uut->isStyleForced());
+ $this->uut->setForceStyle(true);
+ $this->assertTrue($this->uut->isStyleForced());
+ }
+
+ public function testGetPossibleStyles()
+ {
+ $this->assertInternalType('array', $this->uut->getPossibleStyles());
+ $this->assertNotEmpty($this->uut->getPossibleStyles());
+ }
+}
+
diff --git a/vendor/jakub-onderka/php-console-highlighter/.gitignore b/vendor/jakub-onderka/php-console-highlighter/.gitignore
new file mode 100644
index 000000000..70f6ec069
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/.gitignore
@@ -0,0 +1,4 @@
+/.idea/
+/build/
+/vendor/
+/composer.lock
\ No newline at end of file
diff --git a/vendor/jakub-onderka/php-console-highlighter/.travis.yml b/vendor/jakub-onderka/php-console-highlighter/.travis.yml
new file mode 100644
index 000000000..c88c4ec9d
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/.travis.yml
@@ -0,0 +1,22 @@
+language: php
+
+php:
+ - 5.4
+ - 5.5
+ - 5.6
+ - 7.0
+ - 7.1
+ - 7.2
+
+sudo: false
+
+cache:
+ directories:
+ - vendor
+ - $HOME/.composer/cache
+
+before_script:
+ - composer install --no-interaction --prefer-source
+
+script:
+ - ant
diff --git a/vendor/jakub-onderka/php-console-highlighter/LICENSE b/vendor/jakub-onderka/php-console-highlighter/LICENSE
new file mode 100644
index 000000000..1a8317fa1
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/LICENSE
@@ -0,0 +1,21 @@
+The MIT License (MIT)
+
+Copyright (c) 2013 Jakub Onderka
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
\ No newline at end of file
diff --git a/vendor/jakub-onderka/php-console-highlighter/README.md b/vendor/jakub-onderka/php-console-highlighter/README.md
new file mode 100644
index 000000000..1ef3d1340
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/README.md
@@ -0,0 +1,42 @@
+PHP Console Highlighter
+=======================
+
+Highlight PHP code in console (terminal).
+
+Example
+-------
+
+
+Install
+-------
+
+Just create a `composer.json` file and run the `php composer.phar install` command to install it:
+
+```json
+{
+ "require": {
+ "jakub-onderka/php-console-highlighter": "0.*"
+ }
+}
+```
+
+Usage
+-------
+```php
+getWholeFile($fileContent);
+```
+
+------
+
+[](https://packagist.org/packages/jakub-onderka/php-console-highlighter)
+[](https://travis-ci.org/JakubOnderka/PHP-Console-Highlighter)
+[](https://packagist.org/packages/jakub-onderka/php-console-highlighter)
diff --git a/vendor/jakub-onderka/php-console-highlighter/build.xml b/vendor/jakub-onderka/php-console-highlighter/build.xml
new file mode 100644
index 000000000..d656ea9d4
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/build.xml
@@ -0,0 +1,93 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/vendor/jakub-onderka/php-console-highlighter/composer.json b/vendor/jakub-onderka/php-console-highlighter/composer.json
new file mode 100644
index 000000000..21c29f710
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/composer.json
@@ -0,0 +1,28 @@
+{
+ "name": "jakub-onderka/php-console-highlighter",
+ "description": "Highlight PHP code in terminal",
+ "type": "library",
+ "license": "MIT",
+ "authors": [
+ {
+ "name": "Jakub Onderka",
+ "email": "acci@acci.cz",
+ "homepage": "http://www.acci.cz/"
+ }
+ ],
+ "autoload": {
+ "psr-4": {"JakubOnderka\\PhpConsoleHighlighter\\": "src/"}
+ },
+ "require": {
+ "php": ">=5.4.0",
+ "ext-tokenizer": "*",
+ "jakub-onderka/php-console-color": "~0.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.0",
+ "jakub-onderka/php-parallel-lint": "~1.0",
+ "jakub-onderka/php-var-dump-check": "~0.1",
+ "squizlabs/php_codesniffer": "~1.5",
+ "jakub-onderka/php-code-style": "~1.0"
+ }
+}
diff --git a/vendor/jakub-onderka/php-console-highlighter/examples/snippet.php b/vendor/jakub-onderka/php-console-highlighter/examples/snippet.php
new file mode 100644
index 000000000..1bf6ac3bd
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/examples/snippet.php
@@ -0,0 +1,10 @@
+getCodeSnippet($fileContent, 3);
\ No newline at end of file
diff --git a/vendor/jakub-onderka/php-console-highlighter/examples/whole_file.php b/vendor/jakub-onderka/php-console-highlighter/examples/whole_file.php
new file mode 100644
index 000000000..2a023d80a
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/examples/whole_file.php
@@ -0,0 +1,10 @@
+getWholeFile($fileContent);
\ No newline at end of file
diff --git a/vendor/jakub-onderka/php-console-highlighter/examples/whole_file_line_numbers.php b/vendor/jakub-onderka/php-console-highlighter/examples/whole_file_line_numbers.php
new file mode 100644
index 000000000..f9178f2d1
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/examples/whole_file_line_numbers.php
@@ -0,0 +1,10 @@
+getWholeFileWithLineNumbers($fileContent);
\ No newline at end of file
diff --git a/vendor/jakub-onderka/php-console-highlighter/phpunit.xml b/vendor/jakub-onderka/php-console-highlighter/phpunit.xml
new file mode 100644
index 000000000..9c653a680
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/phpunit.xml
@@ -0,0 +1,15 @@
+
+
+
+
+ tests
+
+
+
+
+
+
+ vendor
+
+
+
diff --git a/vendor/jakub-onderka/php-console-highlighter/src/Highlighter.php b/vendor/jakub-onderka/php-console-highlighter/src/Highlighter.php
new file mode 100644
index 000000000..47ce30d2c
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/src/Highlighter.php
@@ -0,0 +1,263 @@
+ 'red',
+ self::TOKEN_COMMENT => 'yellow',
+ self::TOKEN_KEYWORD => 'green',
+ self::TOKEN_DEFAULT => 'default',
+ self::TOKEN_HTML => 'cyan',
+
+ self::ACTUAL_LINE_MARK => 'red',
+ self::LINE_NUMBER => 'dark_gray',
+ );
+
+ /**
+ * @param ConsoleColor $color
+ * @throws \JakubOnderka\PhpConsoleColor\InvalidStyleException
+ */
+ public function __construct(ConsoleColor $color)
+ {
+ $this->color = $color;
+
+ foreach ($this->defaultTheme as $name => $styles) {
+ if (!$this->color->hasTheme($name)) {
+ $this->color->addTheme($name, $styles);
+ }
+ }
+ }
+
+ /**
+ * @param string $source
+ * @param int $lineNumber
+ * @param int $linesBefore
+ * @param int $linesAfter
+ * @return string
+ * @throws \JakubOnderka\PhpConsoleColor\InvalidStyleException
+ * @throws \InvalidArgumentException
+ */
+ public function getCodeSnippet($source, $lineNumber, $linesBefore = 2, $linesAfter = 2)
+ {
+ $tokenLines = $this->getHighlightedLines($source);
+
+ $offset = $lineNumber - $linesBefore - 1;
+ $offset = max($offset, 0);
+ $length = $linesAfter + $linesBefore + 1;
+ $tokenLines = array_slice($tokenLines, $offset, $length, $preserveKeys = true);
+
+ $lines = $this->colorLines($tokenLines);
+
+ return $this->lineNumbers($lines, $lineNumber);
+ }
+
+ /**
+ * @param string $source
+ * @return string
+ * @throws \JakubOnderka\PhpConsoleColor\InvalidStyleException
+ * @throws \InvalidArgumentException
+ */
+ public function getWholeFile($source)
+ {
+ $tokenLines = $this->getHighlightedLines($source);
+ $lines = $this->colorLines($tokenLines);
+ return implode(PHP_EOL, $lines);
+ }
+
+ /**
+ * @param string $source
+ * @return string
+ * @throws \JakubOnderka\PhpConsoleColor\InvalidStyleException
+ * @throws \InvalidArgumentException
+ */
+ public function getWholeFileWithLineNumbers($source)
+ {
+ $tokenLines = $this->getHighlightedLines($source);
+ $lines = $this->colorLines($tokenLines);
+ return $this->lineNumbers($lines);
+ }
+
+ /**
+ * @param string $source
+ * @return array
+ */
+ private function getHighlightedLines($source)
+ {
+ $source = str_replace(array("\r\n", "\r"), "\n", $source);
+ $tokens = $this->tokenize($source);
+ return $this->splitToLines($tokens);
+ }
+
+ /**
+ * @param string $source
+ * @return array
+ */
+ private function tokenize($source)
+ {
+ $tokens = token_get_all($source);
+
+ $output = array();
+ $currentType = null;
+ $buffer = '';
+
+ foreach ($tokens as $token) {
+ if (is_array($token)) {
+ switch ($token[0]) {
+ case T_WHITESPACE:
+ break;
+
+ case T_OPEN_TAG:
+ case T_OPEN_TAG_WITH_ECHO:
+ case T_CLOSE_TAG:
+ case T_STRING:
+ case T_VARIABLE:
+
+ // Constants
+ case T_DIR:
+ case T_FILE:
+ case T_METHOD_C:
+ case T_DNUMBER:
+ case T_LNUMBER:
+ case T_NS_C:
+ case T_LINE:
+ case T_CLASS_C:
+ case T_FUNC_C:
+ case T_TRAIT_C:
+ $newType = self::TOKEN_DEFAULT;
+ break;
+
+ case T_COMMENT:
+ case T_DOC_COMMENT:
+ $newType = self::TOKEN_COMMENT;
+ break;
+
+ case T_ENCAPSED_AND_WHITESPACE:
+ case T_CONSTANT_ENCAPSED_STRING:
+ $newType = self::TOKEN_STRING;
+ break;
+
+ case T_INLINE_HTML:
+ $newType = self::TOKEN_HTML;
+ break;
+
+ default:
+ $newType = self::TOKEN_KEYWORD;
+ }
+ } else {
+ $newType = $token === '"' ? self::TOKEN_STRING : self::TOKEN_KEYWORD;
+ }
+
+ if ($currentType === null) {
+ $currentType = $newType;
+ }
+
+ if ($currentType !== $newType) {
+ $output[] = array($currentType, $buffer);
+ $buffer = '';
+ $currentType = $newType;
+ }
+
+ $buffer .= is_array($token) ? $token[1] : $token;
+ }
+
+ if (isset($newType)) {
+ $output[] = array($newType, $buffer);
+ }
+
+ return $output;
+ }
+
+ /**
+ * @param array $tokens
+ * @return array
+ */
+ private function splitToLines(array $tokens)
+ {
+ $lines = array();
+
+ $line = array();
+ foreach ($tokens as $token) {
+ foreach (explode("\n", $token[1]) as $count => $tokenLine) {
+ if ($count > 0) {
+ $lines[] = $line;
+ $line = array();
+ }
+
+ if ($tokenLine === '') {
+ continue;
+ }
+
+ $line[] = array($token[0], $tokenLine);
+ }
+ }
+
+ $lines[] = $line;
+
+ return $lines;
+ }
+
+ /**
+ * @param array $tokenLines
+ * @return array
+ * @throws \JakubOnderka\PhpConsoleColor\InvalidStyleException
+ * @throws \InvalidArgumentException
+ */
+ private function colorLines(array $tokenLines)
+ {
+ $lines = array();
+ foreach ($tokenLines as $lineCount => $tokenLine) {
+ $line = '';
+ foreach ($tokenLine as $token) {
+ list($tokenType, $tokenValue) = $token;
+ if ($this->color->hasTheme($tokenType)) {
+ $line .= $this->color->apply($tokenType, $tokenValue);
+ } else {
+ $line .= $tokenValue;
+ }
+ }
+ $lines[$lineCount] = $line;
+ }
+
+ return $lines;
+ }
+
+ /**
+ * @param array $lines
+ * @param null|int $markLine
+ * @return string
+ * @throws \JakubOnderka\PhpConsoleColor\InvalidStyleException
+ */
+ private function lineNumbers(array $lines, $markLine = null)
+ {
+ end($lines);
+ $lineStrlen = strlen(key($lines) + 1);
+
+ $snippet = '';
+ foreach ($lines as $i => $line) {
+ if ($markLine !== null) {
+ $snippet .= ($markLine === $i + 1 ? $this->color->apply(self::ACTUAL_LINE_MARK, ' > ') : ' ');
+ }
+
+ $snippet .= $this->color->apply(self::LINE_NUMBER, str_pad($i + 1, $lineStrlen, ' ', STR_PAD_LEFT) . '| ');
+ $snippet .= $line . PHP_EOL;
+ }
+
+ return $snippet;
+ }
+}
\ No newline at end of file
diff --git a/vendor/jakub-onderka/php-console-highlighter/tests/HigligterTest.php b/vendor/jakub-onderka/php-console-highlighter/tests/HigligterTest.php
new file mode 100644
index 000000000..187beb67b
--- /dev/null
+++ b/vendor/jakub-onderka/php-console-highlighter/tests/HigligterTest.php
@@ -0,0 +1,274 @@
+createMock('\JakubOnderka\PhpConsoleColor\ConsoleColor')
+ : $this->getMock('\JakubOnderka\PhpConsoleColor\ConsoleColor');
+
+ $mock->expects($this->any())
+ ->method('apply')
+ ->will($this->returnCallback(function ($style, $text) {
+ return "<$style>$text$style>";
+ }));
+
+ $mock->expects($this->any())
+ ->method('hasTheme')
+ ->will($this->returnValue(true));
+
+ return $mock;
+ }
+
+ protected function setUp()
+ {
+ $this->uut = new Highlighter($this->getConsoleColorMock());
+ }
+
+ protected function compare($original, $expected)
+ {
+ $output = $this->uut->getWholeFile($original);
+ $this->assertEquals($expected, $output);
+ }
+
+ public function testVariable()
+ {
+ $this->compare(
+ <<
+echo \$a ;
+EOL
+ );
+ }
+
+ public function testInteger()
+ {
+ $this->compare(
+ <<
+echo 43 ;
+EOL
+ );
+ }
+
+ public function testFloat()
+ {
+ $this->compare(
+ <<
+echo 43.3 ;
+EOL
+ );
+ }
+
+ public function testHex()
+ {
+ $this->compare(
+ <<
+echo 0x43 ;
+EOL
+ );
+ }
+
+ public function testBasicFunction()
+ {
+ $this->compare(
+ <<
+function plus ( \$a , \$b ) {
+ return \$a + \$b ;
+}
+EOL
+ );
+ }
+
+ public function testStringNormal()
+ {
+ $this->compare(
+ <<
+echo 'Ahoj světe' ;
+EOL
+ );
+ }
+
+ public function testStringDouble()
+ {
+ $this->compare(
+ <<
+echo "Ahoj světe" ;
+EOL
+ );
+ }
+
+ public function testInstanceof()
+ {
+ $this->compare(
+ <<
+\$a instanceof stdClass ;
+EOL
+ );
+ }
+
+ /*
+ * Constants
+ */
+ public function testConstant()
+ {
+ $constants = array(
+ '__FILE__',
+ '__LINE__',
+ '__CLASS__',
+ '__FUNCTION__',
+ '__METHOD__',
+ '__TRAIT__',
+ '__DIR__',
+ '__NAMESPACE__'
+ );
+
+ foreach ($constants as $constant) {
+ $this->compare(
+ <<
+$constant ;
+EOL
+ );
+ }
+ }
+
+ /*
+ * Comments
+ */
+ public function testComment()
+ {
+ $this->compare(
+ <<
+/* Ahoj */
+EOL
+ );
+ }
+
+ public function testDocComment()
+ {
+ $this->compare(
+ <<
+/** Ahoj */
+EOL
+ );
+ }
+
+ public function testInlineComment()
+ {
+ $this->compare(
+ <<
+// Ahoj
+EOL
+ );
+ }
+
+ public function testHashComment()
+ {
+ $this->compare(
+ <<
+# Ahoj
+EOL
+ );
+ }
+
+ public function testEmpty()
+ {
+ $this->compare(
+ ''
+ ,
+ ''
+ );
+ }
+
+ public function testWhitespace()
+ {
+ $this->compare(
+ ' '
+ ,
+ ' '
+ );
+ }
+}
diff --git a/vendor/kylekatarnls/update-helper/LICENSE b/vendor/kylekatarnls/update-helper/LICENSE
new file mode 100644
index 000000000..d55dee549
--- /dev/null
+++ b/vendor/kylekatarnls/update-helper/LICENSE
@@ -0,0 +1,22 @@
+MIT License
+
+Copyright (c) 2017 https://github.com/pug-php
+Copyright (c) 2017 https://github.com/kylekatarnls
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+SOFTWARE.
diff --git a/vendor/kylekatarnls/update-helper/composer.json b/vendor/kylekatarnls/update-helper/composer.json
new file mode 100644
index 000000000..ced852789
--- /dev/null
+++ b/vendor/kylekatarnls/update-helper/composer.json
@@ -0,0 +1,50 @@
+{
+ "name": "kylekatarnls/update-helper",
+ "description": "Update helper",
+ "type": "composer-plugin",
+ "license": "MIT",
+ "minimum-stability": "dev",
+ "prefer-stable": true,
+ "authors": [
+ {
+ "name": "Kyle",
+ "email": "kylekatarnls@gmail.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.3.0",
+ "composer-plugin-api": "^1.1.0 || ^2.0.0"
+ },
+ "require-dev": {
+ "composer/composer": "2.0.x-dev || ^2.0.0-dev",
+ "phpunit/phpunit": ">=4.8.35 <6.0",
+ "codeclimate/php-test-reporter": "dev-master"
+ },
+ "autoload": {
+ "psr-0": {
+ "UpdateHelper\\": "src/"
+ }
+ },
+ "autoload-dev": {
+ "psr-4": {
+ "UpdateHelper\\Tests\\": "tests/UpdateHelper/"
+ }
+ },
+ "scripts": {
+ "post-install-cmd": [
+ "UpdateHelper\\UpdateHelper::check"
+ ],
+ "post-update-cmd": [
+ "UpdateHelper\\UpdateHelper::check"
+ ],
+ "post-package-install": [
+ "UpdateHelper\\UpdateHelper::check"
+ ],
+ "post-package-update": [
+ "UpdateHelper\\UpdateHelper::check"
+ ]
+ },
+ "extra": {
+ "class": "UpdateHelper\\ComposerPlugin"
+ }
+}
diff --git a/vendor/kylekatarnls/update-helper/src/UpdateHelper/ComposerPlugin.php b/vendor/kylekatarnls/update-helper/src/UpdateHelper/ComposerPlugin.php
new file mode 100644
index 000000000..26d394b93
--- /dev/null
+++ b/vendor/kylekatarnls/update-helper/src/UpdateHelper/ComposerPlugin.php
@@ -0,0 +1,47 @@
+io = $io;
+ }
+
+ public function deactivate(Composer $composer, IOInterface $io)
+ {
+ // Not needed
+ }
+
+ public function uninstall(Composer $composer, IOInterface $io)
+ {
+ // Not needed
+ }
+
+ public static function getSubscribedEvents()
+ {
+ return array(
+ 'post-autoload-dump' => array(
+ array('onAutoloadDump', 0),
+ ),
+ );
+ }
+
+ public function onAutoloadDump(Event $event)
+ {
+ if (!class_exists('UpdateHelper\\UpdateHelper')) {
+ return;
+ }
+
+ UpdateHelper::check($event);
+ }
+}
diff --git a/vendor/kylekatarnls/update-helper/src/UpdateHelper/NotUpdateInterfaceInstanceException.php b/vendor/kylekatarnls/update-helper/src/UpdateHelper/NotUpdateInterfaceInstanceException.php
new file mode 100644
index 000000000..8213b5e5f
--- /dev/null
+++ b/vendor/kylekatarnls/update-helper/src/UpdateHelper/NotUpdateInterfaceInstanceException.php
@@ -0,0 +1,9 @@
+read();
+ } catch (Exception $e) {
+ $dependencyConfig = null;
+ }
+
+ if (is_array($dependencyConfig) && isset($dependencyConfig['extra'], $dependencyConfig['extra'][$key])) {
+ $classes[$file] = $dependencyConfig['extra'][$key];
+ }
+ }
+
+ protected static function getUpdateHelperConfig(Composer $composer, $key = null)
+ {
+ $vendorDir = $composer->getConfig()->get('vendor-dir');
+
+ $npm = array();
+
+ foreach (scandir($vendorDir) as $namespace) {
+ if ($namespace === '.' || $namespace === '..' || !is_dir($directory = $vendorDir.DIRECTORY_SEPARATOR.$namespace)) {
+ continue;
+ }
+
+ foreach (scandir($directory) as $dependency) {
+ if ($dependency === '.' || $dependency === '..' || !is_dir($subDirectory = $directory.DIRECTORY_SEPARATOR.$dependency)) {
+ continue;
+ }
+
+ static::appendConfig($npm, $subDirectory, $key);
+ }
+ }
+
+ static::appendConfig($npm, dirname($vendorDir), $key);
+
+ return $npm;
+ }
+
+ /**
+ * @param Event $event
+ * @param IOInterface $io
+ * @param Composer $composer
+ * @param string[] $subClasses
+ */
+ protected static function checkHelper($event, IOInterface $io, $composer, $class)
+ {
+ if (!is_string($class) || !class_exists($class)) {
+ throw new NotUpdateInterfaceInstanceException();
+ }
+
+ try {
+ $helper = new $class();
+ } catch (Exception $e) {
+ throw new InvalidArgumentException($e->getMessage(), 1000, $e);
+ } catch (Throwable $e) {
+ throw new InvalidArgumentException($e->getMessage(), 1000, $e);
+ }
+
+ if (!($helper instanceof UpdateHelperInterface)) {
+ throw new NotUpdateInterfaceInstanceException();
+ }
+
+ $helper->check(new static($event, $io, $composer));
+ }
+
+ /**
+ * @param string $file
+ * @param Event $event
+ * @param IOInterface $io
+ * @param Composer $composer
+ * @param string[] $subClasses
+ */
+ protected static function checkFileHelpers($file, $event, IOInterface $io, $composer, array $subClasses)
+ {
+ foreach ($subClasses as $class) {
+ try {
+ static::checkHelper($event, $io, $composer, $class);
+ } catch (InvalidArgumentException $exception) {
+ $io->writeError(static::getErrorMessage($exception, $file, $class));
+ continue;
+ }
+ }
+ }
+
+ protected static function getErrorMessage(InvalidArgumentException $exception, $file, $class)
+ {
+ if ($exception instanceof NotUpdateInterfaceInstanceException) {
+ return 'UpdateHelper error in '.$file.":\n".JsonFile::encode($class).' is not an instance of UpdateHelperInterface.';
+ }
+
+ return 'UpdateHelper error: '.$exception->getPrevious()->getMessage().
+ "\nFile: ".$exception->getPrevious()->getFile().
+ "\nLine:".$exception->getPrevious()->getLine().
+ "\n\n".$exception->getPrevious()->getTraceAsString();
+ }
+
+ public static function check(Event $event)
+ {
+ if (!($event instanceof ScriptEvent) && !($event instanceof PackageEvent)) {
+ return;
+ }
+
+ $io = $event->getIO();
+ $composer = $event->getComposer();
+ $autoload = $composer->getConfig()->get('vendor-dir').'/autoload.php';
+
+ if (file_exists($autoload)) {
+ include_once $autoload;
+ }
+
+ $classes = static::getUpdateHelperConfig($composer);
+
+ foreach ($classes as $file => $subClasses) {
+ static::checkFileHelpers($file, $event, $io, $composer, (array) $subClasses);
+ }
+ }
+
+ public function __construct(Event $event, IOInterface $io = null, Composer $composer = null)
+ {
+ $this->event = $event;
+ $this->io = $io ?: (method_exists($event, 'getIO') ? $event->getIO() : null);
+ $this->composer = $composer ?: (method_exists($event, 'getComposer') ? $event->getComposer() : null);
+
+ if ($this->composer &&
+ ($directory = $this->composer->getConfig()->get('archive-dir')) &&
+ file_exists($file = $directory.'/composer.json')
+ ) {
+ $this->composerFilePath = $file;
+ $this->file = new JsonFile($this->composerFilePath);
+ $this->dependencies = $this->file->read();
+ }
+ }
+
+ /**
+ * @return JsonFile
+ */
+ public function getFile()
+ {
+ return $this->file;
+ }
+
+ /**
+ * @return string
+ */
+ public function getComposerFilePath()
+ {
+ return $this->composerFilePath;
+ }
+
+ /**
+ * @return Composer
+ */
+ public function getComposer()
+ {
+ return $this->composer;
+ }
+
+ /**
+ * @return Event
+ */
+ public function getEvent()
+ {
+ return $this->event;
+ }
+
+ /**
+ * @return IOInterface|null
+ */
+ public function getIo()
+ {
+ return $this->io;
+ }
+
+ /**
+ * @return array
+ */
+ public function getDependencies()
+ {
+ return $this->dependencies;
+ }
+
+ /**
+ * @return array
+ */
+ public function getDevDependencies()
+ {
+ return isset($this->dependencies['require-dev']) ? $this->dependencies['require-dev'] : array();
+ }
+
+ /**
+ * @return array
+ */
+ public function getProdDependencies()
+ {
+ return isset($this->dependencies['require']) ? $this->dependencies['require'] : array();
+ }
+
+ /**
+ * @return array
+ */
+ public function getFlattenDependencies()
+ {
+ return array_merge($this->getDevDependencies(), $this->getProdDependencies());
+ }
+
+ /**
+ * @param string $dependency
+ *
+ * @return bool
+ */
+ public function hasAsDevDependency($dependency)
+ {
+ return isset($this->dependencies['require-dev'][$dependency]);
+ }
+
+ /**
+ * @param string $dependency
+ *
+ * @return bool
+ */
+ public function hasAsProdDependency($dependency)
+ {
+ return isset($this->dependencies['require'][$dependency]);
+ }
+
+ /**
+ * @param string $dependency
+ *
+ * @return bool
+ */
+ public function hasAsDependency($dependency)
+ {
+ return $this->hasAsDevDependency($dependency) || $this->hasAsProdDependency($dependency);
+ }
+
+ /**
+ * @param string $dependency
+ * @param string $version
+ *
+ * @return bool
+ */
+ public function isDependencyAtLeast($dependency, $version)
+ {
+ if ($this->hasAsProdDependency($dependency)) {
+ return Semver::satisfies($version, $this->dependencies['require'][$dependency]);
+ }
+
+ if ($this->hasAsDevDependency($dependency)) {
+ return Semver::satisfies($version, $this->dependencies['require-dev'][$dependency]);
+ }
+
+ return false;
+ }
+
+ /**
+ * @param string $dependency
+ * @param string $version
+ *
+ * @return bool
+ */
+ public function isDependencyLesserThan($dependency, $version)
+ {
+ return !$this->isDependencyAtLeast($dependency, $version);
+ }
+
+ /**
+ * @param string $dependency
+ * @param string $version
+ * @param array $environments
+ *
+ * @throws Exception
+ *
+ * @return $this
+ */
+ public function setDependencyVersion($dependency, $version, $environments = array('require', 'require-dev'))
+ {
+ return $this->setDependencyVersions(array($dependency => $version), $environments);
+ }
+
+ /**
+ * @param array $dependencies
+ * @param array $environments
+ *
+ * @throws Exception
+ *
+ * @return $this
+ */
+ public function setDependencyVersions($dependencies, $environments = array('require', 'require-dev'))
+ {
+ if (!$this->composerFilePath) {
+ throw new RuntimeException('No composer instance detected.');
+ }
+
+ $touched = false;
+
+ foreach ($environments as $environment) {
+ foreach ($dependencies as $dependency => $version) {
+ if (isset($this->dependencies[$environment], $this->dependencies[$environment][$dependency])) {
+ $this->dependencies[$environment][$dependency] = $version;
+ $touched = true;
+ }
+ }
+ }
+
+ if ($touched) {
+ if (!$this->composerFilePath) {
+ throw new RuntimeException('composer.json not found (custom vendor-dir are not yet supported).');
+ }
+
+ $file = new JsonFile($this->composerFilePath);
+ $file->write($this->dependencies);
+ }
+
+ return $this;
+ }
+
+ /**
+ * @return $this
+ */
+ public function update()
+ {
+ $output = shell_exec('composer update --no-scripts');
+
+ if (!empty($output)) {
+ $this->write($output);
+ }
+
+ return $this;
+ }
+
+ /**
+ * @param string|array $text
+ */
+ public function write($text)
+ {
+ if ($this->io) {
+ $this->io->write($text);
+
+ return;
+ }
+
+ if (is_array($text)) {
+ $text = implode("\n", $text);
+ }
+
+ echo $text;
+ }
+
+ /**
+ * @return bool
+ */
+ public function isInteractive()
+ {
+ return $this->io && $this->io->isInteractive();
+ }
+}
diff --git a/vendor/kylekatarnls/update-helper/src/UpdateHelper/UpdateHelperInterface.php b/vendor/kylekatarnls/update-helper/src/UpdateHelper/UpdateHelperInterface.php
new file mode 100644
index 000000000..3809dc0f2
--- /dev/null
+++ b/vendor/kylekatarnls/update-helper/src/UpdateHelper/UpdateHelperInterface.php
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
+
+## About Laravel
+
+> **Note:** This repository contains the core code of the Laravel framework. If you want to build an application using Laravel 5, visit the main [Laravel repository](https://github.com/laravel/laravel).
+
+Laravel is a web application framework with expressive, elegant syntax. We believe development must be an enjoyable, creative experience to be truly fulfilling. Laravel attempts to take the pain out of development by easing common tasks used in the majority of web projects, such as:
+
+- [Simple, fast routing engine](https://laravel.com/docs/routing).
+- [Powerful dependency injection container](https://laravel.com/docs/container).
+- Multiple back-ends for [session](https://laravel.com/docs/session) and [cache](https://laravel.com/docs/cache) storage.
+- Database agnostic [schema migrations](https://laravel.com/docs/migrations).
+- [Robust background job processing](https://laravel.com/docs/queues).
+- [Real-time event broadcasting](https://laravel.com/docs/broadcasting).
+
+Laravel is accessible, yet powerful, providing tools needed for large, robust applications. A superb combination of simplicity, elegance, and innovation give you tools you need to build any application with which you are tasked.
+
+## Learning Laravel
+
+Laravel has the most extensive and thorough documentation and video tutorial library of any modern web application framework. The [Laravel documentation](https://laravel.com/docs) is thorough, complete, and makes it a breeze to get started learning the framework.
+
+If you're not in the mood to read, [Laracasts](https://laracasts.com) contains over 900 video tutorials covering a range of topics including Laravel, modern PHP, unit testing, JavaScript, and more. Boost the skill level of yourself and your entire team by digging into our comprehensive video library.
+
+## Contributing
+
+Thank you for considering contributing to the Laravel framework! The contribution guide can be found in the [Laravel documentation](http://laravel.com/docs/contributions).
+
+## Code of Conduct
+
+In order to ensure that the Laravel community is welcoming to all, please review and abide by the [Code of Conduct](CODE_OF_CONDUCT.md).
+
+## Security Vulnerabilities
+
+If you discover a security vulnerability within Laravel, please send an e-mail to Taylor Otwell at taylor@laravel.com. All security vulnerabilities will be promptly addressed.
+
+## License
+
+The Laravel framework is open-sourced software licensed under the [MIT license](http://opensource.org/licenses/MIT).
diff --git a/vendor/laravel/framework/composer.json b/vendor/laravel/framework/composer.json
new file mode 100644
index 000000000..bc1c0956d
--- /dev/null
+++ b/vendor/laravel/framework/composer.json
@@ -0,0 +1,126 @@
+{
+ "name": "laravel/framework",
+ "description": "The Laravel Framework.",
+ "keywords": ["framework", "laravel"],
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "ext-mbstring": "*",
+ "ext-openssl": "*",
+ "doctrine/inflector": "~1.1",
+ "erusev/parsedown": "~1.6",
+ "league/flysystem": "~1.0",
+ "monolog/monolog": "~1.11",
+ "mtdowling/cron-expression": "~1.0",
+ "nesbot/carbon": "~1.20",
+ "paragonie/random_compat": "~1.4|~2.0",
+ "ramsey/uuid": "~3.0",
+ "swiftmailer/swiftmailer": "~5.4",
+ "symfony/console": "~3.2",
+ "symfony/debug": "~3.2",
+ "symfony/finder": "~3.2",
+ "symfony/http-foundation": "~3.2",
+ "symfony/http-kernel": "~3.2",
+ "symfony/process": "~3.2",
+ "symfony/routing": "~3.2",
+ "symfony/var-dumper": "~3.2",
+ "tijsverkoyen/css-to-inline-styles": "~2.2",
+ "vlucas/phpdotenv": "~2.2"
+ },
+ "replace": {
+ "illuminate/auth": "self.version",
+ "illuminate/broadcasting": "self.version",
+ "illuminate/bus": "self.version",
+ "illuminate/cache": "self.version",
+ "illuminate/config": "self.version",
+ "illuminate/console": "self.version",
+ "illuminate/container": "self.version",
+ "illuminate/contracts": "self.version",
+ "illuminate/cookie": "self.version",
+ "illuminate/database": "self.version",
+ "illuminate/encryption": "self.version",
+ "illuminate/events": "self.version",
+ "illuminate/exception": "self.version",
+ "illuminate/filesystem": "self.version",
+ "illuminate/hashing": "self.version",
+ "illuminate/http": "self.version",
+ "illuminate/log": "self.version",
+ "illuminate/mail": "self.version",
+ "illuminate/notifications": "self.version",
+ "illuminate/pagination": "self.version",
+ "illuminate/pipeline": "self.version",
+ "illuminate/queue": "self.version",
+ "illuminate/redis": "self.version",
+ "illuminate/routing": "self.version",
+ "illuminate/session": "self.version",
+ "illuminate/support": "self.version",
+ "illuminate/translation": "self.version",
+ "illuminate/validation": "self.version",
+ "illuminate/view": "self.version",
+ "tightenco/collect": "self.version"
+ },
+ "require-dev": {
+ "aws/aws-sdk-php": "~3.0",
+ "doctrine/dbal": "~2.5",
+ "mockery/mockery": "~0.9.4",
+ "pda/pheanstalk": "~3.0",
+ "phpunit/phpunit": "~5.7",
+ "predis/predis": "~1.0",
+ "symfony/css-selector": "~3.2",
+ "symfony/dom-crawler": "~3.2"
+ },
+ "autoload": {
+ "files": [
+ "src/Illuminate/Foundation/helpers.php",
+ "src/Illuminate/Support/helpers.php"
+ ],
+ "psr-4": {
+ "Illuminate\\": "src/Illuminate/"
+ }
+ },
+ "autoload-dev": {
+ "files": [
+ "tests/Database/stubs/MigrationCreatorFakeMigration.php"
+ ],
+ "psr-4": {
+ "Illuminate\\Tests\\": "tests/"
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "aws/aws-sdk-php": "Required to use the SQS queue driver and SES mail driver (~3.0).",
+ "doctrine/dbal": "Required to rename columns and drop SQLite columns (~2.5).",
+ "fzaninotto/faker": "Required to use the eloquent factory builder (~1.4).",
+ "guzzlehttp/guzzle": "Required to use the Mailgun and Mandrill mail drivers and the ping methods on schedules (~6.0).",
+ "laravel/tinker": "Required to use the tinker console command (~1.0).",
+ "league/flysystem-aws-s3-v3": "Required to use the Flysystem S3 driver (~1.0).",
+ "league/flysystem-rackspace": "Required to use the Flysystem Rackspace driver (~1.0).",
+ "nexmo/client": "Required to use the Nexmo transport (~1.0).",
+ "pda/pheanstalk": "Required to use the beanstalk queue driver (~3.0).",
+ "predis/predis": "Required to use the redis cache and queue drivers (~1.0).",
+ "pusher/pusher-php-server": "Required to use the Pusher broadcast driver (~2.0).",
+ "symfony/css-selector": "Required to use some of the crawler integration testing tools (~3.2).",
+ "symfony/dom-crawler": "Required to use most of the crawler integration testing tools (~3.2).",
+ "symfony/psr-http-message-bridge": "Required to psr7 bridging features (0.2.*)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev",
+ "prefer-stable": true
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Access/AuthorizationException.php b/vendor/laravel/framework/src/Illuminate/Auth/Access/AuthorizationException.php
new file mode 100644
index 000000000..dc0753e28
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Access/AuthorizationException.php
@@ -0,0 +1,10 @@
+policies = $policies;
+ $this->container = $container;
+ $this->abilities = $abilities;
+ $this->userResolver = $userResolver;
+ $this->afterCallbacks = $afterCallbacks;
+ $this->beforeCallbacks = $beforeCallbacks;
+ }
+
+ /**
+ * Determine if a given ability has been defined.
+ *
+ * @param string $ability
+ * @return bool
+ */
+ public function has($ability)
+ {
+ return isset($this->abilities[$ability]);
+ }
+
+ /**
+ * Define a new ability.
+ *
+ * @param string $ability
+ * @param callable|string $callback
+ * @return $this
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function define($ability, $callback)
+ {
+ if (is_callable($callback)) {
+ $this->abilities[$ability] = $callback;
+ } elseif (is_string($callback) && Str::contains($callback, '@')) {
+ $this->abilities[$ability] = $this->buildAbilityCallback($callback);
+ } else {
+ throw new InvalidArgumentException("Callback must be a callable or a 'Class@method' string.");
+ }
+
+ return $this;
+ }
+
+ /**
+ * Define abilities for a resource.
+ *
+ * @param string $name
+ * @param string $class
+ * @param array $abilities
+ * @return $this
+ */
+ public function resource($name, $class, array $abilities = null)
+ {
+ $abilities = $abilities ?: [
+ 'view' => 'view',
+ 'create' => 'create',
+ 'update' => 'update',
+ 'delete' => 'delete',
+ ];
+
+ foreach ($abilities as $ability => $method) {
+ $this->define($name.'.'.$ability, $class.'@'.$method);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Create the ability callback for a callback string.
+ *
+ * @param string $callback
+ * @return \Closure
+ */
+ protected function buildAbilityCallback($callback)
+ {
+ return function () use ($callback) {
+ list($class, $method) = Str::parseCallback($callback);
+
+ return $this->resolvePolicy($class)->{$method}(...func_get_args());
+ };
+ }
+
+ /**
+ * Define a policy class for a given class type.
+ *
+ * @param string $class
+ * @param string $policy
+ * @return $this
+ */
+ public function policy($class, $policy)
+ {
+ $this->policies[$class] = $policy;
+
+ return $this;
+ }
+
+ /**
+ * Register a callback to run before all Gate checks.
+ *
+ * @param callable $callback
+ * @return $this
+ */
+ public function before(callable $callback)
+ {
+ $this->beforeCallbacks[] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Register a callback to run after all Gate checks.
+ *
+ * @param callable $callback
+ * @return $this
+ */
+ public function after(callable $callback)
+ {
+ $this->afterCallbacks[] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Determine if the given ability should be granted for the current user.
+ *
+ * @param string $ability
+ * @param array|mixed $arguments
+ * @return bool
+ */
+ public function allows($ability, $arguments = [])
+ {
+ return $this->check($ability, $arguments);
+ }
+
+ /**
+ * Determine if the given ability should be denied for the current user.
+ *
+ * @param string $ability
+ * @param array|mixed $arguments
+ * @return bool
+ */
+ public function denies($ability, $arguments = [])
+ {
+ return ! $this->allows($ability, $arguments);
+ }
+
+ /**
+ * Determine if the given ability should be granted for the current user.
+ *
+ * @param string $ability
+ * @param array|mixed $arguments
+ * @return bool
+ */
+ public function check($ability, $arguments = [])
+ {
+ try {
+ return (bool) $this->raw($ability, $arguments);
+ } catch (AuthorizationException $e) {
+ return false;
+ }
+ }
+
+ /**
+ * Determine if the given ability should be granted for the current user.
+ *
+ * @param string $ability
+ * @param array|mixed $arguments
+ * @return \Illuminate\Auth\Access\Response
+ *
+ * @throws \Illuminate\Auth\Access\AuthorizationException
+ */
+ public function authorize($ability, $arguments = [])
+ {
+ $result = $this->raw($ability, $arguments);
+
+ if ($result instanceof Response) {
+ return $result;
+ }
+
+ return $result ? $this->allow() : $this->deny();
+ }
+
+ /**
+ * Get the raw result from the authorization callback.
+ *
+ * @param string $ability
+ * @param array|mixed $arguments
+ * @return mixed
+ */
+ protected function raw($ability, $arguments = [])
+ {
+ if (! $user = $this->resolveUser()) {
+ return false;
+ }
+
+ $arguments = array_wrap($arguments);
+
+ // First we will call the "before" callbacks for the Gate. If any of these give
+ // back a non-null response, we will immediately return that result in order
+ // to let the developers override all checks for some authorization cases.
+ $result = $this->callBeforeCallbacks(
+ $user, $ability, $arguments
+ );
+
+ if (is_null($result)) {
+ $result = $this->callAuthCallback($user, $ability, $arguments);
+ }
+
+ // After calling the authorization callback, we will call the "after" callbacks
+ // that are registered with the Gate, which allows a developer to do logging
+ // if that is required for this application. Then we'll return the result.
+ $this->callAfterCallbacks(
+ $user, $ability, $arguments, $result
+ );
+
+ return $result;
+ }
+
+ /**
+ * Resolve and call the appropriate authorization callback.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param string $ability
+ * @param array $arguments
+ * @return bool
+ */
+ protected function callAuthCallback($user, $ability, array $arguments)
+ {
+ $callback = $this->resolveAuthCallback($user, $ability, $arguments);
+
+ return $callback($user, ...$arguments);
+ }
+
+ /**
+ * Call all of the before callbacks and return if a result is given.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param string $ability
+ * @param array $arguments
+ * @return bool|null
+ */
+ protected function callBeforeCallbacks($user, $ability, array $arguments)
+ {
+ $arguments = array_merge([$user, $ability], [$arguments]);
+
+ foreach ($this->beforeCallbacks as $before) {
+ if (! is_null($result = $before(...$arguments))) {
+ return $result;
+ }
+ }
+ }
+
+ /**
+ * Call all of the after callbacks with check result.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param string $ability
+ * @param array $arguments
+ * @param bool $result
+ * @return void
+ */
+ protected function callAfterCallbacks($user, $ability, array $arguments, $result)
+ {
+ $arguments = array_merge([$user, $ability, $result], [$arguments]);
+
+ foreach ($this->afterCallbacks as $after) {
+ $after(...$arguments);
+ }
+ }
+
+ /**
+ * Resolve the callable for the given ability and arguments.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param string $ability
+ * @param array $arguments
+ * @return callable
+ */
+ protected function resolveAuthCallback($user, $ability, array $arguments)
+ {
+ if (isset($arguments[0])) {
+ if (! is_null($policy = $this->getPolicyFor($arguments[0]))) {
+ return $this->resolvePolicyCallback($user, $ability, $arguments, $policy);
+ }
+ }
+
+ if (isset($this->abilities[$ability])) {
+ return $this->abilities[$ability];
+ }
+
+ return function () {
+ return false;
+ };
+ }
+
+ /**
+ * Get a policy instance for a given class.
+ *
+ * @param object|string $class
+ * @return mixed
+ */
+ public function getPolicyFor($class)
+ {
+ if (is_object($class)) {
+ $class = get_class($class);
+ }
+
+ if (! is_string($class)) {
+ return null;
+ }
+
+ if (isset($this->policies[$class])) {
+ return $this->resolvePolicy($this->policies[$class]);
+ }
+
+ foreach ($this->policies as $expected => $policy) {
+ if (is_subclass_of($class, $expected)) {
+ return $this->resolvePolicy($policy);
+ }
+ }
+ }
+
+ /**
+ * Build a policy class instance of the given type.
+ *
+ * @param object|string $class
+ * @return mixed
+ */
+ public function resolvePolicy($class)
+ {
+ return $this->container->make($class);
+ }
+
+ /**
+ * Resolve the callback for a policy check.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param string $ability
+ * @param array $arguments
+ * @param mixed $policy
+ * @return callable
+ */
+ protected function resolvePolicyCallback($user, $ability, array $arguments, $policy)
+ {
+ return function () use ($user, $ability, $arguments, $policy) {
+ // This callback will be responsible for calling the policy's before method and
+ // running this policy method if necessary. This is used to when objects are
+ // mapped to policy objects in the user's configurations or on this class.
+ $result = $this->callPolicyBefore(
+ $policy, $user, $ability, $arguments
+ );
+
+ // When we receive a non-null result from this before method, we will return it
+ // as the "final" results. This will allow developers to override the checks
+ // in this policy to return the result for all rules defined in the class.
+ if (! is_null($result)) {
+ return $result;
+ }
+
+ $ability = $this->formatAbilityToMethod($ability);
+
+ // If this first argument is a string, that means they are passing a class name
+ // to the policy. We will remove the first argument from this argument array
+ // because this policy already knows what type of models it can authorize.
+ if (isset($arguments[0]) && is_string($arguments[0])) {
+ array_shift($arguments);
+ }
+
+ return is_callable([$policy, $ability])
+ ? $policy->{$ability}($user, ...$arguments)
+ : false;
+ };
+ }
+
+ /**
+ * Call the "before" method on the given policy, if applicable.
+ *
+ * @param mixed $policy
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param string $ability
+ * @param array $arguments
+ * @return mixed
+ */
+ protected function callPolicyBefore($policy, $user, $ability, $arguments)
+ {
+ if (method_exists($policy, 'before')) {
+ return $policy->before($user, $ability, ...$arguments);
+ }
+ }
+
+ /**
+ * Format the policy ability into a method name.
+ *
+ * @param string $ability
+ * @return string
+ */
+ protected function formatAbilityToMethod($ability)
+ {
+ return strpos($ability, '-') !== false ? Str::camel($ability) : $ability;
+ }
+
+ /**
+ * Get a gate instance for the given user.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable|mixed $user
+ * @return static
+ */
+ public function forUser($user)
+ {
+ $callback = function () use ($user) {
+ return $user;
+ };
+
+ return new static(
+ $this->container, $callback, $this->abilities,
+ $this->policies, $this->beforeCallbacks, $this->afterCallbacks
+ );
+ }
+
+ /**
+ * Resolve the user from the user resolver.
+ *
+ * @return mixed
+ */
+ protected function resolveUser()
+ {
+ return call_user_func($this->userResolver);
+ }
+
+ /**
+ * Get all of the defined abilities.
+ *
+ * @return array
+ */
+ public function abilities()
+ {
+ return $this->abilities;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Access/HandlesAuthorization.php b/vendor/laravel/framework/src/Illuminate/Auth/Access/HandlesAuthorization.php
new file mode 100644
index 000000000..1a597bb99
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Access/HandlesAuthorization.php
@@ -0,0 +1,30 @@
+message = $message;
+ }
+
+ /**
+ * Get the response message.
+ *
+ * @return string|null
+ */
+ public function message()
+ {
+ return $this->message;
+ }
+
+ /**
+ * Get the string representation of the message.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->message();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/AuthManager.php b/vendor/laravel/framework/src/Illuminate/Auth/AuthManager.php
new file mode 100644
index 000000000..984467259
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/AuthManager.php
@@ -0,0 +1,296 @@
+app = $app;
+
+ $this->userResolver = function ($guard = null) {
+ return $this->guard($guard)->user();
+ };
+ }
+
+ /**
+ * Attempt to get the guard from the local cache.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Auth\Guard|\Illuminate\Contracts\Auth\StatefulGuard
+ */
+ public function guard($name = null)
+ {
+ $name = $name ?: $this->getDefaultDriver();
+
+ return isset($this->guards[$name])
+ ? $this->guards[$name]
+ : $this->guards[$name] = $this->resolve($name);
+ }
+
+ /**
+ * Resolve the given guard.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Auth\Guard|\Illuminate\Contracts\Auth\StatefulGuard
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function resolve($name)
+ {
+ $config = $this->getConfig($name);
+
+ if (is_null($config)) {
+ throw new InvalidArgumentException("Auth guard [{$name}] is not defined.");
+ }
+
+ if (isset($this->customCreators[$config['driver']])) {
+ return $this->callCustomCreator($name, $config);
+ }
+
+ $driverMethod = 'create'.ucfirst($config['driver']).'Driver';
+
+ if (method_exists($this, $driverMethod)) {
+ return $this->{$driverMethod}($name, $config);
+ }
+
+ throw new InvalidArgumentException("Auth guard driver [{$name}] is not defined.");
+ }
+
+ /**
+ * Call a custom driver creator.
+ *
+ * @param string $name
+ * @param array $config
+ * @return mixed
+ */
+ protected function callCustomCreator($name, array $config)
+ {
+ return $this->customCreators[$config['driver']]($this->app, $name, $config);
+ }
+
+ /**
+ * Create a session based authentication guard.
+ *
+ * @param string $name
+ * @param array $config
+ * @return \Illuminate\Auth\SessionGuard
+ */
+ public function createSessionDriver($name, $config)
+ {
+ $provider = $this->createUserProvider($config['provider']);
+
+ $guard = new SessionGuard($name, $provider, $this->app['session.store']);
+
+ // When using the remember me functionality of the authentication services we
+ // will need to be set the encryption instance of the guard, which allows
+ // secure, encrypted cookie values to get generated for those cookies.
+ if (method_exists($guard, 'setCookieJar')) {
+ $guard->setCookieJar($this->app['cookie']);
+ }
+
+ if (method_exists($guard, 'setDispatcher')) {
+ $guard->setDispatcher($this->app['events']);
+ }
+
+ if (method_exists($guard, 'setRequest')) {
+ $guard->setRequest($this->app->refresh('request', $guard, 'setRequest'));
+ }
+
+ return $guard;
+ }
+
+ /**
+ * Create a token based authentication guard.
+ *
+ * @param string $name
+ * @param array $config
+ * @return \Illuminate\Auth\TokenGuard
+ */
+ public function createTokenDriver($name, $config)
+ {
+ // The token guard implements a basic API token based guard implementation
+ // that takes an API token field from the request and matches it to the
+ // user in the database or another persistence layer where users are.
+ $guard = new TokenGuard(
+ $this->createUserProvider($config['provider']),
+ $this->app['request']
+ );
+
+ $this->app->refresh('request', $guard, 'setRequest');
+
+ return $guard;
+ }
+
+ /**
+ * Get the guard configuration.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function getConfig($name)
+ {
+ return $this->app['config']["auth.guards.{$name}"];
+ }
+
+ /**
+ * Get the default authentication driver name.
+ *
+ * @return string
+ */
+ public function getDefaultDriver()
+ {
+ return $this->app['config']['auth.defaults.guard'];
+ }
+
+ /**
+ * Set the default guard driver the factory should serve.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function shouldUse($name)
+ {
+ $name = $name ?: $this->getDefaultDriver();
+
+ $this->setDefaultDriver($name);
+
+ $this->userResolver = function ($name = null) {
+ return $this->guard($name)->user();
+ };
+ }
+
+ /**
+ * Set the default authentication driver name.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setDefaultDriver($name)
+ {
+ $this->app['config']['auth.defaults.guard'] = $name;
+ }
+
+ /**
+ * Register a new callback based request guard.
+ *
+ * @param string $driver
+ * @param callable $callback
+ * @return $this
+ */
+ public function viaRequest($driver, callable $callback)
+ {
+ return $this->extend($driver, function () use ($callback) {
+ $guard = new RequestGuard($callback, $this->app['request']);
+
+ $this->app->refresh('request', $guard, 'setRequest');
+
+ return $guard;
+ });
+ }
+
+ /**
+ * Get the user resolver callback.
+ *
+ * @return \Closure
+ */
+ public function userResolver()
+ {
+ return $this->userResolver;
+ }
+
+ /**
+ * Set the callback to be used to resolve users.
+ *
+ * @param \Closure $userResolver
+ * @return $this
+ */
+ public function resolveUsersUsing(Closure $userResolver)
+ {
+ $this->userResolver = $userResolver;
+
+ return $this;
+ }
+
+ /**
+ * Register a custom driver creator Closure.
+ *
+ * @param string $driver
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function extend($driver, Closure $callback)
+ {
+ $this->customCreators[$driver] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Register a custom provider creator Closure.
+ *
+ * @param string $name
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function provider($name, Closure $callback)
+ {
+ $this->customProviderCreators[$name] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Dynamically call the default driver instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->guard()->{$method}(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/AuthServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Auth/AuthServiceProvider.php
new file mode 100644
index 000000000..2820beb48
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/AuthServiceProvider.php
@@ -0,0 +1,90 @@
+registerAuthenticator();
+
+ $this->registerUserResolver();
+
+ $this->registerAccessGate();
+
+ $this->registerRequestRebindHandler();
+ }
+
+ /**
+ * Register the authenticator services.
+ *
+ * @return void
+ */
+ protected function registerAuthenticator()
+ {
+ $this->app->singleton('auth', function ($app) {
+ // Once the authentication service has actually been requested by the developer
+ // we will set a variable in the application indicating such. This helps us
+ // know that we need to set any queued cookies in the after event later.
+ $app['auth.loaded'] = true;
+
+ return new AuthManager($app);
+ });
+
+ $this->app->singleton('auth.driver', function ($app) {
+ return $app['auth']->guard();
+ });
+ }
+
+ /**
+ * Register a resolver for the authenticated user.
+ *
+ * @return void
+ */
+ protected function registerUserResolver()
+ {
+ $this->app->bind(
+ AuthenticatableContract::class, function ($app) {
+ return call_user_func($app['auth']->userResolver());
+ }
+ );
+ }
+
+ /**
+ * Register the access gate service.
+ *
+ * @return void
+ */
+ protected function registerAccessGate()
+ {
+ $this->app->singleton(GateContract::class, function ($app) {
+ return new Gate($app, function () use ($app) {
+ return call_user_func($app['auth']->userResolver());
+ });
+ });
+ }
+
+ /**
+ * Register a resolver for the authenticated user.
+ *
+ * @return void
+ */
+ protected function registerRequestRebindHandler()
+ {
+ $this->app->rebinding('request', function ($app, $request) {
+ $request->setUserResolver(function ($guard = null) use ($app) {
+ return call_user_func($app['auth']->userResolver(), $guard);
+ });
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Authenticatable.php b/vendor/laravel/framework/src/Illuminate/Auth/Authenticatable.php
new file mode 100644
index 000000000..63fa4dd3f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Authenticatable.php
@@ -0,0 +1,78 @@
+getKeyName();
+ }
+
+ /**
+ * Get the unique identifier for the user.
+ *
+ * @return mixed
+ */
+ public function getAuthIdentifier()
+ {
+ return $this->{$this->getAuthIdentifierName()};
+ }
+
+ /**
+ * Get the password for the user.
+ *
+ * @return string
+ */
+ public function getAuthPassword()
+ {
+ return $this->password;
+ }
+
+ /**
+ * Get the token value for the "remember me" session.
+ *
+ * @return string
+ */
+ public function getRememberToken()
+ {
+ if (! empty($this->getRememberTokenName())) {
+ return $this->{$this->getRememberTokenName()};
+ }
+ }
+
+ /**
+ * Set the token value for the "remember me" session.
+ *
+ * @param string $value
+ * @return void
+ */
+ public function setRememberToken($value)
+ {
+ if (! empty($this->getRememberTokenName())) {
+ $this->{$this->getRememberTokenName()} = $value;
+ }
+ }
+
+ /**
+ * Get the column name for the "remember me" token.
+ *
+ * @return string
+ */
+ public function getRememberTokenName()
+ {
+ return $this->rememberTokenName;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/AuthenticationException.php b/vendor/laravel/framework/src/Illuminate/Auth/AuthenticationException.php
new file mode 100644
index 000000000..3445b23a0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/AuthenticationException.php
@@ -0,0 +1,39 @@
+guards = $guards;
+ }
+
+ /**
+ * Get the guards that were checked.
+ *
+ * @return array
+ */
+ public function guards()
+ {
+ return $this->guards;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Console/AuthMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Auth/Console/AuthMakeCommand.php
new file mode 100644
index 000000000..31a89d081
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Console/AuthMakeCommand.php
@@ -0,0 +1,119 @@
+ 'auth/login.blade.php',
+ 'auth/register.stub' => 'auth/register.blade.php',
+ 'auth/passwords/email.stub' => 'auth/passwords/email.blade.php',
+ 'auth/passwords/reset.stub' => 'auth/passwords/reset.blade.php',
+ 'layouts/app.stub' => 'layouts/app.blade.php',
+ 'home.stub' => 'home.blade.php',
+ ];
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $this->createDirectories();
+
+ $this->exportViews();
+
+ if (! $this->option('views')) {
+ file_put_contents(
+ app_path('Http/Controllers/HomeController.php'),
+ $this->compileControllerStub()
+ );
+
+ file_put_contents(
+ base_path('routes/web.php'),
+ file_get_contents(__DIR__.'/stubs/make/routes.stub'),
+ FILE_APPEND
+ );
+ }
+
+ $this->info('Authentication scaffolding generated successfully.');
+ }
+
+ /**
+ * Create the directories for the files.
+ *
+ * @return void
+ */
+ protected function createDirectories()
+ {
+ if (! is_dir(resource_path('views/layouts'))) {
+ mkdir(resource_path('views/layouts'), 0755, true);
+ }
+
+ if (! is_dir(resource_path('views/auth/passwords'))) {
+ mkdir(resource_path('views/auth/passwords'), 0755, true);
+ }
+ }
+
+ /**
+ * Export the authentication views.
+ *
+ * @return void
+ */
+ protected function exportViews()
+ {
+ foreach ($this->views as $key => $value) {
+ if (file_exists(resource_path('views/'.$value)) && ! $this->option('force')) {
+ if (! $this->confirm("The [{$value}] view already exists. Do you want to replace it?")) {
+ continue;
+ }
+ }
+
+ copy(
+ __DIR__.'/stubs/make/views/'.$key,
+ resource_path('views/'.$value)
+ );
+ }
+ }
+
+ /**
+ * Compiles the HomeController stub.
+ *
+ * @return string
+ */
+ protected function compileControllerStub()
+ {
+ return str_replace(
+ '{{namespace}}',
+ $this->getAppNamespace(),
+ file_get_contents(__DIR__.'/stubs/make/controllers/HomeController.stub')
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Console/ClearResetsCommand.php b/vendor/laravel/framework/src/Illuminate/Auth/Console/ClearResetsCommand.php
new file mode 100644
index 000000000..320e934d1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Console/ClearResetsCommand.php
@@ -0,0 +1,34 @@
+laravel['auth.password']->broker($this->argument('name'))->getRepository()->deleteExpired();
+
+ $this->info('Expired reset tokens cleared!');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/controllers/HomeController.stub b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/controllers/HomeController.stub
new file mode 100644
index 000000000..8e0007adc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/controllers/HomeController.stub
@@ -0,0 +1,28 @@
+middleware('auth');
+ }
+
+ /**
+ * Show the application dashboard.
+ *
+ * @return \Illuminate\Http\Response
+ */
+ public function index()
+ {
+ return view('home');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/routes.stub b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/routes.stub
new file mode 100644
index 000000000..2c37ded93
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/routes.stub
@@ -0,0 +1,4 @@
+
+Auth::routes();
+
+Route::get('/home', 'HomeController@index')->name('home');
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/login.stub b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/login.stub
new file mode 100644
index 000000000..07924ce66
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/login.stub
@@ -0,0 +1,69 @@
+@extends('layouts.app')
+
+@section('content')
+
+@endsection
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/passwords/email.stub b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/passwords/email.stub
new file mode 100644
index 000000000..ad38245bd
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/passwords/email.stub
@@ -0,0 +1,47 @@
+@extends('layouts.app')
+
+@section('content')
+
+
+
+
+
Reset Password
+
+
+ @if (session('status'))
+
+ {{ session('status') }}
+
+ @endif
+
+
+
+
+
+
+
+@endsection
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/passwords/reset.stub b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/passwords/reset.stub
new file mode 100644
index 000000000..84ec01016
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/passwords/reset.stub
@@ -0,0 +1,70 @@
+@extends('layouts.app')
+
+@section('content')
+
+@endsection
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/register.stub b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/register.stub
new file mode 100644
index 000000000..38eef8384
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/auth/register.stub
@@ -0,0 +1,77 @@
+@extends('layouts.app')
+
+@section('content')
+
+@endsection
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/home.stub b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/home.stub
new file mode 100644
index 000000000..d8437bf89
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/home.stub
@@ -0,0 +1,23 @@
+@extends('layouts.app')
+
+@section('content')
+
+
+
+
+
Dashboard
+
+
+ @if (session('status'))
+
+ {{ session('status') }}
+
+ @endif
+
+ You are logged in!
+
+
+
+
+
+@endsection
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/layouts/app.stub b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/layouts/app.stub
new file mode 100644
index 000000000..d4745b4e6
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Console/stubs/make/views/layouts/app.stub
@@ -0,0 +1,80 @@
+
+
+
+
+
+
+
+
+
+
+ {{ config('app.name', 'Laravel') }}
+
+
+
+
+
+
+
+
+
+
+ @yield('content')
+
+
+
+
+
+
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/CreatesUserProviders.php b/vendor/laravel/framework/src/Illuminate/Auth/CreatesUserProviders.php
new file mode 100644
index 000000000..715dee046
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/CreatesUserProviders.php
@@ -0,0 +1,67 @@
+app['config']['auth.providers.'.$provider];
+
+ if (isset($this->customProviderCreators[$config['driver']])) {
+ return call_user_func(
+ $this->customProviderCreators[$config['driver']], $this->app, $config
+ );
+ }
+
+ switch ($config['driver']) {
+ case 'database':
+ return $this->createDatabaseProvider($config);
+ case 'eloquent':
+ return $this->createEloquentProvider($config);
+ default:
+ throw new InvalidArgumentException("Authentication user provider [{$config['driver']}] is not defined.");
+ }
+ }
+
+ /**
+ * Create an instance of the database user provider.
+ *
+ * @param array $config
+ * @return \Illuminate\Auth\DatabaseUserProvider
+ */
+ protected function createDatabaseProvider($config)
+ {
+ $connection = $this->app['db']->connection();
+
+ return new DatabaseUserProvider($connection, $this->app['hash'], $config['table']);
+ }
+
+ /**
+ * Create an instance of the Eloquent user provider.
+ *
+ * @param array $config
+ * @return \Illuminate\Auth\EloquentUserProvider
+ */
+ protected function createEloquentProvider($config)
+ {
+ return new EloquentUserProvider($this->app['hash'], $config['model']);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/DatabaseUserProvider.php b/vendor/laravel/framework/src/Illuminate/Auth/DatabaseUserProvider.php
new file mode 100644
index 000000000..a94b74b8b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/DatabaseUserProvider.php
@@ -0,0 +1,146 @@
+conn = $conn;
+ $this->table = $table;
+ $this->hasher = $hasher;
+ }
+
+ /**
+ * Retrieve a user by their unique identifier.
+ *
+ * @param mixed $identifier
+ * @return \Illuminate\Contracts\Auth\Authenticatable|null
+ */
+ public function retrieveById($identifier)
+ {
+ $user = $this->conn->table($this->table)->find($identifier);
+
+ return $this->getGenericUser($user);
+ }
+
+ /**
+ * Retrieve a user by their unique identifier and "remember me" token.
+ *
+ * @param mixed $identifier
+ * @param string $token
+ * @return \Illuminate\Contracts\Auth\Authenticatable|null
+ */
+ public function retrieveByToken($identifier, $token)
+ {
+ $user = $this->conn->table($this->table)
+ ->where('id', $identifier)
+ ->where('remember_token', $token)
+ ->first();
+
+ return $this->getGenericUser($user);
+ }
+
+ /**
+ * Update the "remember me" token for the given user in storage.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param string $token
+ * @return void
+ */
+ public function updateRememberToken(UserContract $user, $token)
+ {
+ $this->conn->table($this->table)
+ ->where('id', $user->getAuthIdentifier())
+ ->update(['remember_token' => $token]);
+ }
+
+ /**
+ * Retrieve a user by the given credentials.
+ *
+ * @param array $credentials
+ * @return \Illuminate\Contracts\Auth\Authenticatable|null
+ */
+ public function retrieveByCredentials(array $credentials)
+ {
+ // First we will add each credential element to the query as a where clause.
+ // Then we can execute the query and, if we found a user, return it in a
+ // generic "user" object that will be utilized by the Guard instances.
+ $query = $this->conn->table($this->table);
+
+ foreach ($credentials as $key => $value) {
+ if (! Str::contains($key, 'password')) {
+ $query->where($key, $value);
+ }
+ }
+
+ // Now we are ready to execute the query to see if we have an user matching
+ // the given credentials. If not, we will just return nulls and indicate
+ // that there are no matching users for these given credential arrays.
+ $user = $query->first();
+
+ return $this->getGenericUser($user);
+ }
+
+ /**
+ * Get the generic user.
+ *
+ * @param mixed $user
+ * @return \Illuminate\Auth\GenericUser|null
+ */
+ protected function getGenericUser($user)
+ {
+ if (! is_null($user)) {
+ return new GenericUser((array) $user);
+ }
+ }
+
+ /**
+ * Validate a user against the given credentials.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param array $credentials
+ * @return bool
+ */
+ public function validateCredentials(UserContract $user, array $credentials)
+ {
+ return $this->hasher->check(
+ $credentials['password'], $user->getAuthPassword()
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/EloquentUserProvider.php b/vendor/laravel/framework/src/Illuminate/Auth/EloquentUserProvider.php
new file mode 100644
index 000000000..0d5cad9c7
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/EloquentUserProvider.php
@@ -0,0 +1,188 @@
+model = $model;
+ $this->hasher = $hasher;
+ }
+
+ /**
+ * Retrieve a user by their unique identifier.
+ *
+ * @param mixed $identifier
+ * @return \Illuminate\Contracts\Auth\Authenticatable|null
+ */
+ public function retrieveById($identifier)
+ {
+ $model = $this->createModel();
+
+ return $model->newQuery()
+ ->where($model->getAuthIdentifierName(), $identifier)
+ ->first();
+ }
+
+ /**
+ * Retrieve a user by their unique identifier and "remember me" token.
+ *
+ * @param mixed $identifier
+ * @param string $token
+ * @return \Illuminate\Contracts\Auth\Authenticatable|null
+ */
+ public function retrieveByToken($identifier, $token)
+ {
+ $model = $this->createModel();
+
+ return $model->newQuery()
+ ->where($model->getAuthIdentifierName(), $identifier)
+ ->where($model->getRememberTokenName(), $token)
+ ->first();
+ }
+
+ /**
+ * Update the "remember me" token for the given user in storage.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param string $token
+ * @return void
+ */
+ public function updateRememberToken(UserContract $user, $token)
+ {
+ $user->setRememberToken($token);
+
+ $timestamps = $user->timestamps;
+
+ $user->timestamps = false;
+
+ $user->save();
+
+ $user->timestamps = $timestamps;
+ }
+
+ /**
+ * Retrieve a user by the given credentials.
+ *
+ * @param array $credentials
+ * @return \Illuminate\Contracts\Auth\Authenticatable|null
+ */
+ public function retrieveByCredentials(array $credentials)
+ {
+ if (empty($credentials)) {
+ return;
+ }
+
+ // First we will add each credential element to the query as a where clause.
+ // Then we can execute the query and, if we found a user, return it in a
+ // Eloquent User "model" that will be utilized by the Guard instances.
+ $query = $this->createModel()->newQuery();
+
+ foreach ($credentials as $key => $value) {
+ if (! Str::contains($key, 'password')) {
+ $query->where($key, $value);
+ }
+ }
+
+ return $query->first();
+ }
+
+ /**
+ * Validate a user against the given credentials.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param array $credentials
+ * @return bool
+ */
+ public function validateCredentials(UserContract $user, array $credentials)
+ {
+ $plain = $credentials['password'];
+
+ return $this->hasher->check($plain, $user->getAuthPassword());
+ }
+
+ /**
+ * Create a new instance of the model.
+ *
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function createModel()
+ {
+ $class = '\\'.ltrim($this->model, '\\');
+
+ return new $class;
+ }
+
+ /**
+ * Gets the hasher implementation.
+ *
+ * @return \Illuminate\Contracts\Hashing\Hasher
+ */
+ public function getHasher()
+ {
+ return $this->hasher;
+ }
+
+ /**
+ * Sets the hasher implementation.
+ *
+ * @param \Illuminate\Contracts\Hashing\Hasher $hasher
+ * @return $this
+ */
+ public function setHasher(HasherContract $hasher)
+ {
+ $this->hasher = $hasher;
+
+ return $this;
+ }
+
+ /**
+ * Gets the name of the Eloquent user model.
+ *
+ * @return string
+ */
+ public function getModel()
+ {
+ return $this->model;
+ }
+
+ /**
+ * Sets the name of the Eloquent user model.
+ *
+ * @param string $model
+ * @return $this
+ */
+ public function setModel($model)
+ {
+ $this->model = $model;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Events/Attempting.php b/vendor/laravel/framework/src/Illuminate/Auth/Events/Attempting.php
new file mode 100644
index 000000000..3d0473000
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Events/Attempting.php
@@ -0,0 +1,32 @@
+remember = $remember;
+ $this->credentials = $credentials;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Events/Authenticated.php b/vendor/laravel/framework/src/Illuminate/Auth/Events/Authenticated.php
new file mode 100644
index 000000000..f33c198d3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Events/Authenticated.php
@@ -0,0 +1,28 @@
+user = $user;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Events/Failed.php b/vendor/laravel/framework/src/Illuminate/Auth/Events/Failed.php
new file mode 100644
index 000000000..5807e8e0e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Events/Failed.php
@@ -0,0 +1,32 @@
+user = $user;
+ $this->credentials = $credentials;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Events/Lockout.php b/vendor/laravel/framework/src/Illuminate/Auth/Events/Lockout.php
new file mode 100644
index 000000000..347943feb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Events/Lockout.php
@@ -0,0 +1,26 @@
+request = $request;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Events/Login.php b/vendor/laravel/framework/src/Illuminate/Auth/Events/Login.php
new file mode 100644
index 000000000..881674593
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Events/Login.php
@@ -0,0 +1,37 @@
+user = $user;
+ $this->remember = $remember;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Events/Logout.php b/vendor/laravel/framework/src/Illuminate/Auth/Events/Logout.php
new file mode 100644
index 000000000..ea788e715
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Events/Logout.php
@@ -0,0 +1,28 @@
+user = $user;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Events/Registered.php b/vendor/laravel/framework/src/Illuminate/Auth/Events/Registered.php
new file mode 100644
index 000000000..f84058cf1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Events/Registered.php
@@ -0,0 +1,28 @@
+user = $user;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/GenericUser.php b/vendor/laravel/framework/src/Illuminate/Auth/GenericUser.php
new file mode 100644
index 000000000..b6880c0ca
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/GenericUser.php
@@ -0,0 +1,134 @@
+attributes = $attributes;
+ }
+
+ /**
+ * Get the name of the unique identifier for the user.
+ *
+ * @return string
+ */
+ public function getAuthIdentifierName()
+ {
+ return 'id';
+ }
+
+ /**
+ * Get the unique identifier for the user.
+ *
+ * @return mixed
+ */
+ public function getAuthIdentifier()
+ {
+ $name = $this->getAuthIdentifierName();
+
+ return $this->attributes[$name];
+ }
+
+ /**
+ * Get the password for the user.
+ *
+ * @return string
+ */
+ public function getAuthPassword()
+ {
+ return $this->attributes['password'];
+ }
+
+ /**
+ * Get the "remember me" token value.
+ *
+ * @return string
+ */
+ public function getRememberToken()
+ {
+ return $this->attributes[$this->getRememberTokenName()];
+ }
+
+ /**
+ * Set the "remember me" token value.
+ *
+ * @param string $value
+ * @return void
+ */
+ public function setRememberToken($value)
+ {
+ $this->attributes[$this->getRememberTokenName()] = $value;
+ }
+
+ /**
+ * Get the column name for the "remember me" token.
+ *
+ * @return string
+ */
+ public function getRememberTokenName()
+ {
+ return 'remember_token';
+ }
+
+ /**
+ * Dynamically access the user's attributes.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function __get($key)
+ {
+ return $this->attributes[$key];
+ }
+
+ /**
+ * Dynamically set an attribute on the user.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function __set($key, $value)
+ {
+ $this->attributes[$key] = $value;
+ }
+
+ /**
+ * Dynamically check if a value is set on the user.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function __isset($key)
+ {
+ return isset($this->attributes[$key]);
+ }
+
+ /**
+ * Dynamically unset a value on the user.
+ *
+ * @param string $key
+ * @return void
+ */
+ public function __unset($key)
+ {
+ unset($this->attributes[$key]);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/GuardHelpers.php b/vendor/laravel/framework/src/Illuminate/Auth/GuardHelpers.php
new file mode 100644
index 000000000..5a227964d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/GuardHelpers.php
@@ -0,0 +1,86 @@
+user())) {
+ return $user;
+ }
+
+ throw new AuthenticationException;
+ }
+
+ /**
+ * Determine if the current user is authenticated.
+ *
+ * @return bool
+ */
+ public function check()
+ {
+ return ! is_null($this->user());
+ }
+
+ /**
+ * Determine if the current user is a guest.
+ *
+ * @return bool
+ */
+ public function guest()
+ {
+ return ! $this->check();
+ }
+
+ /**
+ * Get the ID for the currently authenticated user.
+ *
+ * @return int|null
+ */
+ public function id()
+ {
+ if ($this->user()) {
+ return $this->user()->getAuthIdentifier();
+ }
+ }
+
+ /**
+ * Set the current user.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @return $this
+ */
+ public function setUser(AuthenticatableContract $user)
+ {
+ $this->user = $user;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Middleware/Authenticate.php b/vendor/laravel/framework/src/Illuminate/Auth/Middleware/Authenticate.php
new file mode 100644
index 000000000..21ea4b228
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Middleware/Authenticate.php
@@ -0,0 +1,68 @@
+auth = $auth;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @param string[] ...$guards
+ * @return mixed
+ *
+ * @throws \Illuminate\Auth\AuthenticationException
+ */
+ public function handle($request, Closure $next, ...$guards)
+ {
+ $this->authenticate($guards);
+
+ return $next($request);
+ }
+
+ /**
+ * Determine if the user is logged in to any of the given guards.
+ *
+ * @param array $guards
+ * @return void
+ *
+ * @throws \Illuminate\Auth\AuthenticationException
+ */
+ protected function authenticate(array $guards)
+ {
+ if (empty($guards)) {
+ return $this->auth->authenticate();
+ }
+
+ foreach ($guards as $guard) {
+ if ($this->auth->guard($guard)->check()) {
+ return $this->auth->shouldUse($guard);
+ }
+ }
+
+ throw new AuthenticationException('Unauthenticated.', $guards);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Middleware/AuthenticateWithBasicAuth.php b/vendor/laravel/framework/src/Illuminate/Auth/Middleware/AuthenticateWithBasicAuth.php
new file mode 100644
index 000000000..71f8be878
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Middleware/AuthenticateWithBasicAuth.php
@@ -0,0 +1,40 @@
+auth = $auth;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @param string|null $guard
+ * @return mixed
+ */
+ public function handle($request, Closure $next, $guard = null)
+ {
+ return $this->auth->guard($guard)->basic() ?: $next($request);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Middleware/Authorize.php b/vendor/laravel/framework/src/Illuminate/Auth/Middleware/Authorize.php
new file mode 100644
index 000000000..9220e5841
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Middleware/Authorize.php
@@ -0,0 +1,100 @@
+auth = $auth;
+ $this->gate = $gate;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @param string $ability
+ * @param array|null $models
+ * @return mixed
+ *
+ * @throws \Illuminate\Auth\AuthenticationException
+ * @throws \Illuminate\Auth\Access\AuthorizationException
+ */
+ public function handle($request, Closure $next, $ability, ...$models)
+ {
+ $this->auth->authenticate();
+
+ $this->gate->authorize($ability, $this->getGateArguments($request, $models));
+
+ return $next($request);
+ }
+
+ /**
+ * Get the arguments parameter for the gate.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param array|null $models
+ * @return array|string|\Illuminate\Database\Eloquent\Model
+ */
+ protected function getGateArguments($request, $models)
+ {
+ if (is_null($models)) {
+ return [];
+ }
+
+ return collect($models)->map(function ($model) use ($request) {
+ return $model instanceof Model ? $model : $this->getModel($request, $model);
+ })->all();
+ }
+
+ /**
+ * Get the model to authorize.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param string $model
+ * @return string|\Illuminate\Database\Eloquent\Model
+ */
+ protected function getModel($request, $model)
+ {
+ return $this->isClassName($model) ? $model : $request->route($model);
+ }
+
+ /**
+ * Checks if the given string looks like a fully qualified class name.
+ *
+ * @param string $value
+ * @return bool
+ */
+ protected function isClassName($value)
+ {
+ return strpos($value, '\\') !== false;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Notifications/ResetPassword.php b/vendor/laravel/framework/src/Illuminate/Auth/Notifications/ResetPassword.php
new file mode 100644
index 000000000..cd1ca8661
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Notifications/ResetPassword.php
@@ -0,0 +1,52 @@
+token = $token;
+ }
+
+ /**
+ * Get the notification's channels.
+ *
+ * @param mixed $notifiable
+ * @return array|string
+ */
+ public function via($notifiable)
+ {
+ return ['mail'];
+ }
+
+ /**
+ * Build the mail representation of the notification.
+ *
+ * @param mixed $notifiable
+ * @return \Illuminate\Notifications\Messages\MailMessage
+ */
+ public function toMail($notifiable)
+ {
+ return (new MailMessage)
+ ->line('You are receiving this email because we received a password reset request for your account.')
+ ->action('Reset Password', url(config('app.url').route('password.reset', $this->token, false)))
+ ->line('If you did not request a password reset, no further action is required.');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Passwords/CanResetPassword.php b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/CanResetPassword.php
new file mode 100644
index 000000000..918a288fe
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/CanResetPassword.php
@@ -0,0 +1,29 @@
+email;
+ }
+
+ /**
+ * Send the password reset notification.
+ *
+ * @param string $token
+ * @return void
+ */
+ public function sendPasswordResetNotification($token)
+ {
+ $this->notify(new ResetPasswordNotification($token));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Passwords/DatabaseTokenRepository.php b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/DatabaseTokenRepository.php
new file mode 100644
index 000000000..aff32ca17
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/DatabaseTokenRepository.php
@@ -0,0 +1,204 @@
+table = $table;
+ $this->hasher = $hasher;
+ $this->hashKey = $hashKey;
+ $this->expires = $expires * 60;
+ $this->connection = $connection;
+ }
+
+ /**
+ * Create a new token record.
+ *
+ * @param \Illuminate\Contracts\Auth\CanResetPassword $user
+ * @return string
+ */
+ public function create(CanResetPasswordContract $user)
+ {
+ $email = $user->getEmailForPasswordReset();
+
+ $this->deleteExisting($user);
+
+ // We will create a new, random token for the user so that we can e-mail them
+ // a safe link to the password reset form. Then we will insert a record in
+ // the database so that we can verify the token within the actual reset.
+ $token = $this->createNewToken();
+
+ $this->getTable()->insert($this->getPayload($email, $token));
+
+ return $token;
+ }
+
+ /**
+ * Delete all existing reset tokens from the database.
+ *
+ * @param \Illuminate\Contracts\Auth\CanResetPassword $user
+ * @return int
+ */
+ protected function deleteExisting(CanResetPasswordContract $user)
+ {
+ return $this->getTable()->where('email', $user->getEmailForPasswordReset())->delete();
+ }
+
+ /**
+ * Build the record payload for the table.
+ *
+ * @param string $email
+ * @param string $token
+ * @return array
+ */
+ protected function getPayload($email, $token)
+ {
+ return ['email' => $email, 'token' => $this->hasher->make($token), 'created_at' => new Carbon];
+ }
+
+ /**
+ * Determine if a token record exists and is valid.
+ *
+ * @param \Illuminate\Contracts\Auth\CanResetPassword $user
+ * @param string $token
+ * @return bool
+ */
+ public function exists(CanResetPasswordContract $user, $token)
+ {
+ $record = (array) $this->getTable()->where(
+ 'email', $user->getEmailForPasswordReset()
+ )->first();
+
+ return $record &&
+ ! $this->tokenExpired($record['created_at']) &&
+ $this->hasher->check($token, $record['token']);
+ }
+
+ /**
+ * Determine if the token has expired.
+ *
+ * @param string $createdAt
+ * @return bool
+ */
+ protected function tokenExpired($createdAt)
+ {
+ return Carbon::parse($createdAt)->addSeconds($this->expires)->isPast();
+ }
+
+ /**
+ * Delete a token record by user.
+ *
+ * @param \Illuminate\Contracts\Auth\CanResetPassword $user
+ * @return void
+ */
+ public function delete(CanResetPasswordContract $user)
+ {
+ $this->deleteExisting($user);
+ }
+
+ /**
+ * Delete expired tokens.
+ *
+ * @return void
+ */
+ public function deleteExpired()
+ {
+ $expiredAt = Carbon::now()->subSeconds($this->expires);
+
+ $this->getTable()->where('created_at', '<', $expiredAt)->delete();
+ }
+
+ /**
+ * Create a new token for the user.
+ *
+ * @return string
+ */
+ public function createNewToken()
+ {
+ return hash_hmac('sha256', Str::random(40), $this->hashKey);
+ }
+
+ /**
+ * Get the database connection instance.
+ *
+ * @return \Illuminate\Database\ConnectionInterface
+ */
+ public function getConnection()
+ {
+ return $this->connection;
+ }
+
+ /**
+ * Begin a new database query against the table.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ protected function getTable()
+ {
+ return $this->connection->table($this->table);
+ }
+
+ /**
+ * Get the hasher instance.
+ *
+ * @return \Illuminate\Contracts\Hashing\Hasher
+ */
+ public function getHasher()
+ {
+ return $this->hasher;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBroker.php b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBroker.php
new file mode 100644
index 000000000..e93540966
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBroker.php
@@ -0,0 +1,242 @@
+users = $users;
+ $this->tokens = $tokens;
+ }
+
+ /**
+ * Send a password reset link to a user.
+ *
+ * @param array $credentials
+ * @return string
+ */
+ public function sendResetLink(array $credentials)
+ {
+ // First we will check to see if we found a user at the given credentials and
+ // if we did not we will redirect back to this current URI with a piece of
+ // "flash" data in the session to indicate to the developers the errors.
+ $user = $this->getUser($credentials);
+
+ if (is_null($user)) {
+ return static::INVALID_USER;
+ }
+
+ // Once we have the reset token, we are ready to send the message out to this
+ // user with a link to reset their password. We will then redirect back to
+ // the current URI having nothing set in the session to indicate errors.
+ $user->sendPasswordResetNotification(
+ $this->tokens->create($user)
+ );
+
+ return static::RESET_LINK_SENT;
+ }
+
+ /**
+ * Reset the password for the given token.
+ *
+ * @param array $credentials
+ * @param \Closure $callback
+ * @return mixed
+ */
+ public function reset(array $credentials, Closure $callback)
+ {
+ // If the responses from the validate method is not a user instance, we will
+ // assume that it is a redirect and simply return it from this method and
+ // the user is properly redirected having an error message on the post.
+ $user = $this->validateReset($credentials);
+
+ if (! $user instanceof CanResetPasswordContract) {
+ return $user;
+ }
+
+ $password = $credentials['password'];
+
+ // Once the reset has been validated, we'll call the given callback with the
+ // new password. This gives the user an opportunity to store the password
+ // in their persistent storage. Then we'll delete the token and return.
+ $callback($user, $password);
+
+ $this->tokens->delete($user);
+
+ return static::PASSWORD_RESET;
+ }
+
+ /**
+ * Validate a password reset for the given credentials.
+ *
+ * @param array $credentials
+ * @return \Illuminate\Contracts\Auth\CanResetPassword
+ */
+ protected function validateReset(array $credentials)
+ {
+ if (is_null($user = $this->getUser($credentials))) {
+ return static::INVALID_USER;
+ }
+
+ if (! $this->validateNewPassword($credentials)) {
+ return static::INVALID_PASSWORD;
+ }
+
+ if (! $this->tokens->exists($user, $credentials['token'])) {
+ return static::INVALID_TOKEN;
+ }
+
+ return $user;
+ }
+
+ /**
+ * Set a custom password validator.
+ *
+ * @param \Closure $callback
+ * @return void
+ */
+ public function validator(Closure $callback)
+ {
+ $this->passwordValidator = $callback;
+ }
+
+ /**
+ * Determine if the passwords match for the request.
+ *
+ * @param array $credentials
+ * @return bool
+ */
+ public function validateNewPassword(array $credentials)
+ {
+ if (isset($this->passwordValidator)) {
+ list($password, $confirm) = [
+ $credentials['password'],
+ $credentials['password_confirmation'],
+ ];
+
+ return call_user_func(
+ $this->passwordValidator, $credentials
+ ) && $password === $confirm;
+ }
+
+ return $this->validatePasswordWithDefaults($credentials);
+ }
+
+ /**
+ * Determine if the passwords are valid for the request.
+ *
+ * @param array $credentials
+ * @return bool
+ */
+ protected function validatePasswordWithDefaults(array $credentials)
+ {
+ list($password, $confirm) = [
+ $credentials['password'],
+ $credentials['password_confirmation'],
+ ];
+
+ return $password === $confirm && mb_strlen($password) >= 6;
+ }
+
+ /**
+ * Get the user for the given credentials.
+ *
+ * @param array $credentials
+ * @return \Illuminate\Contracts\Auth\CanResetPassword
+ *
+ * @throws \UnexpectedValueException
+ */
+ public function getUser(array $credentials)
+ {
+ $credentials = Arr::except($credentials, ['token']);
+
+ $user = $this->users->retrieveByCredentials($credentials);
+
+ if ($user && ! $user instanceof CanResetPasswordContract) {
+ throw new UnexpectedValueException('User must implement CanResetPassword interface.');
+ }
+
+ return $user;
+ }
+
+ /**
+ * Create a new password reset token for the given user.
+ *
+ * @param CanResetPasswordContract $user
+ * @return string
+ */
+ public function createToken(CanResetPasswordContract $user)
+ {
+ return $this->tokens->create($user);
+ }
+
+ /**
+ * Delete password reset tokens of the given user.
+ *
+ * @param \Illuminate\Contracts\Auth\CanResetPassword $user
+ * @return void
+ */
+ public function deleteToken(CanResetPasswordContract $user)
+ {
+ $this->tokens->delete($user);
+ }
+
+ /**
+ * Validate the given password reset token.
+ *
+ * @param CanResetPasswordContract $user
+ * @param string $token
+ * @return bool
+ */
+ public function tokenExists(CanResetPasswordContract $user, $token)
+ {
+ return $this->tokens->exists($user, $token);
+ }
+
+ /**
+ * Get the password reset token repository implementation.
+ *
+ * @return \Illuminate\Auth\Passwords\TokenRepositoryInterface
+ */
+ public function getRepository()
+ {
+ return $this->tokens;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBrokerManager.php b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBrokerManager.php
new file mode 100644
index 000000000..1a9498f48
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordBrokerManager.php
@@ -0,0 +1,147 @@
+app = $app;
+ }
+
+ /**
+ * Attempt to get the broker from the local cache.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Auth\PasswordBroker
+ */
+ public function broker($name = null)
+ {
+ $name = $name ?: $this->getDefaultDriver();
+
+ return isset($this->brokers[$name])
+ ? $this->brokers[$name]
+ : $this->brokers[$name] = $this->resolve($name);
+ }
+
+ /**
+ * Resolve the given broker.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Auth\PasswordBroker
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function resolve($name)
+ {
+ $config = $this->getConfig($name);
+
+ if (is_null($config)) {
+ throw new InvalidArgumentException("Password resetter [{$name}] is not defined.");
+ }
+
+ // The password broker uses a token repository to validate tokens and send user
+ // password e-mails, as well as validating that password reset process as an
+ // aggregate service of sorts providing a convenient interface for resets.
+ return new PasswordBroker(
+ $this->createTokenRepository($config),
+ $this->app['auth']->createUserProvider($config['provider'])
+ );
+ }
+
+ /**
+ * Create a token repository instance based on the given configuration.
+ *
+ * @param array $config
+ * @return \Illuminate\Auth\Passwords\TokenRepositoryInterface
+ */
+ protected function createTokenRepository(array $config)
+ {
+ $key = $this->app['config']['app.key'];
+
+ if (Str::startsWith($key, 'base64:')) {
+ $key = base64_decode(substr($key, 7));
+ }
+
+ $connection = isset($config['connection']) ? $config['connection'] : null;
+
+ return new DatabaseTokenRepository(
+ $this->app['db']->connection($connection),
+ $this->app['hash'],
+ $config['table'],
+ $key,
+ $config['expire']
+ );
+ }
+
+ /**
+ * Get the password broker configuration.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function getConfig($name)
+ {
+ return $this->app['config']["auth.passwords.{$name}"];
+ }
+
+ /**
+ * Get the default password broker name.
+ *
+ * @return string
+ */
+ public function getDefaultDriver()
+ {
+ return $this->app['config']['auth.defaults.passwords'];
+ }
+
+ /**
+ * Set the default password broker name.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setDefaultDriver($name)
+ {
+ $this->app['config']['auth.defaults.passwords'] = $name;
+ }
+
+ /**
+ * Dynamically call the default driver instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->broker()->{$method}(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordResetServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordResetServiceProvider.php
new file mode 100644
index 000000000..165ecaf9f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/PasswordResetServiceProvider.php
@@ -0,0 +1,51 @@
+registerPasswordBroker();
+ }
+
+ /**
+ * Register the password broker instance.
+ *
+ * @return void
+ */
+ protected function registerPasswordBroker()
+ {
+ $this->app->singleton('auth.password', function ($app) {
+ return new PasswordBrokerManager($app);
+ });
+
+ $this->app->bind('auth.password.broker', function ($app) {
+ return $app->make('auth.password')->broker();
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return ['auth.password', 'auth.password.broker'];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/Passwords/TokenRepositoryInterface.php b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/TokenRepositoryInterface.php
new file mode 100644
index 000000000..dcd06e8d6
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/Passwords/TokenRepositoryInterface.php
@@ -0,0 +1,40 @@
+recaller = $recaller;
+ }
+
+ /**
+ * Get the user ID from the recaller.
+ *
+ * @return string
+ */
+ public function id()
+ {
+ return explode('|', $this->recaller, 2)[0];
+ }
+
+ /**
+ * Get the "remember token" token from the recaller.
+ *
+ * @return string
+ */
+ public function token()
+ {
+ return explode('|', $this->recaller, 2)[1];
+ }
+
+ /**
+ * Determine if the recaller is valid.
+ *
+ * @return bool
+ */
+ public function valid()
+ {
+ return $this->properString() && $this->hasBothSegments();
+ }
+
+ /**
+ * Determine if the recaller is an invalid string.
+ *
+ * @return bool
+ */
+ protected function properString()
+ {
+ return is_string($this->recaller) && Str::contains($this->recaller, '|');
+ }
+
+ /**
+ * Determine if the recaller has both segments.
+ *
+ * @return bool
+ */
+ protected function hasBothSegments()
+ {
+ $segments = explode('|', $this->recaller);
+
+ return count($segments) == 2 && trim($segments[0]) !== '' && trim($segments[1]) !== '';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/RequestGuard.php b/vendor/laravel/framework/src/Illuminate/Auth/RequestGuard.php
new file mode 100644
index 000000000..d1a18c0f6
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/RequestGuard.php
@@ -0,0 +1,84 @@
+request = $request;
+ $this->callback = $callback;
+ }
+
+ /**
+ * Get the currently authenticated user.
+ *
+ * @return \Illuminate\Contracts\Auth\Authenticatable|null
+ */
+ public function user()
+ {
+ // If we've already retrieved the user for the current request we can just
+ // return it back immediately. We do not want to fetch the user data on
+ // every call to this method because that would be tremendously slow.
+ if (! is_null($this->user)) {
+ return $this->user;
+ }
+
+ return $this->user = call_user_func(
+ $this->callback, $this->request
+ );
+ }
+
+ /**
+ * Validate a user's credentials.
+ *
+ * @param array $credentials
+ * @return bool
+ */
+ public function validate(array $credentials = [])
+ {
+ return ! is_null((new static(
+ $this->callback, $credentials['request']
+ ))->user());
+ }
+
+ /**
+ * Set the current request instance.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return $this
+ */
+ public function setRequest(Request $request)
+ {
+ $this->request = $request;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/SessionGuard.php b/vendor/laravel/framework/src/Illuminate/Auth/SessionGuard.php
new file mode 100644
index 000000000..39d71669f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/SessionGuard.php
@@ -0,0 +1,775 @@
+name = $name;
+ $this->session = $session;
+ $this->request = $request;
+ $this->provider = $provider;
+ }
+
+ /**
+ * Get the currently authenticated user.
+ *
+ * @return \Illuminate\Contracts\Auth\Authenticatable|null
+ */
+ public function user()
+ {
+ if ($this->loggedOut) {
+ return;
+ }
+
+ // If we've already retrieved the user for the current request we can just
+ // return it back immediately. We do not want to fetch the user data on
+ // every call to this method because that would be tremendously slow.
+ if (! is_null($this->user)) {
+ return $this->user;
+ }
+
+ $id = $this->session->get($this->getName());
+
+ // First we will try to load the user using the identifier in the session if
+ // one exists. Otherwise we will check for a "remember me" cookie in this
+ // request, and if one exists, attempt to retrieve the user using that.
+ $user = null;
+
+ if (! is_null($id)) {
+ if ($user = $this->provider->retrieveById($id)) {
+ $this->fireAuthenticatedEvent($user);
+ }
+ }
+
+ // If the user is null, but we decrypt a "recaller" cookie we can attempt to
+ // pull the user data on that cookie which serves as a remember cookie on
+ // the application. Once we have a user we can return it to the caller.
+ $recaller = $this->recaller();
+
+ if (is_null($user) && ! is_null($recaller)) {
+ $user = $this->userFromRecaller($recaller);
+
+ if ($user) {
+ $this->updateSession($user->getAuthIdentifier());
+
+ $this->fireLoginEvent($user, true);
+ }
+ }
+
+ return $this->user = $user;
+ }
+
+ /**
+ * Pull a user from the repository by its "remember me" cookie token.
+ *
+ * @param \Illuminate\Auth\Recaller $recaller
+ * @return mixed
+ */
+ protected function userFromRecaller($recaller)
+ {
+ if (! $recaller->valid() || $this->recallAttempted) {
+ return;
+ }
+
+ // If the user is null, but we decrypt a "recaller" cookie we can attempt to
+ // pull the user data on that cookie which serves as a remember cookie on
+ // the application. Once we have a user we can return it to the caller.
+ $this->recallAttempted = true;
+
+ $this->viaRemember = ! is_null($user = $this->provider->retrieveByToken(
+ $recaller->id(), $recaller->token()
+ ));
+
+ return $user;
+ }
+
+ /**
+ * Get the decrypted recaller cookie for the request.
+ *
+ * @return \Illuminate\Auth\Recaller|null
+ */
+ protected function recaller()
+ {
+ if (is_null($this->request)) {
+ return;
+ }
+
+ if ($recaller = $this->request->cookies->get($this->getRecallerName())) {
+ return new Recaller($recaller);
+ }
+ }
+
+ /**
+ * Get the ID for the currently authenticated user.
+ *
+ * @return int|null
+ */
+ public function id()
+ {
+ if ($this->loggedOut) {
+ return;
+ }
+
+ return $this->user()
+ ? $this->user()->getAuthIdentifier()
+ : $this->session->get($this->getName());
+ }
+
+ /**
+ * Log a user into the application without sessions or cookies.
+ *
+ * @param array $credentials
+ * @return bool
+ */
+ public function once(array $credentials = [])
+ {
+ $this->fireAttemptEvent($credentials);
+
+ if ($this->validate($credentials)) {
+ $this->setUser($this->lastAttempted);
+
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * Log the given user ID into the application without sessions or cookies.
+ *
+ * @param mixed $id
+ * @return \Illuminate\Contracts\Auth\Authenticatable|false
+ */
+ public function onceUsingId($id)
+ {
+ if (! is_null($user = $this->provider->retrieveById($id))) {
+ $this->setUser($user);
+
+ return $user;
+ }
+
+ return false;
+ }
+
+ /**
+ * Validate a user's credentials.
+ *
+ * @param array $credentials
+ * @return bool
+ */
+ public function validate(array $credentials = [])
+ {
+ $this->lastAttempted = $user = $this->provider->retrieveByCredentials($credentials);
+
+ return $this->hasValidCredentials($user, $credentials);
+ }
+
+ /**
+ * Attempt to authenticate using HTTP Basic Auth.
+ *
+ * @param string $field
+ * @param array $extraConditions
+ * @return \Symfony\Component\HttpFoundation\Response|null
+ */
+ public function basic($field = 'email', $extraConditions = [])
+ {
+ if ($this->check()) {
+ return;
+ }
+
+ // If a username is set on the HTTP basic request, we will return out without
+ // interrupting the request lifecycle. Otherwise, we'll need to generate a
+ // request indicating that the given credentials were invalid for login.
+ if ($this->attemptBasic($this->getRequest(), $field, $extraConditions)) {
+ return;
+ }
+
+ return $this->failedBasicResponse();
+ }
+
+ /**
+ * Perform a stateless HTTP Basic login attempt.
+ *
+ * @param string $field
+ * @param array $extraConditions
+ * @return \Symfony\Component\HttpFoundation\Response|null
+ */
+ public function onceBasic($field = 'email', $extraConditions = [])
+ {
+ $credentials = $this->basicCredentials($this->getRequest(), $field);
+
+ if (! $this->once(array_merge($credentials, $extraConditions))) {
+ return $this->failedBasicResponse();
+ }
+ }
+
+ /**
+ * Attempt to authenticate using basic authentication.
+ *
+ * @param \Symfony\Component\HttpFoundation\Request $request
+ * @param string $field
+ * @param array $extraConditions
+ * @return bool
+ */
+ protected function attemptBasic(Request $request, $field, $extraConditions = [])
+ {
+ if (! $request->getUser()) {
+ return false;
+ }
+
+ return $this->attempt(array_merge(
+ $this->basicCredentials($request, $field), $extraConditions
+ ));
+ }
+
+ /**
+ * Get the credential array for a HTTP Basic request.
+ *
+ * @param \Symfony\Component\HttpFoundation\Request $request
+ * @param string $field
+ * @return array
+ */
+ protected function basicCredentials(Request $request, $field)
+ {
+ return [$field => $request->getUser(), 'password' => $request->getPassword()];
+ }
+
+ /**
+ * Get the response for basic authentication.
+ *
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function failedBasicResponse()
+ {
+ return new Response('Invalid credentials.', 401, ['WWW-Authenticate' => 'Basic']);
+ }
+
+ /**
+ * Attempt to authenticate a user using the given credentials.
+ *
+ * @param array $credentials
+ * @param bool $remember
+ * @return bool
+ */
+ public function attempt(array $credentials = [], $remember = false)
+ {
+ $this->fireAttemptEvent($credentials, $remember);
+
+ $this->lastAttempted = $user = $this->provider->retrieveByCredentials($credentials);
+
+ // If an implementation of UserInterface was returned, we'll ask the provider
+ // to validate the user against the given credentials, and if they are in
+ // fact valid we'll log the users into the application and return true.
+ if ($this->hasValidCredentials($user, $credentials)) {
+ $this->login($user, $remember);
+
+ return true;
+ }
+
+ // If the authentication attempt fails we will fire an event so that the user
+ // may be notified of any suspicious attempts to access their account from
+ // an unrecognized user. A developer may listen to this event as needed.
+ $this->fireFailedEvent($user, $credentials);
+
+ return false;
+ }
+
+ /**
+ * Determine if the user matches the credentials.
+ *
+ * @param mixed $user
+ * @param array $credentials
+ * @return bool
+ */
+ protected function hasValidCredentials($user, $credentials)
+ {
+ return ! is_null($user) && $this->provider->validateCredentials($user, $credentials);
+ }
+
+ /**
+ * Log the given user ID into the application.
+ *
+ * @param mixed $id
+ * @param bool $remember
+ * @return \Illuminate\Contracts\Auth\Authenticatable|false
+ */
+ public function loginUsingId($id, $remember = false)
+ {
+ if (! is_null($user = $this->provider->retrieveById($id))) {
+ $this->login($user, $remember);
+
+ return $user;
+ }
+
+ return false;
+ }
+
+ /**
+ * Log a user into the application.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param bool $remember
+ * @return void
+ */
+ public function login(AuthenticatableContract $user, $remember = false)
+ {
+ $this->updateSession($user->getAuthIdentifier());
+
+ // If the user should be permanently "remembered" by the application we will
+ // queue a permanent cookie that contains the encrypted copy of the user
+ // identifier. We will then decrypt this later to retrieve the users.
+ if ($remember) {
+ $this->ensureRememberTokenIsSet($user);
+
+ $this->queueRecallerCookie($user);
+ }
+
+ // If we have an event dispatcher instance set we will fire an event so that
+ // any listeners will hook into the authentication events and run actions
+ // based on the login and logout events fired from the guard instances.
+ $this->fireLoginEvent($user, $remember);
+
+ $this->setUser($user);
+ }
+
+ /**
+ * Update the session with the given ID.
+ *
+ * @param string $id
+ * @return void
+ */
+ protected function updateSession($id)
+ {
+ $this->session->put($this->getName(), $id);
+
+ $this->session->migrate(true);
+ }
+
+ /**
+ * Create a new "remember me" token for the user if one doesn't already exist.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @return void
+ */
+ protected function ensureRememberTokenIsSet(AuthenticatableContract $user)
+ {
+ if (empty($user->getRememberToken())) {
+ $this->cycleRememberToken($user);
+ }
+ }
+
+ /**
+ * Queue the recaller cookie into the cookie jar.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @return void
+ */
+ protected function queueRecallerCookie(AuthenticatableContract $user)
+ {
+ $this->getCookieJar()->queue($this->createRecaller(
+ $user->getAuthIdentifier().'|'.$user->getRememberToken()
+ ));
+ }
+
+ /**
+ * Create a "remember me" cookie for a given ID.
+ *
+ * @param string $value
+ * @return \Symfony\Component\HttpFoundation\Cookie
+ */
+ protected function createRecaller($value)
+ {
+ return $this->getCookieJar()->forever($this->getRecallerName(), $value);
+ }
+
+ /**
+ * Log the user out of the application.
+ *
+ * @return void
+ */
+ public function logout()
+ {
+ $user = $this->user();
+
+ // If we have an event dispatcher instance, we can fire off the logout event
+ // so any further processing can be done. This allows the developer to be
+ // listening for anytime a user signs out of this application manually.
+ $this->clearUserDataFromStorage();
+
+ if (! is_null($this->user)) {
+ $this->cycleRememberToken($user);
+ }
+
+ if (isset($this->events)) {
+ $this->events->dispatch(new Events\Logout($user));
+ }
+
+ // Once we have fired the logout event we will clear the users out of memory
+ // so they are no longer available as the user is no longer considered as
+ // being signed into this application and should not be available here.
+ $this->user = null;
+
+ $this->loggedOut = true;
+ }
+
+ /**
+ * Remove the user data from the session and cookies.
+ *
+ * @return void
+ */
+ protected function clearUserDataFromStorage()
+ {
+ $this->session->remove($this->getName());
+
+ if (! is_null($this->recaller())) {
+ $this->getCookieJar()->queue($this->getCookieJar()
+ ->forget($this->getRecallerName()));
+ }
+ }
+
+ /**
+ * Refresh the "remember me" token for the user.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @return void
+ */
+ protected function cycleRememberToken(AuthenticatableContract $user)
+ {
+ $user->setRememberToken($token = Str::random(60));
+
+ $this->provider->updateRememberToken($user, $token);
+ }
+
+ /**
+ * Register an authentication attempt event listener.
+ *
+ * @param mixed $callback
+ * @return void
+ */
+ public function attempting($callback)
+ {
+ if (isset($this->events)) {
+ $this->events->listen(Events\Attempting::class, $callback);
+ }
+ }
+
+ /**
+ * Fire the attempt event with the arguments.
+ *
+ * @param array $credentials
+ * @param bool $remember
+ * @return void
+ */
+ protected function fireAttemptEvent(array $credentials, $remember = false)
+ {
+ if (isset($this->events)) {
+ $this->events->dispatch(new Events\Attempting(
+ $credentials, $remember
+ ));
+ }
+ }
+
+ /**
+ * Fire the login event if the dispatcher is set.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param bool $remember
+ * @return void
+ */
+ protected function fireLoginEvent($user, $remember = false)
+ {
+ if (isset($this->events)) {
+ $this->events->dispatch(new Events\Login($user, $remember));
+ }
+ }
+
+ /**
+ * Fire the authenticated event if the dispatcher is set.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @return void
+ */
+ protected function fireAuthenticatedEvent($user)
+ {
+ if (isset($this->events)) {
+ $this->events->dispatch(new Events\Authenticated($user));
+ }
+ }
+
+ /**
+ * Fire the failed authentication attempt event with the given arguments.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable|null $user
+ * @param array $credentials
+ * @return void
+ */
+ protected function fireFailedEvent($user, array $credentials)
+ {
+ if (isset($this->events)) {
+ $this->events->dispatch(new Events\Failed($user, $credentials));
+ }
+ }
+
+ /**
+ * Get the last user we attempted to authenticate.
+ *
+ * @return \Illuminate\Contracts\Auth\Authenticatable
+ */
+ public function getLastAttempted()
+ {
+ return $this->lastAttempted;
+ }
+
+ /**
+ * Get a unique identifier for the auth session value.
+ *
+ * @return string
+ */
+ public function getName()
+ {
+ return 'login_'.$this->name.'_'.sha1(static::class);
+ }
+
+ /**
+ * Get the name of the cookie used to store the "recaller".
+ *
+ * @return string
+ */
+ public function getRecallerName()
+ {
+ return 'remember_'.$this->name.'_'.sha1(static::class);
+ }
+
+ /**
+ * Determine if the user was authenticated via "remember me" cookie.
+ *
+ * @return bool
+ */
+ public function viaRemember()
+ {
+ return $this->viaRemember;
+ }
+
+ /**
+ * Get the cookie creator instance used by the guard.
+ *
+ * @return \Illuminate\Contracts\Cookie\QueueingFactory
+ *
+ * @throws \RuntimeException
+ */
+ public function getCookieJar()
+ {
+ if (! isset($this->cookie)) {
+ throw new RuntimeException('Cookie jar has not been set.');
+ }
+
+ return $this->cookie;
+ }
+
+ /**
+ * Set the cookie creator instance used by the guard.
+ *
+ * @param \Illuminate\Contracts\Cookie\QueueingFactory $cookie
+ * @return void
+ */
+ public function setCookieJar(CookieJar $cookie)
+ {
+ $this->cookie = $cookie;
+ }
+
+ /**
+ * Get the event dispatcher instance.
+ *
+ * @return \Illuminate\Contracts\Events\Dispatcher
+ */
+ public function getDispatcher()
+ {
+ return $this->events;
+ }
+
+ /**
+ * Set the event dispatcher instance.
+ *
+ * @param \Illuminate\Contracts\Events\Dispatcher $events
+ * @return void
+ */
+ public function setDispatcher(Dispatcher $events)
+ {
+ $this->events = $events;
+ }
+
+ /**
+ * Get the session store used by the guard.
+ *
+ * @return \Illuminate\Session\Store
+ */
+ public function getSession()
+ {
+ return $this->session;
+ }
+
+ /**
+ * Get the user provider used by the guard.
+ *
+ * @return \Illuminate\Contracts\Auth\UserProvider
+ */
+ public function getProvider()
+ {
+ return $this->provider;
+ }
+
+ /**
+ * Set the user provider used by the guard.
+ *
+ * @param \Illuminate\Contracts\Auth\UserProvider $provider
+ * @return void
+ */
+ public function setProvider(UserProvider $provider)
+ {
+ $this->provider = $provider;
+ }
+
+ /**
+ * Return the currently cached user.
+ *
+ * @return \Illuminate\Contracts\Auth\Authenticatable|null
+ */
+ public function getUser()
+ {
+ return $this->user;
+ }
+
+ /**
+ * Set the current user.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @return $this
+ */
+ public function setUser(AuthenticatableContract $user)
+ {
+ $this->user = $user;
+
+ $this->loggedOut = false;
+
+ $this->fireAuthenticatedEvent($user);
+
+ return $this;
+ }
+
+ /**
+ * Get the current request instance.
+ *
+ * @return \Symfony\Component\HttpFoundation\Request
+ */
+ public function getRequest()
+ {
+ return $this->request ?: Request::createFromGlobals();
+ }
+
+ /**
+ * Set the current request instance.
+ *
+ * @param \Symfony\Component\HttpFoundation\Request $request
+ * @return $this
+ */
+ public function setRequest(Request $request)
+ {
+ $this->request = $request;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/TokenGuard.php b/vendor/laravel/framework/src/Illuminate/Auth/TokenGuard.php
new file mode 100644
index 000000000..dec39f432
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/TokenGuard.php
@@ -0,0 +1,133 @@
+request = $request;
+ $this->provider = $provider;
+ $this->inputKey = 'api_token';
+ $this->storageKey = 'api_token';
+ }
+
+ /**
+ * Get the currently authenticated user.
+ *
+ * @return \Illuminate\Contracts\Auth\Authenticatable|null
+ */
+ public function user()
+ {
+ // If we've already retrieved the user for the current request we can just
+ // return it back immediately. We do not want to fetch the user data on
+ // every call to this method because that would be tremendously slow.
+ if (! is_null($this->user)) {
+ return $this->user;
+ }
+
+ $user = null;
+
+ $token = $this->getTokenForRequest();
+
+ if (! empty($token)) {
+ $user = $this->provider->retrieveByCredentials(
+ [$this->storageKey => $token]
+ );
+ }
+
+ return $this->user = $user;
+ }
+
+ /**
+ * Get the token for the current request.
+ *
+ * @return string
+ */
+ public function getTokenForRequest()
+ {
+ $token = $this->request->query($this->inputKey);
+
+ if (empty($token)) {
+ $token = $this->request->input($this->inputKey);
+ }
+
+ if (empty($token)) {
+ $token = $this->request->bearerToken();
+ }
+
+ if (empty($token)) {
+ $token = $this->request->getPassword();
+ }
+
+ return $token;
+ }
+
+ /**
+ * Validate a user's credentials.
+ *
+ * @param array $credentials
+ * @return bool
+ */
+ public function validate(array $credentials = [])
+ {
+ if (empty($credentials[$this->inputKey])) {
+ return false;
+ }
+
+ $credentials = [$this->storageKey => $credentials[$this->inputKey]];
+
+ if ($this->provider->retrieveByCredentials($credentials)) {
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * Set the current request instance.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return $this
+ */
+ public function setRequest(Request $request)
+ {
+ $this->request = $request;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Auth/composer.json b/vendor/laravel/framework/src/Illuminate/Auth/composer.json
new file mode 100644
index 000000000..54525eb34
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Auth/composer.json
@@ -0,0 +1,43 @@
+{
+ "name": "illuminate/auth",
+ "description": "The Illuminate Auth package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/http": "5.4.*",
+ "illuminate/queue": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "nesbot/carbon": "~1.20"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Auth\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "illuminate/console": "Required to use the auth:clear-resets command (5.4.*).",
+ "illuminate/queue": "Required to fire login / logout events (5.4.*).",
+ "illuminate/session": "Required to use the session based guard (5.4.*)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastController.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastController.php
new file mode 100644
index 000000000..f71c92377
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastController.php
@@ -0,0 +1,21 @@
+event = $event;
+ }
+
+ /**
+ * Handle the queued job.
+ *
+ * @param \Illuminate\Contracts\Broadcasting\Broadcaster $broadcaster
+ * @return void
+ */
+ public function handle(Broadcaster $broadcaster)
+ {
+ $name = method_exists($this->event, 'broadcastAs')
+ ? $this->event->broadcastAs() : get_class($this->event);
+
+ $broadcaster->broadcast(
+ array_wrap($this->event->broadcastOn()), $name,
+ $this->getPayloadFromEvent($this->event)
+ );
+ }
+
+ /**
+ * Get the payload for the given event.
+ *
+ * @param mixed $event
+ * @return array
+ */
+ protected function getPayloadFromEvent($event)
+ {
+ if (method_exists($event, 'broadcastWith')) {
+ return array_merge(
+ $event->broadcastWith(), ['socket' => data_get($event, 'socket')]
+ );
+ }
+
+ $payload = [];
+
+ foreach ((new ReflectionClass($event))->getProperties(ReflectionProperty::IS_PUBLIC) as $property) {
+ $payload[$property->getName()] = $this->formatProperty($property->getValue($event));
+ }
+
+ unset($payload['broadcastQueue']);
+
+ return $payload;
+ }
+
+ /**
+ * Format the given value for a property.
+ *
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function formatProperty($value)
+ {
+ if ($value instanceof Arrayable) {
+ return $value->toArray();
+ }
+
+ return $value;
+ }
+
+ /**
+ * Get the display name for the queued job.
+ *
+ * @return string
+ */
+ public function displayName()
+ {
+ return get_class($this->event);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastException.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastException.php
new file mode 100644
index 000000000..8fd55f7cc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastException.php
@@ -0,0 +1,10 @@
+app = $app;
+ }
+
+ /**
+ * Register the routes for handling broadcast authentication and sockets.
+ *
+ * @param array|null $attributes
+ * @return void
+ */
+ public function routes(array $attributes = null)
+ {
+ if ($this->app->routesAreCached()) {
+ return;
+ }
+
+ $attributes = $attributes ?: ['middleware' => ['web']];
+
+ $this->app['router']->group($attributes, function ($router) {
+ $router->post('/broadcasting/auth', BroadcastController::class.'@authenticate');
+ });
+ }
+
+ /**
+ * Get the socket ID for the given request.
+ *
+ * @param \Illuminate\Http\Request|null $request
+ * @return string|null
+ */
+ public function socket($request = null)
+ {
+ if (! $request && ! $this->app->bound('request')) {
+ return;
+ }
+
+ $request = $request ?: $this->app['request'];
+
+ if ($request->hasHeader('X-Socket-ID')) {
+ return $request->header('X-Socket-ID');
+ }
+ }
+
+ /**
+ * Begin broadcasting an event.
+ *
+ * @param mixed|null $event
+ * @return \Illuminate\Broadcasting\PendingBroadcast|void
+ */
+ public function event($event = null)
+ {
+ return new PendingBroadcast($this->app->make('events'), $event);
+ }
+
+ /**
+ * Queue the given event for broadcast.
+ *
+ * @param mixed $event
+ * @return void
+ */
+ public function queue($event)
+ {
+ $connection = $event instanceof ShouldBroadcastNow ? 'sync' : null;
+
+ if (is_null($connection) && isset($event->connection)) {
+ $connection = $event->connection;
+ }
+
+ $queue = null;
+
+ if (method_exists($event, 'broadcastQueue')) {
+ $queue = $event->broadcastQueue();
+ } elseif (isset($event->broadcastQueue)) {
+ $queue = $event->broadcastQueue;
+ } elseif (isset($event->queue)) {
+ $queue = $event->queue;
+ }
+
+ $this->app->make('queue')->connection($connection)->pushOn(
+ $queue, new BroadcastEvent(clone $event)
+ );
+ }
+
+ /**
+ * Get a driver instance.
+ *
+ * @param string $driver
+ * @return mixed
+ */
+ public function connection($driver = null)
+ {
+ return $this->driver($driver);
+ }
+
+ /**
+ * Get a driver instance.
+ *
+ * @param string $name
+ * @return mixed
+ */
+ public function driver($name = null)
+ {
+ $name = $name ?: $this->getDefaultDriver();
+
+ return $this->drivers[$name] = $this->get($name);
+ }
+
+ /**
+ * Attempt to get the connection from the local cache.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Broadcasting\Broadcaster
+ */
+ protected function get($name)
+ {
+ return isset($this->drivers[$name]) ? $this->drivers[$name] : $this->resolve($name);
+ }
+
+ /**
+ * Resolve the given store.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Broadcasting\Broadcaster
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function resolve($name)
+ {
+ $config = $this->getConfig($name);
+
+ if (is_null($config)) {
+ throw new InvalidArgumentException("Broadcaster [{$name}] is not defined.");
+ }
+
+ if (isset($this->customCreators[$config['driver']])) {
+ return $this->callCustomCreator($config);
+ }
+
+ $driverMethod = 'create'.ucfirst($config['driver']).'Driver';
+
+ if (! method_exists($this, $driverMethod)) {
+ throw new InvalidArgumentException("Driver [{$config['driver']}] is not supported.");
+ }
+
+ return $this->{$driverMethod}($config);
+ }
+
+ /**
+ * Call a custom driver creator.
+ *
+ * @param array $config
+ * @return mixed
+ */
+ protected function callCustomCreator(array $config)
+ {
+ return $this->customCreators[$config['driver']]($this->app, $config);
+ }
+
+ /**
+ * Create an instance of the driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Broadcasting\Broadcaster
+ */
+ protected function createPusherDriver(array $config)
+ {
+ return new PusherBroadcaster(
+ new Pusher($config['key'], $config['secret'],
+ $config['app_id'], Arr::get($config, 'options', []))
+ );
+ }
+
+ /**
+ * Create an instance of the driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Broadcasting\Broadcaster
+ */
+ protected function createRedisDriver(array $config)
+ {
+ return new RedisBroadcaster(
+ $this->app->make('redis'), Arr::get($config, 'connection')
+ );
+ }
+
+ /**
+ * Create an instance of the driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Broadcasting\Broadcaster
+ */
+ protected function createLogDriver(array $config)
+ {
+ return new LogBroadcaster(
+ $this->app->make(LoggerInterface::class)
+ );
+ }
+
+ /**
+ * Create an instance of the driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Broadcasting\Broadcaster
+ */
+ protected function createNullDriver(array $config)
+ {
+ return new NullBroadcaster;
+ }
+
+ /**
+ * Get the connection configuration.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function getConfig($name)
+ {
+ return $this->app['config']["broadcasting.connections.{$name}"];
+ }
+
+ /**
+ * Get the default driver name.
+ *
+ * @return string
+ */
+ public function getDefaultDriver()
+ {
+ return $this->app['config']['broadcasting.default'];
+ }
+
+ /**
+ * Set the default driver name.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setDefaultDriver($name)
+ {
+ $this->app['config']['broadcasting.default'] = $name;
+ }
+
+ /**
+ * Register a custom driver creator Closure.
+ *
+ * @param string $driver
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function extend($driver, Closure $callback)
+ {
+ $this->customCreators[$driver] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Dynamically call the default driver instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->driver()->$method(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastServiceProvider.php
new file mode 100644
index 000000000..adf88a6fc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/BroadcastServiceProvider.php
@@ -0,0 +1,51 @@
+app->singleton(BroadcastManager::class, function ($app) {
+ return new BroadcastManager($app);
+ });
+
+ $this->app->singleton(BroadcasterContract::class, function ($app) {
+ return $app->make(BroadcastManager::class)->connection();
+ });
+
+ $this->app->alias(
+ BroadcastManager::class, BroadcastingFactory::class
+ );
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return [
+ BroadcastManager::class,
+ BroadcastingFactory::class,
+ BroadcasterContract::class,
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/Broadcaster.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/Broadcaster.php
new file mode 100644
index 000000000..ed1c9467b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/Broadcaster.php
@@ -0,0 +1,201 @@
+channels[$channel] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Authenticate the incoming request for a given channel.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param string $channel
+ * @return mixed
+ */
+ protected function verifyUserCanAccessChannel($request, $channel)
+ {
+ foreach ($this->channels as $pattern => $callback) {
+ if (! Str::is(preg_replace('/\{(.*?)\}/', '*', $pattern), $channel)) {
+ continue;
+ }
+
+ $parameters = $this->extractAuthParameters($pattern, $channel, $callback);
+
+ if ($result = $callback($request->user(), ...$parameters)) {
+ return $this->validAuthenticationResponse($request, $result);
+ }
+ }
+
+ throw new HttpException(403);
+ }
+
+ /**
+ * Extract the parameters from the given pattern and channel.
+ *
+ * @param string $pattern
+ * @param string $channel
+ * @param callable $callback
+ * @return array
+ */
+ protected function extractAuthParameters($pattern, $channel, $callback)
+ {
+ $callbackParameters = (new ReflectionFunction($callback))->getParameters();
+
+ return collect($this->extractChannelKeys($pattern, $channel))->reject(function ($value, $key) {
+ return is_numeric($key);
+ })->map(function ($value, $key) use ($callbackParameters) {
+ return $this->resolveBinding($key, $value, $callbackParameters);
+ })->values()->all();
+ }
+
+ /**
+ * Extract the channel keys from the incoming channel name.
+ *
+ * @param string $pattern
+ * @param string $channel
+ * @return array
+ */
+ protected function extractChannelKeys($pattern, $channel)
+ {
+ preg_match('/^'.preg_replace('/\{(.*?)\}/', '(?<$1>[^\.]+)', $pattern).'/', $channel, $keys);
+
+ return $keys;
+ }
+
+ /**
+ * Resolve the given parameter binding.
+ *
+ * @param string $key
+ * @param string $value
+ * @param array $callbackParameters
+ * @return mixed
+ */
+ protected function resolveBinding($key, $value, $callbackParameters)
+ {
+ $newValue = $this->resolveExplicitBindingIfPossible($key, $value);
+
+ return $newValue === $value ? $this->resolveImplicitBindingIfPossible(
+ $key, $value, $callbackParameters
+ ) : $newValue;
+ }
+
+ /**
+ * Resolve an explicit parameter binding if applicable.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function resolveExplicitBindingIfPossible($key, $value)
+ {
+ $binder = $this->binder();
+
+ if ($binder && $binder->getBindingCallback($key)) {
+ return call_user_func($binder->getBindingCallback($key), $value);
+ }
+
+ return $value;
+ }
+
+ /**
+ * Resolve an implicit parameter binding if applicable.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param array $callbackParameters
+ * @return mixed
+ */
+ protected function resolveImplicitBindingIfPossible($key, $value, $callbackParameters)
+ {
+ foreach ($callbackParameters as $parameter) {
+ if (! $this->isImplicitlyBindable($key, $parameter)) {
+ continue;
+ }
+
+ $model = $parameter->getClass()->newInstance();
+
+ return $model->where($model->getRouteKeyName(), $value)->firstOr(function () {
+ throw new HttpException(403);
+ });
+ }
+
+ return $value;
+ }
+
+ /**
+ * Determine if a given key and parameter is implicitly bindable.
+ *
+ * @param string $key
+ * @param ReflectionParameter $parameter
+ * @return bool
+ */
+ protected function isImplicitlyBindable($key, $parameter)
+ {
+ return $parameter->name === $key && $parameter->getClass() &&
+ $parameter->getClass()->isSubclassOf(Model::class);
+ }
+
+ /**
+ * Format the channel array into an array of strings.
+ *
+ * @param array $channels
+ * @return array
+ */
+ protected function formatChannels(array $channels)
+ {
+ return array_map(function ($channel) {
+ return (string) $channel;
+ }, $channels);
+ }
+
+ /**
+ * Get the model binding registrar instance.
+ *
+ * @return BindingRegistrar
+ */
+ protected function binder()
+ {
+ if (! $this->bindingRegistrar) {
+ $this->bindingRegistrar = Container::getInstance()->bound(BindingRegistrar::class)
+ ? Container::getInstance()->make(BindingRegistrar::class) : null;
+ }
+
+ return $this->bindingRegistrar;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/LogBroadcaster.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/LogBroadcaster.php
new file mode 100644
index 000000000..50877dc97
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/LogBroadcaster.php
@@ -0,0 +1,54 @@
+logger = $logger;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function auth($request)
+ {
+ //
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function validAuthenticationResponse($request, $result)
+ {
+ //
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function broadcast(array $channels, $event, array $payload = [])
+ {
+ $channels = implode(', ', $this->formatChannels($channels));
+
+ $payload = json_encode($payload, JSON_PRETTY_PRINT);
+
+ $this->logger->info('Broadcasting ['.$event.'] on channels ['.$channels.'] with payload:'.PHP_EOL.$payload);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/NullBroadcaster.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/NullBroadcaster.php
new file mode 100644
index 000000000..6205c90c1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/NullBroadcaster.php
@@ -0,0 +1,30 @@
+pusher = $pusher;
+ }
+
+ /**
+ * Authenticate the incoming request for a given channel.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return mixed
+ */
+ public function auth($request)
+ {
+ if (Str::startsWith($request->channel_name, ['private-', 'presence-']) &&
+ ! $request->user()) {
+ throw new HttpException(403);
+ }
+
+ $channelName = Str::startsWith($request->channel_name, 'private-')
+ ? Str::replaceFirst('private-', '', $request->channel_name)
+ : Str::replaceFirst('presence-', '', $request->channel_name);
+
+ return parent::verifyUserCanAccessChannel(
+ $request, $channelName
+ );
+ }
+
+ /**
+ * Return the valid authentication response.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param mixed $result
+ * @return mixed
+ */
+ public function validAuthenticationResponse($request, $result)
+ {
+ if (Str::startsWith($request->channel_name, 'private')) {
+ return $this->decodePusherResponse(
+ $this->pusher->socket_auth($request->channel_name, $request->socket_id)
+ );
+ }
+
+ return $this->decodePusherResponse(
+ $this->pusher->presence_auth(
+ $request->channel_name, $request->socket_id, $request->user()->getAuthIdentifier(), $result)
+ );
+ }
+
+ /**
+ * Decode the given Pusher response.
+ *
+ * @param mixed $response
+ * @return array
+ */
+ protected function decodePusherResponse($response)
+ {
+ return json_decode($response, true);
+ }
+
+ /**
+ * Broadcast the given event.
+ *
+ * @param array $channels
+ * @param string $event
+ * @param array $payload
+ * @return void
+ */
+ public function broadcast(array $channels, $event, array $payload = [])
+ {
+ $socket = Arr::pull($payload, 'socket');
+
+ $response = $this->pusher->trigger(
+ $this->formatChannels($channels), $event, $payload, $socket, true
+ );
+
+ if ((is_array($response) && $response['status'] >= 200 && $response['status'] <= 299)
+ || $response === true) {
+ return;
+ }
+
+ throw new BroadcastException(
+ is_bool($response) ? 'Failed to connect to Pusher.' : $response['body']
+ );
+ }
+
+ /**
+ * Get the Pusher SDK instance.
+ *
+ * @return \Pusher
+ */
+ public function getPusher()
+ {
+ return $this->pusher;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/RedisBroadcaster.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/RedisBroadcaster.php
new file mode 100644
index 000000000..999899f26
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/Broadcasters/RedisBroadcaster.php
@@ -0,0 +1,102 @@
+redis = $redis;
+ $this->connection = $connection;
+ }
+
+ /**
+ * Authenticate the incoming request for a given channel.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return mixed
+ */
+ public function auth($request)
+ {
+ if (Str::startsWith($request->channel_name, ['private-', 'presence-']) &&
+ ! $request->user()) {
+ throw new HttpException(403);
+ }
+
+ $channelName = Str::startsWith($request->channel_name, 'private-')
+ ? Str::replaceFirst('private-', '', $request->channel_name)
+ : Str::replaceFirst('presence-', '', $request->channel_name);
+
+ return parent::verifyUserCanAccessChannel(
+ $request, $channelName
+ );
+ }
+
+ /**
+ * Return the valid authentication response.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param mixed $result
+ * @return mixed
+ */
+ public function validAuthenticationResponse($request, $result)
+ {
+ if (is_bool($result)) {
+ return json_encode($result);
+ }
+
+ return json_encode(['channel_data' => [
+ 'user_id' => $request->user()->getAuthIdentifier(),
+ 'user_info' => $result,
+ ]]);
+ }
+
+ /**
+ * Broadcast the given event.
+ *
+ * @param array $channels
+ * @param string $event
+ * @param array $payload
+ * @return void
+ */
+ public function broadcast(array $channels, $event, array $payload = [])
+ {
+ $connection = $this->redis->connection($this->connection);
+
+ $payload = json_encode([
+ 'event' => $event,
+ 'data' => $payload,
+ 'socket' => Arr::pull($payload, 'socket'),
+ ]);
+
+ foreach ($this->formatChannels($channels) as $channel) {
+ $connection->publish($channel, $payload);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/Channel.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/Channel.php
new file mode 100644
index 000000000..798d6026a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/Channel.php
@@ -0,0 +1,34 @@
+name = $name;
+ }
+
+ /**
+ * Convert the channel instance to a string.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->name;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/InteractsWithSockets.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/InteractsWithSockets.php
new file mode 100644
index 000000000..6be0791a5
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/InteractsWithSockets.php
@@ -0,0 +1,39 @@
+socket = Broadcast::socket();
+
+ return $this;
+ }
+
+ /**
+ * Broadcast the event to everyone.
+ *
+ * @return $this
+ */
+ public function broadcastToEveryone()
+ {
+ $this->socket = null;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/PendingBroadcast.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/PendingBroadcast.php
new file mode 100644
index 000000000..b75502902
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/PendingBroadcast.php
@@ -0,0 +1,59 @@
+event = $event;
+ $this->events = $events;
+ }
+
+ /**
+ * Broadcast the event to everyone except the current user.
+ *
+ * @return $this
+ */
+ public function toOthers()
+ {
+ if (method_exists($this->event, 'dontBroadcastToCurrentUser')) {
+ $this->event->dontBroadcastToCurrentUser();
+ }
+
+ return $this;
+ }
+
+ /**
+ * Handle the object's destruction.
+ *
+ * @return void
+ */
+ public function __destruct()
+ {
+ $this->events->dispatch($this->event);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Broadcasting/PresenceChannel.php b/vendor/laravel/framework/src/Illuminate/Broadcasting/PresenceChannel.php
new file mode 100644
index 000000000..22de12d37
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Broadcasting/PresenceChannel.php
@@ -0,0 +1,17 @@
+=5.6.4",
+ "illuminate/bus": "5.4.*",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/queue": "5.4.*",
+ "illuminate/support": "5.4.*"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Broadcasting\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "pusher/pusher-php-server": "Required to use the Pusher broadcast driver (~2.0)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Bus/BusServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Bus/BusServiceProvider.php
new file mode 100644
index 000000000..ade4a77a2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Bus/BusServiceProvider.php
@@ -0,0 +1,54 @@
+app->singleton(Dispatcher::class, function ($app) {
+ return new Dispatcher($app, function ($connection = null) use ($app) {
+ return $app[QueueFactoryContract::class]->connection($connection);
+ });
+ });
+
+ $this->app->alias(
+ Dispatcher::class, DispatcherContract::class
+ );
+
+ $this->app->alias(
+ Dispatcher::class, QueueingDispatcherContract::class
+ );
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return [
+ Dispatcher::class,
+ DispatcherContract::class,
+ QueueingDispatcherContract::class,
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Bus/Dispatcher.php b/vendor/laravel/framework/src/Illuminate/Bus/Dispatcher.php
new file mode 100644
index 000000000..2690fe757
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Bus/Dispatcher.php
@@ -0,0 +1,212 @@
+container = $container;
+ $this->queueResolver = $queueResolver;
+ $this->pipeline = new Pipeline($container);
+ }
+
+ /**
+ * Dispatch a command to its appropriate handler.
+ *
+ * @param mixed $command
+ * @return mixed
+ */
+ public function dispatch($command)
+ {
+ if ($this->queueResolver && $this->commandShouldBeQueued($command)) {
+ return $this->dispatchToQueue($command);
+ } else {
+ return $this->dispatchNow($command);
+ }
+ }
+
+ /**
+ * Dispatch a command to its appropriate handler in the current process.
+ *
+ * @param mixed $command
+ * @param mixed $handler
+ * @return mixed
+ */
+ public function dispatchNow($command, $handler = null)
+ {
+ if ($handler || $handler = $this->getCommandHandler($command)) {
+ $callback = function ($command) use ($handler) {
+ return $handler->handle($command);
+ };
+ } else {
+ $callback = function ($command) {
+ return $this->container->call([$command, 'handle']);
+ };
+ }
+
+ return $this->pipeline->send($command)->through($this->pipes)->then($callback);
+ }
+
+ /**
+ * Determine if the given command has a handler.
+ *
+ * @param mixed $command
+ * @return bool
+ */
+ public function hasCommandHandler($command)
+ {
+ return array_key_exists(get_class($command), $this->handlers);
+ }
+
+ /**
+ * Retrieve the handler for a command.
+ *
+ * @param mixed $command
+ * @return bool|mixed
+ */
+ public function getCommandHandler($command)
+ {
+ if ($this->hasCommandHandler($command)) {
+ return $this->container->make($this->handlers[get_class($command)]);
+ }
+
+ return false;
+ }
+
+ /**
+ * Determine if the given command should be queued.
+ *
+ * @param mixed $command
+ * @return bool
+ */
+ protected function commandShouldBeQueued($command)
+ {
+ return $command instanceof ShouldQueue;
+ }
+
+ /**
+ * Dispatch a command to its appropriate handler behind a queue.
+ *
+ * @param mixed $command
+ * @return mixed
+ *
+ * @throws \RuntimeException
+ */
+ public function dispatchToQueue($command)
+ {
+ $connection = isset($command->connection) ? $command->connection : null;
+
+ $queue = call_user_func($this->queueResolver, $connection);
+
+ if (! $queue instanceof Queue) {
+ throw new RuntimeException('Queue resolver did not return a Queue implementation.');
+ }
+
+ if (method_exists($command, 'queue')) {
+ return $command->queue($queue, $command);
+ } else {
+ return $this->pushCommandToQueue($queue, $command);
+ }
+ }
+
+ /**
+ * Push the command onto the given queue instance.
+ *
+ * @param \Illuminate\Contracts\Queue\Queue $queue
+ * @param mixed $command
+ * @return mixed
+ */
+ protected function pushCommandToQueue($queue, $command)
+ {
+ if (isset($command->queue, $command->delay)) {
+ return $queue->laterOn($command->queue, $command->delay, $command);
+ }
+
+ if (isset($command->queue)) {
+ return $queue->pushOn($command->queue, $command);
+ }
+
+ if (isset($command->delay)) {
+ return $queue->later($command->delay, $command);
+ }
+
+ return $queue->push($command);
+ }
+
+ /**
+ * Set the pipes through which commands should be piped before dispatching.
+ *
+ * @param array $pipes
+ * @return $this
+ */
+ public function pipeThrough(array $pipes)
+ {
+ $this->pipes = $pipes;
+
+ return $this;
+ }
+
+ /**
+ * Map a command to a handler.
+ *
+ * @param array $map
+ * @return $this
+ */
+ public function map(array $map)
+ {
+ $this->handlers = array_merge($this->handlers, $map);
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Bus/Queueable.php b/vendor/laravel/framework/src/Illuminate/Bus/Queueable.php
new file mode 100644
index 000000000..6813363e3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Bus/Queueable.php
@@ -0,0 +1,66 @@
+connection = $connection;
+
+ return $this;
+ }
+
+ /**
+ * Set the desired queue for the job.
+ *
+ * @param string|null $queue
+ * @return $this
+ */
+ public function onQueue($queue)
+ {
+ $this->queue = $queue;
+
+ return $this;
+ }
+
+ /**
+ * Set the desired delay for the job.
+ *
+ * @param \DateTime|int|null $delay
+ * @return $this
+ */
+ public function delay($delay)
+ {
+ $this->delay = $delay;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Bus/composer.json b/vendor/laravel/framework/src/Illuminate/Bus/composer.json
new file mode 100644
index 000000000..1f29f6204
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Bus/composer.json
@@ -0,0 +1,36 @@
+{
+ "name": "illuminate/bus",
+ "description": "The Illuminate Bus package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/pipeline": "5.4.*",
+ "illuminate/support": "5.4.*"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Bus\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/ApcStore.php b/vendor/laravel/framework/src/Illuminate/Cache/ApcStore.php
new file mode 100644
index 000000000..db11ea4eb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/ApcStore.php
@@ -0,0 +1,132 @@
+apc = $apc;
+ $this->prefix = $prefix;
+ }
+
+ /**
+ * Retrieve an item from the cache by key.
+ *
+ * @param string|array $key
+ * @return mixed
+ */
+ public function get($key)
+ {
+ $value = $this->apc->get($this->prefix.$key);
+
+ if ($value !== false) {
+ return $value;
+ }
+ }
+
+ /**
+ * Store an item in the cache for a given number of minutes.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param float|int $minutes
+ * @return void
+ */
+ public function put($key, $value, $minutes)
+ {
+ $this->apc->put($this->prefix.$key, $value, (int) ($minutes * 60));
+ }
+
+ /**
+ * Increment the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int|bool
+ */
+ public function increment($key, $value = 1)
+ {
+ return $this->apc->increment($this->prefix.$key, $value);
+ }
+
+ /**
+ * Decrement the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int|bool
+ */
+ public function decrement($key, $value = 1)
+ {
+ return $this->apc->decrement($this->prefix.$key, $value);
+ }
+
+ /**
+ * Store an item in the cache indefinitely.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function forever($key, $value)
+ {
+ $this->put($key, $value, 0);
+ }
+
+ /**
+ * Remove an item from the cache.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function forget($key)
+ {
+ return $this->apc->delete($this->prefix.$key);
+ }
+
+ /**
+ * Remove all items from the cache.
+ *
+ * @return bool
+ */
+ public function flush()
+ {
+ return $this->apc->flush();
+ }
+
+ /**
+ * Get the cache key prefix.
+ *
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return $this->prefix;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/ApcWrapper.php b/vendor/laravel/framework/src/Illuminate/Cache/ApcWrapper.php
new file mode 100644
index 000000000..42e76aaa8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/ApcWrapper.php
@@ -0,0 +1,92 @@
+apcu = function_exists('apcu_fetch');
+ }
+
+ /**
+ * Get an item from the cache.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function get($key)
+ {
+ return $this->apcu ? apcu_fetch($key) : apc_fetch($key);
+ }
+
+ /**
+ * Store an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param int $seconds
+ * @return array|bool
+ */
+ public function put($key, $value, $seconds)
+ {
+ return $this->apcu ? apcu_store($key, $value, $seconds) : apc_store($key, $value, $seconds);
+ }
+
+ /**
+ * Increment the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int|bool
+ */
+ public function increment($key, $value)
+ {
+ return $this->apcu ? apcu_inc($key, $value) : apc_inc($key, $value);
+ }
+
+ /**
+ * Decrement the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int|bool
+ */
+ public function decrement($key, $value)
+ {
+ return $this->apcu ? apcu_dec($key, $value) : apc_dec($key, $value);
+ }
+
+ /**
+ * Remove an item from the cache.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function delete($key)
+ {
+ return $this->apcu ? apcu_delete($key) : apc_delete($key);
+ }
+
+ /**
+ * Remove all items from the cache.
+ *
+ * @return bool
+ */
+ public function flush()
+ {
+ return $this->apcu ? apcu_clear_cache() : apc_clear_cache('user');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/ArrayStore.php b/vendor/laravel/framework/src/Illuminate/Cache/ArrayStore.php
new file mode 100644
index 000000000..8901a489b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/ArrayStore.php
@@ -0,0 +1,117 @@
+storage)) {
+ return $this->storage[$key];
+ }
+ }
+
+ /**
+ * Store an item in the cache for a given number of minutes.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param float|int $minutes
+ * @return void
+ */
+ public function put($key, $value, $minutes)
+ {
+ $this->storage[$key] = $value;
+ }
+
+ /**
+ * Increment the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int
+ */
+ public function increment($key, $value = 1)
+ {
+ $this->storage[$key] = ! isset($this->storage[$key])
+ ? $value : ((int) $this->storage[$key]) + $value;
+
+ return $this->storage[$key];
+ }
+
+ /**
+ * Decrement the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int
+ */
+ public function decrement($key, $value = 1)
+ {
+ return $this->increment($key, $value * -1);
+ }
+
+ /**
+ * Store an item in the cache indefinitely.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function forever($key, $value)
+ {
+ $this->put($key, $value, 0);
+ }
+
+ /**
+ * Remove an item from the cache.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function forget($key)
+ {
+ unset($this->storage[$key]);
+
+ return true;
+ }
+
+ /**
+ * Remove all items from the cache.
+ *
+ * @return bool
+ */
+ public function flush()
+ {
+ $this->storage = [];
+
+ return true;
+ }
+
+ /**
+ * Get the cache key prefix.
+ *
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return '';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/CacheManager.php b/vendor/laravel/framework/src/Illuminate/Cache/CacheManager.php
new file mode 100644
index 000000000..79dfea865
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/CacheManager.php
@@ -0,0 +1,307 @@
+app = $app;
+ }
+
+ /**
+ * Get a cache store instance by name.
+ *
+ * @param string|null $name
+ * @return mixed
+ */
+ public function store($name = null)
+ {
+ $name = $name ?: $this->getDefaultDriver();
+
+ return $this->stores[$name] = $this->get($name);
+ }
+
+ /**
+ * Get a cache driver instance.
+ *
+ * @param string $driver
+ * @return mixed
+ */
+ public function driver($driver = null)
+ {
+ return $this->store($driver);
+ }
+
+ /**
+ * Attempt to get the store from the local cache.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Cache\Repository
+ */
+ protected function get($name)
+ {
+ return isset($this->stores[$name]) ? $this->stores[$name] : $this->resolve($name);
+ }
+
+ /**
+ * Resolve the given store.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Cache\Repository
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function resolve($name)
+ {
+ $config = $this->getConfig($name);
+
+ if (is_null($config)) {
+ throw new InvalidArgumentException("Cache store [{$name}] is not defined.");
+ }
+
+ if (isset($this->customCreators[$config['driver']])) {
+ return $this->callCustomCreator($config);
+ } else {
+ $driverMethod = 'create'.ucfirst($config['driver']).'Driver';
+
+ if (method_exists($this, $driverMethod)) {
+ return $this->{$driverMethod}($config);
+ } else {
+ throw new InvalidArgumentException("Driver [{$config['driver']}] is not supported.");
+ }
+ }
+ }
+
+ /**
+ * Call a custom driver creator.
+ *
+ * @param array $config
+ * @return mixed
+ */
+ protected function callCustomCreator(array $config)
+ {
+ return $this->customCreators[$config['driver']]($this->app, $config);
+ }
+
+ /**
+ * Create an instance of the APC cache driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Cache\ApcStore
+ */
+ protected function createApcDriver(array $config)
+ {
+ $prefix = $this->getPrefix($config);
+
+ return $this->repository(new ApcStore(new ApcWrapper, $prefix));
+ }
+
+ /**
+ * Create an instance of the array cache driver.
+ *
+ * @return \Illuminate\Cache\ArrayStore
+ */
+ protected function createArrayDriver()
+ {
+ return $this->repository(new ArrayStore);
+ }
+
+ /**
+ * Create an instance of the file cache driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Cache\FileStore
+ */
+ protected function createFileDriver(array $config)
+ {
+ return $this->repository(new FileStore($this->app['files'], $config['path']));
+ }
+
+ /**
+ * Create an instance of the Memcached cache driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Cache\MemcachedStore
+ */
+ protected function createMemcachedDriver(array $config)
+ {
+ $prefix = $this->getPrefix($config);
+
+ $memcached = $this->app['memcached.connector']->connect(
+ $config['servers'],
+ array_get($config, 'persistent_id'),
+ array_get($config, 'options', []),
+ array_filter(array_get($config, 'sasl', []))
+ );
+
+ return $this->repository(new MemcachedStore($memcached, $prefix));
+ }
+
+ /**
+ * Create an instance of the Null cache driver.
+ *
+ * @return \Illuminate\Cache\NullStore
+ */
+ protected function createNullDriver()
+ {
+ return $this->repository(new NullStore);
+ }
+
+ /**
+ * Create an instance of the Redis cache driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Cache\RedisStore
+ */
+ protected function createRedisDriver(array $config)
+ {
+ $redis = $this->app['redis'];
+
+ $connection = Arr::get($config, 'connection', 'default');
+
+ return $this->repository(new RedisStore($redis, $this->getPrefix($config), $connection));
+ }
+
+ /**
+ * Create an instance of the database cache driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Cache\DatabaseStore
+ */
+ protected function createDatabaseDriver(array $config)
+ {
+ $connection = $this->app['db']->connection(Arr::get($config, 'connection'));
+
+ return $this->repository(
+ new DatabaseStore(
+ $connection, $this->app['encrypter'], $config['table'], $this->getPrefix($config)
+ )
+ );
+ }
+
+ /**
+ * Create a new cache repository with the given implementation.
+ *
+ * @param \Illuminate\Contracts\Cache\Store $store
+ * @return \Illuminate\Cache\Repository
+ */
+ public function repository(Store $store)
+ {
+ $repository = new Repository($store);
+
+ if ($this->app->bound(DispatcherContract::class)) {
+ $repository->setEventDispatcher(
+ $this->app[DispatcherContract::class]
+ );
+ }
+
+ return $repository;
+ }
+
+ /**
+ * Get the cache prefix.
+ *
+ * @param array $config
+ * @return string
+ */
+ protected function getPrefix(array $config)
+ {
+ return Arr::get($config, 'prefix') ?: $this->app['config']['cache.prefix'];
+ }
+
+ /**
+ * Get the cache connection configuration.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function getConfig($name)
+ {
+ return $this->app['config']["cache.stores.{$name}"];
+ }
+
+ /**
+ * Get the default cache driver name.
+ *
+ * @return string
+ */
+ public function getDefaultDriver()
+ {
+ return $this->app['config']['cache.default'];
+ }
+
+ /**
+ * Set the default cache driver name.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setDefaultDriver($name)
+ {
+ $this->app['config']['cache.default'] = $name;
+ }
+
+ /**
+ * Register a custom driver creator Closure.
+ *
+ * @param string $driver
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function extend($driver, Closure $callback)
+ {
+ $this->customCreators[$driver] = $callback->bindTo($this, $this);
+
+ return $this;
+ }
+
+ /**
+ * Dynamically call the default driver instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->store()->$method(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/CacheServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Cache/CacheServiceProvider.php
new file mode 100644
index 000000000..8eb5ed60a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/CacheServiceProvider.php
@@ -0,0 +1,47 @@
+app->singleton('cache', function ($app) {
+ return new CacheManager($app);
+ });
+
+ $this->app->singleton('cache.store', function ($app) {
+ return $app['cache']->driver();
+ });
+
+ $this->app->singleton('memcached.connector', function () {
+ return new MemcachedConnector;
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return [
+ 'cache', 'cache.store', 'memcached.connector',
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/Console/CacheTableCommand.php b/vendor/laravel/framework/src/Illuminate/Cache/Console/CacheTableCommand.php
new file mode 100644
index 000000000..7c3f4b62d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/Console/CacheTableCommand.php
@@ -0,0 +1,81 @@
+files = $files;
+ $this->composer = $composer;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $fullPath = $this->createBaseMigration();
+
+ $this->files->put($fullPath, $this->files->get(__DIR__.'/stubs/cache.stub'));
+
+ $this->info('Migration created successfully!');
+
+ $this->composer->dumpAutoloads();
+ }
+
+ /**
+ * Create a base migration file for the table.
+ *
+ * @return string
+ */
+ protected function createBaseMigration()
+ {
+ $name = 'create_cache_table';
+
+ $path = $this->laravel->databasePath().'/migrations';
+
+ return $this->laravel['migration.creator']->create($name, $path);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/Console/ClearCommand.php b/vendor/laravel/framework/src/Illuminate/Cache/Console/ClearCommand.php
new file mode 100644
index 000000000..48c576342
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/Console/ClearCommand.php
@@ -0,0 +1,107 @@
+cache = $cache;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function handle()
+ {
+ $this->laravel['events']->fire('cache:clearing', [$this->argument('store'), $this->tags()]);
+
+ $this->cache()->flush();
+
+ $this->laravel['events']->fire('cache:cleared', [$this->argument('store'), $this->tags()]);
+
+ $this->info('Cache cleared successfully.');
+ }
+
+ /**
+ * Get the cache instance for the command.
+ *
+ * @return \Illuminate\Cache\Repository
+ */
+ protected function cache()
+ {
+ $cache = $this->cache->store($this->argument('store'));
+
+ return empty($this->tags()) ? $cache : $cache->tags($this->tags());
+ }
+
+ /**
+ * Get the tags passed to the command.
+ *
+ * @return array
+ */
+ protected function tags()
+ {
+ return array_filter(explode(',', $this->option('tags')));
+ }
+
+ /**
+ * Get the console command arguments.
+ *
+ * @return array
+ */
+ protected function getArguments()
+ {
+ return [
+ ['store', InputArgument::OPTIONAL, 'The name of the store you would like to clear.'],
+ ];
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['tags', null, InputOption::VALUE_OPTIONAL, 'The cache tags you would like to clear.', null],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/Console/ForgetCommand.php b/vendor/laravel/framework/src/Illuminate/Cache/Console/ForgetCommand.php
new file mode 100644
index 000000000..646dc146a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/Console/ForgetCommand.php
@@ -0,0 +1,57 @@
+cache = $cache;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function handle()
+ {
+ $this->cache->store($this->argument('store'))->forget(
+ $this->argument('key')
+ );
+
+ $this->info('The ['.$this->argument('key').'] key has been removed from the cache.');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/Console/stubs/cache.stub b/vendor/laravel/framework/src/Illuminate/Cache/Console/stubs/cache.stub
new file mode 100644
index 000000000..1f7761c2b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/Console/stubs/cache.stub
@@ -0,0 +1,32 @@
+string('key')->unique();
+ $table->text('value');
+ $table->integer('expiration');
+ });
+ }
+
+ /**
+ * Reverse the migrations.
+ *
+ * @return void
+ */
+ public function down()
+ {
+ Schema::dropIfExists('cache');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/DatabaseStore.php b/vendor/laravel/framework/src/Illuminate/Cache/DatabaseStore.php
new file mode 100644
index 000000000..c120c9758
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/DatabaseStore.php
@@ -0,0 +1,280 @@
+table = $table;
+ $this->prefix = $prefix;
+ $this->encrypter = $encrypter;
+ $this->connection = $connection;
+ }
+
+ /**
+ * Retrieve an item from the cache by key.
+ *
+ * @param string|array $key
+ * @return mixed
+ */
+ public function get($key)
+ {
+ $prefixed = $this->prefix.$key;
+
+ $cache = $this->table()->where('key', '=', $prefixed)->first();
+
+ // If we have a cache record we will check the expiration time against current
+ // time on the system and see if the record has expired. If it has, we will
+ // remove the records from the database table so it isn't returned again.
+ if (is_null($cache)) {
+ return;
+ }
+
+ $cache = is_array($cache) ? (object) $cache : $cache;
+
+ // If this cache expiration date is past the current time, we will remove this
+ // item from the cache. Then we will return a null value since the cache is
+ // expired. We will use "Carbon" to make this comparison with the column.
+ if (Carbon::now()->getTimestamp() >= $cache->expiration) {
+ $this->forget($key);
+
+ return;
+ }
+
+ return $this->encrypter->decrypt($cache->value);
+ }
+
+ /**
+ * Store an item in the cache for a given number of minutes.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param float|int $minutes
+ * @return void
+ */
+ public function put($key, $value, $minutes)
+ {
+ $key = $this->prefix.$key;
+
+ // All of the cached values in the database are encrypted in case this is used
+ // as a session data store by the consumer. We'll also calculate the expire
+ // time and place that on the table so we will check it on our retrieval.
+ $value = $this->encrypter->encrypt($value);
+
+ $expiration = $this->getTime() + (int) ($minutes * 60);
+
+ try {
+ $this->table()->insert(compact('key', 'value', 'expiration'));
+ } catch (Exception $e) {
+ $this->table()->where('key', $key)->update(compact('value', 'expiration'));
+ }
+ }
+
+ /**
+ * Increment the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int|bool
+ */
+ public function increment($key, $value = 1)
+ {
+ return $this->incrementOrDecrement($key, $value, function ($current, $value) {
+ return $current + $value;
+ });
+ }
+
+ /**
+ * Decrement the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int|bool
+ */
+ public function decrement($key, $value = 1)
+ {
+ return $this->incrementOrDecrement($key, $value, function ($current, $value) {
+ return $current - $value;
+ });
+ }
+
+ /**
+ * Increment or decrement an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param \Closure $callback
+ * @return int|bool
+ */
+ protected function incrementOrDecrement($key, $value, Closure $callback)
+ {
+ return $this->connection->transaction(function () use ($key, $value, $callback) {
+ $prefixed = $this->prefix.$key;
+
+ $cache = $this->table()->where('key', $prefixed)
+ ->lockForUpdate()->first();
+
+ // If there is no value in the cache, we will return false here. Otherwise the
+ // value will be decrypted and we will proceed with this function to either
+ // increment or decrement this value based on the given action callbacks.
+ if (is_null($cache)) {
+ return false;
+ }
+
+ $cache = is_array($cache) ? (object) $cache : $cache;
+
+ $current = $this->encrypter->decrypt($cache->value);
+
+ // Here we'll call this callback function that was given to the function which
+ // is used to either increment or decrement the function. We use a callback
+ // so we do not have to recreate all this logic in each of the functions.
+ $new = $callback((int) $current, $value);
+
+ if (! is_numeric($current)) {
+ return false;
+ }
+
+ // Here we will update the values in the table. We will also encrypt the value
+ // since database cache values are encrypted by default with secure storage
+ // that can't be easily read. We will return the new value after storing.
+ $this->table()->where('key', $prefixed)->update([
+ 'value' => $this->encrypter->encrypt($new),
+ ]);
+
+ return $new;
+ });
+ }
+
+ /**
+ * Get the current system time.
+ *
+ * @return int
+ */
+ protected function getTime()
+ {
+ return Carbon::now()->getTimestamp();
+ }
+
+ /**
+ * Store an item in the cache indefinitely.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function forever($key, $value)
+ {
+ $this->put($key, $value, 5256000);
+ }
+
+ /**
+ * Remove an item from the cache.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function forget($key)
+ {
+ $this->table()->where('key', '=', $this->prefix.$key)->delete();
+
+ return true;
+ }
+
+ /**
+ * Remove all items from the cache.
+ *
+ * @return bool
+ */
+ public function flush()
+ {
+ return (bool) $this->table()->delete();
+ }
+
+ /**
+ * Get a query builder for the cache table.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ protected function table()
+ {
+ return $this->connection->table($this->table);
+ }
+
+ /**
+ * Get the underlying database connection.
+ *
+ * @return \Illuminate\Database\ConnectionInterface
+ */
+ public function getConnection()
+ {
+ return $this->connection;
+ }
+
+ /**
+ * Get the encrypter instance.
+ *
+ * @return \Illuminate\Contracts\Encryption\Encrypter
+ */
+ public function getEncrypter()
+ {
+ return $this->encrypter;
+ }
+
+ /**
+ * Get the cache key prefix.
+ *
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return $this->prefix;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/Events/CacheEvent.php b/vendor/laravel/framework/src/Illuminate/Cache/Events/CacheEvent.php
new file mode 100644
index 000000000..6c9d42c58
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/Events/CacheEvent.php
@@ -0,0 +1,46 @@
+key = $key;
+ $this->tags = $tags;
+ }
+
+ /**
+ * Set the tags for the cache event.
+ *
+ * @param array $tags
+ * @return $this
+ */
+ public function setTags($tags)
+ {
+ $this->tags = $tags;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/Events/CacheHit.php b/vendor/laravel/framework/src/Illuminate/Cache/Events/CacheHit.php
new file mode 100644
index 000000000..976c9e4f2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/Events/CacheHit.php
@@ -0,0 +1,28 @@
+value = $value;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/Events/CacheMissed.php b/vendor/laravel/framework/src/Illuminate/Cache/Events/CacheMissed.php
new file mode 100644
index 000000000..d2a5c9f90
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/Events/CacheMissed.php
@@ -0,0 +1,8 @@
+value = $value;
+ $this->minutes = $minutes;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/FileStore.php b/vendor/laravel/framework/src/Illuminate/Cache/FileStore.php
new file mode 100644
index 000000000..90d49c0bc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/FileStore.php
@@ -0,0 +1,263 @@
+files = $files;
+ $this->directory = $directory;
+ }
+
+ /**
+ * Retrieve an item from the cache by key.
+ *
+ * @param string|array $key
+ * @return mixed
+ */
+ public function get($key)
+ {
+ return Arr::get($this->getPayload($key), 'data');
+ }
+
+ /**
+ * Store an item in the cache for a given number of minutes.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param float|int $minutes
+ * @return void
+ */
+ public function put($key, $value, $minutes)
+ {
+ $this->ensureCacheDirectoryExists($path = $this->path($key));
+
+ $this->files->put(
+ $path, $this->expiration($minutes).serialize($value), true
+ );
+ }
+
+ /**
+ * Create the file cache directory if necessary.
+ *
+ * @param string $path
+ * @return void
+ */
+ protected function ensureCacheDirectoryExists($path)
+ {
+ if (! $this->files->exists(dirname($path))) {
+ $this->files->makeDirectory(dirname($path), 0777, true, true);
+ }
+ }
+
+ /**
+ * Increment the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int
+ */
+ public function increment($key, $value = 1)
+ {
+ $raw = $this->getPayload($key);
+
+ return tap(((int) $raw['data']) + $value, function ($newValue) use ($key, $raw) {
+ $this->put($key, $newValue, $raw['time']);
+ });
+ }
+
+ /**
+ * Decrement the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int
+ */
+ public function decrement($key, $value = 1)
+ {
+ return $this->increment($key, $value * -1);
+ }
+
+ /**
+ * Store an item in the cache indefinitely.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function forever($key, $value)
+ {
+ $this->put($key, $value, 0);
+ }
+
+ /**
+ * Remove an item from the cache.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function forget($key)
+ {
+ if ($this->files->exists($file = $this->path($key))) {
+ return $this->files->delete($file);
+ }
+
+ return false;
+ }
+
+ /**
+ * Remove all items from the cache.
+ *
+ * @return bool
+ */
+ public function flush()
+ {
+ if (! $this->files->isDirectory($this->directory)) {
+ return false;
+ }
+
+ foreach ($this->files->directories($this->directory) as $directory) {
+ if (! $this->files->deleteDirectory($directory)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Retrieve an item and expiry time from the cache by key.
+ *
+ * @param string $key
+ * @return array
+ */
+ protected function getPayload($key)
+ {
+ $path = $this->path($key);
+
+ // If the file doesn't exists, we obviously can't return the cache so we will
+ // just return null. Otherwise, we'll get the contents of the file and get
+ // the expiration UNIX timestamps from the start of the file's contents.
+ try {
+ $expire = substr(
+ $contents = $this->files->get($path, true), 0, 10
+ );
+ } catch (Exception $e) {
+ return $this->emptyPayload();
+ }
+
+ // If the current time is greater than expiration timestamps we will delete
+ // the file and return null. This helps clean up the old files and keeps
+ // this directory much cleaner for us as old files aren't hanging out.
+ if (Carbon::now()->getTimestamp() >= $expire) {
+ $this->forget($key);
+
+ return $this->emptyPayload();
+ }
+
+ $data = unserialize(substr($contents, 10));
+
+ // Next, we'll extract the number of minutes that are remaining for a cache
+ // so that we can properly retain the time for things like the increment
+ // operation that may be performed on this cache on a later operation.
+ $time = ($expire - Carbon::now()->getTimestamp()) / 60;
+
+ return compact('data', 'time');
+ }
+
+ /**
+ * Get a default empty payload for the cache.
+ *
+ * @return array
+ */
+ protected function emptyPayload()
+ {
+ return ['data' => null, 'time' => null];
+ }
+
+ /**
+ * Get the full path for the given cache key.
+ *
+ * @param string $key
+ * @return string
+ */
+ protected function path($key)
+ {
+ $parts = array_slice(str_split($hash = sha1($key), 2), 0, 2);
+
+ return $this->directory.'/'.implode('/', $parts).'/'.$hash;
+ }
+
+ /**
+ * Get the expiration time based on the given minutes.
+ *
+ * @param float|int $minutes
+ * @return int
+ */
+ protected function expiration($minutes)
+ {
+ $time = Carbon::now()->getTimestamp() + (int) ($minutes * 60);
+
+ return $minutes === 0 || $time > 9999999999 ? 9999999999 : (int) $time;
+ }
+
+ /**
+ * Get the Filesystem instance.
+ *
+ * @return \Illuminate\Filesystem\Filesystem
+ */
+ public function getFilesystem()
+ {
+ return $this->files;
+ }
+
+ /**
+ * Get the working directory of the cache.
+ *
+ * @return string
+ */
+ public function getDirectory()
+ {
+ return $this->directory;
+ }
+
+ /**
+ * Get the cache key prefix.
+ *
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return '';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/MemcachedConnector.php b/vendor/laravel/framework/src/Illuminate/Cache/MemcachedConnector.php
new file mode 100644
index 000000000..ebfb28c70
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/MemcachedConnector.php
@@ -0,0 +1,87 @@
+getMemcached(
+ $connectionId, $credentials, $options
+ );
+
+ if (! $memcached->getServerList()) {
+ // For each server in the array, we'll just extract the configuration and add
+ // the server to the Memcached connection. Once we have added all of these
+ // servers we'll verify the connection is successful and return it back.
+ foreach ($servers as $server) {
+ $memcached->addServer(
+ $server['host'], $server['port'], $server['weight']
+ );
+ }
+ }
+
+ return $memcached;
+ }
+
+ /**
+ * Get a new Memcached instance.
+ *
+ * @param string|null $connectionId
+ * @param array $credentials
+ * @param array $options
+ * @return \Memcached
+ */
+ protected function getMemcached($connectionId, array $credentials, array $options)
+ {
+ $memcached = $this->createMemcachedInstance($connectionId);
+
+ if (count($credentials) == 2) {
+ $this->setCredentials($memcached, $credentials);
+ }
+
+ if (count($options)) {
+ $memcached->setOptions($options);
+ }
+
+ return $memcached;
+ }
+
+ /**
+ * Create the Memcached instance.
+ *
+ * @param string|null $connectionId
+ * @return \Memcached
+ */
+ protected function createMemcachedInstance($connectionId)
+ {
+ return empty($connectionId) ? new Memcached : new Memcached($connectionId);
+ }
+
+ /**
+ * Set the SASL credentials on the Memcached connection.
+ *
+ * @param \Memcached $memcached
+ * @param array $credentials
+ * @return void
+ */
+ protected function setCredentials($memcached, $credentials)
+ {
+ list($username, $password) = $credentials;
+
+ $memcached->setOption(Memcached::OPT_BINARY_PROTOCOL, true);
+
+ $memcached->setSaslAuthData($username, $password);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/MemcachedStore.php b/vendor/laravel/framework/src/Illuminate/Cache/MemcachedStore.php
new file mode 100644
index 000000000..dfd616b77
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/MemcachedStore.php
@@ -0,0 +1,235 @@
+= 3.0.0.
+ *
+ * @var bool
+ */
+ protected $onVersionThree;
+
+ /**
+ * Create a new Memcached store.
+ *
+ * @param \Memcached $memcached
+ * @param string $prefix
+ * @return void
+ */
+ public function __construct($memcached, $prefix = '')
+ {
+ $this->setPrefix($prefix);
+ $this->memcached = $memcached;
+
+ $this->onVersionThree = (new ReflectionMethod('Memcached', 'getMulti'))
+ ->getNumberOfParameters() == 2;
+ }
+
+ /**
+ * Retrieve an item from the cache by key.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function get($key)
+ {
+ $value = $this->memcached->get($this->prefix.$key);
+
+ if ($this->memcached->getResultCode() == 0) {
+ return $value;
+ }
+ }
+
+ /**
+ * Retrieve multiple items from the cache by key.
+ *
+ * Items not found in the cache will have a null value.
+ *
+ * @param array $keys
+ * @return array
+ */
+ public function many(array $keys)
+ {
+ $prefixedKeys = array_map(function ($key) {
+ return $this->prefix.$key;
+ }, $keys);
+
+ if ($this->onVersionThree) {
+ $values = $this->memcached->getMulti($prefixedKeys, Memcached::GET_PRESERVE_ORDER);
+ } else {
+ $null = null;
+
+ $values = $this->memcached->getMulti($prefixedKeys, $null, Memcached::GET_PRESERVE_ORDER);
+ }
+
+ if ($this->memcached->getResultCode() != 0) {
+ return array_fill_keys($keys, null);
+ }
+
+ return array_combine($keys, $values);
+ }
+
+ /**
+ * Store an item in the cache for a given number of minutes.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param float|int $minutes
+ * @return void
+ */
+ public function put($key, $value, $minutes)
+ {
+ $this->memcached->set($this->prefix.$key, $value, $this->toTimestamp($minutes));
+ }
+
+ /**
+ * Store multiple items in the cache for a given number of minutes.
+ *
+ * @param array $values
+ * @param float|int $minutes
+ * @return void
+ */
+ public function putMany(array $values, $minutes)
+ {
+ $prefixedValues = [];
+
+ foreach ($values as $key => $value) {
+ $prefixedValues[$this->prefix.$key] = $value;
+ }
+
+ $this->memcached->setMulti($prefixedValues, $this->toTimestamp($minutes));
+ }
+
+ /**
+ * Store an item in the cache if the key doesn't exist.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param float|int $minutes
+ * @return bool
+ */
+ public function add($key, $value, $minutes)
+ {
+ return $this->memcached->add($this->prefix.$key, $value, $this->toTimestamp($minutes));
+ }
+
+ /**
+ * Increment the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int|bool
+ */
+ public function increment($key, $value = 1)
+ {
+ return $this->memcached->increment($this->prefix.$key, $value);
+ }
+
+ /**
+ * Decrement the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int|bool
+ */
+ public function decrement($key, $value = 1)
+ {
+ return $this->memcached->decrement($this->prefix.$key, $value);
+ }
+
+ /**
+ * Store an item in the cache indefinitely.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function forever($key, $value)
+ {
+ $this->put($key, $value, 0);
+ }
+
+ /**
+ * Remove an item from the cache.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function forget($key)
+ {
+ return $this->memcached->delete($this->prefix.$key);
+ }
+
+ /**
+ * Remove all items from the cache.
+ *
+ * @return bool
+ */
+ public function flush()
+ {
+ return $this->memcached->flush();
+ }
+
+ /**
+ * Get the UNIX timestamp for the given number of minutes.
+ *
+ * @param int $minutes
+ * @return int
+ */
+ protected function toTimestamp($minutes)
+ {
+ return $minutes > 0 ? Carbon::now()->addSeconds($minutes * 60)->getTimestamp() : 0;
+ }
+
+ /**
+ * Get the underlying Memcached connection.
+ *
+ * @return \Memcached
+ */
+ public function getMemcached()
+ {
+ return $this->memcached;
+ }
+
+ /**
+ * Get the cache key prefix.
+ *
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return $this->prefix;
+ }
+
+ /**
+ * Set the cache key prefix.
+ *
+ * @param string $prefix
+ * @return void
+ */
+ public function setPrefix($prefix)
+ {
+ $this->prefix = ! empty($prefix) ? $prefix.':' : '';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/NullStore.php b/vendor/laravel/framework/src/Illuminate/Cache/NullStore.php
new file mode 100644
index 000000000..16e869c80
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/NullStore.php
@@ -0,0 +1,108 @@
+cache = $cache;
+ }
+
+ /**
+ * Determine if the given key has been "accessed" too many times.
+ *
+ * @param string $key
+ * @param int $maxAttempts
+ * @param float|int $decayMinutes
+ * @return bool
+ */
+ public function tooManyAttempts($key, $maxAttempts, $decayMinutes = 1)
+ {
+ if ($this->cache->has($key.':lockout')) {
+ return true;
+ }
+
+ if ($this->attempts($key) >= $maxAttempts) {
+ $this->lockout($key, $decayMinutes);
+
+ $this->resetAttempts($key);
+
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * Add the lockout key to the cache.
+ *
+ * @param string $key
+ * @param int $decayMinutes
+ * @return void
+ */
+ protected function lockout($key, $decayMinutes)
+ {
+ $this->cache->add(
+ $key.':lockout', Carbon::now()->getTimestamp() + ($decayMinutes * 60), $decayMinutes
+ );
+ }
+
+ /**
+ * Increment the counter for a given key for a given decay time.
+ *
+ * @param string $key
+ * @param float|int $decayMinutes
+ * @return int
+ */
+ public function hit($key, $decayMinutes = 1)
+ {
+ $added = $this->cache->add($key, 0, $decayMinutes);
+
+ $hits = (int) $this->cache->increment($key);
+
+ if (! $added && $hits == 1) {
+ $this->cache->put($key, 1, $decayMinutes);
+ }
+
+ return $hits;
+ }
+
+ /**
+ * Get the number of attempts for the given key.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function attempts($key)
+ {
+ return $this->cache->get($key, 0);
+ }
+
+ /**
+ * Reset the number of attempts for the given key.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function resetAttempts($key)
+ {
+ return $this->cache->forget($key);
+ }
+
+ /**
+ * Get the number of retries left for the given key.
+ *
+ * @param string $key
+ * @param int $maxAttempts
+ * @return int
+ */
+ public function retriesLeft($key, $maxAttempts)
+ {
+ $attempts = $this->attempts($key);
+
+ return $maxAttempts - $attempts;
+ }
+
+ /**
+ * Clear the hits and lockout for the given key.
+ *
+ * @param string $key
+ * @return void
+ */
+ public function clear($key)
+ {
+ $this->resetAttempts($key);
+
+ $this->cache->forget($key.':lockout');
+ }
+
+ /**
+ * Get the number of seconds until the "key" is accessible again.
+ *
+ * @param string $key
+ * @return int
+ */
+ public function availableIn($key)
+ {
+ return $this->cache->get($key.':lockout') - Carbon::now()->getTimestamp();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/RedisStore.php b/vendor/laravel/framework/src/Illuminate/Cache/RedisStore.php
new file mode 100644
index 000000000..100af0d32
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/RedisStore.php
@@ -0,0 +1,277 @@
+redis = $redis;
+ $this->setPrefix($prefix);
+ $this->setConnection($connection);
+ }
+
+ /**
+ * Retrieve an item from the cache by key.
+ *
+ * @param string|array $key
+ * @return mixed
+ */
+ public function get($key)
+ {
+ $value = $this->connection()->get($this->prefix.$key);
+
+ return ! is_null($value) ? $this->unserialize($value) : null;
+ }
+
+ /**
+ * Retrieve multiple items from the cache by key.
+ *
+ * Items not found in the cache will have a null value.
+ *
+ * @param array $keys
+ * @return array
+ */
+ public function many(array $keys)
+ {
+ $results = [];
+
+ $values = $this->connection()->mget(array_map(function ($key) {
+ return $this->prefix.$key;
+ }, $keys));
+
+ foreach ($values as $index => $value) {
+ $results[$keys[$index]] = ! is_null($value) ? $this->unserialize($value) : null;
+ }
+
+ return $results;
+ }
+
+ /**
+ * Store an item in the cache for a given number of minutes.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param float|int $minutes
+ * @return void
+ */
+ public function put($key, $value, $minutes)
+ {
+ $this->connection()->setex(
+ $this->prefix.$key, (int) max(1, $minutes * 60), $this->serialize($value)
+ );
+ }
+
+ /**
+ * Store multiple items in the cache for a given number of minutes.
+ *
+ * @param array $values
+ * @param float|int $minutes
+ * @return void
+ */
+ public function putMany(array $values, $minutes)
+ {
+ $this->connection()->multi();
+
+ foreach ($values as $key => $value) {
+ $this->put($key, $value, $minutes);
+ }
+
+ $this->connection()->exec();
+ }
+
+ /**
+ * Store an item in the cache if the key doesn't exist.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param float|int $minutes
+ * @return bool
+ */
+ public function add($key, $value, $minutes)
+ {
+ $lua = "return redis.call('exists',KEYS[1])<1 and redis.call('setex',KEYS[1],ARGV[2],ARGV[1])";
+
+ return (bool) $this->connection()->eval(
+ $lua, 1, $this->prefix.$key, $this->serialize($value), (int) max(1, $minutes * 60)
+ );
+ }
+
+ /**
+ * Increment the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int
+ */
+ public function increment($key, $value = 1)
+ {
+ return $this->connection()->incrby($this->prefix.$key, $value);
+ }
+
+ /**
+ * Decrement the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int
+ */
+ public function decrement($key, $value = 1)
+ {
+ return $this->connection()->decrby($this->prefix.$key, $value);
+ }
+
+ /**
+ * Store an item in the cache indefinitely.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function forever($key, $value)
+ {
+ $this->connection()->set($this->prefix.$key, $this->serialize($value));
+ }
+
+ /**
+ * Remove an item from the cache.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function forget($key)
+ {
+ return (bool) $this->connection()->del($this->prefix.$key);
+ }
+
+ /**
+ * Remove all items from the cache.
+ *
+ * @return bool
+ */
+ public function flush()
+ {
+ $this->connection()->flushdb();
+
+ return true;
+ }
+
+ /**
+ * Begin executing a new tags operation.
+ *
+ * @param array|mixed $names
+ * @return \Illuminate\Cache\RedisTaggedCache
+ */
+ public function tags($names)
+ {
+ return new RedisTaggedCache(
+ $this, new TagSet($this, is_array($names) ? $names : func_get_args())
+ );
+ }
+
+ /**
+ * Get the Redis connection instance.
+ *
+ * @return \Predis\ClientInterface
+ */
+ public function connection()
+ {
+ return $this->redis->connection($this->connection);
+ }
+
+ /**
+ * Set the connection name to be used.
+ *
+ * @param string $connection
+ * @return void
+ */
+ public function setConnection($connection)
+ {
+ $this->connection = $connection;
+ }
+
+ /**
+ * Get the Redis database instance.
+ *
+ * @return \Illuminate\Contracts\Redis\Factory
+ */
+ public function getRedis()
+ {
+ return $this->redis;
+ }
+
+ /**
+ * Get the cache key prefix.
+ *
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return $this->prefix;
+ }
+
+ /**
+ * Set the cache key prefix.
+ *
+ * @param string $prefix
+ * @return void
+ */
+ public function setPrefix($prefix)
+ {
+ $this->prefix = ! empty($prefix) ? $prefix.':' : '';
+ }
+
+ /**
+ * Serialize the value.
+ *
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function serialize($value)
+ {
+ return is_numeric($value) ? $value : serialize($value);
+ }
+
+ /**
+ * Unserialize the value.
+ *
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function unserialize($value)
+ {
+ return is_numeric($value) ? $value : unserialize($value);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/RedisTaggedCache.php b/vendor/laravel/framework/src/Illuminate/Cache/RedisTaggedCache.php
new file mode 100644
index 000000000..d2325a007
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/RedisTaggedCache.php
@@ -0,0 +1,166 @@
+pushStandardKeys($this->tags->getNamespace(), $key);
+
+ parent::put($key, $value, $minutes);
+ }
+
+ /**
+ * Store an item in the cache indefinitely.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function forever($key, $value)
+ {
+ $this->pushForeverKeys($this->tags->getNamespace(), $key);
+
+ parent::forever($key, $value);
+ }
+
+ /**
+ * Remove all items from the cache.
+ *
+ * @return void
+ */
+ public function flush()
+ {
+ $this->deleteForeverKeys();
+ $this->deleteStandardKeys();
+
+ parent::flush();
+ }
+
+ /**
+ * Store standard key references into store.
+ *
+ * @param string $namespace
+ * @param string $key
+ * @return void
+ */
+ protected function pushStandardKeys($namespace, $key)
+ {
+ $this->pushKeys($namespace, $key, self::REFERENCE_KEY_STANDARD);
+ }
+
+ /**
+ * Store forever key references into store.
+ *
+ * @param string $namespace
+ * @param string $key
+ * @return void
+ */
+ protected function pushForeverKeys($namespace, $key)
+ {
+ $this->pushKeys($namespace, $key, self::REFERENCE_KEY_FOREVER);
+ }
+
+ /**
+ * Store a reference to the cache key against the reference key.
+ *
+ * @param string $namespace
+ * @param string $key
+ * @param string $reference
+ * @return void
+ */
+ protected function pushKeys($namespace, $key, $reference)
+ {
+ $fullKey = $this->store->getPrefix().sha1($namespace).':'.$key;
+
+ foreach (explode('|', $namespace) as $segment) {
+ $this->store->connection()->sadd($this->referenceKey($segment, $reference), $fullKey);
+ }
+ }
+
+ /**
+ * Delete all of the items that were stored forever.
+ *
+ * @return void
+ */
+ protected function deleteForeverKeys()
+ {
+ $this->deleteKeysByReference(self::REFERENCE_KEY_FOREVER);
+ }
+
+ /**
+ * Delete all standard items.
+ *
+ * @return void
+ */
+ protected function deleteStandardKeys()
+ {
+ $this->deleteKeysByReference(self::REFERENCE_KEY_STANDARD);
+ }
+
+ /**
+ * Find and delete all of the items that were stored against a reference.
+ *
+ * @param string $reference
+ * @return void
+ */
+ protected function deleteKeysByReference($reference)
+ {
+ foreach (explode('|', $this->tags->getNamespace()) as $segment) {
+ $this->deleteValues($segment = $this->referenceKey($segment, $reference));
+
+ $this->store->connection()->del($segment);
+ }
+ }
+
+ /**
+ * Delete item keys that have been stored against a reference.
+ *
+ * @param string $referenceKey
+ * @return void
+ */
+ protected function deleteValues($referenceKey)
+ {
+ $values = array_unique($this->store->connection()->smembers($referenceKey));
+
+ if (count($values) > 0) {
+ foreach (array_chunk($values, 1000) as $valuesChunk) {
+ call_user_func_array([$this->store->connection(), 'del'], $valuesChunk);
+ }
+ }
+ }
+
+ /**
+ * Get the reference key for the segment.
+ *
+ * @param string $segment
+ * @param string $suffix
+ * @return string
+ */
+ protected function referenceKey($segment, $suffix)
+ {
+ return $this->store->getPrefix().$segment.':'.$suffix;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/Repository.php b/vendor/laravel/framework/src/Illuminate/Cache/Repository.php
new file mode 100644
index 000000000..7ee1484dd
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/Repository.php
@@ -0,0 +1,520 @@
+store = $store;
+ }
+
+ /**
+ * Determine if an item exists in the cache.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function has($key)
+ {
+ return ! is_null($this->get($key));
+ }
+
+ /**
+ * Retrieve an item from the cache by key.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public function get($key, $default = null)
+ {
+ if (is_array($key)) {
+ return $this->many($key);
+ }
+
+ $value = $this->store->get($this->itemKey($key));
+
+ // If we could not find the cache value, we will fire the missed event and get
+ // the default value for this cache value. This default could be a callback
+ // so we will execute the value function which will resolve it if needed.
+ if (is_null($value)) {
+ $this->event(new CacheMissed($key));
+
+ $value = value($default);
+ } else {
+ $this->event(new CacheHit($key, $value));
+ }
+
+ return $value;
+ }
+
+ /**
+ * Retrieve multiple items from the cache by key.
+ *
+ * Items not found in the cache will have a null value.
+ *
+ * @param array $keys
+ * @return array
+ */
+ public function many(array $keys)
+ {
+ $values = $this->store->many(collect($keys)->map(function ($value, $key) {
+ return is_string($key) ? $key : $value;
+ })->values()->all());
+
+ return collect($values)->map(function ($value, $key) use ($keys) {
+ return $this->handleManyResult($keys, $key, $value);
+ })->all();
+ }
+
+ /**
+ * Handle a result for the "many" method.
+ *
+ * @param array $keys
+ * @param string $key
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function handleManyResult($keys, $key, $value)
+ {
+ // If we could not find the cache value, we will fire the missed event and get
+ // the default value for this cache value. This default could be a callback
+ // so we will execute the value function which will resolve it if needed.
+ if (is_null($value)) {
+ $this->event(new CacheMissed($key));
+
+ return isset($keys[$key]) ? value($keys[$key]) : null;
+ }
+
+ // If we found a valid value we will fire the "hit" event and return the value
+ // back from this function. The "hit" event gives developers an opportunity
+ // to listen for every possible cache "hit" throughout this applications.
+ $this->event(new CacheHit($key, $value));
+
+ return $value;
+ }
+
+ /**
+ * Retrieve an item from the cache and delete it.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public function pull($key, $default = null)
+ {
+ return tap($this->get($key, $default), function ($value) use ($key) {
+ $this->forget($key);
+ });
+ }
+
+ /**
+ * Store an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param \DateTime|float|int $minutes
+ * @return void
+ */
+ public function put($key, $value, $minutes = null)
+ {
+ if (is_array($key)) {
+ return $this->putMany($key, $value);
+ }
+
+ if (! is_null($minutes = $this->getMinutes($minutes))) {
+ $this->store->put($this->itemKey($key), $value, $minutes);
+
+ $this->event(new KeyWritten($key, $value, $minutes));
+ }
+ }
+
+ /**
+ * Store multiple items in the cache for a given number of minutes.
+ *
+ * @param array $values
+ * @param float|int $minutes
+ * @return void
+ */
+ public function putMany(array $values, $minutes)
+ {
+ if (! is_null($minutes = $this->getMinutes($minutes))) {
+ $this->store->putMany($values, $minutes);
+
+ foreach ($values as $key => $value) {
+ $this->event(new KeyWritten($key, $value, $minutes));
+ }
+ }
+ }
+
+ /**
+ * Store an item in the cache if the key does not exist.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param \DateTime|float|int $minutes
+ * @return bool
+ */
+ public function add($key, $value, $minutes)
+ {
+ if (is_null($minutes = $this->getMinutes($minutes))) {
+ return false;
+ }
+
+ // If the store has an "add" method we will call the method on the store so it
+ // has a chance to override this logic. Some drivers better support the way
+ // this operation should work with a total "atomic" implementation of it.
+ if (method_exists($this->store, 'add')) {
+ return $this->store->add(
+ $this->itemKey($key), $value, $minutes
+ );
+ }
+
+ // If the value did not exist in the cache, we will put the value in the cache
+ // so it exists for subsequent requests. Then, we will return true so it is
+ // easy to know if the value gets added. Otherwise, we will return false.
+ if (is_null($this->get($key))) {
+ $this->put($key, $value, $minutes);
+
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * Increment the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int|bool
+ */
+ public function increment($key, $value = 1)
+ {
+ return $this->store->increment($key, $value);
+ }
+
+ /**
+ * Decrement the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return int|bool
+ */
+ public function decrement($key, $value = 1)
+ {
+ return $this->store->decrement($key, $value);
+ }
+
+ /**
+ * Store an item in the cache indefinitely.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function forever($key, $value)
+ {
+ $this->store->forever($this->itemKey($key), $value);
+
+ $this->event(new KeyWritten($key, $value, 0));
+ }
+
+ /**
+ * Get an item from the cache, or store the default value.
+ *
+ * @param string $key
+ * @param \DateTime|float|int $minutes
+ * @param \Closure $callback
+ * @return mixed
+ */
+ public function remember($key, $minutes, Closure $callback)
+ {
+ $value = $this->get($key);
+
+ // If the item exists in the cache we will just return this immediately and if
+ // not we will execute the given Closure and cache the result of that for a
+ // given number of minutes so it's available for all subsequent requests.
+ if (! is_null($value)) {
+ return $value;
+ }
+
+ $this->put($key, $value = $callback(), $minutes);
+
+ return $value;
+ }
+
+ /**
+ * Get an item from the cache, or store the default value forever.
+ *
+ * @param string $key
+ * @param \Closure $callback
+ * @return mixed
+ */
+ public function sear($key, Closure $callback)
+ {
+ return $this->rememberForever($key, $callback);
+ }
+
+ /**
+ * Get an item from the cache, or store the default value forever.
+ *
+ * @param string $key
+ * @param \Closure $callback
+ * @return mixed
+ */
+ public function rememberForever($key, Closure $callback)
+ {
+ $value = $this->get($key);
+
+ // If the item exists in the cache we will just return this immediately and if
+ // not we will execute the given Closure and cache the result of that for a
+ // given number of minutes so it's available for all subsequent requests.
+ if (! is_null($value)) {
+ return $value;
+ }
+
+ $this->forever($key, $value = $callback());
+
+ return $value;
+ }
+
+ /**
+ * Remove an item from the cache.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function forget($key)
+ {
+ return tap($this->store->forget($this->itemKey($key)), function () use ($key) {
+ $this->event(new KeyForgotten($key));
+ });
+ }
+
+ /**
+ * Begin executing a new tags operation if the store supports it.
+ *
+ * @param array|mixed $names
+ * @return \Illuminate\Cache\TaggedCache
+ *
+ * @throws \BadMethodCallException
+ */
+ public function tags($names)
+ {
+ if (! method_exists($this->store, 'tags')) {
+ throw new BadMethodCallException('This cache store does not support tagging.');
+ }
+
+ $cache = $this->store->tags($names);
+
+ if (! is_null($this->events)) {
+ $cache->setEventDispatcher($this->events);
+ }
+
+ return $cache->setDefaultCacheTime($this->default);
+ }
+
+ /**
+ * Format the key for a cache item.
+ *
+ * @param string $key
+ * @return string
+ */
+ protected function itemKey($key)
+ {
+ return $key;
+ }
+
+ /**
+ * Get the default cache time.
+ *
+ * @return float|int
+ */
+ public function getDefaultCacheTime()
+ {
+ return $this->default;
+ }
+
+ /**
+ * Set the default cache time in minutes.
+ *
+ * @param float|int $minutes
+ * @return $this
+ */
+ public function setDefaultCacheTime($minutes)
+ {
+ $this->default = $minutes;
+
+ return $this;
+ }
+
+ /**
+ * Get the cache store implementation.
+ *
+ * @return \Illuminate\Contracts\Cache\Store
+ */
+ public function getStore()
+ {
+ return $this->store;
+ }
+
+ /**
+ * Fire an event for this cache instance.
+ *
+ * @param string $event
+ * @return void
+ */
+ protected function event($event)
+ {
+ if (isset($this->events)) {
+ $this->events->dispatch($event);
+ }
+ }
+
+ /**
+ * Set the event dispatcher instance.
+ *
+ * @param \Illuminate\Contracts\Events\Dispatcher $events
+ * @return void
+ */
+ public function setEventDispatcher(Dispatcher $events)
+ {
+ $this->events = $events;
+ }
+
+ /**
+ * Determine if a cached value exists.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function offsetExists($key)
+ {
+ return $this->has($key);
+ }
+
+ /**
+ * Retrieve an item from the cache by key.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function offsetGet($key)
+ {
+ return $this->get($key);
+ }
+
+ /**
+ * Store an item in the cache for the default time.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function offsetSet($key, $value)
+ {
+ $this->put($key, $value, $this->default);
+ }
+
+ /**
+ * Remove an item from the cache.
+ *
+ * @param string $key
+ * @return void
+ */
+ public function offsetUnset($key)
+ {
+ $this->forget($key);
+ }
+
+ /**
+ * Calculate the number of minutes with the given duration.
+ *
+ * @param \DateTime|float|int $duration
+ * @return float|int|null
+ */
+ protected function getMinutes($duration)
+ {
+ if ($duration instanceof DateTime) {
+ $duration = Carbon::now()->diffInSeconds(Carbon::instance($duration), false) / 60;
+ }
+
+ return (int) ($duration * 60) > 0 ? $duration : null;
+ }
+
+ /**
+ * Handle dynamic calls into macros or pass missing methods to the store.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ if (static::hasMacro($method)) {
+ return $this->macroCall($method, $parameters);
+ }
+
+ return $this->store->$method(...$parameters);
+ }
+
+ /**
+ * Clone cache repository instance.
+ *
+ * @return void
+ */
+ public function __clone()
+ {
+ $this->store = clone $this->store;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/RetrievesMultipleKeys.php b/vendor/laravel/framework/src/Illuminate/Cache/RetrievesMultipleKeys.php
new file mode 100644
index 000000000..4d4679755
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/RetrievesMultipleKeys.php
@@ -0,0 +1,39 @@
+get($key);
+ }
+
+ return $return;
+ }
+
+ /**
+ * Store multiple items in the cache for a given number of minutes.
+ *
+ * @param array $values
+ * @param float|int $minutes
+ * @return void
+ */
+ public function putMany(array $values, $minutes)
+ {
+ foreach ($values as $key => $value) {
+ $this->put($key, $value, $minutes);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/TagSet.php b/vendor/laravel/framework/src/Illuminate/Cache/TagSet.php
new file mode 100644
index 000000000..214d64815
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/TagSet.php
@@ -0,0 +1,110 @@
+store = $store;
+ $this->names = $names;
+ }
+
+ /**
+ * Reset all tags in the set.
+ *
+ * @return void
+ */
+ public function reset()
+ {
+ array_walk($this->names, [$this, 'resetTag']);
+ }
+
+ /**
+ * Reset the tag and return the new tag identifier.
+ *
+ * @param string $name
+ * @return string
+ */
+ public function resetTag($name)
+ {
+ $this->store->forever($this->tagKey($name), $id = str_replace('.', '', uniqid('', true)));
+
+ return $id;
+ }
+
+ /**
+ * Get a unique namespace that changes when any of the tags are flushed.
+ *
+ * @return string
+ */
+ public function getNamespace()
+ {
+ return implode('|', $this->tagIds());
+ }
+
+ /**
+ * Get an array of tag identifiers for all of the tags in the set.
+ *
+ * @return array
+ */
+ protected function tagIds()
+ {
+ return array_map([$this, 'tagId'], $this->names);
+ }
+
+ /**
+ * Get the unique tag identifier for a given tag.
+ *
+ * @param string $name
+ * @return string
+ */
+ public function tagId($name)
+ {
+ return $this->store->get($this->tagKey($name)) ?: $this->resetTag($name);
+ }
+
+ /**
+ * Get the tag identifier key for a given tag.
+ *
+ * @param string $name
+ * @return string
+ */
+ public function tagKey($name)
+ {
+ return 'tag:'.$name.':key';
+ }
+
+ /**
+ * Get all of the tag names in the set.
+ *
+ * @return array
+ */
+ public function getNames()
+ {
+ return $this->names;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/TaggableStore.php b/vendor/laravel/framework/src/Illuminate/Cache/TaggableStore.php
new file mode 100644
index 000000000..ba00fa450
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/TaggableStore.php
@@ -0,0 +1,17 @@
+tags = $tags;
+ }
+
+ /**
+ * Increment the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function increment($key, $value = 1)
+ {
+ $this->store->increment($this->itemKey($key), $value);
+ }
+
+ /**
+ * Increment the value of an item in the cache.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function decrement($key, $value = 1)
+ {
+ $this->store->decrement($this->itemKey($key), $value);
+ }
+
+ /**
+ * Remove all items from the cache.
+ *
+ * @return void
+ */
+ public function flush()
+ {
+ $this->tags->reset();
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function itemKey($key)
+ {
+ return $this->taggedItemKey($key);
+ }
+
+ /**
+ * Get a fully qualified key for a tagged item.
+ *
+ * @param string $key
+ * @return string
+ */
+ public function taggedItemKey($key)
+ {
+ return sha1($this->tags->getNamespace()).':'.$key;
+ }
+
+ /**
+ * Fire an event for this cache instance.
+ *
+ * @param string $event
+ * @return void
+ */
+ protected function event($event)
+ {
+ parent::event($event->setTags($this->tags->getNames()));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cache/composer.json b/vendor/laravel/framework/src/Illuminate/Cache/composer.json
new file mode 100644
index 000000000..0b9f812fa
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cache/composer.json
@@ -0,0 +1,41 @@
+{
+ "name": "illuminate/cache",
+ "description": "The Illuminate Cache package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "nesbot/carbon": "~1.20"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Cache\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "illuminate/database": "Required to use the database cache driver (5.4.*).",
+ "illuminate/filesystem": "Required to use the file cache driver (5.4.*).",
+ "illuminate/redis": "Required to use the redis cache driver (5.4.*)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Config/Repository.php b/vendor/laravel/framework/src/Illuminate/Config/Repository.php
new file mode 100644
index 000000000..2c00686a4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Config/Repository.php
@@ -0,0 +1,154 @@
+items = $items;
+ }
+
+ /**
+ * Determine if the given configuration value exists.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function has($key)
+ {
+ return Arr::has($this->items, $key);
+ }
+
+ /**
+ * Get the specified configuration value.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public function get($key, $default = null)
+ {
+ return Arr::get($this->items, $key, $default);
+ }
+
+ /**
+ * Set a given configuration value.
+ *
+ * @param array|string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function set($key, $value = null)
+ {
+ $keys = is_array($key) ? $key : [$key => $value];
+
+ foreach ($keys as $key => $value) {
+ Arr::set($this->items, $key, $value);
+ }
+ }
+
+ /**
+ * Prepend a value onto an array configuration value.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function prepend($key, $value)
+ {
+ $array = $this->get($key);
+
+ array_unshift($array, $value);
+
+ $this->set($key, $array);
+ }
+
+ /**
+ * Push a value onto an array configuration value.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function push($key, $value)
+ {
+ $array = $this->get($key);
+
+ $array[] = $value;
+
+ $this->set($key, $array);
+ }
+
+ /**
+ * Get all of the configuration items for the application.
+ *
+ * @return array
+ */
+ public function all()
+ {
+ return $this->items;
+ }
+
+ /**
+ * Determine if the given configuration option exists.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function offsetExists($key)
+ {
+ return $this->has($key);
+ }
+
+ /**
+ * Get a configuration option.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function offsetGet($key)
+ {
+ return $this->get($key);
+ }
+
+ /**
+ * Set a configuration option.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function offsetSet($key, $value)
+ {
+ $this->set($key, $value);
+ }
+
+ /**
+ * Unset a configuration option.
+ *
+ * @param string $key
+ * @return void
+ */
+ public function offsetUnset($key)
+ {
+ $this->set($key, null);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Config/composer.json b/vendor/laravel/framework/src/Illuminate/Config/composer.json
new file mode 100644
index 000000000..69ab6e777
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Config/composer.json
@@ -0,0 +1,35 @@
+{
+ "name": "illuminate/config",
+ "description": "The Illuminate Config package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Config\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Application.php b/vendor/laravel/framework/src/Illuminate/Console/Application.php
new file mode 100644
index 000000000..820b16e63
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Application.php
@@ -0,0 +1,247 @@
+laravel = $laravel;
+ $this->setAutoExit(false);
+ $this->setCatchExceptions(false);
+
+ $events->dispatch(new Events\ArtisanStarting($this));
+
+ $this->bootstrap();
+ }
+
+ /**
+ * Determine the proper PHP executable.
+ *
+ * @return string
+ */
+ public static function phpBinary()
+ {
+ return ProcessUtils::escapeArgument((new PhpExecutableFinder)->find(false));
+ }
+
+ /**
+ * Determine the proper Artisan executable.
+ *
+ * @return string
+ */
+ public static function artisanBinary()
+ {
+ return defined('ARTISAN_BINARY') ? ProcessUtils::escapeArgument(ARTISAN_BINARY) : 'artisan';
+ }
+
+ /**
+ * Format the given command as a fully-qualified executable command.
+ *
+ * @param string $string
+ * @return string
+ */
+ public static function formatCommandString($string)
+ {
+ return sprintf('%s %s %s', static::phpBinary(), static::artisanBinary(), $string);
+ }
+
+ /**
+ * Register a console "starting" bootstrapper.
+ *
+ * @param \Closure $callback
+ * @return void
+ */
+ public static function starting(Closure $callback)
+ {
+ static::$bootstrappers[] = $callback;
+ }
+
+ /**
+ * Bootstrap the console application.
+ *
+ * @return void
+ */
+ protected function bootstrap()
+ {
+ foreach (static::$bootstrappers as $bootstrapper) {
+ $bootstrapper($this);
+ }
+ }
+
+ /**
+ * Clear the console application bootstrappers.
+ *
+ * @return void
+ */
+ public static function forgetBootstrappers()
+ {
+ static::$bootstrappers = [];
+ }
+
+ /**
+ * Run an Artisan console command by name.
+ *
+ * @param string $command
+ * @param array $parameters
+ * @param \Symfony\Component\Console\Output\OutputInterface $outputBuffer
+ * @return int
+ */
+ public function call($command, array $parameters = [], $outputBuffer = null)
+ {
+ $parameters = collect($parameters)->prepend($command);
+
+ $this->lastOutput = $outputBuffer ?: new BufferedOutput;
+
+ $this->setCatchExceptions(false);
+
+ $result = $this->run(new ArrayInput($parameters->toArray()), $this->lastOutput);
+
+ $this->setCatchExceptions(true);
+
+ return $result;
+ }
+
+ /**
+ * Get the output for the last run command.
+ *
+ * @return string
+ */
+ public function output()
+ {
+ return $this->lastOutput ? $this->lastOutput->fetch() : '';
+ }
+
+ /**
+ * Add a command to the console.
+ *
+ * @param \Symfony\Component\Console\Command\Command $command
+ * @return \Symfony\Component\Console\Command\Command
+ */
+ public function add(SymfonyCommand $command)
+ {
+ if ($command instanceof Command) {
+ $command->setLaravel($this->laravel);
+ }
+
+ return $this->addToParent($command);
+ }
+
+ /**
+ * Add the command to the parent instance.
+ *
+ * @param \Symfony\Component\Console\Command\Command $command
+ * @return \Symfony\Component\Console\Command\Command
+ */
+ protected function addToParent(SymfonyCommand $command)
+ {
+ return parent::add($command);
+ }
+
+ /**
+ * Add a command, resolving through the application.
+ *
+ * @param string $command
+ * @return \Symfony\Component\Console\Command\Command
+ */
+ public function resolve($command)
+ {
+ return $this->add($this->laravel->make($command));
+ }
+
+ /**
+ * Resolve an array of commands through the application.
+ *
+ * @param array|mixed $commands
+ * @return $this
+ */
+ public function resolveCommands($commands)
+ {
+ $commands = is_array($commands) ? $commands : func_get_args();
+
+ foreach ($commands as $command) {
+ $this->resolve($command);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Get the default input definitions for the applications.
+ *
+ * This is used to add the --env option to every available command.
+ *
+ * @return \Symfony\Component\Console\Input\InputDefinition
+ */
+ protected function getDefaultInputDefinition()
+ {
+ return tap(parent::getDefaultInputDefinition(), function ($definition) {
+ $definition->addOption($this->getEnvironmentOption());
+ });
+ }
+
+ /**
+ * Get the global environment option for the definition.
+ *
+ * @return \Symfony\Component\Console\Input\InputOption
+ */
+ protected function getEnvironmentOption()
+ {
+ $message = 'The environment the command should run under';
+
+ return new InputOption('--env', null, InputOption::VALUE_OPTIONAL, $message);
+ }
+
+ /**
+ * Get the Laravel application instance.
+ *
+ * @return \Illuminate\Contracts\Foundation\Application
+ */
+ public function getLaravel()
+ {
+ return $this->laravel;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Command.php b/vendor/laravel/framework/src/Illuminate/Console/Command.php
new file mode 100644
index 000000000..d0f09b383
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Command.php
@@ -0,0 +1,571 @@
+ OutputInterface::VERBOSITY_VERBOSE,
+ 'vv' => OutputInterface::VERBOSITY_VERY_VERBOSE,
+ 'vvv' => OutputInterface::VERBOSITY_DEBUG,
+ 'quiet' => OutputInterface::VERBOSITY_QUIET,
+ 'normal' => OutputInterface::VERBOSITY_NORMAL,
+ ];
+
+ /**
+ * Create a new console command instance.
+ *
+ * @return void
+ */
+ public function __construct()
+ {
+ // We will go ahead and set the name, description, and parameters on console
+ // commands just to make things a little easier on the developer. This is
+ // so they don't have to all be manually specified in the constructors.
+ if (isset($this->signature)) {
+ $this->configureUsingFluentDefinition();
+ } else {
+ parent::__construct($this->name);
+ }
+
+ // Once we have constructed the command, we'll set the description and other
+ // related properties of the command. If a signature wasn't used to build
+ // the command we'll set the arguments and the options on this command.
+ $this->setDescription($this->description);
+
+ $this->setHidden($this->hidden);
+
+ if (! isset($this->signature)) {
+ $this->specifyParameters();
+ }
+ }
+
+ /**
+ * Configure the console command using a fluent definition.
+ *
+ * @return void
+ */
+ protected function configureUsingFluentDefinition()
+ {
+ list($name, $arguments, $options) = Parser::parse($this->signature);
+
+ parent::__construct($this->name = $name);
+
+ // After parsing the signature we will spin through the arguments and options
+ // and set them on this command. These will already be changed into proper
+ // instances of these "InputArgument" and "InputOption" Symfony classes.
+ foreach ($arguments as $argument) {
+ $this->getDefinition()->addArgument($argument);
+ }
+
+ foreach ($options as $option) {
+ $this->getDefinition()->addOption($option);
+ }
+ }
+
+ /**
+ * Specify the arguments and options on the command.
+ *
+ * @return void
+ */
+ protected function specifyParameters()
+ {
+ // We will loop through all of the arguments and options for the command and
+ // set them all on the base command instance. This specifies what can get
+ // passed into these commands as "parameters" to control the execution.
+ foreach ($this->getArguments() as $arguments) {
+ call_user_func_array([$this, 'addArgument'], $arguments);
+ }
+
+ foreach ($this->getOptions() as $options) {
+ call_user_func_array([$this, 'addOption'], $options);
+ }
+ }
+
+ /**
+ * Run the console command.
+ *
+ * @param \Symfony\Component\Console\Input\InputInterface $input
+ * @param \Symfony\Component\Console\Output\OutputInterface $output
+ * @return int
+ */
+ public function run(InputInterface $input, OutputInterface $output)
+ {
+ return parent::run(
+ $this->input = $input, $this->output = new OutputStyle($input, $output)
+ );
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @param \Symfony\Component\Console\Input\InputInterface $input
+ * @param \Symfony\Component\Console\Output\OutputInterface $output
+ * @return mixed
+ */
+ protected function execute(InputInterface $input, OutputInterface $output)
+ {
+ $method = method_exists($this, 'handle') ? 'handle' : 'fire';
+
+ return $this->laravel->call([$this, $method]);
+ }
+
+ /**
+ * Call another console command.
+ *
+ * @param string $command
+ * @param array $arguments
+ * @return int
+ */
+ public function call($command, array $arguments = [])
+ {
+ $arguments['command'] = $command;
+
+ return $this->getApplication()->find($command)->run(
+ new ArrayInput($arguments), $this->output
+ );
+ }
+
+ /**
+ * Call another console command silently.
+ *
+ * @param string $command
+ * @param array $arguments
+ * @return int
+ */
+ public function callSilent($command, array $arguments = [])
+ {
+ $arguments['command'] = $command;
+
+ return $this->getApplication()->find($command)->run(
+ new ArrayInput($arguments), new NullOutput
+ );
+ }
+
+ /**
+ * Determine if the given argument is present.
+ *
+ * @param string|int $name
+ * @return bool
+ */
+ public function hasArgument($name)
+ {
+ return $this->input->hasArgument($name);
+ }
+
+ /**
+ * Get the value of a command argument.
+ *
+ * @param string|null $key
+ * @return string|array
+ */
+ public function argument($key = null)
+ {
+ if (is_null($key)) {
+ return $this->input->getArguments();
+ }
+
+ return $this->input->getArgument($key);
+ }
+
+ /**
+ * Get all of the arguments passed to the command.
+ *
+ * @return array
+ */
+ public function arguments()
+ {
+ return $this->argument();
+ }
+
+ /**
+ * Determine if the given option is present.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function hasOption($name)
+ {
+ return $this->input->hasOption($name);
+ }
+
+ /**
+ * Get the value of a command option.
+ *
+ * @param string $key
+ * @return string|array
+ */
+ public function option($key = null)
+ {
+ if (is_null($key)) {
+ return $this->input->getOptions();
+ }
+
+ return $this->input->getOption($key);
+ }
+
+ /**
+ * Get all of the options passed to the command.
+ *
+ * @return array
+ */
+ public function options()
+ {
+ return $this->option();
+ }
+
+ /**
+ * Confirm a question with the user.
+ *
+ * @param string $question
+ * @param bool $default
+ * @return bool
+ */
+ public function confirm($question, $default = false)
+ {
+ return $this->output->confirm($question, $default);
+ }
+
+ /**
+ * Prompt the user for input.
+ *
+ * @param string $question
+ * @param string $default
+ * @return string
+ */
+ public function ask($question, $default = null)
+ {
+ return $this->output->ask($question, $default);
+ }
+
+ /**
+ * Prompt the user for input with auto completion.
+ *
+ * @param string $question
+ * @param array $choices
+ * @param string $default
+ * @return string
+ */
+ public function anticipate($question, array $choices, $default = null)
+ {
+ return $this->askWithCompletion($question, $choices, $default);
+ }
+
+ /**
+ * Prompt the user for input with auto completion.
+ *
+ * @param string $question
+ * @param array $choices
+ * @param string $default
+ * @return string
+ */
+ public function askWithCompletion($question, array $choices, $default = null)
+ {
+ $question = new Question($question, $default);
+
+ $question->setAutocompleterValues($choices);
+
+ return $this->output->askQuestion($question);
+ }
+
+ /**
+ * Prompt the user for input but hide the answer from the console.
+ *
+ * @param string $question
+ * @param bool $fallback
+ * @return string
+ */
+ public function secret($question, $fallback = true)
+ {
+ $question = new Question($question);
+
+ $question->setHidden(true)->setHiddenFallback($fallback);
+
+ return $this->output->askQuestion($question);
+ }
+
+ /**
+ * Give the user a single choice from an array of answers.
+ *
+ * @param string $question
+ * @param array $choices
+ * @param string $default
+ * @param mixed $attempts
+ * @param bool $multiple
+ * @return string
+ */
+ public function choice($question, array $choices, $default = null, $attempts = null, $multiple = null)
+ {
+ $question = new ChoiceQuestion($question, $choices, $default);
+
+ $question->setMaxAttempts($attempts)->setMultiselect($multiple);
+
+ return $this->output->askQuestion($question);
+ }
+
+ /**
+ * Format input to textual table.
+ *
+ * @param array $headers
+ * @param \Illuminate\Contracts\Support\Arrayable|array $rows
+ * @param string $style
+ * @return void
+ */
+ public function table(array $headers, $rows, $style = 'default')
+ {
+ $table = new Table($this->output);
+
+ if ($rows instanceof Arrayable) {
+ $rows = $rows->toArray();
+ }
+
+ $table->setHeaders($headers)->setRows($rows)->setStyle($style)->render();
+ }
+
+ /**
+ * Write a string as information output.
+ *
+ * @param string $string
+ * @param null|int|string $verbosity
+ * @return void
+ */
+ public function info($string, $verbosity = null)
+ {
+ $this->line($string, 'info', $verbosity);
+ }
+
+ /**
+ * Write a string as standard output.
+ *
+ * @param string $string
+ * @param string $style
+ * @param null|int|string $verbosity
+ * @return void
+ */
+ public function line($string, $style = null, $verbosity = null)
+ {
+ $styled = $style ? "<$style>$string$style>" : $string;
+
+ $this->output->writeln($styled, $this->parseVerbosity($verbosity));
+ }
+
+ /**
+ * Write a string as comment output.
+ *
+ * @param string $string
+ * @param null|int|string $verbosity
+ * @return void
+ */
+ public function comment($string, $verbosity = null)
+ {
+ $this->line($string, 'comment', $verbosity);
+ }
+
+ /**
+ * Write a string as question output.
+ *
+ * @param string $string
+ * @param null|int|string $verbosity
+ * @return void
+ */
+ public function question($string, $verbosity = null)
+ {
+ $this->line($string, 'question', $verbosity);
+ }
+
+ /**
+ * Write a string as error output.
+ *
+ * @param string $string
+ * @param null|int|string $verbosity
+ * @return void
+ */
+ public function error($string, $verbosity = null)
+ {
+ $this->line($string, 'error', $verbosity);
+ }
+
+ /**
+ * Write a string as warning output.
+ *
+ * @param string $string
+ * @param null|int|string $verbosity
+ * @return void
+ */
+ public function warn($string, $verbosity = null)
+ {
+ if (! $this->output->getFormatter()->hasStyle('warning')) {
+ $style = new OutputFormatterStyle('yellow');
+
+ $this->output->getFormatter()->setStyle('warning', $style);
+ }
+
+ $this->line($string, 'warning', $verbosity);
+ }
+
+ /**
+ * Write a string in an alert box.
+ *
+ * @param string $string
+ * @return void
+ */
+ public function alert($string)
+ {
+ $this->comment(str_repeat('*', strlen($string) + 12));
+ $this->comment('* '.$string.' *');
+ $this->comment(str_repeat('*', strlen($string) + 12));
+
+ $this->output->writeln('');
+ }
+
+ /**
+ * Set the verbosity level.
+ *
+ * @param string|int $level
+ * @return void
+ */
+ protected function setVerbosity($level)
+ {
+ $this->verbosity = $this->parseVerbosity($level);
+ }
+
+ /**
+ * Get the verbosity level in terms of Symfony's OutputInterface level.
+ *
+ * @param string|int $level
+ * @return int
+ */
+ protected function parseVerbosity($level = null)
+ {
+ if (isset($this->verbosityMap[$level])) {
+ $level = $this->verbosityMap[$level];
+ } elseif (! is_int($level)) {
+ $level = $this->verbosity;
+ }
+
+ return $level;
+ }
+
+ /**
+ * Get the console command arguments.
+ *
+ * @return array
+ */
+ protected function getArguments()
+ {
+ return [];
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [];
+ }
+
+ /**
+ * Get the output implementation.
+ *
+ * @return \Symfony\Component\Console\Output\OutputInterface
+ */
+ public function getOutput()
+ {
+ return $this->output;
+ }
+
+ /**
+ * Get the Laravel application instance.
+ *
+ * @return \Illuminate\Contracts\Foundation\Application
+ */
+ public function getLaravel()
+ {
+ return $this->laravel;
+ }
+
+ /**
+ * Set the Laravel application instance.
+ *
+ * @param \Illuminate\Contracts\Container\Container $laravel
+ * @return void
+ */
+ public function setLaravel($laravel)
+ {
+ $this->laravel = $laravel;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/ConfirmableTrait.php b/vendor/laravel/framework/src/Illuminate/Console/ConfirmableTrait.php
new file mode 100644
index 000000000..717221530
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/ConfirmableTrait.php
@@ -0,0 +1,54 @@
+getDefaultConfirmCallback() : $callback;
+
+ $shouldConfirm = $callback instanceof Closure ? call_user_func($callback) : $callback;
+
+ if ($shouldConfirm) {
+ if ($this->option('force')) {
+ return true;
+ }
+
+ $this->alert($warning);
+
+ $confirmed = $this->confirm('Do you really wish to run this command?');
+
+ if (! $confirmed) {
+ $this->comment('Command Cancelled!');
+
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Get the default confirmation callback.
+ *
+ * @return \Closure
+ */
+ protected function getDefaultConfirmCallback()
+ {
+ return function () {
+ return $this->getLaravel()->environment() == 'production';
+ };
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/DetectsApplicationNamespace.php b/vendor/laravel/framework/src/Illuminate/Console/DetectsApplicationNamespace.php
new file mode 100644
index 000000000..cb5e8e849
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/DetectsApplicationNamespace.php
@@ -0,0 +1,18 @@
+getNamespace();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Events/ArtisanStarting.php b/vendor/laravel/framework/src/Illuminate/Console/Events/ArtisanStarting.php
new file mode 100644
index 000000000..f228ac529
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Events/ArtisanStarting.php
@@ -0,0 +1,24 @@
+artisan = $artisan;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/GeneratorCommand.php b/vendor/laravel/framework/src/Illuminate/Console/GeneratorCommand.php
new file mode 100644
index 000000000..c9522e7f1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/GeneratorCommand.php
@@ -0,0 +1,233 @@
+files = $files;
+ }
+
+ /**
+ * Get the stub file for the generator.
+ *
+ * @return string
+ */
+ abstract protected function getStub();
+
+ /**
+ * Execute the console command.
+ *
+ * @return bool|null
+ */
+ public function fire()
+ {
+ $name = $this->qualifyClass($this->getNameInput());
+
+ $path = $this->getPath($name);
+
+ // First we will check to see if the class already exists. If it does, we don't want
+ // to create the class and overwrite the user's code. So, we will bail out so the
+ // code is untouched. Otherwise, we will continue generating this class' files.
+ if ($this->alreadyExists($this->getNameInput())) {
+ $this->error($this->type.' already exists!');
+
+ return false;
+ }
+
+ // Next, we will generate the path to the location where this class' file should get
+ // written. Then, we will build the class and make the proper replacements on the
+ // stub files so that it gets the correctly formatted namespace and class name.
+ $this->makeDirectory($path);
+
+ $this->files->put($path, $this->buildClass($name));
+
+ $this->info($this->type.' created successfully.');
+ }
+
+ /**
+ * Parse the class name and format according to the root namespace.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function qualifyClass($name)
+ {
+ $rootNamespace = $this->rootNamespace();
+
+ if (Str::startsWith($name, $rootNamespace)) {
+ return $name;
+ }
+
+ $name = str_replace('/', '\\', $name);
+
+ return $this->qualifyClass(
+ $this->getDefaultNamespace(trim($rootNamespace, '\\')).'\\'.$name
+ );
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ return $rootNamespace;
+ }
+
+ /**
+ * Determine if the class already exists.
+ *
+ * @param string $rawName
+ * @return bool
+ */
+ protected function alreadyExists($rawName)
+ {
+ return $this->files->exists($this->getPath($this->qualifyClass($rawName)));
+ }
+
+ /**
+ * Get the destination class path.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function getPath($name)
+ {
+ $name = str_replace_first($this->rootNamespace(), '', $name);
+
+ return $this->laravel['path'].'/'.str_replace('\\', '/', $name).'.php';
+ }
+
+ /**
+ * Build the directory for the class if necessary.
+ *
+ * @param string $path
+ * @return string
+ */
+ protected function makeDirectory($path)
+ {
+ if (! $this->files->isDirectory(dirname($path))) {
+ $this->files->makeDirectory(dirname($path), 0777, true, true);
+ }
+
+ return $path;
+ }
+
+ /**
+ * Build the class with the given name.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function buildClass($name)
+ {
+ $stub = $this->files->get($this->getStub());
+
+ return $this->replaceNamespace($stub, $name)->replaceClass($stub, $name);
+ }
+
+ /**
+ * Replace the namespace for the given stub.
+ *
+ * @param string $stub
+ * @param string $name
+ * @return $this
+ */
+ protected function replaceNamespace(&$stub, $name)
+ {
+ $stub = str_replace(
+ ['DummyNamespace', 'DummyRootNamespace'],
+ [$this->getNamespace($name), $this->rootNamespace()],
+ $stub
+ );
+
+ return $this;
+ }
+
+ /**
+ * Get the full namespace for a given class, without the class name.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function getNamespace($name)
+ {
+ return trim(implode('\\', array_slice(explode('\\', $name), 0, -1)), '\\');
+ }
+
+ /**
+ * Replace the class name for the given stub.
+ *
+ * @param string $stub
+ * @param string $name
+ * @return string
+ */
+ protected function replaceClass($stub, $name)
+ {
+ $class = str_replace($this->getNamespace($name).'\\', '', $name);
+
+ return str_replace('DummyClass', $class, $stub);
+ }
+
+ /**
+ * Get the desired class name from the input.
+ *
+ * @return string
+ */
+ protected function getNameInput()
+ {
+ return trim($this->argument('name'));
+ }
+
+ /**
+ * Get the root namespace for the class.
+ *
+ * @return string
+ */
+ protected function rootNamespace()
+ {
+ return $this->laravel->getNamespace();
+ }
+
+ /**
+ * Get the console command arguments.
+ *
+ * @return array
+ */
+ protected function getArguments()
+ {
+ return [
+ ['name', InputArgument::REQUIRED, 'The name of the class'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/OutputStyle.php b/vendor/laravel/framework/src/Illuminate/Console/OutputStyle.php
new file mode 100644
index 000000000..925e66dac
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/OutputStyle.php
@@ -0,0 +1,71 @@
+output = $output;
+
+ parent::__construct($input, $output);
+ }
+
+ /**
+ * Returns whether verbosity is quiet (-q).
+ *
+ * @return bool
+ */
+ public function isQuiet()
+ {
+ return $this->output->isQuiet();
+ }
+
+ /**
+ * Returns whether verbosity is verbose (-v).
+ *
+ * @return bool
+ */
+ public function isVerbose()
+ {
+ return $this->output->isVerbose();
+ }
+
+ /**
+ * Returns whether verbosity is very verbose (-vv).
+ *
+ * @return bool
+ */
+ public function isVeryVerbose()
+ {
+ return $this->output->isVeryVerbose();
+ }
+
+ /**
+ * Returns whether verbosity is debug (-vvv).
+ *
+ * @return bool
+ */
+ public function isDebug()
+ {
+ return $this->output->isDebug();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Parser.php b/vendor/laravel/framework/src/Illuminate/Console/Parser.php
new file mode 100644
index 000000000..4ccc88dc3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Parser.php
@@ -0,0 +1,142 @@
+cache = $cache;
+ }
+
+ /**
+ * Attempt to obtain a mutex for the given event.
+ *
+ * @param \Illuminate\Console\Scheduling\Event $event
+ * @return bool
+ */
+ public function create(Event $event)
+ {
+ return $this->cache->add(
+ $event->mutexName(), true, $event->expiresAt
+ );
+ }
+
+ /**
+ * Determine if a mutex exists for the given event.
+ *
+ * @param \Illuminate\Console\Scheduling\Event $event
+ * @return bool
+ */
+ public function exists(Event $event)
+ {
+ return $this->cache->has($event->mutexName());
+ }
+
+ /**
+ * Clear the mutex for the given event.
+ *
+ * @param \Illuminate\Console\Scheduling\Event $event
+ * @return void
+ */
+ public function forget(Event $event)
+ {
+ $this->cache->forget($event->mutexName());
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Scheduling/CallbackEvent.php b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/CallbackEvent.php
new file mode 100644
index 000000000..50bfc13e8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/CallbackEvent.php
@@ -0,0 +1,136 @@
+mutex = $mutex;
+ $this->callback = $callback;
+ $this->parameters = $parameters;
+ }
+
+ /**
+ * Run the given event.
+ *
+ * @param \Illuminate\Contracts\Container\Container $container
+ * @return mixed
+ *
+ * @throws \Exception
+ */
+ public function run(Container $container)
+ {
+ if ($this->description && $this->withoutOverlapping &&
+ ! $this->mutex->create($this)) {
+ return;
+ }
+
+ register_shutdown_function(function () {
+ $this->removeMutex();
+ });
+
+ try {
+ $response = $container->call($this->callback, $this->parameters);
+ } finally {
+ $this->removeMutex();
+ }
+
+ parent::callAfterCallbacks($container);
+
+ return $response;
+ }
+
+ /**
+ * Clear the mutex for the event.
+ *
+ * @return void
+ */
+ protected function removeMutex()
+ {
+ if ($this->description) {
+ $this->mutex->forget($this);
+ }
+ }
+
+ /**
+ * Do not allow the event to overlap each other.
+ *
+ * @param int $expiresAt
+ * @return $this
+ */
+ public function withoutOverlapping($expiresAt = 1440)
+ {
+ if (! isset($this->description)) {
+ throw new LogicException(
+ "A scheduled event name is required to prevent overlapping. Use the 'name' method before 'withoutOverlapping'."
+ );
+ }
+
+ $this->withoutOverlapping = true;
+
+ $this->expiresAt = $expiresAt;
+
+ return $this->skip(function () {
+ return $this->mutex->exists($this);
+ });
+ }
+
+ /**
+ * Get the mutex name for the scheduled command.
+ *
+ * @return string
+ */
+ public function mutexName()
+ {
+ return 'framework/schedule-'.sha1($this->description);
+ }
+
+ /**
+ * Get the summary of the event for display.
+ *
+ * @return string
+ */
+ public function getSummaryForDisplay()
+ {
+ if (is_string($this->description)) {
+ return $this->description;
+ }
+
+ return is_string($this->callback) ? $this->callback : 'Closure';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Scheduling/CommandBuilder.php b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/CommandBuilder.php
new file mode 100644
index 000000000..acf60dd60
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/CommandBuilder.php
@@ -0,0 +1,71 @@
+runInBackground) {
+ return $this->buildBackgroundCommand($event);
+ } else {
+ return $this->buildForegroundCommand($event);
+ }
+ }
+
+ /**
+ * Build the command for running the event in the foreground.
+ *
+ * @param \Illuminate\Console\Scheduling\Event $event
+ * @return string
+ */
+ protected function buildForegroundCommand(Event $event)
+ {
+ $output = ProcessUtils::escapeArgument($event->output);
+
+ return $this->ensureCorrectUser(
+ $event, $event->command.($event->shouldAppendOutput ? ' >> ' : ' > ').$output.' 2>&1'
+ );
+ }
+
+ /**
+ * Build the command for running the event in the background.
+ *
+ * @param \Illuminate\Console\Scheduling\Event $event
+ * @return string
+ */
+ protected function buildBackgroundCommand(Event $event)
+ {
+ $output = ProcessUtils::escapeArgument($event->output);
+
+ $redirect = $event->shouldAppendOutput ? ' >> ' : ' > ';
+
+ $finished = Application::formatCommandString('schedule:finish').' "'.$event->mutexName().'"';
+
+ return $this->ensureCorrectUser($event,
+ '('.$event->command.$redirect.$output.' 2>&1 '.(windows_os() ? '&' : ';').' '.$finished.') > '
+ .ProcessUtils::escapeArgument($event->getDefaultOutput()).' 2>&1 &'
+ );
+ }
+
+ /**
+ * Finalize the event's command syntax with the correct user.
+ *
+ * @param \Illuminate\Console\Scheduling\Event $event
+ * @param string $command
+ * @return string
+ */
+ protected function ensureCorrectUser(Event $event, $command)
+ {
+ return $event->user && ! windows_os() ? 'sudo -u '.$event->user.' -- sh -c \''.$command.'\'' : $command;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Scheduling/Event.php b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/Event.php
new file mode 100644
index 000000000..bce490eb8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/Event.php
@@ -0,0 +1,673 @@
+mutex = $mutex;
+ $this->command = $command;
+ $this->output = $this->getDefaultOutput();
+ }
+
+ /**
+ * Get the default output depending on the OS.
+ *
+ * @return string
+ */
+ public function getDefaultOutput()
+ {
+ return (DIRECTORY_SEPARATOR == '\\') ? 'NUL' : '/dev/null';
+ }
+
+ /**
+ * Run the given event.
+ *
+ * @param \Illuminate\Contracts\Container\Container $container
+ * @return void
+ */
+ public function run(Container $container)
+ {
+ if ($this->withoutOverlapping &&
+ ! $this->mutex->create($this)) {
+ return;
+ }
+
+ $this->runInBackground
+ ? $this->runCommandInBackground($container)
+ : $this->runCommandInForeground($container);
+ }
+
+ /**
+ * Get the mutex name for the scheduled command.
+ *
+ * @return string
+ */
+ public function mutexName()
+ {
+ return 'framework'.DIRECTORY_SEPARATOR.'schedule-'.sha1($this->expression.$this->command);
+ }
+
+ /**
+ * Run the command in the foreground.
+ *
+ * @param \Illuminate\Contracts\Container\Container $container
+ * @return void
+ */
+ protected function runCommandInForeground(Container $container)
+ {
+ $this->callBeforeCallbacks($container);
+
+ (new Process(
+ $this->buildCommand(), base_path(), null, null, null
+ ))->run();
+
+ $this->callAfterCallbacks($container);
+ }
+
+ /**
+ * Run the command in the background.
+ *
+ * @param \Illuminate\Contracts\Container\Container $container
+ * @return void
+ */
+ protected function runCommandInBackground(Container $container)
+ {
+ $this->callBeforeCallbacks($container);
+
+ (new Process(
+ $this->buildCommand(), base_path(), null, null, null
+ ))->run();
+ }
+
+ /**
+ * Call all of the "before" callbacks for the event.
+ *
+ * @param \Illuminate\Contracts\Container\Container $container
+ * @return void
+ */
+ public function callBeforeCallbacks(Container $container)
+ {
+ foreach ($this->beforeCallbacks as $callback) {
+ $container->call($callback);
+ }
+ }
+
+ /**
+ * Call all of the "after" callbacks for the event.
+ *
+ * @param \Illuminate\Contracts\Container\Container $container
+ * @return void
+ */
+ public function callAfterCallbacks(Container $container)
+ {
+ foreach ($this->afterCallbacks as $callback) {
+ $container->call($callback);
+ }
+ }
+
+ /**
+ * Build the command string.
+ *
+ * @return string
+ */
+ public function buildCommand()
+ {
+ return (new CommandBuilder)->buildCommand($this);
+ }
+
+ /**
+ * Determine if the given event should run based on the Cron expression.
+ *
+ * @param \Illuminate\Contracts\Foundation\Application $app
+ * @return bool
+ */
+ public function isDue($app)
+ {
+ if (! $this->runsInMaintenanceMode() && $app->isDownForMaintenance()) {
+ return false;
+ }
+
+ return $this->expressionPasses() &&
+ $this->runsInEnvironment($app->environment());
+ }
+
+ /**
+ * Determine if the event runs in maintenance mode.
+ *
+ * @return bool
+ */
+ public function runsInMaintenanceMode()
+ {
+ return $this->evenInMaintenanceMode;
+ }
+
+ /**
+ * Determine if the Cron expression passes.
+ *
+ * @return bool
+ */
+ protected function expressionPasses()
+ {
+ $date = Carbon::now();
+
+ if ($this->timezone) {
+ $date->setTimezone($this->timezone);
+ }
+
+ return CronExpression::factory($this->expression)->isDue($date->toDateTimeString());
+ }
+
+ /**
+ * Determine if the event runs in the given environment.
+ *
+ * @param string $environment
+ * @return bool
+ */
+ public function runsInEnvironment($environment)
+ {
+ return empty($this->environments) || in_array($environment, $this->environments);
+ }
+
+ /**
+ * Determine if the filters pass for the event.
+ *
+ * @param \Illuminate\Contracts\Foundation\Application $app
+ * @return bool
+ */
+ public function filtersPass($app)
+ {
+ foreach ($this->filters as $callback) {
+ if (! $app->call($callback)) {
+ return false;
+ }
+ }
+
+ foreach ($this->rejects as $callback) {
+ if ($app->call($callback)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Send the output of the command to a given location.
+ *
+ * @param string $location
+ * @param bool $append
+ * @return $this
+ */
+ public function sendOutputTo($location, $append = false)
+ {
+ $this->output = $location;
+
+ $this->shouldAppendOutput = $append;
+
+ return $this;
+ }
+
+ /**
+ * Append the output of the command to a given location.
+ *
+ * @param string $location
+ * @return $this
+ */
+ public function appendOutputTo($location)
+ {
+ return $this->sendOutputTo($location, true);
+ }
+
+ /**
+ * E-mail the results of the scheduled operation.
+ *
+ * @param array|mixed $addresses
+ * @param bool $onlyIfOutputExists
+ * @return $this
+ *
+ * @throws \LogicException
+ */
+ public function emailOutputTo($addresses, $onlyIfOutputExists = false)
+ {
+ $this->ensureOutputIsBeingCapturedForEmail();
+
+ $addresses = is_array($addresses) ? $addresses : [$addresses];
+
+ return $this->then(function (Mailer $mailer) use ($addresses, $onlyIfOutputExists) {
+ $this->emailOutput($mailer, $addresses, $onlyIfOutputExists);
+ });
+ }
+
+ /**
+ * E-mail the results of the scheduled operation if it produces output.
+ *
+ * @param array|mixed $addresses
+ * @return $this
+ *
+ * @throws \LogicException
+ */
+ public function emailWrittenOutputTo($addresses)
+ {
+ return $this->emailOutputTo($addresses, true);
+ }
+
+ /**
+ * Ensure that output is being captured for email.
+ *
+ * @return void
+ */
+ protected function ensureOutputIsBeingCapturedForEmail()
+ {
+ if (is_null($this->output) || $this->output == $this->getDefaultOutput()) {
+ $this->sendOutputTo(storage_path('logs/schedule-'.sha1($this->mutexName()).'.log'));
+ }
+ }
+
+ /**
+ * E-mail the output of the event to the recipients.
+ *
+ * @param \Illuminate\Contracts\Mail\Mailer $mailer
+ * @param array $addresses
+ * @param bool $onlyIfOutputExists
+ * @return void
+ */
+ protected function emailOutput(Mailer $mailer, $addresses, $onlyIfOutputExists = false)
+ {
+ $text = file_exists($this->output) ? file_get_contents($this->output) : '';
+
+ if ($onlyIfOutputExists && empty($text)) {
+ return;
+ }
+
+ $mailer->raw($text, function ($m) use ($addresses) {
+ $m->to($addresses)->subject($this->getEmailSubject());
+ });
+ }
+
+ /**
+ * Get the e-mail subject line for output results.
+ *
+ * @return string
+ */
+ protected function getEmailSubject()
+ {
+ if ($this->description) {
+ return $this->description;
+ }
+
+ return 'Scheduled Job Output';
+ }
+
+ /**
+ * Register a callback to ping a given URL before the job runs.
+ *
+ * @param string $url
+ * @return $this
+ */
+ public function pingBefore($url)
+ {
+ return $this->before(function () use ($url) {
+ (new HttpClient)->get($url);
+ });
+ }
+
+ /**
+ * Register a callback to ping a given URL after the job runs.
+ *
+ * @param string $url
+ * @return $this
+ */
+ public function thenPing($url)
+ {
+ return $this->then(function () use ($url) {
+ (new HttpClient)->get($url);
+ });
+ }
+
+ /**
+ * State that the command should run in background.
+ *
+ * @return $this
+ */
+ public function runInBackground()
+ {
+ $this->runInBackground = true;
+
+ return $this;
+ }
+
+ /**
+ * Set which user the command should run as.
+ *
+ * @param string $user
+ * @return $this
+ */
+ public function user($user)
+ {
+ $this->user = $user;
+
+ return $this;
+ }
+
+ /**
+ * Limit the environments the command should run in.
+ *
+ * @param array|mixed $environments
+ * @return $this
+ */
+ public function environments($environments)
+ {
+ $this->environments = is_array($environments) ? $environments : func_get_args();
+
+ return $this;
+ }
+
+ /**
+ * State that the command should run even in maintenance mode.
+ *
+ * @return $this
+ */
+ public function evenInMaintenanceMode()
+ {
+ $this->evenInMaintenanceMode = true;
+
+ return $this;
+ }
+
+ /**
+ * Do not allow the event to overlap each other.
+ *
+ * @param int $expiresAt
+ * @return $this
+ */
+ public function withoutOverlapping($expiresAt = 1440)
+ {
+ $this->withoutOverlapping = true;
+
+ $this->expiresAt = $expiresAt;
+
+ return $this->then(function () {
+ $this->mutex->forget($this);
+ })->skip(function () {
+ return $this->mutex->exists($this);
+ });
+ }
+
+ /**
+ * Register a callback to further filter the schedule.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function when(Closure $callback)
+ {
+ $this->filters[] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Register a callback to further filter the schedule.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function skip(Closure $callback)
+ {
+ $this->rejects[] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Register a callback to be called before the operation.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function before(Closure $callback)
+ {
+ $this->beforeCallbacks[] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Register a callback to be called after the operation.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function after(Closure $callback)
+ {
+ return $this->then($callback);
+ }
+
+ /**
+ * Register a callback to be called after the operation.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function then(Closure $callback)
+ {
+ $this->afterCallbacks[] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Set the human-friendly description of the event.
+ *
+ * @param string $description
+ * @return $this
+ */
+ public function name($description)
+ {
+ return $this->description($description);
+ }
+
+ /**
+ * Set the human-friendly description of the event.
+ *
+ * @param string $description
+ * @return $this
+ */
+ public function description($description)
+ {
+ $this->description = $description;
+
+ return $this;
+ }
+
+ /**
+ * Get the summary of the event for display.
+ *
+ * @return string
+ */
+ public function getSummaryForDisplay()
+ {
+ if (is_string($this->description)) {
+ return $this->description;
+ }
+
+ return $this->buildCommand();
+ }
+
+ /**
+ * Determine the next due date for an event.
+ *
+ * @param \DateTime|string $currentTime
+ * @param int $nth
+ * @param bool $allowCurrentDate
+ * @return \Carbon\Carbon
+ */
+ public function nextRunDate($currentTime = 'now', $nth = 0, $allowCurrentDate = false)
+ {
+ return Carbon::instance($nextDue = CronExpression::factory(
+ $this->getExpression()
+ )->getNextRunDate($currentTime, $nth, $allowCurrentDate));
+ }
+
+ /**
+ * Get the Cron expression for the event.
+ *
+ * @return string
+ */
+ public function getExpression()
+ {
+ return $this->expression;
+ }
+
+ /**
+ * Set the mutex implementation to be used.
+ *
+ * @param \Illuminate\Console\Scheduling\Mutex $mutex
+ * @return $this
+ */
+ public function preventOverlapsUsing(Mutex $mutex)
+ {
+ $this->mutex = $mutex;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Scheduling/ManagesFrequencies.php b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/ManagesFrequencies.php
new file mode 100644
index 000000000..4606db971
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/ManagesFrequencies.php
@@ -0,0 +1,401 @@
+expression = $expression;
+
+ return $this;
+ }
+
+ /**
+ * Schedule the event to run between start and end time.
+ *
+ * @param string $startTime
+ * @param string $endTime
+ * @return $this
+ */
+ public function between($startTime, $endTime)
+ {
+ return $this->when($this->inTimeInterval($startTime, $endTime));
+ }
+
+ /**
+ * Schedule the event to not run between start and end time.
+ *
+ * @param string $startTime
+ * @param string $endTime
+ * @return $this
+ */
+ public function unlessBetween($startTime, $endTime)
+ {
+ return $this->skip($this->inTimeInterval($startTime, $endTime));
+ }
+
+ /**
+ * Schedule the event to run between start and end time.
+ *
+ * @param string $startTime
+ * @param string $endTime
+ * @return \Closure
+ */
+ private function inTimeInterval($startTime, $endTime)
+ {
+ return function () use ($startTime, $endTime) {
+ return Carbon::now($this->timezone)->between(
+ Carbon::parse($startTime, $this->timezone),
+ Carbon::parse($endTime, $this->timezone),
+ true
+ );
+ };
+ }
+
+ /**
+ * Schedule the event to run hourly.
+ *
+ * @return $this
+ */
+ public function hourly()
+ {
+ return $this->spliceIntoPosition(1, 0);
+ }
+
+ /**
+ * Schedule the event to run hourly at a given offset in the hour.
+ *
+ * @param int $offset
+ * @return $this
+ */
+ public function hourlyAt($offset)
+ {
+ return $this->spliceIntoPosition(1, $offset);
+ }
+
+ /**
+ * Schedule the event to run daily.
+ *
+ * @return $this
+ */
+ public function daily()
+ {
+ return $this->spliceIntoPosition(1, 0)
+ ->spliceIntoPosition(2, 0);
+ }
+
+ /**
+ * Schedule the command at a given time.
+ *
+ * @param string $time
+ * @return $this
+ */
+ public function at($time)
+ {
+ return $this->dailyAt($time);
+ }
+
+ /**
+ * Schedule the event to run daily at a given time (10:00, 19:30, etc).
+ *
+ * @param string $time
+ * @return $this
+ */
+ public function dailyAt($time)
+ {
+ $segments = explode(':', $time);
+
+ return $this->spliceIntoPosition(2, (int) $segments[0])
+ ->spliceIntoPosition(1, count($segments) == 2 ? (int) $segments[1] : '0');
+ }
+
+ /**
+ * Schedule the event to run twice daily.
+ *
+ * @param int $first
+ * @param int $second
+ * @return $this
+ */
+ public function twiceDaily($first = 1, $second = 13)
+ {
+ $hours = $first.','.$second;
+
+ return $this->spliceIntoPosition(1, 0)
+ ->spliceIntoPosition(2, $hours);
+ }
+
+ /**
+ * Schedule the event to run only on weekdays.
+ *
+ * @return $this
+ */
+ public function weekdays()
+ {
+ return $this->spliceIntoPosition(5, '1-5');
+ }
+
+ /**
+ * Schedule the event to run only on weekends.
+ *
+ * @return $this
+ */
+ public function weekends()
+ {
+ return $this->spliceIntoPosition(5, '0,6');
+ }
+
+ /**
+ * Schedule the event to run only on Mondays.
+ *
+ * @return $this
+ */
+ public function mondays()
+ {
+ return $this->days(1);
+ }
+
+ /**
+ * Schedule the event to run only on Tuesdays.
+ *
+ * @return $this
+ */
+ public function tuesdays()
+ {
+ return $this->days(2);
+ }
+
+ /**
+ * Schedule the event to run only on Wednesdays.
+ *
+ * @return $this
+ */
+ public function wednesdays()
+ {
+ return $this->days(3);
+ }
+
+ /**
+ * Schedule the event to run only on Thursdays.
+ *
+ * @return $this
+ */
+ public function thursdays()
+ {
+ return $this->days(4);
+ }
+
+ /**
+ * Schedule the event to run only on Fridays.
+ *
+ * @return $this
+ */
+ public function fridays()
+ {
+ return $this->days(5);
+ }
+
+ /**
+ * Schedule the event to run only on Saturdays.
+ *
+ * @return $this
+ */
+ public function saturdays()
+ {
+ return $this->days(6);
+ }
+
+ /**
+ * Schedule the event to run only on Sundays.
+ *
+ * @return $this
+ */
+ public function sundays()
+ {
+ return $this->days(0);
+ }
+
+ /**
+ * Schedule the event to run weekly.
+ *
+ * @return $this
+ */
+ public function weekly()
+ {
+ return $this->spliceIntoPosition(1, 0)
+ ->spliceIntoPosition(2, 0)
+ ->spliceIntoPosition(5, 0);
+ }
+
+ /**
+ * Schedule the event to run weekly on a given day and time.
+ *
+ * @param int $day
+ * @param string $time
+ * @return $this
+ */
+ public function weeklyOn($day, $time = '0:0')
+ {
+ $this->dailyAt($time);
+
+ return $this->spliceIntoPosition(5, $day);
+ }
+
+ /**
+ * Schedule the event to run monthly.
+ *
+ * @return $this
+ */
+ public function monthly()
+ {
+ return $this->spliceIntoPosition(1, 0)
+ ->spliceIntoPosition(2, 0)
+ ->spliceIntoPosition(3, 1);
+ }
+
+ /**
+ * Schedule the event to run monthly on a given day and time.
+ *
+ * @param int $day
+ * @param string $time
+ * @return $this
+ */
+ public function monthlyOn($day = 1, $time = '0:0')
+ {
+ $this->dailyAt($time);
+
+ return $this->spliceIntoPosition(3, $day);
+ }
+
+ /**
+ * Schedule the event to run twice monthly.
+ *
+ * @param int $first
+ * @param int $second
+ * @return $this
+ */
+ public function twiceMonthly($first = 1, $second = 16)
+ {
+ $days = $first.','.$second;
+
+ return $this->spliceIntoPosition(1, 0)
+ ->spliceIntoPosition(2, 0)
+ ->spliceIntoPosition(3, $days);
+ }
+
+ /**
+ * Schedule the event to run quarterly.
+ *
+ * @return $this
+ */
+ public function quarterly()
+ {
+ return $this->spliceIntoPosition(1, 0)
+ ->spliceIntoPosition(2, 0)
+ ->spliceIntoPosition(3, 1)
+ ->spliceIntoPosition(4, '*/3');
+ }
+
+ /**
+ * Schedule the event to run yearly.
+ *
+ * @return $this
+ */
+ public function yearly()
+ {
+ return $this->spliceIntoPosition(1, 0)
+ ->spliceIntoPosition(2, 0)
+ ->spliceIntoPosition(3, 1)
+ ->spliceIntoPosition(4, 1);
+ }
+
+ /**
+ * Schedule the event to run every minute.
+ *
+ * @return $this
+ */
+ public function everyMinute()
+ {
+ return $this->spliceIntoPosition(1, '*');
+ }
+
+ /**
+ * Schedule the event to run every five minutes.
+ *
+ * @return $this
+ */
+ public function everyFiveMinutes()
+ {
+ return $this->spliceIntoPosition(1, '*/5');
+ }
+
+ /**
+ * Schedule the event to run every ten minutes.
+ *
+ * @return $this
+ */
+ public function everyTenMinutes()
+ {
+ return $this->spliceIntoPosition(1, '*/10');
+ }
+
+ /**
+ * Schedule the event to run every thirty minutes.
+ *
+ * @return $this
+ */
+ public function everyThirtyMinutes()
+ {
+ return $this->spliceIntoPosition(1, '0,30');
+ }
+
+ /**
+ * Set the days of the week the command should run on.
+ *
+ * @param array|mixed $days
+ * @return $this
+ */
+ public function days($days)
+ {
+ $days = is_array($days) ? $days : func_get_args();
+
+ return $this->spliceIntoPosition(5, implode(',', $days));
+ }
+
+ /**
+ * Set the timezone the date should be evaluated on.
+ *
+ * @param \DateTimeZone|string $timezone
+ * @return $this
+ */
+ public function timezone($timezone)
+ {
+ $this->timezone = $timezone;
+
+ return $this;
+ }
+
+ /**
+ * Splice the given value into the given position of the expression.
+ *
+ * @param int $position
+ * @param string $value
+ * @return $this
+ */
+ protected function spliceIntoPosition($position, $value)
+ {
+ $segments = explode(' ', $this->expression);
+
+ $segments[$position - 1] = $value;
+
+ return $this->cron(implode(' ', $segments));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Scheduling/Mutex.php b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/Mutex.php
new file mode 100644
index 000000000..47ca939e1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/Mutex.php
@@ -0,0 +1,30 @@
+mutex = $container->bound(Mutex::class)
+ ? $container->make(Mutex::class)
+ : $container->make(CacheMutex::class);
+ }
+
+ /**
+ * Add a new callback event to the schedule.
+ *
+ * @param string|callable $callback
+ * @param array $parameters
+ * @return \Illuminate\Console\Scheduling\CallbackEvent
+ */
+ public function call($callback, array $parameters = [])
+ {
+ $this->events[] = $event = new CallbackEvent(
+ $this->mutex, $callback, $parameters
+ );
+
+ return $event;
+ }
+
+ /**
+ * Add a new Artisan command event to the schedule.
+ *
+ * @param string $command
+ * @param array $parameters
+ * @return \Illuminate\Console\Scheduling\Event
+ */
+ public function command($command, array $parameters = [])
+ {
+ if (class_exists($command)) {
+ $command = Container::getInstance()->make($command)->getName();
+ }
+
+ return $this->exec(
+ Application::formatCommandString($command), $parameters
+ );
+ }
+
+ /**
+ * Add a new job callback event to the schedule.
+ *
+ * @param object|string $job
+ * @return \Illuminate\Console\Scheduling\CallbackEvent
+ */
+ public function job($job)
+ {
+ return $this->call(function () use ($job) {
+ dispatch(is_string($job) ? resolve($job) : $job);
+ })->name(is_string($job) ? $job : get_class($job));
+ }
+
+ /**
+ * Add a new command event to the schedule.
+ *
+ * @param string $command
+ * @param array $parameters
+ * @return \Illuminate\Console\Scheduling\Event
+ */
+ public function exec($command, array $parameters = [])
+ {
+ if (count($parameters)) {
+ $command .= ' '.$this->compileParameters($parameters);
+ }
+
+ $this->events[] = $event = new Event($this->mutex, $command);
+
+ return $event;
+ }
+
+ /**
+ * Compile parameters for a command.
+ *
+ * @param array $parameters
+ * @return string
+ */
+ protected function compileParameters(array $parameters)
+ {
+ return collect($parameters)->map(function ($value, $key) {
+ if (is_array($value)) {
+ $value = collect($value)->map(function ($value) {
+ return ProcessUtils::escapeArgument($value);
+ })->implode(' ');
+ } elseif (! is_numeric($value) && ! preg_match('/^(-.$|--.*)/i', $value)) {
+ $value = ProcessUtils::escapeArgument($value);
+ }
+
+ return is_numeric($key) ? $value : "{$key}={$value}";
+ })->implode(' ');
+ }
+
+ /**
+ * Get all of the events on the schedule that are due.
+ *
+ * @param \Illuminate\Contracts\Foundation\Application $app
+ * @return array
+ */
+ public function dueEvents($app)
+ {
+ return collect($this->events)->filter->isDue($app);
+ }
+
+ /**
+ * Get all of the events on the schedule.
+ *
+ * @return \Illuminate\Console\Scheduling\Event[]
+ */
+ public function events()
+ {
+ return $this->events;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleFinishCommand.php b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleFinishCommand.php
new file mode 100644
index 000000000..f22a0c5bf
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleFinishCommand.php
@@ -0,0 +1,61 @@
+schedule = $schedule;
+
+ parent::__construct();
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ collect($this->schedule->events())->filter(function ($value) {
+ return $value->mutexName() == $this->argument('id');
+ })->each->callAfterCallbacks($this->laravel);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleRunCommand.php b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleRunCommand.php
new file mode 100644
index 000000000..8bf7c9029
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/Scheduling/ScheduleRunCommand.php
@@ -0,0 +1,68 @@
+schedule = $schedule;
+
+ parent::__construct();
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $eventsRan = false;
+
+ foreach ($this->schedule->dueEvents($this->laravel) as $event) {
+ if (! $event->filtersPass($this->laravel)) {
+ continue;
+ }
+
+ $this->line('Running scheduled command: '.$event->getSummaryForDisplay());
+
+ $event->run($this->laravel);
+
+ $eventsRan = true;
+ }
+
+ if (! $eventsRan) {
+ $this->info('No scheduled commands are ready to run.');
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Console/composer.json b/vendor/laravel/framework/src/Illuminate/Console/composer.json
new file mode 100644
index 000000000..60a138b17
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Console/composer.json
@@ -0,0 +1,42 @@
+{
+ "name": "illuminate/console",
+ "description": "The Illuminate Console package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "nesbot/carbon": "~1.20",
+ "symfony/console": "~3.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Console\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "guzzlehttp/guzzle": "Required to use the ping methods on schedules (~6.0).",
+ "mtdowling/cron-expression": "Required to use scheduling component (~1.0).",
+ "symfony/process": "Required to use scheduling component (~3.2)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php b/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php
new file mode 100644
index 000000000..d422ea4ba
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Container/BoundMethod.php
@@ -0,0 +1,172 @@
+make($segments[0]), $method], $parameters
+ );
+ }
+
+ /**
+ * Call a method that has been bound to the container.
+ *
+ * @param \Illuminate\Container\Container $container
+ * @param callable $callback
+ * @param mixed $default
+ * @return mixed
+ */
+ protected static function callBoundMethod($container, $callback, $default)
+ {
+ if (! is_array($callback)) {
+ return $default instanceof Closure ? $default() : $default;
+ }
+
+ // Here we need to turn the array callable into a Class@method string we can use to
+ // examine the container and see if there are any method bindings for this given
+ // method. If there are, we can call this method binding callback immediately.
+ $method = static::normalizeMethod($callback);
+
+ if ($container->hasMethodBinding($method)) {
+ return $container->callMethodBinding($method, $callback[0]);
+ }
+
+ return $default instanceof Closure ? $default() : $default;
+ }
+
+ /**
+ * Normalize the given callback into a Class@method string.
+ *
+ * @param callable $callback
+ * @return string
+ */
+ protected static function normalizeMethod($callback)
+ {
+ $class = is_string($callback[0]) ? $callback[0] : get_class($callback[0]);
+
+ return "{$class}@{$callback[1]}";
+ }
+
+ /**
+ * Get all dependencies for a given method.
+ *
+ * @param \Illuminate\Container\Container
+ * @param callable|string $callback
+ * @param array $parameters
+ * @return array
+ */
+ protected static function getMethodDependencies($container, $callback, array $parameters = [])
+ {
+ $dependencies = [];
+
+ foreach (static::getCallReflector($callback)->getParameters() as $parameter) {
+ static::addDependencyForCallParameter($container, $parameter, $parameters, $dependencies);
+ }
+
+ return array_merge($dependencies, $parameters);
+ }
+
+ /**
+ * Get the proper reflection instance for the given callback.
+ *
+ * @param callable|string $callback
+ * @return \ReflectionFunctionAbstract
+ */
+ protected static function getCallReflector($callback)
+ {
+ if (is_string($callback) && strpos($callback, '::') !== false) {
+ $callback = explode('::', $callback);
+ }
+
+ return is_array($callback)
+ ? new ReflectionMethod($callback[0], $callback[1])
+ : new ReflectionFunction($callback);
+ }
+
+ /**
+ * Get the dependency for the given call parameter.
+ *
+ * @param \Illuminate\Container\Container $container
+ * @param \ReflectionParameter $parameter
+ * @param array $parameters
+ * @param array $dependencies
+ * @return mixed
+ */
+ protected static function addDependencyForCallParameter($container, $parameter,
+ array &$parameters, &$dependencies)
+ {
+ if (array_key_exists($parameter->name, $parameters)) {
+ $dependencies[] = $parameters[$parameter->name];
+
+ unset($parameters[$parameter->name]);
+ } elseif ($parameter->getClass()) {
+ $dependencies[] = $container->make($parameter->getClass()->name);
+ } elseif ($parameter->isDefaultValueAvailable()) {
+ $dependencies[] = $parameter->getDefaultValue();
+ }
+ }
+
+ /**
+ * Determine if the given string is in Class@method syntax.
+ *
+ * @param mixed $callback
+ * @return bool
+ */
+ protected static function isCallableWithAtSign($callback)
+ {
+ return is_string($callback) && strpos($callback, '@') !== false;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Container/Container.php b/vendor/laravel/framework/src/Illuminate/Container/Container.php
new file mode 100644
index 000000000..0945cb01c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Container/Container.php
@@ -0,0 +1,1222 @@
+getAlias($concrete));
+ }
+
+ /**
+ * Determine if the given abstract type has been bound.
+ *
+ * @param string $abstract
+ * @return bool
+ */
+ public function bound($abstract)
+ {
+ return isset($this->bindings[$abstract]) ||
+ isset($this->instances[$abstract]) ||
+ $this->isAlias($abstract);
+ }
+
+ /**
+ * Determine if the given abstract type has been resolved.
+ *
+ * @param string $abstract
+ * @return bool
+ */
+ public function resolved($abstract)
+ {
+ if ($this->isAlias($abstract)) {
+ $abstract = $this->getAlias($abstract);
+ }
+
+ return isset($this->resolved[$abstract]) ||
+ isset($this->instances[$abstract]);
+ }
+
+ /**
+ * Determine if a given type is shared.
+ *
+ * @param string $abstract
+ * @return bool
+ */
+ public function isShared($abstract)
+ {
+ return isset($this->instances[$abstract]) ||
+ (isset($this->bindings[$abstract]['shared']) &&
+ $this->bindings[$abstract]['shared'] === true);
+ }
+
+ /**
+ * Determine if a given string is an alias.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function isAlias($name)
+ {
+ return isset($this->aliases[$name]);
+ }
+
+ /**
+ * Register a binding with the container.
+ *
+ * @param string|array $abstract
+ * @param \Closure|string|null $concrete
+ * @param bool $shared
+ * @return void
+ */
+ public function bind($abstract, $concrete = null, $shared = false)
+ {
+ // If no concrete type was given, we will simply set the concrete type to the
+ // abstract type. After that, the concrete type to be registered as shared
+ // without being forced to state their classes in both of the parameters.
+ $this->dropStaleInstances($abstract);
+
+ if (is_null($concrete)) {
+ $concrete = $abstract;
+ }
+
+ // If the factory is not a Closure, it means it is just a class name which is
+ // bound into this container to the abstract type and we will just wrap it
+ // up inside its own Closure to give us more convenience when extending.
+ if (! $concrete instanceof Closure) {
+ $concrete = $this->getClosure($abstract, $concrete);
+ }
+
+ $this->bindings[$abstract] = compact('concrete', 'shared');
+
+ // If the abstract type was already resolved in this container we'll fire the
+ // rebound listener so that any objects which have already gotten resolved
+ // can have their copy of the object updated via the listener callbacks.
+ if ($this->resolved($abstract)) {
+ $this->rebound($abstract);
+ }
+ }
+
+ /**
+ * Get the Closure to be used when building a type.
+ *
+ * @param string $abstract
+ * @param string $concrete
+ * @return \Closure
+ */
+ protected function getClosure($abstract, $concrete)
+ {
+ return function ($container, $parameters = []) use ($abstract, $concrete) {
+ if ($abstract == $concrete) {
+ return $container->build($concrete);
+ }
+
+ return $container->makeWith($concrete, $parameters);
+ };
+ }
+
+ /**
+ * Determine if the container has a method binding.
+ *
+ * @param string $method
+ * @return bool
+ */
+ public function hasMethodBinding($method)
+ {
+ return isset($this->methodBindings[$method]);
+ }
+
+ /**
+ * Bind a callback to resolve with Container::call.
+ *
+ * @param string $method
+ * @param \Closure $callback
+ * @return void
+ */
+ public function bindMethod($method, $callback)
+ {
+ $this->methodBindings[$method] = $callback;
+ }
+
+ /**
+ * Get the method binding for the given method.
+ *
+ * @param string $method
+ * @param mixed $instance
+ * @return mixed
+ */
+ public function callMethodBinding($method, $instance)
+ {
+ return call_user_func($this->methodBindings[$method], $instance, $this);
+ }
+
+ /**
+ * Add a contextual binding to the container.
+ *
+ * @param string $concrete
+ * @param string $abstract
+ * @param \Closure|string $implementation
+ * @return void
+ */
+ public function addContextualBinding($concrete, $abstract, $implementation)
+ {
+ $this->contextual[$concrete][$this->getAlias($abstract)] = $implementation;
+ }
+
+ /**
+ * Register a binding if it hasn't already been registered.
+ *
+ * @param string $abstract
+ * @param \Closure|string|null $concrete
+ * @param bool $shared
+ * @return void
+ */
+ public function bindIf($abstract, $concrete = null, $shared = false)
+ {
+ if (! $this->bound($abstract)) {
+ $this->bind($abstract, $concrete, $shared);
+ }
+ }
+
+ /**
+ * Register a shared binding in the container.
+ *
+ * @param string|array $abstract
+ * @param \Closure|string|null $concrete
+ * @return void
+ */
+ public function singleton($abstract, $concrete = null)
+ {
+ $this->bind($abstract, $concrete, true);
+ }
+
+ /**
+ * "Extend" an abstract type in the container.
+ *
+ * @param string $abstract
+ * @param \Closure $closure
+ * @return void
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function extend($abstract, Closure $closure)
+ {
+ $abstract = $this->getAlias($abstract);
+
+ if (isset($this->instances[$abstract])) {
+ $this->instances[$abstract] = $closure($this->instances[$abstract], $this);
+
+ $this->rebound($abstract);
+ } else {
+ $this->extenders[$abstract][] = $closure;
+
+ if ($this->resolved($abstract)) {
+ $this->rebound($abstract);
+ }
+ }
+ }
+
+ /**
+ * Register an existing instance as shared in the container.
+ *
+ * @param string $abstract
+ * @param mixed $instance
+ * @return void
+ */
+ public function instance($abstract, $instance)
+ {
+ $this->removeAbstractAlias($abstract);
+
+ $isBound = $this->bound($abstract);
+
+ unset($this->aliases[$abstract]);
+
+ // We'll check to determine if this type has been bound before, and if it has
+ // we will fire the rebound callbacks registered with the container and it
+ // can be updated with consuming classes that have gotten resolved here.
+ $this->instances[$abstract] = $instance;
+
+ if ($isBound) {
+ $this->rebound($abstract);
+ }
+ }
+
+ /**
+ * Remove an alias from the contextual binding alias cache.
+ *
+ * @param string $searched
+ * @return void
+ */
+ protected function removeAbstractAlias($searched)
+ {
+ if (! isset($this->aliases[$searched])) {
+ return;
+ }
+
+ foreach ($this->abstractAliases as $abstract => $aliases) {
+ foreach ($aliases as $index => $alias) {
+ if ($alias == $searched) {
+ unset($this->abstractAliases[$abstract][$index]);
+ }
+ }
+ }
+ }
+
+ /**
+ * Assign a set of tags to a given binding.
+ *
+ * @param array|string $abstracts
+ * @param array|mixed ...$tags
+ * @return void
+ */
+ public function tag($abstracts, $tags)
+ {
+ $tags = is_array($tags) ? $tags : array_slice(func_get_args(), 1);
+
+ foreach ($tags as $tag) {
+ if (! isset($this->tags[$tag])) {
+ $this->tags[$tag] = [];
+ }
+
+ foreach ((array) $abstracts as $abstract) {
+ $this->tags[$tag][] = $abstract;
+ }
+ }
+ }
+
+ /**
+ * Resolve all of the bindings for a given tag.
+ *
+ * @param string $tag
+ * @return array
+ */
+ public function tagged($tag)
+ {
+ $results = [];
+
+ if (isset($this->tags[$tag])) {
+ foreach ($this->tags[$tag] as $abstract) {
+ $results[] = $this->make($abstract);
+ }
+ }
+
+ return $results;
+ }
+
+ /**
+ * Alias a type to a different name.
+ *
+ * @param string $abstract
+ * @param string $alias
+ * @return void
+ */
+ public function alias($abstract, $alias)
+ {
+ $this->aliases[$alias] = $abstract;
+
+ $this->abstractAliases[$abstract][] = $alias;
+ }
+
+ /**
+ * Bind a new callback to an abstract's rebind event.
+ *
+ * @param string $abstract
+ * @param \Closure $callback
+ * @return mixed
+ */
+ public function rebinding($abstract, Closure $callback)
+ {
+ $this->reboundCallbacks[$abstract = $this->getAlias($abstract)][] = $callback;
+
+ if ($this->bound($abstract)) {
+ return $this->make($abstract);
+ }
+ }
+
+ /**
+ * Refresh an instance on the given target and method.
+ *
+ * @param string $abstract
+ * @param mixed $target
+ * @param string $method
+ * @return mixed
+ */
+ public function refresh($abstract, $target, $method)
+ {
+ return $this->rebinding($abstract, function ($app, $instance) use ($target, $method) {
+ $target->{$method}($instance);
+ });
+ }
+
+ /**
+ * Fire the "rebound" callbacks for the given abstract type.
+ *
+ * @param string $abstract
+ * @return void
+ */
+ protected function rebound($abstract)
+ {
+ $instance = $this->make($abstract);
+
+ foreach ($this->getReboundCallbacks($abstract) as $callback) {
+ call_user_func($callback, $this, $instance);
+ }
+ }
+
+ /**
+ * Get the rebound callbacks for a given type.
+ *
+ * @param string $abstract
+ * @return array
+ */
+ protected function getReboundCallbacks($abstract)
+ {
+ if (isset($this->reboundCallbacks[$abstract])) {
+ return $this->reboundCallbacks[$abstract];
+ }
+
+ return [];
+ }
+
+ /**
+ * Wrap the given closure such that its dependencies will be injected when executed.
+ *
+ * @param \Closure $callback
+ * @param array $parameters
+ * @return \Closure
+ */
+ public function wrap(Closure $callback, array $parameters = [])
+ {
+ return function () use ($callback, $parameters) {
+ return $this->call($callback, $parameters);
+ };
+ }
+
+ /**
+ * Call the given Closure / class@method and inject its dependencies.
+ *
+ * @param callable|string $callback
+ * @param array $parameters
+ * @param string|null $defaultMethod
+ * @return mixed
+ */
+ public function call($callback, array $parameters = [], $defaultMethod = null)
+ {
+ return BoundMethod::call($this, $callback, $parameters, $defaultMethod);
+ }
+
+ /**
+ * Get a closure to resolve the given type from the container.
+ *
+ * @param string $abstract
+ * @return \Closure
+ */
+ public function factory($abstract)
+ {
+ return function () use ($abstract) {
+ return $this->make($abstract);
+ };
+ }
+
+ /**
+ * Resolve the given type with the given parameter overrides.
+ *
+ * @param string $abstract
+ * @param array $parameters
+ * @return mixed
+ */
+ public function makeWith($abstract, array $parameters)
+ {
+ return $this->resolve($abstract, $parameters);
+ }
+
+ /**
+ * Resolve the given type from the container.
+ *
+ * @param string $abstract
+ * @return mixed
+ */
+ public function make($abstract)
+ {
+ return $this->resolve($abstract);
+ }
+
+ /**
+ * Resolve the given type from the container.
+ *
+ * @param string $abstract
+ * @param array $parameters
+ * @return mixed
+ */
+ protected function resolve($abstract, $parameters = [])
+ {
+ $abstract = $this->getAlias($abstract);
+
+ $needsContextualBuild = ! empty($parameters) || ! is_null(
+ $this->getContextualConcrete($abstract)
+ );
+
+ // If an instance of the type is currently being managed as a singleton we'll
+ // just return an existing instance instead of instantiating new instances
+ // so the developer can keep using the same objects instance every time.
+ if (isset($this->instances[$abstract]) && ! $needsContextualBuild) {
+ return $this->instances[$abstract];
+ }
+
+ $this->with[] = $parameters;
+
+ $concrete = $this->getConcrete($abstract);
+
+ // We're ready to instantiate an instance of the concrete type registered for
+ // the binding. This will instantiate the types, as well as resolve any of
+ // its "nested" dependencies recursively until all have gotten resolved.
+ if ($this->isBuildable($concrete, $abstract)) {
+ $object = $this->build($concrete);
+ } else {
+ $object = $this->make($concrete);
+ }
+
+ // If we defined any extenders for this type, we'll need to spin through them
+ // and apply them to the object being built. This allows for the extension
+ // of services, such as changing configuration or decorating the object.
+ foreach ($this->getExtenders($abstract) as $extender) {
+ $object = $extender($object, $this);
+ }
+
+ // If the requested type is registered as a singleton we'll want to cache off
+ // the instances in "memory" so we can return it later without creating an
+ // entirely new instance of an object on each subsequent request for it.
+ if ($this->isShared($abstract) && ! $needsContextualBuild) {
+ $this->instances[$abstract] = $object;
+ }
+
+ $this->fireResolvingCallbacks($abstract, $object);
+
+ // Before returning, we will also set the resolved flag to "true" and pop off
+ // the parameter overrides for this build. After those two things are done
+ // we will be ready to return back the fully constructed class instance.
+ $this->resolved[$abstract] = true;
+
+ array_pop($this->with);
+
+ return $object;
+ }
+
+ /**
+ * Get the concrete type for a given abstract.
+ *
+ * @param string $abstract
+ * @return mixed $concrete
+ */
+ protected function getConcrete($abstract)
+ {
+ if (! is_null($concrete = $this->getContextualConcrete($abstract))) {
+ return $concrete;
+ }
+
+ // If we don't have a registered resolver or concrete for the type, we'll just
+ // assume each type is a concrete name and will attempt to resolve it as is
+ // since the container should be able to resolve concretes automatically.
+ if (isset($this->bindings[$abstract])) {
+ return $this->bindings[$abstract]['concrete'];
+ }
+
+ return $abstract;
+ }
+
+ /**
+ * Get the contextual concrete binding for the given abstract.
+ *
+ * @param string $abstract
+ * @return string|null
+ */
+ protected function getContextualConcrete($abstract)
+ {
+ if (! is_null($binding = $this->findInContextualBindings($abstract))) {
+ return $binding;
+ }
+
+ // Next we need to see if a contextual binding might be bound under an alias of the
+ // given abstract type. So, we will need to check if any aliases exist with this
+ // type and then spin through them and check for contextual bindings on these.
+ if (empty($this->abstractAliases[$abstract])) {
+ return;
+ }
+
+ foreach ($this->abstractAliases[$abstract] as $alias) {
+ if (! is_null($binding = $this->findInContextualBindings($alias))) {
+ return $binding;
+ }
+ }
+ }
+
+ /**
+ * Find the concrete binding for the given abstract in the contextual binding array.
+ *
+ * @param string $abstract
+ * @return string|null
+ */
+ protected function findInContextualBindings($abstract)
+ {
+ if (isset($this->contextual[end($this->buildStack)][$abstract])) {
+ return $this->contextual[end($this->buildStack)][$abstract];
+ }
+ }
+
+ /**
+ * Determine if the given concrete is buildable.
+ *
+ * @param mixed $concrete
+ * @param string $abstract
+ * @return bool
+ */
+ protected function isBuildable($concrete, $abstract)
+ {
+ return $concrete === $abstract || $concrete instanceof Closure;
+ }
+
+ /**
+ * Instantiate a concrete instance of the given type.
+ *
+ * @param string $concrete
+ * @return mixed
+ *
+ * @throws \Illuminate\Contracts\Container\BindingResolutionException
+ */
+ public function build($concrete)
+ {
+ // If the concrete type is actually a Closure, we will just execute it and
+ // hand back the results of the functions, which allows functions to be
+ // used as resolvers for more fine-tuned resolution of these objects.
+ if ($concrete instanceof Closure) {
+ return $concrete($this, $this->getLastParameterOverride());
+ }
+
+ $reflector = new ReflectionClass($concrete);
+
+ // If the type is not instantiable, the developer is attempting to resolve
+ // an abstract type such as an Interface of Abstract Class and there is
+ // no binding registered for the abstractions so we need to bail out.
+ if (! $reflector->isInstantiable()) {
+ return $this->notInstantiable($concrete);
+ }
+
+ $this->buildStack[] = $concrete;
+
+ $constructor = $reflector->getConstructor();
+
+ // If there are no constructors, that means there are no dependencies then
+ // we can just resolve the instances of the objects right away, without
+ // resolving any other types or dependencies out of these containers.
+ if (is_null($constructor)) {
+ array_pop($this->buildStack);
+
+ return new $concrete;
+ }
+
+ $dependencies = $constructor->getParameters();
+
+ // Once we have all the constructor's parameters we can create each of the
+ // dependency instances and then use the reflection instances to make a
+ // new instance of this class, injecting the created dependencies in.
+ $instances = $this->resolveDependencies(
+ $dependencies
+ );
+
+ array_pop($this->buildStack);
+
+ return $reflector->newInstanceArgs($instances);
+ }
+
+ /**
+ * Resolve all of the dependencies from the ReflectionParameters.
+ *
+ * @param array $dependencies
+ * @return array
+ */
+ protected function resolveDependencies(array $dependencies)
+ {
+ $results = [];
+
+ foreach ($dependencies as $dependency) {
+ // If this dependency has a override for this particular build we will use
+ // that instead as the value. Otherwise, we will continue with this run
+ // of resolutions and let reflection attempt to determine the result.
+ if ($this->hasParameterOverride($dependency)) {
+ $results[] = $this->getParameterOverride($dependency);
+
+ continue;
+ }
+
+ // If the class is null, it means the dependency is a string or some other
+ // primitive type which we can not resolve since it is not a class and
+ // we will just bomb out with an error since we have no-where to go.
+ $results[] = is_null($class = $dependency->getClass())
+ ? $this->resolvePrimitive($dependency)
+ : $this->resolveClass($dependency);
+ }
+
+ return $results;
+ }
+
+ /**
+ * Determine if the given dependency has a parameter override from makeWith.
+ *
+ * @param \ReflectionParameter $dependency
+ * @return bool
+ */
+ protected function hasParameterOverride($dependency)
+ {
+ return array_key_exists(
+ $dependency->name, $this->getLastParameterOverride()
+ );
+ }
+
+ /**
+ * Get a parameter override for a dependency.
+ *
+ * @param \ReflectionParameter $dependency
+ * @return mixed
+ */
+ protected function getParameterOverride($dependency)
+ {
+ return $this->getLastParameterOverride()[$dependency->name];
+ }
+
+ /**
+ * Get the last parameter override.
+ *
+ * @return array
+ */
+ protected function getLastParameterOverride()
+ {
+ return count($this->with) ? end($this->with) : [];
+ }
+
+ /**
+ * Resolve a non-class hinted primitive dependency.
+ *
+ * @param \ReflectionParameter $parameter
+ * @return mixed
+ *
+ * @throws \Illuminate\Contracts\Container\BindingResolutionException
+ */
+ protected function resolvePrimitive(ReflectionParameter $parameter)
+ {
+ if (! is_null($concrete = $this->getContextualConcrete('$'.$parameter->name))) {
+ return $concrete instanceof Closure ? $concrete($this) : $concrete;
+ }
+
+ if ($parameter->isDefaultValueAvailable()) {
+ return $parameter->getDefaultValue();
+ }
+
+ $this->unresolvablePrimitive($parameter);
+ }
+
+ /**
+ * Resolve a class based dependency from the container.
+ *
+ * @param \ReflectionParameter $parameter
+ * @return mixed
+ *
+ * @throws \Illuminate\Contracts\Container\BindingResolutionException
+ */
+ protected function resolveClass(ReflectionParameter $parameter)
+ {
+ try {
+ return $this->make($parameter->getClass()->name);
+ }
+
+ // If we can not resolve the class instance, we will check to see if the value
+ // is optional, and if it is we will return the optional parameter value as
+ // the value of the dependency, similarly to how we do this with scalars.
+ catch (BindingResolutionException $e) {
+ if ($parameter->isOptional()) {
+ return $parameter->getDefaultValue();
+ }
+
+ throw $e;
+ }
+ }
+
+ /**
+ * Throw an exception that the concrete is not instantiable.
+ *
+ * @param string $concrete
+ * @return void
+ *
+ * @throws \Illuminate\Contracts\Container\BindingResolutionException
+ */
+ protected function notInstantiable($concrete)
+ {
+ if (! empty($this->buildStack)) {
+ $previous = implode(', ', $this->buildStack);
+
+ $message = "Target [$concrete] is not instantiable while building [$previous].";
+ } else {
+ $message = "Target [$concrete] is not instantiable.";
+ }
+
+ throw new BindingResolutionException($message);
+ }
+
+ /**
+ * Throw an exception for an unresolvable primitive.
+ *
+ * @param \ReflectionParameter $parameter
+ * @return void
+ *
+ * @throws \Illuminate\Contracts\Container\BindingResolutionException
+ */
+ protected function unresolvablePrimitive(ReflectionParameter $parameter)
+ {
+ $message = "Unresolvable dependency resolving [$parameter] in class {$parameter->getDeclaringClass()->getName()}";
+
+ throw new BindingResolutionException($message);
+ }
+
+ /**
+ * Register a new resolving callback.
+ *
+ * @param string $abstract
+ * @param \Closure|null $callback
+ * @return void
+ */
+ public function resolving($abstract, Closure $callback = null)
+ {
+ if (is_string($abstract)) {
+ $abstract = $this->getAlias($abstract);
+ }
+
+ if (is_null($callback) && $abstract instanceof Closure) {
+ $this->globalResolvingCallbacks[] = $abstract;
+ } else {
+ $this->resolvingCallbacks[$abstract][] = $callback;
+ }
+ }
+
+ /**
+ * Register a new after resolving callback for all types.
+ *
+ * @param string $abstract
+ * @param \Closure|null $callback
+ * @return void
+ */
+ public function afterResolving($abstract, Closure $callback = null)
+ {
+ if (is_string($abstract)) {
+ $abstract = $this->getAlias($abstract);
+ }
+
+ if ($abstract instanceof Closure && is_null($callback)) {
+ $this->globalAfterResolvingCallbacks[] = $abstract;
+ } else {
+ $this->afterResolvingCallbacks[$abstract][] = $callback;
+ }
+ }
+
+ /**
+ * Fire all of the resolving callbacks.
+ *
+ * @param string $abstract
+ * @param mixed $object
+ * @return void
+ */
+ protected function fireResolvingCallbacks($abstract, $object)
+ {
+ $this->fireCallbackArray($object, $this->globalResolvingCallbacks);
+
+ $this->fireCallbackArray(
+ $object, $this->getCallbacksForType($abstract, $object, $this->resolvingCallbacks)
+ );
+
+ $this->fireAfterResolvingCallbacks($abstract, $object);
+ }
+
+ /**
+ * Fire all of the after resolving callbacks.
+ *
+ * @param string $abstract
+ * @param mixed $object
+ * @return void
+ */
+ protected function fireAfterResolvingCallbacks($abstract, $object)
+ {
+ $this->fireCallbackArray($object, $this->globalAfterResolvingCallbacks);
+
+ $this->fireCallbackArray(
+ $object, $this->getCallbacksForType($abstract, $object, $this->afterResolvingCallbacks)
+ );
+ }
+
+ /**
+ * Get all callbacks for a given type.
+ *
+ * @param string $abstract
+ * @param object $object
+ * @param array $callbacksPerType
+ *
+ * @return array
+ */
+ protected function getCallbacksForType($abstract, $object, array $callbacksPerType)
+ {
+ $results = [];
+
+ foreach ($callbacksPerType as $type => $callbacks) {
+ if ($type === $abstract || $object instanceof $type) {
+ $results = array_merge($results, $callbacks);
+ }
+ }
+
+ return $results;
+ }
+
+ /**
+ * Fire an array of callbacks with an object.
+ *
+ * @param mixed $object
+ * @param array $callbacks
+ * @return void
+ */
+ protected function fireCallbackArray($object, array $callbacks)
+ {
+ foreach ($callbacks as $callback) {
+ $callback($object, $this);
+ }
+ }
+
+ /**
+ * Get the container's bindings.
+ *
+ * @return array
+ */
+ public function getBindings()
+ {
+ return $this->bindings;
+ }
+
+ /**
+ * Get the alias for an abstract if available.
+ *
+ * @param string $abstract
+ * @return string
+ *
+ * @throws \LogicException
+ */
+ public function getAlias($abstract)
+ {
+ if (! isset($this->aliases[$abstract])) {
+ return $abstract;
+ }
+
+ if ($this->aliases[$abstract] === $abstract) {
+ throw new LogicException("[{$abstract}] is aliased to itself.");
+ }
+
+ return $this->getAlias($this->aliases[$abstract]);
+ }
+
+ /**
+ * Get the extender callbacks for a given type.
+ *
+ * @param string $abstract
+ * @return array
+ */
+ protected function getExtenders($abstract)
+ {
+ $abstract = $this->getAlias($abstract);
+
+ if (isset($this->extenders[$abstract])) {
+ return $this->extenders[$abstract];
+ }
+
+ return [];
+ }
+
+ /**
+ * Remove all of the extender callbacks for a given type.
+ *
+ * @param string $abstract
+ * @return void
+ */
+ public function forgetExtenders($abstract)
+ {
+ unset($this->extenders[$this->getAlias($abstract)]);
+ }
+
+ /**
+ * Drop all of the stale instances and aliases.
+ *
+ * @param string $abstract
+ * @return void
+ */
+ protected function dropStaleInstances($abstract)
+ {
+ unset($this->instances[$abstract], $this->aliases[$abstract]);
+ }
+
+ /**
+ * Remove a resolved instance from the instance cache.
+ *
+ * @param string $abstract
+ * @return void
+ */
+ public function forgetInstance($abstract)
+ {
+ unset($this->instances[$abstract]);
+ }
+
+ /**
+ * Clear all of the instances from the container.
+ *
+ * @return void
+ */
+ public function forgetInstances()
+ {
+ $this->instances = [];
+ }
+
+ /**
+ * Flush the container of all bindings and resolved instances.
+ *
+ * @return void
+ */
+ public function flush()
+ {
+ $this->aliases = [];
+ $this->resolved = [];
+ $this->bindings = [];
+ $this->instances = [];
+ $this->abstractAliases = [];
+ }
+
+ /**
+ * Set the globally available instance of the container.
+ *
+ * @return static
+ */
+ public static function getInstance()
+ {
+ if (is_null(static::$instance)) {
+ static::$instance = new static;
+ }
+
+ return static::$instance;
+ }
+
+ /**
+ * Set the shared instance of the container.
+ *
+ * @param \Illuminate\Contracts\Container\Container|null $container
+ * @return static
+ */
+ public static function setInstance(ContainerContract $container = null)
+ {
+ return static::$instance = $container;
+ }
+
+ /**
+ * Determine if a given offset exists.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function offsetExists($key)
+ {
+ return $this->bound($key);
+ }
+
+ /**
+ * Get the value at a given offset.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function offsetGet($key)
+ {
+ return $this->make($key);
+ }
+
+ /**
+ * Set the value at a given offset.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function offsetSet($key, $value)
+ {
+ $this->bind($key, $value instanceof Closure ? $value : function () use ($value) {
+ return $value;
+ });
+ }
+
+ /**
+ * Unset the value at a given offset.
+ *
+ * @param string $key
+ * @return void
+ */
+ public function offsetUnset($key)
+ {
+ unset($this->bindings[$key], $this->instances[$key], $this->resolved[$key]);
+ }
+
+ /**
+ * Dynamically access container services.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function __get($key)
+ {
+ return $this[$key];
+ }
+
+ /**
+ * Dynamically set container services.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function __set($key, $value)
+ {
+ $this[$key] = $value;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Container/ContextualBindingBuilder.php b/vendor/laravel/framework/src/Illuminate/Container/ContextualBindingBuilder.php
new file mode 100644
index 000000000..58b70cee4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Container/ContextualBindingBuilder.php
@@ -0,0 +1,68 @@
+concrete = $concrete;
+ $this->container = $container;
+ }
+
+ /**
+ * Define the abstract target that depends on the context.
+ *
+ * @param string $abstract
+ * @return $this
+ */
+ public function needs($abstract)
+ {
+ $this->needs = $abstract;
+
+ return $this;
+ }
+
+ /**
+ * Define the implementation for the contextual binding.
+ *
+ * @param \Closure|string $implementation
+ * @return void
+ */
+ public function give($implementation)
+ {
+ $this->container->addContextualBinding(
+ $this->concrete, $this->needs, $implementation
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Container/composer.json b/vendor/laravel/framework/src/Illuminate/Container/composer.json
new file mode 100644
index 000000000..97a919b26
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Container/composer.json
@@ -0,0 +1,34 @@
+{
+ "name": "illuminate/container",
+ "description": "The Illuminate Container package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Container\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Contracts/Auth/Access/Authorizable.php b/vendor/laravel/framework/src/Illuminate/Contracts/Auth/Access/Authorizable.php
new file mode 100644
index 000000000..2f9657c57
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Contracts/Auth/Access/Authorizable.php
@@ -0,0 +1,15 @@
+id = $id;
+ $this->class = $class;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Contracts/Debug/ExceptionHandler.php b/vendor/laravel/framework/src/Illuminate/Contracts/Debug/ExceptionHandler.php
new file mode 100644
index 000000000..e3f18a598
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Contracts/Debug/ExceptionHandler.php
@@ -0,0 +1,34 @@
+=5.6.4"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Contracts\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cookie/CookieJar.php b/vendor/laravel/framework/src/Illuminate/Cookie/CookieJar.php
new file mode 100644
index 000000000..93f53f535
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cookie/CookieJar.php
@@ -0,0 +1,178 @@
+getPathAndDomain($path, $domain, $secure);
+
+ $time = ($minutes == 0) ? 0 : Carbon::now()->getTimestamp() + ($minutes * 60);
+
+ return new Cookie($name, $value, $time, $path, $domain, $secure, $httpOnly);
+ }
+
+ /**
+ * Create a cookie that lasts "forever" (five years).
+ *
+ * @param string $name
+ * @param string $value
+ * @param string $path
+ * @param string $domain
+ * @param bool $secure
+ * @param bool $httpOnly
+ * @return \Symfony\Component\HttpFoundation\Cookie
+ */
+ public function forever($name, $value, $path = null, $domain = null, $secure = false, $httpOnly = true)
+ {
+ return $this->make($name, $value, 2628000, $path, $domain, $secure, $httpOnly);
+ }
+
+ /**
+ * Expire the given cookie.
+ *
+ * @param string $name
+ * @param string $path
+ * @param string $domain
+ * @return \Symfony\Component\HttpFoundation\Cookie
+ */
+ public function forget($name, $path = null, $domain = null)
+ {
+ return $this->make($name, null, -2628000, $path, $domain);
+ }
+
+ /**
+ * Determine if a cookie has been queued.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function hasQueued($key)
+ {
+ return ! is_null($this->queued($key));
+ }
+
+ /**
+ * Get a queued cookie instance.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return \Symfony\Component\HttpFoundation\Cookie
+ */
+ public function queued($key, $default = null)
+ {
+ return Arr::get($this->queued, $key, $default);
+ }
+
+ /**
+ * Queue a cookie to send with the next response.
+ *
+ * @param array $parameters
+ * @return void
+ */
+ public function queue(...$parameters)
+ {
+ if (head($parameters) instanceof Cookie) {
+ $cookie = head($parameters);
+ } else {
+ $cookie = call_user_func_array([$this, 'make'], $parameters);
+ }
+
+ $this->queued[$cookie->getName()] = $cookie;
+ }
+
+ /**
+ * Remove a cookie from the queue.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function unqueue($name)
+ {
+ unset($this->queued[$name]);
+ }
+
+ /**
+ * Get the path and domain, or the default values.
+ *
+ * @param string $path
+ * @param string $domain
+ * @param bool $secure
+ * @return array
+ */
+ protected function getPathAndDomain($path, $domain, $secure = false)
+ {
+ return [$path ?: $this->path, $domain ?: $this->domain, $secure ?: $this->secure];
+ }
+
+ /**
+ * Set the default path and domain for the jar.
+ *
+ * @param string $path
+ * @param string $domain
+ * @param bool $secure
+ * @return $this
+ */
+ public function setDefaultPathAndDomain($path, $domain, $secure = false)
+ {
+ list($this->path, $this->domain, $this->secure) = [$path, $domain, $secure];
+
+ return $this;
+ }
+
+ /**
+ * Get the cookies which have been queued for the next request.
+ *
+ * @return array
+ */
+ public function getQueuedCookies()
+ {
+ return $this->queued;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cookie/CookieServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Cookie/CookieServiceProvider.php
new file mode 100644
index 000000000..faeaa2a5a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cookie/CookieServiceProvider.php
@@ -0,0 +1,22 @@
+app->singleton('cookie', function ($app) {
+ $config = $app->make('config')->get('session');
+
+ return (new CookieJar)->setDefaultPathAndDomain($config['path'], $config['domain'], $config['secure']);
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cookie/Middleware/AddQueuedCookiesToResponse.php b/vendor/laravel/framework/src/Illuminate/Cookie/Middleware/AddQueuedCookiesToResponse.php
new file mode 100644
index 000000000..4caa57410
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cookie/Middleware/AddQueuedCookiesToResponse.php
@@ -0,0 +1,45 @@
+cookies = $cookies;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @return mixed
+ */
+ public function handle($request, Closure $next)
+ {
+ $response = $next($request);
+
+ foreach ($this->cookies->getQueuedCookies() as $cookie) {
+ $response->headers->setCookie($cookie);
+ }
+
+ return $response;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cookie/Middleware/EncryptCookies.php b/vendor/laravel/framework/src/Illuminate/Cookie/Middleware/EncryptCookies.php
new file mode 100644
index 000000000..1e630118c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cookie/Middleware/EncryptCookies.php
@@ -0,0 +1,163 @@
+encrypter = $encrypter;
+ }
+
+ /**
+ * Disable encryption for the given cookie name(s).
+ *
+ * @param string|array $cookieName
+ * @return void
+ */
+ public function disableFor($cookieName)
+ {
+ $this->except = array_merge($this->except, (array) $cookieName);
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @return mixed
+ */
+ public function handle($request, Closure $next)
+ {
+ return $this->encrypt($next($this->decrypt($request)));
+ }
+
+ /**
+ * Decrypt the cookies on the request.
+ *
+ * @param \Symfony\Component\HttpFoundation\Request $request
+ * @return \Symfony\Component\HttpFoundation\Request
+ */
+ protected function decrypt(Request $request)
+ {
+ foreach ($request->cookies as $key => $c) {
+ if ($this->isDisabled($key)) {
+ continue;
+ }
+
+ try {
+ $request->cookies->set($key, $this->decryptCookie($c));
+ } catch (DecryptException $e) {
+ $request->cookies->set($key, null);
+ }
+ }
+
+ return $request;
+ }
+
+ /**
+ * Decrypt the given cookie and return the value.
+ *
+ * @param string|array $cookie
+ * @return string|array
+ */
+ protected function decryptCookie($cookie)
+ {
+ return is_array($cookie)
+ ? $this->decryptArray($cookie)
+ : $this->encrypter->decrypt($cookie);
+ }
+
+ /**
+ * Decrypt an array based cookie.
+ *
+ * @param array $cookie
+ * @return array
+ */
+ protected function decryptArray(array $cookie)
+ {
+ $decrypted = [];
+
+ foreach ($cookie as $key => $value) {
+ if (is_string($value)) {
+ $decrypted[$key] = $this->encrypter->decrypt($value);
+ }
+ }
+
+ return $decrypted;
+ }
+
+ /**
+ * Encrypt the cookies on an outgoing response.
+ *
+ * @param \Symfony\Component\HttpFoundation\Response $response
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function encrypt(Response $response)
+ {
+ foreach ($response->headers->getCookies() as $cookie) {
+ if ($this->isDisabled($cookie->getName())) {
+ continue;
+ }
+
+ $response->headers->setCookie($this->duplicate(
+ $cookie, $this->encrypter->encrypt($cookie->getValue())
+ ));
+ }
+
+ return $response;
+ }
+
+ /**
+ * Duplicate a cookie with a new value.
+ *
+ * @param \Symfony\Component\HttpFoundation\Cookie $c
+ * @param mixed $value
+ * @return \Symfony\Component\HttpFoundation\Cookie
+ */
+ protected function duplicate(Cookie $c, $value)
+ {
+ return new Cookie(
+ $c->getName(), $value, $c->getExpiresTime(), $c->getPath(),
+ $c->getDomain(), $c->isSecure(), $c->isHttpOnly()
+ );
+ }
+
+ /**
+ * Determine whether encryption has been disabled for the given cookie.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function isDisabled($name)
+ {
+ return in_array($name, $this->except);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Cookie/composer.json b/vendor/laravel/framework/src/Illuminate/Cookie/composer.json
new file mode 100644
index 000000000..d412bad4c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Cookie/composer.json
@@ -0,0 +1,37 @@
+{
+ "name": "illuminate/cookie",
+ "description": "The Illuminate Cookie package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "symfony/http-foundation": "~3.2",
+ "symfony/http-kernel": "~3.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Cookie\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Capsule/Manager.php b/vendor/laravel/framework/src/Illuminate/Database/Capsule/Manager.php
new file mode 100644
index 000000000..b82a792ce
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Capsule/Manager.php
@@ -0,0 +1,201 @@
+setupContainer($container ?: new Container);
+
+ // Once we have the container setup, we will setup the default configuration
+ // options in the container "config" binding. This will make the database
+ // manager work correctly out of the box without extreme configuration.
+ $this->setupDefaultConfiguration();
+
+ $this->setupManager();
+ }
+
+ /**
+ * Setup the default database configuration options.
+ *
+ * @return void
+ */
+ protected function setupDefaultConfiguration()
+ {
+ $this->container['config']['database.fetch'] = PDO::FETCH_OBJ;
+
+ $this->container['config']['database.default'] = 'default';
+ }
+
+ /**
+ * Build the database manager instance.
+ *
+ * @return void
+ */
+ protected function setupManager()
+ {
+ $factory = new ConnectionFactory($this->container);
+
+ $this->manager = new DatabaseManager($this->container, $factory);
+ }
+
+ /**
+ * Get a connection instance from the global manager.
+ *
+ * @param string $connection
+ * @return \Illuminate\Database\Connection
+ */
+ public static function connection($connection = null)
+ {
+ return static::$instance->getConnection($connection);
+ }
+
+ /**
+ * Get a fluent query builder instance.
+ *
+ * @param string $table
+ * @param string $connection
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public static function table($table, $connection = null)
+ {
+ return static::$instance->connection($connection)->table($table);
+ }
+
+ /**
+ * Get a schema builder instance.
+ *
+ * @param string $connection
+ * @return \Illuminate\Database\Schema\Builder
+ */
+ public static function schema($connection = null)
+ {
+ return static::$instance->connection($connection)->getSchemaBuilder();
+ }
+
+ /**
+ * Get a registered connection instance.
+ *
+ * @param string $name
+ * @return \Illuminate\Database\Connection
+ */
+ public function getConnection($name = null)
+ {
+ return $this->manager->connection($name);
+ }
+
+ /**
+ * Register a connection with the manager.
+ *
+ * @param array $config
+ * @param string $name
+ * @return void
+ */
+ public function addConnection(array $config, $name = 'default')
+ {
+ $connections = $this->container['config']['database.connections'];
+
+ $connections[$name] = $config;
+
+ $this->container['config']['database.connections'] = $connections;
+ }
+
+ /**
+ * Bootstrap Eloquent so it is ready for usage.
+ *
+ * @return void
+ */
+ public function bootEloquent()
+ {
+ Eloquent::setConnectionResolver($this->manager);
+
+ // If we have an event dispatcher instance, we will go ahead and register it
+ // with the Eloquent ORM, allowing for model callbacks while creating and
+ // updating "model" instances; however, it is not necessary to operate.
+ if ($dispatcher = $this->getEventDispatcher()) {
+ Eloquent::setEventDispatcher($dispatcher);
+ }
+ }
+
+ /**
+ * Set the fetch mode for the database connections.
+ *
+ * @param int $fetchMode
+ * @return $this
+ */
+ public function setFetchMode($fetchMode)
+ {
+ $this->container['config']['database.fetch'] = $fetchMode;
+
+ return $this;
+ }
+
+ /**
+ * Get the database manager instance.
+ *
+ * @return \Illuminate\Database\DatabaseManager
+ */
+ public function getDatabaseManager()
+ {
+ return $this->manager;
+ }
+
+ /**
+ * Get the current event dispatcher instance.
+ *
+ * @return \Illuminate\Contracts\Events\Dispatcher|null
+ */
+ public function getEventDispatcher()
+ {
+ if ($this->container->bound('events')) {
+ return $this->container['events'];
+ }
+ }
+
+ /**
+ * Set the event dispatcher instance to be used by connections.
+ *
+ * @param \Illuminate\Contracts\Events\Dispatcher $dispatcher
+ * @return void
+ */
+ public function setEventDispatcher(Dispatcher $dispatcher)
+ {
+ $this->container->instance('events', $dispatcher);
+ }
+
+ /**
+ * Dynamically pass methods to the default connection.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public static function __callStatic($method, $parameters)
+ {
+ return static::connection()->$method(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Concerns/BuildsQueries.php b/vendor/laravel/framework/src/Illuminate/Database/Concerns/BuildsQueries.php
new file mode 100644
index 000000000..d1d1d2efa
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Concerns/BuildsQueries.php
@@ -0,0 +1,159 @@
+enforceOrderBy();
+
+ $page = 1;
+
+ do {
+ // We'll execute the query for the given page and get the results. If there are
+ // no results we can just break and return from here. When there are results
+ // we will call the callback with the current chunk of these results here.
+ $results = $this->forPage($page, $count)->get();
+
+ $countResults = $results->count();
+
+ if ($countResults == 0) {
+ break;
+ }
+
+ // On each chunk result set, we will pass them to the callback and then let the
+ // developer take care of everything within the callback, which allows us to
+ // keep the memory low for spinning through large result sets for working.
+ if ($callback($results) === false) {
+ return false;
+ }
+
+ $page++;
+ } while ($countResults == $count);
+
+ return true;
+ }
+
+ /**
+ * Execute a callback over each item while chunking.
+ *
+ * @param callable $callback
+ * @param int $count
+ * @return bool
+ */
+ public function each(callable $callback, $count = 1000)
+ {
+ return $this->chunk($count, function ($results) use ($callback) {
+ foreach ($results as $key => $value) {
+ if ($callback($value, $key) === false) {
+ return false;
+ }
+ }
+ });
+ }
+
+ /**
+ * Execute the query and get the first result.
+ *
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model|static|null
+ */
+ public function first($columns = ['*'])
+ {
+ return $this->take(1)->get($columns)->first();
+ }
+
+ /**
+ * Apply the callback's query changes if the given "value" is true.
+ *
+ * @param mixed $value
+ * @param callable $callback
+ * @param callable $default
+ * @return mixed
+ */
+ public function when($value, $callback, $default = null)
+ {
+ if ($value) {
+ return $callback($this, $value) ?: $this;
+ } elseif ($default) {
+ return $default($this, $value) ?: $this;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Pass the query to a given callback.
+ *
+ * @param \Closure $callback
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function tap($callback)
+ {
+ return $this->when(true, $callback);
+ }
+
+ /**
+ * Apply the callback's query changes if the given "value" is false.
+ *
+ * @param mixed $value
+ * @param callable $callback
+ * @param callable $default
+ * @return mixed
+ */
+ public function unless($value, $callback, $default = null)
+ {
+ if (! $value) {
+ return $callback($this, $value) ?: $this;
+ } elseif ($default) {
+ return $default($this, $value) ?: $this;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Create a new length-aware paginator instance.
+ *
+ * @param \Illuminate\Support\Collection $items
+ * @param int $total
+ * @param int $perPage
+ * @param int $currentPage
+ * @param array $options
+ * @return \Illuminate\Pagination\LengthAwarePaginator
+ */
+ protected function paginator($items, $total, $perPage, $currentPage, $options)
+ {
+ return Container::getInstance()->makeWith(LengthAwarePaginator::class, compact(
+ 'items', 'total', 'perPage', 'currentPage', 'options'
+ ));
+ }
+
+ /**
+ * Create a new simple paginator instance.
+ *
+ * @param \Illuminate\Support\Collection $items
+ * @param int $perPage
+ * @param int $currentPage
+ * @param array $options
+ * @return \Illuminate\Pagination\Paginator
+ */
+ protected function simplePaginator($items, $perPage, $currentPage, $options)
+ {
+ return Container::getInstance()->makeWith(Paginator::class, compact(
+ 'items', 'perPage', 'currentPage', 'options'
+ ));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Concerns/ManagesTransactions.php b/vendor/laravel/framework/src/Illuminate/Database/Concerns/ManagesTransactions.php
new file mode 100644
index 000000000..9b1dcd16c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Concerns/ManagesTransactions.php
@@ -0,0 +1,219 @@
+beginTransaction();
+
+ // We'll simply execute the given callback within a try / catch block and if we
+ // catch any exception we can rollback this transaction so that none of this
+ // gets actually persisted to a database or stored in a permanent fashion.
+ try {
+ return tap($callback($this), function ($result) {
+ $this->commit();
+ });
+ }
+
+ // If we catch an exception we'll rollback this transaction and try again if we
+ // are not out of attempts. If we are out of attempts we will just throw the
+ // exception back out and let the developer handle an uncaught exceptions.
+ catch (Exception $e) {
+ $this->handleTransactionException(
+ $e, $currentAttempt, $attempts
+ );
+ } catch (Throwable $e) {
+ $this->rollBack();
+
+ throw $e;
+ }
+ }
+ }
+
+ /**
+ * Handle an exception encountered when running a transacted statement.
+ *
+ * @param \Exception $e
+ * @param int $currentAttempt
+ * @param int $maxAttempts
+ * @return void
+ *
+ * @throws \Exception
+ */
+ protected function handleTransactionException($e, $currentAttempt, $maxAttempts)
+ {
+ // On a deadlock, MySQL rolls back the entire transaction so we can't just
+ // retry the query. We have to throw this exception all the way out and
+ // let the developer handle it in another way. We will decrement too.
+ if ($this->causedByDeadlock($e) &&
+ $this->transactions > 1) {
+ --$this->transactions;
+
+ throw $e;
+ }
+
+ // If there was an exception we will rollback this transaction and then we
+ // can check if we have exceeded the maximum attempt count for this and
+ // if we haven't we will return and try this query again in our loop.
+ $this->rollBack();
+
+ if ($this->causedByDeadlock($e) &&
+ $currentAttempt < $maxAttempts) {
+ return;
+ }
+
+ throw $e;
+ }
+
+ /**
+ * Start a new database transaction.
+ *
+ * @return void
+ * @throws \Exception
+ */
+ public function beginTransaction()
+ {
+ $this->createTransaction();
+
+ ++$this->transactions;
+
+ $this->fireConnectionEvent('beganTransaction');
+ }
+
+ /**
+ * Create a transaction within the database.
+ *
+ * @return void
+ */
+ protected function createTransaction()
+ {
+ if ($this->transactions == 0) {
+ try {
+ $this->getPdo()->beginTransaction();
+ } catch (Exception $e) {
+ $this->handleBeginTransactionException($e);
+ }
+ } elseif ($this->transactions >= 1 && $this->queryGrammar->supportsSavepoints()) {
+ $this->createSavepoint();
+ }
+ }
+
+ /**
+ * Create a save point within the database.
+ *
+ * @return void
+ */
+ protected function createSavepoint()
+ {
+ $this->getPdo()->exec(
+ $this->queryGrammar->compileSavepoint('trans'.($this->transactions + 1))
+ );
+ }
+
+ /**
+ * Handle an exception from a transaction beginning.
+ *
+ * @param \Exception $e
+ * @return void
+ *
+ * @throws \Exception
+ */
+ protected function handleBeginTransactionException($e)
+ {
+ if ($this->causedByLostConnection($e)) {
+ $this->reconnect();
+
+ $this->pdo->beginTransaction();
+ } else {
+ throw $e;
+ }
+ }
+
+ /**
+ * Commit the active database transaction.
+ *
+ * @return void
+ */
+ public function commit()
+ {
+ if ($this->transactions == 1) {
+ $this->getPdo()->commit();
+ }
+
+ $this->transactions = max(0, $this->transactions - 1);
+
+ $this->fireConnectionEvent('committed');
+ }
+
+ /**
+ * Rollback the active database transaction.
+ *
+ * @param int|null $toLevel
+ * @return void
+ */
+ public function rollBack($toLevel = null)
+ {
+ // We allow developers to rollback to a certain transaction level. We will verify
+ // that this given transaction level is valid before attempting to rollback to
+ // that level. If it's not we will just return out and not attempt anything.
+ $toLevel = is_null($toLevel)
+ ? $this->transactions - 1
+ : $toLevel;
+
+ if ($toLevel < 0 || $toLevel >= $this->transactions) {
+ return;
+ }
+
+ // Next, we will actually perform this rollback within this database and fire the
+ // rollback event. We will also set the current transaction level to the given
+ // level that was passed into this method so it will be right from here out.
+ $this->performRollBack($toLevel);
+
+ $this->transactions = $toLevel;
+
+ $this->fireConnectionEvent('rollingBack');
+ }
+
+ /**
+ * Perform a rollback within the database.
+ *
+ * @param int $toLevel
+ * @return void
+ */
+ protected function performRollBack($toLevel)
+ {
+ if ($toLevel == 0) {
+ $this->getPdo()->rollBack();
+ } elseif ($this->queryGrammar->supportsSavepoints()) {
+ $this->getPdo()->exec(
+ $this->queryGrammar->compileSavepointRollBack('trans'.($toLevel + 1))
+ );
+ }
+ }
+
+ /**
+ * Get the number of active transactions.
+ *
+ * @return int
+ */
+ public function transactionLevel()
+ {
+ return $this->transactions;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Connection.php b/vendor/laravel/framework/src/Illuminate/Database/Connection.php
new file mode 100644
index 000000000..8c744eb70
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Connection.php
@@ -0,0 +1,1203 @@
+pdo = $pdo;
+
+ // First we will setup the default properties. We keep track of the DB
+ // name we are connected to since it is needed when some reflective
+ // type commands are run such as checking whether a table exists.
+ $this->database = $database;
+
+ $this->tablePrefix = $tablePrefix;
+
+ $this->config = $config;
+
+ // We need to initialize a query grammar and the query post processors
+ // which are both very important parts of the database abstractions
+ // so we initialize these to their default values while starting.
+ $this->useDefaultQueryGrammar();
+
+ $this->useDefaultPostProcessor();
+ }
+
+ /**
+ * Set the query grammar to the default implementation.
+ *
+ * @return void
+ */
+ public function useDefaultQueryGrammar()
+ {
+ $this->queryGrammar = $this->getDefaultQueryGrammar();
+ }
+
+ /**
+ * Get the default query grammar instance.
+ *
+ * @return \Illuminate\Database\Query\Grammars\Grammar
+ */
+ protected function getDefaultQueryGrammar()
+ {
+ return new QueryGrammar;
+ }
+
+ /**
+ * Set the schema grammar to the default implementation.
+ *
+ * @return void
+ */
+ public function useDefaultSchemaGrammar()
+ {
+ $this->schemaGrammar = $this->getDefaultSchemaGrammar();
+ }
+
+ /**
+ * Get the default schema grammar instance.
+ *
+ * @return \Illuminate\Database\Schema\Grammars\Grammar
+ */
+ protected function getDefaultSchemaGrammar()
+ {
+ //
+ }
+
+ /**
+ * Set the query post processor to the default implementation.
+ *
+ * @return void
+ */
+ public function useDefaultPostProcessor()
+ {
+ $this->postProcessor = $this->getDefaultPostProcessor();
+ }
+
+ /**
+ * Get the default post processor instance.
+ *
+ * @return \Illuminate\Database\Query\Processors\Processor
+ */
+ protected function getDefaultPostProcessor()
+ {
+ return new Processor;
+ }
+
+ /**
+ * Get a schema builder instance for the connection.
+ *
+ * @return \Illuminate\Database\Schema\Builder
+ */
+ public function getSchemaBuilder()
+ {
+ if (is_null($this->schemaGrammar)) {
+ $this->useDefaultSchemaGrammar();
+ }
+
+ return new SchemaBuilder($this);
+ }
+
+ /**
+ * Begin a fluent query against a database table.
+ *
+ * @param string $table
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function table($table)
+ {
+ return $this->query()->from($table);
+ }
+
+ /**
+ * Get a new query builder instance.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function query()
+ {
+ return new QueryBuilder(
+ $this, $this->getQueryGrammar(), $this->getPostProcessor()
+ );
+ }
+
+ /**
+ * Run a select statement and return a single result.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @param bool $useReadPdo
+ * @return mixed
+ */
+ public function selectOne($query, $bindings = [], $useReadPdo = true)
+ {
+ $records = $this->select($query, $bindings, $useReadPdo);
+
+ return array_shift($records);
+ }
+
+ /**
+ * Run a select statement against the database.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @return array
+ */
+ public function selectFromWriteConnection($query, $bindings = [])
+ {
+ return $this->select($query, $bindings, false);
+ }
+
+ /**
+ * Run a select statement against the database.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @param bool $useReadPdo
+ * @return array
+ */
+ public function select($query, $bindings = [], $useReadPdo = true)
+ {
+ return $this->run($query, $bindings, function ($query, $bindings) use ($useReadPdo) {
+ if ($this->pretending()) {
+ return [];
+ }
+
+ // For select statements, we'll simply execute the query and return an array
+ // of the database result set. Each element in the array will be a single
+ // row from the database table, and will either be an array or objects.
+ $statement = $this->prepared($this->getPdoForSelect($useReadPdo)
+ ->prepare($query));
+
+ $this->bindValues($statement, $this->prepareBindings($bindings));
+
+ $statement->execute();
+
+ return $statement->fetchAll();
+ });
+ }
+
+ /**
+ * Run a select statement against the database and returns a generator.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @param bool $useReadPdo
+ * @return \Generator
+ */
+ public function cursor($query, $bindings = [], $useReadPdo = true)
+ {
+ $statement = $this->run($query, $bindings, function ($query, $bindings) use ($useReadPdo) {
+ if ($this->pretending()) {
+ return [];
+ }
+
+ // First we will create a statement for the query. Then, we will set the fetch
+ // mode and prepare the bindings for the query. Once that's done we will be
+ // ready to execute the query against the database and return the cursor.
+ $statement = $this->prepared($this->getPdoForSelect($useReadPdo)
+ ->prepare($query));
+
+ $this->bindValues(
+ $statement, $this->prepareBindings($bindings)
+ );
+
+ // Next, we'll execute the query against the database and return the statement
+ // so we can return the cursor. The cursor will use a PHP generator to give
+ // back one row at a time without using a bunch of memory to render them.
+ $statement->execute();
+
+ return $statement;
+ });
+
+ while ($record = $statement->fetch()) {
+ yield $record;
+ }
+ }
+
+ /**
+ * Configure the PDO prepared statement.
+ *
+ * @param \PDOStatement $statement
+ * @return \PDOStatement
+ */
+ protected function prepared(PDOStatement $statement)
+ {
+ $statement->setFetchMode($this->fetchMode);
+
+ $this->event(new Events\StatementPrepared(
+ $this, $statement
+ ));
+
+ return $statement;
+ }
+
+ /**
+ * Get the PDO connection to use for a select query.
+ *
+ * @param bool $useReadPdo
+ * @return \PDO
+ */
+ protected function getPdoForSelect($useReadPdo = true)
+ {
+ return $useReadPdo ? $this->getReadPdo() : $this->getPdo();
+ }
+
+ /**
+ * Run an insert statement against the database.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @return bool
+ */
+ public function insert($query, $bindings = [])
+ {
+ return $this->statement($query, $bindings);
+ }
+
+ /**
+ * Run an update statement against the database.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @return int
+ */
+ public function update($query, $bindings = [])
+ {
+ return $this->affectingStatement($query, $bindings);
+ }
+
+ /**
+ * Run a delete statement against the database.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @return int
+ */
+ public function delete($query, $bindings = [])
+ {
+ return $this->affectingStatement($query, $bindings);
+ }
+
+ /**
+ * Execute an SQL statement and return the boolean result.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @return bool
+ */
+ public function statement($query, $bindings = [])
+ {
+ return $this->run($query, $bindings, function ($query, $bindings) {
+ if ($this->pretending()) {
+ return true;
+ }
+
+ $statement = $this->getPdo()->prepare($query);
+
+ $this->bindValues($statement, $this->prepareBindings($bindings));
+
+ return $statement->execute();
+ });
+ }
+
+ /**
+ * Run an SQL statement and get the number of rows affected.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @return int
+ */
+ public function affectingStatement($query, $bindings = [])
+ {
+ return $this->run($query, $bindings, function ($query, $bindings) {
+ if ($this->pretending()) {
+ return 0;
+ }
+
+ // For update or delete statements, we want to get the number of rows affected
+ // by the statement and return that back to the developer. We'll first need
+ // to execute the statement and then we'll use PDO to fetch the affected.
+ $statement = $this->getPdo()->prepare($query);
+
+ $this->bindValues($statement, $this->prepareBindings($bindings));
+
+ $statement->execute();
+
+ return $statement->rowCount();
+ });
+ }
+
+ /**
+ * Run a raw, unprepared query against the PDO connection.
+ *
+ * @param string $query
+ * @return bool
+ */
+ public function unprepared($query)
+ {
+ return $this->run($query, [], function ($query) {
+ if ($this->pretending()) {
+ return true;
+ }
+
+ return $this->getPdo()->exec($query) === false ? false : true;
+ });
+ }
+
+ /**
+ * Execute the given callback in "dry run" mode.
+ *
+ * @param \Closure $callback
+ * @return array
+ */
+ public function pretend(Closure $callback)
+ {
+ return $this->withFreshQueryLog(function () use ($callback) {
+ $this->pretending = true;
+
+ // Basically to make the database connection "pretend", we will just return
+ // the default values for all the query methods, then we will return an
+ // array of queries that were "executed" within the Closure callback.
+ $callback($this);
+
+ $this->pretending = false;
+
+ return $this->queryLog;
+ });
+ }
+
+ /**
+ * Execute the given callback in "dry run" mode.
+ *
+ * @param \Closure $callback
+ * @return array
+ */
+ protected function withFreshQueryLog($callback)
+ {
+ $loggingQueries = $this->loggingQueries;
+
+ // First we will back up the value of the logging queries property and then
+ // we'll be ready to run callbacks. This query log will also get cleared
+ // so we will have a new log of all the queries that are executed now.
+ $this->enableQueryLog();
+
+ $this->queryLog = [];
+
+ // Now we'll execute this callback and capture the result. Once it has been
+ // executed we will restore the value of query logging and give back the
+ // value of hte callback so the original callers can have the results.
+ $result = $callback();
+
+ $this->loggingQueries = $loggingQueries;
+
+ return $result;
+ }
+
+ /**
+ * Bind values to their parameters in the given statement.
+ *
+ * @param \PDOStatement $statement
+ * @param array $bindings
+ * @return void
+ */
+ public function bindValues($statement, $bindings)
+ {
+ foreach ($bindings as $key => $value) {
+ $statement->bindValue(
+ is_string($key) ? $key : $key + 1, $value,
+ is_int($value) ? PDO::PARAM_INT : PDO::PARAM_STR
+ );
+ }
+ }
+
+ /**
+ * Prepare the query bindings for execution.
+ *
+ * @param array $bindings
+ * @return array
+ */
+ public function prepareBindings(array $bindings)
+ {
+ $grammar = $this->getQueryGrammar();
+
+ foreach ($bindings as $key => $value) {
+ // We need to transform all instances of DateTimeInterface into the actual
+ // date string. Each query grammar maintains its own date string format
+ // so we'll just ask the grammar for the format to get from the date.
+ if ($value instanceof DateTimeInterface) {
+ $bindings[$key] = $value->format($grammar->getDateFormat());
+ } elseif ($value === false) {
+ $bindings[$key] = 0;
+ }
+ }
+
+ return $bindings;
+ }
+
+ /**
+ * Run a SQL statement and log its execution context.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @param \Closure $callback
+ * @return mixed
+ *
+ * @throws \Illuminate\Database\QueryException
+ */
+ protected function run($query, $bindings, Closure $callback)
+ {
+ $this->reconnectIfMissingConnection();
+
+ $start = microtime(true);
+
+ // Here we will run this query. If an exception occurs we'll determine if it was
+ // caused by a connection that has been lost. If that is the cause, we'll try
+ // to re-establish connection and re-run the query with a fresh connection.
+ try {
+ $result = $this->runQueryCallback($query, $bindings, $callback);
+ } catch (QueryException $e) {
+ $result = $this->handleQueryException(
+ $e, $query, $bindings, $callback
+ );
+ }
+
+ // Once we have run the query we will calculate the time that it took to run and
+ // then log the query, bindings, and execution time so we will report them on
+ // the event that the developer needs them. We'll log time in milliseconds.
+ $this->logQuery(
+ $query, $bindings, $this->getElapsedTime($start)
+ );
+
+ return $result;
+ }
+
+ /**
+ * Run a SQL statement.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @param \Closure $callback
+ * @return mixed
+ *
+ * @throws \Illuminate\Database\QueryException
+ */
+ protected function runQueryCallback($query, $bindings, Closure $callback)
+ {
+ // To execute the statement, we'll simply call the callback, which will actually
+ // run the SQL against the PDO connection. Then we can calculate the time it
+ // took to execute and log the query SQL, bindings and time in our memory.
+ try {
+ $result = $callback($query, $bindings);
+ }
+
+ // If an exception occurs when attempting to run a query, we'll format the error
+ // message to include the bindings with SQL, which will make this exception a
+ // lot more helpful to the developer instead of just the database's errors.
+ catch (Exception $e) {
+ throw new QueryException(
+ $query, $this->prepareBindings($bindings), $e
+ );
+ }
+
+ return $result;
+ }
+
+ /**
+ * Log a query in the connection's query log.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @param float|null $time
+ * @return void
+ */
+ public function logQuery($query, $bindings, $time = null)
+ {
+ $this->event(new QueryExecuted($query, $bindings, $time, $this));
+
+ if ($this->loggingQueries) {
+ $this->queryLog[] = compact('query', 'bindings', 'time');
+ }
+ }
+
+ /**
+ * Get the elapsed time since a given starting point.
+ *
+ * @param int $start
+ * @return float
+ */
+ protected function getElapsedTime($start)
+ {
+ return round((microtime(true) - $start) * 1000, 2);
+ }
+
+ /**
+ * Handle a query exception.
+ *
+ * @param \Exception $e
+ * @param string $query
+ * @param array $bindings
+ * @param \Closure $callback
+ * @return mixed
+ * @throws \Exception
+ */
+ protected function handleQueryException($e, $query, $bindings, Closure $callback)
+ {
+ if ($this->transactions >= 1) {
+ throw $e;
+ }
+
+ return $this->tryAgainIfCausedByLostConnection(
+ $e, $query, $bindings, $callback
+ );
+ }
+
+ /**
+ * Handle a query exception that occurred during query execution.
+ *
+ * @param \Illuminate\Database\QueryException $e
+ * @param string $query
+ * @param array $bindings
+ * @param \Closure $callback
+ * @return mixed
+ *
+ * @throws \Illuminate\Database\QueryException
+ */
+ protected function tryAgainIfCausedByLostConnection(QueryException $e, $query, $bindings, Closure $callback)
+ {
+ if ($this->causedByLostConnection($e->getPrevious())) {
+ $this->reconnect();
+
+ return $this->runQueryCallback($query, $bindings, $callback);
+ }
+
+ throw $e;
+ }
+
+ /**
+ * Reconnect to the database.
+ *
+ * @return void
+ *
+ * @throws \LogicException
+ */
+ public function reconnect()
+ {
+ if (is_callable($this->reconnector)) {
+ return call_user_func($this->reconnector, $this);
+ }
+
+ throw new LogicException('Lost connection and no reconnector available.');
+ }
+
+ /**
+ * Reconnect to the database if a PDO connection is missing.
+ *
+ * @return void
+ */
+ protected function reconnectIfMissingConnection()
+ {
+ if (is_null($this->pdo)) {
+ $this->reconnect();
+ }
+ }
+
+ /**
+ * Disconnect from the underlying PDO connection.
+ *
+ * @return void
+ */
+ public function disconnect()
+ {
+ $this->setPdo(null)->setReadPdo(null);
+ }
+
+ /**
+ * Register a database query listener with the connection.
+ *
+ * @param \Closure $callback
+ * @return void
+ */
+ public function listen(Closure $callback)
+ {
+ if (isset($this->events)) {
+ $this->events->listen(Events\QueryExecuted::class, $callback);
+ }
+ }
+
+ /**
+ * Fire an event for this connection.
+ *
+ * @param string $event
+ * @return array|null
+ */
+ protected function fireConnectionEvent($event)
+ {
+ if (! isset($this->events)) {
+ return;
+ }
+
+ switch ($event) {
+ case 'beganTransaction':
+ return $this->events->dispatch(new Events\TransactionBeginning($this));
+ case 'committed':
+ return $this->events->dispatch(new Events\TransactionCommitted($this));
+ case 'rollingBack':
+ return $this->events->dispatch(new Events\TransactionRolledBack($this));
+ }
+ }
+
+ /**
+ * Fire the given event if possible.
+ *
+ * @param mixed $event
+ * @return void
+ */
+ protected function event($event)
+ {
+ if (isset($this->events)) {
+ $this->events->dispatch($event);
+ }
+ }
+
+ /**
+ * Get a new raw query expression.
+ *
+ * @param mixed $value
+ * @return \Illuminate\Database\Query\Expression
+ */
+ public function raw($value)
+ {
+ return new Expression($value);
+ }
+
+ /**
+ * Is Doctrine available?
+ *
+ * @return bool
+ */
+ public function isDoctrineAvailable()
+ {
+ return class_exists('Doctrine\DBAL\Connection');
+ }
+
+ /**
+ * Get a Doctrine Schema Column instance.
+ *
+ * @param string $table
+ * @param string $column
+ * @return \Doctrine\DBAL\Schema\Column
+ */
+ public function getDoctrineColumn($table, $column)
+ {
+ $schema = $this->getDoctrineSchemaManager();
+
+ return $schema->listTableDetails($table)->getColumn($column);
+ }
+
+ /**
+ * Get the Doctrine DBAL schema manager for the connection.
+ *
+ * @return \Doctrine\DBAL\Schema\AbstractSchemaManager
+ */
+ public function getDoctrineSchemaManager()
+ {
+ return $this->getDoctrineDriver()->getSchemaManager($this->getDoctrineConnection());
+ }
+
+ /**
+ * Get the Doctrine DBAL database connection instance.
+ *
+ * @return \Doctrine\DBAL\Connection
+ */
+ public function getDoctrineConnection()
+ {
+ if (is_null($this->doctrineConnection)) {
+ $data = ['pdo' => $this->getPdo(), 'dbname' => $this->getConfig('database')];
+
+ $this->doctrineConnection = new DoctrineConnection(
+ $data, $this->getDoctrineDriver()
+ );
+ }
+
+ return $this->doctrineConnection;
+ }
+
+ /**
+ * Get the current PDO connection.
+ *
+ * @return \PDO
+ */
+ public function getPdo()
+ {
+ if ($this->pdo instanceof Closure) {
+ return $this->pdo = call_user_func($this->pdo);
+ }
+
+ return $this->pdo;
+ }
+
+ /**
+ * Get the current PDO connection used for reading.
+ *
+ * @return \PDO
+ */
+ public function getReadPdo()
+ {
+ if ($this->transactions >= 1) {
+ return $this->getPdo();
+ }
+
+ if ($this->readPdo instanceof Closure) {
+ return $this->readPdo = call_user_func($this->readPdo);
+ }
+
+ return $this->readPdo ?: $this->getPdo();
+ }
+
+ /**
+ * Set the PDO connection.
+ *
+ * @param \PDO|\Closure|null $pdo
+ * @return $this
+ */
+ public function setPdo($pdo)
+ {
+ $this->transactions = 0;
+
+ $this->pdo = $pdo;
+
+ return $this;
+ }
+
+ /**
+ * Set the PDO connection used for reading.
+ *
+ * @param \PDO||\Closure|null $pdo
+ * @return $this
+ */
+ public function setReadPdo($pdo)
+ {
+ $this->readPdo = $pdo;
+
+ return $this;
+ }
+
+ /**
+ * Set the reconnect instance on the connection.
+ *
+ * @param callable $reconnector
+ * @return $this
+ */
+ public function setReconnector(callable $reconnector)
+ {
+ $this->reconnector = $reconnector;
+
+ return $this;
+ }
+
+ /**
+ * Get the database connection name.
+ *
+ * @return string|null
+ */
+ public function getName()
+ {
+ return $this->getConfig('name');
+ }
+
+ /**
+ * Get an option from the configuration options.
+ *
+ * @param string|null $option
+ * @return mixed
+ */
+ public function getConfig($option = null)
+ {
+ return Arr::get($this->config, $option);
+ }
+
+ /**
+ * Get the PDO driver name.
+ *
+ * @return string
+ */
+ public function getDriverName()
+ {
+ return $this->getConfig('driver');
+ }
+
+ /**
+ * Get the query grammar used by the connection.
+ *
+ * @return \Illuminate\Database\Query\Grammars\Grammar
+ */
+ public function getQueryGrammar()
+ {
+ return $this->queryGrammar;
+ }
+
+ /**
+ * Set the query grammar used by the connection.
+ *
+ * @param \Illuminate\Database\Query\Grammars\Grammar $grammar
+ * @return void
+ */
+ public function setQueryGrammar(Query\Grammars\Grammar $grammar)
+ {
+ $this->queryGrammar = $grammar;
+ }
+
+ /**
+ * Get the schema grammar used by the connection.
+ *
+ * @return \Illuminate\Database\Schema\Grammars\Grammar
+ */
+ public function getSchemaGrammar()
+ {
+ return $this->schemaGrammar;
+ }
+
+ /**
+ * Set the schema grammar used by the connection.
+ *
+ * @param \Illuminate\Database\Schema\Grammars\Grammar $grammar
+ * @return void
+ */
+ public function setSchemaGrammar(Schema\Grammars\Grammar $grammar)
+ {
+ $this->schemaGrammar = $grammar;
+ }
+
+ /**
+ * Get the query post processor used by the connection.
+ *
+ * @return \Illuminate\Database\Query\Processors\Processor
+ */
+ public function getPostProcessor()
+ {
+ return $this->postProcessor;
+ }
+
+ /**
+ * Set the query post processor used by the connection.
+ *
+ * @param \Illuminate\Database\Query\Processors\Processor $processor
+ * @return void
+ */
+ public function setPostProcessor(Processor $processor)
+ {
+ $this->postProcessor = $processor;
+ }
+
+ /**
+ * Get the event dispatcher used by the connection.
+ *
+ * @return \Illuminate\Contracts\Events\Dispatcher
+ */
+ public function getEventDispatcher()
+ {
+ return $this->events;
+ }
+
+ /**
+ * Set the event dispatcher instance on the connection.
+ *
+ * @param \Illuminate\Contracts\Events\Dispatcher $events
+ * @return void
+ */
+ public function setEventDispatcher(Dispatcher $events)
+ {
+ $this->events = $events;
+ }
+
+ /**
+ * Determine if the connection in a "dry run".
+ *
+ * @return bool
+ */
+ public function pretending()
+ {
+ return $this->pretending === true;
+ }
+
+ /**
+ * Get the connection query log.
+ *
+ * @return array
+ */
+ public function getQueryLog()
+ {
+ return $this->queryLog;
+ }
+
+ /**
+ * Clear the query log.
+ *
+ * @return void
+ */
+ public function flushQueryLog()
+ {
+ $this->queryLog = [];
+ }
+
+ /**
+ * Enable the query log on the connection.
+ *
+ * @return void
+ */
+ public function enableQueryLog()
+ {
+ $this->loggingQueries = true;
+ }
+
+ /**
+ * Disable the query log on the connection.
+ *
+ * @return void
+ */
+ public function disableQueryLog()
+ {
+ $this->loggingQueries = false;
+ }
+
+ /**
+ * Determine whether we're logging queries.
+ *
+ * @return bool
+ */
+ public function logging()
+ {
+ return $this->loggingQueries;
+ }
+
+ /**
+ * Get the name of the connected database.
+ *
+ * @return string
+ */
+ public function getDatabaseName()
+ {
+ return $this->database;
+ }
+
+ /**
+ * Set the name of the connected database.
+ *
+ * @param string $database
+ * @return string
+ */
+ public function setDatabaseName($database)
+ {
+ $this->database = $database;
+ }
+
+ /**
+ * Get the table prefix for the connection.
+ *
+ * @return string
+ */
+ public function getTablePrefix()
+ {
+ return $this->tablePrefix;
+ }
+
+ /**
+ * Set the table prefix in use by the connection.
+ *
+ * @param string $prefix
+ * @return void
+ */
+ public function setTablePrefix($prefix)
+ {
+ $this->tablePrefix = $prefix;
+
+ $this->getQueryGrammar()->setTablePrefix($prefix);
+ }
+
+ /**
+ * Set the table prefix and return the grammar.
+ *
+ * @param \Illuminate\Database\Grammar $grammar
+ * @return \Illuminate\Database\Grammar
+ */
+ public function withTablePrefix(Grammar $grammar)
+ {
+ $grammar->setTablePrefix($this->tablePrefix);
+
+ return $grammar;
+ }
+
+ /**
+ * Register a connection resolver.
+ *
+ * @param string $driver
+ * @param \Closure $callback
+ * @return void
+ */
+ public static function resolverFor($driver, Closure $callback)
+ {
+ static::$resolvers[$driver] = $callback;
+ }
+
+ /**
+ * Get the connection resolver for the given driver.
+ *
+ * @param string $driver
+ * @return mixed
+ */
+ public static function getResolver($driver)
+ {
+ return isset(static::$resolvers[$driver]) ?
+ static::$resolvers[$driver] : null;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/ConnectionInterface.php b/vendor/laravel/framework/src/Illuminate/Database/ConnectionInterface.php
new file mode 100644
index 000000000..9262d6fdf
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/ConnectionInterface.php
@@ -0,0 +1,150 @@
+ $connection) {
+ $this->addConnection($name, $connection);
+ }
+ }
+
+ /**
+ * Get a database connection instance.
+ *
+ * @param string $name
+ * @return \Illuminate\Database\ConnectionInterface
+ */
+ public function connection($name = null)
+ {
+ if (is_null($name)) {
+ $name = $this->getDefaultConnection();
+ }
+
+ return $this->connections[$name];
+ }
+
+ /**
+ * Add a connection to the resolver.
+ *
+ * @param string $name
+ * @param \Illuminate\Database\ConnectionInterface $connection
+ * @return void
+ */
+ public function addConnection($name, ConnectionInterface $connection)
+ {
+ $this->connections[$name] = $connection;
+ }
+
+ /**
+ * Check if a connection has been registered.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function hasConnection($name)
+ {
+ return isset($this->connections[$name]);
+ }
+
+ /**
+ * Get the default connection name.
+ *
+ * @return string
+ */
+ public function getDefaultConnection()
+ {
+ return $this->default;
+ }
+
+ /**
+ * Set the default connection name.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setDefaultConnection($name)
+ {
+ $this->default = $name;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/ConnectionResolverInterface.php b/vendor/laravel/framework/src/Illuminate/Database/ConnectionResolverInterface.php
new file mode 100644
index 000000000..eb0397a5d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/ConnectionResolverInterface.php
@@ -0,0 +1,29 @@
+container = $container;
+ }
+
+ /**
+ * Establish a PDO connection based on the configuration.
+ *
+ * @param array $config
+ * @param string $name
+ * @return \Illuminate\Database\Connection
+ */
+ public function make(array $config, $name = null)
+ {
+ $config = $this->parseConfig($config, $name);
+
+ if (isset($config['read'])) {
+ return $this->createReadWriteConnection($config);
+ }
+
+ return $this->createSingleConnection($config);
+ }
+
+ /**
+ * Parse and prepare the database configuration.
+ *
+ * @param array $config
+ * @param string $name
+ * @return array
+ */
+ protected function parseConfig(array $config, $name)
+ {
+ return Arr::add(Arr::add($config, 'prefix', ''), 'name', $name);
+ }
+
+ /**
+ * Create a single database connection instance.
+ *
+ * @param array $config
+ * @return \Illuminate\Database\Connection
+ */
+ protected function createSingleConnection(array $config)
+ {
+ $pdo = $this->createPdoResolver($config);
+
+ return $this->createConnection(
+ $config['driver'], $pdo, $config['database'], $config['prefix'], $config
+ );
+ }
+
+ /**
+ * Create a single database connection instance.
+ *
+ * @param array $config
+ * @return \Illuminate\Database\Connection
+ */
+ protected function createReadWriteConnection(array $config)
+ {
+ $connection = $this->createSingleConnection($this->getWriteConfig($config));
+
+ return $connection->setReadPdo($this->createReadPdo($config));
+ }
+
+ /**
+ * Create a new PDO instance for reading.
+ *
+ * @param array $config
+ * @return \Closure
+ */
+ protected function createReadPdo(array $config)
+ {
+ return $this->createPdoResolver($this->getReadConfig($config));
+ }
+
+ /**
+ * Get the read configuration for a read / write connection.
+ *
+ * @param array $config
+ * @return array
+ */
+ protected function getReadConfig(array $config)
+ {
+ return $this->mergeReadWriteConfig(
+ $config, $this->getReadWriteConfig($config, 'read')
+ );
+ }
+
+ /**
+ * Get the read configuration for a read / write connection.
+ *
+ * @param array $config
+ * @return array
+ */
+ protected function getWriteConfig(array $config)
+ {
+ return $this->mergeReadWriteConfig(
+ $config, $this->getReadWriteConfig($config, 'write')
+ );
+ }
+
+ /**
+ * Get a read / write level configuration.
+ *
+ * @param array $config
+ * @param string $type
+ * @return array
+ */
+ protected function getReadWriteConfig(array $config, $type)
+ {
+ return isset($config[$type][0])
+ ? Arr::random($config[$type])
+ : $config[$type];
+ }
+
+ /**
+ * Merge a configuration for a read / write connection.
+ *
+ * @param array $config
+ * @param array $merge
+ * @return array
+ */
+ protected function mergeReadWriteConfig(array $config, array $merge)
+ {
+ return Arr::except(array_merge($config, $merge), ['read', 'write']);
+ }
+
+ /**
+ * Create a new Closure that resolves to a PDO instance.
+ *
+ * @param array $config
+ * @return \Closure
+ */
+ protected function createPdoResolver(array $config)
+ {
+ return array_key_exists('host', $config)
+ ? $this->createPdoResolverWithHosts($config)
+ : $this->createPdoResolverWithoutHosts($config);
+ }
+
+ /**
+ * Create a new Closure that resolves to a PDO instance with a specific host or an array of hosts.
+ *
+ * @param array $config
+ * @return \Closure
+ */
+ protected function createPdoResolverWithHosts(array $config)
+ {
+ return function () use ($config) {
+ foreach (Arr::shuffle($hosts = $this->parseHosts($config)) as $key => $host) {
+ $config['host'] = $host;
+
+ try {
+ return $this->createConnector($config)->connect($config);
+ } catch (PDOException $e) {
+ if (count($hosts) - 1 === $key && $this->container->bound(ExceptionHandler::class)) {
+ $this->container->make(ExceptionHandler::class)->report($e);
+ }
+ }
+ }
+
+ throw $e;
+ };
+ }
+
+ /**
+ * Parse the hosts configuration item into an array.
+ *
+ * @param array $config
+ * @return array
+ */
+ protected function parseHosts(array $config)
+ {
+ $hosts = array_wrap($config['host']);
+
+ if (empty($hosts)) {
+ throw new InvalidArgumentException('Database hosts array is empty.');
+ }
+
+ return $hosts;
+ }
+
+ /**
+ * Create a new Closure that resolves to a PDO instance where there is no configured host.
+ *
+ * @param array $config
+ * @return \Closure
+ */
+ protected function createPdoResolverWithoutHosts(array $config)
+ {
+ return function () use ($config) {
+ return $this->createConnector($config)->connect($config);
+ };
+ }
+
+ /**
+ * Create a connector instance based on the configuration.
+ *
+ * @param array $config
+ * @return \Illuminate\Database\Connectors\ConnectorInterface
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function createConnector(array $config)
+ {
+ if (! isset($config['driver'])) {
+ throw new InvalidArgumentException('A driver must be specified.');
+ }
+
+ if ($this->container->bound($key = "db.connector.{$config['driver']}")) {
+ return $this->container->make($key);
+ }
+
+ switch ($config['driver']) {
+ case 'mysql':
+ return new MySqlConnector;
+ case 'pgsql':
+ return new PostgresConnector;
+ case 'sqlite':
+ return new SQLiteConnector;
+ case 'sqlsrv':
+ return new SqlServerConnector;
+ }
+
+ throw new InvalidArgumentException("Unsupported driver [{$config['driver']}]");
+ }
+
+ /**
+ * Create a new connection instance.
+ *
+ * @param string $driver
+ * @param \PDO|\Closure $connection
+ * @param string $database
+ * @param string $prefix
+ * @param array $config
+ * @return \Illuminate\Database\Connection
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function createConnection($driver, $connection, $database, $prefix = '', array $config = [])
+ {
+ if ($resolver = Connection::getResolver($driver)) {
+ return $resolver($connection, $database, $prefix, $config);
+ }
+
+ switch ($driver) {
+ case 'mysql':
+ return new MySqlConnection($connection, $database, $prefix, $config);
+ case 'pgsql':
+ return new PostgresConnection($connection, $database, $prefix, $config);
+ case 'sqlite':
+ return new SQLiteConnection($connection, $database, $prefix, $config);
+ case 'sqlsrv':
+ return new SqlServerConnection($connection, $database, $prefix, $config);
+ }
+
+ throw new InvalidArgumentException("Unsupported driver [$driver]");
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php b/vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php
new file mode 100644
index 000000000..a56fe95a4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Connectors/Connector.php
@@ -0,0 +1,137 @@
+ PDO::CASE_NATURAL,
+ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
+ PDO::ATTR_ORACLE_NULLS => PDO::NULL_NATURAL,
+ PDO::ATTR_STRINGIFY_FETCHES => false,
+ PDO::ATTR_EMULATE_PREPARES => false,
+ ];
+
+ /**
+ * Create a new PDO connection.
+ *
+ * @param string $dsn
+ * @param array $config
+ * @param array $options
+ * @return \PDO
+ */
+ public function createConnection($dsn, array $config, array $options)
+ {
+ list($username, $password) = [
+ Arr::get($config, 'username'), Arr::get($config, 'password'),
+ ];
+
+ try {
+ return $this->createPdoConnection(
+ $dsn, $username, $password, $options
+ );
+ } catch (Exception $e) {
+ return $this->tryAgainIfCausedByLostConnection(
+ $e, $dsn, $username, $password, $options
+ );
+ }
+ }
+
+ /**
+ * Create a new PDO connection instance.
+ *
+ * @param string $dsn
+ * @param string $username
+ * @param string $password
+ * @param array $options
+ * @return \PDO
+ */
+ protected function createPdoConnection($dsn, $username, $password, $options)
+ {
+ if (class_exists(PDOConnection::class) && ! $this->isPersistentConnection($options)) {
+ return new PDOConnection($dsn, $username, $password, $options);
+ }
+
+ return new PDO($dsn, $username, $password, $options);
+ }
+
+ /**
+ * Determine if the connection is persistent.
+ *
+ * @param array $options
+ * @return bool
+ */
+ protected function isPersistentConnection($options)
+ {
+ return isset($options[PDO::ATTR_PERSISTENT]) &&
+ $options[PDO::ATTR_PERSISTENT];
+ }
+
+ /**
+ * Handle an exception that occurred during connect execution.
+ *
+ * @param \Exception $e
+ * @param string $dsn
+ * @param string $username
+ * @param string $password
+ * @param array $options
+ * @return \PDO
+ *
+ * @throws \Exception
+ */
+ protected function tryAgainIfCausedByLostConnection(Exception $e, $dsn, $username, $password, $options)
+ {
+ if ($this->causedByLostConnection($e)) {
+ return $this->createPdoConnection($dsn, $username, $password, $options);
+ }
+
+ throw $e;
+ }
+
+ /**
+ * Get the PDO options based on the configuration.
+ *
+ * @param array $config
+ * @return array
+ */
+ public function getOptions(array $config)
+ {
+ $options = Arr::get($config, 'options', []);
+
+ return array_diff_key($this->options, $options) + $options;
+ }
+
+ /**
+ * Get the default PDO connection options.
+ *
+ * @return array
+ */
+ public function getDefaultOptions()
+ {
+ return $this->options;
+ }
+
+ /**
+ * Set the default PDO connection options.
+ *
+ * @param array $options
+ * @return void
+ */
+ public function setDefaultOptions(array $options)
+ {
+ $this->options = $options;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Connectors/ConnectorInterface.php b/vendor/laravel/framework/src/Illuminate/Database/Connectors/ConnectorInterface.php
new file mode 100644
index 000000000..08597ac0d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Connectors/ConnectorInterface.php
@@ -0,0 +1,14 @@
+getDsn($config);
+
+ $options = $this->getOptions($config);
+
+ // We need to grab the PDO options that should be used while making the brand
+ // new connection instance. The PDO options control various aspects of the
+ // connection's behavior, and some might be specified by the developers.
+ $connection = $this->createConnection($dsn, $config, $options);
+
+ if (! empty($config['database'])) {
+ $connection->exec("use `{$config['database']}`;");
+ }
+
+ $this->configureEncoding($connection, $config);
+
+ // Next, we will check to see if a timezone has been specified in this config
+ // and if it has we will issue a statement to modify the timezone with the
+ // database. Setting this DB timezone is an optional configuration item.
+ $this->configureTimezone($connection, $config);
+
+ $this->setModes($connection, $config);
+
+ return $connection;
+ }
+
+ /**
+ * Set the connection character set and collation.
+ *
+ * @param \PDO $connection
+ * @param array $config
+ * @return void
+ */
+ protected function configureEncoding($connection, array $config)
+ {
+ if (! isset($config['charset'])) {
+ return $connection;
+ }
+
+ $connection->prepare(
+ "set names '{$config['charset']}'".$this->getCollation($config)
+ )->execute();
+ }
+
+ /**
+ * Get the collation for the configuration.
+ *
+ * @param array $config
+ * @return string
+ */
+ protected function getCollation(array $config)
+ {
+ return isset($config['collation']) ? " collate '{$config['collation']}'" : '';
+ }
+
+ /**
+ * Set the timezone on the connection.
+ *
+ * @param \PDO $connection
+ * @param array $config
+ * @return void
+ */
+ protected function configureTimezone($connection, array $config)
+ {
+ if (isset($config['timezone'])) {
+ $connection->prepare('set time_zone="'.$config['timezone'].'"')->execute();
+ }
+ }
+
+ /**
+ * Create a DSN string from a configuration.
+ *
+ * Chooses socket or host/port based on the 'unix_socket' config value.
+ *
+ * @param array $config
+ * @return string
+ */
+ protected function getDsn(array $config)
+ {
+ return $this->hasSocket($config)
+ ? $this->getSocketDsn($config)
+ : $this->getHostDsn($config);
+ }
+
+ /**
+ * Determine if the given configuration array has a UNIX socket value.
+ *
+ * @param array $config
+ * @return bool
+ */
+ protected function hasSocket(array $config)
+ {
+ return isset($config['unix_socket']) && ! empty($config['unix_socket']);
+ }
+
+ /**
+ * Get the DSN string for a socket configuration.
+ *
+ * @param array $config
+ * @return string
+ */
+ protected function getSocketDsn(array $config)
+ {
+ return "mysql:unix_socket={$config['unix_socket']};dbname={$config['database']}";
+ }
+
+ /**
+ * Get the DSN string for a host / port configuration.
+ *
+ * @param array $config
+ * @return string
+ */
+ protected function getHostDsn(array $config)
+ {
+ extract($config, EXTR_SKIP);
+
+ return isset($port)
+ ? "mysql:host={$host};port={$port};dbname={$database}"
+ : "mysql:host={$host};dbname={$database}";
+ }
+
+ /**
+ * Set the modes for the connection.
+ *
+ * @param \PDO $connection
+ * @param array $config
+ * @return void
+ */
+ protected function setModes(PDO $connection, array $config)
+ {
+ if (isset($config['modes'])) {
+ $this->setCustomModes($connection, $config);
+ } elseif (isset($config['strict'])) {
+ if ($config['strict']) {
+ $connection->prepare($this->strictMode())->execute();
+ } else {
+ $connection->prepare("set session sql_mode='NO_ENGINE_SUBSTITUTION'")->execute();
+ }
+ }
+ }
+
+ /**
+ * Set the custom modes on the connection.
+ *
+ * @param \PDO $connection
+ * @param array $config
+ * @return void
+ */
+ protected function setCustomModes(PDO $connection, array $config)
+ {
+ $modes = implode(',', $config['modes']);
+
+ $connection->prepare("set session sql_mode='{$modes}'")->execute();
+ }
+
+ /**
+ * Get the query to enable strict mode.
+ *
+ * @return string
+ */
+ protected function strictMode()
+ {
+ return "set session sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'";
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Connectors/PostgresConnector.php b/vendor/laravel/framework/src/Illuminate/Database/Connectors/PostgresConnector.php
new file mode 100644
index 000000000..0581b8b2a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Connectors/PostgresConnector.php
@@ -0,0 +1,174 @@
+ PDO::CASE_NATURAL,
+ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
+ PDO::ATTR_ORACLE_NULLS => PDO::NULL_NATURAL,
+ PDO::ATTR_STRINGIFY_FETCHES => false,
+ ];
+
+ /**
+ * Establish a database connection.
+ *
+ * @param array $config
+ * @return \PDO
+ */
+ public function connect(array $config)
+ {
+ // First we'll create the basic DSN and connection instance connecting to the
+ // using the configuration option specified by the developer. We will also
+ // set the default character set on the connections to UTF-8 by default.
+ $connection = $this->createConnection(
+ $this->getDsn($config), $config, $this->getOptions($config)
+ );
+
+ $this->configureEncoding($connection, $config);
+
+ // Next, we will check to see if a timezone has been specified in this config
+ // and if it has we will issue a statement to modify the timezone with the
+ // database. Setting this DB timezone is an optional configuration item.
+ $this->configureTimezone($connection, $config);
+
+ $this->configureSchema($connection, $config);
+
+ // Postgres allows an application_name to be set by the user and this name is
+ // used to when monitoring the application with pg_stat_activity. So we'll
+ // determine if the option has been specified and run a statement if so.
+ $this->configureApplicationName($connection, $config);
+
+ return $connection;
+ }
+
+ /**
+ * Set the connection character set and collation.
+ *
+ * @param \PDO $connection
+ * @param array $config
+ * @return void
+ */
+ protected function configureEncoding($connection, $config)
+ {
+ $charset = $config['charset'];
+
+ $connection->prepare("set names '$charset'")->execute();
+ }
+
+ /**
+ * Set the timezone on the connection.
+ *
+ * @param \PDO $connection
+ * @param array $config
+ * @return void
+ */
+ protected function configureTimezone($connection, array $config)
+ {
+ if (isset($config['timezone'])) {
+ $timezone = $config['timezone'];
+
+ $connection->prepare("set time zone '{$timezone}'")->execute();
+ }
+ }
+
+ /**
+ * Set the schema on the connection.
+ *
+ * @param \PDO $connection
+ * @param array $config
+ * @return void
+ */
+ protected function configureSchema($connection, $config)
+ {
+ if (isset($config['schema'])) {
+ $schema = $this->formatSchema($config['schema']);
+
+ $connection->prepare("set search_path to {$schema}")->execute();
+ }
+ }
+
+ /**
+ * Format the schema for the DSN.
+ *
+ * @param array|string $schema
+ * @return string
+ */
+ protected function formatSchema($schema)
+ {
+ if (is_array($schema)) {
+ return '"'.implode('", "', $schema).'"';
+ } else {
+ return '"'.$schema.'"';
+ }
+ }
+
+ /**
+ * Set the schema on the connection.
+ *
+ * @param \PDO $connection
+ * @param array $config
+ * @return void
+ */
+ protected function configureApplicationName($connection, $config)
+ {
+ if (isset($config['application_name'])) {
+ $applicationName = $config['application_name'];
+
+ $connection->prepare("set application_name to '$applicationName'")->execute();
+ }
+ }
+
+ /**
+ * Create a DSN string from a configuration.
+ *
+ * @param array $config
+ * @return string
+ */
+ protected function getDsn(array $config)
+ {
+ // First we will create the basic DSN setup as well as the port if it is in
+ // in the configuration options. This will give us the basic DSN we will
+ // need to establish the PDO connections and return them back for use.
+ extract($config, EXTR_SKIP);
+
+ $host = isset($host) ? "host={$host};" : '';
+
+ $dsn = "pgsql:{$host}dbname={$database}";
+
+ // If a port was specified, we will add it to this Postgres DSN connections
+ // format. Once we have done that we are ready to return this connection
+ // string back out for usage, as this has been fully constructed here.
+ if (isset($config['port'])) {
+ $dsn .= ";port={$port}";
+ }
+
+ return $this->addSslOptions($dsn, $config);
+ }
+
+ /**
+ * Add the SSL options to the DSN.
+ *
+ * @param string $dsn
+ * @param array $config
+ * @return string
+ */
+ protected function addSslOptions($dsn, array $config)
+ {
+ foreach (['sslmode', 'sslcert', 'sslkey', 'sslrootcert'] as $option) {
+ if (isset($config[$option])) {
+ $dsn .= ";{$option}={$config[$option]}";
+ }
+ }
+
+ return $dsn;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Connectors/SQLiteConnector.php b/vendor/laravel/framework/src/Illuminate/Database/Connectors/SQLiteConnector.php
new file mode 100644
index 000000000..28f90915b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Connectors/SQLiteConnector.php
@@ -0,0 +1,39 @@
+getOptions($config);
+
+ // SQLite supports "in-memory" databases that only last as long as the owning
+ // connection does. These are useful for tests or for short lifetime store
+ // querying. In-memory databases may only have a single open connection.
+ if ($config['database'] == ':memory:') {
+ return $this->createConnection('sqlite::memory:', $config, $options);
+ }
+
+ $path = realpath($config['database']);
+
+ // Here we'll verify that the SQLite database exists before going any further
+ // as the developer probably wants to know if the database exists and this
+ // SQLite driver will not throw any exception if it does not by default.
+ if ($path === false) {
+ throw new InvalidArgumentException("Database (${config['database']}) does not exist.");
+ }
+
+ return $this->createConnection("sqlite:{$path}", $config, $options);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Connectors/SqlServerConnector.php b/vendor/laravel/framework/src/Illuminate/Database/Connectors/SqlServerConnector.php
new file mode 100644
index 000000000..02883d5b5
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Connectors/SqlServerConnector.php
@@ -0,0 +1,175 @@
+ PDO::CASE_NATURAL,
+ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
+ PDO::ATTR_ORACLE_NULLS => PDO::NULL_NATURAL,
+ PDO::ATTR_STRINGIFY_FETCHES => false,
+ ];
+
+ /**
+ * Establish a database connection.
+ *
+ * @param array $config
+ * @return \PDO
+ */
+ public function connect(array $config)
+ {
+ $options = $this->getOptions($config);
+
+ return $this->createConnection($this->getDsn($config), $config, $options);
+ }
+
+ /**
+ * Create a DSN string from a configuration.
+ *
+ * @param array $config
+ * @return string
+ */
+ protected function getDsn(array $config)
+ {
+ // First we will create the basic DSN setup as well as the port if it is in
+ // in the configuration options. This will give us the basic DSN we will
+ // need to establish the PDO connections and return them back for use.
+ if (in_array('dblib', $this->getAvailableDrivers())) {
+ return $this->getDblibDsn($config);
+ } elseif ($this->prefersOdbc($config)) {
+ return $this->getOdbcDsn($config);
+ } else {
+ return $this->getSqlSrvDsn($config);
+ }
+ }
+
+ /**
+ * Determine if the database configuration prefers ODBC.
+ *
+ * @param array $config
+ * @return bool
+ */
+ protected function prefersOdbc(array $config)
+ {
+ return in_array('odbc', $this->getAvailableDrivers()) &&
+ array_get($config, 'odbc') === true;
+ }
+
+ /**
+ * Get the DSN string for a DbLib connection.
+ *
+ * @param array $config
+ * @return string
+ */
+ protected function getDblibDsn(array $config)
+ {
+ return $this->buildConnectString('dblib', array_merge([
+ 'host' => $this->buildHostString($config, ':'),
+ 'dbname' => $config['database'],
+ ], Arr::only($config, ['appname', 'charset'])));
+ }
+
+ /**
+ * Get the DSN string for an ODBC connection.
+ *
+ * @param array $config
+ * @return string
+ */
+ protected function getOdbcDsn(array $config)
+ {
+ return isset($config['odbc_datasource_name'])
+ ? 'odbc:'.$config['odbc_datasource_name'] : '';
+ }
+
+ /**
+ * Get the DSN string for a SqlSrv connection.
+ *
+ * @param array $config
+ * @return string
+ */
+ protected function getSqlSrvDsn(array $config)
+ {
+ $arguments = [
+ 'Server' => $this->buildHostString($config, ','),
+ ];
+
+ if (isset($config['database'])) {
+ $arguments['Database'] = $config['database'];
+ }
+
+ if (isset($config['readonly'])) {
+ $arguments['ApplicationIntent'] = 'ReadOnly';
+ }
+
+ if (isset($config['pooling']) && $config['pooling'] === false) {
+ $arguments['ConnectionPooling'] = '0';
+ }
+
+ if (isset($config['appname'])) {
+ $arguments['APP'] = $config['appname'];
+ }
+
+ if (isset($config['encrypt'])) {
+ $arguments['Encrypt'] = $config['encrypt'];
+ }
+
+ if (isset($config['trust_server_certificate'])) {
+ $arguments['TrustServerCertificate'] = $config['trust_server_certificate'];
+ }
+
+ if (isset($config['multiple_active_result_sets']) && $config['multiple_active_result_sets'] === false) {
+ $arguments['MultipleActiveResultSets'] = 'false';
+ }
+
+ return $this->buildConnectString('sqlsrv', $arguments);
+ }
+
+ /**
+ * Build a connection string from the given arguments.
+ *
+ * @param string $driver
+ * @param array $arguments
+ * @return string
+ */
+ protected function buildConnectString($driver, array $arguments)
+ {
+ return $driver.':'.implode(';', array_map(function ($key) use ($arguments) {
+ return sprintf('%s=%s', $key, $arguments[$key]);
+ }, array_keys($arguments)));
+ }
+
+ /**
+ * Build a host string from the given configuration.
+ *
+ * @param array $config
+ * @param string $separator
+ * @return string
+ */
+ protected function buildHostString(array $config, $separator)
+ {
+ if (isset($config['port']) && ! empty($config['port'])) {
+ return $config['host'].$separator.$config['port'];
+ } else {
+ return $config['host'];
+ }
+ }
+
+ /**
+ * Get the available PDO drivers.
+ *
+ * @return array
+ */
+ protected function getAvailableDrivers()
+ {
+ return PDO::getAvailableDrivers();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/BaseCommand.php b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/BaseCommand.php
new file mode 100644
index 000000000..81ca3cc75
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/BaseCommand.php
@@ -0,0 +1,39 @@
+input->hasOption('path') && $this->option('path')) {
+ return collect($this->option('path'))->map(function ($path) {
+ return $this->laravel->basePath().'/'.$path;
+ })->all();
+ }
+
+ return array_merge(
+ [$this->getMigrationPath()], $this->migrator->paths()
+ );
+ }
+
+ /**
+ * Get the path to the migration directory.
+ *
+ * @return string
+ */
+ protected function getMigrationPath()
+ {
+ return $this->laravel->databasePath().DIRECTORY_SEPARATOR.'migrations';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/InstallCommand.php b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/InstallCommand.php
new file mode 100644
index 000000000..103dcaa92
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/InstallCommand.php
@@ -0,0 +1,70 @@
+repository = $repository;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $this->repository->setSource($this->input->getOption('database'));
+
+ $this->repository->createRepository();
+
+ $this->info('Migration table created successfully.');
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['database', null, InputOption::VALUE_OPTIONAL, 'The database connection to use.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateCommand.php b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateCommand.php
new file mode 100644
index 000000000..092a7d242
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateCommand.php
@@ -0,0 +1,102 @@
+migrator = $migrator;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ if (! $this->confirmToProceed()) {
+ return;
+ }
+
+ $this->prepareDatabase();
+
+ // Next, we will check to see if a path option has been defined. If it has
+ // we will use the path relative to the root of this installation folder
+ // so that migrations may be run for any path within the applications.
+ $this->migrator->run($this->getMigrationPaths(), [
+ 'pretend' => $this->option('pretend'),
+ 'step' => $this->option('step'),
+ ]);
+
+ // Once the migrator has run we will grab the note output and send it out to
+ // the console screen, since the migrator itself functions without having
+ // any instances of the OutputInterface contract passed into the class.
+ foreach ($this->migrator->getNotes() as $note) {
+ $this->output->writeln($note);
+ }
+
+ // Finally, if the "seed" option has been given, we will re-run the database
+ // seed task to re-populate the database, which is convenient when adding
+ // a migration and a seed at the same time, as it is only this command.
+ if ($this->option('seed')) {
+ $this->call('db:seed', ['--force' => true]);
+ }
+ }
+
+ /**
+ * Prepare the migration database for running.
+ *
+ * @return void
+ */
+ protected function prepareDatabase()
+ {
+ $this->migrator->setConnection($this->option('database'));
+
+ if (! $this->migrator->repositoryExists()) {
+ $this->call(
+ 'migrate:install', ['--database' => $this->option('database')]
+ );
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateMakeCommand.php
new file mode 100644
index 000000000..fa2024afd
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/MigrateMakeCommand.php
@@ -0,0 +1,119 @@
+creator = $creator;
+ $this->composer = $composer;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ // It's possible for the developer to specify the tables to modify in this
+ // schema operation. The developer may also specify if this table needs
+ // to be freshly created so we can create the appropriate migrations.
+ $name = trim($this->input->getArgument('name'));
+
+ $table = $this->input->getOption('table');
+
+ $create = $this->input->getOption('create') ?: false;
+
+ // If no table was given as an option but a create option is given then we
+ // will use the "create" option as the table name. This allows the devs
+ // to pass a table name into this option as a short-cut for creating.
+ if (! $table && is_string($create)) {
+ $table = $create;
+
+ $create = true;
+ }
+
+ // Now we are ready to write the migration out to disk. Once we've written
+ // the migration out, we will dump-autoload for the entire framework to
+ // make sure that the migrations are registered by the class loaders.
+ $this->writeMigration($name, $table, $create);
+
+ $this->composer->dumpAutoloads();
+ }
+
+ /**
+ * Write the migration file to disk.
+ *
+ * @param string $name
+ * @param string $table
+ * @param bool $create
+ * @return string
+ */
+ protected function writeMigration($name, $table, $create)
+ {
+ $file = pathinfo($this->creator->create(
+ $name, $this->getMigrationPath(), $table, $create
+ ), PATHINFO_FILENAME);
+
+ $this->line("Created Migration: {$file}");
+ }
+
+ /**
+ * Get migration path (either specified by '--path' option or default location).
+ *
+ * @return string
+ */
+ protected function getMigrationPath()
+ {
+ if (! is_null($targetPath = $this->input->getOption('path'))) {
+ return $this->laravel->basePath().'/'.$targetPath;
+ }
+
+ return parent::getMigrationPath();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/RefreshCommand.php b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/RefreshCommand.php
new file mode 100644
index 000000000..4d2772b97
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/RefreshCommand.php
@@ -0,0 +1,154 @@
+confirmToProceed()) {
+ return;
+ }
+
+ // Next we'll gather some of the options so that we can have the right options
+ // to pass to the commands. This includes options such as which database to
+ // use and the path to use for the migration. Then we'll run the command.
+ $database = $this->input->getOption('database');
+
+ $path = $this->input->getOption('path');
+
+ $force = $this->input->getOption('force');
+
+ // If the "step" option is specified it means we only want to rollback a small
+ // number of migrations before migrating again. For example, the user might
+ // only rollback and remigrate the latest four migrations instead of all.
+ $step = $this->input->getOption('step') ?: 0;
+
+ if ($step > 0) {
+ $this->runRollback($database, $path, $step, $force);
+ } else {
+ $this->runReset($database, $path, $force);
+ }
+
+ // The refresh command is essentially just a brief aggregate of a few other of
+ // the migration commands and just provides a convenient wrapper to execute
+ // them in succession. We'll also see if we need to re-seed the database.
+ $this->call('migrate', [
+ '--database' => $database,
+ '--path' => $path,
+ '--force' => $force,
+ ]);
+
+ if ($this->needsSeeding()) {
+ $this->runSeeder($database);
+ }
+ }
+
+ /**
+ * Run the rollback command.
+ *
+ * @param string $database
+ * @param string $path
+ * @param bool $step
+ * @param bool $force
+ * @return void
+ */
+ protected function runRollback($database, $path, $step, $force)
+ {
+ $this->call('migrate:rollback', [
+ '--database' => $database,
+ '--path' => $path,
+ '--step' => $step,
+ '--force' => $force,
+ ]);
+ }
+
+ /**
+ * Run the reset command.
+ *
+ * @param string $database
+ * @param string $path
+ * @param bool $force
+ * @return void
+ */
+ protected function runReset($database, $path, $force)
+ {
+ $this->call('migrate:reset', [
+ '--database' => $database,
+ '--path' => $path,
+ '--force' => $force,
+ ]);
+ }
+
+ /**
+ * Determine if the developer has requested database seeding.
+ *
+ * @return bool
+ */
+ protected function needsSeeding()
+ {
+ return $this->option('seed') || $this->option('seeder');
+ }
+
+ /**
+ * Run the database seeder command.
+ *
+ * @param string $database
+ * @return void
+ */
+ protected function runSeeder($database)
+ {
+ $this->call('db:seed', [
+ '--database' => $database,
+ '--class' => $this->option('seeder') ?: 'DatabaseSeeder',
+ '--force' => $this->option('force'),
+ ]);
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['database', null, InputOption::VALUE_OPTIONAL, 'The database connection to use.'],
+
+ ['force', null, InputOption::VALUE_NONE, 'Force the operation to run when in production.'],
+
+ ['path', null, InputOption::VALUE_OPTIONAL, 'The path of migrations files to be executed.'],
+
+ ['seed', null, InputOption::VALUE_NONE, 'Indicates if the seed task should be re-run.'],
+
+ ['seeder', null, InputOption::VALUE_OPTIONAL, 'The class name of the root seeder.'],
+
+ ['step', null, InputOption::VALUE_OPTIONAL, 'The number of migrations to be reverted & re-run.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/ResetCommand.php b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/ResetCommand.php
new file mode 100644
index 000000000..3b8dab3ea
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/ResetCommand.php
@@ -0,0 +1,96 @@
+migrator = $migrator;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ if (! $this->confirmToProceed()) {
+ return;
+ }
+
+ $this->migrator->setConnection($this->option('database'));
+
+ // First, we'll make sure that the migration table actually exists before we
+ // start trying to rollback and re-run all of the migrations. If it's not
+ // present we'll just bail out with an info message for the developers.
+ if (! $this->migrator->repositoryExists()) {
+ return $this->comment('Migration table not found.');
+ }
+
+ $this->migrator->reset(
+ $this->getMigrationPaths(), $this->option('pretend')
+ );
+
+ // Once the migrator has run we will grab the note output and send it out to
+ // the console screen, since the migrator itself functions without having
+ // any instances of the OutputInterface contract passed into the class.
+ foreach ($this->migrator->getNotes() as $note) {
+ $this->output->writeln($note);
+ }
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['database', null, InputOption::VALUE_OPTIONAL, 'The database connection to use.'],
+
+ ['force', null, InputOption::VALUE_NONE, 'Force the operation to run when in production.'],
+
+ ['path', null, InputOption::VALUE_OPTIONAL | InputOption::VALUE_IS_ARRAY, 'The path(s) of migrations files to be executed.'],
+
+ ['pretend', null, InputOption::VALUE_NONE, 'Dump the SQL queries that would be run.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/RollbackCommand.php b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/RollbackCommand.php
new file mode 100644
index 000000000..4b1a75fae
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/RollbackCommand.php
@@ -0,0 +1,94 @@
+migrator = $migrator;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ if (! $this->confirmToProceed()) {
+ return;
+ }
+
+ $this->migrator->setConnection($this->option('database'));
+
+ $this->migrator->rollback(
+ $this->getMigrationPaths(), [
+ 'pretend' => $this->option('pretend'),
+ 'step' => (int) $this->option('step'),
+ ]
+ );
+
+ // Once the migrator has run we will grab the note output and send it out to
+ // the console screen, since the migrator itself functions without having
+ // any instances of the OutputInterface contract passed into the class.
+ foreach ($this->migrator->getNotes() as $note) {
+ $this->output->writeln($note);
+ }
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['database', null, InputOption::VALUE_OPTIONAL, 'The database connection to use.'],
+
+ ['force', null, InputOption::VALUE_NONE, 'Force the operation to run when in production.'],
+
+ ['path', null, InputOption::VALUE_OPTIONAL, 'The path of migrations files to be executed.'],
+
+ ['pretend', null, InputOption::VALUE_NONE, 'Dump the SQL queries that would be run.'],
+
+ ['step', null, InputOption::VALUE_OPTIONAL, 'The number of migrations to be reverted.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/StatusCommand.php b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/StatusCommand.php
new file mode 100644
index 000000000..34b98f27b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Migrations/StatusCommand.php
@@ -0,0 +1,108 @@
+migrator = $migrator;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $this->migrator->setConnection($this->option('database'));
+
+ if (! $this->migrator->repositoryExists()) {
+ return $this->error('No migrations found.');
+ }
+
+ $ran = $this->migrator->getRepository()->getRan();
+
+ if (count($migrations = $this->getStatusFor($ran)) > 0) {
+ $this->table(['Ran?', 'Migration'], $migrations);
+ } else {
+ $this->error('No migrations found');
+ }
+ }
+
+ /**
+ * Get the status for the given ran migrations.
+ *
+ * @param array $ran
+ * @return \Illuminate\Support\Collection
+ */
+ protected function getStatusFor(array $ran)
+ {
+ return Collection::make($this->getAllMigrationFiles())
+ ->map(function ($migration) use ($ran) {
+ $migrationName = $this->migrator->getMigrationName($migration);
+
+ return in_array($migrationName, $ran)
+ ? ['Y ', $migrationName]
+ : ['N ', $migrationName];
+ });
+ }
+
+ /**
+ * Get an array of all of the migration files.
+ *
+ * @return array
+ */
+ protected function getAllMigrationFiles()
+ {
+ return $this->migrator->getMigrationFiles($this->getMigrationPaths());
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['database', null, InputOption::VALUE_OPTIONAL, 'The database connection to use.'],
+
+ ['path', null, InputOption::VALUE_OPTIONAL, 'The path of migrations files to use.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/SeedCommand.php b/vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/SeedCommand.php
new file mode 100644
index 000000000..cf866e045
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/SeedCommand.php
@@ -0,0 +1,106 @@
+resolver = $resolver;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ if (! $this->confirmToProceed()) {
+ return;
+ }
+
+ $this->resolver->setDefaultConnection($this->getDatabase());
+
+ Model::unguarded(function () {
+ $this->getSeeder()->__invoke();
+ });
+ }
+
+ /**
+ * Get a seeder instance from the container.
+ *
+ * @return \Illuminate\Database\Seeder
+ */
+ protected function getSeeder()
+ {
+ $class = $this->laravel->make($this->input->getOption('class'));
+
+ return $class->setContainer($this->laravel)->setCommand($this);
+ }
+
+ /**
+ * Get the name of the database connection to use.
+ *
+ * @return string
+ */
+ protected function getDatabase()
+ {
+ $database = $this->input->getOption('database');
+
+ return $database ?: $this->laravel['config']['database.default'];
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['class', null, InputOption::VALUE_OPTIONAL, 'The class name of the root seeder', 'DatabaseSeeder'],
+
+ ['database', null, InputOption::VALUE_OPTIONAL, 'The database connection to seed'],
+
+ ['force', null, InputOption::VALUE_NONE, 'Force the operation to run when in production.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/SeederMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/SeederMakeCommand.php
new file mode 100644
index 000000000..89b793122
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/SeederMakeCommand.php
@@ -0,0 +1,96 @@
+composer = $composer;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ parent::fire();
+
+ $this->composer->dumpAutoloads();
+ }
+
+ /**
+ * Get the stub file for the generator.
+ *
+ * @return string
+ */
+ protected function getStub()
+ {
+ return __DIR__.'/stubs/seeder.stub';
+ }
+
+ /**
+ * Get the destination class path.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function getPath($name)
+ {
+ return $this->laravel->databasePath().'/seeds/'.$name.'.php';
+ }
+
+ /**
+ * Parse the class name and format according to the root namespace.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function qualifyClass($name)
+ {
+ return $name;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/stubs/seeder.stub b/vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/stubs/seeder.stub
new file mode 100644
index 000000000..4aa384542
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Console/Seeds/stubs/seeder.stub
@@ -0,0 +1,16 @@
+app = $app;
+ $this->factory = $factory;
+ }
+
+ /**
+ * Get a database connection instance.
+ *
+ * @param string $name
+ * @return \Illuminate\Database\Connection
+ */
+ public function connection($name = null)
+ {
+ list($database, $type) = $this->parseConnectionName($name);
+
+ $name = $name ?: $database;
+
+ // If we haven't created this connection, we'll create it based on the config
+ // provided in the application. Once we've created the connections we will
+ // set the "fetch mode" for PDO which determines the query return types.
+ if (! isset($this->connections[$name])) {
+ $this->connections[$name] = $this->configure(
+ $connection = $this->makeConnection($database), $type
+ );
+ }
+
+ return $this->connections[$name];
+ }
+
+ /**
+ * Parse the connection into an array of the name and read / write type.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function parseConnectionName($name)
+ {
+ $name = $name ?: $this->getDefaultConnection();
+
+ return Str::endsWith($name, ['::read', '::write'])
+ ? explode('::', $name, 2) : [$name, null];
+ }
+
+ /**
+ * Make the database connection instance.
+ *
+ * @param string $name
+ * @return \Illuminate\Database\Connection
+ */
+ protected function makeConnection($name)
+ {
+ $config = $this->configuration($name);
+
+ // First we will check by the connection name to see if an extension has been
+ // registered specifically for that connection. If it has we will call the
+ // Closure and pass it the config allowing it to resolve the connection.
+ if (isset($this->extensions[$name])) {
+ return call_user_func($this->extensions[$name], $config, $name);
+ }
+
+ // Next we will check to see if an extension has been registered for a driver
+ // and will call the Closure if so, which allows us to have a more generic
+ // resolver for the drivers themselves which applies to all connections.
+ if (isset($this->extensions[$driver = $config['driver']])) {
+ return call_user_func($this->extensions[$driver], $config, $name);
+ }
+
+ return $this->factory->make($config, $name);
+ }
+
+ /**
+ * Get the configuration for a connection.
+ *
+ * @param string $name
+ * @return array
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function configuration($name)
+ {
+ $name = $name ?: $this->getDefaultConnection();
+
+ // To get the database connection configuration, we will just pull each of the
+ // connection configurations and get the configurations for the given name.
+ // If the configuration doesn't exist, we'll throw an exception and bail.
+ $connections = $this->app['config']['database.connections'];
+
+ if (is_null($config = Arr::get($connections, $name))) {
+ throw new InvalidArgumentException("Database [$name] not configured.");
+ }
+
+ return $config;
+ }
+
+ /**
+ * Prepare the database connection instance.
+ *
+ * @param \Illuminate\Database\Connection $connection
+ * @param string $type
+ * @return \Illuminate\Database\Connection
+ */
+ protected function configure(Connection $connection, $type)
+ {
+ $connection = $this->setPdoForType($connection, $type);
+
+ // First we'll set the fetch mode and a few other dependencies of the database
+ // connection. This method basically just configures and prepares it to get
+ // used by the application. Once we're finished we'll return it back out.
+ if ($this->app->bound('events')) {
+ $connection->setEventDispatcher($this->app['events']);
+ }
+
+ // Here we'll set a reconnector callback. This reconnector can be any callable
+ // so we will set a Closure to reconnect from this manager with the name of
+ // the connection, which will allow us to reconnect from the connections.
+ $connection->setReconnector(function ($connection) {
+ $this->reconnect($connection->getName());
+ });
+
+ return $connection;
+ }
+
+ /**
+ * Prepare the read / write mode for database connection instance.
+ *
+ * @param \Illuminate\Database\Connection $connection
+ * @param string $type
+ * @return \Illuminate\Database\Connection
+ */
+ protected function setPdoForType(Connection $connection, $type = null)
+ {
+ if ($type == 'read') {
+ $connection->setPdo($connection->getReadPdo());
+ } elseif ($type == 'write') {
+ $connection->setReadPdo($connection->getPdo());
+ }
+
+ return $connection;
+ }
+
+ /**
+ * Disconnect from the given database and remove from local cache.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function purge($name = null)
+ {
+ $name = $name ?: $this->getDefaultConnection();
+
+ $this->disconnect($name);
+
+ unset($this->connections[$name]);
+ }
+
+ /**
+ * Disconnect from the given database.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function disconnect($name = null)
+ {
+ if (isset($this->connections[$name = $name ?: $this->getDefaultConnection()])) {
+ $this->connections[$name]->disconnect();
+ }
+ }
+
+ /**
+ * Reconnect to the given database.
+ *
+ * @param string $name
+ * @return \Illuminate\Database\Connection
+ */
+ public function reconnect($name = null)
+ {
+ $this->disconnect($name = $name ?: $this->getDefaultConnection());
+
+ if (! isset($this->connections[$name])) {
+ return $this->connection($name);
+ }
+
+ return $this->refreshPdoConnections($name);
+ }
+
+ /**
+ * Refresh the PDO connections on a given connection.
+ *
+ * @param string $name
+ * @return \Illuminate\Database\Connection
+ */
+ protected function refreshPdoConnections($name)
+ {
+ $fresh = $this->makeConnection($name);
+
+ return $this->connections[$name]
+ ->setPdo($fresh->getPdo())
+ ->setReadPdo($fresh->getReadPdo());
+ }
+
+ /**
+ * Get the default connection name.
+ *
+ * @return string
+ */
+ public function getDefaultConnection()
+ {
+ return $this->app['config']['database.default'];
+ }
+
+ /**
+ * Set the default connection name.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setDefaultConnection($name)
+ {
+ $this->app['config']['database.default'] = $name;
+ }
+
+ /**
+ * Get all of the support drivers.
+ *
+ * @return array
+ */
+ public function supportedDrivers()
+ {
+ return ['mysql', 'pgsql', 'sqlite', 'sqlsrv'];
+ }
+
+ /**
+ * Get all of the drivers that are actually available.
+ *
+ * @return array
+ */
+ public function availableDrivers()
+ {
+ return array_intersect(
+ $this->supportedDrivers(),
+ str_replace('dblib', 'sqlsrv', PDO::getAvailableDrivers())
+ );
+ }
+
+ /**
+ * Register an extension connection resolver.
+ *
+ * @param string $name
+ * @param callable $resolver
+ * @return void
+ */
+ public function extend($name, callable $resolver)
+ {
+ $this->extensions[$name] = $resolver;
+ }
+
+ /**
+ * Return all of the created connections.
+ *
+ * @return array
+ */
+ public function getConnections()
+ {
+ return $this->connections;
+ }
+
+ /**
+ * Dynamically pass methods to the default connection.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->connection()->$method(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/DatabaseServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Database/DatabaseServiceProvider.php
new file mode 100644
index 000000000..a8ee7b030
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/DatabaseServiceProvider.php
@@ -0,0 +1,99 @@
+app['db']);
+
+ Model::setEventDispatcher($this->app['events']);
+ }
+
+ /**
+ * Register the service provider.
+ *
+ * @return void
+ */
+ public function register()
+ {
+ Model::clearBootedModels();
+
+ $this->registerConnectionServices();
+
+ $this->registerEloquentFactory();
+
+ $this->registerQueueableEntityResolver();
+ }
+
+ /**
+ * Register the primary database bindings.
+ *
+ * @return void
+ */
+ protected function registerConnectionServices()
+ {
+ // The connection factory is used to create the actual connection instances on
+ // the database. We will inject the factory into the manager so that it may
+ // make the connections while they are actually needed and not of before.
+ $this->app->singleton('db.factory', function ($app) {
+ return new ConnectionFactory($app);
+ });
+
+ // The database manager is used to resolve various connections, since multiple
+ // connections might be managed. It also implements the connection resolver
+ // interface which may be used by other components requiring connections.
+ $this->app->singleton('db', function ($app) {
+ return new DatabaseManager($app, $app['db.factory']);
+ });
+
+ $this->app->bind('db.connection', function ($app) {
+ return $app['db']->connection();
+ });
+ }
+
+ /**
+ * Register the Eloquent factory instance in the container.
+ *
+ * @return void
+ */
+ protected function registerEloquentFactory()
+ {
+ $this->app->singleton(FakerGenerator::class, function ($app) {
+ return FakerFactory::create($app['config']->get('app.faker_locale', 'en_US'));
+ });
+
+ $this->app->singleton(EloquentFactory::class, function ($app) {
+ return EloquentFactory::construct(
+ $app->make(FakerGenerator::class), $this->app->databasePath('factories')
+ );
+ });
+ }
+
+ /**
+ * Register the queueable entity resolver implementation.
+ *
+ * @return void
+ */
+ protected function registerQueueableEntityResolver()
+ {
+ $this->app->singleton(EntityResolver::class, function () {
+ return new QueueEntityResolver;
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/DetectsDeadlocks.php b/vendor/laravel/framework/src/Illuminate/Database/DetectsDeadlocks.php
new file mode 100644
index 000000000..ee034b60f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/DetectsDeadlocks.php
@@ -0,0 +1,31 @@
+getMessage();
+
+ return Str::contains($message, [
+ 'Deadlock found when trying to get lock',
+ 'deadlock detected',
+ 'The database file is locked',
+ 'database is locked',
+ 'database table is locked',
+ 'A table in the database is locked',
+ 'has been chosen as the deadlock victim',
+ 'Lock wait timeout exceeded; try restarting transaction',
+ ]);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/DetectsLostConnections.php b/vendor/laravel/framework/src/Illuminate/Database/DetectsLostConnections.php
new file mode 100644
index 000000000..034fbe649
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/DetectsLostConnections.php
@@ -0,0 +1,34 @@
+getMessage();
+
+ return Str::contains($message, [
+ 'server has gone away',
+ 'no connection to the server',
+ 'Lost connection',
+ 'is dead or not enabled',
+ 'Error while sending',
+ 'decryption failed or bad record mac',
+ 'server closed the connection unexpectedly',
+ 'SSL connection has been closed unexpectedly',
+ 'Error writing data to the connection',
+ 'Resource deadlock avoided',
+ 'Transaction() on null',
+ ]);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Builder.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Builder.php
new file mode 100644
index 000000000..9582fe02b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Builder.php
@@ -0,0 +1,1296 @@
+query = $query;
+ }
+
+ /**
+ * Create and return an un-saved model instance.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function make(array $attributes = [])
+ {
+ return $this->newModelInstance($attributes);
+ }
+
+ /**
+ * Register a new global scope.
+ *
+ * @param string $identifier
+ * @param \Illuminate\Database\Eloquent\Scope|\Closure $scope
+ * @return $this
+ */
+ public function withGlobalScope($identifier, $scope)
+ {
+ $this->scopes[$identifier] = $scope;
+
+ if (method_exists($scope, 'extend')) {
+ $scope->extend($this);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Remove a registered global scope.
+ *
+ * @param \Illuminate\Database\Eloquent\Scope|string $scope
+ * @return $this
+ */
+ public function withoutGlobalScope($scope)
+ {
+ if (! is_string($scope)) {
+ $scope = get_class($scope);
+ }
+
+ unset($this->scopes[$scope]);
+
+ $this->removedScopes[] = $scope;
+
+ return $this;
+ }
+
+ /**
+ * Remove all or passed registered global scopes.
+ *
+ * @param array|null $scopes
+ * @return $this
+ */
+ public function withoutGlobalScopes(array $scopes = null)
+ {
+ if (is_array($scopes)) {
+ foreach ($scopes as $scope) {
+ $this->withoutGlobalScope($scope);
+ }
+ } else {
+ $this->scopes = [];
+ }
+
+ return $this;
+ }
+
+ /**
+ * Get an array of global scopes that were removed from the query.
+ *
+ * @return array
+ */
+ public function removedScopes()
+ {
+ return $this->removedScopes;
+ }
+
+ /**
+ * Add a where clause on the primary key to the query.
+ *
+ * @param mixed $id
+ * @return $this
+ */
+ public function whereKey($id)
+ {
+ if (is_array($id) || $id instanceof Arrayable) {
+ $this->query->whereIn($this->model->getQualifiedKeyName(), $id);
+
+ return $this;
+ }
+
+ return $this->where($this->model->getQualifiedKeyName(), '=', $id);
+ }
+
+ /**
+ * Add a basic where clause to the query.
+ *
+ * @param string|array|\Closure $column
+ * @param string $operator
+ * @param mixed $value
+ * @param string $boolean
+ * @return $this
+ */
+ public function where($column, $operator = null, $value = null, $boolean = 'and')
+ {
+ if ($column instanceof Closure) {
+ $query = $this->model->newQueryWithoutScopes();
+
+ $column($query);
+
+ $this->query->addNestedWhereQuery($query->getQuery(), $boolean);
+ } else {
+ $this->query->where(...func_get_args());
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add an "or where" clause to the query.
+ *
+ * @param string|array|\Closure $column
+ * @param string $operator
+ * @param mixed $value
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function orWhere($column, $operator = null, $value = null)
+ {
+ return $this->where($column, $operator, $value, 'or');
+ }
+
+ /**
+ * Create a collection of models from plain arrays.
+ *
+ * @param array $items
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ public function hydrate(array $items)
+ {
+ $instance = $this->newModelInstance();
+
+ return $instance->newCollection(array_map(function ($item) use ($instance) {
+ return $instance->newFromBuilder($item);
+ }, $items));
+ }
+
+ /**
+ * Create a collection of models from a raw query.
+ *
+ * @param string $query
+ * @param array $bindings
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ public function fromQuery($query, $bindings = [])
+ {
+ return $this->hydrate(
+ $this->query->getConnection()->select($query, $bindings)
+ );
+ }
+
+ /**
+ * Find a model by its primary key.
+ *
+ * @param mixed $id
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model|\Illuminate\Database\Eloquent\Collection|static[]|static|null
+ */
+ public function find($id, $columns = ['*'])
+ {
+ if (is_array($id) || $id instanceof Arrayable) {
+ return $this->findMany($id, $columns);
+ }
+
+ return $this->whereKey($id)->first($columns);
+ }
+
+ /**
+ * Find multiple models by their primary keys.
+ *
+ * @param array $ids
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ public function findMany($ids, $columns = ['*'])
+ {
+ if (empty($ids)) {
+ return $this->model->newCollection();
+ }
+
+ return $this->whereKey($ids)->get($columns);
+ }
+
+ /**
+ * Find a model by its primary key or throw an exception.
+ *
+ * @param mixed $id
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model|\Illuminate\Database\Eloquent\Collection
+ *
+ * @throws \Illuminate\Database\Eloquent\ModelNotFoundException
+ */
+ public function findOrFail($id, $columns = ['*'])
+ {
+ $result = $this->find($id, $columns);
+
+ if (is_array($id)) {
+ if (count($result) == count(array_unique($id))) {
+ return $result;
+ }
+ } elseif (! is_null($result)) {
+ return $result;
+ }
+
+ throw (new ModelNotFoundException)->setModel(
+ get_class($this->model), $id
+ );
+ }
+
+ /**
+ * Find a model by its primary key or return fresh model instance.
+ *
+ * @param mixed $id
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function findOrNew($id, $columns = ['*'])
+ {
+ if (! is_null($model = $this->find($id, $columns))) {
+ return $model;
+ }
+
+ return $this->newModelInstance();
+ }
+
+ /**
+ * Get the first record matching the attributes or instantiate it.
+ *
+ * @param array $attributes
+ * @param array $values
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function firstOrNew(array $attributes, array $values = [])
+ {
+ if (! is_null($instance = $this->where($attributes)->first())) {
+ return $instance;
+ }
+
+ return $this->newModelInstance($attributes + $values);
+ }
+
+ /**
+ * Get the first record matching the attributes or create it.
+ *
+ * @param array $attributes
+ * @param array $values
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function firstOrCreate(array $attributes, array $values = [])
+ {
+ if (! is_null($instance = $this->where($attributes)->first())) {
+ return $instance;
+ }
+
+ return tap($this->newModelInstance($attributes + $values), function ($instance) {
+ $instance->save();
+ });
+ }
+
+ /**
+ * Create or update a record matching the attributes, and fill it with values.
+ *
+ * @param array $attributes
+ * @param array $values
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function updateOrCreate(array $attributes, array $values = [])
+ {
+ return tap($this->firstOrNew($attributes), function ($instance) use ($values) {
+ $instance->fill($values)->save();
+ });
+ }
+
+ /**
+ * Execute the query and get the first result or throw an exception.
+ *
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model|static
+ *
+ * @throws \Illuminate\Database\Eloquent\ModelNotFoundException
+ */
+ public function firstOrFail($columns = ['*'])
+ {
+ if (! is_null($model = $this->first($columns))) {
+ return $model;
+ }
+
+ throw (new ModelNotFoundException)->setModel(get_class($this->model));
+ }
+
+ /**
+ * Execute the query and get the first result or call a callback.
+ *
+ * @param \Closure|array $columns
+ * @param \Closure|null $callback
+ * @return \Illuminate\Database\Eloquent\Model|static|mixed
+ */
+ public function firstOr($columns = ['*'], Closure $callback = null)
+ {
+ if ($columns instanceof Closure) {
+ $callback = $columns;
+
+ $columns = ['*'];
+ }
+
+ if (! is_null($model = $this->first($columns))) {
+ return $model;
+ }
+
+ return call_user_func($callback);
+ }
+
+ /**
+ * Get a single column's value from the first result of a query.
+ *
+ * @param string $column
+ * @return mixed
+ */
+ public function value($column)
+ {
+ if ($result = $this->first([$column])) {
+ return $result->{$column};
+ }
+ }
+
+ /**
+ * Execute the query as a "select" statement.
+ *
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Collection|static[]
+ */
+ public function get($columns = ['*'])
+ {
+ $builder = $this->applyScopes();
+
+ // If we actually found models we will also eager load any relationships that
+ // have been specified as needing to be eager loaded, which will solve the
+ // n+1 query issue for the developers to avoid running a lot of queries.
+ if (count($models = $builder->getModels($columns)) > 0) {
+ $models = $builder->eagerLoadRelations($models);
+ }
+
+ return $builder->getModel()->newCollection($models);
+ }
+
+ /**
+ * Get the hydrated models without eager loading.
+ *
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model[]
+ */
+ public function getModels($columns = ['*'])
+ {
+ return $this->model->hydrate(
+ $this->query->get($columns)->all()
+ )->all();
+ }
+
+ /**
+ * Eager load the relationships for the models.
+ *
+ * @param array $models
+ * @return array
+ */
+ public function eagerLoadRelations(array $models)
+ {
+ foreach ($this->eagerLoad as $name => $constraints) {
+ // For nested eager loads we'll skip loading them here and they will be set as an
+ // eager load on the query to retrieve the relation so that they will be eager
+ // loaded on that query, because that is where they get hydrated as models.
+ if (strpos($name, '.') === false) {
+ $models = $this->eagerLoadRelation($models, $name, $constraints);
+ }
+ }
+
+ return $models;
+ }
+
+ /**
+ * Eagerly load the relationship on a set of models.
+ *
+ * @param array $models
+ * @param string $name
+ * @param \Closure $constraints
+ * @return array
+ */
+ protected function eagerLoadRelation(array $models, $name, Closure $constraints)
+ {
+ // First we will "back up" the existing where conditions on the query so we can
+ // add our eager constraints. Then we will merge the wheres that were on the
+ // query back to it in order that any where conditions might be specified.
+ $relation = $this->getRelation($name);
+
+ $relation->addEagerConstraints($models);
+
+ $constraints($relation);
+
+ // Once we have the results, we just match those back up to their parent models
+ // using the relationship instance. Then we just return the finished arrays
+ // of models which have been eagerly hydrated and are readied for return.
+ return $relation->match(
+ $relation->initRelation($models, $name),
+ $relation->getEager(), $name
+ );
+ }
+
+ /**
+ * Get the relation instance for the given relation name.
+ *
+ * @param string $name
+ * @return \Illuminate\Database\Eloquent\Relations\Relation
+ */
+ public function getRelation($name)
+ {
+ // We want to run a relationship query without any constrains so that we will
+ // not have to remove these where clauses manually which gets really hacky
+ // and error prone. We don't want constraints because we add eager ones.
+ $relation = Relation::noConstraints(function () use ($name) {
+ try {
+ return $this->getModel()->{$name}();
+ } catch (BadMethodCallException $e) {
+ throw RelationNotFoundException::make($this->getModel(), $name);
+ }
+ });
+
+ $nested = $this->relationsNestedUnder($name);
+
+ // If there are nested relationships set on the query, we will put those onto
+ // the query instances so that they can be handled after this relationship
+ // is loaded. In this way they will all trickle down as they are loaded.
+ if (count($nested) > 0) {
+ $relation->getQuery()->with($nested);
+ }
+
+ return $relation;
+ }
+
+ /**
+ * Get the deeply nested relations for a given top-level relation.
+ *
+ * @param string $relation
+ * @return array
+ */
+ protected function relationsNestedUnder($relation)
+ {
+ $nested = [];
+
+ // We are basically looking for any relationships that are nested deeper than
+ // the given top-level relationship. We will just check for any relations
+ // that start with the given top relations and adds them to our arrays.
+ foreach ($this->eagerLoad as $name => $constraints) {
+ if ($this->isNestedUnder($relation, $name)) {
+ $nested[substr($name, strlen($relation.'.'))] = $constraints;
+ }
+ }
+
+ return $nested;
+ }
+
+ /**
+ * Determine if the relationship is nested.
+ *
+ * @param string $relation
+ * @param string $name
+ * @return bool
+ */
+ protected function isNestedUnder($relation, $name)
+ {
+ return Str::contains($name, '.') && Str::startsWith($name, $relation.'.');
+ }
+
+ /**
+ * Get a generator for the given query.
+ *
+ * @return \Generator
+ */
+ public function cursor()
+ {
+ foreach ($this->applyScopes()->query->cursor() as $record) {
+ yield $this->model->newFromBuilder($record);
+ }
+ }
+
+ /**
+ * Chunk the results of a query by comparing numeric IDs.
+ *
+ * @param int $count
+ * @param callable $callback
+ * @param string $column
+ * @param string|null $alias
+ * @return bool
+ */
+ public function chunkById($count, callable $callback, $column = null, $alias = null)
+ {
+ $column = is_null($column) ? $this->getModel()->getKeyName() : $column;
+
+ $alias = is_null($alias) ? $column : $alias;
+
+ $lastId = 0;
+
+ do {
+ $clone = clone $this;
+
+ // We'll execute the query for the given page and get the results. If there are
+ // no results we can just break and return from here. When there are results
+ // we will call the callback with the current chunk of these results here.
+ $results = $clone->forPageAfterId($count, $lastId, $column)->get();
+
+ $countResults = $results->count();
+
+ if ($countResults == 0) {
+ break;
+ }
+
+ // On each chunk result set, we will pass them to the callback and then let the
+ // developer take care of everything within the callback, which allows us to
+ // keep the memory low for spinning through large result sets for working.
+ if ($callback($results) === false) {
+ return false;
+ }
+
+ $lastId = $results->last()->{$alias};
+ } while ($countResults == $count);
+
+ return true;
+ }
+
+ /**
+ * Add a generic "order by" clause if the query doesn't already have one.
+ *
+ * @return void
+ */
+ protected function enforceOrderBy()
+ {
+ if (empty($this->query->orders) && empty($this->query->unionOrders)) {
+ $this->orderBy($this->model->getQualifiedKeyName(), 'asc');
+ }
+ }
+
+ /**
+ * Get an array with the values of a given column.
+ *
+ * @param string $column
+ * @param string|null $key
+ * @return \Illuminate\Support\Collection
+ */
+ public function pluck($column, $key = null)
+ {
+ $results = $this->toBase()->pluck($column, $key);
+
+ // If the model has a mutator for the requested column, we will spin through
+ // the results and mutate the values so that the mutated version of these
+ // columns are returned as you would expect from these Eloquent models.
+ if (! $this->model->hasGetMutator($column) &&
+ ! $this->model->hasCast($column) &&
+ ! in_array($column, $this->model->getDates())) {
+ return $results;
+ }
+
+ return $results->map(function ($value) use ($column) {
+ return $this->model->newFromBuilder([$column => $value])->{$column};
+ });
+ }
+
+ /**
+ * Paginate the given query.
+ *
+ * @param int $perPage
+ * @param array $columns
+ * @param string $pageName
+ * @param int|null $page
+ * @return \Illuminate\Contracts\Pagination\LengthAwarePaginator
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function paginate($perPage = null, $columns = ['*'], $pageName = 'page', $page = null)
+ {
+ $page = $page ?: Paginator::resolveCurrentPage($pageName);
+
+ $perPage = $perPage ?: $this->model->getPerPage();
+
+ $results = ($total = $this->toBase()->getCountForPagination())
+ ? $this->forPage($page, $perPage)->get($columns)
+ : $this->model->newCollection();
+
+ return $this->paginator($results, $total, $perPage, $page, [
+ 'path' => Paginator::resolveCurrentPath(),
+ 'pageName' => $pageName,
+ ]);
+ }
+
+ /**
+ * Paginate the given query into a simple paginator.
+ *
+ * @param int $perPage
+ * @param array $columns
+ * @param string $pageName
+ * @param int|null $page
+ * @return \Illuminate\Contracts\Pagination\Paginator
+ */
+ public function simplePaginate($perPage = null, $columns = ['*'], $pageName = 'page', $page = null)
+ {
+ $page = $page ?: Paginator::resolveCurrentPage($pageName);
+
+ $perPage = $perPage ?: $this->model->getPerPage();
+
+ // Next we will set the limit and offset for this query so that when we get the
+ // results we get the proper section of results. Then, we'll create the full
+ // paginator instances for these results with the given page and per page.
+ $this->skip(($page - 1) * $perPage)->take($perPage + 1);
+
+ return $this->simplePaginator($this->get($columns), $perPage, $page, [
+ 'path' => Paginator::resolveCurrentPath(),
+ 'pageName' => $pageName,
+ ]);
+ }
+
+ /**
+ * Save a new model and return the instance.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model|$this
+ */
+ public function create(array $attributes = [])
+ {
+ return tap($this->newModelInstance($attributes), function ($instance) {
+ $instance->save();
+ });
+ }
+
+ /**
+ * Save a new model and return the instance. Allow mass-assignment.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model|$this
+ */
+ public function forceCreate(array $attributes)
+ {
+ return $this->model->unguarded(function () use ($attributes) {
+ return $this->newModelInstance()->create($attributes);
+ });
+ }
+
+ /**
+ * Update a record in the database.
+ *
+ * @param array $values
+ * @return int
+ */
+ public function update(array $values)
+ {
+ return $this->toBase()->update($this->addUpdatedAtColumn($values));
+ }
+
+ /**
+ * Increment a column's value by a given amount.
+ *
+ * @param string $column
+ * @param int $amount
+ * @param array $extra
+ * @return int
+ */
+ public function increment($column, $amount = 1, array $extra = [])
+ {
+ return $this->toBase()->increment(
+ $column, $amount, $this->addUpdatedAtColumn($extra)
+ );
+ }
+
+ /**
+ * Decrement a column's value by a given amount.
+ *
+ * @param string $column
+ * @param int $amount
+ * @param array $extra
+ * @return int
+ */
+ public function decrement($column, $amount = 1, array $extra = [])
+ {
+ return $this->toBase()->decrement(
+ $column, $amount, $this->addUpdatedAtColumn($extra)
+ );
+ }
+
+ /**
+ * Add the "updated at" column to an array of values.
+ *
+ * @param array $values
+ * @return array
+ */
+ protected function addUpdatedAtColumn(array $values)
+ {
+ if (! $this->model->usesTimestamps()) {
+ return $values;
+ }
+
+ return Arr::add(
+ $values, $this->model->getUpdatedAtColumn(),
+ $this->model->freshTimestampString()
+ );
+ }
+
+ /**
+ * Delete a record from the database.
+ *
+ * @return mixed
+ */
+ public function delete()
+ {
+ if (isset($this->onDelete)) {
+ return call_user_func($this->onDelete, $this);
+ }
+
+ return $this->toBase()->delete();
+ }
+
+ /**
+ * Run the default delete function on the builder.
+ *
+ * Since we do not apply scopes here, the row will actually be deleted.
+ *
+ * @return mixed
+ */
+ public function forceDelete()
+ {
+ return $this->query->delete();
+ }
+
+ /**
+ * Register a replacement for the default delete function.
+ *
+ * @param \Closure $callback
+ * @return void
+ */
+ public function onDelete(Closure $callback)
+ {
+ $this->onDelete = $callback;
+ }
+
+ /**
+ * Call the given local model scopes.
+ *
+ * @param array $scopes
+ * @return mixed
+ */
+ public function scopes(array $scopes)
+ {
+ $builder = $this;
+
+ foreach ($scopes as $scope => $parameters) {
+ // If the scope key is an integer, then the scope was passed as the value and
+ // the parameter list is empty, so we will format the scope name and these
+ // parameters here. Then, we'll be ready to call the scope on the model.
+ if (is_int($scope)) {
+ list($scope, $parameters) = [$parameters, []];
+ }
+
+ // Next we'll pass the scope callback to the callScope method which will take
+ // care of groping the "wheres" correctly so the logical order doesn't get
+ // messed up when adding scopes. Then we'll return back out the builder.
+ $builder = $builder->callScope(
+ [$this->model, 'scope'.ucfirst($scope)],
+ (array) $parameters
+ );
+ }
+
+ return $builder;
+ }
+
+ /**
+ * Apply the scopes to the Eloquent builder instance and return it.
+ *
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function applyScopes()
+ {
+ if (! $this->scopes) {
+ return $this;
+ }
+
+ $builder = clone $this;
+
+ foreach ($this->scopes as $identifier => $scope) {
+ if (! isset($builder->scopes[$identifier])) {
+ continue;
+ }
+
+ $builder->callScope(function (Builder $builder) use ($scope) {
+ // If the scope is a Closure we will just go ahead and call the scope with the
+ // builder instance. The "callScope" method will properly group the clauses
+ // that are added to this query so "where" clauses maintain proper logic.
+ if ($scope instanceof Closure) {
+ $scope($builder);
+ }
+
+ // If the scope is a scope object, we will call the apply method on this scope
+ // passing in the builder and the model instance. After we run all of these
+ // scopes we will return back the builder instance to the outside caller.
+ if ($scope instanceof Scope) {
+ $scope->apply($builder, $this->getModel());
+ }
+ });
+ }
+
+ return $builder;
+ }
+
+ /**
+ * Apply the given scope on the current builder instance.
+ *
+ * @param callable $scope
+ * @param array $parameters
+ * @return mixed
+ */
+ protected function callScope(callable $scope, $parameters = [])
+ {
+ array_unshift($parameters, $this);
+
+ $query = $this->getQuery();
+
+ // We will keep track of how many wheres are on the query before running the
+ // scope so that we can properly group the added scope constraints in the
+ // query as their own isolated nested where statement and avoid issues.
+ $originalWhereCount = is_null($query->wheres)
+ ? 0 : count($query->wheres);
+
+ $result = $scope(...array_values($parameters)) ?: $this;
+
+ if (count((array) $query->wheres) > $originalWhereCount) {
+ $this->addNewWheresWithinGroup($query, $originalWhereCount);
+ }
+
+ return $result;
+ }
+
+ /**
+ * Nest where conditions by slicing them at the given where count.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param int $originalWhereCount
+ * @return void
+ */
+ protected function addNewWheresWithinGroup(QueryBuilder $query, $originalWhereCount)
+ {
+ // Here, we totally remove all of the where clauses since we are going to
+ // rebuild them as nested queries by slicing the groups of wheres into
+ // their own sections. This is to prevent any confusing logic order.
+ $allWheres = $query->wheres;
+
+ $query->wheres = [];
+
+ $this->groupWhereSliceForScope(
+ $query, array_slice($allWheres, 0, $originalWhereCount)
+ );
+
+ $this->groupWhereSliceForScope(
+ $query, array_slice($allWheres, $originalWhereCount)
+ );
+ }
+
+ /**
+ * Slice where conditions at the given offset and add them to the query as a nested condition.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $whereSlice
+ * @return void
+ */
+ protected function groupWhereSliceForScope(QueryBuilder $query, $whereSlice)
+ {
+ $whereBooleans = collect($whereSlice)->pluck('boolean');
+
+ // Here we'll check if the given subset of where clauses contains any "or"
+ // booleans and in this case create a nested where expression. That way
+ // we don't add any unnecessary nesting thus keeping the query clean.
+ if ($whereBooleans->contains('or')) {
+ $query->wheres[] = $this->createNestedWhere(
+ $whereSlice, $whereBooleans->first()
+ );
+ } else {
+ $query->wheres = array_merge($query->wheres, $whereSlice);
+ }
+ }
+
+ /**
+ * Create a where array with nested where conditions.
+ *
+ * @param array $whereSlice
+ * @param string $boolean
+ * @return array
+ */
+ protected function createNestedWhere($whereSlice, $boolean = 'and')
+ {
+ $whereGroup = $this->getQuery()->forNestedWhere();
+
+ $whereGroup->wheres = $whereSlice;
+
+ return ['type' => 'Nested', 'query' => $whereGroup, 'boolean' => $boolean];
+ }
+
+ /**
+ * Set the relationships that should be eager loaded.
+ *
+ * @param mixed $relations
+ * @return $this
+ */
+ public function with($relations)
+ {
+ $eagerLoad = $this->parseWithRelations(is_string($relations) ? func_get_args() : $relations);
+
+ $this->eagerLoad = array_merge($this->eagerLoad, $eagerLoad);
+
+ return $this;
+ }
+
+ /**
+ * Prevent the specified relations from being eager loaded.
+ *
+ * @param mixed $relations
+ * @return $this
+ */
+ public function without($relations)
+ {
+ $this->eagerLoad = array_diff_key($this->eagerLoad, array_flip(
+ is_string($relations) ? func_get_args() : $relations
+ ));
+
+ return $this;
+ }
+
+ /**
+ * Create a new instance of the model being queried.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function newModelInstance($attributes = [])
+ {
+ return $this->model->newInstance($attributes)->setConnection(
+ $this->query->getConnection()->getName()
+ );
+ }
+
+ /**
+ * Parse a list of relations into individuals.
+ *
+ * @param array $relations
+ * @return array
+ */
+ protected function parseWithRelations(array $relations)
+ {
+ $results = [];
+
+ foreach ($relations as $name => $constraints) {
+ // If the "relation" value is actually a numeric key, we can assume that no
+ // constraints have been specified for the eager load and we'll just put
+ // an empty Closure with the loader so that we can treat all the same.
+ if (is_numeric($name)) {
+ $name = $constraints;
+
+ list($name, $constraints) = Str::contains($name, ':')
+ ? $this->createSelectWithConstraint($name)
+ : [$name, function () {
+ //
+ }];
+ }
+
+ // We need to separate out any nested includes. Which allows the developers
+ // to load deep relationships using "dots" without stating each level of
+ // the relationship with its own key in the array of eager load names.
+ $results = $this->addNestedWiths($name, $results);
+
+ $results[$name] = $constraints;
+ }
+
+ return $results;
+ }
+
+ /**
+ * Create a constraint to select the given columns for the relation.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function createSelectWithConstraint($name)
+ {
+ return [explode(':', $name)[0], function ($query) use ($name) {
+ $query->select(explode(',', explode(':', $name)[1]));
+ }];
+ }
+
+ /**
+ * Parse the nested relationships in a relation.
+ *
+ * @param string $name
+ * @param array $results
+ * @return array
+ */
+ protected function addNestedWiths($name, $results)
+ {
+ $progress = [];
+
+ // If the relation has already been set on the result array, we will not set it
+ // again, since that would override any constraints that were already placed
+ // on the relationships. We will only set the ones that are not specified.
+ foreach (explode('.', $name) as $segment) {
+ $progress[] = $segment;
+
+ if (! isset($results[$last = implode('.', $progress)])) {
+ $results[$last] = function () {
+ //
+ };
+ }
+ }
+
+ return $results;
+ }
+
+ /**
+ * Get the underlying query builder instance.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function getQuery()
+ {
+ return $this->query;
+ }
+
+ /**
+ * Set the underlying query builder instance.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return $this
+ */
+ public function setQuery($query)
+ {
+ $this->query = $query;
+
+ return $this;
+ }
+
+ /**
+ * Get a base query builder instance.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function toBase()
+ {
+ return $this->applyScopes()->getQuery();
+ }
+
+ /**
+ * Get the relationships being eagerly loaded.
+ *
+ * @return array
+ */
+ public function getEagerLoads()
+ {
+ return $this->eagerLoad;
+ }
+
+ /**
+ * Set the relationships being eagerly loaded.
+ *
+ * @param array $eagerLoad
+ * @return $this
+ */
+ public function setEagerLoads(array $eagerLoad)
+ {
+ $this->eagerLoad = $eagerLoad;
+
+ return $this;
+ }
+
+ /**
+ * Get the model instance being queried.
+ *
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function getModel()
+ {
+ return $this->model;
+ }
+
+ /**
+ * Set a model instance for the model being queried.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @return $this
+ */
+ public function setModel(Model $model)
+ {
+ $this->model = $model;
+
+ $this->query->from($model->getTable());
+
+ return $this;
+ }
+
+ /**
+ * Get the given macro by name.
+ *
+ * @param string $name
+ * @return \Closure
+ */
+ public function getMacro($name)
+ {
+ return Arr::get($this->localMacros, $name);
+ }
+
+ /**
+ * Dynamically handle calls into the query instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ if ($method === 'macro') {
+ $this->localMacros[$parameters[0]] = $parameters[1];
+
+ return;
+ }
+
+ if (isset($this->localMacros[$method])) {
+ array_unshift($parameters, $this);
+
+ return $this->localMacros[$method](...$parameters);
+ }
+
+ if (isset(static::$macros[$method]) and static::$macros[$method] instanceof Closure) {
+ return call_user_func_array(static::$macros[$method]->bindTo($this, static::class), $parameters);
+ }
+
+ if (isset(static::$macros[$method])) {
+ return call_user_func_array(static::$macros[$method]->bindTo($this, static::class), $parameters);
+ }
+
+ if (method_exists($this->model, $scope = 'scope'.ucfirst($method))) {
+ return $this->callScope([$this->model, $scope], $parameters);
+ }
+
+ if (in_array($method, $this->passthru)) {
+ return $this->toBase()->{$method}(...$parameters);
+ }
+
+ $this->query->{$method}(...$parameters);
+
+ return $this;
+ }
+
+ /**
+ * Dynamically handle calls into the query instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ *
+ * @throws \BadMethodCallException
+ */
+ public static function __callStatic($method, $parameters)
+ {
+ if ($method === 'macro') {
+ static::$macros[$parameters[0]] = $parameters[1];
+
+ return;
+ }
+
+ if (! isset(static::$macros[$method])) {
+ throw new BadMethodCallException("Method {$method} does not exist.");
+ }
+
+ if (static::$macros[$method] instanceof Closure) {
+ return call_user_func_array(Closure::bind(static::$macros[$method], null, static::class), $parameters);
+ }
+
+ return call_user_func_array(static::$macros[$method], $parameters);
+ }
+
+ /**
+ * Force a clone of the underlying query builder when cloning.
+ *
+ * @return void
+ */
+ public function __clone()
+ {
+ $this->query = clone $this->query;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Collection.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Collection.php
new file mode 100644
index 000000000..5c679c20e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Collection.php
@@ -0,0 +1,398 @@
+getKey();
+ }
+
+ if (is_array($key)) {
+ if ($this->isEmpty()) {
+ return new static;
+ }
+
+ return $this->whereIn($this->first()->getKeyName(), $key);
+ }
+
+ return Arr::first($this->items, function ($model) use ($key) {
+ return $model->getKey() == $key;
+ }, $default);
+ }
+
+ /**
+ * Load a set of relationships onto the collection.
+ *
+ * @param mixed $relations
+ * @return $this
+ */
+ public function load($relations)
+ {
+ if (count($this->items) > 0) {
+ if (is_string($relations)) {
+ $relations = func_get_args();
+ }
+
+ $query = $this->first()->newQuery()->with($relations);
+
+ $this->items = $query->eagerLoadRelations($this->items);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add an item to the collection.
+ *
+ * @param mixed $item
+ * @return $this
+ */
+ public function add($item)
+ {
+ $this->items[] = $item;
+
+ return $this;
+ }
+
+ /**
+ * Determine if a key exists in the collection.
+ *
+ * @param mixed $key
+ * @param mixed $operator
+ * @param mixed $value
+ * @return bool
+ */
+ public function contains($key, $operator = null, $value = null)
+ {
+ if (func_num_args() > 1 || $this->useAsCallable($key)) {
+ return parent::contains(...func_get_args());
+ }
+
+ if ($key instanceof Model) {
+ return parent::contains(function ($model) use ($key) {
+ return $model->is($key);
+ });
+ }
+
+ return parent::contains(function ($model) use ($key) {
+ return $model->getKey() == $key;
+ });
+ }
+
+ /**
+ * Get the array of primary keys.
+ *
+ * @return array
+ */
+ public function modelKeys()
+ {
+ return array_map(function ($model) {
+ return $model->getKey();
+ }, $this->items);
+ }
+
+ /**
+ * Merge the collection with the given items.
+ *
+ * @param \ArrayAccess|array $items
+ * @return static
+ */
+ public function merge($items)
+ {
+ $dictionary = $this->getDictionary();
+
+ foreach ($items as $item) {
+ $dictionary[$item->getKey()] = $item;
+ }
+
+ return new static(array_values($dictionary));
+ }
+
+ /**
+ * Run a map over each of the items.
+ *
+ * @param callable $callback
+ * @return \Illuminate\Support\Collection|static
+ */
+ public function map(callable $callback)
+ {
+ $result = parent::map($callback);
+
+ return $result->contains(function ($item) {
+ return ! $item instanceof Model;
+ }) ? $result->toBase() : $result;
+ }
+
+ /**
+ * Reload a fresh model instance from the database for all the entities.
+ *
+ * @param array|string $with
+ * @return static
+ */
+ public function fresh($with = [])
+ {
+ if ($this->isEmpty()) {
+ return new static;
+ }
+
+ $model = $this->first();
+
+ $freshModels = $model->newQueryWithoutScopes()
+ ->with(is_string($with) ? func_get_args() : $with)
+ ->whereIn($model->getKeyName(), $this->modelKeys())
+ ->get()
+ ->getDictionary();
+
+ return $this->map(function ($model) use ($freshModels) {
+ return $model->exists ? $freshModels[$model->getKey()] : null;
+ });
+ }
+
+ /**
+ * Diff the collection with the given items.
+ *
+ * @param \ArrayAccess|array $items
+ * @return static
+ */
+ public function diff($items)
+ {
+ $diff = new static;
+
+ $dictionary = $this->getDictionary($items);
+
+ foreach ($this->items as $item) {
+ if (! isset($dictionary[$item->getKey()])) {
+ $diff->add($item);
+ }
+ }
+
+ return $diff;
+ }
+
+ /**
+ * Intersect the collection with the given items.
+ *
+ * @param \ArrayAccess|array $items
+ * @return static
+ */
+ public function intersect($items)
+ {
+ $intersect = new static;
+
+ $dictionary = $this->getDictionary($items);
+
+ foreach ($this->items as $item) {
+ if (isset($dictionary[$item->getKey()])) {
+ $intersect->add($item);
+ }
+ }
+
+ return $intersect;
+ }
+
+ /**
+ * Return only unique items from the collection.
+ *
+ * @param string|callable|null $key
+ * @param bool $strict
+ * @return static|\Illuminate\Support\Collection
+ */
+ public function unique($key = null, $strict = false)
+ {
+ if (! is_null($key)) {
+ return parent::unique($key, $strict);
+ }
+
+ return new static(array_values($this->getDictionary()));
+ }
+
+ /**
+ * Returns only the models from the collection with the specified keys.
+ *
+ * @param mixed $keys
+ * @return static
+ */
+ public function only($keys)
+ {
+ if (is_null($keys)) {
+ return new static($this->items);
+ }
+
+ $dictionary = Arr::only($this->getDictionary(), $keys);
+
+ return new static(array_values($dictionary));
+ }
+
+ /**
+ * Returns all models in the collection except the models with specified keys.
+ *
+ * @param mixed $keys
+ * @return static
+ */
+ public function except($keys)
+ {
+ $dictionary = Arr::except($this->getDictionary(), $keys);
+
+ return new static(array_values($dictionary));
+ }
+
+ /**
+ * Make the given, typically visible, attributes hidden across the entire collection.
+ *
+ * @param array|string $attributes
+ * @return $this
+ */
+ public function makeHidden($attributes)
+ {
+ return $this->each(function ($model) use ($attributes) {
+ $model->addHidden($attributes);
+ });
+ }
+
+ /**
+ * Make the given, typically hidden, attributes visible across the entire collection.
+ *
+ * @param array|string $attributes
+ * @return $this
+ */
+ public function makeVisible($attributes)
+ {
+ return $this->each(function ($model) use ($attributes) {
+ $model->makeVisible($attributes);
+ });
+ }
+
+ /**
+ * Get a dictionary keyed by primary keys.
+ *
+ * @param \ArrayAccess|array|null $items
+ * @return array
+ */
+ public function getDictionary($items = null)
+ {
+ $items = is_null($items) ? $this->items : $items;
+
+ $dictionary = [];
+
+ foreach ($items as $value) {
+ $dictionary[$value->getKey()] = $value;
+ }
+
+ return $dictionary;
+ }
+
+ /**
+ * The following methods are intercepted to always return base collections.
+ */
+
+ /**
+ * Get an array with the values of a given key.
+ *
+ * @param string $value
+ * @param string|null $key
+ * @return \Illuminate\Support\Collection
+ */
+ public function pluck($value, $key = null)
+ {
+ return $this->toBase()->pluck($value, $key);
+ }
+
+ /**
+ * Get the keys of the collection items.
+ *
+ * @return \Illuminate\Support\Collection
+ */
+ public function keys()
+ {
+ return $this->toBase()->keys();
+ }
+
+ /**
+ * Zip the collection together with one or more arrays.
+ *
+ * @param mixed ...$items
+ * @return \Illuminate\Support\Collection
+ */
+ public function zip($items)
+ {
+ return call_user_func_array([$this->toBase(), 'zip'], func_get_args());
+ }
+
+ /**
+ * Collapse the collection of items into a single array.
+ *
+ * @return \Illuminate\Support\Collection
+ */
+ public function collapse()
+ {
+ return $this->toBase()->collapse();
+ }
+
+ /**
+ * Get a flattened array of the items in the collection.
+ *
+ * @param int $depth
+ * @return \Illuminate\Support\Collection
+ */
+ public function flatten($depth = INF)
+ {
+ return $this->toBase()->flatten($depth);
+ }
+
+ /**
+ * Flip the items in the collection.
+ *
+ * @return \Illuminate\Support\Collection
+ */
+ public function flip()
+ {
+ return $this->toBase()->flip();
+ }
+
+ /**
+ * Get the type of the entities being queued.
+ *
+ * @return string|null
+ */
+ public function getQueueableClass()
+ {
+ if ($this->count() === 0) {
+ return;
+ }
+
+ $class = get_class($this->first());
+
+ $this->each(function ($model) use ($class) {
+ if (get_class($model) !== $class) {
+ throw new LogicException('Queueing collections with multiple model types is not supported.');
+ }
+ });
+
+ return $class;
+ }
+
+ /**
+ * Get the identifiers for all of the entities.
+ *
+ * @return array
+ */
+ public function getQueueableIds()
+ {
+ return $this->modelKeys();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/GuardsAttributes.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/GuardsAttributes.php
new file mode 100644
index 000000000..96317cf57
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/GuardsAttributes.php
@@ -0,0 +1,193 @@
+fillable;
+ }
+
+ /**
+ * Set the fillable attributes for the model.
+ *
+ * @param array $fillable
+ * @return $this
+ */
+ public function fillable(array $fillable)
+ {
+ $this->fillable = $fillable;
+
+ return $this;
+ }
+
+ /**
+ * Get the guarded attributes for the model.
+ *
+ * @return array
+ */
+ public function getGuarded()
+ {
+ return $this->guarded;
+ }
+
+ /**
+ * Set the guarded attributes for the model.
+ *
+ * @param array $guarded
+ * @return $this
+ */
+ public function guard(array $guarded)
+ {
+ $this->guarded = $guarded;
+
+ return $this;
+ }
+
+ /**
+ * Disable all mass assignable restrictions.
+ *
+ * @param bool $state
+ * @return void
+ */
+ public static function unguard($state = true)
+ {
+ static::$unguarded = $state;
+ }
+
+ /**
+ * Enable the mass assignment restrictions.
+ *
+ * @return void
+ */
+ public static function reguard()
+ {
+ static::$unguarded = false;
+ }
+
+ /**
+ * Determine if current state is "unguarded".
+ *
+ * @return bool
+ */
+ public static function isUnguarded()
+ {
+ return static::$unguarded;
+ }
+
+ /**
+ * Run the given callable while being unguarded.
+ *
+ * @param callable $callback
+ * @return mixed
+ */
+ public static function unguarded(callable $callback)
+ {
+ if (static::$unguarded) {
+ return $callback();
+ }
+
+ static::unguard();
+
+ try {
+ return $callback();
+ } finally {
+ static::reguard();
+ }
+ }
+
+ /**
+ * Determine if the given attribute may be mass assigned.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function isFillable($key)
+ {
+ if (static::$unguarded) {
+ return true;
+ }
+
+ // If the key is in the "fillable" array, we can of course assume that it's
+ // a fillable attribute. Otherwise, we will check the guarded array when
+ // we need to determine if the attribute is black-listed on the model.
+ if (in_array($key, $this->getFillable())) {
+ return true;
+ }
+
+ // If the attribute is explicitly listed in the "guarded" array then we can
+ // return false immediately. This means this attribute is definitely not
+ // fillable and there is no point in going any further in this method.
+ if ($this->isGuarded($key)) {
+ return false;
+ }
+
+ return empty($this->getFillable()) &&
+ ! Str::startsWith($key, '_');
+ }
+
+ /**
+ * Determine if the given key is guarded.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function isGuarded($key)
+ {
+ return in_array($key, $this->getGuarded()) || $this->getGuarded() == ['*'];
+ }
+
+ /**
+ * Determine if the model is totally guarded.
+ *
+ * @return bool
+ */
+ public function totallyGuarded()
+ {
+ return count($this->getFillable()) == 0 && $this->getGuarded() == ['*'];
+ }
+
+ /**
+ * Get the fillable attributes of a given array.
+ *
+ * @param array $attributes
+ * @return array
+ */
+ protected function fillableFromArray(array $attributes)
+ {
+ if (count($this->getFillable()) > 0 && ! static::$unguarded) {
+ return array_intersect_key($attributes, array_flip($this->getFillable()));
+ }
+
+ return $attributes;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasAttributes.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasAttributes.php
new file mode 100644
index 000000000..ae42b7d6c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasAttributes.php
@@ -0,0 +1,1065 @@
+addDateAttributesToArray(
+ $attributes = $this->getArrayableAttributes()
+ );
+
+ $attributes = $this->addMutatedAttributesToArray(
+ $attributes, $mutatedAttributes = $this->getMutatedAttributes()
+ );
+
+ // Next we will handle any casts that have been setup for this model and cast
+ // the values to their appropriate type. If the attribute has a mutator we
+ // will not perform the cast on those attributes to avoid any confusion.
+ $attributes = $this->addCastAttributesToArray(
+ $attributes, $mutatedAttributes
+ );
+
+ // Here we will grab all of the appended, calculated attributes to this model
+ // as these attributes are not really in the attributes array, but are run
+ // when we need to array or JSON the model for convenience to the coder.
+ foreach ($this->getArrayableAppends() as $key) {
+ $attributes[$key] = $this->mutateAttributeForArray($key, null);
+ }
+
+ return $attributes;
+ }
+
+ /**
+ * Add the date attributes to the attributes array.
+ *
+ * @param array $attributes
+ * @return array
+ */
+ protected function addDateAttributesToArray(array $attributes)
+ {
+ foreach ($this->getDates() as $key) {
+ if (! isset($attributes[$key])) {
+ continue;
+ }
+
+ $attributes[$key] = $this->serializeDate(
+ $this->asDateTime($attributes[$key])
+ );
+ }
+
+ return $attributes;
+ }
+
+ /**
+ * Add the mutated attributes to the attributes array.
+ *
+ * @param array $attributes
+ * @param array $mutatedAttributes
+ * @return array
+ */
+ protected function addMutatedAttributesToArray(array $attributes, array $mutatedAttributes)
+ {
+ foreach ($mutatedAttributes as $key) {
+ // We want to spin through all the mutated attributes for this model and call
+ // the mutator for the attribute. We cache off every mutated attributes so
+ // we don't have to constantly check on attributes that actually change.
+ if (! array_key_exists($key, $attributes)) {
+ continue;
+ }
+
+ // Next, we will call the mutator for this attribute so that we can get these
+ // mutated attribute's actual values. After we finish mutating each of the
+ // attributes we will return this final array of the mutated attributes.
+ $attributes[$key] = $this->mutateAttributeForArray(
+ $key, $attributes[$key]
+ );
+ }
+
+ return $attributes;
+ }
+
+ /**
+ * Add the casted attributes to the attributes array.
+ *
+ * @param array $attributes
+ * @param array $mutatedAttributes
+ * @return array
+ */
+ protected function addCastAttributesToArray(array $attributes, array $mutatedAttributes)
+ {
+ foreach ($this->getCasts() as $key => $value) {
+ if (! array_key_exists($key, $attributes) || in_array($key, $mutatedAttributes)) {
+ continue;
+ }
+
+ // Here we will cast the attribute. Then, if the cast is a date or datetime cast
+ // then we will serialize the date for the array. This will convert the dates
+ // to strings based on the date format specified for these Eloquent models.
+ $attributes[$key] = $this->castAttribute(
+ $key, $attributes[$key]
+ );
+
+ // If the attribute cast was a date or a datetime, we will serialize the date as
+ // a string. This allows the developers to customize hwo dates are serialized
+ // into an array without affecting how they are persisted into the storage.
+ if ($attributes[$key] &&
+ ($value === 'date' || $value === 'datetime')) {
+ $attributes[$key] = $this->serializeDate($attributes[$key]);
+ }
+ }
+
+ return $attributes;
+ }
+
+ /**
+ * Get an attribute array of all arrayable attributes.
+ *
+ * @return array
+ */
+ protected function getArrayableAttributes()
+ {
+ return $this->getArrayableItems($this->attributes);
+ }
+
+ /**
+ * Get all of the appendable values that are arrayable.
+ *
+ * @return array
+ */
+ protected function getArrayableAppends()
+ {
+ if (! count($this->appends)) {
+ return [];
+ }
+
+ return $this->getArrayableItems(
+ array_combine($this->appends, $this->appends)
+ );
+ }
+
+ /**
+ * Get the model's relationships in array form.
+ *
+ * @return array
+ */
+ public function relationsToArray()
+ {
+ $attributes = [];
+
+ foreach ($this->getArrayableRelations() as $key => $value) {
+ // If the values implements the Arrayable interface we can just call this
+ // toArray method on the instances which will convert both models and
+ // collections to their proper array form and we'll set the values.
+ if ($value instanceof Arrayable) {
+ $relation = $value->toArray();
+ }
+
+ // If the value is null, we'll still go ahead and set it in this list of
+ // attributes since null is used to represent empty relationships if
+ // if it a has one or belongs to type relationships on the models.
+ elseif (is_null($value)) {
+ $relation = $value;
+ }
+
+ // If the relationships snake-casing is enabled, we will snake case this
+ // key so that the relation attribute is snake cased in this returned
+ // array to the developers, making this consistent with attributes.
+ if (static::$snakeAttributes) {
+ $key = Str::snake($key);
+ }
+
+ // If the relation value has been set, we will set it on this attributes
+ // list for returning. If it was not arrayable or null, we'll not set
+ // the value on the array because it is some type of invalid value.
+ if (isset($relation) || is_null($value)) {
+ $attributes[$key] = $relation;
+ }
+
+ unset($relation);
+ }
+
+ return $attributes;
+ }
+
+ /**
+ * Get an attribute array of all arrayable relations.
+ *
+ * @return array
+ */
+ protected function getArrayableRelations()
+ {
+ return $this->getArrayableItems($this->relations);
+ }
+
+ /**
+ * Get an attribute array of all arrayable values.
+ *
+ * @param array $values
+ * @return array
+ */
+ protected function getArrayableItems(array $values)
+ {
+ if (count($this->getVisible()) > 0) {
+ $values = array_intersect_key($values, array_flip($this->getVisible()));
+ }
+
+ if (count($this->getHidden()) > 0) {
+ $values = array_diff_key($values, array_flip($this->getHidden()));
+ }
+
+ return $values;
+ }
+
+ /**
+ * Get an attribute from the model.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function getAttribute($key)
+ {
+ if (! $key) {
+ return;
+ }
+
+ // If the attribute exists in the attribute array or has a "get" mutator we will
+ // get the attribute's value. Otherwise, we will proceed as if the developers
+ // are asking for a relationship's value. This covers both types of values.
+ if (array_key_exists($key, $this->attributes) ||
+ $this->hasGetMutator($key)) {
+ return $this->getAttributeValue($key);
+ }
+
+ // Here we will determine if the model base class itself contains this given key
+ // since we do not want to treat any of those methods are relationships since
+ // they are all intended as helper methods and none of these are relations.
+ if (method_exists(self::class, $key)) {
+ return;
+ }
+
+ return $this->getRelationValue($key);
+ }
+
+ /**
+ * Get a plain attribute (not a relationship).
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function getAttributeValue($key)
+ {
+ $value = $this->getAttributeFromArray($key);
+
+ // If the attribute has a get mutator, we will call that then return what
+ // it returns as the value, which is useful for transforming values on
+ // retrieval from the model to a form that is more useful for usage.
+ if ($this->hasGetMutator($key)) {
+ return $this->mutateAttribute($key, $value);
+ }
+
+ // If the attribute exists within the cast array, we will convert it to
+ // an appropriate native PHP type dependant upon the associated value
+ // given with the key in the pair. Dayle made this comment line up.
+ if ($this->hasCast($key)) {
+ return $this->castAttribute($key, $value);
+ }
+
+ // If the attribute is listed as a date, we will convert it to a DateTime
+ // instance on retrieval, which makes it quite convenient to work with
+ // date fields without having to create a mutator for each property.
+ if (in_array($key, $this->getDates()) &&
+ ! is_null($value)) {
+ return $this->asDateTime($value);
+ }
+
+ return $value;
+ }
+
+ /**
+ * Get an attribute from the $attributes array.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ protected function getAttributeFromArray($key)
+ {
+ if (isset($this->attributes[$key])) {
+ return $this->attributes[$key];
+ }
+ }
+
+ /**
+ * Get a relationship.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function getRelationValue($key)
+ {
+ // If the key already exists in the relationships array, it just means the
+ // relationship has already been loaded, so we'll just return it out of
+ // here because there is no need to query within the relations twice.
+ if ($this->relationLoaded($key)) {
+ return $this->relations[$key];
+ }
+
+ // If the "attribute" exists as a method on the model, we will just assume
+ // it is a relationship and will load and return results from the query
+ // and hydrate the relationship's value on the "relationships" array.
+ if (method_exists($this, $key)) {
+ return $this->getRelationshipFromMethod($key);
+ }
+ }
+
+ /**
+ * Get a relationship value from a method.
+ *
+ * @param string $method
+ * @return mixed
+ *
+ * @throws \LogicException
+ */
+ protected function getRelationshipFromMethod($method)
+ {
+ $relation = $this->$method();
+
+ if (! $relation instanceof Relation) {
+ throw new LogicException('Relationship method must return an object of type '
+ .'Illuminate\Database\Eloquent\Relations\Relation');
+ }
+
+ return tap($relation->getResults(), function ($results) use ($method) {
+ $this->setRelation($method, $results);
+ });
+ }
+
+ /**
+ * Determine if a get mutator exists for an attribute.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function hasGetMutator($key)
+ {
+ return method_exists($this, 'get'.Str::studly($key).'Attribute');
+ }
+
+ /**
+ * Get the value of an attribute using its mutator.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function mutateAttribute($key, $value)
+ {
+ return $this->{'get'.Str::studly($key).'Attribute'}($value);
+ }
+
+ /**
+ * Get the value of an attribute using its mutator for array conversion.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function mutateAttributeForArray($key, $value)
+ {
+ $value = $this->mutateAttribute($key, $value);
+
+ return $value instanceof Arrayable ? $value->toArray() : $value;
+ }
+
+ /**
+ * Cast an attribute to a native PHP type.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function castAttribute($key, $value)
+ {
+ if (is_null($value)) {
+ return $value;
+ }
+
+ switch ($this->getCastType($key)) {
+ case 'int':
+ case 'integer':
+ return (int) $value;
+ case 'real':
+ case 'float':
+ case 'double':
+ return (float) $value;
+ case 'string':
+ return (string) $value;
+ case 'bool':
+ case 'boolean':
+ return (bool) $value;
+ case 'object':
+ return $this->fromJson($value, true);
+ case 'array':
+ case 'json':
+ return $this->fromJson($value);
+ case 'collection':
+ return new BaseCollection($this->fromJson($value));
+ case 'date':
+ return $this->asDate($value);
+ case 'datetime':
+ return $this->asDateTime($value);
+ case 'timestamp':
+ return $this->asTimestamp($value);
+ default:
+ return $value;
+ }
+ }
+
+ /**
+ * Get the type of cast for a model attribute.
+ *
+ * @param string $key
+ * @return string
+ */
+ protected function getCastType($key)
+ {
+ return trim(strtolower($this->getCasts()[$key]));
+ }
+
+ /**
+ * Set a given attribute on the model.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return $this
+ */
+ public function setAttribute($key, $value)
+ {
+ // First we will check for the presence of a mutator for the set operation
+ // which simply lets the developers tweak the attribute as it is set on
+ // the model, such as "json_encoding" an listing of data for storage.
+ if ($this->hasSetMutator($key)) {
+ $method = 'set'.Str::studly($key).'Attribute';
+
+ return $this->{$method}($value);
+ }
+
+ // If an attribute is listed as a "date", we'll convert it from a DateTime
+ // instance into a form proper for storage on the database tables using
+ // the connection grammar's date format. We will auto set the values.
+ elseif ($value && $this->isDateAttribute($key)) {
+ $value = $this->fromDateTime($value);
+ }
+
+ if ($this->isJsonCastable($key) && ! is_null($value)) {
+ $value = $this->castAttributeAsJson($key, $value);
+ }
+
+ // If this attribute contains a JSON ->, we'll set the proper value in the
+ // attribute's underlying array. This takes care of properly nesting an
+ // attribute in the array's value in the case of deeply nested items.
+ if (Str::contains($key, '->')) {
+ return $this->fillJsonAttribute($key, $value);
+ }
+
+ $this->attributes[$key] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Determine if a set mutator exists for an attribute.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function hasSetMutator($key)
+ {
+ return method_exists($this, 'set'.Str::studly($key).'Attribute');
+ }
+
+ /**
+ * Determine if the given attribute is a date or date castable.
+ *
+ * @param string $key
+ * @return bool
+ */
+ protected function isDateAttribute($key)
+ {
+ return in_array($key, $this->getDates()) ||
+ $this->isDateCastable($key);
+ }
+
+ /**
+ * Set a given JSON attribute on the model.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return $this
+ */
+ public function fillJsonAttribute($key, $value)
+ {
+ list($key, $path) = explode('->', $key, 2);
+
+ $this->attributes[$key] = $this->asJson($this->getArrayAttributeWithValue(
+ $path, $key, $value
+ ));
+
+ return $this;
+ }
+
+ /**
+ * Get an array attribute with the given key and value set.
+ *
+ * @param string $path
+ * @param string $key
+ * @param mixed $value
+ * @return $this
+ */
+ protected function getArrayAttributeWithValue($path, $key, $value)
+ {
+ return tap($this->getArrayAttributeByKey($key), function (&$array) use ($path, $value) {
+ Arr::set($array, str_replace('->', '.', $path), $value);
+ });
+ }
+
+ /**
+ * Get an array attribute or return an empty array if it is not set.
+ *
+ * @param string $key
+ * @return array
+ */
+ protected function getArrayAttributeByKey($key)
+ {
+ return isset($this->attributes[$key]) ?
+ $this->fromJson($this->attributes[$key]) : [];
+ }
+
+ /**
+ * Cast the given attribute to JSON.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return string
+ */
+ protected function castAttributeAsJson($key, $value)
+ {
+ $value = $this->asJson($value);
+
+ if ($value === false) {
+ throw JsonEncodingException::forAttribute(
+ $this, $key, json_last_error_msg()
+ );
+ }
+
+ return $value;
+ }
+
+ /**
+ * Encode the given value as JSON.
+ *
+ * @param mixed $value
+ * @return string
+ */
+ protected function asJson($value)
+ {
+ return json_encode($value);
+ }
+
+ /**
+ * Decode the given JSON back into an array or object.
+ *
+ * @param string $value
+ * @param bool $asObject
+ * @return mixed
+ */
+ public function fromJson($value, $asObject = false)
+ {
+ return json_decode($value, ! $asObject);
+ }
+
+ /**
+ * Return a timestamp as DateTime object with time set to 00:00:00.
+ *
+ * @param mixed $value
+ * @return \Carbon\Carbon
+ */
+ protected function asDate($value)
+ {
+ return $this->asDateTime($value)->startOfDay();
+ }
+
+ /**
+ * Return a timestamp as DateTime object.
+ *
+ * @param mixed $value
+ * @return \Carbon\Carbon
+ */
+ protected function asDateTime($value)
+ {
+ // If this value is already a Carbon instance, we shall just return it as is.
+ // This prevents us having to re-instantiate a Carbon instance when we know
+ // it already is one, which wouldn't be fulfilled by the DateTime check.
+ if ($value instanceof Carbon) {
+ return $value;
+ }
+
+ // If the value is already a DateTime instance, we will just skip the rest of
+ // these checks since they will be a waste of time, and hinder performance
+ // when checking the field. We will just return the DateTime right away.
+ if ($value instanceof DateTimeInterface) {
+ return new Carbon(
+ $value->format('Y-m-d H:i:s.u'), $value->getTimezone()
+ );
+ }
+
+ // If this value is an integer, we will assume it is a UNIX timestamp's value
+ // and format a Carbon object from this timestamp. This allows flexibility
+ // when defining your date fields as they might be UNIX timestamps here.
+ if (is_numeric($value)) {
+ return Carbon::createFromTimestamp($value);
+ }
+
+ // If the value is in simply year, month, day format, we will instantiate the
+ // Carbon instances from that format. Again, this provides for simple date
+ // fields on the database, while still supporting Carbonized conversion.
+ if ($this->isStandardDateFormat($value)) {
+ return Carbon::createFromFormat('Y-m-d', $value)->startOfDay();
+ }
+
+ // Finally, we will just assume this date is in the format used by default on
+ // the database connection and use that format to create the Carbon object
+ // that is returned back out to the developers after we convert it here.
+ return Carbon::createFromFormat(
+ $this->getDateFormat(), $value
+ );
+ }
+
+ /**
+ * Determine if the given value is a standard date format.
+ *
+ * @param string $value
+ * @return bool
+ */
+ protected function isStandardDateFormat($value)
+ {
+ return preg_match('/^(\d{4})-(\d{1,2})-(\d{1,2})$/', $value);
+ }
+
+ /**
+ * Convert a DateTime to a storable string.
+ *
+ * @param \DateTime|int $value
+ * @return string
+ */
+ public function fromDateTime($value)
+ {
+ return $this->asDateTime($value)->format(
+ $this->getDateFormat()
+ );
+ }
+
+ /**
+ * Return a timestamp as unix timestamp.
+ *
+ * @param mixed $value
+ * @return int
+ */
+ protected function asTimestamp($value)
+ {
+ return $this->asDateTime($value)->getTimestamp();
+ }
+
+ /**
+ * Prepare a date for array / JSON serialization.
+ *
+ * @param \DateTimeInterface $date
+ * @return string
+ */
+ protected function serializeDate(DateTimeInterface $date)
+ {
+ return $date->format($this->getDateFormat());
+ }
+
+ /**
+ * Get the attributes that should be converted to dates.
+ *
+ * @return array
+ */
+ public function getDates()
+ {
+ $defaults = [static::CREATED_AT, static::UPDATED_AT];
+
+ return $this->usesTimestamps()
+ ? array_unique(array_merge($this->dates, $defaults))
+ : $this->dates;
+ }
+
+ /**
+ * Get the format for database stored dates.
+ *
+ * @return string
+ */
+ protected function getDateFormat()
+ {
+ return $this->dateFormat ?: $this->getConnection()->getQueryGrammar()->getDateFormat();
+ }
+
+ /**
+ * Set the date format used by the model.
+ *
+ * @param string $format
+ * @return $this
+ */
+ public function setDateFormat($format)
+ {
+ $this->dateFormat = $format;
+
+ return $this;
+ }
+
+ /**
+ * Determine whether an attribute should be cast to a native type.
+ *
+ * @param string $key
+ * @param array|string|null $types
+ * @return bool
+ */
+ public function hasCast($key, $types = null)
+ {
+ if (array_key_exists($key, $this->getCasts())) {
+ return $types ? in_array($this->getCastType($key), (array) $types, true) : true;
+ }
+
+ return false;
+ }
+
+ /**
+ * Get the casts array.
+ *
+ * @return array
+ */
+ public function getCasts()
+ {
+ if ($this->getIncrementing()) {
+ return array_merge([$this->getKeyName() => $this->getKeyType()], $this->casts);
+ }
+
+ return $this->casts;
+ }
+
+ /**
+ * Determine whether a value is Date / DateTime castable for inbound manipulation.
+ *
+ * @param string $key
+ * @return bool
+ */
+ protected function isDateCastable($key)
+ {
+ return $this->hasCast($key, ['date', 'datetime']);
+ }
+
+ /**
+ * Determine whether a value is JSON castable for inbound manipulation.
+ *
+ * @param string $key
+ * @return bool
+ */
+ protected function isJsonCastable($key)
+ {
+ return $this->hasCast($key, ['array', 'json', 'object', 'collection']);
+ }
+
+ /**
+ * Get all of the current attributes on the model.
+ *
+ * @return array
+ */
+ public function getAttributes()
+ {
+ return $this->attributes;
+ }
+
+ /**
+ * Set the array of model attributes. No checking is done.
+ *
+ * @param array $attributes
+ * @param bool $sync
+ * @return $this
+ */
+ public function setRawAttributes(array $attributes, $sync = false)
+ {
+ $this->attributes = $attributes;
+
+ if ($sync) {
+ $this->syncOriginal();
+ }
+
+ return $this;
+ }
+
+ /**
+ * Get the model's original attribute values.
+ *
+ * @param string|null $key
+ * @param mixed $default
+ * @return mixed|array
+ */
+ public function getOriginal($key = null, $default = null)
+ {
+ return Arr::get($this->original, $key, $default);
+ }
+
+ /**
+ * Sync the original attributes with the current.
+ *
+ * @return $this
+ */
+ public function syncOriginal()
+ {
+ $this->original = $this->attributes;
+
+ return $this;
+ }
+
+ /**
+ * Sync a single original attribute with its current value.
+ *
+ * @param string $attribute
+ * @return $this
+ */
+ public function syncOriginalAttribute($attribute)
+ {
+ $this->original[$attribute] = $this->attributes[$attribute];
+
+ return $this;
+ }
+
+ /**
+ * Determine if the model or given attribute(s) have been modified.
+ *
+ * @param array|string|null $attributes
+ * @return bool
+ */
+ public function isDirty($attributes = null)
+ {
+ $dirty = $this->getDirty();
+
+ // If no specific attributes were provided, we will just see if the dirty array
+ // already contains any attributes. If it does we will just return that this
+ // count is greater than zero. Else, we need to check specific attributes.
+ if (is_null($attributes)) {
+ return count($dirty) > 0;
+ }
+
+ $attributes = is_array($attributes)
+ ? $attributes : func_get_args();
+
+ // Here we will spin through every attribute and see if this is in the array of
+ // dirty attributes. If it is, we will return true and if we make it through
+ // all of the attributes for the entire array we will return false at end.
+ foreach ($attributes as $attribute) {
+ if (array_key_exists($attribute, $dirty)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Determine if the model or given attribute(s) have remained the same.
+ *
+ * @param array|string|null $attributes
+ * @return bool
+ */
+ public function isClean($attributes = null)
+ {
+ return ! $this->isDirty(...func_get_args());
+ }
+
+ /**
+ * Get the attributes that have been changed since last sync.
+ *
+ * @return array
+ */
+ public function getDirty()
+ {
+ $dirty = [];
+
+ foreach ($this->attributes as $key => $value) {
+ if (! array_key_exists($key, $this->original)) {
+ $dirty[$key] = $value;
+ } elseif ($value !== $this->original[$key] &&
+ ! $this->originalIsNumericallyEquivalent($key)) {
+ $dirty[$key] = $value;
+ }
+ }
+
+ return $dirty;
+ }
+
+ /**
+ * Determine if the new and old values for a given key are numerically equivalent.
+ *
+ * @param string $key
+ * @return bool
+ */
+ protected function originalIsNumericallyEquivalent($key)
+ {
+ $current = $this->attributes[$key];
+
+ $original = $this->original[$key];
+
+ // This method checks if the two values are numerically equivalent even if they
+ // are different types. This is in case the two values are not the same type
+ // we can do a fair comparison of the two values to know if this is dirty.
+ return is_numeric($current) && is_numeric($original)
+ && strcmp((string) $current, (string) $original) === 0;
+ }
+
+ /**
+ * Append attributes to query when building a query.
+ *
+ * @param array|string $attributes
+ * @return $this
+ */
+ public function append($attributes)
+ {
+ $this->appends = array_unique(
+ array_merge($this->appends, is_string($attributes) ? func_get_args() : $attributes)
+ );
+
+ return $this;
+ }
+
+ /**
+ * Set the accessors to append to model arrays.
+ *
+ * @param array $appends
+ * @return $this
+ */
+ public function setAppends(array $appends)
+ {
+ $this->appends = $appends;
+
+ return $this;
+ }
+
+ /**
+ * Get the mutated attributes for a given instance.
+ *
+ * @return array
+ */
+ public function getMutatedAttributes()
+ {
+ $class = static::class;
+
+ if (! isset(static::$mutatorCache[$class])) {
+ static::cacheMutatedAttributes($class);
+ }
+
+ return static::$mutatorCache[$class];
+ }
+
+ /**
+ * Extract and cache all the mutated attributes of a class.
+ *
+ * @param string $class
+ * @return void
+ */
+ public static function cacheMutatedAttributes($class)
+ {
+ static::$mutatorCache[$class] = collect(static::getMutatorMethods($class))->map(function ($match) {
+ return lcfirst(static::$snakeAttributes ? Str::snake($match) : $match);
+ })->all();
+ }
+
+ /**
+ * Get all of the attribute mutator methods.
+ *
+ * @param mixed $class
+ * @return array
+ */
+ protected static function getMutatorMethods($class)
+ {
+ preg_match_all('/(?<=^|;)get([^;]+?)Attribute(;|$)/', implode(';', get_class_methods($class)), $matches);
+
+ return $matches[1];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasEvents.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasEvents.php
new file mode 100644
index 000000000..14874e844
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasEvents.php
@@ -0,0 +1,325 @@
+getObservableEvents() as $event) {
+ if (method_exists($class, $event)) {
+ static::registerModelEvent($event, $className.'@'.$event);
+ }
+ }
+ }
+
+ /**
+ * Get the observable event names.
+ *
+ * @return array
+ */
+ public function getObservableEvents()
+ {
+ return array_merge(
+ [
+ 'creating', 'created', 'updating', 'updated',
+ 'deleting', 'deleted', 'saving', 'saved',
+ 'restoring', 'restored',
+ ],
+ $this->observables
+ );
+ }
+
+ /**
+ * Set the observable event names.
+ *
+ * @param array $observables
+ * @return $this
+ */
+ public function setObservableEvents(array $observables)
+ {
+ $this->observables = $observables;
+
+ return $this;
+ }
+
+ /**
+ * Add an observable event name.
+ *
+ * @param array|mixed $observables
+ * @return void
+ */
+ public function addObservableEvents($observables)
+ {
+ $this->observables = array_unique(array_merge(
+ $this->observables, is_array($observables) ? $observables : func_get_args()
+ ));
+ }
+
+ /**
+ * Remove an observable event name.
+ *
+ * @param array|mixed $observables
+ * @return void
+ */
+ public function removeObservableEvents($observables)
+ {
+ $this->observables = array_diff(
+ $this->observables, is_array($observables) ? $observables : func_get_args()
+ );
+ }
+
+ /**
+ * Register a model event with the dispatcher.
+ *
+ * @param string $event
+ * @param \Closure|string $callback
+ * @return void
+ */
+ protected static function registerModelEvent($event, $callback)
+ {
+ if (isset(static::$dispatcher)) {
+ $name = static::class;
+
+ static::$dispatcher->listen("eloquent.{$event}: {$name}", $callback);
+ }
+ }
+
+ /**
+ * Fire the given event for the model.
+ *
+ * @param string $event
+ * @param bool $halt
+ * @return mixed
+ */
+ protected function fireModelEvent($event, $halt = true)
+ {
+ if (! isset(static::$dispatcher)) {
+ return true;
+ }
+
+ // First, we will get the proper method to call on the event dispatcher, and then we
+ // will attempt to fire a custom, object based event for the given event. If that
+ // returns a result we can return that result, or we'll call the string events.
+ $method = $halt ? 'until' : 'fire';
+
+ $result = $this->filterModelEventResults(
+ $this->fireCustomModelEvent($event, $method)
+ );
+
+ if ($result === false) {
+ return false;
+ }
+
+ return ! empty($result) ? $result : static::$dispatcher->{$method}(
+ "eloquent.{$event}: ".static::class, $this
+ );
+ }
+
+ /**
+ * Fire a custom model event for the given event.
+ *
+ * @param string $event
+ * @param string $method
+ * @return mixed|null
+ */
+ protected function fireCustomModelEvent($event, $method)
+ {
+ if (! isset($this->events[$event])) {
+ return;
+ }
+
+ $result = static::$dispatcher->$method(new $this->events[$event]($this));
+
+ if (! is_null($result)) {
+ return $result;
+ }
+ }
+
+ /**
+ * Filter the model event results.
+ *
+ * @param mixed $result
+ * @return mixed
+ */
+ protected function filterModelEventResults($result)
+ {
+ if (is_array($result)) {
+ $result = array_filter($result, function ($response) {
+ return ! is_null($response);
+ });
+ }
+
+ return $result;
+ }
+
+ /**
+ * Register a saving model event with the dispatcher.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public static function saving($callback)
+ {
+ static::registerModelEvent('saving', $callback);
+ }
+
+ /**
+ * Register a saved model event with the dispatcher.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public static function saved($callback)
+ {
+ static::registerModelEvent('saved', $callback);
+ }
+
+ /**
+ * Register an updating model event with the dispatcher.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public static function updating($callback)
+ {
+ static::registerModelEvent('updating', $callback);
+ }
+
+ /**
+ * Register an updated model event with the dispatcher.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public static function updated($callback)
+ {
+ static::registerModelEvent('updated', $callback);
+ }
+
+ /**
+ * Register a creating model event with the dispatcher.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public static function creating($callback)
+ {
+ static::registerModelEvent('creating', $callback);
+ }
+
+ /**
+ * Register a created model event with the dispatcher.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public static function created($callback)
+ {
+ static::registerModelEvent('created', $callback);
+ }
+
+ /**
+ * Register a deleting model event with the dispatcher.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public static function deleting($callback)
+ {
+ static::registerModelEvent('deleting', $callback);
+ }
+
+ /**
+ * Register a deleted model event with the dispatcher.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public static function deleted($callback)
+ {
+ static::registerModelEvent('deleted', $callback);
+ }
+
+ /**
+ * Remove all of the event listeners for the model.
+ *
+ * @return void
+ */
+ public static function flushEventListeners()
+ {
+ if (! isset(static::$dispatcher)) {
+ return;
+ }
+
+ $instance = new static;
+
+ foreach ($instance->getObservableEvents() as $event) {
+ static::$dispatcher->forget("eloquent.{$event}: ".static::class);
+ }
+ }
+
+ /**
+ * Get the event dispatcher instance.
+ *
+ * @return \Illuminate\Contracts\Events\Dispatcher
+ */
+ public static function getEventDispatcher()
+ {
+ return static::$dispatcher;
+ }
+
+ /**
+ * Set the event dispatcher instance.
+ *
+ * @param \Illuminate\Contracts\Events\Dispatcher $dispatcher
+ * @return void
+ */
+ public static function setEventDispatcher(Dispatcher $dispatcher)
+ {
+ static::$dispatcher = $dispatcher;
+ }
+
+ /**
+ * Unset the event dispatcher for models.
+ *
+ * @return void
+ */
+ public static function unsetEventDispatcher()
+ {
+ static::$dispatcher = null;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasGlobalScopes.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasGlobalScopes.php
new file mode 100644
index 000000000..97a549f6c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasGlobalScopes.php
@@ -0,0 +1,71 @@
+newRelatedInstance($related);
+
+ $foreignKey = $foreignKey ?: $this->getForeignKey();
+
+ $localKey = $localKey ?: $this->getKeyName();
+
+ return new HasOne($instance->newQuery(), $this, $instance->getTable().'.'.$foreignKey, $localKey);
+ }
+
+ /**
+ * Define a polymorphic one-to-one relationship.
+ *
+ * @param string $related
+ * @param string $name
+ * @param string $type
+ * @param string $id
+ * @param string $localKey
+ * @return \Illuminate\Database\Eloquent\Relations\MorphOne
+ */
+ public function morphOne($related, $name, $type = null, $id = null, $localKey = null)
+ {
+ $instance = $this->newRelatedInstance($related);
+
+ list($type, $id) = $this->getMorphs($name, $type, $id);
+
+ $table = $instance->getTable();
+
+ $localKey = $localKey ?: $this->getKeyName();
+
+ return new MorphOne($instance->newQuery(), $this, $table.'.'.$type, $table.'.'.$id, $localKey);
+ }
+
+ /**
+ * Define an inverse one-to-one or many relationship.
+ *
+ * @param string $related
+ * @param string $foreignKey
+ * @param string $ownerKey
+ * @param string $relation
+ * @return \Illuminate\Database\Eloquent\Relations\BelongsTo
+ */
+ public function belongsTo($related, $foreignKey = null, $ownerKey = null, $relation = null)
+ {
+ // If no relation name was given, we will use this debug backtrace to extract
+ // the calling method's name and use that as the relationship name as most
+ // of the time this will be what we desire to use for the relationships.
+ if (is_null($relation)) {
+ $relation = $this->guessBelongsToRelation();
+ }
+
+ $instance = $this->newRelatedInstance($related);
+
+ // If no foreign key was supplied, we can use a backtrace to guess the proper
+ // foreign key name by using the name of the relationship function, which
+ // when combined with an "_id" should conventionally match the columns.
+ if (is_null($foreignKey)) {
+ $foreignKey = Str::snake($relation).'_'.$instance->getKeyName();
+ }
+
+ // Once we have the foreign key names, we'll just create a new Eloquent query
+ // for the related models and returns the relationship instance which will
+ // actually be responsible for retrieving and hydrating every relations.
+ $ownerKey = $ownerKey ?: $instance->getKeyName();
+
+ return new BelongsTo(
+ $instance->newQuery(), $this, $foreignKey, $ownerKey, $relation
+ );
+ }
+
+ /**
+ * Define a polymorphic, inverse one-to-one or many relationship.
+ *
+ * @param string $name
+ * @param string $type
+ * @param string $id
+ * @return \Illuminate\Database\Eloquent\Relations\MorphTo
+ */
+ public function morphTo($name = null, $type = null, $id = null)
+ {
+ // If no name is provided, we will use the backtrace to get the function name
+ // since that is most likely the name of the polymorphic interface. We can
+ // use that to get both the class and foreign key that will be utilized.
+ $name = $name ?: $this->guessBelongsToRelation();
+
+ list($type, $id) = $this->getMorphs(
+ Str::snake($name), $type, $id
+ );
+
+ // If the type value is null it is probably safe to assume we're eager loading
+ // the relationship. In this case we'll just pass in a dummy query where we
+ // need to remove any eager loads that may already be defined on a model.
+ return empty($class = $this->{$type})
+ ? $this->morphEagerTo($name, $type, $id)
+ : $this->morphInstanceTo($class, $name, $type, $id);
+ }
+
+ /**
+ * Define a polymorphic, inverse one-to-one or many relationship.
+ *
+ * @param string $name
+ * @param string $type
+ * @param string $id
+ * @return \Illuminate\Database\Eloquent\Relations\MorphTo
+ */
+ protected function morphEagerTo($name, $type, $id)
+ {
+ return new MorphTo(
+ $this->newQuery()->setEagerLoads([]), $this, $id, null, $type, $name
+ );
+ }
+
+ /**
+ * Define a polymorphic, inverse one-to-one or many relationship.
+ *
+ * @param string $target
+ * @param string $name
+ * @param string $type
+ * @param string $id
+ * @return \Illuminate\Database\Eloquent\Relations\MorphTo
+ */
+ protected function morphInstanceTo($target, $name, $type, $id)
+ {
+ $instance = $this->newRelatedInstance(
+ static::getActualClassNameForMorph($target)
+ );
+
+ return new MorphTo(
+ $instance->newQuery(), $this, $id, $instance->getKeyName(), $type, $name
+ );
+ }
+
+ /**
+ * Retrieve the actual class name for a given morph class.
+ *
+ * @param string $class
+ * @return string
+ */
+ public static function getActualClassNameForMorph($class)
+ {
+ return Arr::get(Relation::morphMap() ?: [], $class, $class);
+ }
+
+ /**
+ * Guess the "belongs to" relationship name.
+ *
+ * @return string
+ */
+ protected function guessBelongsToRelation()
+ {
+ list($one, $two, $caller) = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 3);
+
+ return $caller['function'];
+ }
+
+ /**
+ * Define a one-to-many relationship.
+ *
+ * @param string $related
+ * @param string $foreignKey
+ * @param string $localKey
+ * @return \Illuminate\Database\Eloquent\Relations\HasMany
+ */
+ public function hasMany($related, $foreignKey = null, $localKey = null)
+ {
+ $instance = $this->newRelatedInstance($related);
+
+ $foreignKey = $foreignKey ?: $this->getForeignKey();
+
+ $localKey = $localKey ?: $this->getKeyName();
+
+ return new HasMany(
+ $instance->newQuery(), $this, $instance->getTable().'.'.$foreignKey, $localKey
+ );
+ }
+
+ /**
+ * Define a has-many-through relationship.
+ *
+ * @param string $related
+ * @param string $through
+ * @param string|null $firstKey
+ * @param string|null $secondKey
+ * @param string|null $localKey
+ * @return \Illuminate\Database\Eloquent\Relations\HasManyThrough
+ */
+ public function hasManyThrough($related, $through, $firstKey = null, $secondKey = null, $localKey = null)
+ {
+ $through = new $through;
+
+ $firstKey = $firstKey ?: $this->getForeignKey();
+
+ $secondKey = $secondKey ?: $through->getForeignKey();
+
+ $localKey = $localKey ?: $this->getKeyName();
+
+ $instance = $this->newRelatedInstance($related);
+
+ return new HasManyThrough($instance->newQuery(), $this, $through, $firstKey, $secondKey, $localKey);
+ }
+
+ /**
+ * Define a polymorphic one-to-many relationship.
+ *
+ * @param string $related
+ * @param string $name
+ * @param string $type
+ * @param string $id
+ * @param string $localKey
+ * @return \Illuminate\Database\Eloquent\Relations\MorphMany
+ */
+ public function morphMany($related, $name, $type = null, $id = null, $localKey = null)
+ {
+ $instance = $this->newRelatedInstance($related);
+
+ // Here we will gather up the morph type and ID for the relationship so that we
+ // can properly query the intermediate table of a relation. Finally, we will
+ // get the table and create the relationship instances for the developers.
+ list($type, $id) = $this->getMorphs($name, $type, $id);
+
+ $table = $instance->getTable();
+
+ $localKey = $localKey ?: $this->getKeyName();
+
+ return new MorphMany($instance->newQuery(), $this, $table.'.'.$type, $table.'.'.$id, $localKey);
+ }
+
+ /**
+ * Define a many-to-many relationship.
+ *
+ * @param string $related
+ * @param string $table
+ * @param string $foreignKey
+ * @param string $relatedKey
+ * @param string $relation
+ * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
+ */
+ public function belongsToMany($related, $table = null, $foreignKey = null, $relatedKey = null, $relation = null)
+ {
+ // If no relationship name was passed, we will pull backtraces to get the
+ // name of the calling function. We will use that function name as the
+ // title of this relation since that is a great convention to apply.
+ if (is_null($relation)) {
+ $relation = $this->guessBelongsToManyRelation();
+ }
+
+ // First, we'll need to determine the foreign key and "other key" for the
+ // relationship. Once we have determined the keys we'll make the query
+ // instances as well as the relationship instances we need for this.
+ $instance = $this->newRelatedInstance($related);
+
+ $foreignKey = $foreignKey ?: $this->getForeignKey();
+
+ $relatedKey = $relatedKey ?: $instance->getForeignKey();
+
+ // If no table name was provided, we can guess it by concatenating the two
+ // models using underscores in alphabetical order. The two model names
+ // are transformed to snake case from their default CamelCase also.
+ if (is_null($table)) {
+ $table = $this->joiningTable($related);
+ }
+
+ return new BelongsToMany(
+ $instance->newQuery(), $this, $table, $foreignKey, $relatedKey, $relation
+ );
+ }
+
+ /**
+ * Define a polymorphic many-to-many relationship.
+ *
+ * @param string $related
+ * @param string $name
+ * @param string $table
+ * @param string $foreignKey
+ * @param string $relatedKey
+ * @param bool $inverse
+ * @return \Illuminate\Database\Eloquent\Relations\MorphToMany
+ */
+ public function morphToMany($related, $name, $table = null, $foreignKey = null, $relatedKey = null, $inverse = false)
+ {
+ $caller = $this->guessBelongsToManyRelation();
+
+ // First, we will need to determine the foreign key and "other key" for the
+ // relationship. Once we have determined the keys we will make the query
+ // instances, as well as the relationship instances we need for these.
+ $instance = $this->newRelatedInstance($related);
+
+ $foreignKey = $foreignKey ?: $name.'_id';
+
+ $relatedKey = $relatedKey ?: $instance->getForeignKey();
+
+ // Now we're ready to create a new query builder for this related model and
+ // the relationship instances for this relation. This relations will set
+ // appropriate query constraints then entirely manages the hydrations.
+ $table = $table ?: Str::plural($name);
+
+ return new MorphToMany(
+ $instance->newQuery(), $this, $name, $table,
+ $foreignKey, $relatedKey, $caller, $inverse
+ );
+ }
+
+ /**
+ * Define a polymorphic, inverse many-to-many relationship.
+ *
+ * @param string $related
+ * @param string $name
+ * @param string $table
+ * @param string $foreignKey
+ * @param string $relatedKey
+ * @return \Illuminate\Database\Eloquent\Relations\MorphToMany
+ */
+ public function morphedByMany($related, $name, $table = null, $foreignKey = null, $relatedKey = null)
+ {
+ $foreignKey = $foreignKey ?: $this->getForeignKey();
+
+ // For the inverse of the polymorphic many-to-many relations, we will change
+ // the way we determine the foreign and other keys, as it is the opposite
+ // of the morph-to-many method since we're figuring out these inverses.
+ $relatedKey = $relatedKey ?: $name.'_id';
+
+ return $this->morphToMany($related, $name, $table, $foreignKey, $relatedKey, true);
+ }
+
+ /**
+ * Get the relationship name of the belongs to many.
+ *
+ * @return string
+ */
+ protected function guessBelongsToManyRelation()
+ {
+ $caller = Arr::first(debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS), function ($trace) {
+ return ! in_array($trace['function'], Model::$manyMethods);
+ });
+
+ return ! is_null($caller) ? $caller['function'] : null;
+ }
+
+ /**
+ * Get the joining table name for a many-to-many relation.
+ *
+ * @param string $related
+ * @return string
+ */
+ public function joiningTable($related)
+ {
+ // The joining table name, by convention, is simply the snake cased models
+ // sorted alphabetically and concatenated with an underscore, so we can
+ // just sort the models and join them together to get the table name.
+ $models = [
+ Str::snake(class_basename($related)),
+ Str::snake(class_basename($this)),
+ ];
+
+ // Now that we have the model names in an array we can just sort them and
+ // use the implode function to join them together with an underscores,
+ // which is typically used by convention within the database system.
+ sort($models);
+
+ return strtolower(implode('_', $models));
+ }
+
+ /**
+ * Determine if the model touches a given relation.
+ *
+ * @param string $relation
+ * @return bool
+ */
+ public function touches($relation)
+ {
+ return in_array($relation, $this->touches);
+ }
+
+ /**
+ * Touch the owning relations of the model.
+ *
+ * @return void
+ */
+ public function touchOwners()
+ {
+ foreach ($this->touches as $relation) {
+ $this->$relation()->touch();
+
+ if ($this->$relation instanceof self) {
+ $this->$relation->fireModelEvent('saved', false);
+
+ $this->$relation->touchOwners();
+ } elseif ($this->$relation instanceof Collection) {
+ $this->$relation->each(function (Model $relation) {
+ $relation->touchOwners();
+ });
+ }
+ }
+ }
+
+ /**
+ * Get the polymorphic relationship columns.
+ *
+ * @param string $name
+ * @param string $type
+ * @param string $id
+ * @return array
+ */
+ protected function getMorphs($name, $type, $id)
+ {
+ return [$type ?: $name.'_type', $id ?: $name.'_id'];
+ }
+
+ /**
+ * Get the class name for polymorphic relations.
+ *
+ * @return string
+ */
+ public function getMorphClass()
+ {
+ $morphMap = Relation::morphMap();
+
+ if (! empty($morphMap) && in_array(static::class, $morphMap)) {
+ return array_search(static::class, $morphMap, true);
+ }
+
+ return static::class;
+ }
+
+ /**
+ * Create a new model instance for a related model.
+ *
+ * @param string $class
+ * @return mixed
+ */
+ protected function newRelatedInstance($class)
+ {
+ return tap(new $class, function ($instance) {
+ if (! $instance->getConnectionName()) {
+ $instance->setConnection($this->connection);
+ }
+ });
+ }
+
+ /**
+ * Get all the loaded relations for the instance.
+ *
+ * @return array
+ */
+ public function getRelations()
+ {
+ return $this->relations;
+ }
+
+ /**
+ * Get a specified relationship.
+ *
+ * @param string $relation
+ * @return mixed
+ */
+ public function getRelation($relation)
+ {
+ return $this->relations[$relation];
+ }
+
+ /**
+ * Determine if the given relation is loaded.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function relationLoaded($key)
+ {
+ return array_key_exists($key, $this->relations);
+ }
+
+ /**
+ * Set the specific relationship in the model.
+ *
+ * @param string $relation
+ * @param mixed $value
+ * @return $this
+ */
+ public function setRelation($relation, $value)
+ {
+ $this->relations[$relation] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set the entire relations array on the model.
+ *
+ * @param array $relations
+ * @return $this
+ */
+ public function setRelations(array $relations)
+ {
+ $this->relations = $relations;
+
+ return $this;
+ }
+
+ /**
+ * Get the relationships that are touched on save.
+ *
+ * @return array
+ */
+ public function getTouchedRelations()
+ {
+ return $this->touches;
+ }
+
+ /**
+ * Set the relationships that are touched on save.
+ *
+ * @param array $touches
+ * @return $this
+ */
+ public function setTouchedRelations(array $touches)
+ {
+ $this->touches = $touches;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasTimestamps.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasTimestamps.php
new file mode 100644
index 000000000..ba640fe4b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HasTimestamps.php
@@ -0,0 +1,125 @@
+usesTimestamps()) {
+ return false;
+ }
+
+ $this->updateTimestamps();
+
+ return $this->save();
+ }
+
+ /**
+ * Update the creation and update timestamps.
+ *
+ * @return void
+ */
+ protected function updateTimestamps()
+ {
+ $time = $this->freshTimestamp();
+
+ if (! $this->isDirty(static::UPDATED_AT)) {
+ $this->setUpdatedAt($time);
+ }
+
+ if (! $this->exists && ! $this->isDirty(static::CREATED_AT)) {
+ $this->setCreatedAt($time);
+ }
+ }
+
+ /**
+ * Set the value of the "created at" attribute.
+ *
+ * @param mixed $value
+ * @return $this
+ */
+ public function setCreatedAt($value)
+ {
+ $this->{static::CREATED_AT} = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set the value of the "updated at" attribute.
+ *
+ * @param mixed $value
+ * @return $this
+ */
+ public function setUpdatedAt($value)
+ {
+ $this->{static::UPDATED_AT} = $value;
+
+ return $this;
+ }
+
+ /**
+ * Get a fresh timestamp for the model.
+ *
+ * @return \Carbon\Carbon
+ */
+ public function freshTimestamp()
+ {
+ return new Carbon;
+ }
+
+ /**
+ * Get a fresh timestamp for the model.
+ *
+ * @return string
+ */
+ public function freshTimestampString()
+ {
+ return $this->fromDateTime($this->freshTimestamp());
+ }
+
+ /**
+ * Determine if the model uses timestamps.
+ *
+ * @return bool
+ */
+ public function usesTimestamps()
+ {
+ return $this->timestamps;
+ }
+
+ /**
+ * Get the name of the "created at" column.
+ *
+ * @return string
+ */
+ public function getCreatedAtColumn()
+ {
+ return static::CREATED_AT;
+ }
+
+ /**
+ * Get the name of the "updated at" column.
+ *
+ * @return string
+ */
+ public function getUpdatedAtColumn()
+ {
+ return static::UPDATED_AT;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HidesAttributes.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HidesAttributes.php
new file mode 100644
index 000000000..7bd9ef934
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/HidesAttributes.php
@@ -0,0 +1,126 @@
+hidden;
+ }
+
+ /**
+ * Set the hidden attributes for the model.
+ *
+ * @param array $hidden
+ * @return $this
+ */
+ public function setHidden(array $hidden)
+ {
+ $this->hidden = $hidden;
+
+ return $this;
+ }
+
+ /**
+ * Add hidden attributes for the model.
+ *
+ * @param array|string|null $attributes
+ * @return void
+ */
+ public function addHidden($attributes = null)
+ {
+ $this->hidden = array_merge(
+ $this->hidden, is_array($attributes) ? $attributes : func_get_args()
+ );
+ }
+
+ /**
+ * Get the visible attributes for the model.
+ *
+ * @return array
+ */
+ public function getVisible()
+ {
+ return $this->visible;
+ }
+
+ /**
+ * Set the visible attributes for the model.
+ *
+ * @param array $visible
+ * @return $this
+ */
+ public function setVisible(array $visible)
+ {
+ $this->visible = $visible;
+
+ return $this;
+ }
+
+ /**
+ * Add visible attributes for the model.
+ *
+ * @param array|string|null $attributes
+ * @return void
+ */
+ public function addVisible($attributes = null)
+ {
+ $this->visible = array_merge(
+ $this->visible, is_array($attributes) ? $attributes : func_get_args()
+ );
+ }
+
+ /**
+ * Make the given, typically hidden, attributes visible.
+ *
+ * @param array|string $attributes
+ * @return $this
+ */
+ public function makeVisible($attributes)
+ {
+ $this->hidden = array_diff($this->hidden, (array) $attributes);
+
+ if (! empty($this->visible)) {
+ $this->addVisible($attributes);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Make the given, typically visible, attributes hidden.
+ *
+ * @param array|string $attributes
+ * @return $this
+ */
+ public function makeHidden($attributes)
+ {
+ $attributes = (array) $attributes;
+
+ $this->visible = array_diff($this->visible, $attributes);
+
+ $this->hidden = array_unique(array_merge($this->hidden, $attributes));
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/QueriesRelationships.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/QueriesRelationships.php
new file mode 100644
index 000000000..ffae137e9
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Concerns/QueriesRelationships.php
@@ -0,0 +1,313 @@
+=', $count = 1, $boolean = 'and', Closure $callback = null)
+ {
+ if (strpos($relation, '.') !== false) {
+ return $this->hasNested($relation, $operator, $count, $boolean, $callback);
+ }
+
+ $relation = $this->getRelationWithoutConstraints($relation);
+
+ // If we only need to check for the existence of the relation, then we can optimize
+ // the subquery to only run a "where exists" clause instead of this full "count"
+ // clause. This will make these queries run much faster compared with a count.
+ $method = $this->canUseExistsForExistenceCheck($operator, $count)
+ ? 'getRelationExistenceQuery'
+ : 'getRelationExistenceCountQuery';
+
+ $hasQuery = $relation->{$method}(
+ $relation->getRelated()->newQuery(), $this
+ );
+
+ // Next we will call any given callback as an "anonymous" scope so they can get the
+ // proper logical grouping of the where clauses if needed by this Eloquent query
+ // builder. Then, we will be ready to finalize and return this query instance.
+ if ($callback) {
+ $hasQuery->callScope($callback);
+ }
+
+ return $this->addHasWhere(
+ $hasQuery, $relation, $operator, $count, $boolean
+ );
+ }
+
+ /**
+ * Add nested relationship count / exists conditions to the query.
+ *
+ * Sets up recursive call to whereHas until we finish the nested relation.
+ *
+ * @param string $relations
+ * @param string $operator
+ * @param int $count
+ * @param string $boolean
+ * @param \Closure|null $callback
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ protected function hasNested($relations, $operator = '>=', $count = 1, $boolean = 'and', $callback = null)
+ {
+ $relations = explode('.', $relations);
+
+ $closure = function ($q) use (&$closure, &$relations, $operator, $count, $boolean, $callback) {
+ // In order to nest "has", we need to add count relation constraints on the
+ // callback Closure. We'll do this by simply passing the Closure its own
+ // reference to itself so it calls itself recursively on each segment.
+ count($relations) > 1
+ ? $q->whereHas(array_shift($relations), $closure)
+ : $q->has(array_shift($relations), $operator, $count, 'and', $callback);
+ };
+
+ return $this->has(array_shift($relations), '>=', 1, $boolean, $closure);
+ }
+
+ /**
+ * Add a relationship count / exists condition to the query with an "or".
+ *
+ * @param string $relation
+ * @param string $operator
+ * @param int $count
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function orHas($relation, $operator = '>=', $count = 1)
+ {
+ return $this->has($relation, $operator, $count, 'or');
+ }
+
+ /**
+ * Add a relationship count / exists condition to the query.
+ *
+ * @param string $relation
+ * @param string $boolean
+ * @param \Closure|null $callback
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function doesntHave($relation, $boolean = 'and', Closure $callback = null)
+ {
+ return $this->has($relation, '<', 1, $boolean, $callback);
+ }
+
+ /**
+ * Add a relationship count / exists condition to the query with an "or".
+ *
+ * @param string $relation
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function orDoesntHave($relation)
+ {
+ return $this->doesntHave($relation, 'or');
+ }
+
+ /**
+ * Add a relationship count / exists condition to the query with where clauses.
+ *
+ * @param string $relation
+ * @param \Closure|null $callback
+ * @param string $operator
+ * @param int $count
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function whereHas($relation, Closure $callback = null, $operator = '>=', $count = 1)
+ {
+ return $this->has($relation, $operator, $count, 'and', $callback);
+ }
+
+ /**
+ * Add a relationship count / exists condition to the query with where clauses and an "or".
+ *
+ * @param string $relation
+ * @param \Closure $callback
+ * @param string $operator
+ * @param int $count
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function orWhereHas($relation, Closure $callback = null, $operator = '>=', $count = 1)
+ {
+ return $this->has($relation, $operator, $count, 'or', $callback);
+ }
+
+ /**
+ * Add a relationship count / exists condition to the query with where clauses.
+ *
+ * @param string $relation
+ * @param \Closure|null $callback
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function whereDoesntHave($relation, Closure $callback = null)
+ {
+ return $this->doesntHave($relation, 'and', $callback);
+ }
+
+ /**
+ * Add a relationship count / exists condition to the query with where clauses and an "or".
+ *
+ * @param string $relation
+ * @param \Closure $callback
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function orWhereDoesntHave($relation, Closure $callback = null)
+ {
+ return $this->doesntHave($relation, 'or', $callback);
+ }
+
+ /**
+ * Add subselect queries to count the relations.
+ *
+ * @param mixed $relations
+ * @return $this
+ */
+ public function withCount($relations)
+ {
+ if (empty($relations)) {
+ return $this;
+ }
+
+ if (is_null($this->query->columns)) {
+ $this->query->select([$this->query->from.'.*']);
+ }
+
+ $relations = is_array($relations) ? $relations : func_get_args();
+
+ foreach ($this->parseWithRelations($relations) as $name => $constraints) {
+ // First we will determine if the name has been aliased using an "as" clause on the name
+ // and if it has we will extract the actual relationship name and the desired name of
+ // the resulting column. This allows multiple counts on the same relationship name.
+ $segments = explode(' ', $name);
+
+ unset($alias);
+
+ if (count($segments) == 3 && Str::lower($segments[1]) == 'as') {
+ list($name, $alias) = [$segments[0], $segments[2]];
+ }
+
+ $relation = $this->getRelationWithoutConstraints($name);
+
+ // Here we will get the relationship count query and prepare to add it to the main query
+ // as a sub-select. First, we'll get the "has" query and use that to get the relation
+ // count query. We will normalize the relation name then append _count as the name.
+ $query = $relation->getRelationExistenceCountQuery(
+ $relation->getRelated()->newQuery(), $this
+ );
+
+ $query->callScope($constraints);
+
+ $query->mergeConstraintsFrom($relation->getQuery());
+
+ // Finally we will add the proper result column alias to the query and run the subselect
+ // statement against the query builder. Then we will return the builder instance back
+ // to the developer for further constraint chaining that needs to take place on it.
+ $column = snake_case(isset($alias) ? $alias : $name).'_count';
+
+ $this->selectSub($query->toBase(), $column);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add the "has" condition where clause to the query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $hasQuery
+ * @param \Illuminate\Database\Eloquent\Relations\Relation $relation
+ * @param string $operator
+ * @param int $count
+ * @param string $boolean
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ protected function addHasWhere(Builder $hasQuery, Relation $relation, $operator, $count, $boolean)
+ {
+ $hasQuery->mergeConstraintsFrom($relation->getQuery());
+
+ return $this->canUseExistsForExistenceCheck($operator, $count)
+ ? $this->addWhereExistsQuery($hasQuery->toBase(), $boolean, $not = ($operator === '<' && $count === 1))
+ : $this->addWhereCountQuery($hasQuery->toBase(), $operator, $count, $boolean);
+ }
+
+ /**
+ * Merge the where constraints from another query to the current query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $from
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function mergeConstraintsFrom(Builder $from)
+ {
+ $whereBindings = Arr::get(
+ $from->getQuery()->getRawBindings(), 'where', []
+ );
+
+ // Here we have some other query that we want to merge the where constraints from. We will
+ // copy over any where constraints on the query as well as remove any global scopes the
+ // query might have removed. Then we will return ourselves with the finished merging.
+ return $this->withoutGlobalScopes(
+ $from->removedScopes()
+ )->mergeWheres(
+ $from->getQuery()->wheres, $whereBindings
+ );
+ }
+
+ /**
+ * Add a sub-query count clause to this query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param string $operator
+ * @param int $count
+ * @param string $boolean
+ * @return $this
+ */
+ protected function addWhereCountQuery(QueryBuilder $query, $operator = '>=', $count = 1, $boolean = 'and')
+ {
+ $this->query->addBinding($query->getBindings(), 'where');
+
+ return $this->where(
+ new Expression('('.$query->toSql().')'),
+ $operator,
+ is_numeric($count) ? new Expression($count) : $count,
+ $boolean
+ );
+ }
+
+ /**
+ * Get the "has relation" base query instance.
+ *
+ * @param string $relation
+ * @return \Illuminate\Database\Eloquent\Relations\Relation
+ */
+ protected function getRelationWithoutConstraints($relation)
+ {
+ return Relation::noConstraints(function () use ($relation) {
+ return $this->getModel()->{$relation}();
+ });
+ }
+
+ /**
+ * Check if we can run an "exists" query to optimize performance.
+ *
+ * @param string $operator
+ * @param int $count
+ * @return bool
+ */
+ protected function canUseExistsForExistenceCheck($operator, $count)
+ {
+ return ($operator === '>=' || $operator === '<') && $count === 1;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Factory.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Factory.php
new file mode 100644
index 000000000..0b57576e1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Factory.php
@@ -0,0 +1,253 @@
+faker = $faker;
+ }
+
+ /**
+ * Create a new factory container.
+ *
+ * @param \Faker\Generator $faker
+ * @param string|null $pathToFactories
+ * @return static
+ */
+ public static function construct(Faker $faker, $pathToFactories = null)
+ {
+ $pathToFactories = $pathToFactories ?: database_path('factories');
+
+ return (new static($faker))->load($pathToFactories);
+ }
+
+ /**
+ * Define a class with a given short-name.
+ *
+ * @param string $class
+ * @param string $name
+ * @param callable $attributes
+ * @return $this
+ */
+ public function defineAs($class, $name, callable $attributes)
+ {
+ return $this->define($class, $attributes, $name);
+ }
+
+ /**
+ * Define a class with a given set of attributes.
+ *
+ * @param string $class
+ * @param callable $attributes
+ * @param string $name
+ * @return $this
+ */
+ public function define($class, callable $attributes, $name = 'default')
+ {
+ $this->definitions[$class][$name] = $attributes;
+
+ return $this;
+ }
+
+ /**
+ * Define a state with a given set of attributes.
+ *
+ * @param string $class
+ * @param string $state
+ * @param callable $attributes
+ * @return $this
+ */
+ public function state($class, $state, callable $attributes)
+ {
+ $this->states[$class][$state] = $attributes;
+
+ return $this;
+ }
+
+ /**
+ * Create an instance of the given model and persist it to the database.
+ *
+ * @param string $class
+ * @param array $attributes
+ * @return mixed
+ */
+ public function create($class, array $attributes = [])
+ {
+ return $this->of($class)->create($attributes);
+ }
+
+ /**
+ * Create an instance of the given model and type and persist it to the database.
+ *
+ * @param string $class
+ * @param string $name
+ * @param array $attributes
+ * @return mixed
+ */
+ public function createAs($class, $name, array $attributes = [])
+ {
+ return $this->of($class, $name)->create($attributes);
+ }
+
+ /**
+ * Create an instance of the given model.
+ *
+ * @param string $class
+ * @param array $attributes
+ * @return mixed
+ */
+ public function make($class, array $attributes = [])
+ {
+ return $this->of($class)->make($attributes);
+ }
+
+ /**
+ * Create an instance of the given model and type.
+ *
+ * @param string $class
+ * @param string $name
+ * @param array $attributes
+ * @return mixed
+ */
+ public function makeAs($class, $name, array $attributes = [])
+ {
+ return $this->of($class, $name)->make($attributes);
+ }
+
+ /**
+ * Get the raw attribute array for a given named model.
+ *
+ * @param string $class
+ * @param string $name
+ * @param array $attributes
+ * @return array
+ */
+ public function rawOf($class, $name, array $attributes = [])
+ {
+ return $this->raw($class, $attributes, $name);
+ }
+
+ /**
+ * Get the raw attribute array for a given model.
+ *
+ * @param string $class
+ * @param array $attributes
+ * @param string $name
+ * @return array
+ */
+ public function raw($class, array $attributes = [], $name = 'default')
+ {
+ return array_merge(
+ call_user_func($this->definitions[$class][$name], $this->faker), $attributes
+ );
+ }
+
+ /**
+ * Create a builder for the given model.
+ *
+ * @param string $class
+ * @param string $name
+ * @return \Illuminate\Database\Eloquent\FactoryBuilder
+ */
+ public function of($class, $name = 'default')
+ {
+ return new FactoryBuilder($class, $name, $this->definitions, $this->states, $this->faker);
+ }
+
+ /**
+ * Load factories from path.
+ *
+ * @param string $path
+ * @return $this
+ */
+ public function load($path)
+ {
+ $factory = $this;
+
+ if (is_dir($path)) {
+ foreach (Finder::create()->files()->name('*.php')->in($path) as $file) {
+ require $file->getRealPath();
+ }
+ }
+
+ return $factory;
+ }
+
+ /**
+ * Determine if the given offset exists.
+ *
+ * @param string $offset
+ * @return bool
+ */
+ public function offsetExists($offset)
+ {
+ return isset($this->definitions[$offset]);
+ }
+
+ /**
+ * Get the value of the given offset.
+ *
+ * @param string $offset
+ * @return mixed
+ */
+ public function offsetGet($offset)
+ {
+ return $this->make($offset);
+ }
+
+ /**
+ * Set the given offset to the given value.
+ *
+ * @param string $offset
+ * @param callable $value
+ * @return void
+ */
+ public function offsetSet($offset, $value)
+ {
+ return $this->define($offset, $value);
+ }
+
+ /**
+ * Unset the value at the given offset.
+ *
+ * @param string $offset
+ * @return void
+ */
+ public function offsetUnset($offset)
+ {
+ unset($this->definitions[$offset]);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php
new file mode 100644
index 000000000..ffa4789e0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/FactoryBuilder.php
@@ -0,0 +1,282 @@
+name = $name;
+ $this->class = $class;
+ $this->faker = $faker;
+ $this->states = $states;
+ $this->definitions = $definitions;
+ }
+
+ /**
+ * Set the amount of models you wish to create / make.
+ *
+ * @param int $amount
+ * @return $this
+ */
+ public function times($amount)
+ {
+ $this->amount = $amount;
+
+ return $this;
+ }
+
+ /**
+ * Set the states to be applied to the model.
+ *
+ * @param array|mixed $states
+ * @return $this
+ */
+ public function states($states)
+ {
+ $this->activeStates = is_array($states) ? $states : func_get_args();
+
+ return $this;
+ }
+
+ /**
+ * Create a model and persist it in the database if requested.
+ *
+ * @param array $attributes
+ * @return \Closure
+ */
+ public function lazy(array $attributes = [])
+ {
+ return function () use ($attributes) {
+ return $this->create($attributes);
+ };
+ }
+
+ /**
+ * Create a collection of models and persist them to the database.
+ *
+ * @param array $attributes
+ * @return mixed
+ */
+ public function create(array $attributes = [])
+ {
+ $results = $this->make($attributes);
+
+ if ($results instanceof Model) {
+ $this->store(collect([$results]));
+ } else {
+ $this->store($results);
+ }
+
+ return $results;
+ }
+
+ /**
+ * Set the connection name on the results and store them.
+ *
+ * @param \Illuminate\Support\Collection $results
+ * @return void
+ */
+ protected function store($results)
+ {
+ $results->each(function ($model) {
+ $model->setConnection($model->newQueryWithoutScopes()->getConnection()->getName());
+
+ $model->save();
+ });
+ }
+
+ /**
+ * Create a collection of models.
+ *
+ * @param array $attributes
+ * @return mixed
+ */
+ public function make(array $attributes = [])
+ {
+ if ($this->amount === null) {
+ return $this->makeInstance($attributes);
+ }
+
+ if ($this->amount < 1) {
+ return (new $this->class)->newCollection();
+ }
+
+ return (new $this->class)->newCollection(array_map(function () use ($attributes) {
+ return $this->makeInstance($attributes);
+ }, range(1, $this->amount)));
+ }
+
+ /**
+ * Create an array of raw attribute arrays.
+ *
+ * @param array $attributes
+ * @return mixed
+ */
+ public function raw(array $attributes = [])
+ {
+ if ($this->amount === null) {
+ return $this->getRawAttributes($attributes);
+ }
+
+ if ($this->amount < 1) {
+ return [];
+ }
+
+ return array_map(function () use ($attributes) {
+ return $this->getRawAttributes($attributes);
+ }, range(1, $this->amount));
+ }
+
+ /**
+ * Get a raw attributes array for the model.
+ *
+ * @param array $attributes
+ * @return mixed
+ */
+ protected function getRawAttributes(array $attributes = [])
+ {
+ $definition = call_user_func(
+ $this->definitions[$this->class][$this->name],
+ $this->faker, $attributes
+ );
+
+ return $this->expandAttributes(
+ array_merge($this->applyStates($definition, $attributes), $attributes)
+ );
+ }
+
+ /**
+ * Make an instance of the model with the given attributes.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function makeInstance(array $attributes = [])
+ {
+ return Model::unguarded(function () use ($attributes) {
+ if (! isset($this->definitions[$this->class][$this->name])) {
+ throw new InvalidArgumentException("Unable to locate factory with name [{$this->name}] [{$this->class}].");
+ }
+
+ return new $this->class(
+ $this->getRawAttributes($attributes)
+ );
+ });
+ }
+
+ /**
+ * Apply the active states to the model definition array.
+ *
+ * @param array $definition
+ * @param array $attributes
+ * @return array
+ */
+ protected function applyStates(array $definition, array $attributes = [])
+ {
+ foreach ($this->activeStates as $state) {
+ if (! isset($this->states[$this->class][$state])) {
+ throw new InvalidArgumentException("Unable to locate [{$state}] state for [{$this->class}].");
+ }
+
+ $definition = array_merge($definition, call_user_func(
+ $this->states[$this->class][$state],
+ $this->faker, $attributes
+ ));
+ }
+
+ return $definition;
+ }
+
+ /**
+ * Expand all attributes to their underlying values.
+ *
+ * @param array $attributes
+ * @return array
+ */
+ protected function expandAttributes(array $attributes)
+ {
+ foreach ($attributes as &$attribute) {
+ if (is_callable($attribute) && ! is_string($attribute)) {
+ $attribute = $attribute($attributes);
+ }
+
+ if ($attribute instanceof static) {
+ $attribute = $attribute->create()->getKey();
+ }
+
+ if ($attribute instanceof Model) {
+ $attribute = $attribute->getKey();
+ }
+ }
+
+ return $attributes;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/JsonEncodingException.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/JsonEncodingException.php
new file mode 100644
index 000000000..5878b0f7b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/JsonEncodingException.php
@@ -0,0 +1,35 @@
+getKey().'] to JSON: '.$message);
+ }
+
+ /**
+ * Create a new JSON encoding exception for an attribute.
+ *
+ * @param mixed $model
+ * @param mixed $key
+ * @param string $message
+ * @return static
+ */
+ public static function forAttribute($model, $key, $message)
+ {
+ $class = get_class($model);
+
+ return new static("Unable to encode attribute [{$key}] for model [{$class}] to JSON: {$message}.");
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/MassAssignmentException.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/MassAssignmentException.php
new file mode 100644
index 000000000..7c81aae50
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/MassAssignmentException.php
@@ -0,0 +1,10 @@
+bootIfNotBooted();
+
+ $this->syncOriginal();
+
+ $this->fill($attributes);
+ }
+
+ /**
+ * Check if the model needs to be booted and if so, do it.
+ *
+ * @return void
+ */
+ protected function bootIfNotBooted()
+ {
+ if (! isset(static::$booted[static::class])) {
+ static::$booted[static::class] = true;
+
+ $this->fireModelEvent('booting', false);
+
+ static::boot();
+
+ $this->fireModelEvent('booted', false);
+ }
+ }
+
+ /**
+ * The "booting" method of the model.
+ *
+ * @return void
+ */
+ protected static function boot()
+ {
+ static::bootTraits();
+ }
+
+ /**
+ * Boot all of the bootable traits on the model.
+ *
+ * @return void
+ */
+ protected static function bootTraits()
+ {
+ $class = static::class;
+
+ foreach (class_uses_recursive($class) as $trait) {
+ if (method_exists($class, $method = 'boot'.class_basename($trait))) {
+ forward_static_call([$class, $method]);
+ }
+ }
+ }
+
+ /**
+ * Clear the list of booted models so they will be re-booted.
+ *
+ * @return void
+ */
+ public static function clearBootedModels()
+ {
+ static::$booted = [];
+
+ static::$globalScopes = [];
+ }
+
+ /**
+ * Fill the model with an array of attributes.
+ *
+ * @param array $attributes
+ * @return $this
+ *
+ * @throws \Illuminate\Database\Eloquent\MassAssignmentException
+ */
+ public function fill(array $attributes)
+ {
+ $totallyGuarded = $this->totallyGuarded();
+
+ foreach ($this->fillableFromArray($attributes) as $key => $value) {
+ $key = $this->removeTableFromKey($key);
+
+ // The developers may choose to place some attributes in the "fillable" array
+ // which means only those attributes may be set through mass assignment to
+ // the model, and all others will just get ignored for security reasons.
+ if ($this->isFillable($key)) {
+ $this->setAttribute($key, $value);
+ } elseif ($totallyGuarded) {
+ throw new MassAssignmentException($key);
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Fill the model with an array of attributes. Force mass assignment.
+ *
+ * @param array $attributes
+ * @return $this
+ */
+ public function forceFill(array $attributes)
+ {
+ return static::unguarded(function () use ($attributes) {
+ return $this->fill($attributes);
+ });
+ }
+
+ /**
+ * Remove the table name from a given key.
+ *
+ * @param string $key
+ * @return string
+ */
+ protected function removeTableFromKey($key)
+ {
+ return Str::contains($key, '.') ? last(explode('.', $key)) : $key;
+ }
+
+ /**
+ * Create a new instance of the given model.
+ *
+ * @param array $attributes
+ * @param bool $exists
+ * @return static
+ */
+ public function newInstance($attributes = [], $exists = false)
+ {
+ // This method just provides a convenient way for us to generate fresh model
+ // instances of this current model. It is particularly useful during the
+ // hydration of new objects via the Eloquent query builder instances.
+ $model = new static((array) $attributes);
+
+ $model->exists = $exists;
+
+ $model->setConnection(
+ $this->getConnectionName()
+ );
+
+ return $model;
+ }
+
+ /**
+ * Create a new model instance that is existing.
+ *
+ * @param array $attributes
+ * @param string|null $connection
+ * @return static
+ */
+ public function newFromBuilder($attributes = [], $connection = null)
+ {
+ $model = $this->newInstance([], true);
+
+ $model->setRawAttributes((array) $attributes, true);
+
+ $model->setConnection($connection ?: $this->getConnectionName());
+
+ return $model;
+ }
+
+ /**
+ * Begin querying the model on a given connection.
+ *
+ * @param string|null $connection
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public static function on($connection = null)
+ {
+ // First we will just create a fresh instance of this model, and then we can
+ // set the connection on the model so that it is be used for the queries
+ // we execute, as well as being set on each relationship we retrieve.
+ $instance = new static;
+
+ $instance->setConnection($connection);
+
+ return $instance->newQuery();
+ }
+
+ /**
+ * Begin querying the model on the write connection.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public static function onWriteConnection()
+ {
+ $instance = new static;
+
+ return $instance->newQuery()->useWritePdo();
+ }
+
+ /**
+ * Get all of the models from the database.
+ *
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Collection|static[]
+ */
+ public static function all($columns = ['*'])
+ {
+ return (new static)->newQuery()->get(
+ is_array($columns) ? $columns : func_get_args()
+ );
+ }
+
+ /**
+ * Begin querying a model with eager loading.
+ *
+ * @param array|string $relations
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public static function with($relations)
+ {
+ return (new static)->newQuery()->with(
+ is_string($relations) ? func_get_args() : $relations
+ );
+ }
+
+ /**
+ * Eager load relations on the model.
+ *
+ * @param array|string $relations
+ * @return $this
+ */
+ public function load($relations)
+ {
+ $query = $this->newQuery()->with(
+ is_string($relations) ? func_get_args() : $relations
+ );
+
+ $query->eagerLoadRelations([$this]);
+
+ return $this;
+ }
+
+ /**
+ * Increment a column's value by a given amount.
+ *
+ * @param string $column
+ * @param int $amount
+ * @param array $extra
+ * @return int
+ */
+ protected function increment($column, $amount = 1, array $extra = [])
+ {
+ return $this->incrementOrDecrement($column, $amount, $extra, 'increment');
+ }
+
+ /**
+ * Decrement a column's value by a given amount.
+ *
+ * @param string $column
+ * @param int $amount
+ * @param array $extra
+ * @return int
+ */
+ protected function decrement($column, $amount = 1, array $extra = [])
+ {
+ return $this->incrementOrDecrement($column, $amount, $extra, 'decrement');
+ }
+
+ /**
+ * Run the increment or decrement method on the model.
+ *
+ * @param string $column
+ * @param int $amount
+ * @param array $extra
+ * @param string $method
+ * @return int
+ */
+ protected function incrementOrDecrement($column, $amount, $extra, $method)
+ {
+ $query = $this->newQuery();
+
+ if (! $this->exists) {
+ return $query->{$method}($column, $amount, $extra);
+ }
+
+ $this->incrementOrDecrementAttributeValue($column, $amount, $extra, $method);
+
+ return $query->where(
+ $this->getKeyName(), $this->getKey()
+ )->{$method}($column, $amount, $extra);
+ }
+
+ /**
+ * Increment the underlying attribute value and sync with original.
+ *
+ * @param string $column
+ * @param int $amount
+ * @param array $extra
+ * @param string $method
+ * @return void
+ */
+ protected function incrementOrDecrementAttributeValue($column, $amount, $extra, $method)
+ {
+ $this->{$column} = $this->{$column} + ($method == 'increment' ? $amount : $amount * -1);
+
+ $this->forceFill($extra);
+
+ $this->syncOriginalAttribute($column);
+ }
+
+ /**
+ * Update the model in the database.
+ *
+ * @param array $attributes
+ * @param array $options
+ * @return bool
+ */
+ public function update(array $attributes = [], array $options = [])
+ {
+ if (! $this->exists) {
+ return false;
+ }
+
+ return $this->fill($attributes)->save($options);
+ }
+
+ /**
+ * Save the model and all of its relationships.
+ *
+ * @return bool
+ */
+ public function push()
+ {
+ if (! $this->save()) {
+ return false;
+ }
+
+ // To sync all of the relationships to the database, we will simply spin through
+ // the relationships and save each model via this "push" method, which allows
+ // us to recurse into all of these nested relations for the model instance.
+ foreach ($this->relations as $models) {
+ $models = $models instanceof Collection
+ ? $models->all() : [$models];
+
+ foreach (array_filter($models) as $model) {
+ if (! $model->push()) {
+ return false;
+ }
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Save the model to the database.
+ *
+ * @param array $options
+ * @return bool
+ */
+ public function save(array $options = [])
+ {
+ $query = $this->newQueryWithoutScopes();
+
+ // If the "saving" event returns false we'll bail out of the save and return
+ // false, indicating that the save failed. This provides a chance for any
+ // listeners to cancel save operations if validations fail or whatever.
+ if ($this->fireModelEvent('saving') === false) {
+ return false;
+ }
+
+ // If the model already exists in the database we can just update our record
+ // that is already in this database using the current IDs in this "where"
+ // clause to only update this model. Otherwise, we'll just insert them.
+ if ($this->exists) {
+ $saved = $this->isDirty() ?
+ $this->performUpdate($query) : true;
+ }
+
+ // If the model is brand new, we'll insert it into our database and set the
+ // ID attribute on the model to the value of the newly inserted row's ID
+ // which is typically an auto-increment value managed by the database.
+ else {
+ $saved = $this->performInsert($query);
+ }
+
+ // If the model is successfully saved, we need to do a few more things once
+ // that is done. We will call the "saved" method here to run any actions
+ // we need to happen after a model gets successfully saved right here.
+ if ($saved) {
+ $this->finishSave($options);
+ }
+
+ return $saved;
+ }
+
+ /**
+ * Save the model to the database using transaction.
+ *
+ * @param array $options
+ * @return bool
+ *
+ * @throws \Throwable
+ */
+ public function saveOrFail(array $options = [])
+ {
+ return $this->getConnection()->transaction(function () use ($options) {
+ return $this->save($options);
+ });
+ }
+
+ /**
+ * Perform any actions that are necessary after the model is saved.
+ *
+ * @param array $options
+ * @return void
+ */
+ protected function finishSave(array $options)
+ {
+ $this->fireModelEvent('saved', false);
+
+ $this->syncOriginal();
+
+ if (Arr::get($options, 'touch', true)) {
+ $this->touchOwners();
+ }
+ }
+
+ /**
+ * Perform a model update operation.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @return bool
+ */
+ protected function performUpdate(Builder $query)
+ {
+ // If the updating event returns false, we will cancel the update operation so
+ // developers can hook Validation systems into their models and cancel this
+ // operation if the model does not pass validation. Otherwise, we update.
+ if ($this->fireModelEvent('updating') === false) {
+ return false;
+ }
+
+ // First we need to create a fresh query instance and touch the creation and
+ // update timestamp on the model which are maintained by us for developer
+ // convenience. Then we will just continue saving the model instances.
+ if ($this->usesTimestamps()) {
+ $this->updateTimestamps();
+ }
+
+ // Once we have run the update operation, we will fire the "updated" event for
+ // this model instance. This will allow developers to hook into these after
+ // models are updated, giving them a chance to do any special processing.
+ $dirty = $this->getDirty();
+
+ if (count($dirty) > 0) {
+ $this->setKeysForSaveQuery($query)->update($dirty);
+
+ $this->fireModelEvent('updated', false);
+ }
+
+ return true;
+ }
+
+ /**
+ * Set the keys for a save update query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ protected function setKeysForSaveQuery(Builder $query)
+ {
+ $query->where($this->getKeyName(), '=', $this->getKeyForSaveQuery());
+
+ return $query;
+ }
+
+ /**
+ * Get the primary key value for a save query.
+ *
+ * @return mixed
+ */
+ protected function getKeyForSaveQuery()
+ {
+ return isset($this->original[$this->getKeyName()])
+ ? $this->original[$this->getKeyName()]
+ : $this->getAttribute($this->getKeyName());
+ }
+
+ /**
+ * Perform a model insert operation.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @return bool
+ */
+ protected function performInsert(Builder $query)
+ {
+ if ($this->fireModelEvent('creating') === false) {
+ return false;
+ }
+
+ // First we'll need to create a fresh query instance and touch the creation and
+ // update timestamps on this model, which are maintained by us for developer
+ // convenience. After, we will just continue saving these model instances.
+ if ($this->usesTimestamps()) {
+ $this->updateTimestamps();
+ }
+
+ // If the model has an incrementing key, we can use the "insertGetId" method on
+ // the query builder, which will give us back the final inserted ID for this
+ // table from the database. Not all tables have to be incrementing though.
+ $attributes = $this->attributes;
+
+ if ($this->getIncrementing()) {
+ $this->insertAndSetId($query, $attributes);
+ }
+
+ // If the table isn't incrementing we'll simply insert these attributes as they
+ // are. These attribute arrays must contain an "id" column previously placed
+ // there by the developer as the manually determined key for these models.
+ else {
+ if (empty($attributes)) {
+ return true;
+ }
+
+ $query->insert($attributes);
+ }
+
+ // We will go ahead and set the exists property to true, so that it is set when
+ // the created event is fired, just in case the developer tries to update it
+ // during the event. This will allow them to do so and run an update here.
+ $this->exists = true;
+
+ $this->wasRecentlyCreated = true;
+
+ $this->fireModelEvent('created', false);
+
+ return true;
+ }
+
+ /**
+ * Insert the given attributes and set the ID on the model.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param array $attributes
+ * @return void
+ */
+ protected function insertAndSetId(Builder $query, $attributes)
+ {
+ $id = $query->insertGetId($attributes, $keyName = $this->getKeyName());
+
+ $this->setAttribute($keyName, $id);
+ }
+
+ /**
+ * Destroy the models for the given IDs.
+ *
+ * @param array|int $ids
+ * @return int
+ */
+ public static function destroy($ids)
+ {
+ // We'll initialize a count here so we will return the total number of deletes
+ // for the operation. The developers can then check this number as a boolean
+ // type value or get this total count of records deleted for logging, etc.
+ $count = 0;
+
+ $ids = is_array($ids) ? $ids : func_get_args();
+
+ // We will actually pull the models from the database table and call delete on
+ // each of them individually so that their events get fired properly with a
+ // correct set of attributes in case the developers wants to check these.
+ $key = with($instance = new static)->getKeyName();
+
+ foreach ($instance->whereIn($key, $ids)->get() as $model) {
+ if ($model->delete()) {
+ $count++;
+ }
+ }
+
+ return $count;
+ }
+
+ /**
+ * Delete the model from the database.
+ *
+ * @return bool|null
+ *
+ * @throws \Exception
+ */
+ public function delete()
+ {
+ if (is_null($this->getKeyName())) {
+ throw new Exception('No primary key defined on model.');
+ }
+
+ // If the model doesn't exist, there is nothing to delete so we'll just return
+ // immediately and not do anything else. Otherwise, we will continue with a
+ // deletion process on the model, firing the proper events, and so forth.
+ if (! $this->exists) {
+ return;
+ }
+
+ if ($this->fireModelEvent('deleting') === false) {
+ return false;
+ }
+
+ // Here, we'll touch the owning models, verifying these timestamps get updated
+ // for the models. This will allow any caching to get broken on the parents
+ // by the timestamp. Then we will go ahead and delete the model instance.
+ $this->touchOwners();
+
+ $this->performDeleteOnModel();
+
+ $this->exists = false;
+
+ // Once the model has been deleted, we will fire off the deleted event so that
+ // the developers may hook into post-delete operations. We will then return
+ // a boolean true as the delete is presumably successful on the database.
+ $this->fireModelEvent('deleted', false);
+
+ return true;
+ }
+
+ /**
+ * Force a hard delete on a soft deleted model.
+ *
+ * This method protects developers from running forceDelete when trait is missing.
+ *
+ * @return bool|null
+ */
+ public function forceDelete()
+ {
+ return $this->delete();
+ }
+
+ /**
+ * Perform the actual delete query on this model instance.
+ *
+ * @return void
+ */
+ protected function performDeleteOnModel()
+ {
+ $this->setKeysForSaveQuery($this->newQueryWithoutScopes())->delete();
+ }
+
+ /**
+ * Begin querying the model.
+ *
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public static function query()
+ {
+ return (new static)->newQuery();
+ }
+
+ /**
+ * Get a new query builder for the model's table.
+ *
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function newQuery()
+ {
+ $builder = $this->newQueryWithoutScopes();
+
+ foreach ($this->getGlobalScopes() as $identifier => $scope) {
+ $builder->withGlobalScope($identifier, $scope);
+ }
+
+ return $builder;
+ }
+
+ /**
+ * Get a new query builder that doesn't have any global scopes.
+ *
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function newQueryWithoutScopes()
+ {
+ $builder = $this->newEloquentBuilder($this->newBaseQueryBuilder());
+
+ // Once we have the query builders, we will set the model instances so the
+ // builder can easily access any information it may need from the model
+ // while it is constructing and executing various queries against it.
+ return $builder->setModel($this)
+ ->with($this->with)
+ ->withCount($this->withCount);
+ }
+
+ /**
+ * Get a new query instance without a given scope.
+ *
+ * @param \Illuminate\Database\Eloquent\Scope|string $scope
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function newQueryWithoutScope($scope)
+ {
+ $builder = $this->newQuery();
+
+ return $builder->withoutGlobalScope($scope);
+ }
+
+ /**
+ * Create a new Eloquent query builder for the model.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return \Illuminate\Database\Eloquent\Builder|static
+ */
+ public function newEloquentBuilder($query)
+ {
+ return new Builder($query);
+ }
+
+ /**
+ * Get a new query builder instance for the connection.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ protected function newBaseQueryBuilder()
+ {
+ $connection = $this->getConnection();
+
+ return new QueryBuilder(
+ $connection, $connection->getQueryGrammar(), $connection->getPostProcessor()
+ );
+ }
+
+ /**
+ * Create a new Eloquent Collection instance.
+ *
+ * @param array $models
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ public function newCollection(array $models = [])
+ {
+ return new Collection($models);
+ }
+
+ /**
+ * Create a new pivot model instance.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $parent
+ * @param array $attributes
+ * @param string $table
+ * @param bool $exists
+ * @param string|null $using
+ * @return \Illuminate\Database\Eloquent\Relations\Pivot
+ */
+ public function newPivot(Model $parent, array $attributes, $table, $exists, $using = null)
+ {
+ return $using ? $using::fromRawAttributes($parent, $attributes, $table, $exists)
+ : new Pivot($parent, $attributes, $table, $exists);
+ }
+
+ /**
+ * Convert the model instance to an array.
+ *
+ * @return array
+ */
+ public function toArray()
+ {
+ return array_merge($this->attributesToArray(), $this->relationsToArray());
+ }
+
+ /**
+ * Convert the model instance to JSON.
+ *
+ * @param int $options
+ * @return string
+ *
+ * @throws \Illuminate\Database\Eloquent\JsonEncodingException
+ */
+ public function toJson($options = 0)
+ {
+ $json = json_encode($this->jsonSerialize(), $options);
+
+ if (JSON_ERROR_NONE !== json_last_error()) {
+ throw JsonEncodingException::forModel($this, json_last_error_msg());
+ }
+
+ return $json;
+ }
+
+ /**
+ * Convert the object into something JSON serializable.
+ *
+ * @return array
+ */
+ public function jsonSerialize()
+ {
+ return $this->toArray();
+ }
+
+ /**
+ * Reload a fresh model instance from the database.
+ *
+ * @param array|string $with
+ * @return static|null
+ */
+ public function fresh($with = [])
+ {
+ if (! $this->exists) {
+ return;
+ }
+
+ return static::newQueryWithoutScopes()
+ ->with(is_string($with) ? func_get_args() : $with)
+ ->where($this->getKeyName(), $this->getKey())
+ ->first();
+ }
+
+ /**
+ * Reload the current model instance with fresh attributes from the database.
+ *
+ * @return $this
+ */
+ public function refresh()
+ {
+ if (! $this->exists) {
+ return $this;
+ }
+
+ $this->load(array_keys($this->relations));
+
+ $this->setRawAttributes(static::findOrFail($this->getKey())->attributes);
+
+ return $this;
+ }
+
+ /**
+ * Clone the model into a new, non-existing instance.
+ *
+ * @param array|null $except
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function replicate(array $except = null)
+ {
+ $defaults = [
+ $this->getKeyName(),
+ $this->getCreatedAtColumn(),
+ $this->getUpdatedAtColumn(),
+ ];
+
+ $attributes = Arr::except(
+ $this->attributes, $except ? array_unique(array_merge($except, $defaults)) : $defaults
+ );
+
+ return tap(new static, function ($instance) use ($attributes) {
+ $instance->setRawAttributes($attributes);
+
+ $instance->setRelations($this->relations);
+ });
+ }
+
+ /**
+ * Determine if two models have the same ID and belong to the same table.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @return bool
+ */
+ public function is(Model $model)
+ {
+ return $this->getKey() === $model->getKey() &&
+ $this->getTable() === $model->getTable() &&
+ $this->getConnectionName() === $model->getConnectionName();
+ }
+
+ /**
+ * Determine if two models are not the same.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @return bool
+ */
+ public function isNot(Model $model)
+ {
+ return ! $this->is($model);
+ }
+
+ /**
+ * Get the database connection for the model.
+ *
+ * @return \Illuminate\Database\Connection
+ */
+ public function getConnection()
+ {
+ return static::resolveConnection($this->getConnectionName());
+ }
+
+ /**
+ * Get the current connection name for the model.
+ *
+ * @return string
+ */
+ public function getConnectionName()
+ {
+ return $this->connection;
+ }
+
+ /**
+ * Set the connection associated with the model.
+ *
+ * @param string $name
+ * @return $this
+ */
+ public function setConnection($name)
+ {
+ $this->connection = $name;
+
+ return $this;
+ }
+
+ /**
+ * Resolve a connection instance.
+ *
+ * @param string|null $connection
+ * @return \Illuminate\Database\Connection
+ */
+ public static function resolveConnection($connection = null)
+ {
+ return static::$resolver->connection($connection);
+ }
+
+ /**
+ * Get the connection resolver instance.
+ *
+ * @return \Illuminate\Database\ConnectionResolverInterface
+ */
+ public static function getConnectionResolver()
+ {
+ return static::$resolver;
+ }
+
+ /**
+ * Set the connection resolver instance.
+ *
+ * @param \Illuminate\Database\ConnectionResolverInterface $resolver
+ * @return void
+ */
+ public static function setConnectionResolver(Resolver $resolver)
+ {
+ static::$resolver = $resolver;
+ }
+
+ /**
+ * Unset the connection resolver for models.
+ *
+ * @return void
+ */
+ public static function unsetConnectionResolver()
+ {
+ static::$resolver = null;
+ }
+
+ /**
+ * Get the table associated with the model.
+ *
+ * @return string
+ */
+ public function getTable()
+ {
+ if (! isset($this->table)) {
+ return str_replace('\\', '', Str::snake(Str::plural(class_basename($this))));
+ }
+
+ return $this->table;
+ }
+
+ /**
+ * Set the table associated with the model.
+ *
+ * @param string $table
+ * @return $this
+ */
+ public function setTable($table)
+ {
+ $this->table = $table;
+
+ return $this;
+ }
+
+ /**
+ * Get the primary key for the model.
+ *
+ * @return string
+ */
+ public function getKeyName()
+ {
+ return $this->primaryKey;
+ }
+
+ /**
+ * Set the primary key for the model.
+ *
+ * @param string $key
+ * @return $this
+ */
+ public function setKeyName($key)
+ {
+ $this->primaryKey = $key;
+
+ return $this;
+ }
+
+ /**
+ * Get the table qualified key name.
+ *
+ * @return string
+ */
+ public function getQualifiedKeyName()
+ {
+ return $this->getTable().'.'.$this->getKeyName();
+ }
+
+ /**
+ * Get the auto-incrementing key type.
+ *
+ * @return string
+ */
+ public function getKeyType()
+ {
+ return $this->keyType;
+ }
+
+ /**
+ * Set the data type for the primary key.
+ *
+ * @param string $type
+ * @return $this
+ */
+ public function setKeyType($type)
+ {
+ $this->keyType = $type;
+
+ return $this;
+ }
+
+ /**
+ * Get the value indicating whether the IDs are incrementing.
+ *
+ * @return bool
+ */
+ public function getIncrementing()
+ {
+ return $this->incrementing;
+ }
+
+ /**
+ * Set whether IDs are incrementing.
+ *
+ * @param bool $value
+ * @return $this
+ */
+ public function setIncrementing($value)
+ {
+ $this->incrementing = $value;
+
+ return $this;
+ }
+
+ /**
+ * Get the value of the model's primary key.
+ *
+ * @return mixed
+ */
+ public function getKey()
+ {
+ return $this->getAttribute($this->getKeyName());
+ }
+
+ /**
+ * Get the queueable identity for the entity.
+ *
+ * @return mixed
+ */
+ public function getQueueableId()
+ {
+ return $this->getKey();
+ }
+
+ /**
+ * Get the value of the model's route key.
+ *
+ * @return mixed
+ */
+ public function getRouteKey()
+ {
+ return $this->getAttribute($this->getRouteKeyName());
+ }
+
+ /**
+ * Get the route key for the model.
+ *
+ * @return string
+ */
+ public function getRouteKeyName()
+ {
+ return $this->getKeyName();
+ }
+
+ /**
+ * Get the default foreign key name for the model.
+ *
+ * @return string
+ */
+ public function getForeignKey()
+ {
+ return Str::snake(class_basename($this)).'_'.$this->primaryKey;
+ }
+
+ /**
+ * Get the number of models to return per page.
+ *
+ * @return int
+ */
+ public function getPerPage()
+ {
+ return $this->perPage;
+ }
+
+ /**
+ * Set the number of models to return per page.
+ *
+ * @param int $perPage
+ * @return $this
+ */
+ public function setPerPage($perPage)
+ {
+ $this->perPage = $perPage;
+
+ return $this;
+ }
+
+ /**
+ * Dynamically retrieve attributes on the model.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function __get($key)
+ {
+ return $this->getAttribute($key);
+ }
+
+ /**
+ * Dynamically set attributes on the model.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function __set($key, $value)
+ {
+ $this->setAttribute($key, $value);
+ }
+
+ /**
+ * Determine if the given attribute exists.
+ *
+ * @param mixed $offset
+ * @return bool
+ */
+ public function offsetExists($offset)
+ {
+ return isset($this->$offset);
+ }
+
+ /**
+ * Get the value for a given offset.
+ *
+ * @param mixed $offset
+ * @return mixed
+ */
+ public function offsetGet($offset)
+ {
+ return $this->$offset;
+ }
+
+ /**
+ * Set the value for a given offset.
+ *
+ * @param mixed $offset
+ * @param mixed $value
+ * @return void
+ */
+ public function offsetSet($offset, $value)
+ {
+ $this->$offset = $value;
+ }
+
+ /**
+ * Unset the value for a given offset.
+ *
+ * @param mixed $offset
+ * @return void
+ */
+ public function offsetUnset($offset)
+ {
+ unset($this->$offset);
+ }
+
+ /**
+ * Determine if an attribute or relation exists on the model.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function __isset($key)
+ {
+ return ! is_null($this->getAttribute($key));
+ }
+
+ /**
+ * Unset an attribute on the model.
+ *
+ * @param string $key
+ * @return void
+ */
+ public function __unset($key)
+ {
+ unset($this->attributes[$key], $this->relations[$key]);
+ }
+
+ /**
+ * Handle dynamic method calls into the model.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ if (in_array($method, ['increment', 'decrement'])) {
+ return $this->$method(...$parameters);
+ }
+
+ return $this->newQuery()->$method(...$parameters);
+ }
+
+ /**
+ * Handle dynamic static method calls into the method.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public static function __callStatic($method, $parameters)
+ {
+ return (new static)->$method(...$parameters);
+ }
+
+ /**
+ * Convert the model to its string representation.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->toJson();
+ }
+
+ /**
+ * When a model is being unserialized, check if it needs to be booted.
+ *
+ * @return void
+ */
+ public function __wakeup()
+ {
+ $this->bootIfNotBooted();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/ModelNotFoundException.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/ModelNotFoundException.php
new file mode 100644
index 000000000..a18724d24
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/ModelNotFoundException.php
@@ -0,0 +1,65 @@
+model = $model;
+ $this->ids = array_wrap($ids);
+
+ $this->message = "No query results for model [{$model}]";
+
+ if (count($this->ids) > 0) {
+ $this->message .= ' '.implode(', ', $this->ids);
+ } else {
+ $this->message .= '.';
+ }
+
+ return $this;
+ }
+
+ /**
+ * Get the affected Eloquent model.
+ *
+ * @return string
+ */
+ public function getModel()
+ {
+ return $this->model;
+ }
+
+ /**
+ * Get the affected Eloquent model IDs.
+ *
+ * @return int|array
+ */
+ public function getIds()
+ {
+ return $this->ids;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/QueueEntityResolver.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/QueueEntityResolver.php
new file mode 100644
index 000000000..22fccf245
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/QueueEntityResolver.php
@@ -0,0 +1,29 @@
+find($id);
+
+ if ($instance) {
+ return $instance;
+ }
+
+ throw new EntityNotFoundException($type, $id);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/RelationNotFoundException.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/RelationNotFoundException.php
new file mode 100644
index 000000000..5026ac9c8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/RelationNotFoundException.php
@@ -0,0 +1,22 @@
+ownerKey = $ownerKey;
+ $this->relation = $relation;
+ $this->foreignKey = $foreignKey;
+
+ // In the underlying base relationship class, this variable is referred to as
+ // the "parent" since most relationships are not inversed. But, since this
+ // one is we will create a "child" variable for much better readability.
+ $this->child = $child;
+
+ parent::__construct($query, $child);
+ }
+
+ /**
+ * Get the results of the relationship.
+ *
+ * @return mixed
+ */
+ public function getResults()
+ {
+ return $this->query->first() ?: $this->getDefaultFor($this->parent);
+ }
+
+ /**
+ * Set the base constraints on the relation query.
+ *
+ * @return void
+ */
+ public function addConstraints()
+ {
+ if (static::$constraints) {
+ // For belongs to relationships, which are essentially the inverse of has one
+ // or has many relationships, we need to actually query on the primary key
+ // of the related models matching on the foreign key that's on a parent.
+ $table = $this->related->getTable();
+
+ $this->query->where($table.'.'.$this->ownerKey, '=', $this->child->{$this->foreignKey});
+ }
+ }
+
+ /**
+ * Set the constraints for an eager load of the relation.
+ *
+ * @param array $models
+ * @return void
+ */
+ public function addEagerConstraints(array $models)
+ {
+ // We'll grab the primary key name of the related models since it could be set to
+ // a non-standard name and not "id". We will then construct the constraint for
+ // our eagerly loading query so it returns the proper models from execution.
+ $key = $this->related->getTable().'.'.$this->ownerKey;
+
+ $this->query->whereIn($key, $this->getEagerModelKeys($models));
+ }
+
+ /**
+ * Gather the keys from an array of related models.
+ *
+ * @param array $models
+ * @return array
+ */
+ protected function getEagerModelKeys(array $models)
+ {
+ $keys = [];
+
+ // First we need to gather all of the keys from the parent models so we know what
+ // to query for via the eager loading query. We will add them to an array then
+ // execute a "where in" statement to gather up all of those related records.
+ foreach ($models as $model) {
+ if (! is_null($value = $model->{$this->foreignKey})) {
+ $keys[] = $value;
+ }
+ }
+
+ // If there are no keys that were not null we will just return an array with null
+ // so this query wont fail plus returns zero results, which should be what the
+ // developer expects to happen in this situation. Otherwise we'll sort them.
+ if (count($keys) === 0) {
+ return [null];
+ }
+
+ sort($keys);
+
+ return array_values(array_unique($keys));
+ }
+
+ /**
+ * Initialize the relation on a set of models.
+ *
+ * @param array $models
+ * @param string $relation
+ * @return array
+ */
+ public function initRelation(array $models, $relation)
+ {
+ foreach ($models as $model) {
+ $model->setRelation($relation, $this->getDefaultFor($model));
+ }
+
+ return $models;
+ }
+
+ /**
+ * Match the eagerly loaded results to their parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ public function match(array $models, Collection $results, $relation)
+ {
+ $foreign = $this->foreignKey;
+
+ $owner = $this->ownerKey;
+
+ // First we will get to build a dictionary of the child models by their primary
+ // key of the relationship, then we can easily match the children back onto
+ // the parents using that dictionary and the primary key of the children.
+ $dictionary = [];
+
+ foreach ($results as $result) {
+ $dictionary[$result->getAttribute($owner)] = $result;
+ }
+
+ // Once we have the dictionary constructed, we can loop through all the parents
+ // and match back onto their children using these keys of the dictionary and
+ // the primary key of the children to map them onto the correct instances.
+ foreach ($models as $model) {
+ if (isset($dictionary[$model->{$foreign}])) {
+ $model->setRelation($relation, $dictionary[$model->{$foreign}]);
+ }
+ }
+
+ return $models;
+ }
+
+ /**
+ * Update the parent model on the relationship.
+ *
+ * @param array $attributes
+ * @return mixed
+ */
+ public function update(array $attributes)
+ {
+ return $this->getResults()->fill($attributes)->save();
+ }
+
+ /**
+ * Associate the model instance to the given parent.
+ *
+ * @param \Illuminate\Database\Eloquent\Model|int|string $model
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function associate($model)
+ {
+ $ownerKey = $model instanceof Model ? $model->getAttribute($this->ownerKey) : $model;
+
+ $this->child->setAttribute($this->foreignKey, $ownerKey);
+
+ if ($model instanceof Model) {
+ $this->child->setRelation($this->relation, $model);
+ }
+
+ return $this->child;
+ }
+
+ /**
+ * Dissociate previously associated model from the given parent.
+ *
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function dissociate()
+ {
+ $this->child->setAttribute($this->foreignKey, null);
+
+ return $this->child->setRelation($this->relation, null);
+ }
+
+ /**
+ * Add the constraints for a relationship query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceQuery(Builder $query, Builder $parentQuery, $columns = ['*'])
+ {
+ if ($parentQuery->getQuery()->from == $query->getQuery()->from) {
+ return $this->getRelationExistenceQueryForSelfRelation($query, $parentQuery, $columns);
+ }
+
+ return $query->select($columns)->whereColumn(
+ $this->getQualifiedForeignKey(), '=', $query->getModel()->getTable().'.'.$this->ownerKey
+ );
+ }
+
+ /**
+ * Add the constraints for a relationship query on the same table.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceQueryForSelfRelation(Builder $query, Builder $parentQuery, $columns = ['*'])
+ {
+ $query->select($columns)->from(
+ $query->getModel()->getTable().' as '.$hash = $this->getRelationCountHash()
+ );
+
+ $query->getModel()->setTable($hash);
+
+ return $query->whereColumn(
+ $hash.'.'.$query->getModel()->getKeyName(), '=', $this->getQualifiedForeignKey()
+ );
+ }
+
+ /**
+ * Get a relationship join table hash.
+ *
+ * @return string
+ */
+ public function getRelationCountHash()
+ {
+ return 'laravel_reserved_'.static::$selfJoinCount++;
+ }
+
+ /**
+ * Determine if the related model has an auto-incrementing ID.
+ *
+ * @return bool
+ */
+ protected function relationHasIncrementingId()
+ {
+ return $this->related->getIncrementing() &&
+ $this->related->getKeyType() === 'int';
+ }
+
+ /**
+ * Make a new related instance for the given model.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $parent
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ protected function newRelatedInstanceFor(Model $parent)
+ {
+ return $this->related->newInstance();
+ }
+
+ /**
+ * Get the foreign key of the relationship.
+ *
+ * @return string
+ */
+ public function getForeignKey()
+ {
+ return $this->foreignKey;
+ }
+
+ /**
+ * Get the fully qualified foreign key of the relationship.
+ *
+ * @return string
+ */
+ public function getQualifiedForeignKey()
+ {
+ return $this->child->getTable().'.'.$this->foreignKey;
+ }
+
+ /**
+ * Get the associated key of the relationship.
+ *
+ * @return string
+ */
+ public function getOwnerKey()
+ {
+ return $this->ownerKey;
+ }
+
+ /**
+ * Get the fully qualified associated key of the relationship.
+ *
+ * @return string
+ */
+ public function getQualifiedOwnerKeyName()
+ {
+ return $this->related->getTable().'.'.$this->ownerKey;
+ }
+
+ /**
+ * Get the name of the relationship.
+ *
+ * @return string
+ */
+ public function getRelation()
+ {
+ return $this->relation;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsToMany.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsToMany.php
new file mode 100644
index 000000000..4c9fac593
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/BelongsToMany.php
@@ -0,0 +1,911 @@
+table = $table;
+ $this->relatedKey = $relatedKey;
+ $this->foreignKey = $foreignKey;
+ $this->relationName = $relationName;
+
+ parent::__construct($query, $parent);
+ }
+
+ /**
+ * Set the base constraints on the relation query.
+ *
+ * @return void
+ */
+ public function addConstraints()
+ {
+ $this->performJoin();
+
+ if (static::$constraints) {
+ $this->addWhereConstraints();
+ }
+ }
+
+ /**
+ * Set the join clause for the relation query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder|null $query
+ * @return $this
+ */
+ protected function performJoin($query = null)
+ {
+ $query = $query ?: $this->query;
+
+ // We need to join to the intermediate table on the related model's primary
+ // key column with the intermediate table's foreign key for the related
+ // model instance. Then we can set the "where" for the parent models.
+ $baseTable = $this->related->getTable();
+
+ $key = $baseTable.'.'.$this->related->getKeyName();
+
+ $query->join($this->table, $key, '=', $this->getQualifiedRelatedKeyName());
+
+ return $this;
+ }
+
+ /**
+ * Set the where clause for the relation query.
+ *
+ * @return $this
+ */
+ protected function addWhereConstraints()
+ {
+ $this->query->where(
+ $this->getQualifiedForeignKeyName(), '=', $this->parent->getKey()
+ );
+
+ return $this;
+ }
+
+ /**
+ * Set the constraints for an eager load of the relation.
+ *
+ * @param array $models
+ * @return void
+ */
+ public function addEagerConstraints(array $models)
+ {
+ $this->query->whereIn($this->getQualifiedForeignKeyName(), $this->getKeys($models));
+ }
+
+ /**
+ * Initialize the relation on a set of models.
+ *
+ * @param array $models
+ * @param string $relation
+ * @return array
+ */
+ public function initRelation(array $models, $relation)
+ {
+ foreach ($models as $model) {
+ $model->setRelation($relation, $this->related->newCollection());
+ }
+
+ return $models;
+ }
+
+ /**
+ * Match the eagerly loaded results to their parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ public function match(array $models, Collection $results, $relation)
+ {
+ $dictionary = $this->buildDictionary($results);
+
+ // Once we have an array dictionary of child objects we can easily match the
+ // children back to their parent using the dictionary and the keys on the
+ // the parent models. Then we will return the hydrated models back out.
+ foreach ($models as $model) {
+ if (isset($dictionary[$key = $model->getKey()])) {
+ $model->setRelation(
+ $relation, $this->related->newCollection($dictionary[$key])
+ );
+ }
+ }
+
+ return $models;
+ }
+
+ /**
+ * Build model dictionary keyed by the relation's foreign key.
+ *
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @return array
+ */
+ protected function buildDictionary(Collection $results)
+ {
+ // First we will build a dictionary of child models keyed by the foreign key
+ // of the relation so that we will easily and quickly match them to their
+ // parents without having a possibly slow inner loops for every models.
+ $dictionary = [];
+
+ foreach ($results as $result) {
+ $dictionary[$result->pivot->{$this->foreignKey}][] = $result;
+ }
+
+ return $dictionary;
+ }
+
+ /**
+ * Specify the custom pivot model to use for the relationship.
+ *
+ * @param string $class
+ * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
+ */
+ public function using($class)
+ {
+ $this->using = $class;
+
+ return $this;
+ }
+
+ /**
+ * Set a where clause for a pivot table column.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param mixed $value
+ * @param string $boolean
+ * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
+ */
+ public function wherePivot($column, $operator = null, $value = null, $boolean = 'and')
+ {
+ $this->pivotWheres[] = func_get_args();
+
+ return $this->where($this->table.'.'.$column, $operator, $value, $boolean);
+ }
+
+ /**
+ * Set a "where in" clause for a pivot table column.
+ *
+ * @param string $column
+ * @param mixed $values
+ * @param string $boolean
+ * @param bool $not
+ * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
+ */
+ public function wherePivotIn($column, $values, $boolean = 'and', $not = false)
+ {
+ $this->pivotWhereIns[] = func_get_args();
+
+ return $this->whereIn($this->table.'.'.$column, $values, $boolean, $not);
+ }
+
+ /**
+ * Set an "or where" clause for a pivot table column.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param mixed $value
+ * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
+ */
+ public function orWherePivot($column, $operator = null, $value = null)
+ {
+ return $this->wherePivot($column, $operator, $value, 'or');
+ }
+
+ /**
+ * Set an "or where in" clause for a pivot table column.
+ *
+ * @param string $column
+ * @param mixed $values
+ * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
+ */
+ public function orWherePivotIn($column, $values)
+ {
+ return $this->wherePivotIn($column, $values, 'or');
+ }
+
+ /**
+ * Find a related model by its primary key or return new instance of the related model.
+ *
+ * @param mixed $id
+ * @param array $columns
+ * @return \Illuminate\Support\Collection|\Illuminate\Database\Eloquent\Model
+ */
+ public function findOrNew($id, $columns = ['*'])
+ {
+ if (is_null($instance = $this->find($id, $columns))) {
+ $instance = $this->related->newInstance();
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Get the first related model record matching the attributes or instantiate it.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function firstOrNew(array $attributes)
+ {
+ if (is_null($instance = $this->where($attributes)->first())) {
+ $instance = $this->related->newInstance($attributes);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Get the first related record matching the attributes or create it.
+ *
+ * @param array $attributes
+ * @param array $joining
+ * @param bool $touch
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function firstOrCreate(array $attributes, array $joining = [], $touch = true)
+ {
+ if (is_null($instance = $this->where($attributes)->first())) {
+ $instance = $this->create($attributes, $joining, $touch);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Create or update a related record matching the attributes, and fill it with values.
+ *
+ * @param array $attributes
+ * @param array $values
+ * @param array $joining
+ * @param bool $touch
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function updateOrCreate(array $attributes, array $values = [], array $joining = [], $touch = true)
+ {
+ if (is_null($instance = $this->where($attributes)->first())) {
+ return $this->create($values, $joining, $touch);
+ }
+
+ $instance->fill($values);
+
+ $instance->save(['touch' => false]);
+
+ return $instance;
+ }
+
+ /**
+ * Find a related model by its primary key.
+ *
+ * @param mixed $id
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model|\Illuminate\Database\Eloquent\Collection|null
+ */
+ public function find($id, $columns = ['*'])
+ {
+ return is_array($id) ? $this->findMany($id, $columns) : $this->where(
+ $this->getRelated()->getQualifiedKeyName(), '=', $id
+ )->first($columns);
+ }
+
+ /**
+ * Find multiple related models by their primary keys.
+ *
+ * @param mixed $ids
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ public function findMany($ids, $columns = ['*'])
+ {
+ return empty($ids) ? $this->getRelated()->newCollection() : $this->whereIn(
+ $this->getRelated()->getQualifiedKeyName(), $ids
+ )->get($columns);
+ }
+
+ /**
+ * Find a related model by its primary key or throw an exception.
+ *
+ * @param mixed $id
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model|\Illuminate\Database\Eloquent\Collection
+ *
+ * @throws \Illuminate\Database\Eloquent\ModelNotFoundException
+ */
+ public function findOrFail($id, $columns = ['*'])
+ {
+ $result = $this->find($id, $columns);
+
+ if (is_array($id)) {
+ if (count($result) == count(array_unique($id))) {
+ return $result;
+ }
+ } elseif (! is_null($result)) {
+ return $result;
+ }
+
+ throw (new ModelNotFoundException)->setModel(get_class($this->related));
+ }
+
+ /**
+ * Execute the query and get the first result.
+ *
+ * @param array $columns
+ * @return mixed
+ */
+ public function first($columns = ['*'])
+ {
+ $results = $this->take(1)->get($columns);
+
+ return count($results) > 0 ? $results->first() : null;
+ }
+
+ /**
+ * Execute the query and get the first result or throw an exception.
+ *
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model|static
+ *
+ * @throws \Illuminate\Database\Eloquent\ModelNotFoundException
+ */
+ public function firstOrFail($columns = ['*'])
+ {
+ if (! is_null($model = $this->first($columns))) {
+ return $model;
+ }
+
+ throw (new ModelNotFoundException)->setModel(get_class($this->related));
+ }
+
+ /**
+ * Get the results of the relationship.
+ *
+ * @return mixed
+ */
+ public function getResults()
+ {
+ return $this->get();
+ }
+
+ /**
+ * Execute the query as a "select" statement.
+ *
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ public function get($columns = ['*'])
+ {
+ // First we'll add the proper select columns onto the query so it is run with
+ // the proper columns. Then, we will get the results and hydrate out pivot
+ // models with the result of those columns as a separate model relation.
+ $columns = $this->query->getQuery()->columns ? [] : $columns;
+
+ $builder = $this->query->applyScopes();
+
+ $models = $builder->addSelect(
+ $this->shouldSelect($columns)
+ )->getModels();
+
+ $this->hydratePivotRelation($models);
+
+ // If we actually found models we will also eager load any relationships that
+ // have been specified as needing to be eager loaded. This will solve the
+ // n + 1 query problem for the developer and also increase performance.
+ if (count($models) > 0) {
+ $models = $builder->eagerLoadRelations($models);
+ }
+
+ return $this->related->newCollection($models);
+ }
+
+ /**
+ * Get the select columns for the relation query.
+ *
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
+ */
+ protected function shouldSelect(array $columns = ['*'])
+ {
+ if ($columns == ['*']) {
+ $columns = [$this->related->getTable().'.*'];
+ }
+
+ return array_merge($columns, $this->aliasedPivotColumns());
+ }
+
+ /**
+ * Get the pivot columns for the relation.
+ *
+ * "pivot_" is prefixed ot each column for easy removal later.
+ *
+ * @return array
+ */
+ protected function aliasedPivotColumns()
+ {
+ $defaults = [$this->foreignKey, $this->relatedKey];
+
+ return collect(array_merge($defaults, $this->pivotColumns))->map(function ($column) {
+ return $this->table.'.'.$column.' as pivot_'.$column;
+ })->unique()->all();
+ }
+
+ /**
+ * Get a paginator for the "select" statement.
+ *
+ * @param int $perPage
+ * @param array $columns
+ * @param string $pageName
+ * @param int|null $page
+ * @return \Illuminate\Contracts\Pagination\LengthAwarePaginator
+ */
+ public function paginate($perPage = null, $columns = ['*'], $pageName = 'page', $page = null)
+ {
+ $this->query->addSelect($this->shouldSelect($columns));
+
+ return tap($this->query->paginate($perPage, $columns, $pageName, $page), function ($paginator) {
+ $this->hydratePivotRelation($paginator->items());
+ });
+ }
+
+ /**
+ * Paginate the given query into a simple paginator.
+ *
+ * @param int $perPage
+ * @param array $columns
+ * @param string $pageName
+ * @param int|null $page
+ * @return \Illuminate\Contracts\Pagination\Paginator
+ */
+ public function simplePaginate($perPage = null, $columns = ['*'], $pageName = 'page', $page = null)
+ {
+ $this->query->addSelect($this->shouldSelect($columns));
+
+ return tap($this->query->simplePaginate($perPage, $columns, $pageName, $page), function ($paginator) {
+ $this->hydratePivotRelation($paginator->items());
+ });
+ }
+
+ /**
+ * Chunk the results of the query.
+ *
+ * @param int $count
+ * @param callable $callback
+ * @return bool
+ */
+ public function chunk($count, callable $callback)
+ {
+ $this->query->addSelect($this->shouldSelect());
+
+ return $this->query->chunk($count, function ($results) use ($callback) {
+ $this->hydratePivotRelation($results->all());
+
+ return $callback($results);
+ });
+ }
+
+ /**
+ * Hydrate the pivot table relationship on the models.
+ *
+ * @param array $models
+ * @return void
+ */
+ protected function hydratePivotRelation(array $models)
+ {
+ // To hydrate the pivot relationship, we will just gather the pivot attributes
+ // and create a new Pivot model, which is basically a dynamic model that we
+ // will set the attributes, table, and connections on it so it will work.
+ foreach ($models as $model) {
+ $model->setRelation('pivot', $this->newExistingPivot(
+ $this->migratePivotAttributes($model)
+ ));
+ }
+ }
+
+ /**
+ * Get the pivot attributes from a model.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @return array
+ */
+ protected function migratePivotAttributes(Model $model)
+ {
+ $values = [];
+
+ foreach ($model->getAttributes() as $key => $value) {
+ // To get the pivots attributes we will just take any of the attributes which
+ // begin with "pivot_" and add those to this arrays, as well as unsetting
+ // them from the parent's models since they exist in a different table.
+ if (strpos($key, 'pivot_') === 0) {
+ $values[substr($key, 6)] = $value;
+
+ unset($model->$key);
+ }
+ }
+
+ return $values;
+ }
+
+ /**
+ * If we're touching the parent model, touch.
+ *
+ * @return void
+ */
+ public function touchIfTouching()
+ {
+ if ($this->touchingParent()) {
+ $this->getParent()->touch();
+ }
+
+ if ($this->getParent()->touches($this->relationName)) {
+ $this->touch();
+ }
+ }
+
+ /**
+ * Determine if we should touch the parent on sync.
+ *
+ * @return bool
+ */
+ protected function touchingParent()
+ {
+ return $this->getRelated()->touches($this->guessInverseRelation());
+ }
+
+ /**
+ * Attempt to guess the name of the inverse of the relation.
+ *
+ * @return string
+ */
+ protected function guessInverseRelation()
+ {
+ return Str::camel(Str::plural(class_basename($this->getParent())));
+ }
+
+ /**
+ * Touch all of the related models for the relationship.
+ *
+ * E.g.: Touch all roles associated with this user.
+ *
+ * @return void
+ */
+ public function touch()
+ {
+ $key = $this->getRelated()->getKeyName();
+
+ $columns = [
+ $this->related->getUpdatedAtColumn() => $this->related->freshTimestampString(),
+ ];
+
+ // If we actually have IDs for the relation, we will run the query to update all
+ // the related model's timestamps, to make sure these all reflect the changes
+ // to the parent models. This will help us keep any caching synced up here.
+ if (count($ids = $this->allRelatedIds()) > 0) {
+ $this->getRelated()->newQuery()->whereIn($key, $ids)->update($columns);
+ }
+ }
+
+ /**
+ * Get all of the IDs for the related models.
+ *
+ * @return \Illuminate\Support\Collection
+ */
+ public function allRelatedIds()
+ {
+ $related = $this->getRelated();
+
+ return $this->getQuery()->select(
+ $related->getQualifiedKeyName()
+ )->pluck($related->getKeyName());
+ }
+
+ /**
+ * Save a new model and attach it to the parent model.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @param array $pivotAttributes
+ * @param bool $touch
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function save(Model $model, array $pivotAttributes = [], $touch = true)
+ {
+ $model->save(['touch' => false]);
+
+ $this->attach($model->getKey(), $pivotAttributes, $touch);
+
+ return $model;
+ }
+
+ /**
+ * Save an array of new models and attach them to the parent model.
+ *
+ * @param \Illuminate\Support\Collection|array $models
+ * @param array $pivotAttributes
+ * @return array
+ */
+ public function saveMany($models, array $pivotAttributes = [])
+ {
+ foreach ($models as $key => $model) {
+ $this->save($model, (array) Arr::get($pivotAttributes, $key), false);
+ }
+
+ $this->touchIfTouching();
+
+ return $models;
+ }
+
+ /**
+ * Create a new instance of the related model.
+ *
+ * @param array $attributes
+ * @param array $joining
+ * @param bool $touch
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function create(array $attributes, array $joining = [], $touch = true)
+ {
+ $instance = $this->related->newInstance($attributes);
+
+ // Once we save the related model, we need to attach it to the base model via
+ // through intermediate table so we'll use the existing "attach" method to
+ // accomplish this which will insert the record and any more attributes.
+ $instance->save(['touch' => false]);
+
+ $this->attach($instance->getKey(), $joining, $touch);
+
+ return $instance;
+ }
+
+ /**
+ * Create an array of new instances of the related models.
+ *
+ * @param array $records
+ * @param array $joinings
+ * @return array
+ */
+ public function createMany(array $records, array $joinings = [])
+ {
+ $instances = [];
+
+ foreach ($records as $key => $record) {
+ $instances[] = $this->create($record, (array) Arr::get($joinings, $key), false);
+ }
+
+ $this->touchIfTouching();
+
+ return $instances;
+ }
+
+ /**
+ * Add the constraints for a relationship query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceQuery(Builder $query, Builder $parentQuery, $columns = ['*'])
+ {
+ if ($parentQuery->getQuery()->from == $query->getQuery()->from) {
+ return $this->getRelationExistenceQueryForSelfJoin($query, $parentQuery, $columns);
+ }
+
+ $this->performJoin($query);
+
+ return parent::getRelationExistenceQuery($query, $parentQuery, $columns);
+ }
+
+ /**
+ * Add the constraints for a relationship query on the same table.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceQueryForSelfJoin(Builder $query, Builder $parentQuery, $columns = ['*'])
+ {
+ $query->select($columns);
+
+ $query->from($this->related->getTable().' as '.$hash = $this->getRelationCountHash());
+
+ $this->related->setTable($hash);
+
+ $this->performJoin($query);
+
+ return parent::getRelationExistenceQuery($query, $parentQuery, $columns);
+ }
+
+ /**
+ * Get the key for comparing against the parent key in "has" query.
+ *
+ * @return string
+ */
+ public function getExistenceCompareKey()
+ {
+ return $this->getQualifiedForeignKeyName();
+ }
+
+ /**
+ * Get a relationship join table hash.
+ *
+ * @return string
+ */
+ public function getRelationCountHash()
+ {
+ return 'laravel_reserved_'.static::$selfJoinCount++;
+ }
+
+ /**
+ * Specify that the pivot table has creation and update timestamps.
+ *
+ * @param mixed $createdAt
+ * @param mixed $updatedAt
+ * @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
+ */
+ public function withTimestamps($createdAt = null, $updatedAt = null)
+ {
+ $this->pivotCreatedAt = $createdAt;
+ $this->pivotUpdatedAt = $updatedAt;
+
+ return $this->withPivot($this->createdAt(), $this->updatedAt());
+ }
+
+ /**
+ * Get the name of the "created at" column.
+ *
+ * @return string
+ */
+ public function createdAt()
+ {
+ return $this->pivotCreatedAt ?: $this->parent->getCreatedAtColumn();
+ }
+
+ /**
+ * Get the name of the "updated at" column.
+ *
+ * @return string
+ */
+ public function updatedAt()
+ {
+ return $this->pivotUpdatedAt ?: $this->parent->getUpdatedAtColumn();
+ }
+
+ /**
+ * Get the fully qualified foreign key for the relation.
+ *
+ * @return string
+ */
+ public function getQualifiedForeignKeyName()
+ {
+ return $this->table.'.'.$this->foreignKey;
+ }
+
+ /**
+ * Get the fully qualified "related key" for the relation.
+ *
+ * @return string
+ */
+ public function getQualifiedRelatedKeyName()
+ {
+ return $this->table.'.'.$this->relatedKey;
+ }
+
+ /**
+ * Get the intermediate table for the relationship.
+ *
+ * @return string
+ */
+ public function getTable()
+ {
+ return $this->table;
+ }
+
+ /**
+ * Get the relationship name for the relationship.
+ *
+ * @return string
+ */
+ public function getRelationName()
+ {
+ return $this->relationName;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/InteractsWithPivotTable.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/InteractsWithPivotTable.php
new file mode 100644
index 000000000..9d4c73f2b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/InteractsWithPivotTable.php
@@ -0,0 +1,502 @@
+ [], 'detached' => [],
+ ];
+
+ $records = $this->formatRecordsList($this->parseIds($ids));
+
+ // Next, we will determine which IDs should get removed from the join table by
+ // checking which of the given ID/records is in the list of current records
+ // and removing all of those rows from this "intermediate" joining table.
+ $detach = array_values(array_intersect(
+ $this->newPivotQuery()->pluck($this->relatedKey)->all(),
+ array_keys($records)
+ ));
+
+ if (count($detach) > 0) {
+ $this->detach($detach, false);
+
+ $changes['detached'] = $this->castKeys($detach);
+ }
+
+ // Finally, for all of the records which were not "detached", we'll attach the
+ // records into the intermediate table. Then, we will add those attaches to
+ // this change list and get ready to return these results to the callers.
+ $attach = array_diff_key($records, array_flip($detach));
+
+ if (count($attach) > 0) {
+ $this->attach($attach, [], false);
+
+ $changes['attached'] = array_keys($attach);
+ }
+
+ // Once we have finished attaching or detaching the records, we will see if we
+ // have done any attaching or detaching, and if we have we will touch these
+ // relationships if they are configured to touch on any database updates.
+ if ($touch && (count($changes['attached']) ||
+ count($changes['detached']))) {
+ $this->touchIfTouching();
+ }
+
+ return $changes;
+ }
+
+ /**
+ * Sync the intermediate tables with a list of IDs without detaching.
+ *
+ * @param \Illuminate\Database\Eloquent\Collection|array $ids
+ * @return array
+ */
+ public function syncWithoutDetaching($ids)
+ {
+ return $this->sync($ids, false);
+ }
+
+ /**
+ * Sync the intermediate tables with a list of IDs or collection of models.
+ *
+ * @param \Illuminate\Database\Eloquent\Collection|\Illuminate\Support\Collection|array $ids
+ * @param bool $detaching
+ * @return array
+ */
+ public function sync($ids, $detaching = true)
+ {
+ $changes = [
+ 'attached' => [], 'detached' => [], 'updated' => [],
+ ];
+
+ // First we need to attach any of the associated models that are not currently
+ // in this joining table. We'll spin through the given IDs, checking to see
+ // if they exist in the array of current ones, and if not we will insert.
+ $current = $this->newPivotQuery()->pluck(
+ $this->relatedKey
+ )->all();
+
+ $detach = array_diff($current, array_keys(
+ $records = $this->formatRecordsList($this->parseIds($ids))
+ ));
+
+ // Next, we will take the differences of the currents and given IDs and detach
+ // all of the entities that exist in the "current" array but are not in the
+ // array of the new IDs given to the method which will complete the sync.
+ if ($detaching && count($detach) > 0) {
+ $this->detach($detach);
+
+ $changes['detached'] = $this->castKeys($detach);
+ }
+
+ // Now we are finally ready to attach the new records. Note that we'll disable
+ // touching until after the entire operation is complete so we don't fire a
+ // ton of touch operations until we are totally done syncing the records.
+ $changes = array_merge(
+ $changes, $this->attachNew($records, $current, false)
+ );
+
+ // Once we have finished attaching or detaching the records, we will see if we
+ // have done any attaching or detaching, and if we have we will touch these
+ // relationships if they are configured to touch on any database updates.
+ if (count($changes['attached']) ||
+ count($changes['updated'])) {
+ $this->touchIfTouching();
+ }
+
+ return $changes;
+ }
+
+ /**
+ * Format the sync / toggle record list so that it is keyed by ID.
+ *
+ * @param array $records
+ * @return array
+ */
+ protected function formatRecordsList(array $records)
+ {
+ return collect($records)->mapWithKeys(function ($attributes, $id) {
+ if (! is_array($attributes)) {
+ list($id, $attributes) = [$attributes, []];
+ }
+
+ return [$id => $attributes];
+ })->all();
+ }
+
+ /**
+ * Attach all of the records that aren't in the given current records.
+ *
+ * @param array $records
+ * @param array $current
+ * @param bool $touch
+ * @return array
+ */
+ protected function attachNew(array $records, array $current, $touch = true)
+ {
+ $changes = ['attached' => [], 'updated' => []];
+
+ foreach ($records as $id => $attributes) {
+ // If the ID is not in the list of existing pivot IDs, we will insert a new pivot
+ // record, otherwise, we will just update this existing record on this joining
+ // table, so that the developers will easily update these records pain free.
+ if (! in_array($id, $current)) {
+ $this->attach($id, $attributes, $touch);
+
+ $changes['attached'][] = $this->castKey($id);
+ }
+
+ // Now we'll try to update an existing pivot record with the attributes that were
+ // given to the method. If the model is actually updated we will add it to the
+ // list of updated pivot records so we return them back out to the consumer.
+ elseif (count($attributes) > 0 &&
+ $this->updateExistingPivot($id, $attributes, $touch)) {
+ $changes['updated'][] = $this->castKey($id);
+ }
+ }
+
+ return $changes;
+ }
+
+ /**
+ * Update an existing pivot record on the table.
+ *
+ * @param mixed $id
+ * @param array $attributes
+ * @param bool $touch
+ * @return int
+ */
+ public function updateExistingPivot($id, array $attributes, $touch = true)
+ {
+ if (in_array($this->updatedAt(), $this->pivotColumns)) {
+ $attributes = $this->addTimestampsToAttachment($attributes, true);
+ }
+
+ $updated = $this->newPivotStatementForId($id)->update($attributes);
+
+ if ($touch) {
+ $this->touchIfTouching();
+ }
+
+ return $updated;
+ }
+
+ /**
+ * Attach a model to the parent.
+ *
+ * @param mixed $id
+ * @param array $attributes
+ * @param bool $touch
+ * @return void
+ */
+ public function attach($id, array $attributes = [], $touch = true)
+ {
+ // Here we will insert the attachment records into the pivot table. Once we have
+ // inserted the records, we will touch the relationships if necessary and the
+ // function will return. We can parse the IDs before inserting the records.
+ $this->newPivotStatement()->insert($this->formatAttachRecords(
+ $this->parseIds($id), $attributes
+ ));
+
+ if ($touch) {
+ $this->touchIfTouching();
+ }
+ }
+
+ /**
+ * Create an array of records to insert into the pivot table.
+ *
+ * @param array $ids
+ * @param array $attributes
+ * @return array
+ */
+ protected function formatAttachRecords($ids, array $attributes)
+ {
+ $records = [];
+
+ $hasTimestamps = ($this->hasPivotColumn($this->createdAt()) ||
+ $this->hasPivotColumn($this->updatedAt()));
+
+ // To create the attachment records, we will simply spin through the IDs given
+ // and create a new record to insert for each ID. Each ID may actually be a
+ // key in the array, with extra attributes to be placed in other columns.
+ foreach ($ids as $key => $value) {
+ $records[] = $this->formatAttachRecord(
+ $key, $value, $attributes, $hasTimestamps
+ );
+ }
+
+ return $records;
+ }
+
+ /**
+ * Create a full attachment record payload.
+ *
+ * @param int $key
+ * @param mixed $value
+ * @param array $attributes
+ * @param bool $hasTimestamps
+ * @return array
+ */
+ protected function formatAttachRecord($key, $value, $attributes, $hasTimestamps)
+ {
+ list($id, $attributes) = $this->extractAttachIdAndAttributes($key, $value, $attributes);
+
+ return array_merge(
+ $this->baseAttachRecord($id, $hasTimestamps), $attributes
+ );
+ }
+
+ /**
+ * Get the attach record ID and extra attributes.
+ *
+ * @param mixed $key
+ * @param mixed $value
+ * @param array $attributes
+ * @return array
+ */
+ protected function extractAttachIdAndAttributes($key, $value, array $attributes)
+ {
+ return is_array($value)
+ ? [$key, array_merge($value, $attributes)]
+ : [$value, $attributes];
+ }
+
+ /**
+ * Create a new pivot attachment record.
+ *
+ * @param int $id
+ * @param bool $timed
+ * @return array
+ */
+ protected function baseAttachRecord($id, $timed)
+ {
+ $record[$this->relatedKey] = $id;
+
+ $record[$this->foreignKey] = $this->parent->getKey();
+
+ // If the record needs to have creation and update timestamps, we will make
+ // them by calling the parent model's "freshTimestamp" method which will
+ // provide us with a fresh timestamp in this model's preferred format.
+ if ($timed) {
+ $record = $this->addTimestampsToAttachment($record);
+ }
+
+ return $record;
+ }
+
+ /**
+ * Set the creation and update timestamps on an attach record.
+ *
+ * @param array $record
+ * @param bool $exists
+ * @return array
+ */
+ protected function addTimestampsToAttachment(array $record, $exists = false)
+ {
+ $fresh = $this->parent->freshTimestamp();
+
+ if (! $exists && $this->hasPivotColumn($this->createdAt())) {
+ $record[$this->createdAt()] = $fresh;
+ }
+
+ if ($this->hasPivotColumn($this->updatedAt())) {
+ $record[$this->updatedAt()] = $fresh;
+ }
+
+ return $record;
+ }
+
+ /**
+ * Determine whether the given column is defined as a pivot column.
+ *
+ * @param string $column
+ * @return bool
+ */
+ protected function hasPivotColumn($column)
+ {
+ return in_array($column, $this->pivotColumns);
+ }
+
+ /**
+ * Detach models from the relationship.
+ *
+ * @param mixed $ids
+ * @param bool $touch
+ * @return int
+ */
+ public function detach($ids = null, $touch = true)
+ {
+ $query = $this->newPivotQuery();
+
+ // If associated IDs were passed to the method we will only delete those
+ // associations, otherwise all of the association ties will be broken.
+ // We'll return the numbers of affected rows when we do the deletes.
+ if (! is_null($ids)) {
+ $ids = $this->parseIds($ids);
+
+ if (empty($ids)) {
+ return 0;
+ }
+
+ $query->whereIn($this->relatedKey, $ids);
+ }
+
+ // Once we have all of the conditions set on the statement, we are ready
+ // to run the delete on the pivot table. Then, if the touch parameter
+ // is true, we will go ahead and touch all related models to sync.
+ $results = $query->delete();
+
+ if ($touch) {
+ $this->touchIfTouching();
+ }
+
+ return $results;
+ }
+
+ /**
+ * Create a new pivot model instance.
+ *
+ * @param array $attributes
+ * @param bool $exists
+ * @return \Illuminate\Database\Eloquent\Relations\Pivot
+ */
+ public function newPivot(array $attributes = [], $exists = false)
+ {
+ $pivot = $this->related->newPivot(
+ $this->parent, $attributes, $this->table, $exists, $this->using
+ );
+
+ return $pivot->setPivotKeys($this->foreignKey, $this->relatedKey);
+ }
+
+ /**
+ * Create a new existing pivot model instance.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Relations\Pivot
+ */
+ public function newExistingPivot(array $attributes = [])
+ {
+ return $this->newPivot($attributes, true);
+ }
+
+ /**
+ * Get a new plain query builder for the pivot table.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function newPivotStatement()
+ {
+ return $this->query->getQuery()->newQuery()->from($this->table);
+ }
+
+ /**
+ * Get a new pivot statement for a given "other" ID.
+ *
+ * @param mixed $id
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function newPivotStatementForId($id)
+ {
+ return $this->newPivotQuery()->where($this->relatedKey, $id);
+ }
+
+ /**
+ * Create a new query builder for the pivot table.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ protected function newPivotQuery()
+ {
+ $query = $this->newPivotStatement();
+
+ foreach ($this->pivotWheres as $arguments) {
+ call_user_func_array([$query, 'where'], $arguments);
+ }
+
+ foreach ($this->pivotWhereIns as $arguments) {
+ call_user_func_array([$query, 'whereIn'], $arguments);
+ }
+
+ return $query->where($this->foreignKey, $this->parent->getKey());
+ }
+
+ /**
+ * Set the columns on the pivot table to retrieve.
+ *
+ * @param array|mixed $columns
+ * @return $this
+ */
+ public function withPivot($columns)
+ {
+ $this->pivotColumns = array_merge(
+ $this->pivotColumns, is_array($columns) ? $columns : func_get_args()
+ );
+
+ return $this;
+ }
+
+ /**
+ * Get all of the IDs from the given mixed value.
+ *
+ * @param mixed $value
+ * @return array
+ */
+ protected function parseIds($value)
+ {
+ if ($value instanceof Model) {
+ return [$value->getKey()];
+ }
+
+ if ($value instanceof Collection) {
+ return $value->modelKeys();
+ }
+
+ if ($value instanceof BaseCollection) {
+ return $value->toArray();
+ }
+
+ return (array) $value;
+ }
+
+ /**
+ * Cast the given keys to integers if they are numeric and string otherwise.
+ *
+ * @param array $keys
+ * @return array
+ */
+ protected function castKeys(array $keys)
+ {
+ return (array) array_map(function ($v) {
+ return $this->castKey($v);
+ }, $keys);
+ }
+
+ /**
+ * Cast the given key to an integer if it is numeric.
+ *
+ * @param mixed $key
+ * @return mixed
+ */
+ protected function castKey($key)
+ {
+ return is_numeric($key) ? (int) $key : (string) $key;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/SupportsDefaultModels.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/SupportsDefaultModels.php
new file mode 100644
index 000000000..00efd507e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Concerns/SupportsDefaultModels.php
@@ -0,0 +1,63 @@
+withDefault = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Get the default value for this relation.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $parent
+ * @return \Illuminate\Database\Eloquent\Model|null
+ */
+ protected function getDefaultFor(Model $parent)
+ {
+ if (! $this->withDefault) {
+ return;
+ }
+
+ $instance = $this->newRelatedInstanceFor($parent);
+
+ if (is_callable($this->withDefault)) {
+ return call_user_func($this->withDefault, $instance) ?: $instance;
+ }
+
+ if (is_array($this->withDefault)) {
+ $instance->forceFill($this->withDefault);
+ }
+
+ return $instance;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasMany.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasMany.php
new file mode 100644
index 000000000..6149e475a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasMany.php
@@ -0,0 +1,47 @@
+query->get();
+ }
+
+ /**
+ * Initialize the relation on a set of models.
+ *
+ * @param array $models
+ * @param string $relation
+ * @return array
+ */
+ public function initRelation(array $models, $relation)
+ {
+ foreach ($models as $model) {
+ $model->setRelation($relation, $this->related->newCollection());
+ }
+
+ return $models;
+ }
+
+ /**
+ * Match the eagerly loaded results to their parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ public function match(array $models, Collection $results, $relation)
+ {
+ return $this->matchMany($models, $results, $relation);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasManyThrough.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasManyThrough.php
new file mode 100644
index 000000000..3fb7a7cc2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasManyThrough.php
@@ -0,0 +1,455 @@
+localKey = $localKey;
+ $this->firstKey = $firstKey;
+ $this->secondKey = $secondKey;
+ $this->farParent = $farParent;
+ $this->throughParent = $throughParent;
+
+ parent::__construct($query, $throughParent);
+ }
+
+ /**
+ * Set the base constraints on the relation query.
+ *
+ * @return void
+ */
+ public function addConstraints()
+ {
+ $localValue = $this->farParent[$this->localKey];
+
+ $this->performJoin();
+
+ if (static::$constraints) {
+ $this->query->where($this->getQualifiedFirstKeyName(), '=', $localValue);
+ }
+ }
+
+ /**
+ * Set the join clause on the query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder|null $query
+ * @return void
+ */
+ protected function performJoin(Builder $query = null)
+ {
+ $query = $query ?: $this->query;
+
+ $farKey = $this->getQualifiedFarKeyName();
+
+ $query->join($this->throughParent->getTable(), $this->getQualifiedParentKeyName(), '=', $farKey);
+
+ if ($this->throughParentSoftDeletes()) {
+ $query->whereNull($this->throughParent->getQualifiedDeletedAtColumn());
+ }
+ }
+
+ /**
+ * Determine whether "through" parent of the relation uses Soft Deletes.
+ *
+ * @return bool
+ */
+ public function throughParentSoftDeletes()
+ {
+ return in_array(SoftDeletes::class, class_uses_recursive(
+ get_class($this->throughParent)
+ ));
+ }
+
+ /**
+ * Set the constraints for an eager load of the relation.
+ *
+ * @param array $models
+ * @return void
+ */
+ public function addEagerConstraints(array $models)
+ {
+ $this->query->whereIn(
+ $this->getQualifiedFirstKeyName(), $this->getKeys($models, $this->localKey)
+ );
+ }
+
+ /**
+ * Initialize the relation on a set of models.
+ *
+ * @param array $models
+ * @param string $relation
+ * @return array
+ */
+ public function initRelation(array $models, $relation)
+ {
+ foreach ($models as $model) {
+ $model->setRelation($relation, $this->related->newCollection());
+ }
+
+ return $models;
+ }
+
+ /**
+ * Match the eagerly loaded results to their parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ public function match(array $models, Collection $results, $relation)
+ {
+ $dictionary = $this->buildDictionary($results);
+
+ // Once we have the dictionary we can simply spin through the parent models to
+ // link them up with their children using the keyed dictionary to make the
+ // matching very convenient and easy work. Then we'll just return them.
+ foreach ($models as $model) {
+ if (isset($dictionary[$key = $model->getKey()])) {
+ $model->setRelation(
+ $relation, $this->related->newCollection($dictionary[$key])
+ );
+ }
+ }
+
+ return $models;
+ }
+
+ /**
+ * Build model dictionary keyed by the relation's foreign key.
+ *
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @return array
+ */
+ protected function buildDictionary(Collection $results)
+ {
+ $dictionary = [];
+
+ // First we will create a dictionary of models keyed by the foreign key of the
+ // relationship as this will allow us to quickly access all of the related
+ // models without having to do nested looping which will be quite slow.
+ foreach ($results as $result) {
+ $dictionary[$result->{$this->firstKey}][] = $result;
+ }
+
+ return $dictionary;
+ }
+
+ /**
+ * Get the first related model record matching the attributes or instantiate it.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function firstOrNew(array $attributes)
+ {
+ if (is_null($instance = $this->where($attributes)->first())) {
+ $instance = $this->related->newInstance($attributes);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Create or update a related record matching the attributes, and fill it with values.
+ *
+ * @param array $attributes
+ * @param array $values
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function updateOrCreate(array $attributes, array $values = [])
+ {
+ $instance = $this->firstOrNew($attributes);
+
+ $instance->fill($values)->save();
+
+ return $instance;
+ }
+
+ /**
+ * Execute the query and get the first related model.
+ *
+ * @param array $columns
+ * @return mixed
+ */
+ public function first($columns = ['*'])
+ {
+ $results = $this->take(1)->get($columns);
+
+ return count($results) > 0 ? $results->first() : null;
+ }
+
+ /**
+ * Execute the query and get the first result or throw an exception.
+ *
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model|static
+ *
+ * @throws \Illuminate\Database\Eloquent\ModelNotFoundException
+ */
+ public function firstOrFail($columns = ['*'])
+ {
+ if (! is_null($model = $this->first($columns))) {
+ return $model;
+ }
+
+ throw (new ModelNotFoundException)->setModel(get_class($this->related));
+ }
+
+ /**
+ * Find a related model by its primary key.
+ *
+ * @param mixed $id
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model|\Illuminate\Database\Eloquent\Collection|null
+ */
+ public function find($id, $columns = ['*'])
+ {
+ if (is_array($id)) {
+ return $this->findMany($id, $columns);
+ }
+
+ return $this->where(
+ $this->getRelated()->getQualifiedKeyName(), '=', $id
+ )->first($columns);
+ }
+
+ /**
+ * Find multiple related models by their primary keys.
+ *
+ * @param mixed $ids
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ public function findMany($ids, $columns = ['*'])
+ {
+ if (empty($ids)) {
+ return $this->getRelated()->newCollection();
+ }
+
+ return $this->whereIn(
+ $this->getRelated()->getQualifiedKeyName(), $ids
+ )->get($columns);
+ }
+
+ /**
+ * Find a related model by its primary key or throw an exception.
+ *
+ * @param mixed $id
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Model|\Illuminate\Database\Eloquent\Collection
+ *
+ * @throws \Illuminate\Database\Eloquent\ModelNotFoundException
+ */
+ public function findOrFail($id, $columns = ['*'])
+ {
+ $result = $this->find($id, $columns);
+
+ if (is_array($id)) {
+ if (count($result) == count(array_unique($id))) {
+ return $result;
+ }
+ } elseif (! is_null($result)) {
+ return $result;
+ }
+
+ throw (new ModelNotFoundException)->setModel(get_class($this->related));
+ }
+
+ /**
+ * Get the results of the relationship.
+ *
+ * @return mixed
+ */
+ public function getResults()
+ {
+ return $this->get();
+ }
+
+ /**
+ * Execute the query as a "select" statement.
+ *
+ * @param array $columns
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ public function get($columns = ['*'])
+ {
+ // First we'll add the proper select columns onto the query so it is run with
+ // the proper columns. Then, we will get the results and hydrate out pivot
+ // models with the result of those columns as a separate model relation.
+ $columns = $this->query->getQuery()->columns ? [] : $columns;
+
+ $builder = $this->query->applyScopes();
+
+ $models = $builder->addSelect(
+ $this->shouldSelect($columns)
+ )->getModels();
+
+ // If we actually found models we will also eager load any relationships that
+ // have been specified as needing to be eager loaded. This will solve the
+ // n + 1 query problem for the developer and also increase performance.
+ if (count($models) > 0) {
+ $models = $builder->eagerLoadRelations($models);
+ }
+
+ return $this->related->newCollection($models);
+ }
+
+ /**
+ * Get a paginator for the "select" statement.
+ *
+ * @param int $perPage
+ * @param array $columns
+ * @param string $pageName
+ * @param int $page
+ * @return \Illuminate\Contracts\Pagination\LengthAwarePaginator
+ */
+ public function paginate($perPage = null, $columns = ['*'], $pageName = 'page', $page = null)
+ {
+ $this->query->addSelect($this->shouldSelect($columns));
+
+ return $this->query->paginate($perPage, $columns, $pageName, $page);
+ }
+
+ /**
+ * Paginate the given query into a simple paginator.
+ *
+ * @param int $perPage
+ * @param array $columns
+ * @param string $pageName
+ * @param int|null $page
+ * @return \Illuminate\Contracts\Pagination\Paginator
+ */
+ public function simplePaginate($perPage = null, $columns = ['*'], $pageName = 'page', $page = null)
+ {
+ $this->query->addSelect($this->shouldSelect($columns));
+
+ return $this->query->simplePaginate($perPage, $columns, $pageName, $page);
+ }
+
+ /**
+ * Set the select clause for the relation query.
+ *
+ * @param array $columns
+ * @return array
+ */
+ protected function shouldSelect(array $columns = ['*'])
+ {
+ if ($columns == ['*']) {
+ $columns = [$this->related->getTable().'.*'];
+ }
+
+ return array_merge($columns, [$this->getQualifiedFirstKeyName()]);
+ }
+
+ /**
+ * Add the constraints for a relationship query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceQuery(Builder $query, Builder $parentQuery, $columns = ['*'])
+ {
+ $this->performJoin($query);
+
+ return $query->select($columns)->whereColumn(
+ $this->getExistenceCompareKey(), '=', $this->getQualifiedFirstKeyName()
+ );
+ }
+
+ /**
+ * Get the key for comparing against the parent key in "has" query.
+ *
+ * @return string
+ */
+ public function getExistenceCompareKey()
+ {
+ return $this->farParent->getQualifiedKeyName();
+ }
+
+ /**
+ * Get the qualified foreign key on the related model.
+ *
+ * @return string
+ */
+ public function getQualifiedFarKeyName()
+ {
+ return $this->getQualifiedForeignKeyName();
+ }
+
+ /**
+ * Get the qualified foreign key on the related model.
+ *
+ * @return string
+ */
+ public function getQualifiedForeignKeyName()
+ {
+ return $this->related->getTable().'.'.$this->secondKey;
+ }
+
+ /**
+ * Get the qualified foreign key on the "through" model.
+ *
+ * @return string
+ */
+ public function getQualifiedFirstKeyName()
+ {
+ return $this->throughParent->getTable().'.'.$this->firstKey;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOne.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOne.php
new file mode 100644
index 000000000..858e5d070
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOne.php
@@ -0,0 +1,64 @@
+query->first() ?: $this->getDefaultFor($this->parent);
+ }
+
+ /**
+ * Initialize the relation on a set of models.
+ *
+ * @param array $models
+ * @param string $relation
+ * @return array
+ */
+ public function initRelation(array $models, $relation)
+ {
+ foreach ($models as $model) {
+ $model->setRelation($relation, $this->getDefaultFor($model));
+ }
+
+ return $models;
+ }
+
+ /**
+ * Match the eagerly loaded results to their parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ public function match(array $models, Collection $results, $relation)
+ {
+ return $this->matchOne($models, $results, $relation);
+ }
+
+ /**
+ * Make a new related instance for the given model.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $parent
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function newRelatedInstanceFor(Model $parent)
+ {
+ return $this->related->newInstance()->setAttribute(
+ $this->getForeignKeyName(), $parent->{$this->localKey}
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOneOrMany.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOneOrMany.php
new file mode 100644
index 000000000..c6e1ba835
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOneOrMany.php
@@ -0,0 +1,417 @@
+localKey = $localKey;
+ $this->foreignKey = $foreignKey;
+
+ parent::__construct($query, $parent);
+ }
+
+ /**
+ * Create and return an un-saved instance of the related model.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function make(array $attributes = [])
+ {
+ return tap($this->related->newInstance($attributes), function ($instance) {
+ $instance->setAttribute($this->getForeignKeyName(), $this->getParentKey());
+ });
+ }
+
+ /**
+ * Set the base constraints on the relation query.
+ *
+ * @return void
+ */
+ public function addConstraints()
+ {
+ if (static::$constraints) {
+ $this->query->where($this->foreignKey, '=', $this->getParentKey());
+
+ $this->query->whereNotNull($this->foreignKey);
+ }
+ }
+
+ /**
+ * Set the constraints for an eager load of the relation.
+ *
+ * @param array $models
+ * @return void
+ */
+ public function addEagerConstraints(array $models)
+ {
+ $this->query->whereIn(
+ $this->foreignKey, $this->getKeys($models, $this->localKey)
+ );
+ }
+
+ /**
+ * Match the eagerly loaded results to their single parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ public function matchOne(array $models, Collection $results, $relation)
+ {
+ return $this->matchOneOrMany($models, $results, $relation, 'one');
+ }
+
+ /**
+ * Match the eagerly loaded results to their many parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ public function matchMany(array $models, Collection $results, $relation)
+ {
+ return $this->matchOneOrMany($models, $results, $relation, 'many');
+ }
+
+ /**
+ * Match the eagerly loaded results to their many parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @param string $type
+ * @return array
+ */
+ protected function matchOneOrMany(array $models, Collection $results, $relation, $type)
+ {
+ $dictionary = $this->buildDictionary($results);
+
+ // Once we have the dictionary we can simply spin through the parent models to
+ // link them up with their children using the keyed dictionary to make the
+ // matching very convenient and easy work. Then we'll just return them.
+ foreach ($models as $model) {
+ if (isset($dictionary[$key = $model->getAttribute($this->localKey)])) {
+ $model->setRelation(
+ $relation, $this->getRelationValue($dictionary, $key, $type)
+ );
+ }
+ }
+
+ return $models;
+ }
+
+ /**
+ * Get the value of a relationship by one or many type.
+ *
+ * @param array $dictionary
+ * @param string $key
+ * @param string $type
+ * @return mixed
+ */
+ protected function getRelationValue(array $dictionary, $key, $type)
+ {
+ $value = $dictionary[$key];
+
+ return $type == 'one' ? reset($value) : $this->related->newCollection($value);
+ }
+
+ /**
+ * Build model dictionary keyed by the relation's foreign key.
+ *
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @return array
+ */
+ protected function buildDictionary(Collection $results)
+ {
+ $dictionary = [];
+
+ $foreign = $this->getForeignKeyName();
+
+ // First we will create a dictionary of models keyed by the foreign key of the
+ // relationship as this will allow us to quickly access all of the related
+ // models without having to do nested looping which will be quite slow.
+ foreach ($results as $result) {
+ $dictionary[$result->{$foreign}][] = $result;
+ }
+
+ return $dictionary;
+ }
+
+ /**
+ * Find a model by its primary key or return new instance of the related model.
+ *
+ * @param mixed $id
+ * @param array $columns
+ * @return \Illuminate\Support\Collection|\Illuminate\Database\Eloquent\Model
+ */
+ public function findOrNew($id, $columns = ['*'])
+ {
+ if (is_null($instance = $this->find($id, $columns))) {
+ $instance = $this->related->newInstance();
+
+ $instance->setAttribute($this->getForeignKeyName(), $this->getParentKey());
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Get the first related model record matching the attributes or instantiate it.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function firstOrNew(array $attributes)
+ {
+ if (is_null($instance = $this->where($attributes)->first())) {
+ $instance = $this->related->newInstance($attributes);
+
+ $instance->setAttribute($this->getForeignKeyName(), $this->getParentKey());
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Get the first related record matching the attributes or create it.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function firstOrCreate(array $attributes)
+ {
+ if (is_null($instance = $this->where($attributes)->first())) {
+ $instance = $this->create($attributes);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Create or update a related record matching the attributes, and fill it with values.
+ *
+ * @param array $attributes
+ * @param array $values
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function updateOrCreate(array $attributes, array $values = [])
+ {
+ return tap($this->firstOrNew($attributes), function ($instance) use ($values) {
+ $instance->fill($values);
+
+ $instance->save();
+ });
+ }
+
+ /**
+ * Attach a model instance to the parent model.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @return \Illuminate\Database\Eloquent\Model|false
+ */
+ public function save(Model $model)
+ {
+ $model->setAttribute($this->getForeignKeyName(), $this->getParentKey());
+
+ return $model->save() ? $model : false;
+ }
+
+ /**
+ * Attach a collection of models to the parent instance.
+ *
+ * @param \Traversable|array $models
+ * @return \Traversable|array
+ */
+ public function saveMany($models)
+ {
+ foreach ($models as $model) {
+ $this->save($model);
+ }
+
+ return $models;
+ }
+
+ /**
+ * Create a new instance of the related model.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function create(array $attributes)
+ {
+ return tap($this->related->newInstance($attributes), function ($instance) {
+ $instance->setAttribute($this->getForeignKeyName(), $this->getParentKey());
+
+ $instance->save();
+ });
+ }
+
+ /**
+ * Create a Collection of new instances of the related model.
+ *
+ * @param array $records
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ public function createMany(array $records)
+ {
+ $instances = $this->related->newCollection();
+
+ foreach ($records as $record) {
+ $instances->push($this->create($record));
+ }
+
+ return $instances;
+ }
+
+ /**
+ * Perform an update on all the related models.
+ *
+ * @param array $attributes
+ * @return int
+ */
+ public function update(array $attributes)
+ {
+ if ($this->related->usesTimestamps()) {
+ $attributes[$this->relatedUpdatedAt()] = $this->related->freshTimestampString();
+ }
+
+ return $this->query->update($attributes);
+ }
+
+ /**
+ * Add the constraints for a relationship query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceQuery(Builder $query, Builder $parentQuery, $columns = ['*'])
+ {
+ if ($query->getQuery()->from == $parentQuery->getQuery()->from) {
+ return $this->getRelationExistenceQueryForSelfRelation($query, $parentQuery, $columns);
+ }
+
+ return parent::getRelationExistenceQuery($query, $parentQuery, $columns);
+ }
+
+ /**
+ * Add the constraints for a relationship query on the same table.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceQueryForSelfRelation(Builder $query, Builder $parentQuery, $columns = ['*'])
+ {
+ $query->from($query->getModel()->getTable().' as '.$hash = $this->getRelationCountHash());
+
+ $query->getModel()->setTable($hash);
+
+ return $query->select($columns)->whereColumn(
+ $this->getQualifiedParentKeyName(), '=', $hash.'.'.$this->getForeignKeyName()
+ );
+ }
+
+ /**
+ * Get a relationship join table hash.
+ *
+ * @return string
+ */
+ public function getRelationCountHash()
+ {
+ return 'laravel_reserved_'.static::$selfJoinCount++;
+ }
+
+ /**
+ * Get the key for comparing against the parent key in "has" query.
+ *
+ * @return string
+ */
+ public function getExistenceCompareKey()
+ {
+ return $this->getQualifiedForeignKeyName();
+ }
+
+ /**
+ * Get the key value of the parent's local key.
+ *
+ * @return mixed
+ */
+ public function getParentKey()
+ {
+ return $this->parent->getAttribute($this->localKey);
+ }
+
+ /**
+ * Get the fully qualified parent key name.
+ *
+ * @return string
+ */
+ public function getQualifiedParentKeyName()
+ {
+ return $this->parent->getTable().'.'.$this->localKey;
+ }
+
+ /**
+ * Get the plain foreign key.
+ *
+ * @return string
+ */
+ public function getForeignKeyName()
+ {
+ $segments = explode('.', $this->getQualifiedForeignKeyName());
+
+ return $segments[count($segments) - 1];
+ }
+
+ /**
+ * Get the foreign key for the relationship.
+ *
+ * @return string
+ */
+ public function getQualifiedForeignKeyName()
+ {
+ return $this->foreignKey;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphMany.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphMany.php
new file mode 100644
index 000000000..e2a5c5a37
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphMany.php
@@ -0,0 +1,47 @@
+query->get();
+ }
+
+ /**
+ * Initialize the relation on a set of models.
+ *
+ * @param array $models
+ * @param string $relation
+ * @return array
+ */
+ public function initRelation(array $models, $relation)
+ {
+ foreach ($models as $model) {
+ $model->setRelation($relation, $this->related->newCollection());
+ }
+
+ return $models;
+ }
+
+ /**
+ * Match the eagerly loaded results to their parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ public function match(array $models, Collection $results, $relation)
+ {
+ return $this->matchMany($models, $results, $relation);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOne.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOne.php
new file mode 100644
index 000000000..520a7ec94
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOne.php
@@ -0,0 +1,64 @@
+query->first() ?: $this->getDefaultFor($this->parent);
+ }
+
+ /**
+ * Initialize the relation on a set of models.
+ *
+ * @param array $models
+ * @param string $relation
+ * @return array
+ */
+ public function initRelation(array $models, $relation)
+ {
+ foreach ($models as $model) {
+ $model->setRelation($relation, $this->getDefaultFor($model));
+ }
+
+ return $models;
+ }
+
+ /**
+ * Match the eagerly loaded results to their parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ public function match(array $models, Collection $results, $relation)
+ {
+ return $this->matchOne($models, $results, $relation);
+ }
+
+ /**
+ * Make a new related instance for the given model.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $parent
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function newRelatedInstanceFor(Model $parent)
+ {
+ return $this->related->newInstance()
+ ->setAttribute($this->getForeignKeyName(), $parent->{$this->localKey})
+ ->setAttribute($this->getMorphType(), $this->morphClass);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOneOrMany.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOneOrMany.php
new file mode 100644
index 000000000..42f1239d8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphOneOrMany.php
@@ -0,0 +1,248 @@
+morphType = $type;
+
+ $this->morphClass = $parent->getMorphClass();
+
+ parent::__construct($query, $parent, $id, $localKey);
+ }
+
+ /**
+ * Create and return an un-saved instance of the related model.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function make(array $attributes = [])
+ {
+ return tap($this->related->newInstance($attributes), function ($instance) {
+ // When saving a polymorphic relationship, we need to set not only the foreign
+ // key, but also the foreign key type, which is typically the class name of
+ // the parent model. This makes the polymorphic item unique in the table.
+ $this->setForeignAttributesForCreate($instance);
+ });
+ }
+
+ /**
+ * Set the base constraints on the relation query.
+ *
+ * @return void
+ */
+ public function addConstraints()
+ {
+ if (static::$constraints) {
+ parent::addConstraints();
+
+ $this->query->where($this->morphType, $this->morphClass);
+ }
+ }
+
+ /**
+ * Set the constraints for an eager load of the relation.
+ *
+ * @param array $models
+ * @return void
+ */
+ public function addEagerConstraints(array $models)
+ {
+ parent::addEagerConstraints($models);
+
+ $this->query->where($this->morphType, $this->morphClass);
+ }
+
+ /**
+ * Find a related model by its primary key or return new instance of the related model.
+ *
+ * @param mixed $id
+ * @param array $columns
+ * @return \Illuminate\Support\Collection|\Illuminate\Database\Eloquent\Model
+ */
+ public function findOrNew($id, $columns = ['*'])
+ {
+ if (is_null($instance = $this->find($id, $columns))) {
+ $instance = $this->related->newInstance();
+
+ // When saving a polymorphic relationship, we need to set not only the foreign
+ // key, but also the foreign key type, which is typically the class name of
+ // the parent model. This makes the polymorphic item unique in the table.
+ $this->setForeignAttributesForCreate($instance);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Get the first related model record matching the attributes or instantiate it.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function firstOrNew(array $attributes)
+ {
+ if (is_null($instance = $this->where($attributes)->first())) {
+ $instance = $this->related->newInstance($attributes);
+
+ // When saving a polymorphic relationship, we need to set not only the foreign
+ // key, but also the foreign key type, which is typically the class name of
+ // the parent model. This makes the polymorphic item unique in the table.
+ $this->setForeignAttributesForCreate($instance);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Get the first related record matching the attributes or create it.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function firstOrCreate(array $attributes)
+ {
+ if (is_null($instance = $this->where($attributes)->first())) {
+ $instance = $this->create($attributes);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Create or update a related record matching the attributes, and fill it with values.
+ *
+ * @param array $attributes
+ * @param array $values
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function updateOrCreate(array $attributes, array $values = [])
+ {
+ return tap($this->firstOrNew($attributes), function ($instance) use ($values) {
+ $instance->fill($values);
+
+ $instance->save();
+ });
+ }
+
+ /**
+ * Attach a model instance to the parent model.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function save(Model $model)
+ {
+ $model->setAttribute($this->getMorphType(), $this->morphClass);
+
+ return parent::save($model);
+ }
+
+ /**
+ * Create a new instance of the related model.
+ *
+ * @param array $attributes
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function create(array $attributes)
+ {
+ $instance = $this->related->newInstance($attributes);
+
+ // When saving a polymorphic relationship, we need to set not only the foreign
+ // key, but also the foreign key type, which is typically the class name of
+ // the parent model. This makes the polymorphic item unique in the table.
+ $this->setForeignAttributesForCreate($instance);
+
+ $instance->save();
+
+ return $instance;
+ }
+
+ /**
+ * Set the foreign ID and type for creating a related model.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @return void
+ */
+ protected function setForeignAttributesForCreate(Model $model)
+ {
+ $model->{$this->getForeignKeyName()} = $this->getParentKey();
+
+ $model->{$this->getMorphType()} = $this->morphClass;
+ }
+
+ /**
+ * Get the relationship query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceQuery(Builder $query, Builder $parentQuery, $columns = ['*'])
+ {
+ return parent::getRelationExistenceQuery($query, $parentQuery, $columns)->where(
+ $this->morphType, $this->morphClass
+ );
+ }
+
+ /**
+ * Get the foreign key "type" name.
+ *
+ * @return string
+ */
+ public function getQualifiedMorphType()
+ {
+ return $this->morphType;
+ }
+
+ /**
+ * Get the plain morph type name without the table.
+ *
+ * @return string
+ */
+ public function getMorphType()
+ {
+ return last(explode('.', $this->morphType));
+ }
+
+ /**
+ * Get the class name of the parent model.
+ *
+ * @return string
+ */
+ public function getMorphClass()
+ {
+ return $this->morphClass;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphPivot.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphPivot.php
new file mode 100644
index 000000000..b7a2f3419
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphPivot.php
@@ -0,0 +1,79 @@
+where($this->morphType, $this->morphClass);
+
+ return parent::setKeysForSaveQuery($query);
+ }
+
+ /**
+ * Delete the pivot model record from the database.
+ *
+ * @return int
+ */
+ public function delete()
+ {
+ $query = $this->getDeleteQuery();
+
+ $query->where($this->morphType, $this->morphClass);
+
+ return $query->delete();
+ }
+
+ /**
+ * Set the morph type for the pivot.
+ *
+ * @param string $morphType
+ * @return $this
+ */
+ public function setMorphType($morphType)
+ {
+ $this->morphType = $morphType;
+
+ return $this;
+ }
+
+ /**
+ * Set the morph class for the pivot.
+ *
+ * @param string $morphClass
+ * @return \Illuminate\Database\Eloquent\Relations\MorphPivot
+ */
+ public function setMorphClass($morphClass)
+ {
+ $this->morphClass = $morphClass;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphTo.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphTo.php
new file mode 100644
index 000000000..2739786d5
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphTo.php
@@ -0,0 +1,275 @@
+morphType = $type;
+
+ parent::__construct($query, $parent, $foreignKey, $ownerKey, $relation);
+ }
+
+ /**
+ * Set the constraints for an eager load of the relation.
+ *
+ * @param array $models
+ * @return void
+ */
+ public function addEagerConstraints(array $models)
+ {
+ $this->buildDictionary($this->models = Collection::make($models));
+ }
+
+ /**
+ * Build a dictionary with the models.
+ *
+ * @param \Illuminate\Database\Eloquent\Collection $models
+ * @return void
+ */
+ protected function buildDictionary(Collection $models)
+ {
+ foreach ($models as $model) {
+ if ($model->{$this->morphType}) {
+ $this->dictionary[$model->{$this->morphType}][$model->{$this->foreignKey}][] = $model;
+ }
+ }
+ }
+
+ /**
+ * Get the results of the relationship.
+ *
+ * @return mixed
+ */
+ public function getResults()
+ {
+ return $this->ownerKey ? $this->query->first() : null;
+ }
+
+ /**
+ * Get the results of the relationship.
+ *
+ * Called via eager load method of Eloquent query builder.
+ *
+ * @return mixed
+ */
+ public function getEager()
+ {
+ foreach (array_keys($this->dictionary) as $type) {
+ $this->matchToMorphParents($type, $this->getResultsByType($type));
+ }
+
+ return $this->models;
+ }
+
+ /**
+ * Get all of the relation results for a type.
+ *
+ * @param string $type
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ protected function getResultsByType($type)
+ {
+ $instance = $this->createModelByType($type);
+
+ $query = $this->replayMacros($instance->newQuery())
+ ->mergeConstraintsFrom($this->getQuery())
+ ->with($this->getQuery()->getEagerLoads());
+
+ return $query->whereIn(
+ $instance->getTable().'.'.$instance->getKeyName(), $this->gatherKeysByType($type)
+ )->get();
+ }
+
+ /**
+ * Gather all of the foreign keys for a given type.
+ *
+ * @param string $type
+ * @return array
+ */
+ protected function gatherKeysByType($type)
+ {
+ return collect($this->dictionary[$type])->map(function ($models) {
+ return head($models)->{$this->foreignKey};
+ })->values()->unique()->all();
+ }
+
+ /**
+ * Create a new model instance by type.
+ *
+ * @param string $type
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function createModelByType($type)
+ {
+ $class = Model::getActualClassNameForMorph($type);
+
+ return new $class;
+ }
+
+ /**
+ * Match the eagerly loaded results to their parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ public function match(array $models, Collection $results, $relation)
+ {
+ return $models;
+ }
+
+ /**
+ * Match the results for a given type to their parents.
+ *
+ * @param string $type
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @return void
+ */
+ protected function matchToMorphParents($type, Collection $results)
+ {
+ foreach ($results as $result) {
+ if (isset($this->dictionary[$type][$result->getKey()])) {
+ foreach ($this->dictionary[$type][$result->getKey()] as $model) {
+ $model->setRelation($this->relation, $result);
+ }
+ }
+ }
+ }
+
+ /**
+ * Associate the model instance to the given parent.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function associate($model)
+ {
+ $this->parent->setAttribute($this->foreignKey, $model->getKey());
+
+ $this->parent->setAttribute($this->morphType, $model->getMorphClass());
+
+ return $this->parent->setRelation($this->relation, $model);
+ }
+
+ /**
+ * Dissociate previously associated model from the given parent.
+ *
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function dissociate()
+ {
+ $this->parent->setAttribute($this->foreignKey, null);
+
+ $this->parent->setAttribute($this->morphType, null);
+
+ return $this->parent->setRelation($this->relation, null);
+ }
+
+ /**
+ * Get the foreign key "type" name.
+ *
+ * @return string
+ */
+ public function getMorphType()
+ {
+ return $this->morphType;
+ }
+
+ /**
+ * Get the dictionary used by the relationship.
+ *
+ * @return array
+ */
+ public function getDictionary()
+ {
+ return $this->dictionary;
+ }
+
+ /**
+ * Replay stored macro calls on the actual related instance.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ protected function replayMacros(Builder $query)
+ {
+ foreach ($this->macroBuffer as $macro) {
+ $query->{$macro['method']}(...$macro['parameters']);
+ }
+
+ return $query;
+ }
+
+ /**
+ * Handle dynamic method calls to the relationship.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ try {
+ return parent::__call($method, $parameters);
+ }
+
+ // If we tried to call a method that does not exist on the parent Builder instance,
+ // we'll assume that we want to call a query macro (e.g. withTrashed) that only
+ // exists on related models. We will just store the call and replay it later.
+ catch (BadMethodCallException $e) {
+ $this->macroBuffer[] = compact('method', 'parameters');
+
+ return $this;
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphToMany.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphToMany.php
new file mode 100644
index 000000000..2ca44d828
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/MorphToMany.php
@@ -0,0 +1,162 @@
+inverse = $inverse;
+ $this->morphType = $name.'_type';
+ $this->morphClass = $inverse ? $query->getModel()->getMorphClass() : $parent->getMorphClass();
+
+ parent::__construct($query, $parent, $table, $foreignKey, $relatedKey, $relationName);
+ }
+
+ /**
+ * Set the where clause for the relation query.
+ *
+ * @return $this
+ */
+ protected function addWhereConstraints()
+ {
+ parent::addWhereConstraints();
+
+ $this->query->where($this->table.'.'.$this->morphType, $this->morphClass);
+
+ return $this;
+ }
+
+ /**
+ * Set the constraints for an eager load of the relation.
+ *
+ * @param array $models
+ * @return void
+ */
+ public function addEagerConstraints(array $models)
+ {
+ parent::addEagerConstraints($models);
+
+ $this->query->where($this->table.'.'.$this->morphType, $this->morphClass);
+ }
+
+ /**
+ * Create a new pivot attachment record.
+ *
+ * @param int $id
+ * @param bool $timed
+ * @return array
+ */
+ protected function baseAttachRecord($id, $timed)
+ {
+ return Arr::add(
+ parent::baseAttachRecord($id, $timed), $this->morphType, $this->morphClass
+ );
+ }
+
+ /**
+ * Add the constraints for a relationship count query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceQuery(Builder $query, Builder $parentQuery, $columns = ['*'])
+ {
+ return parent::getRelationExistenceQuery($query, $parentQuery, $columns)->where(
+ $this->table.'.'.$this->morphType, $this->morphClass
+ );
+ }
+
+ /**
+ * Create a new query builder for the pivot table.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ protected function newPivotQuery()
+ {
+ return parent::newPivotQuery()->where($this->morphType, $this->morphClass);
+ }
+
+ /**
+ * Create a new pivot model instance.
+ *
+ * @param array $attributes
+ * @param bool $exists
+ * @return \Illuminate\Database\Eloquent\Relations\Pivot
+ */
+ public function newPivot(array $attributes = [], $exists = false)
+ {
+ $using = $this->using;
+
+ $pivot = $using ? $using::fromRawAttributes($this->parent, $attributes, $this->table, $exists)
+ : new MorphPivot($this->parent, $attributes, $this->table, $exists);
+
+ $pivot->setPivotKeys($this->foreignKey, $this->relatedKey)
+ ->setMorphType($this->morphType)
+ ->setMorphClass($this->morphClass);
+
+ return $pivot;
+ }
+
+ /**
+ * Get the foreign key "type" name.
+ *
+ * @return string
+ */
+ public function getMorphType()
+ {
+ return $this->morphType;
+ }
+
+ /**
+ * Get the class name of the parent model.
+ *
+ * @return string
+ */
+ public function getMorphClass()
+ {
+ return $this->morphClass;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Pivot.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Pivot.php
new file mode 100644
index 000000000..84683d8bd
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Pivot.php
@@ -0,0 +1,198 @@
+setConnection($parent->getConnectionName())
+ ->setTable($table)
+ ->forceFill($attributes)
+ ->syncOriginal();
+
+ // We store off the parent instance so we will access the timestamp column names
+ // for the model, since the pivot model timestamps aren't easily configurable
+ // from the developer's point of view. We can use the parents to get these.
+ $this->parent = $parent;
+
+ $this->exists = $exists;
+
+ $this->timestamps = $this->hasTimestampAttributes();
+ }
+
+ /**
+ * Create a new pivot model from raw values returned from a query.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $parent
+ * @param array $attributes
+ * @param string $table
+ * @param bool $exists
+ * @return static
+ */
+ public static function fromRawAttributes(Model $parent, $attributes, $table, $exists = false)
+ {
+ $instance = new static($parent, $attributes, $table, $exists);
+
+ $instance->setRawAttributes($attributes, true);
+
+ return $instance;
+ }
+
+ /**
+ * Set the keys for a save update query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ protected function setKeysForSaveQuery(Builder $query)
+ {
+ $query->where($this->foreignKey, $this->getAttribute($this->foreignKey));
+
+ return $query->where($this->relatedKey, $this->getAttribute($this->relatedKey));
+ }
+
+ /**
+ * Delete the pivot model record from the database.
+ *
+ * @return int
+ */
+ public function delete()
+ {
+ return $this->getDeleteQuery()->delete();
+ }
+
+ /**
+ * Get the query builder for a delete operation on the pivot.
+ *
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ protected function getDeleteQuery()
+ {
+ return $this->newQuery()->where([
+ $this->foreignKey => $this->getAttribute($this->foreignKey),
+ $this->relatedKey => $this->getAttribute($this->relatedKey),
+ ]);
+ }
+
+ /**
+ * Get the foreign key column name.
+ *
+ * @return string
+ */
+ public function getForeignKey()
+ {
+ return $this->foreignKey;
+ }
+
+ /**
+ * Get the "related key" column name.
+ *
+ * @return string
+ */
+ public function getRelatedKey()
+ {
+ return $this->relatedKey;
+ }
+
+ /**
+ * Get the "related key" column name.
+ *
+ * @return string
+ */
+ public function getOtherKey()
+ {
+ return $this->getRelatedKey();
+ }
+
+ /**
+ * Set the key names for the pivot model instance.
+ *
+ * @param string $foreignKey
+ * @param string $relatedKey
+ * @return $this
+ */
+ public function setPivotKeys($foreignKey, $relatedKey)
+ {
+ $this->foreignKey = $foreignKey;
+
+ $this->relatedKey = $relatedKey;
+
+ return $this;
+ }
+
+ /**
+ * Determine if the pivot model has timestamp attributes.
+ *
+ * @return bool
+ */
+ public function hasTimestampAttributes()
+ {
+ return array_key_exists($this->getCreatedAtColumn(), $this->attributes);
+ }
+
+ /**
+ * Get the name of the "created at" column.
+ *
+ * @return string
+ */
+ public function getCreatedAtColumn()
+ {
+ return $this->parent->getCreatedAtColumn();
+ }
+
+ /**
+ * Get the name of the "updated at" column.
+ *
+ * @return string
+ */
+ public function getUpdatedAtColumn()
+ {
+ return $this->parent->getUpdatedAtColumn();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Relation.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Relation.php
new file mode 100644
index 000000000..b4f627153
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/Relation.php
@@ -0,0 +1,374 @@
+query = $query;
+ $this->parent = $parent;
+ $this->related = $query->getModel();
+
+ $this->addConstraints();
+ }
+
+ /**
+ * Run a callback with constraints disabled on the relation.
+ *
+ * @param \Closure $callback
+ * @return mixed
+ */
+ public static function noConstraints(Closure $callback)
+ {
+ $previous = static::$constraints;
+
+ static::$constraints = false;
+
+ // When resetting the relation where clause, we want to shift the first element
+ // off of the bindings, leaving only the constraints that the developers put
+ // as "extra" on the relationships, and not original relation constraints.
+ try {
+ return call_user_func($callback);
+ } finally {
+ static::$constraints = $previous;
+ }
+ }
+
+ /**
+ * Set the base constraints on the relation query.
+ *
+ * @return void
+ */
+ abstract public function addConstraints();
+
+ /**
+ * Set the constraints for an eager load of the relation.
+ *
+ * @param array $models
+ * @return void
+ */
+ abstract public function addEagerConstraints(array $models);
+
+ /**
+ * Initialize the relation on a set of models.
+ *
+ * @param array $models
+ * @param string $relation
+ * @return array
+ */
+ abstract public function initRelation(array $models, $relation);
+
+ /**
+ * Match the eagerly loaded results to their parents.
+ *
+ * @param array $models
+ * @param \Illuminate\Database\Eloquent\Collection $results
+ * @param string $relation
+ * @return array
+ */
+ abstract public function match(array $models, Collection $results, $relation);
+
+ /**
+ * Get the results of the relationship.
+ *
+ * @return mixed
+ */
+ abstract public function getResults();
+
+ /**
+ * Get the relationship for eager loading.
+ *
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ public function getEager()
+ {
+ return $this->get();
+ }
+
+ /**
+ * Touch all of the related models for the relationship.
+ *
+ * @return void
+ */
+ public function touch()
+ {
+ $column = $this->getRelated()->getUpdatedAtColumn();
+
+ $this->rawUpdate([$column => $this->getRelated()->freshTimestampString()]);
+ }
+
+ /**
+ * Run a raw update against the base query.
+ *
+ * @param array $attributes
+ * @return int
+ */
+ public function rawUpdate(array $attributes = [])
+ {
+ return $this->query->update($attributes);
+ }
+
+ /**
+ * Add the constraints for a relationship count query.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceCountQuery(Builder $query, Builder $parentQuery)
+ {
+ return $this->getRelationExistenceQuery(
+ $query, $parentQuery, new Expression('count(*)')
+ );
+ }
+
+ /**
+ * Add the constraints for an internal relationship existence query.
+ *
+ * Essentially, these queries compare on column names like whereColumn.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $query
+ * @param \Illuminate\Database\Eloquent\Builder $parentQuery
+ * @param array|mixed $columns
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getRelationExistenceQuery(Builder $query, Builder $parentQuery, $columns = ['*'])
+ {
+ return $query->select($columns)->whereColumn(
+ $this->getQualifiedParentKeyName(), '=', $this->getExistenceCompareKey()
+ );
+ }
+
+ /**
+ * Get all of the primary keys for an array of models.
+ *
+ * @param array $models
+ * @param string $key
+ * @return array
+ */
+ protected function getKeys(array $models, $key = null)
+ {
+ return collect($models)->map(function ($value) use ($key) {
+ return $key ? $value->getAttribute($key) : $value->getKey();
+ })->values()->unique()->sort()->all();
+ }
+
+ /**
+ * Get the underlying query for the relation.
+ *
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ public function getQuery()
+ {
+ return $this->query;
+ }
+
+ /**
+ * Get the base query builder driving the Eloquent builder.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function getBaseQuery()
+ {
+ return $this->query->getQuery();
+ }
+
+ /**
+ * Get the parent model of the relation.
+ *
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function getParent()
+ {
+ return $this->parent;
+ }
+
+ /**
+ * Get the fully qualified parent key name.
+ *
+ * @return string
+ */
+ public function getQualifiedParentKeyName()
+ {
+ return $this->parent->getQualifiedKeyName();
+ }
+
+ /**
+ * Get the related model of the relation.
+ *
+ * @return \Illuminate\Database\Eloquent\Model
+ */
+ public function getRelated()
+ {
+ return $this->related;
+ }
+
+ /**
+ * Get the name of the "created at" column.
+ *
+ * @return string
+ */
+ public function createdAt()
+ {
+ return $this->parent->getCreatedAtColumn();
+ }
+
+ /**
+ * Get the name of the "updated at" column.
+ *
+ * @return string
+ */
+ public function updatedAt()
+ {
+ return $this->parent->getUpdatedAtColumn();
+ }
+
+ /**
+ * Get the name of the related model's "updated at" column.
+ *
+ * @return string
+ */
+ public function relatedUpdatedAt()
+ {
+ return $this->related->getUpdatedAtColumn();
+ }
+
+ /**
+ * Set or get the morph map for polymorphic relations.
+ *
+ * @param array|null $map
+ * @param bool $merge
+ * @return array
+ */
+ public static function morphMap(array $map = null, $merge = true)
+ {
+ $map = static::buildMorphMapFromModels($map);
+
+ if (is_array($map)) {
+ static::$morphMap = $merge && static::$morphMap
+ ? array_merge(static::$morphMap, $map) : $map;
+ }
+
+ return static::$morphMap;
+ }
+
+ /**
+ * Builds a table-keyed array from model class names.
+ *
+ * @param string[]|null $models
+ * @return array|null
+ */
+ protected static function buildMorphMapFromModels(array $models = null)
+ {
+ if (is_null($models) || Arr::isAssoc($models)) {
+ return $models;
+ }
+
+ return array_combine(array_map(function ($model) {
+ return (new $model)->getTable();
+ }, $models), $models);
+ }
+
+ /**
+ * Get the model associated with a custom polymorphic type.
+ *
+ * @param string $alias
+ * @return string|null
+ */
+ public static function getMorphedModel($alias)
+ {
+ return array_key_exists($alias, self::$morphMap)
+ ? self::$morphMap[$alias]
+ : null;
+ }
+
+ /**
+ * Handle dynamic method calls to the relationship.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ if (static::hasMacro($method)) {
+ return $this->macroCall($method, $parameters);
+ }
+
+ $result = call_user_func_array([$this->query, $method], $parameters);
+
+ if ($result === $this->query) {
+ return $this;
+ }
+
+ return $result;
+ }
+
+ /**
+ * Force a clone of the underlying query builder when cloning.
+ *
+ * @return void
+ */
+ public function __clone()
+ {
+ $this->query = clone $this->query;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Scope.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Scope.php
new file mode 100644
index 000000000..63cba6a51
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/Scope.php
@@ -0,0 +1,15 @@
+forceDeleting = true;
+
+ $deleted = $this->delete();
+
+ $this->forceDeleting = false;
+
+ return $deleted;
+ }
+
+ /**
+ * Perform the actual delete query on this model instance.
+ *
+ * @return mixed
+ */
+ protected function performDeleteOnModel()
+ {
+ if ($this->forceDeleting) {
+ return $this->newQueryWithoutScopes()->where($this->getKeyName(), $this->getKey())->forceDelete();
+ }
+
+ return $this->runSoftDelete();
+ }
+
+ /**
+ * Perform the actual delete query on this model instance.
+ *
+ * @return void
+ */
+ protected function runSoftDelete()
+ {
+ $query = $this->newQueryWithoutScopes()->where($this->getKeyName(), $this->getKey());
+
+ $time = $this->freshTimestamp();
+
+ $columns = [$this->getDeletedAtColumn() => $this->fromDateTime($time)];
+
+ $this->{$this->getDeletedAtColumn()} = $time;
+
+ if ($this->timestamps) {
+ $this->{$this->getUpdatedAtColumn()} = $time;
+
+ $columns[$this->getUpdatedAtColumn()] = $this->fromDateTime($time);
+ }
+
+ $query->update($columns);
+ }
+
+ /**
+ * Restore a soft-deleted model instance.
+ *
+ * @return bool|null
+ */
+ public function restore()
+ {
+ // If the restoring event does not return false, we will proceed with this
+ // restore operation. Otherwise, we bail out so the developer will stop
+ // the restore totally. We will clear the deleted timestamp and save.
+ if ($this->fireModelEvent('restoring') === false) {
+ return false;
+ }
+
+ $this->{$this->getDeletedAtColumn()} = null;
+
+ // Once we have saved the model, we will fire the "restored" event so this
+ // developer will do anything they need to after a restore operation is
+ // totally finished. Then we will return the result of the save call.
+ $this->exists = true;
+
+ $result = $this->save();
+
+ $this->fireModelEvent('restored', false);
+
+ return $result;
+ }
+
+ /**
+ * Determine if the model instance has been soft-deleted.
+ *
+ * @return bool
+ */
+ public function trashed()
+ {
+ return ! is_null($this->{$this->getDeletedAtColumn()});
+ }
+
+ /**
+ * Register a restoring model event with the dispatcher.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public static function restoring($callback)
+ {
+ static::registerModelEvent('restoring', $callback);
+ }
+
+ /**
+ * Register a restored model event with the dispatcher.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public static function restored($callback)
+ {
+ static::registerModelEvent('restored', $callback);
+ }
+
+ /**
+ * Determine if the model is currently force deleting.
+ *
+ * @return bool
+ */
+ public function isForceDeleting()
+ {
+ return $this->forceDeleting;
+ }
+
+ /**
+ * Get the name of the "deleted at" column.
+ *
+ * @return string
+ */
+ public function getDeletedAtColumn()
+ {
+ return defined('static::DELETED_AT') ? static::DELETED_AT : 'deleted_at';
+ }
+
+ /**
+ * Get the fully qualified "deleted at" column.
+ *
+ * @return string
+ */
+ public function getQualifiedDeletedAtColumn()
+ {
+ return $this->getTable().'.'.$this->getDeletedAtColumn();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Eloquent/SoftDeletingScope.php b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/SoftDeletingScope.php
new file mode 100644
index 000000000..6de963ded
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Eloquent/SoftDeletingScope.php
@@ -0,0 +1,127 @@
+whereNull($model->getQualifiedDeletedAtColumn());
+ }
+
+ /**
+ * Extend the query builder with the needed functions.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $builder
+ * @return void
+ */
+ public function extend(Builder $builder)
+ {
+ foreach ($this->extensions as $extension) {
+ $this->{"add{$extension}"}($builder);
+ }
+
+ $builder->onDelete(function (Builder $builder) {
+ $column = $this->getDeletedAtColumn($builder);
+
+ return $builder->update([
+ $column => $builder->getModel()->freshTimestampString(),
+ ]);
+ });
+ }
+
+ /**
+ * Get the "deleted at" column for the builder.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $builder
+ * @return string
+ */
+ protected function getDeletedAtColumn(Builder $builder)
+ {
+ if (count((array) $builder->getQuery()->joins) > 0) {
+ return $builder->getModel()->getQualifiedDeletedAtColumn();
+ }
+
+ return $builder->getModel()->getDeletedAtColumn();
+ }
+
+ /**
+ * Add the restore extension to the builder.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $builder
+ * @return void
+ */
+ protected function addRestore(Builder $builder)
+ {
+ $builder->macro('restore', function (Builder $builder) {
+ $builder->withTrashed();
+
+ return $builder->update([$builder->getModel()->getDeletedAtColumn() => null]);
+ });
+ }
+
+ /**
+ * Add the with-trashed extension to the builder.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $builder
+ * @return void
+ */
+ protected function addWithTrashed(Builder $builder)
+ {
+ $builder->macro('withTrashed', function (Builder $builder) {
+ return $builder->withoutGlobalScope($this);
+ });
+ }
+
+ /**
+ * Add the without-trashed extension to the builder.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $builder
+ * @return void
+ */
+ protected function addWithoutTrashed(Builder $builder)
+ {
+ $builder->macro('withoutTrashed', function (Builder $builder) {
+ $model = $builder->getModel();
+
+ $builder->withoutGlobalScope($this)->whereNull(
+ $model->getQualifiedDeletedAtColumn()
+ );
+
+ return $builder;
+ });
+ }
+
+ /**
+ * Add the only-trashed extension to the builder.
+ *
+ * @param \Illuminate\Database\Eloquent\Builder $builder
+ * @return void
+ */
+ protected function addOnlyTrashed(Builder $builder)
+ {
+ $builder->macro('onlyTrashed', function (Builder $builder) {
+ $model = $builder->getModel();
+
+ $builder->withoutGlobalScope($this)->whereNotNull(
+ $model->getQualifiedDeletedAtColumn()
+ );
+
+ return $builder;
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Events/ConnectionEvent.php b/vendor/laravel/framework/src/Illuminate/Database/Events/ConnectionEvent.php
new file mode 100644
index 000000000..818c7850f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Events/ConnectionEvent.php
@@ -0,0 +1,32 @@
+connection = $connection;
+ $this->connectionName = $connection->getName();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Events/QueryExecuted.php b/vendor/laravel/framework/src/Illuminate/Database/Events/QueryExecuted.php
new file mode 100644
index 000000000..d53473f8b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Events/QueryExecuted.php
@@ -0,0 +1,58 @@
+sql = $sql;
+ $this->time = $time;
+ $this->bindings = $bindings;
+ $this->connection = $connection;
+ $this->connectionName = $connection->getName();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Events/StatementPrepared.php b/vendor/laravel/framework/src/Illuminate/Database/Events/StatementPrepared.php
new file mode 100644
index 000000000..2f603235d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Events/StatementPrepared.php
@@ -0,0 +1,33 @@
+statement = $statement;
+ $this->connection = $connection;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Events/TransactionBeginning.php b/vendor/laravel/framework/src/Illuminate/Database/Events/TransactionBeginning.php
new file mode 100644
index 000000000..3287b5c8d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Events/TransactionBeginning.php
@@ -0,0 +1,8 @@
+isExpression($table)) {
+ return $this->wrap($this->tablePrefix.$table, true);
+ }
+
+ return $this->getValue($table);
+ }
+
+ /**
+ * Wrap a value in keyword identifiers.
+ *
+ * @param \Illuminate\Database\Query\Expression|string $value
+ * @param bool $prefixAlias
+ * @return string
+ */
+ public function wrap($value, $prefixAlias = false)
+ {
+ if ($this->isExpression($value)) {
+ return $this->getValue($value);
+ }
+
+ // If the value being wrapped has a column alias we will need to separate out
+ // the pieces so we can wrap each of the segments of the expression on it
+ // own, and then joins them both back together with the "as" connector.
+ if (strpos(strtolower($value), ' as ') !== false) {
+ return $this->wrapAliasedValue($value, $prefixAlias);
+ }
+
+ return $this->wrapSegments(explode('.', $value));
+ }
+
+ /**
+ * Wrap a value that has an alias.
+ *
+ * @param string $value
+ * @param bool $prefixAlias
+ * @return string
+ */
+ protected function wrapAliasedValue($value, $prefixAlias = false)
+ {
+ $segments = preg_split('/\s+as\s+/i', $value);
+
+ // If we are wrapping a table we need to prefix the alias with the table prefix
+ // as well in order to generate proper syntax. If this is a column of course
+ // no prefix is necessary. The condition will be true when from wrapTable.
+ if ($prefixAlias) {
+ $segments[1] = $this->tablePrefix.$segments[1];
+ }
+
+ return $this->wrap(
+ $segments[0]).' as '.$this->wrapValue($segments[1]
+ );
+ }
+
+ /**
+ * Wrap the given value segments.
+ *
+ * @param array $segments
+ * @return string
+ */
+ protected function wrapSegments($segments)
+ {
+ return collect($segments)->map(function ($segment, $key) use ($segments) {
+ return $key == 0 && count($segments) > 1
+ ? $this->wrapTable($segment)
+ : $this->wrapValue($segment);
+ })->implode('.');
+ }
+
+ /**
+ * Wrap a single string in keyword identifiers.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function wrapValue($value)
+ {
+ if ($value !== '*') {
+ return '"'.str_replace('"', '""', $value).'"';
+ }
+
+ return $value;
+ }
+
+ /**
+ * Convert an array of column names into a delimited string.
+ *
+ * @param array $columns
+ * @return string
+ */
+ public function columnize(array $columns)
+ {
+ return implode(', ', array_map([$this, 'wrap'], $columns));
+ }
+
+ /**
+ * Create query parameter place-holders for an array.
+ *
+ * @param array $values
+ * @return string
+ */
+ public function parameterize(array $values)
+ {
+ return implode(', ', array_map([$this, 'parameter'], $values));
+ }
+
+ /**
+ * Get the appropriate query parameter place-holder for a value.
+ *
+ * @param mixed $value
+ * @return string
+ */
+ public function parameter($value)
+ {
+ return $this->isExpression($value) ? $this->getValue($value) : '?';
+ }
+
+ /**
+ * Determine if the given value is a raw expression.
+ *
+ * @param mixed $value
+ * @return bool
+ */
+ public function isExpression($value)
+ {
+ return $value instanceof Expression;
+ }
+
+ /**
+ * Get the value of a raw expression.
+ *
+ * @param \Illuminate\Database\Query\Expression $expression
+ * @return string
+ */
+ public function getValue($expression)
+ {
+ return $expression->getValue();
+ }
+
+ /**
+ * Get the format for database stored dates.
+ *
+ * @return string
+ */
+ public function getDateFormat()
+ {
+ return 'Y-m-d H:i:s';
+ }
+
+ /**
+ * Get the grammar's table prefix.
+ *
+ * @return string
+ */
+ public function getTablePrefix()
+ {
+ return $this->tablePrefix;
+ }
+
+ /**
+ * Set the grammar's table prefix.
+ *
+ * @param string $prefix
+ * @return $this
+ */
+ public function setTablePrefix($prefix)
+ {
+ $this->tablePrefix = $prefix;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/MigrationServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Database/MigrationServiceProvider.php
new file mode 100644
index 000000000..a8b92ab6e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/MigrationServiceProvider.php
@@ -0,0 +1,87 @@
+registerRepository();
+
+ $this->registerMigrator();
+
+ $this->registerCreator();
+ }
+
+ /**
+ * Register the migration repository service.
+ *
+ * @return void
+ */
+ protected function registerRepository()
+ {
+ $this->app->singleton('migration.repository', function ($app) {
+ $table = $app['config']['database.migrations'];
+
+ return new DatabaseMigrationRepository($app['db'], $table);
+ });
+ }
+
+ /**
+ * Register the migrator service.
+ *
+ * @return void
+ */
+ protected function registerMigrator()
+ {
+ // The migrator is responsible for actually running and rollback the migration
+ // files in the application. We'll pass in our database connection resolver
+ // so the migrator can resolve any of these connections when it needs to.
+ $this->app->singleton('migrator', function ($app) {
+ $repository = $app['migration.repository'];
+
+ return new Migrator($repository, $app['db'], $app['files']);
+ });
+ }
+
+ /**
+ * Register the migration creator.
+ *
+ * @return void
+ */
+ protected function registerCreator()
+ {
+ $this->app->singleton('migration.creator', function ($app) {
+ return new MigrationCreator($app['files']);
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return [
+ 'migrator', 'migration.repository', 'migration.creator',
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Migrations/DatabaseMigrationRepository.php b/vendor/laravel/framework/src/Illuminate/Database/Migrations/DatabaseMigrationRepository.php
new file mode 100644
index 000000000..726cbda0d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Migrations/DatabaseMigrationRepository.php
@@ -0,0 +1,197 @@
+table = $table;
+ $this->resolver = $resolver;
+ }
+
+ /**
+ * Get the ran migrations.
+ *
+ * @return array
+ */
+ public function getRan()
+ {
+ return $this->table()
+ ->orderBy('batch', 'asc')
+ ->orderBy('migration', 'asc')
+ ->pluck('migration')->all();
+ }
+
+ /**
+ * Get list of migrations.
+ *
+ * @param int $steps
+ * @return array
+ */
+ public function getMigrations($steps)
+ {
+ $query = $this->table()->where('batch', '>=', '1');
+
+ return $query->orderBy('migration', 'desc')->take($steps)->get()->all();
+ }
+
+ /**
+ * Get the last migration batch.
+ *
+ * @return array
+ */
+ public function getLast()
+ {
+ $query = $this->table()->where('batch', $this->getLastBatchNumber());
+
+ return $query->orderBy('migration', 'desc')->get()->all();
+ }
+
+ /**
+ * Log that a migration was run.
+ *
+ * @param string $file
+ * @param int $batch
+ * @return void
+ */
+ public function log($file, $batch)
+ {
+ $record = ['migration' => $file, 'batch' => $batch];
+
+ $this->table()->insert($record);
+ }
+
+ /**
+ * Remove a migration from the log.
+ *
+ * @param object $migration
+ * @return void
+ */
+ public function delete($migration)
+ {
+ $this->table()->where('migration', $migration->migration)->delete();
+ }
+
+ /**
+ * Get the next migration batch number.
+ *
+ * @return int
+ */
+ public function getNextBatchNumber()
+ {
+ return $this->getLastBatchNumber() + 1;
+ }
+
+ /**
+ * Get the last migration batch number.
+ *
+ * @return int
+ */
+ public function getLastBatchNumber()
+ {
+ return $this->table()->max('batch');
+ }
+
+ /**
+ * Create the migration repository data store.
+ *
+ * @return void
+ */
+ public function createRepository()
+ {
+ $schema = $this->getConnection()->getSchemaBuilder();
+
+ $schema->create($this->table, function ($table) {
+ // The migrations table is responsible for keeping track of which of the
+ // migrations have actually run for the application. We'll create the
+ // table to hold the migration file's path as well as the batch ID.
+ $table->increments('id');
+ $table->string('migration');
+ $table->integer('batch');
+ });
+ }
+
+ /**
+ * Determine if the migration repository exists.
+ *
+ * @return bool
+ */
+ public function repositoryExists()
+ {
+ $schema = $this->getConnection()->getSchemaBuilder();
+
+ return $schema->hasTable($this->table);
+ }
+
+ /**
+ * Get a query builder for the migration table.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ protected function table()
+ {
+ return $this->getConnection()->table($this->table)->useWritePdo();
+ }
+
+ /**
+ * Get the connection resolver instance.
+ *
+ * @return \Illuminate\Database\ConnectionResolverInterface
+ */
+ public function getConnectionResolver()
+ {
+ return $this->resolver;
+ }
+
+ /**
+ * Resolve the database connection instance.
+ *
+ * @return \Illuminate\Database\Connection
+ */
+ public function getConnection()
+ {
+ return $this->resolver->connection($this->connection);
+ }
+
+ /**
+ * Set the information source to gather data.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setSource($name)
+ {
+ $this->connection = $name;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Migrations/Migration.php b/vendor/laravel/framework/src/Illuminate/Database/Migrations/Migration.php
new file mode 100644
index 000000000..699154c9a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Migrations/Migration.php
@@ -0,0 +1,23 @@
+connection;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Migrations/MigrationCreator.php b/vendor/laravel/framework/src/Illuminate/Database/Migrations/MigrationCreator.php
new file mode 100644
index 000000000..29bae7add
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Migrations/MigrationCreator.php
@@ -0,0 +1,204 @@
+files = $files;
+ }
+
+ /**
+ * Create a new migration at the given path.
+ *
+ * @param string $name
+ * @param string $path
+ * @param string $table
+ * @param bool $create
+ * @return string
+ * @throws \Exception
+ */
+ public function create($name, $path, $table = null, $create = false)
+ {
+ $this->ensureMigrationDoesntAlreadyExist($name);
+
+ // First we will get the stub file for the migration, which serves as a type
+ // of template for the migration. Once we have those we will populate the
+ // various place-holders, save the file, and run the post create event.
+ $stub = $this->getStub($table, $create);
+
+ $this->files->put(
+ $path = $this->getPath($name, $path),
+ $this->populateStub($name, $stub, $table)
+ );
+
+ // Next, we will fire any hooks that are supposed to fire after a migration is
+ // created. Once that is done we'll be ready to return the full path to the
+ // migration file so it can be used however it's needed by the developer.
+ $this->firePostCreateHooks();
+
+ return $path;
+ }
+
+ /**
+ * Ensure that a migration with the given name doesn't already exist.
+ *
+ * @param string $name
+ * @return void
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function ensureMigrationDoesntAlreadyExist($name)
+ {
+ if (class_exists($className = $this->getClassName($name))) {
+ throw new InvalidArgumentException("A {$className} migration already exists.");
+ }
+ }
+
+ /**
+ * Get the migration stub file.
+ *
+ * @param string $table
+ * @param bool $create
+ * @return string
+ */
+ protected function getStub($table, $create)
+ {
+ if (is_null($table)) {
+ return $this->files->get($this->stubPath().'/blank.stub');
+ }
+
+ // We also have stubs for creating new tables and modifying existing tables
+ // to save the developer some typing when they are creating a new tables
+ // or modifying existing tables. We'll grab the appropriate stub here.
+ else {
+ $stub = $create ? 'create.stub' : 'update.stub';
+
+ return $this->files->get($this->stubPath()."/{$stub}");
+ }
+ }
+
+ /**
+ * Populate the place-holders in the migration stub.
+ *
+ * @param string $name
+ * @param string $stub
+ * @param string $table
+ * @return string
+ */
+ protected function populateStub($name, $stub, $table)
+ {
+ $stub = str_replace('DummyClass', $this->getClassName($name), $stub);
+
+ // Here we will replace the table place-holders with the table specified by
+ // the developer, which is useful for quickly creating a tables creation
+ // or update migration from the console instead of typing it manually.
+ if (! is_null($table)) {
+ $stub = str_replace('DummyTable', $table, $stub);
+ }
+
+ return $stub;
+ }
+
+ /**
+ * Get the class name of a migration name.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function getClassName($name)
+ {
+ return Str::studly($name);
+ }
+
+ /**
+ * Get the full path to the migration.
+ *
+ * @param string $name
+ * @param string $path
+ * @return string
+ */
+ protected function getPath($name, $path)
+ {
+ return $path.'/'.$this->getDatePrefix().'_'.$name.'.php';
+ }
+
+ /**
+ * Fire the registered post create hooks.
+ *
+ * @return void
+ */
+ protected function firePostCreateHooks()
+ {
+ foreach ($this->postCreate as $callback) {
+ call_user_func($callback);
+ }
+ }
+
+ /**
+ * Register a post migration create hook.
+ *
+ * @param \Closure $callback
+ * @return void
+ */
+ public function afterCreate(Closure $callback)
+ {
+ $this->postCreate[] = $callback;
+ }
+
+ /**
+ * Get the date prefix for the migration.
+ *
+ * @return string
+ */
+ protected function getDatePrefix()
+ {
+ return date('Y_m_d_His');
+ }
+
+ /**
+ * Get the path to the stubs.
+ *
+ * @return string
+ */
+ public function stubPath()
+ {
+ return __DIR__.'/stubs';
+ }
+
+ /**
+ * Get the filesystem instance.
+ *
+ * @return \Illuminate\Filesystem\Filesystem
+ */
+ public function getFilesystem()
+ {
+ return $this->files;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Migrations/MigrationRepositoryInterface.php b/vendor/laravel/framework/src/Illuminate/Database/Migrations/MigrationRepositoryInterface.php
new file mode 100644
index 000000000..60bc921f8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Migrations/MigrationRepositoryInterface.php
@@ -0,0 +1,74 @@
+files = $files;
+ $this->resolver = $resolver;
+ $this->repository = $repository;
+ }
+
+ /**
+ * Run the pending migrations at a given path.
+ *
+ * @param array|string $paths
+ * @param array $options
+ * @return array
+ */
+ public function run($paths = [], array $options = [])
+ {
+ $this->notes = [];
+
+ // Once we grab all of the migration files for the path, we will compare them
+ // against the migrations that have already been run for this package then
+ // run each of the outstanding migrations against a database connection.
+ $files = $this->getMigrationFiles($paths);
+
+ $this->requireFiles($migrations = $this->pendingMigrations(
+ $files, $this->repository->getRan()
+ ));
+
+ // Once we have all these migrations that are outstanding we are ready to run
+ // we will go ahead and run them "up". This will execute each migration as
+ // an operation against a database. Then we'll return this list of them.
+ $this->runPending($migrations, $options);
+
+ return $migrations;
+ }
+
+ /**
+ * Get the migration files that have not yet run.
+ *
+ * @param array $files
+ * @param array $ran
+ * @return array
+ */
+ protected function pendingMigrations($files, $ran)
+ {
+ return Collection::make($files)
+ ->reject(function ($file) use ($ran) {
+ return in_array($this->getMigrationName($file), $ran);
+ })->values()->all();
+ }
+
+ /**
+ * Run an array of migrations.
+ *
+ * @param array $migrations
+ * @param array $options
+ * @return void
+ */
+ public function runPending(array $migrations, array $options = [])
+ {
+ // First we will just make sure that there are any migrations to run. If there
+ // aren't, we will just make a note of it to the developer so they're aware
+ // that all of the migrations have been run against this database system.
+ if (count($migrations) == 0) {
+ $this->note('Nothing to migrate. ');
+
+ return;
+ }
+
+ // Next, we will get the next batch number for the migrations so we can insert
+ // correct batch number in the database migrations repository when we store
+ // each migration's execution. We will also extract a few of the options.
+ $batch = $this->repository->getNextBatchNumber();
+
+ $pretend = Arr::get($options, 'pretend', false);
+
+ $step = Arr::get($options, 'step', false);
+
+ // Once we have the array of migrations, we will spin through them and run the
+ // migrations "up" so the changes are made to the databases. We'll then log
+ // that the migration was run so we don't repeat it next time we execute.
+ foreach ($migrations as $file) {
+ $this->runUp($file, $batch, $pretend);
+
+ if ($step) {
+ $batch++;
+ }
+ }
+ }
+
+ /**
+ * Run "up" a migration instance.
+ *
+ * @param string $file
+ * @param int $batch
+ * @param bool $pretend
+ * @return void
+ */
+ protected function runUp($file, $batch, $pretend)
+ {
+ // First we will resolve a "real" instance of the migration class from this
+ // migration file name. Once we have the instances we can run the actual
+ // command such as "up" or "down", or we can just simulate the action.
+ $migration = $this->resolve(
+ $name = $this->getMigrationName($file)
+ );
+
+ if ($pretend) {
+ return $this->pretendToRun($migration, 'up');
+ }
+
+ $this->note("Migrating: {$name}");
+
+ $this->runMigration($migration, 'up');
+
+ // Once we have run a migrations class, we will log that it was run in this
+ // repository so that we don't try to run it next time we do a migration
+ // in the application. A migration repository keeps the migrate order.
+ $this->repository->log($name, $batch);
+
+ $this->note("Migrated: {$name}");
+ }
+
+ /**
+ * Rollback the last migration operation.
+ *
+ * @param array|string $paths
+ * @param array $options
+ * @return array
+ */
+ public function rollback($paths = [], array $options = [])
+ {
+ $this->notes = [];
+
+ // We want to pull in the last batch of migrations that ran on the previous
+ // migration operation. We'll then reverse those migrations and run each
+ // of them "down" to reverse the last migration "operation" which ran.
+ $migrations = $this->getMigrationsForRollback($options);
+
+ if (count($migrations) === 0) {
+ $this->note('Nothing to rollback. ');
+
+ return [];
+ } else {
+ return $this->rollbackMigrations($migrations, $paths, $options);
+ }
+ }
+
+ /**
+ * Get the migrations for a rollback operation.
+ *
+ * @param array $options
+ * @return array
+ */
+ protected function getMigrationsForRollback(array $options)
+ {
+ if (($steps = Arr::get($options, 'step', 0)) > 0) {
+ return $this->repository->getMigrations($steps);
+ } else {
+ return $this->repository->getLast();
+ }
+ }
+
+ /**
+ * Rollback the given migrations.
+ *
+ * @param array $migrations
+ * @param array|string $paths
+ * @param array $options
+ * @return array
+ */
+ protected function rollbackMigrations(array $migrations, $paths, array $options)
+ {
+ $rolledBack = [];
+
+ $this->requireFiles($files = $this->getMigrationFiles($paths));
+
+ // Next we will run through all of the migrations and call the "down" method
+ // which will reverse each migration in order. This getLast method on the
+ // repository already returns these migration's names in reverse order.
+ foreach ($migrations as $migration) {
+ $migration = (object) $migration;
+
+ if (! $file = Arr::get($files, $migration->migration)) {
+ $this->note("Migration not found:> {$migration->migration}");
+
+ continue;
+ }
+
+ $rolledBack[] = $file;
+
+ $this->runDown(
+ $file, $migration,
+ Arr::get($options, 'pretend', false)
+ );
+ }
+
+ return $rolledBack;
+ }
+
+ /**
+ * Rolls all of the currently applied migrations back.
+ *
+ * @param array|string $paths
+ * @param bool $pretend
+ * @return array
+ */
+ public function reset($paths = [], $pretend = false)
+ {
+ $this->notes = [];
+
+ // Next, we will reverse the migration list so we can run them back in the
+ // correct order for resetting this database. This will allow us to get
+ // the database back into its "empty" state ready for the migrations.
+ $migrations = array_reverse($this->repository->getRan());
+
+ if (count($migrations) === 0) {
+ $this->note('Nothing to rollback. ');
+
+ return [];
+ } else {
+ return $this->resetMigrations($migrations, $paths, $pretend);
+ }
+ }
+
+ /**
+ * Reset the given migrations.
+ *
+ * @param array $migrations
+ * @param array $paths
+ * @param bool $pretend
+ * @return array
+ */
+ protected function resetMigrations(array $migrations, array $paths, $pretend = false)
+ {
+ // Since the getRan method that retrieves the migration name just gives us the
+ // migration name, we will format the names into objects with the name as a
+ // property on the objects so that we can pass it to the rollback method.
+ $migrations = collect($migrations)->map(function ($m) {
+ return (object) ['migration' => $m];
+ })->all();
+
+ return $this->rollbackMigrations(
+ $migrations, $paths, compact('pretend')
+ );
+ }
+
+ /**
+ * Run "down" a migration instance.
+ *
+ * @param string $file
+ * @param object $migration
+ * @param bool $pretend
+ * @return void
+ */
+ protected function runDown($file, $migration, $pretend)
+ {
+ // First we will get the file name of the migration so we can resolve out an
+ // instance of the migration. Once we get an instance we can either run a
+ // pretend execution of the migration or we can run the real migration.
+ $instance = $this->resolve(
+ $name = $this->getMigrationName($file)
+ );
+
+ $this->note("Rolling back: {$name}");
+
+ if ($pretend) {
+ return $this->pretendToRun($instance, 'down');
+ }
+
+ $this->runMigration($instance, 'down');
+
+ // Once we have successfully run the migration "down" we will remove it from
+ // the migration repository so it will be considered to have not been run
+ // by the application then will be able to fire by any later operation.
+ $this->repository->delete($migration);
+
+ $this->note("Rolled back: {$name}");
+ }
+
+ /**
+ * Run a migration inside a transaction if the database supports it.
+ *
+ * @param object $migration
+ * @param string $method
+ * @return void
+ */
+ protected function runMigration($migration, $method)
+ {
+ $connection = $this->resolveConnection(
+ $migration->getConnection()
+ );
+
+ $callback = function () use ($migration, $method) {
+ if (method_exists($migration, $method)) {
+ $migration->{$method}();
+ }
+ };
+
+ $this->getSchemaGrammar($connection)->supportsSchemaTransactions()
+ ? $connection->transaction($callback)
+ : $callback();
+ }
+
+ /**
+ * Pretend to run the migrations.
+ *
+ * @param object $migration
+ * @param string $method
+ * @return void
+ */
+ protected function pretendToRun($migration, $method)
+ {
+ foreach ($this->getQueries($migration, $method) as $query) {
+ $name = get_class($migration);
+
+ $this->note("{$name}: {$query['query']}");
+ }
+ }
+
+ /**
+ * Get all of the queries that would be run for a migration.
+ *
+ * @param object $migration
+ * @param string $method
+ * @return array
+ */
+ protected function getQueries($migration, $method)
+ {
+ // Now that we have the connections we can resolve it and pretend to run the
+ // queries against the database returning the array of raw SQL statements
+ // that would get fired against the database system for this migration.
+ $db = $this->resolveConnection(
+ $connection = $migration->getConnection()
+ );
+
+ return $db->pretend(function () use ($migration, $method) {
+ if (method_exists($migration, $method)) {
+ $migration->{$method}();
+ }
+ });
+ }
+
+ /**
+ * Resolve a migration instance from a file.
+ *
+ * @param string $file
+ * @return object
+ */
+ public function resolve($file)
+ {
+ $class = Str::studly(implode('_', array_slice(explode('_', $file), 4)));
+
+ return new $class;
+ }
+
+ /**
+ * Get all of the migration files in a given path.
+ *
+ * @param string|array $paths
+ * @return array
+ */
+ public function getMigrationFiles($paths)
+ {
+ return Collection::make($paths)->flatMap(function ($path) {
+ return $this->files->glob($path.'/*_*.php');
+ })->filter()->sortBy(function ($file) {
+ return $this->getMigrationName($file);
+ })->values()->keyBy(function ($file) {
+ return $this->getMigrationName($file);
+ })->all();
+ }
+
+ /**
+ * Require in all the migration files in a given path.
+ *
+ * @param array $files
+ * @return void
+ */
+ public function requireFiles(array $files)
+ {
+ foreach ($files as $file) {
+ $this->files->requireOnce($file);
+ }
+ }
+
+ /**
+ * Get the name of the migration.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function getMigrationName($path)
+ {
+ return str_replace('.php', '', basename($path));
+ }
+
+ /**
+ * Register a custom migration path.
+ *
+ * @param string $path
+ * @return void
+ */
+ public function path($path)
+ {
+ $this->paths = array_unique(array_merge($this->paths, [$path]));
+ }
+
+ /**
+ * Get all of the custom migration paths.
+ *
+ * @return array
+ */
+ public function paths()
+ {
+ return $this->paths;
+ }
+
+ /**
+ * Set the default connection name.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setConnection($name)
+ {
+ if (! is_null($name)) {
+ $this->resolver->setDefaultConnection($name);
+ }
+
+ $this->repository->setSource($name);
+
+ $this->connection = $name;
+ }
+
+ /**
+ * Resolve the database connection instance.
+ *
+ * @param string $connection
+ * @return \Illuminate\Database\Connection
+ */
+ public function resolveConnection($connection)
+ {
+ return $this->resolver->connection($connection ?: $this->connection);
+ }
+
+ /**
+ * Get the schema grammar out of a migration connection.
+ *
+ * @param \Illuminate\Database\Connection $connection
+ * @return \Illuminate\Database\Schema\Grammars\Grammar
+ */
+ protected function getSchemaGrammar($connection)
+ {
+ if (is_null($grammar = $connection->getSchemaGrammar())) {
+ $connection->useDefaultSchemaGrammar();
+
+ $grammar = $connection->getSchemaGrammar();
+ }
+
+ return $grammar;
+ }
+
+ /**
+ * Get the migration repository instance.
+ *
+ * @return \Illuminate\Database\Migrations\MigrationRepositoryInterface
+ */
+ public function getRepository()
+ {
+ return $this->repository;
+ }
+
+ /**
+ * Determine if the migration repository exists.
+ *
+ * @return bool
+ */
+ public function repositoryExists()
+ {
+ return $this->repository->repositoryExists();
+ }
+
+ /**
+ * Get the file system instance.
+ *
+ * @return \Illuminate\Filesystem\Filesystem
+ */
+ public function getFilesystem()
+ {
+ return $this->files;
+ }
+
+ /**
+ * Raise a note event for the migrator.
+ *
+ * @param string $message
+ * @return void
+ */
+ protected function note($message)
+ {
+ $this->notes[] = $message;
+ }
+
+ /**
+ * Get the notes for the last operation.
+ *
+ * @return array
+ */
+ public function getNotes()
+ {
+ return $this->notes;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Migrations/stubs/blank.stub b/vendor/laravel/framework/src/Illuminate/Database/Migrations/stubs/blank.stub
new file mode 100644
index 000000000..da4ce827a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Migrations/stubs/blank.stub
@@ -0,0 +1,28 @@
+increments('id');
+ $table->timestamps();
+ });
+ }
+
+ /**
+ * Reverse the migrations.
+ *
+ * @return void
+ */
+ public function down()
+ {
+ Schema::dropIfExists('DummyTable');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Migrations/stubs/update.stub b/vendor/laravel/framework/src/Illuminate/Database/Migrations/stubs/update.stub
new file mode 100644
index 000000000..1fd4f6ec0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Migrations/stubs/update.stub
@@ -0,0 +1,32 @@
+withTablePrefix(new QueryGrammar);
+ }
+
+ /**
+ * Get a schema builder instance for the connection.
+ *
+ * @return \Illuminate\Database\Schema\MySqlBuilder
+ */
+ public function getSchemaBuilder()
+ {
+ if (is_null($this->schemaGrammar)) {
+ $this->useDefaultSchemaGrammar();
+ }
+
+ return new MySqlBuilder($this);
+ }
+
+ /**
+ * Get the default schema grammar instance.
+ *
+ * @return \Illuminate\Database\Schema\Grammars\MySqlGrammar
+ */
+ protected function getDefaultSchemaGrammar()
+ {
+ return $this->withTablePrefix(new SchemaGrammar);
+ }
+
+ /**
+ * Get the default post processor instance.
+ *
+ * @return \Illuminate\Database\Query\Processors\MySqlProcessor
+ */
+ protected function getDefaultPostProcessor()
+ {
+ return new MySqlProcessor;
+ }
+
+ /**
+ * Get the Doctrine DBAL driver.
+ *
+ * @return \Doctrine\DBAL\Driver\PDOMySql\Driver
+ */
+ protected function getDoctrineDriver()
+ {
+ return new DoctrineDriver;
+ }
+
+ /**
+ * Bind values to their parameters in the given statement.
+ *
+ * @param \PDOStatement $statement
+ * @param array $bindings
+ * @return void
+ */
+ public function bindValues($statement, $bindings)
+ {
+ foreach ($bindings as $key => $value) {
+ $statement->bindValue(
+ is_string($key) ? $key : $key + 1, $value,
+ is_int($value) || is_float($value) ? PDO::PARAM_INT : PDO::PARAM_STR
+ );
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/PostgresConnection.php b/vendor/laravel/framework/src/Illuminate/Database/PostgresConnection.php
new file mode 100644
index 000000000..01804a7b8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/PostgresConnection.php
@@ -0,0 +1,66 @@
+withTablePrefix(new QueryGrammar);
+ }
+
+ /**
+ * Get a schema builder instance for the connection.
+ *
+ * @return \Illuminate\Database\Schema\PostgresBuilder
+ */
+ public function getSchemaBuilder()
+ {
+ if (is_null($this->schemaGrammar)) {
+ $this->useDefaultSchemaGrammar();
+ }
+
+ return new PostgresBuilder($this);
+ }
+
+ /**
+ * Get the default schema grammar instance.
+ *
+ * @return \Illuminate\Database\Schema\Grammars\PostgresGrammar
+ */
+ protected function getDefaultSchemaGrammar()
+ {
+ return $this->withTablePrefix(new SchemaGrammar);
+ }
+
+ /**
+ * Get the default post processor instance.
+ *
+ * @return \Illuminate\Database\Query\Processors\PostgresProcessor
+ */
+ protected function getDefaultPostProcessor()
+ {
+ return new PostgresProcessor;
+ }
+
+ /**
+ * Get the Doctrine DBAL driver.
+ *
+ * @return \Doctrine\DBAL\Driver\PDOPgSql\Driver
+ */
+ protected function getDoctrineDriver()
+ {
+ return new DoctrineDriver;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Builder.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Builder.php
new file mode 100644
index 000000000..c57d73d52
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Builder.php
@@ -0,0 +1,2447 @@
+ [],
+ 'join' => [],
+ 'where' => [],
+ 'having' => [],
+ 'order' => [],
+ 'union' => [],
+ ];
+
+ /**
+ * An aggregate function and column to be run.
+ *
+ * @var array
+ */
+ public $aggregate;
+
+ /**
+ * The columns that should be returned.
+ *
+ * @var array
+ */
+ public $columns;
+
+ /**
+ * Indicates if the query returns distinct results.
+ *
+ * @var bool
+ */
+ public $distinct = false;
+
+ /**
+ * The table which the query is targeting.
+ *
+ * @var string
+ */
+ public $from;
+
+ /**
+ * The table joins for the query.
+ *
+ * @var array
+ */
+ public $joins;
+
+ /**
+ * The where constraints for the query.
+ *
+ * @var array
+ */
+ public $wheres = [];
+
+ /**
+ * The groupings for the query.
+ *
+ * @var array
+ */
+ public $groups;
+
+ /**
+ * The having constraints for the query.
+ *
+ * @var array
+ */
+ public $havings;
+
+ /**
+ * The orderings for the query.
+ *
+ * @var array
+ */
+ public $orders;
+
+ /**
+ * The maximum number of records to return.
+ *
+ * @var int
+ */
+ public $limit;
+
+ /**
+ * The number of records to skip.
+ *
+ * @var int
+ */
+ public $offset;
+
+ /**
+ * The query union statements.
+ *
+ * @var array
+ */
+ public $unions;
+
+ /**
+ * The maximum number of union records to return.
+ *
+ * @var int
+ */
+ public $unionLimit;
+
+ /**
+ * The number of union records to skip.
+ *
+ * @var int
+ */
+ public $unionOffset;
+
+ /**
+ * The orderings for the union query.
+ *
+ * @var array
+ */
+ public $unionOrders;
+
+ /**
+ * Indicates whether row locking is being used.
+ *
+ * @var string|bool
+ */
+ public $lock;
+
+ /**
+ * All of the available clause operators.
+ *
+ * @var array
+ */
+ public $operators = [
+ '=', '<', '>', '<=', '>=', '<>', '!=', '<=>',
+ 'like', 'like binary', 'not like', 'between', 'ilike',
+ '&', '|', '^', '<<', '>>',
+ 'rlike', 'regexp', 'not regexp',
+ '~', '~*', '!~', '!~*', 'similar to',
+ 'not similar to', 'not ilike', '~~*', '!~~*',
+ ];
+
+ /**
+ * Whether use write pdo for select.
+ *
+ * @var bool
+ */
+ public $useWritePdo = false;
+
+ /**
+ * Create a new query builder instance.
+ *
+ * @param \Illuminate\Database\ConnectionInterface $connection
+ * @param \Illuminate\Database\Query\Grammars\Grammar $grammar
+ * @param \Illuminate\Database\Query\Processors\Processor $processor
+ * @return void
+ */
+ public function __construct(ConnectionInterface $connection,
+ Grammar $grammar = null,
+ Processor $processor = null)
+ {
+ $this->connection = $connection;
+ $this->grammar = $grammar ?: $connection->getQueryGrammar();
+ $this->processor = $processor ?: $connection->getPostProcessor();
+ }
+
+ /**
+ * Set the columns to be selected.
+ *
+ * @param array|mixed $columns
+ * @return $this
+ */
+ public function select($columns = ['*'])
+ {
+ $this->columns = is_array($columns) ? $columns : func_get_args();
+
+ return $this;
+ }
+
+ /**
+ * Add a new "raw" select expression to the query.
+ *
+ * @param string $expression
+ * @param array $bindings
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function selectRaw($expression, array $bindings = [])
+ {
+ $this->addSelect(new Expression($expression));
+
+ if ($bindings) {
+ $this->addBinding($bindings, 'select');
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a subselect expression to the query.
+ *
+ * @param \Closure|\Illuminate\Database\Query\Builder|string $query
+ * @param string $as
+ * @return \Illuminate\Database\Query\Builder|static
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function selectSub($query, $as)
+ {
+ // If the given query is a Closure, we will execute it while passing in a new
+ // query instance to the Closure. This will give the developer a chance to
+ // format and work with the query before we cast it to a raw SQL string.
+ if ($query instanceof Closure) {
+ $callback = $query;
+
+ $callback($query = $this->newQuery());
+ }
+
+ // Here, we will parse this query into an SQL string and an array of bindings
+ // so we can add it to the query builder using the selectRaw method so the
+ // query is included in the real SQL generated by this builder instance.
+ list($query, $bindings) = $this->parseSubSelect($query);
+
+ return $this->selectRaw(
+ '('.$query.') as '.$this->grammar->wrap($as), $bindings
+ );
+ }
+
+ /**
+ * Parse the sub-select query into SQL and bindings.
+ *
+ * @param mixed $query
+ * @return array
+ */
+ protected function parseSubSelect($query)
+ {
+ if ($query instanceof self) {
+ $query->columns = [$query->columns[0]];
+
+ return [$query->toSql(), $query->getBindings()];
+ } elseif (is_string($query)) {
+ return [$query, []];
+ } else {
+ throw new InvalidArgumentException;
+ }
+ }
+
+ /**
+ * Add a new select column to the query.
+ *
+ * @param array|mixed $column
+ * @return $this
+ */
+ public function addSelect($column)
+ {
+ $column = is_array($column) ? $column : func_get_args();
+
+ $this->columns = array_merge((array) $this->columns, $column);
+
+ return $this;
+ }
+
+ /**
+ * Force the query to only return distinct results.
+ *
+ * @return $this
+ */
+ public function distinct()
+ {
+ $this->distinct = true;
+
+ return $this;
+ }
+
+ /**
+ * Set the table which the query is targeting.
+ *
+ * @param string $table
+ * @return $this
+ */
+ public function from($table)
+ {
+ $this->from = $table;
+
+ return $this;
+ }
+
+ /**
+ * Add a join clause to the query.
+ *
+ * @param string $table
+ * @param string $first
+ * @param string $operator
+ * @param string $second
+ * @param string $type
+ * @param bool $where
+ * @return $this
+ */
+ public function join($table, $first, $operator = null, $second = null, $type = 'inner', $where = false)
+ {
+ $join = new JoinClause($this, $type, $table);
+
+ // If the first "column" of the join is really a Closure instance the developer
+ // is trying to build a join with a complex "on" clause containing more than
+ // one condition, so we'll add the join and call a Closure with the query.
+ if ($first instanceof Closure) {
+ call_user_func($first, $join);
+
+ $this->joins[] = $join;
+
+ $this->addBinding($join->getBindings(), 'join');
+ }
+
+ // If the column is simply a string, we can assume the join simply has a basic
+ // "on" clause with a single condition. So we will just build the join with
+ // this simple join clauses attached to it. There is not a join callback.
+ else {
+ $method = $where ? 'where' : 'on';
+
+ $this->joins[] = $join->$method($first, $operator, $second);
+
+ $this->addBinding($join->getBindings(), 'join');
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a "join where" clause to the query.
+ *
+ * @param string $table
+ * @param string $first
+ * @param string $operator
+ * @param string $second
+ * @param string $type
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function joinWhere($table, $first, $operator, $second, $type = 'inner')
+ {
+ return $this->join($table, $first, $operator, $second, $type, true);
+ }
+
+ /**
+ * Add a left join to the query.
+ *
+ * @param string $table
+ * @param string $first
+ * @param string $operator
+ * @param string $second
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function leftJoin($table, $first, $operator = null, $second = null)
+ {
+ return $this->join($table, $first, $operator, $second, 'left');
+ }
+
+ /**
+ * Add a "join where" clause to the query.
+ *
+ * @param string $table
+ * @param string $first
+ * @param string $operator
+ * @param string $second
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function leftJoinWhere($table, $first, $operator, $second)
+ {
+ return $this->joinWhere($table, $first, $operator, $second, 'left');
+ }
+
+ /**
+ * Add a right join to the query.
+ *
+ * @param string $table
+ * @param string $first
+ * @param string $operator
+ * @param string $second
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function rightJoin($table, $first, $operator = null, $second = null)
+ {
+ return $this->join($table, $first, $operator, $second, 'right');
+ }
+
+ /**
+ * Add a "right join where" clause to the query.
+ *
+ * @param string $table
+ * @param string $first
+ * @param string $operator
+ * @param string $second
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function rightJoinWhere($table, $first, $operator, $second)
+ {
+ return $this->joinWhere($table, $first, $operator, $second, 'right');
+ }
+
+ /**
+ * Add a "cross join" clause to the query.
+ *
+ * @param string $table
+ * @param string $first
+ * @param string $operator
+ * @param string $second
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function crossJoin($table, $first = null, $operator = null, $second = null)
+ {
+ if ($first) {
+ return $this->join($table, $first, $operator, $second, 'cross');
+ }
+
+ $this->joins[] = new JoinClause($this, 'cross', $table);
+
+ return $this;
+ }
+
+ /**
+ * Merge an array of where clauses and bindings.
+ *
+ * @param array $wheres
+ * @param array $bindings
+ * @return void
+ */
+ public function mergeWheres($wheres, $bindings)
+ {
+ $this->wheres = array_merge($this->wheres, (array) $wheres);
+
+ $this->bindings['where'] = array_values(
+ array_merge($this->bindings['where'], (array) $bindings)
+ );
+ }
+
+ /**
+ * Add a basic where clause to the query.
+ *
+ * @param string|array|\Closure $column
+ * @param string $operator
+ * @param mixed $value
+ * @param string $boolean
+ * @return $this
+ */
+ public function where($column, $operator = null, $value = null, $boolean = 'and')
+ {
+ // If the column is an array, we will assume it is an array of key-value pairs
+ // and can add them each as a where clause. We will maintain the boolean we
+ // received when the method was called and pass it into the nested where.
+ if (is_array($column)) {
+ return $this->addArrayOfWheres($column, $boolean);
+ }
+
+ // Here we will make some assumptions about the operator. If only 2 values are
+ // passed to the method, we will assume that the operator is an equals sign
+ // and keep going. Otherwise, we'll require the operator to be passed in.
+ list($value, $operator) = $this->prepareValueAndOperator(
+ $value, $operator, func_num_args() == 2
+ );
+
+ // If the columns is actually a Closure instance, we will assume the developer
+ // wants to begin a nested where statement which is wrapped in parenthesis.
+ // We'll add that Closure to the query then return back out immediately.
+ if ($column instanceof Closure) {
+ return $this->whereNested($column, $boolean);
+ }
+
+ // If the given operator is not found in the list of valid operators we will
+ // assume that the developer is just short-cutting the '=' operators and
+ // we will set the operators to '=' and set the values appropriately.
+ if ($this->invalidOperator($operator)) {
+ list($value, $operator) = [$operator, '='];
+ }
+
+ // If the value is a Closure, it means the developer is performing an entire
+ // sub-select within the query and we will need to compile the sub-select
+ // within the where clause to get the appropriate query record results.
+ if ($value instanceof Closure) {
+ return $this->whereSub($column, $operator, $value, $boolean);
+ }
+
+ // If the value is "null", we will just assume the developer wants to add a
+ // where null clause to the query. So, we will allow a short-cut here to
+ // that method for convenience so the developer doesn't have to check.
+ if (is_null($value)) {
+ return $this->whereNull($column, $boolean, $operator != '=');
+ }
+
+ // If the column is making a JSON reference we'll check to see if the value
+ // is a boolean. If it is, we'll add the raw boolean string as an actual
+ // value to the query to ensure this is properly handled by the query.
+ if (Str::contains($column, '->') && is_bool($value)) {
+ $value = new Expression($value ? 'true' : 'false');
+ }
+
+ // Now that we are working with just a simple query we can put the elements
+ // in our array and add the query binding to our array of bindings that
+ // will be bound to each SQL statements when it is finally executed.
+ $type = 'Basic';
+
+ $this->wheres[] = compact(
+ 'type', 'column', 'operator', 'value', 'boolean'
+ );
+
+ if (! $value instanceof Expression) {
+ $this->addBinding($value, 'where');
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add an array of where clauses to the query.
+ *
+ * @param array $column
+ * @param string $boolean
+ * @param string $method
+ * @return $this
+ */
+ protected function addArrayOfWheres($column, $boolean, $method = 'where')
+ {
+ return $this->whereNested(function ($query) use ($column, $method, $boolean) {
+ foreach ($column as $key => $value) {
+ if (is_numeric($key) && is_array($value)) {
+ $query->{$method}(...array_values($value));
+ } else {
+ $query->$method($key, '=', $value, $boolean);
+ }
+ }
+ }, $boolean);
+ }
+
+ /**
+ * Prepare the value and operator for a where clause.
+ *
+ * @param string $value
+ * @param string $operator
+ * @param bool $useDefault
+ * @return array
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function prepareValueAndOperator($value, $operator, $useDefault = false)
+ {
+ if ($useDefault) {
+ return [$operator, '='];
+ } elseif ($this->invalidOperatorAndValue($operator, $value)) {
+ throw new InvalidArgumentException('Illegal operator and value combination.');
+ }
+
+ return [$value, $operator];
+ }
+
+ /**
+ * Determine if the given operator and value combination is legal.
+ *
+ * Prevents using Null values with invalid operators.
+ *
+ * @param string $operator
+ * @param mixed $value
+ * @return bool
+ */
+ protected function invalidOperatorAndValue($operator, $value)
+ {
+ return is_null($value) && in_array($operator, $this->operators) &&
+ ! in_array($operator, ['=', '<>', '!=']);
+ }
+
+ /**
+ * Determine if the given operator is supported.
+ *
+ * @param string $operator
+ * @return bool
+ */
+ protected function invalidOperator($operator)
+ {
+ return ! in_array(strtolower($operator), $this->operators, true) &&
+ ! in_array(strtolower($operator), $this->grammar->getOperators(), true);
+ }
+
+ /**
+ * Add an "or where" clause to the query.
+ *
+ * @param string|array|\Closure $column
+ * @param string $operator
+ * @param mixed $value
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhere($column, $operator = null, $value = null)
+ {
+ return $this->where($column, $operator, $value, 'or');
+ }
+
+ /**
+ * Add a "where" clause comparing two columns to the query.
+ *
+ * @param string|array $first
+ * @param string|null $operator
+ * @param string|null $second
+ * @param string|null $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereColumn($first, $operator = null, $second = null, $boolean = 'and')
+ {
+ // If the column is an array, we will assume it is an array of key-value pairs
+ // and can add them each as a where clause. We will maintain the boolean we
+ // received when the method was called and pass it into the nested where.
+ if (is_array($first)) {
+ return $this->addArrayOfWheres($first, $boolean, 'whereColumn');
+ }
+
+ // If the given operator is not found in the list of valid operators we will
+ // assume that the developer is just short-cutting the '=' operators and
+ // we will set the operators to '=' and set the values appropriately.
+ if ($this->invalidOperator($operator)) {
+ list($second, $operator) = [$operator, '='];
+ }
+
+ // Finally, we will add this where clause into this array of clauses that we
+ // are building for the query. All of them will be compiled via a grammar
+ // once the query is about to be executed and run against the database.
+ $type = 'Column';
+
+ $this->wheres[] = compact(
+ 'type', 'first', 'operator', 'second', 'boolean'
+ );
+
+ return $this;
+ }
+
+ /**
+ * Add an "or where" clause comparing two columns to the query.
+ *
+ * @param string|array $first
+ * @param string|null $operator
+ * @param string|null $second
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereColumn($first, $operator = null, $second = null)
+ {
+ return $this->whereColumn($first, $operator, $second, 'or');
+ }
+
+ /**
+ * Add a raw where clause to the query.
+ *
+ * @param string $sql
+ * @param mixed $bindings
+ * @param string $boolean
+ * @return $this
+ */
+ public function whereRaw($sql, $bindings = [], $boolean = 'and')
+ {
+ $this->wheres[] = ['type' => 'raw', 'sql' => $sql, 'boolean' => $boolean];
+
+ $this->addBinding((array) $bindings, 'where');
+
+ return $this;
+ }
+
+ /**
+ * Add a raw or where clause to the query.
+ *
+ * @param string $sql
+ * @param mixed $bindings
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereRaw($sql, $bindings = [])
+ {
+ return $this->whereRaw($sql, $bindings, 'or');
+ }
+
+ /**
+ * Add a "where in" clause to the query.
+ *
+ * @param string $column
+ * @param mixed $values
+ * @param string $boolean
+ * @param bool $not
+ * @return $this
+ */
+ public function whereIn($column, $values, $boolean = 'and', $not = false)
+ {
+ $type = $not ? 'NotIn' : 'In';
+
+ if ($values instanceof EloquentBuilder) {
+ $values = $values->getQuery();
+ }
+
+ // If the value is a query builder instance we will assume the developer wants to
+ // look for any values that exists within this given query. So we will add the
+ // query accordingly so that this query is properly executed when it is run.
+ if ($values instanceof self) {
+ return $this->whereInExistingQuery(
+ $column, $values, $boolean, $not
+ );
+ }
+
+ // If the value of the where in clause is actually a Closure, we will assume that
+ // the developer is using a full sub-select for this "in" statement, and will
+ // execute those Closures, then we can re-construct the entire sub-selects.
+ if ($values instanceof Closure) {
+ return $this->whereInSub($column, $values, $boolean, $not);
+ }
+
+ // Next, if the value is Arrayable we need to cast it to its raw array form so we
+ // have the underlying array value instead of an Arrayable object which is not
+ // able to be added as a binding, etc. We will then add to the wheres array.
+ if ($values instanceof Arrayable) {
+ $values = $values->toArray();
+ }
+
+ $this->wheres[] = compact('type', 'column', 'values', 'boolean');
+
+ // Finally we'll add a binding for each values unless that value is an expression
+ // in which case we will just skip over it since it will be the query as a raw
+ // string and not as a parameterized place-holder to be replaced by the PDO.
+ foreach ($values as $value) {
+ if (! $value instanceof Expression) {
+ $this->addBinding($value, 'where');
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add an "or where in" clause to the query.
+ *
+ * @param string $column
+ * @param mixed $values
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereIn($column, $values)
+ {
+ return $this->whereIn($column, $values, 'or');
+ }
+
+ /**
+ * Add a "where not in" clause to the query.
+ *
+ * @param string $column
+ * @param mixed $values
+ * @param string $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereNotIn($column, $values, $boolean = 'and')
+ {
+ return $this->whereIn($column, $values, $boolean, true);
+ }
+
+ /**
+ * Add an "or where not in" clause to the query.
+ *
+ * @param string $column
+ * @param mixed $values
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereNotIn($column, $values)
+ {
+ return $this->whereNotIn($column, $values, 'or');
+ }
+
+ /**
+ * Add a where in with a sub-select to the query.
+ *
+ * @param string $column
+ * @param \Closure $callback
+ * @param string $boolean
+ * @param bool $not
+ * @return $this
+ */
+ protected function whereInSub($column, Closure $callback, $boolean, $not)
+ {
+ $type = $not ? 'NotInSub' : 'InSub';
+
+ // To create the exists sub-select, we will actually create a query and call the
+ // provided callback with the query so the developer may set any of the query
+ // conditions they want for the in clause, then we'll put it in this array.
+ call_user_func($callback, $query = $this->newQuery());
+
+ $this->wheres[] = compact('type', 'column', 'query', 'boolean');
+
+ $this->addBinding($query->getBindings(), 'where');
+
+ return $this;
+ }
+
+ /**
+ * Add an external sub-select to the query.
+ *
+ * @param string $column
+ * @param \Illuminate\Database\Query\Builder|static $query
+ * @param string $boolean
+ * @param bool $not
+ * @return $this
+ */
+ protected function whereInExistingQuery($column, $query, $boolean, $not)
+ {
+ $type = $not ? 'NotInSub' : 'InSub';
+
+ $this->wheres[] = compact('type', 'column', 'query', 'boolean');
+
+ $this->addBinding($query->getBindings(), 'where');
+
+ return $this;
+ }
+
+ /**
+ * Add a "where null" clause to the query.
+ *
+ * @param string $column
+ * @param string $boolean
+ * @param bool $not
+ * @return $this
+ */
+ public function whereNull($column, $boolean = 'and', $not = false)
+ {
+ $type = $not ? 'NotNull' : 'Null';
+
+ $this->wheres[] = compact('type', 'column', 'boolean');
+
+ return $this;
+ }
+
+ /**
+ * Add an "or where null" clause to the query.
+ *
+ * @param string $column
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereNull($column)
+ {
+ return $this->whereNull($column, 'or');
+ }
+
+ /**
+ * Add a "where not null" clause to the query.
+ *
+ * @param string $column
+ * @param string $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereNotNull($column, $boolean = 'and')
+ {
+ return $this->whereNull($column, $boolean, true);
+ }
+
+ /**
+ * Add a where between statement to the query.
+ *
+ * @param string $column
+ * @param array $values
+ * @param string $boolean
+ * @param bool $not
+ * @return $this
+ */
+ public function whereBetween($column, array $values, $boolean = 'and', $not = false)
+ {
+ $type = 'between';
+
+ $this->wheres[] = compact('column', 'type', 'boolean', 'not');
+
+ $this->addBinding($values, 'where');
+
+ return $this;
+ }
+
+ /**
+ * Add an or where between statement to the query.
+ *
+ * @param string $column
+ * @param array $values
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereBetween($column, array $values)
+ {
+ return $this->whereBetween($column, $values, 'or');
+ }
+
+ /**
+ * Add a where not between statement to the query.
+ *
+ * @param string $column
+ * @param array $values
+ * @param string $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereNotBetween($column, array $values, $boolean = 'and')
+ {
+ return $this->whereBetween($column, $values, $boolean, true);
+ }
+
+ /**
+ * Add an or where not between statement to the query.
+ *
+ * @param string $column
+ * @param array $values
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereNotBetween($column, array $values)
+ {
+ return $this->whereNotBetween($column, $values, 'or');
+ }
+
+ /**
+ * Add an "or where not null" clause to the query.
+ *
+ * @param string $column
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereNotNull($column)
+ {
+ return $this->whereNotNull($column, 'or');
+ }
+
+ /**
+ * Add a "where date" statement to the query.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param mixed $value
+ * @param string $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereDate($column, $operator, $value = null, $boolean = 'and')
+ {
+ list($value, $operator) = $this->prepareValueAndOperator(
+ $value, $operator, func_num_args() == 2
+ );
+
+ return $this->addDateBasedWhere('Date', $column, $operator, $value, $boolean);
+ }
+
+ /**
+ * Add an "or where date" statement to the query.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param string $value
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereDate($column, $operator, $value)
+ {
+ return $this->whereDate($column, $operator, $value, 'or');
+ }
+
+ /**
+ * Add a "where time" statement to the query.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param int $value
+ * @param string $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereTime($column, $operator, $value, $boolean = 'and')
+ {
+ return $this->addDateBasedWhere('Time', $column, $operator, $value, $boolean);
+ }
+
+ /**
+ * Add an "or where time" statement to the query.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param int $value
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereTime($column, $operator, $value)
+ {
+ return $this->whereTime($column, $operator, $value, 'or');
+ }
+
+ /**
+ * Add a "where day" statement to the query.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param mixed $value
+ * @param string $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereDay($column, $operator, $value = null, $boolean = 'and')
+ {
+ list($value, $operator) = $this->prepareValueAndOperator(
+ $value, $operator, func_num_args() == 2
+ );
+
+ return $this->addDateBasedWhere('Day', $column, $operator, $value, $boolean);
+ }
+
+ /**
+ * Add a "where month" statement to the query.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param mixed $value
+ * @param string $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereMonth($column, $operator, $value = null, $boolean = 'and')
+ {
+ list($value, $operator) = $this->prepareValueAndOperator(
+ $value, $operator, func_num_args() == 2
+ );
+
+ return $this->addDateBasedWhere('Month', $column, $operator, $value, $boolean);
+ }
+
+ /**
+ * Add a "where year" statement to the query.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param mixed $value
+ * @param string $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereYear($column, $operator, $value = null, $boolean = 'and')
+ {
+ list($value, $operator) = $this->prepareValueAndOperator(
+ $value, $operator, func_num_args() == 2
+ );
+
+ return $this->addDateBasedWhere('Year', $column, $operator, $value, $boolean);
+ }
+
+ /**
+ * Add a date based (year, month, day, time) statement to the query.
+ *
+ * @param string $type
+ * @param string $column
+ * @param string $operator
+ * @param int $value
+ * @param string $boolean
+ * @return $this
+ */
+ protected function addDateBasedWhere($type, $column, $operator, $value, $boolean = 'and')
+ {
+ $this->wheres[] = compact('column', 'type', 'boolean', 'operator', 'value');
+
+ $this->addBinding($value, 'where');
+
+ return $this;
+ }
+
+ /**
+ * Add a nested where statement to the query.
+ *
+ * @param \Closure $callback
+ * @param string $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereNested(Closure $callback, $boolean = 'and')
+ {
+ call_user_func($callback, $query = $this->forNestedWhere());
+
+ return $this->addNestedWhereQuery($query, $boolean);
+ }
+
+ /**
+ * Create a new query instance for nested where condition.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function forNestedWhere()
+ {
+ return $this->newQuery()->from($this->from);
+ }
+
+ /**
+ * Add another query builder as a nested where to the query builder.
+ *
+ * @param \Illuminate\Database\Query\Builder|static $query
+ * @param string $boolean
+ * @return $this
+ */
+ public function addNestedWhereQuery($query, $boolean = 'and')
+ {
+ if (count($query->wheres)) {
+ $type = 'Nested';
+
+ $this->wheres[] = compact('type', 'query', 'boolean');
+
+ $this->addBinding($query->getBindings(), 'where');
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a full sub-select to the query.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param \Closure $callback
+ * @param string $boolean
+ * @return $this
+ */
+ protected function whereSub($column, $operator, Closure $callback, $boolean)
+ {
+ $type = 'Sub';
+
+ // Once we have the query instance we can simply execute it so it can add all
+ // of the sub-select's conditions to itself, and then we can cache it off
+ // in the array of where clauses for the "main" parent query instance.
+ call_user_func($callback, $query = $this->newQuery());
+
+ $this->wheres[] = compact(
+ 'type', 'column', 'operator', 'query', 'boolean'
+ );
+
+ $this->addBinding($query->getBindings(), 'where');
+
+ return $this;
+ }
+
+ /**
+ * Add an exists clause to the query.
+ *
+ * @param \Closure $callback
+ * @param string $boolean
+ * @param bool $not
+ * @return $this
+ */
+ public function whereExists(Closure $callback, $boolean = 'and', $not = false)
+ {
+ $query = $this->newQuery();
+
+ // Similar to the sub-select clause, we will create a new query instance so
+ // the developer may cleanly specify the entire exists query and we will
+ // compile the whole thing in the grammar and insert it into the SQL.
+ call_user_func($callback, $query);
+
+ return $this->addWhereExistsQuery($query, $boolean, $not);
+ }
+
+ /**
+ * Add an or exists clause to the query.
+ *
+ * @param \Closure $callback
+ * @param bool $not
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereExists(Closure $callback, $not = false)
+ {
+ return $this->whereExists($callback, 'or', $not);
+ }
+
+ /**
+ * Add a where not exists clause to the query.
+ *
+ * @param \Closure $callback
+ * @param string $boolean
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function whereNotExists(Closure $callback, $boolean = 'and')
+ {
+ return $this->whereExists($callback, $boolean, true);
+ }
+
+ /**
+ * Add a where not exists clause to the query.
+ *
+ * @param \Closure $callback
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orWhereNotExists(Closure $callback)
+ {
+ return $this->orWhereExists($callback, true);
+ }
+
+ /**
+ * Add an exists clause to the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param string $boolean
+ * @param bool $not
+ * @return $this
+ */
+ public function addWhereExistsQuery(Builder $query, $boolean = 'and', $not = false)
+ {
+ $type = $not ? 'NotExists' : 'Exists';
+
+ $this->wheres[] = compact('type', 'operator', 'query', 'boolean');
+
+ $this->addBinding($query->getBindings(), 'where');
+
+ return $this;
+ }
+
+ /**
+ * Handles dynamic "where" clauses to the query.
+ *
+ * @param string $method
+ * @param string $parameters
+ * @return $this
+ */
+ public function dynamicWhere($method, $parameters)
+ {
+ $finder = substr($method, 5);
+
+ $segments = preg_split(
+ '/(And|Or)(?=[A-Z])/', $finder, -1, PREG_SPLIT_DELIM_CAPTURE
+ );
+
+ // The connector variable will determine which connector will be used for the
+ // query condition. We will change it as we come across new boolean values
+ // in the dynamic method strings, which could contain a number of these.
+ $connector = 'and';
+
+ $index = 0;
+
+ foreach ($segments as $segment) {
+ // If the segment is not a boolean connector, we can assume it is a column's name
+ // and we will add it to the query as a new constraint as a where clause, then
+ // we can keep iterating through the dynamic method string's segments again.
+ if ($segment != 'And' && $segment != 'Or') {
+ $this->addDynamic($segment, $connector, $parameters, $index);
+
+ $index++;
+ }
+
+ // Otherwise, we will store the connector so we know how the next where clause we
+ // find in the query should be connected to the previous ones, meaning we will
+ // have the proper boolean connector to connect the next where clause found.
+ else {
+ $connector = $segment;
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a single dynamic where clause statement to the query.
+ *
+ * @param string $segment
+ * @param string $connector
+ * @param array $parameters
+ * @param int $index
+ * @return void
+ */
+ protected function addDynamic($segment, $connector, $parameters, $index)
+ {
+ // Once we have parsed out the columns and formatted the boolean operators we
+ // are ready to add it to this query as a where clause just like any other
+ // clause on the query. Then we'll increment the parameter index values.
+ $bool = strtolower($connector);
+
+ $this->where(Str::snake($segment), '=', $parameters[$index], $bool);
+ }
+
+ /**
+ * Add a "group by" clause to the query.
+ *
+ * @param array ...$groups
+ * @return $this
+ */
+ public function groupBy(...$groups)
+ {
+ foreach ($groups as $group) {
+ $this->groups = array_merge(
+ (array) $this->groups,
+ array_wrap($group)
+ );
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a "having" clause to the query.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param string $value
+ * @param string $boolean
+ * @return $this
+ */
+ public function having($column, $operator = null, $value = null, $boolean = 'and')
+ {
+ $type = 'Basic';
+
+ // Here we will make some assumptions about the operator. If only 2 values are
+ // passed to the method, we will assume that the operator is an equals sign
+ // and keep going. Otherwise, we'll require the operator to be passed in.
+ list($value, $operator) = $this->prepareValueAndOperator(
+ $value, $operator, func_num_args() == 2
+ );
+
+ // If the given operator is not found in the list of valid operators we will
+ // assume that the developer is just short-cutting the '=' operators and
+ // we will set the operators to '=' and set the values appropriately.
+ if ($this->invalidOperator($operator)) {
+ list($value, $operator) = [$operator, '='];
+ }
+
+ $this->havings[] = compact('type', 'column', 'operator', 'value', 'boolean');
+
+ if (! $value instanceof Expression) {
+ $this->addBinding($value, 'having');
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a "or having" clause to the query.
+ *
+ * @param string $column
+ * @param string $operator
+ * @param string $value
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orHaving($column, $operator = null, $value = null)
+ {
+ return $this->having($column, $operator, $value, 'or');
+ }
+
+ /**
+ * Add a raw having clause to the query.
+ *
+ * @param string $sql
+ * @param array $bindings
+ * @param string $boolean
+ * @return $this
+ */
+ public function havingRaw($sql, array $bindings = [], $boolean = 'and')
+ {
+ $type = 'Raw';
+
+ $this->havings[] = compact('type', 'sql', 'boolean');
+
+ $this->addBinding($bindings, 'having');
+
+ return $this;
+ }
+
+ /**
+ * Add a raw or having clause to the query.
+ *
+ * @param string $sql
+ * @param array $bindings
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function orHavingRaw($sql, array $bindings = [])
+ {
+ return $this->havingRaw($sql, $bindings, 'or');
+ }
+
+ /**
+ * Add an "order by" clause to the query.
+ *
+ * @param string $column
+ * @param string $direction
+ * @return $this
+ */
+ public function orderBy($column, $direction = 'asc')
+ {
+ $this->{$this->unions ? 'unionOrders' : 'orders'}[] = [
+ 'column' => $column,
+ 'direction' => strtolower($direction) == 'asc' ? 'asc' : 'desc',
+ ];
+
+ return $this;
+ }
+
+ /**
+ * Add a descending "order by" clause to the query.
+ *
+ * @param string $column
+ * @return $this
+ */
+ public function orderByDesc($column)
+ {
+ return $this->orderBy($column, 'desc');
+ }
+
+ /**
+ * Add an "order by" clause for a timestamp to the query.
+ *
+ * @param string $column
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function latest($column = 'created_at')
+ {
+ return $this->orderBy($column, 'desc');
+ }
+
+ /**
+ * Add an "order by" clause for a timestamp to the query.
+ *
+ * @param string $column
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function oldest($column = 'created_at')
+ {
+ return $this->orderBy($column, 'asc');
+ }
+
+ /**
+ * Put the query's results in random order.
+ *
+ * @param string $seed
+ * @return $this
+ */
+ public function inRandomOrder($seed = '')
+ {
+ return $this->orderByRaw($this->grammar->compileRandom($seed));
+ }
+
+ /**
+ * Add a raw "order by" clause to the query.
+ *
+ * @param string $sql
+ * @param array $bindings
+ * @return $this
+ */
+ public function orderByRaw($sql, $bindings = [])
+ {
+ $type = 'Raw';
+
+ $this->{$this->unions ? 'unionOrders' : 'orders'}[] = compact('type', 'sql');
+
+ $this->addBinding($bindings, 'order');
+
+ return $this;
+ }
+
+ /**
+ * Alias to set the "offset" value of the query.
+ *
+ * @param int $value
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function skip($value)
+ {
+ return $this->offset($value);
+ }
+
+ /**
+ * Set the "offset" value of the query.
+ *
+ * @param int $value
+ * @return $this
+ */
+ public function offset($value)
+ {
+ $property = $this->unions ? 'unionOffset' : 'offset';
+
+ $this->$property = max(0, $value);
+
+ return $this;
+ }
+
+ /**
+ * Alias to set the "limit" value of the query.
+ *
+ * @param int $value
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function take($value)
+ {
+ return $this->limit($value);
+ }
+
+ /**
+ * Set the "limit" value of the query.
+ *
+ * @param int $value
+ * @return $this
+ */
+ public function limit($value)
+ {
+ $property = $this->unions ? 'unionLimit' : 'limit';
+
+ if ($value >= 0) {
+ $this->$property = $value;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Set the limit and offset for a given page.
+ *
+ * @param int $page
+ * @param int $perPage
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function forPage($page, $perPage = 15)
+ {
+ return $this->skip(($page - 1) * $perPage)->take($perPage);
+ }
+
+ /**
+ * Constrain the query to the next "page" of results after a given ID.
+ *
+ * @param int $perPage
+ * @param int $lastId
+ * @param string $column
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function forPageAfterId($perPage = 15, $lastId = 0, $column = 'id')
+ {
+ $this->orders = $this->removeExistingOrdersFor($column);
+
+ return $this->where($column, '>', $lastId)
+ ->orderBy($column, 'asc')
+ ->take($perPage);
+ }
+
+ /**
+ * Get an array with all orders with a given column removed.
+ *
+ * @param string $column
+ * @return array
+ */
+ protected function removeExistingOrdersFor($column)
+ {
+ return Collection::make($this->orders)
+ ->reject(function ($order) use ($column) {
+ return isset($order['column'])
+ ? $order['column'] === $column : false;
+ })->values()->all();
+ }
+
+ /**
+ * Add a union statement to the query.
+ *
+ * @param \Illuminate\Database\Query\Builder|\Closure $query
+ * @param bool $all
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function union($query, $all = false)
+ {
+ if ($query instanceof Closure) {
+ call_user_func($query, $query = $this->newQuery());
+ }
+
+ $this->unions[] = compact('query', 'all');
+
+ $this->addBinding($query->getBindings(), 'union');
+
+ return $this;
+ }
+
+ /**
+ * Add a union all statement to the query.
+ *
+ * @param \Illuminate\Database\Query\Builder|\Closure $query
+ * @return \Illuminate\Database\Query\Builder|static
+ */
+ public function unionAll($query)
+ {
+ return $this->union($query, true);
+ }
+
+ /**
+ * Lock the selected rows in the table.
+ *
+ * @param string|bool $value
+ * @return $this
+ */
+ public function lock($value = true)
+ {
+ $this->lock = $value;
+
+ if (! is_null($this->lock)) {
+ $this->useWritePdo();
+ }
+
+ return $this;
+ }
+
+ /**
+ * Lock the selected rows in the table for updating.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function lockForUpdate()
+ {
+ return $this->lock(true);
+ }
+
+ /**
+ * Share lock the selected rows in the table.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function sharedLock()
+ {
+ return $this->lock(false);
+ }
+
+ /**
+ * Get the SQL representation of the query.
+ *
+ * @return string
+ */
+ public function toSql()
+ {
+ return $this->grammar->compileSelect($this);
+ }
+
+ /**
+ * Execute a query for a single record by ID.
+ *
+ * @param int $id
+ * @param array $columns
+ * @return mixed|static
+ */
+ public function find($id, $columns = ['*'])
+ {
+ return $this->where('id', '=', $id)->first($columns);
+ }
+
+ /**
+ * Get a single column's value from the first result of a query.
+ *
+ * @param string $column
+ * @return mixed
+ */
+ public function value($column)
+ {
+ $result = (array) $this->first([$column]);
+
+ return count($result) > 0 ? reset($result) : null;
+ }
+
+ /**
+ * Execute the query as a "select" statement.
+ *
+ * @param array $columns
+ * @return \Illuminate\Support\Collection
+ */
+ public function get($columns = ['*'])
+ {
+ $original = $this->columns;
+
+ if (is_null($original)) {
+ $this->columns = $columns;
+ }
+
+ $results = $this->processor->processSelect($this, $this->runSelect());
+
+ $this->columns = $original;
+
+ return collect($results);
+ }
+
+ /**
+ * Run the query as a "select" statement against the connection.
+ *
+ * @return array
+ */
+ protected function runSelect()
+ {
+ return $this->connection->select(
+ $this->toSql(), $this->getBindings(), ! $this->useWritePdo
+ );
+ }
+
+ /**
+ * Paginate the given query into a simple paginator.
+ *
+ * @param int $perPage
+ * @param array $columns
+ * @param string $pageName
+ * @param int|null $page
+ * @return \Illuminate\Contracts\Pagination\LengthAwarePaginator
+ */
+ public function paginate($perPage = 15, $columns = ['*'], $pageName = 'page', $page = null)
+ {
+ $page = $page ?: Paginator::resolveCurrentPage($pageName);
+
+ $total = $this->getCountForPagination($columns);
+
+ $results = $total ? $this->forPage($page, $perPage)->get($columns) : collect();
+
+ return $this->paginator($results, $total, $perPage, $page, [
+ 'path' => Paginator::resolveCurrentPath(),
+ 'pageName' => $pageName,
+ ]);
+ }
+
+ /**
+ * Get a paginator only supporting simple next and previous links.
+ *
+ * This is more efficient on larger data-sets, etc.
+ *
+ * @param int $perPage
+ * @param array $columns
+ * @param string $pageName
+ * @param int|null $page
+ * @return \Illuminate\Contracts\Pagination\Paginator
+ */
+ public function simplePaginate($perPage = 15, $columns = ['*'], $pageName = 'page', $page = null)
+ {
+ $page = $page ?: Paginator::resolveCurrentPage($pageName);
+
+ $this->skip(($page - 1) * $perPage)->take($perPage + 1);
+
+ return $this->simplePaginator($this->get($columns), $perPage, $page, [
+ 'path' => Paginator::resolveCurrentPath(),
+ 'pageName' => $pageName,
+ ]);
+ }
+
+ /**
+ * Get the count of the total records for the paginator.
+ *
+ * @param array $columns
+ * @return int
+ */
+ public function getCountForPagination($columns = ['*'])
+ {
+ $results = $this->runPaginationCountQuery($columns);
+
+ // Once we have run the pagination count query, we will get the resulting count and
+ // take into account what type of query it was. When there is a group by we will
+ // just return the count of the entire results set since that will be correct.
+ if (isset($this->groups)) {
+ return count($results);
+ } elseif (! isset($results[0])) {
+ return 0;
+ } elseif (is_object($results[0])) {
+ return (int) $results[0]->aggregate;
+ } else {
+ return (int) array_change_key_case((array) $results[0])['aggregate'];
+ }
+ }
+
+ /**
+ * Run a pagination count query.
+ *
+ * @param array $columns
+ * @return array
+ */
+ protected function runPaginationCountQuery($columns = ['*'])
+ {
+ return $this->cloneWithout(['columns', 'orders', 'limit', 'offset'])
+ ->cloneWithoutBindings(['select', 'order'])
+ ->setAggregate('count', $this->withoutSelectAliases($columns))
+ ->get()->all();
+ }
+
+ /**
+ * Remove the column aliases since they will break count queries.
+ *
+ * @param array $columns
+ * @return array
+ */
+ protected function withoutSelectAliases(array $columns)
+ {
+ return array_map(function ($column) {
+ return is_string($column) && ($aliasPosition = strpos(strtolower($column), ' as ')) !== false
+ ? substr($column, 0, $aliasPosition) : $column;
+ }, $columns);
+ }
+
+ /**
+ * Get a generator for the given query.
+ *
+ * @return \Generator
+ */
+ public function cursor()
+ {
+ if (is_null($this->columns)) {
+ $this->columns = ['*'];
+ }
+
+ return $this->connection->cursor(
+ $this->toSql(), $this->getBindings(), ! $this->useWritePdo
+ );
+ }
+
+ /**
+ * Chunk the results of a query by comparing numeric IDs.
+ *
+ * @param int $count
+ * @param callable $callback
+ * @param string $column
+ * @param string $alias
+ * @return bool
+ */
+ public function chunkById($count, callable $callback, $column = 'id', $alias = null)
+ {
+ $alias = $alias ?: $column;
+
+ $lastId = 0;
+
+ do {
+ $clone = clone $this;
+
+ // We'll execute the query for the given page and get the results. If there are
+ // no results we can just break and return from here. When there are results
+ // we will call the callback with the current chunk of these results here.
+ $results = $clone->forPageAfterId($count, $lastId, $column)->get();
+
+ $countResults = $results->count();
+
+ if ($countResults == 0) {
+ break;
+ }
+
+ // On each chunk result set, we will pass them to the callback and then let the
+ // developer take care of everything within the callback, which allows us to
+ // keep the memory low for spinning through large result sets for working.
+ if ($callback($results) === false) {
+ return false;
+ }
+
+ $lastId = $results->last()->{$alias};
+ } while ($countResults == $count);
+
+ return true;
+ }
+
+ /**
+ * Throw an exception if the query doesn't have an orderBy clause.
+ *
+ * @return void
+ *
+ * @throws \RuntimeException
+ */
+ protected function enforceOrderBy()
+ {
+ if (empty($this->orders) && empty($this->unionOrders)) {
+ throw new RuntimeException('You must specify an orderBy clause when using this function.');
+ }
+ }
+
+ /**
+ * Get an array with the values of a given column.
+ *
+ * @param string $column
+ * @param string|null $key
+ * @return \Illuminate\Support\Collection
+ */
+ public function pluck($column, $key = null)
+ {
+ $results = $this->get(is_null($key) ? [$column] : [$column, $key]);
+
+ // If the columns are qualified with a table or have an alias, we cannot use
+ // those directly in the "pluck" operations since the results from the DB
+ // are only keyed by the column itself. We'll strip the table out here.
+ return $results->pluck(
+ $this->stripTableForPluck($column),
+ $this->stripTableForPluck($key)
+ );
+ }
+
+ /**
+ * Strip off the table name or alias from a column identifier.
+ *
+ * @param string $column
+ * @return string|null
+ */
+ protected function stripTableForPluck($column)
+ {
+ return is_null($column) ? $column : last(preg_split('~\.| ~', $column));
+ }
+
+ /**
+ * Concatenate values of a given column as a string.
+ *
+ * @param string $column
+ * @param string $glue
+ * @return string
+ */
+ public function implode($column, $glue = '')
+ {
+ return $this->pluck($column)->implode($glue);
+ }
+
+ /**
+ * Determine if any rows exist for the current query.
+ *
+ * @return bool
+ */
+ public function exists()
+ {
+ $results = $this->connection->select(
+ $this->grammar->compileExists($this), $this->getBindings(), ! $this->useWritePdo
+ );
+
+ // If the results has rows, we will get the row and see if the exists column is a
+ // boolean true. If there is no results for this query we will return false as
+ // there are no rows for this query at all and we can return that info here.
+ if (isset($results[0])) {
+ $results = (array) $results[0];
+
+ return (bool) $results['exists'];
+ }
+
+ return false;
+ }
+
+ /**
+ * Retrieve the "count" result of the query.
+ *
+ * @param string $columns
+ * @return int
+ */
+ public function count($columns = '*')
+ {
+ return (int) $this->aggregate(__FUNCTION__, array_wrap($columns));
+ }
+
+ /**
+ * Retrieve the minimum value of a given column.
+ *
+ * @param string $column
+ * @return mixed
+ */
+ public function min($column)
+ {
+ return $this->aggregate(__FUNCTION__, [$column]);
+ }
+
+ /**
+ * Retrieve the maximum value of a given column.
+ *
+ * @param string $column
+ * @return mixed
+ */
+ public function max($column)
+ {
+ return $this->aggregate(__FUNCTION__, [$column]);
+ }
+
+ /**
+ * Retrieve the sum of the values of a given column.
+ *
+ * @param string $column
+ * @return mixed
+ */
+ public function sum($column)
+ {
+ $result = $this->aggregate(__FUNCTION__, [$column]);
+
+ return $result ?: 0;
+ }
+
+ /**
+ * Retrieve the average of the values of a given column.
+ *
+ * @param string $column
+ * @return mixed
+ */
+ public function avg($column)
+ {
+ return $this->aggregate(__FUNCTION__, [$column]);
+ }
+
+ /**
+ * Alias for the "avg" method.
+ *
+ * @param string $column
+ * @return mixed
+ */
+ public function average($column)
+ {
+ return $this->avg($column);
+ }
+
+ /**
+ * Execute an aggregate function on the database.
+ *
+ * @param string $function
+ * @param array $columns
+ * @return mixed
+ */
+ public function aggregate($function, $columns = ['*'])
+ {
+ $results = $this->cloneWithout(['columns'])
+ ->cloneWithoutBindings(['select'])
+ ->setAggregate($function, $columns)
+ ->get($columns);
+
+ if (! $results->isEmpty()) {
+ return array_change_key_case((array) $results[0])['aggregate'];
+ }
+ }
+
+ /**
+ * Execute a numeric aggregate function on the database.
+ *
+ * @param string $function
+ * @param array $columns
+ * @return float|int
+ */
+ public function numericAggregate($function, $columns = ['*'])
+ {
+ $result = $this->aggregate($function, $columns);
+
+ // If there is no result, we can obviously just return 0 here. Next, we will check
+ // if the result is an integer or float. If it is already one of these two data
+ // types we can just return the result as-is, otherwise we will convert this.
+ if (! $result) {
+ return 0;
+ }
+
+ if (is_int($result) || is_float($result)) {
+ return $result;
+ }
+
+ // If the result doesn't contain a decimal place, we will assume it is an int then
+ // cast it to one. When it does we will cast it to a float since it needs to be
+ // cast to the expected data type for the developers out of pure convenience.
+ return strpos((string) $result, '.') === false
+ ? (int) $result : (float) $result;
+ }
+
+ /**
+ * Set the aggregate property without running the query.
+ *
+ * @param string $function
+ * @param array $columns
+ * @return $this
+ */
+ protected function setAggregate($function, $columns)
+ {
+ $this->aggregate = compact('function', 'columns');
+
+ if (empty($this->groups)) {
+ $this->orders = null;
+
+ $this->bindings['order'] = [];
+ }
+
+ return $this;
+ }
+
+ /**
+ * Insert a new record into the database.
+ *
+ * @param array $values
+ * @return bool
+ */
+ public function insert(array $values)
+ {
+ // Since every insert gets treated like a batch insert, we will make sure the
+ // bindings are structured in a way that is convenient when building these
+ // inserts statements by verifying these elements are actually an array.
+ if (empty($values)) {
+ return true;
+ }
+
+ if (! is_array(reset($values))) {
+ $values = [$values];
+ }
+
+ // Here, we will sort the insert keys for every record so that each insert is
+ // in the same order for the record. We need to make sure this is the case
+ // so there are not any errors or problems when inserting these records.
+ else {
+ foreach ($values as $key => $value) {
+ ksort($value);
+
+ $values[$key] = $value;
+ }
+ }
+
+ // Finally, we will run this query against the database connection and return
+ // the results. We will need to also flatten these bindings before running
+ // the query so they are all in one huge, flattened array for execution.
+ return $this->connection->insert(
+ $this->grammar->compileInsert($this, $values),
+ $this->cleanBindings(Arr::flatten($values, 1))
+ );
+ }
+
+ /**
+ * Insert a new record and get the value of the primary key.
+ *
+ * @param array $values
+ * @param string $sequence
+ * @return int
+ */
+ public function insertGetId(array $values, $sequence = null)
+ {
+ $sql = $this->grammar->compileInsertGetId($this, $values, $sequence);
+
+ $values = $this->cleanBindings($values);
+
+ return $this->processor->processInsertGetId($this, $sql, $values, $sequence);
+ }
+
+ /**
+ * Update a record in the database.
+ *
+ * @param array $values
+ * @return int
+ */
+ public function update(array $values)
+ {
+ $sql = $this->grammar->compileUpdate($this, $values);
+
+ return $this->connection->update($sql, $this->cleanBindings(
+ $this->grammar->prepareBindingsForUpdate($this->bindings, $values)
+ ));
+ }
+
+ /**
+ * Insert or update a record matching the attributes, and fill it with values.
+ *
+ * @param array $attributes
+ * @param array $values
+ * @return bool
+ */
+ public function updateOrInsert(array $attributes, array $values = [])
+ {
+ if (! $this->where($attributes)->exists()) {
+ return $this->insert(array_merge($attributes, $values));
+ }
+
+ return (bool) $this->take(1)->update($values);
+ }
+
+ /**
+ * Increment a column's value by a given amount.
+ *
+ * @param string $column
+ * @param int $amount
+ * @param array $extra
+ * @return int
+ */
+ public function increment($column, $amount = 1, array $extra = [])
+ {
+ if (! is_numeric($amount)) {
+ throw new InvalidArgumentException('Non-numeric value passed to increment method.');
+ }
+
+ $wrapped = $this->grammar->wrap($column);
+
+ $columns = array_merge([$column => $this->raw("$wrapped + $amount")], $extra);
+
+ return $this->update($columns);
+ }
+
+ /**
+ * Decrement a column's value by a given amount.
+ *
+ * @param string $column
+ * @param int $amount
+ * @param array $extra
+ * @return int
+ */
+ public function decrement($column, $amount = 1, array $extra = [])
+ {
+ if (! is_numeric($amount)) {
+ throw new InvalidArgumentException('Non-numeric value passed to decrement method.');
+ }
+
+ $wrapped = $this->grammar->wrap($column);
+
+ $columns = array_merge([$column => $this->raw("$wrapped - $amount")], $extra);
+
+ return $this->update($columns);
+ }
+
+ /**
+ * Delete a record from the database.
+ *
+ * @param mixed $id
+ * @return int
+ */
+ public function delete($id = null)
+ {
+ // If an ID is passed to the method, we will set the where clause to check the
+ // ID to let developers to simply and quickly remove a single row from this
+ // database without manually specifying the "where" clauses on the query.
+ if (! is_null($id)) {
+ $this->where($this->from.'.id', '=', $id);
+ }
+
+ return $this->connection->delete(
+ $this->grammar->compileDelete($this), $this->getBindings()
+ );
+ }
+
+ /**
+ * Run a truncate statement on the table.
+ *
+ * @return void
+ */
+ public function truncate()
+ {
+ foreach ($this->grammar->compileTruncate($this) as $sql => $bindings) {
+ $this->connection->statement($sql, $bindings);
+ }
+ }
+
+ /**
+ * Get a new instance of the query builder.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ public function newQuery()
+ {
+ return new static($this->connection, $this->grammar, $this->processor);
+ }
+
+ /**
+ * Create a raw database expression.
+ *
+ * @param mixed $value
+ * @return \Illuminate\Database\Query\Expression
+ */
+ public function raw($value)
+ {
+ return $this->connection->raw($value);
+ }
+
+ /**
+ * Get the current query value bindings in a flattened array.
+ *
+ * @return array
+ */
+ public function getBindings()
+ {
+ return Arr::flatten($this->bindings);
+ }
+
+ /**
+ * Get the raw array of bindings.
+ *
+ * @return array
+ */
+ public function getRawBindings()
+ {
+ return $this->bindings;
+ }
+
+ /**
+ * Set the bindings on the query builder.
+ *
+ * @param array $bindings
+ * @param string $type
+ * @return $this
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function setBindings(array $bindings, $type = 'where')
+ {
+ if (! array_key_exists($type, $this->bindings)) {
+ throw new InvalidArgumentException("Invalid binding type: {$type}.");
+ }
+
+ $this->bindings[$type] = $bindings;
+
+ return $this;
+ }
+
+ /**
+ * Add a binding to the query.
+ *
+ * @param mixed $value
+ * @param string $type
+ * @return $this
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function addBinding($value, $type = 'where')
+ {
+ if (! array_key_exists($type, $this->bindings)) {
+ throw new InvalidArgumentException("Invalid binding type: {$type}.");
+ }
+
+ if (is_array($value)) {
+ $this->bindings[$type] = array_values(array_merge($this->bindings[$type], $value));
+ } else {
+ $this->bindings[$type][] = $value;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Merge an array of bindings into our bindings.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return $this
+ */
+ public function mergeBindings(Builder $query)
+ {
+ $this->bindings = array_merge_recursive($this->bindings, $query->bindings);
+
+ return $this;
+ }
+
+ /**
+ * Remove all of the expressions from a list of bindings.
+ *
+ * @param array $bindings
+ * @return array
+ */
+ protected function cleanBindings(array $bindings)
+ {
+ return array_values(array_filter($bindings, function ($binding) {
+ return ! $binding instanceof Expression;
+ }));
+ }
+
+ /**
+ * Get the database connection instance.
+ *
+ * @return \Illuminate\Database\ConnectionInterface
+ */
+ public function getConnection()
+ {
+ return $this->connection;
+ }
+
+ /**
+ * Get the database query processor instance.
+ *
+ * @return \Illuminate\Database\Query\Processors\Processor
+ */
+ public function getProcessor()
+ {
+ return $this->processor;
+ }
+
+ /**
+ * Get the query grammar instance.
+ *
+ * @return \Illuminate\Database\Query\Grammars\Grammar
+ */
+ public function getGrammar()
+ {
+ return $this->grammar;
+ }
+
+ /**
+ * Use the write pdo for query.
+ *
+ * @return $this
+ */
+ public function useWritePdo()
+ {
+ $this->useWritePdo = true;
+
+ return $this;
+ }
+
+ /**
+ * Clone the query without the given properties.
+ *
+ * @param array $except
+ * @return static
+ */
+ public function cloneWithout(array $except)
+ {
+ return tap(clone $this, function ($clone) use ($except) {
+ foreach ($except as $property) {
+ $clone->{$property} = null;
+ }
+ });
+ }
+
+ /**
+ * Clone the query without the given bindings.
+ *
+ * @param array $except
+ * @return static
+ */
+ public function cloneWithoutBindings(array $except)
+ {
+ return tap(clone $this, function ($clone) use ($except) {
+ foreach ($except as $type) {
+ $clone->bindings[$type] = [];
+ }
+ });
+ }
+
+ /**
+ * Handle dynamic method calls into the method.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ *
+ * @throws \BadMethodCallException
+ */
+ public function __call($method, $parameters)
+ {
+ if (static::hasMacro($method)) {
+ return $this->macroCall($method, $parameters);
+ }
+
+ if (Str::startsWith($method, 'where')) {
+ return $this->dynamicWhere($method, $parameters);
+ }
+
+ $className = static::class;
+
+ throw new BadMethodCallException("Call to undefined method {$className}::{$method}()");
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Expression.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Expression.php
new file mode 100644
index 000000000..de6902998
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Expression.php
@@ -0,0 +1,44 @@
+value = $value;
+ }
+
+ /**
+ * Get the value of the expression.
+ *
+ * @return mixed
+ */
+ public function getValue()
+ {
+ return $this->value;
+ }
+
+ /**
+ * Get the value of the expression.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return (string) $this->getValue();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/Grammar.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/Grammar.php
new file mode 100644
index 000000000..b7e59733d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/Grammar.php
@@ -0,0 +1,852 @@
+columns;
+
+ if (is_null($query->columns)) {
+ $query->columns = ['*'];
+ }
+
+ // To compile the query, we'll spin through each component of the query and
+ // see if that component exists. If it does we'll just call the compiler
+ // function for the component which is responsible for making the SQL.
+ $sql = trim($this->concatenate(
+ $this->compileComponents($query))
+ );
+
+ $query->columns = $original;
+
+ return $sql;
+ }
+
+ /**
+ * Compile the components necessary for a select clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return array
+ */
+ protected function compileComponents(Builder $query)
+ {
+ $sql = [];
+
+ foreach ($this->selectComponents as $component) {
+ // To compile the query, we'll spin through each component of the query and
+ // see if that component exists. If it does we'll just call the compiler
+ // function for the component which is responsible for making the SQL.
+ if (! is_null($query->$component)) {
+ $method = 'compile'.ucfirst($component);
+
+ $sql[$component] = $this->$method($query, $query->$component);
+ }
+ }
+
+ return $sql;
+ }
+
+ /**
+ * Compile an aggregated select clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $aggregate
+ * @return string
+ */
+ protected function compileAggregate(Builder $query, $aggregate)
+ {
+ $column = $this->columnize($aggregate['columns']);
+
+ // If the query has a "distinct" constraint and we're not asking for all columns
+ // we need to prepend "distinct" onto the column name so that the query takes
+ // it into account when it performs the aggregating operations on the data.
+ if ($query->distinct && $column !== '*') {
+ $column = 'distinct '.$column;
+ }
+
+ return 'select '.$aggregate['function'].'('.$column.') as aggregate';
+ }
+
+ /**
+ * Compile the "select *" portion of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $columns
+ * @return string|null
+ */
+ protected function compileColumns(Builder $query, $columns)
+ {
+ // If the query is actually performing an aggregating select, we will let that
+ // compiler handle the building of the select clauses, as it will need some
+ // more syntax that is best handled by that function to keep things neat.
+ if (! is_null($query->aggregate)) {
+ return;
+ }
+
+ $select = $query->distinct ? 'select distinct ' : 'select ';
+
+ return $select.$this->columnize($columns);
+ }
+
+ /**
+ * Compile the "from" portion of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param string $table
+ * @return string
+ */
+ protected function compileFrom(Builder $query, $table)
+ {
+ return 'from '.$this->wrapTable($table);
+ }
+
+ /**
+ * Compile the "join" portions of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $joins
+ * @return string
+ */
+ protected function compileJoins(Builder $query, $joins)
+ {
+ return collect($joins)->map(function ($join) use ($query) {
+ $table = $this->wrapTable($join->table);
+
+ return trim("{$join->type} join {$table} {$this->compileWheres($join)}");
+ })->implode(' ');
+ }
+
+ /**
+ * Compile the "where" portions of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ protected function compileWheres(Builder $query)
+ {
+ // Each type of where clauses has its own compiler function which is responsible
+ // for actually creating the where clauses SQL. This helps keep the code nice
+ // and maintainable since each clause has a very small method that it uses.
+ if (is_null($query->wheres)) {
+ return '';
+ }
+
+ // If we actually have some where clauses, we will strip off the first boolean
+ // operator, which is added by the query builders for convenience so we can
+ // avoid checking for the first clauses in each of the compilers methods.
+ if (count($sql = $this->compileWheresToArray($query)) > 0) {
+ return $this->concatenateWhereClauses($query, $sql);
+ }
+
+ return '';
+ }
+
+ /**
+ * Get an array of all the where clauses for the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return array
+ */
+ protected function compileWheresToArray($query)
+ {
+ return collect($query->wheres)->map(function ($where) use ($query) {
+ return $where['boolean'].' '.$this->{"where{$where['type']}"}($query, $where);
+ })->all();
+ }
+
+ /**
+ * Format the where clause statements into one string.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $sql
+ * @return string
+ */
+ protected function concatenateWhereClauses($query, $sql)
+ {
+ $conjunction = $query instanceof JoinClause ? 'on' : 'where';
+
+ return $conjunction.' '.$this->removeLeadingBoolean(implode(' ', $sql));
+ }
+
+ /**
+ * Compile a raw where clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereRaw(Builder $query, $where)
+ {
+ return $where['sql'];
+ }
+
+ /**
+ * Compile a basic where clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereBasic(Builder $query, $where)
+ {
+ $value = $this->parameter($where['value']);
+
+ return $this->wrap($where['column']).' '.$where['operator'].' '.$value;
+ }
+
+ /**
+ * Compile a "where in" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereIn(Builder $query, $where)
+ {
+ if (! empty($where['values'])) {
+ return $this->wrap($where['column']).' in ('.$this->parameterize($where['values']).')';
+ }
+
+ return '0 = 1';
+ }
+
+ /**
+ * Compile a "where not in" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereNotIn(Builder $query, $where)
+ {
+ if (! empty($where['values'])) {
+ return $this->wrap($where['column']).' not in ('.$this->parameterize($where['values']).')';
+ }
+
+ return '1 = 1';
+ }
+
+ /**
+ * Compile a where in sub-select clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereInSub(Builder $query, $where)
+ {
+ return $this->wrap($where['column']).' in ('.$this->compileSelect($where['query']).')';
+ }
+
+ /**
+ * Compile a where not in sub-select clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereNotInSub(Builder $query, $where)
+ {
+ return $this->wrap($where['column']).' not in ('.$this->compileSelect($where['query']).')';
+ }
+
+ /**
+ * Compile a "where null" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereNull(Builder $query, $where)
+ {
+ return $this->wrap($where['column']).' is null';
+ }
+
+ /**
+ * Compile a "where not null" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereNotNull(Builder $query, $where)
+ {
+ return $this->wrap($where['column']).' is not null';
+ }
+
+ /**
+ * Compile a "between" where clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereBetween(Builder $query, $where)
+ {
+ $between = $where['not'] ? 'not between' : 'between';
+
+ return $this->wrap($where['column']).' '.$between.' ? and ?';
+ }
+
+ /**
+ * Compile a "where date" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereDate(Builder $query, $where)
+ {
+ return $this->dateBasedWhere('date', $query, $where);
+ }
+
+ /**
+ * Compile a "where time" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereTime(Builder $query, $where)
+ {
+ return $this->dateBasedWhere('time', $query, $where);
+ }
+
+ /**
+ * Compile a "where day" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereDay(Builder $query, $where)
+ {
+ return $this->dateBasedWhere('day', $query, $where);
+ }
+
+ /**
+ * Compile a "where month" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereMonth(Builder $query, $where)
+ {
+ return $this->dateBasedWhere('month', $query, $where);
+ }
+
+ /**
+ * Compile a "where year" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereYear(Builder $query, $where)
+ {
+ return $this->dateBasedWhere('year', $query, $where);
+ }
+
+ /**
+ * Compile a date based where clause.
+ *
+ * @param string $type
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function dateBasedWhere($type, Builder $query, $where)
+ {
+ $value = $this->parameter($where['value']);
+
+ return $type.'('.$this->wrap($where['column']).') '.$where['operator'].' '.$value;
+ }
+
+ /**
+ * Compile a where clause comparing two columns..
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereColumn(Builder $query, $where)
+ {
+ return $this->wrap($where['first']).' '.$where['operator'].' '.$this->wrap($where['second']);
+ }
+
+ /**
+ * Compile a nested where clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereNested(Builder $query, $where)
+ {
+ // Here we will calculate what portion of the string we need to remove. If this
+ // is a join clause query, we need to remove the "on" portion of the SQL and
+ // if it is a normal query we need to take the leading "where" of queries.
+ $offset = $query instanceof JoinClause ? 3 : 6;
+
+ return '('.substr($this->compileWheres($where['query']), $offset).')';
+ }
+
+ /**
+ * Compile a where condition with a sub-select.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereSub(Builder $query, $where)
+ {
+ $select = $this->compileSelect($where['query']);
+
+ return $this->wrap($where['column']).' '.$where['operator']." ($select)";
+ }
+
+ /**
+ * Compile a where exists clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereExists(Builder $query, $where)
+ {
+ return 'exists ('.$this->compileSelect($where['query']).')';
+ }
+
+ /**
+ * Compile a where exists clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereNotExists(Builder $query, $where)
+ {
+ return 'not exists ('.$this->compileSelect($where['query']).')';
+ }
+
+ /**
+ * Compile the "group by" portions of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $groups
+ * @return string
+ */
+ protected function compileGroups(Builder $query, $groups)
+ {
+ return 'group by '.$this->columnize($groups);
+ }
+
+ /**
+ * Compile the "having" portions of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $havings
+ * @return string
+ */
+ protected function compileHavings(Builder $query, $havings)
+ {
+ $sql = implode(' ', array_map([$this, 'compileHaving'], $havings));
+
+ return 'having '.$this->removeLeadingBoolean($sql);
+ }
+
+ /**
+ * Compile a single having clause.
+ *
+ * @param array $having
+ * @return string
+ */
+ protected function compileHaving(array $having)
+ {
+ // If the having clause is "raw", we can just return the clause straight away
+ // without doing any more processing on it. Otherwise, we will compile the
+ // clause into SQL based on the components that make it up from builder.
+ if ($having['type'] === 'Raw') {
+ return $having['boolean'].' '.$having['sql'];
+ }
+
+ return $this->compileBasicHaving($having);
+ }
+
+ /**
+ * Compile a basic having clause.
+ *
+ * @param array $having
+ * @return string
+ */
+ protected function compileBasicHaving($having)
+ {
+ $column = $this->wrap($having['column']);
+
+ $parameter = $this->parameter($having['value']);
+
+ return $having['boolean'].' '.$column.' '.$having['operator'].' '.$parameter;
+ }
+
+ /**
+ * Compile the "order by" portions of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $orders
+ * @return string
+ */
+ protected function compileOrders(Builder $query, $orders)
+ {
+ if (! empty($orders)) {
+ return 'order by '.implode(', ', $this->compileOrdersToArray($query, $orders));
+ }
+
+ return '';
+ }
+
+ /**
+ * Compile the query orders to an array.
+ *
+ * @param \Illuminate\Database\Query\Builder
+ * @param array $orders
+ * @return array
+ */
+ protected function compileOrdersToArray(Builder $query, $orders)
+ {
+ return array_map(function ($order) {
+ return ! isset($order['sql'])
+ ? $this->wrap($order['column']).' '.$order['direction']
+ : $order['sql'];
+ }, $orders);
+ }
+
+ /**
+ * Compile the random statement into SQL.
+ *
+ * @param string $seed
+ * @return string
+ */
+ public function compileRandom($seed)
+ {
+ return 'RANDOM()';
+ }
+
+ /**
+ * Compile the "limit" portions of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param int $limit
+ * @return string
+ */
+ protected function compileLimit(Builder $query, $limit)
+ {
+ return 'limit '.(int) $limit;
+ }
+
+ /**
+ * Compile the "offset" portions of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param int $offset
+ * @return string
+ */
+ protected function compileOffset(Builder $query, $offset)
+ {
+ return 'offset '.(int) $offset;
+ }
+
+ /**
+ * Compile the "union" queries attached to the main query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ protected function compileUnions(Builder $query)
+ {
+ $sql = '';
+
+ foreach ($query->unions as $union) {
+ $sql .= $this->compileUnion($union);
+ }
+
+ if (! empty($query->unionOrders)) {
+ $sql .= ' '.$this->compileOrders($query, $query->unionOrders);
+ }
+
+ if (isset($query->unionLimit)) {
+ $sql .= ' '.$this->compileLimit($query, $query->unionLimit);
+ }
+
+ if (isset($query->unionOffset)) {
+ $sql .= ' '.$this->compileOffset($query, $query->unionOffset);
+ }
+
+ return ltrim($sql);
+ }
+
+ /**
+ * Compile a single union statement.
+ *
+ * @param array $union
+ * @return string
+ */
+ protected function compileUnion(array $union)
+ {
+ $conjuction = $union['all'] ? ' union all ' : ' union ';
+
+ return $conjuction.$union['query']->toSql();
+ }
+
+ /**
+ * Compile an exists statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ public function compileExists(Builder $query)
+ {
+ $select = $this->compileSelect($query);
+
+ return "select exists({$select}) as {$this->wrap('exists')}";
+ }
+
+ /**
+ * Compile an insert statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $values
+ * @return string
+ */
+ public function compileInsert(Builder $query, array $values)
+ {
+ // Essentially we will force every insert to be treated as a batch insert which
+ // simply makes creating the SQL easier for us since we can utilize the same
+ // basic routine regardless of an amount of records given to us to insert.
+ $table = $this->wrapTable($query->from);
+
+ if (! is_array(reset($values))) {
+ $values = [$values];
+ }
+
+ $columns = $this->columnize(array_keys(reset($values)));
+
+ // We need to build a list of parameter place-holders of values that are bound
+ // to the query. Each insert should have the exact same amount of parameter
+ // bindings so we will loop through the record and parameterize them all.
+ $parameters = collect($values)->map(function ($record) {
+ return '('.$this->parameterize($record).')';
+ })->implode(', ');
+
+ return "insert into $table ($columns) values $parameters";
+ }
+
+ /**
+ * Compile an insert and get ID statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $values
+ * @param string $sequence
+ * @return string
+ */
+ public function compileInsertGetId(Builder $query, $values, $sequence)
+ {
+ return $this->compileInsert($query, $values);
+ }
+
+ /**
+ * Compile an update statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $values
+ * @return string
+ */
+ public function compileUpdate(Builder $query, $values)
+ {
+ $table = $this->wrapTable($query->from);
+
+ // Each one of the columns in the update statements needs to be wrapped in the
+ // keyword identifiers, also a place-holder needs to be created for each of
+ // the values in the list of bindings so we can make the sets statements.
+ $columns = collect($values)->map(function ($value, $key) {
+ return $this->wrap($key).' = '.$this->parameter($value);
+ })->implode(', ');
+
+ // If the query has any "join" clauses, we will setup the joins on the builder
+ // and compile them so we can attach them to this update, as update queries
+ // can get join statements to attach to other tables when they're needed.
+ $joins = '';
+
+ if (isset($query->joins)) {
+ $joins = ' '.$this->compileJoins($query, $query->joins);
+ }
+
+ // Of course, update queries may also be constrained by where clauses so we'll
+ // need to compile the where clauses and attach it to the query so only the
+ // intended records are updated by the SQL statements we generate to run.
+ $wheres = $this->compileWheres($query);
+
+ return trim("update {$table}{$joins} set $columns $wheres");
+ }
+
+ /**
+ * Prepare the bindings for an update statement.
+ *
+ * @param array $bindings
+ * @param array $values
+ * @return array
+ */
+ public function prepareBindingsForUpdate(array $bindings, array $values)
+ {
+ $bindingsWithoutJoin = Arr::except($bindings, 'join');
+
+ return array_values(
+ array_merge($bindings['join'], $values, Arr::flatten($bindingsWithoutJoin))
+ );
+ }
+
+ /**
+ * Compile a delete statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ public function compileDelete(Builder $query)
+ {
+ $wheres = is_array($query->wheres) ? $this->compileWheres($query) : '';
+
+ return trim("delete from {$this->wrapTable($query->from)} $wheres");
+ }
+
+ /**
+ * Compile a truncate table statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return array
+ */
+ public function compileTruncate(Builder $query)
+ {
+ return ['truncate '.$this->wrapTable($query->from) => []];
+ }
+
+ /**
+ * Compile the lock into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param bool|string $value
+ * @return string
+ */
+ protected function compileLock(Builder $query, $value)
+ {
+ return is_string($value) ? $value : '';
+ }
+
+ /**
+ * Determine if the grammar supports savepoints.
+ *
+ * @return bool
+ */
+ public function supportsSavepoints()
+ {
+ return true;
+ }
+
+ /**
+ * Compile the SQL statement to define a savepoint.
+ *
+ * @param string $name
+ * @return string
+ */
+ public function compileSavepoint($name)
+ {
+ return 'SAVEPOINT '.$name;
+ }
+
+ /**
+ * Compile the SQL statement to execute a savepoint rollback.
+ *
+ * @param string $name
+ * @return string
+ */
+ public function compileSavepointRollBack($name)
+ {
+ return 'ROLLBACK TO SAVEPOINT '.$name;
+ }
+
+ /**
+ * Concatenate an array of segments, removing empties.
+ *
+ * @param array $segments
+ * @return string
+ */
+ protected function concatenate($segments)
+ {
+ return implode(' ', array_filter($segments, function ($value) {
+ return (string) $value !== '';
+ }));
+ }
+
+ /**
+ * Remove the leading boolean from a statement.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function removeLeadingBoolean($value)
+ {
+ return preg_replace('/and |or /i', '', $value, 1);
+ }
+
+ /**
+ * Get the grammar specific operators.
+ *
+ * @return array
+ */
+ public function getOperators()
+ {
+ return $this->operators;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/MySqlGrammar.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/MySqlGrammar.php
new file mode 100644
index 000000000..6943c147a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/MySqlGrammar.php
@@ -0,0 +1,300 @@
+unions) {
+ $sql = '('.$sql.') '.$this->compileUnions($query);
+ }
+
+ return $sql;
+ }
+
+ /**
+ * Compile a single union statement.
+ *
+ * @param array $union
+ * @return string
+ */
+ protected function compileUnion(array $union)
+ {
+ $conjuction = $union['all'] ? ' union all ' : ' union ';
+
+ return $conjuction.'('.$union['query']->toSql().')';
+ }
+
+ /**
+ * Compile the random statement into SQL.
+ *
+ * @param string $seed
+ * @return string
+ */
+ public function compileRandom($seed)
+ {
+ return 'RAND('.$seed.')';
+ }
+
+ /**
+ * Compile the lock into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param bool|string $value
+ * @return string
+ */
+ protected function compileLock(Builder $query, $value)
+ {
+ if (! is_string($value)) {
+ return $value ? 'for update' : 'lock in share mode';
+ }
+
+ return $value;
+ }
+
+ /**
+ * Compile an update statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $values
+ * @return string
+ */
+ public function compileUpdate(Builder $query, $values)
+ {
+ $table = $this->wrapTable($query->from);
+
+ // Each one of the columns in the update statements needs to be wrapped in the
+ // keyword identifiers, also a place-holder needs to be created for each of
+ // the values in the list of bindings so we can make the sets statements.
+ $columns = $this->compileUpdateColumns($values);
+
+ // If the query has any "join" clauses, we will setup the joins on the builder
+ // and compile them so we can attach them to this update, as update queries
+ // can get join statements to attach to other tables when they're needed.
+ $joins = '';
+
+ if (isset($query->joins)) {
+ $joins = ' '.$this->compileJoins($query, $query->joins);
+ }
+
+ // Of course, update queries may also be constrained by where clauses so we'll
+ // need to compile the where clauses and attach it to the query so only the
+ // intended records are updated by the SQL statements we generate to run.
+ $where = $this->compileWheres($query);
+
+ $sql = rtrim("update {$table}{$joins} set $columns $where");
+
+ // If the query has an order by clause we will compile it since MySQL supports
+ // order bys on update statements. We'll compile them using the typical way
+ // of compiling order bys. Then they will be appended to the SQL queries.
+ if (! empty($query->orders)) {
+ $sql .= ' '.$this->compileOrders($query, $query->orders);
+ }
+
+ // Updates on MySQL also supports "limits", which allow you to easily update a
+ // single record very easily. This is not supported by all database engines
+ // so we have customized this update compiler here in order to add it in.
+ if (isset($query->limit)) {
+ $sql .= ' '.$this->compileLimit($query, $query->limit);
+ }
+
+ return rtrim($sql);
+ }
+
+ /**
+ * Compile all of the columns for an update statement.
+ *
+ * @param array $values
+ * @return string
+ */
+ protected function compileUpdateColumns($values)
+ {
+ return collect($values)->map(function ($value, $key) {
+ if ($this->isJsonSelector($key)) {
+ return $this->compileJsonUpdateColumn($key, new JsonExpression($value));
+ } else {
+ return $this->wrap($key).' = '.$this->parameter($value);
+ }
+ })->implode(', ');
+ }
+
+ /**
+ * Prepares a JSON column being updated using the JSON_SET function.
+ *
+ * @param string $key
+ * @param \Illuminate\Database\Query\JsonExpression $value
+ * @return string
+ */
+ protected function compileJsonUpdateColumn($key, JsonExpression $value)
+ {
+ $path = explode('->', $key);
+
+ $field = $this->wrapValue(array_shift($path));
+
+ $accessor = '"$.'.implode('.', $path).'"';
+
+ return "{$field} = json_set({$field}, {$accessor}, {$value->getValue()})";
+ }
+
+ /**
+ * Prepare the bindings for an update statement.
+ *
+ * Booleans, integers, and doubles are inserted into JSON updates as raw values.
+ *
+ * @param array $bindings
+ * @param array $values
+ * @return array
+ */
+ public function prepareBindingsForUpdate(array $bindings, array $values)
+ {
+ $values = collect($values)->reject(function ($value, $column) {
+ return $this->isJsonSelector($column) &&
+ in_array(gettype($value), ['boolean', 'integer', 'double']);
+ })->all();
+
+ return parent::prepareBindingsForUpdate($bindings, $values);
+ }
+
+ /**
+ * Compile a delete statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ public function compileDelete(Builder $query)
+ {
+ $table = $this->wrapTable($query->from);
+
+ $where = is_array($query->wheres) ? $this->compileWheres($query) : '';
+
+ return isset($query->joins)
+ ? $this->compileDeleteWithJoins($query, $table, $where)
+ : $this->compileDeleteWithoutJoins($query, $table, $where);
+ }
+
+ /**
+ * Compile a delete query that does not use joins.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param string $table
+ * @param array $where
+ * @return string
+ */
+ protected function compileDeleteWithoutJoins($query, $table, $where)
+ {
+ $sql = trim("delete from {$table} {$where}");
+
+ // When using MySQL, delete statements may contain order by statements and limits
+ // so we will compile both of those here. Once we have finished compiling this
+ // we will return the completed SQL statement so it will be executed for us.
+ if (! empty($query->orders)) {
+ $sql .= ' '.$this->compileOrders($query, $query->orders);
+ }
+
+ if (isset($query->limit)) {
+ $sql .= ' '.$this->compileLimit($query, $query->limit);
+ }
+
+ return $sql;
+ }
+
+ /**
+ * Compile a delete query that uses joins.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param string $table
+ * @param array $where
+ * @return string
+ */
+ protected function compileDeleteWithJoins($query, $table, $where)
+ {
+ $joins = ' '.$this->compileJoins($query, $query->joins);
+
+ $alias = strpos(strtolower($table), ' as ') !== false
+ ? explode(' as ', $table)[1] : $table;
+
+ return trim("delete {$alias} from {$table}{$joins} {$where}");
+ }
+
+ /**
+ * Wrap a single string in keyword identifiers.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function wrapValue($value)
+ {
+ if ($value === '*') {
+ return $value;
+ }
+
+ // If the given value is a JSON selector we will wrap it differently than a
+ // traditional value. We will need to split this path and wrap each part
+ // wrapped, etc. Otherwise, we will simply wrap the value as a string.
+ if ($this->isJsonSelector($value)) {
+ return $this->wrapJsonSelector($value);
+ }
+
+ return '`'.str_replace('`', '``', $value).'`';
+ }
+
+ /**
+ * Wrap the given JSON selector.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function wrapJsonSelector($value)
+ {
+ $path = explode('->', $value);
+
+ $field = $this->wrapValue(array_shift($path));
+
+ return sprintf('%s->\'$.%s\'', $field, collect($path)->map(function ($part) {
+ return '"'.$part.'"';
+ })->implode('.'));
+ }
+
+ /**
+ * Determine if the given string is a JSON selector.
+ *
+ * @param string $value
+ * @return bool
+ */
+ protected function isJsonSelector($value)
+ {
+ return Str::contains($value, '->');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/PostgresGrammar.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/PostgresGrammar.php
new file mode 100644
index 000000000..77123fe3d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/PostgresGrammar.php
@@ -0,0 +1,331 @@
+', '<=', '>=', '<>', '!=',
+ 'like', 'not like', 'between', 'ilike',
+ '&', '|', '#', '<<', '>>',
+ '@>', '<@', '?', '?|', '?&', '||', '-', '-', '#-',
+ ];
+
+ /**
+ * Compile a "where date" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereDate(Builder $query, $where)
+ {
+ $value = $this->parameter($where['value']);
+
+ return $this->wrap($where['column']).'::date '.$where['operator'].' '.$value;
+ }
+
+ /**
+ * Compile a date based where clause.
+ *
+ * @param string $type
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function dateBasedWhere($type, Builder $query, $where)
+ {
+ $value = $this->parameter($where['value']);
+
+ return 'extract('.$type.' from '.$this->wrap($where['column']).') '.$where['operator'].' '.$value;
+ }
+
+ /**
+ * Compile the lock into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param bool|string $value
+ * @return string
+ */
+ protected function compileLock(Builder $query, $value)
+ {
+ if (! is_string($value)) {
+ return $value ? 'for update' : 'for share';
+ }
+
+ return $value;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function compileInsert(Builder $query, array $values)
+ {
+ $table = $this->wrapTable($query->from);
+
+ return empty($values)
+ ? "insert into {$table} DEFAULT VALUES"
+ : parent::compileInsert($query, $values);
+ }
+
+ /**
+ * Compile an insert and get ID statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $values
+ * @param string $sequence
+ * @return string
+ */
+ public function compileInsertGetId(Builder $query, $values, $sequence)
+ {
+ if (is_null($sequence)) {
+ $sequence = 'id';
+ }
+
+ return $this->compileInsert($query, $values).' returning '.$this->wrap($sequence);
+ }
+
+ /**
+ * Compile an update statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $values
+ * @return string
+ */
+ public function compileUpdate(Builder $query, $values)
+ {
+ $table = $this->wrapTable($query->from);
+
+ // Each one of the columns in the update statements needs to be wrapped in the
+ // keyword identifiers, also a place-holder needs to be created for each of
+ // the values in the list of bindings so we can make the sets statements.
+ $columns = $this->compileUpdateColumns($values);
+
+ $from = $this->compileUpdateFrom($query);
+
+ $where = $this->compileUpdateWheres($query);
+
+ return trim("update {$table} set {$columns}{$from} {$where}");
+ }
+
+ /**
+ * Compile the columns for the update statement.
+ *
+ * @param array $values
+ * @return string
+ */
+ protected function compileUpdateColumns($values)
+ {
+ // When gathering the columns for an update statement, we'll wrap each of the
+ // columns and convert it to a parameter value. Then we will concatenate a
+ // list of the columns that can be added into this update query clauses.
+ return collect($values)->map(function ($value, $key) {
+ return $this->wrap($key).' = '.$this->parameter($value);
+ })->implode(', ');
+ }
+
+ /**
+ * Compile the "from" clause for an update with a join.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string|null
+ */
+ protected function compileUpdateFrom(Builder $query)
+ {
+ if (! isset($query->joins)) {
+ return '';
+ }
+
+ // When using Postgres, updates with joins list the joined tables in the from
+ // clause, which is different than other systems like MySQL. Here, we will
+ // compile out the tables that are joined and add them to a from clause.
+ $froms = collect($query->joins)->map(function ($join) {
+ return $this->wrapTable($join->table);
+ })->all();
+
+ if (count($froms) > 0) {
+ return ' from '.implode(', ', $froms);
+ }
+ }
+
+ /**
+ * Compile the additional where clauses for updates with joins.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ protected function compileUpdateWheres(Builder $query)
+ {
+ $baseWheres = $this->compileWheres($query);
+
+ if (! isset($query->joins)) {
+ return $baseWheres;
+ }
+
+ // Once we compile the join constraints, we will either use them as the where
+ // clause or append them to the existing base where clauses. If we need to
+ // strip the leading boolean we will do so when using as the only where.
+ $joinWheres = $this->compileUpdateJoinWheres($query);
+
+ if (trim($baseWheres) == '') {
+ return 'where '.$this->removeLeadingBoolean($joinWheres);
+ }
+
+ return $baseWheres.' '.$joinWheres;
+ }
+
+ /**
+ * Compile the "join" clause where clauses for an update.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ protected function compileUpdateJoinWheres(Builder $query)
+ {
+ $joinWheres = [];
+
+ // Here we will just loop through all of the join constraints and compile them
+ // all out then implode them. This should give us "where" like syntax after
+ // everything has been built and then we will join it to the real wheres.
+ foreach ($query->joins as $join) {
+ foreach ($join->wheres as $where) {
+ $method = "where{$where['type']}";
+
+ $joinWheres[] = $where['boolean'].' '.$this->$method($query, $where);
+ }
+ }
+
+ return implode(' ', $joinWheres);
+ }
+
+ /**
+ * Prepare the bindings for an update statement.
+ *
+ * @param array $bindings
+ * @param array $values
+ * @return array
+ */
+ public function prepareBindingsForUpdate(array $bindings, array $values)
+ {
+ // Update statements with "joins" in Postgres use an interesting syntax. We need to
+ // take all of the bindings and put them on the end of this array since they are
+ // added to the end of the "where" clause statements as typical where clauses.
+ $bindingsWithoutJoin = Arr::except($bindings, 'join');
+
+ return array_values(
+ array_merge($values, $bindings['join'], Arr::flatten($bindingsWithoutJoin))
+ );
+ }
+
+ /**
+ * Compile a delete statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ public function compileDelete(Builder $query)
+ {
+ $table = $this->wrapTable($query->from);
+
+ return isset($query->joins)
+ ? $this->compileDeleteWithJoins($query, $table)
+ : parent::compileDelete($query);
+ }
+
+ /**
+ * Compile a delete query that uses joins.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param string $table
+ * @param array $where
+ * @return string
+ */
+ protected function compileDeleteWithJoins($query, $table)
+ {
+ $using = ' USING '.collect($query->joins)->map(function ($join) {
+ return $this->wrapTable($join->table);
+ })->implode(', ');
+
+ $where = count($query->wheres) > 0 ? ' '.$this->compileUpdateWheres($query) : '';
+
+ return trim("delete from {$table}{$using}{$where}");
+ }
+
+ /**
+ * Compile a truncate table statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return array
+ */
+ public function compileTruncate(Builder $query)
+ {
+ return ['truncate '.$this->wrapTable($query->from).' restart identity' => []];
+ }
+
+ /**
+ * Wrap a single string in keyword identifiers.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function wrapValue($value)
+ {
+ if ($value === '*') {
+ return $value;
+ }
+
+ // If the given value is a JSON selector we will wrap it differently than a
+ // traditional value. We will need to split this path and wrap each part
+ // wrapped, etc. Otherwise, we will simply wrap the value as a string.
+ if (Str::contains($value, '->')) {
+ return $this->wrapJsonSelector($value);
+ }
+
+ return '"'.str_replace('"', '""', $value).'"';
+ }
+
+ /**
+ * Wrap the given JSON selector.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function wrapJsonSelector($value)
+ {
+ $path = explode('->', $value);
+
+ $field = $this->wrapValue(array_shift($path));
+
+ $wrappedPath = $this->wrapJsonPathAttributes($path);
+
+ $attribute = array_pop($wrappedPath);
+
+ if (! empty($wrappedPath)) {
+ return $field.'->'.implode('->', $wrappedPath).'->>'.$attribute;
+ }
+
+ return $field.'->>'.$attribute;
+ }
+
+ /**
+ * Wrap the attributes of the give JSON path.
+ *
+ * @param array $path
+ * @return array
+ */
+ protected function wrapJsonPathAttributes($path)
+ {
+ return array_map(function ($attribute) {
+ return "'$attribute'";
+ }, $path);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/SQLiteGrammar.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/SQLiteGrammar.php
new file mode 100644
index 000000000..03dfd510a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/SQLiteGrammar.php
@@ -0,0 +1,190 @@
+', '<=', '>=', '<>', '!=',
+ 'like', 'not like', 'between', 'ilike',
+ '&', '|', '<<', '>>',
+ ];
+
+ /**
+ * Compile a select query into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ public function compileSelect(Builder $query)
+ {
+ $sql = parent::compileSelect($query);
+
+ if ($query->unions) {
+ $sql = 'select * from ('.$sql.') '.$this->compileUnions($query);
+ }
+
+ return $sql;
+ }
+
+ /**
+ * Compile a single union statement.
+ *
+ * @param array $union
+ * @return string
+ */
+ protected function compileUnion(array $union)
+ {
+ $conjuction = $union['all'] ? ' union all ' : ' union ';
+
+ return $conjuction.'select * from ('.$union['query']->toSql().')';
+ }
+
+ /**
+ * Compile a "where date" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereDate(Builder $query, $where)
+ {
+ return $this->dateBasedWhere('%Y-%m-%d', $query, $where);
+ }
+
+ /**
+ * Compile a "where day" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereDay(Builder $query, $where)
+ {
+ return $this->dateBasedWhere('%d', $query, $where);
+ }
+
+ /**
+ * Compile a "where month" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereMonth(Builder $query, $where)
+ {
+ return $this->dateBasedWhere('%m', $query, $where);
+ }
+
+ /**
+ * Compile a "where year" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereYear(Builder $query, $where)
+ {
+ return $this->dateBasedWhere('%Y', $query, $where);
+ }
+
+ /**
+ * Compile a date based where clause.
+ *
+ * @param string $type
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function dateBasedWhere($type, Builder $query, $where)
+ {
+ $value = str_pad($where['value'], 2, '0', STR_PAD_LEFT);
+
+ $value = $this->parameter($value);
+
+ return "strftime('{$type}', {$this->wrap($where['column'])}) {$where['operator']} {$value}";
+ }
+
+ /**
+ * Compile an insert statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $values
+ * @return string
+ */
+ public function compileInsert(Builder $query, array $values)
+ {
+ // Essentially we will force every insert to be treated as a batch insert which
+ // simply makes creating the SQL easier for us since we can utilize the same
+ // basic routine regardless of an amount of records given to us to insert.
+ $table = $this->wrapTable($query->from);
+
+ if (! is_array(reset($values))) {
+ $values = [$values];
+ }
+
+ // If there is only one record being inserted, we will just use the usual query
+ // grammar insert builder because no special syntax is needed for the single
+ // row inserts in SQLite. However, if there are multiples, we'll continue.
+ if (count($values) == 1) {
+ return empty(reset($values))
+ ? "insert into $table default values"
+ : parent::compileInsert($query, reset($values));
+ }
+
+ $names = $this->columnize(array_keys(reset($values)));
+
+ $columns = [];
+
+ // SQLite requires us to build the multi-row insert as a listing of select with
+ // unions joining them together. So we'll build out this list of columns and
+ // then join them all together with select unions to complete the queries.
+ foreach (array_keys(reset($values)) as $column) {
+ $columns[] = '? as '.$this->wrap($column);
+ }
+
+ $columns = array_fill(0, count($values), implode(', ', $columns));
+
+ return "insert into $table ($names) select ".implode(' union all select ', $columns);
+ }
+
+ /**
+ * Compile a truncate table statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return array
+ */
+ public function compileTruncate(Builder $query)
+ {
+ return [
+ 'delete from sqlite_sequence where name = ?' => [$query->from],
+ 'delete from '.$this->wrapTable($query->from) => [],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/SqlServerGrammar.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/SqlServerGrammar.php
new file mode 100644
index 000000000..858fd4655
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Grammars/SqlServerGrammar.php
@@ -0,0 +1,442 @@
+', '<=', '>=', '!<', '!>', '<>', '!=',
+ 'like', 'not like', 'between', 'ilike',
+ '&', '&=', '|', '|=', '^', '^=',
+ ];
+
+ /**
+ * Compile a select query into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ public function compileSelect(Builder $query)
+ {
+ if (! $query->offset) {
+ return parent::compileSelect($query);
+ }
+
+ // If an offset is present on the query, we will need to wrap the query in
+ // a big "ANSI" offset syntax block. This is very nasty compared to the
+ // other database systems but is necessary for implementing features.
+ if (is_null($query->columns)) {
+ $query->columns = ['*'];
+ }
+
+ return $this->compileAnsiOffset(
+ $query, $this->compileComponents($query)
+ );
+ }
+
+ /**
+ * Compile the "select *" portion of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $columns
+ * @return string|null
+ */
+ protected function compileColumns(Builder $query, $columns)
+ {
+ if (! is_null($query->aggregate)) {
+ return;
+ }
+
+ $select = $query->distinct ? 'select distinct ' : 'select ';
+
+ // If there is a limit on the query, but not an offset, we will add the top
+ // clause to the query, which serves as a "limit" type clause within the
+ // SQL Server system similar to the limit keywords available in MySQL.
+ if ($query->limit > 0 && $query->offset <= 0) {
+ $select .= 'top '.$query->limit.' ';
+ }
+
+ return $select.$this->columnize($columns);
+ }
+
+ /**
+ * Compile the "from" portion of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param string $table
+ * @return string
+ */
+ protected function compileFrom(Builder $query, $table)
+ {
+ $from = parent::compileFrom($query, $table);
+
+ if (is_string($query->lock)) {
+ return $from.' '.$query->lock;
+ }
+
+ if (! is_null($query->lock)) {
+ return $from.' with(rowlock,'.($query->lock ? 'updlock,' : '').'holdlock)';
+ }
+
+ return $from;
+ }
+
+ /**
+ * Compile a "where date" clause.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $where
+ * @return string
+ */
+ protected function whereDate(Builder $query, $where)
+ {
+ $value = $this->parameter($where['value']);
+
+ return 'cast('.$this->wrap($where['column']).' as date) '.$where['operator'].' '.$value;
+ }
+
+ /**
+ * Create a full ANSI offset clause for the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $components
+ * @return string
+ */
+ protected function compileAnsiOffset(Builder $query, $components)
+ {
+ // An ORDER BY clause is required to make this offset query work, so if one does
+ // not exist we'll just create a dummy clause to trick the database and so it
+ // does not complain about the queries for not having an "order by" clause.
+ if (empty($components['orders'])) {
+ $components['orders'] = 'order by (select 0)';
+ }
+
+ // We need to add the row number to the query so we can compare it to the offset
+ // and limit values given for the statements. So we will add an expression to
+ // the "select" that will give back the row numbers on each of the records.
+ $components['columns'] .= $this->compileOver($components['orders']);
+
+ unset($components['orders']);
+
+ // Next we need to calculate the constraints that should be placed on the query
+ // to get the right offset and limit from our query but if there is no limit
+ // set we will just handle the offset only since that is all that matters.
+ $sql = $this->concatenate($components);
+
+ return $this->compileTableExpression($sql, $query);
+ }
+
+ /**
+ * Compile the over statement for a table expression.
+ *
+ * @param string $orderings
+ * @return string
+ */
+ protected function compileOver($orderings)
+ {
+ return ", row_number() over ({$orderings}) as row_num";
+ }
+
+ /**
+ * Compile a common table expression for a query.
+ *
+ * @param string $sql
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ protected function compileTableExpression($sql, $query)
+ {
+ $constraint = $this->compileRowConstraint($query);
+
+ return "select * from ({$sql}) as temp_table where row_num {$constraint}";
+ }
+
+ /**
+ * Compile the limit / offset row constraint for a query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ protected function compileRowConstraint($query)
+ {
+ $start = $query->offset + 1;
+
+ if ($query->limit > 0) {
+ $finish = $query->offset + $query->limit;
+
+ return "between {$start} and {$finish}";
+ }
+
+ return ">= {$start}";
+ }
+
+ /**
+ * Compile the random statement into SQL.
+ *
+ * @param string $seed
+ * @return string
+ */
+ public function compileRandom($seed)
+ {
+ return 'NEWID()';
+ }
+
+ /**
+ * Compile the "limit" portions of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param int $limit
+ * @return string
+ */
+ protected function compileLimit(Builder $query, $limit)
+ {
+ return '';
+ }
+
+ /**
+ * Compile the "offset" portions of the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param int $offset
+ * @return string
+ */
+ protected function compileOffset(Builder $query, $offset)
+ {
+ return '';
+ }
+
+ /**
+ * Compile the lock into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param bool|string $value
+ * @return string
+ */
+ protected function compileLock(Builder $query, $value)
+ {
+ return '';
+ }
+
+ /**
+ * Compile an exists statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ public function compileExists(Builder $query)
+ {
+ $existsQuery = clone $query;
+
+ $existsQuery->columns = [];
+
+ return $this->compileSelect($existsQuery->selectRaw('1 [exists]')->limit(1));
+ }
+
+ /**
+ * Compile a delete statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return string
+ */
+ public function compileDelete(Builder $query)
+ {
+ $table = $this->wrapTable($query->from);
+
+ $where = is_array($query->wheres) ? $this->compileWheres($query) : '';
+
+ return isset($query->joins)
+ ? $this->compileDeleteWithJoins($query, $table, $where)
+ : trim("delete from {$table} {$where}");
+ }
+
+ /**
+ * Compile a delete statement with joins into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param string $table
+ * @param string $where
+ * @return string
+ */
+ protected function compileDeleteWithJoins(Builder $query, $table, $where)
+ {
+ $joins = ' '.$this->compileJoins($query, $query->joins);
+
+ $alias = strpos(strtolower($table), ' as ') !== false
+ ? explode(' as ', $table)[1] : $table;
+
+ return trim("delete {$alias} from {$table}{$joins} {$where}");
+ }
+
+ /**
+ * Compile a truncate table statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return array
+ */
+ public function compileTruncate(Builder $query)
+ {
+ return ['truncate table '.$this->wrapTable($query->from) => []];
+ }
+
+ /**
+ * Compile an update statement into SQL.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $values
+ * @return string
+ */
+ public function compileUpdate(Builder $query, $values)
+ {
+ list($table, $alias) = $this->parseUpdateTable($query->from);
+
+ // Each one of the columns in the update statements needs to be wrapped in the
+ // keyword identifiers, also a place-holder needs to be created for each of
+ // the values in the list of bindings so we can make the sets statements.
+ $columns = collect($values)->map(function ($value, $key) {
+ return $this->wrap($key).' = '.$this->parameter($value);
+ })->implode(', ');
+
+ // If the query has any "join" clauses, we will setup the joins on the builder
+ // and compile them so we can attach them to this update, as update queries
+ // can get join statements to attach to other tables when they're needed.
+ $joins = '';
+
+ if (isset($query->joins)) {
+ $joins = ' '.$this->compileJoins($query, $query->joins);
+ }
+
+ // Of course, update queries may also be constrained by where clauses so we'll
+ // need to compile the where clauses and attach it to the query so only the
+ // intended records are updated by the SQL statements we generate to run.
+ $where = $this->compileWheres($query);
+
+ if (! empty($joins)) {
+ return trim("update {$alias} set {$columns} from {$table}{$joins} {$where}");
+ }
+
+ return trim("update {$table}{$joins} set $columns $where");
+ }
+
+ /**
+ * Get the table and alias for the given table.
+ *
+ * @param string $table
+ * @return array
+ */
+ protected function parseUpdateTable($table)
+ {
+ $table = $alias = $this->wrapTable($table);
+
+ if (strpos(strtolower($table), '] as [') !== false) {
+ $alias = '['.explode('] as [', $table)[1];
+ }
+
+ return [$table, $alias];
+ }
+
+ /**
+ * Prepare the bindings for an update statement.
+ *
+ * @param array $bindings
+ * @param array $values
+ * @return array
+ */
+ public function prepareBindingsForUpdate(array $bindings, array $values)
+ {
+ // Update statements with joins in SQL Servers utilize an unique syntax. We need to
+ // take all of the bindings and put them on the end of this array since they are
+ // added to the end of the "where" clause statements as typical where clauses.
+ $bindingsWithoutJoin = Arr::except($bindings, 'join');
+
+ return array_values(
+ array_merge($values, $bindings['join'], Arr::flatten($bindingsWithoutJoin))
+ );
+ }
+
+ /**
+ * Determine if the grammar supports savepoints.
+ *
+ * @return bool
+ */
+ public function supportsSavepoints()
+ {
+ return true;
+ }
+
+ /**
+ * Compile the SQL statement to define a savepoint.
+ *
+ * @param string $name
+ * @return string
+ */
+ public function compileSavepoint($name)
+ {
+ return 'SAVE TRANSACTION '.$name;
+ }
+
+ /**
+ * Compile the SQL statement to execute a savepoint rollback.
+ *
+ * @param string $name
+ * @return string
+ */
+ public function compileSavepointRollBack($name)
+ {
+ return 'ROLLBACK TRANSACTION '.$name;
+ }
+
+ /**
+ * Get the format for database stored dates.
+ *
+ * @return string
+ */
+ public function getDateFormat()
+ {
+ return 'Y-m-d H:i:s.000';
+ }
+
+ /**
+ * Wrap a single string in keyword identifiers.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function wrapValue($value)
+ {
+ return $value === '*' ? $value : '['.str_replace(']', ']]', $value).']';
+ }
+
+ /**
+ * Wrap a table in keyword identifiers.
+ *
+ * @param \Illuminate\Database\Query\Expression|string $table
+ * @return string
+ */
+ public function wrapTable($table)
+ {
+ return $this->wrapTableValuedFunction(parent::wrapTable($table));
+ }
+
+ /**
+ * Wrap a table in keyword identifiers.
+ *
+ * @param string $table
+ * @return string
+ */
+ protected function wrapTableValuedFunction($table)
+ {
+ if (preg_match('/^(.+?)(\(.*?\))]$/', $table, $matches) === 1) {
+ $table = $matches[1].']'.$matches[2];
+ }
+
+ return $table;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/JoinClause.php b/vendor/laravel/framework/src/Illuminate/Database/Query/JoinClause.php
new file mode 100644
index 000000000..ca7b4d454
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/JoinClause.php
@@ -0,0 +1,100 @@
+type = $type;
+ $this->table = $table;
+ $this->parentQuery = $parentQuery;
+
+ parent::__construct(
+ $parentQuery->getConnection(), $parentQuery->getGrammar(), $parentQuery->getProcessor()
+ );
+ }
+
+ /**
+ * Add an "on" clause to the join.
+ *
+ * On clauses can be chained, e.g.
+ *
+ * $join->on('contacts.user_id', '=', 'users.id')
+ * ->on('contacts.info_id', '=', 'info.id')
+ *
+ * will produce the following SQL:
+ *
+ * on `contacts`.`user_id` = `users`.`id` and `contacts`.`info_id` = `info`.`id`
+ *
+ * @param \Closure|string $first
+ * @param string|null $operator
+ * @param string|null $second
+ * @param string $boolean
+ * @return $this
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function on($first, $operator = null, $second = null, $boolean = 'and')
+ {
+ if ($first instanceof Closure) {
+ return $this->whereNested($first, $boolean);
+ }
+
+ return $this->whereColumn($first, $operator, $second, $boolean);
+ }
+
+ /**
+ * Add an "or on" clause to the join.
+ *
+ * @param \Closure|string $first
+ * @param string|null $operator
+ * @param string|null $second
+ * @return \Illuminate\Database\Query\JoinClause
+ */
+ public function orOn($first, $operator = null, $second = null)
+ {
+ return $this->on($first, $operator, $second, 'or');
+ }
+
+ /**
+ * Get a new instance of the join clause builder.
+ *
+ * @return \Illuminate\Database\Query\JoinClause
+ */
+ public function newQuery()
+ {
+ return new static($this->parentQuery, $this->type, $this->table);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/JsonExpression.php b/vendor/laravel/framework/src/Illuminate/Database/Query/JsonExpression.php
new file mode 100644
index 000000000..648a7da1d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/JsonExpression.php
@@ -0,0 +1,70 @@
+value = $this->getJsonBindingParameter($value);
+ }
+
+ /**
+ * Translate the given value into the appropriate JSON binding parameter.
+ *
+ * @param mixed $value
+ * @return string
+ */
+ protected function getJsonBindingParameter($value)
+ {
+ switch ($type = gettype($value)) {
+ case 'boolean':
+ return $value ? 'true' : 'false';
+ case 'integer':
+ case 'double':
+ return $value;
+ case 'string':
+ return '?';
+ case 'object':
+ case 'array':
+ return '?';
+ }
+
+ throw new InvalidArgumentException('JSON value is of illegal type: '.$type);
+ }
+
+ /**
+ * Get the value of the expression.
+ *
+ * @return mixed
+ */
+ public function getValue()
+ {
+ return $this->value;
+ }
+
+ /**
+ * Get the value of the expression.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return (string) $this->getValue();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/MySqlProcessor.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/MySqlProcessor.php
new file mode 100644
index 000000000..eeb07b06a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/MySqlProcessor.php
@@ -0,0 +1,19 @@
+column_name;
+ }, $results);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/PostgresProcessor.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/PostgresProcessor.php
new file mode 100644
index 000000000..dcaee9f23
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/PostgresProcessor.php
@@ -0,0 +1,41 @@
+getConnection()->selectFromWriteConnection($sql, $values)[0];
+
+ $sequence = $sequence ?: 'id';
+
+ $id = is_object($result) ? $result->{$sequence} : $result[$sequence];
+
+ return is_numeric($id) ? (int) $id : $id;
+ }
+
+ /**
+ * Process the results of a column listing query.
+ *
+ * @param array $results
+ * @return array
+ */
+ public function processColumnListing($results)
+ {
+ return array_map(function ($result) {
+ return with((object) $result)->column_name;
+ }, $results);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/Processor.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/Processor.php
new file mode 100644
index 000000000..f78429fba
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/Processor.php
@@ -0,0 +1,49 @@
+getConnection()->insert($sql, $values);
+
+ $id = $query->getConnection()->getPdo()->lastInsertId($sequence);
+
+ return is_numeric($id) ? (int) $id : $id;
+ }
+
+ /**
+ * Process the results of a column listing query.
+ *
+ * @param array $results
+ * @return array
+ */
+ public function processColumnListing($results)
+ {
+ return $results;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/SQLiteProcessor.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/SQLiteProcessor.php
new file mode 100644
index 000000000..ef9cb5ab2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/SQLiteProcessor.php
@@ -0,0 +1,19 @@
+name;
+ }, $results);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/SqlServerProcessor.php b/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/SqlServerProcessor.php
new file mode 100644
index 000000000..b5314c804
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Query/Processors/SqlServerProcessor.php
@@ -0,0 +1,69 @@
+getConnection();
+
+ $connection->insert($sql, $values);
+
+ if ($connection->getConfig('odbc') === true) {
+ $id = $this->processInsertGetIdForOdbc($connection);
+ } else {
+ $id = $connection->getPdo()->lastInsertId();
+ }
+
+ return is_numeric($id) ? (int) $id : $id;
+ }
+
+ /**
+ * Process an "insert get ID" query for ODBC.
+ *
+ * @param \Illuminate\Database\Connection $connection
+ * @return int
+ * @throws \Exception
+ */
+ protected function processInsertGetIdForOdbc(Connection $connection)
+ {
+ $result = $connection->selectFromWriteConnection(
+ 'SELECT CAST(COALESCE(SCOPE_IDENTITY(), @@IDENTITY) AS int) AS insertid'
+ );
+
+ if (! $result) {
+ throw new Exception('Unable to retrieve lastInsertID for ODBC.');
+ }
+
+ $row = $result[0];
+
+ return is_object($row) ? $row->insertid : $row['insertid'];
+ }
+
+ /**
+ * Process the results of a column listing query.
+ *
+ * @param array $results
+ * @return array
+ */
+ public function processColumnListing($results)
+ {
+ return array_map(function ($result) {
+ return with((object) $result)->name;
+ }, $results);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/QueryException.php b/vendor/laravel/framework/src/Illuminate/Database/QueryException.php
new file mode 100644
index 000000000..9a3687d65
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/QueryException.php
@@ -0,0 +1,78 @@
+sql = $sql;
+ $this->bindings = $bindings;
+ $this->code = $previous->getCode();
+ $this->message = $this->formatMessage($sql, $bindings, $previous);
+
+ if ($previous instanceof PDOException) {
+ $this->errorInfo = $previous->errorInfo;
+ }
+ }
+
+ /**
+ * Format the SQL error message.
+ *
+ * @param string $sql
+ * @param array $bindings
+ * @param \Exception $previous
+ * @return string
+ */
+ protected function formatMessage($sql, $bindings, $previous)
+ {
+ return $previous->getMessage().' (SQL: '.Str::replaceArray('?', $bindings, $sql).')';
+ }
+
+ /**
+ * Get the SQL for the query.
+ *
+ * @return string
+ */
+ public function getSql()
+ {
+ return $this->sql;
+ }
+
+ /**
+ * Get the bindings for the query.
+ *
+ * @return array
+ */
+ public function getBindings()
+ {
+ return $this->bindings;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/README.md b/vendor/laravel/framework/src/Illuminate/Database/README.md
new file mode 100644
index 000000000..b3014b082
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/README.md
@@ -0,0 +1,69 @@
+## Illuminate Database
+
+The Illuminate Database component is a full database toolkit for PHP, providing an expressive query builder, ActiveRecord style ORM, and schema builder. It currently supports MySQL, Postgres, SQL Server, and SQLite. It also serves as the database layer of the Laravel PHP framework.
+
+### Usage Instructions
+
+First, create a new "Capsule" manager instance. Capsule aims to make configuring the library for usage outside of the Laravel framework as easy as possible.
+
+```PHP
+use Illuminate\Database\Capsule\Manager as Capsule;
+
+$capsule = new Capsule;
+
+$capsule->addConnection([
+ 'driver' => 'mysql',
+ 'host' => 'localhost',
+ 'database' => 'database',
+ 'username' => 'root',
+ 'password' => 'password',
+ 'charset' => 'utf8',
+ 'collation' => 'utf8_unicode_ci',
+ 'prefix' => '',
+]);
+
+// Set the event dispatcher used by Eloquent models... (optional)
+use Illuminate\Events\Dispatcher;
+use Illuminate\Container\Container;
+$capsule->setEventDispatcher(new Dispatcher(new Container));
+
+// Make this Capsule instance available globally via static methods... (optional)
+$capsule->setAsGlobal();
+
+// Setup the Eloquent ORM... (optional; unless you've used setEventDispatcher())
+$capsule->bootEloquent();
+```
+
+> `composer require "illuminate/events"` required when you need to use observers with Eloquent.
+
+Once the Capsule instance has been registered. You may use it like so:
+
+**Using The Query Builder**
+
+```PHP
+$users = Capsule::table('users')->where('votes', '>', 100)->get();
+```
+Other core methods may be accessed directly from the Capsule in the same manner as from the DB facade:
+```PHP
+$results = Capsule::select('select * from users where id = ?', array(1));
+```
+
+**Using The Schema Builder**
+
+```PHP
+Capsule::schema()->create('users', function ($table) {
+ $table->increments('id');
+ $table->string('email')->unique();
+ $table->timestamps();
+});
+```
+
+**Using The Eloquent ORM**
+
+```PHP
+class User extends Illuminate\Database\Eloquent\Model {}
+
+$users = User::where('votes', '>', 1)->get();
+```
+
+For further documentation on using the various database facilities this library provides, consult the [Laravel framework documentation](https://laravel.com/docs).
diff --git a/vendor/laravel/framework/src/Illuminate/Database/SQLiteConnection.php b/vendor/laravel/framework/src/Illuminate/Database/SQLiteConnection.php
new file mode 100644
index 000000000..b32786c10
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/SQLiteConnection.php
@@ -0,0 +1,51 @@
+withTablePrefix(new QueryGrammar);
+ }
+
+ /**
+ * Get the default schema grammar instance.
+ *
+ * @return \Illuminate\Database\Schema\Grammars\SQLiteGrammar
+ */
+ protected function getDefaultSchemaGrammar()
+ {
+ return $this->withTablePrefix(new SchemaGrammar);
+ }
+
+ /**
+ * Get the default post processor instance.
+ *
+ * @return \Illuminate\Database\Query\Processors\SQLiteProcessor
+ */
+ protected function getDefaultPostProcessor()
+ {
+ return new SQLiteProcessor;
+ }
+
+ /**
+ * Get the Doctrine DBAL driver.
+ *
+ * @return \Doctrine\DBAL\Driver\PDOSqlite\Driver
+ */
+ protected function getDoctrineDriver()
+ {
+ return new DoctrineDriver;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/Blueprint.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/Blueprint.php
new file mode 100644
index 000000000..e3274101e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/Blueprint.php
@@ -0,0 +1,1130 @@
+table = $table;
+
+ if (! is_null($callback)) {
+ $callback($this);
+ }
+ }
+
+ /**
+ * Execute the blueprint against the database.
+ *
+ * @param \Illuminate\Database\Connection $connection
+ * @param \Illuminate\Database\Schema\Grammars\Grammar $grammar
+ * @return void
+ */
+ public function build(Connection $connection, Grammar $grammar)
+ {
+ foreach ($this->toSql($connection, $grammar) as $statement) {
+ $connection->statement($statement);
+ }
+ }
+
+ /**
+ * Get the raw SQL statements for the blueprint.
+ *
+ * @param \Illuminate\Database\Connection $connection
+ * @param \Illuminate\Database\Schema\Grammars\Grammar $grammar
+ * @return array
+ */
+ public function toSql(Connection $connection, Grammar $grammar)
+ {
+ $this->addImpliedCommands();
+
+ $statements = [];
+
+ // Each type of command has a corresponding compiler function on the schema
+ // grammar which is used to build the necessary SQL statements to build
+ // the blueprint element, so we'll just call that compilers function.
+ foreach ($this->commands as $command) {
+ $method = 'compile'.ucfirst($command->name);
+
+ if (method_exists($grammar, $method)) {
+ if (! is_null($sql = $grammar->$method($this, $command, $connection))) {
+ $statements = array_merge($statements, (array) $sql);
+ }
+ }
+ }
+
+ return $statements;
+ }
+
+ /**
+ * Add the commands that are implied by the blueprint's state.
+ *
+ * @return void
+ */
+ protected function addImpliedCommands()
+ {
+ if (count($this->getAddedColumns()) > 0 && ! $this->creating()) {
+ array_unshift($this->commands, $this->createCommand('add'));
+ }
+
+ if (count($this->getChangedColumns()) > 0 && ! $this->creating()) {
+ array_unshift($this->commands, $this->createCommand('change'));
+ }
+
+ $this->addFluentIndexes();
+ }
+
+ /**
+ * Add the index commands fluently specified on columns.
+ *
+ * @return void
+ */
+ protected function addFluentIndexes()
+ {
+ foreach ($this->columns as $column) {
+ foreach (['primary', 'unique', 'index'] as $index) {
+ // If the index has been specified on the given column, but is simply equal
+ // to "true" (boolean), no name has been specified for this index so the
+ // index method can be called without a name and it will generate one.
+ if ($column->{$index} === true) {
+ $this->{$index}($column->name);
+
+ continue 2;
+ }
+
+ // If the index has been specified on the given column, and it has a string
+ // value, we'll go ahead and call the index method and pass the name for
+ // the index since the developer specified the explicit name for this.
+ elseif (isset($column->{$index})) {
+ $this->{$index}($column->name, $column->{$index});
+
+ continue 2;
+ }
+ }
+ }
+ }
+
+ /**
+ * Determine if the blueprint has a create command.
+ *
+ * @return bool
+ */
+ protected function creating()
+ {
+ return collect($this->commands)->contains(function ($command) {
+ return $command->name == 'create';
+ });
+ }
+
+ /**
+ * Indicate that the table needs to be created.
+ *
+ * @return \Illuminate\Support\Fluent
+ */
+ public function create()
+ {
+ return $this->addCommand('create');
+ }
+
+ /**
+ * Indicate that the table needs to be temporary.
+ *
+ * @return void
+ */
+ public function temporary()
+ {
+ $this->temporary = true;
+ }
+
+ /**
+ * Indicate that the table should be dropped.
+ *
+ * @return \Illuminate\Support\Fluent
+ */
+ public function drop()
+ {
+ return $this->addCommand('drop');
+ }
+
+ /**
+ * Indicate that the table should be dropped if it exists.
+ *
+ * @return \Illuminate\Support\Fluent
+ */
+ public function dropIfExists()
+ {
+ return $this->addCommand('dropIfExists');
+ }
+
+ /**
+ * Indicate that the given columns should be dropped.
+ *
+ * @param array|mixed $columns
+ * @return \Illuminate\Support\Fluent
+ */
+ public function dropColumn($columns)
+ {
+ $columns = is_array($columns) ? $columns : (array) func_get_args();
+
+ return $this->addCommand('dropColumn', compact('columns'));
+ }
+
+ /**
+ * Indicate that the given columns should be renamed.
+ *
+ * @param string $from
+ * @param string $to
+ * @return \Illuminate\Support\Fluent
+ */
+ public function renameColumn($from, $to)
+ {
+ return $this->addCommand('renameColumn', compact('from', 'to'));
+ }
+
+ /**
+ * Indicate that the given primary key should be dropped.
+ *
+ * @param string|array $index
+ * @return \Illuminate\Support\Fluent
+ */
+ public function dropPrimary($index = null)
+ {
+ return $this->dropIndexCommand('dropPrimary', 'primary', $index);
+ }
+
+ /**
+ * Indicate that the given unique key should be dropped.
+ *
+ * @param string|array $index
+ * @return \Illuminate\Support\Fluent
+ */
+ public function dropUnique($index)
+ {
+ return $this->dropIndexCommand('dropUnique', 'unique', $index);
+ }
+
+ /**
+ * Indicate that the given index should be dropped.
+ *
+ * @param string|array $index
+ * @return \Illuminate\Support\Fluent
+ */
+ public function dropIndex($index)
+ {
+ return $this->dropIndexCommand('dropIndex', 'index', $index);
+ }
+
+ /**
+ * Indicate that the given foreign key should be dropped.
+ *
+ * @param string|array $index
+ * @return \Illuminate\Support\Fluent
+ */
+ public function dropForeign($index)
+ {
+ return $this->dropIndexCommand('dropForeign', 'foreign', $index);
+ }
+
+ /**
+ * Indicate that the timestamp columns should be dropped.
+ *
+ * @return void
+ */
+ public function dropTimestamps()
+ {
+ $this->dropColumn('created_at', 'updated_at');
+ }
+
+ /**
+ * Indicate that the timestamp columns should be dropped.
+ *
+ * @return void
+ */
+ public function dropTimestampsTz()
+ {
+ $this->dropTimestamps();
+ }
+
+ /**
+ * Indicate that the soft delete column should be dropped.
+ *
+ * @return void
+ */
+ public function dropSoftDeletes()
+ {
+ $this->dropColumn('deleted_at');
+ }
+
+ /**
+ * Indicate that the soft delete column should be dropped.
+ *
+ * @return void
+ */
+ public function dropSoftDeletesTz()
+ {
+ $this->dropSoftDeletes();
+ }
+
+ /**
+ * Indicate that the remember token column should be dropped.
+ *
+ * @return void
+ */
+ public function dropRememberToken()
+ {
+ $this->dropColumn('remember_token');
+ }
+
+ /**
+ * Rename the table to a given name.
+ *
+ * @param string $to
+ * @return \Illuminate\Support\Fluent
+ */
+ public function rename($to)
+ {
+ return $this->addCommand('rename', compact('to'));
+ }
+
+ /**
+ * Specify the primary key(s) for the table.
+ *
+ * @param string|array $columns
+ * @param string $name
+ * @param string|null $algorithm
+ * @return \Illuminate\Support\Fluent
+ */
+ public function primary($columns, $name = null, $algorithm = null)
+ {
+ return $this->indexCommand('primary', $columns, $name, $algorithm);
+ }
+
+ /**
+ * Specify a unique index for the table.
+ *
+ * @param string|array $columns
+ * @param string $name
+ * @param string|null $algorithm
+ * @return \Illuminate\Support\Fluent
+ */
+ public function unique($columns, $name = null, $algorithm = null)
+ {
+ return $this->indexCommand('unique', $columns, $name, $algorithm);
+ }
+
+ /**
+ * Specify an index for the table.
+ *
+ * @param string|array $columns
+ * @param string $name
+ * @param string|null $algorithm
+ * @return \Illuminate\Support\Fluent
+ */
+ public function index($columns, $name = null, $algorithm = null)
+ {
+ return $this->indexCommand('index', $columns, $name, $algorithm);
+ }
+
+ /**
+ * Specify a foreign key for the table.
+ *
+ * @param string|array $columns
+ * @param string $name
+ * @return \Illuminate\Support\Fluent
+ */
+ public function foreign($columns, $name = null)
+ {
+ return $this->indexCommand('foreign', $columns, $name);
+ }
+
+ /**
+ * Create a new auto-incrementing integer (4-byte) column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function increments($column)
+ {
+ return $this->unsignedInteger($column, true);
+ }
+
+ /**
+ * Create a new auto-incrementing tiny integer (1-byte) column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function tinyIncrements($column)
+ {
+ return $this->unsignedTinyInteger($column, true);
+ }
+
+ /**
+ * Create a new auto-incrementing small integer (2-byte) column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function smallIncrements($column)
+ {
+ return $this->unsignedSmallInteger($column, true);
+ }
+
+ /**
+ * Create a new auto-incrementing medium integer (3-byte) column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function mediumIncrements($column)
+ {
+ return $this->unsignedMediumInteger($column, true);
+ }
+
+ /**
+ * Create a new auto-incrementing big integer (8-byte) column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function bigIncrements($column)
+ {
+ return $this->unsignedBigInteger($column, true);
+ }
+
+ /**
+ * Create a new char column on the table.
+ *
+ * @param string $column
+ * @param int $length
+ * @return \Illuminate\Support\Fluent
+ */
+ public function char($column, $length = null)
+ {
+ $length = $length ?: Builder::$defaultStringLength;
+
+ return $this->addColumn('char', $column, compact('length'));
+ }
+
+ /**
+ * Create a new string column on the table.
+ *
+ * @param string $column
+ * @param int $length
+ * @return \Illuminate\Support\Fluent
+ */
+ public function string($column, $length = null)
+ {
+ $length = $length ?: Builder::$defaultStringLength;
+
+ return $this->addColumn('string', $column, compact('length'));
+ }
+
+ /**
+ * Create a new text column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function text($column)
+ {
+ return $this->addColumn('text', $column);
+ }
+
+ /**
+ * Create a new medium text column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function mediumText($column)
+ {
+ return $this->addColumn('mediumText', $column);
+ }
+
+ /**
+ * Create a new long text column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function longText($column)
+ {
+ return $this->addColumn('longText', $column);
+ }
+
+ /**
+ * Create a new integer (4-byte) column on the table.
+ *
+ * @param string $column
+ * @param bool $autoIncrement
+ * @param bool $unsigned
+ * @return \Illuminate\Support\Fluent
+ */
+ public function integer($column, $autoIncrement = false, $unsigned = false)
+ {
+ return $this->addColumn('integer', $column, compact('autoIncrement', 'unsigned'));
+ }
+
+ /**
+ * Create a new tiny integer (1-byte) column on the table.
+ *
+ * @param string $column
+ * @param bool $autoIncrement
+ * @param bool $unsigned
+ * @return \Illuminate\Support\Fluent
+ */
+ public function tinyInteger($column, $autoIncrement = false, $unsigned = false)
+ {
+ return $this->addColumn('tinyInteger', $column, compact('autoIncrement', 'unsigned'));
+ }
+
+ /**
+ * Create a new small integer (2-byte) column on the table.
+ *
+ * @param string $column
+ * @param bool $autoIncrement
+ * @param bool $unsigned
+ * @return \Illuminate\Support\Fluent
+ */
+ public function smallInteger($column, $autoIncrement = false, $unsigned = false)
+ {
+ return $this->addColumn('smallInteger', $column, compact('autoIncrement', 'unsigned'));
+ }
+
+ /**
+ * Create a new medium integer (3-byte) column on the table.
+ *
+ * @param string $column
+ * @param bool $autoIncrement
+ * @param bool $unsigned
+ * @return \Illuminate\Support\Fluent
+ */
+ public function mediumInteger($column, $autoIncrement = false, $unsigned = false)
+ {
+ return $this->addColumn('mediumInteger', $column, compact('autoIncrement', 'unsigned'));
+ }
+
+ /**
+ * Create a new big integer (8-byte) column on the table.
+ *
+ * @param string $column
+ * @param bool $autoIncrement
+ * @param bool $unsigned
+ * @return \Illuminate\Support\Fluent
+ */
+ public function bigInteger($column, $autoIncrement = false, $unsigned = false)
+ {
+ return $this->addColumn('bigInteger', $column, compact('autoIncrement', 'unsigned'));
+ }
+
+ /**
+ * Create a new unsigned integer (4-byte) column on the table.
+ *
+ * @param string $column
+ * @param bool $autoIncrement
+ * @return \Illuminate\Support\Fluent
+ */
+ public function unsignedInteger($column, $autoIncrement = false)
+ {
+ return $this->integer($column, $autoIncrement, true);
+ }
+
+ /**
+ * Create a new unsigned tiny integer (1-byte) column on the table.
+ *
+ * @param string $column
+ * @param bool $autoIncrement
+ * @return \Illuminate\Support\Fluent
+ */
+ public function unsignedTinyInteger($column, $autoIncrement = false)
+ {
+ return $this->tinyInteger($column, $autoIncrement, true);
+ }
+
+ /**
+ * Create a new unsigned small integer (2-byte) column on the table.
+ *
+ * @param string $column
+ * @param bool $autoIncrement
+ * @return \Illuminate\Support\Fluent
+ */
+ public function unsignedSmallInteger($column, $autoIncrement = false)
+ {
+ return $this->smallInteger($column, $autoIncrement, true);
+ }
+
+ /**
+ * Create a new unsigned medium integer (3-byte) column on the table.
+ *
+ * @param string $column
+ * @param bool $autoIncrement
+ * @return \Illuminate\Support\Fluent
+ */
+ public function unsignedMediumInteger($column, $autoIncrement = false)
+ {
+ return $this->mediumInteger($column, $autoIncrement, true);
+ }
+
+ /**
+ * Create a new unsigned big integer (8-byte) column on the table.
+ *
+ * @param string $column
+ * @param bool $autoIncrement
+ * @return \Illuminate\Support\Fluent
+ */
+ public function unsignedBigInteger($column, $autoIncrement = false)
+ {
+ return $this->bigInteger($column, $autoIncrement, true);
+ }
+
+ /**
+ * Create a new float column on the table.
+ *
+ * @param string $column
+ * @param int $total
+ * @param int $places
+ * @return \Illuminate\Support\Fluent
+ */
+ public function float($column, $total = 8, $places = 2)
+ {
+ return $this->addColumn('float', $column, compact('total', 'places'));
+ }
+
+ /**
+ * Create a new double column on the table.
+ *
+ * @param string $column
+ * @param int|null $total
+ * @param int|null $places
+ * @return \Illuminate\Support\Fluent
+ */
+ public function double($column, $total = null, $places = null)
+ {
+ return $this->addColumn('double', $column, compact('total', 'places'));
+ }
+
+ /**
+ * Create a new decimal column on the table.
+ *
+ * @param string $column
+ * @param int $total
+ * @param int $places
+ * @return \Illuminate\Support\Fluent
+ */
+ public function decimal($column, $total = 8, $places = 2)
+ {
+ return $this->addColumn('decimal', $column, compact('total', 'places'));
+ }
+
+ /**
+ * Create a new unsigned decimal column on the table.
+ *
+ * @param string $column
+ * @param int $total
+ * @param int $places
+ * @return \Illuminate\Support\Fluent
+ */
+ public function unsignedDecimal($column, $total = 8, $places = 2)
+ {
+ return $this->addColumn('decimal', $column, [
+ 'total' => $total, 'places' => $places, 'unsigned' => true,
+ ]);
+ }
+
+ /**
+ * Create a new boolean column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function boolean($column)
+ {
+ return $this->addColumn('boolean', $column);
+ }
+
+ /**
+ * Create a new enum column on the table.
+ *
+ * @param string $column
+ * @param array $allowed
+ * @return \Illuminate\Support\Fluent
+ */
+ public function enum($column, array $allowed)
+ {
+ return $this->addColumn('enum', $column, compact('allowed'));
+ }
+
+ /**
+ * Create a new json column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function json($column)
+ {
+ return $this->addColumn('json', $column);
+ }
+
+ /**
+ * Create a new jsonb column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function jsonb($column)
+ {
+ return $this->addColumn('jsonb', $column);
+ }
+
+ /**
+ * Create a new date column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function date($column)
+ {
+ return $this->addColumn('date', $column);
+ }
+
+ /**
+ * Create a new date-time column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function dateTime($column)
+ {
+ return $this->addColumn('dateTime', $column);
+ }
+
+ /**
+ * Create a new date-time column (with time zone) on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function dateTimeTz($column)
+ {
+ return $this->addColumn('dateTimeTz', $column);
+ }
+
+ /**
+ * Create a new time column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function time($column)
+ {
+ return $this->addColumn('time', $column);
+ }
+
+ /**
+ * Create a new time column (with time zone) on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function timeTz($column)
+ {
+ return $this->addColumn('timeTz', $column);
+ }
+
+ /**
+ * Create a new timestamp column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function timestamp($column)
+ {
+ return $this->addColumn('timestamp', $column);
+ }
+
+ /**
+ * Create a new timestamp (with time zone) column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function timestampTz($column)
+ {
+ return $this->addColumn('timestampTz', $column);
+ }
+
+ /**
+ * Add nullable creation and update timestamps to the table.
+ *
+ * @return void
+ */
+ public function timestamps()
+ {
+ $this->timestamp('created_at')->nullable();
+
+ $this->timestamp('updated_at')->nullable();
+ }
+
+ /**
+ * Add nullable creation and update timestamps to the table.
+ *
+ * Alias for self::timestamps().
+ *
+ * @return void
+ */
+ public function nullableTimestamps()
+ {
+ $this->timestamps();
+ }
+
+ /**
+ * Add creation and update timestampTz columns to the table.
+ *
+ * @return void
+ */
+ public function timestampsTz()
+ {
+ $this->timestampTz('created_at')->nullable();
+
+ $this->timestampTz('updated_at')->nullable();
+ }
+
+ /**
+ * Add a "deleted at" timestamp for the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function softDeletes($column = 'deleted_at')
+ {
+ return $this->timestamp($column)->nullable();
+ }
+
+ /**
+ * Add a "deleted at" timestampTz for the table.
+ *
+ * @return \Illuminate\Support\Fluent
+ */
+ public function softDeletesTz()
+ {
+ return $this->timestampTz('deleted_at')->nullable();
+ }
+
+ /**
+ * Create a new binary column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function binary($column)
+ {
+ return $this->addColumn('binary', $column);
+ }
+
+ /**
+ * Create a new uuid column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function uuid($column)
+ {
+ return $this->addColumn('uuid', $column);
+ }
+
+ /**
+ * Create a new IP address column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function ipAddress($column)
+ {
+ return $this->addColumn('ipAddress', $column);
+ }
+
+ /**
+ * Create a new MAC address column on the table.
+ *
+ * @param string $column
+ * @return \Illuminate\Support\Fluent
+ */
+ public function macAddress($column)
+ {
+ return $this->addColumn('macAddress', $column);
+ }
+
+ /**
+ * Add the proper columns for a polymorphic table.
+ *
+ * @param string $name
+ * @param string|null $indexName
+ * @return void
+ */
+ public function morphs($name, $indexName = null)
+ {
+ $this->unsignedInteger("{$name}_id");
+
+ $this->string("{$name}_type");
+
+ $this->index(["{$name}_id", "{$name}_type"], $indexName);
+ }
+
+ /**
+ * Add nullable columns for a polymorphic table.
+ *
+ * @param string $name
+ * @param string|null $indexName
+ * @return void
+ */
+ public function nullableMorphs($name, $indexName = null)
+ {
+ $this->unsignedInteger("{$name}_id")->nullable();
+
+ $this->string("{$name}_type")->nullable();
+
+ $this->index(["{$name}_id", "{$name}_type"], $indexName);
+ }
+
+ /**
+ * Adds the `remember_token` column to the table.
+ *
+ * @return \Illuminate\Support\Fluent
+ */
+ public function rememberToken()
+ {
+ return $this->string('remember_token', 100)->nullable();
+ }
+
+ /**
+ * Add a new index command to the blueprint.
+ *
+ * @param string $type
+ * @param string|array $columns
+ * @param string $index
+ * @param string|null $algorithm
+ * @return \Illuminate\Support\Fluent
+ */
+ protected function indexCommand($type, $columns, $index, $algorithm = null)
+ {
+ $columns = (array) $columns;
+
+ // If no name was specified for this index, we will create one using a basic
+ // convention of the table name, followed by the columns, followed by an
+ // index type, such as primary or index, which makes the index unique.
+ $index = $index ?: $this->createIndexName($type, $columns);
+
+ return $this->addCommand(
+ $type, compact('index', 'columns', 'algorithm')
+ );
+ }
+
+ /**
+ * Create a new drop index command on the blueprint.
+ *
+ * @param string $command
+ * @param string $type
+ * @param string|array $index
+ * @return \Illuminate\Support\Fluent
+ */
+ protected function dropIndexCommand($command, $type, $index)
+ {
+ $columns = [];
+
+ // If the given "index" is actually an array of columns, the developer means
+ // to drop an index merely by specifying the columns involved without the
+ // conventional name, so we will build the index name from the columns.
+ if (is_array($index)) {
+ $index = $this->createIndexName($type, $columns = $index);
+ }
+
+ return $this->indexCommand($command, $columns, $index);
+ }
+
+ /**
+ * Create a default index name for the table.
+ *
+ * @param string $type
+ * @param array $columns
+ * @return string
+ */
+ protected function createIndexName($type, array $columns)
+ {
+ $index = strtolower($this->table.'_'.implode('_', $columns).'_'.$type);
+
+ return str_replace(['-', '.'], '_', $index);
+ }
+
+ /**
+ * Add a new column to the blueprint.
+ *
+ * @param string $type
+ * @param string $name
+ * @param array $parameters
+ * @return \Illuminate\Support\Fluent
+ */
+ public function addColumn($type, $name, array $parameters = [])
+ {
+ $this->columns[] = $column = new Fluent(
+ array_merge(compact('type', 'name'), $parameters)
+ );
+
+ return $column;
+ }
+
+ /**
+ * Remove a column from the schema blueprint.
+ *
+ * @param string $name
+ * @return $this
+ */
+ public function removeColumn($name)
+ {
+ $this->columns = array_values(array_filter($this->columns, function ($c) use ($name) {
+ return $c['attributes']['name'] != $name;
+ }));
+
+ return $this;
+ }
+
+ /**
+ * Add a new command to the blueprint.
+ *
+ * @param string $name
+ * @param array $parameters
+ * @return \Illuminate\Support\Fluent
+ */
+ protected function addCommand($name, array $parameters = [])
+ {
+ $this->commands[] = $command = $this->createCommand($name, $parameters);
+
+ return $command;
+ }
+
+ /**
+ * Create a new Fluent command.
+ *
+ * @param string $name
+ * @param array $parameters
+ * @return \Illuminate\Support\Fluent
+ */
+ protected function createCommand($name, array $parameters = [])
+ {
+ return new Fluent(array_merge(compact('name'), $parameters));
+ }
+
+ /**
+ * Get the table the blueprint describes.
+ *
+ * @return string
+ */
+ public function getTable()
+ {
+ return $this->table;
+ }
+
+ /**
+ * Get the columns on the blueprint.
+ *
+ * @return array
+ */
+ public function getColumns()
+ {
+ return $this->columns;
+ }
+
+ /**
+ * Get the commands on the blueprint.
+ *
+ * @return array
+ */
+ public function getCommands()
+ {
+ return $this->commands;
+ }
+
+ /**
+ * Get the columns on the blueprint that should be added.
+ *
+ * @return array
+ */
+ public function getAddedColumns()
+ {
+ return array_filter($this->columns, function ($column) {
+ return ! $column->change;
+ });
+ }
+
+ /**
+ * Get the columns on the blueprint that should be changed.
+ *
+ * @return array
+ */
+ public function getChangedColumns()
+ {
+ return array_filter($this->columns, function ($column) {
+ return (bool) $column->change;
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/Builder.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/Builder.php
new file mode 100644
index 000000000..4f2fa3868
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/Builder.php
@@ -0,0 +1,291 @@
+connection = $connection;
+ $this->grammar = $connection->getSchemaGrammar();
+ }
+
+ /**
+ * Set the default string length for migrations.
+ *
+ * @param int $length
+ * @return void
+ */
+ public static function defaultStringLength($length)
+ {
+ static::$defaultStringLength = $length;
+ }
+
+ /**
+ * Determine if the given table exists.
+ *
+ * @param string $table
+ * @return bool
+ */
+ public function hasTable($table)
+ {
+ $table = $this->connection->getTablePrefix().$table;
+
+ return count($this->connection->select(
+ $this->grammar->compileTableExists(), [$table]
+ )) > 0;
+ }
+
+ /**
+ * Determine if the given table has a given column.
+ *
+ * @param string $table
+ * @param string $column
+ * @return bool
+ */
+ public function hasColumn($table, $column)
+ {
+ return in_array(
+ strtolower($column), array_map('strtolower', $this->getColumnListing($table))
+ );
+ }
+
+ /**
+ * Determine if the given table has given columns.
+ *
+ * @param string $table
+ * @param array $columns
+ * @return bool
+ */
+ public function hasColumns($table, array $columns)
+ {
+ $tableColumns = array_map('strtolower', $this->getColumnListing($table));
+
+ foreach ($columns as $column) {
+ if (! in_array(strtolower($column), $tableColumns)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Get the data type for the given column name.
+ *
+ * @param string $table
+ * @param string $column
+ * @return string
+ */
+ public function getColumnType($table, $column)
+ {
+ $table = $this->connection->getTablePrefix().$table;
+
+ return $this->connection->getDoctrineColumn($table, $column)->getType()->getName();
+ }
+
+ /**
+ * Get the column listing for a given table.
+ *
+ * @param string $table
+ * @return array
+ */
+ public function getColumnListing($table)
+ {
+ $table = $this->connection->getTablePrefix().$table;
+
+ $results = $this->connection->select($this->grammar->compileColumnListing($table));
+
+ return $this->connection->getPostProcessor()->processColumnListing($results);
+ }
+
+ /**
+ * Modify a table on the schema.
+ *
+ * @param string $table
+ * @param \Closure $callback
+ * @return void
+ */
+ public function table($table, Closure $callback)
+ {
+ $this->build($this->createBlueprint($table, $callback));
+ }
+
+ /**
+ * Create a new table on the schema.
+ *
+ * @param string $table
+ * @param \Closure $callback
+ * @return void
+ */
+ public function create($table, Closure $callback)
+ {
+ $this->build(tap($this->createBlueprint($table), function ($blueprint) use ($callback) {
+ $blueprint->create();
+
+ $callback($blueprint);
+ }));
+ }
+
+ /**
+ * Drop a table from the schema.
+ *
+ * @param string $table
+ * @return void
+ */
+ public function drop($table)
+ {
+ $this->build(tap($this->createBlueprint($table), function ($blueprint) {
+ $blueprint->drop();
+ }));
+ }
+
+ /**
+ * Drop a table from the schema if it exists.
+ *
+ * @param string $table
+ * @return void
+ */
+ public function dropIfExists($table)
+ {
+ $this->build(tap($this->createBlueprint($table), function ($blueprint) {
+ $blueprint->dropIfExists();
+ }));
+ }
+
+ /**
+ * Rename a table on the schema.
+ *
+ * @param string $from
+ * @param string $to
+ * @return void
+ */
+ public function rename($from, $to)
+ {
+ $this->build(tap($this->createBlueprint($from), function ($blueprint) use ($to) {
+ $blueprint->rename($to);
+ }));
+ }
+
+ /**
+ * Enable foreign key constraints.
+ *
+ * @return bool
+ */
+ public function enableForeignKeyConstraints()
+ {
+ return $this->connection->statement(
+ $this->grammar->compileEnableForeignKeyConstraints()
+ );
+ }
+
+ /**
+ * Disable foreign key constraints.
+ *
+ * @return bool
+ */
+ public function disableForeignKeyConstraints()
+ {
+ return $this->connection->statement(
+ $this->grammar->compileDisableForeignKeyConstraints()
+ );
+ }
+
+ /**
+ * Execute the blueprint to build / modify the table.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @return void
+ */
+ protected function build(Blueprint $blueprint)
+ {
+ $blueprint->build($this->connection, $this->grammar);
+ }
+
+ /**
+ * Create a new command set with a Closure.
+ *
+ * @param string $table
+ * @param \Closure|null $callback
+ * @return \Illuminate\Database\Schema\Blueprint
+ */
+ protected function createBlueprint($table, Closure $callback = null)
+ {
+ if (isset($this->resolver)) {
+ return call_user_func($this->resolver, $table, $callback);
+ }
+
+ return new Blueprint($table, $callback);
+ }
+
+ /**
+ * Get the database connection instance.
+ *
+ * @return \Illuminate\Database\Connection
+ */
+ public function getConnection()
+ {
+ return $this->connection;
+ }
+
+ /**
+ * Set the database connection instance.
+ *
+ * @param \Illuminate\Database\Connection $connection
+ * @return $this
+ */
+ public function setConnection(Connection $connection)
+ {
+ $this->connection = $connection;
+
+ return $this;
+ }
+
+ /**
+ * Set the Schema Blueprint resolver callback.
+ *
+ * @param \Closure $resolver
+ * @return void
+ */
+ public function blueprintResolver(Closure $resolver)
+ {
+ $this->resolver = $resolver;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/ChangeColumn.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/ChangeColumn.php
new file mode 100644
index 000000000..4751ecbed
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/ChangeColumn.php
@@ -0,0 +1,205 @@
+isDoctrineAvailable()) {
+ throw new RuntimeException(sprintf(
+ 'Changing columns for table "%s" requires Doctrine DBAL; install "doctrine/dbal".',
+ $blueprint->getTable()
+ ));
+ }
+
+ $tableDiff = static::getChangedDiff(
+ $grammar, $blueprint, $schema = $connection->getDoctrineSchemaManager()
+ );
+
+ if ($tableDiff !== false) {
+ return (array) $schema->getDatabasePlatform()->getAlterTableSQL($tableDiff);
+ }
+
+ return [];
+ }
+
+ /**
+ * Get the Doctrine table difference for the given changes.
+ *
+ * @param \Illuminate\Database\Schema\Grammars\Grammar $grammar
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Doctrine\DBAL\Schema\AbstractSchemaManager $schema
+ * @return \Doctrine\DBAL\Schema\TableDiff|bool
+ */
+ protected static function getChangedDiff($grammar, Blueprint $blueprint, SchemaManager $schema)
+ {
+ $current = $schema->listTableDetails($grammar->getTablePrefix().$blueprint->getTable());
+
+ return (new Comparator)->diffTable(
+ $current, static::getTableWithColumnChanges($blueprint, $current)
+ );
+ }
+
+ /**
+ * Get a copy of the given Doctrine table after making the column changes.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Doctrine\DBAL\Schema\Table $table
+ * @return \Doctrine\DBAL\Schema\Table
+ */
+ protected static function getTableWithColumnChanges(Blueprint $blueprint, Table $table)
+ {
+ $table = clone $table;
+
+ foreach ($blueprint->getChangedColumns() as $fluent) {
+ $column = static::getDoctrineColumn($table, $fluent);
+
+ // Here we will spin through each fluent column definition and map it to the proper
+ // Doctrine column definitions - which is necessary because Laravel and Doctrine
+ // use some different terminology for various column attributes on the tables.
+ foreach ($fluent->getAttributes() as $key => $value) {
+ if (! is_null($option = static::mapFluentOptionToDoctrine($key))) {
+ if (method_exists($column, $method = 'set'.ucfirst($option))) {
+ $column->{$method}(static::mapFluentValueToDoctrine($option, $value));
+ }
+ }
+ }
+ }
+
+ return $table;
+ }
+
+ /**
+ * Get the Doctrine column instance for a column change.
+ *
+ * @param \Doctrine\DBAL\Schema\Table $table
+ * @param \Illuminate\Support\Fluent $fluent
+ * @return \Doctrine\DBAL\Schema\Column
+ */
+ protected static function getDoctrineColumn(Table $table, Fluent $fluent)
+ {
+ return $table->changeColumn(
+ $fluent['name'], static::getDoctrineColumnChangeOptions($fluent)
+ )->getColumn($fluent['name']);
+ }
+
+ /**
+ * Get the Doctrine column change options.
+ *
+ * @param \Illuminate\Support\Fluent $fluent
+ * @return array
+ */
+ protected static function getDoctrineColumnChangeOptions(Fluent $fluent)
+ {
+ $options = ['type' => static::getDoctrineColumnType($fluent['type'])];
+
+ if (in_array($fluent['type'], ['text', 'mediumText', 'longText'])) {
+ $options['length'] = static::calculateDoctrineTextLength($fluent['type']);
+ }
+
+ return $options;
+ }
+
+ /**
+ * Get the doctrine column type.
+ *
+ * @param string $type
+ * @return \Doctrine\DBAL\Types\Type
+ */
+ protected static function getDoctrineColumnType($type)
+ {
+ $type = strtolower($type);
+
+ switch ($type) {
+ case 'biginteger':
+ $type = 'bigint';
+ break;
+ case 'smallinteger':
+ $type = 'smallint';
+ break;
+ case 'mediumtext':
+ case 'longtext':
+ $type = 'text';
+ break;
+ case 'binary':
+ $type = 'blob';
+ break;
+ }
+
+ return Type::getType($type);
+ }
+
+ /**
+ * Calculate the proper column length to force the Doctrine text type.
+ *
+ * @param string $type
+ * @return int
+ */
+ protected static function calculateDoctrineTextLength($type)
+ {
+ switch ($type) {
+ case 'mediumText':
+ return 65535 + 1;
+ case 'longText':
+ return 16777215 + 1;
+ default:
+ return 255 + 1;
+ }
+ }
+
+ /**
+ * Get the matching Doctrine option for a given Fluent attribute name.
+ *
+ * @param string $attribute
+ * @return string|null
+ */
+ protected static function mapFluentOptionToDoctrine($attribute)
+ {
+ switch ($attribute) {
+ case 'type':
+ case 'name':
+ return;
+ case 'nullable':
+ return 'notnull';
+ case 'total':
+ return 'precision';
+ case 'places':
+ return 'scale';
+ default:
+ return $attribute;
+ }
+ }
+
+ /**
+ * Get the matching Doctrine value for a given Fluent attribute.
+ *
+ * @param string $option
+ * @param mixed $value
+ * @return mixed
+ */
+ protected static function mapFluentValueToDoctrine($option, $value)
+ {
+ return $option == 'notnull' ? ! $value : $value;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/Grammar.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/Grammar.php
new file mode 100644
index 000000000..6e880aec0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/Grammar.php
@@ -0,0 +1,255 @@
+wrapTable($blueprint),
+ $this->wrap($command->index)
+ );
+
+ // Once we have the initial portion of the SQL statement we will add on the
+ // key name, table name, and referenced columns. These will complete the
+ // main portion of the SQL statement and this SQL will almost be done.
+ $sql .= sprintf('foreign key (%s) references %s (%s)',
+ $this->columnize($command->columns),
+ $this->wrapTable($command->on),
+ $this->columnize((array) $command->references)
+ );
+
+ // Once we have the basic foreign key creation statement constructed we can
+ // build out the syntax for what should happen on an update or delete of
+ // the affected columns, which will get something like "cascade", etc.
+ if (! is_null($command->onDelete)) {
+ $sql .= " on delete {$command->onDelete}";
+ }
+
+ if (! is_null($command->onUpdate)) {
+ $sql .= " on update {$command->onUpdate}";
+ }
+
+ return $sql;
+ }
+
+ /**
+ * Compile the blueprint's column definitions.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @return array
+ */
+ protected function getColumns(Blueprint $blueprint)
+ {
+ $columns = [];
+
+ foreach ($blueprint->getAddedColumns() as $column) {
+ // Each of the column types have their own compiler functions which are tasked
+ // with turning the column definition into its SQL format for this platform
+ // used by the connection. The column's modifiers are compiled and added.
+ $sql = $this->wrap($column).' '.$this->getType($column);
+
+ $columns[] = $this->addModifiers($sql, $blueprint, $column);
+ }
+
+ return $columns;
+ }
+
+ /**
+ * Get the SQL for the column data type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function getType(Fluent $column)
+ {
+ return $this->{'type'.ucfirst($column->type)}($column);
+ }
+
+ /**
+ * Add the column modifiers to the definition.
+ *
+ * @param string $sql
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function addModifiers($sql, Blueprint $blueprint, Fluent $column)
+ {
+ foreach ($this->modifiers as $modifier) {
+ if (method_exists($this, $method = "modify{$modifier}")) {
+ $sql .= $this->{$method}($blueprint, $column);
+ }
+ }
+
+ return $sql;
+ }
+
+ /**
+ * Get the primary key command if it exists on the blueprint.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param string $name
+ * @return \Illuminate\Support\Fluent|null
+ */
+ protected function getCommandByName(Blueprint $blueprint, $name)
+ {
+ $commands = $this->getCommandsByName($blueprint, $name);
+
+ if (count($commands) > 0) {
+ return reset($commands);
+ }
+ }
+
+ /**
+ * Get all of the commands with a given name.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param string $name
+ * @return array
+ */
+ protected function getCommandsByName(Blueprint $blueprint, $name)
+ {
+ return array_filter($blueprint->getCommands(), function ($value) use ($name) {
+ return $value->name == $name;
+ });
+ }
+
+ /**
+ * Add a prefix to an array of values.
+ *
+ * @param string $prefix
+ * @param array $values
+ * @return array
+ */
+ public function prefixArray($prefix, array $values)
+ {
+ return array_map(function ($value) use ($prefix) {
+ return $prefix.' '.$value;
+ }, $values);
+ }
+
+ /**
+ * Wrap a table in keyword identifiers.
+ *
+ * @param mixed $table
+ * @return string
+ */
+ public function wrapTable($table)
+ {
+ return parent::wrapTable(
+ $table instanceof Blueprint ? $table->getTable() : $table
+ );
+ }
+
+ /**
+ * Wrap a value in keyword identifiers.
+ *
+ * @param \Illuminate\Database\Query\Expression|string $value
+ * @param bool $prefixAlias
+ * @return string
+ */
+ public function wrap($value, $prefixAlias = false)
+ {
+ return parent::wrap(
+ $value instanceof Fluent ? $value->name : $value, $prefixAlias
+ );
+ }
+
+ /**
+ * Format a value so that it can be used in "default" clauses.
+ *
+ * @param mixed $value
+ * @return string
+ */
+ protected function getDefaultValue($value)
+ {
+ if ($value instanceof Expression) {
+ return $value;
+ }
+
+ return is_bool($value)
+ ? "'".(int) $value."'"
+ : "'".strval($value)."'";
+ }
+
+ /**
+ * Create an empty Doctrine DBAL TableDiff from the Blueprint.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Doctrine\DBAL\Schema\AbstractSchemaManager $schema
+ * @return \Doctrine\DBAL\Schema\TableDiff
+ */
+ public function getDoctrineTableDiff(Blueprint $blueprint, SchemaManager $schema)
+ {
+ $table = $this->getTablePrefix().$blueprint->getTable();
+
+ return tap(new TableDiff($table), function ($tableDiff) use ($schema, $table) {
+ $tableDiff->fromTable = $schema->listTableDetails($table);
+ });
+ }
+
+ /**
+ * Check if this Grammar supports schema changes wrapped in a transaction.
+ *
+ * @return bool
+ */
+ public function supportsSchemaTransactions()
+ {
+ return $this->transactions;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/MySqlGrammar.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/MySqlGrammar.php
new file mode 100644
index 000000000..4f8d6b3fe
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/MySqlGrammar.php
@@ -0,0 +1,829 @@
+compileCreateTable(
+ $blueprint, $command, $connection
+ );
+
+ // Once we have the primary SQL, we can add the encoding option to the SQL for
+ // the table. Then, we can check if a storage engine has been supplied for
+ // the table. If so, we will add the engine declaration to the SQL query.
+ $sql = $this->compileCreateEncoding(
+ $sql, $connection, $blueprint
+ );
+
+ // Finally, we will append the engine configuration onto this SQL statement as
+ // the final thing we do before returning this finished SQL. Once this gets
+ // added the query will be ready to execute against the real connections.
+ return $this->compileCreateEngine(
+ $sql, $connection, $blueprint
+ );
+ }
+
+ /**
+ * Create the main create table clause.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @param \Illuminate\Database\Connection $connection
+ * @return string
+ */
+ protected function compileCreateTable($blueprint, $command, $connection)
+ {
+ return sprintf('%s table %s (%s)',
+ $blueprint->temporary ? 'create temporary' : 'create',
+ $this->wrapTable($blueprint),
+ implode(', ', $this->getColumns($blueprint))
+ );
+ }
+
+ /**
+ * Append the character set specifications to a command.
+ *
+ * @param string $sql
+ * @param \Illuminate\Database\Connection $connection
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @return string
+ */
+ protected function compileCreateEncoding($sql, Connection $connection, Blueprint $blueprint)
+ {
+ // First we will set the character set if one has been set on either the create
+ // blueprint itself or on the root configuration for the connection that the
+ // table is being created on. We will add these to the create table query.
+ if (isset($blueprint->charset)) {
+ $sql .= ' default character set '.$blueprint->charset;
+ } elseif (! is_null($charset = $connection->getConfig('charset'))) {
+ $sql .= ' default character set '.$charset;
+ }
+
+ // Next we will add the collation to the create table statement if one has been
+ // added to either this create table blueprint or the configuration for this
+ // connection that the query is targeting. We'll add it to this SQL query.
+ if (isset($blueprint->collation)) {
+ $sql .= ' collate '.$blueprint->collation;
+ } elseif (! is_null($collation = $connection->getConfig('collation'))) {
+ $sql .= ' collate '.$collation;
+ }
+
+ return $sql;
+ }
+
+ /**
+ * Append the engine specifications to a command.
+ *
+ * @param string $sql
+ * @param \Illuminate\Database\Connection $connection
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @return string
+ */
+ protected function compileCreateEngine($sql, Connection $connection, Blueprint $blueprint)
+ {
+ if (isset($blueprint->engine)) {
+ return $sql.' engine = '.$blueprint->engine;
+ } elseif (! is_null($engine = $connection->getConfig('engine'))) {
+ return $sql.' engine = '.$engine;
+ }
+
+ return $sql;
+ }
+
+ /**
+ * Compile an add column command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileAdd(Blueprint $blueprint, Fluent $command)
+ {
+ $columns = $this->prefixArray('add', $this->getColumns($blueprint));
+
+ return 'alter table '.$this->wrapTable($blueprint).' '.implode(', ', $columns);
+ }
+
+ /**
+ * Compile a primary key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compilePrimary(Blueprint $blueprint, Fluent $command)
+ {
+ $command->name(null);
+
+ return $this->compileKey($blueprint, $command, 'primary key');
+ }
+
+ /**
+ * Compile a unique key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileUnique(Blueprint $blueprint, Fluent $command)
+ {
+ return $this->compileKey($blueprint, $command, 'unique');
+ }
+
+ /**
+ * Compile a plain index key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileIndex(Blueprint $blueprint, Fluent $command)
+ {
+ return $this->compileKey($blueprint, $command, 'index');
+ }
+
+ /**
+ * Compile an index creation command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @param string $type
+ * @return string
+ */
+ protected function compileKey(Blueprint $blueprint, Fluent $command, $type)
+ {
+ return sprintf('alter table %s add %s %s%s(%s)',
+ $this->wrapTable($blueprint),
+ $type,
+ $this->wrap($command->index),
+ $command->algorithm ? ' using '.$command->algorithm : '',
+ $this->columnize($command->columns)
+ );
+ }
+
+ /**
+ * Compile a drop table command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDrop(Blueprint $blueprint, Fluent $command)
+ {
+ return 'drop table '.$this->wrapTable($blueprint);
+ }
+
+ /**
+ * Compile a drop table (if exists) command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropIfExists(Blueprint $blueprint, Fluent $command)
+ {
+ return 'drop table if exists '.$this->wrapTable($blueprint);
+ }
+
+ /**
+ * Compile a drop column command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropColumn(Blueprint $blueprint, Fluent $command)
+ {
+ $columns = $this->prefixArray('drop', $this->wrapArray($command->columns));
+
+ return 'alter table '.$this->wrapTable($blueprint).' '.implode(', ', $columns);
+ }
+
+ /**
+ * Compile a drop primary key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropPrimary(Blueprint $blueprint, Fluent $command)
+ {
+ return 'alter table '.$this->wrapTable($blueprint).' drop primary key';
+ }
+
+ /**
+ * Compile a drop unique key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropUnique(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "alter table {$this->wrapTable($blueprint)} drop index {$index}";
+ }
+
+ /**
+ * Compile a drop index command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropIndex(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "alter table {$this->wrapTable($blueprint)} drop index {$index}";
+ }
+
+ /**
+ * Compile a drop foreign key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropForeign(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "alter table {$this->wrapTable($blueprint)} drop foreign key {$index}";
+ }
+
+ /**
+ * Compile a rename table command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileRename(Blueprint $blueprint, Fluent $command)
+ {
+ $from = $this->wrapTable($blueprint);
+
+ return "rename table {$from} to ".$this->wrapTable($command->to);
+ }
+
+ /**
+ * Compile the command to enable foreign key constraints.
+ *
+ * @return string
+ */
+ public function compileEnableForeignKeyConstraints()
+ {
+ return 'SET FOREIGN_KEY_CHECKS=1;';
+ }
+
+ /**
+ * Compile the command to disable foreign key constraints.
+ *
+ * @return string
+ */
+ public function compileDisableForeignKeyConstraints()
+ {
+ return 'SET FOREIGN_KEY_CHECKS=0;';
+ }
+
+ /**
+ * Create the column definition for a char type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeChar(Fluent $column)
+ {
+ return "char({$column->length})";
+ }
+
+ /**
+ * Create the column definition for a string type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeString(Fluent $column)
+ {
+ return "varchar({$column->length})";
+ }
+
+ /**
+ * Create the column definition for a text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeText(Fluent $column)
+ {
+ return 'text';
+ }
+
+ /**
+ * Create the column definition for a medium text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMediumText(Fluent $column)
+ {
+ return 'mediumtext';
+ }
+
+ /**
+ * Create the column definition for a long text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeLongText(Fluent $column)
+ {
+ return 'longtext';
+ }
+
+ /**
+ * Create the column definition for a big integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBigInteger(Fluent $column)
+ {
+ return 'bigint';
+ }
+
+ /**
+ * Create the column definition for an integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeInteger(Fluent $column)
+ {
+ return 'int';
+ }
+
+ /**
+ * Create the column definition for a medium integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMediumInteger(Fluent $column)
+ {
+ return 'mediumint';
+ }
+
+ /**
+ * Create the column definition for a tiny integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTinyInteger(Fluent $column)
+ {
+ return 'tinyint';
+ }
+
+ /**
+ * Create the column definition for a small integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeSmallInteger(Fluent $column)
+ {
+ return 'smallint';
+ }
+
+ /**
+ * Create the column definition for a float type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeFloat(Fluent $column)
+ {
+ return $this->typeDouble($column);
+ }
+
+ /**
+ * Create the column definition for a double type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDouble(Fluent $column)
+ {
+ if ($column->total && $column->places) {
+ return "double({$column->total}, {$column->places})";
+ }
+
+ return 'double';
+ }
+
+ /**
+ * Create the column definition for a decimal type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDecimal(Fluent $column)
+ {
+ return "decimal({$column->total}, {$column->places})";
+ }
+
+ /**
+ * Create the column definition for a boolean type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBoolean(Fluent $column)
+ {
+ return 'tinyint(1)';
+ }
+
+ /**
+ * Create the column definition for an enum type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeEnum(Fluent $column)
+ {
+ return "enum('".implode("', '", $column->allowed)."')";
+ }
+
+ /**
+ * Create the column definition for a json type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeJson(Fluent $column)
+ {
+ return 'json';
+ }
+
+ /**
+ * Create the column definition for a jsonb type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeJsonb(Fluent $column)
+ {
+ return 'json';
+ }
+
+ /**
+ * Create the column definition for a date type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDate(Fluent $column)
+ {
+ return 'date';
+ }
+
+ /**
+ * Create the column definition for a date-time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDateTime(Fluent $column)
+ {
+ return 'datetime';
+ }
+
+ /**
+ * Create the column definition for a date-time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDateTimeTz(Fluent $column)
+ {
+ return 'datetime';
+ }
+
+ /**
+ * Create the column definition for a time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTime(Fluent $column)
+ {
+ return 'time';
+ }
+
+ /**
+ * Create the column definition for a time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimeTz(Fluent $column)
+ {
+ return 'time';
+ }
+
+ /**
+ * Create the column definition for a timestamp type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimestamp(Fluent $column)
+ {
+ if ($column->useCurrent) {
+ return 'timestamp default CURRENT_TIMESTAMP';
+ }
+
+ return 'timestamp';
+ }
+
+ /**
+ * Create the column definition for a timestamp type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimestampTz(Fluent $column)
+ {
+ if ($column->useCurrent) {
+ return 'timestamp default CURRENT_TIMESTAMP';
+ }
+
+ return 'timestamp';
+ }
+
+ /**
+ * Create the column definition for a binary type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBinary(Fluent $column)
+ {
+ return 'blob';
+ }
+
+ /**
+ * Create the column definition for a uuid type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeUuid(Fluent $column)
+ {
+ return 'char(36)';
+ }
+
+ /**
+ * Create the column definition for an IP address type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeIpAddress(Fluent $column)
+ {
+ return 'varchar(45)';
+ }
+
+ /**
+ * Create the column definition for a MAC address type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMacAddress(Fluent $column)
+ {
+ return 'varchar(17)';
+ }
+
+ /**
+ * Get the SQL for a generated virtual column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyVirtualAs(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->virtualAs)) {
+ return " as ({$column->virtualAs})";
+ }
+ }
+
+ /**
+ * Get the SQL for a generated stored column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyStoredAs(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->storedAs)) {
+ return " as ({$column->storedAs}) stored";
+ }
+ }
+
+ /**
+ * Get the SQL for an unsigned column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyUnsigned(Blueprint $blueprint, Fluent $column)
+ {
+ if ($column->unsigned) {
+ return ' unsigned';
+ }
+ }
+
+ /**
+ * Get the SQL for a character set column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyCharset(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->charset)) {
+ return ' character set '.$column->charset;
+ }
+ }
+
+ /**
+ * Get the SQL for a collation column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyCollate(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->collation)) {
+ return ' collate '.$column->collation;
+ }
+ }
+
+ /**
+ * Get the SQL for a nullable column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyNullable(Blueprint $blueprint, Fluent $column)
+ {
+ if (is_null($column->virtualAs) && is_null($column->storedAs)) {
+ return $column->nullable ? ' null' : ' not null';
+ }
+ }
+
+ /**
+ * Get the SQL for a default column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyDefault(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->default)) {
+ return ' default '.$this->getDefaultValue($column->default);
+ }
+ }
+
+ /**
+ * Get the SQL for an auto-increment column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyIncrement(Blueprint $blueprint, Fluent $column)
+ {
+ if (in_array($column->type, $this->serials) && $column->autoIncrement) {
+ return ' auto_increment primary key';
+ }
+ }
+
+ /**
+ * Get the SQL for a "first" column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyFirst(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->first)) {
+ return ' first';
+ }
+ }
+
+ /**
+ * Get the SQL for an "after" column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyAfter(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->after)) {
+ return ' after '.$this->wrap($column->after);
+ }
+ }
+
+ /**
+ * Get the SQL for a "comment" column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyComment(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->comment)) {
+ return " comment '".addslashes($column->comment)."'";
+ }
+ }
+
+ /**
+ * Wrap a single string in keyword identifiers.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function wrapValue($value)
+ {
+ if ($value !== '*') {
+ return '`'.str_replace('`', '``', $value).'`';
+ }
+
+ return $value;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/PostgresGrammar.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/PostgresGrammar.php
new file mode 100644
index 000000000..882e2ddf1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/PostgresGrammar.php
@@ -0,0 +1,626 @@
+temporary ? 'create temporary' : 'create',
+ $this->wrapTable($blueprint),
+ implode(', ', $this->getColumns($blueprint))
+ );
+ }
+
+ /**
+ * Compile a column addition command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileAdd(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('alter table %s %s',
+ $this->wrapTable($blueprint),
+ implode(', ', $this->prefixArray('add column', $this->getColumns($blueprint)))
+ );
+ }
+
+ /**
+ * Compile a primary key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compilePrimary(Blueprint $blueprint, Fluent $command)
+ {
+ $columns = $this->columnize($command->columns);
+
+ return 'alter table '.$this->wrapTable($blueprint)." add primary key ({$columns})";
+ }
+
+ /**
+ * Compile a unique key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileUnique(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('alter table %s add constraint %s unique (%s)',
+ $this->wrapTable($blueprint),
+ $this->wrap($command->index),
+ $this->columnize($command->columns)
+ );
+ }
+
+ /**
+ * Compile a plain index key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileIndex(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('create index %s on %s%s (%s)',
+ $this->wrap($command->index),
+ $this->wrapTable($blueprint),
+ $command->algorithm ? ' using '.$command->algorithm : '',
+ $this->columnize($command->columns)
+ );
+ }
+
+ /**
+ * Compile a drop table command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDrop(Blueprint $blueprint, Fluent $command)
+ {
+ return 'drop table '.$this->wrapTable($blueprint);
+ }
+
+ /**
+ * Compile a drop table (if exists) command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropIfExists(Blueprint $blueprint, Fluent $command)
+ {
+ return 'drop table if exists '.$this->wrapTable($blueprint);
+ }
+
+ /**
+ * Compile a drop column command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropColumn(Blueprint $blueprint, Fluent $command)
+ {
+ $columns = $this->prefixArray('drop column', $this->wrapArray($command->columns));
+
+ return 'alter table '.$this->wrapTable($blueprint).' '.implode(', ', $columns);
+ }
+
+ /**
+ * Compile a drop primary key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropPrimary(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap("{$blueprint->getTable()}_pkey");
+
+ return 'alter table '.$this->wrapTable($blueprint)." drop constraint {$index}";
+ }
+
+ /**
+ * Compile a drop unique key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropUnique(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "alter table {$this->wrapTable($blueprint)} drop constraint {$index}";
+ }
+
+ /**
+ * Compile a drop index command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropIndex(Blueprint $blueprint, Fluent $command)
+ {
+ return "drop index {$this->wrap($command->index)}";
+ }
+
+ /**
+ * Compile a drop foreign key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropForeign(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "alter table {$this->wrapTable($blueprint)} drop constraint {$index}";
+ }
+
+ /**
+ * Compile a rename table command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileRename(Blueprint $blueprint, Fluent $command)
+ {
+ $from = $this->wrapTable($blueprint);
+
+ return "alter table {$from} rename to ".$this->wrapTable($command->to);
+ }
+
+ /**
+ * Compile the command to enable foreign key constraints.
+ *
+ * @return string
+ */
+ public function compileEnableForeignKeyConstraints()
+ {
+ return 'SET CONSTRAINTS ALL IMMEDIATE;';
+ }
+
+ /**
+ * Compile the command to disable foreign key constraints.
+ *
+ * @return string
+ */
+ public function compileDisableForeignKeyConstraints()
+ {
+ return 'SET CONSTRAINTS ALL DEFERRED;';
+ }
+
+ /**
+ * Create the column definition for a char type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeChar(Fluent $column)
+ {
+ return "char({$column->length})";
+ }
+
+ /**
+ * Create the column definition for a string type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeString(Fluent $column)
+ {
+ return "varchar({$column->length})";
+ }
+
+ /**
+ * Create the column definition for a text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeText(Fluent $column)
+ {
+ return 'text';
+ }
+
+ /**
+ * Create the column definition for a medium text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMediumText(Fluent $column)
+ {
+ return 'text';
+ }
+
+ /**
+ * Create the column definition for a long text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeLongText(Fluent $column)
+ {
+ return 'text';
+ }
+
+ /**
+ * Create the column definition for an integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeInteger(Fluent $column)
+ {
+ return $column->autoIncrement ? 'serial' : 'integer';
+ }
+
+ /**
+ * Create the column definition for a big integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBigInteger(Fluent $column)
+ {
+ return $column->autoIncrement ? 'bigserial' : 'bigint';
+ }
+
+ /**
+ * Create the column definition for a medium integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMediumInteger(Fluent $column)
+ {
+ return $column->autoIncrement ? 'serial' : 'integer';
+ }
+
+ /**
+ * Create the column definition for a tiny integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTinyInteger(Fluent $column)
+ {
+ return $column->autoIncrement ? 'smallserial' : 'smallint';
+ }
+
+ /**
+ * Create the column definition for a small integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeSmallInteger(Fluent $column)
+ {
+ return $column->autoIncrement ? 'smallserial' : 'smallint';
+ }
+
+ /**
+ * Create the column definition for a float type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeFloat(Fluent $column)
+ {
+ return $this->typeDouble($column);
+ }
+
+ /**
+ * Create the column definition for a double type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDouble(Fluent $column)
+ {
+ return 'double precision';
+ }
+
+ /**
+ * Create the column definition for a real type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeReal(Fluent $column)
+ {
+ return 'real';
+ }
+
+ /**
+ * Create the column definition for a decimal type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDecimal(Fluent $column)
+ {
+ return "decimal({$column->total}, {$column->places})";
+ }
+
+ /**
+ * Create the column definition for a boolean type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBoolean(Fluent $column)
+ {
+ return 'boolean';
+ }
+
+ /**
+ * Create the column definition for an enum type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeEnum(Fluent $column)
+ {
+ $allowed = array_map(function ($a) {
+ return "'{$a}'";
+ }, $column->allowed);
+
+ return "varchar(255) check (\"{$column->name}\" in (".implode(', ', $allowed).'))';
+ }
+
+ /**
+ * Create the column definition for a json type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeJson(Fluent $column)
+ {
+ return 'json';
+ }
+
+ /**
+ * Create the column definition for a jsonb type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeJsonb(Fluent $column)
+ {
+ return 'jsonb';
+ }
+
+ /**
+ * Create the column definition for a date type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDate(Fluent $column)
+ {
+ return 'date';
+ }
+
+ /**
+ * Create the column definition for a date-time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDateTime(Fluent $column)
+ {
+ return 'timestamp(0) without time zone';
+ }
+
+ /**
+ * Create the column definition for a date-time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDateTimeTz(Fluent $column)
+ {
+ return 'timestamp(0) with time zone';
+ }
+
+ /**
+ * Create the column definition for a time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTime(Fluent $column)
+ {
+ return 'time(0) without time zone';
+ }
+
+ /**
+ * Create the column definition for a time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimeTz(Fluent $column)
+ {
+ return 'time(0) with time zone';
+ }
+
+ /**
+ * Create the column definition for a timestamp type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimestamp(Fluent $column)
+ {
+ if ($column->useCurrent) {
+ return 'timestamp(0) without time zone default CURRENT_TIMESTAMP(0)';
+ }
+
+ return 'timestamp(0) without time zone';
+ }
+
+ /**
+ * Create the column definition for a timestamp type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimestampTz(Fluent $column)
+ {
+ if ($column->useCurrent) {
+ return 'timestamp(0) with time zone default CURRENT_TIMESTAMP(0)';
+ }
+
+ return 'timestamp(0) with time zone';
+ }
+
+ /**
+ * Create the column definition for a binary type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBinary(Fluent $column)
+ {
+ return 'bytea';
+ }
+
+ /**
+ * Create the column definition for a uuid type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeUuid(Fluent $column)
+ {
+ return 'uuid';
+ }
+
+ /**
+ * Create the column definition for an IP address type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeIpAddress(Fluent $column)
+ {
+ return 'inet';
+ }
+
+ /**
+ * Create the column definition for a MAC address type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMacAddress(Fluent $column)
+ {
+ return 'macaddr';
+ }
+
+ /**
+ * Get the SQL for a nullable column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyNullable(Blueprint $blueprint, Fluent $column)
+ {
+ return $column->nullable ? ' null' : ' not null';
+ }
+
+ /**
+ * Get the SQL for a default column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyDefault(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->default)) {
+ return ' default '.$this->getDefaultValue($column->default);
+ }
+ }
+
+ /**
+ * Get the SQL for an auto-increment column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyIncrement(Blueprint $blueprint, Fluent $column)
+ {
+ if (in_array($column->type, $this->serials) && $column->autoIncrement) {
+ return ' primary key';
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/RenameColumn.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/RenameColumn.php
new file mode 100644
index 000000000..a07c4febb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/RenameColumn.php
@@ -0,0 +1,69 @@
+getDoctrineColumn(
+ $grammar->getTablePrefix().$blueprint->getTable(), $command->from
+ );
+
+ $schema = $connection->getDoctrineSchemaManager();
+
+ return (array) $schema->getDatabasePlatform()->getAlterTableSQL(static::getRenamedDiff(
+ $grammar, $blueprint, $command, $column, $schema
+ ));
+ }
+
+ /**
+ * Get a new column instance with the new column name.
+ *
+ * @param \Illuminate\Database\Schema\Grammars\Grammar $grammar
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @param \Doctrine\DBAL\Schema\Column $column
+ * @param \Doctrine\DBAL\Schema\AbstractSchemaManager $schema
+ * @return \Doctrine\DBAL\Schema\TableDiff
+ */
+ protected static function getRenamedDiff(Grammar $grammar, Blueprint $blueprint, Fluent $command, Column $column, SchemaManager $schema)
+ {
+ return static::setRenamedColumns(
+ $grammar->getDoctrineTableDiff($blueprint, $schema), $command, $column
+ );
+ }
+
+ /**
+ * Set the renamed columns on the table diff.
+ *
+ * @param \Doctrine\DBAL\Schema\TableDiff $tableDiff
+ * @param \Illuminate\Support\Fluent $command
+ * @param \Doctrine\DBAL\Schema\Column $column
+ * @return \Doctrine\DBAL\Schema\TableDiff
+ */
+ protected static function setRenamedColumns(TableDiff $tableDiff, Fluent $command, Column $column)
+ {
+ $tableDiff->renamedColumns = [
+ $command->from => new Column($command->to, $column->getType(), $column->toArray()),
+ ];
+
+ return $tableDiff;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/SQLiteGrammar.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/SQLiteGrammar.php
new file mode 100644
index 000000000..d96bfd66f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/SQLiteGrammar.php
@@ -0,0 +1,653 @@
+wrapTable(str_replace('.', '__', $table)).')';
+ }
+
+ /**
+ * Compile a create table command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileCreate(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('%s table %s (%s%s%s)',
+ $blueprint->temporary ? 'create temporary' : 'create',
+ $this->wrapTable($blueprint),
+ implode(', ', $this->getColumns($blueprint)),
+ (string) $this->addForeignKeys($blueprint),
+ (string) $this->addPrimaryKeys($blueprint)
+ );
+ }
+
+ /**
+ * Get the foreign key syntax for a table creation statement.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @return string|null
+ */
+ protected function addForeignKeys(Blueprint $blueprint)
+ {
+ $foreigns = $this->getCommandsByName($blueprint, 'foreign');
+
+ return collect($foreigns)->reduce(function ($sql, $foreign) {
+ // Once we have all the foreign key commands for the table creation statement
+ // we'll loop through each of them and add them to the create table SQL we
+ // are building, since SQLite needs foreign keys on the tables creation.
+ $sql .= $this->getForeignKey($foreign);
+
+ if (! is_null($foreign->onDelete)) {
+ $sql .= " on delete {$foreign->onDelete}";
+ }
+
+ // If this foreign key specifies the action to be taken on update we will add
+ // that to the statement here. We'll append it to this SQL and then return
+ // the SQL so we can keep adding any other foreign consraints onto this.
+ if (! is_null($foreign->onUpdate)) {
+ $sql .= " on update {$foreign->onUpdate}";
+ }
+
+ return $sql;
+ }, '');
+ }
+
+ /**
+ * Get the SQL for the foreign key.
+ *
+ * @param \Illuminate\Support\Fluent $foreign
+ * @return string
+ */
+ protected function getForeignKey($foreign)
+ {
+ // We need to columnize the columns that the foreign key is being defined for
+ // so that it is a properly formatted list. Once we have done this, we can
+ // return the foreign key SQL declaration to the calling method for use.
+ return sprintf(', foreign key(%s) references %s(%s)',
+ $this->columnize($foreign->columns),
+ $this->wrapTable($foreign->on),
+ $this->columnize((array) $foreign->references)
+ );
+ }
+
+ /**
+ * Get the primary key syntax for a table creation statement.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @return string|null
+ */
+ protected function addPrimaryKeys(Blueprint $blueprint)
+ {
+ if (! is_null($primary = $this->getCommandByName($blueprint, 'primary'))) {
+ return ", primary key ({$this->columnize($primary->columns)})";
+ }
+ }
+
+ /**
+ * Compile alter table commands for adding columns.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return array
+ */
+ public function compileAdd(Blueprint $blueprint, Fluent $command)
+ {
+ $columns = $this->prefixArray('add column', $this->getColumns($blueprint));
+
+ return collect($columns)->map(function ($column) use ($blueprint) {
+ return 'alter table '.$this->wrapTable($blueprint).' '.$column;
+ })->all();
+ }
+
+ /**
+ * Compile a unique key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileUnique(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('create unique index %s on %s (%s)',
+ $this->wrap($command->index),
+ $this->wrapTable($blueprint),
+ $this->columnize($command->columns)
+ );
+ }
+
+ /**
+ * Compile a plain index key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileIndex(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('create index %s on %s (%s)',
+ $this->wrap($command->index),
+ $this->wrapTable($blueprint),
+ $this->columnize($command->columns)
+ );
+ }
+
+ /**
+ * Compile a foreign key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileForeign(Blueprint $blueprint, Fluent $command)
+ {
+ // Handled on table creation...
+ }
+
+ /**
+ * Compile a drop table command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDrop(Blueprint $blueprint, Fluent $command)
+ {
+ return 'drop table '.$this->wrapTable($blueprint);
+ }
+
+ /**
+ * Compile a drop table (if exists) command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropIfExists(Blueprint $blueprint, Fluent $command)
+ {
+ return 'drop table if exists '.$this->wrapTable($blueprint);
+ }
+
+ /**
+ * Compile a drop column command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @param \Illuminate\Database\Connection $connection
+ * @return array
+ */
+ public function compileDropColumn(Blueprint $blueprint, Fluent $command, Connection $connection)
+ {
+ $tableDiff = $this->getDoctrineTableDiff(
+ $blueprint, $schema = $connection->getDoctrineSchemaManager()
+ );
+
+ foreach ($command->columns as $name) {
+ $column = $connection->getDoctrineColumn($blueprint->getTable(), $name);
+
+ $tableDiff->removedColumns[$name] = $column;
+ }
+
+ return (array) $schema->getDatabasePlatform()->getAlterTableSQL($tableDiff);
+ }
+
+ /**
+ * Compile a drop unique key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropUnique(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "drop index {$index}";
+ }
+
+ /**
+ * Compile a drop index command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropIndex(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "drop index {$index}";
+ }
+
+ /**
+ * Compile a rename table command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileRename(Blueprint $blueprint, Fluent $command)
+ {
+ $from = $this->wrapTable($blueprint);
+
+ return "alter table {$from} rename to ".$this->wrapTable($command->to);
+ }
+
+ /**
+ * Compile the command to enable foreign key constraints.
+ *
+ * @return string
+ */
+ public function compileEnableForeignKeyConstraints()
+ {
+ return 'PRAGMA foreign_keys = ON;';
+ }
+
+ /**
+ * Compile the command to disable foreign key constraints.
+ *
+ * @return string
+ */
+ public function compileDisableForeignKeyConstraints()
+ {
+ return 'PRAGMA foreign_keys = OFF;';
+ }
+
+ /**
+ * Create the column definition for a char type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeChar(Fluent $column)
+ {
+ return 'varchar';
+ }
+
+ /**
+ * Create the column definition for a string type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeString(Fluent $column)
+ {
+ return 'varchar';
+ }
+
+ /**
+ * Create the column definition for a text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeText(Fluent $column)
+ {
+ return 'text';
+ }
+
+ /**
+ * Create the column definition for a medium text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMediumText(Fluent $column)
+ {
+ return 'text';
+ }
+
+ /**
+ * Create the column definition for a long text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeLongText(Fluent $column)
+ {
+ return 'text';
+ }
+
+ /**
+ * Create the column definition for a integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeInteger(Fluent $column)
+ {
+ return 'integer';
+ }
+
+ /**
+ * Create the column definition for a big integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBigInteger(Fluent $column)
+ {
+ return 'integer';
+ }
+
+ /**
+ * Create the column definition for a medium integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMediumInteger(Fluent $column)
+ {
+ return 'integer';
+ }
+
+ /**
+ * Create the column definition for a tiny integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTinyInteger(Fluent $column)
+ {
+ return 'integer';
+ }
+
+ /**
+ * Create the column definition for a small integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeSmallInteger(Fluent $column)
+ {
+ return 'integer';
+ }
+
+ /**
+ * Create the column definition for a float type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeFloat(Fluent $column)
+ {
+ return 'float';
+ }
+
+ /**
+ * Create the column definition for a double type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDouble(Fluent $column)
+ {
+ return 'float';
+ }
+
+ /**
+ * Create the column definition for a decimal type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDecimal(Fluent $column)
+ {
+ return 'numeric';
+ }
+
+ /**
+ * Create the column definition for a boolean type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBoolean(Fluent $column)
+ {
+ return 'tinyint(1)';
+ }
+
+ /**
+ * Create the column definition for an enum type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeEnum(Fluent $column)
+ {
+ return 'varchar';
+ }
+
+ /**
+ * Create the column definition for a json type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeJson(Fluent $column)
+ {
+ return 'text';
+ }
+
+ /**
+ * Create the column definition for a jsonb type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeJsonb(Fluent $column)
+ {
+ return 'text';
+ }
+
+ /**
+ * Create the column definition for a date type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDate(Fluent $column)
+ {
+ return 'date';
+ }
+
+ /**
+ * Create the column definition for a date-time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDateTime(Fluent $column)
+ {
+ return 'datetime';
+ }
+
+ /**
+ * Create the column definition for a date-time type.
+ *
+ * Note: "SQLite does not have a storage class set aside for storing dates and/or times."
+ * @link https://www.sqlite.org/datatype3.html
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDateTimeTz(Fluent $column)
+ {
+ return 'datetime';
+ }
+
+ /**
+ * Create the column definition for a time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTime(Fluent $column)
+ {
+ return 'time';
+ }
+
+ /**
+ * Create the column definition for a time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimeTz(Fluent $column)
+ {
+ return 'time';
+ }
+
+ /**
+ * Create the column definition for a timestamp type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimestamp(Fluent $column)
+ {
+ if ($column->useCurrent) {
+ return 'datetime default CURRENT_TIMESTAMP';
+ }
+
+ return 'datetime';
+ }
+
+ /**
+ * Create the column definition for a timestamp type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimestampTz(Fluent $column)
+ {
+ if ($column->useCurrent) {
+ return 'datetime default CURRENT_TIMESTAMP';
+ }
+
+ return 'datetime';
+ }
+
+ /**
+ * Create the column definition for a binary type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBinary(Fluent $column)
+ {
+ return 'blob';
+ }
+
+ /**
+ * Create the column definition for a uuid type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeUuid(Fluent $column)
+ {
+ return 'varchar';
+ }
+
+ /**
+ * Create the column definition for an IP address type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeIpAddress(Fluent $column)
+ {
+ return 'varchar';
+ }
+
+ /**
+ * Create the column definition for a MAC address type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMacAddress(Fluent $column)
+ {
+ return 'varchar';
+ }
+
+ /**
+ * Get the SQL for a nullable column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyNullable(Blueprint $blueprint, Fluent $column)
+ {
+ return $column->nullable ? ' null' : ' not null';
+ }
+
+ /**
+ * Get the SQL for a default column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyDefault(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->default)) {
+ return ' default '.$this->getDefaultValue($column->default);
+ }
+ }
+
+ /**
+ * Get the SQL for an auto-increment column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyIncrement(Blueprint $blueprint, Fluent $column)
+ {
+ if (in_array($column->type, $this->serials) && $column->autoIncrement) {
+ return ' primary key autoincrement';
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/SqlServerGrammar.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/SqlServerGrammar.php
new file mode 100644
index 000000000..4ba43bbc3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/Grammars/SqlServerGrammar.php
@@ -0,0 +1,626 @@
+getColumns($blueprint));
+
+ return 'create table '.$this->wrapTable($blueprint)." ($columns)";
+ }
+
+ /**
+ * Compile a column addition table command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileAdd(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('alter table %s add %s',
+ $this->wrapTable($blueprint),
+ implode(', ', $this->getColumns($blueprint))
+ );
+ }
+
+ /**
+ * Compile a primary key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compilePrimary(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('alter table %s add constraint %s primary key (%s)',
+ $this->wrapTable($blueprint),
+ $this->wrap($command->index),
+ $this->columnize($command->columns)
+ );
+ }
+
+ /**
+ * Compile a unique key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileUnique(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('create unique index %s on %s (%s)',
+ $this->wrap($command->index),
+ $this->wrapTable($blueprint),
+ $this->columnize($command->columns)
+ );
+ }
+
+ /**
+ * Compile a plain index key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileIndex(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('create index %s on %s (%s)',
+ $this->wrap($command->index),
+ $this->wrapTable($blueprint),
+ $this->columnize($command->columns)
+ );
+ }
+
+ /**
+ * Compile a drop table command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDrop(Blueprint $blueprint, Fluent $command)
+ {
+ return 'drop table '.$this->wrapTable($blueprint);
+ }
+
+ /**
+ * Compile a drop table (if exists) command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropIfExists(Blueprint $blueprint, Fluent $command)
+ {
+ return sprintf('if exists (select * from INFORMATION_SCHEMA.TABLES where TABLE_NAME = %s) drop table %s',
+ "'".str_replace("'", "''", $this->getTablePrefix().$blueprint->getTable())."'",
+ $this->wrapTable($blueprint)
+ );
+ }
+
+ /**
+ * Compile a drop column command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropColumn(Blueprint $blueprint, Fluent $command)
+ {
+ $columns = $this->wrapArray($command->columns);
+
+ return 'alter table '.$this->wrapTable($blueprint).' drop column '.implode(', ', $columns);
+ }
+
+ /**
+ * Compile a drop primary key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropPrimary(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "alter table {$this->wrapTable($blueprint)} drop constraint {$index}";
+ }
+
+ /**
+ * Compile a drop unique key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropUnique(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "drop index {$index} on {$this->wrapTable($blueprint)}";
+ }
+
+ /**
+ * Compile a drop index command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropIndex(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "drop index {$index} on {$this->wrapTable($blueprint)}";
+ }
+
+ /**
+ * Compile a drop foreign key command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileDropForeign(Blueprint $blueprint, Fluent $command)
+ {
+ $index = $this->wrap($command->index);
+
+ return "alter table {$this->wrapTable($blueprint)} drop constraint {$index}";
+ }
+
+ /**
+ * Compile a rename table command.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $command
+ * @return string
+ */
+ public function compileRename(Blueprint $blueprint, Fluent $command)
+ {
+ $from = $this->wrapTable($blueprint);
+
+ return "sp_rename {$from}, ".$this->wrapTable($command->to);
+ }
+
+ /**
+ * Compile the command to enable foreign key constraints.
+ *
+ * @return string
+ */
+ public function compileEnableForeignKeyConstraints()
+ {
+ return 'EXEC sp_msforeachtable @command1="print \'?\'", @command2="ALTER TABLE ? WITH CHECK CHECK CONSTRAINT all";';
+ }
+
+ /**
+ * Compile the command to disable foreign key constraints.
+ *
+ * @return string
+ */
+ public function compileDisableForeignKeyConstraints()
+ {
+ return 'EXEC sp_msforeachtable "ALTER TABLE ? NOCHECK CONSTRAINT all";';
+ }
+
+ /**
+ * Create the column definition for a char type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeChar(Fluent $column)
+ {
+ return "nchar({$column->length})";
+ }
+
+ /**
+ * Create the column definition for a string type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeString(Fluent $column)
+ {
+ return "nvarchar({$column->length})";
+ }
+
+ /**
+ * Create the column definition for a text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeText(Fluent $column)
+ {
+ return 'nvarchar(max)';
+ }
+
+ /**
+ * Create the column definition for a medium text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMediumText(Fluent $column)
+ {
+ return 'nvarchar(max)';
+ }
+
+ /**
+ * Create the column definition for a long text type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeLongText(Fluent $column)
+ {
+ return 'nvarchar(max)';
+ }
+
+ /**
+ * Create the column definition for an integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeInteger(Fluent $column)
+ {
+ return 'int';
+ }
+
+ /**
+ * Create the column definition for a big integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBigInteger(Fluent $column)
+ {
+ return 'bigint';
+ }
+
+ /**
+ * Create the column definition for a medium integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMediumInteger(Fluent $column)
+ {
+ return 'int';
+ }
+
+ /**
+ * Create the column definition for a tiny integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTinyInteger(Fluent $column)
+ {
+ return 'tinyint';
+ }
+
+ /**
+ * Create the column definition for a small integer type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeSmallInteger(Fluent $column)
+ {
+ return 'smallint';
+ }
+
+ /**
+ * Create the column definition for a float type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeFloat(Fluent $column)
+ {
+ return 'float';
+ }
+
+ /**
+ * Create the column definition for a double type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDouble(Fluent $column)
+ {
+ return 'float';
+ }
+
+ /**
+ * Create the column definition for a decimal type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDecimal(Fluent $column)
+ {
+ return "decimal({$column->total}, {$column->places})";
+ }
+
+ /**
+ * Create the column definition for a boolean type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBoolean(Fluent $column)
+ {
+ return 'bit';
+ }
+
+ /**
+ * Create the column definition for an enum type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeEnum(Fluent $column)
+ {
+ return 'nvarchar(255)';
+ }
+
+ /**
+ * Create the column definition for a json type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeJson(Fluent $column)
+ {
+ return 'nvarchar(max)';
+ }
+
+ /**
+ * Create the column definition for a jsonb type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeJsonb(Fluent $column)
+ {
+ return 'nvarchar(max)';
+ }
+
+ /**
+ * Create the column definition for a date type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDate(Fluent $column)
+ {
+ return 'date';
+ }
+
+ /**
+ * Create the column definition for a date-time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDateTime(Fluent $column)
+ {
+ return 'datetime';
+ }
+
+ /**
+ * Create the column definition for a date-time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeDateTimeTz(Fluent $column)
+ {
+ return 'datetimeoffset(0)';
+ }
+
+ /**
+ * Create the column definition for a time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTime(Fluent $column)
+ {
+ return 'time';
+ }
+
+ /**
+ * Create the column definition for a time type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimeTz(Fluent $column)
+ {
+ return 'time';
+ }
+
+ /**
+ * Create the column definition for a timestamp type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimestamp(Fluent $column)
+ {
+ if ($column->useCurrent) {
+ return 'datetime default CURRENT_TIMESTAMP';
+ }
+
+ return 'datetime';
+ }
+
+ /**
+ * Create the column definition for a timestamp type.
+ *
+ * @link https://msdn.microsoft.com/en-us/library/bb630289(v=sql.120).aspx
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeTimestampTz(Fluent $column)
+ {
+ if ($column->useCurrent) {
+ return 'datetimeoffset(0) default CURRENT_TIMESTAMP';
+ }
+
+ return 'datetimeoffset(0)';
+ }
+
+ /**
+ * Create the column definition for a binary type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeBinary(Fluent $column)
+ {
+ return 'varbinary(max)';
+ }
+
+ /**
+ * Create the column definition for a uuid type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeUuid(Fluent $column)
+ {
+ return 'uniqueidentifier';
+ }
+
+ /**
+ * Create the column definition for an IP address type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeIpAddress(Fluent $column)
+ {
+ return 'nvarchar(45)';
+ }
+
+ /**
+ * Create the column definition for a MAC address type.
+ *
+ * @param \Illuminate\Support\Fluent $column
+ * @return string
+ */
+ protected function typeMacAddress(Fluent $column)
+ {
+ return 'nvarchar(17)';
+ }
+
+ /**
+ * Get the SQL for a collation column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyCollate(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->collation)) {
+ return ' collate '.$column->collation;
+ }
+ }
+
+ /**
+ * Get the SQL for a nullable column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyNullable(Blueprint $blueprint, Fluent $column)
+ {
+ return $column->nullable ? ' null' : ' not null';
+ }
+
+ /**
+ * Get the SQL for a default column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyDefault(Blueprint $blueprint, Fluent $column)
+ {
+ if (! is_null($column->default)) {
+ return ' default '.$this->getDefaultValue($column->default);
+ }
+ }
+
+ /**
+ * Get the SQL for an auto-increment column modifier.
+ *
+ * @param \Illuminate\Database\Schema\Blueprint $blueprint
+ * @param \Illuminate\Support\Fluent $column
+ * @return string|null
+ */
+ protected function modifyIncrement(Blueprint $blueprint, Fluent $column)
+ {
+ if (in_array($column->type, $this->serials) && $column->autoIncrement) {
+ return ' identity primary key';
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/MySqlBuilder.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/MySqlBuilder.php
new file mode 100644
index 000000000..e8d4fe1cc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/MySqlBuilder.php
@@ -0,0 +1,38 @@
+connection->getTablePrefix().$table;
+
+ return count($this->connection->select(
+ $this->grammar->compileTableExists(), [$this->connection->getDatabaseName(), $table]
+ )) > 0;
+ }
+
+ /**
+ * Get the column listing for a given table.
+ *
+ * @param string $table
+ * @return array
+ */
+ public function getColumnListing($table)
+ {
+ $table = $this->connection->getTablePrefix().$table;
+
+ $results = $this->connection->select(
+ $this->grammar->compileColumnListing(), [$this->connection->getDatabaseName(), $table]
+ );
+
+ return $this->connection->getPostProcessor()->processColumnListing($results);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Schema/PostgresBuilder.php b/vendor/laravel/framework/src/Illuminate/Database/Schema/PostgresBuilder.php
new file mode 100644
index 000000000..fb73deaed
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Schema/PostgresBuilder.php
@@ -0,0 +1,27 @@
+connection->getConfig('schema'))) {
+ $schema = head($schema);
+ }
+
+ $schema = $schema ? $schema : 'public';
+
+ $table = $this->connection->getTablePrefix().$table;
+
+ return count($this->connection->select(
+ $this->grammar->compileTableExists(), [$schema, $table]
+ )) > 0;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/Seeder.php b/vendor/laravel/framework/src/Illuminate/Database/Seeder.php
new file mode 100644
index 000000000..6f7c73561
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/Seeder.php
@@ -0,0 +1,117 @@
+command)) {
+ $this->command->getOutput()->writeln("Seeding: $class");
+ }
+
+ $this->resolve($class)->__invoke();
+ }
+
+ /**
+ * Silently seed the given connection from the given path.
+ *
+ * @param string $class
+ * @return void
+ */
+ public function callSilent($class)
+ {
+ $this->resolve($class)->__invoke();
+ }
+
+ /**
+ * Resolve an instance of the given seeder class.
+ *
+ * @param string $class
+ * @return \Illuminate\Database\Seeder
+ */
+ protected function resolve($class)
+ {
+ if (isset($this->container)) {
+ $instance = $this->container->make($class);
+
+ $instance->setContainer($this->container);
+ } else {
+ $instance = new $class;
+ }
+
+ if (isset($this->command)) {
+ $instance->setCommand($this->command);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Set the IoC container instance.
+ *
+ * @param \Illuminate\Container\Container $container
+ * @return $this
+ */
+ public function setContainer(Container $container)
+ {
+ $this->container = $container;
+
+ return $this;
+ }
+
+ /**
+ * Set the console command instance.
+ *
+ * @param \Illuminate\Console\Command $command
+ * @return $this
+ */
+ public function setCommand(Command $command)
+ {
+ $this->command = $command;
+
+ return $this;
+ }
+
+ /**
+ * Run the database seeds.
+ *
+ * @return void
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function __invoke()
+ {
+ if (! method_exists($this, 'run')) {
+ throw new InvalidArgumentException('Method [run] missing from '.get_class($this));
+ }
+
+ return isset($this->container)
+ ? $this->container->call([$this, 'run'])
+ : $this->run();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/SqlServerConnection.php b/vendor/laravel/framework/src/Illuminate/Database/SqlServerConnection.php
new file mode 100644
index 000000000..cdd172ae2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/SqlServerConnection.php
@@ -0,0 +1,98 @@
+getDriverName() == 'sqlsrv') {
+ return parent::transaction($callback);
+ }
+
+ $this->getPdo()->exec('BEGIN TRAN');
+
+ // We'll simply execute the given callback within a try / catch block
+ // and if we catch any exception we can rollback the transaction
+ // so that none of the changes are persisted to the database.
+ try {
+ $result = $callback($this);
+
+ $this->getPdo()->exec('COMMIT TRAN');
+ }
+
+ // If we catch an exception, we will roll back so nothing gets messed
+ // up in the database. Then we'll re-throw the exception so it can
+ // be handled how the developer sees fit for their applications.
+ catch (Exception $e) {
+ $this->getPdo()->exec('ROLLBACK TRAN');
+
+ throw $e;
+ } catch (Throwable $e) {
+ $this->getPdo()->exec('ROLLBACK TRAN');
+
+ throw $e;
+ }
+
+ return $result;
+ }
+ }
+
+ /**
+ * Get the default query grammar instance.
+ *
+ * @return \Illuminate\Database\Query\Grammars\SqlServerGrammar
+ */
+ protected function getDefaultQueryGrammar()
+ {
+ return $this->withTablePrefix(new QueryGrammar);
+ }
+
+ /**
+ * Get the default schema grammar instance.
+ *
+ * @return \Illuminate\Database\Schema\Grammars\SqlServerGrammar
+ */
+ protected function getDefaultSchemaGrammar()
+ {
+ return $this->withTablePrefix(new SchemaGrammar);
+ }
+
+ /**
+ * Get the default post processor instance.
+ *
+ * @return \Illuminate\Database\Query\Processors\SqlServerProcessor
+ */
+ protected function getDefaultPostProcessor()
+ {
+ return new SqlServerProcessor;
+ }
+
+ /**
+ * Get the Doctrine DBAL driver.
+ *
+ * @return \Doctrine\DBAL\Driver\PDOSqlsrv\Driver
+ */
+ protected function getDoctrineDriver()
+ {
+ return new DoctrineDriver;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Database/composer.json b/vendor/laravel/framework/src/Illuminate/Database/composer.json
new file mode 100644
index 000000000..46c1abe17
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Database/composer.json
@@ -0,0 +1,46 @@
+{
+ "name": "illuminate/database",
+ "description": "The Illuminate Database package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "keywords": ["laravel", "database", "sql", "orm"],
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/container": "5.4.*",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "nesbot/carbon": "~1.20"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Database\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "doctrine/dbal": "Required to rename columns and drop SQLite columns (~2.5).",
+ "fzaninotto/faker": "Required to use the eloquent factory builder (~1.4).",
+ "illuminate/console": "Required to use the database commands (5.4.*).",
+ "illuminate/events": "Required to use the observers with Eloquent (5.4.*).",
+ "illuminate/filesystem": "Required to use the migrations (5.4.*).",
+ "illuminate/pagination": "Required to paginate the result set (5.4.*)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Encryption/Encrypter.php b/vendor/laravel/framework/src/Illuminate/Encryption/Encrypter.php
new file mode 100644
index 000000000..5f266a043
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Encryption/Encrypter.php
@@ -0,0 +1,241 @@
+key = $key;
+ $this->cipher = $cipher;
+ } else {
+ throw new RuntimeException('The only supported ciphers are AES-128-CBC and AES-256-CBC with the correct key lengths.');
+ }
+ }
+
+ /**
+ * Determine if the given key and cipher combination is valid.
+ *
+ * @param string $key
+ * @param string $cipher
+ * @return bool
+ */
+ public static function supported($key, $cipher)
+ {
+ $length = mb_strlen($key, '8bit');
+
+ return ($cipher === 'AES-128-CBC' && $length === 16) ||
+ ($cipher === 'AES-256-CBC' && $length === 32);
+ }
+
+ /**
+ * Encrypt the given value.
+ *
+ * @param mixed $value
+ * @param bool $serialize
+ * @return string
+ *
+ * @throws \Illuminate\Contracts\Encryption\EncryptException
+ */
+ public function encrypt($value, $serialize = true)
+ {
+ $iv = random_bytes(16);
+
+ // First we will encrypt the value using OpenSSL. After this is encrypted we
+ // will proceed to calculating a MAC for the encrypted value so that this
+ // value can be verified later as not having been changed by the users.
+ $value = \openssl_encrypt(
+ $serialize ? serialize($value) : $value,
+ $this->cipher, $this->key, 0, $iv
+ );
+
+ if ($value === false) {
+ throw new EncryptException('Could not encrypt the data.');
+ }
+
+ // Once we get the encrypted value we'll go ahead and base64_encode the input
+ // vector and create the MAC for the encrypted value so we can then verify
+ // its authenticity. Then, we'll JSON the data into the "payload" array.
+ $mac = $this->hash($iv = base64_encode($iv), $value);
+
+ $json = json_encode(compact('iv', 'value', 'mac'));
+
+ if (! is_string($json)) {
+ throw new EncryptException('Could not encrypt the data.');
+ }
+
+ return base64_encode($json);
+ }
+
+ /**
+ * Encrypt a string without serialization.
+ *
+ * @param string $value
+ * @return string
+ */
+ public function encryptString($value)
+ {
+ return $this->encrypt($value, false);
+ }
+
+ /**
+ * Decrypt the given value.
+ *
+ * @param mixed $payload
+ * @param bool $unserialize
+ * @return string
+ *
+ * @throws \Illuminate\Contracts\Encryption\DecryptException
+ */
+ public function decrypt($payload, $unserialize = true)
+ {
+ $payload = $this->getJsonPayload($payload);
+
+ $iv = base64_decode($payload['iv']);
+
+ // Here we will decrypt the value. If we are able to successfully decrypt it
+ // we will then unserialize it and return it out to the caller. If we are
+ // unable to decrypt this value we will throw out an exception message.
+ $decrypted = \openssl_decrypt(
+ $payload['value'], $this->cipher, $this->key, 0, $iv
+ );
+
+ if ($decrypted === false) {
+ throw new DecryptException('Could not decrypt the data.');
+ }
+
+ return $unserialize ? unserialize($decrypted) : $decrypted;
+ }
+
+ /**
+ * Decrypt the given string without unserialization.
+ *
+ * @param string $payload
+ * @return string
+ */
+ public function decryptString($payload)
+ {
+ return $this->decrypt($payload, false);
+ }
+
+ /**
+ * Create a MAC for the given value.
+ *
+ * @param string $iv
+ * @param mixed $value
+ * @return string
+ */
+ protected function hash($iv, $value)
+ {
+ return hash_hmac('sha256', $iv.$value, $this->key);
+ }
+
+ /**
+ * Get the JSON array from the given payload.
+ *
+ * @param string $payload
+ * @return array
+ *
+ * @throws \Illuminate\Contracts\Encryption\DecryptException
+ */
+ protected function getJsonPayload($payload)
+ {
+ $payload = json_decode(base64_decode($payload), true);
+
+ // If the payload is not valid JSON or does not have the proper keys set we will
+ // assume it is invalid and bail out of the routine since we will not be able
+ // to decrypt the given value. We'll also check the MAC for this encryption.
+ if (! $this->validPayload($payload)) {
+ throw new DecryptException('The payload is invalid.');
+ }
+
+ if (! $this->validMac($payload)) {
+ throw new DecryptException('The MAC is invalid.');
+ }
+
+ return $payload;
+ }
+
+ /**
+ * Verify that the encryption payload is valid.
+ *
+ * @param mixed $payload
+ * @return bool
+ */
+ protected function validPayload($payload)
+ {
+ return is_array($payload) && isset(
+ $payload['iv'], $payload['value'], $payload['mac']
+ );
+ }
+
+ /**
+ * Determine if the MAC for the given payload is valid.
+ *
+ * @param array $payload
+ * @return bool
+ */
+ protected function validMac(array $payload)
+ {
+ $calculated = $this->calculateMac($payload, $bytes = random_bytes(16));
+
+ return hash_equals(
+ hash_hmac('sha256', $payload['mac'], $bytes, true), $calculated
+ );
+ }
+
+ /**
+ * Calculate the hash of the given payload.
+ *
+ * @param array $payload
+ * @param string $bytes
+ * @return string
+ */
+ protected function calculateMac($payload, $bytes)
+ {
+ return hash_hmac(
+ 'sha256', $this->hash($payload['iv'], $payload['value']), $bytes, true
+ );
+ }
+
+ /**
+ * Get the encryption key.
+ *
+ * @return string
+ */
+ public function getKey()
+ {
+ return $this->key;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Encryption/EncryptionServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Encryption/EncryptionServiceProvider.php
new file mode 100644
index 000000000..d27ed2826
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Encryption/EncryptionServiceProvider.php
@@ -0,0 +1,30 @@
+app->singleton('encrypter', function ($app) {
+ $config = $app->make('config')->get('app');
+
+ // If the key starts with "base64:", we will need to decode the key before handing
+ // it off to the encrypter. Keys may be base-64 encoded for presentation and we
+ // want to make sure to convert them back to the raw bytes before encrypting.
+ if (Str::startsWith($key = $config['key'], 'base64:')) {
+ $key = base64_decode(substr($key, 7));
+ }
+
+ return new Encrypter($key, $config['cipher']);
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Encryption/composer.json b/vendor/laravel/framework/src/Illuminate/Encryption/composer.json
new file mode 100644
index 000000000..05d24fbff
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Encryption/composer.json
@@ -0,0 +1,38 @@
+{
+ "name": "illuminate/encryption",
+ "description": "The Illuminate Encryption package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "ext-mbstring": "*",
+ "ext-openssl": "*",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "paragonie/random_compat": "~1.4|~2.0"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Encryption\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Events/CallQueuedHandler.php b/vendor/laravel/framework/src/Illuminate/Events/CallQueuedHandler.php
new file mode 100644
index 000000000..4a21b64a0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Events/CallQueuedHandler.php
@@ -0,0 +1,86 @@
+container = $container;
+ }
+
+ /**
+ * Handle the queued job.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param array $data
+ * @return void
+ */
+ public function call(Job $job, array $data)
+ {
+ $handler = $this->setJobInstanceIfNecessary(
+ $job, $this->container->make($data['class'])
+ );
+
+ call_user_func_array(
+ [$handler, $data['method']], unserialize($data['data'])
+ );
+
+ if (! $job->isDeletedOrReleased()) {
+ $job->delete();
+ }
+ }
+
+ /**
+ * Set the job instance of the given class if necessary.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param mixed $instance
+ * @return mixed
+ */
+ protected function setJobInstanceIfNecessary(Job $job, $instance)
+ {
+ if (in_array(InteractsWithQueue::class, class_uses_recursive(get_class($instance)))) {
+ $instance->setJob($job);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Call the failed method on the job instance.
+ *
+ * The event instance and the exception will be passed.
+ *
+ * @param array $data
+ * @param \Exception $e
+ * @return void
+ */
+ public function failed(array $data, $e)
+ {
+ $handler = $this->container->make($data['class']);
+
+ $parameters = array_merge(unserialize($data['data']), [$e]);
+
+ if (method_exists($handler, 'failed')) {
+ call_user_func_array([$handler, 'failed'], $parameters);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Events/CallQueuedListener.php b/vendor/laravel/framework/src/Illuminate/Events/CallQueuedListener.php
new file mode 100644
index 000000000..381d5043c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Events/CallQueuedListener.php
@@ -0,0 +1,141 @@
+data = $data;
+ $this->class = $class;
+ $this->method = $method;
+ }
+
+ /**
+ * Handle the queued job.
+ *
+ * @param \Illuminate\Container\Container $container
+ * @return void
+ */
+ public function handle(Container $container)
+ {
+ $this->prepareData();
+
+ $handler = $this->setJobInstanceIfNecessary(
+ $this->job, $container->make($this->class)
+ );
+
+ call_user_func_array(
+ [$handler, $this->method], $this->data
+ );
+ }
+
+ /**
+ * Set the job instance of the given class if necessary.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param mixed $instance
+ * @return mixed
+ */
+ protected function setJobInstanceIfNecessary(Job $job, $instance)
+ {
+ if (in_array(InteractsWithQueue::class, class_uses_recursive(get_class($instance)))) {
+ $instance->setJob($job);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Call the failed method on the job instance.
+ *
+ * The event instance and the exception will be passed.
+ *
+ * @param \Exception $e
+ * @return void
+ */
+ public function failed($e)
+ {
+ $this->prepareData();
+
+ $handler = Container::getInstance()->make($this->class);
+
+ $parameters = array_merge($this->data, [$e]);
+
+ if (method_exists($handler, 'failed')) {
+ call_user_func_array([$handler, 'failed'], $parameters);
+ }
+ }
+
+ /**
+ * Unserialize the data if needed.
+ *
+ * @return void
+ */
+ protected function prepareData()
+ {
+ if (is_string($this->data)) {
+ $this->data = unserialize($this->data);
+ }
+ }
+
+ /**
+ * Get the display name for the queued job.
+ *
+ * @return string
+ */
+ public function displayName()
+ {
+ return $this->class;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Events/Dispatcher.php b/vendor/laravel/framework/src/Illuminate/Events/Dispatcher.php
new file mode 100644
index 000000000..841f33261
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Events/Dispatcher.php
@@ -0,0 +1,563 @@
+container = $container ?: new Container;
+ }
+
+ /**
+ * Register an event listener with the dispatcher.
+ *
+ * @param string|array $events
+ * @param mixed $listener
+ * @return void
+ */
+ public function listen($events, $listener)
+ {
+ foreach ((array) $events as $event) {
+ if (Str::contains($event, '*')) {
+ $this->setupWildcardListen($event, $listener);
+ } else {
+ $this->listeners[$event][] = $this->makeListener($listener);
+ }
+ }
+ }
+
+ /**
+ * Setup a wildcard listener callback.
+ *
+ * @param string $event
+ * @param mixed $listener
+ * @return void
+ */
+ protected function setupWildcardListen($event, $listener)
+ {
+ $this->wildcards[$event][] = $this->makeListener($listener, true);
+ }
+
+ /**
+ * Determine if a given event has listeners.
+ *
+ * @param string $eventName
+ * @return bool
+ */
+ public function hasListeners($eventName)
+ {
+ return isset($this->listeners[$eventName]) || isset($this->wildcards[$eventName]);
+ }
+
+ /**
+ * Register an event and payload to be fired later.
+ *
+ * @param string $event
+ * @param array $payload
+ * @return void
+ */
+ public function push($event, $payload = [])
+ {
+ $this->listen($event.'_pushed', function () use ($event, $payload) {
+ $this->dispatch($event, $payload);
+ });
+ }
+
+ /**
+ * Flush a set of pushed events.
+ *
+ * @param string $event
+ * @return void
+ */
+ public function flush($event)
+ {
+ $this->dispatch($event.'_pushed');
+ }
+
+ /**
+ * Register an event subscriber with the dispatcher.
+ *
+ * @param object|string $subscriber
+ * @return void
+ */
+ public function subscribe($subscriber)
+ {
+ $subscriber = $this->resolveSubscriber($subscriber);
+
+ $subscriber->subscribe($this);
+ }
+
+ /**
+ * Resolve the subscriber instance.
+ *
+ * @param object|string $subscriber
+ * @return mixed
+ */
+ protected function resolveSubscriber($subscriber)
+ {
+ if (is_string($subscriber)) {
+ return $this->container->make($subscriber);
+ }
+
+ return $subscriber;
+ }
+
+ /**
+ * Fire an event until the first non-null response is returned.
+ *
+ * @param string|object $event
+ * @param mixed $payload
+ * @return array|null
+ */
+ public function until($event, $payload = [])
+ {
+ return $this->dispatch($event, $payload, true);
+ }
+
+ /**
+ * Fire an event and call the listeners.
+ *
+ * @param string|object $event
+ * @param mixed $payload
+ * @param bool $halt
+ * @return array|null
+ */
+ public function fire($event, $payload = [], $halt = false)
+ {
+ return $this->dispatch($event, $payload, $halt);
+ }
+
+ /**
+ * Fire an event and call the listeners.
+ *
+ * @param string|object $event
+ * @param mixed $payload
+ * @param bool $halt
+ * @return array|null
+ */
+ public function dispatch($event, $payload = [], $halt = false)
+ {
+ // When the given "event" is actually an object we will assume it is an event
+ // object and use the class as the event name and this event itself as the
+ // payload to the handler, which makes object based events quite simple.
+ list($event, $payload) = $this->parseEventAndPayload(
+ $event, $payload
+ );
+
+ if ($this->shouldBroadcast($payload)) {
+ $this->broadcastEvent($payload[0]);
+ }
+
+ $responses = [];
+
+ foreach ($this->getListeners($event) as $listener) {
+ $response = $listener($event, $payload);
+
+ // If a response is returned from the listener and event halting is enabled
+ // we will just return this response, and not call the rest of the event
+ // listeners. Otherwise we will add the response on the response list.
+ if ($halt && ! is_null($response)) {
+ return $response;
+ }
+
+ // If a boolean false is returned from a listener, we will stop propagating
+ // the event to any further listeners down in the chain, else we keep on
+ // looping through the listeners and firing every one in our sequence.
+ if ($response === false) {
+ break;
+ }
+
+ $responses[] = $response;
+ }
+
+ return $halt ? null : $responses;
+ }
+
+ /**
+ * Parse the given event and payload and prepare them for dispatching.
+ *
+ * @param mixed $event
+ * @param mixed $payload
+ * @return array
+ */
+ protected function parseEventAndPayload($event, $payload)
+ {
+ if (is_object($event)) {
+ list($payload, $event) = [[$event], get_class($event)];
+ }
+
+ return [$event, array_wrap($payload)];
+ }
+
+ /**
+ * Determine if the payload has a broadcastable event.
+ *
+ * @param array $payload
+ * @return bool
+ */
+ protected function shouldBroadcast(array $payload)
+ {
+ return isset($payload[0]) &&
+ $payload[0] instanceof ShouldBroadcast &&
+ $this->broadcastWhen($payload[0]);
+ }
+
+ /**
+ * Check if event should be broadcasted by condition.
+ *
+ * @param mixed $event
+ * @return bool
+ */
+ protected function broadcastWhen($event)
+ {
+ return method_exists($event, 'broadcastWhen')
+ ? $event->broadcastWhen() : true;
+ }
+
+ /**
+ * Broadcast the given event class.
+ *
+ * @param \Illuminate\Contracts\Broadcasting\ShouldBroadcast $event
+ * @return void
+ */
+ protected function broadcastEvent($event)
+ {
+ $this->container->make(BroadcastFactory::class)->queue($event);
+ }
+
+ /**
+ * Get all of the listeners for a given event name.
+ *
+ * @param string $eventName
+ * @return array
+ */
+ public function getListeners($eventName)
+ {
+ $listeners = isset($this->listeners[$eventName]) ? $this->listeners[$eventName] : [];
+
+ $listeners = array_merge(
+ $listeners, $this->getWildcardListeners($eventName)
+ );
+
+ return class_exists($eventName, false)
+ ? $this->addInterfaceListeners($eventName, $listeners)
+ : $listeners;
+ }
+
+ /**
+ * Get the wildcard listeners for the event.
+ *
+ * @param string $eventName
+ * @return array
+ */
+ protected function getWildcardListeners($eventName)
+ {
+ $wildcards = [];
+
+ foreach ($this->wildcards as $key => $listeners) {
+ if (Str::is($key, $eventName)) {
+ $wildcards = array_merge($wildcards, $listeners);
+ }
+ }
+
+ return $wildcards;
+ }
+
+ /**
+ * Add the listeners for the event's interfaces to the given array.
+ *
+ * @param string $eventName
+ * @param array $listeners
+ * @return array
+ */
+ protected function addInterfaceListeners($eventName, array $listeners = [])
+ {
+ foreach (class_implements($eventName) as $interface) {
+ if (isset($this->listeners[$interface])) {
+ foreach ($this->listeners[$interface] as $names) {
+ $listeners = array_merge($listeners, (array) $names);
+ }
+ }
+ }
+
+ return $listeners;
+ }
+
+ /**
+ * Register an event listener with the dispatcher.
+ *
+ * @param string|\Closure $listener
+ * @param bool $wildcard
+ * @return \Closure
+ */
+ public function makeListener($listener, $wildcard = false)
+ {
+ if (is_string($listener)) {
+ return $this->createClassListener($listener, $wildcard);
+ }
+
+ return function ($event, $payload) use ($listener, $wildcard) {
+ if ($wildcard) {
+ return $listener($event, $payload);
+ } else {
+ return $listener(...array_values($payload));
+ }
+ };
+ }
+
+ /**
+ * Create a class based listener using the IoC container.
+ *
+ * @param string $listener
+ * @param bool $wildcard
+ * @return \Closure
+ */
+ public function createClassListener($listener, $wildcard = false)
+ {
+ return function ($event, $payload) use ($listener, $wildcard) {
+ if ($wildcard) {
+ return call_user_func($this->createClassCallable($listener), $event, $payload);
+ } else {
+ return call_user_func_array(
+ $this->createClassCallable($listener), $payload
+ );
+ }
+ };
+ }
+
+ /**
+ * Create the class based event callable.
+ *
+ * @param string $listener
+ * @return callable
+ */
+ protected function createClassCallable($listener)
+ {
+ list($class, $method) = $this->parseClassCallable($listener);
+
+ if ($this->handlerShouldBeQueued($class)) {
+ return $this->createQueuedHandlerCallable($class, $method);
+ } else {
+ return [$this->container->make($class), $method];
+ }
+ }
+
+ /**
+ * Parse the class listener into class and method.
+ *
+ * @param string $listener
+ * @return array
+ */
+ protected function parseClassCallable($listener)
+ {
+ return Str::parseCallback($listener, 'handle');
+ }
+
+ /**
+ * Determine if the event handler class should be queued.
+ *
+ * @param string $class
+ * @return bool
+ */
+ protected function handlerShouldBeQueued($class)
+ {
+ try {
+ return (new ReflectionClass($class))->implementsInterface(
+ ShouldQueue::class
+ );
+ } catch (Exception $e) {
+ return false;
+ }
+ }
+
+ /**
+ * Create a callable for putting an event handler on the queue.
+ *
+ * @param string $class
+ * @param string $method
+ * @return \Closure
+ */
+ protected function createQueuedHandlerCallable($class, $method)
+ {
+ return function () use ($class, $method) {
+ $arguments = array_map(function ($a) {
+ return is_object($a) ? clone $a : $a;
+ }, func_get_args());
+
+ if (method_exists($class, 'queue')) {
+ $this->callQueueMethodOnHandler($class, $method, $arguments);
+ } else {
+ $this->queueHandler($class, $method, $arguments);
+ }
+ };
+ }
+
+ /**
+ * Call the queue method on the handler class.
+ *
+ * @param string $class
+ * @param string $method
+ * @param array $arguments
+ * @return void
+ */
+ protected function callQueueMethodOnHandler($class, $method, $arguments)
+ {
+ $handler = (new ReflectionClass($class))->newInstanceWithoutConstructor();
+
+ $handler->queue($this->resolveQueue(), 'Illuminate\Events\CallQueuedHandler@call', [
+ 'class' => $class, 'method' => $method, 'data' => serialize($arguments),
+ ]);
+ }
+
+ /**
+ * Queue the handler class.
+ *
+ * @param string $class
+ * @param string $method
+ * @param array $arguments
+ * @return void
+ */
+ protected function queueHandler($class, $method, $arguments)
+ {
+ list($listener, $job) = $this->createListenerAndJob($class, $method, $arguments);
+
+ $connection = $this->resolveQueue()->connection(
+ isset($listener->connection) ? $listener->connection : null
+ );
+
+ $queue = isset($listener->queue) ? $listener->queue : null;
+
+ isset($listener->delay)
+ ? $connection->laterOn($queue, $listener->delay, $job)
+ : $connection->pushOn($queue, $job);
+ }
+
+ /**
+ * Create the listener and job for a queued listener.
+ *
+ * @param string $class
+ * @param string $method
+ * @param array $arguments
+ * @return array
+ */
+ protected function createListenerAndJob($class, $method, $arguments)
+ {
+ $listener = (new ReflectionClass($class))->newInstanceWithoutConstructor();
+
+ return [$listener, $this->propogateListenerOptions(
+ $listener, new CallQueuedListener($class, $method, $arguments)
+ )];
+ }
+
+ /**
+ * Propogate listener options to the job.
+ *
+ * @param mixed $listener
+ * @param mixed $job
+ * @return mixed
+ */
+ protected function propogateListenerOptions($listener, $job)
+ {
+ return tap($job, function ($job) use ($listener) {
+ $job->tries = isset($listener->tries) ? $listener->tries : null;
+ $job->timeout = isset($listener->timeout) ? $listener->timeout : null;
+ });
+ }
+
+ /**
+ * Remove a set of listeners from the dispatcher.
+ *
+ * @param string $event
+ * @return void
+ */
+ public function forget($event)
+ {
+ if (Str::contains($event, '*')) {
+ unset($this->wildcards[$event]);
+ } else {
+ unset($this->listeners[$event]);
+ }
+ }
+
+ /**
+ * Forget all of the pushed listeners.
+ *
+ * @return void
+ */
+ public function forgetPushed()
+ {
+ foreach ($this->listeners as $key => $value) {
+ if (Str::endsWith($key, '_pushed')) {
+ $this->forget($key);
+ }
+ }
+ }
+
+ /**
+ * Get the queue implementation from the resolver.
+ *
+ * @return \Illuminate\Contracts\Queue\Queue
+ */
+ protected function resolveQueue()
+ {
+ return call_user_func($this->queueResolver);
+ }
+
+ /**
+ * Set the queue resolver implementation.
+ *
+ * @param callable $resolver
+ * @return $this
+ */
+ public function setQueueResolver(callable $resolver)
+ {
+ $this->queueResolver = $resolver;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Events/EventServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Events/EventServiceProvider.php
new file mode 100644
index 000000000..fa3ed6f6f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Events/EventServiceProvider.php
@@ -0,0 +1,23 @@
+app->singleton('events', function ($app) {
+ return (new Dispatcher($app))->setQueueResolver(function () use ($app) {
+ return $app->make(QueueFactoryContract::class);
+ });
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Events/composer.json b/vendor/laravel/framework/src/Illuminate/Events/composer.json
new file mode 100644
index 000000000..a5ed91583
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Events/composer.json
@@ -0,0 +1,36 @@
+{
+ "name": "illuminate/events",
+ "description": "The Illuminate Events package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/container": "5.4.*",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Events\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Filesystem/Filesystem.php b/vendor/laravel/framework/src/Illuminate/Filesystem/Filesystem.php
new file mode 100644
index 000000000..9589c0f00
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Filesystem/Filesystem.php
@@ -0,0 +1,570 @@
+isFile($path)) {
+ return $lock ? $this->sharedGet($path) : file_get_contents($path);
+ }
+
+ throw new FileNotFoundException("File does not exist at path {$path}");
+ }
+
+ /**
+ * Get contents of a file with shared access.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function sharedGet($path)
+ {
+ $contents = '';
+
+ $handle = fopen($path, 'rb');
+
+ if ($handle) {
+ try {
+ if (flock($handle, LOCK_SH)) {
+ clearstatcache(true, $path);
+
+ $contents = fread($handle, $this->size($path) ?: 1);
+
+ flock($handle, LOCK_UN);
+ }
+ } finally {
+ fclose($handle);
+ }
+ }
+
+ return $contents;
+ }
+
+ /**
+ * Get the returned value of a file.
+ *
+ * @param string $path
+ * @return mixed
+ *
+ * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException
+ */
+ public function getRequire($path)
+ {
+ if ($this->isFile($path)) {
+ return require $path;
+ }
+
+ throw new FileNotFoundException("File does not exist at path {$path}");
+ }
+
+ /**
+ * Require the given file once.
+ *
+ * @param string $file
+ * @return mixed
+ */
+ public function requireOnce($file)
+ {
+ require_once $file;
+ }
+
+ /**
+ * Get the MD5 hash of the file at the given path.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function hash($path)
+ {
+ return md5_file($path);
+ }
+
+ /**
+ * Write the contents of a file.
+ *
+ * @param string $path
+ * @param string $contents
+ * @param bool $lock
+ * @return int
+ */
+ public function put($path, $contents, $lock = false)
+ {
+ return file_put_contents($path, $contents, $lock ? LOCK_EX : 0);
+ }
+
+ /**
+ * Prepend to a file.
+ *
+ * @param string $path
+ * @param string $data
+ * @return int
+ */
+ public function prepend($path, $data)
+ {
+ if ($this->exists($path)) {
+ return $this->put($path, $data.$this->get($path));
+ }
+
+ return $this->put($path, $data);
+ }
+
+ /**
+ * Append to a file.
+ *
+ * @param string $path
+ * @param string $data
+ * @return int
+ */
+ public function append($path, $data)
+ {
+ return file_put_contents($path, $data, FILE_APPEND);
+ }
+
+ /**
+ * Get or set UNIX mode of a file or directory.
+ *
+ * @param string $path
+ * @param int $mode
+ * @return mixed
+ */
+ public function chmod($path, $mode = null)
+ {
+ if ($mode) {
+ return chmod($path, $mode);
+ }
+
+ return substr(sprintf('%o', fileperms($path)), -4);
+ }
+
+ /**
+ * Delete the file at a given path.
+ *
+ * @param string|array $paths
+ * @return bool
+ */
+ public function delete($paths)
+ {
+ $paths = is_array($paths) ? $paths : func_get_args();
+
+ $success = true;
+
+ foreach ($paths as $path) {
+ try {
+ if (! @unlink($path)) {
+ $success = false;
+ }
+ } catch (ErrorException $e) {
+ $success = false;
+ }
+ }
+
+ return $success;
+ }
+
+ /**
+ * Move a file to a new location.
+ *
+ * @param string $path
+ * @param string $target
+ * @return bool
+ */
+ public function move($path, $target)
+ {
+ return rename($path, $target);
+ }
+
+ /**
+ * Copy a file to a new location.
+ *
+ * @param string $path
+ * @param string $target
+ * @return bool
+ */
+ public function copy($path, $target)
+ {
+ return copy($path, $target);
+ }
+
+ /**
+ * Create a hard link to the target file or directory.
+ *
+ * @param string $target
+ * @param string $link
+ * @return void
+ */
+ public function link($target, $link)
+ {
+ if (! windows_os()) {
+ return symlink($target, $link);
+ }
+
+ $mode = $this->isDirectory($target) ? 'J' : 'H';
+
+ exec("mklink /{$mode} \"{$link}\" \"{$target}\"");
+ }
+
+ /**
+ * Extract the file name from a file path.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function name($path)
+ {
+ return pathinfo($path, PATHINFO_FILENAME);
+ }
+
+ /**
+ * Extract the trailing name component from a file path.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function basename($path)
+ {
+ return pathinfo($path, PATHINFO_BASENAME);
+ }
+
+ /**
+ * Extract the parent directory from a file path.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function dirname($path)
+ {
+ return pathinfo($path, PATHINFO_DIRNAME);
+ }
+
+ /**
+ * Extract the file extension from a file path.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function extension($path)
+ {
+ return pathinfo($path, PATHINFO_EXTENSION);
+ }
+
+ /**
+ * Get the file type of a given file.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function type($path)
+ {
+ return filetype($path);
+ }
+
+ /**
+ * Get the mime-type of a given file.
+ *
+ * @param string $path
+ * @return string|false
+ */
+ public function mimeType($path)
+ {
+ return finfo_file(finfo_open(FILEINFO_MIME_TYPE), $path);
+ }
+
+ /**
+ * Get the file size of a given file.
+ *
+ * @param string $path
+ * @return int
+ */
+ public function size($path)
+ {
+ return filesize($path);
+ }
+
+ /**
+ * Get the file's last modification time.
+ *
+ * @param string $path
+ * @return int
+ */
+ public function lastModified($path)
+ {
+ return filemtime($path);
+ }
+
+ /**
+ * Determine if the given path is a directory.
+ *
+ * @param string $directory
+ * @return bool
+ */
+ public function isDirectory($directory)
+ {
+ return is_dir($directory);
+ }
+
+ /**
+ * Determine if the given path is readable.
+ *
+ * @param string $path
+ * @return bool
+ */
+ public function isReadable($path)
+ {
+ return is_readable($path);
+ }
+
+ /**
+ * Determine if the given path is writable.
+ *
+ * @param string $path
+ * @return bool
+ */
+ public function isWritable($path)
+ {
+ return is_writable($path);
+ }
+
+ /**
+ * Determine if the given path is a file.
+ *
+ * @param string $file
+ * @return bool
+ */
+ public function isFile($file)
+ {
+ return is_file($file);
+ }
+
+ /**
+ * Find path names matching a given pattern.
+ *
+ * @param string $pattern
+ * @param int $flags
+ * @return array
+ */
+ public function glob($pattern, $flags = 0)
+ {
+ return glob($pattern, $flags);
+ }
+
+ /**
+ * Get an array of all files in a directory.
+ *
+ * @param string $directory
+ * @return array
+ */
+ public function files($directory)
+ {
+ $glob = glob($directory.DIRECTORY_SEPARATOR.'*');
+
+ if ($glob === false) {
+ return [];
+ }
+
+ // To get the appropriate files, we'll simply glob the directory and filter
+ // out any "files" that are not truly files so we do not end up with any
+ // directories in our list, but only true files within the directory.
+ return array_filter($glob, function ($file) {
+ return filetype($file) == 'file';
+ });
+ }
+
+ /**
+ * Get all of the files from the given directory (recursive).
+ *
+ * @param string $directory
+ * @param bool $hidden
+ * @return array
+ */
+ public function allFiles($directory, $hidden = false)
+ {
+ return iterator_to_array(Finder::create()->files()->ignoreDotFiles(! $hidden)->in($directory), false);
+ }
+
+ /**
+ * Get all of the directories within a given directory.
+ *
+ * @param string $directory
+ * @return array
+ */
+ public function directories($directory)
+ {
+ $directories = [];
+
+ foreach (Finder::create()->in($directory)->directories()->depth(0) as $dir) {
+ $directories[] = $dir->getPathname();
+ }
+
+ return $directories;
+ }
+
+ /**
+ * Create a directory.
+ *
+ * @param string $path
+ * @param int $mode
+ * @param bool $recursive
+ * @param bool $force
+ * @return bool
+ */
+ public function makeDirectory($path, $mode = 0755, $recursive = false, $force = false)
+ {
+ if ($force) {
+ return @mkdir($path, $mode, $recursive);
+ }
+
+ return mkdir($path, $mode, $recursive);
+ }
+
+ /**
+ * Move a directory.
+ *
+ * @param string $from
+ * @param string $to
+ * @param bool $overwrite
+ * @return bool
+ */
+ public function moveDirectory($from, $to, $overwrite = false)
+ {
+ if ($overwrite && $this->isDirectory($to)) {
+ if (! $this->deleteDirectory($to)) {
+ return false;
+ }
+ }
+
+ return @rename($from, $to) === true;
+ }
+
+ /**
+ * Copy a directory from one location to another.
+ *
+ * @param string $directory
+ * @param string $destination
+ * @param int $options
+ * @return bool
+ */
+ public function copyDirectory($directory, $destination, $options = null)
+ {
+ if (! $this->isDirectory($directory)) {
+ return false;
+ }
+
+ $options = $options ?: FilesystemIterator::SKIP_DOTS;
+
+ // If the destination directory does not actually exist, we will go ahead and
+ // create it recursively, which just gets the destination prepared to copy
+ // the files over. Once we make the directory we'll proceed the copying.
+ if (! $this->isDirectory($destination)) {
+ $this->makeDirectory($destination, 0777, true);
+ }
+
+ $items = new FilesystemIterator($directory, $options);
+
+ foreach ($items as $item) {
+ // As we spin through items, we will check to see if the current file is actually
+ // a directory or a file. When it is actually a directory we will need to call
+ // back into this function recursively to keep copying these nested folders.
+ $target = $destination.'/'.$item->getBasename();
+
+ if ($item->isDir()) {
+ $path = $item->getPathname();
+
+ if (! $this->copyDirectory($path, $target, $options)) {
+ return false;
+ }
+ }
+
+ // If the current items is just a regular file, we will just copy this to the new
+ // location and keep looping. If for some reason the copy fails we'll bail out
+ // and return false, so the developer is aware that the copy process failed.
+ else {
+ if (! $this->copy($item->getPathname(), $target)) {
+ return false;
+ }
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Recursively delete a directory.
+ *
+ * The directory itself may be optionally preserved.
+ *
+ * @param string $directory
+ * @param bool $preserve
+ * @return bool
+ */
+ public function deleteDirectory($directory, $preserve = false)
+ {
+ if (! $this->isDirectory($directory)) {
+ return false;
+ }
+
+ $items = new FilesystemIterator($directory);
+
+ foreach ($items as $item) {
+ // If the item is a directory, we can just recurse into the function and
+ // delete that sub-directory otherwise we'll just delete the file and
+ // keep iterating through each file until the directory is cleaned.
+ if ($item->isDir() && ! $item->isLink()) {
+ $this->deleteDirectory($item->getPathname());
+ }
+
+ // If the item is just a file, we can go ahead and delete it since we're
+ // just looping through and waxing all of the files in this directory
+ // and calling directories recursively, so we delete the real path.
+ else {
+ $this->delete($item->getPathname());
+ }
+ }
+
+ if (! $preserve) {
+ @rmdir($directory);
+ }
+
+ return true;
+ }
+
+ /**
+ * Empty the specified directory of all files and folders.
+ *
+ * @param string $directory
+ * @return bool
+ */
+ public function cleanDirectory($directory)
+ {
+ return $this->deleteDirectory($directory, true);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php b/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php
new file mode 100644
index 000000000..410b02e20
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemAdapter.php
@@ -0,0 +1,548 @@
+driver = $driver;
+ }
+
+ /**
+ * Assert that the given file exists.
+ *
+ * @param string $path
+ * @return void
+ */
+ public function assertExists($path)
+ {
+ PHPUnit::assertTrue(
+ $this->exists($path), "Unable to find a file at path [{$path}]."
+ );
+ }
+
+ /**
+ * Assert that the given file does not exist.
+ *
+ * @param string $path
+ * @return void
+ */
+ public function assertMissing($path)
+ {
+ PHPUnit::assertFalse(
+ $this->exists($path), "Found unexpected file at path [{$path}]."
+ );
+ }
+
+ /**
+ * Determine if a file exists.
+ *
+ * @param string $path
+ * @return bool
+ */
+ public function exists($path)
+ {
+ return $this->driver->has($path);
+ }
+
+ /**
+ * Get the full path for the file at the given "short" path.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function path($path)
+ {
+ return $this->driver->getAdapter()->getPathPrefix().$path;
+ }
+
+ /**
+ * Get the contents of a file.
+ *
+ * @param string $path
+ * @return string
+ *
+ * @throws \Illuminate\Contracts\Filesystem\FileNotFoundException
+ */
+ public function get($path)
+ {
+ try {
+ return $this->driver->read($path);
+ } catch (FileNotFoundException $e) {
+ throw new ContractFileNotFoundException($path, $e->getCode(), $e);
+ }
+ }
+
+ /**
+ * Write the contents of a file.
+ *
+ * @param string $path
+ * @param string|resource $contents
+ * @param array $options
+ * @return bool
+ */
+ public function put($path, $contents, $options = [])
+ {
+ if (is_string($options)) {
+ $options = ['visibility' => $options];
+ }
+
+ // If the given contents is actually a file or uploaded file instance than we will
+ // automatically store the file using a stream. This provides a convenient path
+ // for the developer to store streams without managing them manually in code.
+ if ($contents instanceof File ||
+ $contents instanceof UploadedFile) {
+ return $this->putFile($path, $contents, $options);
+ }
+
+ return is_resource($contents)
+ ? $this->driver->putStream($path, $contents, $options)
+ : $this->driver->put($path, $contents, $options);
+ }
+
+ /**
+ * Store the uploaded file on the disk.
+ *
+ * @param string $path
+ * @param \Illuminate\Http\File|\Illuminate\Http\UploadedFile $file
+ * @param array $options
+ * @return string|false
+ */
+ public function putFile($path, $file, $options = [])
+ {
+ return $this->putFileAs($path, $file, $file->hashName(), $options);
+ }
+
+ /**
+ * Store the uploaded file on the disk with a given name.
+ *
+ * @param string $path
+ * @param \Illuminate\Http\File|\Illuminate\Http\UploadedFile $file
+ * @param string $name
+ * @param array $options
+ * @return string|false
+ */
+ public function putFileAs($path, $file, $name, $options = [])
+ {
+ $stream = fopen($file->getRealPath(), 'r+');
+
+ // Next, we will format the path of the file and store the file using a stream since
+ // they provide better performance than alternatives. Once we write the file this
+ // stream will get closed automatically by us so the developer doesn't have to.
+ $result = $this->put(
+ $path = trim($path.'/'.$name, '/'), $stream, $options
+ );
+
+ if (is_resource($stream)) {
+ fclose($stream);
+ }
+
+ return $result ? $path : false;
+ }
+
+ /**
+ * Get the visibility for the given path.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function getVisibility($path)
+ {
+ if ($this->driver->getVisibility($path) == AdapterInterface::VISIBILITY_PUBLIC) {
+ return FilesystemContract::VISIBILITY_PUBLIC;
+ }
+
+ return FilesystemContract::VISIBILITY_PRIVATE;
+ }
+
+ /**
+ * Set the visibility for the given path.
+ *
+ * @param string $path
+ * @param string $visibility
+ * @return void
+ */
+ public function setVisibility($path, $visibility)
+ {
+ return $this->driver->setVisibility($path, $this->parseVisibility($visibility));
+ }
+
+ /**
+ * Prepend to a file.
+ *
+ * @param string $path
+ * @param string $data
+ * @param string $separator
+ * @return int
+ */
+ public function prepend($path, $data, $separator = PHP_EOL)
+ {
+ if ($this->exists($path)) {
+ return $this->put($path, $data.$separator.$this->get($path));
+ }
+
+ return $this->put($path, $data);
+ }
+
+ /**
+ * Append to a file.
+ *
+ * @param string $path
+ * @param string $data
+ * @param string $separator
+ * @return int
+ */
+ public function append($path, $data, $separator = PHP_EOL)
+ {
+ if ($this->exists($path)) {
+ return $this->put($path, $this->get($path).$separator.$data);
+ }
+
+ return $this->put($path, $data);
+ }
+
+ /**
+ * Delete the file at a given path.
+ *
+ * @param string|array $paths
+ * @return bool
+ */
+ public function delete($paths)
+ {
+ $paths = is_array($paths) ? $paths : func_get_args();
+
+ $success = true;
+
+ foreach ($paths as $path) {
+ try {
+ if (! $this->driver->delete($path)) {
+ $success = false;
+ }
+ } catch (FileNotFoundException $e) {
+ $success = false;
+ }
+ }
+
+ return $success;
+ }
+
+ /**
+ * Copy a file to a new location.
+ *
+ * @param string $from
+ * @param string $to
+ * @return bool
+ */
+ public function copy($from, $to)
+ {
+ return $this->driver->copy($from, $to);
+ }
+
+ /**
+ * Move a file to a new location.
+ *
+ * @param string $from
+ * @param string $to
+ * @return bool
+ */
+ public function move($from, $to)
+ {
+ return $this->driver->rename($from, $to);
+ }
+
+ /**
+ * Get the file size of a given file.
+ *
+ * @param string $path
+ * @return int
+ */
+ public function size($path)
+ {
+ return $this->driver->getSize($path);
+ }
+
+ /**
+ * Get the mime-type of a given file.
+ *
+ * @param string $path
+ * @return string|false
+ */
+ public function mimeType($path)
+ {
+ return $this->driver->getMimetype($path);
+ }
+
+ /**
+ * Get the file's last modification time.
+ *
+ * @param string $path
+ * @return int
+ */
+ public function lastModified($path)
+ {
+ return $this->driver->getTimestamp($path);
+ }
+
+ /**
+ * Get the URL for the file at the given path.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function url($path)
+ {
+ $adapter = $this->driver->getAdapter();
+
+ if (method_exists($adapter, 'getUrl')) {
+ return $adapter->getUrl($path);
+ } elseif ($adapter instanceof AwsS3Adapter) {
+ return $this->getAwsUrl($adapter, $path);
+ } elseif ($adapter instanceof LocalAdapter) {
+ return $this->getLocalUrl($path);
+ } else {
+ throw new RuntimeException('This driver does not support retrieving URLs.');
+ }
+ }
+
+ /**
+ * Get the URL for the file at the given path.
+ *
+ * @param \League\Flysystem\AwsS3v3\AwsS3Adapter $adapter
+ * @param string $path
+ * @return string
+ */
+ protected function getAwsUrl($adapter, $path)
+ {
+ return $adapter->getClient()->getObjectUrl(
+ $adapter->getBucket(), $adapter->getPathPrefix().$path
+ );
+ }
+
+ /**
+ * Get the URL for the file at the given path.
+ *
+ * @param string $path
+ * @return string
+ */
+ protected function getLocalUrl($path)
+ {
+ $config = $this->driver->getConfig();
+
+ // If an explicit base URL has been set on the disk configuration then we will use
+ // it as the base URL instead of the default path. This allows the developer to
+ // have full control over the base path for this filesystem's generated URLs.
+ if ($config->has('url')) {
+ return rtrim($config->get('url'), '/').'/'.ltrim($path, '/');
+ }
+
+ $path = '/storage/'.$path;
+
+ // If the path contains "storage/public", it probably means the developer is using
+ // the default disk to generate the path instead of the "public" disk like they
+ // are really supposed to use. We will remove the public from this path here.
+ if (Str::contains($path, '/storage/public/')) {
+ return Str::replaceFirst('/public/', '/', $path);
+ } else {
+ return $path;
+ }
+ }
+
+ /**
+ * Get a temporary URL for the file at the given path.
+ *
+ * @param string $path
+ * @param \DateTimeInterface $expiration
+ * @param array $options
+ * @return string
+ */
+ public function temporaryUrl($path, $expiration, array $options = [])
+ {
+ $adapter = $this->driver->getAdapter();
+
+ if (method_exists($adapter, 'getTemporaryUrl')) {
+ return $adapter->getTemporaryUrl($path, $expiration, $options);
+ } elseif (! $adapter instanceof AwsS3Adapter) {
+ throw new RuntimeException('This driver does not support creating temporary URLs.');
+ }
+
+ $client = $adapter->getClient();
+
+ $command = $client->getCommand('GetObject', array_merge([
+ 'Bucket' => $adapter->getBucket(),
+ 'Key' => $adapter->getPathPrefix().$path,
+ ], $options));
+
+ return (string) $client->createPresignedRequest(
+ $command, $expiration
+ )->getUri();
+ }
+
+ /**
+ * Get an array of all files in a directory.
+ *
+ * @param string|null $directory
+ * @param bool $recursive
+ * @return array
+ */
+ public function files($directory = null, $recursive = false)
+ {
+ $contents = $this->driver->listContents($directory, $recursive);
+
+ return $this->filterContentsByType($contents, 'file');
+ }
+
+ /**
+ * Get all of the files from the given directory (recursive).
+ *
+ * @param string|null $directory
+ * @return array
+ */
+ public function allFiles($directory = null)
+ {
+ return $this->files($directory, true);
+ }
+
+ /**
+ * Get all of the directories within a given directory.
+ *
+ * @param string|null $directory
+ * @param bool $recursive
+ * @return array
+ */
+ public function directories($directory = null, $recursive = false)
+ {
+ $contents = $this->driver->listContents($directory, $recursive);
+
+ return $this->filterContentsByType($contents, 'dir');
+ }
+
+ /**
+ * Get all (recursive) of the directories within a given directory.
+ *
+ * @param string|null $directory
+ * @return array
+ */
+ public function allDirectories($directory = null)
+ {
+ return $this->directories($directory, true);
+ }
+
+ /**
+ * Create a directory.
+ *
+ * @param string $path
+ * @return bool
+ */
+ public function makeDirectory($path)
+ {
+ return $this->driver->createDir($path);
+ }
+
+ /**
+ * Recursively delete a directory.
+ *
+ * @param string $directory
+ * @return bool
+ */
+ public function deleteDirectory($directory)
+ {
+ return $this->driver->deleteDir($directory);
+ }
+
+ /**
+ * Get the Flysystem driver.
+ *
+ * @return \League\Flysystem\FilesystemInterface
+ */
+ public function getDriver()
+ {
+ return $this->driver;
+ }
+
+ /**
+ * Filter directory contents by type.
+ *
+ * @param array $contents
+ * @param string $type
+ * @return array
+ */
+ protected function filterContentsByType($contents, $type)
+ {
+ return Collection::make($contents)
+ ->where('type', $type)
+ ->pluck('path')
+ ->values()
+ ->all();
+ }
+
+ /**
+ * Parse the given visibility value.
+ *
+ * @param string|null $visibility
+ * @return string|null
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function parseVisibility($visibility)
+ {
+ if (is_null($visibility)) {
+ return;
+ }
+
+ switch ($visibility) {
+ case FilesystemContract::VISIBILITY_PUBLIC:
+ return AdapterInterface::VISIBILITY_PUBLIC;
+ case FilesystemContract::VISIBILITY_PRIVATE:
+ return AdapterInterface::VISIBILITY_PRIVATE;
+ }
+
+ throw new InvalidArgumentException('Unknown visibility: '.$visibility);
+ }
+
+ /**
+ * Pass dynamic methods call onto Flysystem.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ *
+ * @throws \BadMethodCallException
+ */
+ public function __call($method, array $parameters)
+ {
+ return call_user_func_array([$this->driver, $method], $parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemManager.php b/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemManager.php
new file mode 100644
index 000000000..9979bfdfe
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemManager.php
@@ -0,0 +1,345 @@
+app = $app;
+ }
+
+ /**
+ * Get a filesystem instance.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Filesystem\Filesystem
+ */
+ public function drive($name = null)
+ {
+ return $this->disk($name);
+ }
+
+ /**
+ * Get a filesystem instance.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Filesystem\Filesystem
+ */
+ public function disk($name = null)
+ {
+ $name = $name ?: $this->getDefaultDriver();
+
+ return $this->disks[$name] = $this->get($name);
+ }
+
+ /**
+ * Get a default cloud filesystem instance.
+ *
+ * @return \Illuminate\Contracts\Filesystem\Filesystem
+ */
+ public function cloud()
+ {
+ $name = $this->getDefaultCloudDriver();
+
+ return $this->disks[$name] = $this->get($name);
+ }
+
+ /**
+ * Attempt to get the disk from the local cache.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Filesystem\Filesystem
+ */
+ protected function get($name)
+ {
+ return isset($this->disks[$name]) ? $this->disks[$name] : $this->resolve($name);
+ }
+
+ /**
+ * Resolve the given disk.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Filesystem\Filesystem
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function resolve($name)
+ {
+ $config = $this->getConfig($name);
+
+ if (isset($this->customCreators[$config['driver']])) {
+ return $this->callCustomCreator($config);
+ }
+
+ $driverMethod = 'create'.ucfirst($config['driver']).'Driver';
+
+ if (method_exists($this, $driverMethod)) {
+ return $this->{$driverMethod}($config);
+ } else {
+ throw new InvalidArgumentException("Driver [{$config['driver']}] is not supported.");
+ }
+ }
+
+ /**
+ * Call a custom driver creator.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Filesystem\Filesystem
+ */
+ protected function callCustomCreator(array $config)
+ {
+ $driver = $this->customCreators[$config['driver']]($this->app, $config);
+
+ if ($driver instanceof FilesystemInterface) {
+ return $this->adapt($driver);
+ }
+
+ return $driver;
+ }
+
+ /**
+ * Create an instance of the local driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Filesystem\Filesystem
+ */
+ public function createLocalDriver(array $config)
+ {
+ $permissions = isset($config['permissions']) ? $config['permissions'] : [];
+
+ $links = Arr::get($config, 'links') === 'skip'
+ ? LocalAdapter::SKIP_LINKS
+ : LocalAdapter::DISALLOW_LINKS;
+
+ return $this->adapt($this->createFlysystem(new LocalAdapter(
+ $config['root'], LOCK_EX, $links, $permissions
+ ), $config));
+ }
+
+ /**
+ * Create an instance of the ftp driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Filesystem\Filesystem
+ */
+ public function createFtpDriver(array $config)
+ {
+ $ftpConfig = Arr::only($config, [
+ 'host', 'username', 'password', 'port', 'root', 'passive', 'ssl', 'timeout',
+ ]);
+
+ return $this->adapt($this->createFlysystem(
+ new FtpAdapter($ftpConfig), $config
+ ));
+ }
+
+ /**
+ * Create an instance of the Amazon S3 driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Filesystem\Cloud
+ */
+ public function createS3Driver(array $config)
+ {
+ $s3Config = $this->formatS3Config($config);
+
+ $root = isset($s3Config['root']) ? $s3Config['root'] : null;
+
+ $options = isset($config['options']) ? $config['options'] : [];
+
+ return $this->adapt($this->createFlysystem(
+ new S3Adapter(new S3Client($s3Config), $s3Config['bucket'], $root, $options), $config
+ ));
+ }
+
+ /**
+ * Format the given S3 configuration with the default options.
+ *
+ * @param array $config
+ * @return array
+ */
+ protected function formatS3Config(array $config)
+ {
+ $config += ['version' => 'latest'];
+
+ if ($config['key'] && $config['secret']) {
+ $config['credentials'] = Arr::only($config, ['key', 'secret']);
+ }
+
+ return $config;
+ }
+
+ /**
+ * Create an instance of the Rackspace driver.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Filesystem\Cloud
+ */
+ public function createRackspaceDriver(array $config)
+ {
+ $client = new Rackspace($config['endpoint'], [
+ 'username' => $config['username'], 'apiKey' => $config['key'],
+ ]);
+
+ $root = isset($config['root']) ? $config['root'] : null;
+
+ return $this->adapt($this->createFlysystem(
+ new RackspaceAdapter($this->getRackspaceContainer($client, $config), $root), $config
+ ));
+ }
+
+ /**
+ * Get the Rackspace Cloud Files container.
+ *
+ * @param \OpenCloud\Rackspace $client
+ * @param array $config
+ * @return \OpenCloud\ObjectStore\Resource\Container
+ */
+ protected function getRackspaceContainer(Rackspace $client, array $config)
+ {
+ $urlType = Arr::get($config, 'url_type');
+
+ $store = $client->objectStoreService('cloudFiles', $config['region'], $urlType);
+
+ return $store->getContainer($config['container']);
+ }
+
+ /**
+ * Create a Flysystem instance with the given adapter.
+ *
+ * @param \League\Flysystem\AdapterInterface $adapter
+ * @param array $config
+ * @return \League\Flysystem\FlysystemInterface
+ */
+ protected function createFlysystem(AdapterInterface $adapter, array $config)
+ {
+ $config = Arr::only($config, ['visibility', 'disable_asserts', 'url']);
+
+ return new Flysystem($adapter, count($config) > 0 ? $config : null);
+ }
+
+ /**
+ * Adapt the filesystem implementation.
+ *
+ * @param \League\Flysystem\FilesystemInterface $filesystem
+ * @return \Illuminate\Contracts\Filesystem\Filesystem
+ */
+ protected function adapt(FilesystemInterface $filesystem)
+ {
+ return new FilesystemAdapter($filesystem);
+ }
+
+ /**
+ * Set the given disk instance.
+ *
+ * @param string $name
+ * @param mixed $disk
+ * @return void
+ */
+ public function set($name, $disk)
+ {
+ $this->disks[$name] = $disk;
+ }
+
+ /**
+ * Get the filesystem connection configuration.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function getConfig($name)
+ {
+ return $this->app['config']["filesystems.disks.{$name}"];
+ }
+
+ /**
+ * Get the default driver name.
+ *
+ * @return string
+ */
+ public function getDefaultDriver()
+ {
+ return $this->app['config']['filesystems.default'];
+ }
+
+ /**
+ * Get the default cloud driver name.
+ *
+ * @return string
+ */
+ public function getDefaultCloudDriver()
+ {
+ return $this->app['config']['filesystems.cloud'];
+ }
+
+ /**
+ * Register a custom driver creator Closure.
+ *
+ * @param string $driver
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function extend($driver, Closure $callback)
+ {
+ $this->customCreators[$driver] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Dynamically call the default driver instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->disk()->$method(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemServiceProvider.php
new file mode 100644
index 000000000..693227056
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemServiceProvider.php
@@ -0,0 +1,82 @@
+registerNativeFilesystem();
+
+ $this->registerFlysystem();
+ }
+
+ /**
+ * Register the native filesystem implementation.
+ *
+ * @return void
+ */
+ protected function registerNativeFilesystem()
+ {
+ $this->app->singleton('files', function () {
+ return new Filesystem;
+ });
+ }
+
+ /**
+ * Register the driver based filesystem.
+ *
+ * @return void
+ */
+ protected function registerFlysystem()
+ {
+ $this->registerManager();
+
+ $this->app->singleton('filesystem.disk', function () {
+ return $this->app['filesystem']->disk($this->getDefaultDriver());
+ });
+
+ $this->app->singleton('filesystem.cloud', function () {
+ return $this->app['filesystem']->disk($this->getCloudDriver());
+ });
+ }
+
+ /**
+ * Register the filesystem manager.
+ *
+ * @return void
+ */
+ protected function registerManager()
+ {
+ $this->app->singleton('filesystem', function () {
+ return new FilesystemManager($this->app);
+ });
+ }
+
+ /**
+ * Get the default file driver.
+ *
+ * @return string
+ */
+ protected function getDefaultDriver()
+ {
+ return $this->app['config']['filesystems.default'];
+ }
+
+ /**
+ * Get the default cloud based file driver.
+ *
+ * @return string
+ */
+ protected function getCloudDriver()
+ {
+ return $this->app['config']['filesystems.cloud'];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Filesystem/composer.json b/vendor/laravel/framework/src/Illuminate/Filesystem/composer.json
new file mode 100644
index 000000000..2dc0f7a39
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Filesystem/composer.json
@@ -0,0 +1,41 @@
+{
+ "name": "illuminate/filesystem",
+ "description": "The Illuminate Filesystem package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "symfony/finder": "~3.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Filesystem\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "league/flysystem": "Required to use the Flysystem local and FTP drivers (~1.0).",
+ "league/flysystem-aws-s3-v3": "Required to use the Flysystem S3 driver (~1.0).",
+ "league/flysystem-rackspace": "Required to use the Flysystem Rackspace driver (~1.0)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/AliasLoader.php b/vendor/laravel/framework/src/Illuminate/Foundation/AliasLoader.php
new file mode 100644
index 000000000..4d9e68483
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/AliasLoader.php
@@ -0,0 +1,242 @@
+aliases = $aliases;
+ }
+
+ /**
+ * Get or create the singleton alias loader instance.
+ *
+ * @param array $aliases
+ * @return \Illuminate\Foundation\AliasLoader
+ */
+ public static function getInstance(array $aliases = [])
+ {
+ if (is_null(static::$instance)) {
+ return static::$instance = new static($aliases);
+ }
+
+ $aliases = array_merge(static::$instance->getAliases(), $aliases);
+
+ static::$instance->setAliases($aliases);
+
+ return static::$instance;
+ }
+
+ /**
+ * Load a class alias if it is registered.
+ *
+ * @param string $alias
+ * @return bool|null
+ */
+ public function load($alias)
+ {
+ if (static::$facadeNamespace && strpos($alias, static::$facadeNamespace) === 0) {
+ $this->loadFacade($alias);
+
+ return true;
+ }
+
+ if (isset($this->aliases[$alias])) {
+ return class_alias($this->aliases[$alias], $alias);
+ }
+ }
+
+ /**
+ * Load a real-time facade for the given alias.
+ *
+ * @param string $alias
+ * @return void
+ */
+ protected function loadFacade($alias)
+ {
+ require $this->ensureFacadeExists($alias);
+ }
+
+ /**
+ * Ensure that the given alias has an existing real-time facade class.
+ *
+ * @param string $alias
+ * @return string
+ */
+ protected function ensureFacadeExists($alias)
+ {
+ if (file_exists($path = storage_path('framework/cache/facade-'.sha1($alias).'.php'))) {
+ return $path;
+ }
+
+ file_put_contents($path, $this->formatFacadeStub(
+ $alias, file_get_contents(__DIR__.'/stubs/facade.stub')
+ ));
+
+ return $path;
+ }
+
+ /**
+ * Format the facade stub with the proper namespace and class.
+ *
+ * @param string $alias
+ * @param string $stub
+ * @return string
+ */
+ protected function formatFacadeStub($alias, $stub)
+ {
+ $replacements = [
+ str_replace('/', '\\', dirname(str_replace('\\', '/', $alias))),
+ class_basename($alias),
+ substr($alias, strlen(static::$facadeNamespace)),
+ ];
+
+ return str_replace(
+ ['DummyNamespace', 'DummyClass', 'DummyTarget'], $replacements, $stub
+ );
+ }
+
+ /**
+ * Add an alias to the loader.
+ *
+ * @param string $class
+ * @param string $alias
+ * @return void
+ */
+ public function alias($class, $alias)
+ {
+ $this->aliases[$class] = $alias;
+ }
+
+ /**
+ * Register the loader on the auto-loader stack.
+ *
+ * @return void
+ */
+ public function register()
+ {
+ if (! $this->registered) {
+ $this->prependToLoaderStack();
+
+ $this->registered = true;
+ }
+ }
+
+ /**
+ * Prepend the load method to the auto-loader stack.
+ *
+ * @return void
+ */
+ protected function prependToLoaderStack()
+ {
+ spl_autoload_register([$this, 'load'], true, true);
+ }
+
+ /**
+ * Get the registered aliases.
+ *
+ * @return array
+ */
+ public function getAliases()
+ {
+ return $this->aliases;
+ }
+
+ /**
+ * Set the registered aliases.
+ *
+ * @param array $aliases
+ * @return void
+ */
+ public function setAliases(array $aliases)
+ {
+ $this->aliases = $aliases;
+ }
+
+ /**
+ * Indicates if the loader has been registered.
+ *
+ * @return bool
+ */
+ public function isRegistered()
+ {
+ return $this->registered;
+ }
+
+ /**
+ * Set the "registered" state of the loader.
+ *
+ * @param bool $value
+ * @return void
+ */
+ public function setRegistered($value)
+ {
+ $this->registered = $value;
+ }
+
+ /**
+ * Set the real-time facade namespace.
+ *
+ * @param string $namespace
+ * @return void
+ */
+ public static function setFacadeNamespace($namespace)
+ {
+ static::$facadeNamespace = rtrim($namespace, '\\').'\\';
+ }
+
+ /**
+ * Set the value of the singleton alias loader.
+ *
+ * @param \Illuminate\Foundation\AliasLoader $loader
+ * @return void
+ */
+ public static function setInstance($loader)
+ {
+ static::$instance = $loader;
+ }
+
+ /**
+ * Clone method.
+ *
+ * @return void
+ */
+ private function __clone()
+ {
+ //
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Application.php b/vendor/laravel/framework/src/Illuminate/Foundation/Application.php
new file mode 100644
index 000000000..bf3f53edf
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Application.php
@@ -0,0 +1,1173 @@
+setBasePath($basePath);
+ }
+
+ $this->registerBaseBindings();
+
+ $this->registerBaseServiceProviders();
+
+ $this->registerCoreContainerAliases();
+ }
+
+ /**
+ * Get the version number of the application.
+ *
+ * @return string
+ */
+ public function version()
+ {
+ return static::VERSION;
+ }
+
+ /**
+ * Register the basic bindings into the container.
+ *
+ * @return void
+ */
+ protected function registerBaseBindings()
+ {
+ static::setInstance($this);
+
+ $this->instance('app', $this);
+
+ $this->instance(Container::class, $this);
+ }
+
+ /**
+ * Register all of the base service providers.
+ *
+ * @return void
+ */
+ protected function registerBaseServiceProviders()
+ {
+ $this->register(new EventServiceProvider($this));
+
+ $this->register(new LogServiceProvider($this));
+
+ $this->register(new RoutingServiceProvider($this));
+ }
+
+ /**
+ * Run the given array of bootstrap classes.
+ *
+ * @param array $bootstrappers
+ * @return void
+ */
+ public function bootstrapWith(array $bootstrappers)
+ {
+ $this->hasBeenBootstrapped = true;
+
+ foreach ($bootstrappers as $bootstrapper) {
+ $this['events']->fire('bootstrapping: '.$bootstrapper, [$this]);
+
+ $this->make($bootstrapper)->bootstrap($this);
+
+ $this['events']->fire('bootstrapped: '.$bootstrapper, [$this]);
+ }
+ }
+
+ /**
+ * Register a callback to run after loading the environment.
+ *
+ * @param \Closure $callback
+ * @return void
+ */
+ public function afterLoadingEnvironment(Closure $callback)
+ {
+ return $this->afterBootstrapping(
+ LoadEnvironmentVariables::class, $callback
+ );
+ }
+
+ /**
+ * Register a callback to run before a bootstrapper.
+ *
+ * @param string $bootstrapper
+ * @param Closure $callback
+ * @return void
+ */
+ public function beforeBootstrapping($bootstrapper, Closure $callback)
+ {
+ $this['events']->listen('bootstrapping: '.$bootstrapper, $callback);
+ }
+
+ /**
+ * Register a callback to run after a bootstrapper.
+ *
+ * @param string $bootstrapper
+ * @param Closure $callback
+ * @return void
+ */
+ public function afterBootstrapping($bootstrapper, Closure $callback)
+ {
+ $this['events']->listen('bootstrapped: '.$bootstrapper, $callback);
+ }
+
+ /**
+ * Determine if the application has been bootstrapped before.
+ *
+ * @return bool
+ */
+ public function hasBeenBootstrapped()
+ {
+ return $this->hasBeenBootstrapped;
+ }
+
+ /**
+ * Set the base path for the application.
+ *
+ * @param string $basePath
+ * @return $this
+ */
+ public function setBasePath($basePath)
+ {
+ $this->basePath = rtrim($basePath, '\/');
+
+ $this->bindPathsInContainer();
+
+ return $this;
+ }
+
+ /**
+ * Bind all of the application paths in the container.
+ *
+ * @return void
+ */
+ protected function bindPathsInContainer()
+ {
+ $this->instance('path', $this->path());
+ $this->instance('path.base', $this->basePath());
+ $this->instance('path.lang', $this->langPath());
+ $this->instance('path.config', $this->configPath());
+ $this->instance('path.public', $this->publicPath());
+ $this->instance('path.storage', $this->storagePath());
+ $this->instance('path.database', $this->databasePath());
+ $this->instance('path.resources', $this->resourcePath());
+ $this->instance('path.bootstrap', $this->bootstrapPath());
+ }
+
+ /**
+ * Get the path to the application "app" directory.
+ *
+ * @param string $path Optionally, a path to append to the app path
+ * @return string
+ */
+ public function path($path = '')
+ {
+ return $this->basePath.DIRECTORY_SEPARATOR.'app'.($path ? DIRECTORY_SEPARATOR.$path : $path);
+ }
+
+ /**
+ * Get the base path of the Laravel installation.
+ *
+ * @param string $path Optionally, a path to append to the base path
+ * @return string
+ */
+ public function basePath($path = '')
+ {
+ return $this->basePath.($path ? DIRECTORY_SEPARATOR.$path : $path);
+ }
+
+ /**
+ * Get the path to the bootstrap directory.
+ *
+ * @param string $path Optionally, a path to append to the bootstrap path
+ * @return string
+ */
+ public function bootstrapPath($path = '')
+ {
+ return $this->basePath.DIRECTORY_SEPARATOR.'bootstrap'.($path ? DIRECTORY_SEPARATOR.$path : $path);
+ }
+
+ /**
+ * Get the path to the application configuration files.
+ *
+ * @param string $path Optionally, a path to append to the config path
+ * @return string
+ */
+ public function configPath($path = '')
+ {
+ return $this->basePath.DIRECTORY_SEPARATOR.'config'.($path ? DIRECTORY_SEPARATOR.$path : $path);
+ }
+
+ /**
+ * Get the path to the database directory.
+ *
+ * @param string $path Optionally, a path to append to the database path
+ * @return string
+ */
+ public function databasePath($path = '')
+ {
+ return ($this->databasePath ?: $this->basePath.DIRECTORY_SEPARATOR.'database').($path ? DIRECTORY_SEPARATOR.$path : $path);
+ }
+
+ /**
+ * Set the database directory.
+ *
+ * @param string $path
+ * @return $this
+ */
+ public function useDatabasePath($path)
+ {
+ $this->databasePath = $path;
+
+ $this->instance('path.database', $path);
+
+ return $this;
+ }
+
+ /**
+ * Get the path to the language files.
+ *
+ * @return string
+ */
+ public function langPath()
+ {
+ return $this->resourcePath().DIRECTORY_SEPARATOR.'lang';
+ }
+
+ /**
+ * Get the path to the public / web directory.
+ *
+ * @return string
+ */
+ public function publicPath()
+ {
+ return $this->basePath.DIRECTORY_SEPARATOR.'public';
+ }
+
+ /**
+ * Get the path to the storage directory.
+ *
+ * @return string
+ */
+ public function storagePath()
+ {
+ return $this->storagePath ?: $this->basePath.DIRECTORY_SEPARATOR.'storage';
+ }
+
+ /**
+ * Set the storage directory.
+ *
+ * @param string $path
+ * @return $this
+ */
+ public function useStoragePath($path)
+ {
+ $this->storagePath = $path;
+
+ $this->instance('path.storage', $path);
+
+ return $this;
+ }
+
+ /**
+ * Get the path to the resources directory.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function resourcePath($path = '')
+ {
+ return $this->basePath.DIRECTORY_SEPARATOR.'resources'.($path ? DIRECTORY_SEPARATOR.$path : $path);
+ }
+
+ /**
+ * Get the path to the environment file directory.
+ *
+ * @return string
+ */
+ public function environmentPath()
+ {
+ return $this->environmentPath ?: $this->basePath;
+ }
+
+ /**
+ * Set the directory for the environment file.
+ *
+ * @param string $path
+ * @return $this
+ */
+ public function useEnvironmentPath($path)
+ {
+ $this->environmentPath = $path;
+
+ return $this;
+ }
+
+ /**
+ * Set the environment file to be loaded during bootstrapping.
+ *
+ * @param string $file
+ * @return $this
+ */
+ public function loadEnvironmentFrom($file)
+ {
+ $this->environmentFile = $file;
+
+ return $this;
+ }
+
+ /**
+ * Get the environment file the application is using.
+ *
+ * @return string
+ */
+ public function environmentFile()
+ {
+ return $this->environmentFile ?: '.env';
+ }
+
+ /**
+ * Get the fully qualified path to the environment file.
+ *
+ * @return string
+ */
+ public function environmentFilePath()
+ {
+ return $this->environmentPath().'/'.$this->environmentFile();
+ }
+
+ /**
+ * Get or check the current application environment.
+ *
+ * @return string|bool
+ */
+ public function environment()
+ {
+ if (func_num_args() > 0) {
+ $patterns = is_array(func_get_arg(0)) ? func_get_arg(0) : func_get_args();
+
+ foreach ($patterns as $pattern) {
+ if (Str::is($pattern, $this['env'])) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ return $this['env'];
+ }
+
+ /**
+ * Determine if application is in local environment.
+ *
+ * @return bool
+ */
+ public function isLocal()
+ {
+ return $this['env'] == 'local';
+ }
+
+ /**
+ * Detect the application's current environment.
+ *
+ * @param \Closure $callback
+ * @return string
+ */
+ public function detectEnvironment(Closure $callback)
+ {
+ $args = isset($_SERVER['argv']) ? $_SERVER['argv'] : null;
+
+ return $this['env'] = (new EnvironmentDetector())->detect($callback, $args);
+ }
+
+ /**
+ * Determine if we are running in the console.
+ *
+ * @return bool
+ */
+ public function runningInConsole()
+ {
+ return php_sapi_name() == 'cli' || php_sapi_name() == 'phpdbg';
+ }
+
+ /**
+ * Determine if we are running unit tests.
+ *
+ * @return bool
+ */
+ public function runningUnitTests()
+ {
+ return $this['env'] == 'testing';
+ }
+
+ /**
+ * Register all of the configured providers.
+ *
+ * @return void
+ */
+ public function registerConfiguredProviders()
+ {
+ (new ProviderRepository($this, new Filesystem, $this->getCachedServicesPath()))
+ ->load($this->config['app.providers']);
+ }
+
+ /**
+ * Register a service provider with the application.
+ *
+ * @param \Illuminate\Support\ServiceProvider|string $provider
+ * @param array $options
+ * @param bool $force
+ * @return \Illuminate\Support\ServiceProvider
+ */
+ public function register($provider, $options = [], $force = false)
+ {
+ if (($registered = $this->getProvider($provider)) && ! $force) {
+ return $registered;
+ }
+
+ // If the given "provider" is a string, we will resolve it, passing in the
+ // application instance automatically for the developer. This is simply
+ // a more convenient way of specifying your service provider classes.
+ if (is_string($provider)) {
+ $provider = $this->resolveProvider($provider);
+ }
+
+ if (method_exists($provider, 'register')) {
+ $provider->register();
+ }
+
+ $this->markAsRegistered($provider);
+
+ // If the application has already booted, we will call this boot method on
+ // the provider class so it has an opportunity to do its boot logic and
+ // will be ready for any usage by this developer's application logic.
+ if ($this->booted) {
+ $this->bootProvider($provider);
+ }
+
+ return $provider;
+ }
+
+ /**
+ * Get the registered service provider instance if it exists.
+ *
+ * @param \Illuminate\Support\ServiceProvider|string $provider
+ * @return \Illuminate\Support\ServiceProvider|null
+ */
+ public function getProvider($provider)
+ {
+ $name = is_string($provider) ? $provider : get_class($provider);
+
+ return Arr::first($this->serviceProviders, function ($value) use ($name) {
+ return $value instanceof $name;
+ });
+ }
+
+ /**
+ * Resolve a service provider instance from the class name.
+ *
+ * @param string $provider
+ * @return \Illuminate\Support\ServiceProvider
+ */
+ public function resolveProvider($provider)
+ {
+ return new $provider($this);
+ }
+
+ /**
+ * Mark the given provider as registered.
+ *
+ * @param \Illuminate\Support\ServiceProvider $provider
+ * @return void
+ */
+ protected function markAsRegistered($provider)
+ {
+ $this->serviceProviders[] = $provider;
+
+ $this->loadedProviders[get_class($provider)] = true;
+ }
+
+ /**
+ * Load and boot all of the remaining deferred providers.
+ *
+ * @return void
+ */
+ public function loadDeferredProviders()
+ {
+ // We will simply spin through each of the deferred providers and register each
+ // one and boot them if the application has booted. This should make each of
+ // the remaining services available to this application for immediate use.
+ foreach ($this->deferredServices as $service => $provider) {
+ $this->loadDeferredProvider($service);
+ }
+
+ $this->deferredServices = [];
+ }
+
+ /**
+ * Load the provider for a deferred service.
+ *
+ * @param string $service
+ * @return void
+ */
+ public function loadDeferredProvider($service)
+ {
+ if (! isset($this->deferredServices[$service])) {
+ return;
+ }
+
+ $provider = $this->deferredServices[$service];
+
+ // If the service provider has not already been loaded and registered we can
+ // register it with the application and remove the service from this list
+ // of deferred services, since it will already be loaded on subsequent.
+ if (! isset($this->loadedProviders[$provider])) {
+ $this->registerDeferredProvider($provider, $service);
+ }
+ }
+
+ /**
+ * Register a deferred provider and service.
+ *
+ * @param string $provider
+ * @param string|null $service
+ * @return void
+ */
+ public function registerDeferredProvider($provider, $service = null)
+ {
+ // Once the provider that provides the deferred service has been registered we
+ // will remove it from our local list of the deferred services with related
+ // providers so that this container does not try to resolve it out again.
+ if ($service) {
+ unset($this->deferredServices[$service]);
+ }
+
+ $this->register($instance = new $provider($this));
+
+ if (! $this->booted) {
+ $this->booting(function () use ($instance) {
+ $this->bootProvider($instance);
+ });
+ }
+ }
+
+ /**
+ * Resolve the given type from the container.
+ *
+ * (Overriding Container::makeWith)
+ *
+ * @param string $abstract
+ * @param array $parameters
+ * @return mixed
+ */
+ public function makeWith($abstract, array $parameters)
+ {
+ $abstract = $this->getAlias($abstract);
+
+ if (isset($this->deferredServices[$abstract])) {
+ $this->loadDeferredProvider($abstract);
+ }
+
+ return parent::makeWith($abstract, $parameters);
+ }
+
+ /**
+ * Resolve the given type from the container.
+ *
+ * (Overriding Container::make)
+ *
+ * @param string $abstract
+ * @return mixed
+ */
+ public function make($abstract)
+ {
+ $abstract = $this->getAlias($abstract);
+
+ if (isset($this->deferredServices[$abstract])) {
+ $this->loadDeferredProvider($abstract);
+ }
+
+ return parent::make($abstract);
+ }
+
+ /**
+ * Determine if the given abstract type has been bound.
+ *
+ * (Overriding Container::bound)
+ *
+ * @param string $abstract
+ * @return bool
+ */
+ public function bound($abstract)
+ {
+ return isset($this->deferredServices[$abstract]) || parent::bound($abstract);
+ }
+
+ /**
+ * Determine if the application has booted.
+ *
+ * @return bool
+ */
+ public function isBooted()
+ {
+ return $this->booted;
+ }
+
+ /**
+ * Boot the application's service providers.
+ *
+ * @return void
+ */
+ public function boot()
+ {
+ if ($this->booted) {
+ return;
+ }
+
+ // Once the application has booted we will also fire some "booted" callbacks
+ // for any listeners that need to do work after this initial booting gets
+ // finished. This is useful when ordering the boot-up processes we run.
+ $this->fireAppCallbacks($this->bootingCallbacks);
+
+ array_walk($this->serviceProviders, function ($p) {
+ $this->bootProvider($p);
+ });
+
+ $this->booted = true;
+
+ $this->fireAppCallbacks($this->bootedCallbacks);
+ }
+
+ /**
+ * Boot the given service provider.
+ *
+ * @param \Illuminate\Support\ServiceProvider $provider
+ * @return mixed
+ */
+ protected function bootProvider(ServiceProvider $provider)
+ {
+ if (method_exists($provider, 'boot')) {
+ return $this->call([$provider, 'boot']);
+ }
+ }
+
+ /**
+ * Register a new boot listener.
+ *
+ * @param mixed $callback
+ * @return void
+ */
+ public function booting($callback)
+ {
+ $this->bootingCallbacks[] = $callback;
+ }
+
+ /**
+ * Register a new "booted" listener.
+ *
+ * @param mixed $callback
+ * @return void
+ */
+ public function booted($callback)
+ {
+ $this->bootedCallbacks[] = $callback;
+
+ if ($this->isBooted()) {
+ $this->fireAppCallbacks([$callback]);
+ }
+ }
+
+ /**
+ * Call the booting callbacks for the application.
+ *
+ * @param array $callbacks
+ * @return void
+ */
+ protected function fireAppCallbacks(array $callbacks)
+ {
+ foreach ($callbacks as $callback) {
+ call_user_func($callback, $this);
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handle(SymfonyRequest $request, $type = self::MASTER_REQUEST, $catch = true)
+ {
+ return $this[HttpKernelContract::class]->handle(Request::createFromBase($request));
+ }
+
+ /**
+ * Determine if middleware has been disabled for the application.
+ *
+ * @return bool
+ */
+ public function shouldSkipMiddleware()
+ {
+ return $this->bound('middleware.disable') &&
+ $this->make('middleware.disable') === true;
+ }
+
+ /**
+ * Get the path to the cached services.php file.
+ *
+ * @return string
+ */
+ public function getCachedServicesPath()
+ {
+ return $this->bootstrapPath().'/cache/services.php';
+ }
+
+ /**
+ * Determine if the application configuration is cached.
+ *
+ * @return bool
+ */
+ public function configurationIsCached()
+ {
+ return file_exists($this->getCachedConfigPath());
+ }
+
+ /**
+ * Get the path to the configuration cache file.
+ *
+ * @return string
+ */
+ public function getCachedConfigPath()
+ {
+ return $this->bootstrapPath().'/cache/config.php';
+ }
+
+ /**
+ * Determine if the application routes are cached.
+ *
+ * @return bool
+ */
+ public function routesAreCached()
+ {
+ return $this['files']->exists($this->getCachedRoutesPath());
+ }
+
+ /**
+ * Get the path to the routes cache file.
+ *
+ * @return string
+ */
+ public function getCachedRoutesPath()
+ {
+ return $this->bootstrapPath().'/cache/routes.php';
+ }
+
+ /**
+ * Determine if the application is currently down for maintenance.
+ *
+ * @return bool
+ */
+ public function isDownForMaintenance()
+ {
+ return file_exists($this->storagePath().'/framework/down');
+ }
+
+ /**
+ * Throw an HttpException with the given data.
+ *
+ * @param int $code
+ * @param string $message
+ * @param array $headers
+ * @return void
+ *
+ * @throws \Symfony\Component\HttpKernel\Exception\HttpException
+ */
+ public function abort($code, $message = '', array $headers = [])
+ {
+ if ($code == 404) {
+ throw new NotFoundHttpException($message);
+ }
+
+ throw new HttpException($code, $message, null, $headers);
+ }
+
+ /**
+ * Register a terminating callback with the application.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function terminating(Closure $callback)
+ {
+ $this->terminatingCallbacks[] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Terminate the application.
+ *
+ * @return void
+ */
+ public function terminate()
+ {
+ foreach ($this->terminatingCallbacks as $terminating) {
+ $this->call($terminating);
+ }
+ }
+
+ /**
+ * Get the service providers that have been loaded.
+ *
+ * @return array
+ */
+ public function getLoadedProviders()
+ {
+ return $this->loadedProviders;
+ }
+
+ /**
+ * Get the application's deferred services.
+ *
+ * @return array
+ */
+ public function getDeferredServices()
+ {
+ return $this->deferredServices;
+ }
+
+ /**
+ * Set the application's deferred services.
+ *
+ * @param array $services
+ * @return void
+ */
+ public function setDeferredServices(array $services)
+ {
+ $this->deferredServices = $services;
+ }
+
+ /**
+ * Add an array of services to the application's deferred services.
+ *
+ * @param array $services
+ * @return void
+ */
+ public function addDeferredServices(array $services)
+ {
+ $this->deferredServices = array_merge($this->deferredServices, $services);
+ }
+
+ /**
+ * Determine if the given service is a deferred service.
+ *
+ * @param string $service
+ * @return bool
+ */
+ public function isDeferredService($service)
+ {
+ return isset($this->deferredServices[$service]);
+ }
+
+ /**
+ * Configure the real-time facade namespace.
+ *
+ * @param string $namespace
+ * @return void
+ */
+ public function provideFacades($namespace)
+ {
+ AliasLoader::setFacadeNamespace($namespace);
+ }
+
+ /**
+ * Define a callback to be used to configure Monolog.
+ *
+ * @param callable $callback
+ * @return $this
+ */
+ public function configureMonologUsing(callable $callback)
+ {
+ $this->monologConfigurator = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Determine if the application has a custom Monolog configurator.
+ *
+ * @return bool
+ */
+ public function hasMonologConfigurator()
+ {
+ return ! is_null($this->monologConfigurator);
+ }
+
+ /**
+ * Get the custom Monolog configurator for the application.
+ *
+ * @return callable
+ */
+ public function getMonologConfigurator()
+ {
+ return $this->monologConfigurator;
+ }
+
+ /**
+ * Get the current application locale.
+ *
+ * @return string
+ */
+ public function getLocale()
+ {
+ return $this['config']->get('app.locale');
+ }
+
+ /**
+ * Set the current application locale.
+ *
+ * @param string $locale
+ * @return void
+ */
+ public function setLocale($locale)
+ {
+ $this['config']->set('app.locale', $locale);
+
+ $this['translator']->setLocale($locale);
+
+ $this['events']->dispatch(new Events\LocaleUpdated($locale));
+ }
+
+ /**
+ * Determine if application locale is the given locale.
+ *
+ * @param string $locale
+ * @return bool
+ */
+ public function isLocale($locale)
+ {
+ return $this->getLocale() == $locale;
+ }
+
+ /**
+ * Register the core class aliases in the container.
+ *
+ * @return void
+ */
+ public function registerCoreContainerAliases()
+ {
+ foreach ([
+ 'app' => [\Illuminate\Foundation\Application::class, \Illuminate\Contracts\Container\Container::class, \Illuminate\Contracts\Foundation\Application::class],
+ 'auth' => [\Illuminate\Auth\AuthManager::class, \Illuminate\Contracts\Auth\Factory::class],
+ 'auth.driver' => [\Illuminate\Contracts\Auth\Guard::class],
+ 'blade.compiler' => [\Illuminate\View\Compilers\BladeCompiler::class],
+ 'cache' => [\Illuminate\Cache\CacheManager::class, \Illuminate\Contracts\Cache\Factory::class],
+ 'cache.store' => [\Illuminate\Cache\Repository::class, \Illuminate\Contracts\Cache\Repository::class],
+ 'config' => [\Illuminate\Config\Repository::class, \Illuminate\Contracts\Config\Repository::class],
+ 'cookie' => [\Illuminate\Cookie\CookieJar::class, \Illuminate\Contracts\Cookie\Factory::class, \Illuminate\Contracts\Cookie\QueueingFactory::class],
+ 'encrypter' => [\Illuminate\Encryption\Encrypter::class, \Illuminate\Contracts\Encryption\Encrypter::class],
+ 'db' => [\Illuminate\Database\DatabaseManager::class],
+ 'db.connection' => [\Illuminate\Database\Connection::class, \Illuminate\Database\ConnectionInterface::class],
+ 'events' => [\Illuminate\Events\Dispatcher::class, \Illuminate\Contracts\Events\Dispatcher::class],
+ 'files' => [\Illuminate\Filesystem\Filesystem::class],
+ 'filesystem' => [\Illuminate\Filesystem\FilesystemManager::class, \Illuminate\Contracts\Filesystem\Factory::class],
+ 'filesystem.disk' => [\Illuminate\Contracts\Filesystem\Filesystem::class],
+ 'filesystem.cloud' => [\Illuminate\Contracts\Filesystem\Cloud::class],
+ 'hash' => [\Illuminate\Contracts\Hashing\Hasher::class],
+ 'translator' => [\Illuminate\Translation\Translator::class, \Illuminate\Contracts\Translation\Translator::class],
+ 'log' => [\Illuminate\Log\Writer::class, \Illuminate\Contracts\Logging\Log::class, \Psr\Log\LoggerInterface::class],
+ 'mailer' => [\Illuminate\Mail\Mailer::class, \Illuminate\Contracts\Mail\Mailer::class, \Illuminate\Contracts\Mail\MailQueue::class],
+ 'auth.password' => [\Illuminate\Auth\Passwords\PasswordBrokerManager::class, \Illuminate\Contracts\Auth\PasswordBrokerFactory::class],
+ 'auth.password.broker' => [\Illuminate\Auth\Passwords\PasswordBroker::class, \Illuminate\Contracts\Auth\PasswordBroker::class],
+ 'queue' => [\Illuminate\Queue\QueueManager::class, \Illuminate\Contracts\Queue\Factory::class, \Illuminate\Contracts\Queue\Monitor::class],
+ 'queue.connection' => [\Illuminate\Contracts\Queue\Queue::class],
+ 'queue.failer' => [\Illuminate\Queue\Failed\FailedJobProviderInterface::class],
+ 'redirect' => [\Illuminate\Routing\Redirector::class],
+ 'redis' => [\Illuminate\Redis\RedisManager::class, \Illuminate\Contracts\Redis\Factory::class],
+ 'request' => [\Illuminate\Http\Request::class, \Symfony\Component\HttpFoundation\Request::class],
+ 'router' => [\Illuminate\Routing\Router::class, \Illuminate\Contracts\Routing\Registrar::class, \Illuminate\Contracts\Routing\BindingRegistrar::class],
+ 'session' => [\Illuminate\Session\SessionManager::class],
+ 'session.store' => [\Illuminate\Session\Store::class, \Illuminate\Contracts\Session\Session::class],
+ 'url' => [\Illuminate\Routing\UrlGenerator::class, \Illuminate\Contracts\Routing\UrlGenerator::class],
+ 'validator' => [\Illuminate\Validation\Factory::class, \Illuminate\Contracts\Validation\Factory::class],
+ 'view' => [\Illuminate\View\Factory::class, \Illuminate\Contracts\View\Factory::class],
+ ] as $key => $aliases) {
+ foreach ($aliases as $alias) {
+ $this->alias($key, $alias);
+ }
+ }
+ }
+
+ /**
+ * Flush the container of all bindings and resolved instances.
+ *
+ * @return void
+ */
+ public function flush()
+ {
+ parent::flush();
+
+ $this->loadedProviders = [];
+ }
+
+ /**
+ * Get the application namespace.
+ *
+ * @return string
+ *
+ * @throws \RuntimeException
+ */
+ public function getNamespace()
+ {
+ if (! is_null($this->namespace)) {
+ return $this->namespace;
+ }
+
+ $composer = json_decode(file_get_contents(base_path('composer.json')), true);
+
+ foreach ((array) data_get($composer, 'autoload.psr-4') as $namespace => $path) {
+ foreach ((array) $path as $pathChoice) {
+ if (realpath(app_path()) == realpath(base_path().'/'.$pathChoice)) {
+ return $this->namespace = $namespace;
+ }
+ }
+ }
+
+ throw new RuntimeException('Unable to detect application namespace.');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Auth/Access/Authorizable.php b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/Access/Authorizable.php
new file mode 100644
index 000000000..9e8e33bdf
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/Access/Authorizable.php
@@ -0,0 +1,44 @@
+forUser($this)->check($ability, $arguments);
+ }
+
+ /**
+ * Determine if the entity does not have a given ability.
+ *
+ * @param string $ability
+ * @param array|mixed $arguments
+ * @return bool
+ */
+ public function cant($ability, $arguments = [])
+ {
+ return ! $this->can($ability, $arguments);
+ }
+
+ /**
+ * Determine if the entity does not have a given ability.
+ *
+ * @param string $ability
+ * @param array|mixed $arguments
+ * @return bool
+ */
+ public function cannot($ability, $arguments = [])
+ {
+ return $this->cant($ability, $arguments);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Auth/Access/AuthorizesRequests.php b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/Access/AuthorizesRequests.php
new file mode 100644
index 000000000..7c2aa1bcd
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/Access/AuthorizesRequests.php
@@ -0,0 +1,125 @@
+parseAbilityAndArguments($ability, $arguments);
+
+ return app(Gate::class)->authorize($ability, $arguments);
+ }
+
+ /**
+ * Authorize a given action for a user.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable|mixed $user
+ * @param mixed $ability
+ * @param mixed|array $arguments
+ * @return \Illuminate\Auth\Access\Response
+ *
+ * @throws \Illuminate\Auth\Access\AuthorizationException
+ */
+ public function authorizeForUser($user, $ability, $arguments = [])
+ {
+ list($ability, $arguments) = $this->parseAbilityAndArguments($ability, $arguments);
+
+ return app(Gate::class)->forUser($user)->authorize($ability, $arguments);
+ }
+
+ /**
+ * Guesses the ability's name if it wasn't provided.
+ *
+ * @param mixed $ability
+ * @param mixed|array $arguments
+ * @return array
+ */
+ protected function parseAbilityAndArguments($ability, $arguments)
+ {
+ if (is_string($ability) && strpos($ability, '\\') === false) {
+ return [$ability, $arguments];
+ }
+
+ $method = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 3)[2]['function'];
+
+ return [$this->normalizeGuessedAbilityName($method), $ability];
+ }
+
+ /**
+ * Normalize the ability name that has been guessed from the method name.
+ *
+ * @param string $ability
+ * @return string
+ */
+ protected function normalizeGuessedAbilityName($ability)
+ {
+ $map = $this->resourceAbilityMap();
+
+ return isset($map[$ability]) ? $map[$ability] : $ability;
+ }
+
+ /**
+ * Authorize a resource action based on the incoming request.
+ *
+ * @param string $model
+ * @param string|null $parameter
+ * @param array $options
+ * @param \Illuminate\Http\Request|null $request
+ * @return void
+ */
+ public function authorizeResource($model, $parameter = null, array $options = [], $request = null)
+ {
+ $parameter = $parameter ?: lcfirst(class_basename($model));
+
+ $middleware = [];
+
+ foreach ($this->resourceAbilityMap() as $method => $ability) {
+ $modelName = in_array($method, $this->resourceMethodsWithoutModels()) ? $model : $parameter;
+
+ $middleware["can:{$ability},{$modelName}"][] = $method;
+ }
+
+ foreach ($middleware as $middlewareName => $methods) {
+ $this->middleware($middlewareName, $options)->only($methods);
+ }
+ }
+
+ /**
+ * Get the map of resource methods to ability names.
+ *
+ * @return array
+ */
+ protected function resourceAbilityMap()
+ {
+ return [
+ 'show' => 'view',
+ 'create' => 'create',
+ 'store' => 'create',
+ 'edit' => 'update',
+ 'update' => 'update',
+ 'destroy' => 'delete',
+ ];
+ }
+
+ /**
+ * Get the list of resource methods which do not have model parameters.
+ *
+ * @return array
+ */
+ protected function resourceMethodsWithoutModels()
+ {
+ return ['index', 'create', 'store'];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php
new file mode 100644
index 000000000..d76e2a45e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/AuthenticatesUsers.php
@@ -0,0 +1,172 @@
+validateLogin($request);
+
+ // If the class is using the ThrottlesLogins trait, we can automatically throttle
+ // the login attempts for this application. We'll key this by the username and
+ // the IP address of the client making these requests into this application.
+ if ($this->hasTooManyLoginAttempts($request)) {
+ $this->fireLockoutEvent($request);
+
+ return $this->sendLockoutResponse($request);
+ }
+
+ if ($this->attemptLogin($request)) {
+ return $this->sendLoginResponse($request);
+ }
+
+ // If the login attempt was unsuccessful we will increment the number of attempts
+ // to login and redirect the user back to the login form. Of course, when this
+ // user surpasses their maximum number of attempts they will get locked out.
+ $this->incrementLoginAttempts($request);
+
+ return $this->sendFailedLoginResponse($request);
+ }
+
+ /**
+ * Validate the user login request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ protected function validateLogin(Request $request)
+ {
+ $this->validate($request, [
+ $this->username() => 'required|string',
+ 'password' => 'required|string',
+ ]);
+ }
+
+ /**
+ * Attempt to log the user into the application.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return bool
+ */
+ protected function attemptLogin(Request $request)
+ {
+ return $this->guard()->attempt(
+ $this->credentials($request), $request->has('remember')
+ );
+ }
+
+ /**
+ * Get the needed authorization credentials from the request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return array
+ */
+ protected function credentials(Request $request)
+ {
+ return $request->only($this->username(), 'password');
+ }
+
+ /**
+ * Send the response after the user was authenticated.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Http\Response
+ */
+ protected function sendLoginResponse(Request $request)
+ {
+ $request->session()->regenerate();
+
+ $this->clearLoginAttempts($request);
+
+ return $this->authenticated($request, $this->guard()->user())
+ ?: redirect()->intended($this->redirectPath());
+ }
+
+ /**
+ * The user has been authenticated.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param mixed $user
+ * @return mixed
+ */
+ protected function authenticated(Request $request, $user)
+ {
+ //
+ }
+
+ /**
+ * Get the failed login response instance.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ protected function sendFailedLoginResponse(Request $request)
+ {
+ $errors = [$this->username() => trans('auth.failed')];
+
+ if ($request->expectsJson()) {
+ return response()->json($errors, 422);
+ }
+
+ return redirect()->back()
+ ->withInput($request->only($this->username(), 'remember'))
+ ->withErrors($errors);
+ }
+
+ /**
+ * Get the login username to be used by the controller.
+ *
+ * @return string
+ */
+ public function username()
+ {
+ return 'email';
+ }
+
+ /**
+ * Log the user out of the application.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Http\Response
+ */
+ public function logout(Request $request)
+ {
+ $this->guard()->logout();
+
+ $request->session()->invalidate();
+
+ return redirect('/');
+ }
+
+ /**
+ * Get the guard to be used during authentication.
+ *
+ * @return \Illuminate\Contracts\Auth\StatefulGuard
+ */
+ protected function guard()
+ {
+ return Auth::guard();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Auth/RedirectsUsers.php b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/RedirectsUsers.php
new file mode 100644
index 000000000..cc992290e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/RedirectsUsers.php
@@ -0,0 +1,20 @@
+redirectTo();
+ }
+
+ return property_exists($this, 'redirectTo') ? $this->redirectTo : '/home';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Auth/RegistersUsers.php b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/RegistersUsers.php
new file mode 100644
index 000000000..f3238f28b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/RegistersUsers.php
@@ -0,0 +1,62 @@
+validator($request->all())->validate();
+
+ event(new Registered($user = $this->create($request->all())));
+
+ $this->guard()->login($user);
+
+ return $this->registered($request, $user)
+ ?: redirect($this->redirectPath());
+ }
+
+ /**
+ * Get the guard to be used during registration.
+ *
+ * @return \Illuminate\Contracts\Auth\StatefulGuard
+ */
+ protected function guard()
+ {
+ return Auth::guard();
+ }
+
+ /**
+ * The user has been registered.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param mixed $user
+ * @return mixed
+ */
+ protected function registered(Request $request, $user)
+ {
+ //
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Auth/ResetsPasswords.php b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/ResetsPasswords.php
new file mode 100644
index 000000000..c6d2cac19
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/ResetsPasswords.php
@@ -0,0 +1,156 @@
+with(
+ ['token' => $token, 'email' => $request->email]
+ );
+ }
+
+ /**
+ * Reset the given user's password.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function reset(Request $request)
+ {
+ $this->validate($request, $this->rules(), $this->validationErrorMessages());
+
+ // Here we will attempt to reset the user's password. If it is successful we
+ // will update the password on an actual user model and persist it to the
+ // database. Otherwise we will parse the error and return the response.
+ $response = $this->broker()->reset(
+ $this->credentials($request), function ($user, $password) {
+ $this->resetPassword($user, $password);
+ }
+ );
+
+ // If the password was successfully reset, we will redirect the user back to
+ // the application's home authenticated view. If there is an error we can
+ // redirect them back to where they came from with their error message.
+ return $response == Password::PASSWORD_RESET
+ ? $this->sendResetResponse($response)
+ : $this->sendResetFailedResponse($request, $response);
+ }
+
+ /**
+ * Get the password reset validation rules.
+ *
+ * @return array
+ */
+ protected function rules()
+ {
+ return [
+ 'token' => 'required',
+ 'email' => 'required|email',
+ 'password' => 'required|confirmed|min:6',
+ ];
+ }
+
+ /**
+ * Get the password reset validation error messages.
+ *
+ * @return array
+ */
+ protected function validationErrorMessages()
+ {
+ return [];
+ }
+
+ /**
+ * Get the password reset credentials from the request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return array
+ */
+ protected function credentials(Request $request)
+ {
+ return $request->only(
+ 'email', 'password', 'password_confirmation', 'token'
+ );
+ }
+
+ /**
+ * Reset the given user's password.
+ *
+ * @param \Illuminate\Contracts\Auth\CanResetPassword $user
+ * @param string $password
+ * @return void
+ */
+ protected function resetPassword($user, $password)
+ {
+ $user->forceFill([
+ 'password' => bcrypt($password),
+ 'remember_token' => Str::random(60),
+ ])->save();
+
+ $this->guard()->login($user);
+ }
+
+ /**
+ * Get the response for a successful password reset.
+ *
+ * @param string $response
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ protected function sendResetResponse($response)
+ {
+ return redirect($this->redirectPath())
+ ->with('status', trans($response));
+ }
+
+ /**
+ * Get the response for a failed password reset.
+ *
+ * @param \Illuminate\Http\Request
+ * @param string $response
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ protected function sendResetFailedResponse(Request $request, $response)
+ {
+ return redirect()->back()
+ ->withInput($request->only('email'))
+ ->withErrors(['email' => trans($response)]);
+ }
+
+ /**
+ * Get the broker to be used during password reset.
+ *
+ * @return \Illuminate\Contracts\Auth\PasswordBroker
+ */
+ public function broker()
+ {
+ return Password::broker();
+ }
+
+ /**
+ * Get the guard to be used during password reset.
+ *
+ * @return \Illuminate\Contracts\Auth\StatefulGuard
+ */
+ protected function guard()
+ {
+ return Auth::guard();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Auth/SendsPasswordResetEmails.php b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/SendsPasswordResetEmails.php
new file mode 100644
index 000000000..eb29b56e2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/SendsPasswordResetEmails.php
@@ -0,0 +1,87 @@
+validateEmail($request);
+
+ // We will send the password reset link to this user. Once we have attempted
+ // to send the link, we will examine the response then see the message we
+ // need to show to the user. Finally, we'll send out a proper response.
+ $response = $this->broker()->sendResetLink(
+ $request->only('email')
+ );
+
+ return $response == Password::RESET_LINK_SENT
+ ? $this->sendResetLinkResponse($response)
+ : $this->sendResetLinkFailedResponse($request, $response);
+ }
+
+ /**
+ * Validate the email for the given request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ protected function validateEmail(Request $request)
+ {
+ $this->validate($request, ['email' => 'required|email']);
+ }
+
+ /**
+ * Get the response for a successful password reset link.
+ *
+ * @param string $response
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ protected function sendResetLinkResponse($response)
+ {
+ return back()->with('status', trans($response));
+ }
+
+ /**
+ * Get the response for a failed password reset link.
+ *
+ * @param \Illuminate\Http\Request
+ * @param string $response
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ protected function sendResetLinkFailedResponse(Request $request, $response)
+ {
+ return back()->withErrors(
+ ['email' => trans($response)]
+ );
+ }
+
+ /**
+ * Get the broker to be used during password reset.
+ *
+ * @return \Illuminate\Contracts\Auth\PasswordBroker
+ */
+ public function broker()
+ {
+ return Password::broker();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Auth/ThrottlesLogins.php b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/ThrottlesLogins.php
new file mode 100644
index 000000000..a7f0b7f2e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/ThrottlesLogins.php
@@ -0,0 +1,124 @@
+limiter()->tooManyAttempts(
+ $this->throttleKey($request), $this->maxAttempts(), $this->decayMinutes()
+ );
+ }
+
+ /**
+ * Increment the login attempts for the user.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ protected function incrementLoginAttempts(Request $request)
+ {
+ $this->limiter()->hit($this->throttleKey($request));
+ }
+
+ /**
+ * Redirect the user after determining they are locked out.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ protected function sendLockoutResponse(Request $request)
+ {
+ $seconds = $this->limiter()->availableIn(
+ $this->throttleKey($request)
+ );
+
+ $message = Lang::get('auth.throttle', ['seconds' => $seconds]);
+
+ $errors = [$this->username() => $message];
+
+ if ($request->expectsJson()) {
+ return response()->json($errors, 423);
+ }
+
+ return redirect()->back()
+ ->withInput($request->only($this->username(), 'remember'))
+ ->withErrors($errors);
+ }
+
+ /**
+ * Clear the login locks for the given user credentials.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ protected function clearLoginAttempts(Request $request)
+ {
+ $this->limiter()->clear($this->throttleKey($request));
+ }
+
+ /**
+ * Fire an event when a lockout occurs.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ protected function fireLockoutEvent(Request $request)
+ {
+ event(new Lockout($request));
+ }
+
+ /**
+ * Get the throttle key for the given request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return string
+ */
+ protected function throttleKey(Request $request)
+ {
+ return Str::lower($request->input($this->username())).'|'.$request->ip();
+ }
+
+ /**
+ * Get the rate limiter instance.
+ *
+ * @return \Illuminate\Cache\RateLimiter
+ */
+ protected function limiter()
+ {
+ return app(RateLimiter::class);
+ }
+
+ /**
+ * Get the maximum number of attempts to allow.
+ *
+ * @return int
+ */
+ public function maxAttempts()
+ {
+ return property_exists($this, 'maxAttempts') ? $this->maxAttempts : 5;
+ }
+
+ /**
+ * Get the number of minutes to throttle for.
+ *
+ * @return int
+ */
+ public function decayMinutes()
+ {
+ return property_exists($this, 'decayMinutes') ? $this->decayMinutes : 1;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Auth/User.php b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/User.php
new file mode 100644
index 000000000..5c8477859
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Auth/User.php
@@ -0,0 +1,19 @@
+boot();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/HandleExceptions.php b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/HandleExceptions.php
new file mode 100644
index 000000000..b7edb6833
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/HandleExceptions.php
@@ -0,0 +1,161 @@
+app = $app;
+
+ error_reporting(-1);
+
+ set_error_handler([$this, 'handleError']);
+
+ set_exception_handler([$this, 'handleException']);
+
+ register_shutdown_function([$this, 'handleShutdown']);
+
+ if (! $app->environment('testing')) {
+ ini_set('display_errors', 'Off');
+ }
+ }
+
+ /**
+ * Convert PHP errors to ErrorException instances.
+ *
+ * @param int $level
+ * @param string $message
+ * @param string $file
+ * @param int $line
+ * @param array $context
+ * @return void
+ *
+ * @throws \ErrorException
+ */
+ public function handleError($level, $message, $file = '', $line = 0, $context = [])
+ {
+ if (error_reporting() & $level) {
+ throw new ErrorException($message, 0, $level, $file, $line);
+ }
+ }
+
+ /**
+ * Handle an uncaught exception from the application.
+ *
+ * Note: Most exceptions can be handled via the try / catch block in
+ * the HTTP and Console kernels. But, fatal error exceptions must
+ * be handled differently since they are not normal exceptions.
+ *
+ * @param \Throwable $e
+ * @return void
+ */
+ public function handleException($e)
+ {
+ if (! $e instanceof Exception) {
+ $e = new FatalThrowableError($e);
+ }
+
+ try {
+ $this->getExceptionHandler()->report($e);
+ } catch (Exception $e) {
+ //
+ }
+
+ if ($this->app->runningInConsole()) {
+ $this->renderForConsole($e);
+ } else {
+ $this->renderHttpResponse($e);
+ }
+ }
+
+ /**
+ * Render an exception to the console.
+ *
+ * @param \Exception $e
+ * @return void
+ */
+ protected function renderForConsole(Exception $e)
+ {
+ $this->getExceptionHandler()->renderForConsole(new ConsoleOutput, $e);
+ }
+
+ /**
+ * Render an exception as an HTTP response and send it.
+ *
+ * @param \Exception $e
+ * @return void
+ */
+ protected function renderHttpResponse(Exception $e)
+ {
+ $this->getExceptionHandler()->render($this->app['request'], $e)->send();
+ }
+
+ /**
+ * Handle the PHP shutdown event.
+ *
+ * @return void
+ */
+ public function handleShutdown()
+ {
+ if (! is_null($error = error_get_last()) && $this->isFatal($error['type'])) {
+ $this->handleException($this->fatalExceptionFromError($error, 0));
+ }
+ }
+
+ /**
+ * Create a new fatal exception instance from an error array.
+ *
+ * @param array $error
+ * @param int|null $traceOffset
+ * @return \Symfony\Component\Debug\Exception\FatalErrorException
+ */
+ protected function fatalExceptionFromError(array $error, $traceOffset = null)
+ {
+ return new FatalErrorException(
+ $error['message'], $error['type'], 0, $error['file'], $error['line'], $traceOffset
+ );
+ }
+
+ /**
+ * Determine if the error type is fatal.
+ *
+ * @param int $type
+ * @return bool
+ */
+ protected function isFatal($type)
+ {
+ return in_array($type, [E_COMPILE_ERROR, E_CORE_ERROR, E_ERROR, E_PARSE]);
+ }
+
+ /**
+ * Get an instance of the exception handler.
+ *
+ * @return \Illuminate\Contracts\Debug\ExceptionHandler
+ */
+ protected function getExceptionHandler()
+ {
+ return $this->app->make(ExceptionHandler::class);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadConfiguration.php b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadConfiguration.php
new file mode 100644
index 000000000..6a2dcfc07
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadConfiguration.php
@@ -0,0 +1,113 @@
+getCachedConfigPath())) {
+ $items = require $cached;
+
+ $loadedFromCache = true;
+ }
+
+ // Next we will spin through all of the configuration files in the configuration
+ // directory and load each one into the repository. This will make all of the
+ // options available to the developer for use in various parts of this app.
+ $app->instance('config', $config = new Repository($items));
+
+ if (! isset($loadedFromCache)) {
+ $this->loadConfigurationFiles($app, $config);
+ }
+
+ // Finally, we will set the application's environment based on the configuration
+ // values that were loaded. We will pass a callback which will be used to get
+ // the environment in a web context where an "--env" switch is not present.
+ $app->detectEnvironment(function () use ($config) {
+ return $config->get('app.env', 'production');
+ });
+
+ date_default_timezone_set($config->get('app.timezone', 'UTC'));
+
+ mb_internal_encoding('UTF-8');
+ }
+
+ /**
+ * Load the configuration items from all of the files.
+ *
+ * @param \Illuminate\Contracts\Foundation\Application $app
+ * @param \Illuminate\Contracts\Config\Repository $repository
+ * @return void
+ * @throws \Exception
+ */
+ protected function loadConfigurationFiles(Application $app, RepositoryContract $repository)
+ {
+ $files = $this->getConfigurationFiles($app);
+
+ if (! isset($files['app'])) {
+ throw new Exception('Unable to load the "app" configuration file.');
+ }
+
+ foreach ($files as $key => $path) {
+ $repository->set($key, require $path);
+ }
+ }
+
+ /**
+ * Get all of the configuration files for the application.
+ *
+ * @param \Illuminate\Contracts\Foundation\Application $app
+ * @return array
+ */
+ protected function getConfigurationFiles(Application $app)
+ {
+ $files = [];
+
+ $configPath = realpath($app->configPath());
+
+ foreach (Finder::create()->files()->name('*.php')->in($configPath) as $file) {
+ $directory = $this->getNestedDirectory($file, $configPath);
+
+ $files[$directory.basename($file->getRealPath(), '.php')] = $file->getRealPath();
+ }
+
+ return $files;
+ }
+
+ /**
+ * Get the configuration file nesting path.
+ *
+ * @param \SplFileInfo $file
+ * @param string $configPath
+ * @return string
+ */
+ protected function getNestedDirectory(SplFileInfo $file, $configPath)
+ {
+ $directory = $file->getPath();
+
+ if ($nested = trim(str_replace($configPath, '', $directory), DIRECTORY_SEPARATOR)) {
+ $nested = str_replace(DIRECTORY_SEPARATOR, '.', $nested).'.';
+ }
+
+ return $nested;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadEnvironmentVariables.php b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadEnvironmentVariables.php
new file mode 100644
index 000000000..6ec3e8029
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadEnvironmentVariables.php
@@ -0,0 +1,69 @@
+configurationIsCached()) {
+ return;
+ }
+
+ $this->checkForSpecificEnvironmentFile($app);
+
+ try {
+ (new Dotenv($app->environmentPath(), $app->environmentFile()))->load();
+ } catch (InvalidPathException $e) {
+ //
+ }
+ }
+
+ /**
+ * Detect if a custom environment file matching the APP_ENV exists.
+ *
+ * @param \Illuminate\Contracts\Foundation\Application $app
+ * @return void
+ */
+ protected function checkForSpecificEnvironmentFile($app)
+ {
+ if (php_sapi_name() == 'cli' && with($input = new ArgvInput)->hasParameterOption('--env')) {
+ $this->setEnvironmentFilePath(
+ $app, $app->environmentFile().'.'.$input->getParameterOption('--env')
+ );
+ }
+
+ if (! env('APP_ENV')) {
+ return;
+ }
+
+ $this->setEnvironmentFilePath(
+ $app, $app->environmentFile().'.'.env('APP_ENV')
+ );
+ }
+
+ /**
+ * Load a custom environment file.
+ *
+ * @param \Illuminate\Contracts\Foundation\Application $app
+ * @param string $file
+ * @return void
+ */
+ protected function setEnvironmentFilePath($app, $file)
+ {
+ if (file_exists($app->environmentPath().'/'.$file)) {
+ $app->loadEnvironmentFrom($file);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterFacades.php b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterFacades.php
new file mode 100644
index 000000000..0c2d5cfce
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterFacades.php
@@ -0,0 +1,25 @@
+make('config')->get('app.aliases', []))->register();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterProviders.php b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterProviders.php
new file mode 100644
index 000000000..f18375cf3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/RegisterProviders.php
@@ -0,0 +1,19 @@
+registerConfiguredProviders();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/SetRequestForConsole.php b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/SetRequestForConsole.php
new file mode 100644
index 000000000..fda735ba2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/SetRequestForConsole.php
@@ -0,0 +1,35 @@
+make('config')->get('app.url', 'http://localhost');
+
+ $components = parse_url($uri);
+
+ $server = $_SERVER;
+
+ if (isset($components['path'])) {
+ $server = array_merge($server, [
+ 'SCRIPT_FILENAME' => $components['path'],
+ 'SCRIPT_NAME' => $components['path'],
+ ]);
+ }
+
+ $app->instance('request', Request::create(
+ $uri, 'GET', [], [], [], $server
+ ));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Bus/Dispatchable.php b/vendor/laravel/framework/src/Illuminate/Foundation/Bus/Dispatchable.php
new file mode 100644
index 000000000..d91d8db20
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Bus/Dispatchable.php
@@ -0,0 +1,16 @@
+dispatch($job);
+ }
+
+ /**
+ * Dispatch a command to its appropriate handler in the current process.
+ *
+ * @param mixed $job
+ * @return mixed
+ */
+ public function dispatchNow($job)
+ {
+ return app(Dispatcher::class)->dispatchNow($job);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Bus/PendingDispatch.php b/vendor/laravel/framework/src/Illuminate/Foundation/Bus/PendingDispatch.php
new file mode 100644
index 000000000..7d5053d82
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Bus/PendingDispatch.php
@@ -0,0 +1,66 @@
+job = $job;
+ }
+
+ /**
+ * Set the desired connection for the job.
+ *
+ * @param string|null $connection
+ * @return $this
+ */
+ public function onConnection($connection)
+ {
+ $this->job->onConnection($connection);
+
+ return $this;
+ }
+
+ /**
+ * Set the desired queue for the job.
+ *
+ * @param string|null $queue
+ * @return $this
+ */
+ public function onQueue($queue)
+ {
+ $this->job->onQueue($queue);
+
+ return $this;
+ }
+
+ /**
+ * Set the desired delay for the job.
+ *
+ * @param \DateTime|int|null $delay
+ * @return $this
+ */
+ public function delay($delay)
+ {
+ $this->job->delay($delay);
+
+ return $this;
+ }
+
+ /**
+ * Handle the object's destruction.
+ *
+ * @return void
+ */
+ public function __destruct()
+ {
+ dispatch($this->job);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/ComposerScripts.php b/vendor/laravel/framework/src/Illuminate/Foundation/ComposerScripts.php
new file mode 100644
index 000000000..9b4c1ddeb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/ComposerScripts.php
@@ -0,0 +1,48 @@
+getComposer()->getConfig()->get('vendor-dir').'/autoload.php';
+
+ static::clearCompiled();
+ }
+
+ /**
+ * Handle the post-update Composer event.
+ *
+ * @param \Composer\Script\Event $event
+ * @return void
+ */
+ public static function postUpdate(Event $event)
+ {
+ require_once $event->getComposer()->getConfig()->get('vendor-dir').'/autoload.php';
+
+ static::clearCompiled();
+ }
+
+ /**
+ * Clear the cached Laravel bootstrapping files.
+ *
+ * @return void
+ */
+ protected static function clearCompiled()
+ {
+ $laravel = new Application(getcwd());
+
+ if (file_exists($servicesPath = $laravel->getCachedServicesPath())) {
+ @unlink($servicesPath);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/AppNameCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/AppNameCommand.php
new file mode 100644
index 000000000..93dd32535
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/AppNameCommand.php
@@ -0,0 +1,289 @@
+files = $files;
+ $this->composer = $composer;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $this->currentRoot = trim($this->laravel->getNamespace(), '\\');
+
+ $this->setAppDirectoryNamespace();
+ $this->setBootstrapNamespaces();
+ $this->setConfigNamespaces();
+ $this->setComposerNamespace();
+ $this->setDatabaseFactoryNamespaces();
+
+ $this->info('Application namespace set!');
+
+ $this->composer->dumpAutoloads();
+
+ $this->call('clear-compiled');
+ }
+
+ /**
+ * Set the namespace on the files in the app directory.
+ *
+ * @return void
+ */
+ protected function setAppDirectoryNamespace()
+ {
+ $files = Finder::create()
+ ->in($this->laravel['path'])
+ ->contains($this->currentRoot)
+ ->name('*.php');
+
+ foreach ($files as $file) {
+ $this->replaceNamespace($file->getRealPath());
+ }
+ }
+
+ /**
+ * Replace the App namespace at the given path.
+ *
+ * @param string $path
+ * @return void
+ */
+ protected function replaceNamespace($path)
+ {
+ $search = [
+ 'namespace '.$this->currentRoot.';',
+ $this->currentRoot.'\\',
+ ];
+
+ $replace = [
+ 'namespace '.$this->argument('name').';',
+ $this->argument('name').'\\',
+ ];
+
+ $this->replaceIn($path, $search, $replace);
+ }
+
+ /**
+ * Set the bootstrap namespaces.
+ *
+ * @return void
+ */
+ protected function setBootstrapNamespaces()
+ {
+ $search = [
+ $this->currentRoot.'\\Http',
+ $this->currentRoot.'\\Console',
+ $this->currentRoot.'\\Exceptions',
+ ];
+
+ $replace = [
+ $this->argument('name').'\\Http',
+ $this->argument('name').'\\Console',
+ $this->argument('name').'\\Exceptions',
+ ];
+
+ $this->replaceIn($this->getBootstrapPath(), $search, $replace);
+ }
+
+ /**
+ * Set the namespace in the appropriate configuration files.
+ *
+ * @return void
+ */
+ protected function setConfigNamespaces()
+ {
+ $this->setAppConfigNamespaces();
+ $this->setAuthConfigNamespace();
+ $this->setServicesConfigNamespace();
+ }
+
+ /**
+ * Set the application provider namespaces.
+ *
+ * @return void
+ */
+ protected function setAppConfigNamespaces()
+ {
+ $search = [
+ $this->currentRoot.'\\Providers',
+ $this->currentRoot.'\\Http\\Controllers\\',
+ ];
+
+ $replace = [
+ $this->argument('name').'\\Providers',
+ $this->argument('name').'\\Http\\Controllers\\',
+ ];
+
+ $this->replaceIn($this->getConfigPath('app'), $search, $replace);
+ }
+
+ /**
+ * Set the authentication User namespace.
+ *
+ * @return void
+ */
+ protected function setAuthConfigNamespace()
+ {
+ $this->replaceIn(
+ $this->getConfigPath('auth'),
+ $this->currentRoot.'\\User',
+ $this->argument('name').'\\User'
+ );
+ }
+
+ /**
+ * Set the services User namespace.
+ *
+ * @return void
+ */
+ protected function setServicesConfigNamespace()
+ {
+ $this->replaceIn(
+ $this->getConfigPath('services'),
+ $this->currentRoot.'\\User',
+ $this->argument('name').'\\User'
+ );
+ }
+
+ /**
+ * Set the PSR-4 namespace in the Composer file.
+ *
+ * @return void
+ */
+ protected function setComposerNamespace()
+ {
+ $this->replaceIn(
+ $this->getComposerPath(),
+ str_replace('\\', '\\\\', $this->currentRoot).'\\\\',
+ str_replace('\\', '\\\\', $this->argument('name')).'\\\\'
+ );
+ }
+
+ /**
+ * Set the namespace in database factory files.
+ *
+ * @return void
+ */
+ protected function setDatabaseFactoryNamespaces()
+ {
+ $this->replaceIn(
+ $this->laravel->databasePath().'/factories/ModelFactory.php',
+ $this->currentRoot, $this->argument('name')
+ );
+ }
+
+ /**
+ * Replace the given string in the given file.
+ *
+ * @param string $path
+ * @param string|array $search
+ * @param string|array $replace
+ * @return void
+ */
+ protected function replaceIn($path, $search, $replace)
+ {
+ if ($this->files->exists($path)) {
+ $this->files->put($path, str_replace($search, $replace, $this->files->get($path)));
+ }
+ }
+
+ /**
+ * Get the path to the bootstrap/app.php file.
+ *
+ * @return string
+ */
+ protected function getBootstrapPath()
+ {
+ return $this->laravel->bootstrapPath().'/app.php';
+ }
+
+ /**
+ * Get the path to the Composer.json file.
+ *
+ * @return string
+ */
+ protected function getComposerPath()
+ {
+ return $this->laravel->basePath().'/composer.json';
+ }
+
+ /**
+ * Get the path to the given configuration file.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function getConfigPath($name)
+ {
+ return $this->laravel['path.config'].'/'.$name.'.php';
+ }
+
+ /**
+ * Get the console command arguments.
+ *
+ * @return array
+ */
+ protected function getArguments()
+ {
+ return [
+ ['name', InputArgument::REQUIRED, 'The desired namespace.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/ClearCompiledCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ClearCompiledCommand.php
new file mode 100644
index 000000000..8d87b715e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ClearCompiledCommand.php
@@ -0,0 +1,38 @@
+laravel->getCachedServicesPath();
+
+ if (file_exists($servicesPath)) {
+ @unlink($servicesPath);
+ }
+
+ $this->info('The compiled services file has been removed.');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/ClosureCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ClosureCommand.php
new file mode 100644
index 000000000..c2f196362
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ClosureCommand.php
@@ -0,0 +1,71 @@
+callback = $callback;
+ $this->signature = $signature;
+
+ parent::__construct();
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @param \Symfony\Component\Console\Input\InputInterface $input
+ * @param \Symfony\Component\Console\Output\OutputInterface $output
+ * @return mixed
+ */
+ protected function execute(InputInterface $input, OutputInterface $output)
+ {
+ $inputs = array_merge($input->getArguments(), $input->getOptions());
+
+ $parameters = [];
+
+ foreach ((new ReflectionFunction($this->callback))->getParameters() as $parameter) {
+ if (isset($inputs[$parameter->name])) {
+ $parameters[$parameter->name] = $inputs[$parameter->name];
+ }
+ }
+
+ return $this->laravel->call(
+ $this->callback->bindTo($this, $this), $parameters
+ );
+ }
+
+ /**
+ * Set the description for the command.
+ *
+ * @param string $description
+ * @return $this
+ */
+ public function describe($description)
+ {
+ $this->setDescription($description);
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/ConfigCacheCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ConfigCacheCommand.php
new file mode 100644
index 000000000..2d4796127
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ConfigCacheCommand.php
@@ -0,0 +1,76 @@
+files = $files;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $this->call('config:clear');
+
+ $config = $this->getFreshConfiguration();
+
+ $this->files->put(
+ $this->laravel->getCachedConfigPath(), 'info('Configuration cached successfully!');
+ }
+
+ /**
+ * Boot a fresh copy of the application configuration.
+ *
+ * @return array
+ */
+ protected function getFreshConfiguration()
+ {
+ $app = require $this->laravel->bootstrapPath().'/app.php';
+
+ $app->make(ConsoleKernelContract::class)->bootstrap();
+
+ return $app['config']->all();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/ConfigClearCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ConfigClearCommand.php
new file mode 100644
index 000000000..bb25a8efb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ConfigClearCommand.php
@@ -0,0 +1,55 @@
+files = $files;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $this->files->delete($this->laravel->getCachedConfigPath());
+
+ $this->info('Configuration cache cleared!');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/ConsoleMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ConsoleMakeCommand.php
new file mode 100644
index 000000000..a9b164b97
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ConsoleMakeCommand.php
@@ -0,0 +1,90 @@
+option('command'), $stub);
+ }
+
+ /**
+ * Get the stub file for the generator.
+ *
+ * @return string
+ */
+ protected function getStub()
+ {
+ return __DIR__.'/stubs/console.stub';
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ return $rootNamespace.'\Console\Commands';
+ }
+
+ /**
+ * Get the console command arguments.
+ *
+ * @return array
+ */
+ protected function getArguments()
+ {
+ return [
+ ['name', InputArgument::REQUIRED, 'The name of the command.'],
+ ];
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['command', null, InputOption::VALUE_OPTIONAL, 'The terminal command that should be assigned.', 'command:name'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/DownCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/DownCommand.php
new file mode 100644
index 000000000..358a5841d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/DownCommand.php
@@ -0,0 +1,65 @@
+laravel->storagePath().'/framework/down',
+ json_encode($this->getDownFilePayload(), JSON_PRETTY_PRINT)
+ );
+
+ $this->comment('Application is now in maintenance mode.');
+ }
+
+ /**
+ * Get the payload to be placed in the "down" file.
+ *
+ * @return array
+ */
+ protected function getDownFilePayload()
+ {
+ return [
+ 'time' => Carbon::now()->getTimestamp(),
+ 'message' => $this->option('message'),
+ 'retry' => $this->getRetryTime(),
+ ];
+ }
+
+ /**
+ * Get the number of seconds the client should wait before retrying their request.
+ *
+ * @return int|null
+ */
+ protected function getRetryTime()
+ {
+ $retry = $this->option('retry');
+
+ return is_numeric($retry) && $retry > 0 ? (int) $retry : null;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/EnvironmentCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/EnvironmentCommand.php
new file mode 100644
index 000000000..b227165ce
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/EnvironmentCommand.php
@@ -0,0 +1,32 @@
+line('Current application environment: '.$this->laravel['env'].' ');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/EventGenerateCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/EventGenerateCommand.php
new file mode 100644
index 000000000..bf4c989e0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/EventGenerateCommand.php
@@ -0,0 +1,74 @@
+laravel->getProvider(EventServiceProvider::class);
+
+ foreach ($provider->listens() as $event => $listeners) {
+ $this->makeEventAndListeners($event, $listeners);
+ }
+
+ $this->info('Events and listeners generated successfully!');
+ }
+
+ /**
+ * Make the event and listeners for the given event.
+ *
+ * @param string $event
+ * @param array $listeners
+ * @return void
+ */
+ protected function makeEventAndListeners($event, $listeners)
+ {
+ if (! Str::contains($event, '\\')) {
+ return;
+ }
+
+ $this->callSilent('make:event', ['name' => $event]);
+
+ $this->makeListeners($event, $listeners);
+ }
+
+ /**
+ * Make the listeners for the given event.
+ *
+ * @param string $event
+ * @param array $listeners
+ * @return void
+ */
+ protected function makeListeners($event, $listeners)
+ {
+ foreach ($listeners as $listener) {
+ $listener = preg_replace('/@.+$/', '', $listener);
+
+ $this->callSilent('make:listener', ['name' => $listener, '--event' => $event]);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/EventMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/EventMakeCommand.php
new file mode 100644
index 000000000..f18719aa9
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/EventMakeCommand.php
@@ -0,0 +1,61 @@
+option('sync')
+ ? __DIR__.'/stubs/job.stub'
+ : __DIR__.'/stubs/job-queued.stub';
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ return $rootNamespace.'\Jobs';
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['sync', null, InputOption::VALUE_NONE, 'Indicates that job should be synchronous.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/Kernel.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/Kernel.php
new file mode 100644
index 000000000..7c7a1f45a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/Kernel.php
@@ -0,0 +1,334 @@
+app = $app;
+ $this->events = $events;
+
+ $this->app->booted(function () {
+ $this->defineConsoleSchedule();
+ });
+ }
+
+ /**
+ * Define the application's command schedule.
+ *
+ * @return void
+ */
+ protected function defineConsoleSchedule()
+ {
+ $this->app->instance(
+ Schedule::class, $schedule = new Schedule($this->app[Cache::class])
+ );
+
+ $this->schedule($schedule);
+ }
+
+ /**
+ * Run the console application.
+ *
+ * @param \Symfony\Component\Console\Input\InputInterface $input
+ * @param \Symfony\Component\Console\Output\OutputInterface $output
+ * @return int
+ */
+ public function handle($input, $output = null)
+ {
+ try {
+ $this->bootstrap();
+
+ if (! $this->commandsLoaded) {
+ $this->commands();
+
+ $this->commandsLoaded = true;
+ }
+
+ return $this->getArtisan()->run($input, $output);
+ } catch (Exception $e) {
+ $this->reportException($e);
+
+ $this->renderException($output, $e);
+
+ return 1;
+ } catch (Throwable $e) {
+ $e = new FatalThrowableError($e);
+
+ $this->reportException($e);
+
+ $this->renderException($output, $e);
+
+ return 1;
+ }
+ }
+
+ /**
+ * Terminate the application.
+ *
+ * @param \Symfony\Component\Console\Input\InputInterface $input
+ * @param int $status
+ * @return void
+ */
+ public function terminate($input, $status)
+ {
+ $this->app->terminate();
+ }
+
+ /**
+ * Define the application's command schedule.
+ *
+ * @param \Illuminate\Console\Scheduling\Schedule $schedule
+ * @return void
+ */
+ protected function schedule(Schedule $schedule)
+ {
+ //
+ }
+
+ /**
+ * Register the Closure based commands for the application.
+ *
+ * @return void
+ */
+ protected function commands()
+ {
+ //
+ }
+
+ /**
+ * Register a Closure based command with the application.
+ *
+ * @param string $signature
+ * @param Closure $callback
+ * @return \Illuminate\Foundation\Console\ClosureCommand
+ */
+ public function command($signature, Closure $callback)
+ {
+ $command = new ClosureCommand($signature, $callback);
+
+ Artisan::starting(function ($artisan) use ($command) {
+ $artisan->add($command);
+ });
+
+ return $command;
+ }
+
+ /**
+ * Register the given command with the console application.
+ *
+ * @param \Symfony\Component\Console\Command\Command $command
+ * @return void
+ */
+ public function registerCommand($command)
+ {
+ $this->getArtisan()->add($command);
+ }
+
+ /**
+ * Run an Artisan console command by name.
+ *
+ * @param string $command
+ * @param array $parameters
+ * @param \Symfony\Component\Console\Output\OutputInterface $outputBuffer
+ * @return int
+ */
+ public function call($command, array $parameters = [], $outputBuffer = null)
+ {
+ $this->bootstrap();
+
+ if (! $this->commandsLoaded) {
+ $this->commands();
+
+ $this->commandsLoaded = true;
+ }
+
+ return $this->getArtisan()->call($command, $parameters, $outputBuffer);
+ }
+
+ /**
+ * Queue the given console command.
+ *
+ * @param string $command
+ * @param array $parameters
+ * @return \Illuminate\Foundation\Bus\PendingDispatch
+ */
+ public function queue($command, array $parameters = [])
+ {
+ return QueuedCommand::dispatch(func_get_args());
+ }
+
+ /**
+ * Get all of the commands registered with the console.
+ *
+ * @return array
+ */
+ public function all()
+ {
+ $this->bootstrap();
+
+ return $this->getArtisan()->all();
+ }
+
+ /**
+ * Get the output for the last run command.
+ *
+ * @return string
+ */
+ public function output()
+ {
+ $this->bootstrap();
+
+ return $this->getArtisan()->output();
+ }
+
+ /**
+ * Bootstrap the application for artisan commands.
+ *
+ * @return void
+ */
+ public function bootstrap()
+ {
+ if (! $this->app->hasBeenBootstrapped()) {
+ $this->app->bootstrapWith($this->bootstrappers());
+ }
+
+ // If we are calling an arbitrary command from within the application, we'll load
+ // all of the available deferred providers which will make all of the commands
+ // available to an application. Otherwise the command will not be available.
+ $this->app->loadDeferredProviders();
+ }
+
+ /**
+ * Get the Artisan application instance.
+ *
+ * @return \Illuminate\Console\Application
+ */
+ protected function getArtisan()
+ {
+ if (is_null($this->artisan)) {
+ return $this->artisan = (new Artisan($this->app, $this->events, $this->app->version()))
+ ->resolveCommands($this->commands);
+ }
+
+ return $this->artisan;
+ }
+
+ /**
+ * Set the Artisan application instance.
+ *
+ * @param \Illuminate\Console\Application $artisan
+ * @return void
+ */
+ public function setArtisan($artisan)
+ {
+ $this->artisan = $artisan;
+ }
+
+ /**
+ * Get the bootstrap classes for the application.
+ *
+ * @return array
+ */
+ protected function bootstrappers()
+ {
+ return $this->bootstrappers;
+ }
+
+ /**
+ * Report the exception to the exception handler.
+ *
+ * @param \Exception $e
+ * @return void
+ */
+ protected function reportException(Exception $e)
+ {
+ $this->app[ExceptionHandler::class]->report($e);
+ }
+
+ /**
+ * Report the exception to the exception handler.
+ *
+ * @param \Symfony\Component\Console\Output\OutputInterface $output
+ * @param \Exception $e
+ * @return void
+ */
+ protected function renderException($output, Exception $e)
+ {
+ $this->app[ExceptionHandler::class]->renderForConsole($output, $e);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/KeyGenerateCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/KeyGenerateCommand.php
new file mode 100644
index 000000000..b48a8069b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/KeyGenerateCommand.php
@@ -0,0 +1,110 @@
+generateRandomKey();
+
+ if ($this->option('show')) {
+ return $this->line(''.$key.' ');
+ }
+
+ // Next, we will replace the application key in the environment file so it is
+ // automatically setup for this developer. This key gets generated using a
+ // secure random byte generator and is later base64 encoded for storage.
+ if (! $this->setKeyInEnvironmentFile($key)) {
+ return;
+ }
+
+ $this->laravel['config']['app.key'] = $key;
+
+ $this->info("Application key [$key] set successfully.");
+ }
+
+ /**
+ * Generate a random key for the application.
+ *
+ * @return string
+ */
+ protected function generateRandomKey()
+ {
+ return 'base64:'.base64_encode(random_bytes(
+ $this->laravel['config']['app.cipher'] == 'AES-128-CBC' ? 16 : 32
+ ));
+ }
+
+ /**
+ * Set the application key in the environment file.
+ *
+ * @param string $key
+ * @return bool
+ */
+ protected function setKeyInEnvironmentFile($key)
+ {
+ $currentKey = $this->laravel['config']['app.key'];
+
+ if (strlen($currentKey) !== 0 && (! $this->confirmToProceed())) {
+ return false;
+ }
+
+ $this->writeNewEnvironmentFileWith($key);
+
+ return true;
+ }
+
+ /**
+ * Write a new environment file with the given key.
+ *
+ * @param string $key
+ * @return void
+ */
+ protected function writeNewEnvironmentFileWith($key)
+ {
+ file_put_contents($this->laravel->environmentFilePath(), preg_replace(
+ $this->keyReplacementPattern(),
+ 'APP_KEY='.$key,
+ file_get_contents($this->laravel->environmentFilePath())
+ ));
+ }
+
+ /**
+ * Get a regex pattern that will match env APP_KEY with any random key.
+ *
+ * @return string
+ */
+ protected function keyReplacementPattern()
+ {
+ $escaped = preg_quote('='.$this->laravel['config']['app.key'], '/');
+
+ return "/^APP_KEY{$escaped}/m";
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/ListenerMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ListenerMakeCommand.php
new file mode 100644
index 000000000..971d1b763
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ListenerMakeCommand.php
@@ -0,0 +1,119 @@
+option('event')) {
+ return $this->error('Missing required option: --event');
+ }
+
+ parent::fire();
+ }
+
+ /**
+ * Build the class with the given name.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function buildClass($name)
+ {
+ $event = $this->option('event');
+
+ if (! Str::startsWith($event, $this->laravel->getNamespace()) &&
+ ! Str::startsWith($event, 'Illuminate')) {
+ $event = $this->laravel->getNamespace().'Events\\'.$event;
+ }
+
+ $stub = str_replace(
+ 'DummyEvent', class_basename($event), parent::buildClass($name)
+ );
+
+ return str_replace(
+ 'DummyFullEvent', $event, $stub
+ );
+ }
+
+ /**
+ * Get the stub file for the generator.
+ *
+ * @return string
+ */
+ protected function getStub()
+ {
+ if ($this->option('queued')) {
+ return __DIR__.'/stubs/listener-queued.stub';
+ } else {
+ return __DIR__.'/stubs/listener.stub';
+ }
+ }
+
+ /**
+ * Determine if the class already exists.
+ *
+ * @param string $rawName
+ * @return bool
+ */
+ protected function alreadyExists($rawName)
+ {
+ return class_exists($rawName);
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ return $rootNamespace.'\Listeners';
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['event', 'e', InputOption::VALUE_REQUIRED, 'The event class being listened for.'],
+
+ ['queued', null, InputOption::VALUE_NONE, 'Indicates the event listener should be queued.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/MailMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/MailMakeCommand.php
new file mode 100644
index 000000000..103fe6391
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/MailMakeCommand.php
@@ -0,0 +1,116 @@
+option('force')) {
+ return;
+ }
+
+ if ($this->option('markdown')) {
+ $this->writeMarkdownTemplate();
+ }
+ }
+
+ /**
+ * Write the Markdown template for the mailable.
+ *
+ * @return void
+ */
+ protected function writeMarkdownTemplate()
+ {
+ $path = resource_path('views/'.str_replace('.', '/', $this->option('markdown'))).'.blade.php';
+
+ if (! $this->files->isDirectory(dirname($path))) {
+ $this->files->makeDirectory(dirname($path), 0755, true);
+ }
+
+ $this->files->put($path, file_get_contents(__DIR__.'/stubs/markdown.stub'));
+ }
+
+ /**
+ * Build the class with the given name.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function buildClass($name)
+ {
+ $class = parent::buildClass($name);
+
+ if ($this->option('markdown')) {
+ $class = str_replace('DummyView', $this->option('markdown'), $class);
+ }
+
+ return $class;
+ }
+
+ /**
+ * Get the stub file for the generator.
+ *
+ * @return string
+ */
+ protected function getStub()
+ {
+ return $this->option('markdown')
+ ? __DIR__.'/stubs/markdown-mail.stub'
+ : __DIR__.'/stubs/mail.stub';
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ return $rootNamespace.'\Mail';
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['force', 'f', InputOption::VALUE_NONE, 'Create the class even if the mailable already exists.'],
+
+ ['markdown', 'm', InputOption::VALUE_OPTIONAL, 'Create a new Markdown template for the mailable.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/ModelMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ModelMakeCommand.php
new file mode 100644
index 000000000..ab14f5930
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ModelMakeCommand.php
@@ -0,0 +1,122 @@
+option('force')) {
+ return;
+ }
+
+ if ($this->option('migration')) {
+ $this->createMigration();
+ }
+
+ if ($this->option('controller') || $this->option('resource')) {
+ $this->createController();
+ }
+ }
+
+ /**
+ * Create a migration file for the model.
+ *
+ * @return void
+ */
+ protected function createMigration()
+ {
+ $table = Str::plural(Str::snake(class_basename($this->argument('name'))));
+
+ $this->call('make:migration', [
+ 'name' => "create_{$table}_table",
+ '--create' => $table,
+ ]);
+ }
+
+ /**
+ * Create a controller for the model.
+ *
+ * @return void
+ */
+ protected function createController()
+ {
+ $controller = Str::studly(class_basename($this->argument('name')));
+
+ $modelName = $this->qualifyClass($this->getNameInput());
+
+ $this->call('make:controller', [
+ 'name' => "{$controller}Controller",
+ '--model' => $this->option('resource') ? $modelName : null,
+ ]);
+ }
+
+ /**
+ * Get the stub file for the generator.
+ *
+ * @return string
+ */
+ protected function getStub()
+ {
+ return __DIR__.'/stubs/model.stub';
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ return $rootNamespace;
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['force', 'f', InputOption::VALUE_NONE, 'Create the class even if the model already exists.'],
+
+ ['migration', 'm', InputOption::VALUE_NONE, 'Create a new migration file for the model.'],
+
+ ['controller', 'c', InputOption::VALUE_NONE, 'Create a new controller for the model.'],
+
+ ['resource', 'r', InputOption::VALUE_NONE, 'Indicates if the generated controller should be a resource controller.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/NotificationMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/NotificationMakeCommand.php
new file mode 100644
index 000000000..fd225bfe2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/NotificationMakeCommand.php
@@ -0,0 +1,116 @@
+option('force')) {
+ return;
+ }
+
+ if ($this->option('markdown')) {
+ $this->writeMarkdownTemplate();
+ }
+ }
+
+ /**
+ * Write the Markdown template for the mailable.
+ *
+ * @return void
+ */
+ protected function writeMarkdownTemplate()
+ {
+ $path = resource_path('views/'.str_replace('.', '/', $this->option('markdown'))).'.blade.php';
+
+ if (! $this->files->isDirectory(dirname($path))) {
+ $this->files->makeDirectory(dirname($path), 0755, true);
+ }
+
+ $this->files->put($path, file_get_contents(__DIR__.'/stubs/markdown.stub'));
+ }
+
+ /**
+ * Build the class with the given name.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function buildClass($name)
+ {
+ $class = parent::buildClass($name);
+
+ if ($this->option('markdown')) {
+ $class = str_replace('DummyView', $this->option('markdown'), $class);
+ }
+
+ return $class;
+ }
+
+ /**
+ * Get the stub file for the generator.
+ *
+ * @return string
+ */
+ protected function getStub()
+ {
+ return $this->option('markdown')
+ ? __DIR__.'/stubs/markdown-notification.stub'
+ : __DIR__.'/stubs/notification.stub';
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ return $rootNamespace.'\Notifications';
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['force', 'f', InputOption::VALUE_NONE, 'Create the class even if the notification already exists.'],
+
+ ['markdown', 'm', InputOption::VALUE_OPTIONAL, 'Create a new Markdown template for the notification.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/OptimizeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/OptimizeCommand.php
new file mode 100644
index 000000000..b64156e17
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/OptimizeCommand.php
@@ -0,0 +1,76 @@
+composer = $composer;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $this->info('Generating optimized class loader');
+
+ if ($this->option('psr')) {
+ $this->composer->dumpAutoloads();
+ } else {
+ $this->composer->dumpOptimized();
+ }
+
+ $this->call('clear-compiled');
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['force', null, InputOption::VALUE_NONE, 'Force the compiled class file to be written (deprecated).'],
+
+ ['psr', null, InputOption::VALUE_NONE, 'Do not optimize Composer dump-autoload.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/PolicyMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/PolicyMakeCommand.php
new file mode 100644
index 000000000..8e0063870
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/PolicyMakeCommand.php
@@ -0,0 +1,134 @@
+replaceUserNamespace(
+ parent::buildClass($name)
+ );
+
+ $model = $this->option('model');
+
+ return $model ? $this->replaceModel($stub, $model) : $stub;
+ }
+
+ /**
+ * Replace the User model namespace.
+ *
+ * @param string $stub
+ * @return string
+ */
+ protected function replaceUserNamespace($stub)
+ {
+ if (! config('auth.providers.users.model')) {
+ return $stub;
+ }
+
+ return str_replace(
+ $this->rootNamespace().'User',
+ config('auth.providers.users.model'),
+ $stub
+ );
+ }
+
+ /**
+ * Replace the model for the given stub.
+ *
+ * @param string $stub
+ * @param string $model
+ * @return string
+ */
+ protected function replaceModel($stub, $model)
+ {
+ $model = str_replace('/', '\\', $model);
+
+ $namespaceModel = $this->laravel->getNamespace().$model;
+
+ if (Str::startsWith($model, '\\')) {
+ $stub = str_replace('NamespacedDummyModel', trim($model, '\\'), $stub);
+ } else {
+ $stub = str_replace('NamespacedDummyModel', $namespaceModel, $stub);
+ }
+
+ $stub = str_replace(
+ "use {$namespaceModel};\nuse {$namespaceModel};", "use {$namespaceModel};", $stub
+ );
+
+ $model = class_basename(trim($model, '\\'));
+
+ $stub = str_replace('DummyModel', $model, $stub);
+
+ $stub = str_replace('dummyModel', Str::camel($model), $stub);
+
+ return str_replace('dummyPluralModel', Str::plural(Str::camel($model)), $stub);
+ }
+
+ /**
+ * Get the stub file for the generator.
+ *
+ * @return string
+ */
+ protected function getStub()
+ {
+ return $this->option('model')
+ ? __DIR__.'/stubs/policy.stub'
+ : __DIR__.'/stubs/policy.plain.stub';
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ return $rootNamespace.'\Policies';
+ }
+
+ /**
+ * Get the console command arguments.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['model', 'm', InputOption::VALUE_OPTIONAL, 'The model that the policy applies to.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/ProviderMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ProviderMakeCommand.php
new file mode 100644
index 000000000..fa887edb6
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ProviderMakeCommand.php
@@ -0,0 +1,50 @@
+data = $data;
+ }
+
+ /**
+ * Handle the job.
+ *
+ * @param \Illuminate\Contracts\Console\Kernel $kernel
+ * @return void
+ */
+ public function handle(KernelContract $kernel)
+ {
+ call_user_func_array([$kernel, 'call'], $this->data);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/RequestMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/RequestMakeCommand.php
new file mode 100644
index 000000000..95b7a87b9
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/RequestMakeCommand.php
@@ -0,0 +1,50 @@
+files = $files;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $this->call('route:clear');
+
+ $routes = $this->getFreshApplicationRoutes();
+
+ if (count($routes) == 0) {
+ return $this->error("Your application doesn't have any routes.");
+ }
+
+ foreach ($routes as $route) {
+ $route->prepareForSerialization();
+ }
+
+ $this->files->put(
+ $this->laravel->getCachedRoutesPath(), $this->buildRouteCacheFile($routes)
+ );
+
+ $this->info('Routes cached successfully!');
+ }
+
+ /**
+ * Boot a fresh copy of the application and get the routes.
+ *
+ * @return \Illuminate\Routing\RouteCollection
+ */
+ protected function getFreshApplicationRoutes()
+ {
+ return tap($this->getFreshApplication()['router']->getRoutes(), function ($routes) {
+ $routes->refreshNameLookups();
+ $routes->refreshActionLookups();
+ });
+ }
+
+ /**
+ * Get a fresh application instance.
+ *
+ * @return \Illuminate\Foundation\Application
+ */
+ protected function getFreshApplication()
+ {
+ return tap(require $this->laravel->bootstrapPath().'/app.php', function ($app) {
+ $app->make(ConsoleKernelContract::class)->bootstrap();
+ });
+ }
+
+ /**
+ * Build the route cache file.
+ *
+ * @param \Illuminate\Routing\RouteCollection $routes
+ * @return string
+ */
+ protected function buildRouteCacheFile(RouteCollection $routes)
+ {
+ $stub = $this->files->get(__DIR__.'/stubs/routes.stub');
+
+ return str_replace('{{routes}}', base64_encode(serialize($routes)), $stub);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/RouteClearCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/RouteClearCommand.php
new file mode 100644
index 000000000..a14b280ea
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/RouteClearCommand.php
@@ -0,0 +1,55 @@
+files = $files;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $this->files->delete($this->laravel->getCachedRoutesPath());
+
+ $this->info('Route cache cleared!');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/RouteListCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/RouteListCommand.php
new file mode 100644
index 000000000..701cc70b4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/RouteListCommand.php
@@ -0,0 +1,192 @@
+router = $router;
+ $this->routes = $router->getRoutes();
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ if (count($this->routes) == 0) {
+ return $this->error("Your application doesn't have any routes.");
+ }
+
+ $this->displayRoutes($this->getRoutes());
+ }
+
+ /**
+ * Compile the routes into a displayable format.
+ *
+ * @return array
+ */
+ protected function getRoutes()
+ {
+ $routes = collect($this->routes)->map(function ($route) {
+ return $this->getRouteInformation($route);
+ })->all();
+
+ if ($sort = $this->option('sort')) {
+ $routes = $this->sortRoutes($sort, $routes);
+ }
+
+ if ($this->option('reverse')) {
+ $routes = array_reverse($routes);
+ }
+
+ return array_filter($routes);
+ }
+
+ /**
+ * Get the route information for a given route.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @return array
+ */
+ protected function getRouteInformation(Route $route)
+ {
+ return $this->filterRoute([
+ 'host' => $route->domain(),
+ 'method' => implode('|', $route->methods()),
+ 'uri' => $route->uri(),
+ 'name' => $route->getName(),
+ 'action' => $route->getActionName(),
+ 'middleware' => $this->getMiddleware($route),
+ ]);
+ }
+
+ /**
+ * Sort the routes by a given element.
+ *
+ * @param string $sort
+ * @param array $routes
+ * @return array
+ */
+ protected function sortRoutes($sort, $routes)
+ {
+ return Arr::sort($routes, function ($route) use ($sort) {
+ return $route[$sort];
+ });
+ }
+
+ /**
+ * Display the route information on the console.
+ *
+ * @param array $routes
+ * @return void
+ */
+ protected function displayRoutes(array $routes)
+ {
+ $this->table($this->headers, $routes);
+ }
+
+ /**
+ * Get before filters.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @return string
+ */
+ protected function getMiddleware($route)
+ {
+ return collect($route->gatherMiddleware())->map(function ($middleware) {
+ return $middleware instanceof Closure ? 'Closure' : $middleware;
+ })->implode(',');
+ }
+
+ /**
+ * Filter the route by URI and / or name.
+ *
+ * @param array $route
+ * @return array|null
+ */
+ protected function filterRoute(array $route)
+ {
+ if (($this->option('name') && ! Str::contains($route['name'], $this->option('name'))) ||
+ $this->option('path') && ! Str::contains($route['uri'], $this->option('path')) ||
+ $this->option('method') && ! Str::contains($route['method'], $this->option('method'))) {
+ return;
+ }
+
+ return $route;
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['method', null, InputOption::VALUE_OPTIONAL, 'Filter the routes by method.'],
+
+ ['name', null, InputOption::VALUE_OPTIONAL, 'Filter the routes by name.'],
+
+ ['path', null, InputOption::VALUE_OPTIONAL, 'Filter the routes by path.'],
+
+ ['reverse', 'r', InputOption::VALUE_NONE, 'Reverse the ordering of the routes.'],
+
+ ['sort', null, InputOption::VALUE_OPTIONAL, 'The column (host, method, uri, name, action, middleware) to sort by.', 'uri'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/ServeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ServeCommand.php
new file mode 100644
index 000000000..927fa4244
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ServeCommand.php
@@ -0,0 +1,90 @@
+laravel->publicPath());
+
+ $this->line("Laravel development server started: host()}:{$this->port()}>");
+
+ passthru($this->serverCommand());
+ }
+
+ /**
+ * Get the full server command.
+ *
+ * @return string
+ */
+ protected function serverCommand()
+ {
+ return sprintf('%s -S %s:%s %s/server.php',
+ ProcessUtils::escapeArgument((new PhpExecutableFinder)->find(false)),
+ $this->host(),
+ $this->port(),
+ ProcessUtils::escapeArgument($this->laravel->basePath())
+ );
+ }
+
+ /**
+ * Get the host for the command.
+ *
+ * @return string
+ */
+ protected function host()
+ {
+ return $this->input->getOption('host');
+ }
+
+ /**
+ * Get the port for the command.
+ *
+ * @return string
+ */
+ protected function port()
+ {
+ return $this->input->getOption('port');
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['host', null, InputOption::VALUE_OPTIONAL, 'The host address to serve the application on.', '127.0.0.1'],
+
+ ['port', null, InputOption::VALUE_OPTIONAL, 'The port to serve the application on.', 8000],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/StorageLinkCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/StorageLinkCommand.php
new file mode 100644
index 000000000..ac29de9b2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/StorageLinkCommand.php
@@ -0,0 +1,40 @@
+error('The "public/storage" directory already exists.');
+ }
+
+ $this->laravel->make('files')->link(
+ storage_path('app/public'), public_path('storage')
+ );
+
+ $this->info('The [public/storage] directory has been linked.');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/TestMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/TestMakeCommand.php
new file mode 100644
index 000000000..3c6332304
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/TestMakeCommand.php
@@ -0,0 +1,81 @@
+option('unit')) {
+ return __DIR__.'/stubs/unit-test.stub';
+ } else {
+ return __DIR__.'/stubs/test.stub';
+ }
+ }
+
+ /**
+ * Get the destination class path.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function getPath($name)
+ {
+ $name = str_replace_first($this->rootNamespace(), '', $name);
+
+ return $this->laravel->basePath().'/tests'.str_replace('\\', '/', $name).'.php';
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ if ($this->option('unit')) {
+ return $rootNamespace.'\Unit';
+ } else {
+ return $rootNamespace.'\Feature';
+ }
+ }
+
+ /**
+ * Get the root namespace for the class.
+ *
+ * @return string
+ */
+ protected function rootNamespace()
+ {
+ return 'Tests';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/UpCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/UpCommand.php
new file mode 100644
index 000000000..82d838505
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/UpCommand.php
@@ -0,0 +1,34 @@
+laravel->storagePath().'/framework/down');
+
+ $this->info('Application is now live.');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/VendorPublishCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/VendorPublishCommand.php
new file mode 100644
index 000000000..73f1c3a3d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/VendorPublishCommand.php
@@ -0,0 +1,189 @@
+files = $files;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $tags = $this->option('tag') ?: [null];
+
+ foreach ((array) $tags as $tag) {
+ $this->publishTag($tag);
+ }
+ }
+
+ /**
+ * Publishes the assets for a tag.
+ *
+ * @param string $tag
+ * @return mixed
+ */
+ protected function publishTag($tag)
+ {
+ foreach ($this->pathsToPublish($tag) as $from => $to) {
+ $this->publishItem($from, $to);
+ }
+
+ $this->info('Publishing complete.');
+ }
+
+ /**
+ * Get all of the paths to publish.
+ *
+ * @param string $tag
+ * @return array
+ */
+ protected function pathsToPublish($tag)
+ {
+ return ServiceProvider::pathsToPublish(
+ $this->option('provider'), $tag
+ );
+ }
+
+ /**
+ * Publish the given item from and to the given location.
+ *
+ * @param string $from
+ * @param string $to
+ * @return void
+ */
+ protected function publishItem($from, $to)
+ {
+ if ($this->files->isFile($from)) {
+ return $this->publishFile($from, $to);
+ } elseif ($this->files->isDirectory($from)) {
+ return $this->publishDirectory($from, $to);
+ }
+
+ $this->error("Can't locate path: <{$from}>");
+ }
+
+ /**
+ * Publish the file to the given path.
+ *
+ * @param string $from
+ * @param string $to
+ * @return void
+ */
+ protected function publishFile($from, $to)
+ {
+ if (! $this->files->exists($to) || $this->option('force')) {
+ $this->createParentDirectory(dirname($to));
+
+ $this->files->copy($from, $to);
+
+ $this->status($from, $to, 'File');
+ }
+ }
+
+ /**
+ * Publish the directory to the given directory.
+ *
+ * @param string $from
+ * @param string $to
+ * @return void
+ */
+ protected function publishDirectory($from, $to)
+ {
+ $this->moveManagedFiles(new MountManager([
+ 'from' => new Flysystem(new LocalAdapter($from)),
+ 'to' => new Flysystem(new LocalAdapter($to)),
+ ]));
+
+ $this->status($from, $to, 'Directory');
+ }
+
+ /**
+ * Move all the files in the given MountManager.
+ *
+ * @param \League\Flysystem\MountManager $manager
+ * @return void
+ */
+ protected function moveManagedFiles($manager)
+ {
+ foreach ($manager->listContents('from://', true) as $file) {
+ if ($file['type'] === 'file' && (! $manager->has('to://'.$file['path']) || $this->option('force'))) {
+ $manager->put('to://'.$file['path'], $manager->read('from://'.$file['path']));
+ }
+ }
+ }
+
+ /**
+ * Create the directory to house the published files if needed.
+ *
+ * @param string $directory
+ * @return void
+ */
+ protected function createParentDirectory($directory)
+ {
+ if (! $this->files->isDirectory($directory)) {
+ $this->files->makeDirectory($directory, 0755, true);
+ }
+ }
+
+ /**
+ * Write a status message to the console.
+ *
+ * @param string $from
+ * @param string $to
+ * @param string $type
+ * @return void
+ */
+ protected function status($from, $to, $type)
+ {
+ $from = str_replace(base_path(), '', realpath($from));
+
+ $to = str_replace(base_path(), '', realpath($to));
+
+ $this->line('Copied '.$type.' ['.$from.'] To ['.$to.'] ');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/ViewClearCommand.php b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ViewClearCommand.php
new file mode 100644
index 000000000..c7e443e7d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/ViewClearCommand.php
@@ -0,0 +1,64 @@
+files = $files;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $path = $this->laravel['config']['view.compiled'];
+
+ if (! $path) {
+ throw new RuntimeException('View path not found.');
+ }
+
+ foreach ($this->files->glob("{$path}/*") as $view) {
+ $this->files->delete($view);
+ }
+
+ $this->info('Compiled views cleared!');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/console.stub b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/console.stub
new file mode 100644
index 000000000..9b770d9c2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/console.stub
@@ -0,0 +1,42 @@
+view('view.name');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown-mail.stub b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown-mail.stub
new file mode 100644
index 000000000..25a0cdc8d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown-mail.stub
@@ -0,0 +1,33 @@
+markdown('DummyView');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown-notification.stub b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown-notification.stub
new file mode 100644
index 000000000..f554b2c30
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown-notification.stub
@@ -0,0 +1,58 @@
+markdown('DummyView');
+ }
+
+ /**
+ * Get the array representation of the notification.
+ *
+ * @param mixed $notifiable
+ * @return array
+ */
+ public function toArray($notifiable)
+ {
+ return [
+ //
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown.stub b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown.stub
new file mode 100644
index 000000000..bc4142827
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/markdown.stub
@@ -0,0 +1,12 @@
+@component('mail::message')
+# Introduction
+
+The body of your message.
+
+@component('mail::button', ['url' => ''])
+Button Text
+@endcomponent
+
+Thanks,
+{{ config('app.name') }}
+@endcomponent
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/model.stub b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/model.stub
new file mode 100644
index 000000000..f01a83337
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/model.stub
@@ -0,0 +1,10 @@
+line('The introduction to the notification.')
+ ->action('Notification Action', url('/'))
+ ->line('Thank you for using our application!');
+ }
+
+ /**
+ * Get the array representation of the notification.
+ *
+ * @param mixed $notifiable
+ * @return array
+ */
+ public function toArray($notifiable)
+ {
+ return [
+ //
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/policy.plain.stub b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/policy.plain.stub
new file mode 100644
index 000000000..e8221befc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/policy.plain.stub
@@ -0,0 +1,21 @@
+setRoutes(
+ unserialize(base64_decode('{{routes}}'))
+);
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/test.stub b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/test.stub
new file mode 100644
index 000000000..dd804dc9a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/test.stub
@@ -0,0 +1,21 @@
+assertTrue(true);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/unit-test.stub b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/unit-test.stub
new file mode 100644
index 000000000..315e70780
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Console/stubs/unit-test.stub
@@ -0,0 +1,20 @@
+assertTrue(true);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/EnvironmentDetector.php b/vendor/laravel/framework/src/Illuminate/Foundation/EnvironmentDetector.php
new file mode 100644
index 000000000..205f73bc1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/EnvironmentDetector.php
@@ -0,0 +1,69 @@
+detectConsoleEnvironment($callback, $consoleArgs);
+ }
+
+ return $this->detectWebEnvironment($callback);
+ }
+
+ /**
+ * Set the application environment for a web request.
+ *
+ * @param \Closure $callback
+ * @return string
+ */
+ protected function detectWebEnvironment(Closure $callback)
+ {
+ return call_user_func($callback);
+ }
+
+ /**
+ * Set the application environment from command-line arguments.
+ *
+ * @param \Closure $callback
+ * @param array $args
+ * @return string
+ */
+ protected function detectConsoleEnvironment(Closure $callback, array $args)
+ {
+ // First we will check if an environment argument was passed via console arguments
+ // and if it was that automatically overrides as the environment. Otherwise, we
+ // will check the environment as a "web" request like a typical HTTP request.
+ if (! is_null($value = $this->getEnvironmentArgument($args))) {
+ return head(array_slice(explode('=', $value), 1));
+ }
+
+ return $this->detectWebEnvironment($callback);
+ }
+
+ /**
+ * Get the environment argument from the console.
+ *
+ * @param array $args
+ * @return string|null
+ */
+ protected function getEnvironmentArgument(array $args)
+ {
+ return Arr::first($args, function ($value) {
+ return Str::startsWith($value, '--env');
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Events/Dispatchable.php b/vendor/laravel/framework/src/Illuminate/Foundation/Events/Dispatchable.php
new file mode 100644
index 000000000..0018295b6
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Events/Dispatchable.php
@@ -0,0 +1,26 @@
+locale = $locale;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Exceptions/Handler.php b/vendor/laravel/framework/src/Illuminate/Foundation/Exceptions/Handler.php
new file mode 100644
index 000000000..f737c6734
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Exceptions/Handler.php
@@ -0,0 +1,256 @@
+container = $container;
+ }
+
+ /**
+ * Report or log an exception.
+ *
+ * @param \Exception $e
+ * @return void
+ *
+ * @throws \Exception
+ */
+ public function report(Exception $e)
+ {
+ if ($this->shouldntReport($e)) {
+ return;
+ }
+
+ try {
+ $logger = $this->container->make(LoggerInterface::class);
+ } catch (Exception $ex) {
+ throw $e; // throw the original exception
+ }
+
+ $logger->error($e);
+ }
+
+ /**
+ * Determine if the exception should be reported.
+ *
+ * @param \Exception $e
+ * @return bool
+ */
+ public function shouldReport(Exception $e)
+ {
+ return ! $this->shouldntReport($e);
+ }
+
+ /**
+ * Determine if the exception is in the "do not report" list.
+ *
+ * @param \Exception $e
+ * @return bool
+ */
+ protected function shouldntReport(Exception $e)
+ {
+ $dontReport = array_merge($this->dontReport, [HttpResponseException::class]);
+
+ return ! is_null(collect($dontReport)->first(function ($type) use ($e) {
+ return $e instanceof $type;
+ }));
+ }
+
+ /**
+ * Render an exception into a response.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Exception $e
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ public function render($request, Exception $e)
+ {
+ $e = $this->prepareException($e);
+
+ if ($e instanceof HttpResponseException) {
+ return $e->getResponse();
+ } elseif ($e instanceof AuthenticationException) {
+ return $this->unauthenticated($request, $e);
+ } elseif ($e instanceof ValidationException) {
+ return $this->convertValidationExceptionToResponse($e, $request);
+ }
+
+ return $this->prepareResponse($request, $e);
+ }
+
+ /**
+ * Prepare exception for rendering.
+ *
+ * @param \Exception $e
+ * @return \Exception
+ */
+ protected function prepareException(Exception $e)
+ {
+ if ($e instanceof ModelNotFoundException) {
+ $e = new NotFoundHttpException($e->getMessage(), $e);
+ } elseif ($e instanceof AuthorizationException) {
+ $e = new HttpException(403, $e->getMessage());
+ }
+
+ return $e;
+ }
+
+ /**
+ * Create a response object from the given validation exception.
+ *
+ * @param \Illuminate\Validation\ValidationException $e
+ * @param \Illuminate\Http\Request $request
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function convertValidationExceptionToResponse(ValidationException $e, $request)
+ {
+ if ($e->response) {
+ return $e->response;
+ }
+
+ $errors = $e->validator->errors()->getMessages();
+
+ if ($request->expectsJson()) {
+ return response()->json($errors, 422);
+ }
+
+ return redirect()->back()->withInput(
+ $request->input()
+ )->withErrors($errors);
+ }
+
+ /**
+ * Prepare response containing exception render.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Exception $e
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function prepareResponse($request, Exception $e)
+ {
+ if ($this->isHttpException($e)) {
+ return $this->toIlluminateResponse($this->renderHttpException($e), $e);
+ } else {
+ return $this->toIlluminateResponse($this->convertExceptionToResponse($e), $e);
+ }
+ }
+
+ /**
+ * Render the given HttpException.
+ *
+ * @param \Symfony\Component\HttpKernel\Exception\HttpException $e
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function renderHttpException(HttpException $e)
+ {
+ $status = $e->getStatusCode();
+
+ view()->replaceNamespace('errors', [
+ resource_path('views/errors'),
+ __DIR__.'/views',
+ ]);
+
+ if (view()->exists("errors::{$status}")) {
+ return response()->view("errors::{$status}", ['exception' => $e], $status, $e->getHeaders());
+ } else {
+ return $this->convertExceptionToResponse($e);
+ }
+ }
+
+ /**
+ * Create a Symfony response for the given exception.
+ *
+ * @param \Exception $e
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function convertExceptionToResponse(Exception $e)
+ {
+ $e = FlattenException::create($e);
+
+ $handler = new SymfonyExceptionHandler(config('app.debug', false));
+
+ return SymfonyResponse::create($handler->getHtml($e), $e->getStatusCode(), $e->getHeaders());
+ }
+
+ /**
+ * Map the given exception into an Illuminate response.
+ *
+ * @param \Symfony\Component\HttpFoundation\Response $response
+ * @param \Exception $e
+ * @return \Illuminate\Http\Response
+ */
+ protected function toIlluminateResponse($response, Exception $e)
+ {
+ if ($response instanceof SymfonyRedirectResponse) {
+ $response = new RedirectResponse($response->getTargetUrl(), $response->getStatusCode(), $response->headers->all());
+ } else {
+ $response = new Response($response->getContent(), $response->getStatusCode(), $response->headers->all());
+ }
+
+ return $response->withException($e);
+ }
+
+ /**
+ * Render an exception to the console.
+ *
+ * @param \Symfony\Component\Console\Output\OutputInterface $output
+ * @param \Exception $e
+ * @return void
+ */
+ public function renderForConsole($output, Exception $e)
+ {
+ (new ConsoleApplication)->renderException($e, $output);
+ }
+
+ /**
+ * Determine if the given exception is an HTTP exception.
+ *
+ * @param \Exception $e
+ * @return bool
+ */
+ protected function isHttpException(Exception $e)
+ {
+ return $e instanceof HttpException;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Exceptions/views/503.blade.php b/vendor/laravel/framework/src/Illuminate/Foundation/Exceptions/views/503.blade.php
new file mode 100644
index 000000000..14098cbc0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Exceptions/views/503.blade.php
@@ -0,0 +1,56 @@
+
+
+
+
+
+
+
+ Service Unavailable
+
+
+
+
+
+
+
+
+
+
+
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Http/Events/RequestHandled.php b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Events/RequestHandled.php
new file mode 100644
index 000000000..d6f71e03f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Events/RequestHandled.php
@@ -0,0 +1,33 @@
+request = $request;
+ $this->response = $response;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Http/Exceptions/MaintenanceModeException.php b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Exceptions/MaintenanceModeException.php
new file mode 100644
index 000000000..6ee1de62f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Exceptions/MaintenanceModeException.php
@@ -0,0 +1,54 @@
+wentDownAt = Carbon::createFromTimestamp($time);
+
+ if ($retryAfter) {
+ $this->retryAfter = $retryAfter;
+
+ $this->willBeAvailableAt = Carbon::createFromTimestamp($time)->addSeconds($this->retryAfter);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Http/FormRequest.php b/vendor/laravel/framework/src/Illuminate/Foundation/Http/FormRequest.php
new file mode 100644
index 000000000..de2ef7d62
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Http/FormRequest.php
@@ -0,0 +1,249 @@
+container->make(ValidationFactory::class);
+
+ if (method_exists($this, 'validator')) {
+ $validator = $this->container->call([$this, 'validator'], compact('factory'));
+ } else {
+ $validator = $this->createDefaultValidator($factory);
+ }
+
+ if (method_exists($this, 'withValidator')) {
+ $this->withValidator($validator);
+ }
+
+ return $validator;
+ }
+
+ /**
+ * Create the default validator instance.
+ *
+ * @param \Illuminate\Contracts\Validation\Factory $factory
+ * @return \Illuminate\Contracts\Validation\Validator
+ */
+ protected function createDefaultValidator(ValidationFactory $factory)
+ {
+ return $factory->make(
+ $this->validationData(), $this->container->call([$this, 'rules']),
+ $this->messages(), $this->attributes()
+ );
+ }
+
+ /**
+ * Get data to be validated from the request.
+ *
+ * @return array
+ */
+ protected function validationData()
+ {
+ return $this->all();
+ }
+
+ /**
+ * Handle a failed validation attempt.
+ *
+ * @param \Illuminate\Contracts\Validation\Validator $validator
+ * @return void
+ *
+ * @throws \Illuminate\Validation\ValidationException
+ */
+ protected function failedValidation(Validator $validator)
+ {
+ throw new ValidationException($validator, $this->response(
+ $this->formatErrors($validator)
+ ));
+ }
+
+ /**
+ * Get the proper failed validation response for the request.
+ *
+ * @param array $errors
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ public function response(array $errors)
+ {
+ if ($this->expectsJson()) {
+ return new JsonResponse($errors, 422);
+ }
+
+ return $this->redirector->to($this->getRedirectUrl())
+ ->withInput($this->except($this->dontFlash))
+ ->withErrors($errors, $this->errorBag);
+ }
+
+ /**
+ * Format the errors from the given Validator instance.
+ *
+ * @param \Illuminate\Contracts\Validation\Validator $validator
+ * @return array
+ */
+ protected function formatErrors(Validator $validator)
+ {
+ return $validator->getMessageBag()->toArray();
+ }
+
+ /**
+ * Get the URL to redirect to on a validation error.
+ *
+ * @return string
+ */
+ protected function getRedirectUrl()
+ {
+ $url = $this->redirector->getUrlGenerator();
+
+ if ($this->redirect) {
+ return $url->to($this->redirect);
+ } elseif ($this->redirectRoute) {
+ return $url->route($this->redirectRoute);
+ } elseif ($this->redirectAction) {
+ return $url->action($this->redirectAction);
+ }
+
+ return $url->previous();
+ }
+
+ /**
+ * Determine if the request passes the authorization check.
+ *
+ * @return bool
+ */
+ protected function passesAuthorization()
+ {
+ if (method_exists($this, 'authorize')) {
+ return $this->container->call([$this, 'authorize']);
+ }
+
+ return false;
+ }
+
+ /**
+ * Handle a failed authorization attempt.
+ *
+ * @return void
+ *
+ * @throws \Illuminate\Auth\Access\AuthorizationException
+ */
+ protected function failedAuthorization()
+ {
+ throw new AuthorizationException('This action is unauthorized.');
+ }
+
+ /**
+ * Get custom messages for validator errors.
+ *
+ * @return array
+ */
+ public function messages()
+ {
+ return [];
+ }
+
+ /**
+ * Get custom attributes for validator errors.
+ *
+ * @return array
+ */
+ public function attributes()
+ {
+ return [];
+ }
+
+ /**
+ * Set the Redirector instance.
+ *
+ * @param \Illuminate\Routing\Redirector $redirector
+ * @return $this
+ */
+ public function setRedirector(Redirector $redirector)
+ {
+ $this->redirector = $redirector;
+
+ return $this;
+ }
+
+ /**
+ * Set the container implementation.
+ *
+ * @param \Illuminate\Contracts\Container\Container $container
+ * @return $this
+ */
+ public function setContainer(Container $container)
+ {
+ $this->container = $container;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Http/Kernel.php b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Kernel.php
new file mode 100644
index 000000000..f37583284
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Kernel.php
@@ -0,0 +1,338 @@
+app = $app;
+ $this->router = $router;
+
+ $router->middlewarePriority = $this->middlewarePriority;
+
+ foreach ($this->middlewareGroups as $key => $middleware) {
+ $router->middlewareGroup($key, $middleware);
+ }
+
+ foreach ($this->routeMiddleware as $key => $middleware) {
+ $router->aliasMiddleware($key, $middleware);
+ }
+ }
+
+ /**
+ * Handle an incoming HTTP request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Http\Response
+ */
+ public function handle($request)
+ {
+ try {
+ $request->enableHttpMethodParameterOverride();
+
+ $response = $this->sendRequestThroughRouter($request);
+ } catch (Exception $e) {
+ $this->reportException($e);
+
+ $response = $this->renderException($request, $e);
+ } catch (Throwable $e) {
+ $this->reportException($e = new FatalThrowableError($e));
+
+ $response = $this->renderException($request, $e);
+ }
+
+ $this->app['events']->dispatch(
+ new Events\RequestHandled($request, $response)
+ );
+
+ return $response;
+ }
+
+ /**
+ * Send the given request through the middleware / router.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Http\Response
+ */
+ protected function sendRequestThroughRouter($request)
+ {
+ $this->app->instance('request', $request);
+
+ Facade::clearResolvedInstance('request');
+
+ $this->bootstrap();
+
+ return (new Pipeline($this->app))
+ ->send($request)
+ ->through($this->app->shouldSkipMiddleware() ? [] : $this->middleware)
+ ->then($this->dispatchToRouter());
+ }
+
+ /**
+ * Bootstrap the application for HTTP requests.
+ *
+ * @return void
+ */
+ public function bootstrap()
+ {
+ if (! $this->app->hasBeenBootstrapped()) {
+ $this->app->bootstrapWith($this->bootstrappers());
+ }
+ }
+
+ /**
+ * Get the route dispatcher callback.
+ *
+ * @return \Closure
+ */
+ protected function dispatchToRouter()
+ {
+ return function ($request) {
+ $this->app->instance('request', $request);
+
+ return $this->router->dispatch($request);
+ };
+ }
+
+ /**
+ * Call the terminate method on any terminable middleware.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Illuminate\Http\Response $response
+ * @return void
+ */
+ public function terminate($request, $response)
+ {
+ $this->terminateMiddleware($request, $response);
+
+ $this->app->terminate();
+ }
+
+ /**
+ * Call the terminate method on any terminable middleware.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Illuminate\Http\Response $response
+ * @return void
+ */
+ protected function terminateMiddleware($request, $response)
+ {
+ $middlewares = $this->app->shouldSkipMiddleware() ? [] : array_merge(
+ $this->gatherRouteMiddleware($request),
+ $this->middleware
+ );
+
+ foreach ($middlewares as $middleware) {
+ if (! is_string($middleware)) {
+ continue;
+ }
+
+ list($name, $parameters) = $this->parseMiddleware($middleware);
+
+ $instance = $this->app->make($name);
+
+ if (method_exists($instance, 'terminate')) {
+ $instance->terminate($request, $response);
+ }
+ }
+ }
+
+ /**
+ * Gather the route middleware for the given request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return array
+ */
+ protected function gatherRouteMiddleware($request)
+ {
+ if ($route = $request->route()) {
+ return $this->router->gatherRouteMiddleware($route);
+ }
+
+ return [];
+ }
+
+ /**
+ * Parse a middleware string to get the name and parameters.
+ *
+ * @param string $middleware
+ * @return array
+ */
+ protected function parseMiddleware($middleware)
+ {
+ list($name, $parameters) = array_pad(explode(':', $middleware, 2), 2, []);
+
+ if (is_string($parameters)) {
+ $parameters = explode(',', $parameters);
+ }
+
+ return [$name, $parameters];
+ }
+
+ /**
+ * Determine if the kernel has a given middleware.
+ *
+ * @param string $middleware
+ * @return bool
+ */
+ public function hasMiddleware($middleware)
+ {
+ return in_array($middleware, $this->middleware);
+ }
+
+ /**
+ * Add a new middleware to beginning of the stack if it does not already exist.
+ *
+ * @param string $middleware
+ * @return $this
+ */
+ public function prependMiddleware($middleware)
+ {
+ if (array_search($middleware, $this->middleware) === false) {
+ array_unshift($this->middleware, $middleware);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a new middleware to end of the stack if it does not already exist.
+ *
+ * @param string $middleware
+ * @return $this
+ */
+ public function pushMiddleware($middleware)
+ {
+ if (array_search($middleware, $this->middleware) === false) {
+ $this->middleware[] = $middleware;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Get the bootstrap classes for the application.
+ *
+ * @return array
+ */
+ protected function bootstrappers()
+ {
+ return $this->bootstrappers;
+ }
+
+ /**
+ * Report the exception to the exception handler.
+ *
+ * @param \Exception $e
+ * @return void
+ */
+ protected function reportException(Exception $e)
+ {
+ $this->app[ExceptionHandler::class]->report($e);
+ }
+
+ /**
+ * Render the exception to a response.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Exception $e
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function renderException($request, Exception $e)
+ {
+ return $this->app[ExceptionHandler::class]->render($request, $e);
+ }
+
+ /**
+ * Get the Laravel application instance.
+ *
+ * @return \Illuminate\Contracts\Foundation\Application
+ */
+ public function getApplication()
+ {
+ return $this->app;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/CheckForMaintenanceMode.php b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/CheckForMaintenanceMode.php
new file mode 100644
index 000000000..6de75096d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/CheckForMaintenanceMode.php
@@ -0,0 +1,48 @@
+app = $app;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @return mixed
+ *
+ * @throws \Symfony\Component\HttpKernel\Exception\HttpException
+ */
+ public function handle($request, Closure $next)
+ {
+ if ($this->app->isDownForMaintenance()) {
+ $data = json_decode(file_get_contents($this->app->storagePath().'/framework/down'), true);
+
+ throw new MaintenanceModeException($data['time'], $data['retry'], $data['message']);
+ }
+
+ return $next($request);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ConvertEmptyStringsToNull.php b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ConvertEmptyStringsToNull.php
new file mode 100644
index 000000000..813c9cf12
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ConvertEmptyStringsToNull.php
@@ -0,0 +1,18 @@
+attributes = $attributes;
+
+ $this->clean($request);
+
+ return $next($request);
+ }
+
+ /**
+ * Clean the request's data.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ protected function clean($request)
+ {
+ $this->cleanParameterBag($request->query);
+
+ if ($request->isJson()) {
+ $this->cleanParameterBag($request->json());
+ } else {
+ $this->cleanParameterBag($request->request);
+ }
+ }
+
+ /**
+ * Clean the data in the parameter bag.
+ *
+ * @param \Symfony\Component\HttpFoundation\ParameterBag $bag
+ * @return void
+ */
+ protected function cleanParameterBag(ParameterBag $bag)
+ {
+ $bag->replace($this->cleanArray($bag->all()));
+ }
+
+ /**
+ * Clean the data in the given array.
+ *
+ * @param array $data
+ * @return array
+ */
+ protected function cleanArray(array $data)
+ {
+ return collect($data)->map(function ($value, $key) {
+ return $this->cleanValue($key, $value);
+ })->all();
+ }
+
+ /**
+ * Clean the given value.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function cleanValue($key, $value)
+ {
+ if (is_array($value)) {
+ return $this->cleanArray($value);
+ }
+
+ return $this->transform($key, $value);
+ }
+
+ /**
+ * Transform the given value.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function transform($key, $value)
+ {
+ return $value;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/TrimStrings.php b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/TrimStrings.php
new file mode 100644
index 000000000..4c8d1ddba
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/TrimStrings.php
@@ -0,0 +1,31 @@
+except, true)) {
+ return $value;
+ }
+
+ return is_string($value) ? trim($value) : $value;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ValidatePostSize.php b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ValidatePostSize.php
new file mode 100644
index 000000000..d952b0c04
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/ValidatePostSize.php
@@ -0,0 +1,54 @@
+getPostMaxSize();
+
+ if ($max > 0 && $request->server('CONTENT_LENGTH') > $max) {
+ throw new PostTooLargeException;
+ }
+
+ return $next($request);
+ }
+
+ /**
+ * Determine the server 'post_max_size' as bytes.
+ *
+ * @return int
+ */
+ protected function getPostMaxSize()
+ {
+ if (is_numeric($postMaxSize = ini_get('post_max_size'))) {
+ return (int) $postMaxSize;
+ }
+
+ $metric = strtoupper(substr($postMaxSize, -1));
+
+ switch ($metric) {
+ case 'K':
+ return (int) $postMaxSize * 1024;
+ case 'M':
+ return (int) $postMaxSize * 1048576;
+ case 'G':
+ return (int) $postMaxSize * 1073741824;
+ default:
+ return (int) $postMaxSize;
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/VerifyCsrfToken.php b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/VerifyCsrfToken.php
new file mode 100644
index 000000000..9424f73aa
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Http/Middleware/VerifyCsrfToken.php
@@ -0,0 +1,165 @@
+app = $app;
+ $this->encrypter = $encrypter;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @return mixed
+ *
+ * @throws \Illuminate\Session\TokenMismatchException
+ */
+ public function handle($request, Closure $next)
+ {
+ if (
+ $this->isReading($request) ||
+ $this->runningUnitTests() ||
+ $this->inExceptArray($request) ||
+ $this->tokensMatch($request)
+ ) {
+ return $this->addCookieToResponse($request, $next($request));
+ }
+
+ throw new TokenMismatchException;
+ }
+
+ /**
+ * Determine if the HTTP request uses a ‘read’ verb.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return bool
+ */
+ protected function isReading($request)
+ {
+ return in_array($request->method(), ['HEAD', 'GET', 'OPTIONS']);
+ }
+
+ /**
+ * Determine if the application is running unit tests.
+ *
+ * @return bool
+ */
+ protected function runningUnitTests()
+ {
+ return $this->app->runningInConsole() && $this->app->runningUnitTests();
+ }
+
+ /**
+ * Determine if the request has a URI that should pass through CSRF verification.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return bool
+ */
+ protected function inExceptArray($request)
+ {
+ foreach ($this->except as $except) {
+ if ($except !== '/') {
+ $except = trim($except, '/');
+ }
+
+ if ($request->is($except)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Determine if the session and input CSRF tokens match.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return bool
+ */
+ protected function tokensMatch($request)
+ {
+ $token = $this->getTokenFromRequest($request);
+
+ return is_string($request->session()->token()) &&
+ is_string($token) &&
+ hash_equals($request->session()->token(), $token);
+ }
+
+ /**
+ * Get the CSRF token from the request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return string
+ */
+ protected function getTokenFromRequest($request)
+ {
+ $token = $request->input('_token') ?: $request->header('X-CSRF-TOKEN');
+
+ if (! $token && $header = $request->header('X-XSRF-TOKEN')) {
+ $token = $this->encrypter->decrypt($header);
+ }
+
+ return $token;
+ }
+
+ /**
+ * Add the CSRF token to the response cookies.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Symfony\Component\HttpFoundation\Response $response
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function addCookieToResponse($request, $response)
+ {
+ $config = config('session');
+
+ $response->headers->setCookie(
+ new Cookie(
+ 'XSRF-TOKEN', $request->session()->token(), Carbon::now()->getTimestamp() + 60 * $config['lifetime'],
+ $config['path'], $config['domain'], $config['secure'], false
+ )
+ );
+
+ return $response;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Inspiring.php b/vendor/laravel/framework/src/Illuminate/Foundation/Inspiring.php
new file mode 100644
index 000000000..5216088a6
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Inspiring.php
@@ -0,0 +1,34 @@
+random();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/ProviderRepository.php b/vendor/laravel/framework/src/Illuminate/Foundation/ProviderRepository.php
new file mode 100644
index 000000000..e29bb3c36
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/ProviderRepository.php
@@ -0,0 +1,210 @@
+app = $app;
+ $this->files = $files;
+ $this->manifestPath = $manifestPath;
+ }
+
+ /**
+ * Register the application service providers.
+ *
+ * @param array $providers
+ * @return void
+ */
+ public function load(array $providers)
+ {
+ $manifest = $this->loadManifest();
+
+ // First we will load the service manifest, which contains information on all
+ // service providers registered with the application and which services it
+ // provides. This is used to know which services are "deferred" loaders.
+ if ($this->shouldRecompile($manifest, $providers)) {
+ $manifest = $this->compileManifest($providers);
+ }
+
+ // Next, we will register events to load the providers for each of the events
+ // that it has requested. This allows the service provider to defer itself
+ // while still getting automatically loaded when a certain event occurs.
+ foreach ($manifest['when'] as $provider => $events) {
+ $this->registerLoadEvents($provider, $events);
+ }
+
+ // We will go ahead and register all of the eagerly loaded providers with the
+ // application so their services can be registered with the application as
+ // a provided service. Then we will set the deferred service list on it.
+ foreach ($manifest['eager'] as $provider) {
+ $this->app->register($provider);
+ }
+
+ $this->app->addDeferredServices($manifest['deferred']);
+ }
+
+ /**
+ * Load the service provider manifest JSON file.
+ *
+ * @return array|null
+ */
+ public function loadManifest()
+ {
+ // The service manifest is a file containing a JSON representation of every
+ // service provided by the application and whether its provider is using
+ // deferred loading or should be eagerly loaded on each request to us.
+ if ($this->files->exists($this->manifestPath)) {
+ $manifest = $this->files->getRequire($this->manifestPath);
+
+ if ($manifest) {
+ return array_merge(['when' => []], $manifest);
+ }
+ }
+ }
+
+ /**
+ * Determine if the manifest should be compiled.
+ *
+ * @param array $manifest
+ * @param array $providers
+ * @return bool
+ */
+ public function shouldRecompile($manifest, $providers)
+ {
+ return is_null($manifest) || $manifest['providers'] != $providers;
+ }
+
+ /**
+ * Register the load events for the given provider.
+ *
+ * @param string $provider
+ * @param array $events
+ * @return void
+ */
+ protected function registerLoadEvents($provider, array $events)
+ {
+ if (count($events) < 1) {
+ return;
+ }
+
+ $this->app->make('events')->listen($events, function () use ($provider) {
+ $this->app->register($provider);
+ });
+ }
+
+ /**
+ * Compile the application service manifest file.
+ *
+ * @param array $providers
+ * @return array
+ */
+ protected function compileManifest($providers)
+ {
+ // The service manifest should contain a list of all of the providers for
+ // the application so we can compare it on each request to the service
+ // and determine if the manifest should be recompiled or is current.
+ $manifest = $this->freshManifest($providers);
+
+ foreach ($providers as $provider) {
+ $instance = $this->createProvider($provider);
+
+ // When recompiling the service manifest, we will spin through each of the
+ // providers and check if it's a deferred provider or not. If so we'll
+ // add it's provided services to the manifest and note the provider.
+ if ($instance->isDeferred()) {
+ foreach ($instance->provides() as $service) {
+ $manifest['deferred'][$service] = $provider;
+ }
+
+ $manifest['when'][$provider] = $instance->when();
+ }
+
+ // If the service providers are not deferred, we will simply add it to an
+ // array of eagerly loaded providers that will get registered on every
+ // request to this application instead of "lazy" loading every time.
+ else {
+ $manifest['eager'][] = $provider;
+ }
+ }
+
+ return $this->writeManifest($manifest);
+ }
+
+ /**
+ * Create a fresh service manifest data structure.
+ *
+ * @param array $providers
+ * @return array
+ */
+ protected function freshManifest(array $providers)
+ {
+ return ['providers' => $providers, 'eager' => [], 'deferred' => []];
+ }
+
+ /**
+ * Write the service manifest file to disk.
+ *
+ * @param array $manifest
+ * @return array
+ *
+ * @throws \Exception
+ */
+ public function writeManifest($manifest)
+ {
+ if (! is_writable(dirname($this->manifestPath))) {
+ throw new Exception('The bootstrap/cache directory must be present and writable.');
+ }
+
+ $this->files->put(
+ $this->manifestPath, ' []], $manifest);
+ }
+
+ /**
+ * Create a new provider instance.
+ *
+ * @param string $provider
+ * @return \Illuminate\Support\ServiceProvider
+ */
+ public function createProvider($provider)
+ {
+ return new $provider($this->app);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Providers/ArtisanServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Foundation/Providers/ArtisanServiceProvider.php
new file mode 100644
index 000000000..411c508f2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Providers/ArtisanServiceProvider.php
@@ -0,0 +1,869 @@
+ 'command.cache.clear',
+ 'CacheForget' => 'command.cache.forget',
+ 'ClearCompiled' => 'command.clear-compiled',
+ 'ClearResets' => 'command.auth.resets.clear',
+ 'ConfigCache' => 'command.config.cache',
+ 'ConfigClear' => 'command.config.clear',
+ 'Down' => 'command.down',
+ 'Environment' => 'command.environment',
+ 'KeyGenerate' => 'command.key.generate',
+ 'Migrate' => 'command.migrate',
+ 'MigrateInstall' => 'command.migrate.install',
+ 'MigrateRefresh' => 'command.migrate.refresh',
+ 'MigrateReset' => 'command.migrate.reset',
+ 'MigrateRollback' => 'command.migrate.rollback',
+ 'MigrateStatus' => 'command.migrate.status',
+ 'Optimize' => 'command.optimize',
+ 'QueueFailed' => 'command.queue.failed',
+ 'QueueFlush' => 'command.queue.flush',
+ 'QueueForget' => 'command.queue.forget',
+ 'QueueListen' => 'command.queue.listen',
+ 'QueueRestart' => 'command.queue.restart',
+ 'QueueRetry' => 'command.queue.retry',
+ 'QueueWork' => 'command.queue.work',
+ 'RouteCache' => 'command.route.cache',
+ 'RouteClear' => 'command.route.clear',
+ 'RouteList' => 'command.route.list',
+ 'Seed' => 'command.seed',
+ 'ScheduleFinish' => ScheduleFinishCommand::class,
+ 'ScheduleRun' => ScheduleRunCommand::class,
+ 'StorageLink' => 'command.storage.link',
+ 'Up' => 'command.up',
+ 'ViewClear' => 'command.view.clear',
+ ];
+
+ /**
+ * The commands to be registered.
+ *
+ * @var array
+ */
+ protected $devCommands = [
+ 'AppName' => 'command.app.name',
+ 'AuthMake' => 'command.auth.make',
+ 'CacheTable' => 'command.cache.table',
+ 'ConsoleMake' => 'command.console.make',
+ 'ControllerMake' => 'command.controller.make',
+ 'EventGenerate' => 'command.event.generate',
+ 'EventMake' => 'command.event.make',
+ 'JobMake' => 'command.job.make',
+ 'ListenerMake' => 'command.listener.make',
+ 'MailMake' => 'command.mail.make',
+ 'MiddlewareMake' => 'command.middleware.make',
+ 'MigrateMake' => 'command.migrate.make',
+ 'ModelMake' => 'command.model.make',
+ 'NotificationMake' => 'command.notification.make',
+ 'NotificationTable' => 'command.notification.table',
+ 'PolicyMake' => 'command.policy.make',
+ 'ProviderMake' => 'command.provider.make',
+ 'QueueFailedTable' => 'command.queue.failed-table',
+ 'QueueTable' => 'command.queue.table',
+ 'RequestMake' => 'command.request.make',
+ 'SeederMake' => 'command.seeder.make',
+ 'SessionTable' => 'command.session.table',
+ 'Serve' => 'command.serve',
+ 'TestMake' => 'command.test.make',
+ 'VendorPublish' => 'command.vendor.publish',
+ ];
+
+ /**
+ * Register the service provider.
+ *
+ * @return void
+ */
+ public function register()
+ {
+ $this->registerCommands(array_merge(
+ $this->commands, $this->devCommands
+ ));
+ }
+
+ /**
+ * Register the given commands.
+ *
+ * @param array $commands
+ * @return void
+ */
+ protected function registerCommands(array $commands)
+ {
+ foreach (array_keys($commands) as $command) {
+ call_user_func_array([$this, "register{$command}Command"], []);
+ }
+
+ $this->commands(array_values($commands));
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerAppNameCommand()
+ {
+ $this->app->singleton('command.app.name', function ($app) {
+ return new AppNameCommand($app['composer'], $app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerAuthMakeCommand()
+ {
+ $this->app->singleton('command.auth.make', function ($app) {
+ return new AuthMakeCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerCacheClearCommand()
+ {
+ $this->app->singleton('command.cache.clear', function ($app) {
+ return new CacheClearCommand($app['cache']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerCacheForgetCommand()
+ {
+ $this->app->singleton('command.cache.forget', function ($app) {
+ return new CacheForgetCommand($app['cache']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerCacheTableCommand()
+ {
+ $this->app->singleton('command.cache.table', function ($app) {
+ return new CacheTableCommand($app['files'], $app['composer']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerClearCompiledCommand()
+ {
+ $this->app->singleton('command.clear-compiled', function () {
+ return new ClearCompiledCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerClearResetsCommand()
+ {
+ $this->app->singleton('command.auth.resets.clear', function () {
+ return new ClearResetsCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerConfigCacheCommand()
+ {
+ $this->app->singleton('command.config.cache', function ($app) {
+ return new ConfigCacheCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerConfigClearCommand()
+ {
+ $this->app->singleton('command.config.clear', function ($app) {
+ return new ConfigClearCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerConsoleMakeCommand()
+ {
+ $this->app->singleton('command.console.make', function ($app) {
+ return new ConsoleMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerControllerMakeCommand()
+ {
+ $this->app->singleton('command.controller.make', function ($app) {
+ return new ControllerMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerEventGenerateCommand()
+ {
+ $this->app->singleton('command.event.generate', function () {
+ return new EventGenerateCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerEventMakeCommand()
+ {
+ $this->app->singleton('command.event.make', function ($app) {
+ return new EventMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerDownCommand()
+ {
+ $this->app->singleton('command.down', function () {
+ return new DownCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerEnvironmentCommand()
+ {
+ $this->app->singleton('command.environment', function () {
+ return new EnvironmentCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerJobMakeCommand()
+ {
+ $this->app->singleton('command.job.make', function ($app) {
+ return new JobMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerKeyGenerateCommand()
+ {
+ $this->app->singleton('command.key.generate', function () {
+ return new KeyGenerateCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerListenerMakeCommand()
+ {
+ $this->app->singleton('command.listener.make', function ($app) {
+ return new ListenerMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerMailMakeCommand()
+ {
+ $this->app->singleton('command.mail.make', function ($app) {
+ return new MailMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerMiddlewareMakeCommand()
+ {
+ $this->app->singleton('command.middleware.make', function ($app) {
+ return new MiddlewareMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerMigrateCommand()
+ {
+ $this->app->singleton('command.migrate', function ($app) {
+ return new MigrateCommand($app['migrator']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerMigrateInstallCommand()
+ {
+ $this->app->singleton('command.migrate.install', function ($app) {
+ return new MigrateInstallCommand($app['migration.repository']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerMigrateMakeCommand()
+ {
+ $this->app->singleton('command.migrate.make', function ($app) {
+ // Once we have the migration creator registered, we will create the command
+ // and inject the creator. The creator is responsible for the actual file
+ // creation of the migrations, and may be extended by these developers.
+ $creator = $app['migration.creator'];
+
+ $composer = $app['composer'];
+
+ return new MigrateMakeCommand($creator, $composer);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerMigrateRefreshCommand()
+ {
+ $this->app->singleton('command.migrate.refresh', function () {
+ return new MigrateRefreshCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerMigrateResetCommand()
+ {
+ $this->app->singleton('command.migrate.reset', function ($app) {
+ return new MigrateResetCommand($app['migrator']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerMigrateRollbackCommand()
+ {
+ $this->app->singleton('command.migrate.rollback', function ($app) {
+ return new MigrateRollbackCommand($app['migrator']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerMigrateStatusCommand()
+ {
+ $this->app->singleton('command.migrate.status', function ($app) {
+ return new MigrateStatusCommand($app['migrator']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerModelMakeCommand()
+ {
+ $this->app->singleton('command.model.make', function ($app) {
+ return new ModelMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerNotificationMakeCommand()
+ {
+ $this->app->singleton('command.notification.make', function ($app) {
+ return new NotificationMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerOptimizeCommand()
+ {
+ $this->app->singleton('command.optimize', function ($app) {
+ return new OptimizeCommand($app['composer']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerProviderMakeCommand()
+ {
+ $this->app->singleton('command.provider.make', function ($app) {
+ return new ProviderMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerQueueFailedCommand()
+ {
+ $this->app->singleton('command.queue.failed', function () {
+ return new ListFailedQueueCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerQueueForgetCommand()
+ {
+ $this->app->singleton('command.queue.forget', function () {
+ return new ForgetFailedQueueCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerQueueFlushCommand()
+ {
+ $this->app->singleton('command.queue.flush', function () {
+ return new FlushFailedQueueCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerQueueListenCommand()
+ {
+ $this->app->singleton('command.queue.listen', function ($app) {
+ return new QueueListenCommand($app['queue.listener']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerQueueRestartCommand()
+ {
+ $this->app->singleton('command.queue.restart', function () {
+ return new QueueRestartCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerQueueRetryCommand()
+ {
+ $this->app->singleton('command.queue.retry', function () {
+ return new QueueRetryCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerQueueWorkCommand()
+ {
+ $this->app->singleton('command.queue.work', function ($app) {
+ return new QueueWorkCommand($app['queue.worker']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerQueueFailedTableCommand()
+ {
+ $this->app->singleton('command.queue.failed-table', function ($app) {
+ return new FailedTableCommand($app['files'], $app['composer']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerQueueTableCommand()
+ {
+ $this->app->singleton('command.queue.table', function ($app) {
+ return new TableCommand($app['files'], $app['composer']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerRequestMakeCommand()
+ {
+ $this->app->singleton('command.request.make', function ($app) {
+ return new RequestMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerSeederMakeCommand()
+ {
+ $this->app->singleton('command.seeder.make', function ($app) {
+ return new SeederMakeCommand($app['files'], $app['composer']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerSessionTableCommand()
+ {
+ $this->app->singleton('command.session.table', function ($app) {
+ return new SessionTableCommand($app['files'], $app['composer']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerStorageLinkCommand()
+ {
+ $this->app->singleton('command.storage.link', function () {
+ return new StorageLinkCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerRouteCacheCommand()
+ {
+ $this->app->singleton('command.route.cache', function ($app) {
+ return new RouteCacheCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerRouteClearCommand()
+ {
+ $this->app->singleton('command.route.clear', function ($app) {
+ return new RouteClearCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerRouteListCommand()
+ {
+ $this->app->singleton('command.route.list', function ($app) {
+ return new RouteListCommand($app['router']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerSeedCommand()
+ {
+ $this->app->singleton('command.seed', function ($app) {
+ return new SeedCommand($app['db']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerScheduleFinishCommand()
+ {
+ $this->app->singleton(ScheduleFinishCommand::class);
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerScheduleRunCommand()
+ {
+ $this->app->singleton(ScheduleRunCommand::class);
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerServeCommand()
+ {
+ $this->app->singleton('command.serve', function () {
+ return new ServeCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerTestMakeCommand()
+ {
+ $this->app->singleton('command.test.make', function ($app) {
+ return new TestMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerUpCommand()
+ {
+ $this->app->singleton('command.up', function () {
+ return new UpCommand;
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerVendorPublishCommand()
+ {
+ $this->app->singleton('command.vendor.publish', function ($app) {
+ return new VendorPublishCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerViewClearCommand()
+ {
+ $this->app->singleton('command.view.clear', function ($app) {
+ return new ViewClearCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerPolicyMakeCommand()
+ {
+ $this->app->singleton('command.policy.make', function ($app) {
+ return new PolicyMakeCommand($app['files']);
+ });
+ }
+
+ /**
+ * Register the command.
+ *
+ * @return void
+ */
+ protected function registerNotificationTableCommand()
+ {
+ $this->app->singleton('command.notification.table', function ($app) {
+ return new NotificationTableCommand($app['files'], $app['composer']);
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return array_merge(array_values($this->commands), array_values($this->devCommands));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Providers/ComposerServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Foundation/Providers/ComposerServiceProvider.php
new file mode 100644
index 000000000..295ca960f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Providers/ComposerServiceProvider.php
@@ -0,0 +1,38 @@
+app->singleton('composer', function ($app) {
+ return new Composer($app['files'], $app->basePath());
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return ['composer'];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Providers/ConsoleSupportServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Foundation/Providers/ConsoleSupportServiceProvider.php
new file mode 100644
index 000000000..8e92d28c7
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Providers/ConsoleSupportServiceProvider.php
@@ -0,0 +1,27 @@
+app->afterResolving(ValidatesWhenResolved::class, function ($resolved) {
+ $resolved->validate();
+ });
+
+ $this->app->resolving(FormRequest::class, function ($request, $app) {
+ $this->initializeRequest($request, $app['request']);
+
+ $request->setContainer($app)->setRedirector($app->make(Redirector::class));
+ });
+ }
+
+ /**
+ * Initialize the form request with data from the given request.
+ *
+ * @param \Illuminate\Foundation\Http\FormRequest $form
+ * @param \Symfony\Component\HttpFoundation\Request $current
+ * @return void
+ */
+ protected function initializeRequest(FormRequest $form, Request $current)
+ {
+ $files = $current->files->all();
+
+ $files = is_array($files) ? array_filter($files) : $files;
+
+ $form->initialize(
+ $current->query->all(), $current->request->all(), $current->attributes->all(),
+ $current->cookies->all(), $files, $current->server->all(), $current->getContent()
+ );
+
+ $form->setJson($current->json());
+
+ if ($session = $current->getSession()) {
+ $form->setLaravelSession($session);
+ }
+
+ $form->setUserResolver($current->getUserResolver());
+
+ $form->setRouteResolver($current->getRouteResolver());
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Providers/FoundationServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Foundation/Providers/FoundationServiceProvider.php
new file mode 100644
index 000000000..f1f483735
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Providers/FoundationServiceProvider.php
@@ -0,0 +1,17 @@
+policies as $key => $value) {
+ Gate::policy($key, $value);
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function register()
+ {
+ //
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Support/Providers/EventServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Foundation/Support/Providers/EventServiceProvider.php
new file mode 100644
index 000000000..307f2cefa
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Support/Providers/EventServiceProvider.php
@@ -0,0 +1,59 @@
+listens() as $event => $listeners) {
+ foreach ($listeners as $listener) {
+ Event::listen($event, $listener);
+ }
+ }
+
+ foreach ($this->subscribe as $subscriber) {
+ Event::subscribe($subscriber);
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function register()
+ {
+ //
+ }
+
+ /**
+ * Get the events and handlers.
+ *
+ * @return array
+ */
+ public function listens()
+ {
+ return $this->listen;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Support/Providers/RouteServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Foundation/Support/Providers/RouteServiceProvider.php
new file mode 100644
index 000000000..c753447b1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Support/Providers/RouteServiceProvider.php
@@ -0,0 +1,101 @@
+setRootControllerNamespace();
+
+ if ($this->app->routesAreCached()) {
+ $this->loadCachedRoutes();
+ } else {
+ $this->loadRoutes();
+
+ $this->app->booted(function () {
+ $this->app['router']->getRoutes()->refreshNameLookups();
+ $this->app['router']->getRoutes()->refreshActionLookups();
+ });
+ }
+ }
+
+ /**
+ * Set the root controller namespace for the application.
+ *
+ * @return void
+ */
+ protected function setRootControllerNamespace()
+ {
+ if (! is_null($this->namespace)) {
+ $this->app[UrlGenerator::class]->setRootControllerNamespace($this->namespace);
+ }
+ }
+
+ /**
+ * Load the cached routes for the application.
+ *
+ * @return void
+ */
+ protected function loadCachedRoutes()
+ {
+ $this->app->booted(function () {
+ require $this->app->getCachedRoutesPath();
+ });
+ }
+
+ /**
+ * Load the application routes.
+ *
+ * @return void
+ */
+ protected function loadRoutes()
+ {
+ if (method_exists($this, 'map')) {
+ $this->app->call([$this, 'map']);
+ }
+ }
+
+ /**
+ * Register the service provider.
+ *
+ * @return void
+ */
+ public function register()
+ {
+ //
+ }
+
+ /**
+ * Pass dynamic methods onto the router instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return call_user_func_array(
+ [$this->app->make(Router::class), $method], $parameters
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithAuthentication.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithAuthentication.php
new file mode 100644
index 000000000..6c5c7a1c2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithAuthentication.php
@@ -0,0 +1,145 @@
+be($user, $driver);
+
+ return $this;
+ }
+
+ /**
+ * Set the currently logged in user for the application.
+ *
+ * @param \Illuminate\Contracts\Auth\Authenticatable $user
+ * @param string|null $driver
+ * @return void
+ */
+ public function be(UserContract $user, $driver = null)
+ {
+ $this->app['auth']->guard($driver)->setUser($user);
+
+ $this->app['auth']->shouldUse($driver);
+ }
+
+ /**
+ * Assert that the user is authenticated.
+ *
+ * @param string|null $guard
+ * @return $this
+ */
+ public function seeIsAuthenticated($guard = null)
+ {
+ $this->assertTrue($this->isAuthenticated($guard), 'The user is not authenticated');
+
+ return $this;
+ }
+
+ /**
+ * Assert that the user is not authenticated.
+ *
+ * @param string|null $guard
+ * @return $this
+ */
+ public function dontSeeIsAuthenticated($guard = null)
+ {
+ $this->assertFalse($this->isAuthenticated($guard), 'The user is authenticated');
+
+ return $this;
+ }
+
+ /**
+ * Return true if the user is authenticated, false otherwise.
+ *
+ * @param string|null $guard
+ * @return bool
+ */
+ protected function isAuthenticated($guard = null)
+ {
+ return $this->app->make('auth')->guard($guard)->check();
+ }
+
+ /**
+ * Assert that the user is authenticated as the given user.
+ *
+ * @param $user
+ * @param string|null $guard
+ * @return $this
+ */
+ public function seeIsAuthenticatedAs($user, $guard = null)
+ {
+ $expected = $this->app->make('auth')->guard($guard)->user();
+
+ $this->assertInstanceOf(
+ get_class($expected), $user,
+ 'The currently authenticated user is not who was expected'
+ );
+
+ $this->assertSame(
+ $expected->getAuthIdentifier(), $user->getAuthIdentifier(),
+ 'The currently authenticated user is not who was expected'
+ );
+
+ return $this;
+ }
+
+ /**
+ * Assert that the given credentials are valid.
+ *
+ * @param array $credentials
+ * @param string|null $guard
+ * @return $this
+ */
+ public function seeCredentials(array $credentials, $guard = null)
+ {
+ $this->assertTrue(
+ $this->hasCredentials($credentials, $guard), 'The given credentials are invalid.'
+ );
+
+ return $this;
+ }
+
+ /**
+ * Assert that the given credentials are invalid.
+ *
+ * @param array $credentials
+ * @param string|null $guard
+ * @return $this
+ */
+ public function dontSeeCredentials(array $credentials, $guard = null)
+ {
+ $this->assertFalse(
+ $this->hasCredentials($credentials, $guard), 'The given credentials are valid.'
+ );
+
+ return $this;
+ }
+
+ /**
+ * Return true if the credentials are valid, false otherwise.
+ *
+ * @param array $credentials
+ * @param string|null $guard
+ * @return bool
+ */
+ protected function hasCredentials(array $credentials, $guard = null)
+ {
+ $provider = $this->app->make('auth')->guard($guard)->getProvider();
+
+ $user = $provider->retrieveByCredentials($credentials);
+
+ return $user && $provider->validateCredentials($user, $credentials);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithConsole.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithConsole.php
new file mode 100644
index 000000000..ba078b314
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithConsole.php
@@ -0,0 +1,20 @@
+app[Kernel::class]->call($command, $parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithContainer.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithContainer.php
new file mode 100644
index 000000000..5a0ad1e0a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithContainer.php
@@ -0,0 +1,32 @@
+instance($abstract, $instance);
+ }
+
+ /**
+ * Register an instance of an object in the container.
+ *
+ * @param string $abstract
+ * @param object $instance
+ * @return object
+ */
+ protected function instance($abstract, $instance)
+ {
+ $this->app->instance($abstract, $instance);
+
+ return $instance;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithDatabase.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithDatabase.php
new file mode 100644
index 000000000..a2e60e791
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithDatabase.php
@@ -0,0 +1,91 @@
+assertThat(
+ $table, new HasInDatabase($this->getConnection($connection), $data)
+ );
+
+ return $this;
+ }
+
+ /**
+ * Assert that a given where condition does not exist in the database.
+ *
+ * @param string $table
+ * @param array $data
+ * @param string $connection
+ * @return $this
+ */
+ protected function assertDatabaseMissing($table, array $data, $connection = null)
+ {
+ $constraint = new ReverseConstraint(
+ new HasInDatabase($this->getConnection($connection), $data)
+ );
+
+ $this->assertThat($table, $constraint);
+
+ return $this;
+ }
+
+ /**
+ * Assert the given record has been deleted.
+ *
+ * @param string $table
+ * @param array $data
+ * @param string $connection
+ * @return $this
+ */
+ protected function assertSoftDeleted($table, array $data, $connection = null)
+ {
+ $this->assertThat(
+ $table, new SoftDeletedInDatabase($this->getConnection($connection), $data)
+ );
+
+ return $this;
+ }
+
+ /**
+ * Get the database connection.
+ *
+ * @param string|null $connection
+ * @return \Illuminate\Database\Connection
+ */
+ protected function getConnection($connection = null)
+ {
+ $database = $this->app->make('db');
+
+ $connection = $connection ?: $database->getDefaultConnection();
+
+ return $database->connection($connection);
+ }
+
+ /**
+ * Seed a given database connection.
+ *
+ * @param string $class
+ * @return $this
+ */
+ public function seed($class = 'DatabaseSeeder')
+ {
+ $this->artisan('db:seed', ['--class' => $class]);
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithSession.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithSession.php
new file mode 100644
index 000000000..9d72e7c30
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/InteractsWithSession.php
@@ -0,0 +1,64 @@
+session($data);
+
+ return $this;
+ }
+
+ /**
+ * Set the session to the given array.
+ *
+ * @param array $data
+ * @return $this
+ */
+ public function session(array $data)
+ {
+ $this->startSession();
+
+ foreach ($data as $key => $value) {
+ $this->app['session']->put($key, $value);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Start the session for the application.
+ *
+ * @return $this
+ */
+ protected function startSession()
+ {
+ if (! $this->app['session']->isStarted()) {
+ $this->app['session']->start();
+ }
+
+ return $this;
+ }
+
+ /**
+ * Flush all of the current session data.
+ *
+ * @return $this
+ */
+ public function flushSession()
+ {
+ $this->startSession();
+
+ $this->app['session']->flush();
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MakesHttpRequests.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MakesHttpRequests.php
new file mode 100644
index 000000000..3c9058e89
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MakesHttpRequests.php
@@ -0,0 +1,328 @@
+serverVariables = $server;
+
+ return $this;
+ }
+
+ /**
+ * Disable middleware for the test.
+ *
+ * @return $this
+ */
+ public function withoutMiddleware()
+ {
+ $this->app->instance('middleware.disable', true);
+
+ return $this;
+ }
+
+ /**
+ * Visit the given URI with a GET request.
+ *
+ * @param string $uri
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function get($uri, array $headers = [])
+ {
+ $server = $this->transformHeadersToServerVars($headers);
+
+ return $this->call('GET', $uri, [], [], [], $server);
+ }
+
+ /**
+ * Visit the given URI with a GET request, expecting a JSON response.
+ *
+ * @param string $uri
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function getJson($uri, array $headers = [])
+ {
+ return $this->json('GET', $uri, [], $headers);
+ }
+
+ /**
+ * Visit the given URI with a POST request.
+ *
+ * @param string $uri
+ * @param array $data
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function post($uri, array $data = [], array $headers = [])
+ {
+ $server = $this->transformHeadersToServerVars($headers);
+
+ return $this->call('POST', $uri, $data, [], [], $server);
+ }
+
+ /**
+ * Visit the given URI with a POST request, expecting a JSON response.
+ *
+ * @param string $uri
+ * @param array $data
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function postJson($uri, array $data = [], array $headers = [])
+ {
+ return $this->json('POST', $uri, $data, $headers);
+ }
+
+ /**
+ * Visit the given URI with a PUT request.
+ *
+ * @param string $uri
+ * @param array $data
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function put($uri, array $data = [], array $headers = [])
+ {
+ $server = $this->transformHeadersToServerVars($headers);
+
+ return $this->call('PUT', $uri, $data, [], [], $server);
+ }
+
+ /**
+ * Visit the given URI with a PUT request, expecting a JSON response.
+ *
+ * @param string $uri
+ * @param array $data
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function putJson($uri, array $data = [], array $headers = [])
+ {
+ return $this->json('PUT', $uri, $data, $headers);
+ }
+
+ /**
+ * Visit the given URI with a PATCH request.
+ *
+ * @param string $uri
+ * @param array $data
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function patch($uri, array $data = [], array $headers = [])
+ {
+ $server = $this->transformHeadersToServerVars($headers);
+
+ return $this->call('PATCH', $uri, $data, [], [], $server);
+ }
+
+ /**
+ * Visit the given URI with a PATCH request, expecting a JSON response.
+ *
+ * @param string $uri
+ * @param array $data
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function patchJson($uri, array $data = [], array $headers = [])
+ {
+ return $this->json('PATCH', $uri, $data, $headers);
+ }
+
+ /**
+ * Visit the given URI with a DELETE request.
+ *
+ * @param string $uri
+ * @param array $data
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function delete($uri, array $data = [], array $headers = [])
+ {
+ $server = $this->transformHeadersToServerVars($headers);
+
+ return $this->call('DELETE', $uri, $data, [], [], $server);
+ }
+
+ /**
+ * Visit the given URI with a DELETE request, expecting a JSON response.
+ *
+ * @param string $uri
+ * @param array $data
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function deleteJson($uri, array $data = [], array $headers = [])
+ {
+ return $this->json('DELETE', $uri, $data, $headers);
+ }
+
+ /**
+ * Call the given URI with a JSON request.
+ *
+ * @param string $method
+ * @param string $uri
+ * @param array $data
+ * @param array $headers
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function json($method, $uri, array $data = [], array $headers = [])
+ {
+ $files = $this->extractFilesFromDataArray($data);
+
+ $content = json_encode($data);
+
+ $headers = array_merge([
+ 'CONTENT_LENGTH' => mb_strlen($content, '8bit'),
+ 'CONTENT_TYPE' => 'application/json',
+ 'Accept' => 'application/json',
+ ], $headers);
+
+ return $this->call(
+ $method, $uri, [], [], $files, $this->transformHeadersToServerVars($headers), $content
+ );
+ }
+
+ /**
+ * Call the given URI and return the Response.
+ *
+ * @param string $method
+ * @param string $uri
+ * @param array $parameters
+ * @param array $cookies
+ * @param array $files
+ * @param array $server
+ * @param string $content
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ public function call($method, $uri, $parameters = [], $cookies = [], $files = [], $server = [], $content = null)
+ {
+ $kernel = $this->app->make(HttpKernel::class);
+
+ $files = array_merge($files, $this->extractFilesFromDataArray($parameters));
+
+ $symfonyRequest = SymfonyRequest::create(
+ $this->prepareUrlForRequest($uri), $method, $parameters,
+ $cookies, $files, array_replace($this->serverVariables, $server), $content
+ );
+
+ $response = $kernel->handle(
+ $request = Request::createFromBase($symfonyRequest)
+ );
+
+ $kernel->terminate($request, $response);
+
+ return $this->createTestResponse($response);
+ }
+
+ /**
+ * Turn the given URI into a fully qualified URL.
+ *
+ * @param string $uri
+ * @return string
+ */
+ protected function prepareUrlForRequest($uri)
+ {
+ if (Str::startsWith($uri, '/')) {
+ $uri = substr($uri, 1);
+ }
+
+ if (! Str::startsWith($uri, 'http')) {
+ $uri = config('app.url').'/'.$uri;
+ }
+
+ return trim($uri, '/');
+ }
+
+ /**
+ * Transform headers array to array of $_SERVER vars with HTTP_* format.
+ *
+ * @param array $headers
+ * @return array
+ */
+ protected function transformHeadersToServerVars(array $headers)
+ {
+ return collect($headers)->mapWithKeys(function ($value, $name) {
+ $name = strtr(strtoupper($name), '-', '_');
+
+ return [$this->formatServerHeaderKey($name) => $value];
+ })->all();
+ }
+
+ /**
+ * Format the header name for the server array.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function formatServerHeaderKey($name)
+ {
+ if (! Str::startsWith($name, 'HTTP_') && $name != 'CONTENT_TYPE') {
+ return 'HTTP_'.$name;
+ }
+
+ return $name;
+ }
+
+ /**
+ * Extract the file uploads from the given data array.
+ *
+ * @param array $data
+ * @return array
+ */
+ protected function extractFilesFromDataArray(&$data)
+ {
+ $files = [];
+
+ foreach ($data as $key => $value) {
+ if ($value instanceof SymfonyUploadedFile) {
+ $files[$key] = $value;
+
+ unset($data[$key]);
+ }
+
+ if (is_array($value)) {
+ $files[$key] = $this->extractFilesFromDataArray($value);
+
+ $data[$key] = $value;
+ }
+ }
+
+ return $files;
+ }
+
+ /**
+ * Create the test response instance from the given response.
+ *
+ * @param \Illuminate\Http\Response $response
+ * @return \Illuminate\Foundation\Testing\TestResponse
+ */
+ protected function createTestResponse($response)
+ {
+ return TestResponse::fromBaseResponse($response);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MocksApplicationServices.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MocksApplicationServices.php
new file mode 100644
index 000000000..04bb2aedd
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Concerns/MocksApplicationServices.php
@@ -0,0 +1,283 @@
+withoutEvents();
+
+ $this->beforeApplicationDestroyed(function () use ($events) {
+ $fired = $this->getFiredEvents($events);
+
+ $this->assertEmpty(
+ $eventsNotFired = array_diff($events, $fired),
+ 'These expected events were not fired: ['.implode(', ', $eventsNotFired).']'
+ );
+ });
+
+ return $this;
+ }
+
+ /**
+ * Specify a list of events that should not be fired for the given operation.
+ *
+ * These events will be mocked, so that handlers will not actually be executed.
+ *
+ * @param array|string $events
+ * @return $this
+ */
+ public function doesntExpectEvents($events)
+ {
+ $events = is_array($events) ? $events : func_get_args();
+
+ $this->withoutEvents();
+
+ $this->beforeApplicationDestroyed(function () use ($events) {
+ $this->assertEmpty(
+ $fired = $this->getFiredEvents($events),
+ 'These unexpected events were fired: ['.implode(', ', $fired).']'
+ );
+ });
+
+ return $this;
+ }
+
+ /**
+ * Mock the event dispatcher so all events are silenced and collected.
+ *
+ * @return $this
+ */
+ protected function withoutEvents()
+ {
+ $mock = Mockery::mock(EventsDispatcherContract::class);
+
+ $mock->shouldReceive('fire', 'dispatch')->andReturnUsing(function ($called) {
+ $this->firedEvents[] = $called;
+ });
+
+ $this->app->instance('events', $mock);
+
+ return $this;
+ }
+
+ /**
+ * Filter the given events against the fired events.
+ *
+ * @param array $events
+ * @return array
+ */
+ protected function getFiredEvents(array $events)
+ {
+ return $this->getDispatched($events, $this->firedEvents);
+ }
+
+ /**
+ * Specify a list of jobs that should be dispatched for the given operation.
+ *
+ * These jobs will be mocked, so that handlers will not actually be executed.
+ *
+ * @param array|string $jobs
+ * @return $this
+ */
+ protected function expectsJobs($jobs)
+ {
+ $jobs = is_array($jobs) ? $jobs : func_get_args();
+
+ $this->withoutJobs();
+
+ $this->beforeApplicationDestroyed(function () use ($jobs) {
+ $dispatched = $this->getDispatchedJobs($jobs);
+
+ $this->assertEmpty(
+ $jobsNotDispatched = array_diff($jobs, $dispatched),
+ 'These expected jobs were not dispatched: ['.implode(', ', $jobsNotDispatched).']'
+ );
+ });
+
+ return $this;
+ }
+
+ /**
+ * Specify a list of jobs that should not be dispatched for the given operation.
+ *
+ * These jobs will be mocked, so that handlers will not actually be executed.
+ *
+ * @param array|string $jobs
+ * @return $this
+ */
+ protected function doesntExpectJobs($jobs)
+ {
+ $jobs = is_array($jobs) ? $jobs : func_get_args();
+
+ $this->withoutJobs();
+
+ $this->beforeApplicationDestroyed(function () use ($jobs) {
+ $this->assertEmpty(
+ $dispatched = $this->getDispatchedJobs($jobs),
+ 'These unexpected jobs were dispatched: ['.implode(', ', $dispatched).']'
+ );
+ });
+
+ return $this;
+ }
+
+ /**
+ * Mock the job dispatcher so all jobs are silenced and collected.
+ *
+ * @return $this
+ */
+ protected function withoutJobs()
+ {
+ $mock = Mockery::mock(BusDispatcherContract::class);
+
+ $mock->shouldReceive('dispatch', 'dispatchNow')->andReturnUsing(function ($dispatched) {
+ $this->dispatchedJobs[] = $dispatched;
+ });
+
+ $this->app->instance(
+ BusDispatcherContract::class, $mock
+ );
+
+ return $this;
+ }
+
+ /**
+ * Filter the given jobs against the dispatched jobs.
+ *
+ * @param array $jobs
+ * @return array
+ */
+ protected function getDispatchedJobs(array $jobs)
+ {
+ return $this->getDispatched($jobs, $this->dispatchedJobs);
+ }
+
+ /**
+ * Filter the given classes against an array of dispatched classes.
+ *
+ * @param array $classes
+ * @param array $dispatched
+ * @return array
+ */
+ protected function getDispatched(array $classes, array $dispatched)
+ {
+ return array_filter($classes, function ($class) use ($dispatched) {
+ return $this->wasDispatched($class, $dispatched);
+ });
+ }
+
+ /**
+ * Check if the given class exists in an array of dispatched classes.
+ *
+ * @param string $needle
+ * @param array $haystack
+ * @return bool
+ */
+ protected function wasDispatched($needle, array $haystack)
+ {
+ foreach ($haystack as $dispatched) {
+ if ((is_string($dispatched) && ($dispatched === $needle || is_subclass_of($dispatched, $needle))) ||
+ $dispatched instanceof $needle) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Mock the notification dispatcher so all notifications are silenced.
+ *
+ * @return $this
+ */
+ protected function withoutNotifications()
+ {
+ $mock = Mockery::mock(NotificationDispatcher::class);
+
+ $mock->shouldReceive('send')->andReturnUsing(function ($notifiable, $instance, $channels = []) {
+ $this->dispatchedNotifications[] = compact(
+ 'notifiable', 'instance', 'channels'
+ );
+ });
+
+ $this->app->instance(NotificationDispatcher::class, $mock);
+
+ return $this;
+ }
+
+ /**
+ * Specify a notification that is expected to be dispatched.
+ *
+ * @param mixed $notifiable
+ * @param string $notification
+ * @return $this
+ */
+ protected function expectsNotification($notifiable, $notification)
+ {
+ $this->withoutNotifications();
+
+ $this->beforeApplicationDestroyed(function () use ($notifiable, $notification) {
+ foreach ($this->dispatchedNotifications as $dispatched) {
+ $notified = $dispatched['notifiable'];
+
+ if (($notified === $notifiable ||
+ $notified->getKey() == $notifiable->getKey()) &&
+ get_class($dispatched['instance']) === $notification
+ ) {
+ return $this;
+ }
+ }
+
+ $this->fail('The following expected notification were not dispatched: ['.$notification.']');
+ });
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/HasInDatabase.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/HasInDatabase.php
new file mode 100644
index 000000000..b3265b4e8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/HasInDatabase.php
@@ -0,0 +1,103 @@
+data = $data;
+
+ $this->database = $database;
+ }
+
+ /**
+ * Check if the data is found in the given table.
+ *
+ * @param string $table
+ * @return bool
+ */
+ public function matches($table)
+ {
+ return $this->database->table($table)->where($this->data)->count() > 0;
+ }
+
+ /**
+ * Get the description of the failure.
+ *
+ * @param string $table
+ * @return string
+ */
+ public function failureDescription($table)
+ {
+ return sprintf(
+ "a row in the table [%s] matches the attributes %s.\n\n%s",
+ $table, $this->toString(JSON_PRETTY_PRINT), $this->getAdditionalInfo($table)
+ );
+ }
+
+ /**
+ * Get additional info about the records found in the database table.
+ *
+ * @param string $table
+ * @return string
+ */
+ protected function getAdditionalInfo($table)
+ {
+ $results = $this->database->table($table)->get();
+
+ if ($results->isEmpty()) {
+ return 'The table is empty';
+ }
+
+ $description = 'Found: '.json_encode($results->take($this->show), JSON_PRETTY_PRINT);
+
+ if ($results->count() > $this->show) {
+ $description .= sprintf(' and %s others', $results->count() - $this->show);
+ }
+
+ return $description;
+ }
+
+ /**
+ * Get a string representation of the object.
+ *
+ * @param int $options
+ * @return string
+ */
+ public function toString($options = 0)
+ {
+ return json_encode($this->data, $options);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/SoftDeletedInDatabase.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/SoftDeletedInDatabase.php
new file mode 100644
index 000000000..8d74d4f6d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/Constraints/SoftDeletedInDatabase.php
@@ -0,0 +1,103 @@
+data = $data;
+
+ $this->database = $database;
+ }
+
+ /**
+ * Check if the data is found in the given table.
+ *
+ * @param string $table
+ * @return bool
+ */
+ public function matches($table)
+ {
+ return $this->database->table($table)
+ ->where($this->data)->whereNotNull('deleted_at')->count() > 0;
+ }
+
+ /**
+ * Get the description of the failure.
+ *
+ * @param string $table
+ * @return string
+ */
+ public function failureDescription($table)
+ {
+ return sprintf(
+ "any soft deleted row in the table [%s] matches the attributes %s.\n\n%s",
+ $table, $this->toString(), $this->getAdditionalInfo($table)
+ );
+ }
+
+ /**
+ * Get additional info about the records found in the database table.
+ *
+ * @param string $table
+ * @return string
+ */
+ protected function getAdditionalInfo($table)
+ {
+ $results = $this->database->table($table)->get();
+
+ if ($results->isEmpty()) {
+ return 'The table is empty';
+ }
+
+ $description = 'Found: '.json_encode($results->take($this->show), JSON_PRETTY_PRINT);
+
+ if ($results->count() > $this->show) {
+ $description .= sprintf(' and %s others', $results->count() - $this->show);
+ }
+
+ return $description;
+ }
+
+ /**
+ * Get a string representation of the object.
+ *
+ * @return string
+ */
+ public function toString()
+ {
+ return json_encode($this->data);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseMigrations.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseMigrations.php
new file mode 100644
index 000000000..a6e527f1f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseMigrations.php
@@ -0,0 +1,24 @@
+artisan('migrate');
+
+ $this->app[Kernel::class]->setArtisan(null);
+
+ $this->beforeApplicationDestroyed(function () {
+ $this->artisan('migrate:rollback');
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseTransactions.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseTransactions.php
new file mode 100644
index 000000000..9870153bb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/DatabaseTransactions.php
@@ -0,0 +1,40 @@
+app->make('db');
+
+ foreach ($this->connectionsToTransact() as $name) {
+ $database->connection($name)->beginTransaction();
+ }
+
+ $this->beforeApplicationDestroyed(function () use ($database) {
+ foreach ($this->connectionsToTransact() as $name) {
+ $connection = $database->connection($name);
+
+ $connection->rollBack();
+ $connection->disconnect();
+ }
+ });
+ }
+
+ /**
+ * The database connections that should have transactions.
+ *
+ * @return array
+ */
+ protected function connectionsToTransact()
+ {
+ return property_exists($this, 'connectionsToTransact')
+ ? $this->connectionsToTransact : [null];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/HttpException.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/HttpException.php
new file mode 100644
index 000000000..67d2b2f22
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/HttpException.php
@@ -0,0 +1,10 @@
+app) {
+ $this->refreshApplication();
+ }
+
+ $this->setUpTraits();
+
+ foreach ($this->afterApplicationCreatedCallbacks as $callback) {
+ call_user_func($callback);
+ }
+
+ Facade::clearResolvedInstances();
+
+ Model::setEventDispatcher($this->app['events']);
+
+ $this->setUpHasRun = true;
+ }
+
+ /**
+ * Refresh the application instance.
+ *
+ * @return void
+ */
+ protected function refreshApplication()
+ {
+ $this->app = $this->createApplication();
+ }
+
+ /**
+ * Boot the testing helper traits.
+ *
+ * @return array
+ */
+ protected function setUpTraits()
+ {
+ $uses = array_flip(class_uses_recursive(static::class));
+
+ if (isset($uses[DatabaseMigrations::class])) {
+ $this->runDatabaseMigrations();
+ }
+
+ if (isset($uses[DatabaseTransactions::class])) {
+ $this->beginDatabaseTransaction();
+ }
+
+ if (isset($uses[WithoutMiddleware::class])) {
+ $this->disableMiddlewareForAllTests();
+ }
+
+ if (isset($uses[WithoutEvents::class])) {
+ $this->disableEventsForAllTests();
+ }
+
+ return $uses;
+ }
+
+ /**
+ * Clean up the testing environment before the next test.
+ *
+ * @return void
+ */
+ protected function tearDown()
+ {
+ if ($this->app) {
+ foreach ($this->beforeApplicationDestroyedCallbacks as $callback) {
+ call_user_func($callback);
+ }
+
+ $this->app->flush();
+
+ $this->app = null;
+ }
+
+ $this->setUpHasRun = false;
+
+ if (property_exists($this, 'serverVariables')) {
+ $this->serverVariables = [];
+ }
+
+ if (class_exists('Mockery')) {
+ Mockery::close();
+ }
+
+ $this->afterApplicationCreatedCallbacks = [];
+ $this->beforeApplicationDestroyedCallbacks = [];
+
+ Artisan::forgetBootstrappers();
+ }
+
+ /**
+ * Register a callback to be run after the application is created.
+ *
+ * @param callable $callback
+ * @return void
+ */
+ public function afterApplicationCreated(callable $callback)
+ {
+ $this->afterApplicationCreatedCallbacks[] = $callback;
+
+ if ($this->setUpHasRun) {
+ call_user_func($callback);
+ }
+ }
+
+ /**
+ * Register a callback to be run before the application is destroyed.
+ *
+ * @param callable $callback
+ * @return void
+ */
+ protected function beforeApplicationDestroyed(callable $callback)
+ {
+ $this->beforeApplicationDestroyedCallbacks[] = $callback;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/TestResponse.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/TestResponse.php
new file mode 100644
index 000000000..becbfae41
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/TestResponse.php
@@ -0,0 +1,657 @@
+baseResponse = $response;
+ }
+
+ /**
+ * Create a new TestResponse from another response.
+ *
+ * @param \Illuminate\Http\Response $response
+ * @return static
+ */
+ public static function fromBaseResponse($response)
+ {
+ return new static($response);
+ }
+
+ /**
+ * Assert that the response has a successful status code.
+ *
+ * @return $this
+ */
+ public function assertSuccessful()
+ {
+ PHPUnit::assertTrue(
+ $this->isSuccessful(),
+ 'Response status code ['.$this->getStatusCode().'] is not a successful status code.'
+ );
+
+ return $this;
+ }
+
+ /**
+ * Assert that the response has the given status code.
+ *
+ * @param int $status
+ * @return $this
+ */
+ public function assertStatus($status)
+ {
+ $actual = $this->getStatusCode();
+
+ PHPUnit::assertTrue(
+ $actual === $status,
+ "Expected status code {$status} but received {$actual}."
+ );
+
+ return $this;
+ }
+
+ /**
+ * Assert whether the response is redirecting to a given URI.
+ *
+ * @param string $uri
+ * @return $this
+ */
+ public function assertRedirect($uri = null)
+ {
+ PHPUnit::assertTrue(
+ $this->isRedirect(), 'Response status code ['.$this->getStatusCode().'] is not a redirect status code.'
+ );
+
+ if (! is_null($uri)) {
+ PHPUnit::assertEquals(app('url')->to($uri), $this->headers->get('Location'));
+ }
+
+ return $this;
+ }
+
+ /**
+ * Asserts that the response contains the given header and equals the optional value.
+ *
+ * @param string $headerName
+ * @param mixed $value
+ * @return $this
+ */
+ public function assertHeader($headerName, $value = null)
+ {
+ PHPUnit::assertTrue(
+ $this->headers->has($headerName), "Header [{$headerName}] not present on response."
+ );
+
+ $actual = $this->headers->get($headerName);
+
+ if (! is_null($value)) {
+ PHPUnit::assertEquals(
+ $value, $this->headers->get($headerName),
+ "Header [{$headerName}] was found, but value [{$actual}] does not match [{$value}]."
+ );
+ }
+
+ return $this;
+ }
+
+ /**
+ * Asserts that the response contains the given cookie and equals the optional value.
+ *
+ * @param string $cookieName
+ * @param mixed $value
+ * @return $this
+ */
+ public function assertPlainCookie($cookieName, $value = null)
+ {
+ $this->assertCookie($cookieName, $value, false);
+
+ return $this;
+ }
+
+ /**
+ * Asserts that the response contains the given cookie and equals the optional value.
+ *
+ * @param string $cookieName
+ * @param mixed $value
+ * @param bool $encrypted
+ * @return $this
+ */
+ public function assertCookie($cookieName, $value = null, $encrypted = true)
+ {
+ PHPUnit::assertNotNull(
+ $cookie = $this->getCookie($cookieName),
+ "Cookie [{$cookieName}] not present on response."
+ );
+
+ if (! $cookie || is_null($value)) {
+ return $this;
+ }
+
+ $cookieValue = $cookie->getValue();
+
+ $actual = $encrypted
+ ? app('encrypter')->decrypt($cookieValue) : $cookieValue;
+
+ PHPUnit::assertEquals(
+ $value, $actual,
+ "Cookie [{$cookieName}] was found, but value [{$actual}] does not match [{$value}]."
+ );
+
+ return $this;
+ }
+
+ /**
+ * Get the given cookie from the response.
+ *
+ * @param string $cookieName
+ * @return \Symfony\Component\HttpFoundation\Cookie|null
+ */
+ protected function getCookie($cookieName)
+ {
+ foreach ($this->headers->getCookies() as $cookie) {
+ if ($cookie->getName() === $cookieName) {
+ return $cookie;
+ }
+ }
+ }
+
+ /**
+ * Assert that the given string is contained within the response.
+ *
+ * @param string $value
+ * @return $this
+ */
+ public function assertSee($value)
+ {
+ PHPUnit::assertContains($value, $this->getContent());
+
+ return $this;
+ }
+
+ /**
+ * Assert that the given string is contained within the response text.
+ *
+ * @param string $value
+ * @return $this
+ */
+ public function assertSeeText($value)
+ {
+ PHPUnit::assertContains($value, strip_tags($this->getContent()));
+
+ return $this;
+ }
+
+ /**
+ * Assert that the given string is not contained within the response.
+ *
+ * @param string $value
+ * @return $this
+ */
+ public function assertDontSee($value)
+ {
+ PHPUnit::assertNotContains($value, $this->getContent());
+
+ return $this;
+ }
+
+ /**
+ * Assert that the given string is not contained within the response text.
+ *
+ * @param string $value
+ * @return $this
+ */
+ public function assertDontSeeText($value)
+ {
+ PHPUnit::assertNotContains($value, strip_tags($this->getContent()));
+
+ return $this;
+ }
+
+ /**
+ * Assert that the response is a superset of the given JSON.
+ *
+ * @param array $data
+ * @return $this
+ */
+ public function assertJson(array $data)
+ {
+ PHPUnit::assertArraySubset(
+ $data, $this->decodeResponseJson(), false, $this->assertJsonMessage($data)
+ );
+
+ return $this;
+ }
+
+ /**
+ * Get the assertion message for assertJson.
+ *
+ * @param array $data
+ * @return string
+ */
+ protected function assertJsonMessage(array $data)
+ {
+ $expected = json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES);
+
+ $actual = json_encode($this->decodeResponseJson(), JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES);
+
+ return 'Unable to find JSON: '.PHP_EOL.PHP_EOL.
+ "[{$expected}]".PHP_EOL.PHP_EOL.
+ 'within response JSON:'.PHP_EOL.PHP_EOL.
+ "[{$actual}].".PHP_EOL.PHP_EOL;
+ }
+
+ /**
+ * Assert that the response has the exact given JSON.
+ *
+ * @param array $data
+ * @return $this
+ */
+ public function assertExactJson(array $data)
+ {
+ $actual = json_encode(Arr::sortRecursive(
+ (array) $this->decodeResponseJson()
+ ));
+
+ PHPUnit::assertEquals(json_encode(Arr::sortRecursive($data)), $actual);
+
+ return $this;
+ }
+
+ /**
+ * Assert that the response contains the given JSON fragment.
+ *
+ * @param array $data
+ * @return $this
+ */
+ public function assertJsonFragment(array $data)
+ {
+ $actual = json_encode(Arr::sortRecursive(
+ (array) $this->decodeResponseJson()
+ ));
+
+ foreach (Arr::sortRecursive($data) as $key => $value) {
+ $expected = substr(json_encode([$key => $value]), 1, -1);
+
+ PHPUnit::assertTrue(
+ Str::contains($actual, $expected),
+ 'Unable to find JSON fragment: '.PHP_EOL.PHP_EOL.
+ "[{$expected}]".PHP_EOL.PHP_EOL.
+ 'within'.PHP_EOL.PHP_EOL.
+ "[{$actual}]."
+ );
+ }
+
+ return $this;
+ }
+
+ /**
+ * Assert that the response does not contain the given JSON fragment.
+ *
+ * @param array $data
+ * @return $this
+ */
+ public function assertJsonMissing(array $data)
+ {
+ $actual = json_encode(Arr::sortRecursive(
+ (array) $this->decodeResponseJson()
+ ));
+
+ foreach (Arr::sortRecursive($data) as $key => $value) {
+ $expected = substr(json_encode([$key => $value]), 1, -1);
+
+ PHPUnit::assertFalse(
+ Str::contains($actual, $expected),
+ 'Found unexpected JSON fragment: '.PHP_EOL.PHP_EOL.
+ "[{$expected}]".PHP_EOL.PHP_EOL.
+ 'within'.PHP_EOL.PHP_EOL.
+ "[{$actual}]."
+ );
+ }
+
+ return $this;
+ }
+
+ /**
+ * Assert that the response has a given JSON structure.
+ *
+ * @param array|null $structure
+ * @param array|null $responseData
+ * @return $this
+ */
+ public function assertJsonStructure(array $structure = null, $responseData = null)
+ {
+ if (is_null($structure)) {
+ return $this->assertJson($this->json());
+ }
+
+ if (is_null($responseData)) {
+ $responseData = $this->decodeResponseJson();
+ }
+
+ foreach ($structure as $key => $value) {
+ if (is_array($value) && $key === '*') {
+ PHPUnit::assertInternalType('array', $responseData);
+
+ foreach ($responseData as $responseDataItem) {
+ $this->assertJsonStructure($structure['*'], $responseDataItem);
+ }
+ } elseif (is_array($value)) {
+ PHPUnit::assertArrayHasKey($key, $responseData);
+
+ $this->assertJsonStructure($structure[$key], $responseData[$key]);
+ } else {
+ PHPUnit::assertArrayHasKey($value, $responseData);
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Validate and return the decoded response JSON.
+ *
+ * @return array
+ */
+ public function decodeResponseJson()
+ {
+ $decodedResponse = json_decode($this->getContent(), true);
+
+ if (is_null($decodedResponse) || $decodedResponse === false) {
+ if ($this->exception) {
+ throw $this->exception;
+ } else {
+ PHPUnit::fail('Invalid JSON was returned from the route.');
+ }
+ }
+
+ return $decodedResponse;
+ }
+
+ /**
+ * Validate and return the decoded response JSON.
+ *
+ * @return array
+ */
+ public function json()
+ {
+ return $this->decodeResponseJson();
+ }
+
+ /**
+ * Assert that the response view equals the given value.
+ *
+ * @param string $value
+ * @return $this
+ */
+ public function assertViewIs($value)
+ {
+ $this->ensureResponseHasView();
+
+ PHPUnit::assertEquals($value, $this->original->getName());
+
+ return $this;
+ }
+
+ /**
+ * Assert that the response view has a given piece of bound data.
+ *
+ * @param string|array $key
+ * @param mixed $value
+ * @return $this
+ */
+ public function assertViewHas($key, $value = null)
+ {
+ if (is_array($key)) {
+ return $this->assertViewHasAll($key);
+ }
+
+ $this->ensureResponseHasView();
+
+ if (is_null($value)) {
+ PHPUnit::assertArrayHasKey($key, $this->original->getData());
+ } elseif ($value instanceof Closure) {
+ PHPUnit::assertTrue($value($this->original->$key));
+ } else {
+ PHPUnit::assertEquals($value, $this->original->$key);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Assert that the response view has a given list of bound data.
+ *
+ * @param array $bindings
+ * @return $this
+ */
+ public function assertViewHasAll(array $bindings)
+ {
+ foreach ($bindings as $key => $value) {
+ if (is_int($key)) {
+ $this->assertViewHas($value);
+ } else {
+ $this->assertViewHas($key, $value);
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Assert that the response view is missing a piece of bound data.
+ *
+ * @param string $key
+ * @return $this
+ */
+ public function assertViewMissing($key)
+ {
+ $this->ensureResponseHasView();
+
+ PHPUnit::assertArrayNotHasKey($key, $this->original->getData());
+
+ return $this;
+ }
+
+ /**
+ * Ensure that the response has a view as its original content.
+ *
+ * @return $this
+ */
+ protected function ensureResponseHasView()
+ {
+ if (! isset($this->original) || ! $this->original instanceof View) {
+ return PHPUnit::fail('The response is not a view.');
+ }
+
+ return $this;
+ }
+
+ /**
+ * Assert that the session has a given value.
+ *
+ * @param string|array $key
+ * @param mixed $value
+ * @return $this
+ */
+ public function assertSessionHas($key, $value = null)
+ {
+ if (is_array($key)) {
+ return $this->assertSessionHasAll($key);
+ }
+
+ if (is_null($value)) {
+ PHPUnit::assertTrue(
+ $this->session()->has($key),
+ "Session is missing expected key [{$key}]."
+ );
+ } else {
+ PHPUnit::assertEquals($value, app('session.store')->get($key));
+ }
+
+ return $this;
+ }
+
+ /**
+ * Assert that the session has a given list of values.
+ *
+ * @param array $bindings
+ * @return $this
+ */
+ public function assertSessionHasAll(array $bindings)
+ {
+ foreach ($bindings as $key => $value) {
+ if (is_int($key)) {
+ $this->assertSessionHas($value);
+ } else {
+ $this->assertSessionHas($key, $value);
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Assert that the session has the given errors.
+ *
+ * @param string|array $keys
+ * @param mixed $format
+ * @return $this
+ */
+ public function assertSessionHasErrors($keys = [], $format = null)
+ {
+ $this->assertSessionHas('errors');
+
+ $keys = (array) $keys;
+
+ $errors = app('session.store')->get('errors');
+
+ foreach ($keys as $key => $value) {
+ if (is_int($key)) {
+ PHPUnit::assertTrue($errors->has($value), "Session missing error: $value");
+ } else {
+ PHPUnit::assertContains($value, $errors->get($key, $format));
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Assert that the session does not have a given key.
+ *
+ * @param string|array $key
+ * @return $this
+ */
+ public function assertSessionMissing($key)
+ {
+ if (is_array($key)) {
+ foreach ($key as $value) {
+ $this->assertSessionMissing($value);
+ }
+ } else {
+ PHPUnit::assertFalse(
+ $this->session()->has($key),
+ "Session has unexpected key [{$key}]."
+ );
+ }
+
+ return $this;
+ }
+
+ /**
+ * Get the current session store.
+ *
+ * @return \Illuminate\Session\Store
+ */
+ protected function session()
+ {
+ return app('session.store');
+ }
+
+ /**
+ * Dump the content from the response.
+ *
+ * @return void
+ */
+ public function dump()
+ {
+ $content = $this->getContent();
+
+ $json = json_decode($content);
+
+ if (json_last_error() === JSON_ERROR_NONE) {
+ $content = $json;
+ }
+
+ dd($content);
+ }
+
+ /**
+ * Dynamically access base response parameters.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function __get($key)
+ {
+ return $this->baseResponse->{$key};
+ }
+
+ /**
+ * Proxy isset() checks to the underlying base response.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function __isset($key)
+ {
+ return isset($this->baseResponse->{$key});
+ }
+
+ /**
+ * Handle dynamic calls into macros or pass missing methods to the base response.
+ *
+ * @param string $method
+ * @param array $args
+ * @return mixed
+ */
+ public function __call($method, $args)
+ {
+ if (static::hasMacro($method)) {
+ return $this->macroCall($method, $args);
+ }
+
+ return $this->baseResponse->{$method}(...$args);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/WithoutEvents.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/WithoutEvents.php
new file mode 100644
index 000000000..fa5df3ce8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/WithoutEvents.php
@@ -0,0 +1,22 @@
+withoutEvents();
+ } else {
+ throw new Exception('Unable to disable events. ApplicationTrait not used.');
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Testing/WithoutMiddleware.php b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/WithoutMiddleware.php
new file mode 100644
index 000000000..269b532d3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Testing/WithoutMiddleware.php
@@ -0,0 +1,22 @@
+withoutMiddleware();
+ } else {
+ throw new Exception('Unable to disable middleware. MakesHttpRequests trait not used.');
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/Validation/ValidatesRequests.php b/vendor/laravel/framework/src/Illuminate/Foundation/Validation/ValidatesRequests.php
new file mode 100644
index 000000000..c1873b4cd
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/Validation/ValidatesRequests.php
@@ -0,0 +1,168 @@
+getValidationFactory()->make($request->all(), $validator);
+ }
+
+ if ($validator->fails()) {
+ $this->throwValidationException($request, $validator);
+ }
+ }
+
+ /**
+ * Validate the given request with the given rules.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param array $rules
+ * @param array $messages
+ * @param array $customAttributes
+ * @return void
+ */
+ public function validate(Request $request, array $rules, array $messages = [], array $customAttributes = [])
+ {
+ $validator = $this->getValidationFactory()->make($request->all(), $rules, $messages, $customAttributes);
+
+ if ($validator->fails()) {
+ $this->throwValidationException($request, $validator);
+ }
+ }
+
+ /**
+ * Validate the given request with the given rules.
+ *
+ * @param string $errorBag
+ * @param \Illuminate\Http\Request $request
+ * @param array $rules
+ * @param array $messages
+ * @param array $customAttributes
+ * @return void
+ *
+ * @throws \Illuminate\Validation\ValidationException
+ */
+ public function validateWithBag($errorBag, Request $request, array $rules, array $messages = [], array $customAttributes = [])
+ {
+ $this->withErrorBag($errorBag, function () use ($request, $rules, $messages, $customAttributes) {
+ $this->validate($request, $rules, $messages, $customAttributes);
+ });
+ }
+
+ /**
+ * Execute a Closure within with a given error bag set as the default bag.
+ *
+ * @param string $errorBag
+ * @param callable $callback
+ * @return void
+ */
+ protected function withErrorBag($errorBag, callable $callback)
+ {
+ $this->validatesRequestErrorBag = $errorBag;
+
+ call_user_func($callback);
+
+ $this->validatesRequestErrorBag = null;
+ }
+
+ /**
+ * Throw the failed validation exception.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Illuminate\Contracts\Validation\Validator $validator
+ * @return void
+ *
+ * @throws \Illuminate\Validation\ValidationException
+ */
+ protected function throwValidationException(Request $request, $validator)
+ {
+ throw new ValidationException($validator, $this->buildFailedValidationResponse(
+ $request, $this->formatValidationErrors($validator)
+ ));
+ }
+
+ /**
+ * Create the response for when a request fails validation.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param array $errors
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function buildFailedValidationResponse(Request $request, array $errors)
+ {
+ if ($request->expectsJson()) {
+ return new JsonResponse($errors, 422);
+ }
+
+ return redirect()->to($this->getRedirectUrl())
+ ->withInput($request->input())
+ ->withErrors($errors, $this->errorBag());
+ }
+
+ /**
+ * Format the validation errors to be returned.
+ *
+ * @param \Illuminate\Contracts\Validation\Validator $validator
+ * @return array
+ */
+ protected function formatValidationErrors(Validator $validator)
+ {
+ return $validator->errors()->getMessages();
+ }
+
+ /**
+ * Get the key to be used for the view error bag.
+ *
+ * @return string
+ */
+ protected function errorBag()
+ {
+ return $this->validatesRequestErrorBag ?: 'default';
+ }
+
+ /**
+ * Get the URL we should redirect to.
+ *
+ * @return string
+ */
+ protected function getRedirectUrl()
+ {
+ return app(UrlGenerator::class)->previous();
+ }
+
+ /**
+ * Get a validation factory instance.
+ *
+ * @return \Illuminate\Contracts\Validation\Factory
+ */
+ protected function getValidationFactory()
+ {
+ return app(Factory::class);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/helpers.php b/vendor/laravel/framework/src/Illuminate/Foundation/helpers.php
new file mode 100644
index 000000000..5313ffb66
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/helpers.php
@@ -0,0 +1,887 @@
+abort($code, $message, $headers);
+ }
+}
+
+if (! function_exists('abort_if')) {
+ /**
+ * Throw an HttpException with the given data if the given condition is true.
+ *
+ * @param bool $boolean
+ * @param int $code
+ * @param string $message
+ * @param array $headers
+ * @return void
+ *
+ * @throws \Symfony\Component\HttpKernel\Exception\HttpException
+ * @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException
+ */
+ function abort_if($boolean, $code, $message = '', array $headers = [])
+ {
+ if ($boolean) {
+ abort($code, $message, $headers);
+ }
+ }
+}
+
+if (! function_exists('abort_unless')) {
+ /**
+ * Throw an HttpException with the given data unless the given condition is true.
+ *
+ * @param bool $boolean
+ * @param int $code
+ * @param string $message
+ * @param array $headers
+ * @return void
+ *
+ * @throws \Symfony\Component\HttpKernel\Exception\HttpException
+ * @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException
+ */
+ function abort_unless($boolean, $code, $message = '', array $headers = [])
+ {
+ if (! $boolean) {
+ abort($code, $message, $headers);
+ }
+ }
+}
+
+if (! function_exists('action')) {
+ /**
+ * Generate the URL to a controller action.
+ *
+ * @param string $name
+ * @param array $parameters
+ * @param bool $absolute
+ * @return string
+ */
+ function action($name, $parameters = [], $absolute = true)
+ {
+ return app('url')->action($name, $parameters, $absolute);
+ }
+}
+
+if (! function_exists('app')) {
+ /**
+ * Get the available container instance.
+ *
+ * @param string $abstract
+ * @param array $parameters
+ * @return mixed|\Illuminate\Foundation\Application
+ */
+ function app($abstract = null, array $parameters = [])
+ {
+ if (is_null($abstract)) {
+ return Container::getInstance();
+ }
+
+ return empty($parameters)
+ ? Container::getInstance()->make($abstract)
+ : Container::getInstance()->makeWith($abstract, $parameters);
+ }
+}
+
+if (! function_exists('app_path')) {
+ /**
+ * Get the path to the application folder.
+ *
+ * @param string $path
+ * @return string
+ */
+ function app_path($path = '')
+ {
+ return app('path').($path ? DIRECTORY_SEPARATOR.$path : $path);
+ }
+}
+
+if (! function_exists('asset')) {
+ /**
+ * Generate an asset path for the application.
+ *
+ * @param string $path
+ * @param bool $secure
+ * @return string
+ */
+ function asset($path, $secure = null)
+ {
+ return app('url')->asset($path, $secure);
+ }
+}
+
+if (! function_exists('auth')) {
+ /**
+ * Get the available auth instance.
+ *
+ * @param string|null $guard
+ * @return \Illuminate\Contracts\Auth\Factory|\Illuminate\Contracts\Auth\Guard|\Illuminate\Contracts\Auth\StatefulGuard
+ */
+ function auth($guard = null)
+ {
+ if (is_null($guard)) {
+ return app(AuthFactory::class);
+ } else {
+ return app(AuthFactory::class)->guard($guard);
+ }
+ }
+}
+
+if (! function_exists('back')) {
+ /**
+ * Create a new redirect response to the previous location.
+ *
+ * @param int $status
+ * @param array $headers
+ * @param mixed $fallback
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ function back($status = 302, $headers = [], $fallback = false)
+ {
+ return app('redirect')->back($status, $headers, $fallback);
+ }
+}
+
+if (! function_exists('base_path')) {
+ /**
+ * Get the path to the base of the install.
+ *
+ * @param string $path
+ * @return string
+ */
+ function base_path($path = '')
+ {
+ return app()->basePath().($path ? DIRECTORY_SEPARATOR.$path : $path);
+ }
+}
+
+if (! function_exists('bcrypt')) {
+ /**
+ * Hash the given value.
+ *
+ * @param string $value
+ * @param array $options
+ * @return string
+ */
+ function bcrypt($value, $options = [])
+ {
+ return app('hash')->make($value, $options);
+ }
+}
+
+if (! function_exists('broadcast')) {
+ /**
+ * Begin broadcasting an event.
+ *
+ * @param mixed|null $event
+ * @return \Illuminate\Broadcasting\PendingBroadcast|void
+ */
+ function broadcast($event = null)
+ {
+ return app(BroadcastFactory::class)->event($event);
+ }
+}
+
+if (! function_exists('cache')) {
+ /**
+ * Get / set the specified cache value.
+ *
+ * If an array is passed, we'll assume you want to put to the cache.
+ *
+ * @param dynamic key|key,default|data,expiration|null
+ * @return mixed
+ *
+ * @throws \Exception
+ */
+ function cache()
+ {
+ $arguments = func_get_args();
+
+ if (empty($arguments)) {
+ return app('cache');
+ }
+
+ if (is_string($arguments[0])) {
+ return app('cache')->get($arguments[0], isset($arguments[1]) ? $arguments[1] : null);
+ }
+
+ if (! is_array($arguments[0])) {
+ throw new Exception(
+ 'When setting a value in the cache, you must pass an array of key / value pairs.'
+ );
+ }
+
+ if (! isset($arguments[1])) {
+ throw new Exception(
+ 'You must specify an expiration time when setting a value in the cache.'
+ );
+ }
+
+ return app('cache')->put(key($arguments[0]), reset($arguments[0]), $arguments[1]);
+ }
+}
+
+if (! function_exists('config')) {
+ /**
+ * Get / set the specified configuration value.
+ *
+ * If an array is passed as the key, we will assume you want to set an array of values.
+ *
+ * @param array|string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ function config($key = null, $default = null)
+ {
+ if (is_null($key)) {
+ return app('config');
+ }
+
+ if (is_array($key)) {
+ return app('config')->set($key);
+ }
+
+ return app('config')->get($key, $default);
+ }
+}
+
+if (! function_exists('config_path')) {
+ /**
+ * Get the configuration path.
+ *
+ * @param string $path
+ * @return string
+ */
+ function config_path($path = '')
+ {
+ return app()->make('path.config').($path ? DIRECTORY_SEPARATOR.$path : $path);
+ }
+}
+
+if (! function_exists('cookie')) {
+ /**
+ * Create a new cookie instance.
+ *
+ * @param string $name
+ * @param string $value
+ * @param int $minutes
+ * @param string $path
+ * @param string $domain
+ * @param bool $secure
+ * @param bool $httpOnly
+ * @return \Symfony\Component\HttpFoundation\Cookie
+ */
+ function cookie($name = null, $value = null, $minutes = 0, $path = null, $domain = null, $secure = false, $httpOnly = true)
+ {
+ $cookie = app(CookieFactory::class);
+
+ if (is_null($name)) {
+ return $cookie;
+ }
+
+ return $cookie->make($name, $value, $minutes, $path, $domain, $secure, $httpOnly);
+ }
+}
+
+if (! function_exists('csrf_field')) {
+ /**
+ * Generate a CSRF token form field.
+ *
+ * @return \Illuminate\Support\HtmlString
+ */
+ function csrf_field()
+ {
+ return new HtmlString(' ');
+ }
+}
+
+if (! function_exists('csrf_token')) {
+ /**
+ * Get the CSRF token value.
+ *
+ * @return string
+ *
+ * @throws \RuntimeException
+ */
+ function csrf_token()
+ {
+ $session = app('session');
+
+ if (isset($session)) {
+ return $session->token();
+ }
+
+ throw new RuntimeException('Application session store not set.');
+ }
+}
+
+if (! function_exists('database_path')) {
+ /**
+ * Get the database path.
+ *
+ * @param string $path
+ * @return string
+ */
+ function database_path($path = '')
+ {
+ return app()->databasePath($path);
+ }
+}
+
+if (! function_exists('decrypt')) {
+ /**
+ * Decrypt the given value.
+ *
+ * @param string $value
+ * @return string
+ */
+ function decrypt($value)
+ {
+ return app('encrypter')->decrypt($value);
+ }
+}
+
+if (! function_exists('dispatch')) {
+ /**
+ * Dispatch a job to its appropriate handler.
+ *
+ * @param mixed $job
+ * @return mixed
+ */
+ function dispatch($job)
+ {
+ return app(Dispatcher::class)->dispatch($job);
+ }
+}
+
+if (! function_exists('elixir')) {
+ /**
+ * Get the path to a versioned Elixir file.
+ *
+ * @param string $file
+ * @param string $buildDirectory
+ * @return string
+ *
+ * @throws \InvalidArgumentException
+ */
+ function elixir($file, $buildDirectory = 'build')
+ {
+ static $manifest = [];
+ static $manifestPath;
+
+ if (empty($manifest) || $manifestPath !== $buildDirectory) {
+ $path = public_path($buildDirectory.'/rev-manifest.json');
+
+ if (file_exists($path)) {
+ $manifest = json_decode(file_get_contents($path), true);
+ $manifestPath = $buildDirectory;
+ }
+ }
+
+ $file = ltrim($file, '/');
+
+ if (isset($manifest[$file])) {
+ return '/'.trim($buildDirectory.'/'.$manifest[$file], '/');
+ }
+
+ $unversioned = public_path($file);
+
+ if (file_exists($unversioned)) {
+ return '/'.trim($file, '/');
+ }
+
+ throw new InvalidArgumentException("File {$file} not defined in asset manifest.");
+ }
+}
+
+if (! function_exists('encrypt')) {
+ /**
+ * Encrypt the given value.
+ *
+ * @param mixed $value
+ * @return string
+ */
+ function encrypt($value)
+ {
+ return app('encrypter')->encrypt($value);
+ }
+}
+
+if (! function_exists('event')) {
+ /**
+ * Dispatch an event and call the listeners.
+ *
+ * @param string|object $event
+ * @param mixed $payload
+ * @param bool $halt
+ * @return array|null
+ */
+ function event(...$args)
+ {
+ return app('events')->dispatch(...$args);
+ }
+}
+
+if (! function_exists('factory')) {
+ /**
+ * Create a model factory builder for a given class, name, and amount.
+ *
+ * @param dynamic class|class,name|class,amount|class,name,amount
+ * @return \Illuminate\Database\Eloquent\FactoryBuilder
+ */
+ function factory()
+ {
+ $factory = app(EloquentFactory::class);
+
+ $arguments = func_get_args();
+
+ if (isset($arguments[1]) && is_string($arguments[1])) {
+ return $factory->of($arguments[0], $arguments[1])->times(isset($arguments[2]) ? $arguments[2] : null);
+ } elseif (isset($arguments[1])) {
+ return $factory->of($arguments[0])->times($arguments[1]);
+ } else {
+ return $factory->of($arguments[0]);
+ }
+ }
+}
+
+if (! function_exists('info')) {
+ /**
+ * Write some information to the log.
+ *
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ function info($message, $context = [])
+ {
+ return app('log')->info($message, $context);
+ }
+}
+
+if (! function_exists('logger')) {
+ /**
+ * Log a debug message to the logs.
+ *
+ * @param string $message
+ * @param array $context
+ * @return \Illuminate\Contracts\Logging\Log|null
+ */
+ function logger($message = null, array $context = [])
+ {
+ if (is_null($message)) {
+ return app('log');
+ }
+
+ return app('log')->debug($message, $context);
+ }
+}
+
+if (! function_exists('method_field')) {
+ /**
+ * Generate a form field to spoof the HTTP verb used by forms.
+ *
+ * @param string $method
+ * @return \Illuminate\Support\HtmlString
+ */
+ function method_field($method)
+ {
+ return new HtmlString(' ');
+ }
+}
+
+if (! function_exists('mix')) {
+ /**
+ * Get the path to a versioned Mix file.
+ *
+ * @param string $path
+ * @param string $manifestDirectory
+ * @return \Illuminate\Support\HtmlString
+ *
+ * @throws \Exception
+ */
+ function mix($path, $manifestDirectory = '')
+ {
+ static $manifests = [];
+
+ if (! starts_with($path, '/')) {
+ $path = "/{$path}";
+ }
+
+ if ($manifestDirectory && ! starts_with($manifestDirectory, '/')) {
+ $manifestDirectory = "/{$manifestDirectory}";
+ }
+
+ if (file_exists(public_path($manifestDirectory.'/hot'))) {
+ return new HtmlString("//localhost:8080{$path}");
+ }
+
+ $manifestPath = public_path($manifestDirectory.'/mix-manifest.json');
+
+ if (! isset($manifests[$manifestPath])) {
+ if (! file_exists($manifestPath)) {
+ throw new Exception('The Mix manifest does not exist.');
+ }
+
+ $manifests[$manifestPath] = json_decode(file_get_contents($manifestPath), true);
+ }
+
+ $manifest = $manifests[$manifestPath];
+
+ if (! isset($manifest[$path])) {
+ throw new Exception(
+ "Unable to locate Mix file: {$path}. Please check your ".
+ 'webpack.mix.js output paths and try again.'
+ );
+ }
+
+ return new HtmlString($manifestDirectory.$manifest[$path]);
+ }
+}
+
+if (! function_exists('old')) {
+ /**
+ * Retrieve an old input item.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ function old($key = null, $default = null)
+ {
+ return app('request')->old($key, $default);
+ }
+}
+
+if (! function_exists('policy')) {
+ /**
+ * Get a policy instance for a given class.
+ *
+ * @param object|string $class
+ * @return mixed
+ *
+ * @throws \InvalidArgumentException
+ */
+ function policy($class)
+ {
+ return app(Gate::class)->getPolicyFor($class);
+ }
+}
+
+if (! function_exists('public_path')) {
+ /**
+ * Get the path to the public folder.
+ *
+ * @param string $path
+ * @return string
+ */
+ function public_path($path = '')
+ {
+ return app()->make('path.public').($path ? DIRECTORY_SEPARATOR.ltrim($path, DIRECTORY_SEPARATOR) : $path);
+ }
+}
+
+if (! function_exists('redirect')) {
+ /**
+ * Get an instance of the redirector.
+ *
+ * @param string|null $to
+ * @param int $status
+ * @param array $headers
+ * @param bool $secure
+ * @return \Illuminate\Routing\Redirector|\Illuminate\Http\RedirectResponse
+ */
+ function redirect($to = null, $status = 302, $headers = [], $secure = null)
+ {
+ if (is_null($to)) {
+ return app('redirect');
+ }
+
+ return app('redirect')->to($to, $status, $headers, $secure);
+ }
+}
+
+if (! function_exists('request')) {
+ /**
+ * Get an instance of the current request or an input item from the request.
+ *
+ * @param array|string $key
+ * @param mixed $default
+ * @return \Illuminate\Http\Request|string|array
+ */
+ function request($key = null, $default = null)
+ {
+ if (is_null($key)) {
+ return app('request');
+ }
+
+ if (is_array($key)) {
+ return app('request')->only($key);
+ }
+
+ return data_get(app('request')->all(), $key, $default);
+ }
+}
+
+if (! function_exists('resolve')) {
+ /**
+ * Resolve a service from the container.
+ *
+ * @param string $name
+ * @return mixed
+ */
+ function resolve($name)
+ {
+ return app($name);
+ }
+}
+
+if (! function_exists('resource_path')) {
+ /**
+ * Get the path to the resources folder.
+ *
+ * @param string $path
+ * @return string
+ */
+ function resource_path($path = '')
+ {
+ return app()->resourcePath($path);
+ }
+}
+
+if (! function_exists('response')) {
+ /**
+ * Return a new response from the application.
+ *
+ * @param string $content
+ * @param int $status
+ * @param array $headers
+ * @return \Symfony\Component\HttpFoundation\Response|\Illuminate\Contracts\Routing\ResponseFactory
+ */
+ function response($content = '', $status = 200, array $headers = [])
+ {
+ $factory = app(ResponseFactory::class);
+
+ if (func_num_args() === 0) {
+ return $factory;
+ }
+
+ return $factory->make($content, $status, $headers);
+ }
+}
+
+if (! function_exists('route')) {
+ /**
+ * Generate the URL to a named route.
+ *
+ * @param string $name
+ * @param array $parameters
+ * @param bool $absolute
+ * @return string
+ */
+ function route($name, $parameters = [], $absolute = true)
+ {
+ return app('url')->route($name, $parameters, $absolute);
+ }
+}
+
+if (! function_exists('secure_asset')) {
+ /**
+ * Generate an asset path for the application.
+ *
+ * @param string $path
+ * @return string
+ */
+ function secure_asset($path)
+ {
+ return asset($path, true);
+ }
+}
+
+if (! function_exists('secure_url')) {
+ /**
+ * Generate a HTTPS url for the application.
+ *
+ * @param string $path
+ * @param mixed $parameters
+ * @return string
+ */
+ function secure_url($path, $parameters = [])
+ {
+ return url($path, $parameters, true);
+ }
+}
+
+if (! function_exists('session')) {
+ /**
+ * Get / set the specified session value.
+ *
+ * If an array is passed as the key, we will assume you want to set an array of values.
+ *
+ * @param array|string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ function session($key = null, $default = null)
+ {
+ if (is_null($key)) {
+ return app('session');
+ }
+
+ if (is_array($key)) {
+ return app('session')->put($key);
+ }
+
+ return app('session')->get($key, $default);
+ }
+}
+
+if (! function_exists('storage_path')) {
+ /**
+ * Get the path to the storage folder.
+ *
+ * @param string $path
+ * @return string
+ */
+ function storage_path($path = '')
+ {
+ return app('path.storage').($path ? DIRECTORY_SEPARATOR.$path : $path);
+ }
+}
+
+if (! function_exists('trans')) {
+ /**
+ * Translate the given message.
+ *
+ * @param string $key
+ * @param array $replace
+ * @param string $locale
+ * @return \Illuminate\Contracts\Translation\Translator|string|array|null
+ */
+ function trans($key = null, $replace = [], $locale = null)
+ {
+ if (is_null($key)) {
+ return app('translator');
+ }
+
+ return app('translator')->trans($key, $replace, $locale);
+ }
+}
+
+if (! function_exists('trans_choice')) {
+ /**
+ * Translates the given message based on a count.
+ *
+ * @param string $key
+ * @param int|array|\Countable $number
+ * @param array $replace
+ * @param string $locale
+ * @return string
+ */
+ function trans_choice($key, $number, array $replace = [], $locale = null)
+ {
+ return app('translator')->transChoice($key, $number, $replace, $locale);
+ }
+}
+
+if (! function_exists('__')) {
+ /**
+ * Translate the given message.
+ *
+ * @param string $key
+ * @param array $replace
+ * @param string $locale
+ * @return \Illuminate\Contracts\Translation\Translator|string
+ */
+ function __($key = null, $replace = [], $locale = null)
+ {
+ return app('translator')->getFromJson($key, $replace, $locale);
+ }
+}
+
+if (! function_exists('url')) {
+ /**
+ * Generate a url for the application.
+ *
+ * @param string $path
+ * @param mixed $parameters
+ * @param bool $secure
+ * @return \Illuminate\Contracts\Routing\UrlGenerator|string
+ */
+ function url($path = null, $parameters = [], $secure = null)
+ {
+ if (is_null($path)) {
+ return app(UrlGenerator::class);
+ }
+
+ return app(UrlGenerator::class)->to($path, $parameters, $secure);
+ }
+}
+
+if (! function_exists('validator')) {
+ /**
+ * Create a new Validator instance.
+ *
+ * @param array $data
+ * @param array $rules
+ * @param array $messages
+ * @param array $customAttributes
+ * @return \Illuminate\Contracts\Validation\Validator
+ */
+ function validator(array $data = [], array $rules = [], array $messages = [], array $customAttributes = [])
+ {
+ $factory = app(ValidationFactory::class);
+
+ if (func_num_args() === 0) {
+ return $factory;
+ }
+
+ return $factory->make($data, $rules, $messages, $customAttributes);
+ }
+}
+
+if (! function_exists('view')) {
+ /**
+ * Get the evaluated view contents for the given view.
+ *
+ * @param string $view
+ * @param array $data
+ * @param array $mergeData
+ * @return \Illuminate\View\View|\Illuminate\Contracts\View\Factory
+ */
+ function view($view = null, $data = [], $mergeData = [])
+ {
+ $factory = app(ViewFactory::class);
+
+ if (func_num_args() === 0) {
+ return $factory;
+ }
+
+ return $factory->make($view, $data, $mergeData);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Foundation/stubs/facade.stub b/vendor/laravel/framework/src/Illuminate/Foundation/stubs/facade.stub
new file mode 100644
index 000000000..aadbe7460
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Foundation/stubs/facade.stub
@@ -0,0 +1,21 @@
+ $this->cost($options),
+ ]);
+
+ if ($hash === false) {
+ throw new RuntimeException('Bcrypt hashing not supported.');
+ }
+
+ return $hash;
+ }
+
+ /**
+ * Check the given plain value against a hash.
+ *
+ * @param string $value
+ * @param string $hashedValue
+ * @param array $options
+ * @return bool
+ */
+ public function check($value, $hashedValue, array $options = [])
+ {
+ if (strlen($hashedValue) === 0) {
+ return false;
+ }
+
+ return password_verify($value, $hashedValue);
+ }
+
+ /**
+ * Check if the given hash has been hashed using the given options.
+ *
+ * @param string $hashedValue
+ * @param array $options
+ * @return bool
+ */
+ public function needsRehash($hashedValue, array $options = [])
+ {
+ return password_needs_rehash($hashedValue, PASSWORD_BCRYPT, [
+ 'cost' => $this->cost($options),
+ ]);
+ }
+
+ /**
+ * Set the default password work factor.
+ *
+ * @param int $rounds
+ * @return $this
+ */
+ public function setRounds($rounds)
+ {
+ $this->rounds = (int) $rounds;
+
+ return $this;
+ }
+
+ /**
+ * Extract the cost value from the options array.
+ *
+ * @param array $options
+ * @return int
+ */
+ protected function cost(array $options = [])
+ {
+ return isset($options['rounds']) ? $options['rounds'] : $this->rounds;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Hashing/HashServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Hashing/HashServiceProvider.php
new file mode 100644
index 000000000..85581f40c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Hashing/HashServiceProvider.php
@@ -0,0 +1,37 @@
+app->singleton('hash', function () {
+ return new BcryptHasher;
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return ['hash'];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Hashing/composer.json b/vendor/laravel/framework/src/Illuminate/Hashing/composer.json
new file mode 100644
index 000000000..246808351
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Hashing/composer.json
@@ -0,0 +1,35 @@
+{
+ "name": "illuminate/hashing",
+ "description": "The Illuminate Hashing package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Hashing\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithContentTypes.php b/vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithContentTypes.php
new file mode 100644
index 000000000..492c131b2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithContentTypes.php
@@ -0,0 +1,157 @@
+header('CONTENT_TYPE'), ['/json', '+json']);
+ }
+
+ /**
+ * Determine if the current request probably expects a JSON response.
+ *
+ * @return bool
+ */
+ public function expectsJson()
+ {
+ return ($this->ajax() && ! $this->pjax()) || $this->wantsJson();
+ }
+
+ /**
+ * Determine if the current request is asking for JSON in return.
+ *
+ * @return bool
+ */
+ public function wantsJson()
+ {
+ $acceptable = $this->getAcceptableContentTypes();
+
+ return isset($acceptable[0]) && Str::contains($acceptable[0], ['/json', '+json']);
+ }
+
+ /**
+ * Determines whether the current requests accepts a given content type.
+ *
+ * @param string|array $contentTypes
+ * @return bool
+ */
+ public function accepts($contentTypes)
+ {
+ $accepts = $this->getAcceptableContentTypes();
+
+ if (count($accepts) === 0) {
+ return true;
+ }
+
+ $types = (array) $contentTypes;
+
+ foreach ($accepts as $accept) {
+ if ($accept === '*/*' || $accept === '*') {
+ return true;
+ }
+
+ foreach ($types as $type) {
+ if ($this->matchesType($accept, $type) || $accept === strtok($type, '/').'/*') {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Return the most suitable content type from the given array based on content negotiation.
+ *
+ * @param string|array $contentTypes
+ * @return string|null
+ */
+ public function prefers($contentTypes)
+ {
+ $accepts = $this->getAcceptableContentTypes();
+
+ $contentTypes = (array) $contentTypes;
+
+ foreach ($accepts as $accept) {
+ if (in_array($accept, ['*/*', '*'])) {
+ return $contentTypes[0];
+ }
+
+ foreach ($contentTypes as $contentType) {
+ $type = $contentType;
+
+ if (! is_null($mimeType = $this->getMimeType($contentType))) {
+ $type = $mimeType;
+ }
+
+ if ($this->matchesType($type, $accept) || $accept === strtok($type, '/').'/*') {
+ return $contentType;
+ }
+ }
+ }
+ }
+
+ /**
+ * Determines whether a request accepts JSON.
+ *
+ * @return bool
+ */
+ public function acceptsJson()
+ {
+ return $this->accepts('application/json');
+ }
+
+ /**
+ * Determines whether a request accepts HTML.
+ *
+ * @return bool
+ */
+ public function acceptsHtml()
+ {
+ return $this->accepts('text/html');
+ }
+
+ /**
+ * Get the data format expected in the response.
+ *
+ * @param string $default
+ * @return string
+ */
+ public function format($default = 'html')
+ {
+ foreach ($this->getAcceptableContentTypes() as $type) {
+ if ($format = $this->getFormat($type)) {
+ return $format;
+ }
+ }
+
+ return $default;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithFlashData.php b/vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithFlashData.php
new file mode 100644
index 000000000..c6b84f2e2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithFlashData.php
@@ -0,0 +1,64 @@
+session()->getOldInput($key, $default);
+ }
+
+ /**
+ * Flash the input for the current request to the session.
+ *
+ * @return void
+ */
+ public function flash()
+ {
+ $this->session()->flashInput($this->input());
+ }
+
+ /**
+ * Flash only some of the input to the session.
+ *
+ * @param array|mixed $keys
+ * @return void
+ */
+ public function flashOnly($keys)
+ {
+ $this->session()->flashInput(
+ $this->only(is_array($keys) ? $keys : func_get_args())
+ );
+ }
+
+ /**
+ * Flash only some of the input to the session.
+ *
+ * @param array|mixed $keys
+ * @return void
+ */
+ public function flashExcept($keys)
+ {
+ $this->session()->flashInput(
+ $this->except(is_array($keys) ? $keys : func_get_args())
+ );
+ }
+
+ /**
+ * Flush all of the old input from the session.
+ *
+ * @return void
+ */
+ public function flush()
+ {
+ $this->session()->flashInput([]);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithInput.php b/vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithInput.php
new file mode 100644
index 000000000..e00b1323d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Concerns/InteractsWithInput.php
@@ -0,0 +1,315 @@
+retrieveItem('server', $key, $default);
+ }
+
+ /**
+ * Determine if a header is set on the request.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function hasHeader($key)
+ {
+ return ! is_null($this->header($key));
+ }
+
+ /**
+ * Retrieve a header from the request.
+ *
+ * @param string $key
+ * @param string|array|null $default
+ * @return string|array
+ */
+ public function header($key = null, $default = null)
+ {
+ return $this->retrieveItem('headers', $key, $default);
+ }
+
+ /**
+ * Get the bearer token from the request headers.
+ *
+ * @return string|null
+ */
+ public function bearerToken()
+ {
+ $header = $this->header('Authorization', '');
+
+ if (Str::startsWith($header, 'Bearer ')) {
+ return Str::substr($header, 7);
+ }
+ }
+
+ /**
+ * Determine if the request contains a given input item key.
+ *
+ * @param string|array $key
+ * @return bool
+ */
+ public function exists($key)
+ {
+ $keys = is_array($key) ? $key : func_get_args();
+
+ $input = $this->all();
+
+ foreach ($keys as $value) {
+ if (! Arr::has($input, $value)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Determine if the request contains a non-empty value for an input item.
+ *
+ * @param string|array $key
+ * @return bool
+ */
+ public function has($key)
+ {
+ $keys = is_array($key) ? $key : func_get_args();
+
+ foreach ($keys as $value) {
+ if ($this->isEmptyString($value)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Determine if the given input key is an empty string for "has".
+ *
+ * @param string $key
+ * @return bool
+ */
+ protected function isEmptyString($key)
+ {
+ $value = $this->input($key);
+
+ return ! is_bool($value) && ! is_array($value) && trim((string) $value) === '';
+ }
+
+ /**
+ * Get all of the input and files for the request.
+ *
+ * @return array
+ */
+ public function all()
+ {
+ return array_replace_recursive($this->input(), $this->allFiles());
+ }
+
+ /**
+ * Retrieve an input item from the request.
+ *
+ * @param string $key
+ * @param string|array|null $default
+ * @return string|array
+ */
+ public function input($key = null, $default = null)
+ {
+ return data_get(
+ $this->getInputSource()->all() + $this->query->all(), $key, $default
+ );
+ }
+
+ /**
+ * Get a subset containing the provided keys with values from the input data.
+ *
+ * @param array|mixed $keys
+ * @return array
+ */
+ public function only($keys)
+ {
+ $keys = is_array($keys) ? $keys : func_get_args();
+
+ $results = [];
+
+ $input = $this->all();
+
+ foreach ($keys as $key) {
+ Arr::set($results, $key, data_get($input, $key));
+ }
+
+ return $results;
+ }
+
+ /**
+ * Get all of the input except for a specified array of items.
+ *
+ * @param array|mixed $keys
+ * @return array
+ */
+ public function except($keys)
+ {
+ $keys = is_array($keys) ? $keys : func_get_args();
+
+ $results = $this->all();
+
+ Arr::forget($results, $keys);
+
+ return $results;
+ }
+
+ /**
+ * Intersect an array of items with the input data.
+ *
+ * @param array|mixed $keys
+ * @return array
+ */
+ public function intersect($keys)
+ {
+ return array_filter($this->only(is_array($keys) ? $keys : func_get_args()));
+ }
+
+ /**
+ * Retrieve a query string item from the request.
+ *
+ * @param string $key
+ * @param string|array|null $default
+ * @return string|array
+ */
+ public function query($key = null, $default = null)
+ {
+ return $this->retrieveItem('query', $key, $default);
+ }
+
+ /**
+ * Determine if a cookie is set on the request.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function hasCookie($key)
+ {
+ return ! is_null($this->cookie($key));
+ }
+
+ /**
+ * Retrieve a cookie from the request.
+ *
+ * @param string $key
+ * @param string|array|null $default
+ * @return string|array
+ */
+ public function cookie($key = null, $default = null)
+ {
+ return $this->retrieveItem('cookies', $key, $default);
+ }
+
+ /**
+ * Get an array of all of the files on the request.
+ *
+ * @return array
+ */
+ public function allFiles()
+ {
+ $files = $this->files->all();
+
+ return $this->convertedFiles
+ ? $this->convertedFiles
+ : $this->convertedFiles = $this->convertUploadedFiles($files);
+ }
+
+ /**
+ * Convert the given array of Symfony UploadedFiles to custom Laravel UploadedFiles.
+ *
+ * @param array $files
+ * @return array
+ */
+ protected function convertUploadedFiles(array $files)
+ {
+ return array_map(function ($file) {
+ if (is_null($file) || (is_array($file) && empty(array_filter($file)))) {
+ return $file;
+ }
+
+ return is_array($file)
+ ? $this->convertUploadedFiles($file)
+ : UploadedFile::createFromBase($file);
+ }, $files);
+ }
+
+ /**
+ * Determine if the uploaded data contains a file.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function hasFile($key)
+ {
+ if (! is_array($files = $this->file($key))) {
+ $files = [$files];
+ }
+
+ foreach ($files as $file) {
+ if ($this->isValidFile($file)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Check that the given file is a valid file instance.
+ *
+ * @param mixed $file
+ * @return bool
+ */
+ protected function isValidFile($file)
+ {
+ return $file instanceof SplFileInfo && $file->getPath() != '';
+ }
+
+ /**
+ * Retrieve a file from the request.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return \Illuminate\Http\UploadedFile|array|null
+ */
+ public function file($key = null, $default = null)
+ {
+ return data_get($this->allFiles(), $key, $default);
+ }
+
+ /**
+ * Retrieve a parameter item from a given source.
+ *
+ * @param string $source
+ * @param string $key
+ * @param string|array|null $default
+ * @return string|array
+ */
+ protected function retrieveItem($source, $key, $default)
+ {
+ if (is_null($key)) {
+ return $this->$source->all();
+ }
+
+ return $this->$source->get($key, $default);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Exceptions/HttpResponseException.php b/vendor/laravel/framework/src/Illuminate/Http/Exceptions/HttpResponseException.php
new file mode 100644
index 000000000..b27052f02
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Exceptions/HttpResponseException.php
@@ -0,0 +1,37 @@
+response = $response;
+ }
+
+ /**
+ * Get the underlying response instance.
+ *
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ public function getResponse()
+ {
+ return $this->response;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Exceptions/PostTooLargeException.php b/vendor/laravel/framework/src/Illuminate/Http/Exceptions/PostTooLargeException.php
new file mode 100644
index 000000000..30421da4d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Exceptions/PostTooLargeException.php
@@ -0,0 +1,10 @@
+getRealPath();
+ }
+
+ /**
+ * Get the file's extension.
+ *
+ * @return string
+ */
+ public function extension()
+ {
+ return $this->guessExtension();
+ }
+
+ /**
+ * Get the file's extension supplied by the client.
+ *
+ * @return string
+ */
+ public function clientExtension()
+ {
+ return $this->guessClientExtension();
+ }
+
+ /**
+ * Get a filename for the file.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function hashName($path = null)
+ {
+ if ($path) {
+ $path = rtrim($path, '/').'/';
+ }
+
+ $hash = $this->hashName ?: $this->hashName = Str::random(40);
+
+ return $path.$hash.'.'.$this->guessExtension();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/JsonResponse.php b/vendor/laravel/framework/src/Illuminate/Http/JsonResponse.php
new file mode 100644
index 000000000..65bbecb1e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/JsonResponse.php
@@ -0,0 +1,110 @@
+encodingOptions = $options;
+
+ parent::__construct($data, $status, $headers);
+ }
+
+ /**
+ * Sets the JSONP callback.
+ *
+ * @param string|null $callback
+ * @return $this
+ */
+ public function withCallback($callback = null)
+ {
+ return $this->setCallback($callback);
+ }
+
+ /**
+ * Get the json_decoded data from the response.
+ *
+ * @param bool $assoc
+ * @param int $depth
+ * @return mixed
+ */
+ public function getData($assoc = false, $depth = 512)
+ {
+ return json_decode($this->data, $assoc, $depth);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setData($data = [])
+ {
+ $this->original = $data;
+
+ if ($data instanceof Arrayable) {
+ $this->data = json_encode($data->toArray(), $this->encodingOptions);
+ } elseif ($data instanceof Jsonable) {
+ $this->data = $data->toJson($this->encodingOptions);
+ } elseif ($data instanceof JsonSerializable) {
+ $this->data = json_encode($data->jsonSerialize(), $this->encodingOptions);
+ } else {
+ $this->data = json_encode($data, $this->encodingOptions);
+ }
+
+ if (! $this->hasValidJson(json_last_error())) {
+ throw new InvalidArgumentException(json_last_error_msg());
+ }
+
+ return $this->update();
+ }
+
+ /**
+ * Determine if an error occurred during JSON encoding.
+ *
+ * @param int $jsonError
+ * @return bool
+ */
+ protected function hasValidJson($jsonError)
+ {
+ return $jsonError === JSON_ERROR_NONE ||
+ ($jsonError === JSON_ERROR_UNSUPPORTED_TYPE &&
+ $this->hasEncodingOption(JSON_PARTIAL_OUTPUT_ON_ERROR));
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setEncodingOptions($options)
+ {
+ $this->encodingOptions = (int) $options;
+
+ return $this->setData($this->getData());
+ }
+
+ /**
+ * Determine if a JSON encoding option is set.
+ *
+ * @param int $option
+ * @return bool
+ */
+ public function hasEncodingOption($option)
+ {
+ return (bool) ($this->encodingOptions & $option);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Middleware/CheckResponseForModifications.php b/vendor/laravel/framework/src/Illuminate/Http/Middleware/CheckResponseForModifications.php
new file mode 100644
index 000000000..2a93e21d9
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Middleware/CheckResponseForModifications.php
@@ -0,0 +1,27 @@
+isNotModified($request);
+ }
+
+ return $response;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Middleware/FrameGuard.php b/vendor/laravel/framework/src/Illuminate/Http/Middleware/FrameGuard.php
new file mode 100644
index 000000000..66edce445
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Middleware/FrameGuard.php
@@ -0,0 +1,24 @@
+headers->set('X-Frame-Options', 'SAMEORIGIN', false);
+
+ return $response;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/RedirectResponse.php b/vendor/laravel/framework/src/Illuminate/Http/RedirectResponse.php
new file mode 100644
index 000000000..0a462ffdb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/RedirectResponse.php
@@ -0,0 +1,238 @@
+ $value];
+
+ foreach ($key as $k => $v) {
+ $this->session->flash($k, $v);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add multiple cookies to the response.
+ *
+ * @param array $cookies
+ * @return $this
+ */
+ public function withCookies(array $cookies)
+ {
+ foreach ($cookies as $cookie) {
+ $this->headers->setCookie($cookie);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Flash an array of input to the session.
+ *
+ * @param array $input
+ * @return $this
+ */
+ public function withInput(array $input = null)
+ {
+ $this->session->flashInput($this->removeFilesFromInput(
+ ! is_null($input) ? $input : $this->request->input()
+ ));
+
+ return $this;
+ }
+
+ /**
+ * Remove all uploaded files form the given input array.
+ *
+ * @param array $input
+ * @return array
+ */
+ protected function removeFilesFromInput(array $input)
+ {
+ foreach ($input as $key => $value) {
+ if (is_array($value)) {
+ $input[$key] = $this->removeFilesFromInput($value);
+ }
+
+ if ($value instanceof SymfonyUploadedFile) {
+ unset($input[$key]);
+ }
+ }
+
+ return $input;
+ }
+
+ /**
+ * Flash an array of input to the session.
+ *
+ * @return $this
+ */
+ public function onlyInput()
+ {
+ return $this->withInput($this->request->only(func_get_args()));
+ }
+
+ /**
+ * Flash an array of input to the session.
+ *
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function exceptInput()
+ {
+ return $this->withInput($this->request->except(func_get_args()));
+ }
+
+ /**
+ * Flash a container of errors to the session.
+ *
+ * @param \Illuminate\Contracts\Support\MessageProvider|array|string $provider
+ * @param string $key
+ * @return $this
+ */
+ public function withErrors($provider, $key = 'default')
+ {
+ $value = $this->parseErrors($provider);
+
+ $errors = $this->session->get('errors', new ViewErrorBag);
+
+ if (! $errors instanceof ViewErrorBag) {
+ $errors = new ViewErrorBag;
+ }
+
+ $this->session->flash(
+ 'errors', $errors->put($key, $value)
+ );
+
+ return $this;
+ }
+
+ /**
+ * Parse the given errors into an appropriate value.
+ *
+ * @param \Illuminate\Contracts\Support\MessageProvider|array|string $provider
+ * @return \Illuminate\Support\MessageBag
+ */
+ protected function parseErrors($provider)
+ {
+ if ($provider instanceof MessageProvider) {
+ return $provider->getMessageBag();
+ }
+
+ return new MessageBag((array) $provider);
+ }
+
+ /**
+ * Get the original response content.
+ *
+ * @return null
+ */
+ public function getOriginalContent()
+ {
+ //
+ }
+
+ /**
+ * Get the request instance.
+ *
+ * @return \Illuminate\Http\Request|null
+ */
+ public function getRequest()
+ {
+ return $this->request;
+ }
+
+ /**
+ * Set the request instance.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ public function setRequest(Request $request)
+ {
+ $this->request = $request;
+ }
+
+ /**
+ * Get the session store implementation.
+ *
+ * @return \Illuminate\Session\Store|null
+ */
+ public function getSession()
+ {
+ return $this->session;
+ }
+
+ /**
+ * Set the session store implementation.
+ *
+ * @param \Illuminate\Session\Store $session
+ * @return void
+ */
+ public function setSession(SessionStore $session)
+ {
+ $this->session = $session;
+ }
+
+ /**
+ * Dynamically bind flash data in the session.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return $this
+ *
+ * @throws \BadMethodCallException
+ */
+ public function __call($method, $parameters)
+ {
+ if (static::hasMacro($method)) {
+ return $this->macroCall($method, $parameters);
+ }
+
+ if (Str::startsWith($method, 'with')) {
+ return $this->with(Str::snake(substr($method, 4)), $parameters[0]);
+ }
+
+ throw new BadMethodCallException(
+ "Method [$method] does not exist on Redirect."
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Request.php b/vendor/laravel/framework/src/Illuminate/Http/Request.php
new file mode 100644
index 000000000..799c7fccd
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Request.php
@@ -0,0 +1,616 @@
+getMethod();
+ }
+
+ /**
+ * Get the root URL for the application.
+ *
+ * @return string
+ */
+ public function root()
+ {
+ return rtrim($this->getSchemeAndHttpHost().$this->getBaseUrl(), '/');
+ }
+
+ /**
+ * Get the URL (no query string) for the request.
+ *
+ * @return string
+ */
+ public function url()
+ {
+ return rtrim(preg_replace('/\?.*/', '', $this->getUri()), '/');
+ }
+
+ /**
+ * Get the full URL for the request.
+ *
+ * @return string
+ */
+ public function fullUrl()
+ {
+ $query = $this->getQueryString();
+
+ $question = $this->getBaseUrl().$this->getPathInfo() == '/' ? '/?' : '?';
+
+ return $query ? $this->url().$question.$query : $this->url();
+ }
+
+ /**
+ * Get the full URL for the request with the added query string parameters.
+ *
+ * @param array $query
+ * @return string
+ */
+ public function fullUrlWithQuery(array $query)
+ {
+ $question = $this->getBaseUrl().$this->getPathInfo() == '/' ? '/?' : '?';
+
+ return count($this->query()) > 0
+ ? $this->url().$question.http_build_query(array_merge($this->query(), $query))
+ : $this->fullUrl().$question.http_build_query($query);
+ }
+
+ /**
+ * Get the current path info for the request.
+ *
+ * @return string
+ */
+ public function path()
+ {
+ $pattern = trim($this->getPathInfo(), '/');
+
+ return $pattern == '' ? '/' : $pattern;
+ }
+
+ /**
+ * Get the current encoded path info for the request.
+ *
+ * @return string
+ */
+ public function decodedPath()
+ {
+ return rawurldecode($this->path());
+ }
+
+ /**
+ * Get a segment from the URI (1 based index).
+ *
+ * @param int $index
+ * @param string|null $default
+ * @return string|null
+ */
+ public function segment($index, $default = null)
+ {
+ return Arr::get($this->segments(), $index - 1, $default);
+ }
+
+ /**
+ * Get all of the segments for the request path.
+ *
+ * @return array
+ */
+ public function segments()
+ {
+ $segments = explode('/', $this->decodedPath());
+
+ return array_values(array_filter($segments, function ($v) {
+ return $v != '';
+ }));
+ }
+
+ /**
+ * Determine if the current request URI matches a pattern.
+ *
+ * @return bool
+ */
+ public function is()
+ {
+ foreach (func_get_args() as $pattern) {
+ if (Str::is($pattern, $this->decodedPath())) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Check if the route name matches the given string.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function routeIs($name)
+ {
+ return $this->route() && $this->route()->named($name);
+ }
+
+ /**
+ * Determine if the current request URL and query string matches a pattern.
+ *
+ * @return bool
+ */
+ public function fullUrlIs()
+ {
+ $url = $this->fullUrl();
+
+ foreach (func_get_args() as $pattern) {
+ if (Str::is($pattern, $url)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Determine if the request is the result of an AJAX call.
+ *
+ * @return bool
+ */
+ public function ajax()
+ {
+ return $this->isXmlHttpRequest();
+ }
+
+ /**
+ * Determine if the request is the result of an PJAX call.
+ *
+ * @return bool
+ */
+ public function pjax()
+ {
+ return $this->headers->get('X-PJAX') == true;
+ }
+
+ /**
+ * Determine if the request is over HTTPS.
+ *
+ * @return bool
+ */
+ public function secure()
+ {
+ return $this->isSecure();
+ }
+
+ /**
+ * Get the client IP address.
+ *
+ * @return string
+ */
+ public function ip()
+ {
+ return $this->getClientIp();
+ }
+
+ /**
+ * Get the client IP addresses.
+ *
+ * @return array
+ */
+ public function ips()
+ {
+ return $this->getClientIps();
+ }
+
+ /**
+ * Get the client user agent.
+ *
+ * @return string
+ */
+ public function userAgent()
+ {
+ return $this->headers->get('User-Agent');
+ }
+
+ /**
+ * Merge new input into the current request's input array.
+ *
+ * @param array $input
+ * @return void
+ */
+ public function merge(array $input)
+ {
+ $this->getInputSource()->add($input);
+ }
+
+ /**
+ * Replace the input for the current request.
+ *
+ * @param array $input
+ * @return void
+ */
+ public function replace(array $input)
+ {
+ $this->getInputSource()->replace($input);
+ }
+
+ /**
+ * Get the JSON payload for the request.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public function json($key = null, $default = null)
+ {
+ if (! isset($this->json)) {
+ $this->json = new ParameterBag((array) json_decode($this->getContent(), true));
+ }
+
+ if (is_null($key)) {
+ return $this->json;
+ }
+
+ return data_get($this->json->all(), $key, $default);
+ }
+
+ /**
+ * Get the input source for the request.
+ *
+ * @return \Symfony\Component\HttpFoundation\ParameterBag
+ */
+ protected function getInputSource()
+ {
+ if ($this->isJson()) {
+ return $this->json();
+ }
+
+ return $this->getRealMethod() == 'GET' ? $this->query : $this->request;
+ }
+
+ /**
+ * Create an Illuminate request from a Symfony instance.
+ *
+ * @param \Symfony\Component\HttpFoundation\Request $request
+ * @return \Illuminate\Http\Request
+ */
+ public static function createFromBase(SymfonyRequest $request)
+ {
+ if ($request instanceof static) {
+ return $request;
+ }
+
+ $content = $request->content;
+
+ $request = (new static)->duplicate(
+ $request->query->all(), $request->request->all(), $request->attributes->all(),
+ $request->cookies->all(), $request->files->all(), $request->server->all()
+ );
+
+ $request->content = $content;
+
+ $request->request = $request->getInputSource();
+
+ return $request;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function duplicate(array $query = null, array $request = null, array $attributes = null, array $cookies = null, array $files = null, array $server = null)
+ {
+ return parent::duplicate($query, $request, $attributes, $cookies, $this->filterFiles($files), $server);
+ }
+
+ /**
+ * Filter the given array of files, removing any empty values.
+ *
+ * @param mixed $files
+ * @return mixed
+ */
+ protected function filterFiles($files)
+ {
+ if (! $files) {
+ return;
+ }
+
+ foreach ($files as $key => $file) {
+ if (is_array($file)) {
+ $files[$key] = $this->filterFiles($files[$key]);
+ }
+
+ if (empty($files[$key])) {
+ unset($files[$key]);
+ }
+ }
+
+ return $files;
+ }
+
+ /**
+ * Get the session associated with the request.
+ *
+ * @return \Illuminate\Session\Store
+ *
+ * @throws \RuntimeException
+ */
+ public function session()
+ {
+ if (! $this->hasSession()) {
+ throw new RuntimeException('Session store not set on request.');
+ }
+
+ return $this->getSession();
+ }
+
+ /**
+ * Set the session instance on the request.
+ *
+ * @param \Illuminate\Contracts\Session\Session $session
+ * @return void
+ */
+ public function setLaravelSession($session)
+ {
+ $this->session = $session;
+ }
+
+ /**
+ * Get the user making the request.
+ *
+ * @param string|null $guard
+ * @return mixed
+ */
+ public function user($guard = null)
+ {
+ return call_user_func($this->getUserResolver(), $guard);
+ }
+
+ /**
+ * Get the route handling the request.
+ *
+ * @param string|null $param
+ *
+ * @return \Illuminate\Routing\Route|object|string
+ */
+ public function route($param = null)
+ {
+ $route = call_user_func($this->getRouteResolver());
+
+ if (is_null($route) || is_null($param)) {
+ return $route;
+ }
+
+ return $route->parameter($param);
+ }
+
+ /**
+ * Get a unique fingerprint for the request / route / IP address.
+ *
+ * @return string
+ *
+ * @throws \RuntimeException
+ */
+ public function fingerprint()
+ {
+ if (! $route = $this->route()) {
+ throw new RuntimeException('Unable to generate fingerprint. Route unavailable.');
+ }
+
+ return sha1(implode('|', array_merge(
+ $route->methods(), [$route->domain(), $route->uri(), $this->ip()]
+ )));
+ }
+
+ /**
+ * Set the JSON payload for the request.
+ *
+ * @param array $json
+ * @return $this
+ */
+ public function setJson($json)
+ {
+ $this->json = $json;
+
+ return $this;
+ }
+
+ /**
+ * Get the user resolver callback.
+ *
+ * @return \Closure
+ */
+ public function getUserResolver()
+ {
+ return $this->userResolver ?: function () {
+ //
+ };
+ }
+
+ /**
+ * Set the user resolver callback.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function setUserResolver(Closure $callback)
+ {
+ $this->userResolver = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Get the route resolver callback.
+ *
+ * @return \Closure
+ */
+ public function getRouteResolver()
+ {
+ return $this->routeResolver ?: function () {
+ //
+ };
+ }
+
+ /**
+ * Set the route resolver callback.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function setRouteResolver(Closure $callback)
+ {
+ $this->routeResolver = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Get all of the input and files for the request.
+ *
+ * @return array
+ */
+ public function toArray()
+ {
+ return $this->all();
+ }
+
+ /**
+ * Determine if the given offset exists.
+ *
+ * @param string $offset
+ * @return bool
+ */
+ public function offsetExists($offset)
+ {
+ return array_key_exists($offset, $this->all());
+ }
+
+ /**
+ * Get the value at the given offset.
+ *
+ * @param string $offset
+ * @return mixed
+ */
+ public function offsetGet($offset)
+ {
+ return data_get($this->all(), $offset);
+ }
+
+ /**
+ * Set the value at the given offset.
+ *
+ * @param string $offset
+ * @param mixed $value
+ * @return void
+ */
+ public function offsetSet($offset, $value)
+ {
+ $this->getInputSource()->set($offset, $value);
+ }
+
+ /**
+ * Remove the value at the given offset.
+ *
+ * @param string $offset
+ * @return void
+ */
+ public function offsetUnset($offset)
+ {
+ $this->getInputSource()->remove($offset);
+ }
+
+ /**
+ * Check if an input element is set on the request.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function __isset($key)
+ {
+ return ! is_null($this->__get($key));
+ }
+
+ /**
+ * Get an input element from the request.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function __get($key)
+ {
+ if ($this->offsetExists($key)) {
+ return $this->offsetGet($key);
+ }
+
+ return $this->route($key);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Response.php b/vendor/laravel/framework/src/Illuminate/Http/Response.php
new file mode 100644
index 000000000..f3bf3fc17
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Response.php
@@ -0,0 +1,72 @@
+original = $content;
+
+ // If the content is "JSONable" we will set the appropriate header and convert
+ // the content to JSON. This is useful when returning something like models
+ // from routes that will be automatically transformed to their JSON form.
+ if ($this->shouldBeJson($content)) {
+ $this->header('Content-Type', 'application/json');
+
+ $content = $this->morphToJson($content);
+ }
+
+ // If this content implements the "Renderable" interface then we will call the
+ // render method on the object so we will avoid any "__toString" exceptions
+ // that might be thrown and have their errors obscured by PHP's handling.
+ elseif ($content instanceof Renderable) {
+ $content = $content->render();
+ }
+
+ return parent::setContent($content);
+ }
+
+ /**
+ * Determine if the given content should be turned into JSON.
+ *
+ * @param mixed $content
+ * @return bool
+ */
+ protected function shouldBeJson($content)
+ {
+ return $content instanceof Jsonable ||
+ $content instanceof ArrayObject ||
+ $content instanceof JsonSerializable ||
+ is_array($content);
+ }
+
+ /**
+ * Morph the given content into JSON.
+ *
+ * @param mixed $content
+ * @return string
+ */
+ protected function morphToJson($content)
+ {
+ if ($content instanceof Jsonable) {
+ return $content->toJson();
+ }
+
+ return json_encode($content);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/ResponseTrait.php b/vendor/laravel/framework/src/Illuminate/Http/ResponseTrait.php
new file mode 100644
index 000000000..c7a4f80ea
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/ResponseTrait.php
@@ -0,0 +1,134 @@
+getStatusCode();
+ }
+
+ /**
+ * Get the content of the response.
+ *
+ * @return string
+ */
+ public function content()
+ {
+ return $this->getContent();
+ }
+
+ /**
+ * Get the original response content.
+ *
+ * @return mixed
+ */
+ public function getOriginalContent()
+ {
+ return $this->original;
+ }
+
+ /**
+ * Set a header on the Response.
+ *
+ * @param string $key
+ * @param array|string $values
+ * @param bool $replace
+ * @return $this
+ */
+ public function header($key, $values, $replace = true)
+ {
+ $this->headers->set($key, $values, $replace);
+
+ return $this;
+ }
+
+ /**
+ * Add an array of headers to the response.
+ *
+ * @param array $headers
+ * @return $this
+ */
+ public function withHeaders(array $headers)
+ {
+ foreach ($headers as $key => $value) {
+ $this->headers->set($key, $value);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a cookie to the response.
+ *
+ * @param \Symfony\Component\HttpFoundation\Cookie|mixed $cookie
+ * @return $this
+ */
+ public function cookie($cookie)
+ {
+ return call_user_func_array([$this, 'withCookie'], func_get_args());
+ }
+
+ /**
+ * Add a cookie to the response.
+ *
+ * @param \Symfony\Component\HttpFoundation\Cookie|mixed $cookie
+ * @return $this
+ */
+ public function withCookie($cookie)
+ {
+ if (is_string($cookie) && function_exists('cookie')) {
+ $cookie = call_user_func_array('cookie', func_get_args());
+ }
+
+ $this->headers->setCookie($cookie);
+
+ return $this;
+ }
+
+ /**
+ * Set the exception to attach to the response.
+ *
+ * @param \Exception $e
+ * @return $this
+ */
+ public function withException(Exception $e)
+ {
+ $this->exception = $e;
+
+ return $this;
+ }
+
+ /**
+ * Throws the response in a HttpResponseException instance.
+ *
+ * @throws \Illuminate\Http\Exceptions\HttpResponseException
+ */
+ public function throwResponse()
+ {
+ throw new HttpResponseException($this);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Testing/File.php b/vendor/laravel/framework/src/Illuminate/Http/Testing/File.php
new file mode 100644
index 000000000..01c118f12
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Testing/File.php
@@ -0,0 +1,115 @@
+name = $name;
+ $this->tempFile = $tempFile;
+
+ parent::__construct(
+ $this->tempFilePath(), $name, $this->getMimeType(),
+ filesize($this->tempFilePath()), $error = null, $test = true
+ );
+ }
+
+ /**
+ * Create a new fake file.
+ *
+ * @param string $name
+ * @param int $kilobytes
+ * @return \Illuminate\Http\Testing\File
+ */
+ public static function create($name, $kilobytes = 0)
+ {
+ return (new FileFactory)->create($name, $kilobytes);
+ }
+
+ /**
+ * Create a new fake image.
+ *
+ * @param string $name
+ * @param int $width
+ * @param int $height
+ * @return \Illuminate\Http\Testing\File
+ */
+ public static function image($name, $width = 10, $height = 10)
+ {
+ return (new FileFactory)->image($name, $width, $height);
+ }
+
+ /**
+ * Set the "size" of the file in kilobytes.
+ *
+ * @param int $kilobytes
+ * @return $this
+ */
+ public function size($kilobytes)
+ {
+ $this->sizeToReport = $kilobytes * 1024;
+
+ return $this;
+ }
+
+ /**
+ * Get the size of the file.
+ *
+ * @return int
+ */
+ public function getSize()
+ {
+ return $this->sizeToReport ?: parent::getSize();
+ }
+
+ /**
+ * Get the MIME type for the file.
+ *
+ * @return string
+ */
+ public function getMimeType()
+ {
+ return MimeType::from($this->name);
+ }
+
+ /**
+ * Get the path to the temporary file.
+ *
+ * @return string
+ */
+ protected function tempFilePath()
+ {
+ return stream_get_meta_data($this->tempFile)['uri'];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Testing/FileFactory.php b/vendor/laravel/framework/src/Illuminate/Http/Testing/FileFactory.php
new file mode 100644
index 000000000..0a677d7da
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Testing/FileFactory.php
@@ -0,0 +1,51 @@
+sizeToReport = $kilobytes * 1024;
+ });
+ }
+
+ /**
+ * Create a new fake image.
+ *
+ * @param string $name
+ * @param int $width
+ * @param int $height
+ * @return \Illuminate\Http\Testing\File
+ */
+ public function image($name, $width = 10, $height = 10)
+ {
+ return new File($name, $this->generateImage($width, $height));
+ }
+
+ /**
+ * Generate a dummy image of the given width and height.
+ *
+ * @param int $width
+ * @param int $height
+ * @return resource
+ */
+ protected function generateImage($width, $height)
+ {
+ return tap(tmpfile(), function ($temp) use ($width, $height) {
+ ob_start();
+
+ imagepng(imagecreatetruecolor($width, $height));
+
+ fwrite($temp, ob_get_clean());
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/Testing/MimeType.php b/vendor/laravel/framework/src/Illuminate/Http/Testing/MimeType.php
new file mode 100644
index 000000000..470614ada
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/Testing/MimeType.php
@@ -0,0 +1,793 @@
+ 'application/andrew-inset',
+ 'aw' => 'application/applixware',
+ 'atom' => 'application/atom+xml',
+ 'atomcat' => 'application/atomcat+xml',
+ 'atomsvc' => 'application/atomsvc+xml',
+ 'ccxml' => 'application/ccxml+xml',
+ 'cdmia' => 'application/cdmi-capability',
+ 'cdmic' => 'application/cdmi-container',
+ 'cdmid' => 'application/cdmi-domain',
+ 'cdmio' => 'application/cdmi-object',
+ 'cdmiq' => 'application/cdmi-queue',
+ 'cu' => 'application/cu-seeme',
+ 'davmount' => 'application/davmount+xml',
+ 'dbk' => 'application/docbook+xml',
+ 'dssc' => 'application/dssc+der',
+ 'xdssc' => 'application/dssc+xml',
+ 'ecma' => 'application/ecmascript',
+ 'emma' => 'application/emma+xml',
+ 'epub' => 'application/epub+zip',
+ 'exi' => 'application/exi',
+ 'pfr' => 'application/font-tdpfr',
+ 'gml' => 'application/gml+xml',
+ 'gpx' => 'application/gpx+xml',
+ 'gxf' => 'application/gxf',
+ 'stk' => 'application/hyperstudio',
+ 'ink' => 'application/inkml+xml',
+ 'ipfix' => 'application/ipfix',
+ 'jar' => 'application/java-archive',
+ 'ser' => 'application/java-serialized-object',
+ 'class' => 'application/java-vm',
+ 'js' => 'application/javascript',
+ 'json' => 'application/json',
+ 'jsonml' => 'application/jsonml+json',
+ 'lostxml' => 'application/lost+xml',
+ 'hqx' => 'application/mac-binhex40',
+ 'cpt' => 'application/mac-compactpro',
+ 'mads' => 'application/mads+xml',
+ 'mrc' => 'application/marc',
+ 'mrcx' => 'application/marcxml+xml',
+ 'ma' => 'application/mathematica',
+ 'mathml' => 'application/mathml+xml',
+ 'mbox' => 'application/mbox',
+ 'mscml' => 'application/mediaservercontrol+xml',
+ 'metalink' => 'application/metalink+xml',
+ 'meta4' => 'application/metalink4+xml',
+ 'mets' => 'application/mets+xml',
+ 'mods' => 'application/mods+xml',
+ 'm21' => 'application/mp21',
+ 'mp4s' => 'application/mp4',
+ 'doc' => 'application/msword',
+ 'mxf' => 'application/mxf',
+ 'bin' => 'application/octet-stream',
+ 'oda' => 'application/oda',
+ 'opf' => 'application/oebps-package+xml',
+ 'ogx' => 'application/ogg',
+ 'omdoc' => 'application/omdoc+xml',
+ 'onetoc' => 'application/onenote',
+ 'oxps' => 'application/oxps',
+ 'xer' => 'application/patch-ops-error+xml',
+ 'pdf' => 'application/pdf',
+ 'pgp' => 'application/pgp-encrypted',
+ 'asc' => 'application/pgp-signature',
+ 'prf' => 'application/pics-rules',
+ 'p10' => 'application/pkcs10',
+ 'p7m' => 'application/pkcs7-mime',
+ 'p7s' => 'application/pkcs7-signature',
+ 'p8' => 'application/pkcs8',
+ 'ac' => 'application/pkix-attr-cert',
+ 'cer' => 'application/pkix-cert',
+ 'crl' => 'application/pkix-crl',
+ 'pkipath' => 'application/pkix-pkipath',
+ 'pki' => 'application/pkixcmp',
+ 'pls' => 'application/pls+xml',
+ 'ai' => 'application/postscript',
+ 'cww' => 'application/prs.cww',
+ 'pskcxml' => 'application/pskc+xml',
+ 'rdf' => 'application/rdf+xml',
+ 'rif' => 'application/reginfo+xml',
+ 'rnc' => 'application/relax-ng-compact-syntax',
+ 'rl' => 'application/resource-lists+xml',
+ 'rld' => 'application/resource-lists-diff+xml',
+ 'rs' => 'application/rls-services+xml',
+ 'gbr' => 'application/rpki-ghostbusters',
+ 'mft' => 'application/rpki-manifest',
+ 'roa' => 'application/rpki-roa',
+ 'rsd' => 'application/rsd+xml',
+ 'rss' => 'application/rss+xml',
+ 'sbml' => 'application/sbml+xml',
+ 'scq' => 'application/scvp-cv-request',
+ 'scs' => 'application/scvp-cv-response',
+ 'spq' => 'application/scvp-vp-request',
+ 'spp' => 'application/scvp-vp-response',
+ 'sdp' => 'application/sdp',
+ 'setpay' => 'application/set-payment-initiation',
+ 'setreg' => 'application/set-registration-initiation',
+ 'shf' => 'application/shf+xml',
+ 'smi' => 'application/smil+xml',
+ 'rq' => 'application/sparql-query',
+ 'srx' => 'application/sparql-results+xml',
+ 'gram' => 'application/srgs',
+ 'grxml' => 'application/srgs+xml',
+ 'sru' => 'application/sru+xml',
+ 'ssdl' => 'application/ssdl+xml',
+ 'ssml' => 'application/ssml+xml',
+ 'tei' => 'application/tei+xml',
+ 'tfi' => 'application/thraud+xml',
+ 'tsd' => 'application/timestamped-data',
+ 'plb' => 'application/vnd.3gpp.pic-bw-large',
+ 'psb' => 'application/vnd.3gpp.pic-bw-small',
+ 'pvb' => 'application/vnd.3gpp.pic-bw-var',
+ 'tcap' => 'application/vnd.3gpp2.tcap',
+ 'pwn' => 'application/vnd.3m.post-it-notes',
+ 'aso' => 'application/vnd.accpac.simply.aso',
+ 'imp' => 'application/vnd.accpac.simply.imp',
+ 'acu' => 'application/vnd.acucobol',
+ 'atc' => 'application/vnd.acucorp',
+ 'air' => 'application/vnd.adobe.air-application-installer-package+zip',
+ 'fcdt' => 'application/vnd.adobe.formscentral.fcdt',
+ 'fxp' => 'application/vnd.adobe.fxp',
+ 'xdp' => 'application/vnd.adobe.xdp+xml',
+ 'xfdf' => 'application/vnd.adobe.xfdf',
+ 'ahead' => 'application/vnd.ahead.space',
+ 'azf' => 'application/vnd.airzip.filesecure.azf',
+ 'azs' => 'application/vnd.airzip.filesecure.azs',
+ 'azw' => 'application/vnd.amazon.ebook',
+ 'acc' => 'application/vnd.americandynamics.acc',
+ 'ami' => 'application/vnd.amiga.ami',
+ 'apk' => 'application/vnd.android.package-archive',
+ 'cii' => 'application/vnd.anser-web-certificate-issue-initiation',
+ 'fti' => 'application/vnd.anser-web-funds-transfer-initiation',
+ 'atx' => 'application/vnd.antix.game-component',
+ 'mpkg' => 'application/vnd.apple.installer+xml',
+ 'm3u8' => 'application/vnd.apple.mpegurl',
+ 'swi' => 'application/vnd.aristanetworks.swi',
+ 'iota' => 'application/vnd.astraea-software.iota',
+ 'aep' => 'application/vnd.audiograph',
+ 'mpm' => 'application/vnd.blueice.multipass',
+ 'bmi' => 'application/vnd.bmi',
+ 'rep' => 'application/vnd.businessobjects',
+ 'cdxml' => 'application/vnd.chemdraw+xml',
+ 'mmd' => 'application/vnd.chipnuts.karaoke-mmd',
+ 'cdy' => 'application/vnd.cinderella',
+ 'cla' => 'application/vnd.claymore',
+ 'rp9' => 'application/vnd.cloanto.rp9',
+ 'c4g' => 'application/vnd.clonk.c4group',
+ 'c11amc' => 'application/vnd.cluetrust.cartomobile-config',
+ 'c11amz' => 'application/vnd.cluetrust.cartomobile-config-pkg',
+ 'csp' => 'application/vnd.commonspace',
+ 'cdbcmsg' => 'application/vnd.contact.cmsg',
+ 'cmc' => 'application/vnd.cosmocaller',
+ 'clkx' => 'application/vnd.crick.clicker',
+ 'clkk' => 'application/vnd.crick.clicker.keyboard',
+ 'clkp' => 'application/vnd.crick.clicker.palette',
+ 'clkt' => 'application/vnd.crick.clicker.template',
+ 'clkw' => 'application/vnd.crick.clicker.wordbank',
+ 'wbs' => 'application/vnd.criticaltools.wbs+xml',
+ 'pml' => 'application/vnd.ctc-posml',
+ 'ppd' => 'application/vnd.cups-ppd',
+ 'car' => 'application/vnd.curl.car',
+ 'pcurl' => 'application/vnd.curl.pcurl',
+ 'dart' => 'application/vnd.dart',
+ 'rdz' => 'application/vnd.data-vision.rdz',
+ 'uvf' => 'application/vnd.dece.data',
+ 'uvt' => 'application/vnd.dece.ttml+xml',
+ 'uvx' => 'application/vnd.dece.unspecified',
+ 'uvz' => 'application/vnd.dece.zip',
+ 'fe_launch' => 'application/vnd.denovo.fcselayout-link',
+ 'dna' => 'application/vnd.dna',
+ 'mlp' => 'application/vnd.dolby.mlp',
+ 'dpg' => 'application/vnd.dpgraph',
+ 'dfac' => 'application/vnd.dreamfactory',
+ 'kpxx' => 'application/vnd.ds-keypoint',
+ 'ait' => 'application/vnd.dvb.ait',
+ 'svc' => 'application/vnd.dvb.service',
+ 'geo' => 'application/vnd.dynageo',
+ 'mag' => 'application/vnd.ecowin.chart',
+ 'nml' => 'application/vnd.enliven',
+ 'esf' => 'application/vnd.epson.esf',
+ 'msf' => 'application/vnd.epson.msf',
+ 'qam' => 'application/vnd.epson.quickanime',
+ 'slt' => 'application/vnd.epson.salt',
+ 'ssf' => 'application/vnd.epson.ssf',
+ 'es3' => 'application/vnd.eszigno3+xml',
+ 'ez2' => 'application/vnd.ezpix-album',
+ 'ez3' => 'application/vnd.ezpix-package',
+ 'fdf' => 'application/vnd.fdf',
+ 'mseed' => 'application/vnd.fdsn.mseed',
+ 'seed' => 'application/vnd.fdsn.seed',
+ 'gph' => 'application/vnd.flographit',
+ 'ftc' => 'application/vnd.fluxtime.clip',
+ 'fm' => 'application/vnd.framemaker',
+ 'fnc' => 'application/vnd.frogans.fnc',
+ 'ltf' => 'application/vnd.frogans.ltf',
+ 'fsc' => 'application/vnd.fsc.weblaunch',
+ 'oas' => 'application/vnd.fujitsu.oasys',
+ 'oa2' => 'application/vnd.fujitsu.oasys2',
+ 'oa3' => 'application/vnd.fujitsu.oasys3',
+ 'fg5' => 'application/vnd.fujitsu.oasysgp',
+ 'bh2' => 'application/vnd.fujitsu.oasysprs',
+ 'ddd' => 'application/vnd.fujixerox.ddd',
+ 'xdw' => 'application/vnd.fujixerox.docuworks',
+ 'xbd' => 'application/vnd.fujixerox.docuworks.binder',
+ 'fzs' => 'application/vnd.fuzzysheet',
+ 'txd' => 'application/vnd.genomatix.tuxedo',
+ 'ggb' => 'application/vnd.geogebra.file',
+ 'ggt' => 'application/vnd.geogebra.tool',
+ 'gex' => 'application/vnd.geometry-explorer',
+ 'gxt' => 'application/vnd.geonext',
+ 'g2w' => 'application/vnd.geoplan',
+ 'g3w' => 'application/vnd.geospace',
+ 'gmx' => 'application/vnd.gmx',
+ 'kml' => 'application/vnd.google-earth.kml+xml',
+ 'kmz' => 'application/vnd.google-earth.kmz',
+ 'gqf' => 'application/vnd.grafeq',
+ 'gac' => 'application/vnd.groove-account',
+ 'ghf' => 'application/vnd.groove-help',
+ 'gim' => 'application/vnd.groove-identity-message',
+ 'grv' => 'application/vnd.groove-injector',
+ 'gtm' => 'application/vnd.groove-tool-message',
+ 'tpl' => 'application/vnd.groove-tool-template',
+ 'vcg' => 'application/vnd.groove-vcard',
+ 'hal' => 'application/vnd.hal+xml',
+ 'zmm' => 'application/vnd.handheld-entertainment+xml',
+ 'hbci' => 'application/vnd.hbci',
+ 'les' => 'application/vnd.hhe.lesson-player',
+ 'hpgl' => 'application/vnd.hp-hpgl',
+ 'hpid' => 'application/vnd.hp-hpid',
+ 'hps' => 'application/vnd.hp-hps',
+ 'jlt' => 'application/vnd.hp-jlyt',
+ 'pcl' => 'application/vnd.hp-pcl',
+ 'pclxl' => 'application/vnd.hp-pclxl',
+ 'sfd-hdstx' => 'application/vnd.hydrostatix.sof-data',
+ 'mpy' => 'application/vnd.ibm.minipay',
+ 'afp' => 'application/vnd.ibm.modcap',
+ 'irm' => 'application/vnd.ibm.rights-management',
+ 'sc' => 'application/vnd.ibm.secure-container',
+ 'icc' => 'application/vnd.iccprofile',
+ 'igl' => 'application/vnd.igloader',
+ 'ivp' => 'application/vnd.immervision-ivp',
+ 'ivu' => 'application/vnd.immervision-ivu',
+ 'igm' => 'application/vnd.insors.igm',
+ 'xpw' => 'application/vnd.intercon.formnet',
+ 'i2g' => 'application/vnd.intergeo',
+ 'qbo' => 'application/vnd.intu.qbo',
+ 'qfx' => 'application/vnd.intu.qfx',
+ 'rcprofile' => 'application/vnd.ipunplugged.rcprofile',
+ 'irp' => 'application/vnd.irepository.package+xml',
+ 'xpr' => 'application/vnd.is-xpr',
+ 'fcs' => 'application/vnd.isac.fcs',
+ 'jam' => 'application/vnd.jam',
+ 'rms' => 'application/vnd.jcp.javame.midlet-rms',
+ 'jisp' => 'application/vnd.jisp',
+ 'joda' => 'application/vnd.joost.joda-archive',
+ 'ktz' => 'application/vnd.kahootz',
+ 'karbon' => 'application/vnd.kde.karbon',
+ 'chrt' => 'application/vnd.kde.kchart',
+ 'kfo' => 'application/vnd.kde.kformula',
+ 'flw' => 'application/vnd.kde.kivio',
+ 'kon' => 'application/vnd.kde.kontour',
+ 'kpr' => 'application/vnd.kde.kpresenter',
+ 'ksp' => 'application/vnd.kde.kspread',
+ 'kwd' => 'application/vnd.kde.kword',
+ 'htke' => 'application/vnd.kenameaapp',
+ 'kia' => 'application/vnd.kidspiration',
+ 'kne' => 'application/vnd.kinar',
+ 'skp' => 'application/vnd.koan',
+ 'sse' => 'application/vnd.kodak-descriptor',
+ 'lasxml' => 'application/vnd.las.las+xml',
+ 'lbd' => 'application/vnd.llamagraphics.life-balance.desktop',
+ 'lbe' => 'application/vnd.llamagraphics.life-balance.exchange+xml',
+ '123' => 'application/vnd.lotus-1-2-3',
+ 'apr' => 'application/vnd.lotus-approach',
+ 'pre' => 'application/vnd.lotus-freelance',
+ 'nsf' => 'application/vnd.lotus-notes',
+ 'org' => 'application/vnd.lotus-organizer',
+ 'scm' => 'application/vnd.lotus-screencam',
+ 'lwp' => 'application/vnd.lotus-wordpro',
+ 'portpkg' => 'application/vnd.macports.portpkg',
+ 'mcd' => 'application/vnd.mcd',
+ 'mc1' => 'application/vnd.medcalcdata',
+ 'cdkey' => 'application/vnd.mediastation.cdkey',
+ 'mwf' => 'application/vnd.mfer',
+ 'mfm' => 'application/vnd.mfmp',
+ 'flo' => 'application/vnd.micrografx.flo',
+ 'igx' => 'application/vnd.micrografx.igx',
+ 'mif' => 'application/vnd.mif',
+ 'daf' => 'application/vnd.mobius.daf',
+ 'dis' => 'application/vnd.mobius.dis',
+ 'mbk' => 'application/vnd.mobius.mbk',
+ 'mqy' => 'application/vnd.mobius.mqy',
+ 'msl' => 'application/vnd.mobius.msl',
+ 'plc' => 'application/vnd.mobius.plc',
+ 'txf' => 'application/vnd.mobius.txf',
+ 'mpn' => 'application/vnd.mophun.application',
+ 'mpc' => 'application/vnd.mophun.certificate',
+ 'xul' => 'application/vnd.mozilla.xul+xml',
+ 'cil' => 'application/vnd.ms-artgalry',
+ 'cab' => 'application/vnd.ms-cab-compressed',
+ 'xls' => 'application/vnd.ms-excel',
+ 'xlam' => 'application/vnd.ms-excel.addin.macroenabled.12',
+ 'xlsb' => 'application/vnd.ms-excel.sheet.binary.macroenabled.12',
+ 'xlsm' => 'application/vnd.ms-excel.sheet.macroenabled.12',
+ 'xltm' => 'application/vnd.ms-excel.template.macroenabled.12',
+ 'eot' => 'application/vnd.ms-fontobject',
+ 'chm' => 'application/vnd.ms-htmlhelp',
+ 'ims' => 'application/vnd.ms-ims',
+ 'lrm' => 'application/vnd.ms-lrm',
+ 'thmx' => 'application/vnd.ms-officetheme',
+ 'cat' => 'application/vnd.ms-pki.seccat',
+ 'stl' => 'application/vnd.ms-pki.stl',
+ 'ppt' => 'application/vnd.ms-powerpoint',
+ 'ppam' => 'application/vnd.ms-powerpoint.addin.macroenabled.12',
+ 'pptm' => 'application/vnd.ms-powerpoint.presentation.macroenabled.12',
+ 'sldm' => 'application/vnd.ms-powerpoint.slide.macroenabled.12',
+ 'ppsm' => 'application/vnd.ms-powerpoint.slideshow.macroenabled.12',
+ 'potm' => 'application/vnd.ms-powerpoint.template.macroenabled.12',
+ 'mpp' => 'application/vnd.ms-project',
+ 'docm' => 'application/vnd.ms-word.document.macroenabled.12',
+ 'dotm' => 'application/vnd.ms-word.template.macroenabled.12',
+ 'wps' => 'application/vnd.ms-works',
+ 'wpl' => 'application/vnd.ms-wpl',
+ 'xps' => 'application/vnd.ms-xpsdocument',
+ 'mseq' => 'application/vnd.mseq',
+ 'mus' => 'application/vnd.musician',
+ 'msty' => 'application/vnd.muvee.style',
+ 'taglet' => 'application/vnd.mynfc',
+ 'nlu' => 'application/vnd.neurolanguage.nlu',
+ 'ntf' => 'application/vnd.nitf',
+ 'nnd' => 'application/vnd.noblenet-directory',
+ 'nns' => 'application/vnd.noblenet-sealer',
+ 'nnw' => 'application/vnd.noblenet-web',
+ 'ngdat' => 'application/vnd.nokia.n-gage.data',
+ 'n-gage' => 'application/vnd.nokia.n-gage.symbian.install',
+ 'rpst' => 'application/vnd.nokia.radio-preset',
+ 'rpss' => 'application/vnd.nokia.radio-presets',
+ 'edm' => 'application/vnd.novadigm.edm',
+ 'edx' => 'application/vnd.novadigm.edx',
+ 'ext' => 'application/vnd.novadigm.ext',
+ 'odc' => 'application/vnd.oasis.opendocument.chart',
+ 'otc' => 'application/vnd.oasis.opendocument.chart-template',
+ 'odb' => 'application/vnd.oasis.opendocument.database',
+ 'odf' => 'application/vnd.oasis.opendocument.formula',
+ 'odft' => 'application/vnd.oasis.opendocument.formula-template',
+ 'odg' => 'application/vnd.oasis.opendocument.graphics',
+ 'otg' => 'application/vnd.oasis.opendocument.graphics-template',
+ 'odi' => 'application/vnd.oasis.opendocument.image',
+ 'oti' => 'application/vnd.oasis.opendocument.image-template',
+ 'odp' => 'application/vnd.oasis.opendocument.presentation',
+ 'otp' => 'application/vnd.oasis.opendocument.presentation-template',
+ 'ods' => 'application/vnd.oasis.opendocument.spreadsheet',
+ 'ots' => 'application/vnd.oasis.opendocument.spreadsheet-template',
+ 'odt' => 'application/vnd.oasis.opendocument.text',
+ 'odm' => 'application/vnd.oasis.opendocument.text-master',
+ 'ott' => 'application/vnd.oasis.opendocument.text-template',
+ 'oth' => 'application/vnd.oasis.opendocument.text-web',
+ 'xo' => 'application/vnd.olpc-sugar',
+ 'dd2' => 'application/vnd.oma.dd2+xml',
+ 'oxt' => 'application/vnd.openofficeorg.extension',
+ 'pptx' => 'application/vnd.openxmlformats-officedocument.presentationml.presentation',
+ 'sldx' => 'application/vnd.openxmlformats-officedocument.presentationml.slide',
+ 'ppsx' => 'application/vnd.openxmlformats-officedocument.presentationml.slideshow',
+ 'potx' => 'application/vnd.openxmlformats-officedocument.presentationml.template',
+ 'xlsx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
+ 'xltx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.template',
+ 'docx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
+ 'dotx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.template',
+ 'mgp' => 'application/vnd.osgeo.mapguide.package',
+ 'dp' => 'application/vnd.osgi.dp',
+ 'esa' => 'application/vnd.osgi.subsystem',
+ 'pdb' => 'application/vnd.palm',
+ 'paw' => 'application/vnd.pawaafile',
+ 'str' => 'application/vnd.pg.format',
+ 'ei6' => 'application/vnd.pg.osasli',
+ 'efif' => 'application/vnd.picsel',
+ 'wg' => 'application/vnd.pmi.widget',
+ 'plf' => 'application/vnd.pocketlearn',
+ 'pbd' => 'application/vnd.powerbuilder6',
+ 'box' => 'application/vnd.previewsystems.box',
+ 'mgz' => 'application/vnd.proteus.magazine',
+ 'qps' => 'application/vnd.publishare-delta-tree',
+ 'ptid' => 'application/vnd.pvi.ptid1',
+ 'qxd' => 'application/vnd.quark.quarkxpress',
+ 'bed' => 'application/vnd.realvnc.bed',
+ 'mxl' => 'application/vnd.recordare.musicxml',
+ 'musicxml' => 'application/vnd.recordare.musicxml+xml',
+ 'cryptonote' => 'application/vnd.rig.cryptonote',
+ 'cod' => 'application/vnd.rim.cod',
+ 'rm' => 'application/vnd.rn-realmedia',
+ 'rmvb' => 'application/vnd.rn-realmedia-vbr',
+ 'link66' => 'application/vnd.route66.link66+xml',
+ 'st' => 'application/vnd.sailingtracker.track',
+ 'see' => 'application/vnd.seemail',
+ 'sema' => 'application/vnd.sema',
+ 'semd' => 'application/vnd.semd',
+ 'semf' => 'application/vnd.semf',
+ 'ifm' => 'application/vnd.shana.informed.formdata',
+ 'itp' => 'application/vnd.shana.informed.formtemplate',
+ 'iif' => 'application/vnd.shana.informed.interchange',
+ 'ipk' => 'application/vnd.shana.informed.package',
+ 'twd' => 'application/vnd.simtech-mindmapper',
+ 'mmf' => 'application/vnd.smaf',
+ 'teacher' => 'application/vnd.smart.teacher',
+ 'sdkm' => 'application/vnd.solent.sdkm+xml',
+ 'dxp' => 'application/vnd.spotfire.dxp',
+ 'sfs' => 'application/vnd.spotfire.sfs',
+ 'sdc' => 'application/vnd.stardivision.calc',
+ 'sda' => 'application/vnd.stardivision.draw',
+ 'sdd' => 'application/vnd.stardivision.impress',
+ 'smf' => 'application/vnd.stardivision.math',
+ 'sdw' => 'application/vnd.stardivision.writer',
+ 'sgl' => 'application/vnd.stardivision.writer-global',
+ 'smzip' => 'application/vnd.stepmania.package',
+ 'sm' => 'application/vnd.stepmania.stepchart',
+ 'sxc' => 'application/vnd.sun.xml.calc',
+ 'stc' => 'application/vnd.sun.xml.calc.template',
+ 'sxd' => 'application/vnd.sun.xml.draw',
+ 'std' => 'application/vnd.sun.xml.draw.template',
+ 'sxi' => 'application/vnd.sun.xml.impress',
+ 'sti' => 'application/vnd.sun.xml.impress.template',
+ 'sxm' => 'application/vnd.sun.xml.math',
+ 'sxw' => 'application/vnd.sun.xml.writer',
+ 'sxg' => 'application/vnd.sun.xml.writer.global',
+ 'stw' => 'application/vnd.sun.xml.writer.template',
+ 'sus' => 'application/vnd.sus-calendar',
+ 'svd' => 'application/vnd.svd',
+ 'sis' => 'application/vnd.symbian.install',
+ 'xsm' => 'application/vnd.syncml+xml',
+ 'bdm' => 'application/vnd.syncml.dm+wbxml',
+ 'xdm' => 'application/vnd.syncml.dm+xml',
+ 'tao' => 'application/vnd.tao.intent-module-archive',
+ 'pcap' => 'application/vnd.tcpdump.pcap',
+ 'tmo' => 'application/vnd.tmobile-livetv',
+ 'tpt' => 'application/vnd.trid.tpt',
+ 'mxs' => 'application/vnd.triscape.mxs',
+ 'tra' => 'application/vnd.trueapp',
+ 'ufd' => 'application/vnd.ufdl',
+ 'utz' => 'application/vnd.uiq.theme',
+ 'umj' => 'application/vnd.umajin',
+ 'unityweb' => 'application/vnd.unity',
+ 'uoml' => 'application/vnd.uoml+xml',
+ 'vcx' => 'application/vnd.vcx',
+ 'vsd' => 'application/vnd.visio',
+ 'vis' => 'application/vnd.visionary',
+ 'vsf' => 'application/vnd.vsf',
+ 'wbxml' => 'application/vnd.wap.wbxml',
+ 'wmlc' => 'application/vnd.wap.wmlc',
+ 'wmlsc' => 'application/vnd.wap.wmlscriptc',
+ 'wtb' => 'application/vnd.webturbo',
+ 'nbp' => 'application/vnd.wolfram.player',
+ 'wpd' => 'application/vnd.wordperfect',
+ 'wqd' => 'application/vnd.wqd',
+ 'stf' => 'application/vnd.wt.stf',
+ 'xar' => 'application/vnd.xara',
+ 'xfdl' => 'application/vnd.xfdl',
+ 'hvd' => 'application/vnd.yamaha.hv-dic',
+ 'hvs' => 'application/vnd.yamaha.hv-script',
+ 'hvp' => 'application/vnd.yamaha.hv-voice',
+ 'osf' => 'application/vnd.yamaha.openscoreformat',
+ 'osfpvg' => 'application/vnd.yamaha.openscoreformat.osfpvg+xml',
+ 'saf' => 'application/vnd.yamaha.smaf-audio',
+ 'spf' => 'application/vnd.yamaha.smaf-phrase',
+ 'cmp' => 'application/vnd.yellowriver-custom-menu',
+ 'zir' => 'application/vnd.zul',
+ 'zaz' => 'application/vnd.zzazz.deck+xml',
+ 'vxml' => 'application/voicexml+xml',
+ 'wgt' => 'application/widget',
+ 'hlp' => 'application/winhlp',
+ 'wsdl' => 'application/wsdl+xml',
+ 'wspolicy' => 'application/wspolicy+xml',
+ '7z' => 'application/x-7z-compressed',
+ 'abw' => 'application/x-abiword',
+ 'ace' => 'application/x-ace-compressed',
+ 'dmg' => 'application/x-apple-diskimage',
+ 'aab' => 'application/x-authorware-bin',
+ 'aam' => 'application/x-authorware-map',
+ 'aas' => 'application/x-authorware-seg',
+ 'bcpio' => 'application/x-bcpio',
+ 'torrent' => 'application/x-bittorrent',
+ 'blb' => 'application/x-blorb',
+ 'bz' => 'application/x-bzip',
+ 'bz2' => 'application/x-bzip2',
+ 'cbr' => 'application/x-cbr',
+ 'vcd' => 'application/x-cdlink',
+ 'cfs' => 'application/x-cfs-compressed',
+ 'chat' => 'application/x-chat',
+ 'pgn' => 'application/x-chess-pgn',
+ 'nsc' => 'application/x-conference',
+ 'cpio' => 'application/x-cpio',
+ 'csh' => 'application/x-csh',
+ 'deb' => 'application/x-debian-package',
+ 'dgc' => 'application/x-dgc-compressed',
+ 'dir' => 'application/x-director',
+ 'wad' => 'application/x-doom',
+ 'ncx' => 'application/x-dtbncx+xml',
+ 'dtb' => 'application/x-dtbook+xml',
+ 'res' => 'application/x-dtbresource+xml',
+ 'dvi' => 'application/x-dvi',
+ 'evy' => 'application/x-envoy',
+ 'eva' => 'application/x-eva',
+ 'bdf' => 'application/x-font-bdf',
+ 'gsf' => 'application/x-font-ghostscript',
+ 'psf' => 'application/x-font-linux-psf',
+ 'otf' => 'application/x-font-otf',
+ 'pcf' => 'application/x-font-pcf',
+ 'snf' => 'application/x-font-snf',
+ 'ttf' => 'application/x-font-ttf',
+ 'pfa' => 'application/x-font-type1',
+ 'woff' => 'application/x-font-woff',
+ 'arc' => 'application/x-freearc',
+ 'spl' => 'application/x-futuresplash',
+ 'gca' => 'application/x-gca-compressed',
+ 'ulx' => 'application/x-glulx',
+ 'gnumeric' => 'application/x-gnumeric',
+ 'gramps' => 'application/x-gramps-xml',
+ 'gtar' => 'application/x-gtar',
+ 'hdf' => 'application/x-hdf',
+ 'install' => 'application/x-install-instructions',
+ 'iso' => 'application/x-iso9660-image',
+ 'jnlp' => 'application/x-java-jnlp-file',
+ 'latex' => 'application/x-latex',
+ 'lzh' => 'application/x-lzh-compressed',
+ 'mie' => 'application/x-mie',
+ 'prc' => 'application/x-mobipocket-ebook',
+ 'application' => 'application/x-ms-application',
+ 'lnk' => 'application/x-ms-shortcut',
+ 'wmd' => 'application/x-ms-wmd',
+ 'wmz' => 'application/x-ms-wmz',
+ 'xbap' => 'application/x-ms-xbap',
+ 'mdb' => 'application/x-msaccess',
+ 'obd' => 'application/x-msbinder',
+ 'crd' => 'application/x-mscardfile',
+ 'clp' => 'application/x-msclip',
+ 'exe' => 'application/x-msdownload',
+ 'mvb' => 'application/x-msmediaview',
+ 'wmf' => 'application/x-msmetafile',
+ 'mny' => 'application/x-msmoney',
+ 'pub' => 'application/x-mspublisher',
+ 'scd' => 'application/x-msschedule',
+ 'trm' => 'application/x-msterminal',
+ 'wri' => 'application/x-mswrite',
+ 'nc' => 'application/x-netcdf',
+ 'nzb' => 'application/x-nzb',
+ 'p12' => 'application/x-pkcs12',
+ 'p7b' => 'application/x-pkcs7-certificates',
+ 'p7r' => 'application/x-pkcs7-certreqresp',
+ 'rar' => 'application/x-rar',
+ 'ris' => 'application/x-research-info-systems',
+ 'sh' => 'application/x-sh',
+ 'shar' => 'application/x-shar',
+ 'swf' => 'application/x-shockwave-flash',
+ 'xap' => 'application/x-silverlight-app',
+ 'sql' => 'application/x-sql',
+ 'sit' => 'application/x-stuffit',
+ 'sitx' => 'application/x-stuffitx',
+ 'srt' => 'application/x-subrip',
+ 'sv4cpio' => 'application/x-sv4cpio',
+ 'sv4crc' => 'application/x-sv4crc',
+ 't3' => 'application/x-t3vm-image',
+ 'gam' => 'application/x-tads',
+ 'tar' => 'application/x-tar',
+ 'tcl' => 'application/x-tcl',
+ 'tex' => 'application/x-tex',
+ 'tfm' => 'application/x-tex-tfm',
+ 'texinfo' => 'application/x-texinfo',
+ 'obj' => 'application/x-tgif',
+ 'ustar' => 'application/x-ustar',
+ 'src' => 'application/x-wais-source',
+ 'der' => 'application/x-x509-ca-cert',
+ 'fig' => 'application/x-xfig',
+ 'xlf' => 'application/x-xliff+xml',
+ 'xpi' => 'application/x-xpinstall',
+ 'xz' => 'application/x-xz',
+ 'z1' => 'application/x-zmachine',
+ 'xaml' => 'application/xaml+xml',
+ 'xdf' => 'application/xcap-diff+xml',
+ 'xenc' => 'application/xenc+xml',
+ 'xhtml' => 'application/xhtml+xml',
+ 'xml' => 'application/xml',
+ 'dtd' => 'application/xml-dtd',
+ 'xop' => 'application/xop+xml',
+ 'xpl' => 'application/xproc+xml',
+ 'xslt' => 'application/xslt+xml',
+ 'xspf' => 'application/xspf+xml',
+ 'mxml' => 'application/xv+xml',
+ 'yang' => 'application/yang',
+ 'yin' => 'application/yin+xml',
+ 'zip' => 'application/zip',
+ 'adp' => 'audio/adpcm',
+ 'au' => 'audio/basic',
+ 'mid' => 'audio/midi',
+ 'mp3' => 'audio/mpeg',
+ 'mp4a' => 'audio/mp4',
+ 'mpga' => 'audio/mpeg',
+ 'oga' => 'audio/ogg',
+ 's3m' => 'audio/s3m',
+ 'sil' => 'audio/silk',
+ 'uva' => 'audio/vnd.dece.audio',
+ 'eol' => 'audio/vnd.digital-winds',
+ 'dra' => 'audio/vnd.dra',
+ 'dts' => 'audio/vnd.dts',
+ 'dtshd' => 'audio/vnd.dts.hd',
+ 'lvp' => 'audio/vnd.lucent.voice',
+ 'pya' => 'audio/vnd.ms-playready.media.pya',
+ 'ecelp4800' => 'audio/vnd.nuera.ecelp4800',
+ 'ecelp7470' => 'audio/vnd.nuera.ecelp7470',
+ 'ecelp9600' => 'audio/vnd.nuera.ecelp9600',
+ 'rip' => 'audio/vnd.rip',
+ 'weba' => 'audio/webm',
+ 'aac' => 'audio/x-aac',
+ 'aif' => 'audio/x-aiff',
+ 'caf' => 'audio/x-caf',
+ 'flac' => 'audio/x-flac',
+ 'mka' => 'audio/x-matroska',
+ 'm3u' => 'audio/x-mpegurl',
+ 'wax' => 'audio/x-ms-wax',
+ 'wma' => 'audio/x-ms-wma',
+ 'ram' => 'audio/x-pn-realaudio',
+ 'rmp' => 'audio/x-pn-realaudio-plugin',
+ 'wav' => 'audio/x-wav',
+ 'xm' => 'audio/xm',
+ 'cdx' => 'chemical/x-cdx',
+ 'cif' => 'chemical/x-cif',
+ 'cmdf' => 'chemical/x-cmdf',
+ 'cml' => 'chemical/x-cml',
+ 'csml' => 'chemical/x-csml',
+ 'xyz' => 'chemical/x-xyz',
+ 'bmp' => 'image/bmp',
+ 'cgm' => 'image/cgm',
+ 'g3' => 'image/g3fax',
+ 'gif' => 'image/gif',
+ 'ief' => 'image/ief',
+ 'jpg' => 'image/jpeg',
+ 'jpeg' => 'image/jpeg',
+ 'ktx' => 'image/ktx',
+ 'png' => 'image/png',
+ 'btif' => 'image/prs.btif',
+ 'sgi' => 'image/sgi',
+ 'svg' => 'image/svg+xml',
+ 'tiff' => 'image/tiff',
+ 'psd' => 'image/vnd.adobe.photoshop',
+ 'uvi' => 'image/vnd.dece.graphic',
+ 'djvu' => 'image/vnd.djvu',
+ 'dwg' => 'image/vnd.dwg',
+ 'dxf' => 'image/vnd.dxf',
+ 'fbs' => 'image/vnd.fastbidsheet',
+ 'fpx' => 'image/vnd.fpx',
+ 'fst' => 'image/vnd.fst',
+ 'mmr' => 'image/vnd.fujixerox.edmics-mmr',
+ 'rlc' => 'image/vnd.fujixerox.edmics-rlc',
+ 'mdi' => 'image/vnd.ms-modi',
+ 'wdp' => 'image/vnd.ms-photo',
+ 'npx' => 'image/vnd.net-fpx',
+ 'wbmp' => 'image/vnd.wap.wbmp',
+ 'xif' => 'image/vnd.xiff',
+ 'webp' => 'image/webp',
+ '3ds' => 'image/x-3ds',
+ 'ras' => 'image/x-cmu-raster',
+ 'cmx' => 'image/x-cmx',
+ 'fh' => 'image/x-freehand',
+ 'ico' => 'image/x-icon',
+ 'sid' => 'image/x-mrsid-image',
+ 'pcx' => 'image/x-pcx',
+ 'pic' => 'image/x-pict',
+ 'pnm' => 'image/x-portable-anymap',
+ 'pbm' => 'image/x-portable-bitmap',
+ 'pgm' => 'image/x-portable-graymap',
+ 'ppm' => 'image/x-portable-pixmap',
+ 'rgb' => 'image/x-rgb',
+ 'tga' => 'image/x-tga',
+ 'xbm' => 'image/x-xbitmap',
+ 'xpm' => 'image/x-xpixmap',
+ 'xwd' => 'image/x-xwindowdump',
+ 'eml' => 'message/rfc822',
+ 'igs' => 'model/iges',
+ 'msh' => 'model/mesh',
+ 'dae' => 'model/vnd.collada+xml',
+ 'dwf' => 'model/vnd.dwf',
+ 'gdl' => 'model/vnd.gdl',
+ 'gtw' => 'model/vnd.gtw',
+ 'mts' => 'model/vnd.mts',
+ 'vtu' => 'model/vnd.vtu',
+ 'wrl' => 'model/vrml',
+ 'x3db' => 'model/x3d+binary',
+ 'x3dv' => 'model/x3d+vrml',
+ 'x3d' => 'model/x3d+xml',
+ 'appcache' => 'text/cache-manifest',
+ 'ics' => 'text/calendar',
+ 'css' => 'text/css',
+ 'csv' => 'text/csv',
+ 'html' => 'text/html',
+ 'n3' => 'text/n3',
+ 'txt' => 'text/plain',
+ 'dsc' => 'text/prs.lines.tag',
+ 'rtx' => 'text/richtext',
+ 'rtf' => 'text/rtf',
+ 'sgml' => 'text/sgml',
+ 'tsv' => 'text/tab-separated-values',
+ 't' => 'text/troff',
+ 'ttl' => 'text/turtle',
+ 'uri' => 'text/uri-list',
+ 'vcard' => 'text/vcard',
+ 'curl' => 'text/vnd.curl',
+ 'dcurl' => 'text/vnd.curl.dcurl',
+ 'scurl' => 'text/vnd.curl.scurl',
+ 'mcurl' => 'text/vnd.curl.mcurl',
+ 'sub' => 'text/vnd.dvb.subtitle',
+ 'fly' => 'text/vnd.fly',
+ 'flx' => 'text/vnd.fmi.flexstor',
+ 'gv' => 'text/vnd.graphviz',
+ '3dml' => 'text/vnd.in3d.3dml',
+ 'spot' => 'text/vnd.in3d.spot',
+ 'jad' => 'text/vnd.sun.j2me.app-descriptor',
+ 'wml' => 'text/vnd.wap.wml',
+ 'wmls' => 'text/vnd.wap.wmlscript',
+ 's' => 'text/x-asm',
+ 'c' => 'text/x-c',
+ 'f' => 'text/x-fortran',
+ 'p' => 'text/x-pascal',
+ 'java' => 'text/x-java-source',
+ 'opml' => 'text/x-opml',
+ 'nfo' => 'text/x-nfo',
+ 'etx' => 'text/x-setext',
+ 'sfv' => 'text/x-sfv',
+ 'uu' => 'text/x-uuencode',
+ 'vcs' => 'text/x-vcalendar',
+ 'vcf' => 'text/x-vcard',
+ '3gp' => 'video/3gpp',
+ '3g2' => 'video/3gpp2',
+ 'h261' => 'video/h261',
+ 'h263' => 'video/h263',
+ 'h264' => 'video/h264',
+ 'jpgv' => 'video/jpeg',
+ 'jpm' => 'video/jpm',
+ 'mj2' => 'video/mj2',
+ 'mp4' => 'video/mp4',
+ 'mpeg' => 'video/mpeg',
+ 'ogv' => 'video/ogg',
+ 'qt' => 'video/quicktime',
+ 'uvh' => 'video/vnd.dece.hd',
+ 'uvm' => 'video/vnd.dece.mobile',
+ 'uvp' => 'video/vnd.dece.pd',
+ 'uvs' => 'video/vnd.dece.sd',
+ 'uvv' => 'video/vnd.dece.video',
+ 'dvb' => 'video/vnd.dvb.file',
+ 'fvt' => 'video/vnd.fvt',
+ 'mxu' => 'video/vnd.mpegurl',
+ 'pyv' => 'video/vnd.ms-playready.media.pyv',
+ 'uvu' => 'video/vnd.uvvu.mp4',
+ 'viv' => 'video/vnd.vivo',
+ 'webm' => 'video/webm',
+ 'f4v' => 'video/x-f4v',
+ 'fli' => 'video/x-fli',
+ 'flv' => 'video/x-flv',
+ 'm4v' => 'video/x-m4v',
+ 'mkv' => 'video/x-matroska',
+ 'mng' => 'video/x-mng',
+ 'asf' => 'video/x-ms-asf',
+ 'vob' => 'video/x-ms-vob',
+ 'wm' => 'video/x-ms-wm',
+ 'wmv' => 'video/x-ms-wmv',
+ 'wmx' => 'video/x-ms-wmx',
+ 'wvx' => 'video/x-ms-wvx',
+ 'avi' => 'video/x-msvideo',
+ 'movie' => 'video/x-sgi-movie',
+ 'smv' => 'video/x-smv',
+ 'ice' => 'x-conference/x-cooltalk',
+ ];
+
+ /**
+ * Get the MIME type for a file based on the file's extension.
+ *
+ * @param string $filename
+ * @return string
+ */
+ public static function from($filename)
+ {
+ $extension = pathinfo($filename, PATHINFO_EXTENSION);
+
+ return collect(self::$mimes)->get($extension, 'application/octet-stream');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/UploadedFile.php b/vendor/laravel/framework/src/Illuminate/Http/UploadedFile.php
new file mode 100644
index 000000000..8ed7e7f98
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/UploadedFile.php
@@ -0,0 +1,122 @@
+storeAs($path, $this->hashName(), $this->parseOptions($options));
+ }
+
+ /**
+ * Store the uploaded file on a filesystem disk with public visibility.
+ *
+ * @param string $path
+ * @param array|string $options
+ * @return string|false
+ */
+ public function storePublicly($path, $options = [])
+ {
+ $options = $this->parseOptions($options);
+
+ $options['visibility'] = 'public';
+
+ return $this->storeAs($path, $this->hashName(), $options);
+ }
+
+ /**
+ * Store the uploaded file on a filesystem disk with public visibility.
+ *
+ * @param string $path
+ * @param string $name
+ * @param array|string $options
+ * @return string|false
+ */
+ public function storePubliclyAs($path, $name, $options = [])
+ {
+ $options = $this->parseOptions($options);
+
+ $options['visibility'] = 'public';
+
+ return $this->storeAs($path, $name, $options);
+ }
+
+ /**
+ * Store the uploaded file on a filesystem disk.
+ *
+ * @param string $path
+ * @param string $name
+ * @param array|string $options
+ * @return string|false
+ */
+ public function storeAs($path, $name, $options = [])
+ {
+ $options = $this->parseOptions($options);
+
+ $disk = Arr::pull($options, 'disk');
+
+ return Container::getInstance()->make(FilesystemFactory::class)->disk($disk)->putFileAs(
+ $path, $this, $name, $options
+ );
+ }
+
+ /**
+ * Create a new file instance from a base instance.
+ *
+ * @param \Symfony\Component\HttpFoundation\File\UploadedFile $file
+ * @param bool $test
+ * @return static
+ */
+ public static function createFromBase(SymfonyUploadedFile $file, $test = false)
+ {
+ return $file instanceof static ? $file : new static(
+ $file->getPathname(),
+ $file->getClientOriginalName(),
+ $file->getClientMimeType(),
+ $file->getClientSize(),
+ $file->getError(),
+ $test
+ );
+ }
+
+ /**
+ * Parse and format the given options.
+ *
+ * @param array|string $options
+ * @return array
+ */
+ protected function parseOptions($options)
+ {
+ if (is_string($options)) {
+ $options = ['disk' => $options];
+ }
+
+ return $options;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Http/composer.json b/vendor/laravel/framework/src/Illuminate/Http/composer.json
new file mode 100644
index 000000000..14bf748ca
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Http/composer.json
@@ -0,0 +1,37 @@
+{
+ "name": "illuminate/http",
+ "description": "The Illuminate Http package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/session": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "symfony/http-foundation": "~3.2",
+ "symfony/http-kernel": "~3.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Http\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Log/Events/MessageLogged.php b/vendor/laravel/framework/src/Illuminate/Log/Events/MessageLogged.php
new file mode 100644
index 000000000..312b343a3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Log/Events/MessageLogged.php
@@ -0,0 +1,42 @@
+level = $level;
+ $this->message = $message;
+ $this->context = $context;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Log/LogServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Log/LogServiceProvider.php
new file mode 100644
index 000000000..a927dbf98
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Log/LogServiceProvider.php
@@ -0,0 +1,154 @@
+app->singleton('log', function () {
+ return $this->createLogger();
+ });
+ }
+
+ /**
+ * Create the logger.
+ *
+ * @return \Illuminate\Log\Writer
+ */
+ public function createLogger()
+ {
+ $log = new Writer(
+ new Monolog($this->channel()), $this->app['events']
+ );
+
+ if ($this->app->hasMonologConfigurator()) {
+ call_user_func($this->app->getMonologConfigurator(), $log->getMonolog());
+ } else {
+ $this->configureHandler($log);
+ }
+
+ return $log;
+ }
+
+ /**
+ * Get the name of the log "channel".
+ *
+ * @return string
+ */
+ protected function channel()
+ {
+ return $this->app->bound('env') ? $this->app->environment() : 'production';
+ }
+
+ /**
+ * Configure the Monolog handlers for the application.
+ *
+ * @param \Illuminate\Log\Writer $log
+ * @return void
+ */
+ protected function configureHandler(Writer $log)
+ {
+ $this->{'configure'.ucfirst($this->handler()).'Handler'}($log);
+ }
+
+ /**
+ * Configure the Monolog handlers for the application.
+ *
+ * @param \Illuminate\Log\Writer $log
+ * @return void
+ */
+ protected function configureSingleHandler(Writer $log)
+ {
+ $log->useFiles(
+ $this->app->storagePath().'/logs/laravel.log',
+ $this->logLevel()
+ );
+ }
+
+ /**
+ * Configure the Monolog handlers for the application.
+ *
+ * @param \Illuminate\Log\Writer $log
+ * @return void
+ */
+ protected function configureDailyHandler(Writer $log)
+ {
+ $log->useDailyFiles(
+ $this->app->storagePath().'/logs/laravel.log', $this->maxFiles(),
+ $this->logLevel()
+ );
+ }
+
+ /**
+ * Configure the Monolog handlers for the application.
+ *
+ * @param \Illuminate\Log\Writer $log
+ * @return void
+ */
+ protected function configureSyslogHandler(Writer $log)
+ {
+ $log->useSyslog('laravel', $this->logLevel());
+ }
+
+ /**
+ * Configure the Monolog handlers for the application.
+ *
+ * @param \Illuminate\Log\Writer $log
+ * @return void
+ */
+ protected function configureErrorlogHandler(Writer $log)
+ {
+ $log->useErrorLog($this->logLevel());
+ }
+
+ /**
+ * Get the default log handler.
+ *
+ * @return string
+ */
+ protected function handler()
+ {
+ if ($this->app->bound('config')) {
+ return $this->app->make('config')->get('app.log', 'single');
+ }
+
+ return 'single';
+ }
+
+ /**
+ * Get the log level for the application.
+ *
+ * @return string
+ */
+ protected function logLevel()
+ {
+ if ($this->app->bound('config')) {
+ return $this->app->make('config')->get('app.log_level', 'debug');
+ }
+
+ return 'debug';
+ }
+
+ /**
+ * Get the maximum number of log files for the application.
+ *
+ * @return int
+ */
+ protected function maxFiles()
+ {
+ if ($this->app->bound('config')) {
+ return $this->app->make('config')->get('app.log_max_files', 5);
+ }
+
+ return 0;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Log/Writer.php b/vendor/laravel/framework/src/Illuminate/Log/Writer.php
new file mode 100644
index 000000000..94b3e2d62
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Log/Writer.php
@@ -0,0 +1,377 @@
+ MonologLogger::DEBUG,
+ 'info' => MonologLogger::INFO,
+ 'notice' => MonologLogger::NOTICE,
+ 'warning' => MonologLogger::WARNING,
+ 'error' => MonologLogger::ERROR,
+ 'critical' => MonologLogger::CRITICAL,
+ 'alert' => MonologLogger::ALERT,
+ 'emergency' => MonologLogger::EMERGENCY,
+ ];
+
+ /**
+ * Create a new log writer instance.
+ *
+ * @param \Monolog\Logger $monolog
+ * @param \Illuminate\Contracts\Events\Dispatcher $dispatcher
+ * @return void
+ */
+ public function __construct(MonologLogger $monolog, Dispatcher $dispatcher = null)
+ {
+ $this->monolog = $monolog;
+
+ if (isset($dispatcher)) {
+ $this->dispatcher = $dispatcher;
+ }
+ }
+
+ /**
+ * Log an emergency message to the logs.
+ *
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ public function emergency($message, array $context = [])
+ {
+ $this->writeLog(__FUNCTION__, $message, $context);
+ }
+
+ /**
+ * Log an alert message to the logs.
+ *
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ public function alert($message, array $context = [])
+ {
+ $this->writeLog(__FUNCTION__, $message, $context);
+ }
+
+ /**
+ * Log a critical message to the logs.
+ *
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ public function critical($message, array $context = [])
+ {
+ $this->writeLog(__FUNCTION__, $message, $context);
+ }
+
+ /**
+ * Log an error message to the logs.
+ *
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ public function error($message, array $context = [])
+ {
+ $this->writeLog(__FUNCTION__, $message, $context);
+ }
+
+ /**
+ * Log a warning message to the logs.
+ *
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ public function warning($message, array $context = [])
+ {
+ $this->writeLog(__FUNCTION__, $message, $context);
+ }
+
+ /**
+ * Log a notice to the logs.
+ *
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ public function notice($message, array $context = [])
+ {
+ $this->writeLog(__FUNCTION__, $message, $context);
+ }
+
+ /**
+ * Log an informational message to the logs.
+ *
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ public function info($message, array $context = [])
+ {
+ $this->writeLog(__FUNCTION__, $message, $context);
+ }
+
+ /**
+ * Log a debug message to the logs.
+ *
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ public function debug($message, array $context = [])
+ {
+ $this->writeLog(__FUNCTION__, $message, $context);
+ }
+
+ /**
+ * Log a message to the logs.
+ *
+ * @param string $level
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ public function log($level, $message, array $context = [])
+ {
+ $this->writeLog($level, $message, $context);
+ }
+
+ /**
+ * Dynamically pass log calls into the writer.
+ *
+ * @param string $level
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ public function write($level, $message, array $context = [])
+ {
+ $this->writeLog($level, $message, $context);
+ }
+
+ /**
+ * Write a message to Monolog.
+ *
+ * @param string $level
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ protected function writeLog($level, $message, $context)
+ {
+ $this->fireLogEvent($level, $message = $this->formatMessage($message), $context);
+
+ $this->monolog->{$level}($message, $context);
+ }
+
+ /**
+ * Register a file log handler.
+ *
+ * @param string $path
+ * @param string $level
+ * @return void
+ */
+ public function useFiles($path, $level = 'debug')
+ {
+ $this->monolog->pushHandler($handler = new StreamHandler($path, $this->parseLevel($level)));
+
+ $handler->setFormatter($this->getDefaultFormatter());
+ }
+
+ /**
+ * Register a daily file log handler.
+ *
+ * @param string $path
+ * @param int $days
+ * @param string $level
+ * @return void
+ */
+ public function useDailyFiles($path, $days = 0, $level = 'debug')
+ {
+ $this->monolog->pushHandler(
+ $handler = new RotatingFileHandler($path, $days, $this->parseLevel($level))
+ );
+
+ $handler->setFormatter($this->getDefaultFormatter());
+ }
+
+ /**
+ * Register a Syslog handler.
+ *
+ * @param string $name
+ * @param string $level
+ * @param mixed $facility
+ * @return \Psr\Log\LoggerInterface
+ */
+ public function useSyslog($name = 'laravel', $level = 'debug', $facility = LOG_USER)
+ {
+ return $this->monolog->pushHandler(new SyslogHandler($name, $facility, $level));
+ }
+
+ /**
+ * Register an error_log handler.
+ *
+ * @param string $level
+ * @param int $messageType
+ * @return void
+ */
+ public function useErrorLog($level = 'debug', $messageType = ErrorLogHandler::OPERATING_SYSTEM)
+ {
+ $this->monolog->pushHandler(
+ $handler = new ErrorLogHandler($messageType, $this->parseLevel($level))
+ );
+
+ $handler->setFormatter($this->getDefaultFormatter());
+ }
+
+ /**
+ * Register a new callback handler for when a log event is triggered.
+ *
+ * @param \Closure $callback
+ * @return void
+ *
+ * @throws \RuntimeException
+ */
+ public function listen(Closure $callback)
+ {
+ if (! isset($this->dispatcher)) {
+ throw new RuntimeException('Events dispatcher has not been set.');
+ }
+
+ $this->dispatcher->listen(MessageLogged::class, $callback);
+ }
+
+ /**
+ * Fires a log event.
+ *
+ * @param string $level
+ * @param string $message
+ * @param array $context
+ * @return void
+ */
+ protected function fireLogEvent($level, $message, array $context = [])
+ {
+ // If the event dispatcher is set, we will pass along the parameters to the
+ // log listeners. These are useful for building profilers or other tools
+ // that aggregate all of the log messages for a given "request" cycle.
+ if (isset($this->dispatcher)) {
+ $this->dispatcher->dispatch(new MessageLogged($level, $message, $context));
+ }
+ }
+
+ /**
+ * Format the parameters for the logger.
+ *
+ * @param mixed $message
+ * @return mixed
+ */
+ protected function formatMessage($message)
+ {
+ if (is_array($message)) {
+ return var_export($message, true);
+ } elseif ($message instanceof Jsonable) {
+ return $message->toJson();
+ } elseif ($message instanceof Arrayable) {
+ return var_export($message->toArray(), true);
+ }
+
+ return $message;
+ }
+
+ /**
+ * Parse the string level into a Monolog constant.
+ *
+ * @param string $level
+ * @return int
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function parseLevel($level)
+ {
+ if (isset($this->levels[$level])) {
+ return $this->levels[$level];
+ }
+
+ throw new InvalidArgumentException('Invalid log level.');
+ }
+
+ /**
+ * Get the underlying Monolog instance.
+ *
+ * @return \Monolog\Logger
+ */
+ public function getMonolog()
+ {
+ return $this->monolog;
+ }
+
+ /**
+ * Get a default Monolog formatter instance.
+ *
+ * @return \Monolog\Formatter\LineFormatter
+ */
+ protected function getDefaultFormatter()
+ {
+ return new LineFormatter(null, null, true, true);
+ }
+
+ /**
+ * Get the event dispatcher instance.
+ *
+ * @return \Illuminate\Contracts\Events\Dispatcher
+ */
+ public function getEventDispatcher()
+ {
+ return $this->dispatcher;
+ }
+
+ /**
+ * Set the event dispatcher instance.
+ *
+ * @param \Illuminate\Contracts\Events\Dispatcher $dispatcher
+ * @return void
+ */
+ public function setEventDispatcher(Dispatcher $dispatcher)
+ {
+ $this->dispatcher = $dispatcher;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Log/composer.json b/vendor/laravel/framework/src/Illuminate/Log/composer.json
new file mode 100644
index 000000000..cfcad97ef
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Log/composer.json
@@ -0,0 +1,36 @@
+{
+ "name": "illuminate/log",
+ "description": "The Illuminate Log package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "monolog/monolog": "~1.11"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Log\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Events/MessageSending.php b/vendor/laravel/framework/src/Illuminate/Mail/Events/MessageSending.php
new file mode 100644
index 000000000..17bc25731
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Events/MessageSending.php
@@ -0,0 +1,24 @@
+message = $message;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Events/MessageSent.php b/vendor/laravel/framework/src/Illuminate/Mail/Events/MessageSent.php
new file mode 100644
index 000000000..8af4a0e93
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Events/MessageSent.php
@@ -0,0 +1,24 @@
+message = $message;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/MailServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Mail/MailServiceProvider.php
new file mode 100644
index 000000000..e185c3796
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/MailServiceProvider.php
@@ -0,0 +1,145 @@
+registerSwiftMailer();
+
+ $this->registerIlluminateMailer();
+
+ $this->registerMarkdownRenderer();
+ }
+
+ /**
+ * Register the Illuminate mailer instance.
+ *
+ * @return void
+ */
+ protected function registerIlluminateMailer()
+ {
+ $this->app->singleton('mailer', function ($app) {
+ $config = $app->make('config')->get('mail');
+
+ // Once we have create the mailer instance, we will set a container instance
+ // on the mailer. This allows us to resolve mailer classes via containers
+ // for maximum testability on said classes instead of passing Closures.
+ $mailer = new Mailer(
+ $app['view'], $app['swift.mailer'], $app['events']
+ );
+
+ if ($app->bound('queue')) {
+ $mailer->setQueue($app['queue']);
+ }
+
+ // Next we will set all of the global addresses on this mailer, which allows
+ // for easy unification of all "from" addresses as well as easy debugging
+ // of sent messages since they get be sent into a single email address.
+ foreach (['from', 'reply_to', 'to'] as $type) {
+ $this->setGlobalAddress($mailer, $config, $type);
+ }
+
+ return $mailer;
+ });
+ }
+
+ /**
+ * Set a global address on the mailer by type.
+ *
+ * @param \Illuminate\Mail\Mailer $mailer
+ * @param array $config
+ * @param string $type
+ * @return void
+ */
+ protected function setGlobalAddress($mailer, array $config, $type)
+ {
+ $address = Arr::get($config, $type);
+
+ if (is_array($address) && isset($address['address'])) {
+ $mailer->{'always'.Str::studly($type)}($address['address'], $address['name']);
+ }
+ }
+
+ /**
+ * Register the Swift Mailer instance.
+ *
+ * @return void
+ */
+ public function registerSwiftMailer()
+ {
+ $this->registerSwiftTransport();
+
+ // Once we have the transporter registered, we will register the actual Swift
+ // mailer instance, passing in the transport instances, which allows us to
+ // override this transporter instances during app start-up if necessary.
+ $this->app->singleton('swift.mailer', function ($app) {
+ return new Swift_Mailer($app['swift.transport']->driver());
+ });
+ }
+
+ /**
+ * Register the Swift Transport instance.
+ *
+ * @return void
+ */
+ protected function registerSwiftTransport()
+ {
+ $this->app->singleton('swift.transport', function ($app) {
+ return new TransportManager($app);
+ });
+ }
+
+ /**
+ * Register the Markdown renderer instance.
+ *
+ * @return void
+ */
+ protected function registerMarkdownRenderer()
+ {
+ if ($this->app->runningInConsole()) {
+ $this->publishes([
+ __DIR__.'/resources/views' => $this->app->resourcePath('views/vendor/mail'),
+ ], 'laravel-mail');
+ }
+
+ $this->app->singleton(Markdown::class, function ($app) {
+ $config = $app->make('config');
+
+ return new Markdown($app->make('view'), [
+ 'theme' => $config->get('mail.markdown.theme', 'default'),
+ 'paths' => $config->get('mail.markdown.paths', []),
+ ]);
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return [
+ 'mailer', 'swift.mailer', 'swift.transport', Markdown::class,
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Mailable.php b/vendor/laravel/framework/src/Illuminate/Mail/Mailable.php
new file mode 100644
index 000000000..01e276062
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Mailable.php
@@ -0,0 +1,665 @@
+call([$this, 'build']);
+
+ $mailer->send($this->buildView(), $this->buildViewData(), function ($message) {
+ $this->buildFrom($message)
+ ->buildRecipients($message)
+ ->buildSubject($message)
+ ->buildAttachments($message)
+ ->runCallbacks($message);
+ });
+ }
+
+ /**
+ * Queue the message for sending.
+ *
+ * @param \Illuminate\Contracts\Queue\Factory $queue
+ * @return mixed
+ */
+ public function queue(Queue $queue)
+ {
+ if (property_exists($this, 'delay')) {
+ return $this->later($this->delay, $queue);
+ }
+
+ $connection = property_exists($this, 'connection') ? $this->connection : null;
+
+ $queueName = property_exists($this, 'queue') ? $this->queue : null;
+
+ return $queue->connection($connection)->pushOn(
+ $queueName ?: null, new SendQueuedMailable($this)
+ );
+ }
+
+ /**
+ * Deliver the queued message after the given delay.
+ *
+ * @param \DateTime|int $delay
+ * @param Queue $queue
+ * @return mixed
+ */
+ public function later($delay, Queue $queue)
+ {
+ $connection = property_exists($this, 'connection') ? $this->connection : null;
+
+ $queueName = property_exists($this, 'queue') ? $this->queue : null;
+
+ return $queue->connection($connection)->laterOn(
+ $queueName ?: null, $delay, new SendQueuedMailable($this)
+ );
+ }
+
+ /**
+ * Build the view for the message.
+ *
+ * @return array|string
+ */
+ protected function buildView()
+ {
+ if (isset($this->markdown)) {
+ return $this->buildMarkdownView();
+ }
+
+ if (isset($this->view, $this->textView)) {
+ return [$this->view, $this->textView];
+ } elseif (isset($this->textView)) {
+ return ['text' => $this->textView];
+ }
+
+ return $this->view;
+ }
+
+ /**
+ * Build the Markdown view for the message.
+ *
+ * @return array
+ */
+ protected function buildMarkdownView()
+ {
+ $markdown = Container::getInstance()->make(Markdown::class);
+
+ $data = $this->buildViewData();
+
+ return [
+ 'html' => $markdown->render($this->markdown, $data),
+ 'text' => $this->buildMarkdownText($markdown, $data),
+ ];
+ }
+
+ /**
+ * Build the view data for the message.
+ *
+ * @return array
+ */
+ public function buildViewData()
+ {
+ $data = $this->viewData;
+
+ foreach ((new ReflectionClass($this))->getProperties(ReflectionProperty::IS_PUBLIC) as $property) {
+ if ($property->getDeclaringClass()->getName() != self::class) {
+ $data[$property->getName()] = $property->getValue($this);
+ }
+ }
+
+ return $data;
+ }
+
+ /**
+ * Build the text view for a Markdown message.
+ *
+ * @param \Illuminate\Mail\Markdown $markdown
+ * @param array $data
+ * @return string
+ */
+ protected function buildMarkdownText($markdown, $data)
+ {
+ return isset($this->textView)
+ ? $this->textView
+ : $markdown->renderText($this->markdown, $data);
+ }
+
+ /**
+ * Add the sender to the message.
+ *
+ * @param \Illuminate\Mail\Message $message
+ * @return $this
+ */
+ protected function buildFrom($message)
+ {
+ if (! empty($this->from)) {
+ $message->from($this->from[0]['address'], $this->from[0]['name']);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add all of the recipients to the message.
+ *
+ * @param \Illuminate\Mail\Message $message
+ * @return $this
+ */
+ protected function buildRecipients($message)
+ {
+ foreach (['to', 'cc', 'bcc', 'replyTo'] as $type) {
+ foreach ($this->{$type} as $recipient) {
+ $message->{$type}($recipient['address'], $recipient['name']);
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Set the subject for the message.
+ *
+ * @param \Illuminate\Mail\Message $message
+ * @return $this
+ */
+ protected function buildSubject($message)
+ {
+ if ($this->subject) {
+ $message->subject($this->subject);
+ } else {
+ $message->subject(Str::title(Str::snake(class_basename($this), ' ')));
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add all of the attachments to the message.
+ *
+ * @param \Illuminate\Mail\Message $message
+ * @return $this
+ */
+ protected function buildAttachments($message)
+ {
+ foreach ($this->attachments as $attachment) {
+ $message->attach($attachment['file'], $attachment['options']);
+ }
+
+ foreach ($this->rawAttachments as $attachment) {
+ $message->attachData(
+ $attachment['data'], $attachment['name'], $attachment['options']
+ );
+ }
+
+ return $this;
+ }
+
+ /**
+ * Run the callbacks for the message.
+ *
+ * @param \Illuminate\Mail\Message $message
+ * @return $this
+ */
+ protected function runCallbacks($message)
+ {
+ foreach ($this->callbacks as $callback) {
+ $callback($message->getSwiftMessage());
+ }
+
+ return $this;
+ }
+
+ /**
+ * Set the priority of this message.
+ *
+ * The value is an integer where 1 is the highest priority and 5 is the lowest.
+ *
+ * @param int $level
+ * @return $this
+ */
+ public function priority($level = 3)
+ {
+ $this->callbacks[] = function ($message) use ($level) {
+ $message->setPriority($level);
+ };
+
+ return $this;
+ }
+
+ /**
+ * Set the sender of the message.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function from($address, $name = null)
+ {
+ return $this->setAddress($address, $name, 'from');
+ }
+
+ /**
+ * Determine if the given recipient is set on the mailable.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @return bool
+ */
+ public function hasFrom($address, $name = null)
+ {
+ return $this->hasRecipient($address, $name, 'from');
+ }
+
+ /**
+ * Set the recipients of the message.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function to($address, $name = null)
+ {
+ return $this->setAddress($address, $name, 'to');
+ }
+
+ /**
+ * Determine if the given recipient is set on the mailable.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @return bool
+ */
+ public function hasTo($address, $name = null)
+ {
+ return $this->hasRecipient($address, $name, 'to');
+ }
+
+ /**
+ * Set the recipients of the message.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function cc($address, $name = null)
+ {
+ return $this->setAddress($address, $name, 'cc');
+ }
+
+ /**
+ * Determine if the given recipient is set on the mailable.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @return bool
+ */
+ public function hasCc($address, $name = null)
+ {
+ return $this->hasRecipient($address, $name, 'cc');
+ }
+
+ /**
+ * Set the recipients of the message.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function bcc($address, $name = null)
+ {
+ return $this->setAddress($address, $name, 'bcc');
+ }
+
+ /**
+ * Determine if the given recipient is set on the mailable.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @return bool
+ */
+ public function hasBcc($address, $name = null)
+ {
+ return $this->hasRecipient($address, $name, 'bcc');
+ }
+
+ /**
+ * Set the "reply to" address of the message.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function replyTo($address, $name = null)
+ {
+ return $this->setAddress($address, $name, 'replyTo');
+ }
+
+ /**
+ * Set the recipients of the message.
+ *
+ * All recipients are stored internally as [['name' => ?, 'address' => ?]]
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @param string $property
+ * @return $this
+ */
+ protected function setAddress($address, $name = null, $property = 'to')
+ {
+ foreach ($this->addressesToArray($address, $name) as $recipient) {
+ $recipient = $this->normalizeRecipient($recipient);
+
+ $this->{$property}[] = [
+ 'name' => isset($recipient->name) ? $recipient->name : null,
+ 'address' => $recipient->email,
+ ];
+ }
+
+ return $this;
+ }
+
+ /**
+ * Convert the given recipient arguments to an array.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @return array
+ */
+ protected function addressesToArray($address, $name)
+ {
+ if (! is_array($address) && ! $address instanceof Collection) {
+ $address = is_string($name) ? [['name' => $name, 'email' => $address]] : [$address];
+ }
+
+ return $address;
+ }
+
+ /**
+ * Convert the given recipient into an object.
+ *
+ * @param mixed $recipient
+ * @return object
+ */
+ protected function normalizeRecipient($recipient)
+ {
+ if (is_array($recipient)) {
+ return (object) $recipient;
+ } elseif (is_string($recipient)) {
+ return (object) ['email' => $recipient];
+ }
+
+ return $recipient;
+ }
+
+ /**
+ * Determine if the given recipient is set on the mailable.
+ *
+ * @param object|array|string $address
+ * @param string|null $name
+ * @param string $property
+ * @return bool
+ */
+ protected function hasRecipient($address, $name = null, $property = 'to')
+ {
+ $expected = $this->normalizeRecipient(
+ $this->addressesToArray($address, $name)[0]
+ );
+
+ $expected = [
+ 'name' => isset($expected->name) ? $expected->name : null,
+ 'address' => $expected->email,
+ ];
+
+ return collect($this->{$property})->contains(function ($actual) use ($expected) {
+ if (! isset($expected['name'])) {
+ return $actual['address'] == $expected['address'];
+ } else {
+ return $actual == $expected;
+ }
+ });
+ }
+
+ /**
+ * Set the subject of the message.
+ *
+ * @param string $subject
+ * @return $this
+ */
+ public function subject($subject)
+ {
+ $this->subject = $subject;
+
+ return $this;
+ }
+
+ /**
+ * Set the Markdown template for the message.
+ *
+ * @param string $view
+ * @param array $data
+ * @return $this
+ */
+ public function markdown($view, array $data = [])
+ {
+ $this->markdown = $view;
+ $this->viewData = array_merge($this->viewData, $data);
+
+ return $this;
+ }
+
+ /**
+ * Set the view and view data for the message.
+ *
+ * @param string $view
+ * @param array $data
+ * @return $this
+ */
+ public function view($view, array $data = [])
+ {
+ $this->view = $view;
+ $this->viewData = array_merge($this->viewData, $data);
+
+ return $this;
+ }
+
+ /**
+ * Set the plain text view for the message.
+ *
+ * @param string $textView
+ * @param array $data
+ * @return $this
+ */
+ public function text($textView, array $data = [])
+ {
+ $this->textView = $textView;
+ $this->viewData = array_merge($this->viewData, $data);
+
+ return $this;
+ }
+
+ /**
+ * Set the view data for the message.
+ *
+ * @param string|array $key
+ * @param mixed $value
+ * @return $this
+ */
+ public function with($key, $value = null)
+ {
+ if (is_array($key)) {
+ $this->viewData = array_merge($this->viewData, $key);
+ } else {
+ $this->viewData[$key] = $value;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Attach a file to the message.
+ *
+ * @param string $file
+ * @param array $options
+ * @return $this
+ */
+ public function attach($file, array $options = [])
+ {
+ $this->attachments[] = compact('file', 'options');
+
+ return $this;
+ }
+
+ /**
+ * Attach in-memory data as an attachment.
+ *
+ * @param string $data
+ * @param string $name
+ * @param array $options
+ * @return $this
+ */
+ public function attachData($data, $name, array $options = [])
+ {
+ $this->rawAttachments[] = compact('data', 'name', 'options');
+
+ return $this;
+ }
+
+ /**
+ * Register a callback to be called with the Swift message instance.
+ *
+ * @param callable $callback
+ * @return $this
+ */
+ public function withSwiftMessage($callback)
+ {
+ $this->callbacks[] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Dynamically bind parameters to the message.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return $this
+ *
+ * @throws \BadMethodCallException
+ */
+ public function __call($method, $parameters)
+ {
+ if (Str::startsWith($method, 'with')) {
+ return $this->with(Str::snake(substr($method, 4)), $parameters[0]);
+ }
+
+ throw new BadMethodCallException("Method [$method] does not exist on mailable.");
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Mailer.php b/vendor/laravel/framework/src/Illuminate/Mail/Mailer.php
new file mode 100644
index 000000000..f29f875bd
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Mailer.php
@@ -0,0 +1,546 @@
+views = $views;
+ $this->swift = $swift;
+ $this->events = $events;
+ }
+
+ /**
+ * Set the global from address and name.
+ *
+ * @param string $address
+ * @param string|null $name
+ * @return void
+ */
+ public function alwaysFrom($address, $name = null)
+ {
+ $this->from = compact('address', 'name');
+ }
+
+ /**
+ * Set the global reply-to address and name.
+ *
+ * @param string $address
+ * @param string|null $name
+ * @return void
+ */
+ public function alwaysReplyTo($address, $name = null)
+ {
+ $this->replyTo = compact('address', 'name');
+ }
+
+ /**
+ * Set the global to address and name.
+ *
+ * @param string $address
+ * @param string|null $name
+ * @return void
+ */
+ public function alwaysTo($address, $name = null)
+ {
+ $this->to = compact('address', 'name');
+ }
+
+ /**
+ * Begin the process of mailing a mailable class instance.
+ *
+ * @param mixed $users
+ * @return \Illuminate\Mail\PendingMail
+ */
+ public function to($users)
+ {
+ return (new PendingMail($this))->to($users);
+ }
+
+ /**
+ * Begin the process of mailing a mailable class instance.
+ *
+ * @param mixed $users
+ * @return \Illuminate\Mail\PendingMail
+ */
+ public function bcc($users)
+ {
+ return (new PendingMail($this))->bcc($users);
+ }
+
+ /**
+ * Send a new message when only a raw text part.
+ *
+ * @param string $text
+ * @param mixed $callback
+ * @return void
+ */
+ public function raw($text, $callback)
+ {
+ return $this->send(['raw' => $text], [], $callback);
+ }
+
+ /**
+ * Send a new message when only a plain part.
+ *
+ * @param string $view
+ * @param array $data
+ * @param mixed $callback
+ * @return void
+ */
+ public function plain($view, array $data, $callback)
+ {
+ return $this->send(['text' => $view], $data, $callback);
+ }
+
+ /**
+ * Send a new message using a view.
+ *
+ * @param string|array $view
+ * @param array $data
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public function send($view, array $data = [], $callback = null)
+ {
+ if ($view instanceof MailableContract) {
+ return $this->sendMailable($view);
+ }
+
+ // First we need to parse the view, which could either be a string or an array
+ // containing both an HTML and plain text versions of the view which should
+ // be used when sending an e-mail. We will extract both of them out here.
+ list($view, $plain, $raw) = $this->parseView($view);
+
+ $data['message'] = $message = $this->createMessage();
+
+ // Once we have retrieved the view content for the e-mail we will set the body
+ // of this message using the HTML type, which will provide a simple wrapper
+ // to creating view based emails that are able to receive arrays of data.
+ $this->addContent($message, $view, $plain, $raw, $data);
+
+ call_user_func($callback, $message);
+
+ // If a global "to" address has been set, we will set that address on the mail
+ // message. This is primarily useful during local development in which each
+ // message should be delivered into a single mail address for inspection.
+ if (isset($this->to['address'])) {
+ $this->setGlobalTo($message);
+ }
+
+ // Next we will determine if the message should be send. We give the developer
+ // one final chance to stop this message and then we will send it to all of
+ // its recipients. We will then fire the sent event for the sent message.
+ $swiftMessage = $message->getSwiftMessage();
+
+ if ($this->shouldSendMessage($swiftMessage)) {
+ $this->sendSwiftMessage($swiftMessage);
+
+ $this->dispatchSentEvent($message);
+ }
+ }
+
+ /**
+ * Send the given mailable.
+ *
+ * @param MailableContract $mailable
+ * @return mixed
+ */
+ protected function sendMailable(MailableContract $mailable)
+ {
+ return $mailable instanceof ShouldQueue
+ ? $mailable->queue($this->queue) : $mailable->send($this);
+ }
+
+ /**
+ * Parse the given view name or array.
+ *
+ * @param string|array $view
+ * @return array
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function parseView($view)
+ {
+ if (is_string($view)) {
+ return [$view, null, null];
+ }
+
+ // If the given view is an array with numeric keys, we will just assume that
+ // both a "pretty" and "plain" view were provided, so we will return this
+ // array as is, since must should contain both views with numeric keys.
+ if (is_array($view) && isset($view[0])) {
+ return [$view[0], $view[1], null];
+ }
+
+ // If this view is an array but doesn't contain numeric keys, we will assume
+ // the views are being explicitly specified and will extract them via the
+ // named keys instead, allowing the developers to use one or the other.
+ if (is_array($view)) {
+ return [
+ Arr::get($view, 'html'),
+ Arr::get($view, 'text'),
+ Arr::get($view, 'raw'),
+ ];
+ }
+
+ throw new InvalidArgumentException('Invalid view.');
+ }
+
+ /**
+ * Add the content to a given message.
+ *
+ * @param \Illuminate\Mail\Message $message
+ * @param string $view
+ * @param string $plain
+ * @param string $raw
+ * @param array $data
+ * @return void
+ */
+ protected function addContent($message, $view, $plain, $raw, $data)
+ {
+ if (isset($view)) {
+ $message->setBody($this->renderView($view, $data), 'text/html');
+ }
+
+ if (isset($plain)) {
+ $method = isset($view) ? 'addPart' : 'setBody';
+
+ $message->$method($this->renderView($plain, $data), 'text/plain');
+ }
+
+ if (isset($raw)) {
+ $method = (isset($view) || isset($plain)) ? 'addPart' : 'setBody';
+
+ $message->$method($raw, 'text/plain');
+ }
+ }
+
+ /**
+ * Render the given view.
+ *
+ * @param string $view
+ * @param array $data
+ * @return string
+ */
+ protected function renderView($view, $data)
+ {
+ return $view instanceof Htmlable
+ ? $view->toHtml()
+ : $this->views->make($view, $data)->render();
+ }
+
+ /**
+ * Set the global "to" address on the given message.
+ *
+ * @param \Illuminate\Mail\Message $message
+ * @return void
+ */
+ protected function setGlobalTo($message)
+ {
+ $message->to($this->to['address'], $this->to['name'], true);
+ $message->cc($this->to['address'], $this->to['name'], true);
+ $message->bcc($this->to['address'], $this->to['name'], true);
+ }
+
+ /**
+ * Queue a new e-mail message for sending.
+ *
+ * @param string|array $view
+ * @param array $data
+ * @param \Closure|string $callback
+ * @param string|null $queue
+ * @return mixed
+ */
+ public function queue($view, array $data = [], $callback = null, $queue = null)
+ {
+ if (! $view instanceof MailableContract) {
+ throw new InvalidArgumentException('Only mailables may be queued.');
+ }
+
+ return $view->queue($this->queue);
+ }
+
+ /**
+ * Queue a new e-mail message for sending on the given queue.
+ *
+ * @param string $queue
+ * @param string|array $view
+ * @param array $data
+ * @param \Closure|string $callback
+ * @return mixed
+ */
+ public function onQueue($queue, $view, array $data, $callback)
+ {
+ return $this->queue($view, $data, $callback, $queue);
+ }
+
+ /**
+ * Queue a new e-mail message for sending on the given queue.
+ *
+ * This method didn't match rest of framework's "onQueue" phrasing. Added "onQueue".
+ *
+ * @param string $queue
+ * @param string|array $view
+ * @param array $data
+ * @param \Closure|string $callback
+ * @return mixed
+ */
+ public function queueOn($queue, $view, array $data, $callback)
+ {
+ return $this->onQueue($queue, $view, $data, $callback);
+ }
+
+ /**
+ * Queue a new e-mail message for sending after (n) seconds.
+ *
+ * @param int $delay
+ * @param string|array $view
+ * @param array $data
+ * @param \Closure|string $callback
+ * @param string|null $queue
+ * @return mixed
+ */
+ public function later($delay, $view, array $data = [], $callback = null, $queue = null)
+ {
+ if (! $view instanceof MailableContract) {
+ throw new InvalidArgumentException('Only mailables may be queued.');
+ }
+
+ return $view->later($delay, $this->queue);
+ }
+
+ /**
+ * Queue a new e-mail message for sending after (n) seconds on the given queue.
+ *
+ * @param string $queue
+ * @param int $delay
+ * @param string|array $view
+ * @param array $data
+ * @param \Closure|string $callback
+ * @return mixed
+ */
+ public function laterOn($queue, $delay, $view, array $data, $callback)
+ {
+ return $this->later($delay, $view, $data, $callback, $queue);
+ }
+
+ /**
+ * Create a new message instance.
+ *
+ * @return \Illuminate\Mail\Message
+ */
+ protected function createMessage()
+ {
+ $message = new Message($this->swift->createMessage('message'));
+
+ // If a global from address has been specified we will set it on every message
+ // instances so the developer does not have to repeat themselves every time
+ // they create a new message. We will just go ahead and push the address.
+ if (! empty($this->from['address'])) {
+ $message->from($this->from['address'], $this->from['name']);
+ }
+
+ // When a global reply address was specified we will set this on every message
+ // instances so the developer does not have to repeat themselves every time
+ // they create a new message. We will just go ahead and push the address.
+ if (! empty($this->replyTo['address'])) {
+ $message->replyTo($this->replyTo['address'], $this->replyTo['name']);
+ }
+
+ return $message;
+ }
+
+ /**
+ * Send a Swift Message instance.
+ *
+ * @param \Swift_Message $message
+ * @return void
+ */
+ protected function sendSwiftMessage($message)
+ {
+ try {
+ return $this->swift->send($message, $this->failedRecipients);
+ } finally {
+ $this->forceReconnection();
+ }
+ }
+
+ /**
+ * Determines if the message can be sent.
+ *
+ * @param \Swift_Message $message
+ * @return bool
+ */
+ protected function shouldSendMessage($message)
+ {
+ if (! $this->events) {
+ return true;
+ }
+
+ return $this->events->until(
+ new Events\MessageSending($message)
+ ) !== false;
+ }
+
+ /**
+ * Dispatch the message sent event.
+ *
+ * @param \Illuminate\Mail\Message $message
+ * @return void
+ */
+ protected function dispatchSentEvent($message)
+ {
+ if ($this->events) {
+ $this->events->dispatch(
+ new Events\MessageSent($message->getSwiftMessage())
+ );
+ }
+ }
+
+ /**
+ * Force the transport to re-connect.
+ *
+ * This will prevent errors in daemon queue situations.
+ *
+ * @return void
+ */
+ protected function forceReconnection()
+ {
+ $this->getSwiftMailer()->getTransport()->stop();
+ }
+
+ /**
+ * Get the view factory instance.
+ *
+ * @return \Illuminate\Contracts\View\Factory
+ */
+ public function getViewFactory()
+ {
+ return $this->views;
+ }
+
+ /**
+ * Get the Swift Mailer instance.
+ *
+ * @return \Swift_Mailer
+ */
+ public function getSwiftMailer()
+ {
+ return $this->swift;
+ }
+
+ /**
+ * Get the array of failed recipients.
+ *
+ * @return array
+ */
+ public function failures()
+ {
+ return $this->failedRecipients;
+ }
+
+ /**
+ * Set the Swift Mailer instance.
+ *
+ * @param \Swift_Mailer $swift
+ * @return void
+ */
+ public function setSwiftMailer($swift)
+ {
+ $this->swift = $swift;
+ }
+
+ /**
+ * Set the queue manager instance.
+ *
+ * @param \Illuminate\Contracts\Queue\Factory $queue
+ * @return $this
+ */
+ public function setQueue(QueueContract $queue)
+ {
+ $this->queue = $queue;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Markdown.php b/vendor/laravel/framework/src/Illuminate/Mail/Markdown.php
new file mode 100644
index 000000000..b1b8e0e3b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Markdown.php
@@ -0,0 +1,148 @@
+view = $view;
+ $this->theme = Arr::get($options, 'theme', 'default');
+ $this->loadComponentsFrom(Arr::get($options, 'paths', []));
+ }
+
+ /**
+ * Render the Markdown template into HTML.
+ *
+ * @param string $view
+ * @param array $data
+ * @param \TijsVerkoyen\CssToInlineStyles\CssToInlineStyles|null $inliner
+ * @return \Illuminate\Support\HtmlString
+ */
+ public function render($view, array $data = [], $inliner = null)
+ {
+ $this->view->flushFinderCache();
+
+ $contents = $this->view->replaceNamespace(
+ 'mail', $this->htmlComponentPaths()
+ )->make($view, $data)->render();
+
+ return new HtmlString(with($inliner ?: new CssToInlineStyles)->convert(
+ $contents, $this->view->make('mail::themes.'.$this->theme)->render()
+ ));
+ }
+
+ /**
+ * Render the Markdown template into HTML.
+ *
+ * @param string $view
+ * @param array $data
+ * @return \Illuminate\Support\HtmlString
+ */
+ public function renderText($view, array $data = [])
+ {
+ $this->view->flushFinderCache();
+
+ $contents = $this->view->replaceNamespace(
+ 'mail', $this->markdownComponentPaths()
+ )->make($view, $data)->render();
+
+ return new HtmlString(
+ html_entity_decode(preg_replace("/[\r\n]{2,}/", "\n\n", $contents), ENT_QUOTES, 'UTF-8')
+ );
+ }
+
+ /**
+ * Parse the given Markdown text into HTML.
+ *
+ * @param string $text
+ * @return string
+ */
+ public static function parse($text)
+ {
+ $parsedown = new Parsedown;
+
+ return new HtmlString($parsedown->text($text));
+ }
+
+ /**
+ * Get the HTML component paths.
+ *
+ * @return array
+ */
+ public function htmlComponentPaths()
+ {
+ return array_map(function ($path) {
+ return $path.'/html';
+ }, $this->componentPaths());
+ }
+
+ /**
+ * Get the Markdown component paths.
+ *
+ * @return array
+ */
+ public function markdownComponentPaths()
+ {
+ return array_map(function ($path) {
+ return $path.'/markdown';
+ }, $this->componentPaths());
+ }
+
+ /**
+ * Get the component paths.
+ *
+ * @return array
+ */
+ protected function componentPaths()
+ {
+ return array_unique(array_merge($this->componentPaths, [
+ __DIR__.'/resources/views',
+ ]));
+ }
+
+ /**
+ * Register new mail component paths.
+ *
+ * @param array $paths
+ * @return void
+ */
+ public function loadComponentsFrom(array $paths = [])
+ {
+ $this->componentPaths = $paths;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Message.php b/vendor/laravel/framework/src/Illuminate/Mail/Message.php
new file mode 100644
index 000000000..a91c18178
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Message.php
@@ -0,0 +1,328 @@
+swift = $swift;
+ }
+
+ /**
+ * Add a "from" address to the message.
+ *
+ * @param string|array $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function from($address, $name = null)
+ {
+ $this->swift->setFrom($address, $name);
+
+ return $this;
+ }
+
+ /**
+ * Set the "sender" of the message.
+ *
+ * @param string|array $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function sender($address, $name = null)
+ {
+ $this->swift->setSender($address, $name);
+
+ return $this;
+ }
+
+ /**
+ * Set the "return path" of the message.
+ *
+ * @param string $address
+ * @return $this
+ */
+ public function returnPath($address)
+ {
+ $this->swift->setReturnPath($address);
+
+ return $this;
+ }
+
+ /**
+ * Add a recipient to the message.
+ *
+ * @param string|array $address
+ * @param string|null $name
+ * @param bool $override
+ * @return $this
+ */
+ public function to($address, $name = null, $override = false)
+ {
+ if ($override) {
+ $this->swift->setTo($address, $name);
+
+ return $this;
+ }
+
+ return $this->addAddresses($address, $name, 'To');
+ }
+
+ /**
+ * Add a carbon copy to the message.
+ *
+ * @param string|array $address
+ * @param string|null $name
+ * @param bool $override
+ * @return $this
+ */
+ public function cc($address, $name = null, $override = false)
+ {
+ if ($override) {
+ $this->swift->setCc($address, $name);
+
+ return $this;
+ }
+
+ return $this->addAddresses($address, $name, 'Cc');
+ }
+
+ /**
+ * Add a blind carbon copy to the message.
+ *
+ * @param string|array $address
+ * @param string|null $name
+ * @param bool $override
+ * @return $this
+ */
+ public function bcc($address, $name = null, $override = false)
+ {
+ if ($override) {
+ $this->swift->setBcc($address, $name);
+
+ return $this;
+ }
+
+ return $this->addAddresses($address, $name, 'Bcc');
+ }
+
+ /**
+ * Add a reply to address to the message.
+ *
+ * @param string|array $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function replyTo($address, $name = null)
+ {
+ return $this->addAddresses($address, $name, 'ReplyTo');
+ }
+
+ /**
+ * Add a recipient to the message.
+ *
+ * @param string|array $address
+ * @param string $name
+ * @param string $type
+ * @return $this
+ */
+ protected function addAddresses($address, $name, $type)
+ {
+ if (is_array($address)) {
+ $this->swift->{"set{$type}"}($address, $name);
+ } else {
+ $this->swift->{"add{$type}"}($address, $name);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Set the subject of the message.
+ *
+ * @param string $subject
+ * @return $this
+ */
+ public function subject($subject)
+ {
+ $this->swift->setSubject($subject);
+
+ return $this;
+ }
+
+ /**
+ * Set the message priority level.
+ *
+ * @param int $level
+ * @return $this
+ */
+ public function priority($level)
+ {
+ $this->swift->setPriority($level);
+
+ return $this;
+ }
+
+ /**
+ * Attach a file to the message.
+ *
+ * @param string $file
+ * @param array $options
+ * @return $this
+ */
+ public function attach($file, array $options = [])
+ {
+ $attachment = $this->createAttachmentFromPath($file);
+
+ return $this->prepAttachment($attachment, $options);
+ }
+
+ /**
+ * Create a Swift Attachment instance.
+ *
+ * @param string $file
+ * @return \Swift_Attachment
+ */
+ protected function createAttachmentFromPath($file)
+ {
+ return Swift_Attachment::fromPath($file);
+ }
+
+ /**
+ * Attach in-memory data as an attachment.
+ *
+ * @param string $data
+ * @param string $name
+ * @param array $options
+ * @return $this
+ */
+ public function attachData($data, $name, array $options = [])
+ {
+ $attachment = $this->createAttachmentFromData($data, $name);
+
+ return $this->prepAttachment($attachment, $options);
+ }
+
+ /**
+ * Create a Swift Attachment instance from data.
+ *
+ * @param string $data
+ * @param string $name
+ * @return \Swift_Attachment
+ */
+ protected function createAttachmentFromData($data, $name)
+ {
+ return Swift_Attachment::newInstance($data, $name);
+ }
+
+ /**
+ * Embed a file in the message and get the CID.
+ *
+ * @param string $file
+ * @return string
+ */
+ public function embed($file)
+ {
+ if (isset($this->embeddedFiles[$file])) {
+ return $this->embeddedFiles[$file];
+ }
+
+ return $this->embeddedFiles[$file] = $this->swift->embed(
+ Swift_Image::fromPath($file)
+ );
+ }
+
+ /**
+ * Embed in-memory data in the message and get the CID.
+ *
+ * @param string $data
+ * @param string $name
+ * @param string|null $contentType
+ * @return string
+ */
+ public function embedData($data, $name, $contentType = null)
+ {
+ $image = Swift_Image::newInstance($data, $name, $contentType);
+
+ return $this->swift->embed($image);
+ }
+
+ /**
+ * Prepare and attach the given attachment.
+ *
+ * @param \Swift_Attachment $attachment
+ * @param array $options
+ * @return $this
+ */
+ protected function prepAttachment($attachment, $options = [])
+ {
+ // First we will check for a MIME type on the message, which instructs the
+ // mail client on what type of attachment the file is so that it may be
+ // downloaded correctly by the user. The MIME option is not required.
+ if (isset($options['mime'])) {
+ $attachment->setContentType($options['mime']);
+ }
+
+ // If an alternative name was given as an option, we will set that on this
+ // attachment so that it will be downloaded with the desired names from
+ // the developer, otherwise the default file names will get assigned.
+ if (isset($options['as'])) {
+ $attachment->setFilename($options['as']);
+ }
+
+ $this->swift->attach($attachment);
+
+ return $this;
+ }
+
+ /**
+ * Get the underlying Swift Message instance.
+ *
+ * @return \Swift_Message
+ */
+ public function getSwiftMessage()
+ {
+ return $this->swift;
+ }
+
+ /**
+ * Dynamically pass missing methods to the Swift instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ $callable = [$this->swift, $method];
+
+ return call_user_func_array($callable, $parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/PendingMail.php b/vendor/laravel/framework/src/Illuminate/Mail/PendingMail.php
new file mode 100644
index 000000000..716c8253d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/PendingMail.php
@@ -0,0 +1,154 @@
+mailer = $mailer;
+ }
+
+ /**
+ * Set the recipients of the message.
+ *
+ * @param mixed $users
+ * @return $this
+ */
+ public function to($users)
+ {
+ $this->to = $users;
+
+ return $this;
+ }
+
+ /**
+ * Set the recipients of the message.
+ *
+ * @param mixed $users
+ * @return $this
+ */
+ public function cc($users)
+ {
+ $this->cc = $users;
+
+ return $this;
+ }
+
+ /**
+ * Set the recipients of the message.
+ *
+ * @param mixed $users
+ * @return $this
+ */
+ public function bcc($users)
+ {
+ $this->bcc = $users;
+
+ return $this;
+ }
+
+ /**
+ * Send a new mailable message instance.
+ *
+ * @param Mailable $mailable
+ * @return mixed
+ */
+ public function send(Mailable $mailable)
+ {
+ if ($mailable instanceof ShouldQueue) {
+ return $this->queue($mailable);
+ }
+
+ return $this->mailer->send($this->fill($mailable));
+ }
+
+ /**
+ * Send a mailable message immediately.
+ *
+ * @param Mailable $mailable
+ * @return mixed
+ */
+ public function sendNow(Mailable $mailable)
+ {
+ return $this->mailer->send($this->fill($mailable));
+ }
+
+ /**
+ * Push the given mailable onto the queue.
+ *
+ * @param Mailable $mailable
+ * @return mixed
+ */
+ public function queue(Mailable $mailable)
+ {
+ $mailable = $this->fill($mailable);
+
+ if (isset($mailable->delay)) {
+ return $this->mailer->later($mailable->delay, $mailable);
+ }
+
+ return $this->mailer->queue($mailable);
+ }
+
+ /**
+ * Deliver the queued message after the given delay.
+ *
+ * @param \DateTime|int $delay
+ * @param Mailable $mailable
+ * @return mixed
+ */
+ public function later($delay, Mailable $mailable)
+ {
+ return $this->mailer->later($delay, $this->fill($mailable));
+ }
+
+ /**
+ * Populate the mailable with the addresses.
+ *
+ * @param Mailable $mailable
+ * @return Mailable
+ */
+ protected function fill(Mailable $mailable)
+ {
+ return $mailable->to($this->to)
+ ->cc($this->cc)
+ ->bcc($this->bcc);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/SendQueuedMailable.php b/vendor/laravel/framework/src/Illuminate/Mail/SendQueuedMailable.php
new file mode 100644
index 000000000..bab05760c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/SendQueuedMailable.php
@@ -0,0 +1,64 @@
+mailable = $mailable;
+ $this->tries = property_exists($mailable, 'tries') ? $mailable->tries : null;
+ $this->timeout = property_exists($mailable, 'timeout') ? $mailable->timeout : null;
+ }
+
+ /**
+ * Handle the queued job.
+ *
+ * @param \Illuminate\Contracts\Mail\Mailer $mailer
+ * @return void
+ */
+ public function handle(MailerContract $mailer)
+ {
+ $this->mailable->send($mailer);
+ }
+
+ /**
+ * Get the display name for the queued job.
+ *
+ * @return string
+ */
+ public function displayName()
+ {
+ return get_class($this->mailable);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Transport/ArrayTransport.php b/vendor/laravel/framework/src/Illuminate/Mail/Transport/ArrayTransport.php
new file mode 100644
index 000000000..6213b5b2e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Transport/ArrayTransport.php
@@ -0,0 +1,58 @@
+messages = new Collection;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function send(Swift_Mime_Message $message, &$failedRecipients = null)
+ {
+ $this->beforeSendPerformed($message);
+
+ $this->messages[] = $message;
+
+ return $this->numberOfRecipients($message);
+ }
+
+ /**
+ * Retrieve the collection of messages.
+ *
+ * @return \Illuminate\Support\Collection
+ */
+ public function messages()
+ {
+ return $this->messages;
+ }
+
+ /**
+ * Clear all of the messages from the local collection.
+ *
+ * @return \Illuminate\Support\Collection
+ */
+ public function flush()
+ {
+ return $this->messages = new Collection;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Transport/LogTransport.php b/vendor/laravel/framework/src/Illuminate/Mail/Transport/LogTransport.php
new file mode 100644
index 000000000..26c2c220f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Transport/LogTransport.php
@@ -0,0 +1,59 @@
+logger = $logger;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function send(Swift_Mime_Message $message, &$failedRecipients = null)
+ {
+ $this->beforeSendPerformed($message);
+
+ $this->logger->debug($this->getMimeEntityString($message));
+
+ $this->sendPerformed($message);
+
+ return $this->numberOfRecipients($message);
+ }
+
+ /**
+ * Get a loggable string out of a Swiftmailer entity.
+ *
+ * @param \Swift_Mime_MimeEntity $entity
+ * @return string
+ */
+ protected function getMimeEntityString(Swift_Mime_MimeEntity $entity)
+ {
+ $string = (string) $entity->getHeaders().PHP_EOL.$entity->getBody();
+
+ foreach ($entity->getChildren() as $children) {
+ $string .= PHP_EOL.PHP_EOL.$this->getMimeEntityString($children);
+ }
+
+ return $string;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Transport/MailgunTransport.php b/vendor/laravel/framework/src/Illuminate/Mail/Transport/MailgunTransport.php
new file mode 100644
index 000000000..3b486808c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Transport/MailgunTransport.php
@@ -0,0 +1,168 @@
+key = $key;
+ $this->client = $client;
+ $this->setDomain($domain);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function send(Swift_Mime_Message $message, &$failedRecipients = null)
+ {
+ $this->beforeSendPerformed($message);
+
+ $to = $this->getTo($message);
+
+ $message->setBcc([]);
+
+ $this->client->post($this->url, $this->payload($message, $to));
+
+ $this->sendPerformed($message);
+
+ return $this->numberOfRecipients($message);
+ }
+
+ /**
+ * Get the HTTP payload for sending the Mailgun message.
+ *
+ * @param \Swift_Mime_Message $message
+ * @param string $to
+ * @return array
+ */
+ protected function payload(Swift_Mime_Message $message, $to)
+ {
+ return [
+ 'auth' => [
+ 'api',
+ $this->key,
+ ],
+ 'multipart' => [
+ [
+ 'name' => 'to',
+ 'contents' => $to,
+ ],
+ [
+ 'name' => 'message',
+ 'contents' => $message->toString(),
+ 'filename' => 'message.mime',
+ ],
+ ],
+ ];
+ }
+
+ /**
+ * Get the "to" payload field for the API request.
+ *
+ * @param \Swift_Mime_Message $message
+ * @return string
+ */
+ protected function getTo(Swift_Mime_Message $message)
+ {
+ return collect($this->allContacts($message))->map(function ($display, $address) {
+ return $display ? $display." <{$address}>" : $address;
+ })->values()->implode(',');
+ }
+
+ /**
+ * Get all of the contacts for the message.
+ *
+ * @param \Swift_Mime_Message $message
+ * @return array
+ */
+ protected function allContacts(Swift_Mime_Message $message)
+ {
+ return array_merge(
+ (array) $message->getTo(), (array) $message->getCc(), (array) $message->getBcc()
+ );
+ }
+
+ /**
+ * Get the API key being used by the transport.
+ *
+ * @return string
+ */
+ public function getKey()
+ {
+ return $this->key;
+ }
+
+ /**
+ * Set the API key being used by the transport.
+ *
+ * @param string $key
+ * @return string
+ */
+ public function setKey($key)
+ {
+ return $this->key = $key;
+ }
+
+ /**
+ * Get the domain being used by the transport.
+ *
+ * @return string
+ */
+ public function getDomain()
+ {
+ return $this->domain;
+ }
+
+ /**
+ * Set the domain being used by the transport.
+ *
+ * @param string $domain
+ * @return void
+ */
+ public function setDomain($domain)
+ {
+ $this->url = 'https://api.mailgun.net/v3/'.$domain.'/messages.mime';
+
+ return $this->domain = $domain;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Transport/MandrillTransport.php b/vendor/laravel/framework/src/Illuminate/Mail/Transport/MandrillTransport.php
new file mode 100644
index 000000000..c8fdfa36e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Transport/MandrillTransport.php
@@ -0,0 +1,105 @@
+key = $key;
+ $this->client = $client;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function send(Swift_Mime_Message $message, &$failedRecipients = null)
+ {
+ $this->beforeSendPerformed($message);
+
+ $this->client->post('https://mandrillapp.com/api/1.0/messages/send-raw.json', [
+ 'form_params' => [
+ 'key' => $this->key,
+ 'to' => $this->getTo($message),
+ 'raw_message' => $message->toString(),
+ 'async' => true,
+ ],
+ ]);
+
+ $this->sendPerformed($message);
+
+ return $this->numberOfRecipients($message);
+ }
+
+ /**
+ * Get all the addresses this message should be sent to.
+ *
+ * Note that Mandrill still respects CC, BCC headers in raw message itself.
+ *
+ * @param \Swift_Mime_Message $message
+ * @return array
+ */
+ protected function getTo(Swift_Mime_Message $message)
+ {
+ $to = [];
+
+ if ($message->getTo()) {
+ $to = array_merge($to, array_keys($message->getTo()));
+ }
+
+ if ($message->getCc()) {
+ $to = array_merge($to, array_keys($message->getCc()));
+ }
+
+ if ($message->getBcc()) {
+ $to = array_merge($to, array_keys($message->getBcc()));
+ }
+
+ return $to;
+ }
+
+ /**
+ * Get the API key being used by the transport.
+ *
+ * @return string
+ */
+ public function getKey()
+ {
+ return $this->key;
+ }
+
+ /**
+ * Set the API key being used by the transport.
+ *
+ * @param string $key
+ * @return string
+ */
+ public function setKey($key)
+ {
+ return $this->key = $key;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Transport/SesTransport.php b/vendor/laravel/framework/src/Illuminate/Mail/Transport/SesTransport.php
new file mode 100644
index 000000000..a790423a4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Transport/SesTransport.php
@@ -0,0 +1,48 @@
+ses = $ses;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function send(Swift_Mime_Message $message, &$failedRecipients = null)
+ {
+ $this->beforeSendPerformed($message);
+
+ $headers = $message->getHeaders();
+
+ $headers->addTextHeader('X-SES-Message-ID', $this->ses->sendRawEmail([
+ 'Source' => key($message->getSender() ?: $message->getFrom()),
+ 'RawMessage' => [
+ 'Data' => $message->toString(),
+ ],
+ ])->get('MessageId'));
+
+ $this->sendPerformed($message);
+
+ return $this->numberOfRecipients($message);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Transport/SparkPostTransport.php b/vendor/laravel/framework/src/Illuminate/Mail/Transport/SparkPostTransport.php
new file mode 100644
index 000000000..0a59bf48c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Transport/SparkPostTransport.php
@@ -0,0 +1,159 @@
+key = $key;
+ $this->client = $client;
+ $this->options = $options;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function send(Swift_Mime_Message $message, &$failedRecipients = null)
+ {
+ $this->beforeSendPerformed($message);
+
+ $recipients = $this->getRecipients($message);
+
+ $message->setBcc([]);
+
+ $response = $this->client->post('https://api.sparkpost.com/api/v1/transmissions', [
+ 'headers' => [
+ 'Authorization' => $this->key,
+ ],
+ 'json' => array_merge([
+ 'recipients' => $recipients,
+ 'content' => [
+ 'email_rfc822' => $message->toString(),
+ ],
+ ], $this->options),
+ ]);
+
+ $message->getHeaders()->addTextHeader(
+ 'X-SparkPost-Transmission-ID', $this->getTransmissionId($response)
+ );
+
+ $this->sendPerformed($message);
+
+ return $this->numberOfRecipients($message);
+ }
+
+ /**
+ * Get all the addresses this message should be sent to.
+ *
+ * Note that SparkPost still respects CC, BCC headers in raw message itself.
+ *
+ * @param \Swift_Mime_Message $message
+ * @return array
+ */
+ protected function getRecipients(Swift_Mime_Message $message)
+ {
+ $recipients = [];
+
+ foreach ((array) $message->getTo() as $email => $name) {
+ $recipients[] = ['address' => compact('name', 'email')];
+ }
+
+ foreach ((array) $message->getCc() as $email => $name) {
+ $recipients[] = ['address' => compact('name', 'email')];
+ }
+
+ foreach ((array) $message->getBcc() as $email => $name) {
+ $recipients[] = ['address' => compact('name', 'email')];
+ }
+
+ return $recipients;
+ }
+
+ /**
+ * Get the transmission ID from the response.
+ *
+ * @param \GuzzleHttp\Psr7\Response $response
+ * @return string
+ */
+ protected function getTransmissionId($response)
+ {
+ return object_get(
+ json_decode($response->getBody()->getContents()), 'results.id'
+ );
+ }
+
+ /**
+ * Get the API key being used by the transport.
+ *
+ * @return string
+ */
+ public function getKey()
+ {
+ return $this->key;
+ }
+
+ /**
+ * Set the API key being used by the transport.
+ *
+ * @param string $key
+ * @return string
+ */
+ public function setKey($key)
+ {
+ return $this->key = $key;
+ }
+
+ /**
+ * Get the transmission options being used by the transport.
+ *
+ * @return string
+ */
+ public function getOptions()
+ {
+ return $this->options;
+ }
+
+ /**
+ * Set the transmission options being used by the transport.
+ *
+ * @param array $options
+ * @return array
+ */
+ public function setOptions(array $options)
+ {
+ return $this->options = $options;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/Transport/Transport.php b/vendor/laravel/framework/src/Illuminate/Mail/Transport/Transport.php
new file mode 100644
index 000000000..76e5d527d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/Transport/Transport.php
@@ -0,0 +1,100 @@
+plugins, $plugin);
+ }
+
+ /**
+ * Iterate through registered plugins and execute plugins' methods.
+ *
+ * @param \Swift_Mime_Message $message
+ * @return void
+ */
+ protected function beforeSendPerformed(Swift_Mime_Message $message)
+ {
+ $event = new Swift_Events_SendEvent($this, $message);
+
+ foreach ($this->plugins as $plugin) {
+ if (method_exists($plugin, 'beforeSendPerformed')) {
+ $plugin->beforeSendPerformed($event);
+ }
+ }
+ }
+
+ /**
+ * Iterate through registered plugins and execute plugins' methods.
+ *
+ * @param \Swift_Mime_Message $message
+ * @return void
+ */
+ protected function sendPerformed(Swift_Mime_Message $message)
+ {
+ $event = new Swift_Events_SendEvent($this, $message);
+
+ foreach ($this->plugins as $plugin) {
+ if (method_exists($plugin, 'sendPerformed')) {
+ $plugin->sendPerformed($event);
+ }
+ }
+ }
+
+ /**
+ * Get the number of recipients.
+ *
+ * @param \Swift_Mime_Message $message
+ * @return int
+ */
+ protected function numberOfRecipients(Swift_Mime_Message $message)
+ {
+ return count(array_merge(
+ (array) $message->getTo(), (array) $message->getCc(), (array) $message->getBcc()
+ ));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/TransportManager.php b/vendor/laravel/framework/src/Illuminate/Mail/TransportManager.php
new file mode 100644
index 000000000..b61c945a7
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/TransportManager.php
@@ -0,0 +1,210 @@
+app->make('config')->get('mail');
+
+ // The Swift SMTP transport instance will allow us to use any SMTP backend
+ // for delivering mail such as Sendgrid, Amazon SES, or a custom server
+ // a developer has available. We will just pass this configured host.
+ $transport = SmtpTransport::newInstance(
+ $config['host'], $config['port']
+ );
+
+ if (isset($config['encryption'])) {
+ $transport->setEncryption($config['encryption']);
+ }
+
+ // Once we have the transport we will check for the presence of a username
+ // and password. If we have it we will set the credentials on the Swift
+ // transporter instance so that we'll properly authenticate delivery.
+ if (isset($config['username'])) {
+ $transport->setUsername($config['username']);
+
+ $transport->setPassword($config['password']);
+ }
+
+ // Next we will set any stream context options specified for the transport
+ // and then return it. The option is not required any may not be inside
+ // the configuration array at all so we'll verify that before adding.
+ if (isset($config['stream'])) {
+ $transport->setStreamOptions($config['stream']);
+ }
+
+ return $transport;
+ }
+
+ /**
+ * Create an instance of the Sendmail Swift Transport driver.
+ *
+ * @return \Swift_SendmailTransport
+ */
+ protected function createSendmailDriver()
+ {
+ return SendmailTransport::newInstance(
+ $this->app['config']['mail']['sendmail']
+ );
+ }
+
+ /**
+ * Create an instance of the Amazon SES Swift Transport driver.
+ *
+ * @return \Swift_SendmailTransport
+ */
+ protected function createSesDriver()
+ {
+ $config = array_merge($this->app['config']->get('services.ses', []), [
+ 'version' => 'latest', 'service' => 'email',
+ ]);
+
+ return new SesTransport(new SesClient(
+ $this->addSesCredentials($config)
+ ));
+ }
+
+ /**
+ * Add the SES credentials to the configuration array.
+ *
+ * @param array $config
+ * @return array
+ */
+ protected function addSesCredentials(array $config)
+ {
+ if ($config['key'] && $config['secret']) {
+ $config['credentials'] = Arr::only($config, ['key', 'secret']);
+ }
+
+ return $config;
+ }
+
+ /**
+ * Create an instance of the Mail Swift Transport driver.
+ *
+ * @return \Swift_MailTransport
+ */
+ protected function createMailDriver()
+ {
+ return MailTransport::newInstance();
+ }
+
+ /**
+ * Create an instance of the Mailgun Swift Transport driver.
+ *
+ * @return \Illuminate\Mail\Transport\MailgunTransport
+ */
+ protected function createMailgunDriver()
+ {
+ $config = $this->app['config']->get('services.mailgun', []);
+
+ return new MailgunTransport(
+ $this->guzzle($config),
+ $config['secret'], $config['domain']
+ );
+ }
+
+ /**
+ * Create an instance of the Mandrill Swift Transport driver.
+ *
+ * @return \Illuminate\Mail\Transport\MandrillTransport
+ */
+ protected function createMandrillDriver()
+ {
+ $config = $this->app['config']->get('services.mandrill', []);
+
+ return new MandrillTransport(
+ $this->guzzle($config), $config['secret']
+ );
+ }
+
+ /**
+ * Create an instance of the SparkPost Swift Transport driver.
+ *
+ * @return \Illuminate\Mail\Transport\SparkPostTransport
+ */
+ protected function createSparkPostDriver()
+ {
+ $config = $this->app['config']->get('services.sparkpost', []);
+
+ return new SparkPostTransport(
+ $this->guzzle($config), $config['secret'], Arr::get($config, 'options', [])
+ );
+ }
+
+ /**
+ * Create an instance of the Log Swift Transport driver.
+ *
+ * @return \Illuminate\Mail\Transport\LogTransport
+ */
+ protected function createLogDriver()
+ {
+ return new LogTransport($this->app->make(LoggerInterface::class));
+ }
+
+ /**
+ * Create an instance of the Array Swift Transport Driver.
+ *
+ * @return \Illuminate\Mail\Transport\ArrayTransport
+ */
+ protected function createArrayDriver()
+ {
+ return new ArrayTransport;
+ }
+
+ /**
+ * Get a fresh Guzzle HTTP client instance.
+ *
+ * @param array $config
+ * @return \GuzzleHttp\Client
+ */
+ protected function guzzle($config)
+ {
+ return new HttpClient(Arr::add(
+ Arr::get($config, 'guzzle', []), 'connect_timeout', 60
+ ));
+ }
+
+ /**
+ * Get the default mail driver name.
+ *
+ * @return string
+ */
+ public function getDefaultDriver()
+ {
+ return $this->app['config']['mail.driver'];
+ }
+
+ /**
+ * Set the default mail driver name.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setDefaultDriver($name)
+ {
+ $this->app['config']['mail.driver'] = $name;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/composer.json b/vendor/laravel/framework/src/Illuminate/Mail/composer.json
new file mode 100644
index 000000000..80a9f662f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/composer.json
@@ -0,0 +1,44 @@
+{
+ "name": "illuminate/mail",
+ "description": "The Illuminate Mail package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "erusev/parsedown": "~1.6",
+ "illuminate/container": "5.4.*",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "psr/log": "~1.0",
+ "swiftmailer/swiftmailer": "~5.4",
+ "tijsverkoyen/css-to-inline-styles": "~2.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Mail\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "aws/aws-sdk-php": "Required to use the SES mail driver (~3.0).",
+ "guzzlehttp/guzzle": "Required to use the Mailgun and Mandrill mail drivers (~6.0)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/button.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/button.blade.php
new file mode 100644
index 000000000..c7aae1b88
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/button.blade.php
@@ -0,0 +1,19 @@
+
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/footer.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/footer.blade.php
new file mode 100644
index 000000000..c3f9360ab
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/footer.blade.php
@@ -0,0 +1,11 @@
+
+
+
+
+
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/header.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/header.blade.php
new file mode 100644
index 000000000..eefabab92
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/header.blade.php
@@ -0,0 +1,7 @@
+
+
+
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/layout.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/layout.blade.php
new file mode 100644
index 000000000..991ae52a8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/layout.blade.php
@@ -0,0 +1,54 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {{ $header or '' }}
+
+
+
+
+
+
+
+
+ {{ Illuminate\Mail\Markdown::parse($slot) }}
+
+ {{ $subcopy or '' }}
+
+
+
+
+
+
+ {{ $footer or '' }}
+
+
+
+
+
+
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/message.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/message.blade.php
new file mode 100644
index 000000000..2ad23a66e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/message.blade.php
@@ -0,0 +1,27 @@
+@component('mail::layout')
+ {{-- Header --}}
+ @slot('header')
+ @component('mail::header', ['url' => config('app.url')])
+ {{ config('app.name') }}
+ @endcomponent
+ @endslot
+
+ {{-- Body --}}
+ {{ $slot }}
+
+ {{-- Subcopy --}}
+ @isset($subcopy)
+ @slot('subcopy')
+ @component('mail::subcopy')
+ {{ $subcopy }}
+ @endcomponent
+ @endslot
+ @endisset
+
+ {{-- Footer --}}
+ @slot('footer')
+ @component('mail::footer')
+ © {{ date('Y') }} {{ config('app.name') }}. All rights reserved.
+ @endcomponent
+ @endslot
+@endcomponent
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/panel.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/panel.blade.php
new file mode 100644
index 000000000..f39708020
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/panel.blade.php
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+ {{ Illuminate\Mail\Markdown::parse($slot) }}
+
+
+
+
+
+
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/promotion.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/promotion.blade.php
new file mode 100644
index 000000000..0debcf8a3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/promotion.blade.php
@@ -0,0 +1,7 @@
+
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/promotion/button.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/promotion/button.blade.php
new file mode 100644
index 000000000..8e79081c5
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/promotion/button.blade.php
@@ -0,0 +1,13 @@
+
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/subcopy.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/subcopy.blade.php
new file mode 100644
index 000000000..c3df7b4c0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/subcopy.blade.php
@@ -0,0 +1,7 @@
+
+
+
+ {{ Illuminate\Mail\Markdown::parse($slot) }}
+
+
+
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/table.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/table.blade.php
new file mode 100644
index 000000000..a5f3348b2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/table.blade.php
@@ -0,0 +1,3 @@
+
+{{ Illuminate\Mail\Markdown::parse($slot) }}
+
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/themes/default.css b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/themes/default.css
new file mode 100644
index 000000000..20659933c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/html/themes/default.css
@@ -0,0 +1,285 @@
+/* Base */
+
+body, body *:not(html):not(style):not(br):not(tr):not(code) {
+ font-family: Avenir, Helvetica, sans-serif;
+ box-sizing: border-box;
+}
+
+body {
+ background-color: #f5f8fa;
+ color: #74787E;
+ height: 100%;
+ hyphens: auto;
+ line-height: 1.4;
+ margin: 0;
+ -moz-hyphens: auto;
+ -ms-word-break: break-all;
+ width: 100% !important;
+ -webkit-hyphens: auto;
+ -webkit-text-size-adjust: none;
+ word-break: break-all;
+ word-break: break-word;
+}
+
+p,
+ul,
+ol,
+blockquote {
+ line-height: 1.4;
+ text-align: left;
+}
+
+a {
+ color: #3869D4;
+}
+
+a img {
+ border: none;
+}
+
+/* Typography */
+
+h1 {
+ color: #2F3133;
+ font-size: 19px;
+ font-weight: bold;
+ margin-top: 0;
+ text-align: left;
+}
+
+h2 {
+ color: #2F3133;
+ font-size: 16px;
+ font-weight: bold;
+ margin-top: 0;
+ text-align: left;
+}
+
+h3 {
+ color: #2F3133;
+ font-size: 14px;
+ font-weight: bold;
+ margin-top: 0;
+ text-align: left;
+}
+
+p {
+ color: #74787E;
+ font-size: 16px;
+ line-height: 1.5em;
+ margin-top: 0;
+ text-align: left;
+}
+
+p.sub {
+ font-size: 12px;
+}
+
+img {
+ max-width: 100%;
+}
+
+/* Layout */
+
+.wrapper {
+ background-color: #f5f8fa;
+ margin: 0;
+ padding: 0;
+ width: 100%;
+ -premailer-cellpadding: 0;
+ -premailer-cellspacing: 0;
+ -premailer-width: 100%;
+}
+
+.content {
+ margin: 0;
+ padding: 0;
+ width: 100%;
+ -premailer-cellpadding: 0;
+ -premailer-cellspacing: 0;
+ -premailer-width: 100%;
+}
+
+/* Header */
+
+.header {
+ padding: 25px 0;
+ text-align: center;
+}
+
+.header a {
+ color: #bbbfc3;
+ font-size: 19px;
+ font-weight: bold;
+ text-decoration: none;
+ text-shadow: 0 1px 0 white;
+}
+
+/* Body */
+
+.body {
+ background-color: #FFFFFF;
+ border-bottom: 1px solid #EDEFF2;
+ border-top: 1px solid #EDEFF2;
+ margin: 0;
+ padding: 0;
+ width: 100%;
+ -premailer-cellpadding: 0;
+ -premailer-cellspacing: 0;
+ -premailer-width: 100%;
+}
+
+.inner-body {
+ background-color: #FFFFFF;
+ margin: 0 auto;
+ padding: 0;
+ width: 570px;
+ -premailer-cellpadding: 0;
+ -premailer-cellspacing: 0;
+ -premailer-width: 570px;
+}
+
+/* Subcopy */
+
+.subcopy {
+ border-top: 1px solid #EDEFF2;
+ margin-top: 25px;
+ padding-top: 25px;
+}
+
+.subcopy p {
+ font-size: 12px;
+}
+
+/* Footer */
+
+.footer {
+ margin: 0 auto;
+ padding: 0;
+ text-align: center;
+ width: 570px;
+ -premailer-cellpadding: 0;
+ -premailer-cellspacing: 0;
+ -premailer-width: 570px;
+}
+
+.footer p {
+ color: #AEAEAE;
+ font-size: 12px;
+ text-align: center;
+}
+
+/* Tables */
+
+.table table {
+ margin: 30px auto;
+ width: 100%;
+ -premailer-cellpadding: 0;
+ -premailer-cellspacing: 0;
+ -premailer-width: 100%;
+}
+
+.table th {
+ border-bottom: 1px solid #EDEFF2;
+ padding-bottom: 8px;
+}
+
+.table td {
+ color: #74787E;
+ font-size: 15px;
+ line-height: 18px;
+ padding: 10px 0;
+}
+
+.content-cell {
+ padding: 35px;
+}
+
+/* Buttons */
+
+.action {
+ margin: 30px auto;
+ padding: 0;
+ text-align: center;
+ width: 100%;
+ -premailer-cellpadding: 0;
+ -premailer-cellspacing: 0;
+ -premailer-width: 100%;
+}
+
+.button {
+ border-radius: 3px;
+ box-shadow: 0 2px 3px rgba(0, 0, 0, 0.16);
+ color: #FFF;
+ display: inline-block;
+ text-decoration: none;
+ -webkit-text-size-adjust: none;
+}
+
+.button-blue {
+ background-color: #3097D1;
+ border-top: 10px solid #3097D1;
+ border-right: 18px solid #3097D1;
+ border-bottom: 10px solid #3097D1;
+ border-left: 18px solid #3097D1;
+}
+
+.button-green {
+ background-color: #2ab27b;
+ border-top: 10px solid #2ab27b;
+ border-right: 18px solid #2ab27b;
+ border-bottom: 10px solid #2ab27b;
+ border-left: 18px solid #2ab27b;
+}
+
+.button-red {
+ background-color: #bf5329;
+ border-top: 10px solid #bf5329;
+ border-right: 18px solid #bf5329;
+ border-bottom: 10px solid #bf5329;
+ border-left: 18px solid #bf5329;
+}
+
+/* Panels */
+
+.panel {
+ margin: 0 0 21px;
+}
+
+.panel-content {
+ background-color: #EDEFF2;
+ padding: 16px;
+}
+
+.panel-item {
+ padding: 0;
+}
+
+.panel-item p:last-of-type {
+ margin-bottom: 0;
+ padding-bottom: 0;
+}
+
+/* Promotions */
+
+.promotion {
+ background-color: #FFFFFF;
+ border: 2px dashed #9BA2AB;
+ margin: 0;
+ margin-bottom: 25px;
+ margin-top: 25px;
+ padding: 24px;
+ width: 100%;
+ -premailer-cellpadding: 0;
+ -premailer-cellspacing: 0;
+ -premailer-width: 100%;
+}
+
+.promotion h1 {
+ text-align: center;
+}
+
+.promotion p {
+ font-size: 15px;
+ text-align: center;
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/button.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/button.blade.php
new file mode 100644
index 000000000..97444ebdc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/button.blade.php
@@ -0,0 +1 @@
+{{ $slot }}: {{ $url }}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/footer.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/footer.blade.php
new file mode 100644
index 000000000..3338f620e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/footer.blade.php
@@ -0,0 +1 @@
+{{ $slot }}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/header.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/header.blade.php
new file mode 100644
index 000000000..aaa3e5754
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/header.blade.php
@@ -0,0 +1 @@
+[{{ $slot }}]({{ $url }})
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/layout.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/layout.blade.php
new file mode 100644
index 000000000..9378baa07
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/layout.blade.php
@@ -0,0 +1,9 @@
+{!! strip_tags($header) !!}
+
+{!! strip_tags($slot) !!}
+@isset($subcopy)
+
+{!! strip_tags($subcopy) !!}
+@endisset
+
+{!! strip_tags($footer) !!}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/message.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/message.blade.php
new file mode 100644
index 000000000..b409c71cb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/message.blade.php
@@ -0,0 +1,27 @@
+@component('mail::layout')
+ {{-- Header --}}
+ @slot('header')
+ @component('mail::header', ['url' => config('app.url')])
+ {{ config('app.name') }}
+ @endcomponent
+ @endslot
+
+ {{-- Body --}}
+ {{ $slot }}
+
+ {{-- Subcopy --}}
+ @isset($subcopy)
+ @slot('subcopy')
+ @component('mail::subcopy')
+ {{ $subcopy }}
+ @endcomponent
+ @endslot
+ @endisset
+
+ {{-- Footer --}}
+ @slot('footer')
+ @component('mail::footer')
+ © {{ date('Y') }} {{ config('app.name') }}. All rights reserved.
+ @endcomponent
+ @endslot
+@endcomponent
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/panel.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/panel.blade.php
new file mode 100644
index 000000000..3338f620e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/panel.blade.php
@@ -0,0 +1 @@
+{{ $slot }}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/promotion.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/promotion.blade.php
new file mode 100644
index 000000000..3338f620e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/promotion.blade.php
@@ -0,0 +1 @@
+{{ $slot }}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/promotion/button.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/promotion/button.blade.php
new file mode 100644
index 000000000..aaa3e5754
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/promotion/button.blade.php
@@ -0,0 +1 @@
+[{{ $slot }}]({{ $url }})
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/subcopy.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/subcopy.blade.php
new file mode 100644
index 000000000..3338f620e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/subcopy.blade.php
@@ -0,0 +1 @@
+{{ $slot }}
diff --git a/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/table.blade.php b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/table.blade.php
new file mode 100644
index 000000000..3338f620e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Mail/resources/views/markdown/table.blade.php
@@ -0,0 +1 @@
+{{ $slot }}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Action.php b/vendor/laravel/framework/src/Illuminate/Notifications/Action.php
new file mode 100644
index 000000000..071db2d9e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Action.php
@@ -0,0 +1,33 @@
+url = $url;
+ $this->text = $text;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/ChannelManager.php b/vendor/laravel/framework/src/Illuminate/Notifications/ChannelManager.php
new file mode 100644
index 000000000..45a11e6d4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/ChannelManager.php
@@ -0,0 +1,174 @@
+app->make(Bus::class), $this->app->make(Dispatcher::class))
+ )->send($notifiables, $notification);
+ }
+
+ /**
+ * Send the given notification immediately.
+ *
+ * @param \Illuminate\Support\Collection|array|mixed $notifiables
+ * @param mixed $notification
+ * @param array|null $channels
+ * @return void
+ */
+ public function sendNow($notifiables, $notification, array $channels = null)
+ {
+ return (new NotificationSender(
+ $this, $this->app->make(Bus::class), $this->app->make(Dispatcher::class))
+ )->sendNow($notifiables, $notification, $channels);
+ }
+
+ /**
+ * Get a channel instance.
+ *
+ * @param string|null $name
+ * @return mixed
+ */
+ public function channel($name = null)
+ {
+ return $this->driver($name);
+ }
+
+ /**
+ * Create an instance of the database driver.
+ *
+ * @return \Illuminate\Notifications\Channels\DatabaseChannel
+ */
+ protected function createDatabaseDriver()
+ {
+ return $this->app->make(Channels\DatabaseChannel::class);
+ }
+
+ /**
+ * Create an instance of the broadcast driver.
+ *
+ * @return \Illuminate\Notifications\Channels\BroadcastChannel
+ */
+ protected function createBroadcastDriver()
+ {
+ return $this->app->make(Channels\BroadcastChannel::class);
+ }
+
+ /**
+ * Create an instance of the mail driver.
+ *
+ * @return \Illuminate\Notifications\Channels\MailChannel
+ */
+ protected function createMailDriver()
+ {
+ return $this->app->make(Channels\MailChannel::class)->setMarkdownResolver(function () {
+ return $this->app->make(Markdown::class);
+ });
+ }
+
+ /**
+ * Create an instance of the Nexmo driver.
+ *
+ * @return \Illuminate\Notifications\Channels\NexmoSmsChannel
+ */
+ protected function createNexmoDriver()
+ {
+ return new Channels\NexmoSmsChannel(
+ new NexmoClient(new NexmoCredentials(
+ $this->app['config']['services.nexmo.key'],
+ $this->app['config']['services.nexmo.secret']
+ )),
+ $this->app['config']['services.nexmo.sms_from']
+ );
+ }
+
+ /**
+ * Create an instance of the Slack driver.
+ *
+ * @return \Illuminate\Notifications\Channels\SlackWebhookChannel
+ */
+ protected function createSlackDriver()
+ {
+ return new Channels\SlackWebhookChannel(new HttpClient);
+ }
+
+ /**
+ * Create a new driver instance.
+ *
+ * @param string $driver
+ * @return mixed
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function createDriver($driver)
+ {
+ try {
+ return parent::createDriver($driver);
+ } catch (InvalidArgumentException $e) {
+ if (class_exists($driver)) {
+ return $this->app->make($driver);
+ }
+
+ throw $e;
+ }
+ }
+
+ /**
+ * Get the default channel driver name.
+ *
+ * @return string
+ */
+ public function getDefaultDriver()
+ {
+ return $this->defaultChannel;
+ }
+
+ /**
+ * Get the default channel driver name.
+ *
+ * @return string
+ */
+ public function deliversVia()
+ {
+ return $this->getDefaultDriver();
+ }
+
+ /**
+ * Set the default channel driver name.
+ *
+ * @param string $channel
+ * @return void
+ */
+ public function deliverVia($channel)
+ {
+ $this->defaultChannel = $channel;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Channels/BroadcastChannel.php b/vendor/laravel/framework/src/Illuminate/Notifications/Channels/BroadcastChannel.php
new file mode 100644
index 000000000..63f85ce71
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Channels/BroadcastChannel.php
@@ -0,0 +1,77 @@
+events = $events;
+ }
+
+ /**
+ * Send the given notification.
+ *
+ * @param mixed $notifiable
+ * @param \Illuminate\Notifications\Notification $notification
+ * @return array|null
+ */
+ public function send($notifiable, Notification $notification)
+ {
+ $message = $this->getData($notifiable, $notification);
+
+ $event = new BroadcastNotificationCreated(
+ $notifiable, $notification, is_array($message) ? $message : $message->data
+ );
+
+ if ($message instanceof BroadcastMessage) {
+ $event->onConnection($message->connection)
+ ->onQueue($message->queue);
+ }
+
+ return $this->events->dispatch($event);
+ }
+
+ /**
+ * Get the data for the notification.
+ *
+ * @param mixed $notifiable
+ * @param \Illuminate\Notifications\Notification $notification
+ * @return mixed
+ *
+ * @throws \RuntimeException
+ */
+ protected function getData($notifiable, Notification $notification)
+ {
+ if (method_exists($notification, 'toBroadcast')) {
+ return $notification->toBroadcast($notifiable);
+ }
+
+ if (method_exists($notification, 'toArray')) {
+ return $notification->toArray($notifiable);
+ }
+
+ throw new RuntimeException(
+ 'Notification is missing toArray method.'
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Channels/DatabaseChannel.php b/vendor/laravel/framework/src/Illuminate/Notifications/Channels/DatabaseChannel.php
new file mode 100644
index 000000000..41767c3e4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Channels/DatabaseChannel.php
@@ -0,0 +1,51 @@
+routeNotificationFor('database')->create([
+ 'id' => $notification->id,
+ 'type' => get_class($notification),
+ 'data' => $this->getData($notifiable, $notification),
+ 'read_at' => null,
+ ]);
+ }
+
+ /**
+ * Get the data for the notification.
+ *
+ * @param mixed $notifiable
+ * @param \Illuminate\Notifications\Notification $notification
+ * @return array
+ *
+ * @throws \RuntimeException
+ */
+ protected function getData($notifiable, Notification $notification)
+ {
+ if (method_exists($notification, 'toDatabase')) {
+ return is_array($data = $notification->toDatabase($notifiable))
+ ? $data : $data->data;
+ }
+
+ if (method_exists($notification, 'toArray')) {
+ return $notification->toArray($notifiable);
+ }
+
+ throw new RuntimeException(
+ 'Notification is missing toDatabase / toArray method.'
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Channels/MailChannel.php b/vendor/laravel/framework/src/Illuminate/Notifications/Channels/MailChannel.php
new file mode 100644
index 000000000..476704cfd
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Channels/MailChannel.php
@@ -0,0 +1,196 @@
+mailer = $mailer;
+ }
+
+ /**
+ * Send the given notification.
+ *
+ * @param mixed $notifiable
+ * @param \Illuminate\Notifications\Notification $notification
+ * @return void
+ */
+ public function send($notifiable, Notification $notification)
+ {
+ if (! $notifiable->routeNotificationFor('mail')) {
+ return;
+ }
+
+ $message = $notification->toMail($notifiable);
+
+ if ($message instanceof Mailable) {
+ return $message->send($this->mailer);
+ }
+
+ $this->mailer->send($this->buildView($message), $message->data(), function ($mailMessage) use ($notifiable, $notification, $message) {
+ $this->buildMessage($mailMessage, $notifiable, $notification, $message);
+ });
+ }
+
+ /**
+ * Build the notification's view.
+ *
+ * @param \Illuminate\Notifications\Messages\MailMessage $message
+ * @return void
+ */
+ protected function buildView($message)
+ {
+ if ($message->view) {
+ return $message->view;
+ }
+
+ $markdown = call_user_func($this->markdownResolver);
+
+ return [
+ 'html' => $markdown->render($message->markdown, $message->data()),
+ 'text' => $markdown->renderText($message->markdown, $message->data()),
+ ];
+ }
+
+ /**
+ * Build the mail message.
+ *
+ * @param \Illuminate\Mail\Message $mailMessage
+ * @param mixed $notifiable
+ * @param \Illuminate\Notifications\Notification $notification
+ * @param \Illuminate\Notifications\Messages\MailMessage $message
+ * @return void
+ */
+ protected function buildMessage($mailMessage, $notifiable, $notification, $message)
+ {
+ $this->addressMessage($mailMessage, $notifiable, $message);
+
+ $mailMessage->subject($message->subject ?: Str::title(
+ Str::snake(class_basename($notification), ' ')
+ ));
+
+ $this->addAttachments($mailMessage, $message);
+
+ if (! is_null($message->priority)) {
+ $mailMessage->setPriority($message->priority);
+ }
+ }
+
+ /**
+ * Address the mail message.
+ *
+ * @param \Illuminate\Mail\Message $mailMessage
+ * @param mixed $notifiable
+ * @param \Illuminate\Notifications\Messages\MailMessage $message
+ * @return void
+ */
+ protected function addressMessage($mailMessage, $notifiable, $message)
+ {
+ $this->addSender($mailMessage, $message);
+
+ $mailMessage->to($this->getRecipients($notifiable, $message));
+
+ if ($message->cc) {
+ $mailMessage->cc($message->cc[0], Arr::get($message->cc, 1));
+ }
+
+ if ($message->bcc) {
+ $mailMessage->bcc($message->bcc[0], Arr::get($message->bcc, 1));
+ }
+ }
+
+ /**
+ * Add the "from" and "reply to" addresses to the message.
+ *
+ * @param \Illuminate\Mail\Message $mailMessage
+ * @param \Illuminate\Notifications\Messages\MailMessage $message
+ * @return void
+ */
+ protected function addSender($mailMessage, $message)
+ {
+ if (! empty($message->from)) {
+ $mailMessage->from($message->from[0], Arr::get($message->from, 1));
+ }
+
+ if (! empty($message->replyTo)) {
+ $mailMessage->replyTo($message->replyTo[0], Arr::get($message->replyTo, 1));
+ }
+ }
+
+ /**
+ * Get the recipients of the given message.
+ *
+ * @param mixed $notifiable
+ * @param \Illuminate\Notifications\Messages\MailMessage $message
+ * @return mixed
+ */
+ protected function getRecipients($notifiable, $message)
+ {
+ if (is_string($recipients = $notifiable->routeNotificationFor('mail'))) {
+ $recipients = [$recipients];
+ }
+
+ return collect($recipients)->map(function ($recipient) {
+ return is_string($recipient) ? $recipient : $recipient->email;
+ })->all();
+ }
+
+ /**
+ * Add the attachments to the message.
+ *
+ * @param \Illuminate\Mail\Message $mailMessage
+ * @param \Illuminate\Notifications\Messages\MailMessage $message
+ * @return void
+ */
+ protected function addAttachments($mailMessage, $message)
+ {
+ foreach ($message->attachments as $attachment) {
+ $mailMessage->attach($attachment['file'], $attachment['options']);
+ }
+
+ foreach ($message->rawAttachments as $attachment) {
+ $mailMessage->attachData($attachment['data'], $attachment['name'], $attachment['options']);
+ }
+ }
+
+ /**
+ * Set the Markdown resolver callback.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function setMarkdownResolver(Closure $callback)
+ {
+ $this->markdownResolver = $callback;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Channels/NexmoSmsChannel.php b/vendor/laravel/framework/src/Illuminate/Notifications/Channels/NexmoSmsChannel.php
new file mode 100644
index 000000000..619332425
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Channels/NexmoSmsChannel.php
@@ -0,0 +1,64 @@
+from = $from;
+ $this->nexmo = $nexmo;
+ }
+
+ /**
+ * Send the given notification.
+ *
+ * @param mixed $notifiable
+ * @param \Illuminate\Notifications\Notification $notification
+ * @return \Nexmo\Message\Message
+ */
+ public function send($notifiable, Notification $notification)
+ {
+ if (! $to = $notifiable->routeNotificationFor('nexmo')) {
+ return;
+ }
+
+ $message = $notification->toNexmo($notifiable);
+
+ if (is_string($message)) {
+ $message = new NexmoMessage($message);
+ }
+
+ return $this->nexmo->message()->send([
+ 'type' => $message->type,
+ 'from' => $message->from ?: $this->from,
+ 'to' => $to,
+ 'text' => trim($message->content),
+ ]);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Channels/SlackWebhookChannel.php b/vendor/laravel/framework/src/Illuminate/Notifications/Channels/SlackWebhookChannel.php
new file mode 100644
index 000000000..77032e310
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Channels/SlackWebhookChannel.php
@@ -0,0 +1,114 @@
+http = $http;
+ }
+
+ /**
+ * Send the given notification.
+ *
+ * @param mixed $notifiable
+ * @param \Illuminate\Notifications\Notification $notification
+ * @return \Psr\Http\Message\ResponseInterface
+ */
+ public function send($notifiable, Notification $notification)
+ {
+ if (! $url = $notifiable->routeNotificationFor('slack')) {
+ return;
+ }
+
+ $this->http->post($url, $this->buildJsonPayload(
+ $notification->toSlack($notifiable)
+ ));
+ }
+
+ /**
+ * Build up a JSON payload for the Slack webhook.
+ *
+ * @param \Illuminate\Notifications\Messages\SlackMessage $message
+ * @return array
+ */
+ protected function buildJsonPayload(SlackMessage $message)
+ {
+ $optionalFields = array_filter([
+ 'channel' => data_get($message, 'channel'),
+ 'icon_emoji' => data_get($message, 'icon'),
+ 'icon_url' => data_get($message, 'image'),
+ 'link_names' => data_get($message, 'linkNames'),
+ 'username' => data_get($message, 'username'),
+ ]);
+
+ return array_merge([
+ 'json' => array_merge([
+ 'text' => $message->content,
+ 'attachments' => $this->attachments($message),
+ ], $optionalFields),
+ ], $message->http);
+ }
+
+ /**
+ * Format the message's attachments.
+ *
+ * @param \Illuminate\Notifications\Messages\SlackMessage $message
+ * @return array
+ */
+ protected function attachments(SlackMessage $message)
+ {
+ return collect($message->attachments)->map(function ($attachment) use ($message) {
+ return array_filter([
+ 'color' => $attachment->color ?: $message->color(),
+ 'fallback' => $attachment->fallback,
+ 'fields' => $this->fields($attachment),
+ 'footer' => $attachment->footer,
+ 'footer_icon' => $attachment->footerIcon,
+ 'image_url' => $attachment->imageUrl,
+ 'mrkdwn_in' => $attachment->markdown,
+ 'text' => $attachment->content,
+ 'title' => $attachment->title,
+ 'title_link' => $attachment->url,
+ 'ts' => $attachment->timestamp,
+ ]);
+ })->all();
+ }
+
+ /**
+ * Format the attachment's fields.
+ *
+ * @param \Illuminate\Notifications\Messages\SlackAttachment $attachment
+ * @return array
+ */
+ protected function fields(SlackAttachment $attachment)
+ {
+ return collect($attachment->fields)->map(function ($value, $key) {
+ if ($value instanceof SlackAttachmentField) {
+ return $value->toArray();
+ }
+
+ return ['title' => $key, 'value' => $value, 'short' => true];
+ })->values()->all();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Console/NotificationTableCommand.php b/vendor/laravel/framework/src/Illuminate/Notifications/Console/NotificationTableCommand.php
new file mode 100644
index 000000000..09b0e3eb5
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Console/NotificationTableCommand.php
@@ -0,0 +1,81 @@
+files = $files;
+ $this->composer = $composer;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $fullPath = $this->createBaseMigration();
+
+ $this->files->put($fullPath, $this->files->get(__DIR__.'/stubs/notifications.stub'));
+
+ $this->info('Migration created successfully!');
+
+ $this->composer->dumpAutoloads();
+ }
+
+ /**
+ * Create a base migration file for the notifications.
+ *
+ * @return string
+ */
+ protected function createBaseMigration()
+ {
+ $name = 'create_notifications_table';
+
+ $path = $this->laravel->databasePath().'/migrations';
+
+ return $this->laravel['migration.creator']->create($name, $path);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Console/stubs/notifications.stub b/vendor/laravel/framework/src/Illuminate/Notifications/Console/stubs/notifications.stub
new file mode 100644
index 000000000..fb16d5bcc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Console/stubs/notifications.stub
@@ -0,0 +1,35 @@
+uuid('id')->primary();
+ $table->string('type');
+ $table->morphs('notifiable');
+ $table->text('data');
+ $table->timestamp('read_at')->nullable();
+ $table->timestamps();
+ });
+ }
+
+ /**
+ * Reverse the migrations.
+ *
+ * @return void
+ */
+ public function down()
+ {
+ Schema::dropIfExists('notifications');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/DatabaseNotification.php b/vendor/laravel/framework/src/Illuminate/Notifications/DatabaseNotification.php
new file mode 100644
index 000000000..f50006e97
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/DatabaseNotification.php
@@ -0,0 +1,90 @@
+ 'array',
+ 'read_at' => 'datetime',
+ ];
+
+ /**
+ * Get the notifiable entity that the notification belongs to.
+ */
+ public function notifiable()
+ {
+ return $this->morphTo();
+ }
+
+ /**
+ * Mark the notification as read.
+ *
+ * @return void
+ */
+ public function markAsRead()
+ {
+ if (is_null($this->read_at)) {
+ $this->forceFill(['read_at' => $this->freshTimestamp()])->save();
+ }
+ }
+
+ /**
+ * Determine if a notification has been read.
+ *
+ * @return bool
+ */
+ public function read()
+ {
+ return $this->read_at !== null;
+ }
+
+ /**
+ * Determine if a notification has not been read.
+ *
+ * @return bool
+ */
+ public function unread()
+ {
+ return $this->read_at === null;
+ }
+
+ /**
+ * Create a new database notification collection instance.
+ *
+ * @param array $models
+ * @return \Illuminate\Notifications\DatabaseNotificationCollection
+ */
+ public function newCollection(array $models = [])
+ {
+ return new DatabaseNotificationCollection($models);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/DatabaseNotificationCollection.php b/vendor/laravel/framework/src/Illuminate/Notifications/DatabaseNotificationCollection.php
new file mode 100644
index 000000000..5ef3f27e1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/DatabaseNotificationCollection.php
@@ -0,0 +1,20 @@
+each(function ($notification) {
+ $notification->markAsRead();
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Events/BroadcastNotificationCreated.php b/vendor/laravel/framework/src/Illuminate/Notifications/Events/BroadcastNotificationCreated.php
new file mode 100644
index 000000000..c93fe5c57
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Events/BroadcastNotificationCreated.php
@@ -0,0 +1,94 @@
+data = $data;
+ $this->notifiable = $notifiable;
+ $this->notification = $notification;
+ }
+
+ /**
+ * Get the channels the event should broadcast on.
+ *
+ * @return array
+ */
+ public function broadcastOn()
+ {
+ $channels = $this->notification->broadcastOn();
+
+ if (! empty($channels)) {
+ return $channels;
+ }
+
+ return [new PrivateChannel($this->channelName())];
+ }
+
+ /**
+ * Get the data that should be sent with the broadcasted event.
+ *
+ * @return array
+ */
+ public function broadcastWith()
+ {
+ return array_merge($this->data, [
+ 'id' => $this->notification->id,
+ 'type' => get_class($this->notification),
+ ]);
+ }
+
+ /**
+ * Get the broadcast channel name for the event.
+ *
+ * @return string
+ */
+ protected function channelName()
+ {
+ if (method_exists($this->notifiable, 'receivesBroadcastNotificationsOn')) {
+ return $this->notifiable->receivesBroadcastNotificationsOn($this->notification);
+ }
+
+ $class = str_replace('\\', '.', get_class($this->notifiable));
+
+ return $class.'.'.$this->notifiable->getKey();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationFailed.php b/vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationFailed.php
new file mode 100644
index 000000000..1ddd96539
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationFailed.php
@@ -0,0 +1,51 @@
+data = $data;
+ $this->channel = $channel;
+ $this->notifiable = $notifiable;
+ $this->notification = $notification;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationSending.php b/vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationSending.php
new file mode 100644
index 000000000..81a218ece
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationSending.php
@@ -0,0 +1,42 @@
+channel = $channel;
+ $this->notifiable = $notifiable;
+ $this->notification = $notification;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationSent.php b/vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationSent.php
new file mode 100644
index 000000000..725d880f5
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Events/NotificationSent.php
@@ -0,0 +1,51 @@
+channel = $channel;
+ $this->response = $response;
+ $this->notifiable = $notifiable;
+ $this->notification = $notification;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/HasDatabaseNotifications.php b/vendor/laravel/framework/src/Illuminate/Notifications/HasDatabaseNotifications.php
new file mode 100644
index 000000000..0b938b01f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/HasDatabaseNotifications.php
@@ -0,0 +1,33 @@
+morphMany(DatabaseNotification::class, 'notifiable')
+ ->orderBy('created_at', 'desc');
+ }
+
+ /**
+ * Get the entity's read notifications.
+ */
+ public function readNotifications()
+ {
+ return $this->notifications()
+ ->whereNotNull('read_at');
+ }
+
+ /**
+ * Get the entity's unread notifications.
+ */
+ public function unreadNotifications()
+ {
+ return $this->notifications()
+ ->whereNull('read_at');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Messages/BroadcastMessage.php b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/BroadcastMessage.php
new file mode 100644
index 000000000..9884a8fbb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/BroadcastMessage.php
@@ -0,0 +1,41 @@
+data = $data;
+ }
+
+ /**
+ * Set the message data.
+ *
+ * @param array $data
+ * @return $this
+ */
+ public function data($data)
+ {
+ $this->data = $data;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Messages/DatabaseMessage.php b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/DatabaseMessage.php
new file mode 100644
index 000000000..55707a7c0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/DatabaseMessage.php
@@ -0,0 +1,24 @@
+data = $data;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Messages/MailMessage.php b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/MailMessage.php
new file mode 100644
index 000000000..a07c8136a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/MailMessage.php
@@ -0,0 +1,220 @@
+view = $view;
+ $this->viewData = $data;
+
+ $this->markdown = null;
+
+ return $this;
+ }
+
+ /**
+ * Set the Markdown template for the notification.
+ *
+ * @param string $view
+ * @param array $data
+ * @return $this
+ */
+ public function markdown($view, array $data = [])
+ {
+ $this->markdown = $view;
+ $this->viewData = $data;
+
+ $this->view = null;
+
+ return $this;
+ }
+
+ /**
+ * Set the from address for the mail message.
+ *
+ * @param string $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function from($address, $name = null)
+ {
+ $this->from = [$address, $name];
+
+ return $this;
+ }
+
+ /**
+ * Set the "reply to" address of the message.
+ *
+ * @param array|string $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function replyTo($address, $name = null)
+ {
+ $this->replyTo = [$address, $name];
+
+ return $this;
+ }
+
+ /**
+ * Set the cc address for the mail message.
+ *
+ * @param string $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function cc($address, $name = null)
+ {
+ $this->cc = [$address, $name];
+
+ return $this;
+ }
+
+ /**
+ * Set the bcc address for the mail message.
+ *
+ * @param string $address
+ * @param string|null $name
+ * @return $this
+ */
+ public function bcc($address, $name = null)
+ {
+ $this->bcc = [$address, $name];
+
+ return $this;
+ }
+
+ /**
+ * Attach a file to the message.
+ *
+ * @param string $file
+ * @param array $options
+ * @return $this
+ */
+ public function attach($file, array $options = [])
+ {
+ $this->attachments[] = compact('file', 'options');
+
+ return $this;
+ }
+
+ /**
+ * Attach in-memory data as an attachment.
+ *
+ * @param string $data
+ * @param string $name
+ * @param array $options
+ * @return $this
+ */
+ public function attachData($data, $name, array $options = [])
+ {
+ $this->rawAttachments[] = compact('data', 'name', 'options');
+
+ return $this;
+ }
+
+ /**
+ * Set the priority of this message.
+ *
+ * The value is an integer where 1 is the highest priority and 5 is the lowest.
+ *
+ * @param int $level
+ * @return $this
+ */
+ public function priority($level)
+ {
+ $this->priority = $level;
+
+ return $this;
+ }
+
+ /**
+ * Get the data array for the mail message.
+ *
+ * @return array
+ */
+ public function data()
+ {
+ return array_merge($this->toArray(), $this->viewData);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Messages/NexmoMessage.php b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/NexmoMessage.php
new file mode 100644
index 000000000..293cf032e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/NexmoMessage.php
@@ -0,0 +1,76 @@
+content = $content;
+ }
+
+ /**
+ * Set the message content.
+ *
+ * @param string $content
+ * @return $this
+ */
+ public function content($content)
+ {
+ $this->content = $content;
+
+ return $this;
+ }
+
+ /**
+ * Set the phone number the message should be sent from.
+ *
+ * @param string $from
+ * @return $this
+ */
+ public function from($from)
+ {
+ $this->from = $from;
+
+ return $this;
+ }
+
+ /**
+ * Set the message type.
+ *
+ * @return $this
+ */
+ public function unicode()
+ {
+ $this->type = 'unicode';
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SimpleMessage.php b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SimpleMessage.php
new file mode 100644
index 000000000..bbc78740a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SimpleMessage.php
@@ -0,0 +1,219 @@
+level = 'success';
+
+ return $this;
+ }
+
+ /**
+ * Indicate that the notification gives information about an error.
+ *
+ * @return $this
+ */
+ public function error()
+ {
+ $this->level = 'error';
+
+ return $this;
+ }
+
+ /**
+ * Set the "level" of the notification (success, error, etc.).
+ *
+ * @param string $level
+ * @return $this
+ */
+ public function level($level)
+ {
+ $this->level = $level;
+
+ return $this;
+ }
+
+ /**
+ * Set the subject of the notification.
+ *
+ * @param string $subject
+ * @return $this
+ */
+ public function subject($subject)
+ {
+ $this->subject = $subject;
+
+ return $this;
+ }
+
+ /**
+ * Set the greeting of the notification.
+ *
+ * @param string $greeting
+ * @return $this
+ */
+ public function greeting($greeting)
+ {
+ $this->greeting = $greeting;
+
+ return $this;
+ }
+
+ /**
+ * Set the salutation of the notification.
+ *
+ * @param string $salutation
+ * @return $this
+ */
+ public function salutation($salutation)
+ {
+ $this->salutation = $salutation;
+
+ return $this;
+ }
+
+ /**
+ * Add a line of text to the notification.
+ *
+ * @param \Illuminate\Notifications\Action|string $line
+ * @return $this
+ */
+ public function line($line)
+ {
+ return $this->with($line);
+ }
+
+ /**
+ * Add a line of text to the notification.
+ *
+ * @param \Illuminate\Notifications\Action|string|array $line
+ * @return $this
+ */
+ public function with($line)
+ {
+ if ($line instanceof Action) {
+ $this->action($line->text, $line->url);
+ } elseif (! $this->actionText) {
+ $this->introLines[] = $this->formatLine($line);
+ } else {
+ $this->outroLines[] = $this->formatLine($line);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Format the given line of text.
+ *
+ * @param string|array $line
+ * @return string
+ */
+ protected function formatLine($line)
+ {
+ if (is_array($line)) {
+ return implode(' ', array_map('trim', $line));
+ }
+
+ return trim(implode(' ', array_map('trim', preg_split('/\\r\\n|\\r|\\n/', $line))));
+ }
+
+ /**
+ * Configure the "call to action" button.
+ *
+ * @param string $text
+ * @param string $url
+ * @return $this
+ */
+ public function action($text, $url)
+ {
+ $this->actionText = $text;
+ $this->actionUrl = $url;
+
+ return $this;
+ }
+
+ /**
+ * Get an array representation of the message.
+ *
+ * @return array
+ */
+ public function toArray()
+ {
+ return [
+ 'level' => $this->level,
+ 'subject' => $this->subject,
+ 'greeting' => $this->greeting,
+ 'salutation' => $this->salutation,
+ 'introLines' => $this->introLines,
+ 'outroLines' => $this->outroLines,
+ 'actionText' => $this->actionText,
+ 'actionUrl' => $this->actionUrl,
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachment.php b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachment.php
new file mode 100644
index 000000000..a2e49cf23
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachment.php
@@ -0,0 +1,241 @@
+title = $title;
+ $this->url = $url;
+
+ return $this;
+ }
+
+ /**
+ * Set the content (text) of the attachment.
+ *
+ * @param string $content
+ * @return $this
+ */
+ public function content($content)
+ {
+ $this->content = $content;
+
+ return $this;
+ }
+
+ /**
+ * A plain-text summary of the attachment.
+ *
+ * @param string $fallback
+ * @return $this
+ */
+ public function fallback($fallback)
+ {
+ $this->fallback = $fallback;
+
+ return $this;
+ }
+
+ /**
+ * Set the color of the attachment.
+ *
+ * @param string $color
+ * @return $this
+ */
+ public function color($color)
+ {
+ $this->color = $color;
+
+ return $this;
+ }
+
+ /**
+ * Add a field to the attachment.
+ *
+ * @param \Closure|string $title
+ * @param string $content
+ * @return $this
+ */
+ public function field($title, $content = '')
+ {
+ if (is_callable($title)) {
+ $callback = $title;
+
+ $callback($attachmentField = new SlackAttachmentField);
+
+ $this->fields[] = $attachmentField;
+
+ return $this;
+ }
+
+ $this->fields[$title] = $content;
+
+ return $this;
+ }
+
+ /**
+ * Set the fields of the attachment.
+ *
+ * @param array $fields
+ * @return $this
+ */
+ public function fields(array $fields)
+ {
+ $this->fields = $fields;
+
+ return $this;
+ }
+
+ /**
+ * Set the fields containing markdown.
+ *
+ * @param array $fields
+ * @return $this
+ */
+ public function markdown(array $fields)
+ {
+ $this->markdown = $fields;
+
+ return $this;
+ }
+
+ /**
+ * Set the image URL.
+ *
+ * @param string $url
+ * @return $this
+ */
+ public function image($url)
+ {
+ $this->imageUrl = $url;
+
+ return $this;
+ }
+
+ /**
+ * Set the footer content.
+ *
+ * @param string $footer
+ * @return $this
+ */
+ public function footer($footer)
+ {
+ $this->footer = $footer;
+
+ return $this;
+ }
+
+ /**
+ * Set the footer icon.
+ *
+ * @param string $icon
+ * @return $this
+ */
+ public function footerIcon($icon)
+ {
+ $this->footerIcon = $icon;
+
+ return $this;
+ }
+
+ /**
+ * Set the timestamp.
+ *
+ * @param Carbon $timestamp
+ * @return $this
+ */
+ public function timestamp(Carbon $timestamp)
+ {
+ $this->timestamp = $timestamp->getTimestamp();
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachmentField.php b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachmentField.php
new file mode 100644
index 000000000..f63bb2678
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackAttachmentField.php
@@ -0,0 +1,79 @@
+title = $title;
+
+ return $this;
+ }
+
+ /**
+ * Set the content of the field.
+ *
+ * @param string $content
+ * @return $this
+ */
+ public function content($content)
+ {
+ $this->content = $content;
+
+ return $this;
+ }
+
+ /**
+ * Indicates that the content should not be displayed side-by-side with other fields.
+ *
+ * @return $this
+ */
+ public function long()
+ {
+ $this->short = false;
+
+ return $this;
+ }
+
+ /**
+ * Get the array representation of the attachment field.
+ *
+ * @return array
+ */
+ public function toArray()
+ {
+ return [
+ 'title' => $this->title,
+ 'value' => $this->content,
+ 'short' => $this->short,
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackMessage.php b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackMessage.php
new file mode 100644
index 000000000..ebeff3fca
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Messages/SlackMessage.php
@@ -0,0 +1,221 @@
+level = 'success';
+
+ return $this;
+ }
+
+ /**
+ * Indicate that the notification gives information about a warning.
+ *
+ * @return $this
+ */
+ public function warning()
+ {
+ $this->level = 'warning';
+
+ return $this;
+ }
+
+ /**
+ * Indicate that the notification gives information about an error.
+ *
+ * @return $this
+ */
+ public function error()
+ {
+ $this->level = 'error';
+
+ return $this;
+ }
+
+ /**
+ * Set a custom username and optional emoji icon for the Slack message.
+ *
+ * @param string $username
+ * @param string|null $icon
+ * @return $this
+ */
+ public function from($username, $icon = null)
+ {
+ $this->username = $username;
+
+ if (! is_null($icon)) {
+ $this->icon = $icon;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Set a custom image icon the message should use.
+ *
+ * @param string $image
+ * @return $this
+ */
+ public function image($image)
+ {
+ $this->image = $image;
+
+ return $this;
+ }
+
+ /**
+ * Set the Slack channel the message should be sent to.
+ *
+ * @param string $channel
+ * @return $this
+ */
+ public function to($channel)
+ {
+ $this->channel = $channel;
+
+ return $this;
+ }
+
+ /**
+ * Set the content of the Slack message.
+ *
+ * @param string $content
+ * @return $this
+ */
+ public function content($content)
+ {
+ $this->content = $content;
+
+ return $this;
+ }
+
+ /**
+ * Define an attachment for the message.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function attachment(Closure $callback)
+ {
+ $this->attachments[] = $attachment = new SlackAttachment;
+
+ $callback($attachment);
+
+ return $this;
+ }
+
+ /**
+ * Get the color for the message.
+ *
+ * @return string
+ */
+ public function color()
+ {
+ switch ($this->level) {
+ case 'success':
+ return 'good';
+ case 'error':
+ return 'danger';
+ case 'warning':
+ return 'warning';
+ }
+ }
+
+ /**
+ * Find and link channel names and usernames.
+ *
+ * @return $this
+ */
+ public function linkNames()
+ {
+ $this->linkNames = 1;
+
+ return $this;
+ }
+
+ /**
+ * Set additional request options for the Guzzle HTTP client.
+ *
+ * @param array $options
+ * @return $this
+ */
+ public function http(array $options)
+ {
+ $this->http = $options;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/Notifiable.php b/vendor/laravel/framework/src/Illuminate/Notifications/Notifiable.php
new file mode 100644
index 000000000..82381e1ed
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/Notifiable.php
@@ -0,0 +1,8 @@
+bus = $bus;
+ $this->events = $events;
+ $this->manager = $manager;
+ }
+
+ /**
+ * Send the given notification to the given notifiable entities.
+ *
+ * @param \Illuminate\Support\Collection|array|mixed $notifiables
+ * @param mixed $notification
+ * @return void
+ */
+ public function send($notifiables, $notification)
+ {
+ $notifiables = $this->formatNotifiables($notifiables);
+
+ if ($notification instanceof ShouldQueue) {
+ return $this->queueNotification($notifiables, $notification);
+ }
+
+ return $this->sendNow($notifiables, $notification);
+ }
+
+ /**
+ * Send the given notification immediately.
+ *
+ * @param \Illuminate\Support\Collection|array|mixed $notifiables
+ * @param mixed $notification
+ * @param array $channels
+ * @return void
+ */
+ public function sendNow($notifiables, $notification, array $channels = null)
+ {
+ $notifiables = $this->formatNotifiables($notifiables);
+
+ $original = clone $notification;
+
+ foreach ($notifiables as $notifiable) {
+ $notificationId = Uuid::uuid4()->toString();
+
+ if (empty($viaChannels = $channels ?: $notification->via($notifiable))) {
+ continue;
+ }
+
+ foreach ((array) $viaChannels as $channel) {
+ $this->sendToNotifiable($notifiable, $notificationId, clone $original, $channel);
+ }
+ }
+ }
+
+ /**
+ * Send the given notification to the given notifiable via a channel.
+ *
+ * @param mixed $notifiable
+ * @param string $id
+ * @param mixed $notification
+ * @param string $channel
+ * @return void
+ */
+ protected function sendToNotifiable($notifiable, $id, $notification, $channel)
+ {
+ if (! $notification->id) {
+ $notification->id = $id;
+ }
+
+ if (! $this->shouldSendNotification($notifiable, $notification, $channel)) {
+ return;
+ }
+
+ $response = $this->manager->driver($channel)->send($notifiable, $notification);
+
+ $this->events->dispatch(
+ new Events\NotificationSent($notifiable, $notification, $channel, $response)
+ );
+ }
+
+ /**
+ * Determines if the notification can be sent.
+ *
+ * @param mixed $notifiable
+ * @param mixed $notification
+ * @param string $channel
+ * @return bool
+ */
+ protected function shouldSendNotification($notifiable, $notification, $channel)
+ {
+ return $this->events->until(
+ new Events\NotificationSending($notifiable, $notification, $channel)
+ ) !== false;
+ }
+
+ /**
+ * Queue the given notification instances.
+ *
+ * @param mixed $notifiables
+ * @param array[\Illuminate\Notifications\Channels\Notification] $notification
+ * @return void
+ */
+ protected function queueNotification($notifiables, $notification)
+ {
+ $notifiables = $this->formatNotifiables($notifiables);
+
+ $original = clone $notification;
+
+ foreach ($notifiables as $notifiable) {
+ $notificationId = Uuid::uuid4()->toString();
+
+ foreach ($original->via($notifiable) as $channel) {
+ $notification = clone $original;
+
+ $notification->id = $notificationId;
+
+ $this->bus->dispatch(
+ (new SendQueuedNotifications($this->formatNotifiables($notifiable), $notification, [$channel]))
+ ->onConnection($notification->connection)
+ ->onQueue($notification->queue)
+ ->delay($notification->delay)
+ );
+ }
+ }
+ }
+
+ /**
+ * Format the notifiables into a Collection / array if necessary.
+ *
+ * @param mixed $notifiables
+ * @return ModelCollection|array
+ */
+ protected function formatNotifiables($notifiables)
+ {
+ if (! $notifiables instanceof Collection && ! is_array($notifiables)) {
+ return $notifiables instanceof Model
+ ? new ModelCollection([$notifiables]) : [$notifiables];
+ }
+
+ return $notifiables;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/NotificationServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Notifications/NotificationServiceProvider.php
new file mode 100644
index 000000000..e8909f455
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/NotificationServiceProvider.php
@@ -0,0 +1,46 @@
+loadViewsFrom(__DIR__.'/resources/views', 'notifications');
+
+ if ($this->app->runningInConsole()) {
+ $this->publishes([
+ __DIR__.'/resources/views' => $this->app->resourcePath('views/vendor/notifications'),
+ ], 'laravel-notifications');
+ }
+ }
+
+ /**
+ * Register the service provider.
+ *
+ * @return void
+ */
+ public function register()
+ {
+ $this->app->singleton(ChannelManager::class, function ($app) {
+ return new ChannelManager($app);
+ });
+
+ $this->app->alias(
+ ChannelManager::class, DispatcherContract::class
+ );
+
+ $this->app->alias(
+ ChannelManager::class, FactoryContract::class
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/RoutesNotifications.php b/vendor/laravel/framework/src/Illuminate/Notifications/RoutesNotifications.php
new file mode 100644
index 000000000..bedbe96ea
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/RoutesNotifications.php
@@ -0,0 +1,42 @@
+send($this, $instance);
+ }
+
+ /**
+ * Get the notification routing information for the given driver.
+ *
+ * @param string $driver
+ * @return mixed
+ */
+ public function routeNotificationFor($driver)
+ {
+ if (method_exists($this, $method = 'routeNotificationFor'.Str::studly($driver))) {
+ return $this->{$method}();
+ }
+
+ switch ($driver) {
+ case 'database':
+ return $this->notifications();
+ case 'mail':
+ return $this->email;
+ case 'nexmo':
+ return $this->phone_number;
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/SendQueuedNotifications.php b/vendor/laravel/framework/src/Illuminate/Notifications/SendQueuedNotifications.php
new file mode 100644
index 000000000..8463ea454
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/SendQueuedNotifications.php
@@ -0,0 +1,69 @@
+channels = $channels;
+ $this->notifiables = $notifiables;
+ $this->notification = $notification;
+ }
+
+ /**
+ * Send the notifications.
+ *
+ * @param \Illuminate\Notifications\ChannelManager $manager
+ * @return void
+ */
+ public function handle(ChannelManager $manager)
+ {
+ $manager->sendNow($this->notifiables, $this->notification, $this->channels);
+ }
+
+ /**
+ * Get the display name for the queued job.
+ *
+ * @return string
+ */
+ public function displayName()
+ {
+ return get_class($this->notification);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/composer.json b/vendor/laravel/framework/src/Illuminate/Notifications/composer.json
new file mode 100644
index 000000000..a8c1cc8b1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/composer.json
@@ -0,0 +1,47 @@
+{
+ "name": "illuminate/notifications",
+ "description": "The Illuminate Notifications package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/broadcasting": "5.4.*",
+ "illuminate/bus": "5.4.*",
+ "illuminate/container": "5.4.*",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/filesystem": "5.4.*",
+ "illuminate/mail": "5.4.*",
+ "illuminate/queue": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "ramsey/uuid": "~3.0"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Notifications\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "guzzlehttp/guzzle": "Required to use the Slack transport (~6.0).",
+ "illuminate/database": "Required to use the database transport (5.4.*).",
+ "nexmo/client": "Required to use the Nexmo transport (~1.0)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Notifications/resources/views/email.blade.php b/vendor/laravel/framework/src/Illuminate/Notifications/resources/views/email.blade.php
new file mode 100644
index 000000000..abfaa88e3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Notifications/resources/views/email.blade.php
@@ -0,0 +1,58 @@
+@component('mail::message')
+{{-- Greeting --}}
+@if (! empty($greeting))
+# {{ $greeting }}
+@else
+@if ($level == 'error')
+# Whoops!
+@else
+# Hello!
+@endif
+@endif
+
+{{-- Intro Lines --}}
+@foreach ($introLines as $line)
+{{ $line }}
+
+@endforeach
+
+{{-- Action Button --}}
+@isset($actionText)
+
+@component('mail::button', ['url' => $actionUrl, 'color' => $color])
+{{ $actionText }}
+@endcomponent
+@endisset
+
+{{-- Outro Lines --}}
+@foreach ($outroLines as $line)
+{{ $line }}
+
+@endforeach
+
+{{-- Salutation --}}
+@if (! empty($salutation))
+{{ $salutation }}
+@else
+Regards, {{ config('app.name') }}
+@endif
+
+{{-- Subcopy --}}
+@isset($actionText)
+@component('mail::subcopy')
+If you’re having trouble clicking the "{{ $actionText }}" button, copy and paste the URL below
+into your web browser: [{{ $actionUrl }}]({{ $actionUrl }})
+@endcomponent
+@endisset
+@endcomponent
diff --git a/vendor/laravel/framework/src/Illuminate/Pagination/AbstractPaginator.php b/vendor/laravel/framework/src/Illuminate/Pagination/AbstractPaginator.php
new file mode 100644
index 000000000..ebaf1ff71
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pagination/AbstractPaginator.php
@@ -0,0 +1,580 @@
+= 1 && filter_var($page, FILTER_VALIDATE_INT) !== false;
+ }
+
+ /**
+ * Get the URL for the previous page.
+ *
+ * @return string|null
+ */
+ public function previousPageUrl()
+ {
+ if ($this->currentPage() > 1) {
+ return $this->url($this->currentPage() - 1);
+ }
+ }
+
+ /**
+ * Create a range of pagination URLs.
+ *
+ * @param int $start
+ * @param int $end
+ * @return array
+ */
+ public function getUrlRange($start, $end)
+ {
+ return collect(range($start, $end))->mapWithKeys(function ($page) {
+ return [$page => $this->url($page)];
+ })->all();
+ }
+
+ /**
+ * Get the URL for a given page number.
+ *
+ * @param int $page
+ * @return string
+ */
+ public function url($page)
+ {
+ if ($page <= 0) {
+ $page = 1;
+ }
+
+ // If we have any extra query string key / value pairs that need to be added
+ // onto the URL, we will put them in query string form and then attach it
+ // to the URL. This allows for extra information like sortings storage.
+ $parameters = [$this->pageName => $page];
+
+ if (count($this->query) > 0) {
+ $parameters = array_merge($this->query, $parameters);
+ }
+
+ return $this->path
+ .(Str::contains($this->path, '?') ? '&' : '?')
+ .http_build_query($parameters, '', '&')
+ .$this->buildFragment();
+ }
+
+ /**
+ * Get / set the URL fragment to be appended to URLs.
+ *
+ * @param string|null $fragment
+ * @return $this|string|null
+ */
+ public function fragment($fragment = null)
+ {
+ if (is_null($fragment)) {
+ return $this->fragment;
+ }
+
+ $this->fragment = $fragment;
+
+ return $this;
+ }
+
+ /**
+ * Add a set of query string values to the paginator.
+ *
+ * @param array|string $key
+ * @param string|null $value
+ * @return $this
+ */
+ public function appends($key, $value = null)
+ {
+ if (is_array($key)) {
+ return $this->appendArray($key);
+ }
+
+ return $this->addQuery($key, $value);
+ }
+
+ /**
+ * Add an array of query string values.
+ *
+ * @param array $keys
+ * @return $this
+ */
+ protected function appendArray(array $keys)
+ {
+ foreach ($keys as $key => $value) {
+ $this->addQuery($key, $value);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a query string value to the paginator.
+ *
+ * @param string $key
+ * @param string $value
+ * @return $this
+ */
+ protected function addQuery($key, $value)
+ {
+ if ($key !== $this->pageName) {
+ $this->query[$key] = $value;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Build the full fragment portion of a URL.
+ *
+ * @return string
+ */
+ protected function buildFragment()
+ {
+ return $this->fragment ? '#'.$this->fragment : '';
+ }
+
+ /**
+ * Get the slice of items being paginated.
+ *
+ * @return array
+ */
+ public function items()
+ {
+ return $this->items->all();
+ }
+
+ /**
+ * Get the number of the first item in the slice.
+ *
+ * @return int
+ */
+ public function firstItem()
+ {
+ return count($this->items) > 0 ? ($this->currentPage - 1) * $this->perPage + 1 : null;
+ }
+
+ /**
+ * Get the number of the last item in the slice.
+ *
+ * @return int
+ */
+ public function lastItem()
+ {
+ return count($this->items) > 0 ? $this->firstItem() + $this->count() - 1 : null;
+ }
+
+ /**
+ * Get the number of items shown per page.
+ *
+ * @return int
+ */
+ public function perPage()
+ {
+ return $this->perPage;
+ }
+
+ /**
+ * Determine if there are enough items to split into multiple pages.
+ *
+ * @return bool
+ */
+ public function hasPages()
+ {
+ return $this->currentPage() != 1 || $this->hasMorePages();
+ }
+
+ /**
+ * Determine if the paginator is on the first page.
+ *
+ * @return bool
+ */
+ public function onFirstPage()
+ {
+ return $this->currentPage() <= 1;
+ }
+
+ /**
+ * Get the current page.
+ *
+ * @return int
+ */
+ public function currentPage()
+ {
+ return $this->currentPage;
+ }
+
+ /**
+ * Get the query string variable used to store the page.
+ *
+ * @return string
+ */
+ public function getPageName()
+ {
+ return $this->pageName;
+ }
+
+ /**
+ * Set the query string variable used to store the page.
+ *
+ * @param string $name
+ * @return $this
+ */
+ public function setPageName($name)
+ {
+ $this->pageName = $name;
+
+ return $this;
+ }
+
+ /**
+ * Set the base path to assign to all URLs.
+ *
+ * @param string $path
+ * @return $this
+ */
+ public function withPath($path)
+ {
+ return $this->setPath($path);
+ }
+
+ /**
+ * Set the base path to assign to all URLs.
+ *
+ * @param string $path
+ * @return $this
+ */
+ public function setPath($path)
+ {
+ $this->path = $path;
+
+ return $this;
+ }
+
+ /**
+ * Resolve the current request path or return the default value.
+ *
+ * @param string $default
+ * @return string
+ */
+ public static function resolveCurrentPath($default = '/')
+ {
+ if (isset(static::$currentPathResolver)) {
+ return call_user_func(static::$currentPathResolver);
+ }
+
+ return $default;
+ }
+
+ /**
+ * Set the current request path resolver callback.
+ *
+ * @param \Closure $resolver
+ * @return void
+ */
+ public static function currentPathResolver(Closure $resolver)
+ {
+ static::$currentPathResolver = $resolver;
+ }
+
+ /**
+ * Resolve the current page or return the default value.
+ *
+ * @param string $pageName
+ * @param int $default
+ * @return int
+ */
+ public static function resolveCurrentPage($pageName = 'page', $default = 1)
+ {
+ if (isset(static::$currentPageResolver)) {
+ return call_user_func(static::$currentPageResolver, $pageName);
+ }
+
+ return $default;
+ }
+
+ /**
+ * Set the current page resolver callback.
+ *
+ * @param \Closure $resolver
+ * @return void
+ */
+ public static function currentPageResolver(Closure $resolver)
+ {
+ static::$currentPageResolver = $resolver;
+ }
+
+ /**
+ * Get an instance of the view factory from the resolver.
+ *
+ * @return \Illuminate\Contracts\View\Factory
+ */
+ public static function viewFactory()
+ {
+ return call_user_func(static::$viewFactoryResolver);
+ }
+
+ /**
+ * Set the view factory resolver callback.
+ *
+ * @param \Closure $resolver
+ * @return void
+ */
+ public static function viewFactoryResolver(Closure $resolver)
+ {
+ static::$viewFactoryResolver = $resolver;
+ }
+
+ /**
+ * Set the default pagination view.
+ *
+ * @param string $view
+ * @return void
+ */
+ public static function defaultView($view)
+ {
+ static::$defaultView = $view;
+ }
+
+ /**
+ * Set the default "simple" pagination view.
+ *
+ * @param string $view
+ * @return void
+ */
+ public static function defaultSimpleView($view)
+ {
+ static::$defaultSimpleView = $view;
+ }
+
+ /**
+ * Get an iterator for the items.
+ *
+ * @return \ArrayIterator
+ */
+ public function getIterator()
+ {
+ return new ArrayIterator($this->items->all());
+ }
+
+ /**
+ * Determine if the list of items is empty or not.
+ *
+ * @return bool
+ */
+ public function isEmpty()
+ {
+ return $this->items->isEmpty();
+ }
+
+ /**
+ * Get the number of items for the current page.
+ *
+ * @return int
+ */
+ public function count()
+ {
+ return $this->items->count();
+ }
+
+ /**
+ * Get the paginator's underlying collection.
+ *
+ * @return \Illuminate\Support\Collection
+ */
+ public function getCollection()
+ {
+ return $this->items;
+ }
+
+ /**
+ * Set the paginator's underlying collection.
+ *
+ * @param \Illuminate\Support\Collection $collection
+ * @return $this
+ */
+ public function setCollection(Collection $collection)
+ {
+ $this->items = $collection;
+
+ return $this;
+ }
+
+ /**
+ * Determine if the given item exists.
+ *
+ * @param mixed $key
+ * @return bool
+ */
+ public function offsetExists($key)
+ {
+ return $this->items->has($key);
+ }
+
+ /**
+ * Get the item at the given offset.
+ *
+ * @param mixed $key
+ * @return mixed
+ */
+ public function offsetGet($key)
+ {
+ return $this->items->get($key);
+ }
+
+ /**
+ * Set the item at the given offset.
+ *
+ * @param mixed $key
+ * @param mixed $value
+ * @return void
+ */
+ public function offsetSet($key, $value)
+ {
+ $this->items->put($key, $value);
+ }
+
+ /**
+ * Unset the item at the given key.
+ *
+ * @param mixed $key
+ * @return void
+ */
+ public function offsetUnset($key)
+ {
+ $this->items->forget($key);
+ }
+
+ /**
+ * Render the contents of the paginator to HTML.
+ *
+ * @return string
+ */
+ public function toHtml()
+ {
+ return (string) $this->render();
+ }
+
+ /**
+ * Make dynamic calls into the collection.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->getCollection()->$method(...$parameters);
+ }
+
+ /**
+ * Render the contents of the paginator when casting to string.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return (string) $this->render();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Pagination/LengthAwarePaginator.php b/vendor/laravel/framework/src/Illuminate/Pagination/LengthAwarePaginator.php
new file mode 100644
index 000000000..e0cd317ae
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pagination/LengthAwarePaginator.php
@@ -0,0 +1,197 @@
+ $value) {
+ $this->{$key} = $value;
+ }
+
+ $this->total = $total;
+ $this->perPage = $perPage;
+ $this->lastPage = (int) ceil($total / $perPage);
+ $this->path = $this->path != '/' ? rtrim($this->path, '/') : $this->path;
+ $this->currentPage = $this->setCurrentPage($currentPage, $this->pageName);
+ $this->items = $items instanceof Collection ? $items : Collection::make($items);
+ }
+
+ /**
+ * Get the current page for the request.
+ *
+ * @param int $currentPage
+ * @param string $pageName
+ * @return int
+ */
+ protected function setCurrentPage($currentPage, $pageName)
+ {
+ $currentPage = $currentPage ?: static::resolveCurrentPage($pageName);
+
+ return $this->isValidPageNumber($currentPage) ? (int) $currentPage : 1;
+ }
+
+ /**
+ * Render the paginator using the given view.
+ *
+ * @param string $view
+ * @param array $data
+ * @return string
+ */
+ public function links($view = null, $data = [])
+ {
+ return $this->render($view, $data);
+ }
+
+ /**
+ * Render the paginator using the given view.
+ *
+ * @param string $view
+ * @param array $data
+ * @return string
+ */
+ public function render($view = null, $data = [])
+ {
+ return new HtmlString(static::viewFactory()->make($view ?: static::$defaultView, array_merge($data, [
+ 'paginator' => $this,
+ 'elements' => $this->elements(),
+ ]))->render());
+ }
+
+ /**
+ * Get the array of elements to pass to the view.
+ *
+ * @return array
+ */
+ protected function elements()
+ {
+ $window = UrlWindow::make($this);
+
+ return array_filter([
+ $window['first'],
+ is_array($window['slider']) ? '...' : null,
+ $window['slider'],
+ is_array($window['last']) ? '...' : null,
+ $window['last'],
+ ]);
+ }
+
+ /**
+ * Get the total number of items being paginated.
+ *
+ * @return int
+ */
+ public function total()
+ {
+ return $this->total;
+ }
+
+ /**
+ * Determine if there are more items in the data source.
+ *
+ * @return bool
+ */
+ public function hasMorePages()
+ {
+ return $this->currentPage() < $this->lastPage();
+ }
+
+ /**
+ * Get the URL for the next page.
+ *
+ * @return string|null
+ */
+ public function nextPageUrl()
+ {
+ if ($this->lastPage() > $this->currentPage()) {
+ return $this->url($this->currentPage() + 1);
+ }
+ }
+
+ /**
+ * Get the last page.
+ *
+ * @return int
+ */
+ public function lastPage()
+ {
+ return $this->lastPage;
+ }
+
+ /**
+ * Get the instance as an array.
+ *
+ * @return array
+ */
+ public function toArray()
+ {
+ return [
+ 'current_page' => $this->currentPage(),
+ 'data' => $this->items->toArray(),
+ 'from' => $this->firstItem(),
+ 'last_page' => $this->lastPage(),
+ 'next_page_url' => $this->nextPageUrl(),
+ 'path' => $this->path,
+ 'per_page' => $this->perPage(),
+ 'prev_page_url' => $this->previousPageUrl(),
+ 'to' => $this->lastItem(),
+ 'total' => $this->total(),
+ ];
+ }
+
+ /**
+ * Convert the object into something JSON serializable.
+ *
+ * @return array
+ */
+ public function jsonSerialize()
+ {
+ return $this->toArray();
+ }
+
+ /**
+ * Convert the object to its JSON representation.
+ *
+ * @param int $options
+ * @return string
+ */
+ public function toJson($options = 0)
+ {
+ return json_encode($this->jsonSerialize(), $options);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Pagination/PaginationServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Pagination/PaginationServiceProvider.php
new file mode 100644
index 000000000..d5ca6daec
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pagination/PaginationServiceProvider.php
@@ -0,0 +1,50 @@
+loadViewsFrom(__DIR__.'/resources/views', 'pagination');
+
+ if ($this->app->runningInConsole()) {
+ $this->publishes([
+ __DIR__.'/resources/views' => $this->app->resourcePath('views/vendor/pagination'),
+ ], 'laravel-pagination');
+ }
+ }
+
+ /**
+ * Register the service provider.
+ *
+ * @return void
+ */
+ public function register()
+ {
+ Paginator::viewFactoryResolver(function () {
+ return $this->app['view'];
+ });
+
+ Paginator::currentPathResolver(function () {
+ return $this->app['request']->url();
+ });
+
+ Paginator::currentPageResolver(function ($pageName = 'page') {
+ $page = $this->app['request']->input($pageName);
+
+ if (filter_var($page, FILTER_VALIDATE_INT) !== false && (int) $page >= 1) {
+ return $page;
+ }
+
+ return 1;
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Pagination/Paginator.php b/vendor/laravel/framework/src/Illuminate/Pagination/Paginator.php
new file mode 100644
index 000000000..61f33e928
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pagination/Paginator.php
@@ -0,0 +1,176 @@
+ $value) {
+ $this->{$key} = $value;
+ }
+
+ $this->perPage = $perPage;
+ $this->currentPage = $this->setCurrentPage($currentPage);
+ $this->path = $this->path != '/' ? rtrim($this->path, '/') : $this->path;
+
+ $this->setItems($items);
+ }
+
+ /**
+ * Get the current page for the request.
+ *
+ * @param int $currentPage
+ * @return int
+ */
+ protected function setCurrentPage($currentPage)
+ {
+ $currentPage = $currentPage ?: static::resolveCurrentPage();
+
+ return $this->isValidPageNumber($currentPage) ? (int) $currentPage : 1;
+ }
+
+ /**
+ * Set the items for the paginator.
+ *
+ * @param mixed $items
+ * @return void
+ */
+ protected function setItems($items)
+ {
+ $this->items = $items instanceof Collection ? $items : Collection::make($items);
+
+ $this->hasMore = count($this->items) > ($this->perPage);
+
+ $this->items = $this->items->slice(0, $this->perPage);
+ }
+
+ /**
+ * Get the URL for the next page.
+ *
+ * @return string|null
+ */
+ public function nextPageUrl()
+ {
+ if ($this->hasMorePages()) {
+ return $this->url($this->currentPage() + 1);
+ }
+ }
+
+ /**
+ * Render the paginator using the given view.
+ *
+ * @param string|null $view
+ * @param array $data
+ * @return string
+ */
+ public function links($view = null, $data = [])
+ {
+ return $this->render($view, $data);
+ }
+
+ /**
+ * Render the paginator using the given view.
+ *
+ * @param string|null $view
+ * @param array $data
+ * @return string
+ */
+ public function render($view = null, $data = [])
+ {
+ return new HtmlString(
+ static::viewFactory()->make($view ?: static::$defaultSimpleView, array_merge($data, [
+ 'paginator' => $this,
+ ]))->render()
+ );
+ }
+
+ /**
+ * Manually indicate that the paginator does have more pages.
+ *
+ * @param bool $value
+ * @return $this
+ */
+ public function hasMorePagesWhen($value = true)
+ {
+ $this->hasMore = $value;
+
+ return $this;
+ }
+
+ /**
+ * Determine if there are more items in the data source.
+ *
+ * @return bool
+ */
+ public function hasMorePages()
+ {
+ return $this->hasMore;
+ }
+
+ /**
+ * Get the instance as an array.
+ *
+ * @return array
+ */
+ public function toArray()
+ {
+ return [
+ 'current_page' => $this->currentPage(),
+ 'data' => $this->items->toArray(),
+ 'from' => $this->firstItem(),
+ 'next_page_url' => $this->nextPageUrl(),
+ 'path' => $this->path,
+ 'per_page' => $this->perPage(),
+ 'prev_page_url' => $this->previousPageUrl(),
+ 'to' => $this->lastItem(),
+ ];
+ }
+
+ /**
+ * Convert the object into something JSON serializable.
+ *
+ * @return array
+ */
+ public function jsonSerialize()
+ {
+ return $this->toArray();
+ }
+
+ /**
+ * Convert the object to its JSON representation.
+ *
+ * @param int $options
+ * @return string
+ */
+ public function toJson($options = 0)
+ {
+ return json_encode($this->jsonSerialize(), $options);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Pagination/UrlWindow.php b/vendor/laravel/framework/src/Illuminate/Pagination/UrlWindow.php
new file mode 100644
index 000000000..6ec0b0c9d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pagination/UrlWindow.php
@@ -0,0 +1,218 @@
+paginator = $paginator;
+ }
+
+ /**
+ * Create a new URL window instance.
+ *
+ * @param \Illuminate\Contracts\Pagination\LengthAwarePaginator $paginator
+ * @param int $onEachSide
+ * @return array
+ */
+ public static function make(PaginatorContract $paginator, $onEachSide = 3)
+ {
+ return (new static($paginator))->get($onEachSide);
+ }
+
+ /**
+ * Get the window of URLs to be shown.
+ *
+ * @param int $onEachSide
+ * @return array
+ */
+ public function get($onEachSide = 3)
+ {
+ if ($this->paginator->lastPage() < ($onEachSide * 2) + 6) {
+ return $this->getSmallSlider();
+ }
+
+ return $this->getUrlSlider($onEachSide);
+ }
+
+ /**
+ * Get the slider of URLs there are not enough pages to slide.
+ *
+ * @return array
+ */
+ protected function getSmallSlider()
+ {
+ return [
+ 'first' => $this->paginator->getUrlRange(1, $this->lastPage()),
+ 'slider' => null,
+ 'last' => null,
+ ];
+ }
+
+ /**
+ * Create a URL slider links.
+ *
+ * @param int $onEachSide
+ * @return array
+ */
+ protected function getUrlSlider($onEachSide)
+ {
+ $window = $onEachSide * 2;
+
+ if (! $this->hasPages()) {
+ return ['first' => null, 'slider' => null, 'last' => null];
+ }
+
+ // If the current page is very close to the beginning of the page range, we will
+ // just render the beginning of the page range, followed by the last 2 of the
+ // links in this list, since we will not have room to create a full slider.
+ if ($this->currentPage() <= $window) {
+ return $this->getSliderTooCloseToBeginning($window);
+ }
+
+ // If the current page is close to the ending of the page range we will just get
+ // this first couple pages, followed by a larger window of these ending pages
+ // since we're too close to the end of the list to create a full on slider.
+ elseif ($this->currentPage() > ($this->lastPage() - $window)) {
+ return $this->getSliderTooCloseToEnding($window);
+ }
+
+ // If we have enough room on both sides of the current page to build a slider we
+ // will surround it with both the beginning and ending caps, with this window
+ // of pages in the middle providing a Google style sliding paginator setup.
+ return $this->getFullSlider($onEachSide);
+ }
+
+ /**
+ * Get the slider of URLs when too close to beginning of window.
+ *
+ * @param int $window
+ * @return array
+ */
+ protected function getSliderTooCloseToBeginning($window)
+ {
+ return [
+ 'first' => $this->paginator->getUrlRange(1, $window + 2),
+ 'slider' => null,
+ 'last' => $this->getFinish(),
+ ];
+ }
+
+ /**
+ * Get the slider of URLs when too close to ending of window.
+ *
+ * @param int $window
+ * @return array
+ */
+ protected function getSliderTooCloseToEnding($window)
+ {
+ $last = $this->paginator->getUrlRange(
+ $this->lastPage() - ($window + 2),
+ $this->lastPage()
+ );
+
+ return [
+ 'first' => $this->getStart(),
+ 'slider' => null,
+ 'last' => $last,
+ ];
+ }
+
+ /**
+ * Get the slider of URLs when a full slider can be made.
+ *
+ * @param int $onEachSide
+ * @return array
+ */
+ protected function getFullSlider($onEachSide)
+ {
+ return [
+ 'first' => $this->getStart(),
+ 'slider' => $this->getAdjacentUrlRange($onEachSide),
+ 'last' => $this->getFinish(),
+ ];
+ }
+
+ /**
+ * Get the page range for the current page window.
+ *
+ * @param int $onEachSide
+ * @return array
+ */
+ public function getAdjacentUrlRange($onEachSide)
+ {
+ return $this->paginator->getUrlRange(
+ $this->currentPage() - $onEachSide,
+ $this->currentPage() + $onEachSide
+ );
+ }
+
+ /**
+ * Get the starting URLs of a pagination slider.
+ *
+ * @return array
+ */
+ public function getStart()
+ {
+ return $this->paginator->getUrlRange(1, 2);
+ }
+
+ /**
+ * Get the ending URLs of a pagination slider.
+ *
+ * @return array
+ */
+ public function getFinish()
+ {
+ return $this->paginator->getUrlRange(
+ $this->lastPage() - 1,
+ $this->lastPage()
+ );
+ }
+
+ /**
+ * Determine if the underlying paginator being presented has pages to show.
+ *
+ * @return bool
+ */
+ public function hasPages()
+ {
+ return $this->paginator->lastPage() > 1;
+ }
+
+ /**
+ * Get the current page from the paginator.
+ *
+ * @return int
+ */
+ protected function currentPage()
+ {
+ return $this->paginator->currentPage();
+ }
+
+ /**
+ * Get the last page from the paginator.
+ *
+ * @return int
+ */
+ protected function lastPage()
+ {
+ return $this->paginator->lastPage();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Pagination/composer.json b/vendor/laravel/framework/src/Illuminate/Pagination/composer.json
new file mode 100644
index 000000000..09563f60b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pagination/composer.json
@@ -0,0 +1,35 @@
+{
+ "name": "illuminate/pagination",
+ "description": "The Illuminate Pagination package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Pagination\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/bootstrap-4.blade.php b/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/bootstrap-4.blade.php
new file mode 100644
index 000000000..3f984557b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/bootstrap-4.blade.php
@@ -0,0 +1,36 @@
+@if ($paginator->hasPages())
+
+@endif
diff --git a/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/default.blade.php b/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/default.blade.php
new file mode 100644
index 000000000..4e795ff41
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/default.blade.php
@@ -0,0 +1,36 @@
+@if ($paginator->hasPages())
+
+@endif
diff --git a/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/simple-bootstrap-4.blade.php b/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/simple-bootstrap-4.blade.php
new file mode 100644
index 000000000..a9a18d32a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/simple-bootstrap-4.blade.php
@@ -0,0 +1,17 @@
+@if ($paginator->hasPages())
+
+@endif
diff --git a/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/simple-default.blade.php b/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/simple-default.blade.php
new file mode 100644
index 000000000..18016092d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pagination/resources/views/simple-default.blade.php
@@ -0,0 +1,17 @@
+@if ($paginator->hasPages())
+
+@endif
diff --git a/vendor/laravel/framework/src/Illuminate/Pipeline/Hub.php b/vendor/laravel/framework/src/Illuminate/Pipeline/Hub.php
new file mode 100644
index 000000000..87331a57b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pipeline/Hub.php
@@ -0,0 +1,74 @@
+container = $container;
+ }
+
+ /**
+ * Define the default named pipeline.
+ *
+ * @param \Closure $callback
+ * @return void
+ */
+ public function defaults(Closure $callback)
+ {
+ return $this->pipeline('default', $callback);
+ }
+
+ /**
+ * Define a new named pipeline.
+ *
+ * @param string $name
+ * @param \Closure $callback
+ * @return void
+ */
+ public function pipeline($name, Closure $callback)
+ {
+ $this->pipelines[$name] = $callback;
+ }
+
+ /**
+ * Send an object through one of the available pipelines.
+ *
+ * @param mixed $object
+ * @param string|null $pipeline
+ * @return mixed
+ */
+ public function pipe($object, $pipeline = null)
+ {
+ $pipeline = $pipeline ?: 'default';
+
+ return call_user_func(
+ $this->pipelines[$pipeline], new Pipeline($this->container), $object
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Pipeline/Pipeline.php b/vendor/laravel/framework/src/Illuminate/Pipeline/Pipeline.php
new file mode 100644
index 000000000..4a481fea4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pipeline/Pipeline.php
@@ -0,0 +1,184 @@
+container = $container;
+ }
+
+ /**
+ * Set the object being sent through the pipeline.
+ *
+ * @param mixed $passable
+ * @return $this
+ */
+ public function send($passable)
+ {
+ $this->passable = $passable;
+
+ return $this;
+ }
+
+ /**
+ * Set the array of pipes.
+ *
+ * @param array|mixed $pipes
+ * @return $this
+ */
+ public function through($pipes)
+ {
+ $this->pipes = is_array($pipes) ? $pipes : func_get_args();
+
+ return $this;
+ }
+
+ /**
+ * Set the method to call on the pipes.
+ *
+ * @param string $method
+ * @return $this
+ */
+ public function via($method)
+ {
+ $this->method = $method;
+
+ return $this;
+ }
+
+ /**
+ * Run the pipeline with a final destination callback.
+ *
+ * @param \Closure $destination
+ * @return mixed
+ */
+ public function then(Closure $destination)
+ {
+ $pipeline = array_reduce(
+ array_reverse($this->pipes), $this->carry(), $this->prepareDestination($destination)
+ );
+
+ return $pipeline($this->passable);
+ }
+
+ /**
+ * Get the final piece of the Closure onion.
+ *
+ * @param \Closure $destination
+ * @return \Closure
+ */
+ protected function prepareDestination(Closure $destination)
+ {
+ return function ($passable) use ($destination) {
+ return $destination($passable);
+ };
+ }
+
+ /**
+ * Get a Closure that represents a slice of the application onion.
+ *
+ * @return \Closure
+ */
+ protected function carry()
+ {
+ return function ($stack, $pipe) {
+ return function ($passable) use ($stack, $pipe) {
+ if ($pipe instanceof Closure) {
+ // If the pipe is an instance of a Closure, we will just call it directly but
+ // otherwise we'll resolve the pipes out of the container and call it with
+ // the appropriate method and arguments, returning the results back out.
+ return $pipe($passable, $stack);
+ } elseif (! is_object($pipe)) {
+ list($name, $parameters) = $this->parsePipeString($pipe);
+
+ // If the pipe is a string we will parse the string and resolve the class out
+ // of the dependency injection container. We can then build a callable and
+ // execute the pipe function giving in the parameters that are required.
+ $pipe = $this->getContainer()->make($name);
+
+ $parameters = array_merge([$passable, $stack], $parameters);
+ } else {
+ // If the pipe is already an object we'll just make a callable and pass it to
+ // the pipe as-is. There is no need to do any extra parsing and formatting
+ // since the object we're given was already a fully instantiated object.
+ $parameters = [$passable, $stack];
+ }
+
+ return $pipe->{$this->method}(...$parameters);
+ };
+ };
+ }
+
+ /**
+ * Parse full pipe string to get name and parameters.
+ *
+ * @param string $pipe
+ * @return array
+ */
+ protected function parsePipeString($pipe)
+ {
+ list($name, $parameters) = array_pad(explode(':', $pipe, 2), 2, []);
+
+ if (is_string($parameters)) {
+ $parameters = explode(',', $parameters);
+ }
+
+ return [$name, $parameters];
+ }
+
+ /**
+ * Get the container instance.
+ *
+ * @return \Illuminate\Contracts\Container\Container
+ * @throws \RuntimeException
+ */
+ protected function getContainer()
+ {
+ if (! $this->container) {
+ throw new RuntimeException('A container instance has not been passed to the Pipeline.');
+ }
+
+ return $this->container;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Pipeline/PipelineServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Pipeline/PipelineServiceProvider.php
new file mode 100644
index 000000000..d82918734
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pipeline/PipelineServiceProvider.php
@@ -0,0 +1,40 @@
+app->singleton(
+ PipelineHubContract::class, Hub::class
+ );
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return [
+ PipelineHubContract::class,
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Pipeline/composer.json b/vendor/laravel/framework/src/Illuminate/Pipeline/composer.json
new file mode 100644
index 000000000..c6efbd556
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Pipeline/composer.json
@@ -0,0 +1,35 @@
+{
+ "name": "illuminate/pipeline",
+ "description": "The Illuminate Pipeline package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Pipeline\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/BeanstalkdQueue.php b/vendor/laravel/framework/src/Illuminate/Queue/BeanstalkdQueue.php
new file mode 100644
index 000000000..54e8e42a4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/BeanstalkdQueue.php
@@ -0,0 +1,163 @@
+default = $default;
+ $this->timeToRun = $timeToRun;
+ $this->pheanstalk = $pheanstalk;
+ }
+
+ /**
+ * Get the size of the queue.
+ *
+ * @param string $queue
+ * @return int
+ */
+ public function size($queue = null)
+ {
+ $queue = $this->getQueue($queue);
+
+ return (int) $this->pheanstalk->statsTube($queue)->current_jobs_ready;
+ }
+
+ /**
+ * Push a new job onto the queue.
+ *
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function push($job, $data = '', $queue = null)
+ {
+ return $this->pushRaw($this->createPayload($job, $data), $queue);
+ }
+
+ /**
+ * Push a raw payload onto the queue.
+ *
+ * @param string $payload
+ * @param string $queue
+ * @param array $options
+ * @return mixed
+ */
+ public function pushRaw($payload, $queue = null, array $options = [])
+ {
+ return $this->pheanstalk->useTube($this->getQueue($queue))->put(
+ $payload, Pheanstalk::DEFAULT_PRIORITY, Pheanstalk::DEFAULT_DELAY, $this->timeToRun
+ );
+ }
+
+ /**
+ * Push a new job onto the queue after a delay.
+ *
+ * @param \DateTime|int $delay
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function later($delay, $job, $data = '', $queue = null)
+ {
+ $pheanstalk = $this->pheanstalk->useTube($this->getQueue($queue));
+
+ return $pheanstalk->put(
+ $this->createPayload($job, $data),
+ Pheanstalk::DEFAULT_PRIORITY,
+ $this->secondsUntil($delay),
+ $this->timeToRun
+ );
+ }
+
+ /**
+ * Pop the next job off of the queue.
+ *
+ * @param string $queue
+ * @return \Illuminate\Contracts\Queue\Job|null
+ */
+ public function pop($queue = null)
+ {
+ $queue = $this->getQueue($queue);
+
+ $job = $this->pheanstalk->watchOnly($queue)->reserve(0);
+
+ if ($job instanceof PheanstalkJob) {
+ return new BeanstalkdJob(
+ $this->container, $this->pheanstalk, $job, $this->connectionName, $queue
+ );
+ }
+ }
+
+ /**
+ * Delete a message from the Beanstalk queue.
+ *
+ * @param string $queue
+ * @param string $id
+ * @return void
+ */
+ public function deleteMessage($queue, $id)
+ {
+ $queue = $this->getQueue($queue);
+
+ $this->pheanstalk->useTube($queue)->delete(new PheanstalkJob($id, ''));
+ }
+
+ /**
+ * Get the queue or return the default.
+ *
+ * @param string|null $queue
+ * @return string
+ */
+ public function getQueue($queue)
+ {
+ return $queue ?: $this->default;
+ }
+
+ /**
+ * Get the underlying Pheanstalk instance.
+ *
+ * @return \Pheanstalk\Pheanstalk
+ */
+ public function getPheanstalk()
+ {
+ return $this->pheanstalk;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/CallQueuedHandler.php b/vendor/laravel/framework/src/Illuminate/Queue/CallQueuedHandler.php
new file mode 100644
index 000000000..ebfb48b6f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/CallQueuedHandler.php
@@ -0,0 +1,101 @@
+dispatcher = $dispatcher;
+ }
+
+ /**
+ * Handle the queued job.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param array $data
+ * @return void
+ */
+ public function call(Job $job, array $data)
+ {
+ $command = $this->setJobInstanceIfNecessary(
+ $job, unserialize($data['command'])
+ );
+
+ $this->dispatcher->dispatchNow(
+ $command, $handler = $this->resolveHandler($job, $command)
+ );
+
+ if (! $job->isDeletedOrReleased()) {
+ $job->delete();
+ }
+ }
+
+ /**
+ * Resolve the handler for the given command.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param mixed $command
+ * @return mixed
+ */
+ protected function resolveHandler($job, $command)
+ {
+ $handler = $this->dispatcher->getCommandHandler($command) ?: null;
+
+ if ($handler) {
+ $this->setJobInstanceIfNecessary($job, $handler);
+ }
+
+ return $handler;
+ }
+
+ /**
+ * Set the job instance of the given class if necessary.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param mixed $instance
+ * @return mixed
+ */
+ protected function setJobInstanceIfNecessary(Job $job, $instance)
+ {
+ if (in_array(InteractsWithQueue::class, class_uses_recursive(get_class($instance)))) {
+ $instance->setJob($job);
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Call the failed method on the job instance.
+ *
+ * The exception that caused the failure will be passed.
+ *
+ * @param array $data
+ * @param \Exception $e
+ * @return void
+ */
+ public function failed(array $data, $e)
+ {
+ $command = unserialize($data['command']);
+
+ if (method_exists($command, 'failed')) {
+ $command->failed($e);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Capsule/Manager.php b/vendor/laravel/framework/src/Illuminate/Queue/Capsule/Manager.php
new file mode 100644
index 000000000..b611812fb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Capsule/Manager.php
@@ -0,0 +1,187 @@
+setupContainer($container ?: new Container);
+
+ // Once we have the container setup, we will setup the default configuration
+ // options in the container "config" bindings. This just makes this queue
+ // manager behave correctly since all the correct binding are in place.
+ $this->setupDefaultConfiguration();
+
+ $this->setupManager();
+
+ $this->registerConnectors();
+ }
+
+ /**
+ * Setup the default queue configuration options.
+ *
+ * @return void
+ */
+ protected function setupDefaultConfiguration()
+ {
+ $this->container['config']['queue.default'] = 'default';
+ }
+
+ /**
+ * Build the queue manager instance.
+ *
+ * @return void
+ */
+ protected function setupManager()
+ {
+ $this->manager = new QueueManager($this->container);
+ }
+
+ /**
+ * Register the default connectors that the component ships with.
+ *
+ * @return void
+ */
+ protected function registerConnectors()
+ {
+ $provider = new QueueServiceProvider($this->container);
+
+ $provider->registerConnectors($this->manager);
+ }
+
+ /**
+ * Get a connection instance from the global manager.
+ *
+ * @param string $connection
+ * @return \Illuminate\Contracts\Queue\Queue
+ */
+ public static function connection($connection = null)
+ {
+ return static::$instance->getConnection($connection);
+ }
+
+ /**
+ * Push a new job onto the queue.
+ *
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @param string $connection
+ * @return mixed
+ */
+ public static function push($job, $data = '', $queue = null, $connection = null)
+ {
+ return static::$instance->connection($connection)->push($job, $data, $queue);
+ }
+
+ /**
+ * Push a new an array of jobs onto the queue.
+ *
+ * @param array $jobs
+ * @param mixed $data
+ * @param string $queue
+ * @param string $connection
+ * @return mixed
+ */
+ public static function bulk($jobs, $data = '', $queue = null, $connection = null)
+ {
+ return static::$instance->connection($connection)->bulk($jobs, $data, $queue);
+ }
+
+ /**
+ * Push a new job onto the queue after a delay.
+ *
+ * @param \DateTime|int $delay
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @param string $connection
+ * @return mixed
+ */
+ public static function later($delay, $job, $data = '', $queue = null, $connection = null)
+ {
+ return static::$instance->connection($connection)->later($delay, $job, $data, $queue);
+ }
+
+ /**
+ * Get a registered connection instance.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Queue\Queue
+ */
+ public function getConnection($name = null)
+ {
+ return $this->manager->connection($name);
+ }
+
+ /**
+ * Register a connection with the manager.
+ *
+ * @param array $config
+ * @param string $name
+ * @return void
+ */
+ public function addConnection(array $config, $name = 'default')
+ {
+ $this->container['config']["queue.connections.{$name}"] = $config;
+ }
+
+ /**
+ * Get the queue manager instance.
+ *
+ * @return \Illuminate\Queue\QueueManager
+ */
+ public function getQueueManager()
+ {
+ return $this->manager;
+ }
+
+ /**
+ * Pass dynamic instance methods to the manager.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->manager->$method(...$parameters);
+ }
+
+ /**
+ * Dynamically pass methods to the default connection.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public static function __callStatic($method, $parameters)
+ {
+ return static::connection()->$method(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Connectors/BeanstalkdConnector.php b/vendor/laravel/framework/src/Illuminate/Queue/Connectors/BeanstalkdConnector.php
new file mode 100644
index 000000000..33840a7b0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Connectors/BeanstalkdConnector.php
@@ -0,0 +1,41 @@
+pheanstalk($config), $config['queue'], $retryAfter);
+ }
+
+ /**
+ * Create a Pheanstalk instance.
+ *
+ * @param array $config
+ * @return \Pheanstalk\Pheanstalk
+ */
+ protected function pheanstalk(array $config)
+ {
+ return new Pheanstalk(
+ $config['host'],
+ Arr::get($config, 'port', PheanstalkInterface::DEFAULT_PORT),
+ Arr::get($config, 'timeout', Connection::DEFAULT_CONNECT_TIMEOUT),
+ Arr::get($config, 'persistent', false)
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Connectors/ConnectorInterface.php b/vendor/laravel/framework/src/Illuminate/Queue/Connectors/ConnectorInterface.php
new file mode 100644
index 000000000..617bf09d6
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Connectors/ConnectorInterface.php
@@ -0,0 +1,14 @@
+connections = $connections;
+ }
+
+ /**
+ * Establish a queue connection.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Queue\Queue
+ */
+ public function connect(array $config)
+ {
+ return new DatabaseQueue(
+ $this->connections->connection(Arr::get($config, 'connection')),
+ $config['table'],
+ $config['queue'],
+ Arr::get($config, 'retry_after', 60)
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Connectors/NullConnector.php b/vendor/laravel/framework/src/Illuminate/Queue/Connectors/NullConnector.php
new file mode 100644
index 000000000..39de4800c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Connectors/NullConnector.php
@@ -0,0 +1,19 @@
+redis = $redis;
+ $this->connection = $connection;
+ }
+
+ /**
+ * Establish a queue connection.
+ *
+ * @param array $config
+ * @return \Illuminate\Contracts\Queue\Queue
+ */
+ public function connect(array $config)
+ {
+ return new RedisQueue(
+ $this->redis, $config['queue'],
+ Arr::get($config, 'connection', $this->connection),
+ Arr::get($config, 'retry_after', 60)
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Connectors/SqsConnector.php b/vendor/laravel/framework/src/Illuminate/Queue/Connectors/SqsConnector.php
new file mode 100644
index 000000000..4e8e5e654
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Connectors/SqsConnector.php
@@ -0,0 +1,46 @@
+getDefaultConfiguration($config);
+
+ if ($config['key'] && $config['secret']) {
+ $config['credentials'] = Arr::only($config, ['key', 'secret']);
+ }
+
+ return new SqsQueue(
+ new SqsClient($config), $config['queue'], Arr::get($config, 'prefix', '')
+ );
+ }
+
+ /**
+ * Get the default configuration for SQS.
+ *
+ * @param array $config
+ * @return array
+ */
+ protected function getDefaultConfiguration(array $config)
+ {
+ return array_merge([
+ 'version' => 'latest',
+ 'http' => [
+ 'timeout' => 60,
+ 'connect_timeout' => 60,
+ ],
+ ], $config);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Connectors/SyncConnector.php b/vendor/laravel/framework/src/Illuminate/Queue/Connectors/SyncConnector.php
new file mode 100644
index 000000000..4269b8039
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Connectors/SyncConnector.php
@@ -0,0 +1,19 @@
+files = $files;
+ $this->composer = $composer;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $table = $this->laravel['config']['queue.failed.table'];
+
+ $this->replaceMigration(
+ $this->createBaseMigration($table), $table, Str::studly($table)
+ );
+
+ $this->info('Migration created successfully!');
+
+ $this->composer->dumpAutoloads();
+ }
+
+ /**
+ * Create a base migration file for the table.
+ *
+ * @param string $table
+ * @return string
+ */
+ protected function createBaseMigration($table = 'failed_jobs')
+ {
+ return $this->laravel['migration.creator']->create(
+ 'create_'.$table.'_table', $this->laravel->databasePath().'/migrations'
+ );
+ }
+
+ /**
+ * Replace the generated migration with the failed job table stub.
+ *
+ * @param string $path
+ * @param string $table
+ * @param string $tableClassName
+ * @return void
+ */
+ protected function replaceMigration($path, $table, $tableClassName)
+ {
+ $stub = str_replace(
+ ['{{table}}', '{{tableClassName}}'],
+ [$table, $tableClassName],
+ $this->files->get(__DIR__.'/stubs/failed_jobs.stub')
+ );
+
+ $this->files->put($path, $stub);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Console/FlushFailedCommand.php b/vendor/laravel/framework/src/Illuminate/Queue/Console/FlushFailedCommand.php
new file mode 100644
index 000000000..fc210931b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Console/FlushFailedCommand.php
@@ -0,0 +1,34 @@
+laravel['queue.failer']->flush();
+
+ $this->info('All failed jobs deleted successfully!');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Console/ForgetFailedCommand.php b/vendor/laravel/framework/src/Illuminate/Queue/Console/ForgetFailedCommand.php
new file mode 100644
index 000000000..2a016cf5c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Console/ForgetFailedCommand.php
@@ -0,0 +1,49 @@
+laravel['queue.failer']->forget($this->argument('id'))) {
+ $this->info('Failed job deleted successfully!');
+ } else {
+ $this->error('No failed job matches the given ID.');
+ }
+ }
+
+ /**
+ * Get the console command arguments.
+ *
+ * @return array
+ */
+ protected function getArguments()
+ {
+ return [
+ ['id', InputArgument::REQUIRED, 'The ID of the failed job'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Console/ListFailedCommand.php b/vendor/laravel/framework/src/Illuminate/Queue/Console/ListFailedCommand.php
new file mode 100644
index 000000000..0b061f46a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Console/ListFailedCommand.php
@@ -0,0 +1,118 @@
+getFailedJobs()) == 0) {
+ return $this->info('No failed jobs!');
+ }
+
+ $this->displayFailedJobs($jobs);
+ }
+
+ /**
+ * Compile the failed jobs into a displayable format.
+ *
+ * @return array
+ */
+ protected function getFailedJobs()
+ {
+ $failed = $this->laravel['queue.failer']->all();
+
+ return collect($failed)->map(function ($failed) {
+ return $this->parseFailedJob((array) $failed);
+ })->filter()->all();
+ }
+
+ /**
+ * Parse the failed job row.
+ *
+ * @param array $failed
+ * @return array
+ */
+ protected function parseFailedJob(array $failed)
+ {
+ $row = array_values(Arr::except($failed, ['payload', 'exception']));
+
+ array_splice($row, 3, 0, $this->extractJobName($failed['payload']));
+
+ return $row;
+ }
+
+ /**
+ * Extract the failed job name from payload.
+ *
+ * @param string $payload
+ * @return string|null
+ */
+ private function extractJobName($payload)
+ {
+ $payload = json_decode($payload, true);
+
+ if ($payload && (! isset($payload['data']['command']))) {
+ return Arr::get($payload, 'job');
+ } elseif ($payload && isset($payload['data']['command'])) {
+ return $this->matchJobName($payload);
+ }
+ }
+
+ /**
+ * Match the job name from the payload.
+ *
+ * @param array $payload
+ * @return string
+ */
+ protected function matchJobName($payload)
+ {
+ preg_match('/"([^"]+)"/', $payload['data']['command'], $matches);
+
+ if (isset($matches[1])) {
+ return $matches[1];
+ } else {
+ return Arr::get($payload, 'job');
+ }
+ }
+
+ /**
+ * Display the failed jobs in the console.
+ *
+ * @param array $jobs
+ * @return void
+ */
+ protected function displayFailedJobs(array $jobs)
+ {
+ $this->table($this->headers, $jobs);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Console/ListenCommand.php b/vendor/laravel/framework/src/Illuminate/Queue/Console/ListenCommand.php
new file mode 100644
index 000000000..11f4ab459
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Console/ListenCommand.php
@@ -0,0 +1,114 @@
+setOutputHandler($this->listener = $listener);
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ // We need to get the right queue for the connection which is set in the queue
+ // configuration file for the application. We will pull it based on the set
+ // connection being run for the queue operation currently being executed.
+ $queue = $this->getQueue(
+ $connection = $this->input->getArgument('connection')
+ );
+
+ $this->listener->listen(
+ $connection, $queue, $this->gatherOptions()
+ );
+ }
+
+ /**
+ * Get the name of the queue connection to listen on.
+ *
+ * @param string $connection
+ * @return string
+ */
+ protected function getQueue($connection)
+ {
+ $connection = $connection ?: $this->laravel['config']['queue.default'];
+
+ return $this->input->getOption('queue') ?: $this->laravel['config']->get(
+ "queue.connections.{$connection}.queue", 'default'
+ );
+ }
+
+ /**
+ * Get the listener options for the command.
+ *
+ * @return \Illuminate\Queue\ListenerOptions
+ */
+ protected function gatherOptions()
+ {
+ return new ListenerOptions(
+ $this->option('env'), $this->option('delay'),
+ $this->option('memory'), $this->option('timeout'),
+ $this->option('sleep'), $this->option('tries'),
+ $this->option('force')
+ );
+ }
+
+ /**
+ * Set the options on the queue listener.
+ *
+ * @param \Illuminate\Queue\Listener $listener
+ * @return void
+ */
+ protected function setOutputHandler(Listener $listener)
+ {
+ $listener->setOutputHandler(function ($type, $line) {
+ $this->output->write($line);
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Console/RestartCommand.php b/vendor/laravel/framework/src/Illuminate/Queue/Console/RestartCommand.php
new file mode 100644
index 000000000..4d9b58781
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Console/RestartCommand.php
@@ -0,0 +1,35 @@
+laravel['cache']->forever('illuminate:queue:restart', Carbon::now()->getTimestamp());
+
+ $this->info('Broadcasting queue restart signal.');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Console/RetryCommand.php b/vendor/laravel/framework/src/Illuminate/Queue/Console/RetryCommand.php
new file mode 100644
index 000000000..df8271725
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Console/RetryCommand.php
@@ -0,0 +1,106 @@
+getJobIds() as $id) {
+ $job = $this->laravel['queue.failer']->find($id);
+
+ if (is_null($job)) {
+ $this->error("Unable to find failed job with ID [{$id}].");
+ } else {
+ $this->retryJob($job);
+
+ $this->info("The failed job [{$id}] has been pushed back onto the queue!");
+
+ $this->laravel['queue.failer']->forget($id);
+ }
+ }
+ }
+
+ /**
+ * Get the job IDs to be retried.
+ *
+ * @return array
+ */
+ protected function getJobIds()
+ {
+ $ids = $this->argument('id');
+
+ if (count($ids) === 1 && $ids[0] === 'all') {
+ $ids = Arr::pluck($this->laravel['queue.failer']->all(), 'id');
+ }
+
+ return $ids;
+ }
+
+ /**
+ * Retry the queue job.
+ *
+ * @param \stdClass $job
+ * @return void
+ */
+ protected function retryJob($job)
+ {
+ $this->laravel['queue']->connection($job->connection)->pushRaw(
+ $this->resetAttempts($job->payload), $job->queue
+ );
+ }
+
+ /**
+ * Reset the payload attempts.
+ *
+ * Applicable to Redis jobs which store attempts in their payload.
+ *
+ * @param string $payload
+ * @return string
+ */
+ protected function resetAttempts($payload)
+ {
+ $payload = json_decode($payload, true);
+
+ if (isset($payload['attempts'])) {
+ $payload['attempts'] = 0;
+ }
+
+ return json_encode($payload);
+ }
+
+ /**
+ * Get the console command arguments.
+ *
+ * @return array
+ */
+ protected function getArguments()
+ {
+ return [
+ ['id', InputArgument::IS_ARRAY, 'The ID of the failed job'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Console/TableCommand.php b/vendor/laravel/framework/src/Illuminate/Queue/Console/TableCommand.php
new file mode 100644
index 000000000..e0d203001
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Console/TableCommand.php
@@ -0,0 +1,102 @@
+files = $files;
+ $this->composer = $composer;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $table = $this->laravel['config']['queue.connections.database.table'];
+
+ $this->replaceMigration(
+ $this->createBaseMigration($table), $table, Str::studly($table)
+ );
+
+ $this->info('Migration created successfully!');
+
+ $this->composer->dumpAutoloads();
+ }
+
+ /**
+ * Create a base migration file for the table.
+ *
+ * @param string $table
+ * @return string
+ */
+ protected function createBaseMigration($table = 'jobs')
+ {
+ return $this->laravel['migration.creator']->create(
+ 'create_'.$table.'_table', $this->laravel->databasePath().'/migrations'
+ );
+ }
+
+ /**
+ * Replace the generated migration with the job table stub.
+ *
+ * @param string $path
+ * @param string $table
+ * @param string $tableClassName
+ * @return void
+ */
+ protected function replaceMigration($path, $table, $tableClassName)
+ {
+ $stub = str_replace(
+ ['{{table}}', '{{tableClassName}}'],
+ [$table, $tableClassName],
+ $this->files->get(__DIR__.'/stubs/jobs.stub')
+ );
+
+ $this->files->put($path, $stub);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Console/WorkCommand.php b/vendor/laravel/framework/src/Illuminate/Queue/Console/WorkCommand.php
new file mode 100644
index 000000000..8b38ac535
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Console/WorkCommand.php
@@ -0,0 +1,213 @@
+worker = $worker;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ if ($this->downForMaintenance() && $this->option('once')) {
+ return $this->worker->sleep($this->option('sleep'));
+ }
+
+ // We'll listen to the processed and failed events so we can write information
+ // to the console as jobs are processed, which will let the developer watch
+ // which jobs are coming through a queue and be informed on its progress.
+ $this->listenForEvents();
+
+ $connection = $this->argument('connection')
+ ?: $this->laravel['config']['queue.default'];
+
+ // We need to get the right queue for the connection which is set in the queue
+ // configuration file for the application. We will pull it based on the set
+ // connection being run for the queue operation currently being executed.
+ $queue = $this->getQueue($connection);
+
+ $this->runWorker(
+ $connection, $queue
+ );
+ }
+
+ /**
+ * Run the worker instance.
+ *
+ * @param string $connection
+ * @param string $queue
+ * @return array
+ */
+ protected function runWorker($connection, $queue)
+ {
+ $this->worker->setCache($this->laravel['cache']->driver());
+
+ return $this->worker->{$this->option('once') ? 'runNextJob' : 'daemon'}(
+ $connection, $queue, $this->gatherWorkerOptions()
+ );
+ }
+
+ /**
+ * Gather all of the queue worker options as a single object.
+ *
+ * @return \Illuminate\Queue\WorkerOptions
+ */
+ protected function gatherWorkerOptions()
+ {
+ return new WorkerOptions(
+ $this->option('delay'), $this->option('memory'),
+ $this->option('timeout'), $this->option('sleep'),
+ $this->option('tries'), $this->option('force')
+ );
+ }
+
+ /**
+ * Listen for the queue events in order to update the console output.
+ *
+ * @return void
+ */
+ protected function listenForEvents()
+ {
+ $this->laravel['events']->listen(JobProcessing::class, function ($event) {
+ $this->writeOutput($event->job, 'starting');
+ });
+
+ $this->laravel['events']->listen(JobProcessed::class, function ($event) {
+ $this->writeOutput($event->job, 'success');
+ });
+
+ $this->laravel['events']->listen(JobFailed::class, function ($event) {
+ $this->writeOutput($event->job, 'failed');
+
+ $this->logFailedJob($event);
+ });
+ }
+
+ /**
+ * Write the status output for the queue worker.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param string $status
+ * @return void
+ */
+ protected function writeOutput(Job $job, $status)
+ {
+ switch ($status) {
+ case 'starting':
+ return $this->writeStatus($job, 'Processing', 'comment');
+ case 'success':
+ return $this->writeStatus($job, 'Processed', 'info');
+ case 'failed':
+ return $this->writeStatus($job, 'Failed', 'error');
+ }
+ }
+
+ /**
+ * Format the status output for the queue worker.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param string $status
+ * @param string $type
+ * @return void
+ */
+ protected function writeStatus(Job $job, $status, $type)
+ {
+ $this->output->writeln(sprintf(
+ "<{$type}>[%s] %s{$type}> %s",
+ Carbon::now()->format('Y-m-d H:i:s'),
+ str_pad("{$status}:", 11), $job->resolveName()
+ ));
+ }
+
+ /**
+ * Store a failed job event.
+ *
+ * @param JobFailed $event
+ * @return void
+ */
+ protected function logFailedJob(JobFailed $event)
+ {
+ $this->laravel['queue.failer']->log(
+ $event->connectionName, $event->job->getQueue(),
+ $event->job->getRawBody(), $event->exception
+ );
+ }
+
+ /**
+ * Get the queue name for the worker.
+ *
+ * @param string $connection
+ * @return string
+ */
+ protected function getQueue($connection)
+ {
+ return $this->option('queue') ?: $this->laravel['config']->get(
+ "queue.connections.{$connection}.queue", 'default'
+ );
+ }
+
+ /**
+ * Determine if the worker should run in maintenance mode.
+ *
+ * @return bool
+ */
+ protected function downForMaintenance()
+ {
+ return $this->option('force') ? false : $this->laravel->isDownForMaintenance();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Console/stubs/failed_jobs.stub b/vendor/laravel/framework/src/Illuminate/Queue/Console/stubs/failed_jobs.stub
new file mode 100644
index 000000000..037b5ee23
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Console/stubs/failed_jobs.stub
@@ -0,0 +1,35 @@
+bigIncrements('id');
+ $table->text('connection');
+ $table->text('queue');
+ $table->longText('payload');
+ $table->longText('exception');
+ $table->timestamp('failed_at')->useCurrent();
+ });
+ }
+
+ /**
+ * Reverse the migrations.
+ *
+ * @return void
+ */
+ public function down()
+ {
+ Schema::dropIfExists('{{table}}');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Console/stubs/jobs.stub b/vendor/laravel/framework/src/Illuminate/Queue/Console/stubs/jobs.stub
new file mode 100644
index 000000000..8d9265d5f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Console/stubs/jobs.stub
@@ -0,0 +1,38 @@
+bigIncrements('id');
+ $table->string('queue');
+ $table->longText('payload');
+ $table->unsignedTinyInteger('attempts');
+ $table->unsignedInteger('reserved_at')->nullable();
+ $table->unsignedInteger('available_at');
+ $table->unsignedInteger('created_at');
+
+ $table->index(['queue', 'reserved_at']);
+ });
+ }
+
+ /**
+ * Reverse the migrations.
+ *
+ * @return void
+ */
+ public function down()
+ {
+ Schema::dropIfExists('{{table}}');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/DatabaseQueue.php b/vendor/laravel/framework/src/Illuminate/Queue/DatabaseQueue.php
new file mode 100644
index 000000000..51a30a7df
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/DatabaseQueue.php
@@ -0,0 +1,323 @@
+table = $table;
+ $this->default = $default;
+ $this->database = $database;
+ $this->retryAfter = $retryAfter;
+ }
+
+ /**
+ * Get the size of the queue.
+ *
+ * @param string $queue
+ * @return int
+ */
+ public function size($queue = null)
+ {
+ return $this->database->table($this->table)
+ ->where('queue', $this->getQueue($queue))
+ ->count();
+ }
+
+ /**
+ * Push a new job onto the queue.
+ *
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function push($job, $data = '', $queue = null)
+ {
+ return $this->pushToDatabase($queue, $this->createPayload($job, $data));
+ }
+
+ /**
+ * Push a raw payload onto the queue.
+ *
+ * @param string $payload
+ * @param string $queue
+ * @param array $options
+ * @return mixed
+ */
+ public function pushRaw($payload, $queue = null, array $options = [])
+ {
+ return $this->pushToDatabase($queue, $payload);
+ }
+
+ /**
+ * Push a new job onto the queue after a delay.
+ *
+ * @param \DateTime|int $delay
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return void
+ */
+ public function later($delay, $job, $data = '', $queue = null)
+ {
+ return $this->pushToDatabase($queue, $this->createPayload($job, $data), $delay);
+ }
+
+ /**
+ * Push an array of jobs onto the queue.
+ *
+ * @param array $jobs
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function bulk($jobs, $data = '', $queue = null)
+ {
+ $queue = $this->getQueue($queue);
+
+ $availableAt = $this->availableAt();
+
+ return $this->database->table($this->table)->insert(collect((array) $jobs)->map(
+ function ($job) use ($queue, $data, $availableAt) {
+ return $this->buildDatabaseRecord($queue, $this->createPayload($job, $data), $availableAt);
+ }
+ )->all());
+ }
+
+ /**
+ * Release a reserved job back onto the queue.
+ *
+ * @param string $queue
+ * @param \Illuminate\Queue\Jobs\DatabaseJobRecord $job
+ * @param int $delay
+ * @return mixed
+ */
+ public function release($queue, $job, $delay)
+ {
+ return $this->pushToDatabase($queue, $job->payload, $delay, $job->attempts);
+ }
+
+ /**
+ * Push a raw payload to the database with a given delay.
+ *
+ * @param string|null $queue
+ * @param string $payload
+ * @param \DateTime|int $delay
+ * @param int $attempts
+ * @return mixed
+ */
+ protected function pushToDatabase($queue, $payload, $delay = 0, $attempts = 0)
+ {
+ return $this->database->table($this->table)->insertGetId($this->buildDatabaseRecord(
+ $this->getQueue($queue), $payload, $this->availableAt($delay), $attempts
+ ));
+ }
+
+ /**
+ * Create an array to insert for the given job.
+ *
+ * @param string|null $queue
+ * @param string $payload
+ * @param int $availableAt
+ * @param int $attempts
+ * @return array
+ */
+ protected function buildDatabaseRecord($queue, $payload, $availableAt, $attempts = 0)
+ {
+ return [
+ 'queue' => $queue,
+ 'payload' => $payload,
+ 'attempts' => $attempts,
+ 'reserved_at' => null,
+ 'available_at' => $availableAt,
+ 'created_at' => $this->currentTime(),
+ ];
+ }
+
+ /**
+ * Pop the next job off of the queue.
+ *
+ * @param string $queue
+ * @return \Illuminate\Contracts\Queue\Job|null
+ */
+ public function pop($queue = null)
+ {
+ $queue = $this->getQueue($queue);
+
+ $this->database->beginTransaction();
+
+ if ($job = $this->getNextAvailableJob($queue)) {
+ return $this->marshalJob($queue, $job);
+ }
+
+ $this->database->commit();
+ }
+
+ /**
+ * Get the next available job for the queue.
+ *
+ * @param string|null $queue
+ * @return \Illuminate\Queue\Jobs\DatabaseJobRecord|null
+ */
+ protected function getNextAvailableJob($queue)
+ {
+ $job = $this->database->table($this->table)
+ ->lockForUpdate()
+ ->where('queue', $this->getQueue($queue))
+ ->where(function ($query) {
+ $this->isAvailable($query);
+ $this->isReservedButExpired($query);
+ })
+ ->orderBy('id', 'asc')
+ ->first();
+
+ return $job ? new DatabaseJobRecord((object) $job) : null;
+ }
+
+ /**
+ * Modify the query to check for available jobs.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return void
+ */
+ protected function isAvailable($query)
+ {
+ $query->where(function ($query) {
+ $query->whereNull('reserved_at')
+ ->where('available_at', '<=', $this->currentTime());
+ });
+ }
+
+ /**
+ * Modify the query to check for jobs that are reserved but have expired.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @return void
+ */
+ protected function isReservedButExpired($query)
+ {
+ $expiration = Carbon::now()->subSeconds($this->retryAfter)->getTimestamp();
+
+ $query->orWhere(function ($query) use ($expiration) {
+ $query->where('reserved_at', '<=', $expiration);
+ });
+ }
+
+ /**
+ * Marshal the reserved job into a DatabaseJob instance.
+ *
+ * @param string $queue
+ * @param \Illuminate\Queue\Jobs\DatabaseJobRecord $job
+ * @return \Illuminate\Queue\Jobs\DatabaseJob
+ */
+ protected function marshalJob($queue, $job)
+ {
+ $job = $this->markJobAsReserved($job);
+
+ $this->database->commit();
+
+ return new DatabaseJob(
+ $this->container, $this, $job, $this->connectionName, $queue
+ );
+ }
+
+ /**
+ * Mark the given job ID as reserved.
+ *
+ * @param \Illuminate\Queue\Jobs\DatabaseJobRecord $job
+ * @return \Illuminate\Queue\Jobs\DatabaseJobRecord
+ */
+ protected function markJobAsReserved($job)
+ {
+ $this->database->table($this->table)->where('id', $job->id)->update([
+ 'reserved_at' => $job->touch(),
+ 'attempts' => $job->increment(),
+ ]);
+
+ return $job;
+ }
+
+ /**
+ * Delete a reserved job from the queue.
+ *
+ * @param string $queue
+ * @param string $id
+ * @return void
+ */
+ public function deleteReserved($queue, $id)
+ {
+ $this->database->beginTransaction();
+
+ if ($this->database->table($this->table)->lockForUpdate()->find($id)) {
+ $this->database->table($this->table)->where('id', $id)->delete();
+ }
+
+ $this->database->commit();
+ }
+
+ /**
+ * Get the queue or return the default.
+ *
+ * @param string|null $queue
+ * @return string
+ */
+ protected function getQueue($queue)
+ {
+ return $queue ?: $this->default;
+ }
+
+ /**
+ * Get the underlying database instance.
+ *
+ * @return \Illuminate\Database\Connection
+ */
+ public function getDatabase()
+ {
+ return $this->database;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Events/JobExceptionOccurred.php b/vendor/laravel/framework/src/Illuminate/Queue/Events/JobExceptionOccurred.php
new file mode 100644
index 000000000..dc7940e1e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Events/JobExceptionOccurred.php
@@ -0,0 +1,42 @@
+job = $job;
+ $this->exception = $exception;
+ $this->connectionName = $connectionName;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Events/JobFailed.php b/vendor/laravel/framework/src/Illuminate/Queue/Events/JobFailed.php
new file mode 100644
index 000000000..49b84f7be
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Events/JobFailed.php
@@ -0,0 +1,42 @@
+job = $job;
+ $this->exception = $exception;
+ $this->connectionName = $connectionName;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Events/JobProcessed.php b/vendor/laravel/framework/src/Illuminate/Queue/Events/JobProcessed.php
new file mode 100644
index 000000000..f8abefb67
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Events/JobProcessed.php
@@ -0,0 +1,33 @@
+job = $job;
+ $this->connectionName = $connectionName;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Events/JobProcessing.php b/vendor/laravel/framework/src/Illuminate/Queue/Events/JobProcessing.php
new file mode 100644
index 000000000..3dd97248b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Events/JobProcessing.php
@@ -0,0 +1,33 @@
+job = $job;
+ $this->connectionName = $connectionName;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Events/Looping.php b/vendor/laravel/framework/src/Illuminate/Queue/Events/Looping.php
new file mode 100644
index 000000000..16923c0cb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Events/Looping.php
@@ -0,0 +1,8 @@
+table = $table;
+ $this->resolver = $resolver;
+ $this->database = $database;
+ }
+
+ /**
+ * Log a failed job into storage.
+ *
+ * @param string $connection
+ * @param string $queue
+ * @param string $payload
+ * @param \Exception $exception
+ * @return int|null
+ */
+ public function log($connection, $queue, $payload, $exception)
+ {
+ $failed_at = Carbon::now();
+
+ $exception = (string) $exception;
+
+ return $this->getTable()->insertGetId(compact(
+ 'connection', 'queue', 'payload', 'exception', 'failed_at'
+ ));
+ }
+
+ /**
+ * Get a list of all of the failed jobs.
+ *
+ * @return array
+ */
+ public function all()
+ {
+ return $this->getTable()->orderBy('id', 'desc')->get()->all();
+ }
+
+ /**
+ * Get a single failed job.
+ *
+ * @param mixed $id
+ * @return array
+ */
+ public function find($id)
+ {
+ return $this->getTable()->find($id);
+ }
+
+ /**
+ * Delete a single failed job from storage.
+ *
+ * @param mixed $id
+ * @return bool
+ */
+ public function forget($id)
+ {
+ return $this->getTable()->where('id', $id)->delete() > 0;
+ }
+
+ /**
+ * Flush all of the failed jobs from storage.
+ *
+ * @return void
+ */
+ public function flush()
+ {
+ $this->getTable()->delete();
+ }
+
+ /**
+ * Get a new query builder instance for the table.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ protected function getTable()
+ {
+ return $this->resolver->connection($this->database)->table($this->table);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Failed/FailedJobProviderInterface.php b/vendor/laravel/framework/src/Illuminate/Queue/Failed/FailedJobProviderInterface.php
new file mode 100644
index 000000000..0268002d3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Failed/FailedJobProviderInterface.php
@@ -0,0 +1,47 @@
+markAsFailed();
+
+ if ($job->isDeleted()) {
+ return;
+ }
+
+ try {
+ // If the job has failed, we will delete it, call the "failed" method and then call
+ // an event indicating the job has failed so it can be logged if needed. This is
+ // to allow every developer to better keep monitor of their failed queue jobs.
+ $job->delete();
+
+ $job->failed($e);
+ } finally {
+ static::events()->fire(new JobFailed(
+ $connectionName, $job, $e ?: new ManuallyFailedException
+ ));
+ }
+ }
+
+ /**
+ * Get the event dispatcher instance.
+ *
+ * @return \Illuminate\Contracts\Events\Dispatcher
+ */
+ protected static function events()
+ {
+ return Container::getInstance()->make(Dispatcher::class);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/InteractsWithQueue.php b/vendor/laravel/framework/src/Illuminate/Queue/InteractsWithQueue.php
new file mode 100644
index 000000000..20bcecb74
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/InteractsWithQueue.php
@@ -0,0 +1,76 @@
+job ? $this->job->attempts() : 1;
+ }
+
+ /**
+ * Delete the job from the queue.
+ *
+ * @return void
+ */
+ public function delete()
+ {
+ if ($this->job) {
+ return $this->job->delete();
+ }
+ }
+
+ /**
+ * Fail the job from the queue.
+ *
+ * @param \Throwable $exception
+ * @return void
+ */
+ public function fail($exception = null)
+ {
+ if ($this->job) {
+ FailingJob::handle($this->job->getConnectionName(), $this->job, $exception);
+ }
+ }
+
+ /**
+ * Release the job back into the queue.
+ *
+ * @param int $delay
+ * @return void
+ */
+ public function release($delay = 0)
+ {
+ if ($this->job) {
+ return $this->job->release($delay);
+ }
+ }
+
+ /**
+ * Set the base queue job instance.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @return $this
+ */
+ public function setJob(JobContract $job)
+ {
+ $this->job = $job;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/InteractsWithTime.php b/vendor/laravel/framework/src/Illuminate/Queue/InteractsWithTime.php
new file mode 100644
index 000000000..92a881f0b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/InteractsWithTime.php
@@ -0,0 +1,45 @@
+getTimestamp() - $this->currentTime())
+ : (int) $delay;
+ }
+
+ /**
+ * Get the "available at" UNIX timestamp.
+ *
+ * @param \DateTimeInterface|int $delay
+ * @return int
+ */
+ protected function availableAt($delay = 0)
+ {
+ return $delay instanceof DateTimeInterface
+ ? $delay->getTimestamp()
+ : Carbon::now()->addSeconds($delay)->getTimestamp();
+ }
+
+ /**
+ * Get the current system time as a UNIX timestamp.
+ *
+ * @return int
+ */
+ protected function currentTime()
+ {
+ return Carbon::now()->getTimestamp();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/InvalidPayloadException.php b/vendor/laravel/framework/src/Illuminate/Queue/InvalidPayloadException.php
new file mode 100644
index 000000000..788fa660d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/InvalidPayloadException.php
@@ -0,0 +1,19 @@
+job = $job;
+ $this->queue = $queue;
+ $this->container = $container;
+ $this->pheanstalk = $pheanstalk;
+ $this->connectionName = $connectionName;
+ }
+
+ /**
+ * Release the job back into the queue.
+ *
+ * @param int $delay
+ * @return void
+ */
+ public function release($delay = 0)
+ {
+ parent::release($delay);
+
+ $priority = Pheanstalk::DEFAULT_PRIORITY;
+
+ $this->pheanstalk->release($this->job, $priority, $delay);
+ }
+
+ /**
+ * Bury the job in the queue.
+ *
+ * @return void
+ */
+ public function bury()
+ {
+ parent::release();
+
+ $this->pheanstalk->bury($this->job);
+ }
+
+ /**
+ * Delete the job from the queue.
+ *
+ * @return void
+ */
+ public function delete()
+ {
+ parent::delete();
+
+ $this->pheanstalk->delete($this->job);
+ }
+
+ /**
+ * Get the number of times the job has been attempted.
+ *
+ * @return int
+ */
+ public function attempts()
+ {
+ $stats = $this->pheanstalk->statsJob($this->job);
+
+ return (int) $stats->reserves;
+ }
+
+ /**
+ * Get the job identifier.
+ *
+ * @return string
+ */
+ public function getJobId()
+ {
+ return $this->job->getId();
+ }
+
+ /**
+ * Get the raw body string for the job.
+ *
+ * @return string
+ */
+ public function getRawBody()
+ {
+ return $this->job->getData();
+ }
+
+ /**
+ * Get the underlying Pheanstalk instance.
+ *
+ * @return \Pheanstalk\Pheanstalk
+ */
+ public function getPheanstalk()
+ {
+ return $this->pheanstalk;
+ }
+
+ /**
+ * Get the underlying Pheanstalk job.
+ *
+ * @return \Pheanstalk\Job
+ */
+ public function getPheanstalkJob()
+ {
+ return $this->job;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJob.php b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJob.php
new file mode 100644
index 000000000..9b57fb0a4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJob.php
@@ -0,0 +1,100 @@
+job = $job;
+ $this->queue = $queue;
+ $this->database = $database;
+ $this->container = $container;
+ $this->connectionName = $connectionName;
+ }
+
+ /**
+ * Release the job back into the queue.
+ *
+ * @param int $delay
+ * @return mixed
+ */
+ public function release($delay = 0)
+ {
+ parent::release($delay);
+
+ $this->delete();
+
+ return $this->database->release($this->queue, $this->job, $delay);
+ }
+
+ /**
+ * Delete the job from the queue.
+ *
+ * @return void
+ */
+ public function delete()
+ {
+ parent::delete();
+
+ $this->database->deleteReserved($this->queue, $this->job->id);
+ }
+
+ /**
+ * Get the number of times the job has been attempted.
+ *
+ * @return int
+ */
+ public function attempts()
+ {
+ return (int) $this->job->attempts;
+ }
+
+ /**
+ * Get the job identifier.
+ *
+ * @return string
+ */
+ public function getJobId()
+ {
+ return $this->job->id;
+ }
+
+ /**
+ * Get the raw body string for the job.
+ *
+ * @return string
+ */
+ public function getRawBody()
+ {
+ return $this->job->payload;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJobRecord.php b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJobRecord.php
new file mode 100644
index 000000000..a0e2ac8b8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/DatabaseJobRecord.php
@@ -0,0 +1,63 @@
+record = $record;
+ }
+
+ /**
+ * Increment the number of times the job has been attempted.
+ *
+ * @return int
+ */
+ public function increment()
+ {
+ $this->record->attempts++;
+
+ return $this->record->attempts;
+ }
+
+ /**
+ * Update the "reserved at" timestamp of the job.
+ *
+ * @return int
+ */
+ public function touch()
+ {
+ $this->record->reserved_at = $this->currentTime();
+
+ return $this->record->reserved_at;
+ }
+
+ /**
+ * Dynamically access the underlying job information.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function __get($key)
+ {
+ return $this->record->{$key};
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Jobs/Job.php b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/Job.php
new file mode 100644
index 000000000..9d80e06b5
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/Job.php
@@ -0,0 +1,254 @@
+payload();
+
+ list($class, $method) = JobName::parse($payload['job']);
+
+ with($this->instance = $this->resolve($class))->{$method}($this, $payload['data']);
+ }
+
+ /**
+ * Delete the job from the queue.
+ *
+ * @return void
+ */
+ public function delete()
+ {
+ $this->deleted = true;
+ }
+
+ /**
+ * Determine if the job has been deleted.
+ *
+ * @return bool
+ */
+ public function isDeleted()
+ {
+ return $this->deleted;
+ }
+
+ /**
+ * Release the job back into the queue.
+ *
+ * @param int $delay
+ * @return void
+ */
+ public function release($delay = 0)
+ {
+ $this->released = true;
+ }
+
+ /**
+ * Determine if the job was released back into the queue.
+ *
+ * @return bool
+ */
+ public function isReleased()
+ {
+ return $this->released;
+ }
+
+ /**
+ * Determine if the job has been deleted or released.
+ *
+ * @return bool
+ */
+ public function isDeletedOrReleased()
+ {
+ return $this->isDeleted() || $this->isReleased();
+ }
+
+ /**
+ * Determine if the job has been marked as a failure.
+ *
+ * @return bool
+ */
+ public function hasFailed()
+ {
+ return $this->failed;
+ }
+
+ /**
+ * Mark the job as "failed".
+ *
+ * @return void
+ */
+ public function markAsFailed()
+ {
+ $this->failed = true;
+ }
+
+ /**
+ * Process an exception that caused the job to fail.
+ *
+ * @param \Exception $e
+ * @return void
+ */
+ public function failed($e)
+ {
+ $this->markAsFailed();
+
+ $payload = $this->payload();
+
+ list($class, $method) = JobName::parse($payload['job']);
+
+ if (method_exists($this->instance = $this->resolve($class), 'failed')) {
+ $this->instance->failed($payload['data'], $e);
+ }
+ }
+
+ /**
+ * Resolve the given class.
+ *
+ * @param string $class
+ * @return mixed
+ */
+ protected function resolve($class)
+ {
+ return $this->container->make($class);
+ }
+
+ /**
+ * Get the decoded body of the job.
+ *
+ * @return array
+ */
+ public function payload()
+ {
+ return json_decode($this->getRawBody(), true);
+ }
+
+ /**
+ * The number of times to attempt a job.
+ *
+ * @return int|null
+ */
+ public function maxTries()
+ {
+ return array_get($this->payload(), 'maxTries');
+ }
+
+ /**
+ * The number of seconds the job can run.
+ *
+ * @return int|null
+ */
+ public function timeout()
+ {
+ return array_get($this->payload(), 'timeout');
+ }
+
+ /**
+ * Get the name of the queued job class.
+ *
+ * @return string
+ */
+ public function getName()
+ {
+ return $this->payload()['job'];
+ }
+
+ /**
+ * Get the resolved name of the queued job class.
+ *
+ * Resolves the name of "wrapped" jobs such as class-based handlers.
+ *
+ * @return string
+ */
+ public function resolveName()
+ {
+ return JobName::resolve($this->getName(), $this->payload());
+ }
+
+ /**
+ * Get the name of the connection the job belongs to.
+ *
+ * @return string
+ */
+ public function getConnectionName()
+ {
+ return $this->connectionName;
+ }
+
+ /**
+ * Get the name of the queue the job belongs to.
+ *
+ * @return string
+ */
+ public function getQueue()
+ {
+ return $this->queue;
+ }
+
+ /**
+ * Get the service container instance.
+ *
+ * @return \Illuminate\Container\Container
+ */
+ public function getContainer()
+ {
+ return $this->container;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Jobs/JobName.php b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/JobName.php
new file mode 100644
index 000000000..3ce43f9f1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/JobName.php
@@ -0,0 +1,44 @@
+job = $job;
+ $this->redis = $redis;
+ $this->queue = $queue;
+ $this->reserved = $reserved;
+ $this->container = $container;
+ $this->connectionName = $connectionName;
+
+ $this->decoded = $this->payload();
+ }
+
+ /**
+ * Get the raw body string for the job.
+ *
+ * @return string
+ */
+ public function getRawBody()
+ {
+ return $this->job;
+ }
+
+ /**
+ * Delete the job from the queue.
+ *
+ * @return void
+ */
+ public function delete()
+ {
+ parent::delete();
+
+ $this->redis->deleteReserved($this->queue, $this);
+ }
+
+ /**
+ * Release the job back into the queue.
+ *
+ * @param int $delay
+ * @return void
+ */
+ public function release($delay = 0)
+ {
+ parent::release($delay);
+
+ $this->redis->deleteAndRelease($this->queue, $this, $delay);
+ }
+
+ /**
+ * Get the number of times the job has been attempted.
+ *
+ * @return int
+ */
+ public function attempts()
+ {
+ return Arr::get($this->decoded, 'attempts') + 1;
+ }
+
+ /**
+ * Get the job identifier.
+ *
+ * @return string
+ */
+ public function getJobId()
+ {
+ return Arr::get($this->decoded, 'id');
+ }
+
+ /**
+ * Get the underlying Redis factory implementation.
+ *
+ * @return \Illuminate\Contracts\Redis\Factory
+ */
+ public function getRedisQueue()
+ {
+ return $this->redis;
+ }
+
+ /**
+ * Get the underlying reserved Redis job.
+ *
+ * @return string
+ */
+ public function getReservedJob()
+ {
+ return $this->reserved;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Jobs/SqsJob.php b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/SqsJob.php
new file mode 100644
index 000000000..962d75842
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/SqsJob.php
@@ -0,0 +1,124 @@
+sqs = $sqs;
+ $this->job = $job;
+ $this->queue = $queue;
+ $this->container = $container;
+ $this->connectionName = $connectionName;
+ }
+
+ /**
+ * Release the job back into the queue.
+ *
+ * @param int $delay
+ * @return void
+ */
+ public function release($delay = 0)
+ {
+ parent::release($delay);
+
+ $this->sqs->changeMessageVisibility([
+ 'QueueUrl' => $this->queue,
+ 'ReceiptHandle' => $this->job['ReceiptHandle'],
+ 'VisibilityTimeout' => $delay,
+ ]);
+ }
+
+ /**
+ * Delete the job from the queue.
+ *
+ * @return void
+ */
+ public function delete()
+ {
+ parent::delete();
+
+ $this->sqs->deleteMessage([
+ 'QueueUrl' => $this->queue, 'ReceiptHandle' => $this->job['ReceiptHandle'],
+ ]);
+ }
+
+ /**
+ * Get the number of times the job has been attempted.
+ *
+ * @return int
+ */
+ public function attempts()
+ {
+ return (int) $this->job['Attributes']['ApproximateReceiveCount'];
+ }
+
+ /**
+ * Get the job identifier.
+ *
+ * @return string
+ */
+ public function getJobId()
+ {
+ return $this->job['MessageId'];
+ }
+
+ /**
+ * Get the raw body string for the job.
+ *
+ * @return string
+ */
+ public function getRawBody()
+ {
+ return $this->job['Body'];
+ }
+
+ /**
+ * Get the underlying SQS client instance.
+ *
+ * @return \Aws\Sqs\SqsClient
+ */
+ public function getSqs()
+ {
+ return $this->sqs;
+ }
+
+ /**
+ * Get the underlying raw SQS job.
+ *
+ * @return array
+ */
+ public function getSqsJob()
+ {
+ return $this->job;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Jobs/SyncJob.php b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/SyncJob.php
new file mode 100644
index 000000000..9aafb8a92
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Jobs/SyncJob.php
@@ -0,0 +1,91 @@
+queue = $queue;
+ $this->payload = $payload;
+ $this->container = $container;
+ $this->connectionName = $connectionName;
+ }
+
+ /**
+ * Release the job back into the queue.
+ *
+ * @param int $delay
+ * @return void
+ */
+ public function release($delay = 0)
+ {
+ parent::release($delay);
+ }
+
+ /**
+ * Get the number of times the job has been attempted.
+ *
+ * @return int
+ */
+ public function attempts()
+ {
+ return 1;
+ }
+
+ /**
+ * Get the job identifier.
+ *
+ * @return string
+ */
+ public function getJobId()
+ {
+ return '';
+ }
+
+ /**
+ * Get the raw body string for the job.
+ *
+ * @return string
+ */
+ public function getRawBody()
+ {
+ return $this->payload;
+ }
+
+ /**
+ * Get the name of the queue the job belongs to.
+ *
+ * @return string
+ */
+ public function getQueue()
+ {
+ return 'sync';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Listener.php b/vendor/laravel/framework/src/Illuminate/Queue/Listener.php
new file mode 100644
index 000000000..fef3299e9
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Listener.php
@@ -0,0 +1,248 @@
+commandPath = $commandPath;
+ $this->workerCommand = $this->buildCommandTemplate();
+ }
+
+ /**
+ * Build the environment specific worker command.
+ *
+ * @return string
+ */
+ protected function buildCommandTemplate()
+ {
+ $command = 'queue:work %s --once --queue=%s --delay=%s --memory=%s --sleep=%s --tries=%s';
+
+ return "{$this->phpBinary()} {$this->artisanBinary()} {$command}";
+ }
+
+ /**
+ * Get the PHP binary.
+ *
+ * @return string
+ */
+ protected function phpBinary()
+ {
+ return ProcessUtils::escapeArgument(
+ (new PhpExecutableFinder)->find(false)
+ );
+ }
+
+ /**
+ * Get the Artisan binary.
+ *
+ * @return string
+ */
+ protected function artisanBinary()
+ {
+ return defined('ARTISAN_BINARY')
+ ? ProcessUtils::escapeArgument(ARTISAN_BINARY)
+ : 'artisan';
+ }
+
+ /**
+ * Listen to the given queue connection.
+ *
+ * @param string $connection
+ * @param string $queue
+ * @param \Illuminate\Queue\ListenerOptions $options
+ * @return void
+ */
+ public function listen($connection, $queue, ListenerOptions $options)
+ {
+ $process = $this->makeProcess($connection, $queue, $options);
+
+ while (true) {
+ $this->runProcess($process, $options->memory);
+ }
+ }
+
+ /**
+ * Create a new Symfony process for the worker.
+ *
+ * @param string $connection
+ * @param string $queue
+ * @param \Illuminate\Queue\ListenerOptions $options
+ * @return \Symfony\Component\Process\Process
+ */
+ public function makeProcess($connection, $queue, ListenerOptions $options)
+ {
+ $command = $this->workerCommand;
+
+ // If the environment is set, we will append it to the command string so the
+ // workers will run under the specified environment. Otherwise, they will
+ // just run under the production environment which is not always right.
+ if (isset($options->environment)) {
+ $command = $this->addEnvironment($command, $options);
+ }
+
+ // Next, we will just format out the worker commands with all of the various
+ // options available for the command. This will produce the final command
+ // line that we will pass into a Symfony process object for processing.
+ $command = $this->formatCommand(
+ $command, $connection, $queue, $options
+ );
+
+ return new Process(
+ $command, $this->commandPath, null, null, $options->timeout
+ );
+ }
+
+ /**
+ * Add the environment option to the given command.
+ *
+ * @param string $command
+ * @param \Illuminate\Queue\ListenerOptions $options
+ * @return string
+ */
+ protected function addEnvironment($command, ListenerOptions $options)
+ {
+ return $command.' --env='.ProcessUtils::escapeArgument($options->environment);
+ }
+
+ /**
+ * Format the given command with the listener options.
+ *
+ * @param string $command
+ * @param string $connection
+ * @param string $queue
+ * @param \Illuminate\Queue\ListenerOptions $options
+ * @return string
+ */
+ protected function formatCommand($command, $connection, $queue, ListenerOptions $options)
+ {
+ return sprintf(
+ $command,
+ ProcessUtils::escapeArgument($connection),
+ ProcessUtils::escapeArgument($queue),
+ $options->delay, $options->memory,
+ $options->sleep, $options->maxTries
+ );
+ }
+
+ /**
+ * Run the given process.
+ *
+ * @param \Symfony\Component\Process\Process $process
+ * @param int $memory
+ * @return void
+ */
+ public function runProcess(Process $process, $memory)
+ {
+ $process->run(function ($type, $line) {
+ $this->handleWorkerOutput($type, $line);
+ });
+
+ // Once we have run the job we'll go check if the memory limit has been exceeded
+ // for the script. If it has, we will kill this script so the process manager
+ // will restart this with a clean slate of memory automatically on exiting.
+ if ($this->memoryExceeded($memory)) {
+ $this->stop();
+ }
+ }
+
+ /**
+ * Handle output from the worker process.
+ *
+ * @param int $type
+ * @param string $line
+ * @return void
+ */
+ protected function handleWorkerOutput($type, $line)
+ {
+ if (isset($this->outputHandler)) {
+ call_user_func($this->outputHandler, $type, $line);
+ }
+ }
+
+ /**
+ * Determine if the memory limit has been exceeded.
+ *
+ * @param int $memoryLimit
+ * @return bool
+ */
+ public function memoryExceeded($memoryLimit)
+ {
+ return (memory_get_usage() / 1024 / 1024) >= $memoryLimit;
+ }
+
+ /**
+ * Stop listening and bail out of the script.
+ *
+ * @return void
+ */
+ public function stop()
+ {
+ die;
+ }
+
+ /**
+ * Set the output handler callback.
+ *
+ * @param \Closure $outputHandler
+ * @return void
+ */
+ public function setOutputHandler(Closure $outputHandler)
+ {
+ $this->outputHandler = $outputHandler;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/ListenerOptions.php b/vendor/laravel/framework/src/Illuminate/Queue/ListenerOptions.php
new file mode 100644
index 000000000..9812a314d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/ListenerOptions.php
@@ -0,0 +1,31 @@
+environment = $environment;
+
+ parent::__construct($delay, $memory, $timeout, $sleep, $maxTries, $force);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/LuaScripts.php b/vendor/laravel/framework/src/Illuminate/Queue/LuaScripts.php
new file mode 100644
index 000000000..93ac04783
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/LuaScripts.php
@@ -0,0 +1,103 @@
+push($job, $data, $queue);
+ }
+
+ /**
+ * Push a new job onto the queue after a delay.
+ *
+ * @param string $queue
+ * @param \DateTime|int $delay
+ * @param string $job
+ * @param mixed $data
+ * @return mixed
+ */
+ public function laterOn($queue, $delay, $job, $data = '')
+ {
+ return $this->later($delay, $job, $data, $queue);
+ }
+
+ /**
+ * Push an array of jobs onto the queue.
+ *
+ * @param array $jobs
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function bulk($jobs, $data = '', $queue = null)
+ {
+ foreach ((array) $jobs as $job) {
+ $this->push($job, $data, $queue);
+ }
+ }
+
+ /**
+ * Create a payload string from the given job and data.
+ *
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return string
+ *
+ * @throws \Illuminate\Queue\InvalidPayloadException
+ */
+ protected function createPayload($job, $data = '', $queue = null)
+ {
+ $payload = json_encode($this->createPayloadArray($job, $data, $queue));
+
+ if (JSON_ERROR_NONE !== json_last_error()) {
+ throw new InvalidPayloadException(
+ 'Unable to JSON encode payload. Error code: '.json_last_error()
+ );
+ }
+
+ return $payload;
+ }
+
+ /**
+ * Create a payload array from the given job and data.
+ *
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return array
+ */
+ protected function createPayloadArray($job, $data = '', $queue = null)
+ {
+ return is_object($job)
+ ? $this->createObjectPayload($job)
+ : $this->createStringPayload($job, $data);
+ }
+
+ /**
+ * Create a payload for an object-based queue handler.
+ *
+ * @param mixed $job
+ * @return array
+ */
+ protected function createObjectPayload($job)
+ {
+ return [
+ 'displayName' => $this->getDisplayName($job),
+ 'job' => 'Illuminate\Queue\CallQueuedHandler@call',
+ 'maxTries' => isset($job->tries) ? $job->tries : null,
+ 'timeout' => isset($job->timeout) ? $job->timeout : null,
+ 'data' => [
+ 'commandName' => get_class($job),
+ 'command' => serialize(clone $job),
+ ],
+ ];
+ }
+
+ /**
+ * Get the display name for the given job.
+ *
+ * @param mixed $job
+ * @return string
+ */
+ protected function getDisplayName($job)
+ {
+ return method_exists($job, 'displayName')
+ ? $job->displayName() : get_class($job);
+ }
+
+ /**
+ * Create a typical, string based queue payload array.
+ *
+ * @param string $job
+ * @param mixed $data
+ * @return array
+ */
+ protected function createStringPayload($job, $data)
+ {
+ return [
+ 'displayName' => is_string($job) ? explode('@', $job)[0] : null,
+ 'job' => $job, 'maxTries' => null,
+ 'timeout' => null, 'data' => $data,
+ ];
+ }
+
+ /**
+ * Get the connection name for the queue.
+ *
+ * @return string
+ */
+ public function getConnectionName()
+ {
+ return $this->connectionName;
+ }
+
+ /**
+ * Set the connection name for the queue.
+ *
+ * @param string $name
+ * @return $this
+ */
+ public function setConnectionName($name)
+ {
+ $this->connectionName = $name;
+
+ return $this;
+ }
+
+ /**
+ * Set the IoC container instance.
+ *
+ * @param \Illuminate\Container\Container $container
+ * @return void
+ */
+ public function setContainer(Container $container)
+ {
+ $this->container = $container;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/QueueManager.php b/vendor/laravel/framework/src/Illuminate/Queue/QueueManager.php
new file mode 100644
index 000000000..f9bb7f6ae
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/QueueManager.php
@@ -0,0 +1,270 @@
+app = $app;
+ }
+
+ /**
+ * Register an event listener for the before job event.
+ *
+ * @param mixed $callback
+ * @return void
+ */
+ public function before($callback)
+ {
+ $this->app['events']->listen(Events\JobProcessing::class, $callback);
+ }
+
+ /**
+ * Register an event listener for the after job event.
+ *
+ * @param mixed $callback
+ * @return void
+ */
+ public function after($callback)
+ {
+ $this->app['events']->listen(Events\JobProcessed::class, $callback);
+ }
+
+ /**
+ * Register an event listener for the exception occurred job event.
+ *
+ * @param mixed $callback
+ * @return void
+ */
+ public function exceptionOccurred($callback)
+ {
+ $this->app['events']->listen(Events\JobExceptionOccurred::class, $callback);
+ }
+
+ /**
+ * Register an event listener for the daemon queue loop.
+ *
+ * @param mixed $callback
+ * @return void
+ */
+ public function looping($callback)
+ {
+ $this->app['events']->listen(Events\Looping::class, $callback);
+ }
+
+ /**
+ * Register an event listener for the failed job event.
+ *
+ * @param mixed $callback
+ * @return void
+ */
+ public function failing($callback)
+ {
+ $this->app['events']->listen(Events\JobFailed::class, $callback);
+ }
+
+ /**
+ * Register an event listener for the daemon queue stopping.
+ *
+ * @param mixed $callback
+ * @return void
+ */
+ public function stopping($callback)
+ {
+ $this->app['events']->listen(Events\WorkerStopping::class, $callback);
+ }
+
+ /**
+ * Determine if the driver is connected.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function connected($name = null)
+ {
+ return isset($this->connections[$name ?: $this->getDefaultDriver()]);
+ }
+
+ /**
+ * Resolve a queue connection instance.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Queue\Queue
+ */
+ public function connection($name = null)
+ {
+ $name = $name ?: $this->getDefaultDriver();
+
+ // If the connection has not been resolved yet we will resolve it now as all
+ // of the connections are resolved when they are actually needed so we do
+ // not make any unnecessary connection to the various queue end-points.
+ if (! isset($this->connections[$name])) {
+ $this->connections[$name] = $this->resolve($name);
+
+ $this->connections[$name]->setContainer($this->app);
+ }
+
+ return $this->connections[$name];
+ }
+
+ /**
+ * Resolve a queue connection.
+ *
+ * @param string $name
+ * @return \Illuminate\Contracts\Queue\Queue
+ */
+ protected function resolve($name)
+ {
+ $config = $this->getConfig($name);
+
+ return $this->getConnector($config['driver'])
+ ->connect($config)
+ ->setConnectionName($name);
+ }
+
+ /**
+ * Get the connector for a given driver.
+ *
+ * @param string $driver
+ * @return \Illuminate\Queue\Connectors\ConnectorInterface
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function getConnector($driver)
+ {
+ if (! isset($this->connectors[$driver])) {
+ throw new InvalidArgumentException("No connector for [$driver]");
+ }
+
+ return call_user_func($this->connectors[$driver]);
+ }
+
+ /**
+ * Add a queue connection resolver.
+ *
+ * @param string $driver
+ * @param \Closure $resolver
+ * @return void
+ */
+ public function extend($driver, Closure $resolver)
+ {
+ return $this->addConnector($driver, $resolver);
+ }
+
+ /**
+ * Add a queue connection resolver.
+ *
+ * @param string $driver
+ * @param \Closure $resolver
+ * @return void
+ */
+ public function addConnector($driver, Closure $resolver)
+ {
+ $this->connectors[$driver] = $resolver;
+ }
+
+ /**
+ * Get the queue connection configuration.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function getConfig($name)
+ {
+ if (! is_null($name) && $name !== 'null') {
+ return $this->app['config']["queue.connections.{$name}"];
+ }
+
+ return ['driver' => 'null'];
+ }
+
+ /**
+ * Get the name of the default queue connection.
+ *
+ * @return string
+ */
+ public function getDefaultDriver()
+ {
+ return $this->app['config']['queue.default'];
+ }
+
+ /**
+ * Set the name of the default queue connection.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setDefaultDriver($name)
+ {
+ $this->app['config']['queue.default'] = $name;
+ }
+
+ /**
+ * Get the full name for the given connection.
+ *
+ * @param string $connection
+ * @return string
+ */
+ public function getName($connection = null)
+ {
+ return $connection ?: $this->getDefaultDriver();
+ }
+
+ /**
+ * Determine if the application is in maintenance mode.
+ *
+ * @return bool
+ */
+ public function isDownForMaintenance()
+ {
+ return $this->app->isDownForMaintenance();
+ }
+
+ /**
+ * Dynamically pass calls to the default connection.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->connection()->$method(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/QueueServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Queue/QueueServiceProvider.php
new file mode 100644
index 000000000..2ad923ec4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/QueueServiceProvider.php
@@ -0,0 +1,230 @@
+registerManager();
+
+ $this->registerConnection();
+
+ $this->registerWorker();
+
+ $this->registerListener();
+
+ $this->registerFailedJobServices();
+ }
+
+ /**
+ * Register the queue manager.
+ *
+ * @return void
+ */
+ protected function registerManager()
+ {
+ $this->app->singleton('queue', function ($app) {
+ // Once we have an instance of the queue manager, we will register the various
+ // resolvers for the queue connectors. These connectors are responsible for
+ // creating the classes that accept queue configs and instantiate queues.
+ return tap(new QueueManager($app), function ($manager) {
+ $this->registerConnectors($manager);
+ });
+ });
+ }
+
+ /**
+ * Register the default queue connection binding.
+ *
+ * @return void
+ */
+ protected function registerConnection()
+ {
+ $this->app->singleton('queue.connection', function ($app) {
+ return $app['queue']->connection();
+ });
+ }
+
+ /**
+ * Register the connectors on the queue manager.
+ *
+ * @param \Illuminate\Queue\QueueManager $manager
+ * @return void
+ */
+ public function registerConnectors($manager)
+ {
+ foreach (['Null', 'Sync', 'Database', 'Redis', 'Beanstalkd', 'Sqs'] as $connector) {
+ $this->{"register{$connector}Connector"}($manager);
+ }
+ }
+
+ /**
+ * Register the Null queue connector.
+ *
+ * @param \Illuminate\Queue\QueueManager $manager
+ * @return void
+ */
+ protected function registerNullConnector($manager)
+ {
+ $manager->addConnector('null', function () {
+ return new NullConnector;
+ });
+ }
+
+ /**
+ * Register the Sync queue connector.
+ *
+ * @param \Illuminate\Queue\QueueManager $manager
+ * @return void
+ */
+ protected function registerSyncConnector($manager)
+ {
+ $manager->addConnector('sync', function () {
+ return new SyncConnector;
+ });
+ }
+
+ /**
+ * Register the database queue connector.
+ *
+ * @param \Illuminate\Queue\QueueManager $manager
+ * @return void
+ */
+ protected function registerDatabaseConnector($manager)
+ {
+ $manager->addConnector('database', function () {
+ return new DatabaseConnector($this->app['db']);
+ });
+ }
+
+ /**
+ * Register the Redis queue connector.
+ *
+ * @param \Illuminate\Queue\QueueManager $manager
+ * @return void
+ */
+ protected function registerRedisConnector($manager)
+ {
+ $manager->addConnector('redis', function () {
+ return new RedisConnector($this->app['redis']);
+ });
+ }
+
+ /**
+ * Register the Beanstalkd queue connector.
+ *
+ * @param \Illuminate\Queue\QueueManager $manager
+ * @return void
+ */
+ protected function registerBeanstalkdConnector($manager)
+ {
+ $manager->addConnector('beanstalkd', function () {
+ return new BeanstalkdConnector;
+ });
+ }
+
+ /**
+ * Register the Amazon SQS queue connector.
+ *
+ * @param \Illuminate\Queue\QueueManager $manager
+ * @return void
+ */
+ protected function registerSqsConnector($manager)
+ {
+ $manager->addConnector('sqs', function () {
+ return new SqsConnector;
+ });
+ }
+
+ /**
+ * Register the queue worker.
+ *
+ * @return void
+ */
+ protected function registerWorker()
+ {
+ $this->app->singleton('queue.worker', function () {
+ return new Worker(
+ $this->app['queue'], $this->app['events'], $this->app[ExceptionHandler::class]
+ );
+ });
+ }
+
+ /**
+ * Register the queue listener.
+ *
+ * @return void
+ */
+ protected function registerListener()
+ {
+ $this->app->singleton('queue.listener', function () {
+ return new Listener($this->app->basePath());
+ });
+ }
+
+ /**
+ * Register the failed job services.
+ *
+ * @return void
+ */
+ protected function registerFailedJobServices()
+ {
+ $this->app->singleton('queue.failer', function () {
+ $config = $this->app['config']['queue.failed'];
+
+ return isset($config['table'])
+ ? $this->databaseFailedJobProvider($config)
+ : new NullFailedJobProvider;
+ });
+ }
+
+ /**
+ * Create a new database failed job provider.
+ *
+ * @param array $config
+ * @return \Illuminate\Queue\Failed\DatabaseFailedJobProvider
+ */
+ protected function databaseFailedJobProvider($config)
+ {
+ return new DatabaseFailedJobProvider(
+ $this->app['db'], $config['database'], $config['table']
+ );
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return [
+ 'queue', 'queue.worker', 'queue.listener',
+ 'queue.failer', 'queue.connection',
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/README.md b/vendor/laravel/framework/src/Illuminate/Queue/README.md
new file mode 100644
index 000000000..d0f2ba4af
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/README.md
@@ -0,0 +1,34 @@
+## Illuminate Queue
+
+The Laravel Queue component provides a unified API across a variety of different queue services. Queues allow you to defer the processing of a time consuming task, such as sending an e-mail, until a later time, thus drastically speeding up the web requests to your application.
+
+### Usage Instructions
+
+First, create a new Queue `Capsule` manager instance. Similar to the "Capsule" provided for the Eloquent ORM, the queue Capsule aims to make configuring the library for usage outside of the Laravel framework as easy as possible.
+
+```PHP
+use Illuminate\Queue\Capsule\Manager as Queue;
+
+$queue = new Queue;
+
+$queue->addConnection([
+ 'driver' => 'beanstalkd',
+ 'host' => 'localhost',
+ 'queue' => 'default',
+]);
+
+// Make this Capsule instance available globally via static methods... (optional)
+$queue->setAsGlobal();
+```
+
+Once the Capsule instance has been registered. You may use it like so:
+
+```PHP
+// As an instance...
+$queue->push('SendEmail', array('message' => $message));
+
+// If setAsGlobal has been called...
+Queue::push('SendEmail', array('message' => $message));
+```
+
+For further documentation on using the queue, consult the [Laravel framework documentation](https://laravel.com/docs).
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/RedisQueue.php b/vendor/laravel/framework/src/Illuminate/Queue/RedisQueue.php
new file mode 100644
index 000000000..7767a1f26
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/RedisQueue.php
@@ -0,0 +1,281 @@
+redis = $redis;
+ $this->default = $default;
+ $this->connection = $connection;
+ $this->retryAfter = $retryAfter;
+ }
+
+ /**
+ * Get the size of the queue.
+ *
+ * @param string $queue
+ * @return int
+ */
+ public function size($queue = null)
+ {
+ $queue = $this->getQueue($queue);
+
+ return $this->getConnection()->eval(
+ LuaScripts::size(), 3, $queue, $queue.':delayed', $queue.':reserved'
+ );
+ }
+
+ /**
+ * Push a new job onto the queue.
+ *
+ * @param object|string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function push($job, $data = '', $queue = null)
+ {
+ return $this->pushRaw($this->createPayload($job, $data), $queue);
+ }
+
+ /**
+ * Push a raw payload onto the queue.
+ *
+ * @param string $payload
+ * @param string $queue
+ * @param array $options
+ * @return mixed
+ */
+ public function pushRaw($payload, $queue = null, array $options = [])
+ {
+ $this->getConnection()->rpush($this->getQueue($queue), $payload);
+
+ return Arr::get(json_decode($payload, true), 'id');
+ }
+
+ /**
+ * Push a new job onto the queue after a delay.
+ *
+ * @param \DateTime|int $delay
+ * @param object|string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function later($delay, $job, $data = '', $queue = null)
+ {
+ return $this->laterRaw($delay, $this->createPayload($job, $data), $queue);
+ }
+
+ /**
+ * Push a raw job onto the queue after a delay.
+ *
+ * @param \DateTime|int $delay
+ * @param string $payload
+ * @param string $queue
+ * @return mixed
+ */
+ protected function laterRaw($delay, $payload, $queue = null)
+ {
+ $this->getConnection()->zadd(
+ $this->getQueue($queue).':delayed', $this->availableAt($delay), $payload
+ );
+
+ return Arr::get(json_decode($payload, true), 'id');
+ }
+
+ /**
+ * Create a payload string from the given job and data.
+ *
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return array
+ */
+ protected function createPayloadArray($job, $data = '', $queue = null)
+ {
+ return array_merge(parent::createPayloadArray($job, $data, $queue), [
+ 'id' => $this->getRandomId(),
+ 'attempts' => 0,
+ ]);
+ }
+
+ /**
+ * Pop the next job off of the queue.
+ *
+ * @param string $queue
+ * @return \Illuminate\Contracts\Queue\Job|null
+ */
+ public function pop($queue = null)
+ {
+ $this->migrate($prefixed = $this->getQueue($queue));
+
+ list($job, $reserved) = $this->retrieveNextJob($prefixed);
+
+ if ($reserved) {
+ return new RedisJob(
+ $this->container, $this, $job,
+ $reserved, $this->connectionName, $queue ?: $this->default
+ );
+ }
+ }
+
+ /**
+ * Migrate any delayed or expired jobs onto the primary queue.
+ *
+ * @param string $queue
+ * @return void
+ */
+ protected function migrate($queue)
+ {
+ $this->migrateExpiredJobs($queue.':delayed', $queue);
+
+ if (! is_null($this->retryAfter)) {
+ $this->migrateExpiredJobs($queue.':reserved', $queue);
+ }
+ }
+
+ /**
+ * Migrate the delayed jobs that are ready to the regular queue.
+ *
+ * @param string $from
+ * @param string $to
+ * @return array
+ */
+ public function migrateExpiredJobs($from, $to)
+ {
+ return $this->getConnection()->eval(
+ LuaScripts::migrateExpiredJobs(), 2, $from, $to, $this->currentTime()
+ );
+ }
+
+ /**
+ * Retrieve the next job from the queue.
+ *
+ * @param string $queue
+ * @return array
+ */
+ protected function retrieveNextJob($queue)
+ {
+ return $this->getConnection()->eval(
+ LuaScripts::pop(), 2, $queue, $queue.':reserved',
+ $this->availableAt($this->retryAfter)
+ );
+ }
+
+ /**
+ * Delete a reserved job from the queue.
+ *
+ * @param string $queue
+ * @param \Illuminate\Queue\Jobs\RedisJob $job
+ * @return void
+ */
+ public function deleteReserved($queue, $job)
+ {
+ $this->getConnection()->zrem($this->getQueue($queue).':reserved', $job->getReservedJob());
+ }
+
+ /**
+ * Delete a reserved job from the reserved queue and release it.
+ *
+ * @param string $queue
+ * @param \Illuminate\Queue\Jobs\RedisJob $job
+ * @param int $delay
+ * @return void
+ */
+ public function deleteAndRelease($queue, $job, $delay)
+ {
+ $queue = $this->getQueue($queue);
+
+ $this->getConnection()->eval(
+ LuaScripts::release(), 2, $queue.':delayed', $queue.':reserved',
+ $job->getReservedJob(), $this->availableAt($delay)
+ );
+ }
+
+ /**
+ * Get a random ID string.
+ *
+ * @return string
+ */
+ protected function getRandomId()
+ {
+ return Str::random(32);
+ }
+
+ /**
+ * Get the queue or return the default.
+ *
+ * @param string|null $queue
+ * @return string
+ */
+ protected function getQueue($queue)
+ {
+ return 'queues:'.($queue ?: $this->default);
+ }
+
+ /**
+ * Get the connection for the queue.
+ *
+ * @return \Predis\ClientInterface
+ */
+ protected function getConnection()
+ {
+ return $this->redis->connection($this->connection);
+ }
+
+ /**
+ * Get the underlying Redis instance.
+ *
+ * @return \Illuminate\Contracts\Redis\Factory
+ */
+ public function getRedis()
+ {
+ return $this->redis;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/SerializesAndRestoresModelIdentifiers.php b/vendor/laravel/framework/src/Illuminate/Queue/SerializesAndRestoresModelIdentifiers.php
new file mode 100644
index 000000000..2e5fedb31
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/SerializesAndRestoresModelIdentifiers.php
@@ -0,0 +1,77 @@
+getQueueableClass(), $value->getQueueableIds());
+ }
+
+ if ($value instanceof QueueableEntity) {
+ return new ModelIdentifier(get_class($value), $value->getQueueableId());
+ }
+
+ return $value;
+ }
+
+ /**
+ * Get the restored property value after deserialization.
+ *
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function getRestoredPropertyValue($value)
+ {
+ if (! $value instanceof ModelIdentifier) {
+ return $value;
+ }
+
+ return is_array($value->id)
+ ? $this->restoreCollection($value)
+ : $this->getQueryForModelRestoration(new $value->class)
+ ->useWritePdo()->findOrFail($value->id);
+ }
+
+ /**
+ * Restore a queueable collection instance.
+ *
+ * @param \Illuminate\Contracts\Database\ModelIdentifier $value
+ * @return \Illuminate\Database\Eloquent\Collection
+ */
+ protected function restoreCollection($value)
+ {
+ if (! $value->class || count($value->id) === 0) {
+ return new EloquentCollection;
+ }
+
+ $model = new $value->class;
+
+ return $this->getQueryForModelRestoration($model)->useWritePdo()
+ ->whereIn($model->getQualifiedKeyName(), $value->id)->get();
+ }
+
+ /**
+ * Get the query for restoration.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @return \Illuminate\Database\Eloquent\Builder
+ */
+ protected function getQueryForModelRestoration($model)
+ {
+ return $model->newQueryWithoutScopes();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/SerializesModels.php b/vendor/laravel/framework/src/Illuminate/Queue/SerializesModels.php
new file mode 100644
index 000000000..62f7e7218
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/SerializesModels.php
@@ -0,0 +1,58 @@
+getProperties();
+
+ foreach ($properties as $property) {
+ $property->setValue($this, $this->getSerializedPropertyValue(
+ $this->getPropertyValue($property)
+ ));
+ }
+
+ return array_map(function ($p) {
+ return $p->getName();
+ }, $properties);
+ }
+
+ /**
+ * Restore the model after serialization.
+ *
+ * @return void
+ */
+ public function __wakeup()
+ {
+ foreach ((new ReflectionClass($this))->getProperties() as $property) {
+ $property->setValue($this, $this->getRestoredPropertyValue(
+ $this->getPropertyValue($property)
+ ));
+ }
+ }
+
+ /**
+ * Get the property value for the given property.
+ *
+ * @param \ReflectionProperty $property
+ * @return mixed
+ */
+ protected function getPropertyValue(ReflectionProperty $property)
+ {
+ $property->setAccessible(true);
+
+ return $property->getValue($this);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/SqsQueue.php b/vendor/laravel/framework/src/Illuminate/Queue/SqsQueue.php
new file mode 100644
index 000000000..dc85d9771
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/SqsQueue.php
@@ -0,0 +1,155 @@
+sqs = $sqs;
+ $this->prefix = $prefix;
+ $this->default = $default;
+ }
+
+ /**
+ * Get the size of the queue.
+ *
+ * @param string $queue
+ * @return int
+ */
+ public function size($queue = null)
+ {
+ $response = $this->sqs->getQueueAttributes([
+ 'QueueUrl' => $this->getQueue($queue),
+ 'AttributeNames' => ['ApproximateNumberOfMessages'],
+ ]);
+
+ $attributes = $response->get('Attributes');
+
+ return (int) $attributes['ApproximateNumberOfMessages'];
+ }
+
+ /**
+ * Push a new job onto the queue.
+ *
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function push($job, $data = '', $queue = null)
+ {
+ return $this->pushRaw($this->createPayload($job, $data), $queue);
+ }
+
+ /**
+ * Push a raw payload onto the queue.
+ *
+ * @param string $payload
+ * @param string $queue
+ * @param array $options
+ * @return mixed
+ */
+ public function pushRaw($payload, $queue = null, array $options = [])
+ {
+ return $this->sqs->sendMessage([
+ 'QueueUrl' => $this->getQueue($queue), 'MessageBody' => $payload,
+ ])->get('MessageId');
+ }
+
+ /**
+ * Push a new job onto the queue after a delay.
+ *
+ * @param \DateTime|int $delay
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function later($delay, $job, $data = '', $queue = null)
+ {
+ return $this->sqs->sendMessage([
+ 'QueueUrl' => $this->getQueue($queue),
+ 'MessageBody' => $this->createPayload($job, $data),
+ 'DelaySeconds' => $this->secondsUntil($delay),
+ ])->get('MessageId');
+ }
+
+ /**
+ * Pop the next job off of the queue.
+ *
+ * @param string $queue
+ * @return \Illuminate\Contracts\Queue\Job|null
+ */
+ public function pop($queue = null)
+ {
+ $response = $this->sqs->receiveMessage([
+ 'QueueUrl' => $queue = $this->getQueue($queue),
+ 'AttributeNames' => ['ApproximateReceiveCount'],
+ ]);
+
+ if (count($response['Messages']) > 0) {
+ return new SqsJob(
+ $this->container, $this->sqs, $response['Messages'][0],
+ $this->connectionName, $queue
+ );
+ }
+ }
+
+ /**
+ * Get the queue or return the default.
+ *
+ * @param string|null $queue
+ * @return string
+ */
+ public function getQueue($queue)
+ {
+ $queue = $queue ?: $this->default;
+
+ return filter_var($queue, FILTER_VALIDATE_URL) === false
+ ? rtrim($this->prefix, '/').'/'.$queue : $queue;
+ }
+
+ /**
+ * Get the underlying SQS instance.
+ *
+ * @return \Aws\Sqs\SqsClient
+ */
+ public function getSqs()
+ {
+ return $this->sqs;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/SyncQueue.php b/vendor/laravel/framework/src/Illuminate/Queue/SyncQueue.php
new file mode 100644
index 000000000..4d8184ca0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/SyncQueue.php
@@ -0,0 +1,161 @@
+resolveJob($this->createPayload($job, $data, $queue), $queue);
+
+ try {
+ $this->raiseBeforeJobEvent($queueJob);
+
+ $queueJob->fire();
+
+ $this->raiseAfterJobEvent($queueJob);
+ } catch (Exception $e) {
+ $this->handleException($queueJob, $e);
+ } catch (Throwable $e) {
+ $this->handleException($queueJob, new FatalThrowableError($e));
+ }
+
+ return 0;
+ }
+
+ /**
+ * Resolve a Sync job instance.
+ *
+ * @param string $payload
+ * @param string $queue
+ * @return \Illuminate\Queue\Jobs\SyncJob
+ */
+ protected function resolveJob($payload, $queue)
+ {
+ return new SyncJob($this->container, $payload, $this->connectionName, $queue);
+ }
+
+ /**
+ * Raise the before queue job event.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @return void
+ */
+ protected function raiseBeforeJobEvent(Job $job)
+ {
+ if ($this->container->bound('events')) {
+ $this->container['events']->fire(new Events\JobProcessing($this->connectionName, $job));
+ }
+ }
+
+ /**
+ * Raise the after queue job event.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @return void
+ */
+ protected function raiseAfterJobEvent(Job $job)
+ {
+ if ($this->container->bound('events')) {
+ $this->container['events']->fire(new Events\JobProcessed($this->connectionName, $job));
+ }
+ }
+
+ /**
+ * Raise the exception occurred queue job event.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param \Exception $e
+ * @return void
+ */
+ protected function raiseExceptionOccurredJobEvent(Job $job, $e)
+ {
+ if ($this->container->bound('events')) {
+ $this->container['events']->fire(new Events\JobExceptionOccurred($this->connectionName, $job, $e));
+ }
+ }
+
+ /**
+ * Handle an exception that occurred while processing a job.
+ *
+ * @param \Illuminate\Queue\Jobs\Job $queueJob
+ * @param \Exception $e
+ * @return void
+ *
+ * @throws \Exception
+ */
+ protected function handleException($queueJob, $e)
+ {
+ $this->raiseExceptionOccurredJobEvent($queueJob, $e);
+
+ FailingJob::handle($this->connectionName, $queueJob, $e);
+
+ throw $e;
+ }
+
+ /**
+ * Push a raw payload onto the queue.
+ *
+ * @param string $payload
+ * @param string $queue
+ * @param array $options
+ * @return mixed
+ */
+ public function pushRaw($payload, $queue = null, array $options = [])
+ {
+ //
+ }
+
+ /**
+ * Push a new job onto the queue after a delay.
+ *
+ * @param \DateTime|int $delay
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function later($delay, $job, $data = '', $queue = null)
+ {
+ return $this->push($job, $data, $queue);
+ }
+
+ /**
+ * Pop the next job off of the queue.
+ *
+ * @param string $queue
+ * @return \Illuminate\Contracts\Queue\Job|null
+ */
+ public function pop($queue = null)
+ {
+ //
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/Worker.php b/vendor/laravel/framework/src/Illuminate/Queue/Worker.php
new file mode 100644
index 000000000..4f29580d8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/Worker.php
@@ -0,0 +1,620 @@
+events = $events;
+ $this->manager = $manager;
+ $this->exceptions = $exceptions;
+ }
+
+ /**
+ * Listen to the given queue in a loop.
+ *
+ * @param string $connectionName
+ * @param string $queue
+ * @param \Illuminate\Queue\WorkerOptions $options
+ * @return void
+ */
+ public function daemon($connectionName, $queue, WorkerOptions $options)
+ {
+ $this->listenForSignals();
+
+ $lastRestart = $this->getTimestampOfLastQueueRestart();
+
+ while (true) {
+ // Before reserving any jobs, we will make sure this queue is not paused and
+ // if it is we will just pause this worker for a given amount of time and
+ // make sure we do not need to kill this worker process off completely.
+ if (! $this->daemonShouldRun($options)) {
+ $this->pauseWorker($options, $lastRestart);
+
+ continue;
+ }
+
+ // First, we will attempt to get the next job off of the queue. We will also
+ // register the timeout handler and reset the alarm for this job so it is
+ // not stuck in a frozen state forever. Then, we can fire off this job.
+ $job = $this->getNextJob(
+ $this->manager->connection($connectionName), $queue
+ );
+
+ $this->registerTimeoutHandler($job, $options);
+
+ // If the daemon should run (not in maintenance mode, etc.), then we can run
+ // fire off this job for processing. Otherwise, we will need to sleep the
+ // worker so no more jobs are processed until they should be processed.
+ if ($job) {
+ $this->runJob($job, $connectionName, $options);
+ } else {
+ $this->sleep($options->sleep);
+ }
+
+ // Finally, we will check to see if we have exceeded our memory limits or if
+ // the queue should restart based on other indications. If so, we'll stop
+ // this worker and let whatever is "monitoring" it restart the process.
+ $this->stopIfNecessary($options, $lastRestart);
+ }
+ }
+
+ /**
+ * Register the worker timeout handler (PHP 7.1+).
+ *
+ * @param \Illuminate\Contracts\Queue\Job|null $job
+ * @param WorkerOptions $options
+ * @return void
+ */
+ protected function registerTimeoutHandler($job, WorkerOptions $options)
+ {
+ if ($this->supportsAsyncSignals()) {
+ // We will register a signal handler for the alarm signal so that we can kill this
+ // process if it is running too long because it has frozen. This uses the async
+ // signals supported in recent versions of PHP to accomplish it conveniently.
+ pcntl_signal(SIGALRM, function () {
+ $this->kill(1);
+ });
+
+ pcntl_alarm(
+ max($this->timeoutForJob($job, $options), 0)
+ );
+ }
+ }
+
+ /**
+ * Get the appropriate timeout for the given job.
+ *
+ * @param \Illuminate\Contracts\Queue\Job|null $job
+ * @param WorkerOptions $options
+ * @return int
+ */
+ protected function timeoutForJob($job, WorkerOptions $options)
+ {
+ return $job && ! is_null($job->timeout()) ? $job->timeout() : $options->timeout;
+ }
+
+ /**
+ * Determine if the daemon should process on this iteration.
+ *
+ * @param WorkerOptions $options
+ * @return bool
+ */
+ protected function daemonShouldRun(WorkerOptions $options)
+ {
+ return ! (($this->manager->isDownForMaintenance() && ! $options->force) ||
+ $this->paused ||
+ $this->events->until(new Events\Looping) === false);
+ }
+
+ /**
+ * Pause the worker for the current loop.
+ *
+ * @param WorkerOptions $options
+ * @param int $lastRestart
+ * @return void
+ */
+ protected function pauseWorker(WorkerOptions $options, $lastRestart)
+ {
+ $this->sleep($options->sleep > 0 ? $options->sleep : 1);
+
+ $this->stopIfNecessary($options, $lastRestart);
+ }
+
+ /**
+ * Stop the process if necessary.
+ *
+ * @param WorkerOptions $options
+ * @param int $lastRestart
+ */
+ protected function stopIfNecessary(WorkerOptions $options, $lastRestart)
+ {
+ if ($this->shouldQuit) {
+ $this->kill();
+ }
+
+ if ($this->memoryExceeded($options->memory)) {
+ $this->stop(12);
+ } elseif ($this->queueShouldRestart($lastRestart)) {
+ $this->stop();
+ }
+ }
+
+ /**
+ * Process the next job on the queue.
+ *
+ * @param string $connectionName
+ * @param string $queue
+ * @param \Illuminate\Queue\WorkerOptions $options
+ * @return void
+ */
+ public function runNextJob($connectionName, $queue, WorkerOptions $options)
+ {
+ $job = $this->getNextJob(
+ $this->manager->connection($connectionName), $queue
+ );
+
+ // If we're able to pull a job off of the stack, we will process it and then return
+ // from this method. If there is no job on the queue, we will "sleep" the worker
+ // for the specified number of seconds, then keep processing jobs after sleep.
+ if ($job) {
+ return $this->runJob($job, $connectionName, $options);
+ }
+
+ $this->sleep($options->sleep);
+ }
+
+ /**
+ * Get the next job from the queue connection.
+ *
+ * @param \Illuminate\Contracts\Queue\Queue $connection
+ * @param string $queue
+ * @return \Illuminate\Contracts\Queue\Job|null
+ */
+ protected function getNextJob($connection, $queue)
+ {
+ try {
+ foreach (explode(',', $queue) as $queue) {
+ if (! is_null($job = $connection->pop($queue))) {
+ return $job;
+ }
+ }
+ } catch (Exception $e) {
+ $this->exceptions->report($e);
+
+ $this->stopWorkerIfLostConnection($e);
+ } catch (Throwable $e) {
+ $this->exceptions->report($e = new FatalThrowableError($e));
+
+ $this->stopWorkerIfLostConnection($e);
+ }
+ }
+
+ /**
+ * Process the given job.
+ *
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param string $connectionName
+ * @param \Illuminate\Queue\WorkerOptions $options
+ * @return void
+ */
+ protected function runJob($job, $connectionName, WorkerOptions $options)
+ {
+ try {
+ return $this->process($connectionName, $job, $options);
+ } catch (Exception $e) {
+ $this->exceptions->report($e);
+
+ $this->stopWorkerIfLostConnection($e);
+ } catch (Throwable $e) {
+ $this->exceptions->report($e = new FatalThrowableError($e));
+
+ $this->stopWorkerIfLostConnection($e);
+ }
+ }
+
+ /**
+ * Stop the worker if we have lost connection to a database.
+ *
+ * @param \Exception $e
+ * @return void
+ */
+ protected function stopWorkerIfLostConnection($e)
+ {
+ if ($this->causedByLostConnection($e)) {
+ $this->shouldQuit = true;
+ }
+ }
+
+ /**
+ * Process the given job from the queue.
+ *
+ * @param string $connectionName
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param \Illuminate\Queue\WorkerOptions $options
+ * @return void
+ *
+ * @throws \Throwable
+ */
+ public function process($connectionName, $job, WorkerOptions $options)
+ {
+ try {
+ // First we will raise the before job event and determine if the job has already ran
+ // over the its maximum attempt limit, which could primarily happen if the job is
+ // continually timing out and not actually throwing any exceptions from itself.
+ $this->raiseBeforeJobEvent($connectionName, $job);
+
+ $this->markJobAsFailedIfAlreadyExceedsMaxAttempts(
+ $connectionName, $job, (int) $options->maxTries
+ );
+
+ // Here we will fire off the job and let it process. We will catch any exceptions so
+ // they can be reported to the developers logs, etc. Once the job is finished the
+ // proper events will be fired to let any listeners know this job has finished.
+ $job->fire();
+
+ $this->raiseAfterJobEvent($connectionName, $job);
+ } catch (Exception $e) {
+ $this->handleJobException($connectionName, $job, $options, $e);
+ } catch (Throwable $e) {
+ $this->handleJobException(
+ $connectionName, $job, $options, new FatalThrowableError($e)
+ );
+ }
+ }
+
+ /**
+ * Handle an exception that occurred while the job was running.
+ *
+ * @param string $connectionName
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param \Illuminate\Queue\WorkerOptions $options
+ * @param \Exception $e
+ * @return void
+ *
+ * @throws \Exception
+ */
+ protected function handleJobException($connectionName, $job, WorkerOptions $options, $e)
+ {
+ try {
+ // First, we will go ahead and mark the job as failed if it will exceed the maximum
+ // attempts it is allowed to run the next time we process it. If so we will just
+ // go ahead and mark it as failed now so we do not have to release this again.
+ if (! $job->hasFailed()) {
+ $this->markJobAsFailedIfWillExceedMaxAttempts(
+ $connectionName, $job, (int) $options->maxTries, $e
+ );
+ }
+
+ $this->raiseExceptionOccurredJobEvent(
+ $connectionName, $job, $e
+ );
+ } finally {
+ // If we catch an exception, we will attempt to release the job back onto the queue
+ // so it is not lost entirely. This'll let the job be retried at a later time by
+ // another listener (or this same one). We will re-throw this exception after.
+ if (! $job->isDeleted() && ! $job->isReleased() && ! $job->hasFailed()) {
+ $job->release($options->delay);
+ }
+ }
+
+ throw $e;
+ }
+
+ /**
+ * Mark the given job as failed if it has exceeded the maximum allowed attempts.
+ *
+ * This will likely be because the job previously exceeded a timeout.
+ *
+ * @param string $connectionName
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param int $maxTries
+ * @return void
+ */
+ protected function markJobAsFailedIfAlreadyExceedsMaxAttempts($connectionName, $job, $maxTries)
+ {
+ $maxTries = ! is_null($job->maxTries()) ? $job->maxTries() : $maxTries;
+
+ if ($maxTries === 0 || $job->attempts() <= $maxTries) {
+ return;
+ }
+
+ $this->failJob($connectionName, $job, $e = new MaxAttemptsExceededException(
+ 'A queued job has been attempted too many times. The job may have previously timed out.'
+ ));
+
+ throw $e;
+ }
+
+ /**
+ * Mark the given job as failed if it has exceeded the maximum allowed attempts.
+ *
+ * @param string $connectionName
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param int $maxTries
+ * @param \Exception $e
+ * @return void
+ */
+ protected function markJobAsFailedIfWillExceedMaxAttempts($connectionName, $job, $maxTries, $e)
+ {
+ $maxTries = ! is_null($job->maxTries()) ? $job->maxTries() : $maxTries;
+
+ if ($maxTries > 0 && $job->attempts() >= $maxTries) {
+ $this->failJob($connectionName, $job, $e);
+ }
+ }
+
+ /**
+ * Mark the given job as failed and raise the relevant event.
+ *
+ * @param string $connectionName
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param \Exception $e
+ * @return void
+ */
+ protected function failJob($connectionName, $job, $e)
+ {
+ return FailingJob::handle($connectionName, $job, $e);
+ }
+
+ /**
+ * Raise the before queue job event.
+ *
+ * @param string $connectionName
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @return void
+ */
+ protected function raiseBeforeJobEvent($connectionName, $job)
+ {
+ $this->events->fire(new Events\JobProcessing(
+ $connectionName, $job
+ ));
+ }
+
+ /**
+ * Raise the after queue job event.
+ *
+ * @param string $connectionName
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @return void
+ */
+ protected function raiseAfterJobEvent($connectionName, $job)
+ {
+ $this->events->fire(new Events\JobProcessed(
+ $connectionName, $job
+ ));
+ }
+
+ /**
+ * Raise the exception occurred queue job event.
+ *
+ * @param string $connectionName
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param \Exception $e
+ * @return void
+ */
+ protected function raiseExceptionOccurredJobEvent($connectionName, $job, $e)
+ {
+ $this->events->fire(new Events\JobExceptionOccurred(
+ $connectionName, $job, $e
+ ));
+ }
+
+ /**
+ * Raise the failed queue job event.
+ *
+ * @param string $connectionName
+ * @param \Illuminate\Contracts\Queue\Job $job
+ * @param \Exception $e
+ * @return void
+ */
+ protected function raiseFailedJobEvent($connectionName, $job, $e)
+ {
+ $this->events->fire(new Events\JobFailed(
+ $connectionName, $job, $e
+ ));
+ }
+
+ /**
+ * Determine if the queue worker should restart.
+ *
+ * @param int|null $lastRestart
+ * @return bool
+ */
+ protected function queueShouldRestart($lastRestart)
+ {
+ return $this->getTimestampOfLastQueueRestart() != $lastRestart;
+ }
+
+ /**
+ * Get the last queue restart timestamp, or null.
+ *
+ * @return int|null
+ */
+ protected function getTimestampOfLastQueueRestart()
+ {
+ if ($this->cache) {
+ return $this->cache->get('illuminate:queue:restart');
+ }
+ }
+
+ /**
+ * Enable async signals for the process.
+ *
+ * @return void
+ */
+ protected function listenForSignals()
+ {
+ if ($this->supportsAsyncSignals()) {
+ pcntl_async_signals(true);
+
+ pcntl_signal(SIGTERM, function () {
+ $this->shouldQuit = true;
+ });
+
+ pcntl_signal(SIGUSR2, function () {
+ $this->paused = true;
+ });
+
+ pcntl_signal(SIGCONT, function () {
+ $this->paused = false;
+ });
+ }
+ }
+
+ /**
+ * Determine if "async" signals are supported.
+ *
+ * @return bool
+ */
+ protected function supportsAsyncSignals()
+ {
+ return version_compare(PHP_VERSION, '7.1.0') >= 0 &&
+ extension_loaded('pcntl');
+ }
+
+ /**
+ * Determine if the memory limit has been exceeded.
+ *
+ * @param int $memoryLimit
+ * @return bool
+ */
+ public function memoryExceeded($memoryLimit)
+ {
+ return (memory_get_usage() / 1024 / 1024) >= $memoryLimit;
+ }
+
+ /**
+ * Stop listening and bail out of the script.
+ *
+ * @param int $status
+ * @return void
+ */
+ public function stop($status = 0)
+ {
+ $this->events->fire(new Events\WorkerStopping);
+
+ exit($status);
+ }
+
+ /**
+ * Kill the process.
+ *
+ * @param int $status
+ * @return void
+ */
+ public function kill($status = 0)
+ {
+ if (extension_loaded('posix')) {
+ posix_kill(getmypid(), SIGKILL);
+ }
+
+ exit($status);
+ }
+
+ /**
+ * Sleep the script for a given number of seconds.
+ *
+ * @param int $seconds
+ * @return void
+ */
+ public function sleep($seconds)
+ {
+ sleep($seconds);
+ }
+
+ /**
+ * Set the cache repository implementation.
+ *
+ * @param \Illuminate\Contracts\Cache\Repository $cache
+ * @return void
+ */
+ public function setCache(CacheContract $cache)
+ {
+ $this->cache = $cache;
+ }
+
+ /**
+ * Get the queue manager instance.
+ *
+ * @return \Illuminate\Queue\QueueManager
+ */
+ public function getManager()
+ {
+ return $this->manager;
+ }
+
+ /**
+ * Set the queue manager instance.
+ *
+ * @param \Illuminate\Queue\QueueManager $manager
+ * @return void
+ */
+ public function setManager(QueueManager $manager)
+ {
+ $this->manager = $manager;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/WorkerOptions.php b/vendor/laravel/framework/src/Illuminate/Queue/WorkerOptions.php
new file mode 100644
index 000000000..ba35e751f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/WorkerOptions.php
@@ -0,0 +1,68 @@
+delay = $delay;
+ $this->sleep = $sleep;
+ $this->force = $force;
+ $this->memory = $memory;
+ $this->timeout = $timeout;
+ $this->maxTries = $maxTries;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Queue/composer.json b/vendor/laravel/framework/src/Illuminate/Queue/composer.json
new file mode 100644
index 000000000..29f970a88
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Queue/composer.json
@@ -0,0 +1,47 @@
+{
+ "name": "illuminate/queue",
+ "description": "The Illuminate Queue package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/console": "5.4.*",
+ "illuminate/container": "5.4.*",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/database": "5.4.*",
+ "illuminate/filesystem": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "nesbot/carbon": "~1.20",
+ "symfony/debug": "~3.2",
+ "symfony/process": "~3.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Queue\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "aws/aws-sdk-php": "Required to use the SQS queue driver (~3.0).",
+ "illuminate/redis": "Required to use the Redis queue driver (5.4.*).",
+ "pda/pheanstalk": "Required to use the Beanstalk queue driver (~3.0)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Redis/Connections/Connection.php b/vendor/laravel/framework/src/Illuminate/Redis/Connections/Connection.php
new file mode 100644
index 000000000..9cadad697
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Redis/Connections/Connection.php
@@ -0,0 +1,86 @@
+client;
+ }
+
+ /**
+ * Subscribe to a set of given channels for messages.
+ *
+ * @param array|string $channels
+ * @param \Closure $callback
+ * @return void
+ */
+ public function subscribe($channels, Closure $callback)
+ {
+ return $this->createSubscription($channels, $callback, __FUNCTION__);
+ }
+
+ /**
+ * Subscribe to a set of given channels with wildcards.
+ *
+ * @param array|string $channels
+ * @param \Closure $callback
+ * @return void
+ */
+ public function psubscribe($channels, Closure $callback)
+ {
+ return $this->createSubscription($channels, $callback, __FUNCTION__);
+ }
+
+ /**
+ * Run a command against the Redis database.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function command($method, array $parameters = [])
+ {
+ return $this->client->{$method}(...$parameters);
+ }
+
+ /**
+ * Pass other method calls down to the underlying client.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->command($method, $parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Redis/Connections/PhpRedisClusterConnection.php b/vendor/laravel/framework/src/Illuminate/Redis/Connections/PhpRedisClusterConnection.php
new file mode 100644
index 000000000..e246fe6a1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Redis/Connections/PhpRedisClusterConnection.php
@@ -0,0 +1,8 @@
+client = $client;
+ }
+
+ /**
+ * Returns the value of the given key.
+ *
+ * @param string $key
+ * @return string|null
+ */
+ public function get($key)
+ {
+ $result = $this->client->get($key);
+
+ return $result !== false ? $result : null;
+ }
+
+ /**
+ * Get the values of all the given keys.
+ *
+ * @param array $keys
+ * @return array
+ */
+ public function mget(array $keys)
+ {
+ return array_map(function ($value) {
+ return $value !== false ? $value : null;
+ }, $this->client->mget($keys));
+ }
+
+ /**
+ * Set the string value in argument as value of the key.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @param string|null $expireResolution
+ * @param int|null $expireTTL
+ * @param string|null $flag
+ * @return bool
+ */
+ public function set($key, $value, $expireResolution = null, $expireTTL = null, $flag = null)
+ {
+ return $this->command('set', [
+ $key,
+ $value,
+ $expireResolution ? [$expireResolution, $flag => $expireTTL] : null,
+ ]);
+ }
+
+ /**
+ * Removes the first count occurrences of the value element from the list.
+ *
+ * @param string $key
+ * @param int $count
+ * @param $value $value
+ * @return int|false
+ */
+ public function lrem($key, $count, $value)
+ {
+ return $this->command('lrem', [$key, $value, $count]);
+ }
+
+ /**
+ * Removes and returns a random element from the set value at key.
+ *
+ * @param string $key
+ * @param int|null $count
+ * @return mixed|false
+ */
+ public function spop($key, $count = null)
+ {
+ return $this->command('spop', [$key]);
+ }
+
+ /**
+ * Add one or more members to a sorted set or update its score if it already exists.
+ *
+ * @param string $key
+ * @param mixed $dictionary
+ * @return int
+ */
+ public function zadd($key, ...$dictionary)
+ {
+ if (count($dictionary) === 1) {
+ $_dictionary = [];
+
+ foreach ($dictionary[0] as $member => $score) {
+ $_dictionary[] = $score;
+ $_dictionary[] = $member;
+ }
+
+ $dictionary = $_dictionary;
+ }
+
+ return $this->client->zadd($key, ...$dictionary);
+ }
+
+ /**
+ * Execute commands in a pipeline.
+ *
+ * @param callable $callback
+ * @return array|\Redis
+ */
+ public function pipeline(callable $callback = null)
+ {
+ $pipeline = $this->client()->pipeline();
+
+ return is_null($callback)
+ ? $pipeline
+ : tap($pipeline, $callback)->exec();
+ }
+
+ /**
+ * Execute commands in a transaction.
+ *
+ * @param callable $callback
+ * @return array|\Redis
+ */
+ public function transaction(callable $callback = null)
+ {
+ $transaction = $this->client()->multi();
+
+ return is_null($callback)
+ ? $transaction
+ : tap($transaction, $callback)->exec();
+ }
+
+ /**
+ * Evaluate a LUA script serverside, from the SHA1 hash of the script instead of the script itself.
+ *
+ * @param string $script
+ * @param int $numkeys
+ * @param mixed $arguments
+ * @return mixed
+ */
+ public function evalsha($script, $numkeys, ...$arguments)
+ {
+ return $this->command('evalsha', [
+ $this->script('load', $script), $arguments, $numkeys,
+ ]);
+ }
+
+ /**
+ * Proxy a call to the eval function of PhpRedis.
+ *
+ * @param array $parameters
+ * @return mixed
+ */
+ protected function proxyToEval(array $parameters)
+ {
+ return $this->command('eval', [
+ isset($parameters[0]) ? $parameters[0] : null,
+ array_slice($parameters, 2),
+ isset($parameters[1]) ? $parameters[1] : null,
+ ]);
+ }
+
+ /**
+ * Subscribe to a set of given channels for messages.
+ *
+ * @param array|string $channels
+ * @param \Closure $callback
+ * @return void
+ */
+ public function subscribe($channels, Closure $callback)
+ {
+ $this->client->subscribe((array) $channels, function ($redis, $channel, $message) use ($callback) {
+ $callback($message, $channel);
+ });
+ }
+
+ /**
+ * Subscribe to a set of given channels with wildcards.
+ *
+ * @param array|string $channels
+ * @param \Closure $callback
+ * @return void
+ */
+ public function psubscribe($channels, Closure $callback)
+ {
+ $this->client->psubscribe((array) $channels, function ($redis, $pattern, $channel, $message) use ($callback) {
+ $callback($message, $channel);
+ });
+ }
+
+ /**
+ * Subscribe to a set of given channels for messages.
+ *
+ * @param array|string $channels
+ * @param \Closure $callback
+ * @param string $method
+ * @return void
+ */
+ public function createSubscription($channels, Closure $callback, $method = 'subscribe')
+ {
+ //
+ }
+
+ /**
+ * Execute a raw command.
+ *
+ * @param array $parameters
+ * @return mixed
+ */
+ public function executeRaw(array $parameters)
+ {
+ return $this->command('rawCommand', $parameters);
+ }
+
+ /**
+ * Disconnects from the Redis instance.
+ *
+ * @return void
+ */
+ public function disconnect()
+ {
+ $this->client->close();
+ }
+
+ /**
+ * Pass other method calls down to the underlying client.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ $method = strtolower($method);
+
+ if ($method == 'eval') {
+ return $this->proxyToEval($parameters);
+ }
+
+ if ($method == 'zrangebyscore' || $method == 'zrevrangebyscore') {
+ $parameters = array_map(function ($parameter) {
+ return is_array($parameter) ? array_change_key_case($parameter) : $parameter;
+ }, $parameters);
+ }
+
+ return parent::__call($method, $parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Redis/Connections/PredisClusterConnection.php b/vendor/laravel/framework/src/Illuminate/Redis/Connections/PredisClusterConnection.php
new file mode 100644
index 000000000..399be1ea7
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Redis/Connections/PredisClusterConnection.php
@@ -0,0 +1,8 @@
+client = $client;
+ }
+
+ /**
+ * Subscribe to a set of given channels for messages.
+ *
+ * @param array|string $channels
+ * @param \Closure $callback
+ * @param string $method
+ * @return void
+ */
+ public function createSubscription($channels, Closure $callback, $method = 'subscribe')
+ {
+ $loop = $this->pubSubLoop();
+
+ call_user_func_array([$loop, $method], (array) $channels);
+
+ foreach ($loop as $message) {
+ if ($message->kind === 'message' || $message->kind === 'pmessage') {
+ call_user_func($callback, $message->payload, $message->channel);
+ }
+ }
+
+ unset($loop);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Redis/Connectors/PhpRedisConnector.php b/vendor/laravel/framework/src/Illuminate/Redis/Connectors/PhpRedisConnector.php
new file mode 100644
index 000000000..970a770df
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Redis/Connectors/PhpRedisConnector.php
@@ -0,0 +1,117 @@
+createClient(array_merge(
+ $config, $options, Arr::pull($config, 'options', [])
+ )));
+ }
+
+ /**
+ * Create a new clustered Predis connection.
+ *
+ * @param array $config
+ * @param array $clusterOptions
+ * @param array $options
+ * @return \Illuminate\Redis\Connections\PhpRedisClusterConnection
+ */
+ public function connectToCluster(array $config, array $clusterOptions, array $options)
+ {
+ $options = array_merge($options, $clusterOptions, Arr::pull($config, 'options', []));
+
+ return new PhpRedisClusterConnection($this->createRedisClusterInstance(
+ array_map([$this, 'buildClusterConnectionString'], $config), $options
+ ));
+ }
+
+ /**
+ * Build a single cluster seed string from array.
+ *
+ * @param array $server
+ * @return string
+ */
+ protected function buildClusterConnectionString(array $server)
+ {
+ return $server['host'].':'.$server['port'].'?'.http_build_query(Arr::only($server, [
+ 'database', 'password', 'prefix', 'read_timeout',
+ ]));
+ }
+
+ /**
+ * Create the Redis client instance.
+ *
+ * @param array $config
+ * @return \Redis
+ */
+ protected function createClient(array $config)
+ {
+ return tap(new Redis, function ($client) use ($config) {
+ $this->establishConnection($client, $config);
+
+ if (! empty($config['password'])) {
+ $client->auth($config['password']);
+ }
+
+ if (! empty($config['database'])) {
+ $client->select($config['database']);
+ }
+
+ if (! empty($config['prefix'])) {
+ $client->setOption(Redis::OPT_PREFIX, $config['prefix']);
+ }
+
+ if (! empty($config['read_timeout'])) {
+ $client->setOption(Redis::OPT_READ_TIMEOUT, $config['read_timeout']);
+ }
+ });
+ }
+
+ /**
+ * Establish a connection with the Redis host.
+ *
+ * @param \Redis $client
+ * @param array $config
+ * @return void
+ */
+ protected function establishConnection($client, array $config)
+ {
+ $client->{Arr::get($config, 'persistent', false) === true ? 'pconnect' : 'connect'}(
+ $config['host'], $config['port'], Arr::get($config, 'timeout', 0)
+ );
+ }
+
+ /**
+ * Create a new redis cluster instance.
+ *
+ * @param array $servers
+ * @param array $options
+ * @return \RedisCluster
+ */
+ protected function createRedisClusterInstance(array $servers, array $options)
+ {
+ return new RedisCluster(
+ null,
+ array_values($servers),
+ Arr::get($options, 'timeout', 0),
+ Arr::get($options, 'read_timeout', 0),
+ isset($options['persistent']) && $options['persistent']
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Redis/Connectors/PredisConnector.php b/vendor/laravel/framework/src/Illuminate/Redis/Connectors/PredisConnector.php
new file mode 100644
index 000000000..8b1a46b19
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Redis/Connectors/PredisConnector.php
@@ -0,0 +1,44 @@
+ 10.0], $options, Arr::pull($config, 'options', [])
+ );
+
+ return new PredisConnection(new Client($config, $formattedOptions));
+ }
+
+ /**
+ * Create a new clustered Predis connection.
+ *
+ * @param array $config
+ * @param array $clusterOptions
+ * @param array $options
+ * @return \Illuminate\Redis\Connections\PredisClusterConnection
+ */
+ public function connectToCluster(array $config, array $clusterOptions, array $options)
+ {
+ $clusterSpecificOptions = Arr::pull($config, 'options', []);
+
+ return new PredisClusterConnection(new Client(array_values($config), array_merge(
+ $options, $clusterOptions, $clusterSpecificOptions
+ )));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Redis/RedisManager.php b/vendor/laravel/framework/src/Illuminate/Redis/RedisManager.php
new file mode 100644
index 000000000..e16927f1b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Redis/RedisManager.php
@@ -0,0 +1,132 @@
+driver = $driver;
+ $this->config = $config;
+ }
+
+ /**
+ * Get a Redis connection by name.
+ *
+ * @param string|null $name
+ * @return \Illuminate\Redis\Connections\Connection
+ */
+ public function connection($name = null)
+ {
+ $name = $name ?: 'default';
+
+ if (isset($this->connections[$name])) {
+ return $this->connections[$name];
+ }
+
+ return $this->connections[$name] = $this->resolve($name);
+ }
+
+ /**
+ * Resolve the given connection by name.
+ *
+ * @param string|null $name
+ * @return \Illuminate\Redis\Connections\Connection
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function resolve($name = null)
+ {
+ $name = $name ?: 'default';
+
+ $options = Arr::get($this->config, 'options', []);
+
+ if (isset($this->config[$name])) {
+ return $this->connector()->connect($this->config[$name], $options);
+ }
+
+ if (isset($this->config['clusters'][$name])) {
+ return $this->resolveCluster($name);
+ }
+
+ throw new InvalidArgumentException(
+ "Redis connection [{$name}] not configured."
+ );
+ }
+
+ /**
+ * Resolve the given cluster connection by name.
+ *
+ * @param string $name
+ * @return \Illuminate\Redis\Connections\Connection
+ */
+ protected function resolveCluster($name)
+ {
+ $clusterOptions = Arr::get($this->config, 'clusters.options', []);
+
+ return $this->connector()->connectToCluster(
+ $this->config['clusters'][$name], $clusterOptions, Arr::get($this->config, 'options', [])
+ );
+ }
+
+ /**
+ * Get the connector instance for the current driver.
+ *
+ * @return \Illuminate\Redis\Connectors\PhpRedisConnector|\Illuminate\Redis\Connectors\PredisConnector
+ */
+ protected function connector()
+ {
+ switch ($this->driver) {
+ case 'predis':
+ return new Connectors\PredisConnector;
+ case 'phpredis':
+ return new Connectors\PhpRedisConnector;
+ }
+ }
+
+ /**
+ * Pass methods onto the default Redis connection.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->connection()->{$method}(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Redis/RedisServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Redis/RedisServiceProvider.php
new file mode 100644
index 000000000..20d78e603
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Redis/RedisServiceProvider.php
@@ -0,0 +1,44 @@
+app->singleton('redis', function ($app) {
+ $config = $app->make('config')->get('database.redis');
+
+ return new RedisManager(Arr::pull($config, 'client', 'predis'), $config);
+ });
+
+ $this->app->bind('redis.connection', function ($app) {
+ return $app['redis']->connection();
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return ['redis', 'redis.connection'];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Redis/composer.json b/vendor/laravel/framework/src/Illuminate/Redis/composer.json
new file mode 100644
index 000000000..ac41ba3d7
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Redis/composer.json
@@ -0,0 +1,36 @@
+{
+ "name": "illuminate/redis",
+ "description": "The Illuminate Redis package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "predis/predis": "~1.0"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Redis\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Console/ControllerMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Routing/Console/ControllerMakeCommand.php
new file mode 100644
index 000000000..4ce15afd9
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Console/ControllerMakeCommand.php
@@ -0,0 +1,172 @@
+option('parent')) {
+ return __DIR__.'/stubs/controller.nested.stub';
+ } elseif ($this->option('model')) {
+ return __DIR__.'/stubs/controller.model.stub';
+ } elseif ($this->option('resource')) {
+ return __DIR__.'/stubs/controller.stub';
+ }
+
+ return __DIR__.'/stubs/controller.plain.stub';
+ }
+
+ /**
+ * Get the default namespace for the class.
+ *
+ * @param string $rootNamespace
+ * @return string
+ */
+ protected function getDefaultNamespace($rootNamespace)
+ {
+ return $rootNamespace.'\Http\Controllers';
+ }
+
+ /**
+ * Build the class with the given name.
+ *
+ * Remove the base controller import if we are already in base namespace.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function buildClass($name)
+ {
+ $controllerNamespace = $this->getNamespace($name);
+
+ $replace = [];
+
+ if ($this->option('parent')) {
+ $replace = $this->buildParentReplacements();
+ }
+
+ if ($this->option('model')) {
+ $replace = $this->buildModelReplacements($replace);
+ }
+
+ $replace["use {$controllerNamespace}\Controller;\n"] = '';
+
+ return str_replace(
+ array_keys($replace), array_values($replace), parent::buildClass($name)
+ );
+ }
+
+ /**
+ * Build the replacements for a parent controller.
+ *
+ * @return array
+ */
+ protected function buildParentReplacements()
+ {
+ $parentModelClass = $this->parseModel($this->option('parent'));
+
+ if (! class_exists($parentModelClass)) {
+ if ($this->confirm("A {$parentModelClass} model does not exist. Do you want to generate it?", true)) {
+ $this->call('make:model', ['name' => $parentModelClass]);
+ }
+ }
+
+ return [
+ 'ParentDummyFullModelClass' => $parentModelClass,
+ 'ParentDummyModelClass' => class_basename($parentModelClass),
+ 'ParentDummyModelVariable' => lcfirst(class_basename($parentModelClass)),
+ ];
+ }
+
+ /**
+ * Build the model replacement values.
+ *
+ * @param array $replace
+ * @return array
+ */
+ protected function buildModelReplacements(array $replace)
+ {
+ $modelClass = $this->parseModel($this->option('model'));
+
+ if (! class_exists($modelClass)) {
+ if ($this->confirm("A {$modelClass} model does not exist. Do you want to generate it?", true)) {
+ $this->call('make:model', ['name' => $modelClass]);
+ }
+ }
+
+ return array_merge($replace, [
+ 'DummyFullModelClass' => $modelClass,
+ 'DummyModelClass' => class_basename($modelClass),
+ 'DummyModelVariable' => lcfirst(class_basename($modelClass)),
+ ]);
+ }
+
+ /**
+ * Get the fully-qualified model class name.
+ *
+ * @param string $model
+ * @return string
+ */
+ protected function parseModel($model)
+ {
+ if (preg_match('([^A-Za-z0-9_/\\\\])', $model)) {
+ throw new InvalidArgumentException('Model name contains invalid characters.');
+ }
+
+ $model = trim(str_replace('/', '\\', $model), '\\');
+
+ if (! Str::startsWith($model, $rootNamespace = $this->laravel->getNamespace())) {
+ $model = $rootNamespace.$model;
+ }
+
+ return $model;
+ }
+
+ /**
+ * Get the console command options.
+ *
+ * @return array
+ */
+ protected function getOptions()
+ {
+ return [
+ ['model', 'm', InputOption::VALUE_OPTIONAL, 'Generate a resource controller for the given model.'],
+
+ ['resource', 'r', InputOption::VALUE_NONE, 'Generate a resource controller class.'],
+
+ ['parent', 'p', InputOption::VALUE_OPTIONAL, 'Generate a nested resource controller class.'],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Console/MiddlewareMakeCommand.php b/vendor/laravel/framework/src/Illuminate/Routing/Console/MiddlewareMakeCommand.php
new file mode 100644
index 000000000..e41813d32
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Console/MiddlewareMakeCommand.php
@@ -0,0 +1,50 @@
+middleware[] = [
+ 'middleware' => $m,
+ 'options' => &$options,
+ ];
+ }
+
+ return new ControllerMiddlewareOptions($options);
+ }
+
+ /**
+ * Get the middleware assigned to the controller.
+ *
+ * @return array
+ */
+ public function getMiddleware()
+ {
+ return $this->middleware;
+ }
+
+ /**
+ * Execute an action on the controller.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ public function callAction($method, $parameters)
+ {
+ return call_user_func_array([$this, $method], $parameters);
+ }
+
+ /**
+ * Handle calls to missing methods on the controller.
+ *
+ * @param array $parameters
+ * @return mixed
+ *
+ * @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException
+ */
+ public function missingMethod($parameters = [])
+ {
+ throw new NotFoundHttpException('Controller method not found.');
+ }
+
+ /**
+ * Handle calls to missing methods on the controller.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ *
+ * @throws \BadMethodCallException
+ */
+ public function __call($method, $parameters)
+ {
+ throw new BadMethodCallException("Method [{$method}] does not exist.");
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php b/vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php
new file mode 100644
index 000000000..979c4b5ec
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php
@@ -0,0 +1,80 @@
+container = $container;
+ }
+
+ /**
+ * Dispatch a request to a given controller and method.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @param mixed $controller
+ * @param string $method
+ * @return mixed
+ */
+ public function dispatch(Route $route, $controller, $method)
+ {
+ $parameters = $this->resolveClassMethodDependencies(
+ $route->parametersWithoutNulls(), $controller, $method
+ );
+
+ if (method_exists($controller, 'callAction')) {
+ return $controller->callAction($method, $parameters);
+ }
+
+ return $controller->{$method}(...array_values($parameters));
+ }
+
+ /**
+ * Get the middleware for the controller instance.
+ *
+ * @param \Illuminate\Routing\Controller $controller
+ * @param string $method
+ * @return array
+ */
+ public static function getMiddleware($controller, $method)
+ {
+ if (! method_exists($controller, 'getMiddleware')) {
+ return [];
+ }
+
+ return collect($controller->getMiddleware())->reject(function ($data) use ($method) {
+ return static::methodExcludedByOptions($method, $data['options']);
+ })->pluck('middleware')->all();
+ }
+
+ /**
+ * Determine if the given options exclude a particular method.
+ *
+ * @param string $method
+ * @param array $options
+ * @return bool
+ */
+ protected static function methodExcludedByOptions($method, array $options)
+ {
+ return (isset($options['only']) && ! in_array($method, (array) $options['only'])) ||
+ (! empty($options['except']) && in_array($method, (array) $options['except']));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/ControllerMiddlewareOptions.php b/vendor/laravel/framework/src/Illuminate/Routing/ControllerMiddlewareOptions.php
new file mode 100644
index 000000000..13ef1898d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/ControllerMiddlewareOptions.php
@@ -0,0 +1,50 @@
+options = &$options;
+ }
+
+ /**
+ * Set the controller methods the middleware should apply to.
+ *
+ * @param array|string|dynamic $methods
+ * @return $this
+ */
+ public function only($methods)
+ {
+ $this->options['only'] = is_array($methods) ? $methods : func_get_args();
+
+ return $this;
+ }
+
+ /**
+ * Set the controller methods the middleware should exclude.
+ *
+ * @param array|string|dynamic $methods
+ * @return $this
+ */
+ public function except($methods)
+ {
+ $this->options['except'] = is_array($methods) ? $methods : func_get_args();
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Events/RouteMatched.php b/vendor/laravel/framework/src/Illuminate/Routing/Events/RouteMatched.php
new file mode 100644
index 000000000..c84860717
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Events/RouteMatched.php
@@ -0,0 +1,33 @@
+route = $route;
+ $this->request = $request;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Exceptions/UrlGenerationException.php b/vendor/laravel/framework/src/Illuminate/Routing/Exceptions/UrlGenerationException.php
new file mode 100644
index 000000000..1853b2aff
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Exceptions/UrlGenerationException.php
@@ -0,0 +1,19 @@
+getName()}] [URI: {$route->uri()}].");
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/ImplicitRouteBinding.php b/vendor/laravel/framework/src/Illuminate/Routing/ImplicitRouteBinding.php
new file mode 100644
index 000000000..f357a24b1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/ImplicitRouteBinding.php
@@ -0,0 +1,58 @@
+parameters();
+
+ foreach ($route->signatureParameters(Model::class) as $parameter) {
+ if (! $parameterName = static::getParameterName($parameter->name, $parameters)) {
+ continue;
+ }
+
+ $parameterValue = $parameters[$parameterName];
+
+ if ($parameterValue instanceof Model) {
+ continue;
+ }
+
+ $model = $container->make($parameter->getClass()->name);
+
+ $route->setParameter($parameterName, $model->where(
+ $model->getRouteKeyName(), $parameterValue
+ )->firstOrFail());
+ }
+ }
+
+ /**
+ * Return the parameter name if it exists in the given parameters.
+ *
+ * @param string $name
+ * @param array $parameters
+ * @return string|null
+ */
+ protected static function getParameterName($name, $parameters)
+ {
+ if (array_key_exists($name, $parameters)) {
+ return $name;
+ }
+
+ $snakedName = snake_case($name);
+
+ if (array_key_exists($snakedName, $parameters)) {
+ return $snakedName;
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Matching/HostValidator.php b/vendor/laravel/framework/src/Illuminate/Routing/Matching/HostValidator.php
new file mode 100644
index 000000000..76f9d878e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Matching/HostValidator.php
@@ -0,0 +1,25 @@
+getCompiled()->getHostRegex())) {
+ return true;
+ }
+
+ return preg_match($route->getCompiled()->getHostRegex(), $request->getHost());
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Matching/MethodValidator.php b/vendor/laravel/framework/src/Illuminate/Routing/Matching/MethodValidator.php
new file mode 100644
index 000000000..f9cf155d8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Matching/MethodValidator.php
@@ -0,0 +1,21 @@
+getMethod(), $route->methods());
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Matching/SchemeValidator.php b/vendor/laravel/framework/src/Illuminate/Routing/Matching/SchemeValidator.php
new file mode 100644
index 000000000..fd5d5af8f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Matching/SchemeValidator.php
@@ -0,0 +1,27 @@
+httpOnly()) {
+ return ! $request->secure();
+ } elseif ($route->secure()) {
+ return $request->secure();
+ }
+
+ return true;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Matching/UriValidator.php b/vendor/laravel/framework/src/Illuminate/Routing/Matching/UriValidator.php
new file mode 100644
index 000000000..6a54d1296
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Matching/UriValidator.php
@@ -0,0 +1,23 @@
+path() == '/' ? '/' : '/'.$request->path();
+
+ return preg_match($route->getCompiled()->getRegex(), rawurldecode($path));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Matching/ValidatorInterface.php b/vendor/laravel/framework/src/Illuminate/Routing/Matching/ValidatorInterface.php
new file mode 100644
index 000000000..0f178f135
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Matching/ValidatorInterface.php
@@ -0,0 +1,18 @@
+router = $router;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @return mixed
+ */
+ public function handle($request, Closure $next)
+ {
+ $this->router->substituteBindings($route = $request->route());
+
+ $this->router->substituteImplicitBindings($route);
+
+ return $next($request);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Middleware/ThrottleRequests.php b/vendor/laravel/framework/src/Illuminate/Routing/Middleware/ThrottleRequests.php
new file mode 100644
index 000000000..5d0af90d1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Middleware/ThrottleRequests.php
@@ -0,0 +1,130 @@
+limiter = $limiter;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @param int $maxAttempts
+ * @param float|int $decayMinutes
+ * @return mixed
+ */
+ public function handle($request, Closure $next, $maxAttempts = 60, $decayMinutes = 1)
+ {
+ $key = $this->resolveRequestSignature($request);
+
+ if ($this->limiter->tooManyAttempts($key, $maxAttempts, $decayMinutes)) {
+ return $this->buildResponse($key, $maxAttempts);
+ }
+
+ $this->limiter->hit($key, $decayMinutes);
+
+ $response = $next($request);
+
+ return $this->addHeaders(
+ $response, $maxAttempts,
+ $this->calculateRemainingAttempts($key, $maxAttempts)
+ );
+ }
+
+ /**
+ * Resolve request signature.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return string
+ */
+ protected function resolveRequestSignature($request)
+ {
+ return $request->fingerprint();
+ }
+
+ /**
+ * Create a 'too many attempts' response.
+ *
+ * @param string $key
+ * @param int $maxAttempts
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function buildResponse($key, $maxAttempts)
+ {
+ $response = new Response('Too Many Attempts.', 429);
+
+ $retryAfter = $this->limiter->availableIn($key);
+
+ return $this->addHeaders(
+ $response, $maxAttempts,
+ $this->calculateRemainingAttempts($key, $maxAttempts, $retryAfter),
+ $retryAfter
+ );
+ }
+
+ /**
+ * Add the limit header information to the given response.
+ *
+ * @param \Symfony\Component\HttpFoundation\Response $response
+ * @param int $maxAttempts
+ * @param int $remainingAttempts
+ * @param int|null $retryAfter
+ * @return \Symfony\Component\HttpFoundation\Response
+ */
+ protected function addHeaders(Response $response, $maxAttempts, $remainingAttempts, $retryAfter = null)
+ {
+ $headers = [
+ 'X-RateLimit-Limit' => $maxAttempts,
+ 'X-RateLimit-Remaining' => $remainingAttempts,
+ ];
+
+ if (! is_null($retryAfter)) {
+ $headers['Retry-After'] = $retryAfter;
+ $headers['X-RateLimit-Reset'] = Carbon::now()->getTimestamp() + $retryAfter;
+ }
+
+ $response->headers->add($headers);
+
+ return $response;
+ }
+
+ /**
+ * Calculate the number of remaining attempts.
+ *
+ * @param string $key
+ * @param int $maxAttempts
+ * @param int|null $retryAfter
+ * @return int
+ */
+ protected function calculateRemainingAttempts($key, $maxAttempts, $retryAfter = null)
+ {
+ if (is_null($retryAfter)) {
+ return $this->limiter->retriesLeft($key, $maxAttempts);
+ }
+
+ return 0;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/MiddlewareNameResolver.php b/vendor/laravel/framework/src/Illuminate/Routing/MiddlewareNameResolver.php
new file mode 100644
index 000000000..3ccf1ac4e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/MiddlewareNameResolver.php
@@ -0,0 +1,85 @@
+handleException($passable, $e);
+ } catch (Throwable $e) {
+ return $this->handleException($passable, new FatalThrowableError($e));
+ }
+ };
+ }
+
+ /**
+ * Get a Closure that represents a slice of the application onion.
+ *
+ * @return \Closure
+ */
+ protected function carry()
+ {
+ return function ($stack, $pipe) {
+ return function ($passable) use ($stack, $pipe) {
+ try {
+ $slice = parent::carry();
+
+ $callable = $slice($stack, $pipe);
+
+ return $callable($passable);
+ } catch (Exception $e) {
+ return $this->handleException($passable, $e);
+ } catch (Throwable $e) {
+ return $this->handleException($passable, new FatalThrowableError($e));
+ }
+ };
+ };
+ }
+
+ /**
+ * Handle the given exception.
+ *
+ * @param mixed $passable
+ * @param \Exception $e
+ * @return mixed
+ *
+ * @throws \Exception
+ */
+ protected function handleException($passable, Exception $e)
+ {
+ if (! $this->container->bound(ExceptionHandler::class) || ! $passable instanceof Request) {
+ throw $e;
+ }
+
+ $handler = $this->container->make(ExceptionHandler::class);
+
+ $handler->report($e);
+
+ $response = $handler->render($passable, $e);
+
+ if (method_exists($response, 'withException')) {
+ $response->withException($e);
+ }
+
+ return $response;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Redirector.php b/vendor/laravel/framework/src/Illuminate/Routing/Redirector.php
new file mode 100644
index 000000000..59d6a9850
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Redirector.php
@@ -0,0 +1,210 @@
+generator = $generator;
+ }
+
+ /**
+ * Create a new redirect response to the "home" route.
+ *
+ * @param int $status
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function home($status = 302)
+ {
+ return $this->to($this->generator->route('home'), $status);
+ }
+
+ /**
+ * Create a new redirect response to the previous location.
+ *
+ * @param int $status
+ * @param array $headers
+ * @param mixed $fallback
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function back($status = 302, $headers = [], $fallback = false)
+ {
+ return $this->createRedirect($this->generator->previous($fallback), $status, $headers);
+ }
+
+ /**
+ * Create a new redirect response to the current URI.
+ *
+ * @param int $status
+ * @param array $headers
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function refresh($status = 302, $headers = [])
+ {
+ return $this->to($this->generator->getRequest()->path(), $status, $headers);
+ }
+
+ /**
+ * Create a new redirect response, while putting the current URL in the session.
+ *
+ * @param string $path
+ * @param int $status
+ * @param array $headers
+ * @param bool $secure
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function guest($path, $status = 302, $headers = [], $secure = null)
+ {
+ $this->session->put('url.intended', $this->generator->full());
+
+ return $this->to($path, $status, $headers, $secure);
+ }
+
+ /**
+ * Create a new redirect response to the previously intended location.
+ *
+ * @param string $default
+ * @param int $status
+ * @param array $headers
+ * @param bool $secure
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function intended($default = '/', $status = 302, $headers = [], $secure = null)
+ {
+ $path = $this->session->pull('url.intended', $default);
+
+ return $this->to($path, $status, $headers, $secure);
+ }
+
+ /**
+ * Create a new redirect response to the given path.
+ *
+ * @param string $path
+ * @param int $status
+ * @param array $headers
+ * @param bool $secure
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function to($path, $status = 302, $headers = [], $secure = null)
+ {
+ return $this->createRedirect($this->generator->to($path, [], $secure), $status, $headers);
+ }
+
+ /**
+ * Create a new redirect response to an external URL (no validation).
+ *
+ * @param string $path
+ * @param int $status
+ * @param array $headers
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function away($path, $status = 302, $headers = [])
+ {
+ return $this->createRedirect($path, $status, $headers);
+ }
+
+ /**
+ * Create a new redirect response to the given HTTPS path.
+ *
+ * @param string $path
+ * @param int $status
+ * @param array $headers
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function secure($path, $status = 302, $headers = [])
+ {
+ return $this->to($path, $status, $headers, true);
+ }
+
+ /**
+ * Create a new redirect response to a named route.
+ *
+ * @param string $route
+ * @param array $parameters
+ * @param int $status
+ * @param array $headers
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function route($route, $parameters = [], $status = 302, $headers = [])
+ {
+ return $this->to($this->generator->route($route, $parameters), $status, $headers);
+ }
+
+ /**
+ * Create a new redirect response to a controller action.
+ *
+ * @param string $action
+ * @param array $parameters
+ * @param int $status
+ * @param array $headers
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function action($action, $parameters = [], $status = 302, $headers = [])
+ {
+ return $this->to($this->generator->action($action, $parameters), $status, $headers);
+ }
+
+ /**
+ * Create a new redirect response.
+ *
+ * @param string $path
+ * @param int $status
+ * @param array $headers
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ protected function createRedirect($path, $status, $headers)
+ {
+ return tap(new RedirectResponse($path, $status, $headers), function ($redirect) {
+ if (isset($this->session)) {
+ $redirect->setSession($this->session);
+ }
+
+ $redirect->setRequest($this->generator->getRequest());
+ });
+ }
+
+ /**
+ * Get the URL generator instance.
+ *
+ * @return \Illuminate\Routing\UrlGenerator
+ */
+ public function getUrlGenerator()
+ {
+ return $this->generator;
+ }
+
+ /**
+ * Set the active session store.
+ *
+ * @param \Illuminate\Session\Store $session
+ * @return void
+ */
+ public function setSession(SessionStore $session)
+ {
+ $this->session = $session;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/ResourceRegistrar.php b/vendor/laravel/framework/src/Illuminate/Routing/ResourceRegistrar.php
new file mode 100644
index 000000000..5209e9e92
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/ResourceRegistrar.php
@@ -0,0 +1,440 @@
+ 'create',
+ 'edit' => 'edit',
+ ];
+
+ /**
+ * Create a new resource registrar instance.
+ *
+ * @param \Illuminate\Routing\Router $router
+ * @return void
+ */
+ public function __construct(Router $router)
+ {
+ $this->router = $router;
+ }
+
+ /**
+ * Route a resource to a controller.
+ *
+ * @param string $name
+ * @param string $controller
+ * @param array $options
+ * @return void
+ */
+ public function register($name, $controller, array $options = [])
+ {
+ if (isset($options['parameters']) && ! isset($this->parameters)) {
+ $this->parameters = $options['parameters'];
+ }
+
+ // If the resource name contains a slash, we will assume the developer wishes to
+ // register these resource routes with a prefix so we will set that up out of
+ // the box so they don't have to mess with it. Otherwise, we will continue.
+ if (Str::contains($name, '/')) {
+ $this->prefixedResource($name, $controller, $options);
+
+ return;
+ }
+
+ // We need to extract the base resource from the resource name. Nested resources
+ // are supported in the framework, but we need to know what name to use for a
+ // place-holder on the route parameters, which should be the base resources.
+ $base = $this->getResourceWildcard(last(explode('.', $name)));
+
+ $defaults = $this->resourceDefaults;
+
+ foreach ($this->getResourceMethods($defaults, $options) as $m) {
+ $this->{'addResource'.ucfirst($m)}($name, $base, $controller, $options);
+ }
+ }
+
+ /**
+ * Build a set of prefixed resource routes.
+ *
+ * @param string $name
+ * @param string $controller
+ * @param array $options
+ * @return void
+ */
+ protected function prefixedResource($name, $controller, array $options)
+ {
+ list($name, $prefix) = $this->getResourcePrefix($name);
+
+ // We need to extract the base resource from the resource name. Nested resources
+ // are supported in the framework, but we need to know what name to use for a
+ // place-holder on the route parameters, which should be the base resources.
+ $callback = function ($me) use ($name, $controller, $options) {
+ $me->resource($name, $controller, $options);
+ };
+
+ return $this->router->group(compact('prefix'), $callback);
+ }
+
+ /**
+ * Extract the resource and prefix from a resource name.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function getResourcePrefix($name)
+ {
+ $segments = explode('/', $name);
+
+ // To get the prefix, we will take all of the name segments and implode them on
+ // a slash. This will generate a proper URI prefix for us. Then we take this
+ // last segment, which will be considered the final resources name we use.
+ $prefix = implode('/', array_slice($segments, 0, -1));
+
+ return [end($segments), $prefix];
+ }
+
+ /**
+ * Get the applicable resource methods.
+ *
+ * @param array $defaults
+ * @param array $options
+ * @return array
+ */
+ protected function getResourceMethods($defaults, $options)
+ {
+ if (isset($options['only'])) {
+ return array_intersect($defaults, (array) $options['only']);
+ } elseif (isset($options['except'])) {
+ return array_diff($defaults, (array) $options['except']);
+ }
+
+ return $defaults;
+ }
+
+ /**
+ * Add the index method for a resourceful route.
+ *
+ * @param string $name
+ * @param string $base
+ * @param string $controller
+ * @param array $options
+ * @return \Illuminate\Routing\Route
+ */
+ protected function addResourceIndex($name, $base, $controller, $options)
+ {
+ $uri = $this->getResourceUri($name);
+
+ $action = $this->getResourceAction($name, $controller, 'index', $options);
+
+ return $this->router->get($uri, $action);
+ }
+
+ /**
+ * Add the create method for a resourceful route.
+ *
+ * @param string $name
+ * @param string $base
+ * @param string $controller
+ * @param array $options
+ * @return \Illuminate\Routing\Route
+ */
+ protected function addResourceCreate($name, $base, $controller, $options)
+ {
+ $uri = $this->getResourceUri($name).'/'.static::$verbs['create'];
+
+ $action = $this->getResourceAction($name, $controller, 'create', $options);
+
+ return $this->router->get($uri, $action);
+ }
+
+ /**
+ * Add the store method for a resourceful route.
+ *
+ * @param string $name
+ * @param string $base
+ * @param string $controller
+ * @param array $options
+ * @return \Illuminate\Routing\Route
+ */
+ protected function addResourceStore($name, $base, $controller, $options)
+ {
+ $uri = $this->getResourceUri($name);
+
+ $action = $this->getResourceAction($name, $controller, 'store', $options);
+
+ return $this->router->post($uri, $action);
+ }
+
+ /**
+ * Add the show method for a resourceful route.
+ *
+ * @param string $name
+ * @param string $base
+ * @param string $controller
+ * @param array $options
+ * @return \Illuminate\Routing\Route
+ */
+ protected function addResourceShow($name, $base, $controller, $options)
+ {
+ $uri = $this->getResourceUri($name).'/{'.$base.'}';
+
+ $action = $this->getResourceAction($name, $controller, 'show', $options);
+
+ return $this->router->get($uri, $action);
+ }
+
+ /**
+ * Add the edit method for a resourceful route.
+ *
+ * @param string $name
+ * @param string $base
+ * @param string $controller
+ * @param array $options
+ * @return \Illuminate\Routing\Route
+ */
+ protected function addResourceEdit($name, $base, $controller, $options)
+ {
+ $uri = $this->getResourceUri($name).'/{'.$base.'}/'.static::$verbs['edit'];
+
+ $action = $this->getResourceAction($name, $controller, 'edit', $options);
+
+ return $this->router->get($uri, $action);
+ }
+
+ /**
+ * Add the update method for a resourceful route.
+ *
+ * @param string $name
+ * @param string $base
+ * @param string $controller
+ * @param array $options
+ * @return \Illuminate\Routing\Route
+ */
+ protected function addResourceUpdate($name, $base, $controller, $options)
+ {
+ $uri = $this->getResourceUri($name).'/{'.$base.'}';
+
+ $action = $this->getResourceAction($name, $controller, 'update', $options);
+
+ return $this->router->match(['PUT', 'PATCH'], $uri, $action);
+ }
+
+ /**
+ * Add the destroy method for a resourceful route.
+ *
+ * @param string $name
+ * @param string $base
+ * @param string $controller
+ * @param array $options
+ * @return \Illuminate\Routing\Route
+ */
+ protected function addResourceDestroy($name, $base, $controller, $options)
+ {
+ $uri = $this->getResourceUri($name).'/{'.$base.'}';
+
+ $action = $this->getResourceAction($name, $controller, 'destroy', $options);
+
+ return $this->router->delete($uri, $action);
+ }
+
+ /**
+ * Get the base resource URI for a given resource.
+ *
+ * @param string $resource
+ * @return string
+ */
+ public function getResourceUri($resource)
+ {
+ if (! Str::contains($resource, '.')) {
+ return $resource;
+ }
+
+ // Once we have built the base URI, we'll remove the parameter holder for this
+ // base resource name so that the individual route adders can suffix these
+ // paths however they need to, as some do not have any parameters at all.
+ $segments = explode('.', $resource);
+
+ $uri = $this->getNestedResourceUri($segments);
+
+ return str_replace('/{'.$this->getResourceWildcard(end($segments)).'}', '', $uri);
+ }
+
+ /**
+ * Get the URI for a nested resource segment array.
+ *
+ * @param array $segments
+ * @return string
+ */
+ protected function getNestedResourceUri(array $segments)
+ {
+ // We will spin through the segments and create a place-holder for each of the
+ // resource segments, as well as the resource itself. Then we should get an
+ // entire string for the resource URI that contains all nested resources.
+ return implode('/', array_map(function ($s) {
+ return $s.'/{'.$this->getResourceWildcard($s).'}';
+ }, $segments));
+ }
+
+ /**
+ * Format a resource parameter for usage.
+ *
+ * @param string $value
+ * @return string
+ */
+ public function getResourceWildcard($value)
+ {
+ if (isset($this->parameters[$value])) {
+ $value = $this->parameters[$value];
+ } elseif (isset(static::$parameterMap[$value])) {
+ $value = static::$parameterMap[$value];
+ } elseif ($this->parameters === 'singular' || static::$singularParameters) {
+ $value = Str::singular($value);
+ }
+
+ return str_replace('-', '_', $value);
+ }
+
+ /**
+ * Get the action array for a resource route.
+ *
+ * @param string $resource
+ * @param string $controller
+ * @param string $method
+ * @param array $options
+ * @return array
+ */
+ protected function getResourceAction($resource, $controller, $method, $options)
+ {
+ $name = $this->getResourceRouteName($resource, $method, $options);
+
+ $action = ['as' => $name, 'uses' => $controller.'@'.$method];
+
+ if (isset($options['middleware'])) {
+ $action['middleware'] = $options['middleware'];
+ }
+
+ return $action;
+ }
+
+ /**
+ * Get the name for a given resource.
+ *
+ * @param string $resource
+ * @param string $method
+ * @param array $options
+ * @return string
+ */
+ protected function getResourceRouteName($resource, $method, $options)
+ {
+ $name = $resource;
+
+ // If the names array has been provided to us we will check for an entry in the
+ // array first. We will also check for the specific method within this array
+ // so the names may be specified on a more "granular" level using methods.
+ if (isset($options['names'])) {
+ if (is_string($options['names'])) {
+ $name = $options['names'];
+ } elseif (isset($options['names'][$method])) {
+ return $options['names'][$method];
+ }
+ }
+
+ // If a global prefix has been assigned to all names for this resource, we will
+ // grab that so we can prepend it onto the name when we create this name for
+ // the resource action. Otherwise we'll just use an empty string for here.
+ $prefix = isset($options['as']) ? $options['as'].'.' : '';
+
+ return trim(sprintf('%s%s.%s', $prefix, $name, $method), '.');
+ }
+
+ /**
+ * Set or unset the unmapped global parameters to singular.
+ *
+ * @param bool $singular
+ * @return void
+ */
+ public static function singularParameters($singular = true)
+ {
+ static::$singularParameters = (bool) $singular;
+ }
+
+ /**
+ * Get the global parameter map.
+ *
+ * @return array
+ */
+ public static function getParameters()
+ {
+ return static::$parameterMap;
+ }
+
+ /**
+ * Set the global parameter mapping.
+ *
+ * @param array $parameters
+ * @return void
+ */
+ public static function setParameters(array $parameters = [])
+ {
+ static::$parameterMap = $parameters;
+ }
+
+ /**
+ * Get or set the action verbs used in the resource URIs.
+ *
+ * @param array $verbs
+ * @return array
+ */
+ public static function verbs(array $verbs = [])
+ {
+ if (empty($verbs)) {
+ return static::$verbs;
+ } else {
+ static::$verbs = array_merge(static::$verbs, $verbs);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/ResponseFactory.php b/vendor/laravel/framework/src/Illuminate/Routing/ResponseFactory.php
new file mode 100644
index 000000000..0fe015122
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/ResponseFactory.php
@@ -0,0 +1,215 @@
+view = $view;
+ $this->redirector = $redirector;
+ }
+
+ /**
+ * Return a new response from the application.
+ *
+ * @param string $content
+ * @param int $status
+ * @param array $headers
+ * @return \Illuminate\Http\Response
+ */
+ public function make($content = '', $status = 200, array $headers = [])
+ {
+ return new Response($content, $status, $headers);
+ }
+
+ /**
+ * Return a new view response from the application.
+ *
+ * @param string $view
+ * @param array $data
+ * @param int $status
+ * @param array $headers
+ * @return \Illuminate\Http\Response
+ */
+ public function view($view, $data = [], $status = 200, array $headers = [])
+ {
+ return $this->make($this->view->make($view, $data), $status, $headers);
+ }
+
+ /**
+ * Return a new JSON response from the application.
+ *
+ * @param mixed $data
+ * @param int $status
+ * @param array $headers
+ * @param int $options
+ * @return \Illuminate\Http\JsonResponse
+ */
+ public function json($data = [], $status = 200, array $headers = [], $options = 0)
+ {
+ return new JsonResponse($data, $status, $headers, $options);
+ }
+
+ /**
+ * Return a new JSONP response from the application.
+ *
+ * @param string $callback
+ * @param mixed $data
+ * @param int $status
+ * @param array $headers
+ * @param int $options
+ * @return \Illuminate\Http\JsonResponse
+ */
+ public function jsonp($callback, $data = [], $status = 200, array $headers = [], $options = 0)
+ {
+ return $this->json($data, $status, $headers, $options)->setCallback($callback);
+ }
+
+ /**
+ * Return a new streamed response from the application.
+ *
+ * @param \Closure $callback
+ * @param int $status
+ * @param array $headers
+ * @return \Symfony\Component\HttpFoundation\StreamedResponse
+ */
+ public function stream($callback, $status = 200, array $headers = [])
+ {
+ return new StreamedResponse($callback, $status, $headers);
+ }
+
+ /**
+ * Create a new file download response.
+ *
+ * @param \SplFileInfo|string $file
+ * @param string $name
+ * @param array $headers
+ * @param string|null $disposition
+ * @return \Symfony\Component\HttpFoundation\BinaryFileResponse
+ */
+ public function download($file, $name = null, array $headers = [], $disposition = 'attachment')
+ {
+ $response = new BinaryFileResponse($file, 200, $headers, true, $disposition);
+
+ if (! is_null($name)) {
+ return $response->setContentDisposition($disposition, $name, str_replace('%', '', Str::ascii($name)));
+ }
+
+ return $response;
+ }
+
+ /**
+ * Return the raw contents of a binary file.
+ *
+ * @param \SplFileInfo|string $file
+ * @param array $headers
+ * @return \Symfony\Component\HttpFoundation\BinaryFileResponse
+ */
+ public function file($file, array $headers = [])
+ {
+ return new BinaryFileResponse($file, 200, $headers);
+ }
+
+ /**
+ * Create a new redirect response to the given path.
+ *
+ * @param string $path
+ * @param int $status
+ * @param array $headers
+ * @param bool|null $secure
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function redirectTo($path, $status = 302, $headers = [], $secure = null)
+ {
+ return $this->redirector->to($path, $status, $headers, $secure);
+ }
+
+ /**
+ * Create a new redirect response to a named route.
+ *
+ * @param string $route
+ * @param array $parameters
+ * @param int $status
+ * @param array $headers
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function redirectToRoute($route, $parameters = [], $status = 302, $headers = [])
+ {
+ return $this->redirector->route($route, $parameters, $status, $headers);
+ }
+
+ /**
+ * Create a new redirect response to a controller action.
+ *
+ * @param string $action
+ * @param array $parameters
+ * @param int $status
+ * @param array $headers
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function redirectToAction($action, $parameters = [], $status = 302, $headers = [])
+ {
+ return $this->redirector->action($action, $parameters, $status, $headers);
+ }
+
+ /**
+ * Create a new redirect response, while putting the current URL in the session.
+ *
+ * @param string $path
+ * @param int $status
+ * @param array $headers
+ * @param bool|null $secure
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function redirectGuest($path, $status = 302, $headers = [], $secure = null)
+ {
+ return $this->redirector->guest($path, $status, $headers, $secure);
+ }
+
+ /**
+ * Create a new redirect response to the previously intended location.
+ *
+ * @param string $default
+ * @param int $status
+ * @param array $headers
+ * @param bool|null $secure
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function redirectToIntended($default = '/', $status = 302, $headers = [], $secure = null)
+ {
+ return $this->redirector->intended($default, $status, $headers, $secure);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Route.php b/vendor/laravel/framework/src/Illuminate/Routing/Route.php
new file mode 100644
index 000000000..34149447c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Route.php
@@ -0,0 +1,835 @@
+uri = $uri;
+ $this->methods = (array) $methods;
+ $this->action = $this->parseAction($action);
+
+ if (in_array('GET', $this->methods) && ! in_array('HEAD', $this->methods)) {
+ $this->methods[] = 'HEAD';
+ }
+
+ if (isset($this->action['prefix'])) {
+ $this->prefix($this->action['prefix']);
+ }
+ }
+
+ /**
+ * Parse the route action into a standard array.
+ *
+ * @param callable|array|null $action
+ * @return array
+ *
+ * @throws \UnexpectedValueException
+ */
+ protected function parseAction($action)
+ {
+ return RouteAction::parse($this->uri, $action);
+ }
+
+ /**
+ * Run the route action and return the response.
+ *
+ * @return mixed
+ */
+ public function run()
+ {
+ $this->container = $this->container ?: new Container;
+
+ try {
+ if ($this->isControllerAction()) {
+ return $this->runController();
+ }
+
+ return $this->runCallable();
+ } catch (HttpResponseException $e) {
+ return $e->getResponse();
+ }
+ }
+
+ /**
+ * Checks whether the route's action is a controller.
+ *
+ * @return bool
+ */
+ protected function isControllerAction()
+ {
+ return is_string($this->action['uses']);
+ }
+
+ /**
+ * Run the route action and return the response.
+ *
+ * @return mixed
+ */
+ protected function runCallable()
+ {
+ $callable = $this->action['uses'];
+
+ return $callable(...array_values($this->resolveMethodDependencies(
+ $this->parametersWithoutNulls(), new ReflectionFunction($this->action['uses'])
+ )));
+ }
+
+ /**
+ * Run the route action and return the response.
+ *
+ * @return mixed
+ *
+ * @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException
+ */
+ protected function runController()
+ {
+ return (new ControllerDispatcher($this->container))->dispatch(
+ $this, $this->getController(), $this->getControllerMethod()
+ );
+ }
+
+ /**
+ * Get the controller instance for the route.
+ *
+ * @return mixed
+ */
+ public function getController()
+ {
+ $class = $this->parseControllerCallback()[0];
+
+ if (! $this->controller) {
+ $this->controller = $this->container->make($class);
+ }
+
+ return $this->controller;
+ }
+
+ /**
+ * Get the controller method used for the route.
+ *
+ * @return string
+ */
+ protected function getControllerMethod()
+ {
+ return $this->parseControllerCallback()[1];
+ }
+
+ /**
+ * Parse the controller.
+ *
+ * @return array
+ */
+ protected function parseControllerCallback()
+ {
+ return Str::parseCallback($this->action['uses']);
+ }
+
+ /**
+ * Determine if the route matches given request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param bool $includingMethod
+ * @return bool
+ */
+ public function matches(Request $request, $includingMethod = true)
+ {
+ $this->compileRoute();
+
+ foreach ($this->getValidators() as $validator) {
+ if (! $includingMethod && $validator instanceof MethodValidator) {
+ continue;
+ }
+
+ if (! $validator->matches($this, $request)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Compile the route into a Symfony CompiledRoute instance.
+ *
+ * @return void
+ */
+ protected function compileRoute()
+ {
+ if (! $this->compiled) {
+ $this->compiled = (new RouteCompiler($this))->compile();
+ }
+
+ return $this->compiled;
+ }
+
+ /**
+ * Bind the route to a given request for execution.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return $this
+ */
+ public function bind(Request $request)
+ {
+ $this->compileRoute();
+
+ $this->parameters = (new RouteParameterBinder($this))
+ ->parameters($request);
+
+ return $this;
+ }
+
+ /**
+ * Determine if the route has parameters.
+ *
+ * @return bool
+ */
+ public function hasParameters()
+ {
+ return isset($this->parameters);
+ }
+
+ /**
+ * Determine a given parameter exists from the route.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function hasParameter($name)
+ {
+ if ($this->hasParameters()) {
+ return array_key_exists($name, $this->parameters());
+ }
+
+ return false;
+ }
+
+ /**
+ * Get a given parameter from the route.
+ *
+ * @param string $name
+ * @param mixed $default
+ * @return string|object
+ */
+ public function parameter($name, $default = null)
+ {
+ return Arr::get($this->parameters(), $name, $default);
+ }
+
+ /**
+ * Set a parameter to the given value.
+ *
+ * @param string $name
+ * @param mixed $value
+ * @return void
+ */
+ public function setParameter($name, $value)
+ {
+ $this->parameters();
+
+ $this->parameters[$name] = $value;
+ }
+
+ /**
+ * Unset a parameter on the route if it is set.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function forgetParameter($name)
+ {
+ $this->parameters();
+
+ unset($this->parameters[$name]);
+ }
+
+ /**
+ * Get the key / value list of parameters for the route.
+ *
+ * @return array
+ *
+ * @throws \LogicException
+ */
+ public function parameters()
+ {
+ if (isset($this->parameters)) {
+ return $this->parameters;
+ }
+
+ throw new LogicException('Route is not bound.');
+ }
+
+ /**
+ * Get the key / value list of parameters without null values.
+ *
+ * @return array
+ */
+ public function parametersWithoutNulls()
+ {
+ return array_filter($this->parameters(), function ($p) {
+ return ! is_null($p);
+ });
+ }
+
+ /**
+ * Get all of the parameter names for the route.
+ *
+ * @return array
+ */
+ public function parameterNames()
+ {
+ if (isset($this->parameterNames)) {
+ return $this->parameterNames;
+ }
+
+ return $this->parameterNames = $this->compileParameterNames();
+ }
+
+ /**
+ * Get the parameter names for the route.
+ *
+ * @return array
+ */
+ protected function compileParameterNames()
+ {
+ preg_match_all('/\{(.*?)\}/', $this->domain().$this->uri, $matches);
+
+ return array_map(function ($m) {
+ return trim($m, '?');
+ }, $matches[1]);
+ }
+
+ /**
+ * Get the parameters that are listed in the route / controller signature.
+ *
+ * @param string|null $subClass
+ * @return array
+ */
+ public function signatureParameters($subClass = null)
+ {
+ return RouteSignatureParameters::fromAction($this->action, $subClass);
+ }
+
+ /**
+ * Set a default value for the route.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return $this
+ */
+ public function defaults($key, $value)
+ {
+ $this->defaults[$key] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set a regular expression requirement on the route.
+ *
+ * @param array|string $name
+ * @param string $expression
+ * @return $this
+ */
+ public function where($name, $expression = null)
+ {
+ foreach ($this->parseWhere($name, $expression) as $name => $expression) {
+ $this->wheres[$name] = $expression;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Parse arguments to the where method into an array.
+ *
+ * @param array|string $name
+ * @param string $expression
+ * @return array
+ */
+ protected function parseWhere($name, $expression)
+ {
+ return is_array($name) ? $name : [$name => $expression];
+ }
+
+ /**
+ * Set a list of regular expression requirements on the route.
+ *
+ * @param array $wheres
+ * @return $this
+ */
+ protected function whereArray(array $wheres)
+ {
+ foreach ($wheres as $name => $expression) {
+ $this->where($name, $expression);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Get the HTTP verbs the route responds to.
+ *
+ * @return array
+ */
+ public function methods()
+ {
+ return $this->methods;
+ }
+
+ /**
+ * Determine if the route only responds to HTTP requests.
+ *
+ * @return bool
+ */
+ public function httpOnly()
+ {
+ return in_array('http', $this->action, true);
+ }
+
+ /**
+ * Determine if the route only responds to HTTPS requests.
+ *
+ * @return bool
+ */
+ public function httpsOnly()
+ {
+ return $this->secure();
+ }
+
+ /**
+ * Determine if the route only responds to HTTPS requests.
+ *
+ * @return bool
+ */
+ public function secure()
+ {
+ return in_array('https', $this->action, true);
+ }
+
+ /**
+ * Get the domain defined for the route.
+ *
+ * @return string|null
+ */
+ public function domain()
+ {
+ return isset($this->action['domain'])
+ ? str_replace(['http://', 'https://'], '', $this->action['domain']) : null;
+ }
+
+ /**
+ * Get the prefix of the route instance.
+ *
+ * @return string
+ */
+ public function getPrefix()
+ {
+ return isset($this->action['prefix']) ? $this->action['prefix'] : null;
+ }
+
+ /**
+ * Add a prefix to the route URI.
+ *
+ * @param string $prefix
+ * @return $this
+ */
+ public function prefix($prefix)
+ {
+ $uri = rtrim($prefix, '/').'/'.ltrim($this->uri, '/');
+
+ $this->uri = trim($uri, '/');
+
+ return $this;
+ }
+
+ /**
+ * Get the URI associated with the route.
+ *
+ * @return string
+ */
+ public function uri()
+ {
+ return $this->uri;
+ }
+
+ /**
+ * Set the URI that the route responds to.
+ *
+ * @param string $uri
+ * @return $this
+ */
+ public function setUri($uri)
+ {
+ $this->uri = $uri;
+
+ return $this;
+ }
+
+ /**
+ * Get the name of the route instance.
+ *
+ * @return string
+ */
+ public function getName()
+ {
+ return isset($this->action['as']) ? $this->action['as'] : null;
+ }
+
+ /**
+ * Add or change the route name.
+ *
+ * @param string $name
+ * @return $this
+ */
+ public function name($name)
+ {
+ $this->action['as'] = isset($this->action['as']) ? $this->action['as'].$name : $name;
+
+ return $this;
+ }
+
+ /**
+ * Determine whether the route's name matches the given name.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function named($name)
+ {
+ return $this->getName() === $name;
+ }
+
+ /**
+ * Set the handler for the route.
+ *
+ * @param \Closure|string $action
+ * @return $this
+ */
+ public function uses($action)
+ {
+ $action = is_string($action) ? $this->addGroupNamespaceToStringUses($action) : $action;
+
+ return $this->setAction(array_merge($this->action, $this->parseAction([
+ 'uses' => $action,
+ 'controller' => $action,
+ ])));
+ }
+
+ /**
+ * Parse a string based action for the "uses" fluent method.
+ *
+ * @param string $action
+ * @return string
+ */
+ protected function addGroupNamespaceToStringUses($action)
+ {
+ $groupStack = last($this->router->getGroupStack());
+
+ if (isset($groupStack['namespace']) && strpos($action, '\\') !== 0) {
+ return $groupStack['namespace'].'\\'.$action;
+ }
+
+ return $action;
+ }
+
+ /**
+ * Get the action name for the route.
+ *
+ * @return string
+ */
+ public function getActionName()
+ {
+ return isset($this->action['controller']) ? $this->action['controller'] : 'Closure';
+ }
+
+ /**
+ * Get the method name of the route action.
+ *
+ * @return string
+ */
+ public function getActionMethod()
+ {
+ return array_last(explode('@', $this->getActionName()));
+ }
+
+ /**
+ * Get the action array for the route.
+ *
+ * @return array
+ */
+ public function getAction()
+ {
+ return $this->action;
+ }
+
+ /**
+ * Set the action array for the route.
+ *
+ * @param array $action
+ * @return $this
+ */
+ public function setAction(array $action)
+ {
+ $this->action = $action;
+
+ return $this;
+ }
+
+ /**
+ * Get all middleware, including the ones from the controller.
+ *
+ * @return array
+ */
+ public function gatherMiddleware()
+ {
+ if (! is_null($this->computedMiddleware)) {
+ return $this->computedMiddleware;
+ }
+
+ $this->computedMiddleware = [];
+
+ return $this->computedMiddleware = array_unique(array_merge(
+ $this->middleware(), $this->controllerMiddleware()
+ ), SORT_REGULAR);
+ }
+
+ /**
+ * Get or set the middlewares attached to the route.
+ *
+ * @param array|string|null $middleware
+ * @return $this|array
+ */
+ public function middleware($middleware = null)
+ {
+ if (is_null($middleware)) {
+ return (array) Arr::get($this->action, 'middleware', []);
+ }
+
+ if (is_string($middleware)) {
+ $middleware = func_get_args();
+ }
+
+ $this->action['middleware'] = array_merge(
+ (array) Arr::get($this->action, 'middleware', []), $middleware
+ );
+
+ return $this;
+ }
+
+ /**
+ * Get the middleware for the route's controller.
+ *
+ * @return array
+ */
+ public function controllerMiddleware()
+ {
+ if (! $this->isControllerAction()) {
+ return [];
+ }
+
+ return ControllerDispatcher::getMiddleware(
+ $this->getController(), $this->getControllerMethod()
+ );
+ }
+
+ /**
+ * Get the route validators for the instance.
+ *
+ * @return array
+ */
+ public static function getValidators()
+ {
+ if (isset(static::$validators)) {
+ return static::$validators;
+ }
+
+ // To match the route, we will use a chain of responsibility pattern with the
+ // validator implementations. We will spin through each one making sure it
+ // passes and then we will know if the route as a whole matches request.
+ return static::$validators = [
+ new UriValidator, new MethodValidator,
+ new SchemeValidator, new HostValidator,
+ ];
+ }
+
+ /**
+ * Get the compiled version of the route.
+ *
+ * @return \Symfony\Component\Routing\CompiledRoute
+ */
+ public function getCompiled()
+ {
+ return $this->compiled;
+ }
+
+ /**
+ * Set the router instance on the route.
+ *
+ * @param \Illuminate\Routing\Router $router
+ * @return $this
+ */
+ public function setRouter(Router $router)
+ {
+ $this->router = $router;
+
+ return $this;
+ }
+
+ /**
+ * Set the container instance on the route.
+ *
+ * @param \Illuminate\Container\Container $container
+ * @return $this
+ */
+ public function setContainer(Container $container)
+ {
+ $this->container = $container;
+
+ return $this;
+ }
+
+ /**
+ * Prepare the route instance for serialization.
+ *
+ * @return void
+ *
+ * @throws \LogicException
+ */
+ public function prepareForSerialization()
+ {
+ if ($this->action['uses'] instanceof Closure) {
+ throw new LogicException("Unable to prepare route [{$this->uri}] for serialization. Uses Closure.");
+ }
+
+ $this->compileRoute();
+
+ unset($this->router, $this->container);
+ }
+
+ /**
+ * Dynamically access route parameters.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function __get($key)
+ {
+ return $this->parameter($key);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RouteAction.php b/vendor/laravel/framework/src/Illuminate/Routing/RouteAction.php
new file mode 100644
index 000000000..678806ba5
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RouteAction.php
@@ -0,0 +1,89 @@
+ $action];
+ }
+
+ // If no "uses" property has been set, we will dig through the array to find a
+ // Closure instance within this list. We will set the first Closure we come
+ // across into the "uses" property that will get fired off by this route.
+ elseif (! isset($action['uses'])) {
+ $action['uses'] = static::findCallable($action);
+ }
+
+ if (is_string($action['uses']) && ! Str::contains($action['uses'], '@')) {
+ $action['uses'] = static::makeInvokable($action['uses']);
+ }
+
+ return $action;
+ }
+
+ /**
+ * Get an action for a route that has no action.
+ *
+ * @param string $uri
+ * @return array
+ */
+ protected static function missingAction($uri)
+ {
+ return ['uses' => function () use ($uri) {
+ throw new LogicException("Route for [{$uri}] has no action.");
+ }];
+ }
+
+ /**
+ * Find the callable in an action array.
+ *
+ * @param array $action
+ * @return callable
+ */
+ protected static function findCallable(array $action)
+ {
+ return Arr::first($action, function ($value, $key) {
+ return is_callable($value) && is_numeric($key);
+ });
+ }
+
+ /**
+ * Make an action for an invokable controller.
+ *
+ * @param string $action
+ * @return string
+ */
+ protected static function makeInvokable($action)
+ {
+ if (! method_exists($action, '__invoke')) {
+ throw new UnexpectedValueException("Invalid route action: [{$action}].");
+ }
+
+ return $action.'@__invoke';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RouteBinding.php b/vendor/laravel/framework/src/Illuminate/Routing/RouteBinding.php
new file mode 100644
index 000000000..213753461
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RouteBinding.php
@@ -0,0 +1,82 @@
+make($class), $method];
+
+ return call_user_func($callable, $value, $route);
+ };
+ }
+
+ /**
+ * Create a Route model binding for a model.
+ *
+ * @param \Illuminate\Container\Container $container
+ * @param string $class
+ * @param \Closure|null $callback
+ * @return \Closure
+ */
+ public static function forModel($container, $class, $callback = null)
+ {
+ return function ($value) use ($container, $class, $callback) {
+ if (is_null($value)) {
+ return;
+ }
+
+ // For model binders, we will attempt to retrieve the models using the first
+ // method on the model instance. If we cannot retrieve the models we'll
+ // throw a not found exception otherwise we will return the instance.
+ $instance = $container->make($class);
+
+ if ($model = $instance->where($instance->getRouteKeyName(), $value)->first()) {
+ return $model;
+ }
+
+ // If a callback was supplied to the method we will call that to determine
+ // what we should do when the model is not found. This just gives these
+ // developer a little greater flexibility to decide what will happen.
+ if ($callback instanceof Closure) {
+ return call_user_func($callback, $value);
+ }
+
+ throw (new ModelNotFoundException)->setModel($class);
+ };
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RouteCollection.php b/vendor/laravel/framework/src/Illuminate/Routing/RouteCollection.php
new file mode 100644
index 000000000..74e6b164a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RouteCollection.php
@@ -0,0 +1,347 @@
+addToCollections($route);
+
+ $this->addLookups($route);
+
+ return $route;
+ }
+
+ /**
+ * Add the given route to the arrays of routes.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @return void
+ */
+ protected function addToCollections($route)
+ {
+ $domainAndUri = $route->domain().$route->uri();
+
+ foreach ($route->methods() as $method) {
+ $this->routes[$method][$domainAndUri] = $route;
+ }
+
+ $this->allRoutes[$method.$domainAndUri] = $route;
+ }
+
+ /**
+ * Add the route to any look-up tables if necessary.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @return void
+ */
+ protected function addLookups($route)
+ {
+ // If the route has a name, we will add it to the name look-up table so that we
+ // will quickly be able to find any route associate with a name and not have
+ // to iterate through every route every time we need to perform a look-up.
+ $action = $route->getAction();
+
+ if (isset($action['as'])) {
+ $this->nameList[$action['as']] = $route;
+ }
+
+ // When the route is routing to a controller we will also store the action that
+ // is used by the route. This will let us reverse route to controllers while
+ // processing a request and easily generate URLs to the given controllers.
+ if (isset($action['controller'])) {
+ $this->addToActionList($action, $route);
+ }
+ }
+
+ /**
+ * Add a route to the controller action dictionary.
+ *
+ * @param array $action
+ * @param \Illuminate\Routing\Route $route
+ * @return void
+ */
+ protected function addToActionList($action, $route)
+ {
+ $this->actionList[trim($action['controller'], '\\')] = $route;
+ }
+
+ /**
+ * Refresh the name look-up table.
+ *
+ * This is done in case any names are fluently defined or if routes are overwritten.
+ *
+ * @return void
+ */
+ public function refreshNameLookups()
+ {
+ $this->nameList = [];
+
+ foreach ($this->allRoutes as $route) {
+ if ($route->getName()) {
+ $this->nameList[$route->getName()] = $route;
+ }
+ }
+ }
+
+ /**
+ * Refresh the action look-up table.
+ *
+ * This is done in case any actions are overwritten with new controllers.
+ *
+ * @return void
+ */
+ public function refreshActionLookups()
+ {
+ $this->actionList = [];
+
+ foreach ($this->allRoutes as $route) {
+ if (isset($route->getAction()['controller'])) {
+ $this->addToActionList($route->getAction(), $route);
+ }
+ }
+ }
+
+ /**
+ * Find the first route matching a given request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Routing\Route
+ *
+ * @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException
+ */
+ public function match(Request $request)
+ {
+ $routes = $this->get($request->getMethod());
+
+ // First, we will see if we can find a matching route for this current request
+ // method. If we can, great, we can just return it so that it can be called
+ // by the consumer. Otherwise we will check for routes with another verb.
+ $route = $this->matchAgainstRoutes($routes, $request);
+
+ if (! is_null($route)) {
+ return $route->bind($request);
+ }
+
+ // If no route was found we will now check if a matching route is specified by
+ // another HTTP verb. If it is we will need to throw a MethodNotAllowed and
+ // inform the user agent of which HTTP verb it should use for this route.
+ $others = $this->checkForAlternateVerbs($request);
+
+ if (count($others) > 0) {
+ return $this->getRouteForMethods($request, $others);
+ }
+
+ throw new NotFoundHttpException;
+ }
+
+ /**
+ * Determine if a route in the array matches the request.
+ *
+ * @param array $routes
+ * @param \Illuminate\http\Request $request
+ * @param bool $includingMethod
+ * @return \Illuminate\Routing\Route|null
+ */
+ protected function matchAgainstRoutes(array $routes, $request, $includingMethod = true)
+ {
+ return Arr::first($routes, function ($value) use ($request, $includingMethod) {
+ return $value->matches($request, $includingMethod);
+ });
+ }
+
+ /**
+ * Determine if any routes match on another HTTP verb.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return array
+ */
+ protected function checkForAlternateVerbs($request)
+ {
+ $methods = array_diff(Router::$verbs, [$request->getMethod()]);
+
+ // Here we will spin through all verbs except for the current request verb and
+ // check to see if any routes respond to them. If they do, we will return a
+ // proper error response with the correct headers on the response string.
+ $others = [];
+
+ foreach ($methods as $method) {
+ if (! is_null($this->matchAgainstRoutes($this->get($method), $request, false))) {
+ $others[] = $method;
+ }
+ }
+
+ return $others;
+ }
+
+ /**
+ * Get a route (if necessary) that responds when other available methods are present.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param array $methods
+ * @return \Illuminate\Routing\Route
+ *
+ * @throws \Symfony\Component\HttpKernel\Exception\MethodNotAllowedHttpException
+ */
+ protected function getRouteForMethods($request, array $methods)
+ {
+ if ($request->method() == 'OPTIONS') {
+ return (new Route('OPTIONS', $request->path(), function () use ($methods) {
+ return new Response('', 200, ['Allow' => implode(',', $methods)]);
+ }))->bind($request);
+ }
+
+ $this->methodNotAllowed($methods);
+ }
+
+ /**
+ * Throw a method not allowed HTTP exception.
+ *
+ * @param array $others
+ * @return void
+ *
+ * @throws \Symfony\Component\HttpKernel\Exception\MethodNotAllowedHttpException
+ */
+ protected function methodNotAllowed(array $others)
+ {
+ throw new MethodNotAllowedHttpException($others);
+ }
+
+ /**
+ * Get routes from the collection by method.
+ *
+ * @param string|null $method
+ * @return array
+ */
+ public function get($method = null)
+ {
+ return is_null($method) ? $this->getRoutes() : Arr::get($this->routes, $method, []);
+ }
+
+ /**
+ * Determine if the route collection contains a given named route.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function hasNamedRoute($name)
+ {
+ return ! is_null($this->getByName($name));
+ }
+
+ /**
+ * Get a route instance by its name.
+ *
+ * @param string $name
+ * @return \Illuminate\Routing\Route|null
+ */
+ public function getByName($name)
+ {
+ return isset($this->nameList[$name]) ? $this->nameList[$name] : null;
+ }
+
+ /**
+ * Get a route instance by its controller action.
+ *
+ * @param string $action
+ * @return \Illuminate\Routing\Route|null
+ */
+ public function getByAction($action)
+ {
+ return isset($this->actionList[$action]) ? $this->actionList[$action] : null;
+ }
+
+ /**
+ * Get all of the routes in the collection.
+ *
+ * @return array
+ */
+ public function getRoutes()
+ {
+ return array_values($this->allRoutes);
+ }
+
+ /**
+ * Get all of the routes keyed by their HTTP verb / method.
+ *
+ * @return array
+ */
+ public function getRoutesByMethod()
+ {
+ return $this->routes;
+ }
+
+ /**
+ * Get all of the routes keyed by their name.
+ *
+ * @return array
+ */
+ public function getRoutesByName()
+ {
+ return $this->nameList;
+ }
+
+ /**
+ * Get an iterator for the items.
+ *
+ * @return \ArrayIterator
+ */
+ public function getIterator()
+ {
+ return new ArrayIterator($this->getRoutes());
+ }
+
+ /**
+ * Count the number of items in the collection.
+ *
+ * @return int
+ */
+ public function count()
+ {
+ return count($this->getRoutes());
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RouteCompiler.php b/vendor/laravel/framework/src/Illuminate/Routing/RouteCompiler.php
new file mode 100644
index 000000000..b4e213c08
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RouteCompiler.php
@@ -0,0 +1,54 @@
+route = $route;
+ }
+
+ /**
+ * Compile the route.
+ *
+ * @return \Symfony\Component\Routing\CompiledRoute
+ */
+ public function compile()
+ {
+ $optionals = $this->getOptionalParameters();
+
+ $uri = preg_replace('/\{(\w+?)\?\}/', '{$1}', $this->route->uri());
+
+ return (
+ new SymfonyRoute($uri, $optionals, $this->route->wheres, [], $this->route->domain() ?: '')
+ )->compile();
+ }
+
+ /**
+ * Get the optional parameters for the route.
+ *
+ * @return array
+ */
+ protected function getOptionalParameters()
+ {
+ preg_match_all('/\{(\w+?)\?\}/', $this->route->uri(), $matches);
+
+ return isset($matches[1]) ? array_fill_keys($matches[1], null) : [];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RouteDependencyResolverTrait.php b/vendor/laravel/framework/src/Illuminate/Routing/RouteDependencyResolverTrait.php
new file mode 100644
index 000000000..704585f07
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RouteDependencyResolverTrait.php
@@ -0,0 +1,109 @@
+resolveMethodDependencies(
+ $parameters, new ReflectionMethod($instance, $method)
+ );
+ }
+
+ /**
+ * Resolve the given method's type-hinted dependencies.
+ *
+ * @param array $parameters
+ * @param \ReflectionFunctionAbstract $reflector
+ * @return array
+ */
+ public function resolveMethodDependencies(array $parameters, ReflectionFunctionAbstract $reflector)
+ {
+ $instanceCount = 0;
+
+ $values = array_values($parameters);
+
+ foreach ($reflector->getParameters() as $key => $parameter) {
+ $instance = $this->transformDependency(
+ $parameter, $parameters
+ );
+
+ if (! is_null($instance)) {
+ $instanceCount++;
+
+ $this->spliceIntoParameters($parameters, $key, $instance);
+ } elseif (! isset($values[$key - $instanceCount]) &&
+ $parameter->isDefaultValueAvailable()) {
+ $this->spliceIntoParameters($parameters, $key, $parameter->getDefaultValue());
+ }
+ }
+
+ return $parameters;
+ }
+
+ /**
+ * Attempt to transform the given parameter into a class instance.
+ *
+ * @param \ReflectionParameter $parameter
+ * @param array $parameters
+ * @return mixed
+ */
+ protected function transformDependency(ReflectionParameter $parameter, $parameters)
+ {
+ $class = $parameter->getClass();
+
+ // If the parameter has a type-hinted class, we will check to see if it is already in
+ // the list of parameters. If it is we will just skip it as it is probably a model
+ // binding and we do not want to mess with those; otherwise, we resolve it here.
+ if ($class && ! $this->alreadyInParameters($class->name, $parameters)) {
+ return $this->container->make($class->name);
+ }
+ }
+
+ /**
+ * Determine if an object of the given class is in a list of parameters.
+ *
+ * @param string $class
+ * @param array $parameters
+ * @return bool
+ */
+ protected function alreadyInParameters($class, array $parameters)
+ {
+ return ! is_null(Arr::first($parameters, function ($value) use ($class) {
+ return $value instanceof $class;
+ }));
+ }
+
+ /**
+ * Splice the given value into the parameter list.
+ *
+ * @param array $parameters
+ * @param string $offset
+ * @param mixed $value
+ * @return void
+ */
+ protected function spliceIntoParameters(array &$parameters, $offset, $value)
+ {
+ array_splice(
+ $parameters, $offset, 0, [$value]
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RouteGroup.php b/vendor/laravel/framework/src/Illuminate/Routing/RouteGroup.php
new file mode 100644
index 000000000..7b5d4b557
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RouteGroup.php
@@ -0,0 +1,95 @@
+ static::formatNamespace($new, $old),
+ 'prefix' => static::formatPrefix($new, $old),
+ 'where' => static::formatWhere($new, $old),
+ ]);
+
+ return array_merge_recursive(Arr::except(
+ $old, ['namespace', 'prefix', 'where', 'as']
+ ), $new);
+ }
+
+ /**
+ * Format the namespace for the new group attributes.
+ *
+ * @param array $new
+ * @param array $old
+ * @return string|null
+ */
+ protected static function formatNamespace($new, $old)
+ {
+ if (isset($new['namespace'])) {
+ return isset($old['namespace'])
+ ? trim($old['namespace'], '\\').'\\'.trim($new['namespace'], '\\')
+ : trim($new['namespace'], '\\');
+ }
+
+ return isset($old['namespace']) ? $old['namespace'] : null;
+ }
+
+ /**
+ * Format the prefix for the new group attributes.
+ *
+ * @param array $new
+ * @param array $old
+ * @return string|null
+ */
+ protected static function formatPrefix($new, $old)
+ {
+ $old = Arr::get($old, 'prefix');
+
+ return isset($new['prefix']) ? trim($old, '/').'/'.trim($new['prefix'], '/') : $old;
+ }
+
+ /**
+ * Format the "wheres" for the new group attributes.
+ *
+ * @param array $new
+ * @param array $old
+ * @return array
+ */
+ protected static function formatWhere($new, $old)
+ {
+ return array_merge(
+ isset($old['where']) ? $old['where'] : [],
+ isset($new['where']) ? $new['where'] : []
+ );
+ }
+
+ /**
+ * Format the "as" clause of the new group attributes.
+ *
+ * @param array $new
+ * @param array $old
+ * @return array
+ */
+ protected static function formatAs($new, $old)
+ {
+ if (isset($old['as'])) {
+ $new['as'] = $old['as'].Arr::get($new, 'as', '');
+ }
+
+ return $new;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RouteParameterBinder.php b/vendor/laravel/framework/src/Illuminate/Routing/RouteParameterBinder.php
new file mode 100644
index 000000000..3f5fd2c98
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RouteParameterBinder.php
@@ -0,0 +1,120 @@
+route = $route;
+ }
+
+ /**
+ * Get the parameters for the route.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return array
+ */
+ public function parameters($request)
+ {
+ // If the route has a regular expression for the host part of the URI, we will
+ // compile that and get the parameter matches for this domain. We will then
+ // merge them into this parameters array so that this array is completed.
+ $parameters = $this->bindPathParameters($request);
+
+ // If the route has a regular expression for the host part of the URI, we will
+ // compile that and get the parameter matches for this domain. We will then
+ // merge them into this parameters array so that this array is completed.
+ if (! is_null($this->route->compiled->getHostRegex())) {
+ $parameters = $this->bindHostParameters(
+ $request, $parameters
+ );
+ }
+
+ return $this->replaceDefaults($parameters);
+ }
+
+ /**
+ * Get the parameter matches for the path portion of the URI.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return array
+ */
+ protected function bindPathParameters($request)
+ {
+ $path = '/'.ltrim($request->decodedPath(), '/');
+
+ preg_match($this->route->compiled->getRegex(), $path, $matches);
+
+ return $this->matchToKeys(array_slice($matches, 1));
+ }
+
+ /**
+ * Extract the parameter list from the host part of the request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param array $parameters
+ * @return array
+ */
+ protected function bindHostParameters($request, $parameters)
+ {
+ preg_match($this->route->compiled->getHostRegex(), $request->getHost(), $matches);
+
+ return array_merge($this->matchToKeys(array_slice($matches, 1)), $parameters);
+ }
+
+ /**
+ * Combine a set of parameter matches with the route's keys.
+ *
+ * @param array $matches
+ * @return array
+ */
+ protected function matchToKeys(array $matches)
+ {
+ if (empty($parameterNames = $this->route->parameterNames())) {
+ return [];
+ }
+
+ $parameters = array_intersect_key($matches, array_flip($parameterNames));
+
+ return array_filter($parameters, function ($value) {
+ return is_string($value) && strlen($value) > 0;
+ });
+ }
+
+ /**
+ * Replace null parameters with their defaults.
+ *
+ * @param array $parameters
+ * @return array
+ */
+ protected function replaceDefaults(array $parameters)
+ {
+ foreach ($parameters as $key => $value) {
+ $parameters[$key] = isset($value) ? $value : Arr::get($this->route->defaults, $key);
+ }
+
+ foreach ($this->route->defaults as $key => $value) {
+ if (! isset($parameters[$key])) {
+ $parameters[$key] = $value;
+ }
+ }
+
+ return $parameters;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RouteRegistrar.php b/vendor/laravel/framework/src/Illuminate/Routing/RouteRegistrar.php
new file mode 100644
index 000000000..221df9f29
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RouteRegistrar.php
@@ -0,0 +1,175 @@
+ 'as',
+ ];
+
+ /**
+ * Create a new route registrar instance.
+ *
+ * @param \Illuminate\Routing\Router $router
+ * @return void
+ */
+ public function __construct(Router $router)
+ {
+ $this->router = $router;
+ }
+
+ /**
+ * Set the value for a given attribute.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return $this
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function attribute($key, $value)
+ {
+ if (! in_array($key, $this->allowedAttributes)) {
+ throw new InvalidArgumentException("Attribute [{$key}] does not exist.");
+ }
+
+ $this->attributes[array_get($this->aliases, $key, $key)] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Route a resource to a controller.
+ *
+ * @param string $name
+ * @param string $controller
+ * @param array $options
+ * @return void
+ */
+ public function resource($name, $controller, array $options = [])
+ {
+ $this->router->resource($name, $controller, $this->attributes + $options);
+ }
+
+ /**
+ * Create a route group with shared attributes.
+ *
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public function group($callback)
+ {
+ $this->router->group($this->attributes, $callback);
+ }
+
+ /**
+ * Register a new route with the given verbs.
+ *
+ * @param array|string $methods
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ public function match($methods, $uri, $action = null)
+ {
+ return $this->router->match($methods, $uri, $this->compileAction($action));
+ }
+
+ /**
+ * Register a new route with the router.
+ *
+ * @param string $method
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ protected function registerRoute($method, $uri, $action = null)
+ {
+ if (! is_array($action)) {
+ $action = array_merge($this->attributes, $action ? ['uses' => $action] : []);
+ }
+
+ return $this->router->{$method}($uri, $this->compileAction($action));
+ }
+
+ /**
+ * Compile the action into an array including the attributes.
+ *
+ * @param \Closure|array|string|null $action
+ * @return array
+ */
+ protected function compileAction($action)
+ {
+ if (is_null($action)) {
+ return $this->attributes;
+ }
+
+ if (is_string($action) || $action instanceof Closure) {
+ $action = ['uses' => $action];
+ }
+
+ return array_merge($this->attributes, $action);
+ }
+
+ /**
+ * Dynamically handle calls into the route registrar.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return \Illuminate\Routing\Route|$this
+ */
+ public function __call($method, $parameters)
+ {
+ if (in_array($method, $this->passthru)) {
+ return $this->registerRoute($method, ...$parameters);
+ }
+
+ if (in_array($method, $this->allowedAttributes)) {
+ return $this->attribute($method, $parameters[0]);
+ }
+
+ throw new BadMethodCallException("Method [{$method}] does not exist.");
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RouteSignatureParameters.php b/vendor/laravel/framework/src/Illuminate/Routing/RouteSignatureParameters.php
new file mode 100644
index 000000000..c09baeb98
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RouteSignatureParameters.php
@@ -0,0 +1,45 @@
+getParameters();
+
+ return is_null($subClass) ? $parameters : array_filter($parameters, function ($p) use ($subClass) {
+ return $p->getClass() && $p->getClass()->isSubclassOf($subClass);
+ });
+ }
+
+ /**
+ * Get the parameters for the given class / method by string.
+ *
+ * @param string $uses
+ * @return array
+ */
+ protected static function fromClassMethodString($uses)
+ {
+ list($class, $method) = Str::parseCallback($uses);
+
+ if (! method_exists($class, $method) && is_callable($class, $method)) {
+ return [];
+ }
+
+ return (new ReflectionMethod($class, $method))->getParameters();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RouteUrlGenerator.php b/vendor/laravel/framework/src/Illuminate/Routing/RouteUrlGenerator.php
new file mode 100644
index 000000000..a60dc68cc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RouteUrlGenerator.php
@@ -0,0 +1,307 @@
+ '/',
+ '%40' => '@',
+ '%3A' => ':',
+ '%3B' => ';',
+ '%2C' => ',',
+ '%3D' => '=',
+ '%2B' => '+',
+ '%21' => '!',
+ '%2A' => '*',
+ '%7C' => '|',
+ '%3F' => '?',
+ '%26' => '&',
+ '%23' => '#',
+ '%25' => '%',
+ ];
+
+ /**
+ * Create a new Route URL generator.
+ *
+ * @param \Illuminate\Routing\UrlGenerator $url
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ public function __construct($url, $request)
+ {
+ $this->url = $url;
+ $this->request = $request;
+ }
+
+ /**
+ * Generate a URL for the given route.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @param array $parameters
+ * @param bool $absolute
+ * @return string
+ *
+ * @throws \Illuminate\Routing\Exceptions\UrlGenerationException
+ */
+ public function to($route, $parameters = [], $absolute = false)
+ {
+ $domain = $this->getRouteDomain($route, $parameters);
+
+ // First we will construct the entire URI including the root and query string. Once it
+ // has been constructed, we'll make sure we don't have any missing parameters or we
+ // will need to throw the exception to let the developers know one was not given.
+ $uri = $this->addQueryString($this->url->format(
+ $root = $this->replaceRootParameters($route, $domain, $parameters),
+ $this->replaceRouteParameters($route->uri(), $parameters)
+ ), $parameters);
+
+ if (preg_match('/\{.*?\}/', $uri)) {
+ throw UrlGenerationException::forMissingParameters($route);
+ }
+
+ // Once we have ensured that there are no missing parameters in the URI we will encode
+ // the URI and prepare it for returning to the developer. If the URI is supposed to
+ // be absolute, we will return it as-is. Otherwise we will remove the URL's root.
+ $uri = strtr(rawurlencode($uri), $this->dontEncode);
+
+ if (! $absolute) {
+ return '/'.ltrim(str_replace($root, '', $uri), '/');
+ }
+
+ return $uri;
+ }
+
+ /**
+ * Get the formatted domain for a given route.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @param array $parameters
+ * @return string
+ */
+ protected function getRouteDomain($route, &$parameters)
+ {
+ return $route->domain() ? $this->formatDomain($route, $parameters) : null;
+ }
+
+ /**
+ * Format the domain and port for the route and request.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @param array $parameters
+ * @return string
+ */
+ protected function formatDomain($route, &$parameters)
+ {
+ return $this->addPortToDomain(
+ $this->getRouteScheme($route).$route->domain()
+ );
+ }
+
+ /**
+ * Get the scheme for the given route.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @return string
+ */
+ protected function getRouteScheme($route)
+ {
+ if ($route->httpOnly()) {
+ return 'http://';
+ } elseif ($route->httpsOnly()) {
+ return 'https://';
+ } else {
+ return $this->url->formatScheme(null);
+ }
+ }
+
+ /**
+ * Add the port to the domain if necessary.
+ *
+ * @param string $domain
+ * @return string
+ */
+ protected function addPortToDomain($domain)
+ {
+ $secure = $this->request->isSecure();
+
+ $port = (int) $this->request->getPort();
+
+ return ($secure && $port === 443) || (! $secure && $port === 80)
+ ? $domain : $domain.':'.$port;
+ }
+
+ /**
+ * Replace the parameters on the root path.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @param string $domain
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceRootParameters($route, $domain, &$parameters)
+ {
+ $scheme = $this->getRouteScheme($route);
+
+ return $this->replaceRouteParameters(
+ $this->url->formatRoot($scheme, $domain), $parameters
+ );
+ }
+
+ /**
+ * Replace all of the wildcard parameters for a route path.
+ *
+ * @param string $path
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceRouteParameters($path, array &$parameters)
+ {
+ $path = $this->replaceNamedParameters($path, $parameters);
+
+ $path = preg_replace_callback('/\{.*?\}/', function ($match) use (&$parameters) {
+ return (empty($parameters) && ! Str::endsWith($match[0], '?}'))
+ ? $match[0]
+ : array_shift($parameters);
+ }, $path);
+
+ return trim(preg_replace('/\{.*?\?\}/', '', $path), '/');
+ }
+
+ /**
+ * Replace all of the named parameters in the path.
+ *
+ * @param string $path
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceNamedParameters($path, &$parameters)
+ {
+ return preg_replace_callback('/\{(.*?)\??\}/', function ($m) use (&$parameters) {
+ if (isset($parameters[$m[1]])) {
+ return Arr::pull($parameters, $m[1]);
+ } elseif (isset($this->defaultParameters[$m[1]])) {
+ return $this->defaultParameters[$m[1]];
+ } else {
+ return $m[0];
+ }
+ }, $path);
+ }
+
+ /**
+ * Add a query string to the URI.
+ *
+ * @param string $uri
+ * @param array $parameters
+ * @return mixed|string
+ */
+ protected function addQueryString($uri, array $parameters)
+ {
+ // If the URI has a fragment we will move it to the end of this URI since it will
+ // need to come after any query string that may be added to the URL else it is
+ // not going to be available. We will remove it then append it back on here.
+ if (! is_null($fragment = parse_url($uri, PHP_URL_FRAGMENT))) {
+ $uri = preg_replace('/#.*/', '', $uri);
+ }
+
+ $uri .= $this->getRouteQueryString($parameters);
+
+ return is_null($fragment) ? $uri : $uri."#{$fragment}";
+ }
+
+ /**
+ * Get the query string for a given route.
+ *
+ * @param array $parameters
+ * @return string
+ */
+ protected function getRouteQueryString(array $parameters)
+ {
+ // First we will get all of the string parameters that are remaining after we
+ // have replaced the route wildcards. We'll then build a query string from
+ // these string parameters then use it as a starting point for the rest.
+ if (count($parameters) == 0) {
+ return '';
+ }
+
+ $query = http_build_query(
+ $keyed = $this->getStringParameters($parameters)
+ );
+
+ // Lastly, if there are still parameters remaining, we will fetch the numeric
+ // parameters that are in the array and add them to the query string or we
+ // will make the initial query string if it wasn't started with strings.
+ if (count($keyed) < count($parameters)) {
+ $query .= '&'.implode(
+ '&', $this->getNumericParameters($parameters)
+ );
+ }
+
+ return '?'.trim($query, '&');
+ }
+
+ /**
+ * Get the string parameters from a given list.
+ *
+ * @param array $parameters
+ * @return array
+ */
+ protected function getStringParameters(array $parameters)
+ {
+ return array_filter($parameters, 'is_string', ARRAY_FILTER_USE_KEY);
+ }
+
+ /**
+ * Get the numeric parameters from a given list.
+ *
+ * @param array $parameters
+ * @return array
+ */
+ protected function getNumericParameters(array $parameters)
+ {
+ return array_filter($parameters, 'is_numeric', ARRAY_FILTER_USE_KEY);
+ }
+
+ /**
+ * Set the default named parameters used by the URL generator.
+ *
+ * @param array $defaults
+ * @return void
+ */
+ public function defaults(array $defaults)
+ {
+ $this->defaultParameters = array_merge(
+ $this->defaultParameters, $defaults
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/Router.php b/vendor/laravel/framework/src/Illuminate/Routing/Router.php
new file mode 100644
index 000000000..e5856ef02
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/Router.php
@@ -0,0 +1,1100 @@
+events = $events;
+ $this->routes = new RouteCollection;
+ $this->container = $container ?: new Container;
+ }
+
+ /**
+ * Register a new GET route with the router.
+ *
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ public function get($uri, $action = null)
+ {
+ return $this->addRoute(['GET', 'HEAD'], $uri, $action);
+ }
+
+ /**
+ * Register a new POST route with the router.
+ *
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ public function post($uri, $action = null)
+ {
+ return $this->addRoute('POST', $uri, $action);
+ }
+
+ /**
+ * Register a new PUT route with the router.
+ *
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ public function put($uri, $action = null)
+ {
+ return $this->addRoute('PUT', $uri, $action);
+ }
+
+ /**
+ * Register a new PATCH route with the router.
+ *
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ public function patch($uri, $action = null)
+ {
+ return $this->addRoute('PATCH', $uri, $action);
+ }
+
+ /**
+ * Register a new DELETE route with the router.
+ *
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ public function delete($uri, $action = null)
+ {
+ return $this->addRoute('DELETE', $uri, $action);
+ }
+
+ /**
+ * Register a new OPTIONS route with the router.
+ *
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ public function options($uri, $action = null)
+ {
+ return $this->addRoute('OPTIONS', $uri, $action);
+ }
+
+ /**
+ * Register a new route responding to all verbs.
+ *
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ public function any($uri, $action = null)
+ {
+ return $this->addRoute(self::$verbs, $uri, $action);
+ }
+
+ /**
+ * Register a new route with the given verbs.
+ *
+ * @param array|string $methods
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ public function match($methods, $uri, $action = null)
+ {
+ return $this->addRoute(array_map('strtoupper', (array) $methods), $uri, $action);
+ }
+
+ /**
+ * Register an array of resource controllers.
+ *
+ * @param array $resources
+ * @return void
+ */
+ public function resources(array $resources)
+ {
+ foreach ($resources as $name => $controller) {
+ $this->resource($name, $controller);
+ }
+ }
+
+ /**
+ * Route a resource to a controller.
+ *
+ * @param string $name
+ * @param string $controller
+ * @param array $options
+ * @return void
+ */
+ public function resource($name, $controller, array $options = [])
+ {
+ if ($this->container && $this->container->bound(ResourceRegistrar::class)) {
+ $registrar = $this->container->make(ResourceRegistrar::class);
+ } else {
+ $registrar = new ResourceRegistrar($this);
+ }
+
+ $registrar->register($name, $controller, $options);
+ }
+
+ /**
+ * Route an api resource to a controller.
+ *
+ * @param string $name
+ * @param string $controller
+ * @param array $options
+ * @return void
+ */
+ public function apiResource($name, $controller, array $options = [])
+ {
+ $this->resource($name, $controller, array_merge([
+ 'only' => ['index', 'show', 'store', 'update', 'destroy'],
+ ], $options));
+ }
+
+ /**
+ * Create a route group with shared attributes.
+ *
+ * @param array $attributes
+ * @param \Closure|string $routes
+ * @return void
+ */
+ public function group(array $attributes, $routes)
+ {
+ $this->updateGroupStack($attributes);
+
+ // Once we have updated the group stack, we'll load the provided routes and
+ // merge in the group's attributes when the routes are created. After we
+ // have created the routes, we will pop the attributes off the stack.
+ $this->loadRoutes($routes);
+
+ array_pop($this->groupStack);
+ }
+
+ /**
+ * Update the group stack with the given attributes.
+ *
+ * @param array $attributes
+ * @return void
+ */
+ protected function updateGroupStack(array $attributes)
+ {
+ if (! empty($this->groupStack)) {
+ $attributes = RouteGroup::merge($attributes, end($this->groupStack));
+ }
+
+ $this->groupStack[] = $attributes;
+ }
+
+ /**
+ * Merge the given array with the last group stack.
+ *
+ * @param array $new
+ * @return array
+ */
+ public function mergeWithLastGroup($new)
+ {
+ return RouteGroup::merge($new, end($this->groupStack));
+ }
+
+ /**
+ * Load the provided routes.
+ *
+ * @param \Closure|string $routes
+ * @return void
+ */
+ protected function loadRoutes($routes)
+ {
+ if ($routes instanceof Closure) {
+ $routes($this);
+ } else {
+ $router = $this;
+
+ require $routes;
+ }
+ }
+
+ /**
+ * Get the prefix from the last group on the stack.
+ *
+ * @return string
+ */
+ public function getLastGroupPrefix()
+ {
+ if (! empty($this->groupStack)) {
+ $last = end($this->groupStack);
+
+ return isset($last['prefix']) ? $last['prefix'] : '';
+ }
+
+ return '';
+ }
+
+ /**
+ * Add a route to the underlying route collection.
+ *
+ * @param array|string $methods
+ * @param string $uri
+ * @param \Closure|array|string|null $action
+ * @return \Illuminate\Routing\Route
+ */
+ protected function addRoute($methods, $uri, $action)
+ {
+ return $this->routes->add($this->createRoute($methods, $uri, $action));
+ }
+
+ /**
+ * Create a new route instance.
+ *
+ * @param array|string $methods
+ * @param string $uri
+ * @param mixed $action
+ * @return \Illuminate\Routing\Route
+ */
+ protected function createRoute($methods, $uri, $action)
+ {
+ // If the route is routing to a controller we will parse the route action into
+ // an acceptable array format before registering it and creating this route
+ // instance itself. We need to build the Closure that will call this out.
+ if ($this->actionReferencesController($action)) {
+ $action = $this->convertToControllerAction($action);
+ }
+
+ $route = $this->newRoute(
+ $methods, $this->prefix($uri), $action
+ );
+
+ // If we have groups that need to be merged, we will merge them now after this
+ // route has already been created and is ready to go. After we're done with
+ // the merge we will be ready to return the route back out to the caller.
+ if ($this->hasGroupStack()) {
+ $this->mergeGroupAttributesIntoRoute($route);
+ }
+
+ $this->addWhereClausesToRoute($route);
+
+ return $route;
+ }
+
+ /**
+ * Determine if the action is routing to a controller.
+ *
+ * @param array $action
+ * @return bool
+ */
+ protected function actionReferencesController($action)
+ {
+ if (! $action instanceof Closure) {
+ return is_string($action) || (isset($action['uses']) && is_string($action['uses']));
+ }
+
+ return false;
+ }
+
+ /**
+ * Add a controller based route action to the action array.
+ *
+ * @param array|string $action
+ * @return array
+ */
+ protected function convertToControllerAction($action)
+ {
+ if (is_string($action)) {
+ $action = ['uses' => $action];
+ }
+
+ // Here we'll merge any group "uses" statement if necessary so that the action
+ // has the proper clause for this property. Then we can simply set the name
+ // of the controller on the action and return the action array for usage.
+ if (! empty($this->groupStack)) {
+ $action['uses'] = $this->prependGroupNamespace($action['uses']);
+ }
+
+ // Here we will set this controller name on the action array just so we always
+ // have a copy of it for reference if we need it. This can be used while we
+ // search for a controller name or do some other type of fetch operation.
+ $action['controller'] = $action['uses'];
+
+ return $action;
+ }
+
+ /**
+ * Prepend the last group namespace onto the use clause.
+ *
+ * @param string $class
+ * @return string
+ */
+ protected function prependGroupNamespace($class)
+ {
+ $group = end($this->groupStack);
+
+ return isset($group['namespace']) && strpos($class, '\\') !== 0
+ ? $group['namespace'].'\\'.$class : $class;
+ }
+
+ /**
+ * Create a new Route object.
+ *
+ * @param array|string $methods
+ * @param string $uri
+ * @param mixed $action
+ * @return \Illuminate\Routing\Route
+ */
+ protected function newRoute($methods, $uri, $action)
+ {
+ return (new Route($methods, $uri, $action))
+ ->setRouter($this)
+ ->setContainer($this->container);
+ }
+
+ /**
+ * Prefix the given URI with the last prefix.
+ *
+ * @param string $uri
+ * @return string
+ */
+ protected function prefix($uri)
+ {
+ return trim(trim($this->getLastGroupPrefix(), '/').'/'.trim($uri, '/'), '/') ?: '/';
+ }
+
+ /**
+ * Add the necessary where clauses to the route based on its initial registration.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @return \Illuminate\Routing\Route
+ */
+ protected function addWhereClausesToRoute($route)
+ {
+ $route->where(array_merge(
+ $this->patterns, isset($route->getAction()['where']) ? $route->getAction()['where'] : []
+ ));
+
+ return $route;
+ }
+
+ /**
+ * Merge the group stack with the controller action.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @return void
+ */
+ protected function mergeGroupAttributesIntoRoute($route)
+ {
+ $route->setAction($this->mergeWithLastGroup($route->getAction()));
+ }
+
+ /**
+ * Dispatch the request to the application.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Http\Response
+ */
+ public function dispatch(Request $request)
+ {
+ $this->currentRequest = $request;
+
+ return $this->dispatchToRoute($request);
+ }
+
+ /**
+ * Dispatch the request to a route and return the response.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return mixed
+ */
+ public function dispatchToRoute(Request $request)
+ {
+ // First we will find a route that matches this request. We will also set the
+ // route resolver on the request so middlewares assigned to the route will
+ // receive access to this route instance for checking of the parameters.
+ $route = $this->findRoute($request);
+
+ $request->setRouteResolver(function () use ($route) {
+ return $route;
+ });
+
+ $this->events->dispatch(new Events\RouteMatched($route, $request));
+
+ $response = $this->runRouteWithinStack($route, $request);
+
+ return $this->prepareResponse($request, $response);
+ }
+
+ /**
+ * Find the route matching a given request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Routing\Route
+ */
+ protected function findRoute($request)
+ {
+ $this->current = $route = $this->routes->match($request);
+
+ $this->container->instance(Route::class, $route);
+
+ return $route;
+ }
+
+ /**
+ * Run the given route within a Stack "onion" instance.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @param \Illuminate\Http\Request $request
+ * @return mixed
+ */
+ protected function runRouteWithinStack(Route $route, Request $request)
+ {
+ $shouldSkipMiddleware = $this->container->bound('middleware.disable') &&
+ $this->container->make('middleware.disable') === true;
+
+ $middleware = $shouldSkipMiddleware ? [] : $this->gatherRouteMiddleware($route);
+
+ return (new Pipeline($this->container))
+ ->send($request)
+ ->through($middleware)
+ ->then(function ($request) use ($route) {
+ return $this->prepareResponse(
+ $request, $route->run()
+ );
+ });
+ }
+
+ /**
+ * Gather the middleware for the given route with resolved class names.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @return array
+ */
+ public function gatherRouteMiddleware(Route $route)
+ {
+ $middleware = collect($route->gatherMiddleware())->map(function ($name) {
+ return (array) MiddlewareNameResolver::resolve($name, $this->middleware, $this->middlewareGroups);
+ })->flatten();
+
+ return $this->sortMiddleware($middleware);
+ }
+
+ /**
+ * Sort the given middleware by priority.
+ *
+ * @param \Illuminate\Support\Collection $middlewares
+ * @return array
+ */
+ protected function sortMiddleware(Collection $middlewares)
+ {
+ return (new SortedMiddleware($this->middlewarePriority, $middlewares))->all();
+ }
+
+ /**
+ * Create a response instance from the given value.
+ *
+ * @param \Symfony\Component\HttpFoundation\Request $request
+ * @param mixed $response
+ * @return \Illuminate\Http\Response
+ */
+ public function prepareResponse($request, $response)
+ {
+ if ($response instanceof PsrResponseInterface) {
+ $response = (new HttpFoundationFactory)->createResponse($response);
+ } elseif (! $response instanceof SymfonyResponse) {
+ $response = new Response($response);
+ }
+
+ return $response->prepare($request);
+ }
+
+ /**
+ * Substitute the route bindings onto the route.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @return \Illuminate\Routing\Route
+ */
+ public function substituteBindings($route)
+ {
+ foreach ($route->parameters() as $key => $value) {
+ if (isset($this->binders[$key])) {
+ $route->setParameter($key, $this->performBinding($key, $value, $route));
+ }
+ }
+
+ return $route;
+ }
+
+ /**
+ * Substitute the implicit Eloquent model bindings for the route.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @return void
+ */
+ public function substituteImplicitBindings($route)
+ {
+ ImplicitRouteBinding::resolveForRoute($this->container, $route);
+ }
+
+ /**
+ * Call the binding callback for the given key.
+ *
+ * @param string $key
+ * @param string $value
+ * @param \Illuminate\Routing\Route $route
+ * @return mixed
+ */
+ protected function performBinding($key, $value, $route)
+ {
+ return call_user_func($this->binders[$key], $value, $route);
+ }
+
+ /**
+ * Register a route matched event listener.
+ *
+ * @param string|callable $callback
+ * @return void
+ */
+ public function matched($callback)
+ {
+ $this->events->listen(Events\RouteMatched::class, $callback);
+ }
+
+ /**
+ * Get all of the defined middleware short-hand names.
+ *
+ * @return array
+ */
+ public function getMiddleware()
+ {
+ return $this->middleware;
+ }
+
+ /**
+ * Register a short-hand name for a middleware.
+ *
+ * @param string $name
+ * @param string $class
+ * @return $this
+ */
+ public function aliasMiddleware($name, $class)
+ {
+ $this->middleware[$name] = $class;
+
+ return $this;
+ }
+
+ /**
+ * Check if a middlewareGroup with the given name exists.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function hasMiddlewareGroup($name)
+ {
+ return array_key_exists($name, $this->middlewareGroups);
+ }
+
+ /**
+ * Get all of the defined middleware groups.
+ *
+ * @return array
+ */
+ public function getMiddlewareGroups()
+ {
+ return $this->middlewareGroups;
+ }
+
+ /**
+ * Register a group of middleware.
+ *
+ * @param string $name
+ * @param array $middleware
+ * @return $this
+ */
+ public function middlewareGroup($name, array $middleware)
+ {
+ $this->middlewareGroups[$name] = $middleware;
+
+ return $this;
+ }
+
+ /**
+ * Add a middleware to the beginning of a middleware group.
+ *
+ * If the middleware is already in the group, it will not be added again.
+ *
+ * @param string $group
+ * @param string $middleware
+ * @return $this
+ */
+ public function prependMiddlewareToGroup($group, $middleware)
+ {
+ if (isset($this->middlewareGroups[$group]) && ! in_array($middleware, $this->middlewareGroups[$group])) {
+ array_unshift($this->middlewareGroups[$group], $middleware);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a middleware to the end of a middleware group.
+ *
+ * If the middleware is already in the group, it will not be added again.
+ *
+ * @param string $group
+ * @param string $middleware
+ * @return $this
+ */
+ public function pushMiddlewareToGroup($group, $middleware)
+ {
+ if (! array_key_exists($group, $this->middlewareGroups)) {
+ $this->middlewareGroups[$group] = [];
+ }
+
+ if (! in_array($middleware, $this->middlewareGroups[$group])) {
+ $this->middlewareGroups[$group][] = $middleware;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a new route parameter binder.
+ *
+ * @param string $key
+ * @param string|callable $binder
+ * @return void
+ */
+ public function bind($key, $binder)
+ {
+ $this->binders[str_replace('-', '_', $key)] = RouteBinding::forCallback(
+ $this->container, $binder
+ );
+ }
+
+ /**
+ * Register a model binder for a wildcard.
+ *
+ * @param string $key
+ * @param string $class
+ * @param \Closure|null $callback
+ * @return void
+ *
+ * @throws \Illuminate\Database\Eloquent\ModelNotFoundException
+ */
+ public function model($key, $class, Closure $callback = null)
+ {
+ $this->bind($key, RouteBinding::forModel($this->container, $class, $callback));
+ }
+
+ /**
+ * Get the binding callback for a given binding.
+ *
+ * @param string $key
+ * @return \Closure|null
+ */
+ public function getBindingCallback($key)
+ {
+ if (isset($this->binders[$key = str_replace('-', '_', $key)])) {
+ return $this->binders[$key];
+ }
+ }
+
+ /**
+ * Get the global "where" patterns.
+ *
+ * @return array
+ */
+ public function getPatterns()
+ {
+ return $this->patterns;
+ }
+
+ /**
+ * Set a global where pattern on all routes.
+ *
+ * @param string $key
+ * @param string $pattern
+ * @return void
+ */
+ public function pattern($key, $pattern)
+ {
+ $this->patterns[$key] = $pattern;
+ }
+
+ /**
+ * Set a group of global where patterns on all routes.
+ *
+ * @param array $patterns
+ * @return void
+ */
+ public function patterns($patterns)
+ {
+ foreach ($patterns as $key => $pattern) {
+ $this->pattern($key, $pattern);
+ }
+ }
+
+ /**
+ * Determine if the router currently has a group stack.
+ *
+ * @return bool
+ */
+ public function hasGroupStack()
+ {
+ return ! empty($this->groupStack);
+ }
+
+ /**
+ * Get the current group stack for the router.
+ *
+ * @return array
+ */
+ public function getGroupStack()
+ {
+ return $this->groupStack;
+ }
+
+ /**
+ * Get a route parameter for the current route.
+ *
+ * @param string $key
+ * @param string $default
+ * @return mixed
+ */
+ public function input($key, $default = null)
+ {
+ return $this->current()->parameter($key, $default);
+ }
+
+ /**
+ * Get the request currently being dispatched.
+ *
+ * @return \Illuminate\Http\Request
+ */
+ public function getCurrentRequest()
+ {
+ return $this->currentRequest;
+ }
+
+ /**
+ * Get the currently dispatched route instance.
+ *
+ * @return \Illuminate\Routing\Route
+ */
+ public function getCurrentRoute()
+ {
+ return $this->current();
+ }
+
+ /**
+ * Get the currently dispatched route instance.
+ *
+ * @return \Illuminate\Routing\Route
+ */
+ public function current()
+ {
+ return $this->current;
+ }
+
+ /**
+ * Check if a route with the given name exists.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function has($name)
+ {
+ return $this->routes->hasNamedRoute($name);
+ }
+
+ /**
+ * Get the current route name.
+ *
+ * @return string|null
+ */
+ public function currentRouteName()
+ {
+ return $this->current() ? $this->current()->getName() : null;
+ }
+
+ /**
+ * Alias for the "currentRouteNamed" method.
+ *
+ * @return bool
+ */
+ public function is()
+ {
+ foreach (func_get_args() as $pattern) {
+ if (Str::is($pattern, $this->currentRouteName())) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Determine if the current route matches a given name.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function currentRouteNamed($name)
+ {
+ return $this->current() ? $this->current()->named($name) : false;
+ }
+
+ /**
+ * Get the current route action.
+ *
+ * @return string|null
+ */
+ public function currentRouteAction()
+ {
+ if (! $this->current()) {
+ return;
+ }
+
+ $action = $this->current()->getAction();
+
+ return isset($action['controller']) ? $action['controller'] : null;
+ }
+
+ /**
+ * Alias for the "currentRouteUses" method.
+ *
+ * @return bool
+ */
+ public function uses()
+ {
+ foreach (func_get_args() as $pattern) {
+ if (Str::is($pattern, $this->currentRouteAction())) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Determine if the current route action matches a given action.
+ *
+ * @param string $action
+ * @return bool
+ */
+ public function currentRouteUses($action)
+ {
+ return $this->currentRouteAction() == $action;
+ }
+
+ /**
+ * Register the typical authentication routes for an application.
+ *
+ * @return void
+ */
+ public function auth()
+ {
+ // Authentication Routes...
+ $this->get('login', 'Auth\LoginController@showLoginForm')->name('login');
+ $this->post('login', 'Auth\LoginController@login');
+ $this->post('logout', 'Auth\LoginController@logout')->name('logout');
+
+ // Registration Routes...
+ $this->get('register', 'Auth\RegisterController@showRegistrationForm')->name('register');
+ $this->post('register', 'Auth\RegisterController@register');
+
+ // Password Reset Routes...
+ $this->get('password/reset', 'Auth\ForgotPasswordController@showLinkRequestForm')->name('password.request');
+ $this->post('password/email', 'Auth\ForgotPasswordController@sendResetLinkEmail')->name('password.email');
+ $this->get('password/reset/{token}', 'Auth\ResetPasswordController@showResetForm')->name('password.reset');
+ $this->post('password/reset', 'Auth\ResetPasswordController@reset');
+ }
+
+ /**
+ * Set the unmapped global resource parameters to singular.
+ *
+ * @param bool $singular
+ * @return void
+ */
+ public function singularResourceParameters($singular = true)
+ {
+ ResourceRegistrar::singularParameters($singular);
+ }
+
+ /**
+ * Set the global resource parameter mapping.
+ *
+ * @param array $parameters
+ * @return void
+ */
+ public function resourceParameters(array $parameters = [])
+ {
+ ResourceRegistrar::setParameters($parameters);
+ }
+
+ /**
+ * Get or set the verbs used in the resource URIs.
+ *
+ * @param array $verbs
+ * @return array|null
+ */
+ public function resourceVerbs(array $verbs = [])
+ {
+ return ResourceRegistrar::verbs($verbs);
+ }
+
+ /**
+ * Get the underlying route collection.
+ *
+ * @return \Illuminate\Routing\RouteCollection
+ */
+ public function getRoutes()
+ {
+ return $this->routes;
+ }
+
+ /**
+ * Set the route collection instance.
+ *
+ * @param \Illuminate\Routing\RouteCollection $routes
+ * @return void
+ */
+ public function setRoutes(RouteCollection $routes)
+ {
+ foreach ($routes as $route) {
+ $route->setRouter($this)->setContainer($this->container);
+ }
+
+ $this->routes = $routes;
+
+ $this->container->instance('routes', $this->routes);
+ }
+
+ /**
+ * Dynamically handle calls into the router instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ if (static::hasMacro($method)) {
+ return $this->macroCall($method, $parameters);
+ }
+
+ return (new RouteRegistrar($this))->attribute($method, $parameters[0]);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/RoutingServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Routing/RoutingServiceProvider.php
new file mode 100644
index 000000000..762971e1f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/RoutingServiceProvider.php
@@ -0,0 +1,151 @@
+registerRouter();
+
+ $this->registerUrlGenerator();
+
+ $this->registerRedirector();
+
+ $this->registerPsrRequest();
+
+ $this->registerPsrResponse();
+
+ $this->registerResponseFactory();
+ }
+
+ /**
+ * Register the router instance.
+ *
+ * @return void
+ */
+ protected function registerRouter()
+ {
+ $this->app->singleton('router', function ($app) {
+ return new Router($app['events'], $app);
+ });
+ }
+
+ /**
+ * Register the URL generator service.
+ *
+ * @return void
+ */
+ protected function registerUrlGenerator()
+ {
+ $this->app->singleton('url', function ($app) {
+ $routes = $app['router']->getRoutes();
+
+ // The URL generator needs the route collection that exists on the router.
+ // Keep in mind this is an object, so we're passing by references here
+ // and all the registered routes will be available to the generator.
+ $app->instance('routes', $routes);
+
+ $url = new UrlGenerator(
+ $routes, $app->rebinding(
+ 'request', $this->requestRebinder()
+ )
+ );
+
+ $url->setSessionResolver(function () {
+ return $this->app['session'];
+ });
+
+ // If the route collection is "rebound", for example, when the routes stay
+ // cached for the application, we will need to rebind the routes on the
+ // URL generator instance so it has the latest version of the routes.
+ $app->rebinding('routes', function ($app, $routes) {
+ $app['url']->setRoutes($routes);
+ });
+
+ return $url;
+ });
+ }
+
+ /**
+ * Get the URL generator request rebinder.
+ *
+ * @return \Closure
+ */
+ protected function requestRebinder()
+ {
+ return function ($app, $request) {
+ $app['url']->setRequest($request);
+ };
+ }
+
+ /**
+ * Register the Redirector service.
+ *
+ * @return void
+ */
+ protected function registerRedirector()
+ {
+ $this->app->singleton('redirect', function ($app) {
+ $redirector = new Redirector($app['url']);
+
+ // If the session is set on the application instance, we'll inject it into
+ // the redirector instance. This allows the redirect responses to allow
+ // for the quite convenient "with" methods that flash to the session.
+ if (isset($app['session.store'])) {
+ $redirector->setSession($app['session.store']);
+ }
+
+ return $redirector;
+ });
+ }
+
+ /**
+ * Register a binding for the PSR-7 request implementation.
+ *
+ * @return void
+ */
+ protected function registerPsrRequest()
+ {
+ $this->app->bind(ServerRequestInterface::class, function ($app) {
+ return (new DiactorosFactory)->createRequest($app->make('request'));
+ });
+ }
+
+ /**
+ * Register a binding for the PSR-7 response implementation.
+ *
+ * @return void
+ */
+ protected function registerPsrResponse()
+ {
+ $this->app->bind(ResponseInterface::class, function ($app) {
+ return new PsrResponse();
+ });
+ }
+
+ /**
+ * Register the response factory implementation.
+ *
+ * @return void
+ */
+ protected function registerResponseFactory()
+ {
+ $this->app->singleton(ResponseFactoryContract::class, function ($app) {
+ return new ResponseFactory($app[ViewFactoryContract::class], $app['redirect']);
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/SortedMiddleware.php b/vendor/laravel/framework/src/Illuminate/Routing/SortedMiddleware.php
new file mode 100644
index 000000000..ad0945677
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/SortedMiddleware.php
@@ -0,0 +1,84 @@
+all();
+ }
+
+ $this->items = $this->sortMiddleware($priorityMap, $middlewares);
+ }
+
+ /**
+ * Sort the middlewares by the given priority map.
+ *
+ * Each call to this method makes one discrete middleware movement if necessary.
+ *
+ * @param array $priorityMap
+ * @param array $middlewares
+ * @return array
+ */
+ protected function sortMiddleware($priorityMap, $middlewares)
+ {
+ $lastIndex = 0;
+
+ foreach ($middlewares as $index => $middleware) {
+ if (! is_string($middleware)) {
+ continue;
+ }
+
+ $stripped = head(explode(':', $middleware));
+
+ if (in_array($stripped, $priorityMap)) {
+ $priorityIndex = array_search($stripped, $priorityMap);
+
+ // This middleware is in the priority map. If we have encountered another middleware
+ // that was also in the priority map and was at a lower priority than the current
+ // middleware, we will move this middleware to be above the previous encounter.
+ if (isset($lastPriorityIndex) && $priorityIndex < $lastPriorityIndex) {
+ return $this->sortMiddleware(
+ $priorityMap, array_values($this->moveMiddleware($middlewares, $index, $lastIndex))
+ );
+ }
+
+ // This middleware is in the priority map; but, this is the first middleware we have
+ // encountered from the map thus far. We'll save its current index plus its index
+ // from the priority map so we can compare against them on the next iterations.
+ $lastIndex = $index;
+ $lastPriorityIndex = $priorityIndex;
+ }
+ }
+
+ return array_values(array_unique($middlewares, SORT_REGULAR));
+ }
+
+ /**
+ * Splice a middleware into a new position and remove the old entry.
+ *
+ * @param array $middlewares
+ * @param int $from
+ * @param int $to
+ * @return array
+ */
+ protected function moveMiddleware($middlewares, $from, $to)
+ {
+ array_splice($middlewares, $to, 0, $middlewares[$from]);
+
+ unset($middlewares[$from + 1]);
+
+ return $middlewares;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/UrlGenerator.php b/vendor/laravel/framework/src/Illuminate/Routing/UrlGenerator.php
new file mode 100644
index 000000000..001129760
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/UrlGenerator.php
@@ -0,0 +1,618 @@
+routes = $routes;
+
+ $this->setRequest($request);
+ }
+
+ /**
+ * Get the full URL for the current request.
+ *
+ * @return string
+ */
+ public function full()
+ {
+ return $this->request->fullUrl();
+ }
+
+ /**
+ * Get the current URL for the request.
+ *
+ * @return string
+ */
+ public function current()
+ {
+ return $this->to($this->request->getPathInfo());
+ }
+
+ /**
+ * Get the URL for the previous request.
+ *
+ * @param mixed $fallback
+ * @return string
+ */
+ public function previous($fallback = false)
+ {
+ $referrer = $this->request->headers->get('referer');
+
+ $url = $referrer ? $this->to($referrer) : $this->getPreviousUrlFromSession();
+
+ if ($url) {
+ return $url;
+ } elseif ($fallback) {
+ return $this->to($fallback);
+ } else {
+ return $this->to('/');
+ }
+ }
+
+ /**
+ * Get the previous URL from the session if possible.
+ *
+ * @return string|null
+ */
+ protected function getPreviousUrlFromSession()
+ {
+ $session = $this->getSession();
+
+ return $session ? $session->previousUrl() : null;
+ }
+
+ /**
+ * Generate an absolute URL to the given path.
+ *
+ * @param string $path
+ * @param mixed $extra
+ * @param bool|null $secure
+ * @return string
+ */
+ public function to($path, $extra = [], $secure = null)
+ {
+ // First we will check if the URL is already a valid URL. If it is we will not
+ // try to generate a new one but will simply return the URL as is, which is
+ // convenient since developers do not always have to check if it's valid.
+ if ($this->isValidUrl($path)) {
+ return $path;
+ }
+
+ $tail = implode('/', array_map(
+ 'rawurlencode', (array) $this->formatParameters($extra))
+ );
+
+ // Once we have the scheme we will compile the "tail" by collapsing the values
+ // into a single string delimited by slashes. This just makes it convenient
+ // for passing the array of parameters to this URL as a list of segments.
+ $root = $this->formatRoot($this->formatScheme($secure));
+
+ list($path, $query) = $this->extractQueryString($path);
+
+ return $this->format(
+ $root, '/'.trim($path.'/'.$tail, '/')
+ ).$query;
+ }
+
+ /**
+ * Generate a secure, absolute URL to the given path.
+ *
+ * @param string $path
+ * @param array $parameters
+ * @return string
+ */
+ public function secure($path, $parameters = [])
+ {
+ return $this->to($path, $parameters, true);
+ }
+
+ /**
+ * Generate the URL to an application asset.
+ *
+ * @param string $path
+ * @param bool|null $secure
+ * @return string
+ */
+ public function asset($path, $secure = null)
+ {
+ if ($this->isValidUrl($path)) {
+ return $path;
+ }
+
+ // Once we get the root URL, we will check to see if it contains an index.php
+ // file in the paths. If it does, we will remove it since it is not needed
+ // for asset paths, but only for routes to endpoints in the application.
+ $root = $this->formatRoot($this->formatScheme($secure));
+
+ return $this->removeIndex($root).'/'.trim($path, '/');
+ }
+
+ /**
+ * Generate the URL to a secure asset.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function secureAsset($path)
+ {
+ return $this->asset($path, true);
+ }
+
+ /**
+ * Generate the URL to an asset from a custom root domain such as CDN, etc.
+ *
+ * @param string $root
+ * @param string $path
+ * @param bool|null $secure
+ * @return string
+ */
+ public function assetFrom($root, $path, $secure = null)
+ {
+ // Once we get the root URL, we will check to see if it contains an index.php
+ // file in the paths. If it does, we will remove it since it is not needed
+ // for asset paths, but only for routes to endpoints in the application.
+ $root = $this->formatRoot($this->formatScheme($secure), $root);
+
+ return $this->removeIndex($root).'/'.trim($path, '/');
+ }
+
+ /**
+ * Remove the index.php file from a path.
+ *
+ * @param string $root
+ * @return string
+ */
+ protected function removeIndex($root)
+ {
+ $i = 'index.php';
+
+ return Str::contains($root, $i) ? str_replace('/'.$i, '', $root) : $root;
+ }
+
+ /**
+ * Get the default scheme for a raw URL.
+ *
+ * @param bool|null $secure
+ * @return string
+ */
+ public function formatScheme($secure)
+ {
+ if (! is_null($secure)) {
+ return $secure ? 'https://' : 'http://';
+ }
+
+ if (is_null($this->cachedSchema)) {
+ $this->cachedSchema = $this->forceScheme ?: $this->request->getScheme().'://';
+ }
+
+ return $this->cachedSchema;
+ }
+
+ /**
+ * Get the URL to a named route.
+ *
+ * @param string $name
+ * @param mixed $parameters
+ * @param bool $absolute
+ * @return string
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function route($name, $parameters = [], $absolute = true)
+ {
+ if (! is_null($route = $this->routes->getByName($name))) {
+ return $this->toRoute($route, $parameters, $absolute);
+ }
+
+ throw new InvalidArgumentException("Route [{$name}] not defined.");
+ }
+
+ /**
+ * Get the URL for a given route instance.
+ *
+ * @param \Illuminate\Routing\Route $route
+ * @param mixed $parameters
+ * @param bool $absolute
+ * @return string
+ *
+ * @throws \Illuminate\Routing\Exceptions\UrlGenerationException
+ */
+ protected function toRoute($route, $parameters, $absolute)
+ {
+ return $this->routeUrl()->to(
+ $route, $this->formatParameters($parameters), $absolute
+ );
+ }
+
+ /**
+ * Get the URL to a controller action.
+ *
+ * @param string $action
+ * @param mixed $parameters
+ * @param bool $absolute
+ * @return string
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function action($action, $parameters = [], $absolute = true)
+ {
+ if (is_null($route = $this->routes->getByAction($action = $this->formatAction($action)))) {
+ throw new InvalidArgumentException("Action {$action} not defined.");
+ }
+
+ return $this->toRoute($route, $parameters, $absolute);
+ }
+
+ /**
+ * Format the given controller action.
+ *
+ * @param string $action
+ * @return string
+ */
+ protected function formatAction($action)
+ {
+ if ($this->rootNamespace && ! (strpos($action, '\\') === 0)) {
+ return $this->rootNamespace.'\\'.$action;
+ } else {
+ return trim($action, '\\');
+ }
+ }
+
+ /**
+ * Format the array of URL parameters.
+ *
+ * @param mixed|array $parameters
+ * @return array
+ */
+ public function formatParameters($parameters)
+ {
+ $parameters = array_wrap($parameters);
+
+ foreach ($parameters as $key => $parameter) {
+ if ($parameter instanceof UrlRoutable) {
+ $parameters[$key] = $parameter->getRouteKey();
+ }
+ }
+
+ return $parameters;
+ }
+
+ /**
+ * Extract the query string from the given path.
+ *
+ * @param string $path
+ * @return array
+ */
+ protected function extractQueryString($path)
+ {
+ if (($queryPosition = strpos($path, '?')) !== false) {
+ return [
+ substr($path, 0, $queryPosition),
+ substr($path, $queryPosition),
+ ];
+ }
+
+ return [$path, ''];
+ }
+
+ /**
+ * Get the base URL for the request.
+ *
+ * @param string $scheme
+ * @param string $root
+ * @return string
+ */
+ public function formatRoot($scheme, $root = null)
+ {
+ if (is_null($root)) {
+ if (is_null($this->cachedRoot)) {
+ $this->cachedRoot = $this->forcedRoot ?: $this->request->root();
+ }
+
+ $root = $this->cachedRoot;
+ }
+
+ $start = Str::startsWith($root, 'http://') ? 'http://' : 'https://';
+
+ return preg_replace('~'.$start.'~', $scheme, $root, 1);
+ }
+
+ /**
+ * Format the given URL segments into a single URL.
+ *
+ * @param string $root
+ * @param string $path
+ * @return string
+ */
+ public function format($root, $path)
+ {
+ $path = '/'.trim($path, '/');
+
+ if ($this->formatHostUsing) {
+ $root = call_user_func($this->formatHostUsing, $root);
+ }
+
+ if ($this->formatPathUsing) {
+ $path = call_user_func($this->formatPathUsing, $path);
+ }
+
+ return trim($root.$path, '/');
+ }
+
+ /**
+ * Determine if the given path is a valid URL.
+ *
+ * @param string $path
+ * @return bool
+ */
+ public function isValidUrl($path)
+ {
+ if (! preg_match('~^(#|//|https?://|mailto:|tel:)~', $path)) {
+ return filter_var($path, FILTER_VALIDATE_URL) !== false;
+ }
+
+ return true;
+ }
+
+ /**
+ * Get the Route URL generator instance.
+ *
+ * @return \Illuminate\Routing\RouteUrlGenerator
+ */
+ protected function routeUrl()
+ {
+ if (! $this->routeGenerator) {
+ $this->routeGenerator = new RouteUrlGenerator($this, $this->request);
+ }
+
+ return $this->routeGenerator;
+ }
+
+ /**
+ * Set the default named parameters used by the URL generator.
+ *
+ * @param array $defaults
+ * @return void
+ */
+ public function defaults(array $defaults)
+ {
+ $this->routeUrl()->defaults($defaults);
+ }
+
+ /**
+ * Force the scheme for URLs.
+ *
+ * @param string $schema
+ * @return void
+ */
+ public function forceScheme($schema)
+ {
+ $this->cachedSchema = null;
+
+ $this->forceScheme = $schema.'://';
+ }
+
+ /**
+ * Set the forced root URL.
+ *
+ * @param string $root
+ * @return void
+ */
+ public function forceRootUrl($root)
+ {
+ $this->forcedRoot = rtrim($root, '/');
+
+ $this->cachedRoot = null;
+ }
+
+ /**
+ * Set a callback to be used to format the host of generated URLs.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function formatHostUsing(Closure $callback)
+ {
+ $this->formatHostUsing = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Set a callback to be used to format the path of generated URLs.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function formatPathUsing(Closure $callback)
+ {
+ $this->formatPathUsing = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Get the path formatter being used by the URL generator.
+ *
+ * @return \Closure
+ */
+ public function pathFormatter()
+ {
+ return $this->formatPathUsing ?: function ($path) {
+ return $path;
+ };
+ }
+
+ /**
+ * Get the request instance.
+ *
+ * @return \Illuminate\Http\Request
+ */
+ public function getRequest()
+ {
+ return $this->request;
+ }
+
+ /**
+ * Set the current request instance.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ public function setRequest(Request $request)
+ {
+ $this->request = $request;
+
+ $this->cachedRoot = null;
+ $this->cachedSchema = null;
+ $this->routeGenerator = null;
+ }
+
+ /**
+ * Set the route collection.
+ *
+ * @param \Illuminate\Routing\RouteCollection $routes
+ * @return $this
+ */
+ public function setRoutes(RouteCollection $routes)
+ {
+ $this->routes = $routes;
+
+ return $this;
+ }
+
+ /**
+ * Get the session implementation from the resolver.
+ *
+ * @return \Illuminate\Session\Store|null
+ */
+ protected function getSession()
+ {
+ if ($this->sessionResolver) {
+ return call_user_func($this->sessionResolver);
+ }
+ }
+
+ /**
+ * Set the session resolver for the generator.
+ *
+ * @param callable $sessionResolver
+ * @return $this
+ */
+ public function setSessionResolver(callable $sessionResolver)
+ {
+ $this->sessionResolver = $sessionResolver;
+
+ return $this;
+ }
+
+ /**
+ * Set the root controller namespace.
+ *
+ * @param string $rootNamespace
+ * @return $this
+ */
+ public function setRootControllerNamespace($rootNamespace)
+ {
+ $this->rootNamespace = $rootNamespace;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Routing/composer.json b/vendor/laravel/framework/src/Illuminate/Routing/composer.json
new file mode 100644
index 000000000..39bfc2fe1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Routing/composer.json
@@ -0,0 +1,47 @@
+{
+ "name": "illuminate/routing",
+ "description": "The Illuminate Routing package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/container": "5.4.*",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/http": "5.4.*",
+ "illuminate/pipeline": "5.4.*",
+ "illuminate/session": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "symfony/debug": "~3.2",
+ "symfony/http-foundation": "~3.2",
+ "symfony/http-kernel": "~3.2",
+ "symfony/routing": "~3.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Routing\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "illuminate/console": "Required to use the make commands (5.4.*).",
+ "symfony/psr-http-message-bridge": "Required to psr7 bridging features (0.2.*)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/CacheBasedSessionHandler.php b/vendor/laravel/framework/src/Illuminate/Session/CacheBasedSessionHandler.php
new file mode 100644
index 000000000..a2990bdd1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/CacheBasedSessionHandler.php
@@ -0,0 +1,94 @@
+cache = $cache;
+ $this->minutes = $minutes;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function open($savePath, $sessionName)
+ {
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function close()
+ {
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function read($sessionId)
+ {
+ return $this->cache->get($sessionId, '');
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function write($sessionId, $data)
+ {
+ return $this->cache->put($sessionId, $data, $this->minutes);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function destroy($sessionId)
+ {
+ return $this->cache->forget($sessionId);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function gc($lifetime)
+ {
+ return true;
+ }
+
+ /**
+ * Get the underlying cache repository.
+ *
+ * @return \Illuminate\Contracts\Cache\Repository
+ */
+ public function getCache()
+ {
+ return $this->cache;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/Console/SessionTableCommand.php b/vendor/laravel/framework/src/Illuminate/Session/Console/SessionTableCommand.php
new file mode 100644
index 000000000..d8f2903df
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/Console/SessionTableCommand.php
@@ -0,0 +1,81 @@
+files = $files;
+ $this->composer = $composer;
+ }
+
+ /**
+ * Execute the console command.
+ *
+ * @return void
+ */
+ public function fire()
+ {
+ $fullPath = $this->createBaseMigration();
+
+ $this->files->put($fullPath, $this->files->get(__DIR__.'/stubs/database.stub'));
+
+ $this->info('Migration created successfully!');
+
+ $this->composer->dumpAutoloads();
+ }
+
+ /**
+ * Create a base migration file for the session.
+ *
+ * @return string
+ */
+ protected function createBaseMigration()
+ {
+ $name = 'create_sessions_table';
+
+ $path = $this->laravel->databasePath().'/migrations';
+
+ return $this->laravel['migration.creator']->create($name, $path);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/Console/stubs/database.stub b/vendor/laravel/framework/src/Illuminate/Session/Console/stubs/database.stub
new file mode 100644
index 000000000..c213297d1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/Console/stubs/database.stub
@@ -0,0 +1,35 @@
+string('id')->unique();
+ $table->unsignedInteger('user_id')->nullable();
+ $table->string('ip_address', 45)->nullable();
+ $table->text('user_agent')->nullable();
+ $table->text('payload');
+ $table->integer('last_activity');
+ });
+ }
+
+ /**
+ * Reverse the migrations.
+ *
+ * @return void
+ */
+ public function down()
+ {
+ Schema::dropIfExists('sessions');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/CookieSessionHandler.php b/vendor/laravel/framework/src/Illuminate/Session/CookieSessionHandler.php
new file mode 100644
index 000000000..95b7bcc02
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/CookieSessionHandler.php
@@ -0,0 +1,119 @@
+cookie = $cookie;
+ $this->minutes = $minutes;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function open($savePath, $sessionName)
+ {
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function close()
+ {
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function read($sessionId)
+ {
+ $value = $this->request->cookies->get($sessionId) ?: '';
+
+ if (! is_null($decoded = json_decode($value, true)) && is_array($decoded)) {
+ if (isset($decoded['expires']) && Carbon::now()->getTimestamp() <= $decoded['expires']) {
+ return $decoded['data'];
+ }
+ }
+
+ return '';
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function write($sessionId, $data)
+ {
+ $this->cookie->queue($sessionId, json_encode([
+ 'data' => $data,
+ 'expires' => Carbon::now()->addMinutes($this->minutes)->getTimestamp(),
+ ]), $this->minutes);
+
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function destroy($sessionId)
+ {
+ $this->cookie->queue($this->cookie->forget($sessionId));
+
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function gc($lifetime)
+ {
+ return true;
+ }
+
+ /**
+ * Set the request instance.
+ *
+ * @param \Symfony\Component\HttpFoundation\Request $request
+ * @return void
+ */
+ public function setRequest(Request $request)
+ {
+ $this->request = $request;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/DatabaseSessionHandler.php b/vendor/laravel/framework/src/Illuminate/Session/DatabaseSessionHandler.php
new file mode 100644
index 000000000..dd4bf225e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/DatabaseSessionHandler.php
@@ -0,0 +1,289 @@
+table = $table;
+ $this->minutes = $minutes;
+ $this->container = $container;
+ $this->connection = $connection;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function open($savePath, $sessionName)
+ {
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function close()
+ {
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function read($sessionId)
+ {
+ $session = (object) $this->getQuery()->find($sessionId);
+
+ if ($this->expired($session)) {
+ $this->exists = true;
+
+ return;
+ }
+
+ if (isset($session->payload)) {
+ $this->exists = true;
+
+ return base64_decode($session->payload);
+ }
+ }
+
+ /**
+ * Determine if the session is expired.
+ *
+ * @param \stdClass $session
+ * @return bool
+ */
+ protected function expired($session)
+ {
+ return isset($session->last_activity) &&
+ $session->last_activity < Carbon::now()->subMinutes($this->minutes)->getTimestamp();
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function write($sessionId, $data)
+ {
+ $payload = $this->getDefaultPayload($data);
+
+ if (! $this->exists) {
+ $this->read($sessionId);
+ }
+
+ if ($this->exists) {
+ $this->performUpdate($sessionId, $payload);
+ } else {
+ $this->performInsert($sessionId, $payload);
+ }
+
+ return $this->exists = true;
+ }
+
+ /**
+ * Perform an insert operation on the session ID.
+ *
+ * @param string $sessionId
+ * @param string $payload
+ * @return void
+ */
+ protected function performInsert($sessionId, $payload)
+ {
+ try {
+ return $this->getQuery()->insert(Arr::set($payload, 'id', $sessionId));
+ } catch (QueryException $e) {
+ $this->performUpdate($sessionId, $payload);
+ }
+ }
+
+ /**
+ * Perform an update operation on the session ID.
+ *
+ * @param string $sessionId
+ * @param string $payload
+ * @return int
+ */
+ protected function performUpdate($sessionId, $payload)
+ {
+ return $this->getQuery()->where('id', $sessionId)->update($payload);
+ }
+
+ /**
+ * Get the default payload for the session.
+ *
+ * @param string $data
+ * @return array
+ */
+ protected function getDefaultPayload($data)
+ {
+ $payload = [
+ 'payload' => base64_encode($data),
+ 'last_activity' => Carbon::now()->getTimestamp(),
+ ];
+
+ if (! $this->container) {
+ return $payload;
+ }
+
+ return tap($payload, function (&$payload) {
+ $this->addUserInformation($payload)
+ ->addRequestInformation($payload);
+ });
+ }
+
+ /**
+ * Add the user information to the session payload.
+ *
+ * @param array $payload
+ * @return $this
+ */
+ protected function addUserInformation(&$payload)
+ {
+ if ($this->container->bound(Guard::class)) {
+ $payload['user_id'] = $this->userId();
+ }
+
+ return $this;
+ }
+
+ /**
+ * Get the currently authenticated user's ID.
+ *
+ * @return mixed
+ */
+ protected function userId()
+ {
+ return $this->container->make(Guard::class)->id();
+ }
+
+ /**
+ * Add the request information to the session payload.
+ *
+ * @param array $payload
+ * @return $this
+ */
+ protected function addRequestInformation(&$payload)
+ {
+ if ($this->container->bound('request')) {
+ $payload = array_merge($payload, [
+ 'ip_address' => $this->ipAddress(),
+ 'user_agent' => $this->userAgent(),
+ ]);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Get the IP address for the current request.
+ *
+ * @return string
+ */
+ protected function ipAddress()
+ {
+ return $this->container->make('request')->ip();
+ }
+
+ /**
+ * Get the user agent for the current request.
+ *
+ * @return string
+ */
+ protected function userAgent()
+ {
+ return substr((string) $this->container->make('request')->header('User-Agent'), 0, 500);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function destroy($sessionId)
+ {
+ $this->getQuery()->where('id', $sessionId)->delete();
+
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function gc($lifetime)
+ {
+ $this->getQuery()->where('last_activity', '<=', Carbon::now()->getTimestamp() - $lifetime)->delete();
+ }
+
+ /**
+ * Get a fresh query builder instance for the table.
+ *
+ * @return \Illuminate\Database\Query\Builder
+ */
+ protected function getQuery()
+ {
+ return $this->connection->table($this->table);
+ }
+
+ /**
+ * Set the existence state for the session.
+ *
+ * @param bool $value
+ * @return $this
+ */
+ public function setExists($value)
+ {
+ $this->exists = $value;
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/EncryptedStore.php b/vendor/laravel/framework/src/Illuminate/Session/EncryptedStore.php
new file mode 100644
index 000000000..078d13fd7
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/EncryptedStore.php
@@ -0,0 +1,69 @@
+encrypter = $encrypter;
+
+ parent::__construct($name, $handler, $id);
+ }
+
+ /**
+ * Prepare the raw string data from the session for unserialization.
+ *
+ * @param string $data
+ * @return string
+ */
+ protected function prepareForUnserialize($data)
+ {
+ try {
+ return $this->encrypter->decrypt($data);
+ } catch (DecryptException $e) {
+ return serialize([]);
+ }
+ }
+
+ /**
+ * Prepare the serialized session data for storage.
+ *
+ * @param string $data
+ * @return string
+ */
+ protected function prepareForStorage($data)
+ {
+ return $this->encrypter->encrypt($data);
+ }
+
+ /**
+ * Get the encrypter instance.
+ *
+ * @return \Illuminate\Contracts\Encryption\Encrypter
+ */
+ public function getEncrypter()
+ {
+ return $this->encrypter;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/ExistenceAwareInterface.php b/vendor/laravel/framework/src/Illuminate/Session/ExistenceAwareInterface.php
new file mode 100644
index 000000000..4a6bd984e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/ExistenceAwareInterface.php
@@ -0,0 +1,14 @@
+path = $path;
+ $this->files = $files;
+ $this->minutes = $minutes;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function open($savePath, $sessionName)
+ {
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function close()
+ {
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function read($sessionId)
+ {
+ if ($this->files->exists($path = $this->path.'/'.$sessionId)) {
+ if (filemtime($path) >= Carbon::now()->subMinutes($this->minutes)->getTimestamp()) {
+ return $this->files->get($path, true);
+ }
+ }
+
+ return '';
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function write($sessionId, $data)
+ {
+ $this->files->put($this->path.'/'.$sessionId, $data, true);
+
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function destroy($sessionId)
+ {
+ $this->files->delete($this->path.'/'.$sessionId);
+
+ return true;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function gc($lifetime)
+ {
+ $files = Finder::create()
+ ->in($this->path)
+ ->files()
+ ->ignoreDotFiles(true)
+ ->date('<= now - '.$lifetime.' seconds');
+
+ foreach ($files as $file) {
+ $this->files->delete($file->getRealPath());
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/Middleware/AuthenticateSession.php b/vendor/laravel/framework/src/Illuminate/Session/Middleware/AuthenticateSession.php
new file mode 100644
index 000000000..d93c38cff
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/Middleware/AuthenticateSession.php
@@ -0,0 +1,92 @@
+auth = $auth;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @return mixed
+ */
+ public function handle($request, Closure $next)
+ {
+ if (! $request->user() || ! $request->session()) {
+ return $next($request);
+ }
+
+ if (! $request->session()->has('password_hash') && $this->auth->viaRemember()) {
+ $this->logout($request);
+ }
+
+ if (! $request->session()->has('password_hash')) {
+ $this->storePasswordHashInSession($request);
+ }
+
+ if ($request->session()->get('password_hash') !== $request->user()->getAuthPassword()) {
+ $this->logout($request);
+ }
+
+ return tap($next($request), function () use ($request) {
+ $this->storePasswordHashInSession($request);
+ });
+ }
+
+ /**
+ * Store the user's current password hash in the session.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ protected function storePasswordHashInSession($request)
+ {
+ if (! $request->user()) {
+ return;
+ }
+
+ $request->session()->put([
+ 'password_hash' => $request->user()->getAuthPassword(),
+ ]);
+ }
+
+ /**
+ * Log the user out of the application.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ *
+ * @throws \Illuminate\Auth\AuthenticationException
+ */
+ protected function logout($request)
+ {
+ $this->auth->logout();
+
+ $request->session()->flush();
+
+ throw new AuthenticationException;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/Middleware/StartSession.php b/vendor/laravel/framework/src/Illuminate/Session/Middleware/StartSession.php
new file mode 100644
index 000000000..d50189080
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/Middleware/StartSession.php
@@ -0,0 +1,243 @@
+manager = $manager;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @return mixed
+ */
+ public function handle($request, Closure $next)
+ {
+ $this->sessionHandled = true;
+
+ // If a session driver has been configured, we will need to start the session here
+ // so that the data is ready for an application. Note that the Laravel sessions
+ // do not make use of PHP "native" sessions in any way since they are crappy.
+ if ($this->sessionConfigured()) {
+ $request->setLaravelSession(
+ $session = $this->startSession($request)
+ );
+
+ $this->collectGarbage($session);
+ }
+
+ $response = $next($request);
+
+ // Again, if the session has been configured we will need to close out the session
+ // so that the attributes may be persisted to some storage medium. We will also
+ // add the session identifier cookie to the application response headers now.
+ if ($this->sessionConfigured()) {
+ $this->storeCurrentUrl($request, $session);
+
+ $this->addCookieToResponse($response, $session);
+ }
+
+ return $response;
+ }
+
+ /**
+ * Perform any final actions for the request lifecycle.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Symfony\Component\HttpFoundation\Response $response
+ * @return void
+ */
+ public function terminate($request, $response)
+ {
+ if ($this->sessionHandled && $this->sessionConfigured() && ! $this->usingCookieSessions()) {
+ $this->manager->driver()->save();
+ }
+ }
+
+ /**
+ * Start the session for the given request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Contracts\Session\Session
+ */
+ protected function startSession(Request $request)
+ {
+ return tap($this->getSession($request), function ($session) use ($request) {
+ $session->setRequestOnHandler($request);
+
+ $session->start();
+ });
+ }
+
+ /**
+ * Get the session implementation from the manager.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return \Illuminate\Contracts\Session\Session
+ */
+ public function getSession(Request $request)
+ {
+ return tap($this->manager->driver(), function ($session) use ($request) {
+ $session->setId($request->cookies->get($session->getName()));
+ });
+ }
+
+ /**
+ * Remove the garbage from the session if necessary.
+ *
+ * @param \Illuminate\Contracts\Session\Session $session
+ * @return void
+ */
+ protected function collectGarbage(Session $session)
+ {
+ $config = $this->manager->getSessionConfig();
+
+ // Here we will see if this request hits the garbage collection lottery by hitting
+ // the odds needed to perform garbage collection on any given request. If we do
+ // hit it, we'll call this handler to let it delete all the expired sessions.
+ if ($this->configHitsLottery($config)) {
+ $session->getHandler()->gc($this->getSessionLifetimeInSeconds());
+ }
+ }
+
+ /**
+ * Determine if the configuration odds hit the lottery.
+ *
+ * @param array $config
+ * @return bool
+ */
+ protected function configHitsLottery(array $config)
+ {
+ return random_int(1, $config['lottery'][1]) <= $config['lottery'][0];
+ }
+
+ /**
+ * Store the current URL for the request if necessary.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Illuminate\Contracts\Session\Session $session
+ * @return void
+ */
+ protected function storeCurrentUrl(Request $request, $session)
+ {
+ if ($request->method() === 'GET' && $request->route() && ! $request->ajax()) {
+ $session->setPreviousUrl($request->fullUrl());
+ }
+ }
+
+ /**
+ * Add the session cookie to the application response.
+ *
+ * @param \Symfony\Component\HttpFoundation\Response $response
+ * @param \Illuminate\Contracts\Session\Session $session
+ * @return void
+ */
+ protected function addCookieToResponse(Response $response, Session $session)
+ {
+ if ($this->usingCookieSessions()) {
+ $this->manager->driver()->save();
+ }
+
+ if ($this->sessionIsPersistent($config = $this->manager->getSessionConfig())) {
+ $response->headers->setCookie(new Cookie(
+ $session->getName(), $session->getId(), $this->getCookieExpirationDate(),
+ $config['path'], $config['domain'], Arr::get($config, 'secure', false),
+ Arr::get($config, 'http_only', true)
+ ));
+ }
+ }
+
+ /**
+ * Get the session lifetime in seconds.
+ *
+ * @return int
+ */
+ protected function getSessionLifetimeInSeconds()
+ {
+ return Arr::get($this->manager->getSessionConfig(), 'lifetime') * 60;
+ }
+
+ /**
+ * Get the cookie lifetime in seconds.
+ *
+ * @return \DateTimeInterface
+ */
+ protected function getCookieExpirationDate()
+ {
+ $config = $this->manager->getSessionConfig();
+
+ return $config['expire_on_close'] ? 0 : Carbon::now()->addMinutes($config['lifetime']);
+ }
+
+ /**
+ * Determine if a session driver has been configured.
+ *
+ * @return bool
+ */
+ protected function sessionConfigured()
+ {
+ return ! is_null(Arr::get($this->manager->getSessionConfig(), 'driver'));
+ }
+
+ /**
+ * Determine if the configured session driver is persistent.
+ *
+ * @param array|null $config
+ * @return bool
+ */
+ protected function sessionIsPersistent(array $config = null)
+ {
+ $config = $config ?: $this->manager->getSessionConfig();
+
+ return ! in_array($config['driver'], [null, 'array']);
+ }
+
+ /**
+ * Determine if the session is using cookie sessions.
+ *
+ * @return bool
+ */
+ protected function usingCookieSessions()
+ {
+ if ($this->sessionConfigured()) {
+ return $this->manager->driver()->getHandler() instanceof CookieSessionHandler;
+ }
+
+ return false;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/SessionManager.php b/vendor/laravel/framework/src/Illuminate/Session/SessionManager.php
new file mode 100644
index 000000000..f8ad80250
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/SessionManager.php
@@ -0,0 +1,216 @@
+buildSession(parent::callCustomCreator($driver));
+ }
+
+ /**
+ * Create an instance of the "array" session driver.
+ *
+ * @return \Illuminate\Session\Store
+ */
+ protected function createArrayDriver()
+ {
+ return $this->buildSession(new NullSessionHandler);
+ }
+
+ /**
+ * Create an instance of the "cookie" session driver.
+ *
+ * @return \Illuminate\Session\Store
+ */
+ protected function createCookieDriver()
+ {
+ return $this->buildSession(new CookieSessionHandler(
+ $this->app['cookie'], $this->app['config']['session.lifetime']
+ ));
+ }
+
+ /**
+ * Create an instance of the file session driver.
+ *
+ * @return \Illuminate\Session\Store
+ */
+ protected function createFileDriver()
+ {
+ return $this->createNativeDriver();
+ }
+
+ /**
+ * Create an instance of the file session driver.
+ *
+ * @return \Illuminate\Session\Store
+ */
+ protected function createNativeDriver()
+ {
+ $lifetime = $this->app['config']['session.lifetime'];
+
+ return $this->buildSession(new FileSessionHandler(
+ $this->app['files'], $this->app['config']['session.files'], $lifetime
+ ));
+ }
+
+ /**
+ * Create an instance of the database session driver.
+ *
+ * @return \Illuminate\Session\Store
+ */
+ protected function createDatabaseDriver()
+ {
+ $table = $this->app['config']['session.table'];
+
+ $lifetime = $this->app['config']['session.lifetime'];
+
+ return $this->buildSession(new DatabaseSessionHandler(
+ $this->getDatabaseConnection(), $table, $lifetime, $this->app
+ ));
+ }
+
+ /**
+ * Get the database connection for the database driver.
+ *
+ * @return \Illuminate\Database\Connection
+ */
+ protected function getDatabaseConnection()
+ {
+ $connection = $this->app['config']['session.connection'];
+
+ return $this->app['db']->connection($connection);
+ }
+
+ /**
+ * Create an instance of the APC session driver.
+ *
+ * @return \Illuminate\Session\Store
+ */
+ protected function createApcDriver()
+ {
+ return $this->createCacheBased('apc');
+ }
+
+ /**
+ * Create an instance of the Memcached session driver.
+ *
+ * @return \Illuminate\Session\Store
+ */
+ protected function createMemcachedDriver()
+ {
+ return $this->createCacheBased('memcached');
+ }
+
+ /**
+ * Create an instance of the Redis session driver.
+ *
+ * @return \Illuminate\Session\Store
+ */
+ protected function createRedisDriver()
+ {
+ $handler = $this->createCacheHandler('redis');
+
+ $handler->getCache()->getStore()->setConnection(
+ $this->app['config']['session.connection']
+ );
+
+ return $this->buildSession($handler);
+ }
+
+ /**
+ * Create an instance of a cache driven driver.
+ *
+ * @param string $driver
+ * @return \Illuminate\Session\Store
+ */
+ protected function createCacheBased($driver)
+ {
+ return $this->buildSession($this->createCacheHandler($driver));
+ }
+
+ /**
+ * Create the cache based session handler instance.
+ *
+ * @param string $driver
+ * @return \Illuminate\Session\CacheBasedSessionHandler
+ */
+ protected function createCacheHandler($driver)
+ {
+ $store = $this->app['config']->get('session.store') ?: $driver;
+
+ return new CacheBasedSessionHandler(
+ clone $this->app['cache']->store($store),
+ $this->app['config']['session.lifetime']
+ );
+ }
+
+ /**
+ * Build the session instance.
+ *
+ * @param \SessionHandlerInterface $handler
+ * @return \Illuminate\Session\Store
+ */
+ protected function buildSession($handler)
+ {
+ if ($this->app['config']['session.encrypt']) {
+ return $this->buildEncryptedSession($handler);
+ } else {
+ return new Store($this->app['config']['session.cookie'], $handler);
+ }
+ }
+
+ /**
+ * Build the encrypted session instance.
+ *
+ * @param \SessionHandlerInterface $handler
+ * @return \Illuminate\Session\EncryptedStore
+ */
+ protected function buildEncryptedSession($handler)
+ {
+ return new EncryptedStore(
+ $this->app['config']['session.cookie'], $handler, $this->app['encrypter']
+ );
+ }
+
+ /**
+ * Get the session configuration.
+ *
+ * @return array
+ */
+ public function getSessionConfig()
+ {
+ return $this->app['config']['session'];
+ }
+
+ /**
+ * Get the default session driver name.
+ *
+ * @return string
+ */
+ public function getDefaultDriver()
+ {
+ return $this->app['config']['session.driver'];
+ }
+
+ /**
+ * Set the default session driver name.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setDefaultDriver($name)
+ {
+ $this->app['config']['session.driver'] = $name;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/SessionServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Session/SessionServiceProvider.php
new file mode 100644
index 000000000..c85850624
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/SessionServiceProvider.php
@@ -0,0 +1,50 @@
+registerSessionManager();
+
+ $this->registerSessionDriver();
+
+ $this->app->singleton(StartSession::class);
+ }
+
+ /**
+ * Register the session manager instance.
+ *
+ * @return void
+ */
+ protected function registerSessionManager()
+ {
+ $this->app->singleton('session', function ($app) {
+ return new SessionManager($app);
+ });
+ }
+
+ /**
+ * Register the session driver instance.
+ *
+ * @return void
+ */
+ protected function registerSessionDriver()
+ {
+ $this->app->singleton('session.store', function ($app) {
+ // First, we will create the session manager which is responsible for the
+ // creation of the various session drivers when they are needed by the
+ // application instance, and will resolve them on a lazy load basis.
+ return $app->make('session')->driver();
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/Store.php b/vendor/laravel/framework/src/Illuminate/Session/Store.php
new file mode 100644
index 000000000..bf00202bc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/Store.php
@@ -0,0 +1,656 @@
+setId($id);
+ $this->name = $name;
+ $this->handler = $handler;
+ }
+
+ /**
+ * Start the session, reading the data from a handler.
+ *
+ * @return bool
+ */
+ public function start()
+ {
+ $this->loadSession();
+
+ if (! $this->has('_token')) {
+ $this->regenerateToken();
+ }
+
+ return $this->started = true;
+ }
+
+ /**
+ * Load the session data from the handler.
+ *
+ * @return void
+ */
+ protected function loadSession()
+ {
+ $this->attributes = array_merge($this->attributes, $this->readFromHandler());
+ }
+
+ /**
+ * Read the session data from the handler.
+ *
+ * @return array
+ */
+ protected function readFromHandler()
+ {
+ if ($data = $this->handler->read($this->getId())) {
+ $data = @unserialize($this->prepareForUnserialize($data));
+
+ if ($data !== false && ! is_null($data) && is_array($data)) {
+ return $data;
+ }
+ }
+
+ return [];
+ }
+
+ /**
+ * Prepare the raw string data from the session for unserialization.
+ *
+ * @param string $data
+ * @return string
+ */
+ protected function prepareForUnserialize($data)
+ {
+ return $data;
+ }
+
+ /**
+ * Save the session data to storage.
+ *
+ * @return bool
+ */
+ public function save()
+ {
+ $this->ageFlashData();
+
+ $this->handler->write($this->getId(), $this->prepareForStorage(
+ serialize($this->attributes)
+ ));
+
+ $this->started = false;
+ }
+
+ /**
+ * Prepare the serialized session data for storage.
+ *
+ * @param string $data
+ * @return string
+ */
+ protected function prepareForStorage($data)
+ {
+ return $data;
+ }
+
+ /**
+ * Age the flash data for the session.
+ *
+ * @return void
+ */
+ public function ageFlashData()
+ {
+ $this->forget($this->get('_flash.old', []));
+
+ $this->put('_flash.old', $this->get('_flash.new', []));
+
+ $this->put('_flash.new', []);
+ }
+
+ /**
+ * Get all of the session data.
+ *
+ * @return array
+ */
+ public function all()
+ {
+ return $this->attributes;
+ }
+
+ /**
+ * Checks if a key exists.
+ *
+ * @param string|array $key
+ * @return bool
+ */
+ public function exists($key)
+ {
+ return ! collect(is_array($key) ? $key : func_get_args())->contains(function ($key) {
+ return ! Arr::exists($this->attributes, $key);
+ });
+ }
+
+ /**
+ * Checks if a key is present and not null.
+ *
+ * @param string|array $key
+ * @return bool
+ */
+ public function has($key)
+ {
+ return ! collect(is_array($key) ? $key : func_get_args())->contains(function ($key) {
+ return is_null($this->get($key));
+ });
+ }
+
+ /**
+ * Get an item from the session.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public function get($key, $default = null)
+ {
+ return Arr::get($this->attributes, $key, $default);
+ }
+
+ /**
+ * Get the value of a given key and then forget it.
+ *
+ * @param string $key
+ * @param string $default
+ * @return mixed
+ */
+ public function pull($key, $default = null)
+ {
+ return Arr::pull($this->attributes, $key, $default);
+ }
+
+ /**
+ * Determine if the session contains old input.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function hasOldInput($key = null)
+ {
+ $old = $this->getOldInput($key);
+
+ return is_null($key) ? count($old) > 0 : ! is_null($old);
+ }
+
+ /**
+ * Get the requested item from the flashed input array.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public function getOldInput($key = null, $default = null)
+ {
+ return Arr::get($this->get('_old_input', []), $key, $default);
+ }
+
+ /**
+ * Replace the given session attributes entirely.
+ *
+ * @param array $attributes
+ * @return void
+ */
+ public function replace(array $attributes)
+ {
+ $this->put($attributes);
+ }
+
+ /**
+ * Put a key / value pair or array of key / value pairs in the session.
+ *
+ * @param string|array $key
+ * @param mixed $value
+ * @return void
+ */
+ public function put($key, $value = null)
+ {
+ if (! is_array($key)) {
+ $key = [$key => $value];
+ }
+
+ foreach ($key as $arrayKey => $arrayValue) {
+ Arr::set($this->attributes, $arrayKey, $arrayValue);
+ }
+ }
+
+ /**
+ * Get an item from the session, or store the default value.
+ *
+ * @param string $key
+ * @param \Closure $callback
+ * @return mixed
+ */
+ public function remember($key, Closure $callback)
+ {
+ if (! is_null($value = $this->get($key))) {
+ return $value;
+ }
+
+ return tap($callback(), function ($value) use ($key) {
+ $this->put($key, $value);
+ });
+ }
+
+ /**
+ * Push a value onto a session array.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function push($key, $value)
+ {
+ $array = $this->get($key, []);
+
+ $array[] = $value;
+
+ $this->put($key, $array);
+ }
+
+ /**
+ * Increment the value of an item in the session.
+ *
+ * @param string $key
+ * @param int $amount
+ * @return mixed
+ */
+ public function increment($key, $amount = 1)
+ {
+ $this->put($key, $value = $this->get($key, 0) + $amount);
+
+ return $value;
+ }
+
+ /**
+ * Decrement the value of an item in the session.
+ *
+ * @param string $key
+ * @param int $amount
+ * @return int
+ */
+ public function decrement($key, $amount = 1)
+ {
+ return $this->increment($key, $amount * -1);
+ }
+
+ /**
+ * Flash a key / value pair to the session.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function flash($key, $value)
+ {
+ $this->put($key, $value);
+
+ $this->push('_flash.new', $key);
+
+ $this->removeFromOldFlashData([$key]);
+ }
+
+ /**
+ * Flash a key / value pair to the session for immediate use.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function now($key, $value)
+ {
+ $this->put($key, $value);
+
+ $this->push('_flash.old', $key);
+ }
+
+ /**
+ * Reflash all of the session flash data.
+ *
+ * @return void
+ */
+ public function reflash()
+ {
+ $this->mergeNewFlashes($this->get('_flash.old', []));
+
+ $this->put('_flash.old', []);
+ }
+
+ /**
+ * Reflash a subset of the current flash data.
+ *
+ * @param array|mixed $keys
+ * @return void
+ */
+ public function keep($keys = null)
+ {
+ $this->mergeNewFlashes($keys = is_array($keys) ? $keys : func_get_args());
+
+ $this->removeFromOldFlashData($keys);
+ }
+
+ /**
+ * Merge new flash keys into the new flash array.
+ *
+ * @param array $keys
+ * @return void
+ */
+ protected function mergeNewFlashes(array $keys)
+ {
+ $values = array_unique(array_merge($this->get('_flash.new', []), $keys));
+
+ $this->put('_flash.new', $values);
+ }
+
+ /**
+ * Remove the given keys from the old flash data.
+ *
+ * @param array $keys
+ * @return void
+ */
+ protected function removeFromOldFlashData(array $keys)
+ {
+ $this->put('_flash.old', array_diff($this->get('_flash.old', []), $keys));
+ }
+
+ /**
+ * Flash an input array to the session.
+ *
+ * @param array $value
+ * @return void
+ */
+ public function flashInput(array $value)
+ {
+ $this->flash('_old_input', $value);
+ }
+
+ /**
+ * Remove an item from the session, returning its value.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function remove($key)
+ {
+ return Arr::pull($this->attributes, $key);
+ }
+
+ /**
+ * Remove one or many items from the session.
+ *
+ * @param string|array $keys
+ * @return void
+ */
+ public function forget($keys)
+ {
+ Arr::forget($this->attributes, $keys);
+ }
+
+ /**
+ * Remove all of the items from the session.
+ *
+ * @return void
+ */
+ public function flush()
+ {
+ $this->attributes = [];
+ }
+
+ /**
+ * Flush the session data and regenerate the ID.
+ *
+ * @return bool
+ */
+ public function invalidate()
+ {
+ $this->flush();
+
+ return $this->migrate(true);
+ }
+
+ /**
+ * Generate a new session identifier.
+ *
+ * @param bool $destroy
+ * @return bool
+ */
+ public function regenerate($destroy = false)
+ {
+ return $this->migrate($destroy);
+ }
+
+ /**
+ * Generate a new session ID for the session.
+ *
+ * @param bool $destroy
+ * @return bool
+ */
+ public function migrate($destroy = false)
+ {
+ if ($destroy) {
+ $this->handler->destroy($this->getId());
+ }
+
+ $this->setExists(false);
+
+ $this->setId($this->generateSessionId());
+
+ return true;
+ }
+
+ /**
+ * Determine if the session has been started.
+ *
+ * @return bool
+ */
+ public function isStarted()
+ {
+ return $this->started;
+ }
+
+ /**
+ * Get the name of the session.
+ *
+ * @return string
+ */
+ public function getName()
+ {
+ return $this->name;
+ }
+
+ /**
+ * Set the name of the session.
+ *
+ * @param string $name
+ * @return void
+ */
+ public function setName($name)
+ {
+ $this->name = $name;
+ }
+
+ /**
+ * Get the current session ID.
+ *
+ * @return string
+ */
+ public function getId()
+ {
+ return $this->id;
+ }
+
+ /**
+ * Set the session ID.
+ *
+ * @param string $id
+ * @return void
+ */
+ public function setId($id)
+ {
+ $this->id = $this->isValidId($id) ? $id : $this->generateSessionId();
+ }
+
+ /**
+ * Determine if this is a valid session ID.
+ *
+ * @param string $id
+ * @return bool
+ */
+ public function isValidId($id)
+ {
+ return is_string($id) && ctype_alnum($id) && strlen($id) === 40;
+ }
+
+ /**
+ * Get a new, random session ID.
+ *
+ * @return string
+ */
+ protected function generateSessionId()
+ {
+ return Str::random(40);
+ }
+
+ /**
+ * Set the existence of the session on the handler if applicable.
+ *
+ * @param bool $value
+ * @return void
+ */
+ public function setExists($value)
+ {
+ if ($this->handler instanceof ExistenceAwareInterface) {
+ $this->handler->setExists($value);
+ }
+ }
+
+ /**
+ * Get the CSRF token value.
+ *
+ * @return string
+ */
+ public function token()
+ {
+ return $this->get('_token');
+ }
+
+ /**
+ * Regenerate the CSRF token value.
+ *
+ * @return void
+ */
+ public function regenerateToken()
+ {
+ $this->put('_token', Str::random(40));
+ }
+
+ /**
+ * Get the previous URL from the session.
+ *
+ * @return string|null
+ */
+ public function previousUrl()
+ {
+ return $this->get('_previous.url');
+ }
+
+ /**
+ * Set the "previous" URL in the session.
+ *
+ * @param string $url
+ * @return void
+ */
+ public function setPreviousUrl($url)
+ {
+ $this->put('_previous.url', $url);
+ }
+
+ /**
+ * Get the underlying session handler implementation.
+ *
+ * @return \SessionHandlerInterface
+ */
+ public function getHandler()
+ {
+ return $this->handler;
+ }
+
+ /**
+ * Determine if the session handler needs a request.
+ *
+ * @return bool
+ */
+ public function handlerNeedsRequest()
+ {
+ return $this->handler instanceof CookieSessionHandler;
+ }
+
+ /**
+ * Set the request on the handler instance.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ */
+ public function setRequestOnHandler($request)
+ {
+ if ($this->handlerNeedsRequest()) {
+ $this->handler->setRequest($request);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Session/TokenMismatchException.php b/vendor/laravel/framework/src/Illuminate/Session/TokenMismatchException.php
new file mode 100644
index 000000000..98d99a1e8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Session/TokenMismatchException.php
@@ -0,0 +1,10 @@
+=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/filesystem": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "nesbot/carbon": "~1.20",
+ "symfony/finder": "~3.2",
+ "symfony/http-foundation": "~3.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Session\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "illuminate/console": "Required to use the session:table command (5.4.*)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/AggregateServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Support/AggregateServiceProvider.php
new file mode 100644
index 000000000..d7425c5c2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/AggregateServiceProvider.php
@@ -0,0 +1,52 @@
+instances = [];
+
+ foreach ($this->providers as $provider) {
+ $this->instances[] = $this->app->register($provider);
+ }
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ $provides = [];
+
+ foreach ($this->providers as $provider) {
+ $instance = $this->app->resolveProvider($provider);
+
+ $provides = array_merge($provides, $instance->provides());
+ }
+
+ return $provides;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Arr.php b/vendor/laravel/framework/src/Illuminate/Support/Arr.php
new file mode 100644
index 000000000..4b3e44715
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Arr.php
@@ -0,0 +1,602 @@
+all();
+ } elseif (! is_array($values)) {
+ continue;
+ }
+
+ $results = array_merge($results, $values);
+ }
+
+ return $results;
+ }
+
+ /**
+ * Cross join the given arrays, returning all possible permutations.
+ *
+ * @param array ...$arrays
+ * @return array
+ */
+ public static function crossJoin(...$arrays)
+ {
+ $results = [[]];
+
+ foreach ($arrays as $index => $array) {
+ $append = [];
+
+ foreach ($results as $product) {
+ foreach ($array as $item) {
+ $product[$index] = $item;
+
+ $append[] = $product;
+ }
+ }
+
+ $results = $append;
+ }
+
+ return $results;
+ }
+
+ /**
+ * Divide an array into two arrays. One with keys and the other with values.
+ *
+ * @param array $array
+ * @return array
+ */
+ public static function divide($array)
+ {
+ return [array_keys($array), array_values($array)];
+ }
+
+ /**
+ * Flatten a multi-dimensional associative array with dots.
+ *
+ * @param array $array
+ * @param string $prepend
+ * @return array
+ */
+ public static function dot($array, $prepend = '')
+ {
+ $results = [];
+
+ foreach ($array as $key => $value) {
+ if (is_array($value) && ! empty($value)) {
+ $results = array_merge($results, static::dot($value, $prepend.$key.'.'));
+ } else {
+ $results[$prepend.$key] = $value;
+ }
+ }
+
+ return $results;
+ }
+
+ /**
+ * Get all of the given array except for a specified array of items.
+ *
+ * @param array $array
+ * @param array|string $keys
+ * @return array
+ */
+ public static function except($array, $keys)
+ {
+ static::forget($array, $keys);
+
+ return $array;
+ }
+
+ /**
+ * Determine if the given key exists in the provided array.
+ *
+ * @param \ArrayAccess|array $array
+ * @param string|int $key
+ * @return bool
+ */
+ public static function exists($array, $key)
+ {
+ if ($array instanceof ArrayAccess) {
+ return $array->offsetExists($key);
+ }
+
+ return array_key_exists($key, $array);
+ }
+
+ /**
+ * Return the first element in an array passing a given truth test.
+ *
+ * @param array $array
+ * @param callable|null $callback
+ * @param mixed $default
+ * @return mixed
+ */
+ public static function first($array, callable $callback = null, $default = null)
+ {
+ if (is_null($callback)) {
+ if (empty($array)) {
+ return value($default);
+ }
+
+ foreach ($array as $item) {
+ return $item;
+ }
+ }
+
+ foreach ($array as $key => $value) {
+ if (call_user_func($callback, $value, $key)) {
+ return $value;
+ }
+ }
+
+ return value($default);
+ }
+
+ /**
+ * Return the last element in an array passing a given truth test.
+ *
+ * @param array $array
+ * @param callable|null $callback
+ * @param mixed $default
+ * @return mixed
+ */
+ public static function last($array, callable $callback = null, $default = null)
+ {
+ if (is_null($callback)) {
+ return empty($array) ? value($default) : end($array);
+ }
+
+ return static::first(array_reverse($array, true), $callback, $default);
+ }
+
+ /**
+ * Flatten a multi-dimensional array into a single level.
+ *
+ * @param array $array
+ * @param int $depth
+ * @return array
+ */
+ public static function flatten($array, $depth = INF)
+ {
+ return array_reduce($array, function ($result, $item) use ($depth) {
+ $item = $item instanceof Collection ? $item->all() : $item;
+
+ if (! is_array($item)) {
+ return array_merge($result, [$item]);
+ } elseif ($depth === 1) {
+ return array_merge($result, array_values($item));
+ } else {
+ return array_merge($result, static::flatten($item, $depth - 1));
+ }
+ }, []);
+ }
+
+ /**
+ * Remove one or many array items from a given array using "dot" notation.
+ *
+ * @param array $array
+ * @param array|string $keys
+ * @return void
+ */
+ public static function forget(&$array, $keys)
+ {
+ $original = &$array;
+
+ $keys = (array) $keys;
+
+ if (count($keys) === 0) {
+ return;
+ }
+
+ foreach ($keys as $key) {
+ // if the exact key exists in the top-level, remove it
+ if (static::exists($array, $key)) {
+ unset($array[$key]);
+
+ continue;
+ }
+
+ $parts = explode('.', $key);
+
+ // clean up before each pass
+ $array = &$original;
+
+ while (count($parts) > 1) {
+ $part = array_shift($parts);
+
+ if (isset($array[$part]) && is_array($array[$part])) {
+ $array = &$array[$part];
+ } else {
+ continue 2;
+ }
+ }
+
+ unset($array[array_shift($parts)]);
+ }
+ }
+
+ /**
+ * Get an item from an array using "dot" notation.
+ *
+ * @param \ArrayAccess|array $array
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public static function get($array, $key, $default = null)
+ {
+ if (! static::accessible($array)) {
+ return value($default);
+ }
+
+ if (is_null($key)) {
+ return $array;
+ }
+
+ if (static::exists($array, $key)) {
+ return $array[$key];
+ }
+
+ foreach (explode('.', $key) as $segment) {
+ if (static::accessible($array) && static::exists($array, $segment)) {
+ $array = $array[$segment];
+ } else {
+ return value($default);
+ }
+ }
+
+ return $array;
+ }
+
+ /**
+ * Check if an item or items exist in an array using "dot" notation.
+ *
+ * @param \ArrayAccess|array $array
+ * @param string|array $keys
+ * @return bool
+ */
+ public static function has($array, $keys)
+ {
+ if (is_null($keys)) {
+ return false;
+ }
+
+ $keys = (array) $keys;
+
+ if (! $array) {
+ return false;
+ }
+
+ if ($keys === []) {
+ return false;
+ }
+
+ foreach ($keys as $key) {
+ $subKeyArray = $array;
+
+ if (static::exists($array, $key)) {
+ continue;
+ }
+
+ foreach (explode('.', $key) as $segment) {
+ if (static::accessible($subKeyArray) && static::exists($subKeyArray, $segment)) {
+ $subKeyArray = $subKeyArray[$segment];
+ } else {
+ return false;
+ }
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Determines if an array is associative.
+ *
+ * An array is "associative" if it doesn't have sequential numerical keys beginning with zero.
+ *
+ * @param array $array
+ * @return bool
+ */
+ public static function isAssoc(array $array)
+ {
+ $keys = array_keys($array);
+
+ return array_keys($keys) !== $keys;
+ }
+
+ /**
+ * Get a subset of the items from the given array.
+ *
+ * @param array $array
+ * @param array|string $keys
+ * @return array
+ */
+ public static function only($array, $keys)
+ {
+ return array_intersect_key($array, array_flip((array) $keys));
+ }
+
+ /**
+ * Pluck an array of values from an array.
+ *
+ * @param array $array
+ * @param string|array $value
+ * @param string|array|null $key
+ * @return array
+ */
+ public static function pluck($array, $value, $key = null)
+ {
+ $results = [];
+
+ list($value, $key) = static::explodePluckParameters($value, $key);
+
+ foreach ($array as $item) {
+ $itemValue = data_get($item, $value);
+
+ // If the key is "null", we will just append the value to the array and keep
+ // looping. Otherwise we will key the array using the value of the key we
+ // received from the developer. Then we'll return the final array form.
+ if (is_null($key)) {
+ $results[] = $itemValue;
+ } else {
+ $itemKey = data_get($item, $key);
+
+ if (is_object($itemKey) && method_exists($itemKey, '__toString')) {
+ $itemKey = (string) $itemKey;
+ }
+
+ $results[$itemKey] = $itemValue;
+ }
+ }
+
+ return $results;
+ }
+
+ /**
+ * Explode the "value" and "key" arguments passed to "pluck".
+ *
+ * @param string|array $value
+ * @param string|array|null $key
+ * @return array
+ */
+ protected static function explodePluckParameters($value, $key)
+ {
+ $value = is_string($value) ? explode('.', $value) : $value;
+
+ $key = is_null($key) || is_array($key) ? $key : explode('.', $key);
+
+ return [$value, $key];
+ }
+
+ /**
+ * Push an item onto the beginning of an array.
+ *
+ * @param array $array
+ * @param mixed $value
+ * @param mixed $key
+ * @return array
+ */
+ public static function prepend($array, $value, $key = null)
+ {
+ if (is_null($key)) {
+ array_unshift($array, $value);
+ } else {
+ $array = [$key => $value] + $array;
+ }
+
+ return $array;
+ }
+
+ /**
+ * Get a value from the array, and remove it.
+ *
+ * @param array $array
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public static function pull(&$array, $key, $default = null)
+ {
+ $value = static::get($array, $key, $default);
+
+ static::forget($array, $key);
+
+ return $value;
+ }
+
+ /**
+ * Get one or a specified number of random values from an array.
+ *
+ * @param array $array
+ * @param int|null $number
+ * @return mixed
+ *
+ * @throws \InvalidArgumentException
+ */
+ public static function random($array, $number = null)
+ {
+ $requested = is_null($number) ? 1 : $number;
+
+ $count = count($array);
+
+ if ($requested > $count) {
+ throw new InvalidArgumentException(
+ "You requested {$requested} items, but there are only {$count} items available."
+ );
+ }
+
+ if (is_null($number)) {
+ return $array[array_rand($array)];
+ }
+
+ if ((int) $number === 0) {
+ return [];
+ }
+
+ $keys = array_rand($array, $number);
+
+ $results = [];
+
+ foreach ((array) $keys as $key) {
+ $results[] = $array[$key];
+ }
+
+ return $results;
+ }
+
+ /**
+ * Set an array item to a given value using "dot" notation.
+ *
+ * If no key is given to the method, the entire array will be replaced.
+ *
+ * @param array $array
+ * @param string $key
+ * @param mixed $value
+ * @return array
+ */
+ public static function set(&$array, $key, $value)
+ {
+ if (is_null($key)) {
+ return $array = $value;
+ }
+
+ $keys = explode('.', $key);
+
+ while (count($keys) > 1) {
+ $key = array_shift($keys);
+
+ // If the key doesn't exist at this depth, we will just create an empty array
+ // to hold the next value, allowing us to create the arrays to hold final
+ // values at the correct depth. Then we'll keep digging into the array.
+ if (! isset($array[$key]) || ! is_array($array[$key])) {
+ $array[$key] = [];
+ }
+
+ $array = &$array[$key];
+ }
+
+ $array[array_shift($keys)] = $value;
+
+ return $array;
+ }
+
+ /**
+ * Shuffle the given array and return the result.
+ *
+ * @param array $array
+ * @return array
+ */
+ public static function shuffle($array)
+ {
+ shuffle($array);
+
+ return $array;
+ }
+
+ /**
+ * Sort the array using the given callback or "dot" notation.
+ *
+ * @param array $array
+ * @param callable|string $callback
+ * @return array
+ */
+ public static function sort($array, $callback)
+ {
+ return Collection::make($array)->sortBy($callback)->all();
+ }
+
+ /**
+ * Recursively sort an array by keys and values.
+ *
+ * @param array $array
+ * @return array
+ */
+ public static function sortRecursive($array)
+ {
+ foreach ($array as &$value) {
+ if (is_array($value)) {
+ $value = static::sortRecursive($value);
+ }
+ }
+
+ if (static::isAssoc($array)) {
+ ksort($array);
+ } else {
+ sort($array);
+ }
+
+ return $array;
+ }
+
+ /**
+ * Filter the array using the given callback.
+ *
+ * @param array $array
+ * @param callable $callback
+ * @return array
+ */
+ public static function where($array, callable $callback)
+ {
+ return array_filter($array, $callback, ARRAY_FILTER_USE_BOTH);
+ }
+
+ /**
+ * If the given value is not an array, wrap it in one.
+ *
+ * @param mixed $value
+ * @return array
+ */
+ public static function wrap($value)
+ {
+ return ! is_array($value) ? [$value] : $value;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Collection.php b/vendor/laravel/framework/src/Illuminate/Support/Collection.php
new file mode 100644
index 000000000..fa7a8505a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Collection.php
@@ -0,0 +1,1655 @@
+items = $this->getArrayableItems($items);
+ }
+
+ /**
+ * Create a new collection instance if the value isn't one already.
+ *
+ * @param mixed $items
+ * @return static
+ */
+ public static function make($items = [])
+ {
+ return new static($items);
+ }
+
+ /**
+ * Create a new collection by invoking the callback a given number of times.
+ *
+ * @param int $number
+ * @param callable $callback
+ * @return static
+ */
+ public static function times($number, callable $callback = null)
+ {
+ if ($number < 1) {
+ return new static;
+ }
+
+ if (is_null($callback)) {
+ return new static(range(1, $number));
+ }
+
+ return (new static(range(1, $number)))->map($callback);
+ }
+
+ /**
+ * Get all of the items in the collection.
+ *
+ * @return array
+ */
+ public function all()
+ {
+ return $this->items;
+ }
+
+ /**
+ * Get the average value of a given key.
+ *
+ * @param callable|string|null $callback
+ * @return mixed
+ */
+ public function avg($callback = null)
+ {
+ if ($count = $this->count()) {
+ return $this->sum($callback) / $count;
+ }
+ }
+
+ /**
+ * Alias for the "avg" method.
+ *
+ * @param callable|string|null $callback
+ * @return mixed
+ */
+ public function average($callback = null)
+ {
+ return $this->avg($callback);
+ }
+
+ /**
+ * Get the median of a given key.
+ *
+ * @param null $key
+ * @return mixed
+ */
+ public function median($key = null)
+ {
+ $count = $this->count();
+
+ if ($count == 0) {
+ return;
+ }
+
+ $values = with(isset($key) ? $this->pluck($key) : $this)
+ ->sort()->values();
+
+ $middle = (int) ($count / 2);
+
+ if ($count % 2) {
+ return $values->get($middle);
+ }
+
+ return (new static([
+ $values->get($middle - 1), $values->get($middle),
+ ]))->average();
+ }
+
+ /**
+ * Get the mode of a given key.
+ *
+ * @param mixed $key
+ * @return array|null
+ */
+ public function mode($key = null)
+ {
+ $count = $this->count();
+
+ if ($count == 0) {
+ return;
+ }
+
+ $collection = isset($key) ? $this->pluck($key) : $this;
+
+ $counts = new self;
+
+ $collection->each(function ($value) use ($counts) {
+ $counts[$value] = isset($counts[$value]) ? $counts[$value] + 1 : 1;
+ });
+
+ $sorted = $counts->sort();
+
+ $highestValue = $sorted->last();
+
+ return $sorted->filter(function ($value) use ($highestValue) {
+ return $value == $highestValue;
+ })->sort()->keys()->all();
+ }
+
+ /**
+ * Collapse the collection of items into a single array.
+ *
+ * @return static
+ */
+ public function collapse()
+ {
+ return new static(Arr::collapse($this->items));
+ }
+
+ /**
+ * Determine if an item exists in the collection.
+ *
+ * @param mixed $key
+ * @param mixed $operator
+ * @param mixed $value
+ * @return bool
+ */
+ public function contains($key, $operator = null, $value = null)
+ {
+ if (func_num_args() == 1) {
+ if ($this->useAsCallable($key)) {
+ return ! is_null($this->first($key));
+ }
+
+ return in_array($key, $this->items);
+ }
+
+ if (func_num_args() == 2) {
+ $value = $operator;
+
+ $operator = '=';
+ }
+
+ return $this->contains($this->operatorForWhere($key, $operator, $value));
+ }
+
+ /**
+ * Determine if an item exists in the collection using strict comparison.
+ *
+ * @param mixed $key
+ * @param mixed $value
+ * @return bool
+ */
+ public function containsStrict($key, $value = null)
+ {
+ if (func_num_args() == 2) {
+ return $this->contains(function ($item) use ($key, $value) {
+ return data_get($item, $key) === $value;
+ });
+ }
+
+ if ($this->useAsCallable($key)) {
+ return ! is_null($this->first($key));
+ }
+
+ return in_array($key, $this->items, true);
+ }
+
+ /**
+ * Cross join with the given lists, returning all possible permutations.
+ *
+ * @param mixed ...$lists
+ * @return static
+ */
+ public function crossJoin(...$lists)
+ {
+ return new static(Arr::crossJoin(
+ $this->items, ...array_map([$this, 'getArrayableItems'], $lists)
+ ));
+ }
+
+ /**
+ * Get the items in the collection that are not present in the given items.
+ *
+ * @param mixed $items
+ * @return static
+ */
+ public function diff($items)
+ {
+ return new static(array_diff($this->items, $this->getArrayableItems($items)));
+ }
+
+ /**
+ * Get the items in the collection whose keys and values are not present in the given items.
+ *
+ * @param mixed $items
+ * @return static
+ */
+ public function diffAssoc($items)
+ {
+ return new static(array_diff_assoc($this->items, $this->getArrayableItems($items)));
+ }
+
+ /**
+ * Get the items in the collection whose keys are not present in the given items.
+ *
+ * @param mixed $items
+ * @return static
+ */
+ public function diffKeys($items)
+ {
+ return new static(array_diff_key($this->items, $this->getArrayableItems($items)));
+ }
+
+ /**
+ * Execute a callback over each item.
+ *
+ * @param callable $callback
+ * @return $this
+ */
+ public function each(callable $callback)
+ {
+ foreach ($this->items as $key => $item) {
+ if ($callback($item, $key) === false) {
+ break;
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Execute a callback over each nested chunk of items.
+ *
+ * @param callable $callback
+ * @return static
+ */
+ public function eachSpread(callable $callback)
+ {
+ return $this->each(function ($chunk) use ($callback) {
+ return $callback(...$chunk);
+ });
+ }
+
+ /**
+ * Determine if all items in the collection pass the given test.
+ *
+ * @param string|callable $key
+ * @param mixed $operator
+ * @param mixed $value
+ * @return bool
+ */
+ public function every($key, $operator = null, $value = null)
+ {
+ if (func_num_args() == 1) {
+ $callback = $this->valueRetriever($key);
+
+ foreach ($this->items as $k => $v) {
+ if (! $callback($v, $k)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ if (func_num_args() == 2) {
+ $value = $operator;
+
+ $operator = '=';
+ }
+
+ return $this->every($this->operatorForWhere($key, $operator, $value));
+ }
+
+ /**
+ * Get all items except for those with the specified keys.
+ *
+ * @param mixed $keys
+ * @return static
+ */
+ public function except($keys)
+ {
+ $keys = is_array($keys) ? $keys : func_get_args();
+
+ return new static(Arr::except($this->items, $keys));
+ }
+
+ /**
+ * Run a filter over each of the items.
+ *
+ * @param callable|null $callback
+ * @return static
+ */
+ public function filter(callable $callback = null)
+ {
+ if ($callback) {
+ return new static(Arr::where($this->items, $callback));
+ }
+
+ return new static(array_filter($this->items));
+ }
+
+ /**
+ * Apply the callback if the value is truthy.
+ *
+ * @param bool $value
+ * @param callable $callback
+ * @param callable $default
+ * @return mixed
+ */
+ public function when($value, callable $callback, callable $default = null)
+ {
+ if ($value) {
+ return $callback($this);
+ } elseif ($default) {
+ return $default($this);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Apply the callback if the value is falsy.
+ *
+ * @param bool $value
+ * @param callable $callback
+ * @param callable $default
+ * @return mixed
+ */
+ public function unless($value, callable $callback, callable $default = null)
+ {
+ return $this->when(! $value, $callback, $default);
+ }
+
+ /**
+ * Filter items by the given key value pair.
+ *
+ * @param string $key
+ * @param mixed $operator
+ * @param mixed $value
+ * @return static
+ */
+ public function where($key, $operator, $value = null)
+ {
+ if (func_num_args() == 2) {
+ $value = $operator;
+
+ $operator = '=';
+ }
+
+ return $this->filter($this->operatorForWhere($key, $operator, $value));
+ }
+
+ /**
+ * Get an operator checker callback.
+ *
+ * @param string $key
+ * @param string $operator
+ * @param mixed $value
+ * @return \Closure
+ */
+ protected function operatorForWhere($key, $operator, $value)
+ {
+ return function ($item) use ($key, $operator, $value) {
+ $retrieved = data_get($item, $key);
+
+ switch ($operator) {
+ default:
+ case '=':
+ case '==': return $retrieved == $value;
+ case '!=':
+ case '<>': return $retrieved != $value;
+ case '<': return $retrieved < $value;
+ case '>': return $retrieved > $value;
+ case '<=': return $retrieved <= $value;
+ case '>=': return $retrieved >= $value;
+ case '===': return $retrieved === $value;
+ case '!==': return $retrieved !== $value;
+ }
+ };
+ }
+
+ /**
+ * Filter items by the given key value pair using strict comparison.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return static
+ */
+ public function whereStrict($key, $value)
+ {
+ return $this->where($key, '===', $value);
+ }
+
+ /**
+ * Filter items by the given key value pair.
+ *
+ * @param string $key
+ * @param mixed $values
+ * @param bool $strict
+ * @return static
+ */
+ public function whereIn($key, $values, $strict = false)
+ {
+ $values = $this->getArrayableItems($values);
+
+ return $this->filter(function ($item) use ($key, $values, $strict) {
+ return in_array(data_get($item, $key), $values, $strict);
+ });
+ }
+
+ /**
+ * Filter items by the given key value pair using strict comparison.
+ *
+ * @param string $key
+ * @param mixed $values
+ * @return static
+ */
+ public function whereInStrict($key, $values)
+ {
+ return $this->whereIn($key, $values, true);
+ }
+
+ /**
+ * Filter items by the given key value pair.
+ *
+ * @param string $key
+ * @param mixed $values
+ * @param bool $strict
+ * @return static
+ */
+ public function whereNotIn($key, $values, $strict = false)
+ {
+ $values = $this->getArrayableItems($values);
+
+ return $this->reject(function ($item) use ($key, $values, $strict) {
+ return in_array(data_get($item, $key), $values, $strict);
+ });
+ }
+
+ /**
+ * Filter items by the given key value pair using strict comparison.
+ *
+ * @param string $key
+ * @param mixed $values
+ * @return static
+ */
+ public function whereNotInStrict($key, $values)
+ {
+ return $this->whereNotIn($key, $values, true);
+ }
+
+ /**
+ * Get the first item from the collection.
+ *
+ * @param callable|null $callback
+ * @param mixed $default
+ * @return mixed
+ */
+ public function first(callable $callback = null, $default = null)
+ {
+ return Arr::first($this->items, $callback, $default);
+ }
+
+ /**
+ * Get a flattened array of the items in the collection.
+ *
+ * @param int $depth
+ * @return static
+ */
+ public function flatten($depth = INF)
+ {
+ return new static(Arr::flatten($this->items, $depth));
+ }
+
+ /**
+ * Flip the items in the collection.
+ *
+ * @return static
+ */
+ public function flip()
+ {
+ return new static(array_flip($this->items));
+ }
+
+ /**
+ * Remove an item from the collection by key.
+ *
+ * @param string|array $keys
+ * @return $this
+ */
+ public function forget($keys)
+ {
+ foreach ((array) $keys as $key) {
+ $this->offsetUnset($key);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Get an item from the collection by key.
+ *
+ * @param mixed $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public function get($key, $default = null)
+ {
+ if ($this->offsetExists($key)) {
+ return $this->items[$key];
+ }
+
+ return value($default);
+ }
+
+ /**
+ * Group an associative array by a field or using a callback.
+ *
+ * @param callable|string $groupBy
+ * @param bool $preserveKeys
+ * @return static
+ */
+ public function groupBy($groupBy, $preserveKeys = false)
+ {
+ $groupBy = $this->valueRetriever($groupBy);
+
+ $results = [];
+
+ foreach ($this->items as $key => $value) {
+ $groupKeys = $groupBy($value, $key);
+
+ if (! is_array($groupKeys)) {
+ $groupKeys = [$groupKeys];
+ }
+
+ foreach ($groupKeys as $groupKey) {
+ $groupKey = is_bool($groupKey) ? (int) $groupKey : $groupKey;
+
+ if (! array_key_exists($groupKey, $results)) {
+ $results[$groupKey] = new static;
+ }
+
+ $results[$groupKey]->offsetSet($preserveKeys ? $key : null, $value);
+ }
+ }
+
+ return new static($results);
+ }
+
+ /**
+ * Key an associative array by a field or using a callback.
+ *
+ * @param callable|string $keyBy
+ * @return static
+ */
+ public function keyBy($keyBy)
+ {
+ $keyBy = $this->valueRetriever($keyBy);
+
+ $results = [];
+
+ foreach ($this->items as $key => $item) {
+ $resolvedKey = $keyBy($item, $key);
+
+ if (is_object($resolvedKey)) {
+ $resolvedKey = (string) $resolvedKey;
+ }
+
+ $results[$resolvedKey] = $item;
+ }
+
+ return new static($results);
+ }
+
+ /**
+ * Determine if an item exists in the collection by key.
+ *
+ * @param mixed $key
+ * @return bool
+ */
+ public function has($key)
+ {
+ return $this->offsetExists($key);
+ }
+
+ /**
+ * Concatenate values of a given key as a string.
+ *
+ * @param string $value
+ * @param string $glue
+ * @return string
+ */
+ public function implode($value, $glue = null)
+ {
+ $first = $this->first();
+
+ if (is_array($first) || is_object($first)) {
+ return implode($glue, $this->pluck($value)->all());
+ }
+
+ return implode($value, $this->items);
+ }
+
+ /**
+ * Intersect the collection with the given items.
+ *
+ * @param mixed $items
+ * @return static
+ */
+ public function intersect($items)
+ {
+ return new static(array_intersect($this->items, $this->getArrayableItems($items)));
+ }
+
+ /**
+ * Intersect the collection with the given items by key.
+ *
+ * @param mixed $items
+ * @return static
+ */
+ public function intersectKey($items)
+ {
+ return new static(array_intersect_key($this->items, $this->getArrayableItems($items)));
+ }
+
+ /**
+ * Determine if the collection is empty or not.
+ *
+ * @return bool
+ */
+ public function isEmpty()
+ {
+ return empty($this->items);
+ }
+
+ /**
+ * Determine if the collection is not empty.
+ *
+ * @return bool
+ */
+ public function isNotEmpty()
+ {
+ return ! $this->isEmpty();
+ }
+
+ /**
+ * Determine if the given value is callable, but not a string.
+ *
+ * @param mixed $value
+ * @return bool
+ */
+ protected function useAsCallable($value)
+ {
+ return ! is_string($value) && is_callable($value);
+ }
+
+ /**
+ * Get the keys of the collection items.
+ *
+ * @return static
+ */
+ public function keys()
+ {
+ return new static(array_keys($this->items));
+ }
+
+ /**
+ * Get the last item from the collection.
+ *
+ * @param callable|null $callback
+ * @param mixed $default
+ * @return mixed
+ */
+ public function last(callable $callback = null, $default = null)
+ {
+ return Arr::last($this->items, $callback, $default);
+ }
+
+ /**
+ * Get the values of a given key.
+ *
+ * @param string|array $value
+ * @param string|null $key
+ * @return static
+ */
+ public function pluck($value, $key = null)
+ {
+ return new static(Arr::pluck($this->items, $value, $key));
+ }
+
+ /**
+ * Run a map over each of the items.
+ *
+ * @param callable $callback
+ * @return static
+ */
+ public function map(callable $callback)
+ {
+ $keys = array_keys($this->items);
+
+ $items = array_map($callback, $this->items, $keys);
+
+ return new static(array_combine($keys, $items));
+ }
+
+ /**
+ * Run a map over each nested chunk of items.
+ *
+ * @param callable $callback
+ * @return static
+ */
+ public function mapSpread(callable $callback)
+ {
+ return $this->map(function ($chunk) use ($callback) {
+ return $callback(...$chunk);
+ });
+ }
+
+ /**
+ * Run a grouping map over the items.
+ *
+ * The callback should return an associative array with a single key/value pair.
+ *
+ * @param callable $callback
+ * @return static
+ */
+ public function mapToGroups(callable $callback)
+ {
+ $groups = $this->map($callback)->reduce(function ($groups, $pair) {
+ $groups[key($pair)][] = reset($pair);
+
+ return $groups;
+ }, []);
+
+ return (new static($groups))->map([$this, 'make']);
+ }
+
+ /**
+ * Run an associative map over each of the items.
+ *
+ * The callback should return an associative array with a single key/value pair.
+ *
+ * @param callable $callback
+ * @return static
+ */
+ public function mapWithKeys(callable $callback)
+ {
+ $result = [];
+
+ foreach ($this->items as $key => $value) {
+ $assoc = $callback($value, $key);
+
+ foreach ($assoc as $mapKey => $mapValue) {
+ $result[$mapKey] = $mapValue;
+ }
+ }
+
+ return new static($result);
+ }
+
+ /**
+ * Map a collection and flatten the result by a single level.
+ *
+ * @param callable $callback
+ * @return static
+ */
+ public function flatMap(callable $callback)
+ {
+ return $this->map($callback)->collapse();
+ }
+
+ /**
+ * Get the max value of a given key.
+ *
+ * @param callable|string|null $callback
+ * @return mixed
+ */
+ public function max($callback = null)
+ {
+ $callback = $this->valueRetriever($callback);
+
+ return $this->filter(function ($value) {
+ return ! is_null($value);
+ })->reduce(function ($result, $item) use ($callback) {
+ $value = $callback($item);
+
+ return is_null($result) || $value > $result ? $value : $result;
+ });
+ }
+
+ /**
+ * Merge the collection with the given items.
+ *
+ * @param mixed $items
+ * @return static
+ */
+ public function merge($items)
+ {
+ return new static(array_merge($this->items, $this->getArrayableItems($items)));
+ }
+
+ /**
+ * Create a collection by using this collection for keys and another for its values.
+ *
+ * @param mixed $values
+ * @return static
+ */
+ public function combine($values)
+ {
+ return new static(array_combine($this->all(), $this->getArrayableItems($values)));
+ }
+
+ /**
+ * Union the collection with the given items.
+ *
+ * @param mixed $items
+ * @return static
+ */
+ public function union($items)
+ {
+ return new static($this->items + $this->getArrayableItems($items));
+ }
+
+ /**
+ * Get the min value of a given key.
+ *
+ * @param callable|string|null $callback
+ * @return mixed
+ */
+ public function min($callback = null)
+ {
+ $callback = $this->valueRetriever($callback);
+
+ return $this->filter(function ($value) {
+ return ! is_null($value);
+ })->reduce(function ($result, $item) use ($callback) {
+ $value = $callback($item);
+
+ return is_null($result) || $value < $result ? $value : $result;
+ });
+ }
+
+ /**
+ * Create a new collection consisting of every n-th element.
+ *
+ * @param int $step
+ * @param int $offset
+ * @return static
+ */
+ public function nth($step, $offset = 0)
+ {
+ $new = [];
+
+ $position = 0;
+
+ foreach ($this->items as $item) {
+ if ($position % $step === $offset) {
+ $new[] = $item;
+ }
+
+ $position++;
+ }
+
+ return new static($new);
+ }
+
+ /**
+ * Get the items with the specified keys.
+ *
+ * @param mixed $keys
+ * @return static
+ */
+ public function only($keys)
+ {
+ if (is_null($keys)) {
+ return new static($this->items);
+ }
+
+ $keys = is_array($keys) ? $keys : func_get_args();
+
+ return new static(Arr::only($this->items, $keys));
+ }
+
+ /**
+ * "Paginate" the collection by slicing it into a smaller collection.
+ *
+ * @param int $page
+ * @param int $perPage
+ * @return static
+ */
+ public function forPage($page, $perPage)
+ {
+ return $this->slice(($page - 1) * $perPage, $perPage);
+ }
+
+ /**
+ * Partition the collection into two arrays using the given callback or key.
+ *
+ * @param callable|string $callback
+ * @return static
+ */
+ public function partition($callback)
+ {
+ $partitions = [new static, new static];
+
+ $callback = $this->valueRetriever($callback);
+
+ foreach ($this->items as $key => $item) {
+ $partitions[(int) ! $callback($item)][$key] = $item;
+ }
+
+ return new static($partitions);
+ }
+
+ /**
+ * Pass the collection to the given callback and return the result.
+ *
+ * @param callable $callback
+ * @return mixed
+ */
+ public function pipe(callable $callback)
+ {
+ return $callback($this);
+ }
+
+ /**
+ * Get and remove the last item from the collection.
+ *
+ * @return mixed
+ */
+ public function pop()
+ {
+ return array_pop($this->items);
+ }
+
+ /**
+ * Push an item onto the beginning of the collection.
+ *
+ * @param mixed $value
+ * @param mixed $key
+ * @return $this
+ */
+ public function prepend($value, $key = null)
+ {
+ $this->items = Arr::prepend($this->items, $value, $key);
+
+ return $this;
+ }
+
+ /**
+ * Push an item onto the end of the collection.
+ *
+ * @param mixed $value
+ * @return $this
+ */
+ public function push($value)
+ {
+ $this->offsetSet(null, $value);
+
+ return $this;
+ }
+
+ /**
+ * Push all of the given items onto the collection.
+ *
+ * @param \Traversable $source
+ * @return self
+ */
+ public function concat($source)
+ {
+ $result = new static($this);
+
+ foreach ($source as $item) {
+ $result->push($item);
+ }
+
+ return $result;
+ }
+
+ /**
+ * Get and remove an item from the collection.
+ *
+ * @param mixed $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public function pull($key, $default = null)
+ {
+ return Arr::pull($this->items, $key, $default);
+ }
+
+ /**
+ * Put an item in the collection by key.
+ *
+ * @param mixed $key
+ * @param mixed $value
+ * @return $this
+ */
+ public function put($key, $value)
+ {
+ $this->offsetSet($key, $value);
+
+ return $this;
+ }
+
+ /**
+ * Get one or a specified number of items randomly from the collection.
+ *
+ * @param int|null $number
+ * @return mixed
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function random($number = null)
+ {
+ if (is_null($number)) {
+ return Arr::random($this->items);
+ }
+
+ return new static(Arr::random($this->items, $number));
+ }
+
+ /**
+ * Reduce the collection to a single value.
+ *
+ * @param callable $callback
+ * @param mixed $initial
+ * @return mixed
+ */
+ public function reduce(callable $callback, $initial = null)
+ {
+ return array_reduce($this->items, $callback, $initial);
+ }
+
+ /**
+ * Create a collection of all elements that do not pass a given truth test.
+ *
+ * @param callable|mixed $callback
+ * @return static
+ */
+ public function reject($callback)
+ {
+ if ($this->useAsCallable($callback)) {
+ return $this->filter(function ($value, $key) use ($callback) {
+ return ! $callback($value, $key);
+ });
+ }
+
+ return $this->filter(function ($item) use ($callback) {
+ return $item != $callback;
+ });
+ }
+
+ /**
+ * Reverse items order.
+ *
+ * @return static
+ */
+ public function reverse()
+ {
+ return new static(array_reverse($this->items, true));
+ }
+
+ /**
+ * Search the collection for a given value and return the corresponding key if successful.
+ *
+ * @param mixed $value
+ * @param bool $strict
+ * @return mixed
+ */
+ public function search($value, $strict = false)
+ {
+ if (! $this->useAsCallable($value)) {
+ return array_search($value, $this->items, $strict);
+ }
+
+ foreach ($this->items as $key => $item) {
+ if (call_user_func($value, $item, $key)) {
+ return $key;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Get and remove the first item from the collection.
+ *
+ * @return mixed
+ */
+ public function shift()
+ {
+ return array_shift($this->items);
+ }
+
+ /**
+ * Shuffle the items in the collection.
+ *
+ * @param int $seed
+ * @return static
+ */
+ public function shuffle($seed = null)
+ {
+ $items = $this->items;
+
+ if (is_null($seed)) {
+ shuffle($items);
+ } else {
+ srand($seed);
+
+ usort($items, function () {
+ return rand(-1, 1);
+ });
+ }
+
+ return new static($items);
+ }
+
+ /**
+ * Slice the underlying collection array.
+ *
+ * @param int $offset
+ * @param int $length
+ * @return static
+ */
+ public function slice($offset, $length = null)
+ {
+ return new static(array_slice($this->items, $offset, $length, true));
+ }
+
+ /**
+ * Split a collection into a certain number of groups.
+ *
+ * @param int $numberOfGroups
+ * @return static
+ */
+ public function split($numberOfGroups)
+ {
+ if ($this->isEmpty()) {
+ return new static;
+ }
+
+ $groupSize = ceil($this->count() / $numberOfGroups);
+
+ return $this->chunk($groupSize);
+ }
+
+ /**
+ * Chunk the underlying collection array.
+ *
+ * @param int $size
+ * @return static
+ */
+ public function chunk($size)
+ {
+ if ($size <= 0) {
+ return new static;
+ }
+
+ $chunks = [];
+
+ foreach (array_chunk($this->items, $size, true) as $chunk) {
+ $chunks[] = new static($chunk);
+ }
+
+ return new static($chunks);
+ }
+
+ /**
+ * Sort through each item with a callback.
+ *
+ * @param callable|null $callback
+ * @return static
+ */
+ public function sort(callable $callback = null)
+ {
+ $items = $this->items;
+
+ $callback
+ ? uasort($items, $callback)
+ : asort($items);
+
+ return new static($items);
+ }
+
+ /**
+ * Sort the collection using the given callback.
+ *
+ * @param callable|string $callback
+ * @param int $options
+ * @param bool $descending
+ * @return static
+ */
+ public function sortBy($callback, $options = SORT_REGULAR, $descending = false)
+ {
+ $results = [];
+
+ $callback = $this->valueRetriever($callback);
+
+ // First we will loop through the items and get the comparator from a callback
+ // function which we were given. Then, we will sort the returned values and
+ // and grab the corresponding values for the sorted keys from this array.
+ foreach ($this->items as $key => $value) {
+ $results[$key] = $callback($value, $key);
+ }
+
+ $descending ? arsort($results, $options)
+ : asort($results, $options);
+
+ // Once we have sorted all of the keys in the array, we will loop through them
+ // and grab the corresponding model so we can set the underlying items list
+ // to the sorted version. Then we'll just return the collection instance.
+ foreach (array_keys($results) as $key) {
+ $results[$key] = $this->items[$key];
+ }
+
+ return new static($results);
+ }
+
+ /**
+ * Sort the collection in descending order using the given callback.
+ *
+ * @param callable|string $callback
+ * @param int $options
+ * @return static
+ */
+ public function sortByDesc($callback, $options = SORT_REGULAR)
+ {
+ return $this->sortBy($callback, $options, true);
+ }
+
+ /**
+ * Splice a portion of the underlying collection array.
+ *
+ * @param int $offset
+ * @param int|null $length
+ * @param mixed $replacement
+ * @return static
+ */
+ public function splice($offset, $length = null, $replacement = [])
+ {
+ if (func_num_args() == 1) {
+ return new static(array_splice($this->items, $offset));
+ }
+
+ return new static(array_splice($this->items, $offset, $length, $replacement));
+ }
+
+ /**
+ * Get the sum of the given values.
+ *
+ * @param callable|string|null $callback
+ * @return mixed
+ */
+ public function sum($callback = null)
+ {
+ if (is_null($callback)) {
+ return array_sum($this->items);
+ }
+
+ $callback = $this->valueRetriever($callback);
+
+ return $this->reduce(function ($result, $item) use ($callback) {
+ return $result + $callback($item);
+ }, 0);
+ }
+
+ /**
+ * Take the first or last {$limit} items.
+ *
+ * @param int $limit
+ * @return static
+ */
+ public function take($limit)
+ {
+ if ($limit < 0) {
+ return $this->slice($limit, abs($limit));
+ }
+
+ return $this->slice(0, $limit);
+ }
+
+ /**
+ * Pass the collection to the given callback and then return it.
+ *
+ * @param callable $callback
+ * @return $this
+ */
+ public function tap(callable $callback)
+ {
+ $callback(new static($this->items));
+
+ return $this;
+ }
+
+ /**
+ * Transform each item in the collection using a callback.
+ *
+ * @param callable $callback
+ * @return $this
+ */
+ public function transform(callable $callback)
+ {
+ $this->items = $this->map($callback)->all();
+
+ return $this;
+ }
+
+ /**
+ * Return only unique items from the collection array.
+ *
+ * @param string|callable|null $key
+ * @param bool $strict
+ * @return static
+ */
+ public function unique($key = null, $strict = false)
+ {
+ if (is_null($key)) {
+ return new static(array_unique($this->items, SORT_REGULAR));
+ }
+
+ $callback = $this->valueRetriever($key);
+
+ $exists = [];
+
+ return $this->reject(function ($item, $key) use ($callback, $strict, &$exists) {
+ if (in_array($id = $callback($item, $key), $exists, $strict)) {
+ return true;
+ }
+
+ $exists[] = $id;
+ });
+ }
+
+ /**
+ * Return only unique items from the collection array using strict comparison.
+ *
+ * @param string|callable|null $key
+ * @return static
+ */
+ public function uniqueStrict($key = null)
+ {
+ return $this->unique($key, true);
+ }
+
+ /**
+ * Reset the keys on the underlying array.
+ *
+ * @return static
+ */
+ public function values()
+ {
+ return new static(array_values($this->items));
+ }
+
+ /**
+ * Get a value retrieving callback.
+ *
+ * @param string $value
+ * @return callable
+ */
+ protected function valueRetriever($value)
+ {
+ if ($this->useAsCallable($value)) {
+ return $value;
+ }
+
+ return function ($item) use ($value) {
+ return data_get($item, $value);
+ };
+ }
+
+ /**
+ * Zip the collection together with one or more arrays.
+ *
+ * e.g. new Collection([1, 2, 3])->zip([4, 5, 6]);
+ * => [[1, 4], [2, 5], [3, 6]]
+ *
+ * @param mixed ...$items
+ * @return static
+ */
+ public function zip($items)
+ {
+ $arrayableItems = array_map(function ($items) {
+ return $this->getArrayableItems($items);
+ }, func_get_args());
+
+ $params = array_merge([function () {
+ return new static(func_get_args());
+ }, $this->items], $arrayableItems);
+
+ return new static(call_user_func_array('array_map', $params));
+ }
+
+ /**
+ * Get the collection of items as a plain array.
+ *
+ * @return array
+ */
+ public function toArray()
+ {
+ return array_map(function ($value) {
+ return $value instanceof Arrayable ? $value->toArray() : $value;
+ }, $this->items);
+ }
+
+ /**
+ * Convert the object into something JSON serializable.
+ *
+ * @return array
+ */
+ public function jsonSerialize()
+ {
+ return array_map(function ($value) {
+ if ($value instanceof JsonSerializable) {
+ return $value->jsonSerialize();
+ } elseif ($value instanceof Jsonable) {
+ return json_decode($value->toJson(), true);
+ } elseif ($value instanceof Arrayable) {
+ return $value->toArray();
+ } else {
+ return $value;
+ }
+ }, $this->items);
+ }
+
+ /**
+ * Get the collection of items as JSON.
+ *
+ * @param int $options
+ * @return string
+ */
+ public function toJson($options = 0)
+ {
+ return json_encode($this->jsonSerialize(), $options);
+ }
+
+ /**
+ * Get an iterator for the items.
+ *
+ * @return \ArrayIterator
+ */
+ public function getIterator()
+ {
+ return new ArrayIterator($this->items);
+ }
+
+ /**
+ * Get a CachingIterator instance.
+ *
+ * @param int $flags
+ * @return \CachingIterator
+ */
+ public function getCachingIterator($flags = CachingIterator::CALL_TOSTRING)
+ {
+ return new CachingIterator($this->getIterator(), $flags);
+ }
+
+ /**
+ * Count the number of items in the collection.
+ *
+ * @return int
+ */
+ public function count()
+ {
+ return count($this->items);
+ }
+
+ /**
+ * Get a base Support collection instance from this collection.
+ *
+ * @return \Illuminate\Support\Collection
+ */
+ public function toBase()
+ {
+ return new self($this);
+ }
+
+ /**
+ * Determine if an item exists at an offset.
+ *
+ * @param mixed $key
+ * @return bool
+ */
+ public function offsetExists($key)
+ {
+ return array_key_exists($key, $this->items);
+ }
+
+ /**
+ * Get an item at a given offset.
+ *
+ * @param mixed $key
+ * @return mixed
+ */
+ public function offsetGet($key)
+ {
+ return $this->items[$key];
+ }
+
+ /**
+ * Set the item at a given offset.
+ *
+ * @param mixed $key
+ * @param mixed $value
+ * @return void
+ */
+ public function offsetSet($key, $value)
+ {
+ if (is_null($key)) {
+ $this->items[] = $value;
+ } else {
+ $this->items[$key] = $value;
+ }
+ }
+
+ /**
+ * Unset the item at a given offset.
+ *
+ * @param string $key
+ * @return void
+ */
+ public function offsetUnset($key)
+ {
+ unset($this->items[$key]);
+ }
+
+ /**
+ * Convert the collection to its string representation.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->toJson();
+ }
+
+ /**
+ * Results array of items from Collection or Arrayable.
+ *
+ * @param mixed $items
+ * @return array
+ */
+ protected function getArrayableItems($items)
+ {
+ if (is_array($items)) {
+ return $items;
+ } elseif ($items instanceof self) {
+ return $items->all();
+ } elseif ($items instanceof Arrayable) {
+ return $items->toArray();
+ } elseif ($items instanceof Jsonable) {
+ return json_decode($items->toJson(), true);
+ } elseif ($items instanceof JsonSerializable) {
+ return $items->jsonSerialize();
+ } elseif ($items instanceof Traversable) {
+ return iterator_to_array($items);
+ }
+
+ return (array) $items;
+ }
+
+ /**
+ * Add a method to the list of proxied methods.
+ *
+ * @param string $method
+ * @return void
+ */
+ public static function proxy($method)
+ {
+ static::$proxies[] = $method;
+ }
+
+ /**
+ * Dynamically access collection proxies.
+ *
+ * @param string $key
+ * @return mixed
+ *
+ * @throws \Exception
+ */
+ public function __get($key)
+ {
+ if (! in_array($key, static::$proxies)) {
+ throw new Exception("Property [{$key}] does not exist on this collection instance.");
+ }
+
+ return new HigherOrderCollectionProxy($this, $key);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Composer.php b/vendor/laravel/framework/src/Illuminate/Support/Composer.php
new file mode 100644
index 000000000..b0eaa9236
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Composer.php
@@ -0,0 +1,100 @@
+files = $files;
+ $this->workingPath = $workingPath;
+ }
+
+ /**
+ * Regenerate the Composer autoloader files.
+ *
+ * @param string $extra
+ * @return void
+ */
+ public function dumpAutoloads($extra = '')
+ {
+ $process = $this->getProcess();
+
+ $process->setCommandLine(trim($this->findComposer().' dump-autoload '.$extra));
+
+ $process->run();
+ }
+
+ /**
+ * Regenerate the optimized Composer autoloader files.
+ *
+ * @return void
+ */
+ public function dumpOptimized()
+ {
+ $this->dumpAutoloads('--optimize');
+ }
+
+ /**
+ * Get the composer command for the environment.
+ *
+ * @return string
+ */
+ protected function findComposer()
+ {
+ if ($this->files->exists($this->workingPath.'/composer.phar')) {
+ return ProcessUtils::escapeArgument((new PhpExecutableFinder)->find(false)).' composer.phar';
+ }
+
+ return 'composer';
+ }
+
+ /**
+ * Get a new Symfony process instance.
+ *
+ * @return \Symfony\Component\Process\Process
+ */
+ protected function getProcess()
+ {
+ return (new Process('', $this->workingPath))->setTimeout(null);
+ }
+
+ /**
+ * Set the working path used by the class.
+ *
+ * @param string $path
+ * @return $this
+ */
+ public function setWorkingPath($path)
+ {
+ $this->workingPath = realpath($path);
+
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Debug/Dumper.php b/vendor/laravel/framework/src/Illuminate/Support/Debug/Dumper.php
new file mode 100644
index 000000000..0c84a8b19
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Debug/Dumper.php
@@ -0,0 +1,26 @@
+dump((new VarCloner)->cloneVar($value));
+ } else {
+ var_dump($value);
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Debug/HtmlDumper.php b/vendor/laravel/framework/src/Illuminate/Support/Debug/HtmlDumper.php
new file mode 100644
index 000000000..5825ac8db
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Debug/HtmlDumper.php
@@ -0,0 +1,29 @@
+ 'background-color:#fff; color:#222; line-height:1.2em; font-weight:normal; font:12px Monaco, Consolas, monospace; word-wrap: break-word; white-space: pre-wrap; position:relative; z-index:100000',
+ 'num' => 'color:#a71d5d',
+ 'const' => 'color:#795da3',
+ 'str' => 'color:#df5000',
+ 'cchr' => 'color:#222',
+ 'note' => 'color:#a71d5d',
+ 'ref' => 'color:#a0a0a0',
+ 'public' => 'color:#795da3',
+ 'protected' => 'color:#795da3',
+ 'private' => 'color:#795da3',
+ 'meta' => 'color:#b729d9',
+ 'key' => 'color:#df5000',
+ 'index' => 'color:#a71d5d',
+ ];
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Facades/App.php b/vendor/laravel/framework/src/Illuminate/Support/Facades/App.php
new file mode 100644
index 000000000..0e9e6370f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Facades/App.php
@@ -0,0 +1,31 @@
+make('router')->auth();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Facades/Blade.php b/vendor/laravel/framework/src/Illuminate/Support/Facades/Blade.php
new file mode 100644
index 000000000..b016a46c2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Facades/Blade.php
@@ -0,0 +1,19 @@
+getEngineResolver()->resolve('blade')->getCompiler();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Facades/Broadcast.php b/vendor/laravel/framework/src/Illuminate/Support/Facades/Broadcast.php
new file mode 100644
index 000000000..81af93217
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Facades/Broadcast.php
@@ -0,0 +1,21 @@
+cookie($key, null));
+ }
+
+ /**
+ * Retrieve a cookie from the request.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return string
+ */
+ public static function get($key = null, $default = null)
+ {
+ return static::$app['request']->cookie($key, $default);
+ }
+
+ /**
+ * Get the registered name of the component.
+ *
+ * @return string
+ */
+ protected static function getFacadeAccessor()
+ {
+ return 'cookie';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Facades/Crypt.php b/vendor/laravel/framework/src/Illuminate/Support/Facades/Crypt.php
new file mode 100644
index 000000000..0eef08d1b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Facades/Crypt.php
@@ -0,0 +1,19 @@
+shouldReceive(...func_get_args());
+ }
+
+ /**
+ * Create a fresh mock instance for the given class.
+ *
+ * @return \Mockery\Expectation
+ */
+ protected static function createFreshMockInstance()
+ {
+ return tap(static::createMock(), function ($mock) {
+ static::swap($mock);
+
+ $mock->shouldAllowMockingProtectedMethods();
+ });
+ }
+
+ /**
+ * Create a fresh mock instance for the given class.
+ *
+ * @return \Mockery\MockInterface
+ */
+ protected static function createMock()
+ {
+ $class = static::getMockableClass();
+
+ return $class ? Mockery::mock($class) : Mockery::mock();
+ }
+
+ /**
+ * Determines whether a mock is set as the instance of the facade.
+ *
+ * @return bool
+ */
+ protected static function isMock()
+ {
+ $name = static::getFacadeAccessor();
+
+ return isset(static::$resolvedInstance[$name]) &&
+ static::$resolvedInstance[$name] instanceof MockInterface;
+ }
+
+ /**
+ * Get the mockable class for the bound instance.
+ *
+ * @return string|null
+ */
+ protected static function getMockableClass()
+ {
+ if ($root = static::getFacadeRoot()) {
+ return get_class($root);
+ }
+ }
+
+ /**
+ * Hotswap the underlying instance behind the facade.
+ *
+ * @param mixed $instance
+ * @return void
+ */
+ public static function swap($instance)
+ {
+ static::$resolvedInstance[static::getFacadeAccessor()] = $instance;
+
+ if (isset(static::$app)) {
+ static::$app->instance(static::getFacadeAccessor(), $instance);
+ }
+ }
+
+ /**
+ * Get the root object behind the facade.
+ *
+ * @return mixed
+ */
+ public static function getFacadeRoot()
+ {
+ return static::resolveFacadeInstance(static::getFacadeAccessor());
+ }
+
+ /**
+ * Get the registered name of the component.
+ *
+ * @return string
+ *
+ * @throws \RuntimeException
+ */
+ protected static function getFacadeAccessor()
+ {
+ throw new RuntimeException('Facade does not implement getFacadeAccessor method.');
+ }
+
+ /**
+ * Resolve the facade root instance from the container.
+ *
+ * @param string|object $name
+ * @return mixed
+ */
+ protected static function resolveFacadeInstance($name)
+ {
+ if (is_object($name)) {
+ return $name;
+ }
+
+ if (isset(static::$resolvedInstance[$name])) {
+ return static::$resolvedInstance[$name];
+ }
+
+ return static::$resolvedInstance[$name] = static::$app[$name];
+ }
+
+ /**
+ * Clear a resolved facade instance.
+ *
+ * @param string $name
+ * @return void
+ */
+ public static function clearResolvedInstance($name)
+ {
+ unset(static::$resolvedInstance[$name]);
+ }
+
+ /**
+ * Clear all of the resolved instances.
+ *
+ * @return void
+ */
+ public static function clearResolvedInstances()
+ {
+ static::$resolvedInstance = [];
+ }
+
+ /**
+ * Get the application instance behind the facade.
+ *
+ * @return \Illuminate\Contracts\Foundation\Application
+ */
+ public static function getFacadeApplication()
+ {
+ return static::$app;
+ }
+
+ /**
+ * Set the application instance.
+ *
+ * @param \Illuminate\Contracts\Foundation\Application $app
+ * @return void
+ */
+ public static function setFacadeApplication($app)
+ {
+ static::$app = $app;
+ }
+
+ /**
+ * Handle dynamic, static calls to the object.
+ *
+ * @param string $method
+ * @param array $args
+ * @return mixed
+ *
+ * @throws \RuntimeException
+ */
+ public static function __callStatic($method, $args)
+ {
+ $instance = static::getFacadeRoot();
+
+ if (! $instance) {
+ throw new RuntimeException('A facade root has not been set.');
+ }
+
+ return $instance->$method(...$args);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Facades/File.php b/vendor/laravel/framework/src/Illuminate/Support/Facades/File.php
new file mode 100644
index 000000000..0f81bf62a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Facades/File.php
@@ -0,0 +1,19 @@
+input($key, $default);
+ }
+
+ /**
+ * Get the registered name of the component.
+ *
+ * @return string
+ */
+ protected static function getFacadeAccessor()
+ {
+ return 'request';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Facades/Lang.php b/vendor/laravel/framework/src/Illuminate/Support/Facades/Lang.php
new file mode 100644
index 000000000..e5862b993
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Facades/Lang.php
@@ -0,0 +1,19 @@
+connection($name)->getSchemaBuilder();
+ }
+
+ /**
+ * Get a schema builder instance for the default connection.
+ *
+ * @return \Illuminate\Database\Schema\Builder
+ */
+ protected static function getFacadeAccessor()
+ {
+ return static::$app['db']->connection()->getSchemaBuilder();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Facades/Session.php b/vendor/laravel/framework/src/Illuminate/Support/Facades/Session.php
new file mode 100644
index 000000000..bc9b5fd9a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Facades/Session.php
@@ -0,0 +1,20 @@
+cleanDirectory(
+ $root = storage_path('framework/testing/disks/'.$disk)
+ );
+
+ static::set($disk, self::createLocalDriver(['root' => $root]));
+ }
+
+ /**
+ * Replace the given disk with a persistent local testing disk.
+ *
+ * @param string $disk
+ * @return void
+ */
+ public static function persistentFake($disk)
+ {
+ static::set($disk, self::createLocalDriver([
+ 'root' => storage_path('framework/testing/disks/'.$disk),
+ ]));
+ }
+
+ /**
+ * Get the registered name of the component.
+ *
+ * @return string
+ */
+ protected static function getFacadeAccessor()
+ {
+ return 'filesystem';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Facades/URL.php b/vendor/laravel/framework/src/Illuminate/Support/Facades/URL.php
new file mode 100644
index 000000000..e17414bc0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Facades/URL.php
@@ -0,0 +1,19 @@
+ $value) {
+ $this->attributes[$key] = $value;
+ }
+ }
+
+ /**
+ * Get an attribute from the container.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public function get($key, $default = null)
+ {
+ if (array_key_exists($key, $this->attributes)) {
+ return $this->attributes[$key];
+ }
+
+ return value($default);
+ }
+
+ /**
+ * Get the attributes from the container.
+ *
+ * @return array
+ */
+ public function getAttributes()
+ {
+ return $this->attributes;
+ }
+
+ /**
+ * Convert the Fluent instance to an array.
+ *
+ * @return array
+ */
+ public function toArray()
+ {
+ return $this->attributes;
+ }
+
+ /**
+ * Convert the object into something JSON serializable.
+ *
+ * @return array
+ */
+ public function jsonSerialize()
+ {
+ return $this->toArray();
+ }
+
+ /**
+ * Convert the Fluent instance to JSON.
+ *
+ * @param int $options
+ * @return string
+ */
+ public function toJson($options = 0)
+ {
+ return json_encode($this->jsonSerialize(), $options);
+ }
+
+ /**
+ * Determine if the given offset exists.
+ *
+ * @param string $offset
+ * @return bool
+ */
+ public function offsetExists($offset)
+ {
+ return isset($this->{$offset});
+ }
+
+ /**
+ * Get the value for a given offset.
+ *
+ * @param string $offset
+ * @return mixed
+ */
+ public function offsetGet($offset)
+ {
+ return $this->{$offset};
+ }
+
+ /**
+ * Set the value at the given offset.
+ *
+ * @param string $offset
+ * @param mixed $value
+ * @return void
+ */
+ public function offsetSet($offset, $value)
+ {
+ $this->{$offset} = $value;
+ }
+
+ /**
+ * Unset the value at the given offset.
+ *
+ * @param string $offset
+ * @return void
+ */
+ public function offsetUnset($offset)
+ {
+ unset($this->{$offset});
+ }
+
+ /**
+ * Handle dynamic calls to the container to set attributes.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return $this
+ */
+ public function __call($method, $parameters)
+ {
+ $this->attributes[$method] = count($parameters) > 0 ? $parameters[0] : true;
+
+ return $this;
+ }
+
+ /**
+ * Dynamically retrieve the value of an attribute.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function __get($key)
+ {
+ return $this->get($key);
+ }
+
+ /**
+ * Dynamically set the value of an attribute.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function __set($key, $value)
+ {
+ $this->attributes[$key] = $value;
+ }
+
+ /**
+ * Dynamically check if an attribute is set.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function __isset($key)
+ {
+ return isset($this->attributes[$key]);
+ }
+
+ /**
+ * Dynamically unset an attribute.
+ *
+ * @param string $key
+ * @return void
+ */
+ public function __unset($key)
+ {
+ unset($this->attributes[$key]);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/HigherOrderCollectionProxy.php b/vendor/laravel/framework/src/Illuminate/Support/HigherOrderCollectionProxy.php
new file mode 100644
index 000000000..7a781a021
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/HigherOrderCollectionProxy.php
@@ -0,0 +1,63 @@
+method = $method;
+ $this->collection = $collection;
+ }
+
+ /**
+ * Proxy accessing an attribute onto the collection items.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function __get($key)
+ {
+ return $this->collection->{$this->method}(function ($value) use ($key) {
+ return is_array($value) ? $value[$key] : $value->{$key};
+ });
+ }
+
+ /**
+ * Proxy a method call onto the collection items.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->collection->{$this->method}(function ($value) use ($method, $parameters) {
+ return $value->{$method}(...$parameters);
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/HigherOrderTapProxy.php b/vendor/laravel/framework/src/Illuminate/Support/HigherOrderTapProxy.php
new file mode 100644
index 000000000..bbf9b2e54
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/HigherOrderTapProxy.php
@@ -0,0 +1,38 @@
+target = $target;
+ }
+
+ /**
+ * Dynamically pass method calls to the target.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ $this->target->{$method}(...$parameters);
+
+ return $this->target;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/HtmlString.php b/vendor/laravel/framework/src/Illuminate/Support/HtmlString.php
new file mode 100644
index 000000000..c13adfd47
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/HtmlString.php
@@ -0,0 +1,46 @@
+html = $html;
+ }
+
+ /**
+ * Get the HTML string.
+ *
+ * @return string
+ */
+ public function toHtml()
+ {
+ return $this->html;
+ }
+
+ /**
+ * Get the HTML string.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->toHtml();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Manager.php b/vendor/laravel/framework/src/Illuminate/Support/Manager.php
new file mode 100644
index 000000000..592776c2c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Manager.php
@@ -0,0 +1,140 @@
+app = $app;
+ }
+
+ /**
+ * Get the default driver name.
+ *
+ * @return string
+ */
+ abstract public function getDefaultDriver();
+
+ /**
+ * Get a driver instance.
+ *
+ * @param string $driver
+ * @return mixed
+ */
+ public function driver($driver = null)
+ {
+ $driver = $driver ?: $this->getDefaultDriver();
+
+ // If the given driver has not been created before, we will create the instances
+ // here and cache it so we can return it next time very quickly. If there is
+ // already a driver created by this name, we'll just return that instance.
+ if (! isset($this->drivers[$driver])) {
+ $this->drivers[$driver] = $this->createDriver($driver);
+ }
+
+ return $this->drivers[$driver];
+ }
+
+ /**
+ * Create a new driver instance.
+ *
+ * @param string $driver
+ * @return mixed
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function createDriver($driver)
+ {
+ // We'll check to see if a creator method exists for the given driver. If not we
+ // will check for a custom driver creator, which allows developers to create
+ // drivers using their own customized driver creator Closure to create it.
+ if (isset($this->customCreators[$driver])) {
+ return $this->callCustomCreator($driver);
+ } else {
+ $method = 'create'.Str::studly($driver).'Driver';
+
+ if (method_exists($this, $method)) {
+ return $this->$method();
+ }
+ }
+ throw new InvalidArgumentException("Driver [$driver] not supported.");
+ }
+
+ /**
+ * Call a custom driver creator.
+ *
+ * @param string $driver
+ * @return mixed
+ */
+ protected function callCustomCreator($driver)
+ {
+ return $this->customCreators[$driver]($this->app);
+ }
+
+ /**
+ * Register a custom driver creator Closure.
+ *
+ * @param string $driver
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function extend($driver, Closure $callback)
+ {
+ $this->customCreators[$driver] = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Get all of the created "drivers".
+ *
+ * @return array
+ */
+ public function getDrivers()
+ {
+ return $this->drivers;
+ }
+
+ /**
+ * Dynamically call the default driver instance.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->driver()->$method(...$parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/MessageBag.php b/vendor/laravel/framework/src/Illuminate/Support/MessageBag.php
new file mode 100644
index 000000000..657b8acf2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/MessageBag.php
@@ -0,0 +1,384 @@
+ $value) {
+ $this->messages[$key] = (array) $value;
+ }
+ }
+
+ /**
+ * Get the keys present in the message bag.
+ *
+ * @return array
+ */
+ public function keys()
+ {
+ return array_keys($this->messages);
+ }
+
+ /**
+ * Add a message to the bag.
+ *
+ * @param string $key
+ * @param string $message
+ * @return $this
+ */
+ public function add($key, $message)
+ {
+ if ($this->isUnique($key, $message)) {
+ $this->messages[$key][] = $message;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Determine if a key and message combination already exists.
+ *
+ * @param string $key
+ * @param string $message
+ * @return bool
+ */
+ protected function isUnique($key, $message)
+ {
+ $messages = (array) $this->messages;
+
+ return ! isset($messages[$key]) || ! in_array($message, $messages[$key]);
+ }
+
+ /**
+ * Merge a new array of messages into the bag.
+ *
+ * @param \Illuminate\Contracts\Support\MessageProvider|array $messages
+ * @return $this
+ */
+ public function merge($messages)
+ {
+ if ($messages instanceof MessageProvider) {
+ $messages = $messages->getMessageBag()->getMessages();
+ }
+
+ $this->messages = array_merge_recursive($this->messages, $messages);
+
+ return $this;
+ }
+
+ /**
+ * Determine if messages exist for all of the given keys.
+ *
+ * @param array|string $key
+ * @return bool
+ */
+ public function has($key)
+ {
+ if (is_null($key)) {
+ return $this->any();
+ }
+
+ $keys = is_array($key) ? $key : func_get_args();
+
+ foreach ($keys as $key) {
+ if ($this->first($key) === '') {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Determine if messages exist for any of the given keys.
+ *
+ * @param array|string $keys
+ * @return bool
+ */
+ public function hasAny($keys = [])
+ {
+ $keys = is_array($keys) ? $keys : func_get_args();
+
+ foreach ($keys as $key) {
+ if ($this->has($key)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Get the first message from the bag for a given key.
+ *
+ * @param string $key
+ * @param string $format
+ * @return string
+ */
+ public function first($key = null, $format = null)
+ {
+ $messages = is_null($key) ? $this->all($format) : $this->get($key, $format);
+
+ $firstMessage = Arr::first($messages, null, '');
+
+ return is_array($firstMessage) ? Arr::first($firstMessage) : $firstMessage;
+ }
+
+ /**
+ * Get all of the messages from the bag for a given key.
+ *
+ * @param string $key
+ * @param string $format
+ * @return array
+ */
+ public function get($key, $format = null)
+ {
+ // If the message exists in the container, we will transform it and return
+ // the message. Otherwise, we'll check if the key is implicit & collect
+ // all the messages that match a given key and output it as an array.
+ if (array_key_exists($key, $this->messages)) {
+ return $this->transform(
+ $this->messages[$key], $this->checkFormat($format), $key
+ );
+ }
+
+ if (Str::contains($key, '*')) {
+ return $this->getMessagesForWildcardKey($key, $format);
+ }
+
+ return [];
+ }
+
+ /**
+ * Get the messages for a wildcard key.
+ *
+ * @param string $key
+ * @param string|null $format
+ * @return array
+ */
+ protected function getMessagesForWildcardKey($key, $format)
+ {
+ return collect($this->messages)
+ ->filter(function ($messages, $messageKey) use ($key) {
+ return Str::is($key, $messageKey);
+ })
+ ->map(function ($messages, $messageKey) use ($format) {
+ return $this->transform(
+ $messages, $this->checkFormat($format), $messageKey
+ );
+ })->all();
+ }
+
+ /**
+ * Get all of the messages for every key in the bag.
+ *
+ * @param string $format
+ * @return array
+ */
+ public function all($format = null)
+ {
+ $format = $this->checkFormat($format);
+
+ $all = [];
+
+ foreach ($this->messages as $key => $messages) {
+ $all = array_merge($all, $this->transform($messages, $format, $key));
+ }
+
+ return $all;
+ }
+
+ /**
+ * Get all of the unique messages for every key in the bag.
+ *
+ * @param string $format
+ * @return array
+ */
+ public function unique($format = null)
+ {
+ return array_unique($this->all($format));
+ }
+
+ /**
+ * Format an array of messages.
+ *
+ * @param array $messages
+ * @param string $format
+ * @param string $messageKey
+ * @return array
+ */
+ protected function transform($messages, $format, $messageKey)
+ {
+ return collect((array) $messages)
+ ->map(function ($message) use ($format, $messageKey) {
+ // We will simply spin through the given messages and transform each one
+ // replacing the :message place holder with the real message allowing
+ // the messages to be easily formatted to each developer's desires.
+ return str_replace([':message', ':key'], [$message, $messageKey], $format);
+ })->all();
+ }
+
+ /**
+ * Get the appropriate format based on the given format.
+ *
+ * @param string $format
+ * @return string
+ */
+ protected function checkFormat($format)
+ {
+ return $format ?: $this->format;
+ }
+
+ /**
+ * Get the raw messages in the container.
+ *
+ * @return array
+ */
+ public function messages()
+ {
+ return $this->messages;
+ }
+
+ /**
+ * Get the raw messages in the container.
+ *
+ * @return array
+ */
+ public function getMessages()
+ {
+ return $this->messages();
+ }
+
+ /**
+ * Get the messages for the instance.
+ *
+ * @return \Illuminate\Support\MessageBag
+ */
+ public function getMessageBag()
+ {
+ return $this;
+ }
+
+ /**
+ * Get the default message format.
+ *
+ * @return string
+ */
+ public function getFormat()
+ {
+ return $this->format;
+ }
+
+ /**
+ * Set the default message format.
+ *
+ * @param string $format
+ * @return \Illuminate\Support\MessageBag
+ */
+ public function setFormat($format = ':message')
+ {
+ $this->format = $format;
+
+ return $this;
+ }
+
+ /**
+ * Determine if the message bag has any messages.
+ *
+ * @return bool
+ */
+ public function isEmpty()
+ {
+ return ! $this->any();
+ }
+
+ /**
+ * Determine if the message bag has any messages.
+ *
+ * @return bool
+ */
+ public function any()
+ {
+ return $this->count() > 0;
+ }
+
+ /**
+ * Get the number of messages in the container.
+ *
+ * @return int
+ */
+ public function count()
+ {
+ return count($this->messages, COUNT_RECURSIVE) - count($this->messages);
+ }
+
+ /**
+ * Get the instance as an array.
+ *
+ * @return array
+ */
+ public function toArray()
+ {
+ return $this->getMessages();
+ }
+
+ /**
+ * Convert the object into something JSON serializable.
+ *
+ * @return array
+ */
+ public function jsonSerialize()
+ {
+ return $this->toArray();
+ }
+
+ /**
+ * Convert the object to its JSON representation.
+ *
+ * @param int $options
+ * @return string
+ */
+ public function toJson($options = 0)
+ {
+ return json_encode($this->jsonSerialize(), $options);
+ }
+
+ /**
+ * Convert the message bag to its string representation.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->toJson();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/NamespacedItemResolver.php b/vendor/laravel/framework/src/Illuminate/Support/NamespacedItemResolver.php
new file mode 100644
index 000000000..cdf6cf9b5
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/NamespacedItemResolver.php
@@ -0,0 +1,106 @@
+parsed[$key])) {
+ return $this->parsed[$key];
+ }
+
+ // If the key does not contain a double colon, it means the key is not in a
+ // namespace, and is just a regular configuration item. Namespaces are a
+ // tool for organizing configuration items for things such as modules.
+ if (strpos($key, '::') === false) {
+ $segments = explode('.', $key);
+
+ $parsed = $this->parseBasicSegments($segments);
+ } else {
+ $parsed = $this->parseNamespacedSegments($key);
+ }
+
+ // Once we have the parsed array of this key's elements, such as its groups
+ // and namespace, we will cache each array inside a simple list that has
+ // the key and the parsed array for quick look-ups for later requests.
+ return $this->parsed[$key] = $parsed;
+ }
+
+ /**
+ * Parse an array of basic segments.
+ *
+ * @param array $segments
+ * @return array
+ */
+ protected function parseBasicSegments(array $segments)
+ {
+ // The first segment in a basic array will always be the group, so we can go
+ // ahead and grab that segment. If there is only one total segment we are
+ // just pulling an entire group out of the array and not a single item.
+ $group = $segments[0];
+
+ if (count($segments) == 1) {
+ return [null, $group, null];
+ }
+
+ // If there is more than one segment in this group, it means we are pulling
+ // a specific item out of a group and will need to return this item name
+ // as well as the group so we know which item to pull from the arrays.
+ else {
+ $item = implode('.', array_slice($segments, 1));
+
+ return [null, $group, $item];
+ }
+ }
+
+ /**
+ * Parse an array of namespaced segments.
+ *
+ * @param string $key
+ * @return array
+ */
+ protected function parseNamespacedSegments($key)
+ {
+ list($namespace, $item) = explode('::', $key);
+
+ // First we'll just explode the first segment to get the namespace and group
+ // since the item should be in the remaining segments. Once we have these
+ // two pieces of data we can proceed with parsing out the item's value.
+ $itemSegments = explode('.', $item);
+
+ $groupAndItem = array_slice(
+ $this->parseBasicSegments($itemSegments), 1
+ );
+
+ return array_merge([$namespace], $groupAndItem);
+ }
+
+ /**
+ * Set the parsed value of a key.
+ *
+ * @param string $key
+ * @param array $parsed
+ * @return void
+ */
+ public function setParsedKey($key, $parsed)
+ {
+ $this->parsed[$key] = $parsed;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Pluralizer.php b/vendor/laravel/framework/src/Illuminate/Support/Pluralizer.php
new file mode 100644
index 000000000..4d845aa89
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Pluralizer.php
@@ -0,0 +1,114 @@
+app = $app;
+ }
+
+ /**
+ * Merge the given configuration with the existing configuration.
+ *
+ * @param string $path
+ * @param string $key
+ * @return void
+ */
+ protected function mergeConfigFrom($path, $key)
+ {
+ $config = $this->app['config']->get($key, []);
+
+ $this->app['config']->set($key, array_merge(require $path, $config));
+ }
+
+ /**
+ * Load the given routes file if routes are not already cached.
+ *
+ * @param string $path
+ * @return void
+ */
+ protected function loadRoutesFrom($path)
+ {
+ if (! $this->app->routesAreCached()) {
+ require $path;
+ }
+ }
+
+ /**
+ * Register a view file namespace.
+ *
+ * @param string $path
+ * @param string $namespace
+ * @return void
+ */
+ protected function loadViewsFrom($path, $namespace)
+ {
+ if (is_dir($appPath = $this->app->resourcePath().'/views/vendor/'.$namespace)) {
+ $this->app['view']->addNamespace($namespace, $appPath);
+ }
+
+ $this->app['view']->addNamespace($namespace, $path);
+ }
+
+ /**
+ * Register a translation file namespace.
+ *
+ * @param string $path
+ * @param string $namespace
+ * @return void
+ */
+ protected function loadTranslationsFrom($path, $namespace)
+ {
+ $this->app['translator']->addNamespace($namespace, $path);
+ }
+
+ /**
+ * Register a database migration path.
+ *
+ * @param array|string $paths
+ * @return void
+ */
+ protected function loadMigrationsFrom($paths)
+ {
+ $this->app->afterResolving('migrator', function ($migrator) use ($paths) {
+ foreach ((array) $paths as $path) {
+ $migrator->path($path);
+ }
+ });
+ }
+
+ /**
+ * Register paths to be published by the publish command.
+ *
+ * @param array $paths
+ * @param string $group
+ * @return void
+ */
+ protected function publishes(array $paths, $group = null)
+ {
+ $this->ensurePublishArrayInitialized($class = static::class);
+
+ static::$publishes[$class] = array_merge(static::$publishes[$class], $paths);
+
+ if ($group) {
+ $this->addPublishGroup($group, $paths);
+ }
+ }
+
+ /**
+ * Ensure the publish array for the service provider is initialized.
+ *
+ * @param string $class
+ * @return void
+ */
+ protected function ensurePublishArrayInitialized($class)
+ {
+ if (! array_key_exists($class, static::$publishes)) {
+ static::$publishes[$class] = [];
+ }
+ }
+
+ /**
+ * Add a publish group / tag to the service provider.
+ *
+ * @param string $group
+ * @param array $paths
+ * @return void
+ */
+ protected function addPublishGroup($group, $paths)
+ {
+ if (! array_key_exists($group, static::$publishGroups)) {
+ static::$publishGroups[$group] = [];
+ }
+
+ static::$publishGroups[$group] = array_merge(
+ static::$publishGroups[$group], $paths
+ );
+ }
+
+ /**
+ * Get the paths to publish.
+ *
+ * @param string $provider
+ * @param string $group
+ * @return array
+ */
+ public static function pathsToPublish($provider = null, $group = null)
+ {
+ if (! is_null($paths = static::pathsForProviderOrGroup($provider, $group))) {
+ return $paths;
+ }
+
+ return collect(static::$publishes)->reduce(function ($paths, $p) {
+ return array_merge($paths, $p);
+ }, []);
+ }
+
+ /**
+ * Get the paths for the provider or group (or both).
+ *
+ * @param string|null $provider
+ * @param string|null $group
+ * @return array
+ */
+ protected static function pathsForProviderOrGroup($provider, $group)
+ {
+ if ($provider && $group) {
+ return static::pathsForProviderAndGroup($provider, $group);
+ } elseif ($group && array_key_exists($group, static::$publishGroups)) {
+ return static::$publishGroups[$group];
+ } elseif ($provider && array_key_exists($provider, static::$publishes)) {
+ return static::$publishes[$provider];
+ } elseif ($group || $provider) {
+ return [];
+ }
+ }
+
+ /**
+ * Get the paths for the provider and group.
+ *
+ * @param string $provider
+ * @param string $group
+ * @return array
+ */
+ protected static function pathsForProviderAndGroup($provider, $group)
+ {
+ if (! empty(static::$publishes[$provider]) && ! empty(static::$publishGroups[$group])) {
+ return array_intersect_key(static::$publishes[$provider], static::$publishGroups[$group]);
+ }
+
+ return [];
+ }
+
+ /**
+ * Register the package's custom Artisan commands.
+ *
+ * @param array|mixed $commands
+ * @return void
+ */
+ public function commands($commands)
+ {
+ $commands = is_array($commands) ? $commands : func_get_args();
+
+ Artisan::starting(function ($artisan) use ($commands) {
+ $artisan->resolveCommands($commands);
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return [];
+ }
+
+ /**
+ * Get the events that trigger this service provider to register.
+ *
+ * @return array
+ */
+ public function when()
+ {
+ return [];
+ }
+
+ /**
+ * Determine if the provider is deferred.
+ *
+ * @return bool
+ */
+ public function isDeferred()
+ {
+ return $this->defer;
+ }
+
+ /**
+ * Get a list of files that should be compiled for the package.
+ *
+ * @deprecated
+ *
+ * @return array
+ */
+ public static function compiles()
+ {
+ return [];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Str.php b/vendor/laravel/framework/src/Illuminate/Support/Str.php
new file mode 100644
index 000000000..3b5b33c77
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Str.php
@@ -0,0 +1,646 @@
+ $val) {
+ $value = str_replace($val, $key, $value);
+ }
+
+ return preg_replace('/[^\x20-\x7E]/u', '', $value);
+ }
+
+ /**
+ * Convert a value to camel case.
+ *
+ * @param string $value
+ * @return string
+ */
+ public static function camel($value)
+ {
+ if (isset(static::$camelCache[$value])) {
+ return static::$camelCache[$value];
+ }
+
+ return static::$camelCache[$value] = lcfirst(static::studly($value));
+ }
+
+ /**
+ * Determine if a given string contains a given substring.
+ *
+ * @param string $haystack
+ * @param string|array $needles
+ * @return bool
+ */
+ public static function contains($haystack, $needles)
+ {
+ foreach ((array) $needles as $needle) {
+ if ($needle != '' && mb_strpos($haystack, $needle) !== false) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Determine if a given string ends with a given substring.
+ *
+ * @param string $haystack
+ * @param string|array $needles
+ * @return bool
+ */
+ public static function endsWith($haystack, $needles)
+ {
+ foreach ((array) $needles as $needle) {
+ if (substr($haystack, -strlen($needle)) === (string) $needle) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Cap a string with a single instance of a given value.
+ *
+ * @param string $value
+ * @param string $cap
+ * @return string
+ */
+ public static function finish($value, $cap)
+ {
+ $quoted = preg_quote($cap, '/');
+
+ return preg_replace('/(?:'.$quoted.')+$/u', '', $value).$cap;
+ }
+
+ /**
+ * Determine if a given string matches a given pattern.
+ *
+ * @param string $pattern
+ * @param string $value
+ * @return bool
+ */
+ public static function is($pattern, $value)
+ {
+ if ($pattern == $value) {
+ return true;
+ }
+
+ $pattern = preg_quote($pattern, '#');
+
+ // Asterisks are translated into zero-or-more regular expression wildcards
+ // to make it convenient to check if the strings starts with the given
+ // pattern such as "library/*", making any string check convenient.
+ $pattern = str_replace('\*', '.*', $pattern);
+
+ return (bool) preg_match('#^'.$pattern.'\z#u', $value);
+ }
+
+ /**
+ * Convert a string to kebab case.
+ *
+ * @param string $value
+ * @return string
+ */
+ public static function kebab($value)
+ {
+ return static::snake($value, '-');
+ }
+
+ /**
+ * Return the length of the given string.
+ *
+ * @param string $value
+ * @param string $encoding
+ * @return int
+ */
+ public static function length($value, $encoding = null)
+ {
+ if ($encoding) {
+ return mb_strlen($value, $encoding);
+ }
+
+ return mb_strlen($value);
+ }
+
+ /**
+ * Limit the number of characters in a string.
+ *
+ * @param string $value
+ * @param int $limit
+ * @param string $end
+ * @return string
+ */
+ public static function limit($value, $limit = 100, $end = '...')
+ {
+ if (mb_strwidth($value, 'UTF-8') <= $limit) {
+ return $value;
+ }
+
+ return rtrim(mb_strimwidth($value, 0, $limit, '', 'UTF-8')).$end;
+ }
+
+ /**
+ * Convert the given string to lower-case.
+ *
+ * @param string $value
+ * @return string
+ */
+ public static function lower($value)
+ {
+ return mb_strtolower($value, 'UTF-8');
+ }
+
+ /**
+ * Limit the number of words in a string.
+ *
+ * @param string $value
+ * @param int $words
+ * @param string $end
+ * @return string
+ */
+ public static function words($value, $words = 100, $end = '...')
+ {
+ preg_match('/^\s*+(?:\S++\s*+){1,'.$words.'}/u', $value, $matches);
+
+ if (! isset($matches[0]) || static::length($value) === static::length($matches[0])) {
+ return $value;
+ }
+
+ return rtrim($matches[0]).$end;
+ }
+
+ /**
+ * Parse a Class@method style callback into class and method.
+ *
+ * @param string $callback
+ * @param string|null $default
+ * @return array
+ */
+ public static function parseCallback($callback, $default = null)
+ {
+ return static::contains($callback, '@') ? explode('@', $callback, 2) : [$callback, $default];
+ }
+
+ /**
+ * Get the plural form of an English word.
+ *
+ * @param string $value
+ * @param int $count
+ * @return string
+ */
+ public static function plural($value, $count = 2)
+ {
+ return Pluralizer::plural($value, $count);
+ }
+
+ /**
+ * Generate a more truly "random" alpha-numeric string.
+ *
+ * @param int $length
+ * @return string
+ */
+ public static function random($length = 16)
+ {
+ $string = '';
+
+ while (($len = strlen($string)) < $length) {
+ $size = $length - $len;
+
+ $bytes = random_bytes($size);
+
+ $string .= substr(str_replace(['/', '+', '='], '', base64_encode($bytes)), 0, $size);
+ }
+
+ return $string;
+ }
+
+ /**
+ * Generate a "random" alpha-numeric string.
+ *
+ * Should not be considered sufficient for cryptography, etc.
+ *
+ * @deprecated since version 5.3. Use the "random" method directly.
+ *
+ * @param int $length
+ * @return string
+ */
+ public static function quickRandom($length = 16)
+ {
+ if (PHP_MAJOR_VERSION > 5) {
+ return static::random($length);
+ }
+
+ $pool = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
+
+ return substr(str_shuffle(str_repeat($pool, $length)), 0, $length);
+ }
+
+ /**
+ * Replace a given value in the string sequentially with an array.
+ *
+ * @param string $search
+ * @param array $replace
+ * @param string $subject
+ * @return string
+ */
+ public static function replaceArray($search, array $replace, $subject)
+ {
+ foreach ($replace as $value) {
+ $subject = static::replaceFirst($search, $value, $subject);
+ }
+
+ return $subject;
+ }
+
+ /**
+ * Replace the first occurrence of a given value in the string.
+ *
+ * @param string $search
+ * @param string $replace
+ * @param string $subject
+ * @return string
+ */
+ public static function replaceFirst($search, $replace, $subject)
+ {
+ if ($search == '') {
+ return $subject;
+ }
+
+ $position = strpos($subject, $search);
+
+ if ($position !== false) {
+ return substr_replace($subject, $replace, $position, strlen($search));
+ }
+
+ return $subject;
+ }
+
+ /**
+ * Replace the last occurrence of a given value in the string.
+ *
+ * @param string $search
+ * @param string $replace
+ * @param string $subject
+ * @return string
+ */
+ public static function replaceLast($search, $replace, $subject)
+ {
+ $position = strrpos($subject, $search);
+
+ if ($position !== false) {
+ return substr_replace($subject, $replace, $position, strlen($search));
+ }
+
+ return $subject;
+ }
+
+ /**
+ * Begin a string with a single instance of a given value.
+ *
+ * @param string $value
+ * @param string $prefix
+ * @return string
+ */
+ public static function start($value, $prefix)
+ {
+ $quoted = preg_quote($prefix, '/');
+
+ return $prefix.preg_replace('/^(?:'.$quoted.')+/u', '', $value);
+ }
+
+ /**
+ * Convert the given string to upper-case.
+ *
+ * @param string $value
+ * @return string
+ */
+ public static function upper($value)
+ {
+ return mb_strtoupper($value, 'UTF-8');
+ }
+
+ /**
+ * Convert the given string to title case.
+ *
+ * @param string $value
+ * @return string
+ */
+ public static function title($value)
+ {
+ return mb_convert_case($value, MB_CASE_TITLE, 'UTF-8');
+ }
+
+ /**
+ * Get the singular form of an English word.
+ *
+ * @param string $value
+ * @return string
+ */
+ public static function singular($value)
+ {
+ return Pluralizer::singular($value);
+ }
+
+ /**
+ * Generate a URL friendly "slug" from a given string.
+ *
+ * @param string $title
+ * @param string $separator
+ * @return string
+ */
+ public static function slug($title, $separator = '-')
+ {
+ $title = static::ascii($title);
+
+ // Convert all dashes/underscores into separator
+ $flip = $separator == '-' ? '_' : '-';
+
+ $title = preg_replace('!['.preg_quote($flip).']+!u', $separator, $title);
+
+ // Remove all characters that are not the separator, letters, numbers, or whitespace.
+ $title = preg_replace('![^'.preg_quote($separator).'\pL\pN\s]+!u', '', mb_strtolower($title));
+
+ // Replace all separator characters and whitespace by a single separator
+ $title = preg_replace('!['.preg_quote($separator).'\s]+!u', $separator, $title);
+
+ return trim($title, $separator);
+ }
+
+ /**
+ * Convert a string to snake case.
+ *
+ * @param string $value
+ * @param string $delimiter
+ * @return string
+ */
+ public static function snake($value, $delimiter = '_')
+ {
+ $key = $value;
+
+ if (isset(static::$snakeCache[$key][$delimiter])) {
+ return static::$snakeCache[$key][$delimiter];
+ }
+
+ if (! ctype_lower($value)) {
+ $value = preg_replace('/\s+/u', '', $value);
+
+ $value = static::lower(preg_replace('/(.)(?=[A-Z])/u', '$1'.$delimiter, $value));
+ }
+
+ return static::$snakeCache[$key][$delimiter] = $value;
+ }
+
+ /**
+ * Determine if a given string starts with a given substring.
+ *
+ * @param string $haystack
+ * @param string|array $needles
+ * @return bool
+ */
+ public static function startsWith($haystack, $needles)
+ {
+ foreach ((array) $needles as $needle) {
+ if ($needle != '' && substr($haystack, 0, strlen($needle)) === (string) $needle) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Convert a value to studly caps case.
+ *
+ * @param string $value
+ * @return string
+ */
+ public static function studly($value)
+ {
+ $key = $value;
+
+ if (isset(static::$studlyCache[$key])) {
+ return static::$studlyCache[$key];
+ }
+
+ $value = ucwords(str_replace(['-', '_'], ' ', $value));
+
+ return static::$studlyCache[$key] = str_replace(' ', '', $value);
+ }
+
+ /**
+ * Returns the portion of string specified by the start and length parameters.
+ *
+ * @param string $string
+ * @param int $start
+ * @param int|null $length
+ * @return string
+ */
+ public static function substr($string, $start, $length = null)
+ {
+ return mb_substr($string, $start, $length, 'UTF-8');
+ }
+
+ /**
+ * Make a string's first character uppercase.
+ *
+ * @param string $string
+ * @return string
+ */
+ public static function ucfirst($string)
+ {
+ return static::upper(static::substr($string, 0, 1)).static::substr($string, 1);
+ }
+
+ /**
+ * Returns the replacements for the ascii method.
+ *
+ * Note: Adapted from Stringy\Stringy.
+ *
+ * @see https://github.com/danielstjules/Stringy/blob/2.3.1/LICENSE.txt
+ *
+ * @return array
+ */
+ protected static function charsArray()
+ {
+ static $charsArray;
+
+ if (isset($charsArray)) {
+ return $charsArray;
+ }
+
+ return $charsArray = [
+ '0' => ['°', '₀', '۰'],
+ '1' => ['¹', 'â‚', 'Û±'],
+ '2' => ['²', '₂', '۲'],
+ '3' => ['³', '₃', '۳'],
+ '4' => ['â´', 'â‚„', 'Û´', 'Ù¤'],
+ '5' => ['âµ', 'â‚…', 'Ûµ', 'Ù¥'],
+ '6' => ['â¶', '₆', 'Û¶', 'Ù¦'],
+ '7' => ['â·', '₇', 'Û·'],
+ '8' => ['â¸', '₈', 'Û¸'],
+ '9' => ['â¹', '₉', 'Û¹'],
+ 'a' => ['à ', 'á', 'ả', 'ã', 'ạ', 'ă', 'ắ', 'ằ', 'ẳ', 'ẵ', 'ặ', 'â', 'ấ', 'ầ', 'ẩ', 'ẫ', 'áº', 'Ä', 'Ä…', 'Ã¥', 'α', 'ά', 'á¼€', 'á¼', 'ἂ', 'ἃ', 'ἄ', 'á¼…', 'ἆ', 'ἇ', 'á¾€', 'á¾', 'ᾂ', 'ᾃ', 'ᾄ', 'á¾…', 'ᾆ', 'ᾇ', 'á½°', 'ά', 'á¾°', 'á¾±', 'á¾²', 'á¾³', 'á¾´', 'á¾¶', 'á¾·', 'а', 'Ø£', 'အ', 'ာ', 'ါ', 'Ç»', 'ÇŽ', 'ª', 'áƒ', 'अ', 'ا'],
+ 'b' => ['б', 'β', 'Ъ', 'Ь', 'ب', 'ဗ', 'ბ'],
+ 'c' => ['ç', 'ć', 'Ä', 'ĉ', 'Ä‹'],
+ 'd' => ['Ä', 'ð', 'Ä‘', 'ÆŒ', 'È¡', 'É–', 'É—', 'áµ', 'á¶', 'á¶‘', 'д', 'δ', 'د', 'ض', 'á€', 'ဒ', 'დ'],
+ 'e' => ['é', 'è', 'ẻ', 'ẽ', 'ẹ', 'ê', 'ế', 'á»', 'ể', 'á»…', 'ệ', 'ë', 'Ä“', 'Ä™', 'Ä›', 'Ä•', 'Ä—', 'ε', 'Î', 'á¼', 'ἑ', 'á¼’', 'ἓ', 'á¼”', 'ἕ', 'á½²', 'Î', 'е', 'Ñ‘', 'Ñ', 'Ñ”', 'É™', 'ဧ', 'ေ', 'ဲ', 'ე', 'à¤', 'Ø¥', 'ئ'],
+ 'f' => ['Ñ„', 'φ', 'Ù', 'Æ’', 'ფ'],
+ 'g' => ['Ä', 'ÄŸ', 'Ä¡', 'Ä£', 'г', 'Ò‘', 'γ', 'ဂ', 'გ', 'Ú¯'],
+ 'h' => ['Ä¥', 'ħ', 'η', 'ή', 'Ø', 'Ù‡', 'ဟ', 'ှ', 'ჰ'],
+ 'i' => ['Ã', 'ì', 'ỉ', 'Ä©', 'ị', 'î', 'ï', 'Ä«', 'Ä', 'į', 'ı', 'ι', 'ί', 'ÏŠ', 'Î', 'á¼°', 'á¼±', 'á¼²', 'á¼³', 'á¼´', 'á¼µ', 'á¼¶', 'á¼·', 'á½¶', 'ί', 'á¿', 'á¿‘', 'á¿’', 'Î', 'á¿–', 'á¿—', 'Ñ–', 'Ñ—', 'и', 'ဣ', 'á€', 'ီ', 'ည်', 'Ç', 'ი', 'इ'],
+ 'j' => ['ĵ', 'ј', 'Ј', 'ჯ', 'ج'],
+ 'k' => ['ķ', 'ĸ', 'к', 'κ', 'Ķ', 'ق', 'ك', 'က', 'კ', 'ქ', 'ک'],
+ 'l' => ['ł', 'ľ', 'ĺ', 'ļ', 'ŀ', 'л', 'λ', 'ل', 'လ', 'ლ'],
+ 'm' => ['м', 'μ', 'م', 'မ', 'მ'],
+ 'n' => ['ñ', 'ń', 'ň', 'ņ', 'ʼn', 'ŋ', 'ν', 'н', 'ن', 'န', 'ნ'],
+ 'o' => ['ó', 'ò', 'á»', 'õ', 'á»', 'ô', 'ố', 'ồ', 'ổ', 'á»—', 'á»™', 'Æ¡', 'á»›', 'á»', 'ở', 'ỡ', 'ợ', 'ø', 'Å', 'Å‘', 'Å', 'ο', 'á½€', 'á½', 'ὂ', 'ὃ', 'ὄ', 'á½…', 'ὸ', 'ÏŒ', 'о', 'Ùˆ', 'θ', 'á€á€¯', 'Ç’', 'Ç¿', 'º', 'áƒ', 'ओ'],
+ 'p' => ['п', 'π', 'ပ', 'პ', 'پ'],
+ 'q' => ['ყ'],
+ 'r' => ['Å•', 'Å™', 'Å—', 'Ñ€', 'Ï', 'ر', 'რ'],
+ 's' => ['Å›', 'Å¡', 'ÅŸ', 'Ñ', 'σ', 'È™', 'Ï‚', 'س', 'ص', 'စ', 'Å¿', 'ს'],
+ 't' => ['Å¥', 'Å£', 'Ñ‚', 'Ï„', 'È›', 'ت', 'Ø·', 'ဋ', 'á€', 'ŧ', 'თ', 'ტ'],
+ 'u' => ['ú', 'ù', 'á»§', 'Å©', 'ụ', 'ư', 'ứ', 'ừ', 'á»', 'ữ', 'á»±', 'û', 'Å«', 'ů', 'ű', 'Å', 'ų', 'µ', 'у', 'ဉ', 'ု', 'ူ', 'Ç”', 'Ç–', 'ǘ', 'Çš', 'Çœ', 'უ', 'उ'],
+ 'v' => ['в', 'ვ', 'Ï'],
+ 'w' => ['ŵ', 'ω', 'ÏŽ', 'á€', 'ွ'],
+ 'x' => ['χ', 'ξ'],
+ 'y' => ['ý', 'ỳ', 'á»·', 'ỹ', 'ỵ', 'ÿ', 'Å·', 'й', 'Ñ‹', 'Ï…', 'Ï‹', 'Ï', 'ΰ', 'ÙŠ', 'ယ'],
+ 'z' => ['ź', 'ž', 'ż', 'з', 'ζ', 'ز', 'ဇ', 'ზ'],
+ 'aa' => ['ع', 'आ', 'آ'],
+ 'ae' => ['ä', 'æ', 'ǽ'],
+ 'ai' => ['à¤'],
+ 'at' => ['@'],
+ 'ch' => ['ч', 'ჩ', 'áƒ', 'Ú†'],
+ 'dj' => ['Ñ’', 'Ä‘'],
+ 'dz' => ['џ', 'ძ'],
+ 'ei' => ['à¤'],
+ 'gh' => ['غ', 'ღ'],
+ 'ii' => ['ई'],
+ 'ij' => ['ij'],
+ 'kh' => ['х', 'خ', 'ხ'],
+ 'lj' => ['Ñ™'],
+ 'nj' => ['Ñš'],
+ 'oe' => ['ö', 'œ', 'ؤ'],
+ 'oi' => ['ऑ'],
+ 'oii' => ['ऒ'],
+ 'ps' => ['ψ'],
+ 'sh' => ['ш', 'შ', 'ش'],
+ 'shch' => ['щ'],
+ 'ss' => ['ß'],
+ 'sx' => ['Å'],
+ 'th' => ['þ', 'ϑ', 'ث', 'ذ', 'ظ'],
+ 'ts' => ['ц', 'ც', 'წ'],
+ 'ue' => ['ü'],
+ 'uu' => ['ऊ'],
+ 'ya' => ['Ñ'],
+ 'yu' => ['ÑŽ'],
+ 'zh' => ['ж', 'ჟ', 'ژ'],
+ '(c)' => ['©'],
+ 'A' => ['Ã', 'À', 'Ả', 'Ã', 'Ạ', 'Ä‚', 'Ắ', 'Ằ', 'Ẳ', 'Ẵ', 'Ặ', 'Â', 'Ấ', 'Ầ', 'Ẩ', 'Ẫ', 'Ậ', 'Ã…', 'Ä€', 'Ä„', 'Α', 'Ά', 'Ἀ', 'Ἁ', 'Ἂ', 'Ἃ', 'Ἄ', 'á¼', 'Ἆ', 'á¼', 'ᾈ', 'ᾉ', 'ᾊ', 'ᾋ', 'ᾌ', 'á¾', 'ᾎ', 'á¾', 'Ᾰ', 'á¾¹', 'Ὰ', 'Ά', 'á¾¼', 'Ð', 'Ǻ', 'Ç'],
+ 'B' => ['Б', 'Β', 'ब'],
+ 'C' => ['Ç', 'Ć', 'Č', 'Ĉ', 'Ċ'],
+ 'D' => ['ÄŽ', 'Ã', 'Ä', 'Ɖ', 'ÆŠ', 'Æ‹', 'á´…', 'á´†', 'Д', 'Δ'],
+ 'E' => ['É', 'È', 'Ẻ', 'Ẽ', 'Ẹ', 'Ê', 'Ế', 'Ề', 'Ể', 'Ễ', 'Ệ', 'Ë', 'Ä’', 'Ę', 'Äš', 'Ä”', 'Ä–', 'Ε', 'Έ', 'Ἐ', 'á¼™', 'Ἒ', 'á¼›', 'Ἔ', 'á¼', 'Έ', 'Ὲ', 'Е', 'Ð', 'Ð', 'Є', 'Æ'],
+ 'F' => ['Ф', 'Φ'],
+ 'G' => ['Äž', 'Ä ', 'Ä¢', 'Г', 'Ò', 'Γ'],
+ 'H' => ['Η', 'Ή', 'Ħ'],
+ 'I' => ['Ã', 'ÃŒ', 'Ỉ', 'Ĩ', 'Ị', 'ÃŽ', 'Ã', 'Ī', 'Ĭ', 'Ä®', 'İ', 'Ι', 'Ί', 'Ϊ', 'Ἰ', 'á¼¹', 'á¼»', 'á¼¼', 'á¼½', 'á¼¾', 'Ἷ', 'Ῐ', 'á¿™', 'Ὶ', 'Ί', 'И', 'І', 'Ї', 'Ç', 'Ï’'],
+ 'K' => ['К', 'Κ'],
+ 'L' => ['Ĺ', 'Å', 'Л', 'Λ', 'Ä»', 'Ľ', 'Ä¿', 'ल'],
+ 'M' => ['М', 'Μ'],
+ 'N' => ['Ń', 'Ñ', 'Ň', 'Å…', 'ÅŠ', 'Ð', 'Î'],
+ 'O' => ['Ó', 'Ã’', 'Ỏ', 'Õ', 'Ọ', 'Ô', 'á»', 'á»’', 'á»”', 'á»–', 'Ộ', 'Æ ', 'Ớ', 'Ờ', 'Ở', 'á» ', 'Ợ', 'Ø', 'ÅŒ', 'Å', 'ÅŽ', 'Ο', 'ÎŒ', 'Ὀ', 'Ὁ', 'Ὂ', 'Ὃ', 'Ὄ', 'á½', 'Ὸ', 'ÎŒ', 'О', 'Θ', 'Ó¨', 'Ç‘', 'Ǿ'],
+ 'P' => ['П', 'Π'],
+ 'R' => ['Ř', 'Ŕ', 'Р', 'Ρ', 'Ŗ'],
+ 'S' => ['Ş', 'Ŝ', 'Ș', 'Š', 'Ś', 'С', 'Σ'],
+ 'T' => ['Ť', 'Ţ', 'Ŧ', 'Ț', 'Т', 'Τ'],
+ 'U' => ['Ú', 'Ù', 'Ủ', 'Ũ', 'Ụ', 'Ư', 'Ứ', 'Ừ', 'Ử', 'Ữ', 'Ự', 'Û', 'Ū', 'Ů', 'Ű', 'Ŭ', 'Ų', 'У', 'Ǔ', 'Ǖ', 'Ǘ', 'Ǚ', 'Ǜ'],
+ 'V' => ['Ð’'],
+ 'W' => ['Ω', 'Î', 'Å´'],
+ 'X' => ['Χ', 'Ξ'],
+ 'Y' => ['Ã', 'Ỳ', 'á»¶', 'Ỹ', 'á»´', 'Ÿ', 'Ῠ', 'á¿©', 'Ὺ', 'ÎŽ', 'Ы', 'Й', 'Î¥', 'Ϋ', 'Ŷ'],
+ 'Z' => ['Ź', 'Ž', 'Ż', 'З', 'Ζ'],
+ 'AE' => ['Ä', 'Æ', 'Ǽ'],
+ 'CH' => ['Ч'],
+ 'DJ' => ['Ђ'],
+ 'DZ' => ['Ð'],
+ 'GX' => ['Ĝ'],
+ 'HX' => ['Ĥ'],
+ 'IJ' => ['IJ'],
+ 'JX' => ['Ä´'],
+ 'KH' => ['Ð¥'],
+ 'LJ' => ['Љ'],
+ 'NJ' => ['Њ'],
+ 'OE' => ['Ö', 'Œ'],
+ 'PS' => ['Ψ'],
+ 'SH' => ['Ш'],
+ 'SHCH' => ['Щ'],
+ 'SS' => ['ẞ'],
+ 'TH' => ['Þ'],
+ 'TS' => ['Ц'],
+ 'UE' => ['Ü'],
+ 'YA' => ['Я'],
+ 'YU' => ['Ю'],
+ 'ZH' => ['Ж'],
+ ' ' => ["\xC2\xA0", "\xE2\x80\x80", "\xE2\x80\x81", "\xE2\x80\x82", "\xE2\x80\x83", "\xE2\x80\x84", "\xE2\x80\x85", "\xE2\x80\x86", "\xE2\x80\x87", "\xE2\x80\x88", "\xE2\x80\x89", "\xE2\x80\x8A", "\xE2\x80\xAF", "\xE2\x81\x9F", "\xE3\x80\x80"],
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/BusFake.php b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/BusFake.php
new file mode 100644
index 000000000..a90fedb99
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/BusFake.php
@@ -0,0 +1,113 @@
+dispatched($command, $callback)->count() > 0,
+ "The expected [{$command}] job was not dispatched."
+ );
+ }
+
+ /**
+ * Determine if a job was dispatched based on a truth-test callback.
+ *
+ * @param string $command
+ * @param callable|null $callback
+ * @return void
+ */
+ public function assertNotDispatched($command, $callback = null)
+ {
+ PHPUnit::assertTrue(
+ $this->dispatched($command, $callback)->count() === 0,
+ "The unexpected [{$command}] job was dispatched."
+ );
+ }
+
+ /**
+ * Get all of the jobs matching a truth-test callback.
+ *
+ * @param string $command
+ * @param callable|null $callback
+ * @return \Illuminate\Support\Collection
+ */
+ public function dispatched($command, $callback = null)
+ {
+ if (! $this->hasDispatched($command)) {
+ return collect();
+ }
+
+ $callback = $callback ?: function () {
+ return true;
+ };
+
+ return collect($this->commands[$command])->filter(function ($command) use ($callback) {
+ return $callback($command);
+ });
+ }
+
+ /**
+ * Determine if there are any stored commands for a given class.
+ *
+ * @param string $command
+ * @return bool
+ */
+ public function hasDispatched($command)
+ {
+ return isset($this->commands[$command]) && ! empty($this->commands[$command]);
+ }
+
+ /**
+ * Dispatch a command to its appropriate handler.
+ *
+ * @param mixed $command
+ * @return mixed
+ */
+ public function dispatch($command)
+ {
+ return $this->dispatchNow($command);
+ }
+
+ /**
+ * Dispatch a command to its appropriate handler in the current process.
+ *
+ * @param mixed $command
+ * @param mixed $handler
+ * @return mixed
+ */
+ public function dispatchNow($command, $handler = null)
+ {
+ $this->commands[get_class($command)][] = $command;
+ }
+
+ /**
+ * Set the pipes commands should be piped through before dispatching.
+ *
+ * @param array $pipes
+ * @return $this
+ */
+ public function pipeThrough(array $pipes)
+ {
+ //
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/EventFake.php b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/EventFake.php
new file mode 100644
index 000000000..e21f666d2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/EventFake.php
@@ -0,0 +1,197 @@
+dispatched($event, $callback)->count() > 0,
+ "The expected [{$event}] event was not dispatched."
+ );
+ }
+
+ /**
+ * Determine if an event was dispatched based on a truth-test callback.
+ *
+ * @param string $event
+ * @param callable|null $callback
+ * @return void
+ */
+ public function assertNotDispatched($event, $callback = null)
+ {
+ PHPUnit::assertTrue(
+ $this->dispatched($event, $callback)->count() === 0,
+ "The unexpected [{$event}] event was dispatched."
+ );
+ }
+
+ /**
+ * Get all of the events matching a truth-test callback.
+ *
+ * @param string $event
+ * @param callable|null $callback
+ * @return \Illuminate\Support\Collection
+ */
+ public function dispatched($event, $callback = null)
+ {
+ if (! $this->hasDispatched($event)) {
+ return collect();
+ }
+
+ $callback = $callback ?: function () {
+ return true;
+ };
+
+ return collect($this->events[$event])->filter(function ($arguments) use ($callback) {
+ return $callback(...$arguments);
+ });
+ }
+
+ /**
+ * Determine if the given event has been dispatched.
+ *
+ * @param string $event
+ * @return bool
+ */
+ public function hasDispatched($event)
+ {
+ return isset($this->events[$event]) && ! empty($this->events[$event]);
+ }
+
+ /**
+ * Register an event listener with the dispatcher.
+ *
+ * @param string|array $events
+ * @param mixed $listener
+ * @return void
+ */
+ public function listen($events, $listener)
+ {
+ //
+ }
+
+ /**
+ * Determine if a given event has listeners.
+ *
+ * @param string $eventName
+ * @return bool
+ */
+ public function hasListeners($eventName)
+ {
+ //
+ }
+
+ /**
+ * Register an event and payload to be dispatched later.
+ *
+ * @param string $event
+ * @param array $payload
+ * @return void
+ */
+ public function push($event, $payload = [])
+ {
+ //
+ }
+
+ /**
+ * Register an event subscriber with the dispatcher.
+ *
+ * @param object|string $subscriber
+ * @return void
+ */
+ public function subscribe($subscriber)
+ {
+ //
+ }
+
+ /**
+ * Flush a set of pushed events.
+ *
+ * @param string $event
+ * @return void
+ */
+ public function flush($event)
+ {
+ //
+ }
+
+ /**
+ * Fire an event and call the listeners.
+ *
+ * @param string|object $event
+ * @param mixed $payload
+ * @param bool $halt
+ * @return array|null
+ */
+ public function fire($event, $payload = [], $halt = false)
+ {
+ return $this->dispatch($event, $payload, $halt);
+ }
+
+ /**
+ * Fire an event and call the listeners.
+ *
+ * @param string|object $event
+ * @param mixed $payload
+ * @param bool $halt
+ * @return array|null
+ */
+ public function dispatch($event, $payload = [], $halt = false)
+ {
+ $name = is_object($event) ? get_class($event) : (string) $event;
+
+ $this->events[$name][] = func_get_args();
+ }
+
+ /**
+ * Remove a set of listeners from the dispatcher.
+ *
+ * @param string $event
+ * @return void
+ */
+ public function forget($event)
+ {
+ //
+ }
+
+ /**
+ * Forget all of the queued listeners.
+ *
+ * @return void
+ */
+ public function forgetPushed()
+ {
+ //
+ }
+
+ /**
+ * Dispatch an event and call the listeners.
+ *
+ * @param string|object $event
+ * @param mixed $payload
+ * @return void
+ */
+ public function until($event, $payload = [])
+ {
+ return $this->dispatch($event, $payload, true);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/MailFake.php b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/MailFake.php
new file mode 100644
index 000000000..338f2195c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/MailFake.php
@@ -0,0 +1,178 @@
+sent($mailable, $callback)->count() > 0,
+ "The expected [{$mailable}] mailable was not sent."
+ );
+ }
+
+ /**
+ * Determine if a mailable was not sent based on a truth-test callback.
+ *
+ * @param string $mailable
+ * @param callable|null $callback
+ * @return void
+ */
+ public function assertNotSent($mailable, $callback = null)
+ {
+ PHPUnit::assertTrue(
+ $this->sent($mailable, $callback)->count() === 0,
+ "The unexpected [{$mailable}] mailable was sent."
+ );
+ }
+
+ /**
+ * Assert that no mailables were sent.
+ *
+ * @return void
+ */
+ public function assertNothingSent()
+ {
+ PHPUnit::assertEmpty($this->mailables, 'Mailables were sent unexpectedly.');
+ }
+
+ /**
+ * Get all of the mailables matching a truth-test callback.
+ *
+ * @param string $mailable
+ * @param callable|null $callback
+ * @return \Illuminate\Support\Collection
+ */
+ public function sent($mailable, $callback = null)
+ {
+ if (! $this->hasSent($mailable)) {
+ return collect();
+ }
+
+ $callback = $callback ?: function () {
+ return true;
+ };
+
+ return $this->mailablesOf($mailable)->filter(function ($mailable) use ($callback) {
+ return $callback($mailable);
+ });
+ }
+
+ /**
+ * Determine if the given mailable has been sent.
+ *
+ * @param string $mailable
+ * @return bool
+ */
+ public function hasSent($mailable)
+ {
+ return $this->mailablesOf($mailable)->count() > 0;
+ }
+
+ /**
+ * Get all of the mailed mailables for a given type.
+ *
+ * @param string $type
+ * @return \Illuminate\Support\Collection
+ */
+ protected function mailablesOf($type)
+ {
+ return collect($this->mailables)->filter(function ($mailable) use ($type) {
+ return $mailable instanceof $type;
+ });
+ }
+
+ /**
+ * Begin the process of mailing a mailable class instance.
+ *
+ * @param mixed $users
+ * @return \Illuminate\Mail\PendingMail
+ */
+ public function to($users)
+ {
+ return (new PendingMailFake($this))->to($users);
+ }
+
+ /**
+ * Begin the process of mailing a mailable class instance.
+ *
+ * @param mixed $users
+ * @return \Illuminate\Mail\PendingMail
+ */
+ public function bcc($users)
+ {
+ return (new PendingMailFake($this))->bcc($users);
+ }
+
+ /**
+ * Send a new message when only a raw text part.
+ *
+ * @param string $text
+ * @param \Closure|string $callback
+ * @return int
+ */
+ public function raw($text, $callback)
+ {
+ //
+ }
+
+ /**
+ * Send a new message using a view.
+ *
+ * @param string|array $view
+ * @param array $data
+ * @param \Closure|string $callback
+ * @return void
+ */
+ public function send($view, array $data = [], $callback = null)
+ {
+ if (! $view instanceof Mailable) {
+ return;
+ }
+
+ $this->mailables[] = $view;
+ }
+
+ /**
+ * Queue a new e-mail message for sending.
+ *
+ * @param string|array $view
+ * @param array $data
+ * @param \Closure|string $callback
+ * @param string|null $queue
+ * @return mixed
+ */
+ public function queue($view, array $data = [], $callback = null, $queue = null)
+ {
+ $this->send($view);
+ }
+
+ /**
+ * Get the array of failed recipients.
+ *
+ * @return array
+ */
+ public function failures()
+ {
+ //
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/NotificationFake.php b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/NotificationFake.php
new file mode 100644
index 000000000..63050c582
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/NotificationFake.php
@@ -0,0 +1,165 @@
+assertSentTo($singleNotifiable, $notification, $callback);
+ }
+
+ return;
+ }
+
+ PHPUnit::assertTrue(
+ $this->sent($notifiable, $notification, $callback)->count() > 0,
+ "The expected [{$notification}] notification was not sent."
+ );
+ }
+
+ /**
+ * Determine if a notification was sent based on a truth-test callback.
+ *
+ * @param mixed $notifiable
+ * @param string $notification
+ * @param callable|null $callback
+ * @return void
+ */
+ public function assertNotSentTo($notifiable, $notification, $callback = null)
+ {
+ if (is_array($notifiable) || $notifiable instanceof Collection) {
+ foreach ($notifiable as $singleNotifiable) {
+ $this->assertNotSentTo($singleNotifiable, $notification, $callback);
+ }
+
+ return;
+ }
+
+ PHPUnit::assertTrue(
+ $this->sent($notifiable, $notification, $callback)->count() === 0,
+ "The unexpected [{$notification}] notification was sent."
+ );
+ }
+
+ /**
+ * Get all of the notifications matching a truth-test callback.
+ *
+ * @param mixed $notifiable
+ * @param string $notification
+ * @param callable|null $callback
+ * @return \Illuminate\Support\Collection
+ */
+ public function sent($notifiable, $notification, $callback = null)
+ {
+ if (! $this->hasSent($notifiable, $notification)) {
+ return collect();
+ }
+
+ $callback = $callback ?: function () {
+ return true;
+ };
+
+ $notifications = collect($this->notificationsFor($notifiable, $notification));
+
+ return $notifications->filter(function ($arguments) use ($callback) {
+ return $callback(...array_values($arguments));
+ })->pluck('notification');
+ }
+
+ /**
+ * Determine if there are more notifications left to inspect.
+ *
+ * @param mixed $notifiable
+ * @param string $notification
+ * @return bool
+ */
+ public function hasSent($notifiable, $notification)
+ {
+ return ! empty($this->notificationsFor($notifiable, $notification));
+ }
+
+ /**
+ * Get all of the notifications for a notifiable entity by type.
+ *
+ * @param mixed $notifiable
+ * @param string $notification
+ * @return array
+ */
+ protected function notificationsFor($notifiable, $notification)
+ {
+ if (isset($this->notifications[get_class($notifiable)][$notifiable->getKey()][$notification])) {
+ return $this->notifications[get_class($notifiable)][$notifiable->getKey()][$notification];
+ }
+
+ return [];
+ }
+
+ /**
+ * Send the given notification to the given notifiable entities.
+ *
+ * @param \Illuminate\Support\Collection|array|mixed $notifiables
+ * @param mixed $notification
+ * @return void
+ */
+ public function send($notifiables, $notification)
+ {
+ return $this->sendNow($notifiables, $notification);
+ }
+
+ /**
+ * Send the given notification immediately.
+ *
+ * @param \Illuminate\Support\Collection|array|mixed $notifiables
+ * @param mixed $notification
+ * @return void
+ */
+ public function sendNow($notifiables, $notification)
+ {
+ if (! $notifiables instanceof Collection && ! is_array($notifiables)) {
+ $notifiables = [$notifiables];
+ }
+
+ foreach ($notifiables as $notifiable) {
+ $notification->id = Uuid::uuid4()->toString();
+
+ $this->notifications[get_class($notifiable)][$notifiable->getKey()][get_class($notification)][] = [
+ 'notification' => $notification,
+ 'channels' => $notification->via($notifiable),
+ ];
+ }
+ }
+
+ /**
+ * Get a channel instance by name.
+ *
+ * @param string|null $name
+ * @return mixed
+ */
+ public function channel($name = null)
+ {
+ //
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/PendingMailFake.php b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/PendingMailFake.php
new file mode 100644
index 000000000..0baa9d2a2
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/PendingMailFake.php
@@ -0,0 +1,53 @@
+mailer = $mailer;
+ }
+
+ /**
+ * Send a new mailable message instance.
+ *
+ * @param Mailable $mailable
+ * @return mixed
+ */
+ public function send(Mailable $mailable)
+ {
+ return $this->sendNow($mailable);
+ }
+
+ /**
+ * Send a mailable message immediately.
+ *
+ * @param Mailable $mailable
+ * @return mixed
+ */
+ public function sendNow(Mailable $mailable)
+ {
+ $this->mailer->send($this->fill($mailable));
+ }
+
+ /**
+ * Push the given mailable onto the queue.
+ *
+ * @param Mailable $mailable
+ * @return mixed
+ */
+ public function queue(Mailable $mailable)
+ {
+ return $this->sendNow($mailable);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/QueueFake.php b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/QueueFake.php
new file mode 100644
index 000000000..4da24c8e5
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Testing/Fakes/QueueFake.php
@@ -0,0 +1,238 @@
+pushed($job, $callback)->count() > 0,
+ "The expected [{$job}] job was not pushed."
+ );
+ }
+
+ /**
+ * Assert if a job was pushed based on a truth-test callback.
+ *
+ * @param string $queue
+ * @param string $job
+ * @param callable|null $callback
+ * @return void
+ */
+ public function assertPushedOn($queue, $job, $callback = null)
+ {
+ return $this->assertPushed($job, function ($job, $pushedQueue) use ($callback, $queue) {
+ if ($pushedQueue !== $queue) {
+ return false;
+ }
+
+ return $callback ? $callback(...func_get_args()) : true;
+ });
+ }
+
+ /**
+ * Determine if a job was pushed based on a truth-test callback.
+ *
+ * @param string $job
+ * @param callable|null $callback
+ * @return void
+ */
+ public function assertNotPushed($job, $callback = null)
+ {
+ PHPUnit::assertTrue(
+ $this->pushed($job, $callback)->count() === 0,
+ "The unexpected [{$job}] job was pushed."
+ );
+ }
+
+ /**
+ * Get all of the jobs matching a truth-test callback.
+ *
+ * @param string $job
+ * @param callable|null $callback
+ * @return \Illuminate\Support\Collection
+ */
+ public function pushed($job, $callback = null)
+ {
+ if (! $this->hasPushed($job)) {
+ return collect();
+ }
+
+ $callback = $callback ?: function () {
+ return true;
+ };
+
+ return collect($this->jobs[$job])->filter(function ($data) use ($callback) {
+ return $callback($data['job'], $data['queue']);
+ })->pluck('job');
+ }
+
+ /**
+ * Determine if there are any stored jobs for a given class.
+ *
+ * @param string $job
+ * @return bool
+ */
+ public function hasPushed($job)
+ {
+ return isset($this->jobs[$job]) && ! empty($this->jobs[$job]);
+ }
+
+ /**
+ * Resolve a queue connection instance.
+ *
+ * @param mixed $value
+ * @return \Illuminate\Contracts\Queue\Queue
+ */
+ public function connection($value = null)
+ {
+ return $this;
+ }
+
+ /**
+ * Get the size of the queue.
+ *
+ * @param string $queue
+ * @return int
+ */
+ public function size($queue = null)
+ {
+ return 0;
+ }
+
+ /**
+ * Push a new job onto the queue.
+ *
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function push($job, $data = '', $queue = null)
+ {
+ $this->jobs[is_object($job) ? get_class($job) : $job][] = [
+ 'job' => $job,
+ 'queue' => $queue,
+ ];
+ }
+
+ /**
+ * Push a raw payload onto the queue.
+ *
+ * @param string $payload
+ * @param string $queue
+ * @param array $options
+ * @return mixed
+ */
+ public function pushRaw($payload, $queue = null, array $options = [])
+ {
+ //
+ }
+
+ /**
+ * Push a new job onto the queue after a delay.
+ *
+ * @param \DateTime|int $delay
+ * @param string $job
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function later($delay, $job, $data = '', $queue = null)
+ {
+ return $this->push($job, $data, $queue);
+ }
+
+ /**
+ * Push a new job onto the queue.
+ *
+ * @param string $queue
+ * @param string $job
+ * @param mixed $data
+ * @return mixed
+ */
+ public function pushOn($queue, $job, $data = '')
+ {
+ return $this->push($job, $data, $queue);
+ }
+
+ /**
+ * Push a new job onto the queue after a delay.
+ *
+ * @param string $queue
+ * @param \DateTime|int $delay
+ * @param string $job
+ * @param mixed $data
+ * @return mixed
+ */
+ public function laterOn($queue, $delay, $job, $data = '')
+ {
+ return $this->push($job, $data, $queue);
+ }
+
+ /**
+ * Pop the next job off of the queue.
+ *
+ * @param string $queue
+ * @return \Illuminate\Contracts\Queue\Job|null
+ */
+ public function pop($queue = null)
+ {
+ //
+ }
+
+ /**
+ * Push an array of jobs onto the queue.
+ *
+ * @param array $jobs
+ * @param mixed $data
+ * @param string $queue
+ * @return mixed
+ */
+ public function bulk($jobs, $data = '', $queue = null)
+ {
+ foreach ($this->jobs as $job) {
+ $this->push($job);
+ }
+ }
+
+ /**
+ * Get the connection name for the queue.
+ *
+ * @return string
+ */
+ public function getConnectionName()
+ {
+ //
+ }
+
+ /**
+ * Set the connection name for the queue.
+ *
+ * @param string $name
+ * @return $this
+ */
+ public function setConnectionName($name)
+ {
+ return $this;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Traits/CapsuleManagerTrait.php b/vendor/laravel/framework/src/Illuminate/Support/Traits/CapsuleManagerTrait.php
new file mode 100644
index 000000000..08089ef66
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Traits/CapsuleManagerTrait.php
@@ -0,0 +1,69 @@
+container = $container;
+
+ if (! $this->container->bound('config')) {
+ $this->container->instance('config', new Fluent);
+ }
+ }
+
+ /**
+ * Make this capsule instance available globally.
+ *
+ * @return void
+ */
+ public function setAsGlobal()
+ {
+ static::$instance = $this;
+ }
+
+ /**
+ * Get the IoC container instance.
+ *
+ * @return \Illuminate\Contracts\Container\Container
+ */
+ public function getContainer()
+ {
+ return $this->container;
+ }
+
+ /**
+ * Set the IoC container instance.
+ *
+ * @param \Illuminate\Contracts\Container\Container $container
+ * @return void
+ */
+ public function setContainer(Container $container)
+ {
+ $this->container = $container;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/Traits/Macroable.php b/vendor/laravel/framework/src/Illuminate/Support/Traits/Macroable.php
new file mode 100644
index 000000000..2c103d4fc
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/Traits/Macroable.php
@@ -0,0 +1,83 @@
+bindTo($this, static::class), $parameters);
+ }
+
+ return call_user_func_array(static::$macros[$method], $parameters);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/ViewErrorBag.php b/vendor/laravel/framework/src/Illuminate/Support/ViewErrorBag.php
new file mode 100644
index 000000000..89e6a0527
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/ViewErrorBag.php
@@ -0,0 +1,120 @@
+bags[$key]);
+ }
+
+ /**
+ * Get a MessageBag instance from the bags.
+ *
+ * @param string $key
+ * @return \Illuminate\Contracts\Support\MessageBag
+ */
+ public function getBag($key)
+ {
+ return Arr::get($this->bags, $key) ?: new MessageBag;
+ }
+
+ /**
+ * Get all the bags.
+ *
+ * @return array
+ */
+ public function getBags()
+ {
+ return $this->bags;
+ }
+
+ /**
+ * Add a new MessageBag instance to the bags.
+ *
+ * @param string $key
+ * @param \Illuminate\Contracts\Support\MessageBag $bag
+ * @return $this
+ */
+ public function put($key, MessageBagContract $bag)
+ {
+ $this->bags[$key] = $bag;
+
+ return $this;
+ }
+
+ /**
+ * Determine if the default message bag has any messages.
+ *
+ * @return bool
+ */
+ public function any()
+ {
+ return $this->count() > 0;
+ }
+
+ /**
+ * Get the number of messages in the default bag.
+ *
+ * @return int
+ */
+ public function count()
+ {
+ return $this->getBag('default')->count();
+ }
+
+ /**
+ * Dynamically call methods on the default bag.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ */
+ public function __call($method, $parameters)
+ {
+ return $this->getBag('default')->$method(...$parameters);
+ }
+
+ /**
+ * Dynamically access a view error bag.
+ *
+ * @param string $key
+ * @return \Illuminate\Contracts\Support\MessageBag
+ */
+ public function __get($key)
+ {
+ return $this->getBag($key);
+ }
+
+ /**
+ * Dynamically set a view error bag.
+ *
+ * @param string $key
+ * @param \Illuminate\Contracts\Support\MessageBag $value
+ * @return void
+ */
+ public function __set($key, $value)
+ {
+ $this->put($key, $value);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/composer.json b/vendor/laravel/framework/src/Illuminate/Support/composer.json
new file mode 100644
index 000000000..0aac0b49c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/composer.json
@@ -0,0 +1,48 @@
+{
+ "name": "illuminate/support",
+ "description": "The Illuminate Support package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "ext-mbstring": "*",
+ "doctrine/inflector": "~1.1",
+ "illuminate/contracts": "5.4.*",
+ "paragonie/random_compat": "~1.4|~2.0"
+ },
+ "replace": {
+ "tightenco/collect": "self.version"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Support\\": ""
+ },
+ "files": [
+ "helpers.php"
+ ]
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "illuminate/filesystem": "Required to use the composer class (5.2.*).",
+ "symfony/process": "Required to use the composer class (~3.2).",
+ "symfony/var-dumper": "Required to use the dd function (~3.2)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Support/helpers.php b/vendor/laravel/framework/src/Illuminate/Support/helpers.php
new file mode 100644
index 000000000..2656fe28a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Support/helpers.php
@@ -0,0 +1,1038 @@
+ $value) {
+ if (is_numeric($key)) {
+ $start++;
+
+ $array[$start] = Arr::pull($array, $key);
+ }
+ }
+
+ return $array;
+ }
+}
+
+if (! function_exists('array_add')) {
+ /**
+ * Add an element to an array using "dot" notation if it doesn't exist.
+ *
+ * @param array $array
+ * @param string $key
+ * @param mixed $value
+ * @return array
+ */
+ function array_add($array, $key, $value)
+ {
+ return Arr::add($array, $key, $value);
+ }
+}
+
+if (! function_exists('array_collapse')) {
+ /**
+ * Collapse an array of arrays into a single array.
+ *
+ * @param array $array
+ * @return array
+ */
+ function array_collapse($array)
+ {
+ return Arr::collapse($array);
+ }
+}
+
+if (! function_exists('array_divide')) {
+ /**
+ * Divide an array into two arrays. One with keys and the other with values.
+ *
+ * @param array $array
+ * @return array
+ */
+ function array_divide($array)
+ {
+ return Arr::divide($array);
+ }
+}
+
+if (! function_exists('array_dot')) {
+ /**
+ * Flatten a multi-dimensional associative array with dots.
+ *
+ * @param array $array
+ * @param string $prepend
+ * @return array
+ */
+ function array_dot($array, $prepend = '')
+ {
+ return Arr::dot($array, $prepend);
+ }
+}
+
+if (! function_exists('array_except')) {
+ /**
+ * Get all of the given array except for a specified array of items.
+ *
+ * @param array $array
+ * @param array|string $keys
+ * @return array
+ */
+ function array_except($array, $keys)
+ {
+ return Arr::except($array, $keys);
+ }
+}
+
+if (! function_exists('array_first')) {
+ /**
+ * Return the first element in an array passing a given truth test.
+ *
+ * @param array $array
+ * @param callable|null $callback
+ * @param mixed $default
+ * @return mixed
+ */
+ function array_first($array, callable $callback = null, $default = null)
+ {
+ return Arr::first($array, $callback, $default);
+ }
+}
+
+if (! function_exists('array_flatten')) {
+ /**
+ * Flatten a multi-dimensional array into a single level.
+ *
+ * @param array $array
+ * @param int $depth
+ * @return array
+ */
+ function array_flatten($array, $depth = INF)
+ {
+ return Arr::flatten($array, $depth);
+ }
+}
+
+if (! function_exists('array_forget')) {
+ /**
+ * Remove one or many array items from a given array using "dot" notation.
+ *
+ * @param array $array
+ * @param array|string $keys
+ * @return void
+ */
+ function array_forget(&$array, $keys)
+ {
+ return Arr::forget($array, $keys);
+ }
+}
+
+if (! function_exists('array_get')) {
+ /**
+ * Get an item from an array using "dot" notation.
+ *
+ * @param \ArrayAccess|array $array
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ function array_get($array, $key, $default = null)
+ {
+ return Arr::get($array, $key, $default);
+ }
+}
+
+if (! function_exists('array_has')) {
+ /**
+ * Check if an item or items exist in an array using "dot" notation.
+ *
+ * @param \ArrayAccess|array $array
+ * @param string|array $keys
+ * @return bool
+ */
+ function array_has($array, $keys)
+ {
+ return Arr::has($array, $keys);
+ }
+}
+
+if (! function_exists('array_last')) {
+ /**
+ * Return the last element in an array passing a given truth test.
+ *
+ * @param array $array
+ * @param callable|null $callback
+ * @param mixed $default
+ * @return mixed
+ */
+ function array_last($array, callable $callback = null, $default = null)
+ {
+ return Arr::last($array, $callback, $default);
+ }
+}
+
+if (! function_exists('array_only')) {
+ /**
+ * Get a subset of the items from the given array.
+ *
+ * @param array $array
+ * @param array|string $keys
+ * @return array
+ */
+ function array_only($array, $keys)
+ {
+ return Arr::only($array, $keys);
+ }
+}
+
+if (! function_exists('array_pluck')) {
+ /**
+ * Pluck an array of values from an array.
+ *
+ * @param array $array
+ * @param string|array $value
+ * @param string|array|null $key
+ * @return array
+ */
+ function array_pluck($array, $value, $key = null)
+ {
+ return Arr::pluck($array, $value, $key);
+ }
+}
+
+if (! function_exists('array_prepend')) {
+ /**
+ * Push an item onto the beginning of an array.
+ *
+ * @param array $array
+ * @param mixed $value
+ * @param mixed $key
+ * @return array
+ */
+ function array_prepend($array, $value, $key = null)
+ {
+ return Arr::prepend($array, $value, $key);
+ }
+}
+
+if (! function_exists('array_pull')) {
+ /**
+ * Get a value from the array, and remove it.
+ *
+ * @param array $array
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ function array_pull(&$array, $key, $default = null)
+ {
+ return Arr::pull($array, $key, $default);
+ }
+}
+
+if (! function_exists('array_random')) {
+ /**
+ * Get a random value from an array.
+ *
+ * @param array $array
+ * @param int|null $num
+ * @return mixed
+ */
+ function array_random($array, $num = null)
+ {
+ return Arr::random($array, $num);
+ }
+}
+
+if (! function_exists('array_set')) {
+ /**
+ * Set an array item to a given value using "dot" notation.
+ *
+ * If no key is given to the method, the entire array will be replaced.
+ *
+ * @param array $array
+ * @param string $key
+ * @param mixed $value
+ * @return array
+ */
+ function array_set(&$array, $key, $value)
+ {
+ return Arr::set($array, $key, $value);
+ }
+}
+
+if (! function_exists('array_sort')) {
+ /**
+ * Sort the array by the given callback or attribute name.
+ *
+ * @param array $array
+ * @param callable|string $callback
+ * @return array
+ */
+ function array_sort($array, $callback)
+ {
+ return Arr::sort($array, $callback);
+ }
+}
+
+if (! function_exists('array_sort_recursive')) {
+ /**
+ * Recursively sort an array by keys and values.
+ *
+ * @param array $array
+ * @return array
+ */
+ function array_sort_recursive($array)
+ {
+ return Arr::sortRecursive($array);
+ }
+}
+
+if (! function_exists('array_where')) {
+ /**
+ * Filter the array using the given callback.
+ *
+ * @param array $array
+ * @param callable $callback
+ * @return array
+ */
+ function array_where($array, callable $callback)
+ {
+ return Arr::where($array, $callback);
+ }
+}
+
+if (! function_exists('array_wrap')) {
+ /**
+ * If the given value is not an array, wrap it in one.
+ *
+ * @param mixed $value
+ * @return array
+ */
+ function array_wrap($value)
+ {
+ return Arr::wrap($value);
+ }
+}
+
+if (! function_exists('camel_case')) {
+ /**
+ * Convert a value to camel case.
+ *
+ * @param string $value
+ * @return string
+ */
+ function camel_case($value)
+ {
+ return Str::camel($value);
+ }
+}
+
+if (! function_exists('class_basename')) {
+ /**
+ * Get the class "basename" of the given object / class.
+ *
+ * @param string|object $class
+ * @return string
+ */
+ function class_basename($class)
+ {
+ $class = is_object($class) ? get_class($class) : $class;
+
+ return basename(str_replace('\\', '/', $class));
+ }
+}
+
+if (! function_exists('class_uses_recursive')) {
+ /**
+ * Returns all traits used by a class, its subclasses and trait of their traits.
+ *
+ * @param object|string $class
+ * @return array
+ */
+ function class_uses_recursive($class)
+ {
+ if (is_object($class)) {
+ $class = get_class($class);
+ }
+
+ $results = [];
+
+ foreach (array_merge([$class => $class], class_parents($class)) as $class) {
+ $results += trait_uses_recursive($class);
+ }
+
+ return array_unique($results);
+ }
+}
+
+if (! function_exists('collect')) {
+ /**
+ * Create a collection from the given value.
+ *
+ * @param mixed $value
+ * @return \Illuminate\Support\Collection
+ */
+ function collect($value = null)
+ {
+ return new Collection($value);
+ }
+}
+
+if (! function_exists('data_fill')) {
+ /**
+ * Fill in data where it's missing.
+ *
+ * @param mixed $target
+ * @param string|array $key
+ * @param mixed $value
+ * @return mixed
+ */
+ function data_fill(&$target, $key, $value)
+ {
+ return data_set($target, $key, $value, false);
+ }
+}
+
+if (! function_exists('data_get')) {
+ /**
+ * Get an item from an array or object using "dot" notation.
+ *
+ * @param mixed $target
+ * @param string|array $key
+ * @param mixed $default
+ * @return mixed
+ */
+ function data_get($target, $key, $default = null)
+ {
+ if (is_null($key)) {
+ return $target;
+ }
+
+ $key = is_array($key) ? $key : explode('.', $key);
+
+ while (! is_null($segment = array_shift($key))) {
+ if ($segment === '*') {
+ if ($target instanceof Collection) {
+ $target = $target->all();
+ } elseif (! is_array($target)) {
+ return value($default);
+ }
+
+ $result = Arr::pluck($target, $key);
+
+ return in_array('*', $key) ? Arr::collapse($result) : $result;
+ }
+
+ if (Arr::accessible($target) && Arr::exists($target, $segment)) {
+ $target = $target[$segment];
+ } elseif (is_object($target) && isset($target->{$segment})) {
+ $target = $target->{$segment};
+ } else {
+ return value($default);
+ }
+ }
+
+ return $target;
+ }
+}
+
+if (! function_exists('data_set')) {
+ /**
+ * Set an item on an array or object using dot notation.
+ *
+ * @param mixed $target
+ * @param string|array $key
+ * @param mixed $value
+ * @param bool $overwrite
+ * @return mixed
+ */
+ function data_set(&$target, $key, $value, $overwrite = true)
+ {
+ $segments = is_array($key) ? $key : explode('.', $key);
+
+ if (($segment = array_shift($segments)) === '*') {
+ if (! Arr::accessible($target)) {
+ $target = [];
+ }
+
+ if ($segments) {
+ foreach ($target as &$inner) {
+ data_set($inner, $segments, $value, $overwrite);
+ }
+ } elseif ($overwrite) {
+ foreach ($target as &$inner) {
+ $inner = $value;
+ }
+ }
+ } elseif (Arr::accessible($target)) {
+ if ($segments) {
+ if (! Arr::exists($target, $segment)) {
+ $target[$segment] = [];
+ }
+
+ data_set($target[$segment], $segments, $value, $overwrite);
+ } elseif ($overwrite || ! Arr::exists($target, $segment)) {
+ $target[$segment] = $value;
+ }
+ } elseif (is_object($target)) {
+ if ($segments) {
+ if (! isset($target->{$segment})) {
+ $target->{$segment} = [];
+ }
+
+ data_set($target->{$segment}, $segments, $value, $overwrite);
+ } elseif ($overwrite || ! isset($target->{$segment})) {
+ $target->{$segment} = $value;
+ }
+ } else {
+ $target = [];
+
+ if ($segments) {
+ data_set($target[$segment], $segments, $value, $overwrite);
+ } elseif ($overwrite) {
+ $target[$segment] = $value;
+ }
+ }
+
+ return $target;
+ }
+}
+
+if (! function_exists('dd')) {
+ /**
+ * Dump the passed variables and end the script.
+ *
+ * @param mixed
+ * @return void
+ */
+ function dd(...$args)
+ {
+ foreach ($args as $x) {
+ (new Dumper)->dump($x);
+ }
+
+ die(1);
+ }
+}
+
+if (! function_exists('e')) {
+ /**
+ * Escape HTML special characters in a string.
+ *
+ * @param \Illuminate\Contracts\Support\Htmlable|string $value
+ * @return string
+ */
+ function e($value)
+ {
+ if ($value instanceof Htmlable) {
+ return $value->toHtml();
+ }
+
+ return htmlspecialchars($value, ENT_QUOTES, 'UTF-8', false);
+ }
+}
+
+if (! function_exists('ends_with')) {
+ /**
+ * Determine if a given string ends with a given substring.
+ *
+ * @param string $haystack
+ * @param string|array $needles
+ * @return bool
+ */
+ function ends_with($haystack, $needles)
+ {
+ return Str::endsWith($haystack, $needles);
+ }
+}
+
+if (! function_exists('env')) {
+ /**
+ * Gets the value of an environment variable.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ function env($key, $default = null)
+ {
+ $value = getenv($key);
+
+ if ($value === false) {
+ return value($default);
+ }
+
+ switch (strtolower($value)) {
+ case 'true':
+ case '(true)':
+ return true;
+ case 'false':
+ case '(false)':
+ return false;
+ case 'empty':
+ case '(empty)':
+ return '';
+ case 'null':
+ case '(null)':
+ return;
+ }
+
+ if (strlen($value) > 1 && Str::startsWith($value, '"') && Str::endsWith($value, '"')) {
+ return substr($value, 1, -1);
+ }
+
+ return $value;
+ }
+}
+
+if (! function_exists('head')) {
+ /**
+ * Get the first element of an array. Useful for method chaining.
+ *
+ * @param array $array
+ * @return mixed
+ */
+ function head($array)
+ {
+ return reset($array);
+ }
+}
+
+if (! function_exists('kebab_case')) {
+ /**
+ * Convert a string to kebab case.
+ *
+ * @param string $value
+ * @return string
+ */
+ function kebab_case($value)
+ {
+ return Str::kebab($value);
+ }
+}
+
+if (! function_exists('last')) {
+ /**
+ * Get the last element from an array.
+ *
+ * @param array $array
+ * @return mixed
+ */
+ function last($array)
+ {
+ return end($array);
+ }
+}
+
+if (! function_exists('object_get')) {
+ /**
+ * Get an item from an object using "dot" notation.
+ *
+ * @param object $object
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ function object_get($object, $key, $default = null)
+ {
+ if (is_null($key) || trim($key) == '') {
+ return $object;
+ }
+
+ foreach (explode('.', $key) as $segment) {
+ if (! is_object($object) || ! isset($object->{$segment})) {
+ return value($default);
+ }
+
+ $object = $object->{$segment};
+ }
+
+ return $object;
+ }
+}
+
+if (! function_exists('preg_replace_array')) {
+ /**
+ * Replace a given pattern with each value in the array in sequentially.
+ *
+ * @param string $pattern
+ * @param array $replacements
+ * @param string $subject
+ * @return string
+ */
+ function preg_replace_array($pattern, array $replacements, $subject)
+ {
+ return preg_replace_callback($pattern, function () use (&$replacements) {
+ foreach ($replacements as $key => $value) {
+ return array_shift($replacements);
+ }
+ }, $subject);
+ }
+}
+
+if (! function_exists('retry')) {
+ /**
+ * Retry an operation a given number of times.
+ *
+ * @param int $times
+ * @param callable $callback
+ * @param int $sleep
+ * @return mixed
+ *
+ * @throws \Exception
+ */
+ function retry($times, callable $callback, $sleep = 0)
+ {
+ $times--;
+
+ beginning:
+ try {
+ return $callback();
+ } catch (Exception $e) {
+ if (! $times) {
+ throw $e;
+ }
+
+ $times--;
+
+ if ($sleep) {
+ usleep($sleep * 1000);
+ }
+
+ goto beginning;
+ }
+ }
+}
+
+if (! function_exists('snake_case')) {
+ /**
+ * Convert a string to snake case.
+ *
+ * @param string $value
+ * @param string $delimiter
+ * @return string
+ */
+ function snake_case($value, $delimiter = '_')
+ {
+ return Str::snake($value, $delimiter);
+ }
+}
+
+if (! function_exists('starts_with')) {
+ /**
+ * Determine if a given string starts with a given substring.
+ *
+ * @param string $haystack
+ * @param string|array $needles
+ * @return bool
+ */
+ function starts_with($haystack, $needles)
+ {
+ return Str::startsWith($haystack, $needles);
+ }
+}
+
+if (! function_exists('str_after')) {
+ /**
+ * Return the remainder of a string after a given value.
+ *
+ * @param string $subject
+ * @param string $search
+ * @return string
+ */
+ function str_after($subject, $search)
+ {
+ return Str::after($subject, $search);
+ }
+}
+
+if (! function_exists('str_contains')) {
+ /**
+ * Determine if a given string contains a given substring.
+ *
+ * @param string $haystack
+ * @param string|array $needles
+ * @return bool
+ */
+ function str_contains($haystack, $needles)
+ {
+ return Str::contains($haystack, $needles);
+ }
+}
+
+if (! function_exists('str_finish')) {
+ /**
+ * Cap a string with a single instance of a given value.
+ *
+ * @param string $value
+ * @param string $cap
+ * @return string
+ */
+ function str_finish($value, $cap)
+ {
+ return Str::finish($value, $cap);
+ }
+}
+
+if (! function_exists('str_is')) {
+ /**
+ * Determine if a given string matches a given pattern.
+ *
+ * @param string $pattern
+ * @param string $value
+ * @return bool
+ */
+ function str_is($pattern, $value)
+ {
+ return Str::is($pattern, $value);
+ }
+}
+
+if (! function_exists('str_limit')) {
+ /**
+ * Limit the number of characters in a string.
+ *
+ * @param string $value
+ * @param int $limit
+ * @param string $end
+ * @return string
+ */
+ function str_limit($value, $limit = 100, $end = '...')
+ {
+ return Str::limit($value, $limit, $end);
+ }
+}
+
+if (! function_exists('str_plural')) {
+ /**
+ * Get the plural form of an English word.
+ *
+ * @param string $value
+ * @param int $count
+ * @return string
+ */
+ function str_plural($value, $count = 2)
+ {
+ return Str::plural($value, $count);
+ }
+}
+
+if (! function_exists('str_random')) {
+ /**
+ * Generate a more truly "random" alpha-numeric string.
+ *
+ * @param int $length
+ * @return string
+ *
+ * @throws \RuntimeException
+ */
+ function str_random($length = 16)
+ {
+ return Str::random($length);
+ }
+}
+
+if (! function_exists('str_replace_array')) {
+ /**
+ * Replace a given value in the string sequentially with an array.
+ *
+ * @param string $search
+ * @param array $replace
+ * @param string $subject
+ * @return string
+ */
+ function str_replace_array($search, array $replace, $subject)
+ {
+ return Str::replaceArray($search, $replace, $subject);
+ }
+}
+
+if (! function_exists('str_replace_first')) {
+ /**
+ * Replace the first occurrence of a given value in the string.
+ *
+ * @param string $search
+ * @param string $replace
+ * @param string $subject
+ * @return string
+ */
+ function str_replace_first($search, $replace, $subject)
+ {
+ return Str::replaceFirst($search, $replace, $subject);
+ }
+}
+
+if (! function_exists('str_replace_last')) {
+ /**
+ * Replace the last occurrence of a given value in the string.
+ *
+ * @param string $search
+ * @param string $replace
+ * @param string $subject
+ * @return string
+ */
+ function str_replace_last($search, $replace, $subject)
+ {
+ return Str::replaceLast($search, $replace, $subject);
+ }
+}
+
+if (! function_exists('str_singular')) {
+ /**
+ * Get the singular form of an English word.
+ *
+ * @param string $value
+ * @return string
+ */
+ function str_singular($value)
+ {
+ return Str::singular($value);
+ }
+}
+
+if (! function_exists('str_slug')) {
+ /**
+ * Generate a URL friendly "slug" from a given string.
+ *
+ * @param string $title
+ * @param string $separator
+ * @return string
+ */
+ function str_slug($title, $separator = '-')
+ {
+ return Str::slug($title, $separator);
+ }
+}
+
+if (! function_exists('str_start')) {
+ /**
+ * Begin a string with a single instance of a given value.
+ *
+ * @param string $value
+ * @param string $prefix
+ * @return string
+ */
+ function str_start($value, $prefix)
+ {
+ return Str::start($value, $prefix);
+ }
+}
+
+if (! function_exists('studly_case')) {
+ /**
+ * Convert a value to studly caps case.
+ *
+ * @param string $value
+ * @return string
+ */
+ function studly_case($value)
+ {
+ return Str::studly($value);
+ }
+}
+
+if (! function_exists('tap')) {
+ /**
+ * Call the given Closure with the given value then return the value.
+ *
+ * @param mixed $value
+ * @param callable|null $callback
+ * @return mixed
+ */
+ function tap($value, $callback = null)
+ {
+ if (is_null($callback)) {
+ return new HigherOrderTapProxy($value);
+ }
+
+ $callback($value);
+
+ return $value;
+ }
+}
+
+if (! function_exists('title_case')) {
+ /**
+ * Convert a value to title case.
+ *
+ * @param string $value
+ * @return string
+ */
+ function title_case($value)
+ {
+ return Str::title($value);
+ }
+}
+
+if (! function_exists('trait_uses_recursive')) {
+ /**
+ * Returns all traits used by a trait and its traits.
+ *
+ * @param string $trait
+ * @return array
+ */
+ function trait_uses_recursive($trait)
+ {
+ $traits = class_uses($trait);
+
+ foreach ($traits as $trait) {
+ $traits += trait_uses_recursive($trait);
+ }
+
+ return $traits;
+ }
+}
+
+if (! function_exists('value')) {
+ /**
+ * Return the default value of the given value.
+ *
+ * @param mixed $value
+ * @return mixed
+ */
+ function value($value)
+ {
+ return $value instanceof Closure ? $value() : $value;
+ }
+}
+
+if (! function_exists('windows_os')) {
+ /**
+ * Determine whether the current environment is Windows based.
+ *
+ * @return bool
+ */
+ function windows_os()
+ {
+ return strtolower(substr(PHP_OS, 0, 3)) === 'win';
+ }
+}
+
+if (! function_exists('with')) {
+ /**
+ * Return the given object. Useful for chaining.
+ *
+ * @param mixed $object
+ * @return mixed
+ */
+ function with($object)
+ {
+ return $object;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Translation/ArrayLoader.php b/vendor/laravel/framework/src/Illuminate/Translation/ArrayLoader.php
new file mode 100644
index 000000000..5e0b2d077
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Translation/ArrayLoader.php
@@ -0,0 +1,72 @@
+messages[$namespace][$locale][$group])) {
+ return $this->messages[$namespace][$locale][$group];
+ }
+
+ return [];
+ }
+
+ /**
+ * Add a new namespace to the loader.
+ *
+ * @param string $namespace
+ * @param string $hint
+ * @return void
+ */
+ public function addNamespace($namespace, $hint)
+ {
+ //
+ }
+
+ /**
+ * Add messages to the loader.
+ *
+ * @param string $locale
+ * @param string $group
+ * @param array $messages
+ * @param string|null $namespace
+ * @return $this
+ */
+ public function addMessages($locale, $group, array $messages, $namespace = null)
+ {
+ $namespace = $namespace ?: '*';
+
+ $this->messages[$namespace][$locale][$group] = $messages;
+
+ return $this;
+ }
+
+ /**
+ * Get an array of all the registered namespaces.
+ *
+ * @return array
+ */
+ public function namespaces()
+ {
+ return [];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Translation/FileLoader.php b/vendor/laravel/framework/src/Illuminate/Translation/FileLoader.php
new file mode 100644
index 000000000..9d45c06a0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Translation/FileLoader.php
@@ -0,0 +1,157 @@
+path = $path;
+ $this->files = $files;
+ }
+
+ /**
+ * Load the messages for the given locale.
+ *
+ * @param string $locale
+ * @param string $group
+ * @param string $namespace
+ * @return array
+ */
+ public function load($locale, $group, $namespace = null)
+ {
+ if ($group == '*' && $namespace == '*') {
+ return $this->loadJsonPath($this->path, $locale);
+ }
+
+ if (is_null($namespace) || $namespace == '*') {
+ return $this->loadPath($this->path, $locale, $group);
+ }
+
+ return $this->loadNamespaced($locale, $group, $namespace);
+ }
+
+ /**
+ * Load a namespaced translation group.
+ *
+ * @param string $locale
+ * @param string $group
+ * @param string $namespace
+ * @return array
+ */
+ protected function loadNamespaced($locale, $group, $namespace)
+ {
+ if (isset($this->hints[$namespace])) {
+ $lines = $this->loadPath($this->hints[$namespace], $locale, $group);
+
+ return $this->loadNamespaceOverrides($lines, $locale, $group, $namespace);
+ }
+
+ return [];
+ }
+
+ /**
+ * Load a local namespaced translation group for overrides.
+ *
+ * @param array $lines
+ * @param string $locale
+ * @param string $group
+ * @param string $namespace
+ * @return array
+ */
+ protected function loadNamespaceOverrides(array $lines, $locale, $group, $namespace)
+ {
+ $file = "{$this->path}/vendor/{$namespace}/{$locale}/{$group}.php";
+
+ if ($this->files->exists($file)) {
+ return array_replace_recursive($lines, $this->files->getRequire($file));
+ }
+
+ return $lines;
+ }
+
+ /**
+ * Load a locale from a given path.
+ *
+ * @param string $path
+ * @param string $locale
+ * @param string $group
+ * @return array
+ */
+ protected function loadPath($path, $locale, $group)
+ {
+ if ($this->files->exists($full = "{$path}/{$locale}/{$group}.php")) {
+ return $this->files->getRequire($full);
+ }
+
+ return [];
+ }
+
+ /**
+ * Load a locale from the given JSON file path.
+ *
+ * @param string $path
+ * @param string $locale
+ * @return array
+ */
+ protected function loadJsonPath($path, $locale)
+ {
+ if ($this->files->exists($full = "{$path}/{$locale}.json")) {
+ return json_decode($this->files->get($full), true);
+ }
+
+ return [];
+ }
+
+ /**
+ * Add a new namespace to the loader.
+ *
+ * @param string $namespace
+ * @param string $hint
+ * @return void
+ */
+ public function addNamespace($namespace, $hint)
+ {
+ $this->hints[$namespace] = $hint;
+ }
+
+ /**
+ * Get an array of all the registered namespaces.
+ *
+ * @return array
+ */
+ public function namespaces()
+ {
+ return $this->hints;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Translation/LoaderInterface.php b/vendor/laravel/framework/src/Illuminate/Translation/LoaderInterface.php
new file mode 100644
index 000000000..cbebebfc6
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Translation/LoaderInterface.php
@@ -0,0 +1,32 @@
+extract($segments, $number)) !== null) {
+ return trim($value);
+ }
+
+ $segments = $this->stripConditions($segments);
+
+ $pluralIndex = $this->getPluralIndex($locale, $number);
+
+ if (count($segments) == 1 || ! isset($segments[$pluralIndex])) {
+ return $segments[0];
+ }
+
+ return $segments[$pluralIndex];
+ }
+
+ /**
+ * Extract a translation string using inline conditions.
+ *
+ * @param array $segments
+ * @param int $number
+ * @return mixed
+ */
+ private function extract($segments, $number)
+ {
+ foreach ($segments as $part) {
+ if (! is_null($line = $this->extractFromString($part, $number))) {
+ return $line;
+ }
+ }
+ }
+
+ /**
+ * Get the translation string if the condition matches.
+ *
+ * @param string $part
+ * @param int $number
+ * @return mixed
+ */
+ private function extractFromString($part, $number)
+ {
+ preg_match('/^[\{\[]([^\[\]\{\}]*)[\}\]](.*)/s', $part, $matches);
+
+ if (count($matches) != 3) {
+ return;
+ }
+
+ $condition = $matches[1];
+
+ $value = $matches[2];
+
+ if (Str::contains($condition, ',')) {
+ list($from, $to) = explode(',', $condition, 2);
+
+ if ($to == '*' && $number >= $from) {
+ return $value;
+ } elseif ($from == '*' && $number <= $to) {
+ return $value;
+ } elseif ($number >= $from && $number <= $to) {
+ return $value;
+ }
+ }
+
+ return $condition == $number ? $value : null;
+ }
+
+ /**
+ * Strip the inline conditions from each segment, just leaving the text.
+ *
+ * @param array $segments
+ * @return array
+ */
+ private function stripConditions($segments)
+ {
+ return collect($segments)->map(function ($part) {
+ return preg_replace('/^[\{\[]([^\[\]\{\}]*)[\}\]]/', '', $part);
+ })->all();
+ }
+
+ /**
+ * Get the index to use for pluralization.
+ *
+ * The plural rules are derived from code of the Zend Framework (2010-09-25), which
+ * is subject to the new BSD license (http://framework.zend.com/license/new-bsd)
+ * Copyright (c) 2005-2010 - Zend Technologies USA Inc. (http://www.zend.com)
+ *
+ * @param string $locale
+ * @param int $number
+ * @return int
+ */
+ public function getPluralIndex($locale, $number)
+ {
+ switch ($locale) {
+ case 'az':
+ case 'az_AZ':
+ case 'bo':
+ case 'bo_CN':
+ case 'bo_IN':
+ case 'dz':
+ case 'dz_BT':
+ case 'id':
+ case 'id_ID':
+ case 'ja':
+ case 'ja_JP':
+ case 'jv':
+ case 'ka':
+ case 'ka_GE':
+ case 'km':
+ case 'km_KH':
+ case 'kn':
+ case 'kn_IN':
+ case 'ko':
+ case 'ko_KR':
+ case 'ms':
+ case 'ms_MY':
+ case 'th':
+ case 'th_TH':
+ case 'tr':
+ case 'tr_CY':
+ case 'tr_TR':
+ case 'vi':
+ case 'vi_VN':
+ case 'zh':
+ case 'zh_CN':
+ case 'zh_HK':
+ case 'zh_SG':
+ case 'zh_TW':
+ return 0;
+ case 'af':
+ case 'af_ZA':
+ case 'bn':
+ case 'bn_BD':
+ case 'bn_IN':
+ case 'bg':
+ case 'bg_BG':
+ case 'ca':
+ case 'ca_AD':
+ case 'ca_ES':
+ case 'ca_FR':
+ case 'ca_IT':
+ case 'da':
+ case 'da_DK':
+ case 'de':
+ case 'de_AT':
+ case 'de_BE':
+ case 'de_CH':
+ case 'de_DE':
+ case 'de_LI':
+ case 'de_LU':
+ case 'el':
+ case 'el_CY':
+ case 'el_GR':
+ case 'en':
+ case 'en_AG':
+ case 'en_AU':
+ case 'en_BW':
+ case 'en_CA':
+ case 'en_DK':
+ case 'en_GB':
+ case 'en_HK':
+ case 'en_IE':
+ case 'en_IN':
+ case 'en_NG':
+ case 'en_NZ':
+ case 'en_PH':
+ case 'en_SG':
+ case 'en_US':
+ case 'en_ZA':
+ case 'en_ZM':
+ case 'en_ZW':
+ case 'eo':
+ case 'eo_US':
+ case 'es':
+ case 'es_AR':
+ case 'es_BO':
+ case 'es_CL':
+ case 'es_CO':
+ case 'es_CR':
+ case 'es_CU':
+ case 'es_DO':
+ case 'es_EC':
+ case 'es_ES':
+ case 'es_GT':
+ case 'es_HN':
+ case 'es_MX':
+ case 'es_NI':
+ case 'es_PA':
+ case 'es_PE':
+ case 'es_PR':
+ case 'es_PY':
+ case 'es_SV':
+ case 'es_US':
+ case 'es_UY':
+ case 'es_VE':
+ case 'et':
+ case 'et_EE':
+ case 'eu':
+ case 'eu_ES':
+ case 'eu_FR':
+ case 'fa':
+ case 'fa_IR':
+ case 'fi':
+ case 'fi_FI':
+ case 'fo':
+ case 'fo_FO':
+ case 'fur':
+ case 'fur_IT':
+ case 'fy':
+ case 'fy_DE':
+ case 'fy_NL':
+ case 'gl':
+ case 'gl_ES':
+ case 'gu':
+ case 'gu_IN':
+ case 'ha':
+ case 'ha_NG':
+ case 'he':
+ case 'he_IL':
+ case 'hu':
+ case 'hu_HU':
+ case 'is':
+ case 'is_IS':
+ case 'it':
+ case 'it_CH':
+ case 'it_IT':
+ case 'ku':
+ case 'ku_TR':
+ case 'lb':
+ case 'lb_LU':
+ case 'ml':
+ case 'ml_IN':
+ case 'mn':
+ case 'mn_MN':
+ case 'mr':
+ case 'mr_IN':
+ case 'nah':
+ case 'nb':
+ case 'nb_NO':
+ case 'ne':
+ case 'ne_NP':
+ case 'nl':
+ case 'nl_AW':
+ case 'nl_BE':
+ case 'nl_NL':
+ case 'nn':
+ case 'nn_NO':
+ case 'no':
+ case 'om':
+ case 'om_ET':
+ case 'om_KE':
+ case 'or':
+ case 'or_IN':
+ case 'pa':
+ case 'pa_IN':
+ case 'pa_PK':
+ case 'pap':
+ case 'pap_AN':
+ case 'pap_AW':
+ case 'pap_CW':
+ case 'ps':
+ case 'ps_AF':
+ case 'pt':
+ case 'pt_BR':
+ case 'pt_PT':
+ case 'so':
+ case 'so_DJ':
+ case 'so_ET':
+ case 'so_KE':
+ case 'so_SO':
+ case 'sq':
+ case 'sq_AL':
+ case 'sq_MK':
+ case 'sv':
+ case 'sv_FI':
+ case 'sv_SE':
+ case 'sw':
+ case 'sw_KE':
+ case 'sw_TZ':
+ case 'ta':
+ case 'ta_IN':
+ case 'ta_LK':
+ case 'te':
+ case 'te_IN':
+ case 'tk':
+ case 'tk_TM':
+ case 'ur':
+ case 'ur_IN':
+ case 'ur_PK':
+ case 'zu':
+ case 'zu_ZA':
+ return ($number == 1) ? 0 : 1;
+ case 'am':
+ case 'am_ET':
+ case 'bh':
+ case 'fil':
+ case 'fil_PH':
+ case 'fr':
+ case 'fr_BE':
+ case 'fr_CA':
+ case 'fr_CH':
+ case 'fr_FR':
+ case 'fr_LU':
+ case 'gun':
+ case 'hi':
+ case 'hi_IN':
+ case 'hy':
+ case 'hy_AM':
+ case 'ln':
+ case 'ln_CD':
+ case 'mg':
+ case 'mg_MG':
+ case 'nso':
+ case 'nso_ZA':
+ case 'ti':
+ case 'ti_ER':
+ case 'ti_ET':
+ case 'wa':
+ case 'wa_BE':
+ case 'xbr':
+ return (($number == 0) || ($number == 1)) ? 0 : 1;
+ case 'be':
+ case 'be_BY':
+ case 'bs':
+ case 'bs_BA':
+ case 'hr':
+ case 'hr_HR':
+ case 'ru':
+ case 'ru_RU':
+ case 'ru_UA':
+ case 'sr':
+ case 'sr_ME':
+ case 'sr_RS':
+ case 'uk':
+ case 'uk_UA':
+ return (($number % 10 == 1) && ($number % 100 != 11)) ? 0 : ((($number % 10 >= 2) && ($number % 10 <= 4) && (($number % 100 < 10) || ($number % 100 >= 20))) ? 1 : 2);
+ case 'cs':
+ case 'cs_CZ':
+ case 'sk':
+ case 'sk_SK':
+ return ($number == 1) ? 0 : ((($number >= 2) && ($number <= 4)) ? 1 : 2);
+ case 'ga':
+ case 'ga_IE':
+ return ($number == 1) ? 0 : (($number == 2) ? 1 : 2);
+ case 'lt':
+ case 'lt_LT':
+ return (($number % 10 == 1) && ($number % 100 != 11)) ? 0 : ((($number % 10 >= 2) && (($number % 100 < 10) || ($number % 100 >= 20))) ? 1 : 2);
+ case 'sl':
+ case 'sl_SI':
+ return ($number % 100 == 1) ? 0 : (($number % 100 == 2) ? 1 : ((($number % 100 == 3) || ($number % 100 == 4)) ? 2 : 3));
+ case 'mk':
+ case 'mk_MK':
+ return ($number % 10 == 1) ? 0 : 1;
+ case 'mt':
+ case 'mt_MT':
+ return ($number == 1) ? 0 : ((($number == 0) || (($number % 100 > 1) && ($number % 100 < 11))) ? 1 : ((($number % 100 > 10) && ($number % 100 < 20)) ? 2 : 3));
+ case 'lv':
+ case 'lv_LV':
+ return ($number == 0) ? 0 : ((($number % 10 == 1) && ($number % 100 != 11)) ? 1 : 2);
+ case 'pl':
+ case 'pl_PL':
+ return ($number == 1) ? 0 : ((($number % 10 >= 2) && ($number % 10 <= 4) && (($number % 100 < 12) || ($number % 100 > 14))) ? 1 : 2);
+ case 'cy':
+ case 'cy_GB':
+ return ($number == 1) ? 0 : (($number == 2) ? 1 : ((($number == 8) || ($number == 11)) ? 2 : 3));
+ case 'ro':
+ case 'ro_RO':
+ return ($number == 1) ? 0 : ((($number == 0) || (($number % 100 > 0) && ($number % 100 < 20))) ? 1 : 2);
+ case 'ar':
+ case 'ar_AE':
+ case 'ar_BH':
+ case 'ar_DZ':
+ case 'ar_EG':
+ case 'ar_IN':
+ case 'ar_IQ':
+ case 'ar_JO':
+ case 'ar_KW':
+ case 'ar_LB':
+ case 'ar_LY':
+ case 'ar_MA':
+ case 'ar_OM':
+ case 'ar_QA':
+ case 'ar_SA':
+ case 'ar_SD':
+ case 'ar_SS':
+ case 'ar_SY':
+ case 'ar_TN':
+ case 'ar_YE':
+ return ($number == 0) ? 0 : (($number == 1) ? 1 : (($number == 2) ? 2 : ((($number % 100 >= 3) && ($number % 100 <= 10)) ? 3 : ((($number % 100 >= 11) && ($number % 100 <= 99)) ? 4 : 5))));
+ default:
+ return 0;
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Translation/TranslationServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Translation/TranslationServiceProvider.php
new file mode 100644
index 000000000..f0dd3fe73
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Translation/TranslationServiceProvider.php
@@ -0,0 +1,62 @@
+registerLoader();
+
+ $this->app->singleton('translator', function ($app) {
+ $loader = $app['translation.loader'];
+
+ // When registering the translator component, we'll need to set the default
+ // locale as well as the fallback locale. So, we'll grab the application
+ // configuration so we can easily get both of these values from there.
+ $locale = $app['config']['app.locale'];
+
+ $trans = new Translator($loader, $locale);
+
+ $trans->setFallback($app['config']['app.fallback_locale']);
+
+ return $trans;
+ });
+ }
+
+ /**
+ * Register the translation line loader.
+ *
+ * @return void
+ */
+ protected function registerLoader()
+ {
+ $this->app->singleton('translation.loader', function ($app) {
+ return new FileLoader($app['files'], $app['path.lang']);
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return ['translator', 'translation.loader'];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Translation/Translator.php b/vendor/laravel/framework/src/Illuminate/Translation/Translator.php
new file mode 100644
index 000000000..fc8980eda
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Translation/Translator.php
@@ -0,0 +1,468 @@
+loader = $loader;
+ $this->locale = $locale;
+ }
+
+ /**
+ * Determine if a translation exists for a given locale.
+ *
+ * @param string $key
+ * @param string|null $locale
+ * @return bool
+ */
+ public function hasForLocale($key, $locale = null)
+ {
+ return $this->has($key, $locale, false);
+ }
+
+ /**
+ * Determine if a translation exists.
+ *
+ * @param string $key
+ * @param string|null $locale
+ * @param bool $fallback
+ * @return bool
+ */
+ public function has($key, $locale = null, $fallback = true)
+ {
+ return $this->get($key, [], $locale, $fallback) !== $key;
+ }
+
+ /**
+ * Get the translation for a given key.
+ *
+ * @param string $key
+ * @param array $replace
+ * @param string $locale
+ * @return string|array|null
+ */
+ public function trans($key, array $replace = [], $locale = null)
+ {
+ return $this->get($key, $replace, $locale);
+ }
+
+ /**
+ * Get the translation for the given key.
+ *
+ * @param string $key
+ * @param array $replace
+ * @param string|null $locale
+ * @param bool $fallback
+ * @return string|array|null
+ */
+ public function get($key, array $replace = [], $locale = null, $fallback = true)
+ {
+ list($namespace, $group, $item) = $this->parseKey($key);
+
+ // Here we will get the locale that should be used for the language line. If one
+ // was not passed, we will use the default locales which was given to us when
+ // the translator was instantiated. Then, we can load the lines and return.
+ $locales = $fallback ? $this->localeArray($locale)
+ : [$locale ?: $this->locale];
+
+ foreach ($locales as $locale) {
+ if (! is_null($line = $this->getLine(
+ $namespace, $group, $locale, $item, $replace
+ ))) {
+ break;
+ }
+ }
+
+ // If the line doesn't exist, we will return back the key which was requested as
+ // that will be quick to spot in the UI if language keys are wrong or missing
+ // from the application's language files. Otherwise we can return the line.
+ if (isset($line)) {
+ return $line;
+ }
+
+ return $key;
+ }
+
+ /**
+ * Get the translation for a given key from the JSON translation files.
+ *
+ * @param string $key
+ * @param array $replace
+ * @param string $locale
+ * @return string
+ */
+ public function getFromJson($key, array $replace = [], $locale = null)
+ {
+ $locale = $locale ?: $this->locale;
+
+ // For JSON translations, there is only one file per locale, so we will simply load
+ // that file and then we will be ready to check the array for the key. These are
+ // only one level deep so we do not need to do any fancy searching through it.
+ $this->load('*', '*', $locale);
+
+ $line = isset($this->loaded['*']['*'][$locale][$key])
+ ? $this->loaded['*']['*'][$locale][$key] : null;
+
+ // If we can't find a translation for the JSON key, we will attempt to translate it
+ // using the typical translation file. This way developers can always just use a
+ // helper such as __ instead of having to pick between trans or __ with views.
+ if (! isset($line)) {
+ $fallback = $this->get($key, $replace, $locale);
+
+ if ($fallback !== $key) {
+ return $fallback;
+ }
+ }
+
+ return $this->makeReplacements($line ?: $key, $replace);
+ }
+
+ /**
+ * Get a translation according to an integer value.
+ *
+ * @param string $key
+ * @param int|array|\Countable $number
+ * @param array $replace
+ * @param string $locale
+ * @return string
+ */
+ public function transChoice($key, $number, array $replace = [], $locale = null)
+ {
+ return $this->choice($key, $number, $replace, $locale);
+ }
+
+ /**
+ * Get a translation according to an integer value.
+ *
+ * @param string $key
+ * @param int|array|\Countable $number
+ * @param array $replace
+ * @param string $locale
+ * @return string
+ */
+ public function choice($key, $number, array $replace = [], $locale = null)
+ {
+ $line = $this->get(
+ $key, $replace, $locale = $this->localeForChoice($locale)
+ );
+
+ // If the given "number" is actually an array or countable we will simply count the
+ // number of elements in an instance. This allows developers to pass an array of
+ // items without having to count it on their end first which gives bad syntax.
+ if (is_array($number) || $number instanceof Countable) {
+ $number = count($number);
+ }
+
+ $replace['count'] = $number;
+
+ return $this->makeReplacements(
+ $this->getSelector()->choose($line, $number, $locale), $replace
+ );
+ }
+
+ /**
+ * Get the proper locale for a choice operation.
+ *
+ * @param string|null $locale
+ * @return string
+ */
+ protected function localeForChoice($locale)
+ {
+ return $locale ?: $this->locale ?: $this->fallback;
+ }
+
+ /**
+ * Retrieve a language line out the loaded array.
+ *
+ * @param string $namespace
+ * @param string $group
+ * @param string $locale
+ * @param string $item
+ * @param array $replace
+ * @return string|array|null
+ */
+ protected function getLine($namespace, $group, $locale, $item, array $replace)
+ {
+ $this->load($namespace, $group, $locale);
+
+ $line = Arr::get($this->loaded[$namespace][$group][$locale], $item);
+
+ if (is_string($line)) {
+ return $this->makeReplacements($line, $replace);
+ } elseif (is_array($line) && count($line) > 0) {
+ return $line;
+ }
+ }
+
+ /**
+ * Make the place-holder replacements on a line.
+ *
+ * @param string $line
+ * @param array $replace
+ * @return string
+ */
+ protected function makeReplacements($line, array $replace)
+ {
+ if (empty($replace)) {
+ return $line;
+ }
+
+ $replace = $this->sortReplacements($replace);
+
+ foreach ($replace as $key => $value) {
+ $line = str_replace(
+ [':'.$key, ':'.Str::upper($key), ':'.Str::ucfirst($key)],
+ [$value, Str::upper($value), Str::ucfirst($value)],
+ $line
+ );
+ }
+
+ return $line;
+ }
+
+ /**
+ * Sort the replacements array.
+ *
+ * @param array $replace
+ * @return array
+ */
+ protected function sortReplacements(array $replace)
+ {
+ return (new Collection($replace))->sortBy(function ($value, $key) {
+ return mb_strlen($key) * -1;
+ })->all();
+ }
+
+ /**
+ * Add translation lines to the given locale.
+ *
+ * @param array $lines
+ * @param string $locale
+ * @param string $namespace
+ * @return void
+ */
+ public function addLines(array $lines, $locale, $namespace = '*')
+ {
+ foreach ($lines as $key => $value) {
+ list($group, $item) = explode('.', $key, 2);
+
+ Arr::set($this->loaded, "$namespace.$group.$locale.$item", $value);
+ }
+ }
+
+ /**
+ * Load the specified language group.
+ *
+ * @param string $namespace
+ * @param string $group
+ * @param string $locale
+ * @return void
+ */
+ public function load($namespace, $group, $locale)
+ {
+ if ($this->isLoaded($namespace, $group, $locale)) {
+ return;
+ }
+
+ // The loader is responsible for returning the array of language lines for the
+ // given namespace, group, and locale. We'll set the lines in this array of
+ // lines that have already been loaded so that we can easily access them.
+ $lines = $this->loader->load($locale, $group, $namespace);
+
+ $this->loaded[$namespace][$group][$locale] = $lines;
+ }
+
+ /**
+ * Determine if the given group has been loaded.
+ *
+ * @param string $namespace
+ * @param string $group
+ * @param string $locale
+ * @return bool
+ */
+ protected function isLoaded($namespace, $group, $locale)
+ {
+ return isset($this->loaded[$namespace][$group][$locale]);
+ }
+
+ /**
+ * Add a new namespace to the loader.
+ *
+ * @param string $namespace
+ * @param string $hint
+ * @return void
+ */
+ public function addNamespace($namespace, $hint)
+ {
+ $this->loader->addNamespace($namespace, $hint);
+ }
+
+ /**
+ * Parse a key into namespace, group, and item.
+ *
+ * @param string $key
+ * @return array
+ */
+ public function parseKey($key)
+ {
+ $segments = parent::parseKey($key);
+
+ if (is_null($segments[0])) {
+ $segments[0] = '*';
+ }
+
+ return $segments;
+ }
+
+ /**
+ * Get the array of locales to be checked.
+ *
+ * @param string|null $locale
+ * @return array
+ */
+ protected function localeArray($locale)
+ {
+ return array_filter([$locale ?: $this->locale, $this->fallback]);
+ }
+
+ /**
+ * Get the message selector instance.
+ *
+ * @return \Illuminate\Translation\MessageSelector
+ */
+ public function getSelector()
+ {
+ if (! isset($this->selector)) {
+ $this->selector = new MessageSelector;
+ }
+
+ return $this->selector;
+ }
+
+ /**
+ * Set the message selector instance.
+ *
+ * @param \Illuminate\Translation\MessageSelector $selector
+ * @return void
+ */
+ public function setSelector(MessageSelector $selector)
+ {
+ $this->selector = $selector;
+ }
+
+ /**
+ * Get the language line loader implementation.
+ *
+ * @return \Illuminate\Translation\LoaderInterface
+ */
+ public function getLoader()
+ {
+ return $this->loader;
+ }
+
+ /**
+ * Get the default locale being used.
+ *
+ * @return string
+ */
+ public function locale()
+ {
+ return $this->getLocale();
+ }
+
+ /**
+ * Get the default locale being used.
+ *
+ * @return string
+ */
+ public function getLocale()
+ {
+ return $this->locale;
+ }
+
+ /**
+ * Set the default locale.
+ *
+ * @param string $locale
+ * @return void
+ */
+ public function setLocale($locale)
+ {
+ $this->locale = $locale;
+ }
+
+ /**
+ * Get the fallback locale being used.
+ *
+ * @return string
+ */
+ public function getFallback()
+ {
+ return $this->fallback;
+ }
+
+ /**
+ * Set the fallback locale being used.
+ *
+ * @param string $fallback
+ * @return void
+ */
+ public function setFallback($fallback)
+ {
+ $this->fallback = $fallback;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Translation/composer.json b/vendor/laravel/framework/src/Illuminate/Translation/composer.json
new file mode 100644
index 000000000..e1d990dcb
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Translation/composer.json
@@ -0,0 +1,36 @@
+{
+ "name": "illuminate/translation",
+ "description": "The Illuminate Translation package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/filesystem": "5.4.*",
+ "illuminate/support": "5.4.*"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Translation\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/Concerns/FormatsMessages.php b/vendor/laravel/framework/src/Illuminate/Validation/Concerns/FormatsMessages.php
new file mode 100644
index 000000000..3784511f4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/Concerns/FormatsMessages.php
@@ -0,0 +1,348 @@
+getFromLocalArray(
+ $attribute, $lowerRule = Str::snake($rule)
+ );
+
+ // First we will retrieve the custom message for the validation rule if one
+ // exists. If a custom validation message is being used we'll return the
+ // custom message, otherwise we'll keep searching for a valid message.
+ if (! is_null($inlineMessage)) {
+ return $inlineMessage;
+ }
+
+ $customMessage = $this->getCustomMessageFromTranslator(
+ $customKey = "validation.custom.{$attribute}.{$lowerRule}"
+ );
+
+ // First we check for a custom defined validation message for the attribute
+ // and rule. This allows the developer to specify specific messages for
+ // only some attributes and rules that need to get specially formed.
+ if ($customMessage !== $customKey) {
+ return $customMessage;
+ }
+
+ // If the rule being validated is a "size" rule, we will need to gather the
+ // specific error message for the type of attribute being validated such
+ // as a number, file or string which all have different message types.
+ elseif (in_array($rule, $this->sizeRules)) {
+ return $this->getSizeMessage($attribute, $rule);
+ }
+
+ // Finally, if no developer specified messages have been set, and no other
+ // special messages apply for this rule, we will just pull the default
+ // messages out of the translator service for this validation rule.
+ $key = "validation.{$lowerRule}";
+
+ if ($key != ($value = $this->translator->trans($key))) {
+ return $value;
+ }
+
+ return $this->getFromLocalArray(
+ $attribute, $lowerRule, $this->fallbackMessages
+ ) ?: $key;
+ }
+
+ /**
+ * Get the inline message for a rule if it exists.
+ *
+ * @param string $attribute
+ * @param string $lowerRule
+ * @param array|null $source
+ * @return string|null
+ */
+ protected function getFromLocalArray($attribute, $lowerRule, $source = null)
+ {
+ $source = $source ?: $this->customMessages;
+
+ $keys = ["{$attribute}.{$lowerRule}", $lowerRule];
+
+ // First we will check for a custom message for an attribute specific rule
+ // message for the fields, then we will check for a general custom line
+ // that is not attribute specific. If we find either we'll return it.
+ foreach ($keys as $key) {
+ foreach (array_keys($source) as $sourceKey) {
+ if (Str::is($sourceKey, $key)) {
+ return $source[$sourceKey];
+ }
+ }
+ }
+ }
+
+ /**
+ * Get the custom error message from translator.
+ *
+ * @param string $key
+ * @return string
+ */
+ protected function getCustomMessageFromTranslator($key)
+ {
+ if (($message = $this->translator->trans($key)) !== $key) {
+ return $message;
+ }
+
+ // If an exact match was not found for the key, we will collapse all of these
+ // messages and loop through them and try to find a wildcard match for the
+ // given key. Otherwise, we will simply return the key's value back out.
+ $shortKey = preg_replace(
+ '/^validation\.custom\./', '', $key
+ );
+
+ return $this->getWildcardCustomMessages(Arr::dot(
+ (array) $this->translator->trans('validation.custom')
+ ), $shortKey, $key);
+ }
+
+ /**
+ * Check the given messages for a wildcard key.
+ *
+ * @param array $messages
+ * @param string $search
+ * @param string $default
+ * @return string
+ */
+ protected function getWildcardCustomMessages($messages, $search, $default)
+ {
+ foreach ($messages as $key => $message) {
+ if ($search === $key || (Str::contains($key, ['*']) && Str::is($key, $search))) {
+ return $message;
+ }
+ }
+
+ return $default;
+ }
+
+ /**
+ * Get the proper error message for an attribute and size rule.
+ *
+ * @param string $attribute
+ * @param string $rule
+ * @return string
+ */
+ protected function getSizeMessage($attribute, $rule)
+ {
+ $lowerRule = Str::snake($rule);
+
+ // There are three different types of size validations. The attribute may be
+ // either a number, file, or string so we will check a few things to know
+ // which type of value it is and return the correct line for that type.
+ $type = $this->getAttributeType($attribute);
+
+ $key = "validation.{$lowerRule}.{$type}";
+
+ return $this->translator->trans($key);
+ }
+
+ /**
+ * Get the data type of the given attribute.
+ *
+ * @param string $attribute
+ * @return string
+ */
+ protected function getAttributeType($attribute)
+ {
+ // We assume that the attributes present in the file array are files so that
+ // means that if the attribute does not have a numeric rule and the files
+ // list doesn't have it we'll just consider it a string by elimination.
+ if ($this->hasRule($attribute, $this->numericRules)) {
+ return 'numeric';
+ } elseif ($this->hasRule($attribute, ['Array'])) {
+ return 'array';
+ } elseif ($this->getValue($attribute) instanceof UploadedFile) {
+ return 'file';
+ }
+
+ return 'string';
+ }
+
+ /**
+ * Replace all error message place-holders with actual values.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ public function makeReplacements($message, $attribute, $rule, $parameters)
+ {
+ $message = $this->replaceAttributePlaceholder(
+ $message, $this->getDisplayableAttribute($attribute)
+ );
+
+ if (isset($this->replacers[Str::snake($rule)])) {
+ return $this->callReplacer($message, $attribute, Str::snake($rule), $parameters, $this);
+ } elseif (method_exists($this, $replacer = "replace{$rule}")) {
+ return $this->$replacer($message, $attribute, $rule, $parameters);
+ }
+
+ return $message;
+ }
+
+ /**
+ * Get the displayable name of the attribute.
+ *
+ * @param string $attribute
+ * @return string
+ */
+ public function getDisplayableAttribute($attribute)
+ {
+ $primaryAttribute = $this->getPrimaryAttribute($attribute);
+
+ $expectedAttributes = $attribute != $primaryAttribute
+ ? [$attribute, $primaryAttribute] : [$attribute];
+
+ foreach ($expectedAttributes as $name) {
+ // The developer may dynamically specify the array of custom attributes on this
+ // validator instance. If the attribute exists in this array it is used over
+ // the other ways of pulling the attribute name for this given attributes.
+ if (isset($this->customAttributes[$name])) {
+ return $this->customAttributes[$name];
+ }
+
+ // We allow for a developer to specify language lines for any attribute in this
+ // application, which allows flexibility for displaying a unique displayable
+ // version of the attribute name instead of the name used in an HTTP POST.
+ if ($line = $this->getAttributeFromTranslations($name)) {
+ return $line;
+ }
+ }
+
+ // When no language line has been specified for the attribute and it is also
+ // an implicit attribute we will display the raw attribute's name and not
+ // modify it with any of these replacements before we display the name.
+ if (isset($this->implicitAttributes[$primaryAttribute])) {
+ return $attribute;
+ }
+
+ return str_replace('_', ' ', Str::snake($attribute));
+ }
+
+ /**
+ * Get the given attribute from the attribute translations.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function getAttributeFromTranslations($name)
+ {
+ return Arr::get($this->translator->trans('validation.attributes'), $name);
+ }
+
+ /**
+ * Replace the :attribute placeholder in the given message.
+ *
+ * @param string $message
+ * @param string $value
+ * @return string
+ */
+ protected function replaceAttributePlaceholder($message, $value)
+ {
+ return str_replace(
+ [':attribute', ':ATTRIBUTE', ':Attribute'],
+ [$value, Str::upper($value), Str::ucfirst($value)],
+ $message
+ );
+ }
+
+ /**
+ * Get the displayable name of the value.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return string
+ */
+ public function getDisplayableValue($attribute, $value)
+ {
+ if (isset($this->customValues[$attribute][$value])) {
+ return $this->customValues[$attribute][$value];
+ }
+
+ $key = "validation.values.{$attribute}.{$value}";
+
+ if (($line = $this->translator->trans($key)) !== $key) {
+ return $line;
+ }
+
+ return $value;
+ }
+
+ /**
+ * Transform an array of attributes to their displayable form.
+ *
+ * @param array $values
+ * @return array
+ */
+ protected function getAttributeList(array $values)
+ {
+ $attributes = [];
+
+ // For each attribute in the list we will simply get its displayable form as
+ // this is convenient when replacing lists of parameters like some of the
+ // replacement functions do when formatting out the validation message.
+ foreach ($values as $key => $value) {
+ $attributes[$key] = $this->getDisplayableAttribute($value);
+ }
+
+ return $attributes;
+ }
+
+ /**
+ * Call a custom validator message replacer.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @param \Illuminate\Validation\Validator $validator
+ * @return string|null
+ */
+ protected function callReplacer($message, $attribute, $rule, $parameters, $validator)
+ {
+ $callback = $this->replacers[$rule];
+
+ if ($callback instanceof Closure) {
+ return call_user_func_array($callback, func_get_args());
+ } elseif (is_string($callback)) {
+ return $this->callClassBasedReplacer($callback, $message, $attribute, $rule, $parameters, $validator);
+ }
+ }
+
+ /**
+ * Call a class based validator message replacer.
+ *
+ * @param string $callback
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @param \Illuminate\Validation\Validator $validator
+ * @return string
+ */
+ protected function callClassBasedReplacer($callback, $message, $attribute, $rule, $parameters, $validator)
+ {
+ list($class, $method) = Str::parseCallback($callback, 'replace');
+
+ return call_user_func_array([$this->container->make($class), $method], array_slice(func_get_args(), 1));
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/Concerns/ReplacesAttributes.php b/vendor/laravel/framework/src/Illuminate/Validation/Concerns/ReplacesAttributes.php
new file mode 100644
index 000000000..ed108768a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/Concerns/ReplacesAttributes.php
@@ -0,0 +1,380 @@
+replaceSame($message, $attribute, $rule, $parameters);
+ }
+
+ /**
+ * Replace all place-holders for the digits rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceDigits($message, $attribute, $rule, $parameters)
+ {
+ return str_replace(':digits', $parameters[0], $message);
+ }
+
+ /**
+ * Replace all place-holders for the digits (between) rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceDigitsBetween($message, $attribute, $rule, $parameters)
+ {
+ return $this->replaceBetween($message, $attribute, $rule, $parameters);
+ }
+
+ /**
+ * Replace all place-holders for the min rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceMin($message, $attribute, $rule, $parameters)
+ {
+ return str_replace(':min', $parameters[0], $message);
+ }
+
+ /**
+ * Replace all place-holders for the max rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceMax($message, $attribute, $rule, $parameters)
+ {
+ return str_replace(':max', $parameters[0], $message);
+ }
+
+ /**
+ * Replace all place-holders for the in rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceIn($message, $attribute, $rule, $parameters)
+ {
+ foreach ($parameters as &$parameter) {
+ $parameter = $this->getDisplayableValue($attribute, $parameter);
+ }
+
+ return str_replace(':values', implode(', ', $parameters), $message);
+ }
+
+ /**
+ * Replace all place-holders for the not_in rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceNotIn($message, $attribute, $rule, $parameters)
+ {
+ return $this->replaceIn($message, $attribute, $rule, $parameters);
+ }
+
+ /**
+ * Replace all place-holders for the in_array rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceInArray($message, $attribute, $rule, $parameters)
+ {
+ return str_replace(':other', $this->getDisplayableAttribute($parameters[0]), $message);
+ }
+
+ /**
+ * Replace all place-holders for the mimetypes rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceMimetypes($message, $attribute, $rule, $parameters)
+ {
+ return str_replace(':values', implode(', ', $parameters), $message);
+ }
+
+ /**
+ * Replace all place-holders for the mimes rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceMimes($message, $attribute, $rule, $parameters)
+ {
+ return str_replace(':values', implode(', ', $parameters), $message);
+ }
+
+ /**
+ * Replace all place-holders for the required_with rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceRequiredWith($message, $attribute, $rule, $parameters)
+ {
+ return str_replace(':values', implode(' / ', $this->getAttributeList($parameters)), $message);
+ }
+
+ /**
+ * Replace all place-holders for the required_with_all rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceRequiredWithAll($message, $attribute, $rule, $parameters)
+ {
+ return $this->replaceRequiredWith($message, $attribute, $rule, $parameters);
+ }
+
+ /**
+ * Replace all place-holders for the required_without rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceRequiredWithout($message, $attribute, $rule, $parameters)
+ {
+ return $this->replaceRequiredWith($message, $attribute, $rule, $parameters);
+ }
+
+ /**
+ * Replace all place-holders for the required_without_all rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceRequiredWithoutAll($message, $attribute, $rule, $parameters)
+ {
+ return $this->replaceRequiredWith($message, $attribute, $rule, $parameters);
+ }
+
+ /**
+ * Replace all place-holders for the size rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceSize($message, $attribute, $rule, $parameters)
+ {
+ return str_replace(':size', $parameters[0], $message);
+ }
+
+ /**
+ * Replace all place-holders for the required_if rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceRequiredIf($message, $attribute, $rule, $parameters)
+ {
+ $parameters[1] = $this->getDisplayableValue($parameters[0], Arr::get($this->data, $parameters[0]));
+
+ $parameters[0] = $this->getDisplayableAttribute($parameters[0]);
+
+ return str_replace([':other', ':value'], $parameters, $message);
+ }
+
+ /**
+ * Replace all place-holders for the required_unless rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceRequiredUnless($message, $attribute, $rule, $parameters)
+ {
+ $other = $this->getDisplayableAttribute(array_shift($parameters));
+
+ return str_replace([':other', ':values'], [$other, implode(', ', $parameters)], $message);
+ }
+
+ /**
+ * Replace all place-holders for the same rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceSame($message, $attribute, $rule, $parameters)
+ {
+ return str_replace(':other', $this->getDisplayableAttribute($parameters[0]), $message);
+ }
+
+ /**
+ * Replace all place-holders for the before rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceBefore($message, $attribute, $rule, $parameters)
+ {
+ if (! (strtotime($parameters[0]))) {
+ return str_replace(':date', $this->getDisplayableAttribute($parameters[0]), $message);
+ }
+
+ return str_replace(':date', $parameters[0], $message);
+ }
+
+ /**
+ * Replace all place-holders for the before_or_equal rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceBeforeOrEqual($message, $attribute, $rule, $parameters)
+ {
+ return $this->replaceBefore($message, $attribute, $rule, $parameters);
+ }
+
+ /**
+ * Replace all place-holders for the after rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceAfter($message, $attribute, $rule, $parameters)
+ {
+ return $this->replaceBefore($message, $attribute, $rule, $parameters);
+ }
+
+ /**
+ * Replace all place-holders for the after_or_equal rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceAfterOrEqual($message, $attribute, $rule, $parameters)
+ {
+ return $this->replaceBefore($message, $attribute, $rule, $parameters);
+ }
+
+ /**
+ * Replace all place-holders for the dimensions rule.
+ *
+ * @param string $message
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return string
+ */
+ protected function replaceDimensions($message, $attribute, $rule, $parameters)
+ {
+ $parameters = $this->parseNamedParameters($parameters);
+
+ if (is_array($parameters)) {
+ foreach ($parameters as $key => $value) {
+ $message = str_replace(':'.$key, $value, $message);
+ }
+ }
+
+ return $message;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/Concerns/ValidatesAttributes.php b/vendor/laravel/framework/src/Illuminate/Validation/Concerns/ValidatesAttributes.php
new file mode 100644
index 000000000..ff0429a87
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/Concerns/ValidatesAttributes.php
@@ -0,0 +1,1457 @@
+validateRequired($attribute, $value) && in_array($value, $acceptable, true);
+ }
+
+ /**
+ * Validate that an attribute is an active URL.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateActiveUrl($attribute, $value)
+ {
+ if (! is_string($value)) {
+ return false;
+ }
+
+ if ($url = parse_url($value, PHP_URL_HOST)) {
+ try {
+ return count(dns_get_record($url, DNS_A | DNS_AAAA)) > 0;
+ } catch (Exception $e) {
+ return false;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * "Break" on first validation fail.
+ *
+ * Always returns true, just lets us put "bail" in rules.
+ *
+ * @return bool
+ */
+ protected function validateBail()
+ {
+ return true;
+ }
+
+ /**
+ * Validate the date is before a given date.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateBefore($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'before');
+
+ return $this->compareDates($attribute, $value, $parameters, '<');
+ }
+
+ /**
+ * Validate the date is before or equal a given date.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateBeforeOrEqual($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'before_or_equal');
+
+ return $this->compareDates($attribute, $value, $parameters, '<=');
+ }
+
+ /**
+ * Validate the date is after a given date.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateAfter($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'after');
+
+ return $this->compareDates($attribute, $value, $parameters, '>');
+ }
+
+ /**
+ * Validate the date is equal or after a given date.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateAfterOrEqual($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'after_or_equal');
+
+ return $this->compareDates($attribute, $value, $parameters, '>=');
+ }
+
+ /**
+ * Compare a given date against another using an operator.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @param string $operator
+ * @return bool
+ */
+ protected function compareDates($attribute, $value, $parameters, $operator)
+ {
+ if (! is_string($value) && ! is_numeric($value) && ! $value instanceof DateTimeInterface) {
+ return false;
+ }
+
+ if ($format = $this->getDateFormat($attribute)) {
+ return $this->checkDateTimeOrder(
+ $format, $value, $this->getValue($parameters[0]) ?: $parameters[0], $operator
+ );
+ }
+
+ if (! $date = $this->getDateTimestamp($parameters[0])) {
+ $date = $this->getDateTimestamp($this->getValue($parameters[0]));
+ }
+
+ return $this->compare($this->getDateTimestamp($value), $date, $operator);
+ }
+
+ /**
+ * Get the date format for an attribute if it has one.
+ *
+ * @param string $attribute
+ * @return string|null
+ */
+ protected function getDateFormat($attribute)
+ {
+ if ($result = $this->getRule($attribute, 'DateFormat')) {
+ return $result[1][0];
+ }
+ }
+
+ /**
+ * Get the date timestamp.
+ *
+ * @param mixed $value
+ * @return int
+ */
+ protected function getDateTimestamp($value)
+ {
+ return $value instanceof DateTimeInterface ? $value->getTimestamp() : strtotime($value);
+ }
+
+ /**
+ * Given two date/time strings, check that one is after the other.
+ *
+ * @param string $format
+ * @param string $first
+ * @param string $second
+ * @param string $operator
+ * @return bool
+ */
+ protected function checkDateTimeOrder($format, $first, $second, $operator)
+ {
+ $first = $this->getDateTimeWithOptionalFormat($format, $first);
+
+ $second = $this->getDateTimeWithOptionalFormat($format, $second);
+
+ return ($first && $second) && ($this->compare($first, $second, $operator));
+ }
+
+ /**
+ * Get a DateTime instance from a string.
+ *
+ * @param string $format
+ * @param string $value
+ * @return \DateTime|null
+ */
+ protected function getDateTimeWithOptionalFormat($format, $value)
+ {
+ if ($date = DateTime::createFromFormat($format, $value)) {
+ return $date;
+ }
+
+ try {
+ return new DateTime($value);
+ } catch (Exception $e) {
+ //
+ }
+ }
+
+ /**
+ * Validate that an attribute contains only alphabetic characters.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateAlpha($attribute, $value)
+ {
+ return is_string($value) && preg_match('/^[\pL\pM]+$/u', $value);
+ }
+
+ /**
+ * Validate that an attribute contains only alpha-numeric characters, dashes, and underscores.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateAlphaDash($attribute, $value)
+ {
+ if (! is_string($value) && ! is_numeric($value)) {
+ return false;
+ }
+
+ return preg_match('/^[\pL\pM\pN_-]+$/u', $value) > 0;
+ }
+
+ /**
+ * Validate that an attribute contains only alpha-numeric characters.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateAlphaNum($attribute, $value)
+ {
+ if (! is_string($value) && ! is_numeric($value)) {
+ return false;
+ }
+
+ return preg_match('/^[\pL\pM\pN]+$/u', $value) > 0;
+ }
+
+ /**
+ * Validate that an attribute is an array.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateArray($attribute, $value)
+ {
+ return is_array($value);
+ }
+
+ /**
+ * Validate the size of an attribute is between a set of values.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateBetween($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(2, $parameters, 'between');
+
+ $size = $this->getSize($attribute, $value);
+
+ return $size >= $parameters[0] && $size <= $parameters[1];
+ }
+
+ /**
+ * Validate that an attribute is a boolean.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateBoolean($attribute, $value)
+ {
+ $acceptable = [true, false, 0, 1, '0', '1'];
+
+ return in_array($value, $acceptable, true);
+ }
+
+ /**
+ * Validate that an attribute has a matching confirmation.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateConfirmed($attribute, $value)
+ {
+ return $this->validateSame($attribute, $value, [$attribute.'_confirmation']);
+ }
+
+ /**
+ * Validate that an attribute is a valid date.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateDate($attribute, $value)
+ {
+ if ($value instanceof DateTime) {
+ return true;
+ }
+
+ if ((! is_string($value) && ! is_numeric($value)) || strtotime($value) === false) {
+ return false;
+ }
+
+ $date = date_parse($value);
+
+ return checkdate($date['month'], $date['day'], $date['year']);
+ }
+
+ /**
+ * Validate that an attribute matches a date format.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateDateFormat($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'date_format');
+
+ if (! is_string($value) && ! is_numeric($value)) {
+ return false;
+ }
+
+ $format = $parameters[0] == 'Y-m' ? '!Y-m' : $parameters[0];
+
+ $date = DateTime::createFromFormat($format, $value);
+
+ return $date && $date->format($parameters[0]) == $value;
+ }
+
+ /**
+ * Validate that an attribute is different from another attribute.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateDifferent($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'different');
+
+ foreach ($parameters as $parameter) {
+ $other = Arr::get($this->data, $parameter);
+
+ if (is_null($other) || $value === $other) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Validate that an attribute has a given number of digits.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateDigits($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'digits');
+
+ return ! preg_match('/[^0-9]/', $value)
+ && strlen((string) $value) == $parameters[0];
+ }
+
+ /**
+ * Validate that an attribute is between a given number of digits.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateDigitsBetween($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(2, $parameters, 'digits_between');
+
+ $length = strlen((string) $value);
+
+ return ! preg_match('/[^0-9]/', $value)
+ && $length >= $parameters[0] && $length <= $parameters[1];
+ }
+
+ /**
+ * Validate the dimensions of an image matches the given values.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateDimensions($attribute, $value, $parameters)
+ {
+ if (! $this->isValidFileInstance($value) || ! $sizeDetails = @getimagesize($value->getRealPath())) {
+ return false;
+ }
+
+ $this->requireParameterCount(1, $parameters, 'dimensions');
+
+ list($width, $height) = $sizeDetails;
+
+ $parameters = $this->parseNamedParameters($parameters);
+
+ if ($this->failsBasicDimensionChecks($parameters, $width, $height) ||
+ $this->failsRatioCheck($parameters, $width, $height)) {
+ return false;
+ }
+
+ return true;
+ }
+
+ /**
+ * Test if the given width and height fail any conditions.
+ *
+ * @param array $parameters
+ * @param int $width
+ * @param int $height
+ * @return bool
+ */
+ protected function failsBasicDimensionChecks($parameters, $width, $height)
+ {
+ return (isset($parameters['width']) && $parameters['width'] != $width) ||
+ (isset($parameters['min_width']) && $parameters['min_width'] > $width) ||
+ (isset($parameters['max_width']) && $parameters['max_width'] < $width) ||
+ (isset($parameters['height']) && $parameters['height'] != $height) ||
+ (isset($parameters['min_height']) && $parameters['min_height'] > $height) ||
+ (isset($parameters['max_height']) && $parameters['max_height'] < $height);
+ }
+
+ /**
+ * Determine if the given parameters fail a dimension ratio check.
+ *
+ * @param array $parameters
+ * @param int $width
+ * @param int $height
+ * @return bool
+ */
+ protected function failsRatioCheck($parameters, $width, $height)
+ {
+ if (! isset($parameters['ratio'])) {
+ return false;
+ }
+
+ list($numerator, $denominator) = array_replace(
+ [1, 1], array_filter(sscanf($parameters['ratio'], '%f/%d'))
+ );
+
+ $precision = 1 / max($width, $height);
+
+ return abs($numerator / $denominator - $width / $height) > $precision;
+ }
+
+ /**
+ * Validate an attribute is unique among other values.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateDistinct($attribute, $value, $parameters)
+ {
+ $attributeName = $this->getPrimaryAttribute($attribute);
+
+ $attributeData = ValidationData::extractDataFromPath(
+ ValidationData::getLeadingExplicitAttributePath($attributeName), $this->data
+ );
+
+ $pattern = str_replace('\*', '[^.]+', preg_quote($attributeName, '#'));
+
+ $data = Arr::where(Arr::dot($attributeData), function ($value, $key) use ($attribute, $pattern) {
+ return $key != $attribute && (bool) preg_match('#^'.$pattern.'\z#u', $key);
+ });
+
+ return ! in_array($value, array_values($data));
+ }
+
+ /**
+ * Validate that an attribute is a valid e-mail address.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateEmail($attribute, $value)
+ {
+ return filter_var($value, FILTER_VALIDATE_EMAIL) !== false;
+ }
+
+ /**
+ * Validate the existence of an attribute value in a database table.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateExists($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'exists');
+
+ list($connection, $table) = $this->parseTable($parameters[0]);
+
+ // The second parameter position holds the name of the column that should be
+ // verified as existing. If this parameter is not specified we will guess
+ // that the columns being "verified" shares the given attribute's name.
+ $column = $this->getQueryColumn($parameters, $attribute);
+
+ $expected = (is_array($value)) ? count($value) : 1;
+
+ return $this->getExistCount(
+ $connection, $table, $column, $value, $parameters
+ ) >= $expected;
+ }
+
+ /**
+ * Get the number of records that exist in storage.
+ *
+ * @param mixed $connection
+ * @param string $table
+ * @param string $column
+ * @param mixed $value
+ * @param array $parameters
+ * @return int
+ */
+ protected function getExistCount($connection, $table, $column, $value, $parameters)
+ {
+ $verifier = $this->getPresenceVerifierFor($connection);
+
+ $extra = $this->getExtraConditions(
+ array_values(array_slice($parameters, 2))
+ );
+
+ if ($this->currentRule instanceof Exists) {
+ $extra = array_merge($extra, $this->currentRule->queryCallbacks());
+ }
+
+ return is_array($value)
+ ? $verifier->getMultiCount($table, $column, $value, $extra)
+ : $verifier->getCount($table, $column, $value, null, null, $extra);
+ }
+
+ /**
+ * Validate the uniqueness of an attribute value on a given database table.
+ *
+ * If a database column is not specified, the attribute will be used.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateUnique($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'unique');
+
+ list($connection, $table) = $this->parseTable($parameters[0]);
+
+ // The second parameter position holds the name of the column that needs to
+ // be verified as unique. If this parameter isn't specified we will just
+ // assume that this column to be verified shares the attribute's name.
+ $column = $this->getQueryColumn($parameters, $attribute);
+
+ list($idColumn, $id) = [null, null];
+
+ if (isset($parameters[2])) {
+ list($idColumn, $id) = $this->getUniqueIds($parameters);
+ }
+
+ // The presence verifier is responsible for counting rows within this store
+ // mechanism which might be a relational database or any other permanent
+ // data store like Redis, etc. We will use it to determine uniqueness.
+ $verifier = $this->getPresenceVerifierFor($connection);
+
+ $extra = $this->getUniqueExtra($parameters);
+
+ if ($this->currentRule instanceof Unique) {
+ $extra = array_merge($extra, $this->currentRule->queryCallbacks());
+ }
+
+ return $verifier->getCount(
+ $table, $column, $value, $id, $idColumn, $extra
+ ) == 0;
+ }
+
+ /**
+ * Get the excluded ID column and value for the unique rule.
+ *
+ * @param array $parameters
+ * @return array
+ */
+ protected function getUniqueIds($parameters)
+ {
+ $idColumn = isset($parameters[3]) ? $parameters[3] : 'id';
+
+ return [$idColumn, $this->prepareUniqueId($parameters[2])];
+ }
+
+ /**
+ * Prepare the given ID for querying.
+ *
+ * @param mixed $id
+ * @return int
+ */
+ protected function prepareUniqueId($id)
+ {
+ if (preg_match('/\[(.*)\]/', $id, $matches)) {
+ $id = $this->getValue($matches[1]);
+ }
+
+ if (strtolower($id) == 'null') {
+ $id = null;
+ }
+
+ if (filter_var($id, FILTER_VALIDATE_INT) !== false) {
+ $id = intval($id);
+ }
+
+ return $id;
+ }
+
+ /**
+ * Get the extra conditions for a unique rule.
+ *
+ * @param array $parameters
+ * @return array
+ */
+ protected function getUniqueExtra($parameters)
+ {
+ if (isset($parameters[4])) {
+ return $this->getExtraConditions(array_slice($parameters, 4));
+ }
+
+ return [];
+ }
+
+ /**
+ * Parse the connection / table for the unique / exists rules.
+ *
+ * @param string $table
+ * @return array
+ */
+ protected function parseTable($table)
+ {
+ return Str::contains($table, '.') ? explode('.', $table, 2) : [null, $table];
+ }
+
+ /**
+ * Get the column name for an exists / unique query.
+ *
+ * @param array $parameters
+ * @param string $attribute
+ * @return bool
+ */
+ protected function getQueryColumn($parameters, $attribute)
+ {
+ return isset($parameters[1]) && $parameters[1] !== 'NULL'
+ ? $parameters[1] : $this->guessColumnForQuery($attribute);
+ }
+
+ /**
+ * Guess the database column from the given attribute name.
+ *
+ * @param string $attribute
+ * @return string
+ */
+ public function guessColumnForQuery($attribute)
+ {
+ if (in_array($attribute, array_collapse($this->implicitAttributes))
+ && ! is_numeric($last = last(explode('.', $attribute)))) {
+ return $last;
+ }
+
+ return $attribute;
+ }
+
+ /**
+ * Get the extra conditions for a unique / exists rule.
+ *
+ * @param array $segments
+ * @return array
+ */
+ protected function getExtraConditions(array $segments)
+ {
+ $extra = [];
+
+ $count = count($segments);
+
+ for ($i = 0; $i < $count; $i += 2) {
+ $extra[$segments[$i]] = $segments[$i + 1];
+ }
+
+ return $extra;
+ }
+
+ /**
+ * Validate the given value is a valid file.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateFile($attribute, $value)
+ {
+ return $this->isValidFileInstance($value);
+ }
+
+ /**
+ * Validate the given attribute is filled if it is present.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateFilled($attribute, $value)
+ {
+ if (Arr::has($this->data, $attribute)) {
+ return $this->validateRequired($attribute, $value);
+ }
+
+ return true;
+ }
+
+ /**
+ * Validate the MIME type of a file is an image MIME type.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateImage($attribute, $value)
+ {
+ return $this->validateMimes($attribute, $value, ['jpeg', 'png', 'gif', 'bmp', 'svg']);
+ }
+
+ /**
+ * Validate an attribute is contained within a list of values.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateIn($attribute, $value, $parameters)
+ {
+ if (is_array($value) && $this->hasRule($attribute, 'Array')) {
+ foreach ($value as $element) {
+ if (is_array($element)) {
+ return false;
+ }
+ }
+
+ return count(array_diff($value, $parameters)) == 0;
+ }
+
+ return ! is_array($value) && in_array((string) $value, $parameters);
+ }
+
+ /**
+ * Validate that the values of an attribute is in another attribute.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateInArray($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'in_array');
+
+ $explicitPath = ValidationData::getLeadingExplicitAttributePath($parameters[0]);
+
+ $attributeData = ValidationData::extractDataFromPath($explicitPath, $this->data);
+
+ $otherValues = Arr::where(Arr::dot($attributeData), function ($value, $key) use ($parameters) {
+ return Str::is($parameters[0], $key);
+ });
+
+ return in_array($value, $otherValues);
+ }
+
+ /**
+ * Validate that an attribute is an integer.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateInteger($attribute, $value)
+ {
+ return filter_var($value, FILTER_VALIDATE_INT) !== false;
+ }
+
+ /**
+ * Validate that an attribute is a valid IP.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateIp($attribute, $value)
+ {
+ return filter_var($value, FILTER_VALIDATE_IP) !== false;
+ }
+
+ /**
+ * Validate that an attribute is a valid IPv4.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateIpv4($attribute, $value)
+ {
+ return filter_var($value, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4) !== false;
+ }
+
+ /**
+ * Validate that an attribute is a valid IPv6.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateIpv6($attribute, $value)
+ {
+ return filter_var($value, FILTER_VALIDATE_IP, FILTER_FLAG_IPV6) !== false;
+ }
+
+ /**
+ * Validate the attribute is a valid JSON string.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateJson($attribute, $value)
+ {
+ if (! is_scalar($value) && ! method_exists($value, '__toString')) {
+ return false;
+ }
+
+ json_decode($value);
+
+ return json_last_error() === JSON_ERROR_NONE;
+ }
+
+ /**
+ * Validate the size of an attribute is less than a maximum value.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateMax($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'max');
+
+ if ($value instanceof UploadedFile && ! $value->isValid()) {
+ return false;
+ }
+
+ return $this->getSize($attribute, $value) <= $parameters[0];
+ }
+
+ /**
+ * Validate the guessed extension of a file upload is in a set of file extensions.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateMimes($attribute, $value, $parameters)
+ {
+ if (! $this->isValidFileInstance($value)) {
+ return false;
+ }
+
+ if ($this->shouldBlockPhpUpload($value, $parameters)) {
+ return false;
+ }
+
+ return $value->getPath() != '' && in_array($value->guessExtension(), $parameters);
+ }
+
+ /**
+ * Validate the MIME type of a file upload attribute is in a set of MIME types.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateMimetypes($attribute, $value, $parameters)
+ {
+ if (! $this->isValidFileInstance($value)) {
+ return false;
+ }
+
+ if ($this->shouldBlockPhpUpload($value, $parameters)) {
+ return false;
+ }
+
+ return $value->getPath() != '' &&
+ (in_array($value->getMimeType(), $parameters) ||
+ in_array(explode('/', $value->getMimeType())[0].'/*', $parameters));
+ }
+
+ /**
+ * Check if PHP uploads are explicitly allowed.
+ *
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function shouldBlockPhpUpload($value, $parameters)
+ {
+ if (in_array('php', $parameters)) {
+ return false;
+ }
+
+ return ($value instanceof UploadedFile)
+ ? strtolower($value->getClientOriginalExtension()) === 'php'
+ : strtolower($value->getExtension()) === 'php';
+ }
+
+ /**
+ * Validate the size of an attribute is greater than a minimum value.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateMin($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'min');
+
+ return $this->getSize($attribute, $value) >= $parameters[0];
+ }
+
+ /**
+ * "Indicate" validation should pass if value is null.
+ *
+ * Always returns true, just lets us put "nullable" in rules.
+ *
+ * @return bool
+ */
+ protected function validateNullable()
+ {
+ return true;
+ }
+
+ /**
+ * Validate an attribute is not contained within a list of values.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateNotIn($attribute, $value, $parameters)
+ {
+ return ! $this->validateIn($attribute, $value, $parameters);
+ }
+
+ /**
+ * Validate that an attribute is numeric.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateNumeric($attribute, $value)
+ {
+ return is_numeric($value);
+ }
+
+ /**
+ * Validate that an attribute exists even if not filled.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validatePresent($attribute, $value)
+ {
+ return Arr::has($this->data, $attribute);
+ }
+
+ /**
+ * Validate that an attribute passes a regular expression check.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateRegex($attribute, $value, $parameters)
+ {
+ if (! is_string($value) && ! is_numeric($value)) {
+ return false;
+ }
+
+ $this->requireParameterCount(1, $parameters, 'regex');
+
+ return preg_match($parameters[0], $value) > 0;
+ }
+
+ /**
+ * Validate that a required attribute exists.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateRequired($attribute, $value)
+ {
+ if (is_null($value)) {
+ return false;
+ } elseif (is_string($value) && trim($value) === '') {
+ return false;
+ } elseif ((is_array($value) || $value instanceof Countable) && count($value) < 1) {
+ return false;
+ } elseif ($value instanceof File) {
+ return (string) $value->getPath() != '';
+ }
+
+ return true;
+ }
+
+ /**
+ * Validate that an attribute exists when another attribute has a given value.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param mixed $parameters
+ * @return bool
+ */
+ protected function validateRequiredIf($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(2, $parameters, 'required_if');
+
+ $other = Arr::get($this->data, $parameters[0]);
+
+ $values = array_slice($parameters, 1);
+
+ if (is_bool($other)) {
+ $values = $this->convertValuesToBoolean($values);
+ }
+
+ if (in_array($other, $values)) {
+ return $this->validateRequired($attribute, $value);
+ }
+
+ return true;
+ }
+
+ /**
+ * Convert the given values to boolean if they are string "true" / "false".
+ *
+ * @param array $values
+ * @return array
+ */
+ protected function convertValuesToBoolean($values)
+ {
+ return array_map(function ($value) {
+ if ($value === 'true') {
+ return true;
+ } elseif ($value === 'false') {
+ return false;
+ }
+
+ return $value;
+ }, $values);
+ }
+
+ /**
+ * Validate that an attribute exists when another attribute does not have a given value.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param mixed $parameters
+ * @return bool
+ */
+ protected function validateRequiredUnless($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(2, $parameters, 'required_unless');
+
+ $data = Arr::get($this->data, $parameters[0]);
+
+ $values = array_slice($parameters, 1);
+
+ if (! in_array($data, $values)) {
+ return $this->validateRequired($attribute, $value);
+ }
+
+ return true;
+ }
+
+ /**
+ * Validate that an attribute exists when any other attribute exists.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param mixed $parameters
+ * @return bool
+ */
+ protected function validateRequiredWith($attribute, $value, $parameters)
+ {
+ if (! $this->allFailingRequired($parameters)) {
+ return $this->validateRequired($attribute, $value);
+ }
+
+ return true;
+ }
+
+ /**
+ * Validate that an attribute exists when all other attributes exists.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param mixed $parameters
+ * @return bool
+ */
+ protected function validateRequiredWithAll($attribute, $value, $parameters)
+ {
+ if (! $this->anyFailingRequired($parameters)) {
+ return $this->validateRequired($attribute, $value);
+ }
+
+ return true;
+ }
+
+ /**
+ * Validate that an attribute exists when another attribute does not.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param mixed $parameters
+ * @return bool
+ */
+ protected function validateRequiredWithout($attribute, $value, $parameters)
+ {
+ if ($this->anyFailingRequired($parameters)) {
+ return $this->validateRequired($attribute, $value);
+ }
+
+ return true;
+ }
+
+ /**
+ * Validate that an attribute exists when all other attributes do not.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param mixed $parameters
+ * @return bool
+ */
+ protected function validateRequiredWithoutAll($attribute, $value, $parameters)
+ {
+ if ($this->allFailingRequired($parameters)) {
+ return $this->validateRequired($attribute, $value);
+ }
+
+ return true;
+ }
+
+ /**
+ * Determine if any of the given attributes fail the required test.
+ *
+ * @param array $attributes
+ * @return bool
+ */
+ protected function anyFailingRequired(array $attributes)
+ {
+ foreach ($attributes as $key) {
+ if (! $this->validateRequired($key, $this->getValue($key))) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Determine if all of the given attributes fail the required test.
+ *
+ * @param array $attributes
+ * @return bool
+ */
+ protected function allFailingRequired(array $attributes)
+ {
+ foreach ($attributes as $key) {
+ if ($this->validateRequired($key, $this->getValue($key))) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Validate that two attributes match.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateSame($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'same');
+
+ $other = Arr::get($this->data, $parameters[0]);
+
+ return $value === $other;
+ }
+
+ /**
+ * Validate the size of an attribute.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @param array $parameters
+ * @return bool
+ */
+ protected function validateSize($attribute, $value, $parameters)
+ {
+ $this->requireParameterCount(1, $parameters, 'size');
+
+ return $this->getSize($attribute, $value) == $parameters[0];
+ }
+
+ /**
+ * "Validate" optional attributes.
+ *
+ * Always returns true, just lets us put sometimes in rules.
+ *
+ * @return bool
+ */
+ protected function validateSometimes()
+ {
+ return true;
+ }
+
+ /**
+ * Validate that an attribute is a string.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateString($attribute, $value)
+ {
+ return is_string($value);
+ }
+
+ /**
+ * Validate that an attribute is a valid timezone.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateTimezone($attribute, $value)
+ {
+ try {
+ new DateTimeZone($value);
+ } catch (Exception $e) {
+ return false;
+ } catch (Throwable $e) {
+ return false;
+ }
+
+ return true;
+ }
+
+ /**
+ * Validate that an attribute is a valid URL.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function validateUrl($attribute, $value)
+ {
+ if (! is_string($value)) {
+ return false;
+ }
+
+ /*
+ * This pattern is derived from Symfony\Component\Validator\Constraints\UrlValidator (2.7.4).
+ *
+ * (c) Fabien Potencier http://symfony.com
+ */
+ $pattern = '~^
+ ((aaa|aaas|about|acap|acct|acr|adiumxtra|afp|afs|aim|apt|attachment|aw|barion|beshare|bitcoin|blob|bolo|callto|cap|chrome|chrome-extension|cid|coap|coaps|com-eventbrite-attendee|content|crid|cvs|data|dav|dict|dlna-playcontainer|dlna-playsingle|dns|dntp|dtn|dvb|ed2k|example|facetime|fax|feed|feedready|file|filesystem|finger|fish|ftp|geo|gg|git|gizmoproject|go|gopher|gtalk|h323|ham|hcp|http|https|iax|icap|icon|im|imap|info|iotdisco|ipn|ipp|ipps|irc|irc6|ircs|iris|iris.beep|iris.lwz|iris.xpc|iris.xpcs|itms|jabber|jar|jms|keyparc|lastfm|ldap|ldaps|magnet|mailserver|mailto|maps|market|message|mid|mms|modem|ms-help|ms-settings|ms-settings-airplanemode|ms-settings-bluetooth|ms-settings-camera|ms-settings-cellular|ms-settings-cloudstorage|ms-settings-emailandaccounts|ms-settings-language|ms-settings-location|ms-settings-lock|ms-settings-nfctransactions|ms-settings-notifications|ms-settings-power|ms-settings-privacy|ms-settings-proximity|ms-settings-screenrotation|ms-settings-wifi|ms-settings-workplace|msnim|msrp|msrps|mtqp|mumble|mupdate|mvn|news|nfs|ni|nih|nntp|notes|oid|opaquelocktoken|pack|palm|paparazzi|pkcs11|platform|pop|pres|prospero|proxy|psyc|query|redis|rediss|reload|res|resource|rmi|rsync|rtmfp|rtmp|rtsp|rtsps|rtspu|secondlife|service|session|sftp|sgn|shttp|sieve|sip|sips|skype|smb|sms|smtp|snews|snmp|soap.beep|soap.beeps|soldat|spotify|ssh|steam|stun|stuns|submit|svn|tag|teamspeak|tel|teliaeid|telnet|tftp|things|thismessage|tip|tn3270|turn|turns|tv|udp|unreal|urn|ut2004|vemmi|ventrilo|videotex|view-source|wais|webcal|ws|wss|wtai|wyciwyg|xcon|xcon-userid|xfire|xmlrpc\.beep|xmlrpc.beeps|xmpp|xri|ymsgr|z39\.50|z39\.50r|z39\.50s)):// # protocol
+ (([\pL\pN-]+:)?([\pL\pN-]+)@)? # basic auth
+ (
+ ([\pL\pN\pS-\.])+(\.?([\pL]|xn\-\-[\pL\pN-]+)+\.?) # a domain name
+ | # or
+ \d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3} # an IP address
+ | # or
+ \[
+ (?:(?:(?:(?:(?:(?:(?:[0-9a-f]{1,4})):){6})(?:(?:(?:(?:(?:[0-9a-f]{1,4})):(?:(?:[0-9a-f]{1,4})))|(?:(?:(?:(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9]))\.){3}(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9])))))))|(?:(?:::(?:(?:(?:[0-9a-f]{1,4})):){5})(?:(?:(?:(?:(?:[0-9a-f]{1,4})):(?:(?:[0-9a-f]{1,4})))|(?:(?:(?:(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9]))\.){3}(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9])))))))|(?:(?:(?:(?:(?:[0-9a-f]{1,4})))?::(?:(?:(?:[0-9a-f]{1,4})):){4})(?:(?:(?:(?:(?:[0-9a-f]{1,4})):(?:(?:[0-9a-f]{1,4})))|(?:(?:(?:(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9]))\.){3}(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9])))))))|(?:(?:(?:(?:(?:(?:[0-9a-f]{1,4})):){0,1}(?:(?:[0-9a-f]{1,4})))?::(?:(?:(?:[0-9a-f]{1,4})):){3})(?:(?:(?:(?:(?:[0-9a-f]{1,4})):(?:(?:[0-9a-f]{1,4})))|(?:(?:(?:(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9]))\.){3}(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9])))))))|(?:(?:(?:(?:(?:(?:[0-9a-f]{1,4})):){0,2}(?:(?:[0-9a-f]{1,4})))?::(?:(?:(?:[0-9a-f]{1,4})):){2})(?:(?:(?:(?:(?:[0-9a-f]{1,4})):(?:(?:[0-9a-f]{1,4})))|(?:(?:(?:(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9]))\.){3}(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9])))))))|(?:(?:(?:(?:(?:(?:[0-9a-f]{1,4})):){0,3}(?:(?:[0-9a-f]{1,4})))?::(?:(?:[0-9a-f]{1,4})):)(?:(?:(?:(?:(?:[0-9a-f]{1,4})):(?:(?:[0-9a-f]{1,4})))|(?:(?:(?:(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9]))\.){3}(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9])))))))|(?:(?:(?:(?:(?:(?:[0-9a-f]{1,4})):){0,4}(?:(?:[0-9a-f]{1,4})))?::)(?:(?:(?:(?:(?:[0-9a-f]{1,4})):(?:(?:[0-9a-f]{1,4})))|(?:(?:(?:(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9]))\.){3}(?:(?:25[0-5]|(?:[1-9]|1[0-9]|2[0-4])?[0-9])))))))|(?:(?:(?:(?:(?:(?:[0-9a-f]{1,4})):){0,5}(?:(?:[0-9a-f]{1,4})))?::)(?:(?:[0-9a-f]{1,4})))|(?:(?:(?:(?:(?:(?:[0-9a-f]{1,4})):){0,6}(?:(?:[0-9a-f]{1,4})))?::))))
+ \] # an IPv6 address
+ )
+ (:[0-9]+)? # a port (optional)
+ (/?|/\S+|\?\S*|\#\S*) # a /, nothing, a / with something, a query or a fragment
+ $~ixu';
+
+ return preg_match($pattern, $value) > 0;
+ }
+
+ /**
+ * Get the size of an attribute.
+ *
+ * @param string $attribute
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function getSize($attribute, $value)
+ {
+ $hasNumeric = $this->hasRule($attribute, $this->numericRules);
+
+ // This method will determine if the attribute is a number, string, or file and
+ // return the proper size accordingly. If it is a number, then number itself
+ // is the size. If it is a file, we take kilobytes, and for a string the
+ // entire length of the string will be considered the attribute size.
+ if (is_numeric($value) && $hasNumeric) {
+ return $value;
+ } elseif (is_array($value)) {
+ return count($value);
+ } elseif ($value instanceof File) {
+ return $value->getSize() / 1024;
+ }
+
+ return mb_strlen($value);
+ }
+
+ /**
+ * Check that the given value is a valid file instance.
+ *
+ * @param mixed $value
+ * @return bool
+ */
+ public function isValidFileInstance($value)
+ {
+ if ($value instanceof UploadedFile && ! $value->isValid()) {
+ return false;
+ }
+
+ return $value instanceof File;
+ }
+
+ /**
+ * Determine if a comparison passes between the given values.
+ *
+ * @param mixed $first
+ * @param mixed $second
+ * @param string $operator
+ * @return bool
+ */
+ protected function compare($first, $second, $operator)
+ {
+ switch ($operator) {
+ case '<':
+ return $first < $second;
+ case '>':
+ return $first > $second;
+ case '<=':
+ return $first <= $second;
+ case '>=':
+ return $first >= $second;
+ default:
+ throw new InvalidArgumentException;
+ }
+ }
+
+ /**
+ * Parse named parameters to $key => $value items.
+ *
+ * @param array $parameters
+ * @return array
+ */
+ protected function parseNamedParameters($parameters)
+ {
+ return array_reduce($parameters, function ($result, $item) {
+ list($key, $value) = array_pad(explode('=', $item, 2), 2, null);
+
+ $result[$key] = $value;
+
+ return $result;
+ });
+ }
+
+ /**
+ * Require a certain number of parameters to be present.
+ *
+ * @param int $count
+ * @param array $parameters
+ * @param string $rule
+ * @return void
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function requireParameterCount($count, $parameters, $rule)
+ {
+ if (count($parameters) < $count) {
+ throw new InvalidArgumentException("Validation rule $rule requires at least $count parameters.");
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/DatabasePresenceVerifier.php b/vendor/laravel/framework/src/Illuminate/Validation/DatabasePresenceVerifier.php
new file mode 100644
index 000000000..b8cd7c209
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/DatabasePresenceVerifier.php
@@ -0,0 +1,138 @@
+db = $db;
+ }
+
+ /**
+ * Count the number of objects in a collection having the given value.
+ *
+ * @param string $collection
+ * @param string $column
+ * @param string $value
+ * @param int $excludeId
+ * @param string $idColumn
+ * @param array $extra
+ * @return int
+ */
+ public function getCount($collection, $column, $value, $excludeId = null, $idColumn = null, array $extra = [])
+ {
+ $query = $this->table($collection)->where($column, '=', $value);
+
+ if (! is_null($excludeId) && $excludeId != 'NULL') {
+ $query->where($idColumn ?: 'id', '<>', $excludeId);
+ }
+
+ return $this->addConditions($query, $extra)->count();
+ }
+
+ /**
+ * Count the number of objects in a collection with the given values.
+ *
+ * @param string $collection
+ * @param string $column
+ * @param array $values
+ * @param array $extra
+ * @return int
+ */
+ public function getMultiCount($collection, $column, array $values, array $extra = [])
+ {
+ $query = $this->table($collection)->whereIn($column, $values);
+
+ return $this->addConditions($query, $extra)->count();
+ }
+
+ /**
+ * Add the given conditions to the query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param array $conditions
+ * @return \Illuminate\Database\Query\Builder
+ */
+ protected function addConditions($query, $conditions)
+ {
+ foreach ($conditions as $key => $value) {
+ if ($value instanceof Closure) {
+ $query->where(function ($query) use ($value) {
+ $value($query);
+ });
+ } else {
+ $this->addWhere($query, $key, $value);
+ }
+ }
+
+ return $query;
+ }
+
+ /**
+ * Add a "where" clause to the given query.
+ *
+ * @param \Illuminate\Database\Query\Builder $query
+ * @param string $key
+ * @param string $extraValue
+ * @return void
+ */
+ protected function addWhere($query, $key, $extraValue)
+ {
+ if ($extraValue === 'NULL') {
+ $query->whereNull($key);
+ } elseif ($extraValue === 'NOT_NULL') {
+ $query->whereNotNull($key);
+ } elseif (Str::startsWith($extraValue, '!')) {
+ $query->where($key, '!=', mb_substr($extraValue, 1));
+ } else {
+ $query->where($key, $extraValue);
+ }
+ }
+
+ /**
+ * Get a query builder for the given table.
+ *
+ * @param string $table
+ * @return \Illuminate\Database\Query\Builder
+ */
+ protected function table($table)
+ {
+ return $this->db->connection($this->connection)->table($table)->useWritePdo();
+ }
+
+ /**
+ * Set the connection to be used.
+ *
+ * @param string $connection
+ * @return void
+ */
+ public function setConnection($connection)
+ {
+ $this->connection = $connection;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/Factory.php b/vendor/laravel/framework/src/Illuminate/Validation/Factory.php
new file mode 100644
index 000000000..c31ee4a4a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/Factory.php
@@ -0,0 +1,283 @@
+container = $container;
+ $this->translator = $translator;
+ }
+
+ /**
+ * Create a new Validator instance.
+ *
+ * @param array $data
+ * @param array $rules
+ * @param array $messages
+ * @param array $customAttributes
+ * @return \Illuminate\Validation\Validator
+ */
+ public function make(array $data, array $rules, array $messages = [], array $customAttributes = [])
+ {
+ // The presence verifier is responsible for checking the unique and exists data
+ // for the validator. It is behind an interface so that multiple versions of
+ // it may be written besides database. We'll inject it into the validator.
+ $validator = $this->resolve(
+ $data, $rules, $messages, $customAttributes
+ );
+
+ if (! is_null($this->verifier)) {
+ $validator->setPresenceVerifier($this->verifier);
+ }
+
+ // Next we'll set the IoC container instance of the validator, which is used to
+ // resolve out class based validator extensions. If it is not set then these
+ // types of extensions will not be possible on these validation instances.
+ if (! is_null($this->container)) {
+ $validator->setContainer($this->container);
+ }
+
+ $this->addExtensions($validator);
+
+ return $validator;
+ }
+
+ /**
+ * Validate the given data against the provided rules.
+ *
+ * @param array $data
+ * @param array $rules
+ * @param array $messages
+ * @param array $customAttributes
+ * @return void
+ *
+ * @throws \Illuminate\Validation\ValidationException
+ */
+ public function validate(array $data, array $rules, array $messages = [], array $customAttributes = [])
+ {
+ $this->make($data, $rules, $messages, $customAttributes)->validate();
+ }
+
+ /**
+ * Resolve a new Validator instance.
+ *
+ * @param array $data
+ * @param array $rules
+ * @param array $messages
+ * @param array $customAttributes
+ * @return \Illuminate\Validation\Validator
+ */
+ protected function resolve(array $data, array $rules, array $messages, array $customAttributes)
+ {
+ if (is_null($this->resolver)) {
+ return new Validator($this->translator, $data, $rules, $messages, $customAttributes);
+ }
+
+ return call_user_func($this->resolver, $this->translator, $data, $rules, $messages, $customAttributes);
+ }
+
+ /**
+ * Add the extensions to a validator instance.
+ *
+ * @param \Illuminate\Validation\Validator $validator
+ * @return void
+ */
+ protected function addExtensions(Validator $validator)
+ {
+ $validator->addExtensions($this->extensions);
+
+ // Next, we will add the implicit extensions, which are similar to the required
+ // and accepted rule in that they are run even if the attributes is not in a
+ // array of data that is given to a validator instances via instantiation.
+ $validator->addImplicitExtensions($this->implicitExtensions);
+
+ $validator->addDependentExtensions($this->dependentExtensions);
+
+ $validator->addReplacers($this->replacers);
+
+ $validator->setFallbackMessages($this->fallbackMessages);
+ }
+
+ /**
+ * Register a custom validator extension.
+ *
+ * @param string $rule
+ * @param \Closure|string $extension
+ * @param string $message
+ * @return void
+ */
+ public function extend($rule, $extension, $message = null)
+ {
+ $this->extensions[$rule] = $extension;
+
+ if ($message) {
+ $this->fallbackMessages[Str::snake($rule)] = $message;
+ }
+ }
+
+ /**
+ * Register a custom implicit validator extension.
+ *
+ * @param string $rule
+ * @param \Closure|string $extension
+ * @param string $message
+ * @return void
+ */
+ public function extendImplicit($rule, $extension, $message = null)
+ {
+ $this->implicitExtensions[$rule] = $extension;
+
+ if ($message) {
+ $this->fallbackMessages[Str::snake($rule)] = $message;
+ }
+ }
+
+ /**
+ * Register a custom dependent validator extension.
+ *
+ * @param string $rule
+ * @param \Closure|string $extension
+ * @param string $message
+ * @return void
+ */
+ public function extendDependent($rule, $extension, $message = null)
+ {
+ $this->dependentExtensions[$rule] = $extension;
+
+ if ($message) {
+ $this->fallbackMessages[Str::snake($rule)] = $message;
+ }
+ }
+
+ /**
+ * Register a custom validator message replacer.
+ *
+ * @param string $rule
+ * @param \Closure|string $replacer
+ * @return void
+ */
+ public function replacer($rule, $replacer)
+ {
+ $this->replacers[$rule] = $replacer;
+ }
+
+ /**
+ * Set the Validator instance resolver.
+ *
+ * @param \Closure $resolver
+ * @return void
+ */
+ public function resolver(Closure $resolver)
+ {
+ $this->resolver = $resolver;
+ }
+
+ /**
+ * Get the Translator implementation.
+ *
+ * @return \Illuminate\Contracts\Translation\Translator
+ */
+ public function getTranslator()
+ {
+ return $this->translator;
+ }
+
+ /**
+ * Get the Presence Verifier implementation.
+ *
+ * @return \Illuminate\Validation\PresenceVerifierInterface
+ */
+ public function getPresenceVerifier()
+ {
+ return $this->verifier;
+ }
+
+ /**
+ * Set the Presence Verifier implementation.
+ *
+ * @param \Illuminate\Validation\PresenceVerifierInterface $presenceVerifier
+ * @return void
+ */
+ public function setPresenceVerifier(PresenceVerifierInterface $presenceVerifier)
+ {
+ $this->verifier = $presenceVerifier;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/PresenceVerifierInterface.php b/vendor/laravel/framework/src/Illuminate/Validation/PresenceVerifierInterface.php
new file mode 100644
index 000000000..74496299d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/PresenceVerifierInterface.php
@@ -0,0 +1,30 @@
+constraints = $constraints;
+ }
+
+ /**
+ * Set the "width" constraint.
+ *
+ * @param int $value
+ * @return $this
+ */
+ public function width($value)
+ {
+ $this->constraints['width'] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set the "height" constraint.
+ *
+ * @param int $value
+ * @return $this
+ */
+ public function height($value)
+ {
+ $this->constraints['height'] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set the "min width" constraint.
+ *
+ * @param int $value
+ * @return $this
+ */
+ public function minWidth($value)
+ {
+ $this->constraints['min_width'] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set the "min height" constraint.
+ *
+ * @param int $value
+ * @return $this
+ */
+ public function minHeight($value)
+ {
+ $this->constraints['min_height'] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set the "max width" constraint.
+ *
+ * @param int $value
+ * @return $this
+ */
+ public function maxWidth($value)
+ {
+ $this->constraints['max_width'] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set the "max height" constraint.
+ *
+ * @param int $value
+ * @return $this
+ */
+ public function maxHeight($value)
+ {
+ $this->constraints['max_height'] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set the "ratio" constraint.
+ *
+ * @param float $value
+ * @return $this
+ */
+ public function ratio($value)
+ {
+ $this->constraints['ratio'] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Convert the rule to a validation string.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ $result = '';
+
+ foreach ($this->constraints as $key => $value) {
+ $result .= "$key=$value,";
+ }
+
+ return 'dimensions:'.substr($result, 0, -1);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/Rules/Exists.php b/vendor/laravel/framework/src/Illuminate/Validation/Rules/Exists.php
new file mode 100644
index 000000000..017043d4e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/Rules/Exists.php
@@ -0,0 +1,150 @@
+table = $table;
+ $this->column = $column;
+ }
+
+ /**
+ * Set a "where" constraint on the query.
+ *
+ * @param string $column
+ * @param string $value
+ * @return $this
+ */
+ public function where($column, $value = null)
+ {
+ if ($column instanceof Closure) {
+ return $this->using($column);
+ }
+
+ $this->wheres[] = compact('column', 'value');
+
+ return $this;
+ }
+
+ /**
+ * Set a "where not" constraint on the query.
+ *
+ * @param string $column
+ * @param string $value
+ * @return $this
+ */
+ public function whereNot($column, $value)
+ {
+ return $this->where($column, '!'.$value);
+ }
+
+ /**
+ * Set a "where null" constraint on the query.
+ *
+ * @param string $column
+ * @return $this
+ */
+ public function whereNull($column)
+ {
+ return $this->where($column, 'NULL');
+ }
+
+ /**
+ * Set a "where not null" constraint on the query.
+ *
+ * @param string $column
+ * @return $this
+ */
+ public function whereNotNull($column)
+ {
+ return $this->where($column, 'NOT_NULL');
+ }
+
+ /**
+ * Register a custom query callback.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function using(Closure $callback)
+ {
+ $this->using = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Format the where clauses.
+ *
+ * @return string
+ */
+ protected function formatWheres()
+ {
+ return collect($this->wheres)->map(function ($where) {
+ return $where['column'].','.$where['value'];
+ })->implode(',');
+ }
+
+ /**
+ * Get the custom query callbacks for the rule.
+ *
+ * @return array
+ */
+ public function queryCallbacks()
+ {
+ return $this->using ? [$this->using] : [];
+ }
+
+ /**
+ * Convert the rule to a validation string.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return rtrim(sprintf('exists:%s,%s,%s',
+ $this->table,
+ $this->column,
+ $this->formatWheres()
+ ), ',');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/Rules/In.php b/vendor/laravel/framework/src/Illuminate/Validation/Rules/In.php
new file mode 100644
index 000000000..374dd84c4
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/Rules/In.php
@@ -0,0 +1,39 @@
+values = $values;
+ }
+
+ /**
+ * Convert the rule to a validation string.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->rule.':'.implode(',', $this->values);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/Rules/NotIn.php b/vendor/laravel/framework/src/Illuminate/Validation/Rules/NotIn.php
new file mode 100644
index 000000000..ed93bc897
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/Rules/NotIn.php
@@ -0,0 +1,39 @@
+values = $values;
+ }
+
+ /**
+ * Convert the rule to a validation string.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->rule.':'.implode(',', $this->values);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/Rules/Unique.php b/vendor/laravel/framework/src/Illuminate/Validation/Rules/Unique.php
new file mode 100644
index 000000000..957966a4f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/Rules/Unique.php
@@ -0,0 +1,181 @@
+table = $table;
+ $this->column = $column;
+ }
+
+ /**
+ * Set a "where" constraint on the query.
+ *
+ * @param string $column
+ * @param string $value
+ * @return $this
+ */
+ public function where($column, $value = null)
+ {
+ if ($column instanceof Closure) {
+ return $this->using($column);
+ }
+
+ $this->wheres[] = compact('column', 'value');
+
+ return $this;
+ }
+
+ /**
+ * Set a "where not" constraint on the query.
+ *
+ * @param string $column
+ * @param string $value
+ * @return $this
+ */
+ public function whereNot($column, $value)
+ {
+ return $this->where($column, '!'.$value);
+ }
+
+ /**
+ * Set a "where null" constraint on the query.
+ *
+ * @param string $column
+ * @return $this
+ */
+ public function whereNull($column)
+ {
+ return $this->where($column, 'NULL');
+ }
+
+ /**
+ * Set a "where not null" constraint on the query.
+ *
+ * @param string $column
+ * @return $this
+ */
+ public function whereNotNull($column)
+ {
+ return $this->where($column, 'NOT_NULL');
+ }
+
+ /**
+ * Ignore the given ID during the unique check.
+ *
+ * @param mixed $id
+ * @param string $idColumn
+ * @return $this
+ */
+ public function ignore($id, $idColumn = 'id')
+ {
+ $this->ignore = $id;
+ $this->idColumn = $idColumn;
+
+ return $this;
+ }
+
+ /**
+ * Register a custom query callback.
+ *
+ * @param \Closure $callback
+ * @return $this
+ */
+ public function using(Closure $callback)
+ {
+ $this->using = $callback;
+
+ return $this;
+ }
+
+ /**
+ * Format the where clauses.
+ *
+ * @return string
+ */
+ protected function formatWheres()
+ {
+ return collect($this->wheres)->map(function ($where) {
+ return $where['column'].','.$where['value'];
+ })->implode(',');
+ }
+
+ /**
+ * Get the custom query callbacks for the rule.
+ *
+ * @return array
+ */
+ public function queryCallbacks()
+ {
+ return $this->using ? [$this->using] : [];
+ }
+
+ /**
+ * Convert the rule to a validation string.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return rtrim(sprintf('unique:%s,%s,%s,%s,%s',
+ $this->table,
+ $this->column,
+ $this->ignore ? '"'.$this->ignore.'"' : 'NULL',
+ $this->idColumn,
+ $this->formatWheres()
+ ), ',');
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/UnauthorizedException.php b/vendor/laravel/framework/src/Illuminate/Validation/UnauthorizedException.php
new file mode 100644
index 000000000..ea8a6ec0f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/UnauthorizedException.php
@@ -0,0 +1,10 @@
+prepareForValidation();
+
+ $instance = $this->getValidatorInstance();
+
+ if (! $this->passesAuthorization()) {
+ $this->failedAuthorization();
+ } elseif (! $instance->passes()) {
+ $this->failedValidation($instance);
+ }
+ }
+
+ /**
+ * Prepare the data for validation.
+ *
+ * @return void
+ */
+ protected function prepareForValidation()
+ {
+ // no default action
+ }
+
+ /**
+ * Get the validator instance for the request.
+ *
+ * @return \Illuminate\Validation\Validator
+ */
+ protected function getValidatorInstance()
+ {
+ return $this->validator();
+ }
+
+ /**
+ * Handle a failed validation attempt.
+ *
+ * @param \Illuminate\Validation\Validator $validator
+ * @return void
+ *
+ * @throws \Illuminate\Validation\ValidationException
+ */
+ protected function failedValidation(Validator $validator)
+ {
+ throw new ValidationException($validator);
+ }
+
+ /**
+ * Determine if the request passes the authorization check.
+ *
+ * @return bool
+ */
+ protected function passesAuthorization()
+ {
+ if (method_exists($this, 'authorize')) {
+ return $this->authorize();
+ }
+
+ return true;
+ }
+
+ /**
+ * Handle a failed authorization attempt.
+ *
+ * @return void
+ *
+ * @throws \Illuminate\Validation\UnauthorizedException
+ */
+ protected function failedAuthorization()
+ {
+ throw new UnauthorizedException;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/ValidationData.php b/vendor/laravel/framework/src/Illuminate/Validation/ValidationData.php
new file mode 100644
index 000000000..438858a0e
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/ValidationData.php
@@ -0,0 +1,106 @@
+ $value) {
+ if ((bool) preg_match('/^'.$pattern.'/', $key, $matches)) {
+ $keys[] = $matches[0];
+ }
+ }
+
+ $keys = array_unique($keys);
+
+ $data = [];
+
+ foreach ($keys as $key) {
+ $data[$key] = array_get($masterData, $key);
+ }
+
+ return $data;
+ }
+
+ /**
+ * Extract data based on the given dot-notated path.
+ *
+ * Used to extract a sub-section of the data for faster iteration.
+ *
+ * @param string $attribute
+ * @param array $masterData
+ * @return array
+ */
+ public static function extractDataFromPath($attribute, $masterData)
+ {
+ $results = [];
+
+ $value = Arr::get($masterData, $attribute, '__missing__');
+
+ if ($value != '__missing__') {
+ Arr::set($results, $attribute, $value);
+ }
+
+ return $results;
+ }
+
+ /**
+ * Get the explicit part of the attribute name.
+ *
+ * E.g. 'foo.bar.*.baz' -> 'foo.bar'
+ *
+ * Allows us to not spin through all of the flattened data for some operations.
+ *
+ * @param string $attribute
+ * @return string
+ */
+ public static function getLeadingExplicitAttributePath($attribute)
+ {
+ return rtrim(explode('*', $attribute)[0], '.') ?: null;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/ValidationException.php b/vendor/laravel/framework/src/Illuminate/Validation/ValidationException.php
new file mode 100644
index 000000000..03b6226e7
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/ValidationException.php
@@ -0,0 +1,47 @@
+response = $response;
+ $this->validator = $validator;
+ }
+
+ /**
+ * Get the underlying response instance.
+ *
+ * @return \Symfony\Component\HttpFoundation\Response|null
+ */
+ public function getResponse()
+ {
+ return $this->response;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/ValidationRuleParser.php b/vendor/laravel/framework/src/Illuminate/Validation/ValidationRuleParser.php
new file mode 100644
index 000000000..73e1a519c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/ValidationRuleParser.php
@@ -0,0 +1,264 @@
+data = $data;
+ }
+
+ /**
+ * Parse the human-friendly rules into a full rules array for the validator.
+ *
+ * @param array $rules
+ * @return \stdClass
+ */
+ public function explode($rules)
+ {
+ $this->implicitAttributes = [];
+
+ $rules = $this->explodeRules($rules);
+
+ return (object) [
+ 'rules' => $rules,
+ 'implicitAttributes' => $this->implicitAttributes,
+ ];
+ }
+
+ /**
+ * Explode the rules into an array of explicit rules.
+ *
+ * @param array $rules
+ * @return array
+ */
+ protected function explodeRules($rules)
+ {
+ foreach ($rules as $key => $rule) {
+ if (Str::contains($key, '*')) {
+ $rules = $this->explodeWildcardRules($rules, $key, [$rule]);
+
+ unset($rules[$key]);
+ } else {
+ $rules[$key] = $this->explodeExplicitRule($rule);
+ }
+ }
+
+ return $rules;
+ }
+
+ /**
+ * Explode the explicit rule into an array if necessary.
+ *
+ * @param mixed $rule
+ * @return array
+ */
+ protected function explodeExplicitRule($rule)
+ {
+ if (is_string($rule)) {
+ return explode('|', $rule);
+ } elseif (is_object($rule)) {
+ return [$this->prepareRule($rule)];
+ } else {
+ return array_map([$this, 'prepareRule'], $rule);
+ }
+ }
+
+ /**
+ * Prepare the given rule for the Validator.
+ *
+ * @param mixed $rule
+ * @return mixed
+ */
+ protected function prepareRule($rule)
+ {
+ if (! is_object($rule) ||
+ ($rule instanceof Exists && $rule->queryCallbacks()) ||
+ ($rule instanceof Unique && $rule->queryCallbacks())) {
+ return $rule;
+ }
+
+ return strval($rule);
+ }
+
+ /**
+ * Define a set of rules that apply to each element in an array attribute.
+ *
+ * @param array $results
+ * @param string $attribute
+ * @param string|array $rules
+ * @return array
+ */
+ protected function explodeWildcardRules($results, $attribute, $rules)
+ {
+ $pattern = str_replace('\*', '[^\.]*', preg_quote($attribute));
+
+ $data = ValidationData::initializeAndGatherData($attribute, $this->data);
+
+ foreach ($data as $key => $value) {
+ if (Str::startsWith($key, $attribute) || (bool) preg_match('/^'.$pattern.'\z/', $key)) {
+ foreach ((array) $rules as $rule) {
+ $this->implicitAttributes[$attribute][] = $key;
+
+ $results = $this->mergeRules($results, $key, $rule);
+ }
+ }
+ }
+
+ return $results;
+ }
+
+ /**
+ * Merge additional rules into a given attribute(s).
+ *
+ * @param array $results
+ * @param string|array $attribute
+ * @param string|array $rules
+ * @return array
+ */
+ public function mergeRules($results, $attribute, $rules = [])
+ {
+ if (is_array($attribute)) {
+ foreach ((array) $attribute as $innerAttribute => $innerRules) {
+ $results = $this->mergeRulesForAttribute($results, $innerAttribute, $innerRules);
+ }
+
+ return $results;
+ }
+
+ return $this->mergeRulesForAttribute(
+ $results, $attribute, $rules
+ );
+ }
+
+ /**
+ * Merge additional rules into a given attribute.
+ *
+ * @param array $results
+ * @param string $attribute
+ * @param string|array $rules
+ * @return array
+ */
+ protected function mergeRulesForAttribute($results, $attribute, $rules)
+ {
+ $merge = head($this->explodeRules([$rules]));
+
+ $results[$attribute] = array_merge(
+ isset($results[$attribute]) ? $this->explodeExplicitRule($results[$attribute]) : [], $merge
+ );
+
+ return $results;
+ }
+
+ /**
+ * Extract the rule name and parameters from a rule.
+ *
+ * @param array|string $rules
+ * @return array
+ */
+ public static function parse($rules)
+ {
+ if (is_array($rules)) {
+ $rules = static::parseArrayRule($rules);
+ } else {
+ $rules = static::parseStringRule($rules);
+ }
+
+ $rules[0] = static::normalizeRule($rules[0]);
+
+ return $rules;
+ }
+
+ /**
+ * Parse an array based rule.
+ *
+ * @param array $rules
+ * @return array
+ */
+ protected static function parseArrayRule(array $rules)
+ {
+ return [Str::studly(trim(Arr::get($rules, 0))), array_slice($rules, 1)];
+ }
+
+ /**
+ * Parse a string based rule.
+ *
+ * @param string $rules
+ * @return array
+ */
+ protected static function parseStringRule($rules)
+ {
+ $parameters = [];
+
+ // The format for specifying validation rules and parameters follows an
+ // easy {rule}:{parameters} formatting convention. For instance the
+ // rule "Max:3" states that the value may only be three letters.
+ if (strpos($rules, ':') !== false) {
+ list($rules, $parameter) = explode(':', $rules, 2);
+
+ $parameters = static::parseParameters($rules, $parameter);
+ }
+
+ return [Str::studly(trim($rules)), $parameters];
+ }
+
+ /**
+ * Parse a parameter list.
+ *
+ * @param string $rule
+ * @param string $parameter
+ * @return array
+ */
+ protected static function parseParameters($rule, $parameter)
+ {
+ if (strtolower($rule) == 'regex') {
+ return [$parameter];
+ }
+
+ return str_getcsv($parameter);
+ }
+
+ /**
+ * Normalizes a rule so that we can accept short types.
+ *
+ * @param string $rule
+ * @return string
+ */
+ protected static function normalizeRule($rule)
+ {
+ switch ($rule) {
+ case 'Int':
+ return 'Integer';
+ case 'Bool':
+ return 'Boolean';
+ default:
+ return $rule;
+ }
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/ValidationServiceProvider.php b/vendor/laravel/framework/src/Illuminate/Validation/ValidationServiceProvider.php
new file mode 100644
index 000000000..a3c593f9a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/ValidationServiceProvider.php
@@ -0,0 +1,72 @@
+registerPresenceVerifier();
+
+ $this->registerValidationFactory();
+ }
+
+ /**
+ * Register the validation factory.
+ *
+ * @return void
+ */
+ protected function registerValidationFactory()
+ {
+ $this->app->singleton('validator', function ($app) {
+ $validator = new Factory($app['translator'], $app);
+
+ // The validation presence verifier is responsible for determining the existence of
+ // values in a given data collection which is typically a relational database or
+ // other persistent data stores. It is used to check for "uniqueness" as well.
+ if (isset($app['db'], $app['validation.presence'])) {
+ $validator->setPresenceVerifier($app['validation.presence']);
+ }
+
+ return $validator;
+ });
+ }
+
+ /**
+ * Register the database presence verifier.
+ *
+ * @return void
+ */
+ protected function registerPresenceVerifier()
+ {
+ $this->app->singleton('validation.presence', function ($app) {
+ return new DatabasePresenceVerifier($app['db']);
+ });
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return [
+ 'validator', 'validation.presence',
+ ];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/Validator.php b/vendor/laravel/framework/src/Illuminate/Validation/Validator.php
new file mode 100644
index 000000000..dfcedc70d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/Validator.php
@@ -0,0 +1,1112 @@
+initialRules = $rules;
+ $this->translator = $translator;
+ $this->customMessages = $messages;
+ $this->data = $this->parseData($data);
+ $this->customAttributes = $customAttributes;
+
+ $this->setRules($rules);
+ }
+
+ /**
+ * Parse the data array, converting dots to ->.
+ *
+ * @param array $data
+ * @return array
+ */
+ public function parseData(array $data)
+ {
+ $newData = [];
+
+ foreach ($data as $key => $value) {
+ if (is_array($value)) {
+ $value = $this->parseData($value);
+ }
+
+ // If the data key contains a dot, we will replace it with another character
+ // sequence so it doesn't interfere with dot processing when working with
+ // array based validation rules and array_dot later in the validations.
+ if (Str::contains($key, '.')) {
+ $newData[str_replace('.', '->', $key)] = $value;
+ } else {
+ $newData[$key] = $value;
+ }
+ }
+
+ return $newData;
+ }
+
+ /**
+ * Add an after validation callback.
+ *
+ * @param callable|string $callback
+ * @return $this
+ */
+ public function after($callback)
+ {
+ $this->after[] = function () use ($callback) {
+ return call_user_func_array($callback, [$this]);
+ };
+
+ return $this;
+ }
+
+ /**
+ * Determine if the data passes the validation rules.
+ *
+ * @return bool
+ */
+ public function passes()
+ {
+ $this->messages = new MessageBag;
+
+ // We'll spin through each rule, validating the attributes attached to that
+ // rule. Any error messages will be added to the containers with each of
+ // the other error messages, returning true if we don't have messages.
+ foreach ($this->rules as $attribute => $rules) {
+ $attribute = str_replace('\.', '->', $attribute);
+
+ foreach ($rules as $rule) {
+ $this->validateAttribute($attribute, $rule);
+
+ if ($this->shouldStopValidating($attribute)) {
+ break;
+ }
+ }
+ }
+
+ // Here we will spin through all of the "after" hooks on this validator and
+ // fire them off. This gives the callbacks a chance to perform all kinds
+ // of other validation that needs to get wrapped up in this operation.
+ foreach ($this->after as $after) {
+ call_user_func($after);
+ }
+
+ return $this->messages->isEmpty();
+ }
+
+ /**
+ * Determine if the data fails the validation rules.
+ *
+ * @return bool
+ */
+ public function fails()
+ {
+ return ! $this->passes();
+ }
+
+ /**
+ * Run the validator's rules against its data.
+ *
+ * @return void
+ *
+ * @throws \Illuminate\Validation\ValidationException
+ */
+ public function validate()
+ {
+ if ($this->fails()) {
+ throw new ValidationException($this);
+ }
+ }
+
+ /**
+ * Validate a given attribute against a rule.
+ *
+ * @param string $attribute
+ * @param string $rule
+ * @return void
+ */
+ protected function validateAttribute($attribute, $rule)
+ {
+ $this->currentRule = $rule;
+
+ list($rule, $parameters) = ValidationRuleParser::parse($rule);
+
+ if ($rule == '') {
+ return;
+ }
+
+ // First we will get the correct keys for the given attribute in case the field is nested in
+ // an array. Then we determine if the given rule accepts other field names as parameters.
+ // If so, we will replace any asterisks found in the parameters with the correct keys.
+ if (($keys = $this->getExplicitKeys($attribute)) &&
+ $this->dependsOnOtherFields($rule)) {
+ $parameters = $this->replaceAsterisksInParameters($parameters, $keys);
+ }
+
+ $value = $this->getValue($attribute);
+
+ // If the attribute is a file, we will verify that the file upload was actually successful
+ // and if it wasn't we will add a failure for the attribute. Files may not successfully
+ // upload if they are too large based on PHP's settings so we will bail in this case.
+ if ($value instanceof UploadedFile && ! $value->isValid() &&
+ $this->hasRule($attribute, array_merge($this->fileRules, $this->implicitRules))
+ ) {
+ return $this->addFailure($attribute, 'uploaded', []);
+ }
+
+ // If we have made it this far we will make sure the attribute is validatable and if it is
+ // we will call the validation method with the attribute. If a method returns false the
+ // attribute is invalid and we will add a failure message for this failing attribute.
+ $validatable = $this->isValidatable($rule, $attribute, $value);
+
+ $method = "validate{$rule}";
+
+ if ($validatable && ! $this->$method($attribute, $value, $parameters, $this)) {
+ $this->addFailure($attribute, $rule, $parameters);
+ }
+ }
+
+ /**
+ * Determine if the given rule depends on other fields.
+ *
+ * @param string $rule
+ * @return bool
+ */
+ protected function dependsOnOtherFields($rule)
+ {
+ return in_array($rule, $this->dependentRules);
+ }
+
+ /**
+ * Get the explicit keys from an attribute flattened with dot notation.
+ *
+ * E.g. 'foo.1.bar.spark.baz' -> [1, 'spark'] for 'foo.*.bar.*.baz'
+ *
+ * @param string $attribute
+ * @return array
+ */
+ protected function getExplicitKeys($attribute)
+ {
+ $pattern = str_replace('\*', '([^\.]+)', preg_quote($this->getPrimaryAttribute($attribute), '/'));
+
+ if (preg_match('/^'.$pattern.'/', $attribute, $keys)) {
+ array_shift($keys);
+
+ return $keys;
+ }
+
+ return [];
+ }
+
+ /**
+ * Get the primary attribute name.
+ *
+ * For example, if "name.0" is given, "name.*" will be returned.
+ *
+ * @param string $attribute
+ * @return string
+ */
+ protected function getPrimaryAttribute($attribute)
+ {
+ foreach ($this->implicitAttributes as $unparsed => $parsed) {
+ if (in_array($attribute, $parsed)) {
+ return $unparsed;
+ }
+ }
+
+ return $attribute;
+ }
+
+ /**
+ * Replace each field parameter which has asterisks with the given keys.
+ *
+ * @param array $parameters
+ * @param array $keys
+ * @return array
+ */
+ protected function replaceAsterisksInParameters(array $parameters, array $keys)
+ {
+ return array_map(function ($field) use ($keys) {
+ return vsprintf(str_replace('*', '%s', $field), $keys);
+ }, $parameters);
+ }
+
+ /**
+ * Determine if the attribute is validatable.
+ *
+ * @param string $rule
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function isValidatable($rule, $attribute, $value)
+ {
+ return $this->presentOrRuleIsImplicit($rule, $attribute, $value) &&
+ $this->passesOptionalCheck($attribute) &&
+ $this->isNotNullIfMarkedAsNullable($rule, $attribute) &&
+ $this->hasNotFailedPreviousRuleIfPresenceRule($rule, $attribute);
+ }
+
+ /**
+ * Determine if the field is present, or the rule implies required.
+ *
+ * @param string $rule
+ * @param string $attribute
+ * @param mixed $value
+ * @return bool
+ */
+ protected function presentOrRuleIsImplicit($rule, $attribute, $value)
+ {
+ if (is_string($value) && trim($value) === '') {
+ return $this->isImplicit($rule);
+ }
+
+ return $this->validatePresent($attribute, $value) || $this->isImplicit($rule);
+ }
+
+ /**
+ * Determine if a given rule implies the attribute is required.
+ *
+ * @param string $rule
+ * @return bool
+ */
+ protected function isImplicit($rule)
+ {
+ return in_array($rule, $this->implicitRules);
+ }
+
+ /**
+ * Determine if the attribute passes any optional check.
+ *
+ * @param string $attribute
+ * @return bool
+ */
+ protected function passesOptionalCheck($attribute)
+ {
+ if (! $this->hasRule($attribute, ['Sometimes'])) {
+ return true;
+ }
+
+ $data = ValidationData::initializeAndGatherData($attribute, $this->data);
+
+ return array_key_exists($attribute, $data)
+ || in_array($attribute, array_keys($this->data));
+ }
+
+ /**
+ * Determine if the attribute fails the nullable check.
+ *
+ * @param string $rule
+ * @param string $attribute
+ * @return bool
+ */
+ protected function isNotNullIfMarkedAsNullable($rule, $attribute)
+ {
+ if (in_array($rule, $this->implicitRules) || ! $this->hasRule($attribute, ['Nullable'])) {
+ return true;
+ }
+
+ return ! is_null(Arr::get($this->data, $attribute, 0));
+ }
+
+ /**
+ * Determine if it's a necessary presence validation.
+ *
+ * This is to avoid possible database type comparison errors.
+ *
+ * @param string $rule
+ * @param string $attribute
+ * @return bool
+ */
+ protected function hasNotFailedPreviousRuleIfPresenceRule($rule, $attribute)
+ {
+ return in_array($rule, ['Unique', 'Exists']) ? ! $this->messages->has($attribute) : true;
+ }
+
+ /**
+ * Check if we should stop further validations on a given attribute.
+ *
+ * @param string $attribute
+ * @return bool
+ */
+ protected function shouldStopValidating($attribute)
+ {
+ if ($this->hasRule($attribute, ['Bail'])) {
+ return $this->messages->has($attribute);
+ }
+
+ if (isset($this->failedRules[$attribute]) &&
+ in_array('uploaded', array_keys($this->failedRules[$attribute]))) {
+ return true;
+ }
+
+ // In case the attribute has any rule that indicates that the field is required
+ // and that rule already failed then we should stop validation at this point
+ // as now there is no point in calling other rules with this field empty.
+ return $this->hasRule($attribute, $this->implicitRules) &&
+ isset($this->failedRules[$attribute]) &&
+ array_intersect(array_keys($this->failedRules[$attribute]), $this->implicitRules);
+ }
+
+ /**
+ * Add a failed rule and error message to the collection.
+ *
+ * @param string $attribute
+ * @param string $rule
+ * @param array $parameters
+ * @return void
+ */
+ protected function addFailure($attribute, $rule, $parameters)
+ {
+ $this->messages->add($attribute, $this->makeReplacements(
+ $this->getMessage($attribute, $rule), $attribute, $rule, $parameters
+ ));
+
+ $this->failedRules[$attribute][$rule] = $parameters;
+ }
+
+ /**
+ * Returns the data which was valid.
+ *
+ * @return array
+ */
+ public function valid()
+ {
+ if (! $this->messages) {
+ $this->passes();
+ }
+
+ return array_diff_key(
+ $this->data, $this->attributesThatHaveMessages()
+ );
+ }
+
+ /**
+ * Returns the data which was invalid.
+ *
+ * @return array
+ */
+ public function invalid()
+ {
+ if (! $this->messages) {
+ $this->passes();
+ }
+
+ return array_intersect_key(
+ $this->data, $this->attributesThatHaveMessages()
+ );
+ }
+
+ /**
+ * Generate an array of all attributes that have messages.
+ *
+ * @return array
+ */
+ protected function attributesThatHaveMessages()
+ {
+ return collect($this->messages()->toArray())->map(function ($message, $key) {
+ return explode('.', $key)[0];
+ })->unique()->flip()->all();
+ }
+
+ /**
+ * Get the failed validation rules.
+ *
+ * @return array
+ */
+ public function failed()
+ {
+ return $this->failedRules;
+ }
+
+ /**
+ * Get the message container for the validator.
+ *
+ * @return \Illuminate\Support\MessageBag
+ */
+ public function messages()
+ {
+ if (! $this->messages) {
+ $this->passes();
+ }
+
+ return $this->messages;
+ }
+
+ /**
+ * An alternative more semantic shortcut to the message container.
+ *
+ * @return \Illuminate\Support\MessageBag
+ */
+ public function errors()
+ {
+ return $this->messages();
+ }
+
+ /**
+ * Get the messages for the instance.
+ *
+ * @return \Illuminate\Support\MessageBag
+ */
+ public function getMessageBag()
+ {
+ return $this->messages();
+ }
+
+ /**
+ * Determine if the given attribute has a rule in the given set.
+ *
+ * @param string $attribute
+ * @param string|array $rules
+ * @return bool
+ */
+ public function hasRule($attribute, $rules)
+ {
+ return ! is_null($this->getRule($attribute, $rules));
+ }
+
+ /**
+ * Get a rule and its parameters for a given attribute.
+ *
+ * @param string $attribute
+ * @param string|array $rules
+ * @return array|null
+ */
+ protected function getRule($attribute, $rules)
+ {
+ if (! array_key_exists($attribute, $this->rules)) {
+ return;
+ }
+
+ $rules = (array) $rules;
+
+ foreach ($this->rules[$attribute] as $rule) {
+ list($rule, $parameters) = ValidationRuleParser::parse($rule);
+
+ if (in_array($rule, $rules)) {
+ return [$rule, $parameters];
+ }
+ }
+ }
+
+ /**
+ * Get the data under validation.
+ *
+ * @return array
+ */
+ public function attributes()
+ {
+ return $this->getData();
+ }
+
+ /**
+ * Get the data under validation.
+ *
+ * @return array
+ */
+ public function getData()
+ {
+ return $this->data;
+ }
+
+ /**
+ * Set the data under validation.
+ *
+ * @param array $data
+ * @return $this
+ */
+ public function setData(array $data)
+ {
+ $this->data = $this->parseData($data);
+
+ $this->setRules($this->initialRules);
+
+ return $this;
+ }
+
+ /**
+ * Get the value of a given attribute.
+ *
+ * @param string $attribute
+ * @return mixed
+ */
+ protected function getValue($attribute)
+ {
+ return Arr::get($this->data, $attribute);
+ }
+
+ /**
+ * Get the validation rules.
+ *
+ * @return array
+ */
+ public function getRules()
+ {
+ return $this->rules;
+ }
+
+ /**
+ * Set the validation rules.
+ *
+ * @param array $rules
+ * @return $this
+ */
+ public function setRules(array $rules)
+ {
+ $this->initialRules = $rules;
+
+ $this->rules = [];
+
+ $this->addRules($rules);
+
+ return $this;
+ }
+
+ /**
+ * Parse the given rules and merge them into current rules.
+ *
+ * @param array $rules
+ * @return void
+ */
+ public function addRules($rules)
+ {
+ // The primary purpose of this parser is to expand any "*" rules to the all
+ // of the explicit rules needed for the given data. For example the rule
+ // names.* would get expanded to names.0, names.1, etc. for this data.
+ $response = (new ValidationRuleParser($this->data))
+ ->explode($rules);
+
+ $this->rules = array_merge_recursive(
+ $this->rules, $response->rules
+ );
+
+ $this->implicitAttributes = array_merge(
+ $this->implicitAttributes, $response->implicitAttributes
+ );
+ }
+
+ /**
+ * Add conditions to a given field based on a Closure.
+ *
+ * @param string|array $attribute
+ * @param string|array $rules
+ * @param callable $callback
+ * @return $this
+ */
+ public function sometimes($attribute, $rules, callable $callback)
+ {
+ $payload = new Fluent($this->getData());
+
+ if (call_user_func($callback, $payload)) {
+ foreach ((array) $attribute as $key) {
+ $this->addRules([$key => $rules]);
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Register an array of custom validator extensions.
+ *
+ * @param array $extensions
+ * @return void
+ */
+ public function addExtensions(array $extensions)
+ {
+ if ($extensions) {
+ $keys = array_map('\Illuminate\Support\Str::snake', array_keys($extensions));
+
+ $extensions = array_combine($keys, array_values($extensions));
+ }
+
+ $this->extensions = array_merge($this->extensions, $extensions);
+ }
+
+ /**
+ * Register an array of custom implicit validator extensions.
+ *
+ * @param array $extensions
+ * @return void
+ */
+ public function addImplicitExtensions(array $extensions)
+ {
+ $this->addExtensions($extensions);
+
+ foreach ($extensions as $rule => $extension) {
+ $this->implicitRules[] = Str::studly($rule);
+ }
+ }
+
+ /**
+ * Register an array of custom implicit validator extensions.
+ *
+ * @param array $extensions
+ * @return void
+ */
+ public function addDependentExtensions(array $extensions)
+ {
+ $this->addExtensions($extensions);
+
+ foreach ($extensions as $rule => $extension) {
+ $this->dependentRules[] = Str::studly($rule);
+ }
+ }
+
+ /**
+ * Register a custom validator extension.
+ *
+ * @param string $rule
+ * @param \Closure|string $extension
+ * @return void
+ */
+ public function addExtension($rule, $extension)
+ {
+ $this->extensions[Str::snake($rule)] = $extension;
+ }
+
+ /**
+ * Register a custom implicit validator extension.
+ *
+ * @param string $rule
+ * @param \Closure|string $extension
+ * @return void
+ */
+ public function addImplicitExtension($rule, $extension)
+ {
+ $this->addExtension($rule, $extension);
+
+ $this->implicitRules[] = Str::studly($rule);
+ }
+
+ /**
+ * Register a custom dependent validator extension.
+ *
+ * @param string $rule
+ * @param \Closure|string $extension
+ * @return void
+ */
+ public function addDependentExtension($rule, $extension)
+ {
+ $this->addExtension($rule, $extension);
+
+ $this->dependentRules[] = Str::studly($rule);
+ }
+
+ /**
+ * Register an array of custom validator message replacers.
+ *
+ * @param array $replacers
+ * @return void
+ */
+ public function addReplacers(array $replacers)
+ {
+ if ($replacers) {
+ $keys = array_map('\Illuminate\Support\Str::snake', array_keys($replacers));
+
+ $replacers = array_combine($keys, array_values($replacers));
+ }
+
+ $this->replacers = array_merge($this->replacers, $replacers);
+ }
+
+ /**
+ * Register a custom validator message replacer.
+ *
+ * @param string $rule
+ * @param \Closure|string $replacer
+ * @return void
+ */
+ public function addReplacer($rule, $replacer)
+ {
+ $this->replacers[Str::snake($rule)] = $replacer;
+ }
+
+ /**
+ * Set the custom messages for the validator.
+ *
+ * @param array $messages
+ * @return void
+ */
+ public function setCustomMessages(array $messages)
+ {
+ $this->customMessages = array_merge($this->customMessages, $messages);
+ }
+
+ /**
+ * Set the custom attributes on the validator.
+ *
+ * @param array $attributes
+ * @return $this
+ */
+ public function setAttributeNames(array $attributes)
+ {
+ $this->customAttributes = $attributes;
+
+ return $this;
+ }
+
+ /**
+ * Add custom attributes to the validator.
+ *
+ * @param array $customAttributes
+ * @return $this
+ */
+ public function addCustomAttributes(array $customAttributes)
+ {
+ $this->customAttributes = array_merge($this->customAttributes, $customAttributes);
+
+ return $this;
+ }
+
+ /**
+ * Set the custom values on the validator.
+ *
+ * @param array $values
+ * @return $this
+ */
+ public function setValueNames(array $values)
+ {
+ $this->customValues = $values;
+
+ return $this;
+ }
+
+ /**
+ * Add the custom values for the validator.
+ *
+ * @param array $customValues
+ * @return $this
+ */
+ public function addCustomValues(array $customValues)
+ {
+ $this->customValues = array_merge($this->customValues, $customValues);
+
+ return $this;
+ }
+
+ /**
+ * Set the fallback messages for the validator.
+ *
+ * @param array $messages
+ * @return void
+ */
+ public function setFallbackMessages(array $messages)
+ {
+ $this->fallbackMessages = $messages;
+ }
+
+ /**
+ * Get the Presence Verifier implementation.
+ *
+ * @return \Illuminate\Validation\PresenceVerifierInterface
+ *
+ * @throws \RuntimeException
+ */
+ public function getPresenceVerifier()
+ {
+ if (! isset($this->presenceVerifier)) {
+ throw new RuntimeException('Presence verifier has not been set.');
+ }
+
+ return $this->presenceVerifier;
+ }
+
+ /**
+ * Get the Presence Verifier implementation.
+ *
+ * @param string $connection
+ * @return \Illuminate\Validation\PresenceVerifierInterface
+ *
+ * @throws \RuntimeException
+ */
+ protected function getPresenceVerifierFor($connection)
+ {
+ return tap($this->getPresenceVerifier(), function ($verifier) use ($connection) {
+ $verifier->setConnection($connection);
+ });
+ }
+
+ /**
+ * Set the Presence Verifier implementation.
+ *
+ * @param \Illuminate\Validation\PresenceVerifierInterface $presenceVerifier
+ * @return void
+ */
+ public function setPresenceVerifier(PresenceVerifierInterface $presenceVerifier)
+ {
+ $this->presenceVerifier = $presenceVerifier;
+ }
+
+ /**
+ * Get the Translator implementation.
+ *
+ * @return \Illuminate\Contracts\Translation\Translator
+ */
+ public function getTranslator()
+ {
+ return $this->translator;
+ }
+
+ /**
+ * Set the Translator implementation.
+ *
+ * @param \Illuminate\Contracts\Translation\Translator $translator
+ * @return void
+ */
+ public function setTranslator(Translator $translator)
+ {
+ $this->translator = $translator;
+ }
+
+ /**
+ * Set the IoC container instance.
+ *
+ * @param \Illuminate\Contracts\Container\Container $container
+ * @return void
+ */
+ public function setContainer(Container $container)
+ {
+ $this->container = $container;
+ }
+
+ /**
+ * Call a custom validator extension.
+ *
+ * @param string $rule
+ * @param array $parameters
+ * @return bool|null
+ */
+ protected function callExtension($rule, $parameters)
+ {
+ $callback = $this->extensions[$rule];
+
+ if (is_callable($callback)) {
+ return call_user_func_array($callback, $parameters);
+ } elseif (is_string($callback)) {
+ return $this->callClassBasedExtension($callback, $parameters);
+ }
+ }
+
+ /**
+ * Call a class based validator extension.
+ *
+ * @param string $callback
+ * @param array $parameters
+ * @return bool
+ */
+ protected function callClassBasedExtension($callback, $parameters)
+ {
+ list($class, $method) = Str::parseCallback($callback, 'validate');
+
+ return call_user_func_array([$this->container->make($class), $method], $parameters);
+ }
+
+ /**
+ * Handle dynamic calls to class methods.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return mixed
+ *
+ * @throws \BadMethodCallException
+ */
+ public function __call($method, $parameters)
+ {
+ $rule = Str::snake(substr($method, 8));
+
+ if (isset($this->extensions[$rule])) {
+ return $this->callExtension($rule, $parameters);
+ }
+
+ throw new BadMethodCallException("Method [$method] does not exist.");
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/Validation/composer.json b/vendor/laravel/framework/src/Illuminate/Validation/composer.json
new file mode 100644
index 000000000..497a1dbe6
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/Validation/composer.json
@@ -0,0 +1,41 @@
+{
+ "name": "illuminate/validation",
+ "description": "The Illuminate Validation package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/container": "5.4.*",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "illuminate/translation": "5.4.*",
+ "symfony/http-foundation": "~3.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\Validation\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "suggest": {
+ "illuminate/database": "Required to use the database presence verifier (5.4.*)."
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/BladeCompiler.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/BladeCompiler.php
new file mode 100644
index 000000000..e11731e8a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/BladeCompiler.php
@@ -0,0 +1,380 @@
+setPath($path);
+ }
+
+ if (! is_null($this->cachePath)) {
+ $contents = $this->compileString($this->files->get($this->getPath()));
+
+ $this->files->put($this->getCompiledPath($this->getPath()), $contents);
+ }
+ }
+
+ /**
+ * Get the path currently being compiled.
+ *
+ * @return string
+ */
+ public function getPath()
+ {
+ return $this->path;
+ }
+
+ /**
+ * Set the path currently being compiled.
+ *
+ * @param string $path
+ * @return void
+ */
+ public function setPath($path)
+ {
+ $this->path = $path;
+ }
+
+ /**
+ * Compile the given Blade template contents.
+ *
+ * @param string $value
+ * @return string
+ */
+ public function compileString($value)
+ {
+ $result = '';
+
+ if (strpos($value, '@verbatim') !== false) {
+ $value = $this->storeVerbatimBlocks($value);
+ }
+
+ $this->footer = [];
+
+ // Here we will loop through all of the tokens returned by the Zend lexer and
+ // parse each one into the corresponding valid PHP. We will then have this
+ // template as the correctly rendered PHP that can be rendered natively.
+ foreach (token_get_all($value) as $token) {
+ $result .= is_array($token) ? $this->parseToken($token) : $token;
+ }
+
+ if (! empty($this->verbatimBlocks)) {
+ $result = $this->restoreVerbatimBlocks($result);
+ }
+
+ // If there are any footer lines that need to get added to a template we will
+ // add them here at the end of the template. This gets used mainly for the
+ // template inheritance via the extends keyword that should be appended.
+ if (count($this->footer) > 0) {
+ $result = $this->addFooters($result);
+ }
+
+ return $result;
+ }
+
+ /**
+ * Store the verbatim blocks and replace them with a temporary placeholder.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function storeVerbatimBlocks($value)
+ {
+ return preg_replace_callback('/(?verbatimBlocks[] = $matches[1];
+
+ return $this->verbatimPlaceholder;
+ }, $value);
+ }
+
+ /**
+ * Replace the raw placeholders with the original code stored in the raw blocks.
+ *
+ * @param string $result
+ * @return string
+ */
+ protected function restoreVerbatimBlocks($result)
+ {
+ $result = preg_replace_callback('/'.preg_quote($this->verbatimPlaceholder).'/', function () {
+ return array_shift($this->verbatimBlocks);
+ }, $result);
+
+ $this->verbatimBlocks = [];
+
+ return $result;
+ }
+
+ /**
+ * Add the stored footers onto the given content.
+ *
+ * @param string $result
+ * @return string
+ */
+ protected function addFooters($result)
+ {
+ return ltrim($result, PHP_EOL)
+ .PHP_EOL.implode(PHP_EOL, array_reverse($this->footer));
+ }
+
+ /**
+ * Parse the tokens from the template.
+ *
+ * @param array $token
+ * @return string
+ */
+ protected function parseToken($token)
+ {
+ list($id, $content) = $token;
+
+ if ($id == T_INLINE_HTML) {
+ foreach ($this->compilers as $type) {
+ $content = $this->{"compile{$type}"}($content);
+ }
+ }
+
+ return $content;
+ }
+
+ /**
+ * Execute the user defined extensions.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function compileExtensions($value)
+ {
+ foreach ($this->extensions as $compiler) {
+ $value = call_user_func($compiler, $value, $this);
+ }
+
+ return $value;
+ }
+
+ /**
+ * Compile Blade statements that start with "@".
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function compileStatements($value)
+ {
+ return preg_replace_callback(
+ '/\B@(@?\w+(?:::\w+)?)([ \t]*)(\( ( (?>[^()]+) | (?3) )* \))?/x', function ($match) {
+ return $this->compileStatement($match);
+ }, $value
+ );
+ }
+
+ /**
+ * Compile a single Blade @ statement.
+ *
+ * @param array $match
+ * @return string
+ */
+ protected function compileStatement($match)
+ {
+ if (Str::contains($match[1], '@')) {
+ $match[0] = isset($match[3]) ? $match[1].$match[3] : $match[1];
+ } elseif (isset($this->customDirectives[$match[1]])) {
+ $match[0] = $this->callCustomDirective($match[1], Arr::get($match, 3));
+ } elseif (method_exists($this, $method = 'compile'.ucfirst($match[1]))) {
+ $match[0] = $this->$method(Arr::get($match, 3));
+ }
+
+ return isset($match[3]) ? $match[0] : $match[0].$match[2];
+ }
+
+ /**
+ * Call the given directive with the given value.
+ *
+ * @param string $name
+ * @param string|null $value
+ * @return string
+ */
+ protected function callCustomDirective($name, $value)
+ {
+ if (Str::startsWith($value, '(') && Str::endsWith($value, ')')) {
+ $value = Str::substr($value, 1, -1);
+ }
+
+ return call_user_func($this->customDirectives[$name], trim($value));
+ }
+
+ /**
+ * Strip the parentheses from the given expression.
+ *
+ * @param string $expression
+ * @return string
+ */
+ public function stripParentheses($expression)
+ {
+ if (Str::startsWith($expression, '(')) {
+ $expression = substr($expression, 1, -1);
+ }
+
+ return $expression;
+ }
+
+ /**
+ * Register a custom Blade compiler.
+ *
+ * @param callable $compiler
+ * @return void
+ */
+ public function extend(callable $compiler)
+ {
+ $this->extensions[] = $compiler;
+ }
+
+ /**
+ * Get the extensions used by the compiler.
+ *
+ * @return array
+ */
+ public function getExtensions()
+ {
+ return $this->extensions;
+ }
+
+ /**
+ * Register a handler for custom directives.
+ *
+ * @param string $name
+ * @param callable $handler
+ * @return void
+ */
+ public function directive($name, callable $handler)
+ {
+ $this->customDirectives[$name] = $handler;
+ }
+
+ /**
+ * Get the list of custom directives.
+ *
+ * @return array
+ */
+ public function getCustomDirectives()
+ {
+ return $this->customDirectives;
+ }
+
+ /**
+ * Set the echo format to be used by the compiler.
+ *
+ * @param string $format
+ * @return void
+ */
+ public function setEchoFormat($format)
+ {
+ $this->echoFormat = $format;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Compiler.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Compiler.php
new file mode 100644
index 000000000..94074192a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Compiler.php
@@ -0,0 +1,74 @@
+files = $files;
+ $this->cachePath = $cachePath;
+ }
+
+ /**
+ * Get the path to the compiled version of a view.
+ *
+ * @param string $path
+ * @return string
+ */
+ public function getCompiledPath($path)
+ {
+ return $this->cachePath.'/'.sha1($path).'.php';
+ }
+
+ /**
+ * Determine if the view at the given path is expired.
+ *
+ * @param string $path
+ * @return bool
+ */
+ public function isExpired($path)
+ {
+ $compiled = $this->getCompiledPath($path);
+
+ // If the compiled file doesn't exist we will indicate that the view is expired
+ // so that it can be re-compiled. Else, we will verify the last modification
+ // of the views is less than the modification times of the compiled views.
+ if (! $this->files->exists($compiled)) {
+ return true;
+ }
+
+ return $this->files->lastModified($path) >=
+ $this->files->lastModified($compiled);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/CompilerInterface.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/CompilerInterface.php
new file mode 100644
index 000000000..dfcb023af
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/CompilerInterface.php
@@ -0,0 +1,30 @@
+check{$expression}): ?>";
+ }
+
+ /**
+ * Compile the cannot statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileCannot($expression)
+ {
+ return "denies{$expression}): ?>";
+ }
+
+ /**
+ * Compile the else-can statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileElsecan($expression)
+ {
+ return "check{$expression}): ?>";
+ }
+
+ /**
+ * Compile the else-cannot statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileElsecannot($expression)
+ {
+ return "denies{$expression}): ?>";
+ }
+
+ /**
+ * Compile the end-can statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndcan()
+ {
+ return '';
+ }
+
+ /**
+ * Compile the end-cannot statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndcannot()
+ {
+ return '';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComments.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComments.php
new file mode 100644
index 000000000..104a9c815
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComments.php
@@ -0,0 +1,19 @@
+contentTags[0], $this->contentTags[1]);
+
+ return preg_replace($pattern, '', $value);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComponents.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComponents.php
new file mode 100644
index 000000000..af0eee7b6
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesComponents.php
@@ -0,0 +1,48 @@
+startComponent{$expression}; ?>";
+ }
+
+ /**
+ * Compile the end-component statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndComponent()
+ {
+ return 'renderComponent(); ?>';
+ }
+
+ /**
+ * Compile the slot statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileSlot($expression)
+ {
+ return "slot{$expression}; ?>";
+ }
+
+ /**
+ * Compile the end-slot statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndSlot()
+ {
+ return 'endSlot(); ?>';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesConditionals.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesConditionals.php
new file mode 100644
index 000000000..31b8fe77b
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesConditionals.php
@@ -0,0 +1,147 @@
+yieldContent{$expression}))): ?>";
+ }
+
+ /**
+ * Compile the if-auth statements into valid PHP.
+ *
+ * @param string|null $guard
+ * @return string
+ */
+ protected function compileAuth($guard = null)
+ {
+ $guard = is_null($guard) ? '()' : $guard;
+
+ return "guard{$guard}->check()): ?>";
+ }
+
+ /**
+ * Compile the end-auth statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndAuth()
+ {
+ return '';
+ }
+
+ /**
+ * Compile the if-guest statements into valid PHP.
+ *
+ * @param string|null $guard
+ * @return string
+ */
+ protected function compileGuest($guard = null)
+ {
+ $guard = is_null($guard) ? '()' : $guard;
+
+ return "guard{$guard}->guest()): ?>";
+ }
+
+ /**
+ * Compile the end-guest statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndGuest()
+ {
+ return '';
+ }
+
+ /**
+ * Compile the if statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileIf($expression)
+ {
+ return "";
+ }
+
+ /**
+ * Compile the unless statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileUnless($expression)
+ {
+ return "";
+ }
+
+ /**
+ * Compile the else-if statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileElseif($expression)
+ {
+ return "";
+ }
+
+ /**
+ * Compile the else statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileElse()
+ {
+ return '';
+ }
+
+ /**
+ * Compile the end-if statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndif()
+ {
+ return '';
+ }
+
+ /**
+ * Compile the end-unless statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndunless()
+ {
+ return '';
+ }
+
+ /**
+ * Compile the if-isset statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileIsset($expression)
+ {
+ return "";
+ }
+
+ /**
+ * Compile the end-isset statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndIsset()
+ {
+ return '';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesEchos.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesEchos.php
new file mode 100644
index 000000000..018f90b89
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesEchos.php
@@ -0,0 +1,105 @@
+getEchoMethods() as $method) {
+ $value = $this->$method($value);
+ }
+
+ return $value;
+ }
+
+ /**
+ * Get the echo methods in the proper order for compilation.
+ *
+ * @return array
+ */
+ protected function getEchoMethods()
+ {
+ return [
+ 'compileRawEchos',
+ 'compileEscapedEchos',
+ 'compileRegularEchos',
+ ];
+ }
+
+ /**
+ * Compile the "raw" echo statements.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function compileRawEchos($value)
+ {
+ $pattern = sprintf('/(@)?%s\s*(.+?)\s*%s(\r?\n)?/s', $this->rawTags[0], $this->rawTags[1]);
+
+ $callback = function ($matches) {
+ $whitespace = empty($matches[3]) ? '' : $matches[3].$matches[3];
+
+ return $matches[1] ? substr($matches[0], 1) : "compileEchoDefaults($matches[2])}; ?>{$whitespace}";
+ };
+
+ return preg_replace_callback($pattern, $callback, $value);
+ }
+
+ /**
+ * Compile the "regular" echo statements.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function compileRegularEchos($value)
+ {
+ $pattern = sprintf('/(@)?%s\s*(.+?)\s*%s(\r?\n)?/s', $this->contentTags[0], $this->contentTags[1]);
+
+ $callback = function ($matches) {
+ $whitespace = empty($matches[3]) ? '' : $matches[3].$matches[3];
+
+ $wrapped = sprintf($this->echoFormat, $this->compileEchoDefaults($matches[2]));
+
+ return $matches[1] ? substr($matches[0], 1) : "{$whitespace}";
+ };
+
+ return preg_replace_callback($pattern, $callback, $value);
+ }
+
+ /**
+ * Compile the escaped echo statements.
+ *
+ * @param string $value
+ * @return string
+ */
+ protected function compileEscapedEchos($value)
+ {
+ $pattern = sprintf('/(@)?%s\s*(.+?)\s*%s(\r?\n)?/s', $this->escapedTags[0], $this->escapedTags[1]);
+
+ $callback = function ($matches) {
+ $whitespace = empty($matches[3]) ? '' : $matches[3].$matches[3];
+
+ return $matches[1] ? $matches[0] : "compileEchoDefaults($matches[2])}); ?>{$whitespace}";
+ };
+
+ return preg_replace_callback($pattern, $callback, $value);
+ }
+
+ /**
+ * Compile the default values for the echo statement.
+ *
+ * @param string $value
+ * @return string
+ */
+ public function compileEchoDefaults($value)
+ {
+ return preg_replace('/^(?=\$)(.+?)(?:\s+or\s+)(.+?)$/si', 'isset($1) ? $1 : $2', $value);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesIncludes.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesIncludes.php
new file mode 100644
index 000000000..595f70cd7
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesIncludes.php
@@ -0,0 +1,56 @@
+renderEach{$expression}; ?>";
+ }
+
+ /**
+ * Compile the include statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileInclude($expression)
+ {
+ $expression = $this->stripParentheses($expression);
+
+ return "make({$expression}, array_except(get_defined_vars(), array('__data', '__path')))->render(); ?>";
+ }
+
+ /**
+ * Compile the include-if statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileIncludeIf($expression)
+ {
+ $expression = $this->stripParentheses($expression);
+
+ return "exists({$expression})) echo \$__env->make({$expression}, array_except(get_defined_vars(), array('__data', '__path')))->render(); ?>";
+ }
+
+ /**
+ * Compile the include-when statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileIncludeWhen($expression)
+ {
+ $expression = $this->stripParentheses($expression);
+
+ return "renderWhen($expression, array_except(get_defined_vars(), array('__data', '__path'))); ?>";
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesInjections.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesInjections.php
new file mode 100644
index 000000000..c295bcd44
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesInjections.php
@@ -0,0 +1,23 @@
+";
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLayouts.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLayouts.php
new file mode 100644
index 000000000..329a7055d
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLayouts.php
@@ -0,0 +1,116 @@
+stripParentheses($expression);
+
+ $echo = "make({$expression}, array_except(get_defined_vars(), array('__data', '__path')))->render(); ?>";
+
+ $this->footer[] = $echo;
+
+ return '';
+ }
+
+ /**
+ * Compile the section statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileSection($expression)
+ {
+ $this->lastSection = trim($expression, "()'\" ");
+
+ return "startSection{$expression}; ?>";
+ }
+
+ /**
+ * Replace the @parent directive to a placeholder.
+ *
+ * @return string
+ */
+ protected function compileParent()
+ {
+ return ViewFactory::parentPlaceholder($this->lastSection ?: '');
+ }
+
+ /**
+ * Compile the yield statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileYield($expression)
+ {
+ return "yieldContent{$expression}; ?>";
+ }
+
+ /**
+ * Compile the show statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileShow()
+ {
+ return 'yieldSection(); ?>';
+ }
+
+ /**
+ * Compile the append statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileAppend()
+ {
+ return 'appendSection(); ?>';
+ }
+
+ /**
+ * Compile the overwrite statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileOverwrite()
+ {
+ return 'stopSection(true); ?>';
+ }
+
+ /**
+ * Compile the stop statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileStop()
+ {
+ return 'stopSection(); ?>';
+ }
+
+ /**
+ * Compile the end-section statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndsection()
+ {
+ return 'stopSection(); ?>';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLoops.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLoops.php
new file mode 100644
index 000000000..9f64c4f20
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesLoops.php
@@ -0,0 +1,180 @@
+forElseCounter;
+
+ preg_match('/\( *(.*) +as *(.*)\)$/is', $expression, $matches);
+
+ $iteratee = trim($matches[1]);
+
+ $iteration = trim($matches[2]);
+
+ $initLoop = "\$__currentLoopData = {$iteratee}; \$__env->addLoop(\$__currentLoopData);";
+
+ $iterateLoop = '$__env->incrementLoopIndices(); $loop = $__env->getLastLoop();';
+
+ return "";
+ }
+
+ /**
+ * Compile the for-else-empty and empty statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileEmpty($expression)
+ {
+ if ($expression) {
+ return "";
+ }
+
+ $empty = '$__empty_'.$this->forElseCounter--;
+
+ return "popLoop(); \$loop = \$__env->getLastLoop(); if ({$empty}): ?>";
+ }
+
+ /**
+ * Compile the end-for-else statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndforelse()
+ {
+ return '';
+ }
+
+ /**
+ * Compile the end-empty statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndEmpty()
+ {
+ return '';
+ }
+
+ /**
+ * Compile the for statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileFor($expression)
+ {
+ return "";
+ }
+
+ /**
+ * Compile the for-each statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileForeach($expression)
+ {
+ preg_match('/\( *(.*) +as *(.*)\)$/is', $expression, $matches);
+
+ $iteratee = trim($matches[1]);
+
+ $iteration = trim($matches[2]);
+
+ $initLoop = "\$__currentLoopData = {$iteratee}; \$__env->addLoop(\$__currentLoopData);";
+
+ $iterateLoop = '$__env->incrementLoopIndices(); $loop = $__env->getLastLoop();';
+
+ return "";
+ }
+
+ /**
+ * Compile the break statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileBreak($expression)
+ {
+ if ($expression) {
+ preg_match('/\(\s*(-?\d+)\s*\)$/', $expression, $matches);
+
+ return $matches ? '' : "";
+ }
+
+ return '';
+ }
+
+ /**
+ * Compile the continue statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileContinue($expression)
+ {
+ if ($expression) {
+ preg_match('/\(\s*(-?\d+)\s*\)$/', $expression, $matches);
+
+ return $matches ? '' : "";
+ }
+
+ return '';
+ }
+
+ /**
+ * Compile the end-for statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndfor()
+ {
+ return '';
+ }
+
+ /**
+ * Compile the end-for-each statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndforeach()
+ {
+ return 'popLoop(); $loop = $__env->getLastLoop(); ?>';
+ }
+
+ /**
+ * Compile the while statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileWhile($expression)
+ {
+ return "";
+ }
+
+ /**
+ * Compile the end-while statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndwhile()
+ {
+ return '';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesRawPhp.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesRawPhp.php
new file mode 100644
index 000000000..b49a386e3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesRawPhp.php
@@ -0,0 +1,38 @@
+" : '';
+ }
+
+ /**
+ * Compile the unset statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileUnset($expression)
+ {
+ return "";
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesStacks.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesStacks.php
new file mode 100644
index 000000000..79a380e6c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesStacks.php
@@ -0,0 +1,59 @@
+yieldPushContent{$expression}; ?>";
+ }
+
+ /**
+ * Compile the push statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compilePush($expression)
+ {
+ return "startPush{$expression}; ?>";
+ }
+
+ /**
+ * Compile the end-push statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndpush()
+ {
+ return 'stopPush(); ?>';
+ }
+
+ /**
+ * Compile the prepend statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compilePrepend($expression)
+ {
+ return "startPrepend{$expression}; ?>";
+ }
+
+ /**
+ * Compile the end-prepend statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndprepend()
+ {
+ return 'stopPrepend(); ?>';
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesTranslations.php b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesTranslations.php
new file mode 100644
index 000000000..37c61e861
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Compilers/Concerns/CompilesTranslations.php
@@ -0,0 +1,44 @@
+startTranslation(); ?>';
+ } elseif ($expression[1] === '[') {
+ return "startTranslation{$expression}; ?>";
+ } else {
+ return "getFromJson{$expression}; ?>";
+ }
+ }
+
+ /**
+ * Compile the end-lang statements into valid PHP.
+ *
+ * @return string
+ */
+ protected function compileEndlang()
+ {
+ return 'renderTranslation(); ?>';
+ }
+
+ /**
+ * Compile the choice statements into valid PHP.
+ *
+ * @param string $expression
+ * @return string
+ */
+ protected function compileChoice($expression)
+ {
+ return "choice{$expression}; ?>";
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesComponents.php b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesComponents.php
new file mode 100644
index 000000000..d523f7e8a
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesComponents.php
@@ -0,0 +1,128 @@
+componentStack[] = $name;
+
+ $this->componentData[$this->currentComponent()] = $data;
+
+ $this->slots[$this->currentComponent()] = [];
+ }
+ }
+
+ /**
+ * Render the current component.
+ *
+ * @return string
+ */
+ public function renderComponent()
+ {
+ $name = array_pop($this->componentStack);
+
+ return $this->make($name, $this->componentData($name))->render();
+ }
+
+ /**
+ * Get the data for the given component.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function componentData($name)
+ {
+ return array_merge(
+ $this->componentData[count($this->componentStack)],
+ ['slot' => new HtmlString(trim(ob_get_clean()))],
+ $this->slots[count($this->componentStack)]
+ );
+ }
+
+ /**
+ * Start the slot rendering process.
+ *
+ * @param string $name
+ * @param string|null $content
+ * @return void
+ */
+ public function slot($name, $content = null)
+ {
+ if (count(func_get_args()) == 2) {
+ $this->slots[$this->currentComponent()][$name] = $content;
+ } else {
+ if (ob_start()) {
+ $this->slots[$this->currentComponent()][$name] = '';
+
+ $this->slotStack[$this->currentComponent()][] = $name;
+ }
+ }
+ }
+
+ /**
+ * Save the slot content for rendering.
+ *
+ * @return void
+ */
+ public function endSlot()
+ {
+ last($this->componentStack);
+
+ $currentSlot = array_pop(
+ $this->slotStack[$this->currentComponent()]
+ );
+
+ $this->slots[$this->currentComponent()]
+ [$currentSlot] = new HtmlString(trim(ob_get_clean()));
+ }
+
+ /**
+ * Get the index for the current component.
+ *
+ * @return int
+ */
+ protected function currentComponent()
+ {
+ return count($this->componentStack) - 1;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesEvents.php b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesEvents.php
new file mode 100644
index 000000000..427609e75
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesEvents.php
@@ -0,0 +1,192 @@
+addViewEvent($view, $callback, 'creating: ');
+ }
+
+ return $creators;
+ }
+
+ /**
+ * Register multiple view composers via an array.
+ *
+ * @param array $composers
+ * @return array
+ */
+ public function composers(array $composers)
+ {
+ $registered = [];
+
+ foreach ($composers as $callback => $views) {
+ $registered = array_merge($registered, $this->composer($views, $callback));
+ }
+
+ return $registered;
+ }
+
+ /**
+ * Register a view composer event.
+ *
+ * @param array|string $views
+ * @param \Closure|string $callback
+ * @return array
+ */
+ public function composer($views, $callback)
+ {
+ $composers = [];
+
+ foreach ((array) $views as $view) {
+ $composers[] = $this->addViewEvent($view, $callback, 'composing: ');
+ }
+
+ return $composers;
+ }
+
+ /**
+ * Add an event for a given view.
+ *
+ * @param string $view
+ * @param \Closure|string $callback
+ * @param string $prefix
+ * @return \Closure|null
+ */
+ protected function addViewEvent($view, $callback, $prefix = 'composing: ')
+ {
+ $view = $this->normalizeName($view);
+
+ if ($callback instanceof Closure) {
+ $this->addEventListener($prefix.$view, $callback);
+
+ return $callback;
+ } elseif (is_string($callback)) {
+ return $this->addClassEvent($view, $callback, $prefix);
+ }
+ }
+
+ /**
+ * Register a class based view composer.
+ *
+ * @param string $view
+ * @param string $class
+ * @param string $prefix
+ * @return \Closure
+ */
+ protected function addClassEvent($view, $class, $prefix)
+ {
+ $name = $prefix.$view;
+
+ // When registering a class based view "composer", we will simply resolve the
+ // classes from the application IoC container then call the compose method
+ // on the instance. This allows for convenient, testable view composers.
+ $callback = $this->buildClassEventCallback(
+ $class, $prefix
+ );
+
+ $this->addEventListener($name, $callback);
+
+ return $callback;
+ }
+
+ /**
+ * Build a class based container callback Closure.
+ *
+ * @param string $class
+ * @param string $prefix
+ * @return \Closure
+ */
+ protected function buildClassEventCallback($class, $prefix)
+ {
+ list($class, $method) = $this->parseClassEvent($class, $prefix);
+
+ // Once we have the class and method name, we can build the Closure to resolve
+ // the instance out of the IoC container and call the method on it with the
+ // given arguments that are passed to the Closure as the composer's data.
+ return function () use ($class, $method) {
+ return call_user_func_array(
+ [$this->container->make($class), $method], func_get_args()
+ );
+ };
+ }
+
+ /**
+ * Parse a class based composer name.
+ *
+ * @param string $class
+ * @param string $prefix
+ * @return array
+ */
+ protected function parseClassEvent($class, $prefix)
+ {
+ return Str::parseCallback($class, $this->classEventMethodForPrefix($prefix));
+ }
+
+ /**
+ * Determine the class event method based on the given prefix.
+ *
+ * @param string $prefix
+ * @return string
+ */
+ protected function classEventMethodForPrefix($prefix)
+ {
+ return Str::contains($prefix, 'composing') ? 'compose' : 'create';
+ }
+
+ /**
+ * Add a listener to the event dispatcher.
+ *
+ * @param string $name
+ * @param \Closure $callback
+ * @return void
+ */
+ protected function addEventListener($name, $callback)
+ {
+ if (Str::contains($name, '*')) {
+ $callback = function ($name, array $data) use ($callback) {
+ return $callback($data[0]);
+ };
+ }
+
+ $this->events->listen($name, $callback);
+ }
+
+ /**
+ * Call the composer for a given view.
+ *
+ * @param \Illuminate\Contracts\View\View $view
+ * @return void
+ */
+ public function callComposer(ViewContract $view)
+ {
+ $this->events->fire('composing: '.$view->name(), [$view]);
+ }
+
+ /**
+ * Call the creator for a given view.
+ *
+ * @param \Illuminate\Contracts\View\View $view
+ * @return void
+ */
+ public function callCreator(ViewContract $view)
+ {
+ $this->events->fire('creating: '.$view->name(), [$view]);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesLayouts.php b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesLayouts.php
new file mode 100644
index 000000000..b3b4aefe3
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesLayouts.php
@@ -0,0 +1,218 @@
+sectionStack[] = $section;
+ }
+ } else {
+ $this->extendSection($section, $content instanceof View ? $content : e($content));
+ }
+ }
+
+ /**
+ * Inject inline content into a section.
+ *
+ * @param string $section
+ * @param string $content
+ * @return void
+ */
+ public function inject($section, $content)
+ {
+ return $this->startSection($section, $content);
+ }
+
+ /**
+ * Stop injecting content into a section and return its contents.
+ *
+ * @return string
+ */
+ public function yieldSection()
+ {
+ if (empty($this->sectionStack)) {
+ return '';
+ }
+
+ return $this->yieldContent($this->stopSection());
+ }
+
+ /**
+ * Stop injecting content into a section.
+ *
+ * @param bool $overwrite
+ * @return string
+ * @throws \InvalidArgumentException
+ */
+ public function stopSection($overwrite = false)
+ {
+ if (empty($this->sectionStack)) {
+ throw new InvalidArgumentException('Cannot end a section without first starting one.');
+ }
+
+ $last = array_pop($this->sectionStack);
+
+ if ($overwrite) {
+ $this->sections[$last] = ob_get_clean();
+ } else {
+ $this->extendSection($last, ob_get_clean());
+ }
+
+ return $last;
+ }
+
+ /**
+ * Stop injecting content into a section and append it.
+ *
+ * @return string
+ * @throws \InvalidArgumentException
+ */
+ public function appendSection()
+ {
+ if (empty($this->sectionStack)) {
+ throw new InvalidArgumentException('Cannot end a section without first starting one.');
+ }
+
+ $last = array_pop($this->sectionStack);
+
+ if (isset($this->sections[$last])) {
+ $this->sections[$last] .= ob_get_clean();
+ } else {
+ $this->sections[$last] = ob_get_clean();
+ }
+
+ return $last;
+ }
+
+ /**
+ * Append content to a given section.
+ *
+ * @param string $section
+ * @param string $content
+ * @return void
+ */
+ protected function extendSection($section, $content)
+ {
+ if (isset($this->sections[$section])) {
+ $content = str_replace(static::parentPlaceholder($section), $content, $this->sections[$section]);
+ }
+
+ $this->sections[$section] = $content;
+ }
+
+ /**
+ * Get the string contents of a section.
+ *
+ * @param string $section
+ * @param string $default
+ * @return string
+ */
+ public function yieldContent($section, $default = '')
+ {
+ $sectionContent = $default instanceof View ? $default : e($default);
+
+ if (isset($this->sections[$section])) {
+ $sectionContent = $this->sections[$section];
+ }
+
+ $sectionContent = str_replace('@@parent', '--parent--holder--', $sectionContent);
+
+ return str_replace(
+ '--parent--holder--', '@parent', str_replace(static::parentPlaceholder($section), '', $sectionContent)
+ );
+ }
+
+ /**
+ * Get the parent placeholder for the current request.
+ *
+ * @param string $section
+ * @return string
+ */
+ public static function parentPlaceholder($section = '')
+ {
+ if (! isset(static::$parentPlaceholder[$section])) {
+ static::$parentPlaceholder[$section] = '##parent-placeholder-'.sha1($section).'##';
+ }
+
+ return static::$parentPlaceholder[$section];
+ }
+
+ /**
+ * Check if section exists.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function hasSection($name)
+ {
+ return array_key_exists($name, $this->sections);
+ }
+
+ /**
+ * Get the contents of a section.
+ *
+ * @param string $name
+ * @param string $default
+ * @return mixed
+ */
+ public function getSection($name, $default = null)
+ {
+ return isset($this->getSections()[$name]) ? $this->getSections()[$name] : $default;
+ }
+
+ /**
+ * Get the entire array of sections.
+ *
+ * @return array
+ */
+ public function getSections()
+ {
+ return $this->sections;
+ }
+
+ /**
+ * Flush all of the sections.
+ *
+ * @return void
+ */
+ public function flushSections()
+ {
+ $this->sections = [];
+ $this->sectionStack = [];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesLoops.php b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesLoops.php
new file mode 100644
index 000000000..305a1ccf1
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesLoops.php
@@ -0,0 +1,90 @@
+loopsStack);
+
+ $this->loopsStack[] = [
+ 'iteration' => 0,
+ 'index' => 0,
+ 'remaining' => isset($length) ? $length : null,
+ 'count' => $length,
+ 'first' => true,
+ 'last' => isset($length) ? $length == 1 : null,
+ 'depth' => count($this->loopsStack) + 1,
+ 'parent' => $parent ? (object) $parent : null,
+ ];
+ }
+
+ /**
+ * Increment the top loop's indices.
+ *
+ * @return void
+ */
+ public function incrementLoopIndices()
+ {
+ $loop = $this->loopsStack[$index = count($this->loopsStack) - 1];
+
+ $this->loopsStack[$index] = array_merge($this->loopsStack[$index], [
+ 'iteration' => $loop['iteration'] + 1,
+ 'index' => $loop['iteration'],
+ 'first' => $loop['iteration'] == 0,
+ 'remaining' => isset($loop['count']) ? $loop['remaining'] - 1 : null,
+ 'last' => isset($loop['count']) ? $loop['iteration'] == $loop['count'] - 1 : null,
+ ]);
+ }
+
+ /**
+ * Pop a loop from the top of the loop stack.
+ *
+ * @return void
+ */
+ public function popLoop()
+ {
+ array_pop($this->loopsStack);
+ }
+
+ /**
+ * Get an instance of the last loop in the stack.
+ *
+ * @return \stdClass|null
+ */
+ public function getLastLoop()
+ {
+ if ($last = Arr::last($this->loopsStack)) {
+ return (object) $last;
+ }
+ }
+
+ /**
+ * Get the entire loop stack.
+ *
+ * @return array
+ */
+ public function getLoopStack()
+ {
+ return $this->loopsStack;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesStacks.php b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesStacks.php
new file mode 100644
index 000000000..53af024fe
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesStacks.php
@@ -0,0 +1,177 @@
+pushStack[] = $section;
+ }
+ } else {
+ $this->extendPush($section, $content);
+ }
+ }
+
+ /**
+ * Stop injecting content into a push section.
+ *
+ * @return string
+ * @throws \InvalidArgumentException
+ */
+ public function stopPush()
+ {
+ if (empty($this->pushStack)) {
+ throw new InvalidArgumentException('Cannot end a push stack without first starting one.');
+ }
+
+ return tap(array_pop($this->pushStack), function ($last) {
+ $this->extendPush($last, ob_get_clean());
+ });
+ }
+
+ /**
+ * Append content to a given push section.
+ *
+ * @param string $section
+ * @param string $content
+ * @return void
+ */
+ protected function extendPush($section, $content)
+ {
+ if (! isset($this->pushes[$section])) {
+ $this->pushes[$section] = [];
+ }
+
+ if (! isset($this->pushes[$section][$this->renderCount])) {
+ $this->pushes[$section][$this->renderCount] = $content;
+ } else {
+ $this->pushes[$section][$this->renderCount] .= $content;
+ }
+ }
+
+ /**
+ * Start prepending content into a push section.
+ *
+ * @param string $section
+ * @param string $content
+ * @return void
+ */
+ public function startPrepend($section, $content = '')
+ {
+ if ($content === '') {
+ if (ob_start()) {
+ $this->pushStack[] = $section;
+ }
+ } else {
+ $this->extendPrepend($section, $content);
+ }
+ }
+
+ /**
+ * Stop prepending content into a push section.
+ *
+ * @return string
+ * @throws \InvalidArgumentException
+ */
+ public function stopPrepend()
+ {
+ if (empty($this->pushStack)) {
+ throw new InvalidArgumentException('Cannot end a prepend operation without first starting one.');
+ }
+
+ return tap(array_pop($this->pushStack), function ($last) {
+ $this->extendPrepend($last, ob_get_clean());
+ });
+ }
+
+ /**
+ * Prepend content to a given stack.
+ *
+ * @param string $section
+ * @param string $content
+ * @return void
+ */
+ protected function extendPrepend($section, $content)
+ {
+ if (! isset($this->prepends[$section])) {
+ $this->prepends[$section] = [];
+ }
+
+ if (! isset($this->prepends[$section][$this->renderCount])) {
+ $this->prepends[$section][$this->renderCount] = $content;
+ } else {
+ $this->prepends[$section][$this->renderCount] = $content.$this->prepends[$section][$this->renderCount];
+ }
+ }
+
+ /**
+ * Get the string contents of a push section.
+ *
+ * @param string $section
+ * @param string $default
+ * @return string
+ */
+ public function yieldPushContent($section, $default = '')
+ {
+ if (! isset($this->pushes[$section]) && ! isset($this->prepends[$section])) {
+ return $default;
+ }
+
+ $output = '';
+
+ if (isset($this->prepends[$section])) {
+ $output .= implode(array_reverse($this->prepends[$section]));
+ }
+
+ if (isset($this->pushes[$section])) {
+ $output .= implode($this->pushes[$section]);
+ }
+
+ return $output;
+ }
+
+ /**
+ * Flush all of the stacks.
+ *
+ * @return void
+ */
+ public function flushStacks()
+ {
+ $this->pushes = [];
+ $this->prepends = [];
+ $this->pushStack = [];
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesTranslations.php b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesTranslations.php
new file mode 100644
index 000000000..841c3fe18
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Concerns/ManagesTranslations.php
@@ -0,0 +1,38 @@
+translationReplacements = $replacements;
+ }
+
+ /**
+ * Render the current translation.
+ *
+ * @return string
+ */
+ public function renderTranslation()
+ {
+ return $this->container->make('translator')->getFromJson(
+ trim(ob_get_clean()), $this->translationReplacements
+ );
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Engines/CompilerEngine.php b/vendor/laravel/framework/src/Illuminate/View/Engines/CompilerEngine.php
new file mode 100644
index 000000000..2f7f84b17
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Engines/CompilerEngine.php
@@ -0,0 +1,102 @@
+compiler = $compiler;
+ }
+
+ /**
+ * Get the evaluated contents of the view.
+ *
+ * @param string $path
+ * @param array $data
+ * @return string
+ */
+ public function get($path, array $data = [])
+ {
+ $this->lastCompiled[] = $path;
+
+ // If this given view has expired, which means it has simply been edited since
+ // it was last compiled, we will re-compile the views so we can evaluate a
+ // fresh copy of the view. We'll pass the compiler the path of the view.
+ if ($this->compiler->isExpired($path)) {
+ $this->compiler->compile($path);
+ }
+
+ $compiled = $this->compiler->getCompiledPath($path);
+
+ // Once we have the path to the compiled file, we will evaluate the paths with
+ // typical PHP just like any other templates. We also keep a stack of views
+ // which have been rendered for right exception messages to be generated.
+ $results = $this->evaluatePath($compiled, $data);
+
+ array_pop($this->lastCompiled);
+
+ return $results;
+ }
+
+ /**
+ * Handle a view exception.
+ *
+ * @param \Exception $e
+ * @param int $obLevel
+ * @return void
+ *
+ * @throws \Exception
+ */
+ protected function handleViewException(Exception $e, $obLevel)
+ {
+ $e = new ErrorException($this->getMessage($e), 0, 1, $e->getFile(), $e->getLine(), $e);
+
+ parent::handleViewException($e, $obLevel);
+ }
+
+ /**
+ * Get the exception message for an exception.
+ *
+ * @param \Exception $e
+ * @return string
+ */
+ protected function getMessage(Exception $e)
+ {
+ return $e->getMessage().' (View: '.realpath(last($this->lastCompiled)).')';
+ }
+
+ /**
+ * Get the compiler implementation.
+ *
+ * @return \Illuminate\View\Compilers\CompilerInterface
+ */
+ public function getCompiler()
+ {
+ return $this->compiler;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Engines/Engine.php b/vendor/laravel/framework/src/Illuminate/View/Engines/Engine.php
new file mode 100644
index 000000000..bf5c748d8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Engines/Engine.php
@@ -0,0 +1,23 @@
+lastRendered;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Engines/EngineInterface.php b/vendor/laravel/framework/src/Illuminate/View/Engines/EngineInterface.php
new file mode 100644
index 000000000..a6f71d2af
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Engines/EngineInterface.php
@@ -0,0 +1,15 @@
+resolved[$engine]);
+
+ $this->resolvers[$engine] = $resolver;
+ }
+
+ /**
+ * Resolve an engine instance by name.
+ *
+ * @param string $engine
+ * @return \Illuminate\View\Engines\EngineInterface
+ * @throws \InvalidArgumentException
+ */
+ public function resolve($engine)
+ {
+ if (isset($this->resolved[$engine])) {
+ return $this->resolved[$engine];
+ }
+
+ if (isset($this->resolvers[$engine])) {
+ return $this->resolved[$engine] = call_user_func($this->resolvers[$engine]);
+ }
+
+ throw new InvalidArgumentException("Engine $engine not found.");
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Engines/FileEngine.php b/vendor/laravel/framework/src/Illuminate/View/Engines/FileEngine.php
new file mode 100644
index 000000000..e9ec85d8f
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Engines/FileEngine.php
@@ -0,0 +1,18 @@
+evaluatePath($path, $data);
+ }
+
+ /**
+ * Get the evaluated contents of the view at the given path.
+ *
+ * @param string $__path
+ * @param array $__data
+ * @return string
+ */
+ protected function evaluatePath($__path, $__data)
+ {
+ $obLevel = ob_get_level();
+
+ ob_start();
+
+ extract($__data, EXTR_SKIP);
+
+ // We'll evaluate the contents of the view inside a try/catch block so we can
+ // flush out any stray output that might get out before an error occurs or
+ // an exception is thrown. This prevents any partial views from leaking.
+ try {
+ include $__path;
+ } catch (Exception $e) {
+ $this->handleViewException($e, $obLevel);
+ } catch (Throwable $e) {
+ $this->handleViewException(new FatalThrowableError($e), $obLevel);
+ }
+
+ return ltrim(ob_get_clean());
+ }
+
+ /**
+ * Handle a view exception.
+ *
+ * @param \Exception $e
+ * @param int $obLevel
+ * @return void
+ *
+ * @throws \Exception
+ */
+ protected function handleViewException(Exception $e, $obLevel)
+ {
+ while (ob_get_level() > $obLevel) {
+ ob_end_clean();
+ }
+
+ throw $e;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Factory.php b/vendor/laravel/framework/src/Illuminate/View/Factory.php
new file mode 100644
index 000000000..238e0c679
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Factory.php
@@ -0,0 +1,542 @@
+ 'blade',
+ 'php' => 'php',
+ 'css' => 'file',
+ ];
+
+ /**
+ * The view composer events.
+ *
+ * @var array
+ */
+ protected $composers = [];
+
+ /**
+ * The number of active rendering operations.
+ *
+ * @var int
+ */
+ protected $renderCount = 0;
+
+ /**
+ * Create a new view factory instance.
+ *
+ * @param \Illuminate\View\Engines\EngineResolver $engines
+ * @param \Illuminate\View\ViewFinderInterface $finder
+ * @param \Illuminate\Contracts\Events\Dispatcher $events
+ * @return void
+ */
+ public function __construct(EngineResolver $engines, ViewFinderInterface $finder, Dispatcher $events)
+ {
+ $this->finder = $finder;
+ $this->events = $events;
+ $this->engines = $engines;
+
+ $this->share('__env', $this);
+ }
+
+ /**
+ * Get the evaluated view contents for the given view.
+ *
+ * @param string $path
+ * @param array $data
+ * @param array $mergeData
+ * @return \Illuminate\Contracts\View\View
+ */
+ public function file($path, $data = [], $mergeData = [])
+ {
+ $data = array_merge($mergeData, $this->parseData($data));
+
+ return tap($this->viewInstance($path, $path, $data), function ($view) {
+ $this->callCreator($view);
+ });
+ }
+
+ /**
+ * Get the evaluated view contents for the given view.
+ *
+ * @param string $view
+ * @param array $data
+ * @param array $mergeData
+ * @return \Illuminate\Contracts\View\View
+ */
+ public function make($view, $data = [], $mergeData = [])
+ {
+ $path = $this->finder->find(
+ $view = $this->normalizeName($view)
+ );
+
+ // Next, we will create the view instance and call the view creator for the view
+ // which can set any data, etc. Then we will return the view instance back to
+ // the caller for rendering or performing other view manipulations on this.
+ $data = array_merge($mergeData, $this->parseData($data));
+
+ return tap($this->viewInstance($view, $path, $data), function ($view) {
+ $this->callCreator($view);
+ });
+ }
+
+ /**
+ * Get the rendered content of the view based on a given condition.
+ *
+ * @param bool $condition
+ * @param string $view
+ * @param array $data
+ * @param array $mergeData
+ * @return string
+ */
+ public function renderWhen($condition, $view, $data = [], $mergeData = [])
+ {
+ if (! $condition) {
+ return '';
+ }
+
+ return $this->make($view, $this->parseData($data), $mergeData)->render();
+ }
+
+ /**
+ * Get the rendered contents of a partial from a loop.
+ *
+ * @param string $view
+ * @param array $data
+ * @param string $iterator
+ * @param string $empty
+ * @return string
+ */
+ public function renderEach($view, $data, $iterator, $empty = 'raw|')
+ {
+ $result = '';
+
+ // If is actually data in the array, we will loop through the data and append
+ // an instance of the partial view to the final result HTML passing in the
+ // iterated value of this data array, allowing the views to access them.
+ if (count($data) > 0) {
+ foreach ($data as $key => $value) {
+ $result .= $this->make(
+ $view, ['key' => $key, $iterator => $value]
+ )->render();
+ }
+ }
+
+ // If there is no data in the array, we will render the contents of the empty
+ // view. Alternatively, the "empty view" could be a raw string that begins
+ // with "raw|" for convenience and to let this know that it is a string.
+ else {
+ $result = Str::startsWith($empty, 'raw|')
+ ? substr($empty, 4)
+ : $this->make($empty)->render();
+ }
+
+ return $result;
+ }
+
+ /**
+ * Normalize a view name.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function normalizeName($name)
+ {
+ return ViewName::normalize($name);
+ }
+
+ /**
+ * Parse the given data into a raw array.
+ *
+ * @param mixed $data
+ * @return array
+ */
+ protected function parseData($data)
+ {
+ return $data instanceof Arrayable ? $data->toArray() : $data;
+ }
+
+ /**
+ * Create a new view instance from the given arguments.
+ *
+ * @param string $view
+ * @param string $path
+ * @param array $data
+ * @return \Illuminate\Contracts\View\View
+ */
+ protected function viewInstance($view, $path, $data)
+ {
+ return new View($this, $this->getEngineFromPath($path), $view, $path, $data);
+ }
+
+ /**
+ * Determine if a given view exists.
+ *
+ * @param string $view
+ * @return bool
+ */
+ public function exists($view)
+ {
+ try {
+ $this->finder->find($view);
+ } catch (InvalidArgumentException $e) {
+ return false;
+ }
+
+ return true;
+ }
+
+ /**
+ * Get the appropriate view engine for the given path.
+ *
+ * @param string $path
+ * @return \Illuminate\View\Engines\EngineInterface
+ *
+ * @throws \InvalidArgumentException
+ */
+ public function getEngineFromPath($path)
+ {
+ if (! $extension = $this->getExtension($path)) {
+ throw new InvalidArgumentException("Unrecognized extension in file: $path");
+ }
+
+ $engine = $this->extensions[$extension];
+
+ return $this->engines->resolve($engine);
+ }
+
+ /**
+ * Get the extension used by the view file.
+ *
+ * @param string $path
+ * @return string
+ */
+ protected function getExtension($path)
+ {
+ $extensions = array_keys($this->extensions);
+
+ return Arr::first($extensions, function ($value) use ($path) {
+ return Str::endsWith($path, '.'.$value);
+ });
+ }
+
+ /**
+ * Add a piece of shared data to the environment.
+ *
+ * @param array|string $key
+ * @param mixed $value
+ * @return mixed
+ */
+ public function share($key, $value = null)
+ {
+ $keys = is_array($key) ? $key : [$key => $value];
+
+ foreach ($keys as $key => $value) {
+ $this->shared[$key] = $value;
+ }
+
+ return $value;
+ }
+
+ /**
+ * Increment the rendering counter.
+ *
+ * @return void
+ */
+ public function incrementRender()
+ {
+ $this->renderCount++;
+ }
+
+ /**
+ * Decrement the rendering counter.
+ *
+ * @return void
+ */
+ public function decrementRender()
+ {
+ $this->renderCount--;
+ }
+
+ /**
+ * Check if there are no active render operations.
+ *
+ * @return bool
+ */
+ public function doneRendering()
+ {
+ return $this->renderCount == 0;
+ }
+
+ /**
+ * Add a location to the array of view locations.
+ *
+ * @param string $location
+ * @return void
+ */
+ public function addLocation($location)
+ {
+ $this->finder->addLocation($location);
+ }
+
+ /**
+ * Add a new namespace to the loader.
+ *
+ * @param string $namespace
+ * @param string|array $hints
+ * @return $this
+ */
+ public function addNamespace($namespace, $hints)
+ {
+ $this->finder->addNamespace($namespace, $hints);
+
+ return $this;
+ }
+
+ /**
+ * Prepend a new namespace to the loader.
+ *
+ * @param string $namespace
+ * @param string|array $hints
+ * @return $this
+ */
+ public function prependNamespace($namespace, $hints)
+ {
+ $this->finder->prependNamespace($namespace, $hints);
+
+ return $this;
+ }
+
+ /**
+ * Replace the namespace hints for the given namespace.
+ *
+ * @param string $namespace
+ * @param string|array $hints
+ * @return $this
+ */
+ public function replaceNamespace($namespace, $hints)
+ {
+ $this->finder->replaceNamespace($namespace, $hints);
+
+ return $this;
+ }
+
+ /**
+ * Register a valid view extension and its engine.
+ *
+ * @param string $extension
+ * @param string $engine
+ * @param \Closure $resolver
+ * @return void
+ */
+ public function addExtension($extension, $engine, $resolver = null)
+ {
+ $this->finder->addExtension($extension);
+
+ if (isset($resolver)) {
+ $this->engines->register($engine, $resolver);
+ }
+
+ unset($this->extensions[$extension]);
+
+ $this->extensions = array_merge([$extension => $engine], $this->extensions);
+ }
+
+ /**
+ * Flush all of the factory state like sections and stacks.
+ *
+ * @return void
+ */
+ public function flushState()
+ {
+ $this->renderCount = 0;
+
+ $this->flushSections();
+ $this->flushStacks();
+ }
+
+ /**
+ * Flush all of the section contents if done rendering.
+ *
+ * @return void
+ */
+ public function flushStateIfDoneRendering()
+ {
+ if ($this->doneRendering()) {
+ $this->flushState();
+ }
+ }
+
+ /**
+ * Get the extension to engine bindings.
+ *
+ * @return array
+ */
+ public function getExtensions()
+ {
+ return $this->extensions;
+ }
+
+ /**
+ * Get the engine resolver instance.
+ *
+ * @return \Illuminate\View\Engines\EngineResolver
+ */
+ public function getEngineResolver()
+ {
+ return $this->engines;
+ }
+
+ /**
+ * Get the view finder instance.
+ *
+ * @return \Illuminate\View\ViewFinderInterface
+ */
+ public function getFinder()
+ {
+ return $this->finder;
+ }
+
+ /**
+ * Set the view finder instance.
+ *
+ * @param \Illuminate\View\ViewFinderInterface $finder
+ * @return void
+ */
+ public function setFinder(ViewFinderInterface $finder)
+ {
+ $this->finder = $finder;
+ }
+
+ /**
+ * Flush the cache of views located by the finder.
+ *
+ * @return void
+ */
+ public function flushFinderCache()
+ {
+ $this->getFinder()->flush();
+ }
+
+ /**
+ * Get the event dispatcher instance.
+ *
+ * @return \Illuminate\Contracts\Events\Dispatcher
+ */
+ public function getDispatcher()
+ {
+ return $this->events;
+ }
+
+ /**
+ * Set the event dispatcher instance.
+ *
+ * @param \Illuminate\Contracts\Events\Dispatcher $events
+ * @return void
+ */
+ public function setDispatcher(Dispatcher $events)
+ {
+ $this->events = $events;
+ }
+
+ /**
+ * Get the IoC container instance.
+ *
+ * @return \Illuminate\Contracts\Container\Container
+ */
+ public function getContainer()
+ {
+ return $this->container;
+ }
+
+ /**
+ * Set the IoC container instance.
+ *
+ * @param \Illuminate\Contracts\Container\Container $container
+ * @return void
+ */
+ public function setContainer(Container $container)
+ {
+ $this->container = $container;
+ }
+
+ /**
+ * Get an item from the shared data.
+ *
+ * @param string $key
+ * @param mixed $default
+ * @return mixed
+ */
+ public function shared($key, $default = null)
+ {
+ return Arr::get($this->shared, $key, $default);
+ }
+
+ /**
+ * Get all of the shared data for the environment.
+ *
+ * @return array
+ */
+ public function getShared()
+ {
+ return $this->shared;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/FileViewFinder.php b/vendor/laravel/framework/src/Illuminate/View/FileViewFinder.php
new file mode 100644
index 000000000..cf6bb8efa
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/FileViewFinder.php
@@ -0,0 +1,298 @@
+files = $files;
+ $this->paths = $paths;
+
+ if (isset($extensions)) {
+ $this->extensions = $extensions;
+ }
+ }
+
+ /**
+ * Get the fully qualified location of the view.
+ *
+ * @param string $name
+ * @return string
+ */
+ public function find($name)
+ {
+ if (isset($this->views[$name])) {
+ return $this->views[$name];
+ }
+
+ if ($this->hasHintInformation($name = trim($name))) {
+ return $this->views[$name] = $this->findNamespacedView($name);
+ }
+
+ return $this->views[$name] = $this->findInPaths($name, $this->paths);
+ }
+
+ /**
+ * Get the path to a template with a named path.
+ *
+ * @param string $name
+ * @return string
+ */
+ protected function findNamespacedView($name)
+ {
+ list($namespace, $view) = $this->parseNamespaceSegments($name);
+
+ return $this->findInPaths($view, $this->hints[$namespace]);
+ }
+
+ /**
+ * Get the segments of a template with a named path.
+ *
+ * @param string $name
+ * @return array
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function parseNamespaceSegments($name)
+ {
+ $segments = explode(static::HINT_PATH_DELIMITER, $name);
+
+ if (count($segments) != 2) {
+ throw new InvalidArgumentException("View [$name] has an invalid name.");
+ }
+
+ if (! isset($this->hints[$segments[0]])) {
+ throw new InvalidArgumentException("No hint path defined for [{$segments[0]}].");
+ }
+
+ return $segments;
+ }
+
+ /**
+ * Find the given view in the list of paths.
+ *
+ * @param string $name
+ * @param array $paths
+ * @return string
+ *
+ * @throws \InvalidArgumentException
+ */
+ protected function findInPaths($name, $paths)
+ {
+ foreach ((array) $paths as $path) {
+ foreach ($this->getPossibleViewFiles($name) as $file) {
+ if ($this->files->exists($viewPath = $path.'/'.$file)) {
+ return $viewPath;
+ }
+ }
+ }
+
+ throw new InvalidArgumentException("View [$name] not found.");
+ }
+
+ /**
+ * Get an array of possible view files.
+ *
+ * @param string $name
+ * @return array
+ */
+ protected function getPossibleViewFiles($name)
+ {
+ return array_map(function ($extension) use ($name) {
+ return str_replace('.', '/', $name).'.'.$extension;
+ }, $this->extensions);
+ }
+
+ /**
+ * Add a location to the finder.
+ *
+ * @param string $location
+ * @return void
+ */
+ public function addLocation($location)
+ {
+ $this->paths[] = $location;
+ }
+
+ /**
+ * Prepend a location to the finder.
+ *
+ * @param string $location
+ * @return void
+ */
+ public function prependLocation($location)
+ {
+ array_unshift($this->paths, $location);
+ }
+
+ /**
+ * Add a namespace hint to the finder.
+ *
+ * @param string $namespace
+ * @param string|array $hints
+ * @return void
+ */
+ public function addNamespace($namespace, $hints)
+ {
+ $hints = (array) $hints;
+
+ if (isset($this->hints[$namespace])) {
+ $hints = array_merge($this->hints[$namespace], $hints);
+ }
+
+ $this->hints[$namespace] = $hints;
+ }
+
+ /**
+ * Prepend a namespace hint to the finder.
+ *
+ * @param string $namespace
+ * @param string|array $hints
+ * @return void
+ */
+ public function prependNamespace($namespace, $hints)
+ {
+ $hints = (array) $hints;
+
+ if (isset($this->hints[$namespace])) {
+ $hints = array_merge($hints, $this->hints[$namespace]);
+ }
+
+ $this->hints[$namespace] = $hints;
+ }
+
+ /**
+ * Replace the namespace hints for the given namespace.
+ *
+ * @param string $namespace
+ * @param string|array $hints
+ * @return void
+ */
+ public function replaceNamespace($namespace, $hints)
+ {
+ $this->hints[$namespace] = (array) $hints;
+ }
+
+ /**
+ * Register an extension with the view finder.
+ *
+ * @param string $extension
+ * @return void
+ */
+ public function addExtension($extension)
+ {
+ if (($index = array_search($extension, $this->extensions)) !== false) {
+ unset($this->extensions[$index]);
+ }
+
+ array_unshift($this->extensions, $extension);
+ }
+
+ /**
+ * Returns whether or not the view name has any hint information.
+ *
+ * @param string $name
+ * @return bool
+ */
+ public function hasHintInformation($name)
+ {
+ return strpos($name, static::HINT_PATH_DELIMITER) > 0;
+ }
+
+ /**
+ * Flush the cache of located views.
+ *
+ * @return void
+ */
+ public function flush()
+ {
+ $this->views = [];
+ }
+
+ /**
+ * Get the filesystem instance.
+ *
+ * @return \Illuminate\Filesystem\Filesystem
+ */
+ public function getFilesystem()
+ {
+ return $this->files;
+ }
+
+ /**
+ * Get the active view paths.
+ *
+ * @return array
+ */
+ public function getPaths()
+ {
+ return $this->paths;
+ }
+
+ /**
+ * Get the namespace to file path hints.
+ *
+ * @return array
+ */
+ public function getHints()
+ {
+ return $this->hints;
+ }
+
+ /**
+ * Get registered extensions.
+ *
+ * @return array
+ */
+ public function getExtensions()
+ {
+ return $this->extensions;
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/Middleware/ShareErrorsFromSession.php b/vendor/laravel/framework/src/Illuminate/View/Middleware/ShareErrorsFromSession.php
new file mode 100644
index 000000000..618b7dd4c
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/Middleware/ShareErrorsFromSession.php
@@ -0,0 +1,51 @@
+view = $view;
+ }
+
+ /**
+ * Handle an incoming request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @param \Closure $next
+ * @return mixed
+ */
+ public function handle($request, Closure $next)
+ {
+ // If the current session has an "errors" variable bound to it, we will share
+ // its value with all view instances so the views can easily access errors
+ // without having to bind. An empty bag is set when there aren't errors.
+ $this->view->share(
+ 'errors', $request->session()->get('errors') ?: new ViewErrorBag
+ );
+
+ // Putting the errors in the view for every view allows the developer to just
+ // assume that some errors are always available, which is convenient since
+ // they don't have to continually run checks for the presence of errors.
+
+ return $next($request);
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/View.php b/vendor/laravel/framework/src/Illuminate/View/View.php
new file mode 100644
index 000000000..a43900639
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/View.php
@@ -0,0 +1,414 @@
+view = $view;
+ $this->path = $path;
+ $this->engine = $engine;
+ $this->factory = $factory;
+
+ $this->data = $data instanceof Arrayable ? $data->toArray() : (array) $data;
+ }
+
+ /**
+ * Get the string contents of the view.
+ *
+ * @param callable|null $callback
+ * @return string
+ *
+ * @throws \Throwable
+ */
+ public function render(callable $callback = null)
+ {
+ try {
+ $contents = $this->renderContents();
+
+ $response = isset($callback) ? call_user_func($callback, $this, $contents) : null;
+
+ // Once we have the contents of the view, we will flush the sections if we are
+ // done rendering all views so that there is nothing left hanging over when
+ // another view gets rendered in the future by the application developer.
+ $this->factory->flushStateIfDoneRendering();
+
+ return ! is_null($response) ? $response : $contents;
+ } catch (Exception $e) {
+ $this->factory->flushState();
+
+ throw $e;
+ } catch (Throwable $e) {
+ $this->factory->flushState();
+
+ throw $e;
+ }
+ }
+
+ /**
+ * Get the contents of the view instance.
+ *
+ * @return string
+ */
+ protected function renderContents()
+ {
+ // We will keep track of the amount of views being rendered so we can flush
+ // the section after the complete rendering operation is done. This will
+ // clear out the sections for any separate views that may be rendered.
+ $this->factory->incrementRender();
+
+ $this->factory->callComposer($this);
+
+ $contents = $this->getContents();
+
+ // Once we've finished rendering the view, we'll decrement the render count
+ // so that each sections get flushed out next time a view is created and
+ // no old sections are staying around in the memory of an environment.
+ $this->factory->decrementRender();
+
+ return $contents;
+ }
+
+ /**
+ * Get the evaluated contents of the view.
+ *
+ * @return string
+ */
+ protected function getContents()
+ {
+ return $this->engine->get($this->path, $this->gatherData());
+ }
+
+ /**
+ * Get the data bound to the view instance.
+ *
+ * @return array
+ */
+ protected function gatherData()
+ {
+ $data = array_merge($this->factory->getShared(), $this->data);
+
+ foreach ($data as $key => $value) {
+ if ($value instanceof Renderable) {
+ $data[$key] = $value->render();
+ }
+ }
+
+ return $data;
+ }
+
+ /**
+ * Get the sections of the rendered view.
+ *
+ * @return array
+ */
+ public function renderSections()
+ {
+ return $this->render(function () {
+ return $this->factory->getSections();
+ });
+ }
+
+ /**
+ * Add a piece of data to the view.
+ *
+ * @param string|array $key
+ * @param mixed $value
+ * @return $this
+ */
+ public function with($key, $value = null)
+ {
+ if (is_array($key)) {
+ $this->data = array_merge($this->data, $key);
+ } else {
+ $this->data[$key] = $value;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add a view instance to the view data.
+ *
+ * @param string $key
+ * @param string $view
+ * @param array $data
+ * @return $this
+ */
+ public function nest($key, $view, array $data = [])
+ {
+ return $this->with($key, $this->factory->make($view, $data));
+ }
+
+ /**
+ * Add validation errors to the view.
+ *
+ * @param \Illuminate\Contracts\Support\MessageProvider|array $provider
+ * @return $this
+ */
+ public function withErrors($provider)
+ {
+ $this->with('errors', $this->formatErrors($provider));
+
+ return $this;
+ }
+
+ /**
+ * Format the given message provider into a MessageBag.
+ *
+ * @param \Illuminate\Contracts\Support\MessageProvider|array $provider
+ * @return \Illuminate\Support\MessageBag
+ */
+ protected function formatErrors($provider)
+ {
+ return $provider instanceof MessageProvider
+ ? $provider->getMessageBag() : new MessageBag((array) $provider);
+ }
+
+ /**
+ * Get the name of the view.
+ *
+ * @return string
+ */
+ public function name()
+ {
+ return $this->getName();
+ }
+
+ /**
+ * Get the name of the view.
+ *
+ * @return string
+ */
+ public function getName()
+ {
+ return $this->view;
+ }
+
+ /**
+ * Get the array of view data.
+ *
+ * @return array
+ */
+ public function getData()
+ {
+ return $this->data;
+ }
+
+ /**
+ * Get the path to the view file.
+ *
+ * @return string
+ */
+ public function getPath()
+ {
+ return $this->path;
+ }
+
+ /**
+ * Set the path to the view.
+ *
+ * @param string $path
+ * @return void
+ */
+ public function setPath($path)
+ {
+ $this->path = $path;
+ }
+
+ /**
+ * Get the view factory instance.
+ *
+ * @return \Illuminate\View\Factory
+ */
+ public function getFactory()
+ {
+ return $this->factory;
+ }
+
+ /**
+ * Get the view's rendering engine.
+ *
+ * @return \Illuminate\View\Engines\EngineInterface
+ */
+ public function getEngine()
+ {
+ return $this->engine;
+ }
+
+ /**
+ * Determine if a piece of data is bound.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function offsetExists($key)
+ {
+ return array_key_exists($key, $this->data);
+ }
+
+ /**
+ * Get a piece of bound data to the view.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function offsetGet($key)
+ {
+ return $this->data[$key];
+ }
+
+ /**
+ * Set a piece of data on the view.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function offsetSet($key, $value)
+ {
+ $this->with($key, $value);
+ }
+
+ /**
+ * Unset a piece of data from the view.
+ *
+ * @param string $key
+ * @return void
+ */
+ public function offsetUnset($key)
+ {
+ unset($this->data[$key]);
+ }
+
+ /**
+ * Get a piece of data from the view.
+ *
+ * @param string $key
+ * @return mixed
+ */
+ public function &__get($key)
+ {
+ return $this->data[$key];
+ }
+
+ /**
+ * Set a piece of data on the view.
+ *
+ * @param string $key
+ * @param mixed $value
+ * @return void
+ */
+ public function __set($key, $value)
+ {
+ $this->with($key, $value);
+ }
+
+ /**
+ * Check if a piece of data is bound to the view.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function __isset($key)
+ {
+ return isset($this->data[$key]);
+ }
+
+ /**
+ * Remove a piece of bound data from the view.
+ *
+ * @param string $key
+ * @return bool
+ */
+ public function __unset($key)
+ {
+ unset($this->data[$key]);
+ }
+
+ /**
+ * Dynamically bind parameters to the view.
+ *
+ * @param string $method
+ * @param array $parameters
+ * @return \Illuminate\View\View
+ *
+ * @throws \BadMethodCallException
+ */
+ public function __call($method, $parameters)
+ {
+ if (! Str::startsWith($method, 'with')) {
+ throw new BadMethodCallException("Method [$method] does not exist on view.");
+ }
+
+ return $this->with(Str::snake(substr($method, 4)), $parameters[0]);
+ }
+
+ /**
+ * Get the string contents of the view.
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return $this->render();
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/ViewFinderInterface.php b/vendor/laravel/framework/src/Illuminate/View/ViewFinderInterface.php
new file mode 100644
index 000000000..49d609ea0
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/ViewFinderInterface.php
@@ -0,0 +1,71 @@
+registerFactory();
+
+ $this->registerViewFinder();
+
+ $this->registerEngineResolver();
+ }
+
+ /**
+ * Register the view environment.
+ *
+ * @return void
+ */
+ public function registerFactory()
+ {
+ $this->app->singleton('view', function ($app) {
+ // Next we need to grab the engine resolver instance that will be used by the
+ // environment. The resolver will be used by an environment to get each of
+ // the various engine implementations such as plain PHP or Blade engine.
+ $resolver = $app['view.engine.resolver'];
+
+ $finder = $app['view.finder'];
+
+ $env = new Factory($resolver, $finder, $app['events']);
+
+ // We will also set the container instance on this view environment since the
+ // view composers may be classes registered in the container, which allows
+ // for great testable, flexible composers for the application developer.
+ $env->setContainer($app);
+
+ $env->share('app', $app);
+
+ return $env;
+ });
+ }
+
+ /**
+ * Register the view finder implementation.
+ *
+ * @return void
+ */
+ public function registerViewFinder()
+ {
+ $this->app->bind('view.finder', function ($app) {
+ return new FileViewFinder($app['files'], $app['config']['view.paths']);
+ });
+ }
+
+ /**
+ * Register the engine resolver instance.
+ *
+ * @return void
+ */
+ public function registerEngineResolver()
+ {
+ $this->app->singleton('view.engine.resolver', function () {
+ $resolver = new EngineResolver;
+
+ // Next, we will register the various view engines with the resolver so that the
+ // environment will resolve the engines needed for various views based on the
+ // extension of view file. We call a method for each of the view's engines.
+ foreach (['file', 'php', 'blade'] as $engine) {
+ $this->{'register'.ucfirst($engine).'Engine'}($resolver);
+ }
+
+ return $resolver;
+ });
+ }
+
+ /**
+ * Register the file engine implementation.
+ *
+ * @param \Illuminate\View\Engines\EngineResolver $resolver
+ * @return void
+ */
+ public function registerFileEngine($resolver)
+ {
+ $resolver->register('file', function () {
+ return new FileEngine;
+ });
+ }
+
+ /**
+ * Register the PHP engine implementation.
+ *
+ * @param \Illuminate\View\Engines\EngineResolver $resolver
+ * @return void
+ */
+ public function registerPhpEngine($resolver)
+ {
+ $resolver->register('php', function () {
+ return new PhpEngine;
+ });
+ }
+
+ /**
+ * Register the Blade engine implementation.
+ *
+ * @param \Illuminate\View\Engines\EngineResolver $resolver
+ * @return void
+ */
+ public function registerBladeEngine($resolver)
+ {
+ // The Compiler engine requires an instance of the CompilerInterface, which in
+ // this case will be the Blade compiler, so we'll first create the compiler
+ // instance to pass into the engine so it can compile the views properly.
+ $this->app->singleton('blade.compiler', function () {
+ return new BladeCompiler(
+ $this->app['files'], $this->app['config']['view.compiled']
+ );
+ });
+
+ $resolver->register('blade', function () {
+ return new CompilerEngine($this->app['blade.compiler']);
+ });
+ }
+}
diff --git a/vendor/laravel/framework/src/Illuminate/View/composer.json b/vendor/laravel/framework/src/Illuminate/View/composer.json
new file mode 100644
index 000000000..8450fcdb8
--- /dev/null
+++ b/vendor/laravel/framework/src/Illuminate/View/composer.json
@@ -0,0 +1,39 @@
+{
+ "name": "illuminate/view",
+ "description": "The Illuminate View package.",
+ "license": "MIT",
+ "homepage": "https://laravel.com",
+ "support": {
+ "issues": "https://github.com/laravel/framework/issues",
+ "source": "https://github.com/laravel/framework"
+ },
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.6.4",
+ "illuminate/container": "5.4.*",
+ "illuminate/contracts": "5.4.*",
+ "illuminate/events": "5.4.*",
+ "illuminate/filesystem": "5.4.*",
+ "illuminate/support": "5.4.*",
+ "symfony/debug": "~3.2"
+ },
+ "autoload": {
+ "psr-4": {
+ "Illuminate\\View\\": ""
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "5.4-dev"
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "minimum-stability": "dev"
+}
diff --git a/vendor/laravel/tinker/.styleci.yml b/vendor/laravel/tinker/.styleci.yml
new file mode 100644
index 000000000..215fbcfe3
--- /dev/null
+++ b/vendor/laravel/tinker/.styleci.yml
@@ -0,0 +1,4 @@
+php:
+ preset: laravel
+js: true
+css: true
diff --git a/vendor/laravel/tinker/LICENSE.md b/vendor/laravel/tinker/LICENSE.md
new file mode 100644
index 000000000..79810c848
--- /dev/null
+++ b/vendor/laravel/tinker/LICENSE.md
@@ -0,0 +1,21 @@
+The MIT License (MIT)
+
+Copyright (c) Taylor Otwell
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
diff --git a/vendor/laravel/tinker/README.md b/vendor/laravel/tinker/README.md
new file mode 100644
index 000000000..3a51325fa
--- /dev/null
+++ b/vendor/laravel/tinker/README.md
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+
+
+
+## Introduction
+
+Laravel Tinker is a powerful REPL for the Laravel framework.
+
+## Installation
+
+To get started with Laravel Tinker, simply run:
+
+ composer require laravel/tinker
+
+## Basic Usage
+
+From your console, execute the `php artisan tinker` command.
+
+### Dispatching Jobs
+
+The `dispatch` helper function and `dispatch` method on the `Dispatchable` class depends on garbage collection to place the job on the queue. Therefore, when using `tinker`, you should use `Bus::dispatch` or `Queue::push` to dispatch jobs.
+
+## License
+
+Laravel Tinker is open-sourced software licensed under the [MIT license](https://opensource.org/licenses/MIT).
diff --git a/vendor/laravel/tinker/composer.json b/vendor/laravel/tinker/composer.json
new file mode 100644
index 000000000..0d14d4663
--- /dev/null
+++ b/vendor/laravel/tinker/composer.json
@@ -0,0 +1,49 @@
+{
+ "name": "laravel/tinker",
+ "description": "Powerful REPL for the Laravel framework.",
+ "keywords": ["tinker", "repl", "psysh", "laravel"],
+ "license": "MIT",
+ "authors": [
+ {
+ "name": "Taylor Otwell",
+ "email": "taylor@laravel.com"
+ }
+ ],
+ "require": {
+ "php": ">=5.5.9",
+ "illuminate/console": "~5.1|^6.0",
+ "illuminate/contracts": "~5.1|^6.0",
+ "illuminate/support": "~5.1|^6.0",
+ "psy/psysh": "0.7.*|0.8.*|0.9.*",
+ "symfony/var-dumper": "~3.0|~4.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.0|~5.0"
+ },
+ "autoload": {
+ "psr-4": {
+ "Laravel\\Tinker\\": "src/"
+ }
+ },
+ "autoload-dev": {
+ "psr-4": {
+ "Laravel\\Tinker\\Tests\\": "tests/"
+ }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.0-dev"
+ },
+ "laravel": {
+ "providers": [
+ "Laravel\\Tinker\\TinkerServiceProvider"
+ ]
+ }
+ },
+ "config": {
+ "sort-packages": true
+ },
+ "suggest": {
+ "illuminate/database": "The Illuminate Database package (~5.1)."
+ }
+}
diff --git a/vendor/laravel/tinker/config/tinker.php b/vendor/laravel/tinker/config/tinker.php
new file mode 100644
index 000000000..0d2bf00e7
--- /dev/null
+++ b/vendor/laravel/tinker/config/tinker.php
@@ -0,0 +1,35 @@
+ [
+ // App\Console\Commands\ExampleCommand::class,
+ ],
+
+ /*
+ |--------------------------------------------------------------------------
+ | Alias Blacklist
+ |--------------------------------------------------------------------------
+ |
+ | Typically, Tinker automatically aliases classes as you require them in
+ | Tinker. However, you may wish to never alias certain classes, which
+ | you may accomplish by listing the classes in the following array.
+ |
+ */
+
+ 'dont_alias' => [
+ 'App\Nova',
+ ],
+
+];
diff --git a/vendor/laravel/tinker/src/ClassAliasAutoloader.php b/vendor/laravel/tinker/src/ClassAliasAutoloader.php
new file mode 100644
index 000000000..5afdb4f50
--- /dev/null
+++ b/vendor/laravel/tinker/src/ClassAliasAutoloader.php
@@ -0,0 +1,116 @@
+shell = $shell;
+
+ $vendorPath = dirname(dirname($classMapPath));
+
+ $classes = require $classMapPath;
+
+ $excludedAliases = collect(config('tinker.dont_alias', []));
+
+ foreach ($classes as $class => $path) {
+ if (! Str::contains($class, '\\') || Str::startsWith($path, $vendorPath)) {
+ continue;
+ }
+
+ if (! $excludedAliases->filter(function ($alias) use ($class) {
+ return Str::startsWith($class, $alias);
+ })->isEmpty()) {
+ continue;
+ }
+
+ $name = class_basename($class);
+
+ if (! isset($this->classes[$name])) {
+ $this->classes[$name] = $class;
+ }
+ }
+ }
+
+ /**
+ * Find the closest class by name.
+ *
+ * @param string $class
+ * @return void
+ */
+ public function aliasClass($class)
+ {
+ if (Str::contains($class, '\\')) {
+ return;
+ }
+
+ $fullName = isset($this->classes[$class])
+ ? $this->classes[$class]
+ : false;
+
+ if ($fullName) {
+ $this->shell->writeStdout("[!] Aliasing '{$class}' to '{$fullName}' for this Tinker session.\n");
+
+ class_alias($fullName, $class);
+ }
+ }
+
+ /**
+ * Unregister the alias loader instance.
+ *
+ * @return void
+ */
+ public function unregister()
+ {
+ spl_autoload_unregister([$this, 'aliasClass']);
+ }
+
+ /**
+ * Handle the destruction of the instance.
+ *
+ * @return void
+ */
+ public function __destruct()
+ {
+ $this->unregister();
+ }
+}
diff --git a/vendor/laravel/tinker/src/Console/TinkerCommand.php b/vendor/laravel/tinker/src/Console/TinkerCommand.php
new file mode 100644
index 000000000..c644dfea3
--- /dev/null
+++ b/vendor/laravel/tinker/src/Console/TinkerCommand.php
@@ -0,0 +1,129 @@
+getApplication()->setCatchExceptions(false);
+
+ $config = new Configuration([
+ 'updateCheck' => 'never',
+ ]);
+
+ $config->getPresenter()->addCasters(
+ $this->getCasters()
+ );
+
+ $shell = new Shell($config);
+ $shell->addCommands($this->getCommands());
+ $shell->setIncludes($this->argument('include'));
+
+ if (isset($_ENV['COMPOSER_VENDOR_DIR'])) {
+ $path = $_ENV['COMPOSER_VENDOR_DIR'];
+ } else {
+ $path = $this->getLaravel()->basePath().DIRECTORY_SEPARATOR.'vendor';
+ }
+
+ $path .= '/composer/autoload_classmap.php';
+
+ $loader = ClassAliasAutoloader::register($shell, $path);
+
+ try {
+ $shell->run();
+ } finally {
+ $loader->unregister();
+ }
+ }
+
+ /**
+ * Get artisan commands to pass through to PsySH.
+ *
+ * @return array
+ */
+ protected function getCommands()
+ {
+ $commands = [];
+
+ foreach ($this->getApplication()->all() as $name => $command) {
+ if (in_array($name, $this->commandWhitelist)) {
+ $commands[] = $command;
+ }
+ }
+
+ foreach (config('tinker.commands', []) as $command) {
+ $commands[] = $this->getApplication()->resolve($command);
+ }
+
+ return $commands;
+ }
+
+ /**
+ * Get an array of Laravel tailored casters.
+ *
+ * @return array
+ */
+ protected function getCasters()
+ {
+ $casters = [
+ 'Illuminate\Support\Collection' => 'Laravel\Tinker\TinkerCaster::castCollection',
+ ];
+
+ if (class_exists('Illuminate\Database\Eloquent\Model')) {
+ $casters['Illuminate\Database\Eloquent\Model'] = 'Laravel\Tinker\TinkerCaster::castModel';
+ }
+
+ if (class_exists('Illuminate\Foundation\Application')) {
+ $casters['Illuminate\Foundation\Application'] = 'Laravel\Tinker\TinkerCaster::castApplication';
+ }
+
+ return $casters;
+ }
+
+ /**
+ * Get the console command arguments.
+ *
+ * @return array
+ */
+ protected function getArguments()
+ {
+ return [
+ ['include', InputArgument::IS_ARRAY, 'Include file(s) before starting tinker'],
+ ];
+ }
+}
diff --git a/vendor/laravel/tinker/src/TinkerCaster.php b/vendor/laravel/tinker/src/TinkerCaster.php
new file mode 100644
index 000000000..42862e375
--- /dev/null
+++ b/vendor/laravel/tinker/src/TinkerCaster.php
@@ -0,0 +1,95 @@
+$property();
+
+ if (! is_null($val)) {
+ $results[Caster::PREFIX_VIRTUAL.$property] = $val;
+ }
+ } catch (Exception $e) {
+ //
+ }
+ }
+
+ return $results;
+ }
+
+ /**
+ * Get an array representing the properties of a collection.
+ *
+ * @param \Illuminate\Support\Collection $collection
+ * @return array
+ */
+ public static function castCollection($collection)
+ {
+ return [
+ Caster::PREFIX_VIRTUAL.'all' => $collection->all(),
+ ];
+ }
+
+ /**
+ * Get an array representing the properties of a model.
+ *
+ * @param \Illuminate\Database\Eloquent\Model $model
+ * @return array
+ */
+ public static function castModel($model)
+ {
+ $attributes = array_merge(
+ $model->getAttributes(), $model->getRelations()
+ );
+
+ $visible = array_flip(
+ $model->getVisible() ?: array_diff(array_keys($attributes), $model->getHidden())
+ );
+
+ $results = [];
+
+ foreach (array_intersect_key($attributes, $visible) as $key => $value) {
+ $results[(isset($visible[$key]) ? Caster::PREFIX_VIRTUAL : Caster::PREFIX_PROTECTED).$key] = $value;
+ }
+
+ return $results;
+ }
+}
diff --git a/vendor/laravel/tinker/src/TinkerServiceProvider.php b/vendor/laravel/tinker/src/TinkerServiceProvider.php
new file mode 100644
index 000000000..7c626775f
--- /dev/null
+++ b/vendor/laravel/tinker/src/TinkerServiceProvider.php
@@ -0,0 +1,60 @@
+app instanceof LaravelApplication && $this->app->runningInConsole()) {
+ $this->publishes([$source => config_path('tinker.php')]);
+ } elseif ($this->app instanceof LumenApplication) {
+ $this->app->configure('tinker');
+ }
+
+ $this->mergeConfigFrom($source, 'tinker');
+ }
+
+ /**
+ * Register the service provider.
+ *
+ * @return void
+ */
+ public function register()
+ {
+ $this->app->singleton('command.tinker', function () {
+ return new TinkerCommand;
+ });
+
+ $this->commands(['command.tinker']);
+ }
+
+ /**
+ * Get the services provided by the provider.
+ *
+ * @return array
+ */
+ public function provides()
+ {
+ return ['command.tinker'];
+ }
+}
diff --git a/vendor/league/flysystem/LICENSE b/vendor/league/flysystem/LICENSE
new file mode 100644
index 000000000..f2684c841
--- /dev/null
+++ b/vendor/league/flysystem/LICENSE
@@ -0,0 +1,19 @@
+Copyright (c) 2013-2019 Frank de Jonge
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is furnished
+to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
diff --git a/vendor/league/flysystem/SECURITY.md b/vendor/league/flysystem/SECURITY.md
new file mode 100644
index 000000000..f5b205ed0
--- /dev/null
+++ b/vendor/league/flysystem/SECURITY.md
@@ -0,0 +1,16 @@
+# Security Policy
+
+## Supported Versions
+
+| Version | Supported |
+| ------- | ------------------ |
+| 1.0.x | :white_check_mark: |
+| 2.0.x | :x: |
+
+## Reporting a Vulnerability
+
+When you've encountered a security vulnerability, please disclose it securely.
+
+The security process is described at:
+[https://flysystem.thephpleague.com/docs/security/](https://flysystem.thephpleague.com/docs/security/)
+
diff --git a/vendor/league/flysystem/composer.json b/vendor/league/flysystem/composer.json
new file mode 100644
index 000000000..b0a68ec4b
--- /dev/null
+++ b/vendor/league/flysystem/composer.json
@@ -0,0 +1,71 @@
+{
+ "name": "league/flysystem",
+ "type": "library",
+ "description": "Filesystem abstraction: Many filesystems, one API.",
+ "keywords": [
+ "filesystem", "filesystems", "files", "storage", "dropbox", "aws",
+ "abstraction", "s3", "ftp", "sftp", "remote", "webdav",
+ "file systems", "cloud", "cloud files", "rackspace", "copy.com"
+ ],
+ "funding": [
+ {
+ "type": "other",
+ "url": "https://offset.earth/frankdejonge"
+ }
+ ],
+ "license": "MIT",
+ "authors": [
+ {
+ "name": "Frank de Jonge",
+ "email": "info@frenky.net"
+ }
+ ],
+ "require": {
+ "php": ">=5.5.9",
+ "ext-fileinfo": "*"
+ },
+ "require-dev": {
+ "phpspec/phpspec": "^3.4 || ^4.0 || ^5.0 || ^6.0",
+ "phpunit/phpunit": "^5.7.26"
+ },
+ "autoload": {
+ "psr-4": {
+ "League\\Flysystem\\": "src/"
+ }
+ },
+ "autoload-dev": {
+ "psr-4": {
+ "League\\Flysystem\\Stub\\": "stub/"
+ },
+ "files": [
+ "tests/PHPUnitHacks.php"
+ ]
+ },
+ "suggest": {
+ "ext-fileinfo": "Required for MimeType",
+ "league/flysystem-eventable-filesystem": "Allows you to use EventableFilesystem",
+ "league/flysystem-rackspace": "Allows you to use Rackspace Cloud Files",
+ "league/flysystem-azure": "Allows you to use Windows Azure Blob storage",
+ "league/flysystem-webdav": "Allows you to use WebDAV storage",
+ "league/flysystem-aws-s3-v2": "Allows you to use S3 storage with AWS SDK v2",
+ "league/flysystem-aws-s3-v3": "Allows you to use S3 storage with AWS SDK v3",
+ "spatie/flysystem-dropbox": "Allows you to use Dropbox storage",
+ "srmklive/flysystem-dropbox-v2": "Allows you to use Dropbox storage for PHP 5 applications",
+ "league/flysystem-cached-adapter": "Flysystem adapter decorator for metadata caching",
+ "ext-ftp": "Allows you to use FTP server storage",
+ "ext-openssl": "Allows you to use FTPS server storage",
+ "league/flysystem-sftp": "Allows you to use SFTP server storage via phpseclib",
+ "league/flysystem-ziparchive": "Allows you to use ZipArchive adapter"
+ },
+ "conflict": {
+ "league/flysystem-sftp": "<1.0.6"
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "1.1-dev"
+ }
+ },
+ "scripts": {
+ "phpstan": "php phpstan.php"
+ }
+}
diff --git a/vendor/league/flysystem/deprecations.md b/vendor/league/flysystem/deprecations.md
new file mode 100644
index 000000000..c336a425d
--- /dev/null
+++ b/vendor/league/flysystem/deprecations.md
@@ -0,0 +1,19 @@
+# Deprecations
+
+This document lists all the planned deprecations.
+
+## Handlers will be removed in 2.0
+
+The `Handler` type and associated calls will be removed in version 2.0.
+
+### Upgrade path
+
+You should create your own implementation for handling OOP usage,
+but it's recommended to move away from using an OOP-style wrapper entirely.
+
+The reason for this is that it's too easy for implementation details (for
+your application this is Flysystem) to leak into the application. The most
+important part for Flysystem is that it improves portability and creates a
+solid boundary between your application core and the infrastructure you use.
+The OOP-style handling breaks this principle, therefore I want to stop
+promoting it.
diff --git a/vendor/league/flysystem/src/Adapter/AbstractAdapter.php b/vendor/league/flysystem/src/Adapter/AbstractAdapter.php
new file mode 100644
index 000000000..e577ac4a7
--- /dev/null
+++ b/vendor/league/flysystem/src/Adapter/AbstractAdapter.php
@@ -0,0 +1,72 @@
+pathPrefix = null;
+
+ return;
+ }
+
+ $this->pathPrefix = rtrim($prefix, '\\/') . $this->pathSeparator;
+ }
+
+ /**
+ * Get the path prefix.
+ *
+ * @return string|null path prefix or null if pathPrefix is empty
+ */
+ public function getPathPrefix()
+ {
+ return $this->pathPrefix;
+ }
+
+ /**
+ * Prefix a path.
+ *
+ * @param string $path
+ *
+ * @return string prefixed path
+ */
+ public function applyPathPrefix($path)
+ {
+ return $this->getPathPrefix() . ltrim($path, '\\/');
+ }
+
+ /**
+ * Remove a path prefix.
+ *
+ * @param string $path
+ *
+ * @return string path without the prefix
+ */
+ public function removePathPrefix($path)
+ {
+ return substr($path, strlen($this->getPathPrefix()));
+ }
+}
diff --git a/vendor/league/flysystem/src/Adapter/AbstractFtpAdapter.php b/vendor/league/flysystem/src/Adapter/AbstractFtpAdapter.php
new file mode 100644
index 000000000..95a6b4d09
--- /dev/null
+++ b/vendor/league/flysystem/src/Adapter/AbstractFtpAdapter.php
@@ -0,0 +1,697 @@
+safeStorage = new SafeStorage();
+ $this->setConfig($config);
+ }
+
+ /**
+ * Set the config.
+ *
+ * @param array $config
+ *
+ * @return $this
+ */
+ public function setConfig(array $config)
+ {
+ foreach ($this->configurable as $setting) {
+ if ( ! isset($config[$setting])) {
+ continue;
+ }
+
+ $method = 'set' . ucfirst($setting);
+
+ if (method_exists($this, $method)) {
+ $this->$method($config[$setting]);
+ }
+ }
+
+ return $this;
+ }
+
+ /**
+ * Returns the host.
+ *
+ * @return string
+ */
+ public function getHost()
+ {
+ return $this->host;
+ }
+
+ /**
+ * Set the host.
+ *
+ * @param string $host
+ *
+ * @return $this
+ */
+ public function setHost($host)
+ {
+ $this->host = $host;
+
+ return $this;
+ }
+
+ /**
+ * Set the public permission value.
+ *
+ * @param int $permPublic
+ *
+ * @return $this
+ */
+ public function setPermPublic($permPublic)
+ {
+ $this->permPublic = $permPublic;
+
+ return $this;
+ }
+
+ /**
+ * Set the private permission value.
+ *
+ * @param int $permPrivate
+ *
+ * @return $this
+ */
+ public function setPermPrivate($permPrivate)
+ {
+ $this->permPrivate = $permPrivate;
+
+ return $this;
+ }
+
+ /**
+ * Returns the ftp port.
+ *
+ * @return int
+ */
+ public function getPort()
+ {
+ return $this->port;
+ }
+
+ /**
+ * Returns the root folder to work from.
+ *
+ * @return string
+ */
+ public function getRoot()
+ {
+ return $this->root;
+ }
+
+ /**
+ * Set the ftp port.
+ *
+ * @param int|string $port
+ *
+ * @return $this
+ */
+ public function setPort($port)
+ {
+ $this->port = (int) $port;
+
+ return $this;
+ }
+
+ /**
+ * Set the root folder to work from.
+ *
+ * @param string $root
+ *
+ * @return $this
+ */
+ public function setRoot($root)
+ {
+ $this->root = rtrim($root, '\\/') . $this->separator;
+
+ return $this;
+ }
+
+ /**
+ * Returns the ftp username.
+ *
+ * @return string username
+ */
+ public function getUsername()
+ {
+ $username = $this->safeStorage->retrieveSafely('username');
+
+ return $username !== null ? $username : 'anonymous';
+ }
+
+ /**
+ * Set ftp username.
+ *
+ * @param string $username
+ *
+ * @return $this
+ */
+ public function setUsername($username)
+ {
+ $this->safeStorage->storeSafely('username', $username);
+
+ return $this;
+ }
+
+ /**
+ * Returns the password.
+ *
+ * @return string password
+ */
+ public function getPassword()
+ {
+ return $this->safeStorage->retrieveSafely('password');
+ }
+
+ /**
+ * Set the ftp password.
+ *
+ * @param string $password
+ *
+ * @return $this
+ */
+ public function setPassword($password)
+ {
+ $this->safeStorage->storeSafely('password', $password);
+
+ return $this;
+ }
+
+ /**
+ * Returns the amount of seconds before the connection will timeout.
+ *
+ * @return int
+ */
+ public function getTimeout()
+ {
+ return $this->timeout;
+ }
+
+ /**
+ * Set the amount of seconds before the connection should timeout.
+ *
+ * @param int $timeout
+ *
+ * @return $this
+ */
+ public function setTimeout($timeout)
+ {
+ $this->timeout = (int) $timeout;
+
+ return $this;
+ }
+
+ /**
+ * Return the FTP system type.
+ *
+ * @return string
+ */
+ public function getSystemType()
+ {
+ return $this->systemType;
+ }
+
+ /**
+ * Set the FTP system type (windows or unix).
+ *
+ * @param string $systemType
+ *
+ * @return $this
+ */
+ public function setSystemType($systemType)
+ {
+ $this->systemType = strtolower($systemType);
+
+ return $this;
+ }
+
+ /**
+ * True to enable timestamps for FTP servers that return unix-style listings.
+ *
+ * @param bool $bool
+ *
+ * @return $this
+ */
+ public function setEnableTimestampsOnUnixListings($bool = false)
+ {
+ $this->enableTimestampsOnUnixListings = $bool;
+
+ return $this;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function listContents($directory = '', $recursive = false)
+ {
+ return $this->listDirectoryContents($directory, $recursive);
+ }
+
+ abstract protected function listDirectoryContents($directory, $recursive = false);
+
+ /**
+ * Normalize a directory listing.
+ *
+ * @param array $listing
+ * @param string $prefix
+ *
+ * @return array directory listing
+ */
+ protected function normalizeListing(array $listing, $prefix = '')
+ {
+ $base = $prefix;
+ $result = [];
+ $listing = $this->removeDotDirectories($listing);
+
+ while ($item = array_shift($listing)) {
+ if (preg_match('#^.*:$#', $item)) {
+ $base = preg_replace('~^\./*|:$~', '', $item);
+ continue;
+ }
+
+ $result[] = $this->normalizeObject($item, $base);
+ }
+
+ return $this->sortListing($result);
+ }
+
+ /**
+ * Sort a directory listing.
+ *
+ * @param array $result
+ *
+ * @return array sorted listing
+ */
+ protected function sortListing(array $result)
+ {
+ $compare = function ($one, $two) {
+ return strnatcmp($one['path'], $two['path']);
+ };
+
+ usort($result, $compare);
+
+ return $result;
+ }
+
+ /**
+ * Normalize a file entry.
+ *
+ * @param string $item
+ * @param string $base
+ *
+ * @return array normalized file array
+ *
+ * @throws NotSupportedException
+ */
+ protected function normalizeObject($item, $base)
+ {
+ $systemType = $this->systemType ?: $this->detectSystemType($item);
+
+ if ($systemType === 'unix') {
+ return $this->normalizeUnixObject($item, $base);
+ } elseif ($systemType === 'windows') {
+ return $this->normalizeWindowsObject($item, $base);
+ }
+
+ throw NotSupportedException::forFtpSystemType($systemType);
+ }
+
+ /**
+ * Normalize a Unix file entry.
+ *
+ * Given $item contains:
+ * '-rw-r--r-- 1 ftp ftp 409 Aug 19 09:01 file1.txt'
+ *
+ * This function will return:
+ * [
+ * 'type' => 'file',
+ * 'path' => 'file1.txt',
+ * 'visibility' => 'public',
+ * 'size' => 409,
+ * 'timestamp' => 1566205260
+ * ]
+ *
+ * @param string $item
+ * @param string $base
+ *
+ * @return array normalized file array
+ */
+ protected function normalizeUnixObject($item, $base)
+ {
+ $item = preg_replace('#\s+#', ' ', trim($item), 7);
+
+ if (count(explode(' ', $item, 9)) !== 9) {
+ throw new RuntimeException("Metadata can't be parsed from item '$item' , not enough parts.");
+ }
+
+ list($permissions, /* $number */, /* $owner */, /* $group */, $size, $month, $day, $timeOrYear, $name) = explode(' ', $item, 9);
+ $type = $this->detectType($permissions);
+ $path = $base === '' ? $name : $base . $this->separator . $name;
+
+ if ($type === 'dir') {
+ return compact('type', 'path');
+ }
+
+ $permissions = $this->normalizePermissions($permissions);
+ $visibility = $permissions & 0044 ? AdapterInterface::VISIBILITY_PUBLIC : AdapterInterface::VISIBILITY_PRIVATE;
+ $size = (int) $size;
+
+ $result = compact('type', 'path', 'visibility', 'size');
+ if ($this->enableTimestampsOnUnixListings) {
+ $timestamp = $this->normalizeUnixTimestamp($month, $day, $timeOrYear);
+ $result += compact('timestamp');
+ }
+
+ return $result;
+ }
+
+ /**
+ * Only accurate to the minute (current year), or to the day.
+ *
+ * Inadequacies in timestamp accuracy are due to limitations of the FTP 'LIST' command
+ *
+ * Note: The 'MLSD' command is a machine-readable replacement for 'LIST'
+ * but many FTP servers do not support it :(
+ *
+ * @param string $month e.g. 'Aug'
+ * @param string $day e.g. '19'
+ * @param string $timeOrYear e.g. '09:01' OR '2015'
+ *
+ * @return int
+ */
+ protected function normalizeUnixTimestamp($month, $day, $timeOrYear)
+ {
+ if (is_numeric($timeOrYear)) {
+ $year = $timeOrYear;
+ $hour = '00';
+ $minute = '00';
+ $seconds = '00';
+ } else {
+ $year = date('Y');
+ list($hour, $minute) = explode(':', $timeOrYear);
+ $seconds = '00';
+ }
+ $dateTime = DateTime::createFromFormat('Y-M-j-G:i:s', "{$year}-{$month}-{$day}-{$hour}:{$minute}:{$seconds}");
+
+ return $dateTime->getTimestamp();
+ }
+
+ /**
+ * Normalize a Windows/DOS file entry.
+ *
+ * @param string $item
+ * @param string $base
+ *
+ * @return array normalized file array
+ */
+ protected function normalizeWindowsObject($item, $base)
+ {
+ $item = preg_replace('#\s+#', ' ', trim($item), 3);
+
+ if (count(explode(' ', $item, 4)) !== 4) {
+ throw new RuntimeException("Metadata can't be parsed from item '$item' , not enough parts.");
+ }
+
+ list($date, $time, $size, $name) = explode(' ', $item, 4);
+ $path = $base === '' ? $name : $base . $this->separator . $name;
+
+ // Check for the correct date/time format
+ $format = strlen($date) === 8 ? 'm-d-yH:iA' : 'Y-m-dH:i';
+ $dt = DateTime::createFromFormat($format, $date . $time);
+ $timestamp = $dt ? $dt->getTimestamp() : (int) strtotime("$date $time");
+
+ if ($size === '') {
+ $type = 'dir';
+
+ return compact('type', 'path', 'timestamp');
+ }
+
+ $type = 'file';
+ $visibility = AdapterInterface::VISIBILITY_PUBLIC;
+ $size = (int) $size;
+
+ return compact('type', 'path', 'visibility', 'size', 'timestamp');
+ }
+
+ /**
+ * Get the system type from a listing item.
+ *
+ * @param string $item
+ *
+ * @return string the system type
+ */
+ protected function detectSystemType($item)
+ {
+ return preg_match('/^[0-9]{2,4}-[0-9]{2}-[0-9]{2}/', $item) ? 'windows' : 'unix';
+ }
+
+ /**
+ * Get the file type from the permissions.
+ *
+ * @param string $permissions
+ *
+ * @return string file type
+ */
+ protected function detectType($permissions)
+ {
+ return substr($permissions, 0, 1) === 'd' ? 'dir' : 'file';
+ }
+
+ /**
+ * Normalize a permissions string.
+ *
+ * @param string $permissions
+ *
+ * @return int
+ */
+ protected function normalizePermissions($permissions)
+ {
+ if (is_numeric($permissions)) {
+ return ((int) $permissions) & 0777;
+ }
+
+ // remove the type identifier
+ $permissions = substr($permissions, 1);
+
+ // map the string rights to the numeric counterparts
+ $map = ['-' => '0', 'r' => '4', 'w' => '2', 'x' => '1'];
+ $permissions = strtr($permissions, $map);
+
+ // split up the permission groups
+ $parts = str_split($permissions, 3);
+
+ // convert the groups
+ $mapper = function ($part) {
+ return array_sum(str_split($part));
+ };
+
+ // converts to decimal number
+ return octdec(implode('', array_map($mapper, $parts)));
+ }
+
+ /**
+ * Filter out dot-directories.
+ *
+ * @param array $list
+ *
+ * @return array
+ */
+ public function removeDotDirectories(array $list)
+ {
+ $filter = function ($line) {
+ return $line !== '' && ! preg_match('#.* \.(\.)?$|^total#', $line);
+ };
+
+ return array_filter($list, $filter);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function has($path)
+ {
+ return $this->getMetadata($path);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getSize($path)
+ {
+ return $this->getMetadata($path);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getVisibility($path)
+ {
+ return $this->getMetadata($path);
+ }
+
+ /**
+ * Ensure a directory exists.
+ *
+ * @param string $dirname
+ */
+ public function ensureDirectory($dirname)
+ {
+ $dirname = (string) $dirname;
+
+ if ($dirname !== '' && ! $this->has($dirname)) {
+ $this->createDir($dirname, new Config());
+ }
+ }
+
+ /**
+ * @return mixed
+ */
+ public function getConnection()
+ {
+ $tries = 0;
+
+ while ( ! $this->isConnected() && $tries < 3) {
+ $tries++;
+ $this->disconnect();
+ $this->connect();
+ }
+
+ return $this->connection;
+ }
+
+ /**
+ * Get the public permission value.
+ *
+ * @return int
+ */
+ public function getPermPublic()
+ {
+ return $this->permPublic;
+ }
+
+ /**
+ * Get the private permission value.
+ *
+ * @return int
+ */
+ public function getPermPrivate()
+ {
+ return $this->permPrivate;
+ }
+
+ /**
+ * Disconnect on destruction.
+ */
+ public function __destruct()
+ {
+ $this->disconnect();
+ }
+
+ /**
+ * Establish a connection.
+ */
+ abstract public function connect();
+
+ /**
+ * Close the connection.
+ */
+ abstract public function disconnect();
+
+ /**
+ * Check if a connection is active.
+ *
+ * @return bool
+ */
+ abstract public function isConnected();
+}
diff --git a/vendor/league/flysystem/src/Adapter/CanOverwriteFiles.php b/vendor/league/flysystem/src/Adapter/CanOverwriteFiles.php
new file mode 100644
index 000000000..fd8d2161e
--- /dev/null
+++ b/vendor/league/flysystem/src/Adapter/CanOverwriteFiles.php
@@ -0,0 +1,12 @@
+transferMode = $mode;
+
+ return $this;
+ }
+
+ /**
+ * Set if Ssl is enabled.
+ *
+ * @param bool $ssl
+ *
+ * @return $this
+ */
+ public function setSsl($ssl)
+ {
+ $this->ssl = (bool) $ssl;
+
+ return $this;
+ }
+
+ /**
+ * Set if passive mode should be used.
+ *
+ * @param bool $passive
+ */
+ public function setPassive($passive = true)
+ {
+ $this->passive = $passive;
+ }
+
+ /**
+ * @param bool $ignorePassiveAddress
+ */
+ public function setIgnorePassiveAddress($ignorePassiveAddress)
+ {
+ $this->ignorePassiveAddress = $ignorePassiveAddress;
+ }
+
+ /**
+ * @param bool $recurseManually
+ */
+ public function setRecurseManually($recurseManually)
+ {
+ $this->recurseManually = $recurseManually;
+ }
+
+ /**
+ * @param bool $utf8
+ */
+ public function setUtf8($utf8)
+ {
+ $this->utf8 = (bool) $utf8;
+ }
+
+ /**
+ * Connect to the FTP server.
+ */
+ public function connect()
+ {
+ if ($this->ssl) {
+ $this->connection = @ftp_ssl_connect($this->getHost(), $this->getPort(), $this->getTimeout());
+ } else {
+ $this->connection = @ftp_connect($this->getHost(), $this->getPort(), $this->getTimeout());
+ }
+
+ if ( ! $this->connection) {
+ throw new ConnectionRuntimeException('Could not connect to host: ' . $this->getHost() . ', port:' . $this->getPort());
+ }
+
+ $this->login();
+ $this->setUtf8Mode();
+ $this->setConnectionPassiveMode();
+ $this->setConnectionRoot();
+ $this->isPureFtpd = $this->isPureFtpdServer();
+ }
+
+ /**
+ * Set the connection to UTF-8 mode.
+ */
+ protected function setUtf8Mode()
+ {
+ if ($this->utf8) {
+ $response = ftp_raw($this->connection, "OPTS UTF8 ON");
+ if (substr($response[0], 0, 3) !== '200') {
+ throw new ConnectionRuntimeException(
+ 'Could not set UTF-8 mode for connection: ' . $this->getHost() . '::' . $this->getPort()
+ );
+ }
+ }
+ }
+
+ /**
+ * Set the connections to passive mode.
+ *
+ * @throws ConnectionRuntimeException
+ */
+ protected function setConnectionPassiveMode()
+ {
+ if (is_bool($this->ignorePassiveAddress) && defined('FTP_USEPASVADDRESS')) {
+ ftp_set_option($this->connection, FTP_USEPASVADDRESS, ! $this->ignorePassiveAddress);
+ }
+
+ if ( ! ftp_pasv($this->connection, $this->passive)) {
+ throw new ConnectionRuntimeException(
+ 'Could not set passive mode for connection: ' . $this->getHost() . '::' . $this->getPort()
+ );
+ }
+ }
+
+ /**
+ * Set the connection root.
+ */
+ protected function setConnectionRoot()
+ {
+ $root = $this->getRoot();
+ $connection = $this->connection;
+
+ if ($root && ! ftp_chdir($connection, $root)) {
+ throw new InvalidRootException('Root is invalid or does not exist: ' . $this->getRoot());
+ }
+
+ // Store absolute path for further reference.
+ // This is needed when creating directories and
+ // initial root was a relative path, else the root
+ // would be relative to the chdir'd path.
+ $this->root = ftp_pwd($connection);
+ }
+
+ /**
+ * Login.
+ *
+ * @throws ConnectionRuntimeException
+ */
+ protected function login()
+ {
+ set_error_handler(function () {
+ });
+ $isLoggedIn = ftp_login(
+ $this->connection,
+ $this->getUsername(),
+ $this->getPassword()
+ );
+ restore_error_handler();
+
+ if ( ! $isLoggedIn) {
+ $this->disconnect();
+ throw new ConnectionRuntimeException(
+ 'Could not login with connection: ' . $this->getHost() . '::' . $this->getPort(
+ ) . ', username: ' . $this->getUsername()
+ );
+ }
+ }
+
+ /**
+ * Disconnect from the FTP server.
+ */
+ public function disconnect()
+ {
+ if (is_resource($this->connection)) {
+ @ftp_close($this->connection);
+ }
+
+ $this->connection = null;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function write($path, $contents, Config $config)
+ {
+ $stream = fopen('php://temp', 'w+b');
+ fwrite($stream, $contents);
+ rewind($stream);
+ $result = $this->writeStream($path, $stream, $config);
+ fclose($stream);
+
+ if ($result === false) {
+ return false;
+ }
+
+ $result['contents'] = $contents;
+ $result['mimetype'] = $config->get('mimetype') ?: Util::guessMimeType($path, $contents);
+
+ return $result;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function writeStream($path, $resource, Config $config)
+ {
+ $this->ensureDirectory(Util::dirname($path));
+
+ if ( ! ftp_fput($this->getConnection(), $path, $resource, $this->transferMode)) {
+ return false;
+ }
+
+ if ($visibility = $config->get('visibility')) {
+ $this->setVisibility($path, $visibility);
+ }
+
+ $type = 'file';
+
+ return compact('type', 'path', 'visibility');
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function update($path, $contents, Config $config)
+ {
+ return $this->write($path, $contents, $config);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function updateStream($path, $resource, Config $config)
+ {
+ return $this->writeStream($path, $resource, $config);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function rename($path, $newpath)
+ {
+ return ftp_rename($this->getConnection(), $path, $newpath);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function delete($path)
+ {
+ return ftp_delete($this->getConnection(), $path);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function deleteDir($dirname)
+ {
+ $connection = $this->getConnection();
+ $contents = array_reverse($this->listDirectoryContents($dirname, false));
+
+ foreach ($contents as $object) {
+ if ($object['type'] === 'file') {
+ if ( ! ftp_delete($connection, $object['path'])) {
+ return false;
+ }
+ } elseif ( ! $this->deleteDir($object['path'])) {
+ return false;
+ }
+ }
+
+ return ftp_rmdir($connection, $dirname);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function createDir($dirname, Config $config)
+ {
+ $connection = $this->getConnection();
+ $directories = explode('/', $dirname);
+
+ foreach ($directories as $directory) {
+ if (false === $this->createActualDirectory($directory, $connection)) {
+ $this->setConnectionRoot();
+
+ return false;
+ }
+
+ ftp_chdir($connection, $directory);
+ }
+
+ $this->setConnectionRoot();
+
+ return ['type' => 'dir', 'path' => $dirname];
+ }
+
+ /**
+ * Create a directory.
+ *
+ * @param string $directory
+ * @param resource $connection
+ *
+ * @return bool
+ */
+ protected function createActualDirectory($directory, $connection)
+ {
+ // List the current directory
+ $listing = ftp_nlist($connection, '.') ?: [];
+
+ foreach ($listing as $key => $item) {
+ if (preg_match('~^\./.*~', $item)) {
+ $listing[$key] = substr($item, 2);
+ }
+ }
+
+ if (in_array($directory, $listing, true)) {
+ return true;
+ }
+
+ return (boolean) ftp_mkdir($connection, $directory);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getMetadata($path)
+ {
+ if ($path === '') {
+ return ['type' => 'dir', 'path' => ''];
+ }
+
+ if (@ftp_chdir($this->getConnection(), $path) === true) {
+ $this->setConnectionRoot();
+
+ return ['type' => 'dir', 'path' => $path];
+ }
+
+ $listing = $this->ftpRawlist('-A', str_replace('*', '\\*', $path));
+
+ if (empty($listing) || in_array('total 0', $listing, true)) {
+ return false;
+ }
+
+ if (preg_match('/.* not found/', $listing[0])) {
+ return false;
+ }
+
+ if (preg_match('/^total [0-9]*$/', $listing[0])) {
+ array_shift($listing);
+ }
+
+ return $this->normalizeObject($listing[0], '');
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getMimetype($path)
+ {
+ if ( ! $metadata = $this->getMetadata($path)) {
+ return false;
+ }
+
+ $metadata['mimetype'] = MimeType::detectByFilename($path);
+
+ return $metadata;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getTimestamp($path)
+ {
+ $timestamp = ftp_mdtm($this->getConnection(), $path);
+
+ return ($timestamp !== -1) ? ['path' => $path, 'timestamp' => $timestamp] : false;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function read($path)
+ {
+ if ( ! $object = $this->readStream($path)) {
+ return false;
+ }
+
+ $object['contents'] = stream_get_contents($object['stream']);
+ fclose($object['stream']);
+ unset($object['stream']);
+
+ return $object;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function readStream($path)
+ {
+ $stream = fopen('php://temp', 'w+b');
+ $result = ftp_fget($this->getConnection(), $stream, $path, $this->transferMode);
+ rewind($stream);
+
+ if ( ! $result) {
+ fclose($stream);
+
+ return false;
+ }
+
+ return ['type' => 'file', 'path' => $path, 'stream' => $stream];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function setVisibility($path, $visibility)
+ {
+ $mode = $visibility === AdapterInterface::VISIBILITY_PUBLIC ? $this->getPermPublic() : $this->getPermPrivate();
+
+ if ( ! ftp_chmod($this->getConnection(), $mode, $path)) {
+ return false;
+ }
+
+ return compact('path', 'visibility');
+ }
+
+ /**
+ * @inheritdoc
+ *
+ * @param string $directory
+ */
+ protected function listDirectoryContents($directory, $recursive = true)
+ {
+ $directory = str_replace('*', '\\*', $directory);
+
+ if ($recursive && $this->recurseManually) {
+ return $this->listDirectoryContentsRecursive($directory);
+ }
+
+ $options = $recursive ? '-alnR' : '-aln';
+ $listing = $this->ftpRawlist($options, $directory);
+
+ return $listing ? $this->normalizeListing($listing, $directory) : [];
+ }
+
+ /**
+ * @inheritdoc
+ *
+ * @param string $directory
+ */
+ protected function listDirectoryContentsRecursive($directory)
+ {
+ $listing = $this->normalizeListing($this->ftpRawlist('-aln', $directory) ?: [], $directory);
+ $output = [];
+
+ foreach ($listing as $item) {
+ $output[] = $item;
+ if ($item['type'] !== 'dir') {
+ continue;
+ }
+ $output = array_merge($output, $this->listDirectoryContentsRecursive($item['path']));
+ }
+
+ return $output;
+ }
+
+ /**
+ * Check if the connection is open.
+ *
+ * @return bool
+ *
+ * @throws ConnectionErrorException
+ */
+ public function isConnected()
+ {
+ return is_resource($this->connection)
+ && $this->getRawExecResponseCode('NOOP') === 200;
+ }
+
+ /**
+ * @return bool
+ */
+ protected function isPureFtpdServer()
+ {
+ $response = ftp_raw($this->connection, 'HELP');
+
+ return stripos(implode(' ', $response), 'Pure-FTPd') !== false;
+ }
+
+ /**
+ * The ftp_rawlist function with optional escaping.
+ *
+ * @param string $options
+ * @param string $path
+ *
+ * @return array
+ */
+ protected function ftpRawlist($options, $path)
+ {
+ $connection = $this->getConnection();
+
+ if ($this->isPureFtpd) {
+ $path = str_replace(' ', '\ ', $path);
+ }
+
+ return ftp_rawlist($connection, $options . ' ' . $path);
+ }
+
+ private function getRawExecResponseCode($command)
+ {
+ $response = @ftp_raw($this->connection, trim($command));
+
+ return (int) preg_replace('/\D/', '', implode(' ', $response));
+ }
+}
diff --git a/vendor/league/flysystem/src/Adapter/Ftpd.php b/vendor/league/flysystem/src/Adapter/Ftpd.php
new file mode 100644
index 000000000..d5349e475
--- /dev/null
+++ b/vendor/league/flysystem/src/Adapter/Ftpd.php
@@ -0,0 +1,45 @@
+ 'dir', 'path' => ''];
+ }
+ if (@ftp_chdir($this->getConnection(), $path) === true) {
+ $this->setConnectionRoot();
+
+ return ['type' => 'dir', 'path' => $path];
+ }
+
+ if ( ! ($object = ftp_raw($this->getConnection(), 'STAT ' . $path)) || count($object) < 3) {
+ return false;
+ }
+
+ if (substr($object[1], 0, 5) === "ftpd:") {
+ return false;
+ }
+
+ return $this->normalizeObject($object[1], '');
+ }
+
+ /**
+ * @inheritdoc
+ */
+ protected function listDirectoryContents($directory, $recursive = true)
+ {
+ $listing = ftp_rawlist($this->getConnection(), $directory, $recursive);
+
+ if ($listing === false || ( ! empty($listing) && substr($listing[0], 0, 5) === "ftpd:")) {
+ return [];
+ }
+
+ return $this->normalizeListing($listing, $directory);
+ }
+}
diff --git a/vendor/league/flysystem/src/Adapter/Local.php b/vendor/league/flysystem/src/Adapter/Local.php
new file mode 100644
index 000000000..747c463ec
--- /dev/null
+++ b/vendor/league/flysystem/src/Adapter/Local.php
@@ -0,0 +1,533 @@
+ [
+ 'public' => 0644,
+ 'private' => 0600,
+ ],
+ 'dir' => [
+ 'public' => 0755,
+ 'private' => 0700,
+ ],
+ ];
+
+ /**
+ * @var string
+ */
+ protected $pathSeparator = DIRECTORY_SEPARATOR;
+
+ /**
+ * @var array
+ */
+ protected $permissionMap;
+
+ /**
+ * @var int
+ */
+ protected $writeFlags;
+
+ /**
+ * @var int
+ */
+ private $linkHandling;
+
+ /**
+ * Constructor.
+ *
+ * @param string $root
+ * @param int $writeFlags
+ * @param int $linkHandling
+ * @param array $permissions
+ *
+ * @throws LogicException
+ */
+ public function __construct($root, $writeFlags = LOCK_EX, $linkHandling = self::DISALLOW_LINKS, array $permissions = [])
+ {
+ $root = is_link($root) ? realpath($root) : $root;
+ $this->permissionMap = array_replace_recursive(static::$permissions, $permissions);
+ $this->ensureDirectory($root);
+
+ if ( ! is_dir($root) || ! is_readable($root)) {
+ throw new LogicException('The root path ' . $root . ' is not readable.');
+ }
+
+ $this->setPathPrefix($root);
+ $this->writeFlags = $writeFlags;
+ $this->linkHandling = $linkHandling;
+ }
+
+ /**
+ * Ensure the root directory exists.
+ *
+ * @param string $root root directory path
+ *
+ * @return void
+ *
+ * @throws Exception in case the root directory can not be created
+ */
+ protected function ensureDirectory($root)
+ {
+ if ( ! is_dir($root)) {
+ $umask = umask(0);
+
+ if ( ! @mkdir($root, $this->permissionMap['dir']['public'], true)) {
+ $mkdirError = error_get_last();
+ }
+
+ umask($umask);
+ clearstatcache(false, $root);
+
+ if ( ! is_dir($root)) {
+ $errorMessage = isset($mkdirError['message']) ? $mkdirError['message'] : '';
+ throw new Exception(sprintf('Impossible to create the root directory "%s". %s', $root, $errorMessage));
+ }
+ }
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function has($path)
+ {
+ $location = $this->applyPathPrefix($path);
+
+ return file_exists($location);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function write($path, $contents, Config $config)
+ {
+ $location = $this->applyPathPrefix($path);
+ $this->ensureDirectory(dirname($location));
+
+ if (($size = file_put_contents($location, $contents, $this->writeFlags)) === false) {
+ return false;
+ }
+
+ $type = 'file';
+ $result = compact('contents', 'type', 'size', 'path');
+
+ if ($visibility = $config->get('visibility')) {
+ $result['visibility'] = $visibility;
+ $this->setVisibility($path, $visibility);
+ }
+
+ return $result;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function writeStream($path, $resource, Config $config)
+ {
+ $location = $this->applyPathPrefix($path);
+ $this->ensureDirectory(dirname($location));
+ $stream = fopen($location, 'w+b');
+
+ if ( ! $stream || stream_copy_to_stream($resource, $stream) === false || ! fclose($stream)) {
+ return false;
+ }
+
+ $type = 'file';
+ $result = compact('type', 'path');
+
+ if ($visibility = $config->get('visibility')) {
+ $this->setVisibility($path, $visibility);
+ $result['visibility'] = $visibility;
+ }
+
+ return $result;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function readStream($path)
+ {
+ $location = $this->applyPathPrefix($path);
+ $stream = fopen($location, 'rb');
+
+ return ['type' => 'file', 'path' => $path, 'stream' => $stream];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function updateStream($path, $resource, Config $config)
+ {
+ return $this->writeStream($path, $resource, $config);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function update($path, $contents, Config $config)
+ {
+ $location = $this->applyPathPrefix($path);
+ $size = file_put_contents($location, $contents, $this->writeFlags);
+
+ if ($size === false) {
+ return false;
+ }
+
+ $type = 'file';
+
+ $result = compact('type', 'path', 'size', 'contents');
+
+ if ($visibility = $config->get('visibility')) {
+ $this->setVisibility($path, $visibility);
+ $result['visibility'] = $visibility;
+ }
+
+ return $result;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function read($path)
+ {
+ $location = $this->applyPathPrefix($path);
+ $contents = @file_get_contents($location);
+
+ if ($contents === false) {
+ return false;
+ }
+
+ return ['type' => 'file', 'path' => $path, 'contents' => $contents];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function rename($path, $newpath)
+ {
+ $location = $this->applyPathPrefix($path);
+ $destination = $this->applyPathPrefix($newpath);
+ $parentDirectory = $this->applyPathPrefix(Util::dirname($newpath));
+ $this->ensureDirectory($parentDirectory);
+
+ return rename($location, $destination);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function copy($path, $newpath)
+ {
+ $location = $this->applyPathPrefix($path);
+ $destination = $this->applyPathPrefix($newpath);
+ $this->ensureDirectory(dirname($destination));
+
+ return copy($location, $destination);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function delete($path)
+ {
+ $location = $this->applyPathPrefix($path);
+
+ return @unlink($location);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function listContents($directory = '', $recursive = false)
+ {
+ $result = [];
+ $location = $this->applyPathPrefix($directory);
+
+ if ( ! is_dir($location)) {
+ return [];
+ }
+
+ $iterator = $recursive ? $this->getRecursiveDirectoryIterator($location) : $this->getDirectoryIterator($location);
+
+ foreach ($iterator as $file) {
+ $path = $this->getFilePath($file);
+
+ if (preg_match('#(^|/|\\\\)\.{1,2}$#', $path)) {
+ continue;
+ }
+
+ $result[] = $this->normalizeFileInfo($file);
+ }
+
+ unset($iterator);
+
+ return array_filter($result);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getMetadata($path)
+ {
+ $location = $this->applyPathPrefix($path);
+ clearstatcache(false, $location);
+ $info = new SplFileInfo($location);
+
+ return $this->normalizeFileInfo($info);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getSize($path)
+ {
+ return $this->getMetadata($path);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getMimetype($path)
+ {
+ $location = $this->applyPathPrefix($path);
+ $finfo = new Finfo(FILEINFO_MIME_TYPE);
+ $mimetype = $finfo->file($location);
+
+ if (in_array($mimetype, ['application/octet-stream', 'inode/x-empty', 'application/x-empty'])) {
+ $mimetype = Util\MimeType::detectByFilename($location);
+ }
+
+ return ['path' => $path, 'type' => 'file', 'mimetype' => $mimetype];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getTimestamp($path)
+ {
+ return $this->getMetadata($path);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getVisibility($path)
+ {
+ $location = $this->applyPathPrefix($path);
+ clearstatcache(false, $location);
+ $permissions = octdec(substr(sprintf('%o', fileperms($location)), -4));
+ $type = is_dir($location) ? 'dir' : 'file';
+
+ foreach ($this->permissionMap[$type] as $visibility => $visibilityPermissions) {
+ if ($visibilityPermissions == $permissions) {
+ return compact('path', 'visibility');
+ }
+ }
+
+ $visibility = substr(sprintf('%o', fileperms($location)), -4);
+
+ return compact('path', 'visibility');
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function setVisibility($path, $visibility)
+ {
+ $location = $this->applyPathPrefix($path);
+ $type = is_dir($location) ? 'dir' : 'file';
+ $success = chmod($location, $this->permissionMap[$type][$visibility]);
+
+ if ($success === false) {
+ return false;
+ }
+
+ return compact('path', 'visibility');
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function createDir($dirname, Config $config)
+ {
+ $location = $this->applyPathPrefix($dirname);
+ $umask = umask(0);
+ $visibility = $config->get('visibility', 'public');
+ $return = ['path' => $dirname, 'type' => 'dir'];
+
+ if ( ! is_dir($location)) {
+ if (false === @mkdir($location, $this->permissionMap['dir'][$visibility], true)
+ || false === is_dir($location)) {
+ $return = false;
+ }
+ }
+
+ umask($umask);
+
+ return $return;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function deleteDir($dirname)
+ {
+ $location = $this->applyPathPrefix($dirname);
+
+ if ( ! is_dir($location)) {
+ return false;
+ }
+
+ $contents = $this->getRecursiveDirectoryIterator($location, RecursiveIteratorIterator::CHILD_FIRST);
+
+ /** @var SplFileInfo $file */
+ foreach ($contents as $file) {
+ $this->guardAgainstUnreadableFileInfo($file);
+ $this->deleteFileInfoObject($file);
+ }
+
+ unset($contents);
+
+ return rmdir($location);
+ }
+
+ /**
+ * @param SplFileInfo $file
+ */
+ protected function deleteFileInfoObject(SplFileInfo $file)
+ {
+ switch ($file->getType()) {
+ case 'dir':
+ rmdir($file->getRealPath());
+ break;
+ case 'link':
+ unlink($file->getPathname());
+ break;
+ default:
+ unlink($file->getRealPath());
+ }
+ }
+
+ /**
+ * Normalize the file info.
+ *
+ * @param SplFileInfo $file
+ *
+ * @return array|void
+ *
+ * @throws NotSupportedException
+ */
+ protected function normalizeFileInfo(SplFileInfo $file)
+ {
+ if ( ! $file->isLink()) {
+ return $this->mapFileInfo($file);
+ }
+
+ if ($this->linkHandling & self::DISALLOW_LINKS) {
+ throw NotSupportedException::forLink($file);
+ }
+ }
+
+ /**
+ * Get the normalized path from a SplFileInfo object.
+ *
+ * @param SplFileInfo $file
+ *
+ * @return string
+ */
+ protected function getFilePath(SplFileInfo $file)
+ {
+ $location = $file->getPathname();
+ $path = $this->removePathPrefix($location);
+
+ return trim(str_replace('\\', '/', $path), '/');
+ }
+
+ /**
+ * @param string $path
+ * @param int $mode
+ *
+ * @return RecursiveIteratorIterator
+ */
+ protected function getRecursiveDirectoryIterator($path, $mode = RecursiveIteratorIterator::SELF_FIRST)
+ {
+ return new RecursiveIteratorIterator(
+ new RecursiveDirectoryIterator($path, FilesystemIterator::SKIP_DOTS),
+ $mode
+ );
+ }
+
+ /**
+ * @param string $path
+ *
+ * @return DirectoryIterator
+ */
+ protected function getDirectoryIterator($path)
+ {
+ $iterator = new DirectoryIterator($path);
+
+ return $iterator;
+ }
+
+ /**
+ * @param SplFileInfo $file
+ *
+ * @return array
+ */
+ protected function mapFileInfo(SplFileInfo $file)
+ {
+ $normalized = [
+ 'type' => $file->getType(),
+ 'path' => $this->getFilePath($file),
+ ];
+
+ $normalized['timestamp'] = $file->getMTime();
+
+ if ($normalized['type'] === 'file') {
+ $normalized['size'] = $file->getSize();
+ }
+
+ return $normalized;
+ }
+
+ /**
+ * @param SplFileInfo $file
+ *
+ * @throws UnreadableFileException
+ */
+ protected function guardAgainstUnreadableFileInfo(SplFileInfo $file)
+ {
+ if ( ! $file->isReadable()) {
+ throw UnreadableFileException::forFileInfo($file);
+ }
+ }
+}
diff --git a/vendor/league/flysystem/src/Adapter/NullAdapter.php b/vendor/league/flysystem/src/Adapter/NullAdapter.php
new file mode 100644
index 000000000..2527087f7
--- /dev/null
+++ b/vendor/league/flysystem/src/Adapter/NullAdapter.php
@@ -0,0 +1,144 @@
+get('visibility')) {
+ $result['visibility'] = $visibility;
+ }
+
+ return $result;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function update($path, $contents, Config $config)
+ {
+ return false;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function read($path)
+ {
+ return false;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function rename($path, $newpath)
+ {
+ return false;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function delete($path)
+ {
+ return false;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function listContents($directory = '', $recursive = false)
+ {
+ return [];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getMetadata($path)
+ {
+ return false;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getSize($path)
+ {
+ return false;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getMimetype($path)
+ {
+ return false;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getTimestamp($path)
+ {
+ return false;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getVisibility($path)
+ {
+ return false;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function setVisibility($path, $visibility)
+ {
+ return compact('visibility');
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function createDir($dirname, Config $config)
+ {
+ return ['path' => $dirname, 'type' => 'dir'];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function deleteDir($dirname)
+ {
+ return false;
+ }
+}
diff --git a/vendor/league/flysystem/src/Adapter/Polyfill/NotSupportingVisibilityTrait.php b/vendor/league/flysystem/src/Adapter/Polyfill/NotSupportingVisibilityTrait.php
new file mode 100644
index 000000000..fc0a747ac
--- /dev/null
+++ b/vendor/league/flysystem/src/Adapter/Polyfill/NotSupportingVisibilityTrait.php
@@ -0,0 +1,33 @@
+readStream($path);
+
+ if ($response === false || ! is_resource($response['stream'])) {
+ return false;
+ }
+
+ $result = $this->writeStream($newpath, $response['stream'], new Config());
+
+ if ($result !== false && is_resource($response['stream'])) {
+ fclose($response['stream']);
+ }
+
+ return $result !== false;
+ }
+
+ // Required abstract method
+
+ /**
+ * @param string $path
+ *
+ * @return resource
+ */
+ abstract public function readStream($path);
+
+ /**
+ * @param string $path
+ * @param resource $resource
+ * @param Config $config
+ *
+ * @return resource
+ */
+ abstract public function writeStream($path, $resource, Config $config);
+}
diff --git a/vendor/league/flysystem/src/Adapter/Polyfill/StreamedReadingTrait.php b/vendor/league/flysystem/src/Adapter/Polyfill/StreamedReadingTrait.php
new file mode 100644
index 000000000..2b31c01d6
--- /dev/null
+++ b/vendor/league/flysystem/src/Adapter/Polyfill/StreamedReadingTrait.php
@@ -0,0 +1,44 @@
+read($path)) {
+ return false;
+ }
+
+ $stream = fopen('php://temp', 'w+b');
+ fwrite($stream, $data['contents']);
+ rewind($stream);
+ $data['stream'] = $stream;
+ unset($data['contents']);
+
+ return $data;
+ }
+
+ /**
+ * Reads a file.
+ *
+ * @param string $path
+ *
+ * @return array|false
+ *
+ * @see League\Flysystem\ReadInterface::read()
+ */
+ abstract public function read($path);
+}
diff --git a/vendor/league/flysystem/src/Adapter/Polyfill/StreamedTrait.php b/vendor/league/flysystem/src/Adapter/Polyfill/StreamedTrait.php
new file mode 100644
index 000000000..80424960c
--- /dev/null
+++ b/vendor/league/flysystem/src/Adapter/Polyfill/StreamedTrait.php
@@ -0,0 +1,9 @@
+stream($path, $resource, $config, 'write');
+ }
+
+ /**
+ * Update a file using a stream.
+ *
+ * @param string $path
+ * @param resource $resource
+ * @param Config $config Config object or visibility setting
+ *
+ * @return mixed false of file metadata
+ */
+ public function updateStream($path, $resource, Config $config)
+ {
+ return $this->stream($path, $resource, $config, 'update');
+ }
+
+ // Required abstract methods
+ abstract public function write($pash, $contents, Config $config);
+ abstract public function update($pash, $contents, Config $config);
+}
diff --git a/vendor/league/flysystem/src/Adapter/SynologyFtp.php b/vendor/league/flysystem/src/Adapter/SynologyFtp.php
new file mode 100644
index 000000000..fe0d344cf
--- /dev/null
+++ b/vendor/league/flysystem/src/Adapter/SynologyFtp.php
@@ -0,0 +1,8 @@
+settings = $settings;
+ }
+
+ /**
+ * Get a setting.
+ *
+ * @param string $key
+ * @param mixed $default
+ *
+ * @return mixed config setting or default when not found
+ */
+ public function get($key, $default = null)
+ {
+ if ( ! array_key_exists($key, $this->settings)) {
+ return $this->getDefault($key, $default);
+ }
+
+ return $this->settings[$key];
+ }
+
+ /**
+ * Check if an item exists by key.
+ *
+ * @param string $key
+ *
+ * @return bool
+ */
+ public function has($key)
+ {
+ if (array_key_exists($key, $this->settings)) {
+ return true;
+ }
+
+ return $this->fallback instanceof Config
+ ? $this->fallback->has($key)
+ : false;
+ }
+
+ /**
+ * Try to retrieve a default setting from a config fallback.
+ *
+ * @param string $key
+ * @param mixed $default
+ *
+ * @return mixed config setting or default when not found
+ */
+ protected function getDefault($key, $default)
+ {
+ if ( ! $this->fallback) {
+ return $default;
+ }
+
+ return $this->fallback->get($key, $default);
+ }
+
+ /**
+ * Set a setting.
+ *
+ * @param string $key
+ * @param mixed $value
+ *
+ * @return $this
+ */
+ public function set($key, $value)
+ {
+ $this->settings[$key] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set the fallback.
+ *
+ * @param Config $fallback
+ *
+ * @return $this
+ */
+ public function setFallback(Config $fallback)
+ {
+ $this->fallback = $fallback;
+
+ return $this;
+ }
+}
diff --git a/vendor/league/flysystem/src/ConfigAwareTrait.php b/vendor/league/flysystem/src/ConfigAwareTrait.php
new file mode 100644
index 000000000..202d605da
--- /dev/null
+++ b/vendor/league/flysystem/src/ConfigAwareTrait.php
@@ -0,0 +1,49 @@
+config = $config ? Util::ensureConfig($config) : new Config;
+ }
+
+ /**
+ * Get the Config.
+ *
+ * @return Config config object
+ */
+ public function getConfig()
+ {
+ return $this->config;
+ }
+
+ /**
+ * Convert a config array to a Config object with the correct fallback.
+ *
+ * @param array $config
+ *
+ * @return Config
+ */
+ protected function prepareConfig(array $config)
+ {
+ $config = new Config($config);
+ $config->setFallback($this->getConfig());
+
+ return $config;
+ }
+}
diff --git a/vendor/league/flysystem/src/ConnectionErrorException.php b/vendor/league/flysystem/src/ConnectionErrorException.php
new file mode 100644
index 000000000..adb651d3d
--- /dev/null
+++ b/vendor/league/flysystem/src/ConnectionErrorException.php
@@ -0,0 +1,9 @@
+filesystem->deleteDir($this->path);
+ }
+
+ /**
+ * List the directory contents.
+ *
+ * @param bool $recursive
+ *
+ * @return array|bool directory contents or false
+ */
+ public function getContents($recursive = false)
+ {
+ return $this->filesystem->listContents($this->path, $recursive);
+ }
+}
diff --git a/vendor/league/flysystem/src/Exception.php b/vendor/league/flysystem/src/Exception.php
new file mode 100644
index 000000000..4596c0a9a
--- /dev/null
+++ b/vendor/league/flysystem/src/Exception.php
@@ -0,0 +1,8 @@
+filesystem->has($this->path);
+ }
+
+ /**
+ * Read the file.
+ *
+ * @return string|false file contents
+ */
+ public function read()
+ {
+ return $this->filesystem->read($this->path);
+ }
+
+ /**
+ * Read the file as a stream.
+ *
+ * @return resource|false file stream
+ */
+ public function readStream()
+ {
+ return $this->filesystem->readStream($this->path);
+ }
+
+ /**
+ * Write the new file.
+ *
+ * @param string $content
+ *
+ * @return bool success boolean
+ */
+ public function write($content)
+ {
+ return $this->filesystem->write($this->path, $content);
+ }
+
+ /**
+ * Write the new file using a stream.
+ *
+ * @param resource $resource
+ *
+ * @return bool success boolean
+ */
+ public function writeStream($resource)
+ {
+ return $this->filesystem->writeStream($this->path, $resource);
+ }
+
+ /**
+ * Update the file contents.
+ *
+ * @param string $content
+ *
+ * @return bool success boolean
+ */
+ public function update($content)
+ {
+ return $this->filesystem->update($this->path, $content);
+ }
+
+ /**
+ * Update the file contents with a stream.
+ *
+ * @param resource $resource
+ *
+ * @return bool success boolean
+ */
+ public function updateStream($resource)
+ {
+ return $this->filesystem->updateStream($this->path, $resource);
+ }
+
+ /**
+ * Create the file or update if exists.
+ *
+ * @param string $content
+ *
+ * @return bool success boolean
+ */
+ public function put($content)
+ {
+ return $this->filesystem->put($this->path, $content);
+ }
+
+ /**
+ * Create the file or update if exists using a stream.
+ *
+ * @param resource $resource
+ *
+ * @return bool success boolean
+ */
+ public function putStream($resource)
+ {
+ return $this->filesystem->putStream($this->path, $resource);
+ }
+
+ /**
+ * Rename the file.
+ *
+ * @param string $newpath
+ *
+ * @return bool success boolean
+ */
+ public function rename($newpath)
+ {
+ if ($this->filesystem->rename($this->path, $newpath)) {
+ $this->path = $newpath;
+
+ return true;
+ }
+
+ return false;
+ }
+
+ /**
+ * Copy the file.
+ *
+ * @param string $newpath
+ *
+ * @return File|false new file or false
+ */
+ public function copy($newpath)
+ {
+ if ($this->filesystem->copy($this->path, $newpath)) {
+ return new File($this->filesystem, $newpath);
+ }
+
+ return false;
+ }
+
+ /**
+ * Get the file's timestamp.
+ *
+ * @return string|false The timestamp or false on failure.
+ */
+ public function getTimestamp()
+ {
+ return $this->filesystem->getTimestamp($this->path);
+ }
+
+ /**
+ * Get the file's mimetype.
+ *
+ * @return string|false The file mime-type or false on failure.
+ */
+ public function getMimetype()
+ {
+ return $this->filesystem->getMimetype($this->path);
+ }
+
+ /**
+ * Get the file's visibility.
+ *
+ * @return string|false The visibility (public|private) or false on failure.
+ */
+ public function getVisibility()
+ {
+ return $this->filesystem->getVisibility($this->path);
+ }
+
+ /**
+ * Get the file's metadata.
+ *
+ * @return array|false The file metadata or false on failure.
+ */
+ public function getMetadata()
+ {
+ return $this->filesystem->getMetadata($this->path);
+ }
+
+ /**
+ * Get the file size.
+ *
+ * @return int|false The file size or false on failure.
+ */
+ public function getSize()
+ {
+ return $this->filesystem->getSize($this->path);
+ }
+
+ /**
+ * Delete the file.
+ *
+ * @return bool success boolean
+ */
+ public function delete()
+ {
+ return $this->filesystem->delete($this->path);
+ }
+}
diff --git a/vendor/league/flysystem/src/FileExistsException.php b/vendor/league/flysystem/src/FileExistsException.php
new file mode 100644
index 000000000..c82e20c16
--- /dev/null
+++ b/vendor/league/flysystem/src/FileExistsException.php
@@ -0,0 +1,37 @@
+path = $path;
+
+ parent::__construct('File already exists at path: ' . $this->getPath(), $code, $previous);
+ }
+
+ /**
+ * Get the path which was found.
+ *
+ * @return string
+ */
+ public function getPath()
+ {
+ return $this->path;
+ }
+}
diff --git a/vendor/league/flysystem/src/FileNotFoundException.php b/vendor/league/flysystem/src/FileNotFoundException.php
new file mode 100644
index 000000000..989df69bb
--- /dev/null
+++ b/vendor/league/flysystem/src/FileNotFoundException.php
@@ -0,0 +1,37 @@
+path = $path;
+
+ parent::__construct('File not found at path: ' . $this->getPath(), $code, $previous);
+ }
+
+ /**
+ * Get the path which was not found.
+ *
+ * @return string
+ */
+ public function getPath()
+ {
+ return $this->path;
+ }
+}
diff --git a/vendor/league/flysystem/src/Filesystem.php b/vendor/league/flysystem/src/Filesystem.php
new file mode 100644
index 000000000..0ce24845a
--- /dev/null
+++ b/vendor/league/flysystem/src/Filesystem.php
@@ -0,0 +1,408 @@
+adapter = $adapter;
+ $this->setConfig($config);
+ }
+
+ /**
+ * Get the Adapter.
+ *
+ * @return AdapterInterface adapter
+ */
+ public function getAdapter()
+ {
+ return $this->adapter;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function has($path)
+ {
+ $path = Util::normalizePath($path);
+
+ return strlen($path) === 0 ? false : (bool) $this->getAdapter()->has($path);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function write($path, $contents, array $config = [])
+ {
+ $path = Util::normalizePath($path);
+ $this->assertAbsent($path);
+ $config = $this->prepareConfig($config);
+
+ return (bool) $this->getAdapter()->write($path, $contents, $config);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function writeStream($path, $resource, array $config = [])
+ {
+ if ( ! is_resource($resource)) {
+ throw new InvalidArgumentException(__METHOD__ . ' expects argument #2 to be a valid resource.');
+ }
+
+ $path = Util::normalizePath($path);
+ $this->assertAbsent($path);
+ $config = $this->prepareConfig($config);
+
+ Util::rewindStream($resource);
+
+ return (bool) $this->getAdapter()->writeStream($path, $resource, $config);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function put($path, $contents, array $config = [])
+ {
+ $path = Util::normalizePath($path);
+ $config = $this->prepareConfig($config);
+
+ if ( ! $this->getAdapter() instanceof CanOverwriteFiles && $this->has($path)) {
+ return (bool) $this->getAdapter()->update($path, $contents, $config);
+ }
+
+ return (bool) $this->getAdapter()->write($path, $contents, $config);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function putStream($path, $resource, array $config = [])
+ {
+ if ( ! is_resource($resource)) {
+ throw new InvalidArgumentException(__METHOD__ . ' expects argument #2 to be a valid resource.');
+ }
+
+ $path = Util::normalizePath($path);
+ $config = $this->prepareConfig($config);
+ Util::rewindStream($resource);
+
+ if ( ! $this->getAdapter() instanceof CanOverwriteFiles && $this->has($path)) {
+ return (bool) $this->getAdapter()->updateStream($path, $resource, $config);
+ }
+
+ return (bool) $this->getAdapter()->writeStream($path, $resource, $config);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function readAndDelete($path)
+ {
+ $path = Util::normalizePath($path);
+ $this->assertPresent($path);
+ $contents = $this->read($path);
+
+ if ($contents === false) {
+ return false;
+ }
+
+ $this->delete($path);
+
+ return $contents;
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function update($path, $contents, array $config = [])
+ {
+ $path = Util::normalizePath($path);
+ $config = $this->prepareConfig($config);
+
+ $this->assertPresent($path);
+
+ return (bool) $this->getAdapter()->update($path, $contents, $config);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function updateStream($path, $resource, array $config = [])
+ {
+ if ( ! is_resource($resource)) {
+ throw new InvalidArgumentException(__METHOD__ . ' expects argument #2 to be a valid resource.');
+ }
+
+ $path = Util::normalizePath($path);
+ $config = $this->prepareConfig($config);
+ $this->assertPresent($path);
+ Util::rewindStream($resource);
+
+ return (bool) $this->getAdapter()->updateStream($path, $resource, $config);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function read($path)
+ {
+ $path = Util::normalizePath($path);
+ $this->assertPresent($path);
+
+ if ( ! ($object = $this->getAdapter()->read($path))) {
+ return false;
+ }
+
+ return $object['contents'];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function readStream($path)
+ {
+ $path = Util::normalizePath($path);
+ $this->assertPresent($path);
+
+ if ( ! $object = $this->getAdapter()->readStream($path)) {
+ return false;
+ }
+
+ return $object['stream'];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function rename($path, $newpath)
+ {
+ $path = Util::normalizePath($path);
+ $newpath = Util::normalizePath($newpath);
+ $this->assertPresent($path);
+ $this->assertAbsent($newpath);
+
+ return (bool) $this->getAdapter()->rename($path, $newpath);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function copy($path, $newpath)
+ {
+ $path = Util::normalizePath($path);
+ $newpath = Util::normalizePath($newpath);
+ $this->assertPresent($path);
+ $this->assertAbsent($newpath);
+
+ return $this->getAdapter()->copy($path, $newpath);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function delete($path)
+ {
+ $path = Util::normalizePath($path);
+ $this->assertPresent($path);
+
+ return $this->getAdapter()->delete($path);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function deleteDir($dirname)
+ {
+ $dirname = Util::normalizePath($dirname);
+
+ if ($dirname === '') {
+ throw new RootViolationException('Root directories can not be deleted.');
+ }
+
+ return (bool) $this->getAdapter()->deleteDir($dirname);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function createDir($dirname, array $config = [])
+ {
+ $dirname = Util::normalizePath($dirname);
+ $config = $this->prepareConfig($config);
+
+ return (bool) $this->getAdapter()->createDir($dirname, $config);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function listContents($directory = '', $recursive = false)
+ {
+ $directory = Util::normalizePath($directory);
+ $contents = $this->getAdapter()->listContents($directory, $recursive);
+
+ return (new ContentListingFormatter($directory, $recursive, $this->config->get('case_sensitive', true)))
+ ->formatListing($contents);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getMimetype($path)
+ {
+ $path = Util::normalizePath($path);
+ $this->assertPresent($path);
+
+ if (( ! $object = $this->getAdapter()->getMimetype($path)) || ! array_key_exists('mimetype', $object)) {
+ return false;
+ }
+
+ return $object['mimetype'];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getTimestamp($path)
+ {
+ $path = Util::normalizePath($path);
+ $this->assertPresent($path);
+
+ if (( ! $object = $this->getAdapter()->getTimestamp($path)) || ! array_key_exists('timestamp', $object)) {
+ return false;
+ }
+
+ return (int) $object['timestamp'];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getVisibility($path)
+ {
+ $path = Util::normalizePath($path);
+ $this->assertPresent($path);
+
+ if (( ! $object = $this->getAdapter()->getVisibility($path)) || ! array_key_exists('visibility', $object)) {
+ return false;
+ }
+
+ return $object['visibility'];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getSize($path)
+ {
+ $path = Util::normalizePath($path);
+ $this->assertPresent($path);
+
+ if (( ! $object = $this->getAdapter()->getSize($path)) || ! array_key_exists('size', $object)) {
+ return false;
+ }
+
+ return (int) $object['size'];
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function setVisibility($path, $visibility)
+ {
+ $path = Util::normalizePath($path);
+ $this->assertPresent($path);
+
+ return (bool) $this->getAdapter()->setVisibility($path, $visibility);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function getMetadata($path)
+ {
+ $path = Util::normalizePath($path);
+ $this->assertPresent($path);
+
+ return $this->getAdapter()->getMetadata($path);
+ }
+
+ /**
+ * @inheritdoc
+ */
+ public function get($path, Handler $handler = null)
+ {
+ $path = Util::normalizePath($path);
+
+ if ( ! $handler) {
+ $metadata = $this->getMetadata($path);
+ $handler = ($metadata && $metadata['type'] === 'file') ? new File($this, $path) : new Directory($this, $path);
+ }
+
+ $handler->setPath($path);
+ $handler->setFilesystem($this);
+
+ return $handler;
+ }
+
+ /**
+ * Assert a file is present.
+ *
+ * @param string $path path to file
+ *
+ * @throws FileNotFoundException
+ *
+ * @return void
+ */
+ public function assertPresent($path)
+ {
+ if ($this->config->get('disable_asserts', false) === false && ! $this->has($path)) {
+ throw new FileNotFoundException($path);
+ }
+ }
+
+ /**
+ * Assert a file is absent.
+ *
+ * @param string $path path to file
+ *
+ * @throws FileExistsException
+ *
+ * @return void
+ */
+ public function assertAbsent($path)
+ {
+ if ($this->config->get('disable_asserts', false) === false && $this->has($path)) {
+ throw new FileExistsException($path);
+ }
+ }
+}
diff --git a/vendor/league/flysystem/src/FilesystemException.php b/vendor/league/flysystem/src/FilesystemException.php
new file mode 100644
index 000000000..3121e533d
--- /dev/null
+++ b/vendor/league/flysystem/src/FilesystemException.php
@@ -0,0 +1,7 @@
+path = $path;
+ $this->filesystem = $filesystem;
+ }
+
+ /**
+ * Check whether the entree is a directory.
+ *
+ * @return bool
+ */
+ public function isDir()
+ {
+ return $this->getType() === 'dir';
+ }
+
+ /**
+ * Check whether the entree is a file.
+ *
+ * @return bool
+ */
+ public function isFile()
+ {
+ return $this->getType() === 'file';
+ }
+
+ /**
+ * Retrieve the entree type (file|dir).
+ *
+ * @return string file or dir
+ */
+ public function getType()
+ {
+ $metadata = $this->filesystem->getMetadata($this->path);
+
+ return $metadata ? $metadata['type'] : 'dir';
+ }
+
+ /**
+ * Set the Filesystem object.
+ *
+ * @param FilesystemInterface $filesystem
+ *
+ * @return $this
+ */
+ public function setFilesystem(FilesystemInterface $filesystem)
+ {
+ $this->filesystem = $filesystem;
+
+ return $this;
+ }
+
+ /**
+ * Retrieve the Filesystem object.
+ *
+ * @return FilesystemInterface
+ */
+ public function getFilesystem()
+ {
+ return $this->filesystem;
+ }
+
+ /**
+ * Set the entree path.
+ *
+ * @param string $path
+ *
+ * @return $this
+ */
+ public function setPath($path)
+ {
+ $this->path = $path;
+
+ return $this;
+ }
+
+ /**
+ * Retrieve the entree path.
+ *
+ * @return string path
+ */
+ public function getPath()
+ {
+ return $this->path;
+ }
+
+ /**
+ * Plugins pass-through.
+ *
+ * @param string $method
+ * @param array $arguments
+ *
+ * @return mixed
+ */
+ public function __call($method, array $arguments)
+ {
+ array_unshift($arguments, $this->path);
+ $callback = [$this->filesystem, $method];
+
+ try {
+ return call_user_func_array($callback, $arguments);
+ } catch (BadMethodCallException $e) {
+ throw new BadMethodCallException(
+ 'Call to undefined method '
+ . get_called_class()
+ . '::' . $method
+ );
+ }
+ }
+}
diff --git a/vendor/league/flysystem/src/InvalidRootException.php b/vendor/league/flysystem/src/InvalidRootException.php
new file mode 100644
index 000000000..468d1d58c
--- /dev/null
+++ b/vendor/league/flysystem/src/InvalidRootException.php
@@ -0,0 +1,9 @@
+ Filesystem,]
+ *
+ * @throws InvalidArgumentException
+ */
+ public function __construct(array $filesystems = [])
+ {
+ $this->mountFilesystems($filesystems);
+ }
+
+ /**
+ * Mount filesystems.
+ *
+ * @param FilesystemInterface[] $filesystems [:prefix => Filesystem,]
+ *
+ * @throws InvalidArgumentException
+ *
+ * @return $this
+ */
+ public function mountFilesystems(array $filesystems)
+ {
+ foreach ($filesystems as $prefix => $filesystem) {
+ $this->mountFilesystem($prefix, $filesystem);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Mount filesystems.
+ *
+ * @param string $prefix
+ * @param FilesystemInterface $filesystem
+ *
+ * @throws InvalidArgumentException
+ *
+ * @return $this
+ */
+ public function mountFilesystem($prefix, FilesystemInterface $filesystem)
+ {
+ if ( ! is_string($prefix)) {
+ throw new InvalidArgumentException(__METHOD__ . ' expects argument #1 to be a string.');
+ }
+
+ $this->filesystems[$prefix] = $filesystem;
+
+ return $this;
+ }
+
+ /**
+ * Get the filesystem with the corresponding prefix.
+ *
+ * @param string $prefix
+ *
+ * @throws FilesystemNotFoundException
+ *
+ * @return FilesystemInterface
+ */
+ public function getFilesystem($prefix)
+ {
+ if ( ! isset($this->filesystems[$prefix])) {
+ throw new FilesystemNotFoundException('No filesystem mounted with prefix ' . $prefix);
+ }
+
+ return $this->filesystems[$prefix];
+ }
+
+ /**
+ * Retrieve the prefix from an arguments array.
+ *
+ * @param array $arguments
+ *
+ * @throws InvalidArgumentException
+ *
+ * @return array [:prefix, :arguments]
+ */
+ public function filterPrefix(array $arguments)
+ {
+ if (empty($arguments)) {
+ throw new InvalidArgumentException('At least one argument needed');
+ }
+
+ $path = array_shift($arguments);
+
+ if ( ! is_string($path)) {
+ throw new InvalidArgumentException('First argument should be a string');
+ }
+
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+ array_unshift($arguments, $path);
+
+ return [$prefix, $arguments];
+ }
+
+ /**
+ * @param string $directory
+ * @param bool $recursive
+ *
+ * @throws InvalidArgumentException
+ * @throws FilesystemNotFoundException
+ *
+ * @return array
+ */
+ public function listContents($directory = '', $recursive = false)
+ {
+ list($prefix, $directory) = $this->getPrefixAndPath($directory);
+ $filesystem = $this->getFilesystem($prefix);
+ $result = $filesystem->listContents($directory, $recursive);
+
+ foreach ($result as &$file) {
+ $file['filesystem'] = $prefix;
+ }
+
+ return $result;
+ }
+
+ /**
+ * Call forwarder.
+ *
+ * @param string $method
+ * @param array $arguments
+ *
+ * @throws InvalidArgumentException
+ * @throws FilesystemNotFoundException
+ *
+ * @return mixed
+ */
+ public function __call($method, $arguments)
+ {
+ list($prefix, $arguments) = $this->filterPrefix($arguments);
+
+ return $this->invokePluginOnFilesystem($method, $arguments, $prefix);
+ }
+
+ /**
+ * @param string $from
+ * @param string $to
+ * @param array $config
+ *
+ * @throws InvalidArgumentException
+ * @throws FilesystemNotFoundException
+ * @throws FileExistsException
+ *
+ * @return bool
+ */
+ public function copy($from, $to, array $config = [])
+ {
+ list($prefixFrom, $from) = $this->getPrefixAndPath($from);
+
+ $buffer = $this->getFilesystem($prefixFrom)->readStream($from);
+
+ if ($buffer === false) {
+ return false;
+ }
+
+ list($prefixTo, $to) = $this->getPrefixAndPath($to);
+
+ $result = $this->getFilesystem($prefixTo)->writeStream($to, $buffer, $config);
+
+ if (is_resource($buffer)) {
+ fclose($buffer);
+ }
+
+ return $result;
+ }
+
+ /**
+ * List with plugin adapter.
+ *
+ * @param array $keys
+ * @param string $directory
+ * @param bool $recursive
+ *
+ * @throws InvalidArgumentException
+ * @throws FilesystemNotFoundException
+ *
+ * @return array
+ */
+ public function listWith(array $keys = [], $directory = '', $recursive = false)
+ {
+ list($prefix, $directory) = $this->getPrefixAndPath($directory);
+ $arguments = [$keys, $directory, $recursive];
+
+ return $this->invokePluginOnFilesystem('listWith', $arguments, $prefix);
+ }
+
+ /**
+ * Move a file.
+ *
+ * @param string $from
+ * @param string $to
+ * @param array $config
+ *
+ * @throws InvalidArgumentException
+ * @throws FilesystemNotFoundException
+ *
+ * @return bool
+ */
+ public function move($from, $to, array $config = [])
+ {
+ list($prefixFrom, $pathFrom) = $this->getPrefixAndPath($from);
+ list($prefixTo, $pathTo) = $this->getPrefixAndPath($to);
+
+ if ($prefixFrom === $prefixTo) {
+ $filesystem = $this->getFilesystem($prefixFrom);
+ $renamed = $filesystem->rename($pathFrom, $pathTo);
+
+ if ($renamed && isset($config['visibility'])) {
+ return $filesystem->setVisibility($pathTo, $config['visibility']);
+ }
+
+ return $renamed;
+ }
+
+ $copied = $this->copy($from, $to, $config);
+
+ if ($copied) {
+ return $this->delete($from);
+ }
+
+ return false;
+ }
+
+ /**
+ * Invoke a plugin on a filesystem mounted on a given prefix.
+ *
+ * @param string $method
+ * @param array $arguments
+ * @param string $prefix
+ *
+ * @throws FilesystemNotFoundException
+ *
+ * @return mixed
+ */
+ public function invokePluginOnFilesystem($method, $arguments, $prefix)
+ {
+ $filesystem = $this->getFilesystem($prefix);
+
+ try {
+ return $this->invokePlugin($method, $arguments, $filesystem);
+ } catch (PluginNotFoundException $e) {
+ // Let it pass, it's ok, don't panic.
+ }
+
+ $callback = [$filesystem, $method];
+
+ return call_user_func_array($callback, $arguments);
+ }
+
+ /**
+ * @param string $path
+ *
+ * @throws InvalidArgumentException
+ *
+ * @return string[] [:prefix, :path]
+ */
+ protected function getPrefixAndPath($path)
+ {
+ if (strpos($path, '://') < 1) {
+ throw new InvalidArgumentException('No prefix detected in path: ' . $path);
+ }
+
+ return explode('://', $path, 2);
+ }
+
+ /**
+ * Check whether a file exists.
+ *
+ * @param string $path
+ *
+ * @return bool
+ */
+ public function has($path)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->has($path);
+ }
+
+ /**
+ * Read a file.
+ *
+ * @param string $path The path to the file.
+ *
+ * @throws FileNotFoundException
+ *
+ * @return string|false The file contents or false on failure.
+ */
+ public function read($path)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->read($path);
+ }
+
+ /**
+ * Retrieves a read-stream for a path.
+ *
+ * @param string $path The path to the file.
+ *
+ * @throws FileNotFoundException
+ *
+ * @return resource|false The path resource or false on failure.
+ */
+ public function readStream($path)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->readStream($path);
+ }
+
+ /**
+ * Get a file's metadata.
+ *
+ * @param string $path The path to the file.
+ *
+ * @throws FileNotFoundException
+ *
+ * @return array|false The file metadata or false on failure.
+ */
+ public function getMetadata($path)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->getMetadata($path);
+ }
+
+ /**
+ * Get a file's size.
+ *
+ * @param string $path The path to the file.
+ *
+ * @throws FileNotFoundException
+ *
+ * @return int|false The file size or false on failure.
+ */
+ public function getSize($path)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->getSize($path);
+ }
+
+ /**
+ * Get a file's mime-type.
+ *
+ * @param string $path The path to the file.
+ *
+ * @throws FileNotFoundException
+ *
+ * @return string|false The file mime-type or false on failure.
+ */
+ public function getMimetype($path)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->getMimetype($path);
+ }
+
+ /**
+ * Get a file's timestamp.
+ *
+ * @param string $path The path to the file.
+ *
+ * @throws FileNotFoundException
+ *
+ * @return string|false The timestamp or false on failure.
+ */
+ public function getTimestamp($path)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->getTimestamp($path);
+ }
+
+ /**
+ * Get a file's visibility.
+ *
+ * @param string $path The path to the file.
+ *
+ * @throws FileNotFoundException
+ *
+ * @return string|false The visibility (public|private) or false on failure.
+ */
+ public function getVisibility($path)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->getVisibility($path);
+ }
+
+ /**
+ * Write a new file.
+ *
+ * @param string $path The path of the new file.
+ * @param string $contents The file contents.
+ * @param array $config An optional configuration array.
+ *
+ * @throws FileExistsException
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function write($path, $contents, array $config = [])
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->write($path, $contents, $config);
+ }
+
+ /**
+ * Write a new file using a stream.
+ *
+ * @param string $path The path of the new file.
+ * @param resource $resource The file handle.
+ * @param array $config An optional configuration array.
+ *
+ * @throws InvalidArgumentException If $resource is not a file handle.
+ * @throws FileExistsException
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function writeStream($path, $resource, array $config = [])
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->writeStream($path, $resource, $config);
+ }
+
+ /**
+ * Update an existing file.
+ *
+ * @param string $path The path of the existing file.
+ * @param string $contents The file contents.
+ * @param array $config An optional configuration array.
+ *
+ * @throws FileNotFoundException
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function update($path, $contents, array $config = [])
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->update($path, $contents, $config);
+ }
+
+ /**
+ * Update an existing file using a stream.
+ *
+ * @param string $path The path of the existing file.
+ * @param resource $resource The file handle.
+ * @param array $config An optional configuration array.
+ *
+ * @throws InvalidArgumentException If $resource is not a file handle.
+ * @throws FileNotFoundException
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function updateStream($path, $resource, array $config = [])
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->updateStream($path, $resource, $config);
+ }
+
+ /**
+ * Rename a file.
+ *
+ * @param string $path Path to the existing file.
+ * @param string $newpath The new path of the file.
+ *
+ * @throws FileExistsException Thrown if $newpath exists.
+ * @throws FileNotFoundException Thrown if $path does not exist.
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function rename($path, $newpath)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->rename($path, $newpath);
+ }
+
+ /**
+ * Delete a file.
+ *
+ * @param string $path
+ *
+ * @throws FileNotFoundException
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function delete($path)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->delete($path);
+ }
+
+ /**
+ * Delete a directory.
+ *
+ * @param string $dirname
+ *
+ * @throws RootViolationException Thrown if $dirname is empty.
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function deleteDir($dirname)
+ {
+ list($prefix, $dirname) = $this->getPrefixAndPath($dirname);
+
+ return $this->getFilesystem($prefix)->deleteDir($dirname);
+ }
+
+ /**
+ * Create a directory.
+ *
+ * @param string $dirname The name of the new directory.
+ * @param array $config An optional configuration array.
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function createDir($dirname, array $config = [])
+ {
+ list($prefix, $dirname) = $this->getPrefixAndPath($dirname);
+
+ return $this->getFilesystem($prefix)->createDir($dirname);
+ }
+
+ /**
+ * Set the visibility for a file.
+ *
+ * @param string $path The path to the file.
+ * @param string $visibility One of 'public' or 'private'.
+ *
+ * @throws FileNotFoundException
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function setVisibility($path, $visibility)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->setVisibility($path, $visibility);
+ }
+
+ /**
+ * Create a file or update if exists.
+ *
+ * @param string $path The path to the file.
+ * @param string $contents The file contents.
+ * @param array $config An optional configuration array.
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function put($path, $contents, array $config = [])
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->put($path, $contents, $config);
+ }
+
+ /**
+ * Create a file or update if exists.
+ *
+ * @param string $path The path to the file.
+ * @param resource $resource The file handle.
+ * @param array $config An optional configuration array.
+ *
+ * @throws InvalidArgumentException Thrown if $resource is not a resource.
+ *
+ * @return bool True on success, false on failure.
+ */
+ public function putStream($path, $resource, array $config = [])
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->putStream($path, $resource, $config);
+ }
+
+ /**
+ * Read and delete a file.
+ *
+ * @param string $path The path to the file.
+ *
+ * @throws FileNotFoundException
+ *
+ * @return string|false The file contents, or false on failure.
+ */
+ public function readAndDelete($path)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->readAndDelete($path);
+ }
+
+ /**
+ * Get a file/directory handler.
+ *
+ * @deprecated
+ *
+ * @param string $path The path to the file.
+ * @param Handler $handler An optional existing handler to populate.
+ *
+ * @return Handler Either a file or directory handler.
+ */
+ public function get($path, Handler $handler = null)
+ {
+ list($prefix, $path) = $this->getPrefixAndPath($path);
+
+ return $this->getFilesystem($prefix)->get($path);
+ }
+}
diff --git a/vendor/league/flysystem/src/NotSupportedException.php b/vendor/league/flysystem/src/NotSupportedException.php
new file mode 100644
index 000000000..e0a989b22
--- /dev/null
+++ b/vendor/league/flysystem/src/NotSupportedException.php
@@ -0,0 +1,37 @@
+getPathname());
+ }
+
+ /**
+ * Create a new exception for a link.
+ *
+ * @param string $systemType
+ *
+ * @return static
+ */
+ public static function forFtpSystemType($systemType)
+ {
+ $message = "The FTP system type '$systemType' is currently not supported.";
+
+ return new static($message);
+ }
+}
diff --git a/vendor/league/flysystem/src/Plugin/AbstractPlugin.php b/vendor/league/flysystem/src/Plugin/AbstractPlugin.php
new file mode 100644
index 000000000..0d5678976
--- /dev/null
+++ b/vendor/league/flysystem/src/Plugin/AbstractPlugin.php
@@ -0,0 +1,24 @@
+filesystem = $filesystem;
+ }
+}
diff --git a/vendor/league/flysystem/src/Plugin/EmptyDir.php b/vendor/league/flysystem/src/Plugin/EmptyDir.php
new file mode 100644
index 000000000..b5ae7f582
--- /dev/null
+++ b/vendor/league/flysystem/src/Plugin/EmptyDir.php
@@ -0,0 +1,34 @@
+filesystem->listContents($dirname, false);
+
+ foreach ($listing as $item) {
+ if ($item['type'] === 'dir') {
+ $this->filesystem->deleteDir($item['path']);
+ } else {
+ $this->filesystem->delete($item['path']);
+ }
+ }
+ }
+}
diff --git a/vendor/league/flysystem/src/Plugin/ForcedCopy.php b/vendor/league/flysystem/src/Plugin/ForcedCopy.php
new file mode 100644
index 000000000..a41e9f3ae
--- /dev/null
+++ b/vendor/league/flysystem/src/Plugin/ForcedCopy.php
@@ -0,0 +1,44 @@
+filesystem->delete($newpath);
+ } catch (FileNotFoundException $e) {
+ // The destination path does not exist. That's ok.
+ $deleted = true;
+ }
+
+ if ($deleted) {
+ return $this->filesystem->copy($path, $newpath);
+ }
+
+ return false;
+ }
+}
diff --git a/vendor/league/flysystem/src/Plugin/ForcedRename.php b/vendor/league/flysystem/src/Plugin/ForcedRename.php
new file mode 100644
index 000000000..3f51cd607
--- /dev/null
+++ b/vendor/league/flysystem/src/Plugin/ForcedRename.php
@@ -0,0 +1,44 @@
+filesystem->delete($newpath);
+ } catch (FileNotFoundException $e) {
+ // The destination path does not exist. That's ok.
+ $deleted = true;
+ }
+
+ if ($deleted) {
+ return $this->filesystem->rename($path, $newpath);
+ }
+
+ return false;
+ }
+}
diff --git a/vendor/league/flysystem/src/Plugin/GetWithMetadata.php b/vendor/league/flysystem/src/Plugin/GetWithMetadata.php
new file mode 100644
index 000000000..6fe4f0562
--- /dev/null
+++ b/vendor/league/flysystem/src/Plugin/GetWithMetadata.php
@@ -0,0 +1,51 @@
+filesystem->getMetadata($path);
+
+ if ( ! $object) {
+ return false;
+ }
+
+ $keys = array_diff($metadata, array_keys($object));
+
+ foreach ($keys as $key) {
+ if ( ! method_exists($this->filesystem, $method = 'get' . ucfirst($key))) {
+ throw new InvalidArgumentException('Could not fetch metadata: ' . $key);
+ }
+
+ $object[$key] = $this->filesystem->{$method}($path);
+ }
+
+ return $object;
+ }
+}
diff --git a/vendor/league/flysystem/src/Plugin/ListFiles.php b/vendor/league/flysystem/src/Plugin/ListFiles.php
new file mode 100644
index 000000000..9669fe7e7
--- /dev/null
+++ b/vendor/league/flysystem/src/Plugin/ListFiles.php
@@ -0,0 +1,35 @@
+filesystem->listContents($directory, $recursive);
+
+ $filter = function ($object) {
+ return $object['type'] === 'file';
+ };
+
+ return array_values(array_filter($contents, $filter));
+ }
+}
diff --git a/vendor/league/flysystem/src/Plugin/ListPaths.php b/vendor/league/flysystem/src/Plugin/ListPaths.php
new file mode 100644
index 000000000..514bdf0b3
--- /dev/null
+++ b/vendor/league/flysystem/src/Plugin/ListPaths.php
@@ -0,0 +1,36 @@
+filesystem->listContents($directory, $recursive);
+
+ foreach ($contents as $object) {
+ $result[] = $object['path'];
+ }
+
+ return $result;
+ }
+}
diff --git a/vendor/league/flysystem/src/Plugin/ListWith.php b/vendor/league/flysystem/src/Plugin/ListWith.php
new file mode 100644
index 000000000..d90464e52
--- /dev/null
+++ b/vendor/league/flysystem/src/Plugin/ListWith.php
@@ -0,0 +1,60 @@
+filesystem->listContents($directory, $recursive);
+
+ foreach ($contents as $index => $object) {
+ if ($object['type'] === 'file') {
+ $missingKeys = array_diff($keys, array_keys($object));
+ $contents[$index] = array_reduce($missingKeys, [$this, 'getMetadataByName'], $object);
+ }
+ }
+
+ return $contents;
+ }
+
+ /**
+ * Get a meta-data value by key name.
+ *
+ * @param array $object
+ * @param string $key
+ *
+ * @return array
+ */
+ protected function getMetadataByName(array $object, $key)
+ {
+ $method = 'get' . ucfirst($key);
+
+ if ( ! method_exists($this->filesystem, $method)) {
+ throw new \InvalidArgumentException('Could not get meta-data for key: ' . $key);
+ }
+
+ $object[$key] = $this->filesystem->{$method}($object['path']);
+
+ return $object;
+ }
+}
diff --git a/vendor/league/flysystem/src/Plugin/PluggableTrait.php b/vendor/league/flysystem/src/Plugin/PluggableTrait.php
new file mode 100644
index 000000000..922edfe52
--- /dev/null
+++ b/vendor/league/flysystem/src/Plugin/PluggableTrait.php
@@ -0,0 +1,97 @@
+plugins[$plugin->getMethod()] = $plugin;
+
+ return $this;
+ }
+
+ /**
+ * Find a specific plugin.
+ *
+ * @param string $method
+ *
+ * @throws PluginNotFoundException
+ *
+ * @return PluginInterface
+ */
+ protected function findPlugin($method)
+ {
+ if ( ! isset($this->plugins[$method])) {
+ throw new PluginNotFoundException('Plugin not found for method: ' . $method);
+ }
+
+ return $this->plugins[$method];
+ }
+
+ /**
+ * Invoke a plugin by method name.
+ *
+ * @param string $method
+ * @param array $arguments
+ * @param FilesystemInterface $filesystem
+ *
+ * @throws PluginNotFoundException
+ *
+ * @return mixed
+ */
+ protected function invokePlugin($method, array $arguments, FilesystemInterface $filesystem)
+ {
+ $plugin = $this->findPlugin($method);
+ $plugin->setFilesystem($filesystem);
+ $callback = [$plugin, 'handle'];
+
+ return call_user_func_array($callback, $arguments);
+ }
+
+ /**
+ * Plugins pass-through.
+ *
+ * @param string $method
+ * @param array $arguments
+ *
+ * @throws BadMethodCallException
+ *
+ * @return mixed
+ */
+ public function __call($method, array $arguments)
+ {
+ try {
+ return $this->invokePlugin($method, $arguments, $this);
+ } catch (PluginNotFoundException $e) {
+ throw new BadMethodCallException(
+ 'Call to undefined method '
+ . get_class($this)
+ . '::' . $method
+ );
+ }
+ }
+}
diff --git a/vendor/league/flysystem/src/Plugin/PluginNotFoundException.php b/vendor/league/flysystem/src/Plugin/PluginNotFoundException.php
new file mode 100644
index 000000000..fd1d7e7e3
--- /dev/null
+++ b/vendor/league/flysystem/src/Plugin/PluginNotFoundException.php
@@ -0,0 +1,10 @@
+hash = spl_object_hash($this);
+ static::$safeStorage[$this->hash] = [];
+ }
+
+ public function storeSafely($key, $value)
+ {
+ static::$safeStorage[$this->hash][$key] = $value;
+ }
+
+ public function retrieveSafely($key)
+ {
+ if (array_key_exists($key, static::$safeStorage[$this->hash])) {
+ return static::$safeStorage[$this->hash][$key];
+ }
+ }
+
+ public function __destruct()
+ {
+ unset(static::$safeStorage[$this->hash]);
+ }
+}
diff --git a/vendor/league/flysystem/src/UnreadableFileException.php b/vendor/league/flysystem/src/UnreadableFileException.php
new file mode 100644
index 000000000..e66803383
--- /dev/null
+++ b/vendor/league/flysystem/src/UnreadableFileException.php
@@ -0,0 +1,18 @@
+getRealPath()
+ )
+ );
+ }
+}
diff --git a/vendor/league/flysystem/src/Util.php b/vendor/league/flysystem/src/Util.php
new file mode 100644
index 000000000..76454a05e
--- /dev/null
+++ b/vendor/league/flysystem/src/Util.php
@@ -0,0 +1,353 @@
+ ''];
+ }
+
+ /**
+ * Normalize a dirname return value.
+ *
+ * @param string $dirname
+ *
+ * @return string normalized dirname
+ */
+ public static function normalizeDirname($dirname)
+ {
+ return $dirname === '.' ? '' : $dirname;
+ }
+
+ /**
+ * Get a normalized dirname from a path.
+ *
+ * @param string $path
+ *
+ * @return string dirname
+ */
+ public static function dirname($path)
+ {
+ return static::normalizeDirname(dirname($path));
+ }
+
+ /**
+ * Map result arrays.
+ *
+ * @param array $object
+ * @param array $map
+ *
+ * @return array mapped result
+ */
+ public static function map(array $object, array $map)
+ {
+ $result = [];
+
+ foreach ($map as $from => $to) {
+ if ( ! isset($object[$from])) {
+ continue;
+ }
+
+ $result[$to] = $object[$from];
+ }
+
+ return $result;
+ }
+
+ /**
+ * Normalize path.
+ *
+ * @param string $path
+ *
+ * @throws LogicException
+ *
+ * @return string
+ */
+ public static function normalizePath($path)
+ {
+ return static::normalizeRelativePath($path);
+ }
+
+ /**
+ * Normalize relative directories in a path.
+ *
+ * @param string $path
+ *
+ * @throws LogicException
+ *
+ * @return string
+ */
+ public static function normalizeRelativePath($path)
+ {
+ $path = str_replace('\\', '/', $path);
+ $path = static::removeFunkyWhiteSpace($path);
+
+ $parts = [];
+
+ foreach (explode('/', $path) as $part) {
+ switch ($part) {
+ case '':
+ case '.':
+ break;
+
+ case '..':
+ if (empty($parts)) {
+ throw new LogicException(
+ 'Path is outside of the defined root, path: [' . $path . ']'
+ );
+ }
+ array_pop($parts);
+ break;
+
+ default:
+ $parts[] = $part;
+ break;
+ }
+ }
+
+ return implode('/', $parts);
+ }
+
+ /**
+ * Removes unprintable characters and invalid unicode characters.
+ *
+ * @param string $path
+ *
+ * @return string $path
+ */
+ protected static function removeFunkyWhiteSpace($path)
+ {
+ // We do this check in a loop, since removing invalid unicode characters
+ // can lead to new characters being created.
+ while (preg_match('#\p{C}+|^\./#u', $path)) {
+ $path = preg_replace('#\p{C}+|^\./#u', '', $path);
+ }
+
+ return $path;
+ }
+
+ /**
+ * Normalize prefix.
+ *
+ * @param string $prefix
+ * @param string $separator
+ *
+ * @return string normalized path
+ */
+ public static function normalizePrefix($prefix, $separator)
+ {
+ return rtrim($prefix, $separator) . $separator;
+ }
+
+ /**
+ * Get content size.
+ *
+ * @param string $contents
+ *
+ * @return int content size
+ */
+ public static function contentSize($contents)
+ {
+ return defined('MB_OVERLOAD_STRING') ? mb_strlen($contents, '8bit') : strlen($contents);
+ }
+
+ /**
+ * Guess MIME Type based on the path of the file and it's content.
+ *
+ * @param string $path
+ * @param string|resource $content
+ *
+ * @return string|null MIME Type or NULL if no extension detected
+ */
+ public static function guessMimeType($path, $content)
+ {
+ $mimeType = MimeType::detectByContent($content);
+
+ if ( ! (empty($mimeType) || in_array($mimeType, ['application/x-empty', 'text/plain', 'text/x-asm']))) {
+ return $mimeType;
+ }
+
+ return MimeType::detectByFilename($path);
+ }
+
+ /**
+ * Emulate directories.
+ *
+ * @param array $listing
+ *
+ * @return array listing with emulated directories
+ */
+ public static function emulateDirectories(array $listing)
+ {
+ $directories = [];
+ $listedDirectories = [];
+
+ foreach ($listing as $object) {
+ list($directories, $listedDirectories) = static::emulateObjectDirectories($object, $directories, $listedDirectories);
+ }
+
+ $directories = array_diff(array_unique($directories), array_unique($listedDirectories));
+
+ foreach ($directories as $directory) {
+ $listing[] = static::pathinfo($directory) + ['type' => 'dir'];
+ }
+
+ return $listing;
+ }
+
+ /**
+ * Ensure a Config instance.
+ *
+ * @param null|array|Config $config
+ *
+ * @return Config config instance
+ *
+ * @throw LogicException
+ */
+ public static function ensureConfig($config)
+ {
+ if ($config === null) {
+ return new Config();
+ }
+
+ if ($config instanceof Config) {
+ return $config;
+ }
+
+ if (is_array($config)) {
+ return new Config($config);
+ }
+
+ throw new LogicException('A config should either be an array or a Flysystem\Config object.');
+ }
+
+ /**
+ * Rewind a stream.
+ *
+ * @param resource $resource
+ */
+ public static function rewindStream($resource)
+ {
+ if (ftell($resource) !== 0 && static::isSeekableStream($resource)) {
+ rewind($resource);
+ }
+ }
+
+ public static function isSeekableStream($resource)
+ {
+ $metadata = stream_get_meta_data($resource);
+
+ return $metadata['seekable'];
+ }
+
+ /**
+ * Get the size of a stream.
+ *
+ * @param resource $resource
+ *
+ * @return int|null stream size
+ */
+ public static function getStreamSize($resource)
+ {
+ $stat = fstat($resource);
+
+ if ( ! is_array($stat) || ! isset($stat['size'])) {
+ return null;
+ }
+
+ return $stat['size'];
+ }
+
+ /**
+ * Emulate the directories of a single object.
+ *
+ * @param array $object
+ * @param array $directories
+ * @param array $listedDirectories
+ *
+ * @return array
+ */
+ protected static function emulateObjectDirectories(array $object, array $directories, array $listedDirectories)
+ {
+ if ($object['type'] === 'dir') {
+ $listedDirectories[] = $object['path'];
+ }
+
+ if ( ! isset($object['dirname']) || trim($object['dirname']) === '') {
+ return [$directories, $listedDirectories];
+ }
+
+ $parent = $object['dirname'];
+
+ while (isset($parent) && trim($parent) !== '' && ! in_array($parent, $directories)) {
+ $directories[] = $parent;
+ $parent = static::dirname($parent);
+ }
+
+ if (isset($object['type']) && $object['type'] === 'dir') {
+ $listedDirectories[] = $object['path'];
+
+ return [$directories, $listedDirectories];
+ }
+
+ return [$directories, $listedDirectories];
+ }
+
+ /**
+ * Returns the trailing name component of the path.
+ *
+ * @param string $path
+ *
+ * @return string
+ */
+ private static function basename($path)
+ {
+ $separators = DIRECTORY_SEPARATOR === '/' ? '/' : '\/';
+
+ $path = rtrim($path, $separators);
+
+ $basename = preg_replace('#.*?([^' . preg_quote($separators, '#') . ']+$)#', '$1', $path);
+
+ if (DIRECTORY_SEPARATOR === '/') {
+ return $basename;
+ }
+ // @codeCoverageIgnoreStart
+ // Extra Windows path munging. This is tested via AppVeyor, but code
+ // coverage is not reported.
+
+ // Handle relative paths with drive letters. c:file.txt.
+ while (preg_match('#^[a-zA-Z]{1}:[^\\\/]#', $basename)) {
+ $basename = substr($basename, 2);
+ }
+
+ // Remove colon for standalone drive letter names.
+ if (preg_match('#^[a-zA-Z]{1}:$#', $basename)) {
+ $basename = rtrim($basename, ':');
+ }
+
+ return $basename;
+ // @codeCoverageIgnoreEnd
+ }
+}
diff --git a/vendor/league/flysystem/src/Util/ContentListingFormatter.php b/vendor/league/flysystem/src/Util/ContentListingFormatter.php
new file mode 100644
index 000000000..ae0d3b91d
--- /dev/null
+++ b/vendor/league/flysystem/src/Util/ContentListingFormatter.php
@@ -0,0 +1,122 @@
+directory = rtrim($directory, '/');
+ $this->recursive = $recursive;
+ $this->caseSensitive = $caseSensitive;
+ }
+
+ /**
+ * Format contents listing.
+ *
+ * @param array $listing
+ *
+ * @return array
+ */
+ public function formatListing(array $listing)
+ {
+ $listing = array_filter(array_map([$this, 'addPathInfo'], $listing), [$this, 'isEntryOutOfScope']);
+
+ return $this->sortListing(array_values($listing));
+ }
+
+ private function addPathInfo(array $entry)
+ {
+ return $entry + Util::pathinfo($entry['path']);
+ }
+
+ /**
+ * Determine if the entry is out of scope.
+ *
+ * @param array $entry
+ *
+ * @return bool
+ */
+ private function isEntryOutOfScope(array $entry)
+ {
+ if (empty($entry['path']) && $entry['path'] !== '0') {
+ return false;
+ }
+
+ if ($this->recursive) {
+ return $this->residesInDirectory($entry);
+ }
+
+ return $this->isDirectChild($entry);
+ }
+
+ /**
+ * Check if the entry resides within the parent directory.
+ *
+ * @param array $entry
+ *
+ * @return bool
+ */
+ private function residesInDirectory(array $entry)
+ {
+ if ($this->directory === '') {
+ return true;
+ }
+
+ return $this->caseSensitive
+ ? strpos($entry['path'], $this->directory . '/') === 0
+ : stripos($entry['path'], $this->directory . '/') === 0;
+ }
+
+ /**
+ * Check if the entry is a direct child of the directory.
+ *
+ * @param array $entry
+ *
+ * @return bool
+ */
+ private function isDirectChild(array $entry)
+ {
+ return $this->caseSensitive
+ ? $entry['dirname'] === $this->directory
+ : strcasecmp($this->directory, $entry['dirname']) === 0;
+ }
+
+ /**
+ * @param array $listing
+ *
+ * @return array
+ */
+ private function sortListing(array $listing)
+ {
+ usort($listing, function ($a, $b) {
+ return strcasecmp($a['path'], $b['path']);
+ });
+
+ return $listing;
+ }
+}
diff --git a/vendor/league/flysystem/src/Util/MimeType.php b/vendor/league/flysystem/src/Util/MimeType.php
new file mode 100644
index 000000000..1f1949ce0
--- /dev/null
+++ b/vendor/league/flysystem/src/Util/MimeType.php
@@ -0,0 +1,249 @@
+ 'application/mac-binhex40',
+ 'cpt' => 'application/mac-compactpro',
+ 'csv' => 'text/csv',
+ 'bin' => 'application/octet-stream',
+ 'dms' => 'application/octet-stream',
+ 'lha' => 'application/octet-stream',
+ 'lzh' => 'application/octet-stream',
+ 'exe' => 'application/octet-stream',
+ 'class' => 'application/octet-stream',
+ 'psd' => 'application/x-photoshop',
+ 'so' => 'application/octet-stream',
+ 'sea' => 'application/octet-stream',
+ 'dll' => 'application/octet-stream',
+ 'oda' => 'application/oda',
+ 'pdf' => 'application/pdf',
+ 'ai' => 'application/pdf',
+ 'eps' => 'application/postscript',
+ 'epub' => 'application/epub+zip',
+ 'ps' => 'application/postscript',
+ 'smi' => 'application/smil',
+ 'smil' => 'application/smil',
+ 'mif' => 'application/vnd.mif',
+ 'xls' => 'application/vnd.ms-excel',
+ 'xlt' => 'application/vnd.ms-excel',
+ 'xla' => 'application/vnd.ms-excel',
+ 'ppt' => 'application/powerpoint',
+ 'pot' => 'application/vnd.ms-powerpoint',
+ 'pps' => 'application/vnd.ms-powerpoint',
+ 'ppa' => 'application/vnd.ms-powerpoint',
+ 'pptx' => 'application/vnd.openxmlformats-officedocument.presentationml.presentation',
+ 'potx' => 'application/vnd.openxmlformats-officedocument.presentationml.template',
+ 'ppsx' => 'application/vnd.openxmlformats-officedocument.presentationml.slideshow',
+ 'ppam' => 'application/vnd.ms-powerpoint.addin.macroEnabled.12',
+ 'pptm' => 'application/vnd.ms-powerpoint.presentation.macroEnabled.12',
+ 'potm' => 'application/vnd.ms-powerpoint.presentation.macroEnabled.12',
+ 'ppsm' => 'application/vnd.ms-powerpoint.slideshow.macroEnabled.12',
+ 'wbxml' => 'application/wbxml',
+ 'wmlc' => 'application/wmlc',
+ 'dcr' => 'application/x-director',
+ 'dir' => 'application/x-director',
+ 'dxr' => 'application/x-director',
+ 'dvi' => 'application/x-dvi',
+ 'gtar' => 'application/x-gtar',
+ 'gz' => 'application/x-gzip',
+ 'gzip' => 'application/x-gzip',
+ 'php' => 'application/x-httpd-php',
+ 'php4' => 'application/x-httpd-php',
+ 'php3' => 'application/x-httpd-php',
+ 'phtml' => 'application/x-httpd-php',
+ 'phps' => 'application/x-httpd-php-source',
+ 'js' => 'application/javascript',
+ 'swf' => 'application/x-shockwave-flash',
+ 'sit' => 'application/x-stuffit',
+ 'tar' => 'application/x-tar',
+ 'tgz' => 'application/x-tar',
+ 'z' => 'application/x-compress',
+ 'xhtml' => 'application/xhtml+xml',
+ 'xht' => 'application/xhtml+xml',
+ 'rdf' => 'application/rdf+xml',
+ 'zip' => 'application/x-zip',
+ 'rar' => 'application/x-rar',
+ 'mid' => 'audio/midi',
+ 'midi' => 'audio/midi',
+ 'mpga' => 'audio/mpeg',
+ 'mp2' => 'audio/mpeg',
+ 'mp3' => 'audio/mpeg',
+ 'aif' => 'audio/x-aiff',
+ 'aiff' => 'audio/x-aiff',
+ 'aifc' => 'audio/x-aiff',
+ 'ram' => 'audio/x-pn-realaudio',
+ 'rm' => 'audio/x-pn-realaudio',
+ 'rpm' => 'audio/x-pn-realaudio-plugin',
+ 'ra' => 'audio/x-realaudio',
+ 'rv' => 'video/vnd.rn-realvideo',
+ 'wav' => 'audio/x-wav',
+ 'jpg' => 'image/jpeg',
+ 'jpeg' => 'image/jpeg',
+ 'jpe' => 'image/jpeg',
+ 'png' => 'image/png',
+ 'gif' => 'image/gif',
+ 'bmp' => 'image/bmp',
+ 'tiff' => 'image/tiff',
+ 'tif' => 'image/tiff',
+ 'svg' => 'image/svg+xml',
+ 'css' => 'text/css',
+ 'html' => 'text/html',
+ 'htm' => 'text/html',
+ 'shtml' => 'text/html',
+ 'txt' => 'text/plain',
+ 'text' => 'text/plain',
+ 'log' => 'text/plain',
+ 'markdown' => 'text/markdown',
+ 'md' => 'text/markdown',
+ 'rtx' => 'text/richtext',
+ 'rtf' => 'text/rtf',
+ 'xml' => 'application/xml',
+ 'xsl' => 'application/xml',
+ 'dmn' => 'application/octet-stream',
+ 'bpmn' => 'application/octet-stream',
+ 'mpeg' => 'video/mpeg',
+ 'mpg' => 'video/mpeg',
+ 'mpe' => 'video/mpeg',
+ 'qt' => 'video/quicktime',
+ 'mov' => 'video/quicktime',
+ 'avi' => 'video/x-msvideo',
+ 'movie' => 'video/x-sgi-movie',
+ 'doc' => 'application/msword',
+ 'docx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
+ 'docm' => 'application/vnd.ms-word.template.macroEnabled.12',
+ 'dotm' => 'application/vnd.ms-word.template.macroEnabled.12',
+ 'dot' => 'application/msword',
+ 'dotx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.template',
+ 'xlsx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
+ 'xltx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.template',
+ 'xlsm' => 'application/vnd.ms-excel.sheet.macroEnabled.12',
+ 'xltm' => 'application/vnd.ms-excel.template.macroEnabled.12',
+ 'xlam' => 'application/vnd.ms-excel.addin.macroEnabled.12',
+ 'xlsb' => 'application/vnd.ms-excel.sheet.binary.macroEnabled.12',
+ 'word' => 'application/msword',
+ 'xl' => 'application/excel',
+ 'eml' => 'message/rfc822',
+ 'json' => 'application/json',
+ 'pem' => 'application/x-x509-user-cert',
+ 'p10' => 'application/x-pkcs10',
+ 'p12' => 'application/x-pkcs12',
+ 'p7a' => 'application/x-pkcs7-signature',
+ 'p7c' => 'application/pkcs7-mime',
+ 'p7m' => 'application/pkcs7-mime',
+ 'p7r' => 'application/x-pkcs7-certreqresp',
+ 'p7s' => 'application/pkcs7-signature',
+ 'crt' => 'application/x-x509-ca-cert',
+ 'crl' => 'application/pkix-crl',
+ 'der' => 'application/x-x509-ca-cert',
+ 'kdb' => 'application/octet-stream',
+ 'pgp' => 'application/pgp',
+ 'gpg' => 'application/gpg-keys',
+ 'sst' => 'application/octet-stream',
+ 'csr' => 'application/octet-stream',
+ 'rsa' => 'application/x-pkcs7',
+ 'cer' => 'application/pkix-cert',
+ '3g2' => 'video/3gpp2',
+ '3gp' => 'video/3gp',
+ 'mp4' => 'video/mp4',
+ 'm4a' => 'audio/x-m4a',
+ 'f4v' => 'video/mp4',
+ 'webm' => 'video/webm',
+ 'aac' => 'audio/x-acc',
+ 'm4u' => 'application/vnd.mpegurl',
+ 'm3u' => 'text/plain',
+ 'xspf' => 'application/xspf+xml',
+ 'vlc' => 'application/videolan',
+ 'wmv' => 'video/x-ms-wmv',
+ 'au' => 'audio/x-au',
+ 'ac3' => 'audio/ac3',
+ 'flac' => 'audio/x-flac',
+ 'ogg' => 'audio/ogg',
+ 'kmz' => 'application/vnd.google-earth.kmz',
+ 'kml' => 'application/vnd.google-earth.kml+xml',
+ 'ics' => 'text/calendar',
+ 'zsh' => 'text/x-scriptzsh',
+ '7zip' => 'application/x-7z-compressed',
+ 'cdr' => 'application/cdr',
+ 'wma' => 'audio/x-ms-wma',
+ 'jar' => 'application/java-archive',
+ 'tex' => 'application/x-tex',
+ 'latex' => 'application/x-latex',
+ 'odt' => 'application/vnd.oasis.opendocument.text',
+ 'ods' => 'application/vnd.oasis.opendocument.spreadsheet',
+ 'odp' => 'application/vnd.oasis.opendocument.presentation',
+ 'odg' => 'application/vnd.oasis.opendocument.graphics',
+ 'odc' => 'application/vnd.oasis.opendocument.chart',
+ 'odf' => 'application/vnd.oasis.opendocument.formula',
+ 'odi' => 'application/vnd.oasis.opendocument.image',
+ 'odm' => 'application/vnd.oasis.opendocument.text-master',
+ 'odb' => 'application/vnd.oasis.opendocument.database',
+ 'ott' => 'application/vnd.oasis.opendocument.text-template',
+ 'webp' => 'image/webp',
+ 'ico' => 'image/x-icon',
+ ];
+
+ /**
+ * Detects MIME Type based on given content.
+ *
+ * @param mixed $content
+ *
+ * @return string|null MIME Type or NULL if no mime type detected
+ */
+ public static function detectByContent($content)
+ {
+ if ( ! class_exists('finfo') || ! is_string($content)) {
+ return null;
+ }
+ try {
+ $finfo = new finfo(FILEINFO_MIME_TYPE);
+
+ return $finfo->buffer($content) ?: null;
+ // @codeCoverageIgnoreStart
+ } catch (ErrorException $e) {
+ // This is caused by an array to string conversion error.
+ }
+ } // @codeCoverageIgnoreEnd
+
+ /**
+ * Detects MIME Type based on file extension.
+ *
+ * @param string $extension
+ *
+ * @return string|null MIME Type or NULL if no extension detected
+ */
+ public static function detectByFileExtension($extension)
+ {
+ return isset(static::$extensionToMimeTypeMap[$extension])
+ ? static::$extensionToMimeTypeMap[$extension]
+ : 'text/plain';
+ }
+
+ /**
+ * @param string $filename
+ *
+ * @return string|null MIME Type or NULL if no extension detected
+ */
+ public static function detectByFilename($filename)
+ {
+ $extension = strtolower(pathinfo($filename, PATHINFO_EXTENSION));
+
+ return empty($extension) ? 'text/plain' : static::detectByFileExtension($extension);
+ }
+
+ /**
+ * @return array Map of file extension to MIME Type
+ */
+ public static function getExtensionToMimeTypeMap()
+ {
+ return static::$extensionToMimeTypeMap;
+ }
+}
diff --git a/vendor/league/flysystem/src/Util/StreamHasher.php b/vendor/league/flysystem/src/Util/StreamHasher.php
new file mode 100644
index 000000000..938ec5db7
--- /dev/null
+++ b/vendor/league/flysystem/src/Util/StreamHasher.php
@@ -0,0 +1,36 @@
+algo = $algo;
+ }
+
+ /**
+ * @param resource $resource
+ *
+ * @return string
+ */
+ public function hash($resource)
+ {
+ rewind($resource);
+ $context = hash_init($this->algo);
+ hash_update_stream($context, $resource);
+ fclose($resource);
+
+ return hash_final($context);
+ }
+}
diff --git a/vendor/mockery/mockery/.gitignore b/vendor/mockery/mockery/.gitignore
new file mode 100644
index 000000000..3b5e189cd
--- /dev/null
+++ b/vendor/mockery/mockery/.gitignore
@@ -0,0 +1,12 @@
+*~
+pearfarm.spec
+*.sublime-project
+library/Hamcrest/*
+composer.lock
+vendor/
+composer.phar
+test.php
+build/
+phpunit.xml
+*.DS_store
+.idea/*
diff --git a/vendor/mockery/mockery/.php_cs b/vendor/mockery/mockery/.php_cs
new file mode 100644
index 000000000..74df8bf75
--- /dev/null
+++ b/vendor/mockery/mockery/.php_cs
@@ -0,0 +1,14 @@
+exclude('examples')
+ ->exclude('docs')
+ ->exclude('travis')
+ ->exclude('vendor')
+ ->exclude('tests/Mockery/_files')
+ ->exclude('tests/Mockery/_files')
+ ->in(__DIR__);
+
+return Symfony\CS\Config\Config::create()
+ ->level('psr2')
+ ->finder($finder);
\ No newline at end of file
diff --git a/vendor/mockery/mockery/.scrutinizer.yml b/vendor/mockery/mockery/.scrutinizer.yml
new file mode 100644
index 000000000..3b633cc33
--- /dev/null
+++ b/vendor/mockery/mockery/.scrutinizer.yml
@@ -0,0 +1,24 @@
+filter:
+ paths: [library/*]
+ excluded_paths: [vendor/*, tests/*, examples/*]
+before_commands:
+ - 'composer install --dev --prefer-source'
+tools:
+ external_code_coverage:
+ timeout: 300
+ php_code_sniffer: true
+ php_cpd:
+ enabled: true
+ excluded_dirs: [vendor, tests, examples]
+ php_pdepend:
+ enabled: true
+ excluded_dirs: [vendor, tests, examples]
+ php_loc:
+ enabled: true
+ excluded_dirs: [vendor, tests, examples]
+ php_hhvm: false
+ php_mess_detector: true
+ php_analyzer: true
+changetracking:
+ bug_patterns: ["\bfix(?:es|ed)?\b"]
+ feature_patterns: ["\badd(?:s|ed)?\b", "\bimplement(?:s|ed)?\b"]
diff --git a/vendor/mockery/mockery/.styleci.yml b/vendor/mockery/mockery/.styleci.yml
new file mode 100644
index 000000000..247a09c5d
--- /dev/null
+++ b/vendor/mockery/mockery/.styleci.yml
@@ -0,0 +1 @@
+preset: psr2
diff --git a/vendor/mockery/mockery/.travis.yml b/vendor/mockery/mockery/.travis.yml
new file mode 100644
index 000000000..637b4d0c3
--- /dev/null
+++ b/vendor/mockery/mockery/.travis.yml
@@ -0,0 +1,42 @@
+language: php
+
+php:
+ - 5.3
+ - 5.4
+ - 5.5
+ - 5.6
+ - 7.0
+ - hhvm
+ - hhvm-nightly
+
+matrix:
+ allow_failures:
+ - php: hhvm
+ - php: hhvm-nightly
+
+sudo: false
+
+cache:
+ directories:
+ - $HOME/.composer/cache
+
+before_install:
+ - composer self-update
+
+install:
+ - travis_retry ./travis/install.sh
+
+before_script:
+ - ./travis/before_script.sh
+
+script:
+ - ./travis/script.sh
+
+after_success:
+ - ./travis/after_success.sh
+
+notifications:
+ email:
+ - padraic.brady@gmail.com
+ - dave@atstsolutions.co.uk
+ irc: "irc.freenode.org#mockery"
diff --git a/vendor/mockery/mockery/CHANGELOG.md b/vendor/mockery/mockery/CHANGELOG.md
new file mode 100644
index 000000000..187dfe325
--- /dev/null
+++ b/vendor/mockery/mockery/CHANGELOG.md
@@ -0,0 +1,48 @@
+# Change Log
+
+## 0.9.11 (2019-02-12)
+
+* Set property values on all related mocks #944
+
+## 0.9.4 (2015-04-02)
+
+* `shouldIgnoreMissing` will respect global `allowMockingNonExistentMethods`
+ config
+* Some support for variadic parameters
+* Hamcrest is now a required dependency
+* Instance mocks now respect `shouldIgnoreMissing` call on control instance
+* This will be the *last version to support PHP 5.3*
+* Added `Mockery\Adapter\Phpunit\MockeryPHPUnitIntegration` trait
+* Added `makePartial` to `Mockery\MockInterface` as it was missing
+
+## 0.9.3 (2014-12-22)
+
+* Added a basic spy implementation
+* Added `Mockery\Adapter\Phpunit\MockeryTestCase` for more reliable PHPUnit
+ integration
+
+## 0.9.2 (2014-09-03)
+
+* Some workarounds for the serilisation problems created by changes to PHP in 5.5.13, 5.4.29,
+ 5.6.
+* Demeter chains attempt to reuse doubles as they see fit, so for foo->bar and
+ foo->baz, we'll attempt to use the same foo
+
+## 0.9.1 (2014-05-02)
+
+* Allow specifying consecutive exceptions to be thrown with `andThrowExceptions`
+* Allow specifying methods which can be mocked when using
+ `Mockery\Configuration::allowMockingNonExistentMethods(false)` with
+ `Mockery\MockInterface::shouldAllowMockingMethod($methodName)`
+* Added andReturnSelf method: `$mock->shouldReceive("foo")->andReturnSelf()`
+* `shouldIgnoreMissing` now takes an optional value that will be return instead
+ of null, e.g. `$mock->shouldIgnoreMissing($mock)`
+
+## 0.9.0 (2014-02-05)
+
+* Allow mocking classes with final __wakeup() method
+* Quick definitions are now always `byDefault`
+* Allow mocking of protected methods with `shouldAllowMockingProtectedMethods`
+* Support official Hamcrest package
+* Generator completely rewritten
+* Easily create named mocks with namedMock
diff --git a/vendor/mockery/mockery/CONTRIBUTING.md b/vendor/mockery/mockery/CONTRIBUTING.md
new file mode 100644
index 000000000..9ceb66572
--- /dev/null
+++ b/vendor/mockery/mockery/CONTRIBUTING.md
@@ -0,0 +1,89 @@
+# Contributing
+
+
+We'd love you to help out with mockery and no contribution is too small.
+
+
+## Reporting Bugs
+
+Issues can be reported on the [issue
+tracker](https://github.com/padraic/mockery/issues). Please try and report any
+bugs with a minimal reproducible example, it will make things easier for other
+contributors and your problems will hopefully be resolved quickly.
+
+
+## Requesting Features
+
+We're always interested to hear about your ideas and you can request features by
+creating a ticket in the [issue
+tracker](https://github.com/padraic/mockery/issues). We can't always guarantee
+someone will jump on it straight away, but putting it out there to see if anyone
+else is interested is a good idea.
+
+Likewise, if a feature you would like is already listed in
+the issue tracker, add a :+1: so that other contributors know it's a feature
+that would help others.
+
+
+## Contributing code and documentation
+
+We loosely follow the
+[PSR-1](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-1-basic-coding-standard.md)
+and
+[PSR-2](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-2-coding-style-guide.md) coding standards,
+but we'll probably merge any code that looks close enough.
+
+* Fork the [repository](https://github.com/padraic/mockery) on GitHub
+* Add the code for your feature or bug
+* Add some tests for your feature or bug
+* Optionally, but preferably, write some documentation
+* Optionally, update the CHANGELOG.md file with your feature or
+ [BC](http://en.wikipedia.org/wiki/Backward_compatibility) break
+* If you have created new library files, add them to the root package.xml file for PEAR install support.
+* Send a [Pull
+ Request](https://help.github.com/articles/creating-a-pull-request) to the
+ correct target branch (see below)
+
+If you have a big change or would like to discuss something, create an issue in
+the [issue tracker](https://github.com/padraic/mockery/issues) or jump in to
+\#mockery on freenode
+
+
+Any code you contribute must be licensed under the [BSD 3-Clause
+License](http://opensource.org/licenses/BSD-3-Clause).
+
+
+## Target Branch
+
+Mockery may have several active branches at any one time and roughly follows a
+[Git Branching Model](https://igor.io/2013/10/21/git-branching-model.html).
+Generally, if you're developing a new feature, you want to be targeting the
+master branch, if it's a bug fix, you want to be targeting a release branch,
+e.g. 0.8.
+
+
+## Testing Mockery
+
+To run the unit tests for Mockery, clone the git repository, download Composer using
+the instructions at [http://getcomposer.org/download/](http://getcomposer.org/download/),
+then install the dependencies with `php /path/to/composer.phar install --dev`.
+
+This will install the required PHPUnit and Hamcrest dev dependencies and create the
+autoload files required by the unit tests. You may run the `vendor/bin/phpunit` command
+to run the unit tests. If everything goes to plan, there will be no failed tests!
+
+
+## Debugging Mockery
+
+Mockery and it's code generation can be difficult to debug. A good start is to
+use the `RequireLoader`, which will dump the code generated by mockery to a file
+before requiring it, rather than using eval. This will help with stack traces,
+and you will be able to open the mock class in your editor.
+
+``` php
+
+// tests/bootstrap.php
+
+Mockery::setLoader(new Mockery\Loader\RequireLoader(sys_get_temp_dir()));
+
+```
diff --git a/vendor/mockery/mockery/LICENSE b/vendor/mockery/mockery/LICENSE
new file mode 100644
index 000000000..2ca3b0640
--- /dev/null
+++ b/vendor/mockery/mockery/LICENSE
@@ -0,0 +1,27 @@
+Copyright (c) 2010-2014, Pádraic Brady
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without modification,
+are permitted provided that the following conditions are met:
+
+ * Redistributions of source code must retain the above copyright notice,
+ this list of conditions and the following disclaimer.
+
+ * Redistributions in binary form must reproduce the above copyright notice,
+ this list of conditions and the following disclaimer in the documentation
+ and/or other materials provided with the distribution.
+
+ * The name of Pádraic Brady may not be used to endorse or promote
+ products derived from this software without specific prior written
+ permission.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
+ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
+ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
diff --git a/vendor/mockery/mockery/README.md b/vendor/mockery/mockery/README.md
new file mode 100644
index 000000000..b22444316
--- /dev/null
+++ b/vendor/mockery/mockery/README.md
@@ -0,0 +1,68 @@
+Mockery
+=======
+
+[](http://travis-ci.org/mockery/mockery)
+[](https://packagist.org/packages/mockery/mockery)
+[](https://packagist.org/packages/mockery/mockery)
+
+
+Mockery is a simple yet flexible PHP mock object framework for use in unit testing
+with PHPUnit, PHPSpec or any other testing framework. Its core goal is to offer a
+test double framework with a succinct API capable of clearly defining all possible
+object operations and interactions using a human readable Domain Specific Language
+(DSL). Designed as a drop in alternative to PHPUnit's phpunit-mock-objects library,
+Mockery is easy to integrate with PHPUnit and can operate alongside
+phpunit-mock-objects without the World ending.
+
+Mockery is released under a New BSD License.
+
+The current released version on Packagist is 0.9.3.
+The current released version for PEAR is 0.9.0. Composer users may instead opt to use
+the current master branch aliased to 0.9.x-dev.
+
+## Installation
+
+To install Mockery, run the command below and you will get the latest
+version
+
+```sh
+composer require mockery/mockery
+```
+
+If you want to run the tests:
+
+```sh
+vendor/bin/phpunit
+```
+
+####Note
+
+The future Mockery 0.9.4 release will be the final version to have PHP 5.3
+as a minimum requirement. The minimum PHP requirement will thereafter move to
+PHP 5.4. Also, the PEAR channel will go offline permanently no earlier than 30
+June 2015.
+
+## Mock Objects
+
+In unit tests, mock objects simulate the behaviour of real objects. They are
+commonly utilised to offer test isolation, to stand in for objects which do not
+yet exist, or to allow for the exploratory design of class APIs without
+requiring actual implementation up front.
+
+The benefits of a mock object framework are to allow for the flexible generation
+of such mock objects (and stubs). They allow the setting of expected method calls
+and return values using a flexible API which is capable of capturing every
+possible real object behaviour in way that is stated as close as possible to a
+natural language description.
+
+
+## Prerequisites
+
+Mockery requires PHP 5.3.2 or greater. In addition, it is recommended to install
+the Hamcrest library (see below for instructions) which contains additional
+matchers used when defining expected method arguments.
+
+
+## Documentation
+
+The current version can be seen at [docs.mockery.io](http://docs.mockery.io).
diff --git a/vendor/mockery/mockery/composer.json b/vendor/mockery/mockery/composer.json
new file mode 100644
index 000000000..d538f0d24
--- /dev/null
+++ b/vendor/mockery/mockery/composer.json
@@ -0,0 +1,35 @@
+{
+ "name": "mockery/mockery",
+ "description": "Mockery is a simple yet flexible PHP mock object framework for use in unit testing with PHPUnit, PHPSpec or any other testing framework. Its core goal is to offer a test double framework with a succinct API capable of clearly defining all possible object operations and interactions using a human readable Domain Specific Language (DSL). Designed as a drop in alternative to PHPUnit's phpunit-mock-objects library, Mockery is easy to integrate with PHPUnit and can operate alongside phpunit-mock-objects without the World ending.",
+ "keywords": ["library", "testing", "test", "stub", "mock", "mockery", "test double", "tdd", "bdd", "mock objects"],
+ "homepage": "http://github.com/padraic/mockery",
+ "license": "BSD-3-Clause",
+ "authors": [
+ {
+ "name": "Pádraic Brady",
+ "email": "padraic.brady@gmail.com",
+ "homepage": "http://blog.astrumfutura.com"
+ },
+ {
+ "name": "Dave Marshall",
+ "email": "dave.marshall@atstsolutions.co.uk",
+ "homepage": "http://davedevelopment.co.uk"
+ }
+ ],
+ "require": {
+ "php": ">=5.3.2",
+ "lib-pcre": ">=7.0",
+ "hamcrest/hamcrest-php": "~1.1"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.0"
+ },
+ "autoload": {
+ "psr-0": { "Mockery": "library/" }
+ },
+ "extra": {
+ "branch-alias": {
+ "dev-master": "0.9.x-dev"
+ }
+ }
+}
diff --git a/vendor/mockery/mockery/docs/.gitignore b/vendor/mockery/mockery/docs/.gitignore
new file mode 100644
index 000000000..e35d8850c
--- /dev/null
+++ b/vendor/mockery/mockery/docs/.gitignore
@@ -0,0 +1 @@
+_build
diff --git a/vendor/mockery/mockery/docs/Makefile b/vendor/mockery/mockery/docs/Makefile
new file mode 100644
index 000000000..9a8c94087
--- /dev/null
+++ b/vendor/mockery/mockery/docs/Makefile
@@ -0,0 +1,177 @@
+# Makefile for Sphinx documentation
+#
+
+# You can set these variables from the command line.
+SPHINXOPTS =
+SPHINXBUILD = sphinx-build
+PAPER =
+BUILDDIR = _build
+
+# User-friendly check for sphinx-build
+ifeq ($(shell which $(SPHINXBUILD) >/dev/null 2>&1; echo $$?), 1)
+$(error The '$(SPHINXBUILD)' command was not found. Make sure you have Sphinx installed, then set the SPHINXBUILD environment variable to point to the full path of the '$(SPHINXBUILD)' executable. Alternatively you can add the directory with the executable to your PATH. If you don't have Sphinx installed, grab it from http://sphinx-doc.org/)
+endif
+
+# Internal variables.
+PAPEROPT_a4 = -D latex_paper_size=a4
+PAPEROPT_letter = -D latex_paper_size=letter
+ALLSPHINXOPTS = -d $(BUILDDIR)/doctrees $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) .
+# the i18n builder cannot share the environment and doctrees with the others
+I18NSPHINXOPTS = $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) .
+
+.PHONY: help clean html dirhtml singlehtml pickle json htmlhelp qthelp devhelp epub latex latexpdf text man changes linkcheck doctest gettext
+
+help:
+ @echo "Please use \`make ' where is one of"
+ @echo " html to make standalone HTML files"
+ @echo " dirhtml to make HTML files named index.html in directories"
+ @echo " singlehtml to make a single large HTML file"
+ @echo " pickle to make pickle files"
+ @echo " json to make JSON files"
+ @echo " htmlhelp to make HTML files and a HTML help project"
+ @echo " qthelp to make HTML files and a qthelp project"
+ @echo " devhelp to make HTML files and a Devhelp project"
+ @echo " epub to make an epub"
+ @echo " latex to make LaTeX files, you can set PAPER=a4 or PAPER=letter"
+ @echo " latexpdf to make LaTeX files and run them through pdflatex"
+ @echo " latexpdfja to make LaTeX files and run them through platex/dvipdfmx"
+ @echo " text to make text files"
+ @echo " man to make manual pages"
+ @echo " texinfo to make Texinfo files"
+ @echo " info to make Texinfo files and run them through makeinfo"
+ @echo " gettext to make PO message catalogs"
+ @echo " changes to make an overview of all changed/added/deprecated items"
+ @echo " xml to make Docutils-native XML files"
+ @echo " pseudoxml to make pseudoxml-XML files for display purposes"
+ @echo " linkcheck to check all external links for integrity"
+ @echo " doctest to run all doctests embedded in the documentation (if enabled)"
+
+clean:
+ rm -rf $(BUILDDIR)/*
+
+html:
+ $(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR)/html
+ @echo
+ @echo "Build finished. The HTML pages are in $(BUILDDIR)/html."
+
+dirhtml:
+ $(SPHINXBUILD) -b dirhtml $(ALLSPHINXOPTS) $(BUILDDIR)/dirhtml
+ @echo
+ @echo "Build finished. The HTML pages are in $(BUILDDIR)/dirhtml."
+
+singlehtml:
+ $(SPHINXBUILD) -b singlehtml $(ALLSPHINXOPTS) $(BUILDDIR)/singlehtml
+ @echo
+ @echo "Build finished. The HTML page is in $(BUILDDIR)/singlehtml."
+
+pickle:
+ $(SPHINXBUILD) -b pickle $(ALLSPHINXOPTS) $(BUILDDIR)/pickle
+ @echo
+ @echo "Build finished; now you can process the pickle files."
+
+json:
+ $(SPHINXBUILD) -b json $(ALLSPHINXOPTS) $(BUILDDIR)/json
+ @echo
+ @echo "Build finished; now you can process the JSON files."
+
+htmlhelp:
+ $(SPHINXBUILD) -b htmlhelp $(ALLSPHINXOPTS) $(BUILDDIR)/htmlhelp
+ @echo
+ @echo "Build finished; now you can run HTML Help Workshop with the" \
+ ".hhp project file in $(BUILDDIR)/htmlhelp."
+
+qthelp:
+ $(SPHINXBUILD) -b qthelp $(ALLSPHINXOPTS) $(BUILDDIR)/qthelp
+ @echo
+ @echo "Build finished; now you can run "qcollectiongenerator" with the" \
+ ".qhcp project file in $(BUILDDIR)/qthelp, like this:"
+ @echo "# qcollectiongenerator $(BUILDDIR)/qthelp/MockeryDocs.qhcp"
+ @echo "To view the help file:"
+ @echo "# assistant -collectionFile $(BUILDDIR)/qthelp/MockeryDocs.qhc"
+
+devhelp:
+ $(SPHINXBUILD) -b devhelp $(ALLSPHINXOPTS) $(BUILDDIR)/devhelp
+ @echo
+ @echo "Build finished."
+ @echo "To view the help file:"
+ @echo "# mkdir -p $$HOME/.local/share/devhelp/MockeryDocs"
+ @echo "# ln -s $(BUILDDIR)/devhelp $$HOME/.local/share/devhelp/MockeryDocs"
+ @echo "# devhelp"
+
+epub:
+ $(SPHINXBUILD) -b epub $(ALLSPHINXOPTS) $(BUILDDIR)/epub
+ @echo
+ @echo "Build finished. The epub file is in $(BUILDDIR)/epub."
+
+latex:
+ $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex
+ @echo
+ @echo "Build finished; the LaTeX files are in $(BUILDDIR)/latex."
+ @echo "Run \`make' in that directory to run these through (pdf)latex" \
+ "(use \`make latexpdf' here to do that automatically)."
+
+latexpdf:
+ $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex
+ @echo "Running LaTeX files through pdflatex..."
+ $(MAKE) -C $(BUILDDIR)/latex all-pdf
+ @echo "pdflatex finished; the PDF files are in $(BUILDDIR)/latex."
+
+latexpdfja:
+ $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex
+ @echo "Running LaTeX files through platex and dvipdfmx..."
+ $(MAKE) -C $(BUILDDIR)/latex all-pdf-ja
+ @echo "pdflatex finished; the PDF files are in $(BUILDDIR)/latex."
+
+text:
+ $(SPHINXBUILD) -b text $(ALLSPHINXOPTS) $(BUILDDIR)/text
+ @echo
+ @echo "Build finished. The text files are in $(BUILDDIR)/text."
+
+man:
+ $(SPHINXBUILD) -b man $(ALLSPHINXOPTS) $(BUILDDIR)/man
+ @echo
+ @echo "Build finished. The manual pages are in $(BUILDDIR)/man."
+
+texinfo:
+ $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo
+ @echo
+ @echo "Build finished. The Texinfo files are in $(BUILDDIR)/texinfo."
+ @echo "Run \`make' in that directory to run these through makeinfo" \
+ "(use \`make info' here to do that automatically)."
+
+info:
+ $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo
+ @echo "Running Texinfo files through makeinfo..."
+ make -C $(BUILDDIR)/texinfo info
+ @echo "makeinfo finished; the Info files are in $(BUILDDIR)/texinfo."
+
+gettext:
+ $(SPHINXBUILD) -b gettext $(I18NSPHINXOPTS) $(BUILDDIR)/locale
+ @echo
+ @echo "Build finished. The message catalogs are in $(BUILDDIR)/locale."
+
+changes:
+ $(SPHINXBUILD) -b changes $(ALLSPHINXOPTS) $(BUILDDIR)/changes
+ @echo
+ @echo "The overview file is in $(BUILDDIR)/changes."
+
+linkcheck:
+ $(SPHINXBUILD) -b linkcheck $(ALLSPHINXOPTS) $(BUILDDIR)/linkcheck
+ @echo
+ @echo "Link check complete; look for any errors in the above output " \
+ "or in $(BUILDDIR)/linkcheck/output.txt."
+
+doctest:
+ $(SPHINXBUILD) -b doctest $(ALLSPHINXOPTS) $(BUILDDIR)/doctest
+ @echo "Testing of doctests in the sources finished, look at the " \
+ "results in $(BUILDDIR)/doctest/output.txt."
+
+xml:
+ $(SPHINXBUILD) -b xml $(ALLSPHINXOPTS) $(BUILDDIR)/xml
+ @echo
+ @echo "Build finished. The XML files are in $(BUILDDIR)/xml."
+
+pseudoxml:
+ $(SPHINXBUILD) -b pseudoxml $(ALLSPHINXOPTS) $(BUILDDIR)/pseudoxml
+ @echo
+ @echo "Build finished. The pseudo-XML files are in $(BUILDDIR)/pseudoxml."
diff --git a/vendor/mockery/mockery/docs/README.md b/vendor/mockery/mockery/docs/README.md
new file mode 100644
index 000000000..63ca69db7
--- /dev/null
+++ b/vendor/mockery/mockery/docs/README.md
@@ -0,0 +1,4 @@
+mockery-docs
+============
+
+Document for the PHP Mockery framework on readthedocs.org
\ No newline at end of file
diff --git a/vendor/mockery/mockery/docs/conf.py b/vendor/mockery/mockery/docs/conf.py
new file mode 100644
index 000000000..088cdcc21
--- /dev/null
+++ b/vendor/mockery/mockery/docs/conf.py
@@ -0,0 +1,259 @@
+# -*- coding: utf-8 -*-
+#
+# Mockery Docs documentation build configuration file, created by
+# sphinx-quickstart on Mon Mar 3 14:04:26 2014.
+#
+# This file is execfile()d with the current directory set to its
+# containing dir.
+#
+# Note that not all possible configuration values are present in this
+# autogenerated file.
+#
+# All configuration values have a default; values that are commented out
+# serve to show the default.
+
+import sys
+import os
+
+# If extensions (or modules to document with autodoc) are in another directory,
+# add these directories to sys.path here. If the directory is relative to the
+# documentation root, use os.path.abspath to make it absolute, like shown here.
+#sys.path.insert(0, os.path.abspath('.'))
+
+# -- General configuration ------------------------------------------------
+
+# If your documentation needs a minimal Sphinx version, state it here.
+#needs_sphinx = '1.0'
+
+# Add any Sphinx extension module names here, as strings. They can be
+# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
+# ones.
+extensions = [
+ 'sphinx.ext.todo',
+]
+
+# Add any paths that contain templates here, relative to this directory.
+templates_path = ['_templates']
+
+# The suffix of source filenames.
+source_suffix = '.rst'
+
+# The encoding of source files.
+#source_encoding = 'utf-8-sig'
+
+# The master toctree document.
+master_doc = 'index'
+
+# General information about the project.
+project = u'Mockery Docs'
+copyright = u'2014, Pádraic Brady, Dave Marshall, Wouter, Graham Campbell'
+
+# The version info for the project you're documenting, acts as replacement for
+# |version| and |release|, also used in various other places throughout the
+# built documents.
+#
+# The short X.Y version.
+version = '0.9'
+# The full version, including alpha/beta/rc tags.
+release = '0.9'
+
+# The language for content autogenerated by Sphinx. Refer to documentation
+# for a list of supported languages.
+#language = None
+
+# There are two options for replacing |today|: either, you set today to some
+# non-false value, then it is used:
+#today = ''
+# Else, today_fmt is used as the format for a strftime call.
+#today_fmt = '%B %d, %Y'
+
+# List of patterns, relative to source directory, that match files and
+# directories to ignore when looking for source files.
+exclude_patterns = ['_build']
+
+# The reST default role (used for this markup: `text`) to use for all
+# documents.
+#default_role = None
+
+# If true, '()' will be appended to :func: etc. cross-reference text.
+#add_function_parentheses = True
+
+# If true, the current module name will be prepended to all description
+# unit titles (such as .. function::).
+#add_module_names = True
+
+# If true, sectionauthor and moduleauthor directives will be shown in the
+# output. They are ignored by default.
+#show_authors = False
+
+# The name of the Pygments (syntax highlighting) style to use.
+pygments_style = 'sphinx'
+
+# A list of ignored prefixes for module index sorting.
+#modindex_common_prefix = []
+
+# If true, keep warnings as "system message" paragraphs in the built documents.
+#keep_warnings = False
+
+
+# -- Options for HTML output ----------------------------------------------
+
+# The theme to use for HTML and HTML Help pages. See the documentation for
+# a list of builtin themes.
+html_theme = 'default'
+
+# Theme options are theme-specific and customize the look and feel of a theme
+# further. For a list of options available for each theme, see the
+# documentation.
+#html_theme_options = {}
+
+# Add any paths that contain custom themes here, relative to this directory.
+#html_theme_path = []
+
+# The name of an image file (within the static path) to use as favicon of the
+# docs. This file should be a Windows icon file (.ico) being 16x16 or 32x32
+# pixels large.
+#html_favicon = None
+
+# Add any paths that contain custom static files (such as style sheets) here,
+# relative to this directory. They are copied after the builtin static files,
+# so a file named "default.css" will overwrite the builtin "default.css".
+html_static_path = ['_static']
+
+# Add any extra paths that contain custom files (such as robots.txt or
+# .htaccess) here, relative to this directory. These files are copied
+# directly to the root of the documentation.
+#html_extra_path = []
+
+# If not '', a 'Last updated on:' timestamp is inserted at every page bottom,
+# using the given strftime format.
+#html_last_updated_fmt = '%b %d, %Y'
+
+# If true, SmartyPants will be used to convert quotes and dashes to
+# typographically correct entities.
+#html_use_smartypants = True
+
+# Custom sidebar templates, maps document names to template names.
+#html_sidebars = {}
+
+# Additional templates that should be rendered to pages, maps page names to
+# template names.
+#html_additional_pages = {}
+
+# If false, no module index is generated.
+#html_domain_indices = True
+
+# If false, no index is generated.
+#html_use_index = True
+
+# If true, the index is split into individual pages for each letter.
+#html_split_index = False
+
+# If true, links to the reST sources are added to the pages.
+#html_show_sourcelink = True
+
+# If true, "Created using Sphinx" is shown in the HTML footer. Default is True.
+#html_show_sphinx = True
+
+# If true, "(C) Copyright ..." is shown in the HTML footer. Default is True.
+#html_show_copyright = True
+
+# If true, an OpenSearch description file will be output, and all pages will
+# contain a tag referring to it. The value of this option must be the
+# base URL from which the finished HTML is served.
+#html_use_opensearch = ''
+
+# This is the file name suffix for HTML files (e.g. ".xhtml").
+#html_file_suffix = None
+
+# Output file base name for HTML help builder.
+htmlhelp_basename = 'MockeryDocsdoc'
+
+
+# -- Options for LaTeX output ---------------------------------------------
+
+latex_elements = {
+# The paper size ('letterpaper' or 'a4paper').
+#'papersize': 'letterpaper',
+
+# The font size ('10pt', '11pt' or '12pt').
+#'pointsize': '10pt',
+
+# Additional stuff for the LaTeX preamble.
+#'preamble': '',
+}
+
+# Grouping the document tree into LaTeX files. List of tuples
+# (source start file, target name, title,
+# author, documentclass [howto, manual, or own class]).
+latex_documents = [
+ ('index2', 'MockeryDocs.tex', u'Mockery Docs Documentation',
+ u'Pádraic Brady, Dave Marshall, Wouter, Graham Campbell', 'manual'),
+]
+
+# The name of an image file (relative to this directory) to place at the top of
+# the title page.
+#latex_logo = None
+
+# For "manual" documents, if this is true, then toplevel headings are parts,
+# not chapters.
+#latex_use_parts = False
+
+# If true, show page references after internal links.
+#latex_show_pagerefs = False
+
+# If true, show URL addresses after external links.
+#latex_show_urls = False
+
+# Documents to append as an appendix to all manuals.
+#latex_appendices = []
+
+# If false, no module index is generated.
+#latex_domain_indices = True
+
+
+# -- Options for manual page output ---------------------------------------
+
+# One entry per manual page. List of tuples
+# (source start file, name, description, authors, manual section).
+man_pages = [
+ ('index2', 'mockerydocs', u'Mockery Docs Documentation',
+ [u'Pádraic Brady, Dave Marshall, Wouter, Graham Campbell'], 1)
+]
+
+# If true, show URL addresses after external links.
+#man_show_urls = False
+
+
+# -- Options for Texinfo output -------------------------------------------
+
+# Grouping the document tree into Texinfo files. List of tuples
+# (source start file, target name, title, author,
+# dir menu entry, description, category)
+texinfo_documents = [
+ ('index2', 'MockeryDocs', u'Mockery Docs Documentation',
+ u'Pádraic Brady, Dave Marshall, Wouter, Graham Campbell', 'MockeryDocs', 'One line description of project.',
+ 'Miscellaneous'),
+]
+
+# Documents to append as an appendix to all manuals.
+#texinfo_appendices = []
+
+# If false, no module index is generated.
+#texinfo_domain_indices = True
+
+# How to display URL addresses: 'footnote', 'no', or 'inline'.
+#texinfo_show_urls = 'footnote'
+
+# If true, do not generate a @detailmenu in the "Top" node's menu.
+#texinfo_no_detailmenu = False
+
+
+#on_rtd is whether we are on readthedocs.org, this line of code grabbed from docs.readthedocs.org
+on_rtd = os.environ.get('READTHEDOCS', None) == 'True'
+
+if not on_rtd: # only import and set the theme if we're building docs locally
+ import sphinx_rtd_theme
+ html_theme = 'sphinx_rtd_theme'
+ html_theme_path = [sphinx_rtd_theme.get_html_theme_path()]
+ print sphinx_rtd_theme.get_html_theme_path()
diff --git a/vendor/mockery/mockery/docs/cookbook/default_expectations.rst b/vendor/mockery/mockery/docs/cookbook/default_expectations.rst
new file mode 100644
index 000000000..2c6fcae23
--- /dev/null
+++ b/vendor/mockery/mockery/docs/cookbook/default_expectations.rst
@@ -0,0 +1,17 @@
+.. index::
+ single: Cookbook; Default Mock Expectations
+
+Default Mock Expectations
+=========================
+
+Often in unit testing, we end up with sets of tests which use the same object
+dependency over and over again. Rather than mocking this class/object within
+every single unit test (requiring a mountain of duplicate code), we can
+instead define reusable default mocks within the test case's ``setup()``
+method. This even works where unit tests use varying expectations on the same
+or similar mock object.
+
+How this works, is that you can define mocks with default expectations. Then,
+in a later unit test, you can add or fine-tune expectations for that specific
+test. Any expectation can be set as a default using the ``byDefault()``
+declaration.
diff --git a/vendor/mockery/mockery/docs/cookbook/detecting_mock_objects.rst b/vendor/mockery/mockery/docs/cookbook/detecting_mock_objects.rst
new file mode 100644
index 000000000..0210c692b
--- /dev/null
+++ b/vendor/mockery/mockery/docs/cookbook/detecting_mock_objects.rst
@@ -0,0 +1,13 @@
+.. index::
+ single: Cookbook; Detecting Mock Objects
+
+Detecting Mock Objects
+======================
+
+Users may find it useful to check whether a given object is a real object or a
+simulated Mock Object. All Mockery mocks implement the
+``\Mockery\MockInterface`` interface which can be used in a type check.
+
+.. code-block:: php
+
+ assert($mightBeMocked instanceof \Mockery\MockInterface);
diff --git a/vendor/mockery/mockery/docs/cookbook/index.rst b/vendor/mockery/mockery/docs/cookbook/index.rst
new file mode 100644
index 000000000..a1fc36f96
--- /dev/null
+++ b/vendor/mockery/mockery/docs/cookbook/index.rst
@@ -0,0 +1,11 @@
+Cookbook
+========
+
+.. toctree::
+ :hidden:
+
+ default_expectations
+ detecting_mock_objects
+ mocking_hard_dependencies
+
+.. include:: map.rst.inc
diff --git a/vendor/mockery/mockery/docs/cookbook/map.rst.inc b/vendor/mockery/mockery/docs/cookbook/map.rst.inc
new file mode 100644
index 000000000..e128f80d0
--- /dev/null
+++ b/vendor/mockery/mockery/docs/cookbook/map.rst.inc
@@ -0,0 +1,3 @@
+* :doc:`/cookbook/default_expectations`
+* :doc:`/cookbook/detecting_mock_objects`
+* :doc:`/cookbook/mocking_hard_dependencies`
diff --git a/vendor/mockery/mockery/docs/cookbook/mocking_hard_dependencies.rst b/vendor/mockery/mockery/docs/cookbook/mocking_hard_dependencies.rst
new file mode 100644
index 000000000..6d6271978
--- /dev/null
+++ b/vendor/mockery/mockery/docs/cookbook/mocking_hard_dependencies.rst
@@ -0,0 +1,93 @@
+.. index::
+ single: Cookbook; Mocking Hard Dependencies
+
+Mocking Hard Dependencies (new Keyword)
+=======================================
+
+One prerequisite to mock hard dependencies is that the code we are trying to test uses autoloading.
+
+Let's take the following code for an example:
+
+.. code-block:: php
+
+ sendSomething($param);
+ return $externalService->getSomething();
+ }
+ }
+
+The way we can test this without doing any changes to the code itself is by creating :doc:`instance mocks ` by using the ``overload`` prefix.
+
+.. code-block:: php
+
+ shouldReceive('sendSomething')
+ ->once()
+ ->with($param);
+ $externalMock->shouldReceive('getSomething')
+ ->once()
+ ->andReturn('Tested!');
+
+ $service = new \App\Service();
+
+ $result = $service->callExternalService($param);
+
+ $this->assertSame('Tested!', $result);
+ }
+ }
+
+If we run this test now, it should pass. Mockery does its job and our ``App\Service`` will use the mocked external service instead of the real one.
+
+The problem with this is when we want to, for example, test the ``App\Service\External`` itself, or if we use that class somewhere else in our tests.
+
+When Mockery overloads a class, because of how PHP works with files, that overloaded class file must not be included otherwise Mockery will throw a "class already exists" exception. This is where autoloading kicks in and makes our job a lot easier.
+
+To make this possible, we'll tell PHPUnit to run the tests that have overloaded classes in separate processes and to not preserve global state. That way we'll avoid having the overloaded class included more than once. Of course this has its downsides as these tests will run slower.
+
+Our test example from above now becomes:
+
+.. code-block:: php
+
+ shouldReceive('sendSomething')
+ ->once()
+ ->with($param);
+ $externalMock->shouldReceive('getSomething')
+ ->once()
+ ->andReturn('Tested!');
+
+ $service = new \App\Service();
+
+ $result = $service->callExternalService($param);
+
+ $this->assertSame('Tested!', $result);
+ }
+ }
diff --git a/vendor/mockery/mockery/docs/getting_started/index.rst b/vendor/mockery/mockery/docs/getting_started/index.rst
new file mode 100644
index 000000000..df30ee2b7
--- /dev/null
+++ b/vendor/mockery/mockery/docs/getting_started/index.rst
@@ -0,0 +1,11 @@
+Getting Started
+===============
+
+.. toctree::
+ :hidden:
+
+ installation
+ upgrading
+ simple_example
+
+.. include:: map.rst.inc
diff --git a/vendor/mockery/mockery/docs/getting_started/installation.rst b/vendor/mockery/mockery/docs/getting_started/installation.rst
new file mode 100644
index 000000000..46a27833c
--- /dev/null
+++ b/vendor/mockery/mockery/docs/getting_started/installation.rst
@@ -0,0 +1,68 @@
+.. index::
+ single: Installation
+
+Installation
+============
+
+Mockery can be installed using Composer, PEAR or by cloning it from its GitHub
+repository. These three options are outlined below.
+
+Composer
+--------
+
+You can read more about Composer on `getcomposer.org `_.
+To install Mockery using Composer, first install Composer for your project
+using the instructions on the `Composer download page `_.
+You can then define your development dependency on Mockery using the suggested
+parameters below. While every effort is made to keep the master branch stable,
+you may prefer to use the current stable version tag instead (use the
+``@stable`` tag).
+
+.. code-block:: json
+
+ {
+ "require-dev": {
+ "mockery/mockery": "dev-master"
+ }
+ }
+
+To install, you then may call:
+
+.. code-block:: bash
+
+ php composer.phar update
+
+This will install Mockery as a development dependency, meaning it won't be
+installed when using ``php composer.phar update --no-dev`` in production.
+
+PEAR
+----
+
+Mockery is hosted on the `survivethedeepend.com `_
+PEAR channel and can be installed using the following commands:
+
+.. code-block:: bash
+
+ sudo pear channel-discover pear.survivethedeepend.com
+ sudo pear channel-discover hamcrest.googlecode.com/svn/pear
+ sudo pear install --alldeps deepend/Mockery
+
+Git
+---
+
+The Git repository hosts the development version in its master branch. You can
+install this using Composer by referencing ``dev-master`` as your preferred
+version in your project's ``composer.json`` file as the earlier example shows.
+
+You may also install this development version using PEAR:
+
+.. code-block:: bash
+
+ git clone git://github.com/padraic/mockery.git
+ cd mockery
+ sudo pear channel-discover hamcrest.googlecode.com/svn/pear
+ sudo pear install --alldeps package.xml
+
+The above processes will install both Mockery and Hamcrest. While omitting
+Hamcrest will not break Mockery, Hamcrest is recommended as it adds a wider
+variety of functionality for argument matching.
diff --git a/vendor/mockery/mockery/docs/getting_started/map.rst.inc b/vendor/mockery/mockery/docs/getting_started/map.rst.inc
new file mode 100644
index 000000000..9a1dbc874
--- /dev/null
+++ b/vendor/mockery/mockery/docs/getting_started/map.rst.inc
@@ -0,0 +1,3 @@
+* :doc:`/getting_started/installation`
+* :doc:`/getting_started/upgrading`
+* :doc:`/getting_started/simple_example`
diff --git a/vendor/mockery/mockery/docs/getting_started/simple_example.rst b/vendor/mockery/mockery/docs/getting_started/simple_example.rst
new file mode 100644
index 000000000..d150dd83b
--- /dev/null
+++ b/vendor/mockery/mockery/docs/getting_started/simple_example.rst
@@ -0,0 +1,66 @@
+.. index::
+ single: Getting Started; Simple Example
+
+Simple Example
+==============
+
+Imagine we have a ``Temperature`` class which samples the temperature of a
+locale before reporting an average temperature. The data could come from a web
+service or any other data source, but we do not have such a class at present.
+We can, however, assume some basic interactions with such a class based on its
+interaction with the ``Temperature`` class:
+
+.. code-block:: php
+
+ class Temperature
+ {
+
+ public function __construct($service)
+ {
+ $this->_service = $service;
+ }
+
+ public function average()
+ {
+ $total = 0;
+ for ($i=0;$i<3;$i++) {
+ $total += $this->_service->readTemp();
+ }
+ return $total/3;
+ }
+
+ }
+
+Even without an actual service class, we can see how we expect it to operate.
+When writing a test for the ``Temperature`` class, we can now substitute a
+mock object for the real service which allows us to test the behaviour of the
+``Temperature`` class without actually needing a concrete service instance.
+
+.. code-block:: php
+
+ use \Mockery as m;
+
+ class TemperatureTest extends PHPUnit_Framework_TestCase
+ {
+
+ public function tearDown()
+ {
+ m::close();
+ }
+
+ public function testGetsAverageTemperatureFromThreeServiceReadings()
+ {
+ $service = m::mock('service');
+ $service->shouldReceive('readTemp')->times(3)->andReturn(10, 12, 14);
+
+ $temperature = new Temperature($service);
+
+ $this->assertEquals(12, $temperature->average());
+ }
+
+ }
+
+.. note::
+
+ PHPUnit integration can remove the need for a ``tearDown()`` method. See
+ ":doc:`/reference/phpunit_integration`" for more information.
diff --git a/vendor/mockery/mockery/docs/getting_started/upgrading.rst b/vendor/mockery/mockery/docs/getting_started/upgrading.rst
new file mode 100644
index 000000000..d8cd291d3
--- /dev/null
+++ b/vendor/mockery/mockery/docs/getting_started/upgrading.rst
@@ -0,0 +1,26 @@
+.. index::
+ single: Upgrading
+
+Upgrading
+=========
+
+Upgrading to 0.9
+----------------
+
+The generator was completely rewritten, so any code with a deep integration to
+mockery will need evaluating
+
+Upgrading to 0.8
+----------------
+
+Since the release of 0.8.0 the following behaviours were altered:
+
+1. The ``shouldIgnoreMissing()`` behaviour optionally applied to mock objects
+ returned an instance of ``\Mockery\Undefined`` when methods called did not
+ match a known expectation. Since 0.8.0, this behaviour was switched to
+ returning ``null`` instead. You can restore the 0.7.2 behavour by using the
+ following:
+
+ .. code-block:: php
+
+ $mock = \Mockery::mock('stdClass')->shouldIgnoreMissing()->asUndefined();
diff --git a/vendor/mockery/mockery/docs/index.rst b/vendor/mockery/mockery/docs/index.rst
new file mode 100644
index 000000000..8f09b6c44
--- /dev/null
+++ b/vendor/mockery/mockery/docs/index.rst
@@ -0,0 +1,64 @@
+Mockery
+=======
+
+Mockery is a simple yet flexible PHP mock object framework for use in unit
+testing with PHPUnit, PHPSpec or any other testing framework. Its core goal is
+to offer a test double framework with a succinct API capable of clearly
+defining all possible object operations and interactions using a human
+readable Domain Specific Language (DSL). Designed as a drop in alternative to
+PHPUnit's phpunit-mock-objects library, Mockery is easy to integrate with
+PHPUnit and can operate alongside phpunit-mock-objects without the World
+ending.
+
+Mock Objects
+------------
+
+In unit tests, mock objects simulate the behaviour of real objects. They are
+commonly utilised to offer test isolation, to stand in for objects which do
+not yet exist, or to allow for the exploratory design of class APIs without
+requiring actual implementation up front.
+
+The benefits of a mock object framework are to allow for the flexible
+generation of such mock objects (and stubs). They allow the setting of
+expected method calls and return values using a flexible API which is capable
+of capturing every possible real object behaviour in way that is stated as
+close as possible to a natural language description.
+
+Getting Started
+---------------
+
+Ready to dive into the Mockery framework? Then you can get started by reading
+the "Getting Started" section!
+
+.. toctree::
+ :hidden:
+
+ getting_started/index
+
+.. include:: getting_started/map.rst.inc
+
+Reference
+---------
+
+The reference contains a complete overview of all features of the Mockery
+framework.
+
+.. toctree::
+ :hidden:
+
+ reference/index
+
+.. include:: reference/map.rst.inc
+
+Cookbook
+--------
+
+Want to learn some easy tips and tricks? Take a look at the cookbook articles!
+
+.. toctree::
+ :hidden:
+
+ cookbook/index
+
+.. include:: cookbook/map.rst.inc
+
diff --git a/vendor/mockery/mockery/docs/reference/argument_validation.rst b/vendor/mockery/mockery/docs/reference/argument_validation.rst
new file mode 100644
index 000000000..2696fc89d
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/argument_validation.rst
@@ -0,0 +1,168 @@
+.. index::
+ single: Argument Validation
+
+Argument Validation
+===================
+
+The arguments passed to the ``with()`` declaration when setting up an
+expectation determine the criteria for matching method calls to expectations.
+Thus, you can setup up many expectations for a single method, each
+differentiated by the expected arguments. Such argument matching is done on a
+"best fit" basis. This ensures explicit matches take precedence over
+generalised matches.
+
+An explicit match is merely where the expected argument and the actual
+argument are easily equated (i.e. using ``===`` or ``==``). More generalised
+matches are possible using regular expressions, class hinting and the
+available generic matchers. The purpose of generalised matchers is to allow
+arguments be defined in non-explicit terms, e.g. ``Mockery::any()`` passed to
+``with()`` will match **any** argument in that position.
+
+Mockery's generic matchers do not cover all possibilities but offers optional
+support for the Hamcrest library of matchers. Hamcrest is a PHP port of the
+similarly named Java library (which has been ported also to Python, Erlang,
+etc). I strongly recommend using Hamcrest since Mockery simply does not need
+to duplicate Hamcrest's already impressive utility which itself promotes a
+natural English DSL.
+
+The example below show Mockery matchers and their Hamcrest equivalent.
+Hamcrest uses functions (no namespacing).
+
+Here's a sample of the possibilities.
+
+.. code-block:: php
+
+ with(1)
+
+Matches the integer ``1``. This passes the ``===`` test (identical). It does
+facilitate a less strict ``==`` check (equals) where the string ``'1'`` would
+also match the
+argument.
+
+.. code-block:: php
+
+ with(\Mockery::any()) OR with(anything())
+
+Matches any argument. Basically, anything and everything passed in this
+argument slot is passed unconstrained.
+
+.. code-block:: php
+
+ with(\Mockery::type('resource')) OR with(resourceValue()) OR with(typeOf('resource'))
+
+Matches any resource, i.e. returns true from an ``is_resource()`` call. The
+Type matcher accepts any string which can be attached to ``is_`` to form a
+valid type check. For example, ``\Mockery::type('float')`` or Hamcrest's
+``floatValue()`` and ``typeOf('float')`` checks using ``is_float()``, and
+``\Mockery::type('callable')`` or Hamcrest's ``callable()`` uses
+``is_callable()``.
+
+The Type matcher also accepts a class or interface name to be used in an
+``instanceof`` evaluation of the actual argument (similarly Hamcrest uses
+``anInstanceOf()``).
+
+You may find a full list of the available type checkers at
+`php.net `_ or browse Hamcrest's function
+list in
+`the Hamcrest code `_.
+
+.. code-block:: php
+
+ with(\Mockery::on(closure))
+
+The On matcher accepts a closure (anonymous function) to which the actual
+argument will be passed. If the closure evaluates to (i.e. returns) boolean
+``true`` then the argument is assumed to have matched the expectation. This is
+invaluable where your argument expectation is a bit too complex for or simply
+not implemented in the current default matchers.
+
+There is no Hamcrest version of this functionality.
+
+.. code-block:: php
+
+ with('/^foo/') OR with(matchesPattern('/^foo/'))
+
+The argument declarator also assumes any given string may be a regular
+expression to be used against actual arguments when matching. The regex option
+is only used when a) there is no ``===`` or ``==`` match and b) when the regex
+is verified to be a valid regex (i.e. does not return false from
+``preg_match()``). If the regex detection doesn't suit your tastes, Hamcrest
+offers the more explicit ``matchesPattern()`` function.
+
+.. code-block:: php
+
+ with(\Mockery::ducktype('foo', 'bar'))
+
+The Ducktype matcher is an alternative to matching by class type. It simply
+matches any argument which is an object containing the provided list of
+methods to call.
+
+There is no Hamcrest version of this functionality.
+
+.. code-block:: php
+
+ with(\Mockery::mustBe(2)) OR with(identicalTo(2))
+
+The MustBe matcher is more strict than the default argument matcher. The
+default matcher allows for PHP type casting, but the MustBe matcher also
+verifies that the argument must be of the same type as the expected value.
+Thus by default, the argument `'2'` matches the actual argument 2 (integer)
+but the MustBe matcher would fail in the same situation since the expected
+argument was a string and instead we got an integer.
+
+Note: Objects are not subject to an identical comparison using this matcher
+since PHP would fail the comparison if both objects were not the exact same
+instance. This is a hindrance when objects are generated prior to being
+returned, since an identical match just would never be possible.
+
+.. code-block:: php
+
+ with(\Mockery::not(2)) OR with(not(2))
+
+The Not matcher matches any argument which is not equal or identical to the
+matcher's parameter.
+
+.. code-block:: php
+
+ with(\Mockery::anyOf(1, 2)) OR with(anyOf(1,2))
+
+Matches any argument which equals any one of the given parameters.
+
+.. code-block:: php
+
+ with(\Mockery::notAnyOf(1, 2))
+
+Matches any argument which is not equal or identical to any of the given
+parameters.
+
+There is no Hamcrest version of this functionality.
+
+.. code-block:: php
+
+ with(\Mockery::subset(array(0 => 'foo')))
+
+Matches any argument which is any array containing the given array subset.
+This enforces both key naming and values, i.e. both the key and value of each
+actual element is compared.
+
+There is no Hamcrest version of this functionality, though Hamcrest can check
+a single entry using ``hasEntry()`` or ``hasKeyValuePair()``.
+
+.. code-block:: php
+
+ with(\Mockery::contains(value1, value2))
+
+Matches any argument which is an array containing the listed values. The
+naming of keys is ignored.
+
+.. code-block:: php
+
+ with(\Mockery::hasKey(key));
+
+Matches any argument which is an array containing the given key name.
+
+.. code-block:: php
+
+ with(\Mockery::hasValue(value));
+
+Matches any argument which is an array containing the given value.
diff --git a/vendor/mockery/mockery/docs/reference/demeter_chains.rst b/vendor/mockery/mockery/docs/reference/demeter_chains.rst
new file mode 100644
index 000000000..531d017fb
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/demeter_chains.rst
@@ -0,0 +1,38 @@
+.. index::
+ single: Mocking; Demeter Chains
+
+Mocking Demeter Chains And Fluent Interfaces
+============================================
+
+Both of these terms refer to the growing practice of invoking statements
+similar to:
+
+.. code-block:: php
+
+ $object->foo()->bar()->zebra()->alpha()->selfDestruct();
+
+The long chain of method calls isn't necessarily a bad thing, assuming they
+each link back to a local object the calling class knows. Just as a fun
+example, Mockery's long chains (after the first ``shouldReceive()`` method)
+all call to the same instance of ``\Mockery\Expectation``. However, sometimes
+this is not the case and the chain is constantly crossing object boundaries.
+
+In either case, mocking such a chain can be a horrible task. To make it easier
+Mockery support demeter chain mocking. Essentially, we shortcut through the
+chain and return a defined value from the final call. For example, let's
+assume ``selfDestruct()`` returns the string "Ten!" to $object (an instance of
+``CaptainsConsole``). Here's how we could mock it.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('CaptainsConsole');
+ $mock->shouldReceive('foo->bar->zebra->alpha->selfDestruct')->andReturn('Ten!');
+
+The above expectation can follow any previously seen format or expectation,
+except that the method name is simply the string of all expected chain calls
+separated by ``->``. Mockery will automatically setup the chain of expected
+calls with its final return values, regardless of whatever intermediary object
+might be used in the real implementation.
+
+Arguments to all members of the chain (except the final call) are ignored in
+this process.
diff --git a/vendor/mockery/mockery/docs/reference/expectations.rst b/vendor/mockery/mockery/docs/reference/expectations.rst
new file mode 100644
index 000000000..e9175098d
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/expectations.rst
@@ -0,0 +1,260 @@
+.. index::
+ single: Expectations
+
+Expectation Declarations
+========================
+
+Once you have created a mock object, you'll often want to start defining how
+exactly it should behave (and how it should be called). This is where the
+Mockery expectation declarations take over.
+
+.. code-block:: php
+
+ shouldReceive(method_name)
+
+Declares that the mock expects a call to the given method name. This is the
+starting expectation upon which all other expectations and constraints are
+appended.
+
+.. code-block:: php
+
+ shouldReceive(method1, method2, ...)
+
+Declares a number of expected method calls, all of which will adopt any
+chained expectations or constraints.
+
+.. code-block:: php
+
+ shouldReceive(array('method1'=>1, 'method2'=>2, ...))
+
+Declares a number of expected calls but also their return values. All will
+adopt any additional chained expectations or constraints.
+
+.. code-block:: php
+
+ shouldReceive(closure)
+
+Creates a mock object (only from a partial mock) which is used to create a
+mock object recorder. The recorder is a simple proxy to the original object
+passed in for mocking. This is passed to the closure, which may run it through
+a set of operations which are recorded as expectations on the partial mock. A
+simple use case is automatically recording expectations based on an existing
+usage (e.g. during refactoring). See examples in a later section.
+
+.. code-block:: php
+
+ shouldNotReceive(method_name)
+
+Declares that the mock should not expect a call to the given method name. This
+method is a convenience method for calling ``shouldReceive()->never()``.
+
+.. code-block:: php
+
+ with(arg1, arg2, ...) / withArgs(array(arg1, arg2, ...))
+
+Adds a constraint that this expectation only applies to method calls which
+match the expected argument list. You can add a lot more flexibility to
+argument matching using the built in matcher classes (see later). For example,
+``\Mockery::any()`` matches any argument passed to that position in the
+``with()`` parameter list. Mockery also allows Hamcrest library matchers - for
+example, the Hamcrest function ``anything()`` is equivalent to
+``\Mockery::any()``.
+
+It's important to note that this means all expectations attached only apply to
+the given method when it is called with these exact arguments. This allows for
+setting up differing expectations based on the arguments provided to expected
+calls.
+
+.. code-block:: php
+
+ withAnyArgs()
+
+Declares that this expectation matches a method call regardless of what
+arguments are passed. This is set by default unless otherwise specified.
+
+.. code-block:: php
+
+ withNoArgs()
+
+Declares this expectation matches method calls with zero arguments.
+
+.. code-block:: php
+
+ andReturn(value)
+
+Sets a value to be returned from the expected method call.
+
+.. code-block:: php
+
+ andReturn(value1, value2, ...)
+
+Sets up a sequence of return values or closures. For example, the first call
+will return value1 and the second value2. Note that all subsequent calls to a
+mocked method will always return the final value (or the only value) given to
+this declaration.
+
+.. code-block:: php
+
+ andReturnNull() / andReturn([NULL])
+
+Both of the above options are primarily for communication to test readers.
+They mark the mock object method call as returning ``null`` or nothing.
+
+.. code-block:: php
+
+ andReturnValues(array)
+
+Alternative syntax for ``andReturn()`` that accepts a simple array instead of
+a list of parameters. The order of return is determined by the numerical
+index of the given array with the last array member being return on all calls
+once previous return values are exhausted.
+
+.. code-block:: php
+
+ andReturnUsing(closure, ...)
+
+Sets a closure (anonymous function) to be called with the arguments passed to
+the method. The return value from the closure is then returned. Useful for
+some dynamic processing of arguments into related concrete results. Closures
+can queued by passing them as extra parameters as for ``andReturn()``.
+
+.. note::
+
+ You cannot currently mix ``andReturnUsing()`` with ``andReturn()``.
+
+.. code-block:: php
+
+ andThrow(Exception)
+
+Declares that this method will throw the given ``Exception`` object when
+called.
+
+.. code-block:: php
+
+ andThrow(exception_name, message)
+
+Rather than an object, you can pass in the ``Exception`` class and message to
+use when throwing an ``Exception`` from the mocked method.
+
+.. code-block:: php
+
+ andSet(name, value1) / set(name, value1)
+
+Used with an expectation so that when a matching method is called, one can
+also cause a mock object's public property to be set to a specified value.
+
+.. code-block:: php
+
+ passthru()
+
+Tells the expectation to bypass a return queue and instead call the real
+method of the class that was mocked and return the result. Basically, it
+allows expectation matching and call count validation to be applied against
+real methods while still calling the real class method with the expected
+arguments.
+
+.. code-block:: php
+
+ zeroOrMoreTimes()
+
+Declares that the expected method may be called zero or more times. This is
+the default for all methods unless otherwise set.
+
+.. code-block:: php
+
+ once()
+
+Declares that the expected method may only be called once. Like all other call
+count constraints, it will throw a ``\Mockery\CountValidator\Exception`` if
+breached and can be modified by the ``atLeast()`` and ``atMost()``
+constraints.
+
+.. code-block:: php
+
+ twice()
+
+Declares that the expected method may only be called twice.
+
+.. code-block:: php
+
+ times(n)
+
+Declares that the expected method may only be called n times.
+
+.. code-block:: php
+
+ never()
+
+Declares that the expected method may never be called. Ever!
+
+.. code-block:: php
+
+ atLeast()
+
+Adds a minimum modifier to the next call count expectation. Thus
+``atLeast()->times(3)`` means the call must be called at least three times
+(given matching method args) but never less than three times.
+
+.. code-block:: php
+
+ atMost()
+
+Adds a maximum modifier to the next call count expectation. Thus
+``atMost()->times(3)`` means the call must be called no more than three times.
+This also means no calls are acceptable.
+
+.. code-block:: php
+
+ between(min, max)
+
+Sets an expected range of call counts. This is actually identical to using
+``atLeast()->times(min)->atMost()->times(max)`` but is provided as a
+shorthand. It may be followed by a ``times()`` call with no parameter to
+preserve the APIs natural language readability.
+
+.. code-block:: php
+
+ ordered()
+
+Declares that this method is expected to be called in a specific order in
+relation to similarly marked methods. The order is dictated by the order in
+which this modifier is actually used when setting up mocks.
+
+.. code-block:: php
+
+ ordered(group)
+
+Declares the method as belonging to an order group (which can be named or
+numbered). Methods within a group can be called in any order, but the ordered
+calls from outside the group are ordered in relation to the group, i.e. you
+can set up so that method1 is called before group1 which is in turn called
+before method 2.
+
+.. code-block:: php
+
+ globally()
+
+When called prior to ``ordered()`` or ``ordered(group)``, it declares this
+ordering to apply across all mock objects (not just the current mock). This
+allows for dictating order expectations across multiple mocks.
+
+.. code-block:: php
+
+ byDefault()
+
+Marks an expectation as a default. Default expectations are applied unless a
+non-default expectation is created. These later expectations immediately
+replace the previously defined default. This is useful so you can setup
+default mocks in your unit test ``setup()`` and later tweak them in specific
+tests as needed.
+
+.. code-block:: php
+
+ getMock()
+
+Returns the current mock object from an expectation chain. Useful where you
+prefer to keep mock setups as a single statement, e.g.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('foo')->shouldReceive('foo')->andReturn(1)->getMock();
diff --git a/vendor/mockery/mockery/docs/reference/final_methods_classes.rst b/vendor/mockery/mockery/docs/reference/final_methods_classes.rst
new file mode 100644
index 000000000..4f8783aed
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/final_methods_classes.rst
@@ -0,0 +1,23 @@
+.. index::
+ single: Mocking; Final Classes/Methods
+
+Dealing with Final Classes/Methods
+==================================
+
+One of the primary restrictions of mock objects in PHP, is that mocking
+classes or methods marked final is hard. The final keyword prevents methods so
+marked from being replaced in subclasses (subclassing is how mock objects can
+inherit the type of the class or object being mocked.
+
+The simplest solution is not to mark classes or methods as final!
+
+However, in a compromise between mocking functionality and type safety,
+Mockery does allow creating "proxy mocks" from classes marked final, or from
+classes with methods marked final. This offers all the usual mock object
+goodness but the resulting mock will not inherit the class type of the object
+being mocked, i.e. it will not pass any instanceof comparison.
+
+You can create a proxy mock by passing the instantiated object you wish to
+mock into ``\Mockery::mock()``, i.e. Mockery will then generate a Proxy to the
+real object and selectively intercept method calls for the purposes of setting
+and meeting expectations.
diff --git a/vendor/mockery/mockery/docs/reference/index.rst b/vendor/mockery/mockery/docs/reference/index.rst
new file mode 100644
index 000000000..fe693c673
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/index.rst
@@ -0,0 +1,20 @@
+Reference
+=========
+
+.. toctree::
+ :hidden:
+
+ startup_methods
+ expectations
+ argument_validation
+ partial_mocks
+ public_properties
+ public_static_properties
+ pass_by_reference_behaviours
+ demeter_chains
+ object_recording
+ final_methods_classes
+ magic_methods
+ mockery/index
+
+.. include:: map.rst.inc
diff --git a/vendor/mockery/mockery/docs/reference/instance_mocking.rst b/vendor/mockery/mockery/docs/reference/instance_mocking.rst
new file mode 100644
index 000000000..9d1aa283e
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/instance_mocking.rst
@@ -0,0 +1,22 @@
+.. index::
+ single: Mocking; Instance
+
+Instance Mocking
+================
+
+Instance mocking means that a statement like:
+
+.. code-block:: php
+
+ $obj = new \MyNamespace\Foo;
+
+...will actually generate a mock object. This is done by replacing the real
+class with an instance mock (similar to an alias mock), as with mocking public
+methods. The alias will import its expectations from the original mock of
+that type (note that the original is never verified and should be ignored
+after its expectations are setup). This lets you intercept instantiation where
+you can't simply inject a replacement object.
+
+As before, this does not prevent a require statement from including the real
+class and triggering a fatal PHP error. It's intended for use where
+autoloading is the primary class loading mechanism.
diff --git a/vendor/mockery/mockery/docs/reference/magic_methods.rst b/vendor/mockery/mockery/docs/reference/magic_methods.rst
new file mode 100644
index 000000000..da5cee438
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/magic_methods.rst
@@ -0,0 +1,16 @@
+.. index::
+ single: Mocking; Magic Methods
+
+PHP Magic Methods
+=================
+
+PHP magic methods which are prefixed with a double underscore, e.g.
+``__set()``, pose a particular problem in mocking and unit testing in general.
+It is strongly recommended that unit tests and mock objects do not directly
+refer to magic methods. Instead, refer only to the virtual methods and
+properties these magic methods simulate.
+
+Following this piece of advice will ensure you are testing the real API of
+classes and also ensures there is no conflict should Mockery override these
+magic methods, which it will inevitably do in order to support its role in
+intercepting method calls and properties.
diff --git a/vendor/mockery/mockery/docs/reference/map.rst.inc b/vendor/mockery/mockery/docs/reference/map.rst.inc
new file mode 100644
index 000000000..88ea36b82
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/map.rst.inc
@@ -0,0 +1,19 @@
+* :doc:`/reference/startup_methods`
+* :doc:`/reference/expectations`
+* :doc:`/reference/argument_validation`
+* :doc:`/reference/partial_mocks`
+* :doc:`/reference/public_properties`
+* :doc:`/reference/public_static_properties`
+* :doc:`/reference/pass_by_reference_behaviours`
+* :doc:`/reference/demeter_chains`
+* :doc:`/reference/object_recording`
+* :doc:`/reference/final_methods_classes`
+* :doc:`/reference/magic_methods`
+
+Mockery Reference
+-----------------
+
+* :doc:`/reference/mockery/configuration`
+* :doc:`/reference/mockery/exceptions`
+* :doc:`/reference/mockery/reserved_method_names`
+* :doc:`/reference/mockery/gotchas`
diff --git a/vendor/mockery/mockery/docs/reference/mockery/configuration.rst b/vendor/mockery/mockery/docs/reference/mockery/configuration.rst
new file mode 100644
index 000000000..9f8db7444
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/mockery/configuration.rst
@@ -0,0 +1,52 @@
+.. index::
+ single: Mockery; Configuration
+
+Mockery Global Configuration
+============================
+
+To allow for a degree of fine-tuning, Mockery utilises a singleton
+configuration object to store a small subset of core behaviours. The three
+currently present include:
+
+* Option to allow/disallow the mocking of methods which do not actually exist
+* Option to allow/disallow the existence of expectations which are never
+ fulfilled (i.e. unused)
+* Setter/Getter for added a parameter map for internal PHP class methods
+ (``Reflection`` cannot detect these automatically)
+
+By default, the first two behaviours are enabled. Of course, there are
+situations where this can lead to unintended consequences. The mocking of
+non-existent methods may allow mocks based on real classes/objects to fall out
+of sync with the actual implementations, especially when some degree of
+integration testing (testing of object wiring) is not being performed.
+Allowing unfulfilled expectations means unnecessary mock expectations go
+unnoticed, cluttering up test code, and potentially confusing test readers.
+
+You may allow or disallow these behaviours (whether for whole test suites or
+just select tests) by using one or both of the following two calls:
+
+.. code-block:: php
+
+ \Mockery::getConfiguration()->allowMockingNonExistentMethods(bool);
+ \Mockery::getConfiguration()->allowMockingMethodsUnnecessarily(bool);
+
+Passing a true allows the behaviour, false disallows it. Both take effect
+immediately until switched back. In both cases, if either behaviour is
+detected when not allowed, it will result in an Exception being thrown at that
+point. Note that disallowing these behaviours should be carefully considered
+since they necessarily remove at least some of Mockery's flexibility.
+
+The other two methods are:
+
+.. code-block:: php
+
+ \Mockery::getConfiguration()->setInternalClassMethodParamMap($class, $method, array $paramMap)
+ \Mockery::getConfiguration()->getInternalClassMethodParamMap($class, $method)
+
+These are used to define parameters (i.e. the signature string of each) for the
+methods of internal PHP classes (e.g. SPL, or PECL extension classes like
+ext/mongo's MongoCollection. Reflection cannot analyse the parameters of internal
+classes. Most of the time, you never need to do this. It's mainly needed where an
+internal class method uses pass-by-reference for a parameter - you MUST in such
+cases ensure the parameter signature includes the ``&`` symbol correctly as Mockery
+won't correctly add it automatically for internal classes.
diff --git a/vendor/mockery/mockery/docs/reference/mockery/exceptions.rst b/vendor/mockery/mockery/docs/reference/mockery/exceptions.rst
new file mode 100644
index 000000000..623b158e2
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/mockery/exceptions.rst
@@ -0,0 +1,65 @@
+.. index::
+ single: Mockery; Exceptions
+
+Mockery Exceptions
+==================
+
+Mockery throws three types of exceptions when it cannot verify a mock object.
+
+#. ``\Mockery\Exception\InvalidCountException``
+#. ``\Mockery\Exception\InvalidOrderException``
+#. ``\Mockery\Exception\NoMatchingExpectationException``
+
+You can capture any of these exceptions in a try...catch block to query them
+for specific information which is also passed along in the exception message
+but is provided separately from getters should they be useful when logging or
+reformatting output.
+
+\Mockery\Exception\InvalidCountException
+----------------------------------------
+
+The exception class is used when a method is called too many (or too few)
+times and offers the following methods:
+
+* ``getMock()`` - return actual mock object
+* ``getMockName()`` - return the name of the mock object
+* ``getMethodName()`` - return the name of the method the failing expectation
+ is attached to
+* ``getExpectedCount()`` - return expected calls
+* ``getExpectedCountComparative()`` - returns a string, e.g. ``<=`` used to
+ compare to actual count
+* ``getActualCount()`` - return actual calls made with given argument
+ constraints
+
+\Mockery\Exception\InvalidOrderException
+----------------------------------------
+
+The exception class is used when a method is called outside the expected order
+set using the ``ordered()`` and ``globally()`` expectation modifiers. It
+offers the following methods:
+
+* ``getMock()`` - return actual mock object
+* ``getMockName()`` - return the name of the mock object
+* ``getMethodName()`` - return the name of the method the failing expectation
+ is attached to
+* ``getExpectedOrder()`` - returns an integer represented the expected index
+ for which this call was expected
+* ``getActualOrder()`` - return the actual index at which this method call
+ occurred.
+
+\Mockery\Exception\NoMatchingExpectationException
+-------------------------------------------------
+
+The exception class is used when a method call does not match any known
+expectation. All expectations are uniquely identified in a mock object by the
+method name and the list of expected arguments. You can disable this exception
+and opt for returning NULL from all unexpected method calls by using the
+earlier mentioned shouldIgnoreMissing() behaviour modifier. This exception
+class offers the following methods:
+
+* ``getMock()`` - return actual mock object
+* ``getMockName()`` - return the name of the mock object
+* ``getMethodName()`` - return the name of the method the failing expectation
+ is attached to
+* ``getActualArguments()`` - return actual arguments used to search for a
+ matching expectation
diff --git a/vendor/mockery/mockery/docs/reference/mockery/gotchas.rst b/vendor/mockery/mockery/docs/reference/mockery/gotchas.rst
new file mode 100644
index 000000000..2d3ff6ce8
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/mockery/gotchas.rst
@@ -0,0 +1,42 @@
+.. index::
+ single: Mockery; Gotchas
+
+Gotchas!
+========
+
+Mocking objects in PHP has its limitations and gotchas. Some functionality
+can't be mocked or can't be mocked YET! If you locate such a circumstance,
+please please (pretty please with sugar on top) create a new issue on GitHub
+so it can be documented and resolved where possible. Here is a list to note:
+
+1. Classes containing public ``__wakeup()`` methods can be mocked but the
+ mocked ``__wakeup()`` method will perform no actions and cannot have
+ expectations set for it. This is necessary since Mockery must serialize and
+ unserialize objects to avoid some ``__construct()`` insanity and attempting
+ to mock a ``__wakeup()`` method as normal leads to a
+ ``BadMethodCallException`` been thrown.
+
+2. Classes using non-real methods, i.e. where a method call triggers a
+ ``__call()`` method, will throw an exception that the non-real method does
+ not exist unless you first define at least one expectation (a simple
+ ``shouldReceive()`` call would suffice). This is necessary since there is
+ no other way for Mockery to be aware of the method name.
+
+3. Mockery has two scenarios where real classes are replaced: Instance mocks
+ and alias mocks. Both will generate PHP fatal errors if the real class is
+ loaded, usually via a require or include statement. Only use these two mock
+ types where autoloading is in place and where classes are not explicitly
+ loaded on a per-file basis using ``require()``, ``require_once()``, etc.
+
+4. Internal PHP classes are not entirely capable of being fully analysed using
+ ``Reflection``. For example, ``Reflection`` cannot reveal details of
+ expected parameters to the methods of such internal classes. As a result,
+ there will be problems where a method parameter is defined to accept a
+ value by reference (Mockery cannot detect this condition and will assume a
+ pass by value on scalars and arrays). If references as internal class
+ method parameters are needed, you should use the
+ ``\Mockery\Configuration::setInternalClassMethodParamMap()`` method.
+
+The gotchas noted above are largely down to PHP's architecture and are assumed
+to be unavoidable. But - if you figure out a solution (or a better one than
+what may exist), let us know!
diff --git a/vendor/mockery/mockery/docs/reference/mockery/index.rst b/vendor/mockery/mockery/docs/reference/mockery/index.rst
new file mode 100644
index 000000000..6951b0ad1
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/mockery/index.rst
@@ -0,0 +1,10 @@
+Mockery
+=======
+
+.. toctree::
+ :maxdepth: 2
+
+ configuration
+ exceptions
+ reserved_method_names
+ gotchas
diff --git a/vendor/mockery/mockery/docs/reference/mockery/reserved_method_names.rst b/vendor/mockery/mockery/docs/reference/mockery/reserved_method_names.rst
new file mode 100644
index 000000000..112d6f0a5
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/mockery/reserved_method_names.rst
@@ -0,0 +1,20 @@
+.. index::
+ single: Reserved Method Names
+
+Reserved Method Names
+=====================
+
+As you may have noticed, Mockery uses a number of methods called directly on
+all mock objects, for example ``shouldReceive()``. Such methods are necessary
+in order to setup expectations on the given mock, and so they cannot be
+implemented on the classes or objects being mocked without creating a method
+name collision (reported as a PHP fatal error). The methods reserved by
+Mockery are:
+
+* ``shouldReceive()``
+* ``shouldBeStrict()``
+
+In addition, all mocks utilise a set of added methods and protected properties
+which cannot exist on the class or object being mocked. These are far less
+likely to cause collisions. All properties are prefixed with ``_mockery`` and
+all method names with ``mockery_``.
diff --git a/vendor/mockery/mockery/docs/reference/object_recording.rst b/vendor/mockery/mockery/docs/reference/object_recording.rst
new file mode 100644
index 000000000..9578e81be
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/object_recording.rst
@@ -0,0 +1,93 @@
+.. index::
+ single: Mocking; Object Recording
+
+Mock Object Recording
+=====================
+
+In certain cases, you may find that you are testing against an already
+established pattern of behaviour, perhaps during refactoring. Rather then hand
+crafting mock object expectations for this behaviour, you could instead use
+the existing source code to record the interactions a real object undergoes
+onto a mock object as expectations - expectations you can then verify against
+an alternative or refactored version of the source code.
+
+To record expectations, you need a concrete instance of the class to be
+mocked. This can then be used to create a partial mock to which is given the
+necessary code to execute the object interactions to be recorded. A simple
+example is outline below (we use a closure for passing instructions to the
+mock).
+
+Here we have a very simple setup, a class (``SubjectUser``) which uses another
+class (``Subject``) to retrieve some value. We want to record as expectations
+on our mock (which will replace ``Subject`` later) all the calls and return
+values of a Subject instance when interacting with ``SubjectUser``.
+
+.. code-block:: php
+
+ class Subject
+ {
+
+ public function execute() {
+ return 'executed!';
+ }
+
+ }
+
+ class SubjectUser
+ {
+
+ public function use(Subject $subject) {
+ return $subject->execute();
+ }
+
+ }
+
+Here's the test case showing the recording:
+
+.. code-block:: php
+
+ class SubjectUserTest extends PHPUnit_Framework_TestCase
+ {
+
+ public function tearDown()
+ {
+ \Mockery::close();
+ }
+
+ public function testSomething()
+ {
+ $mock = \Mockery::mock(new Subject);
+ $mock->shouldExpect(function ($subject) {
+ $user = new SubjectUser;
+ $user->use($subject);
+ });
+
+ /**
+ * Assume we have a replacement SubjectUser called NewSubjectUser.
+ * We want to verify it behaves identically to SubjectUser, i.e.
+ * it uses Subject in the exact same way
+ */
+ $newSubject = new NewSubjectUser;
+ $newSubject->use($mock);
+ }
+
+ }
+
+After the ``\Mockery::close()`` call in ``tearDown()`` validates the mock
+object, we should have zero exceptions if ``NewSubjectUser`` acted on
+`Subject` in a similar way to ``SubjectUser``. By default the order of calls
+are not enforced, and loose argument matching is enabled, i.e. arguments may
+be equal (``==``) but not necessarily identical (``===``).
+
+If you wished to be more strict, for example ensuring the order of calls and
+the final call counts were identical, or ensuring arguments are completely
+identical, you can invoke the recorder's strict mode from the closure block,
+e.g.
+
+.. code-block:: php
+
+ $mock->shouldExpect(function ($subject) {
+ $subject->shouldBeStrict();
+ $user = new SubjectUser;
+ $user->use($subject);
+ });
diff --git a/vendor/mockery/mockery/docs/reference/partial_mocks.rst b/vendor/mockery/mockery/docs/reference/partial_mocks.rst
new file mode 100644
index 000000000..1e46c5a9c
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/partial_mocks.rst
@@ -0,0 +1,94 @@
+.. index::
+ single: Mocking; Partial Mocks
+
+Creating Partial Mocks
+======================
+
+Partial mocks are useful when you only need to mock several methods of an
+object leaving the remainder free to respond to calls normally (i.e. as
+implemented). Mockery implements three distinct strategies for creating
+partials. Each has specific advantages and disadvantages so which strategy you
+use will depend on your own preferences and the source code in need of
+mocking.
+
+#. Traditional Partial Mock
+#. Passive Partial Mock
+#. Proxied Partial Mock
+
+Traditional Partial Mock
+------------------------
+
+A traditional partial mock, defines ahead of time which methods of a class are
+to be mocked and which are to be left unmocked (i.e. callable as normal). The
+syntax for creating traditional mocks is:
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('MyClass[foo,bar]');
+
+In the above example, the ``foo()`` and ``bar()`` methods of MyClass will be
+mocked but no other MyClass methods are touched. You will need to define
+expectations for the ``foo()`` and ``bar()`` methods to dictate their mocked
+behaviour.
+
+Don't forget that you can pass in constructor arguments since unmocked methods
+may rely on those!
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('MyNamespace\MyClass[foo]', array($arg1, $arg2));
+
+Passive Partial Mock
+--------------------
+
+A passive partial mock is more of a default state of being.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('MyClass')->makePartial();
+
+In a passive partial, we assume that all methods will simply defer to the
+parent class (``MyClass``) original methods unless a method call matches a
+known expectation. If you have no matching expectation for a specific method
+call, that call is deferred to the class being mocked. Since the division
+between mocked and unmocked calls depends entirely on the expectations you
+define, there is no need to define which methods to mock in advance. The
+``makePartial()`` method is identical to the original ``shouldDeferMissing()``
+method which first introduced this Partial Mock type.
+
+Proxied Partial Mock
+--------------------
+
+A proxied partial mock is a partial of last resort. You may encounter a class
+which is simply not capable of being mocked because it has been marked as
+final. Similarly, you may find a class with methods marked as final. In such a
+scenario, we cannot simply extend the class and override methods to mock - we
+need to get creative.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock(new MyClass);
+
+Yes, the new mock is a Proxy. It intercepts calls and reroutes them to the
+proxied object (which you construct and pass in) for methods which are not
+subject to any expectations. Indirectly, this allows you to mock methods
+marked final since the Proxy is not subject to those limitations. The tradeoff
+should be obvious - a proxied partial will fail any typehint checks for the
+class being mocked since it cannot extend that class.
+
+Special Internal Cases
+----------------------
+
+All mock objects, with the exception of Proxied Partials, allow you to make
+any expectation call the underlying real class method using the ``passthru()``
+expectation call. This will return values from the real call and bypass any
+mocked return queue (which can simply be omitted obviously).
+
+There is a fourth kind of partial mock reserved for internal use. This is
+automatically generated when you attempt to mock a class containing methods
+marked final. Since we cannot override such methods, they are simply left
+unmocked. Typically, you don't need to worry about this but if you really
+really must mock a final method, the only possible means is through a Proxied
+Partial Mock. SplFileInfo, for example, is a common class subject to this form
+of automatic internal partial since it contains public final methods used
+internally.
diff --git a/vendor/mockery/mockery/docs/reference/pass_by_reference_behaviours.rst b/vendor/mockery/mockery/docs/reference/pass_by_reference_behaviours.rst
new file mode 100644
index 000000000..ac4cdbad6
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/pass_by_reference_behaviours.rst
@@ -0,0 +1,83 @@
+.. index::
+ single: Pass-By-Reference Method Parameter Behaviour
+
+Preserving Pass-By-Reference Method Parameter Behaviour
+=======================================================
+
+PHP Class method may accept parameters by reference. In this case, changes
+made to the parameter (a reference to the original variable passed to the
+method) are reflected in the original variable. A simple example:
+
+.. code-block:: php
+
+ class Foo
+ {
+
+ public function bar(&$a)
+ {
+ $a++;
+ }
+
+ }
+
+ $baz = 1;
+ $foo = new Foo;
+ $foo->bar($baz);
+
+ echo $baz; // will echo the integer 2
+
+In the example above, the variable $baz is passed by reference to
+``Foo::bar()`` (notice the ``&`` symbol in front of the parameter?). Any
+change ``bar()`` makes to the parameter reference is reflected in the original
+variable, ``$baz``.
+
+Mockery 0.7+ handles references correctly for all methods where it can analyse
+the parameter (using ``Reflection``) to see if it is passed by reference. To
+mock how a reference is manipulated by the class method, you can use a closure
+argument matcher to manipulate it, i.e. ``\Mockery::on()`` - see the
+":doc:`argument_validation`" chapter.
+
+There is an exception for internal PHP classes where Mockery cannot analyse
+method parameters using ``Reflection`` (a limitation in PHP). To work around
+this, you can explicitly declare method parameters for an internal class using
+``/Mockery/Configuration::setInternalClassMethodParamMap()``.
+
+Here's an example using ``MongoCollection::insert()``. ``MongoCollection`` is
+an internal class offered by the mongo extension from PECL. Its ``insert()``
+method accepts an array of data as the first parameter, and an optional
+options array as the second parameter. The original data array is updated
+(i.e. when a ``insert()`` pass-by-reference parameter) to include a new
+``_id`` field. We can mock this behaviour using a configured parameter map (to
+tell Mockery to expect a pass by reference parameter) and a ``Closure``
+attached to the expected method parameter to be updated.
+
+Here's a PHPUnit unit test verifying that this pass-by-reference behaviour is
+preserved:
+
+.. code-block:: php
+
+ public function testCanOverrideExpectedParametersOfInternalPHPClassesToPreserveRefs()
+ {
+ \Mockery::getConfiguration()->setInternalClassMethodParamMap(
+ 'MongoCollection',
+ 'insert',
+ array('&$data', '$options = array()')
+ );
+ $m = \Mockery::mock('MongoCollection');
+ $m->shouldReceive('insert')->with(
+ \Mockery::on(function(&$data) {
+ if (!is_array($data)) return false;
+ $data['_id'] = 123;
+ return true;
+ }),
+ \Mockery::any()
+ );
+
+ $data = array('a'=>1,'b'=>2);
+ $m->insert($data);
+
+ $this->assertTrue(isset($data['_id']));
+ $this->assertEquals(123, $data['_id']);
+
+ \Mockery::resetContainer();
+ }
diff --git a/vendor/mockery/mockery/docs/reference/phpunit_integration.rst b/vendor/mockery/mockery/docs/reference/phpunit_integration.rst
new file mode 100644
index 000000000..ea8eb4693
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/phpunit_integration.rst
@@ -0,0 +1,110 @@
+.. index::
+ single: PHPUnit Integration
+
+PHPUnit Integration
+===================
+
+Mockery was designed as a simple-to-use *standalone* mock object framework, so
+its need for integration with any testing framework is entirely optional. To
+integrate Mockery, you just need to define a ``tearDown()`` method for your
+tests containing the following (you may use a shorter ``\Mockery`` namespace
+alias):
+
+.. code-block:: php
+
+ public function tearDown() {
+ \Mockery::close();
+ }
+
+This static call cleans up the Mockery container used by the current test, and
+run any verification tasks needed for your expectations.
+
+For some added brevity when it comes to using Mockery, you can also explicitly
+use the Mockery namespace with a shorter alias. For example:
+
+.. code-block:: php
+
+ use \Mockery as m;
+
+ class SimpleTest extends PHPUnit_Framework_TestCase
+ {
+ public function testSimpleMock() {
+ $mock = m::mock('simplemock');
+ $mock->shouldReceive('foo')->with(5, m::any())->once()->andReturn(10);
+
+ $this->assertEquals(10, $mock->foo(5));
+ }
+
+ public function tearDown() {
+ m::close();
+ }
+ }
+
+Mockery ships with an autoloader so you don't need to litter your tests with
+``require_once()`` calls. To use it, ensure Mockery is on your
+``include_path`` and add the following to your test suite's ``Bootstrap.php``
+or ``TestHelper.php`` file:
+
+.. code-block:: php
+
+ require_once 'Mockery/Loader.php';
+ require_once 'Hamcrest/Hamcrest.php';
+
+ $loader = new \Mockery\Loader;
+ $loader->register();
+
+If you are using Composer, you can simplify this to just including the
+Composer generated autoloader file:
+
+.. code-block:: php
+
+ require __DIR__ . '/../vendor/autoload.php'; // assuming vendor is one directory up
+
+.. caution::
+
+ Prior to Hamcrest 1.0.0, the ``Hamcrest.php`` file name had a small "h"
+ (i.e. ``hamcrest.php``). If upgrading Hamcrest to 1.0.0 remember to check
+ the file name is updated for all your projects.)
+
+To integrate Mockery into PHPUnit and avoid having to call the close method
+and have Mockery remove itself from code coverage reports, use this in you
+suite:
+
+.. code-block:: php
+
+ // Create Suite
+ $suite = new PHPUnit_Framework_TestSuite();
+
+ // Create a result listener or add it
+ $result = new PHPUnit_Framework_TestResult();
+ $result->addListener(new \Mockery\Adapter\Phpunit\TestListener());
+
+ // Run the tests.
+ $suite->run($result);
+
+If you are using PHPUnit's XML configuration approach, you can include the
+following to load the ``TestListener``:
+
+.. code-block:: xml
+
+
+
+
+
+Make sure Composer's or Mockery's autoloader is present in the bootstrap file
+or you will need to also define a "file" attribute pointing to the file of the
+above ``TestListener`` class.
+
+.. caution::
+
+ PHPUnit provides a functionality that allows
+ `tests to run in a separated process `_,
+ to ensure better isolation. Mockery verifies the mocks expectations using the
+ ``Mockery::close()`` method, and provides a PHPUnit listener, that automatically
+ calls this method for you after every test.
+
+ However, this listener is not called in the right process when using PHPUnit's process
+ isolation, resulting in expectations that might not be respected, but without raising
+ any ``Mockery\Exception``. To avoid this, you cannot rely on the supplied Mockery PHPUnit
+ ``TestListener``, and you need to explicitly calls ``Mockery::close``. The easiest solution
+ to include this call in the ``tearDown()`` method, as explained previously.
diff --git a/vendor/mockery/mockery/docs/reference/public_properties.rst b/vendor/mockery/mockery/docs/reference/public_properties.rst
new file mode 100644
index 000000000..209f1bf01
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/public_properties.rst
@@ -0,0 +1,16 @@
+.. index::
+ single: Mocking; Public Properties
+
+Mocking Public Properties
+=========================
+
+Mockery allows you to mock properties in several ways. The simplest is that
+you can simply set a public property and value on any mock object. The second
+is that you can use the expectation methods ``set()`` and ``andSet()`` to set
+property values if that expectation is ever met.
+
+You should note that, in general, Mockery does not support mocking any magic
+methods since these are generally not considered a public API (and besides
+they are a PITA to differentiate when you badly need them for mocking!). So
+please mock virtual properties (those relying on ``__get()`` and ``__set()``)
+as if they were actually declared on the class.
diff --git a/vendor/mockery/mockery/docs/reference/public_static_properties.rst b/vendor/mockery/mockery/docs/reference/public_static_properties.rst
new file mode 100644
index 000000000..3079c8b74
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/public_static_properties.rst
@@ -0,0 +1,12 @@
+.. index::
+ single: Mocking; Public Static Methods
+
+Mocking Public Static Methods
+=============================
+
+Static methods are not called on real objects, so normal mock objects can't
+mock them. Mockery supports class aliased mocks, mocks representing a class
+name which would normally be loaded (via autoloading or a require statement)
+in the system under test. These aliases block that loading (unless via a
+require statement - so please use autoloading!) and allow Mockery to intercept
+static method calls and add expectations for them.
diff --git a/vendor/mockery/mockery/docs/reference/quick_examples.rst b/vendor/mockery/mockery/docs/reference/quick_examples.rst
new file mode 100644
index 000000000..f68736b8b
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/quick_examples.rst
@@ -0,0 +1,130 @@
+.. index::
+ single: Reference; Examples
+
+Quick Examples
+==============
+
+Create a mock object to return a sequence of values from a set of method
+calls.
+
+.. code-block:: php
+
+ class SimpleTest extends PHPUnit_Framework_TestCase
+ {
+
+ public function tearDown()
+ {
+ \Mockery::close();
+ }
+
+ public function testSimpleMock()
+ {
+ $mock = \Mockery::mock(array('pi' => 3.1416, 'e' => 2.71));
+ $this->assertEquals(3.1416, $mock->pi());
+ $this->assertEquals(2.71, $mock->e());
+ }
+
+ }
+
+Create a mock object which returns a self-chaining Undefined object for a
+method call.
+
+.. code-block:: php
+
+ use \Mockery as m;
+
+ class UndefinedTest extends PHPUnit_Framework_TestCase
+ {
+
+ public function tearDown()
+ {
+ m::close();
+ }
+
+ public function testUndefinedValues()
+ {
+ $mock = m::mock('mymock');
+ $mock->shouldReceive('divideBy')->with(0)->andReturnUndefined();
+ $this->assertTrue($mock->divideBy(0) instanceof \Mockery\Undefined);
+ }
+
+ }
+
+Creates a mock object which multiple query calls and a single update call.
+
+.. code-block:: php
+
+ use \Mockery as m;
+
+ class DbTest extends PHPUnit_Framework_TestCase
+ {
+
+ public function tearDown()
+ {
+ m::close();
+ }
+
+ public function testDbAdapter()
+ {
+ $mock = m::mock('db');
+ $mock->shouldReceive('query')->andReturn(1, 2, 3);
+ $mock->shouldReceive('update')->with(5)->andReturn(NULL)->once();
+
+ // ... test code here using the mock
+ }
+
+ }
+
+Expect all queries to be executed before any updates.
+
+.. code-block:: php
+
+ use \Mockery as m;
+
+ class DbTest extends PHPUnit_Framework_TestCase
+ {
+
+ public function tearDown()
+ {
+ m::close();
+ }
+
+ public function testQueryAndUpdateOrder()
+ {
+ $mock = m::mock('db');
+ $mock->shouldReceive('query')->andReturn(1, 2, 3)->ordered();
+ $mock->shouldReceive('update')->andReturn(NULL)->once()->ordered();
+
+ // ... test code here using the mock
+ }
+
+ }
+
+Create a mock object where all queries occur after startup, but before finish,
+and where queries are expected with several different params.
+
+.. code-block:: php
+
+ use \Mockery as m;
+
+ class DbTest extends PHPUnit_Framework_TestCase
+ {
+
+ public function tearDown()
+ {
+ m::close();
+ }
+
+ public function testOrderedQueries()
+ {
+ $db = m::mock('db');
+ $db->shouldReceive('startup')->once()->ordered();
+ $db->shouldReceive('query')->with('CPWR')->andReturn(12.3)->once()->ordered('queries');
+ $db->shouldReceive('query')->with('MSFT')->andReturn(10.0)->once()->ordered('queries');
+ $db->shouldReceive('query')->with("/^....$/")->andReturn(3.3)->atLeast()->once()->ordered('queries');
+ $db->shouldReceive('finish')->once()->ordered();
+
+ // ... test code here using the mock
+ }
+
+ }
diff --git a/vendor/mockery/mockery/docs/reference/startup_methods.rst b/vendor/mockery/mockery/docs/reference/startup_methods.rst
new file mode 100644
index 000000000..334a98ae0
--- /dev/null
+++ b/vendor/mockery/mockery/docs/reference/startup_methods.rst
@@ -0,0 +1,230 @@
+.. index::
+ single: Reference; Quick Reference
+
+Quick Reference
+===============
+
+Mockery implements a shorthand API when creating a mock. Here's a sampling of
+the possible startup methods.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('foo');
+
+Creates a mock object named "foo". In this case, "foo" is a name (not
+necessarily a class name) used as a simple identifier when raising exceptions.
+This creates a mock object of type ``\Mockery\Mock`` and is the loosest form
+of mock possible.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock(array('foo'=>1,'bar'=>2));
+
+Creates an mock object named unknown since we passed no name. However we did
+pass an expectation array, a quick method of setting up methods to expect with
+their return values.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('foo', array('foo'=>1,'bar'=>2));
+
+Similar to the previous examples and all examples going forward, expectation
+arrays can be passed for all mock objects as the second parameter to
+``mock()``.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('foo', function($mock) {
+ $mock->shouldReceive(method_name);
+ });
+
+In addition to expectation arrays, you can also pass in a closure which
+contains reusable expectations. This can be passed as the second parameter, or
+as the third parameter if partnered with an expectation array. This is one
+method for creating reusable mock expectations.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('stdClass');
+
+Creates a mock identical to a named mock, except the name is an actual class
+name. Creates a simple mock as previous examples show, except the mock object
+will inherit the class type (via inheritance), i.e. it will pass type hints or
+instanceof evaluations for stdClass. Useful where a mock object must be of a
+specific type.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('FooInterface');
+
+You can create mock objects based on any concrete class, abstract class or
+even an interface. Again, the primary purpose is to ensure the mock object
+inherits a specific type for type hinting. There is an exception in that
+classes marked final, or with methods marked final, cannot be mocked fully. In
+these cases a partial mock (explained later) must be utilised.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('alias:MyNamespace\MyClass');
+
+Prefixing the valid name of a class (which is NOT currently loaded) with
+"alias:" will generate an "alias mock". Alias mocks create a class alias with
+the given classname to stdClass and are generally used to enable the mocking
+of public static methods. Expectations set on the new mock object which refer
+to static methods will be used by all static calls to this class.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('overload:MyNamespace\MyClass');
+
+Prefixing the valid name of a class (which is NOT currently loaded) with
+"overload:" will generate an alias mock (as with "alias:") except that created
+new instances of that class will import any expectations set on the origin
+mock (``$mock``). The origin mock is never verified since it's used an
+expectation store for new instances. For this purpose we use the term
+"instance mock" to differentiate it from the simpler "alias mock".
+
+.. note::
+
+ Using alias/instance mocks across more than one test will generate a fatal
+ error since you can't have two classes of the same name. To avoid this,
+ run each test of this kind in a separate PHP process (which is supported
+ out of the box by both PHPUnit and PHPT).
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('stdClass, MyInterface1, MyInterface2');
+
+The first argument can also accept a list of interfaces that the mock object
+must implement, optionally including no more than one existing class to be
+based on. The class name doesn't need to be the first member of the list but
+it's a friendly convention to use for readability. All subsequent arguments
+remain unchanged from previous examples.
+
+If the given class does not exist, you must define and include it beforehand
+or a ``\Mockery\Exception`` will be thrown.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('MyNamespace\MyClass[foo,bar]');
+
+The syntax above tells Mockery to partially mock the ``MyNamespace\MyClass``
+class, by mocking the ``foo()`` and ``bar()`` methods only. Any other method
+will be not be overridden by Mockery. This traditional form of "partial mock"
+can be applied to any class or abstract class (e.g. mocking abstract methods
+where a concrete implementation does not exist yet). If you attempt to partial
+mock a method marked final, it will actually be ignored in that instance
+leaving the final method untouched. This is necessary since mocking of final
+methods is, by definition in PHP, impossible.
+
+Please refer to ":doc:`partial_mocks`" for a detailed explanation on how to
+create Partial Mocks in Mockery.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock("MyNamespace\MyClass[foo]", array($arg1, $arg2));
+
+If Mockery encounters an indexed array as the second or third argument, it
+will assume they are constructor parameters and pass them when constructing
+the mock object. The syntax above will create a new partial mock, particularly
+useful if method ``bar`` calls method ``foo`` internally with
+``$this->foo()``.
+
+.. code-block:: php
+
+ $mock = \Mockery::mock(new Foo);
+
+Passing any real object into Mockery will create a Proxied Partial Mock. This
+can be useful if real partials are impossible, e.g. a final class or class
+where you absolutely must override a method marked final. Since you can
+already create a concrete object, so all we need to do is selectively override
+a subset of existing methods (or add non-existing methods!) for our
+expectations.
+
+A little revision: All mock methods accept the class, object or alias name to
+be mocked as the first parameter. The second parameter can be an expectation
+array of methods and their return values, or an expectation closure (which can
+be the third param if used in conjunction with an expectation array).
+
+.. code-block:: php
+
+ \Mockery::self()
+
+At times, you will discover that expectations on a mock include methods which
+need to return the same mock object (e.g. a common case when designing a
+Domain Specific Language (DSL) such as the one Mockery itself uses!). To
+facilitate this, calling ``\Mockery::self()`` will always return the last Mock
+Object created by calling ``\Mockery::mock()``. For example:
+
+.. code-block:: php
+
+ $mock = \Mockery::mock('BazIterator')
+ ->shouldReceive('next')
+ ->andReturn(\Mockery::self())
+ ->mock();
+
+The above class being mocked, as the ``next()`` method suggests, is an
+iterator. In many cases, you can replace all the iterated elements (since they
+are the same type many times) with just the one mock object which is
+programmed to act as discrete iterated elements.
+
+.. code-block:: php
+
+ $mock = \Mockery::namedMock('MyClassName', 'DateTime');
+
+The ``namedMock`` method will generate a class called by the first argument,
+so in this example ``MyClassName``. The rest of the arguments are treat in the
+same way as the ``mock`` method, so again, this example would create a class
+called ``MyClassName`` that extends ``DateTime``.
+
+Named mocks are quite an edge case, but they can be useful when code depends
+on the ``__CLASS__`` magic constant, or when you need two derivatives of an
+abstract type, that are actually different classes.
+
+.. caution::
+
+ You can only create a named mock once, any subsequent calls to
+ ``namedMock``, with different arguments are likely to cause exceptions.
+
+Behaviour Modifiers
+-------------------
+
+When creating a mock object, you may wish to use some commonly preferred
+behaviours that are not the default in Mockery.
+
+.. code-block:: php
+
+ \Mockery::mock('MyClass')->shouldIgnoreMissing()
+
+The use of the ``shouldIgnoreMissing()`` behaviour modifier will label this
+mock object as a Passive Mock. In such a mock object, calls to methods which
+are not covered by expectations will return ``null`` instead of the usual
+complaining about there being no expectation matching the call.
+
+You can optionally prefer to return an object of type ``\Mockery\Undefined``
+(i.e. a ``null`` object) (which was the 0.7.2 behaviour) by using an
+additional modifier:
+
+.. code-block:: php
+
+ \Mockery::mock('MyClass')->shouldIgnoreMissing()->asUndefined()
+
+The returned object is nothing more than a placeholder so if, by some act of
+fate, it's erroneously used somewhere it shouldn't it will likely not pass a
+logic check.
+
+.. code-block:: php
+
+ \Mockery::mock('MyClass')->makePartial()
+
+also
+
+.. code-block:: php
+
+ \Mockery::mock('MyClass')->shouldDeferMissing()
+
+Known as a Passive Partial Mock (not to be confused with real partial mock
+objects discussed later), this form of mock object will defer all methods not
+subject to an expectation to the parent class of the mock, i.e. ``MyClass``.
+Whereas the previous ``shouldIgnoreMissing()`` returned ``null``, this
+behaviour simply calls the parent's matching method.
diff --git a/vendor/mockery/mockery/examples/starship/Bootstrap.php b/vendor/mockery/mockery/examples/starship/Bootstrap.php
new file mode 100644
index 000000000..93b0af9a4
--- /dev/null
+++ b/vendor/mockery/mockery/examples/starship/Bootstrap.php
@@ -0,0 +1,11 @@
+register();
diff --git a/vendor/mockery/mockery/examples/starship/Starship.php b/vendor/mockery/mockery/examples/starship/Starship.php
new file mode 100644
index 000000000..ca26ef105
--- /dev/null
+++ b/vendor/mockery/mockery/examples/starship/Starship.php
@@ -0,0 +1,24 @@
+_engineering = $engineering;
+ }
+
+ public function enterOrbit()
+ {
+ $this->_engineering->disengageWarp();
+ $this->_engineering->runDiagnosticLevel(5);
+ $this->_engineering->divertPower(0.40, 'sensors');
+ $this->_engineering->divertPower(0.30, 'auxengines');
+ $this->_engineering->runDiagnosticLevel(1);
+
+ // We can add more runDiagnosticLevel() calls without failing the test
+ // anywhere above since they are unordered.
+ }
+}
diff --git a/vendor/mockery/mockery/examples/starship/StarshipTest.php b/vendor/mockery/mockery/examples/starship/StarshipTest.php
new file mode 100644
index 000000000..a85def5d7
--- /dev/null
+++ b/vendor/mockery/mockery/examples/starship/StarshipTest.php
@@ -0,0 +1,21 @@
+shouldReceive('disengageWarp')->once()->ordered();
+ $mock->shouldReceive('divertPower')->with(0.40, 'sensors')->once()->ordered();
+ $mock->shouldReceive('divertPower')->with(0.30, 'auxengines')->once()->ordered();
+ $mock->shouldReceive('runDiagnosticLevel')->with(1)->once()->ordered();
+ $mock->shouldReceive('runDiagnosticLevel')->with(M::type('int'))->zeroOrMoreTimes();
+
+ $starship = new Starship($mock);
+ $starship->enterOrbit();
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery.php b/vendor/mockery/mockery/library/Mockery.php
new file mode 100644
index 000000000..09b6098f6
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery.php
@@ -0,0 +1,769 @@
+shouldIgnoreMissing();
+ }
+
+ /**
+ * @return \Mockery\MockInterface
+ */
+ public static function instanceMock()
+ {
+ $args = func_get_args();
+
+ return call_user_func_array(array(self::getContainer(), 'mock'), $args);
+ }
+
+ /**
+ * Static shortcut to \Mockery\Container::mock(), first argument names the mock.
+ *
+ * @return \Mockery\MockInterface
+ */
+ public static function namedMock()
+ {
+ $args = func_get_args();
+ $name = array_shift($args);
+
+ $builder = new MockConfigurationBuilder();
+ $builder->setName($name);
+
+ array_unshift($args, $builder);
+
+ return call_user_func_array(array(self::getContainer(), 'mock'), $args);
+ }
+
+ /**
+ * Static shortcut to \Mockery\Container::self().
+ *
+ * @throws LogicException
+ *
+ * @return \Mockery\MockInterface
+ */
+ public static function self()
+ {
+ if (is_null(self::$_container)) {
+ throw new \LogicException('You have not declared any mocks yet');
+ }
+
+ return self::$_container->self();
+ }
+
+ /**
+ * Static shortcut to closing up and verifying all mocks in the global
+ * container, and resetting the container static variable to null.
+ *
+ * @return void
+ */
+ public static function close()
+ {
+ foreach (self::$_filesToCleanUp as $fileName) {
+ @unlink($fileName);
+ }
+ self::$_filesToCleanUp = array();
+
+ if (is_null(self::$_container)) {
+ return;
+ }
+
+ self::$_container->mockery_teardown();
+ self::$_container->mockery_close();
+ self::$_container = null;
+ }
+
+ /**
+ * Static fetching of a mock associated with a name or explicit class poser.
+ *
+ * @param $name
+ *
+ * @return \Mockery\Mock
+ */
+ public static function fetchMock($name)
+ {
+ return self::$_container->fetchMock($name);
+ }
+
+ /**
+ * Get the container.
+ */
+ public static function getContainer()
+ {
+ if (is_null(self::$_container)) {
+ self::$_container = new Mockery\Container(self::getGenerator(), self::getLoader());
+ }
+
+ return self::$_container;
+ }
+
+ /**
+ * @param \Mockery\Generator\Generator $generator
+ */
+ public static function setGenerator(Generator $generator)
+ {
+ self::$_generator = $generator;
+ }
+
+ public static function getGenerator()
+ {
+ if (is_null(self::$_generator)) {
+ self::$_generator = self::getDefaultGenerator();
+ }
+
+ return self::$_generator;
+ }
+
+ public static function getDefaultGenerator()
+ {
+ $generator = new StringManipulationGenerator(array(
+ new CallTypeHintPass(),
+ new ClassPass(),
+ new ClassNamePass(),
+ new InstanceMockPass(),
+ new InterfacePass(),
+ new MethodDefinitionPass(),
+ new RemoveUnserializeForInternalSerializableClassesPass(),
+ new RemoveBuiltinMethodsThatAreFinalPass(),
+ ));
+
+ return new CachingGenerator($generator);
+ }
+
+ /**
+ * @param Loader $loader
+ */
+ public static function setLoader(Loader $loader)
+ {
+ self::$_loader = $loader;
+ }
+
+ /**
+ * @return Loader
+ */
+ public static function getLoader()
+ {
+ if (is_null(self::$_loader)) {
+ self::$_loader = self::getDefaultLoader();
+ }
+
+ return self::$_loader;
+ }
+
+ /**
+ * @return EvalLoader
+ */
+ public static function getDefaultLoader()
+ {
+ return new EvalLoader();
+ }
+
+ /**
+ * Set the container.
+ *
+ * @param \Mockery\Container $container
+ *
+ * @return \Mockery\Container
+ */
+ public static function setContainer(Mockery\Container $container)
+ {
+ return self::$_container = $container;
+ }
+
+ /**
+ * Reset the container to null.
+ */
+ public static function resetContainer()
+ {
+ self::$_container = null;
+ }
+
+ /**
+ * Return instance of ANY matcher.
+ *
+ * @return \Mockery\Matcher\Any
+ */
+ public static function any()
+ {
+ return new \Mockery\Matcher\Any();
+ }
+
+ /**
+ * Return instance of TYPE matcher.
+ *
+ * @param $expected
+ *
+ * @return \Mockery\Matcher\Type
+ */
+ public static function type($expected)
+ {
+ return new \Mockery\Matcher\Type($expected);
+ }
+
+ /**
+ * Return instance of DUCKTYPE matcher.
+ *
+ * @return \Mockery\Matcher\Ducktype
+ */
+ public static function ducktype()
+ {
+ return new \Mockery\Matcher\Ducktype(func_get_args());
+ }
+
+ /**
+ * Return instance of SUBSET matcher.
+ *
+ * @param array $part
+ *
+ * @return \Mockery\Matcher\Subset
+ */
+ public static function subset(array $part)
+ {
+ return new \Mockery\Matcher\Subset($part);
+ }
+
+ /**
+ * Return instance of CONTAINS matcher.
+ *
+ * @return \Mockery\Matcher\Contains
+ */
+ public static function contains()
+ {
+ return new \Mockery\Matcher\Contains(func_get_args());
+ }
+
+ /**
+ * Return instance of HASKEY matcher.
+ *
+ * @param $key
+ *
+ * @return \Mockery\Matcher\HasKey
+ */
+ public static function hasKey($key)
+ {
+ return new \Mockery\Matcher\HasKey($key);
+ }
+
+ /**
+ * Return instance of HASVALUE matcher.
+ *
+ * @param $val
+ *
+ * @return \Mockery\Matcher\HasValue
+ */
+ public static function hasValue($val)
+ {
+ return new \Mockery\Matcher\HasValue($val);
+ }
+
+ /**
+ * Return instance of CLOSURE matcher.
+ *
+ * @param $closure
+ *
+ * @return \Mockery\Matcher\Closure
+ */
+ public static function on($closure)
+ {
+ return new \Mockery\Matcher\Closure($closure);
+ }
+
+ /**
+ * Return instance of MUSTBE matcher.
+ *
+ * @param $expected
+ *
+ * @return \Mockery\Matcher\MustBe
+ */
+ public static function mustBe($expected)
+ {
+ return new \Mockery\Matcher\MustBe($expected);
+ }
+
+ /**
+ * Return instance of NOT matcher.
+ *
+ * @param $expected
+ *
+ * @return \Mockery\Matcher\Not
+ */
+ public static function not($expected)
+ {
+ return new \Mockery\Matcher\Not($expected);
+ }
+
+ /**
+ * Return instance of ANYOF matcher.
+ *
+ * @return \Mockery\Matcher\AnyOf
+ */
+ public static function anyOf()
+ {
+ return new \Mockery\Matcher\AnyOf(func_get_args());
+ }
+
+ /**
+ * Return instance of NOTANYOF matcher.
+ *
+ * @return \Mockery\Matcher\NotAnyOf
+ */
+ public static function notAnyOf()
+ {
+ return new \Mockery\Matcher\NotAnyOf(func_get_args());
+ }
+
+ /**
+ * Get the global configuration container.
+ */
+ public static function getConfiguration()
+ {
+ if (is_null(self::$_config)) {
+ self::$_config = new \Mockery\Configuration();
+ }
+
+ return self::$_config;
+ }
+
+ /**
+ * Utility method to format method name and arguments into a string.
+ *
+ * @param string $method
+ * @param array $arguments
+ *
+ * @return string
+ */
+ public static function formatArgs($method, array $arguments = null)
+ {
+ if (is_null($arguments)) {
+ return $method . '()';
+ }
+
+ $formattedArguments = array();
+ foreach ($arguments as $argument) {
+ $formattedArguments[] = self::formatArgument($argument);
+ }
+
+ return $method . '(' . implode(', ', $formattedArguments) . ')';
+ }
+
+ private static function formatArgument($argument, $depth = 0)
+ {
+ if (is_object($argument)) {
+ return 'object(' . get_class($argument) . ')';
+ }
+
+ if (is_int($argument) || is_float($argument)) {
+ return $argument;
+ }
+
+ if (is_array($argument)) {
+ if ($depth === 1) {
+ $argument = 'array(...)';
+ } else {
+ $sample = array();
+ foreach ($argument as $key => $value) {
+ $sample[$key] = self::formatArgument($value, $depth + 1);
+ }
+ $argument = preg_replace("{\s}", '', var_export($sample, true));
+ }
+
+ return ((strlen($argument) > 1000) ? substr($argument, 0, 1000).'...)' : $argument);
+ }
+
+ if (is_bool($argument)) {
+ return $argument ? 'true' : 'false';
+ }
+
+ if (is_resource($argument)) {
+ return 'resource(...)';
+ }
+
+ if (is_null($argument)) {
+ return 'NULL';
+ }
+
+ $argument = (string) $argument;
+
+ return $depth === 0 ? '"' . $argument . '"' : $argument;
+ }
+
+ /**
+ * Utility function to format objects to printable arrays.
+ *
+ * @param array $objects
+ *
+ * @return string
+ */
+ public static function formatObjects(array $objects = null)
+ {
+ static $formatting;
+
+ if ($formatting) {
+ return '[Recursion]';
+ }
+
+ if (is_null($objects)) {
+ return '';
+ }
+
+ $objects = array_filter($objects, 'is_object');
+ if (empty($objects)) {
+ return '';
+ }
+
+ $formatting = true;
+ $parts = array();
+
+ foreach ($objects as $object) {
+ $parts[get_class($object)] = self::objectToArray($object);
+ }
+
+ $formatting = false;
+
+ return 'Objects: ( ' . var_export($parts, true) . ')';
+ }
+
+ /**
+ * Utility function to turn public properties and public get* and is* method values into an array.
+ *
+ * @param $object
+ * @param int $nesting
+ *
+ * @return array
+ */
+ private static function objectToArray($object, $nesting = 3)
+ {
+ if ($nesting == 0) {
+ return array('...');
+ }
+
+ return array(
+ 'class' => get_class($object),
+ 'properties' => self::extractInstancePublicProperties($object, $nesting),
+ 'getters' => self::extractGetters($object, $nesting)
+ );
+ }
+
+ /**
+ * Returns all public instance properties.
+ *
+ * @param $object
+ * @param $nesting
+ *
+ * @return array
+ */
+ private static function extractInstancePublicProperties($object, $nesting)
+ {
+ $reflection = new \ReflectionClass(get_class($object));
+ $properties = $reflection->getProperties(\ReflectionProperty::IS_PUBLIC);
+ $cleanedProperties = array();
+
+ foreach ($properties as $publicProperty) {
+ if (!$publicProperty->isStatic()) {
+ $name = $publicProperty->getName();
+ $cleanedProperties[$name] = self::cleanupNesting($object->$name, $nesting);
+ }
+ }
+
+ return $cleanedProperties;
+ }
+
+ /**
+ * Returns all object getters.
+ *
+ * @param $object
+ * @param $nesting
+ *
+ * @return array
+ */
+ private static function extractGetters($object, $nesting)
+ {
+ $reflection = new \ReflectionClass(get_class($object));
+ $publicMethods = $reflection->getMethods(\ReflectionMethod::IS_PUBLIC);
+ $getters = array();
+
+ foreach ($publicMethods as $publicMethod) {
+ $name = $publicMethod->getName();
+ $irrelevantName = (substr($name, 0, 3) !== 'get' && substr($name, 0, 2) !== 'is');
+ $isStatic = $publicMethod->isStatic();
+ $numberOfParameters = $publicMethod->getNumberOfParameters();
+
+ if ($irrelevantName || $numberOfParameters != 0 || $isStatic) {
+ continue;
+ }
+
+ try {
+ $getters[$name] = self::cleanupNesting($object->$name(), $nesting);
+ } catch (\Exception $e) {
+ $getters[$name] = '!! ' . get_class($e) . ': ' . $e->getMessage() . ' !!';
+ }
+ }
+
+ return $getters;
+ }
+
+ private static function cleanupNesting($argument, $nesting)
+ {
+ if (is_object($argument)) {
+ $object = self::objectToArray($argument, $nesting - 1);
+ $object['class'] = get_class($argument);
+
+ return $object;
+ }
+
+ if (is_array($argument)) {
+ return self::cleanupArray($argument, $nesting - 1);
+ }
+
+ return $argument;
+ }
+
+ private static function cleanupArray($argument, $nesting = 3)
+ {
+ if ($nesting == 0) {
+ return '...';
+ }
+
+ foreach ($argument as $key => $value) {
+ if (is_array($value)) {
+ $argument[$key] = self::cleanupArray($value, $nesting - 1);
+ } elseif (is_object($value)) {
+ $argument[$key] = self::objectToArray($value, $nesting - 1);
+ }
+ }
+
+ return $argument;
+ }
+
+ /**
+ * Utility function to parse shouldReceive() arguments and generate
+ * expectations from such as needed.
+ *
+ * @param Mockery\MockInterface $mock
+ * @param array $args
+ * @param callable $add
+ * @return \Mockery\CompositeExpectation
+ */
+ public static function parseShouldReturnArgs(\Mockery\MockInterface $mock, $args, $add)
+ {
+ $composite = new \Mockery\CompositeExpectation();
+
+ foreach ($args as $arg) {
+ if (is_array($arg)) {
+ foreach ($arg as $k => $v) {
+ $expectation = self::buildDemeterChain($mock, $k, $add)->andReturn($v);
+ $composite->add($expectation);
+ }
+ } elseif (is_string($arg)) {
+ $expectation = self::buildDemeterChain($mock, $arg, $add);
+ $composite->add($expectation);
+ }
+ }
+
+ return $composite;
+ }
+
+ /**
+ * Sets up expectations on the members of the CompositeExpectation and
+ * builds up any demeter chain that was passed to shouldReceive.
+ *
+ * @param \Mockery\MockInterface $mock
+ * @param string $arg
+ * @param callable $add
+ * @throws Mockery\Exception
+ * @return \Mockery\ExpectationDirector
+ */
+ protected static function buildDemeterChain(\Mockery\MockInterface $mock, $arg, $add)
+ {
+ /** @var Mockery\Container $container */
+ $container = $mock->mockery_getContainer();
+ $methodNames = explode('->', $arg);
+ reset($methodNames);
+
+ if (!\Mockery::getConfiguration()->mockingNonExistentMethodsAllowed()
+ && !$mock->mockery_isAnonymous()
+ && !in_array(current($methodNames), $mock->mockery_getMockableMethods())
+ ) {
+ throw new \Mockery\Exception(
+ 'Mockery\'s configuration currently forbids mocking the method '
+ . current($methodNames) . ' as it does not exist on the class or object '
+ . 'being mocked'
+ );
+ }
+
+ /** @var ExpectationInterface|null $expectations */
+ $expectations = null;
+
+ /** @var Callable $nextExp */
+ $nextExp = function ($method) use ($add) {
+ return $add($method);
+ };
+
+ while (true) {
+ $method = array_shift($methodNames);
+ $expectations = $mock->mockery_getExpectationsFor($method);
+
+ if (is_null($expectations) || self::noMoreElementsInChain($methodNames)) {
+ $expectations = $nextExp($method);
+ if (self::noMoreElementsInChain($methodNames)) {
+ break;
+ }
+
+ $mock = self::getNewDemeterMock($container, $method, $expectations);
+ } else {
+ $demeterMockKey = $container->getKeyOfDemeterMockFor($method);
+ if ($demeterMockKey) {
+ $mock = self::getExistingDemeterMock($container, $demeterMockKey);
+ }
+ }
+
+ $nextExp = function ($n) use ($mock) {
+ return $mock->shouldReceive($n);
+ };
+ }
+
+ return $expectations;
+ }
+
+ /**
+ * @param \Mockery\Container $container
+ * @param string $method
+ * @param Mockery\ExpectationInterface $exp
+ *
+ * @return \Mockery\Mock
+ */
+ private static function getNewDemeterMock(Mockery\Container $container,
+ $method,
+ Mockery\ExpectationInterface $exp
+ ) {
+ $mock = $container->mock('demeter_' . $method);
+ $exp->andReturn($mock);
+
+ return $mock;
+ }
+
+ /**
+ * @param \Mockery\Container $container
+ * @param string $demeterMockKey
+ *
+ * @return mixed
+ */
+ private static function getExistingDemeterMock(Mockery\Container $container, $demeterMockKey)
+ {
+ $mocks = $container->getMocks();
+ $mock = $mocks[$demeterMockKey];
+
+ return $mock;
+ }
+
+ /**
+ * @param array $methodNames
+ *
+ * @return bool
+ */
+ private static function noMoreElementsInChain(array $methodNames)
+ {
+ return empty($methodNames);
+ }
+
+ /**
+ * Register a file to be deleted on tearDown.
+ *
+ * @param string $fileName
+ */
+ public static function registerFileForCleanUp($fileName)
+ {
+ self::$_filesToCleanUp[] = $fileName;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryPHPUnitIntegration.php b/vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryPHPUnitIntegration.php
new file mode 100644
index 000000000..aefc6d3f2
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryPHPUnitIntegration.php
@@ -0,0 +1,26 @@
+addToAssertionCount($container->mockery_getExpectationCount());
+ }
+
+ // Verify Mockery expectations.
+ \Mockery::close();
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryTestCase.php b/vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryTestCase.php
new file mode 100644
index 000000000..acbba3044
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/MockeryTestCase.php
@@ -0,0 +1,30 @@
+addMockeryExpectationsToAssertionCount();
+ $this->closeMockery();
+
+ parent::assertPostConditions();
+ }
+
+ protected function addMockeryExpectationsToAssertionCount()
+ {
+ $container = Mockery::getContainer();
+ if ($container != null) {
+ $count = $container->mockery_getExpectationCount();
+ $this->addToAssertionCount($count);
+ }
+ }
+
+ protected function closeMockery()
+ {
+ Mockery::close();
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/TestListener.php b/vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/TestListener.php
new file mode 100644
index 000000000..578d32625
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Adapter/Phpunit/TestListener.php
@@ -0,0 +1,93 @@
+mockery_getExpectationCount();
+ $test->addToAssertionCount($expectation_count);
+ }
+ \Mockery::close();
+ } catch (\Exception $e) {
+ $result = $test->getTestResultObject();
+ $result->addError($test, $e, $time);
+ }
+ }
+
+ /**
+ * Add Mockery files to PHPUnit's blacklist so they don't showup on coverage reports
+ */
+ public function startTestSuite(\PHPUnit_Framework_TestSuite $suite)
+ {
+ if (class_exists('\\PHP_CodeCoverage_Filter')
+ && method_exists('\\PHP_CodeCoverage_Filter', 'getInstance')) {
+ \PHP_CodeCoverage_Filter::getInstance()->addDirectoryToBlacklist(
+ __DIR__.'/../../../Mockery/', '.php', '', 'PHPUNIT'
+ );
+
+ \PHP_CodeCoverage_Filter::getInstance()->addFileToBlacklist(__DIR__.'/../../../Mockery.php', 'PHPUNIT');
+ }
+ }
+ /**
+ * The Listening methods below are not required for Mockery
+ */
+ public function addError(\PHPUnit_Framework_Test $test, \Exception $e, $time)
+ {
+ }
+
+ public function addFailure(\PHPUnit_Framework_Test $test, \PHPUnit_Framework_AssertionFailedError $e, $time)
+ {
+ }
+
+ public function addIncompleteTest(\PHPUnit_Framework_Test $test, \Exception $e, $time)
+ {
+ }
+
+ public function addSkippedTest(\PHPUnit_Framework_Test $test, \Exception $e, $time)
+ {
+ }
+
+ public function addRiskyTest(\PHPUnit_Framework_Test $test, \Exception $e, $time)
+ {
+ }
+
+ public function endTestSuite(\PHPUnit_Framework_TestSuite $suite)
+ {
+ }
+
+ public function startTest(\PHPUnit_Framework_Test $test)
+ {
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/CompositeExpectation.php b/vendor/mockery/mockery/library/Mockery/CompositeExpectation.php
new file mode 100644
index 000000000..242d73b91
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/CompositeExpectation.php
@@ -0,0 +1,131 @@
+_expectations[] = $expectation;
+ }
+
+ /**
+ * @param mixed ...
+ */
+ public function andReturn()
+ {
+ return $this->__call(__FUNCTION__, func_get_args());
+ }
+
+ /**
+ * Intercept any expectation calls and direct against all expectations
+ *
+ * @param string $method
+ * @param array $args
+ * @return self
+ */
+ public function __call($method, array $args)
+ {
+ foreach ($this->_expectations as $expectation) {
+ call_user_func_array(array($expectation, $method), $args);
+ }
+ return $this;
+ }
+
+ /**
+ * Return order number of the first expectation
+ *
+ * @return int
+ */
+ public function getOrderNumber()
+ {
+ reset($this->_expectations);
+ $first = current($this->_expectations);
+ return $first->getOrderNumber();
+ }
+
+ /**
+ * Return the parent mock of the first expectation
+ *
+ * @return \Mockery\MockInterface
+ */
+ public function getMock()
+ {
+ reset($this->_expectations);
+ $first = current($this->_expectations);
+ return $first->getMock();
+ }
+
+ /**
+ * Mockery API alias to getMock
+ *
+ * @return \Mockery\MockInterface
+ */
+ public function mock()
+ {
+ return $this->getMock();
+ }
+
+ /**
+ * Starts a new expectation addition on the first mock which is the primary
+ * target outside of a demeter chain
+ *
+ * @param mixed ...
+ * @return \Mockery\Expectation
+ */
+ public function shouldReceive()
+ {
+ $args = func_get_args();
+ reset($this->_expectations);
+ $first = current($this->_expectations);
+ return call_user_func_array(array($first->getMock(), 'shouldReceive'), $args);
+ }
+
+ /**
+ * Return the string summary of this composite expectation
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ $return = '[';
+ $parts = array();
+ foreach ($this->_expectations as $exp) {
+ $parts[] = (string) $exp;
+ }
+ $return .= implode(', ', $parts) . ']';
+ return $return;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Configuration.php b/vendor/mockery/mockery/library/Mockery/Configuration.php
new file mode 100644
index 000000000..a6366b88e
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Configuration.php
@@ -0,0 +1,131 @@
+_allowMockingNonExistentMethod = (bool) $flag;
+ }
+
+ /**
+ * Return flag indicating whether mocking non-existent methods allowed
+ *
+ * @return bool
+ */
+ public function mockingNonExistentMethodsAllowed()
+ {
+ return $this->_allowMockingNonExistentMethod;
+ }
+
+ /**
+ * Set boolean to allow/prevent unnecessary mocking of methods
+ *
+ * @param bool
+ */
+ public function allowMockingMethodsUnnecessarily($flag = true)
+ {
+ $this->_allowMockingMethodsUnnecessarily = (bool) $flag;
+ }
+
+ /**
+ * Return flag indicating whether mocking non-existent methods allowed
+ *
+ * @return bool
+ */
+ public function mockingMethodsUnnecessarilyAllowed()
+ {
+ return $this->_allowMockingMethodsUnnecessarily;
+ }
+
+ /**
+ * Set a parameter map (array of param signature strings) for the method
+ * of an internal PHP class.
+ *
+ * @param string $class
+ * @param string $method
+ * @param array $map
+ */
+ public function setInternalClassMethodParamMap($class, $method, array $map)
+ {
+ if (!isset($this->_internalClassParamMap[strtolower($class)])) {
+ $this->_internalClassParamMap[strtolower($class)] = array();
+ }
+ $this->_internalClassParamMap[strtolower($class)][strtolower($method)] = $map;
+ }
+
+ /**
+ * Remove all overriden parameter maps from internal PHP classes.
+ */
+ public function resetInternalClassMethodParamMaps()
+ {
+ $this->_internalClassParamMap = array();
+ }
+
+ /**
+ * Get the parameter map of an internal PHP class method
+ *
+ * @return array
+ */
+ public function getInternalClassMethodParamMap($class, $method)
+ {
+ if (isset($this->_internalClassParamMap[strtolower($class)][strtolower($method)])) {
+ return $this->_internalClassParamMap[strtolower($class)][strtolower($method)];
+ }
+ }
+
+ public function getInternalClassMethodParamMaps()
+ {
+ return $this->_internalClassParamMap;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Container.php b/vendor/mockery/mockery/library/Mockery/Container.php
new file mode 100644
index 000000000..d112266a1
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Container.php
@@ -0,0 +1,524 @@
+_generator = $generator ?: \Mockery::getDefaultGenerator();
+ $this->_loader = $loader ?: \Mockery::getDefaultLoader();
+ }
+
+ /**
+ * Generates a new mock object for this container
+ *
+ * I apologies in advance for this. A God Method just fits the API which
+ * doesn't require differentiating between classes, interfaces, abstracts,
+ * names or partials - just so long as it's something that can be mocked.
+ * I'll refactor it one day so it's easier to follow.
+ *
+ * @throws Exception\RuntimeException
+ * @throws Exception
+ * @return \Mockery\Mock
+ */
+ public function mock()
+ {
+ $expectationClosure = null;
+ $quickdefs = array();
+ $constructorArgs = null;
+ $blocks = array();
+ $args = func_get_args();
+
+ if (count($args) > 1) {
+ $finalArg = end($args);
+ reset($args);
+ if (is_callable($finalArg) && is_object($finalArg)) {
+ $expectationClosure = array_pop($args);
+ }
+ }
+
+ $builder = new MockConfigurationBuilder();
+
+ foreach ($args as $k => $arg) {
+ if ($arg instanceof MockConfigurationBuilder) {
+ $builder = $arg;
+ unset($args[$k]);
+ }
+ }
+ reset($args);
+
+ $builder->setParameterOverrides(\Mockery::getConfiguration()->getInternalClassMethodParamMaps());
+
+ while (count($args) > 0) {
+ $arg = current($args);
+ // check for multiple interfaces
+ if (is_string($arg) && strpos($arg, ',') && !strpos($arg, ']')) {
+ $interfaces = explode(',', str_replace(' ', '', $arg));
+ foreach ($interfaces as $i) {
+ if (!interface_exists($i, true) && !class_exists($i, true)) {
+ throw new \Mockery\Exception(
+ 'Class name follows the format for defining multiple'
+ . ' interfaces, however one or more of the interfaces'
+ . ' do not exist or are not included, or the base class'
+ . ' (which you may omit from the mock definition) does not exist'
+ );
+ }
+ }
+ $builder->addTargets($interfaces);
+ array_shift($args);
+
+ continue;
+ } elseif (is_string($arg) && substr($arg, 0, 6) == 'alias:') {
+ $name = array_shift($args);
+ $name = str_replace('alias:', '', $name);
+ $builder->addTarget('stdClass');
+ $builder->setName($name);
+ continue;
+ } elseif (is_string($arg) && substr($arg, 0, 9) == 'overload:') {
+ $name = array_shift($args);
+ $name = str_replace('overload:', '', $name);
+ $builder->setInstanceMock(true);
+ $builder->addTarget('stdClass');
+ $builder->setName($name);
+ continue;
+ } elseif (is_string($arg) && substr($arg, strlen($arg)-1, 1) == ']') {
+ $parts = explode('[', $arg);
+ if (!class_exists($parts[0], true) && !interface_exists($parts[0], true)) {
+ throw new \Mockery\Exception('Can only create a partial mock from'
+ . ' an existing class or interface');
+ }
+ $class = $parts[0];
+ $parts[1] = str_replace(' ', '', $parts[1]);
+ $partialMethods = explode(',', strtolower(rtrim($parts[1], ']')));
+ $builder->addTarget($class);
+ $builder->setWhiteListedMethods($partialMethods);
+ array_shift($args);
+ continue;
+ } elseif (is_string($arg) && (class_exists($arg, true) || interface_exists($arg, true))) {
+ $class = array_shift($args);
+ $builder->addTarget($class);
+ continue;
+ } elseif (is_string($arg)) {
+ $class = array_shift($args);
+ $builder->addTarget($class);
+ continue;
+ } elseif (is_object($arg)) {
+ $partial = array_shift($args);
+ $builder->addTarget($partial);
+ continue;
+ } elseif (is_array($arg) && !empty($arg) && array_keys($arg) !== range(0, count($arg) - 1)) {
+ // if associative array
+ if (array_key_exists(self::BLOCKS, $arg)) {
+ $blocks = $arg[self::BLOCKS];
+ }
+ unset($arg[self::BLOCKS]);
+ $quickdefs = array_shift($args);
+ continue;
+ } elseif (is_array($arg)) {
+ $constructorArgs = array_shift($args);
+ continue;
+ }
+
+ throw new \Mockery\Exception(
+ 'Unable to parse arguments sent to '
+ . get_class($this) . '::mock()'
+ );
+ }
+
+ $builder->addBlackListedMethods($blocks);
+
+ if (!is_null($constructorArgs)) {
+ $builder->addBlackListedMethod("__construct"); // we need to pass through
+ }
+
+ if (!empty($partialMethods) && $constructorArgs === null) {
+ $constructorArgs = array();
+ }
+
+ $config = $builder->getMockConfiguration();
+
+ $this->checkForNamedMockClashes($config);
+
+ $def = $this->getGenerator()->generate($config);
+
+ if (class_exists($def->getClassName(), $attemptAutoload = false)) {
+ $rfc = new \ReflectionClass($def->getClassName());
+ if (!$rfc->implementsInterface("Mockery\MockInterface")) {
+ throw new \Mockery\Exception\RuntimeException("Could not load mock {$def->getClassName()}, class already exists");
+ }
+ }
+
+ $this->getLoader()->load($def);
+
+ $mock = $this->_getInstance($def->getClassName(), $constructorArgs);
+ $mock->mockery_init($this, $config->getTargetObject());
+
+ if (!empty($quickdefs)) {
+ $mock->shouldReceive($quickdefs)->byDefault();
+ }
+ if (!empty($expectationClosure)) {
+ $expectationClosure($mock);
+ }
+ $this->rememberMock($mock);
+ return $mock;
+ }
+
+ public function instanceMock()
+ {
+ }
+
+ public function getLoader()
+ {
+ return $this->_loader;
+ }
+
+ public function getGenerator()
+ {
+ return $this->_generator;
+ }
+
+ /**
+ * @param string $method
+ * @return string|null
+ */
+ public function getKeyOfDemeterMockFor($method)
+ {
+ $keys = array_keys($this->_mocks);
+ $match = preg_grep("/__demeter_{$method}$/", $keys);
+ if (count($match) == 1) {
+ $res = array_values($match);
+ if (count($res) > 0) {
+ return $res[0];
+ }
+ }
+ return null;
+ }
+
+ /**
+ * @return array
+ */
+ public function getMocks()
+ {
+ return $this->_mocks;
+ }
+
+ /**
+ * Tear down tasks for this container
+ *
+ * @throws \Exception
+ * @return void
+ */
+ public function mockery_teardown()
+ {
+ try {
+ $this->mockery_verify();
+ } catch (\Exception $e) {
+ $this->mockery_close();
+ throw $e;
+ }
+ }
+
+ /**
+ * Verify the container mocks
+ *
+ * @return void
+ */
+ public function mockery_verify()
+ {
+ foreach ($this->_mocks as $mock) {
+ $mock->mockery_verify();
+ }
+ }
+
+ /**
+ * Reset the container to its original state
+ *
+ * @return void
+ */
+ public function mockery_close()
+ {
+ foreach ($this->_mocks as $mock) {
+ $mock->mockery_teardown();
+ }
+ $this->_mocks = array();
+ }
+
+ /**
+ * Fetch the next available allocation order number
+ *
+ * @return int
+ */
+ public function mockery_allocateOrder()
+ {
+ $this->_allocatedOrder += 1;
+ return $this->_allocatedOrder;
+ }
+
+ /**
+ * Set ordering for a group
+ *
+ * @param mixed $group
+ * @param int $order
+ */
+ public function mockery_setGroup($group, $order)
+ {
+ $this->_groups[$group] = $order;
+ }
+
+ /**
+ * Fetch array of ordered groups
+ *
+ * @return array
+ */
+ public function mockery_getGroups()
+ {
+ return $this->_groups;
+ }
+
+ /**
+ * Set current ordered number
+ *
+ * @param int $order
+ * @return int The current order number that was set
+ */
+ public function mockery_setCurrentOrder($order)
+ {
+ $this->_currentOrder = $order;
+ return $this->_currentOrder;
+ }
+
+ /**
+ * Get current ordered number
+ *
+ * @return int
+ */
+ public function mockery_getCurrentOrder()
+ {
+ return $this->_currentOrder;
+ }
+
+ /**
+ * Validate the current mock's ordering
+ *
+ * @param string $method
+ * @param int $order
+ * @throws \Mockery\Exception
+ * @return void
+ */
+ public function mockery_validateOrder($method, $order, \Mockery\MockInterface $mock)
+ {
+ if ($order < $this->_currentOrder) {
+ $exception = new \Mockery\Exception\InvalidOrderException(
+ 'Method ' . $method . ' called out of order: expected order '
+ . $order . ', was ' . $this->_currentOrder
+ );
+ $exception->setMock($mock)
+ ->setMethodName($method)
+ ->setExpectedOrder($order)
+ ->setActualOrder($this->_currentOrder);
+ throw $exception;
+ }
+ $this->mockery_setCurrentOrder($order);
+ }
+
+ /**
+ * Gets the count of expectations on the mocks
+ *
+ * @return int
+ */
+ public function mockery_getExpectationCount()
+ {
+ $count = 0;
+ foreach ($this->_mocks as $mock) {
+ $count += $mock->mockery_getExpectationCount();
+ }
+ return $count;
+ }
+
+ /**
+ * Store a mock and set its container reference
+ *
+ * @param \Mockery\Mock
+ * @return \Mockery\Mock
+ */
+ public function rememberMock(\Mockery\MockInterface $mock)
+ {
+ if (!isset($this->_mocks[get_class($mock)])) {
+ $this->_mocks[get_class($mock)] = $mock;
+ } else {
+ /**
+ * This condition triggers for an instance mock where origin mock
+ * is already remembered
+ */
+ $this->_mocks[] = $mock;
+ }
+ return $mock;
+ }
+
+ /**
+ * Retrieve the last remembered mock object, which is the same as saying
+ * retrieve the current mock being programmed where you have yet to call
+ * mock() to change it - thus why the method name is "self" since it will be
+ * be used during the programming of the same mock.
+ *
+ * @return \Mockery\Mock
+ */
+ public function self()
+ {
+ $mocks = array_values($this->_mocks);
+ $index = count($mocks) - 1;
+ return $mocks[$index];
+ }
+
+ /**
+ * Return a specific remembered mock according to the array index it
+ * was stored to in this container instance
+ *
+ * @return \Mockery\Mock
+ */
+ public function fetchMock($reference)
+ {
+ if (isset($this->_mocks[$reference])) {
+ return $this->_mocks[$reference];
+ }
+ }
+
+ protected function _getInstance($mockName, $constructorArgs = null)
+ {
+ if ($constructorArgs !== null) {
+ $r = new \ReflectionClass($mockName);
+ return $r->newInstanceArgs($constructorArgs);
+ }
+
+ try {
+ $instantiator = new Instantiator;
+ $instance = $instantiator->instantiate($mockName);
+ } catch (\Exception $ex) {
+ $internalMockName = $mockName . '_Internal';
+
+ if (!class_exists($internalMockName)) {
+ eval("class $internalMockName extends $mockName {" .
+ 'public function __construct() {}' .
+ '}');
+ }
+
+ $instance = new $internalMockName();
+ }
+
+ return $instance;
+ }
+
+ /**
+ * Takes a class name and declares it
+ *
+ * @param string $fqcn
+ */
+ public function declareClass($fqcn)
+ {
+ if (false !== strpos($fqcn, '/')) {
+ throw new \Mockery\Exception(
+ 'Class name contains a forward slash instead of backslash needed '
+ . 'when employing namespaces'
+ );
+ }
+ if (false !== strpos($fqcn, "\\")) {
+ $parts = array_filter(explode("\\", $fqcn), function ($part) {
+ return $part !== "";
+ });
+ $cl = array_pop($parts);
+ $ns = implode("\\", $parts);
+ eval(" namespace $ns { class $cl {} }");
+ } else {
+ eval(" class $fqcn {} ");
+ }
+ }
+
+ protected function checkForNamedMockClashes($config)
+ {
+ $name = $config->getName();
+
+ if (!$name) {
+ return;
+ }
+
+ $hash = $config->getHash();
+
+ if (isset($this->_namedMocks[$name])) {
+ if ($hash !== $this->_namedMocks[$name]) {
+ throw new \Mockery\Exception(
+ "The mock named '$name' has been already defined with a different mock configuration"
+ );
+ }
+ }
+
+ $this->_namedMocks[$name] = $hash;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/CountValidator/AtLeast.php b/vendor/mockery/mockery/library/Mockery/CountValidator/AtLeast.php
new file mode 100644
index 000000000..ca097ce16
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/CountValidator/AtLeast.php
@@ -0,0 +1,63 @@
+_limit > $n) {
+ $exception = new Mockery\Exception\InvalidCountException(
+ 'Method ' . (string) $this->_expectation
+ . ' from ' . $this->_expectation->getMock()->mockery_getName()
+ . ' should be called' . PHP_EOL
+ . ' at least ' . $this->_limit . ' times but called ' . $n
+ . ' times.'
+ );
+ $exception->setMock($this->_expectation->getMock())
+ ->setMethodName((string) $this->_expectation)
+ ->setExpectedCountComparative('>=')
+ ->setExpectedCount($this->_limit)
+ ->setActualCount($n);
+ throw $exception;
+ }
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/CountValidator/AtMost.php b/vendor/mockery/mockery/library/Mockery/CountValidator/AtMost.php
new file mode 100644
index 000000000..83349d67e
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/CountValidator/AtMost.php
@@ -0,0 +1,52 @@
+_limit < $n) {
+ $exception = new Mockery\Exception\InvalidCountException(
+ 'Method ' . (string) $this->_expectation
+ . ' from ' . $this->_expectation->getMock()->mockery_getName()
+ . ' should be called' . PHP_EOL
+ . ' at most ' . $this->_limit . ' times but called ' . $n
+ . ' times.'
+ );
+ $exception->setMock($this->_expectation->getMock())
+ ->setMethodName((string) $this->_expectation)
+ ->setExpectedCountComparative('<=')
+ ->setExpectedCount($this->_limit)
+ ->setActualCount($n);
+ throw $exception;
+ }
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/CountValidator/CountValidatorAbstract.php b/vendor/mockery/mockery/library/Mockery/CountValidator/CountValidatorAbstract.php
new file mode 100644
index 000000000..b35a7ceb3
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/CountValidator/CountValidatorAbstract.php
@@ -0,0 +1,70 @@
+_expectation = $expectation;
+ $this->_limit = $limit;
+ }
+
+ /**
+ * Checks if the validator can accept an additional nth call
+ *
+ * @param int $n
+ * @return bool
+ */
+ public function isEligible($n)
+ {
+ return ($n < $this->_limit);
+ }
+
+ /**
+ * Validate the call count against this validator
+ *
+ * @param int $n
+ * @return bool
+ */
+ abstract public function validate($n);
+}
diff --git a/vendor/mockery/mockery/library/Mockery/CountValidator/Exact.php b/vendor/mockery/mockery/library/Mockery/CountValidator/Exact.php
new file mode 100644
index 000000000..7e3948c1e
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/CountValidator/Exact.php
@@ -0,0 +1,52 @@
+_limit !== $n) {
+ $exception = new Mockery\Exception\InvalidCountException(
+ 'Method ' . (string) $this->_expectation
+ . ' from ' . $this->_expectation->getMock()->mockery_getName()
+ . ' should be called' . PHP_EOL
+ . ' exactly ' . $this->_limit . ' times but called ' . $n
+ . ' times.'
+ );
+ $exception->setMock($this->_expectation->getMock())
+ ->setMethodName((string) $this->_expectation)
+ ->setExpectedCountComparative('=')
+ ->setExpectedCount($this->_limit)
+ ->setActualCount($n);
+ throw $exception;
+ }
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/CountValidator/Exception.php b/vendor/mockery/mockery/library/Mockery/CountValidator/Exception.php
new file mode 100644
index 000000000..65126ddea
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/CountValidator/Exception.php
@@ -0,0 +1,25 @@
+mockObject = $mock;
+ return $this;
+ }
+
+ public function setMethodName($name)
+ {
+ $this->method = $name;
+ return $this;
+ }
+
+ public function setActualCount($count)
+ {
+ $this->actual = $count;
+ return $this;
+ }
+
+ public function setExpectedCount($count)
+ {
+ $this->expected = $count;
+ return $this;
+ }
+
+ public function setExpectedCountComparative($comp)
+ {
+ if (!in_array($comp, array('=', '>', '<', '>=', '<='))) {
+ throw new RuntimeException(
+ 'Illegal comparative for expected call counts set: ' . $comp
+ );
+ }
+ $this->expectedComparative = $comp;
+ return $this;
+ }
+
+ public function getMock()
+ {
+ return $this->mockObject;
+ }
+
+ public function getMethodName()
+ {
+ return $this->method;
+ }
+
+ public function getActualCount()
+ {
+ return $this->actual;
+ }
+
+ public function getExpectedCount()
+ {
+ return $this->expected;
+ }
+
+ public function getMockName()
+ {
+ return $this->getMock()->mockery_getName();
+ }
+
+ public function getExpectedCountComparative()
+ {
+ return $this->expectedComparative;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Exception/InvalidOrderException.php b/vendor/mockery/mockery/library/Mockery/Exception/InvalidOrderException.php
new file mode 100644
index 000000000..418372c75
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Exception/InvalidOrderException.php
@@ -0,0 +1,84 @@
+mockObject = $mock;
+ return $this;
+ }
+
+ public function setMethodName($name)
+ {
+ $this->method = $name;
+ return $this;
+ }
+
+ public function setActualOrder($count)
+ {
+ $this->actual = $count;
+ return $this;
+ }
+
+ public function setExpectedOrder($count)
+ {
+ $this->expected = $count;
+ return $this;
+ }
+
+ public function getMock()
+ {
+ return $this->mockObject;
+ }
+
+ public function getMethodName()
+ {
+ return $this->method;
+ }
+
+ public function getActualOrder()
+ {
+ return $this->actual;
+ }
+
+ public function getExpectedOrder()
+ {
+ return $this->expected;
+ }
+
+ public function getMockName()
+ {
+ return $this->getMock()->mockery_getName();
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Exception/NoMatchingExpectationException.php b/vendor/mockery/mockery/library/Mockery/Exception/NoMatchingExpectationException.php
new file mode 100644
index 000000000..8476b5934
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Exception/NoMatchingExpectationException.php
@@ -0,0 +1,71 @@
+mockObject = $mock;
+ return $this;
+ }
+
+ public function setMethodName($name)
+ {
+ $this->method = $name;
+ return $this;
+ }
+
+ public function setActualArguments($count)
+ {
+ $this->actual = $count;
+ return $this;
+ }
+
+ public function getMock()
+ {
+ return $this->mockObject;
+ }
+
+ public function getMethodName()
+ {
+ return $this->method;
+ }
+
+ public function getActualArguments()
+ {
+ return $this->actual;
+ }
+
+ public function getMockName()
+ {
+ return $this->getMock()->mockery_getName();
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Exception/RuntimeException.php b/vendor/mockery/mockery/library/Mockery/Exception/RuntimeException.php
new file mode 100644
index 000000000..323b33d11
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Exception/RuntimeException.php
@@ -0,0 +1,25 @@
+_mock = $mock;
+ $this->_name = $name;
+ }
+
+ /**
+ * Return a string with the method name and arguments formatted
+ *
+ * @param string $name Name of the expected method
+ * @param array $args List of arguments to the method
+ * @return string
+ */
+ public function __toString()
+ {
+ return \Mockery::formatArgs($this->_name, $this->_expectedArgs);
+ }
+
+ /**
+ * Verify the current call, i.e. that the given arguments match those
+ * of this expectation
+ *
+ * @param array $args
+ * @return mixed
+ */
+ public function verifyCall(array $args)
+ {
+ $this->validateOrder();
+ $this->_actualCount++;
+ if (true === $this->_passthru) {
+ return $this->_mock->mockery_callSubjectMethod($this->_name, $args);
+ }
+ $return = $this->_getReturnValue($args);
+ if ($return instanceof \Exception && $this->_throw === true) {
+ throw $return;
+ }
+ $this->_setValues();
+ return $return;
+ }
+
+ /**
+ * Sets public properties with queued values to the mock object
+ *
+ * @param array $args
+ * @return mixed
+ */
+ protected function _setValues()
+ {
+ $mockClass = get_class($this->_mock);
+ $container = $this->_mock->mockery_getContainer();
+ $mocks = $container->getMocks();
+ foreach ($this->_setQueue as $name => &$values) {
+ if (count($values) > 0) {
+ $value = array_shift($values);
+ foreach ($mocks as $mock) {
+ if (is_a($mock, $mockClass)) {
+ $mock->{$name} = $value;
+ }
+ }
+ }
+ }
+ }
+
+ /**
+ * Fetch the return value for the matching args
+ *
+ * @param array $args
+ * @return mixed
+ */
+ protected function _getReturnValue(array $args)
+ {
+ if (count($this->_closureQueue) > 1) {
+ return call_user_func_array(array_shift($this->_closureQueue), $args);
+ } elseif (count($this->_closureQueue) > 0) {
+ return call_user_func_array(current($this->_closureQueue), $args);
+ } elseif (count($this->_returnQueue) > 1) {
+ return array_shift($this->_returnQueue);
+ } elseif (count($this->_returnQueue) > 0) {
+ return current($this->_returnQueue);
+ }
+
+ $rm = $this->_mock->mockery_getMethod($this->_name);
+ if ($rm && version_compare(PHP_VERSION, '7.0.0-dev') >= 0 && $rm->hasReturnType()) {
+ $type = (string) $rm->getReturnType();
+ switch ($type) {
+ case '': return;
+ case 'void': return;
+ case 'string': return '';
+ case 'int': return 0;
+ case 'float': return 0.0;
+ case 'bool': return false;
+ case 'array': return array();
+
+ case 'callable':
+ case 'Closure':
+ return function () {
+ };
+
+ case 'Traversable':
+ case 'Generator':
+ // Remove eval() when minimum version >=5.5
+ $generator = eval('return function () { yield; };');
+ return $generator();
+
+ default:
+ return \Mockery::mock($type);
+ }
+ }
+ }
+
+ /**
+ * Checks if this expectation is eligible for additional calls
+ *
+ * @return bool
+ */
+ public function isEligible()
+ {
+ foreach ($this->_countValidators as $validator) {
+ if (!$validator->isEligible($this->_actualCount)) {
+ return false;
+ }
+ }
+ return true;
+ }
+
+ /**
+ * Check if there is a constraint on call count
+ *
+ * @return bool
+ */
+ public function isCallCountConstrained()
+ {
+ return (count($this->_countValidators) > 0);
+ }
+
+ /**
+ * Verify call order
+ *
+ * @return void
+ */
+ public function validateOrder()
+ {
+ if ($this->_orderNumber) {
+ $this->_mock->mockery_validateOrder((string) $this, $this->_orderNumber, $this->_mock);
+ }
+ if ($this->_globalOrderNumber) {
+ $this->_mock->mockery_getContainer()
+ ->mockery_validateOrder((string) $this, $this->_globalOrderNumber, $this->_mock);
+ }
+ }
+
+ /**
+ * Verify this expectation
+ *
+ * @return bool
+ */
+ public function verify()
+ {
+ foreach ($this->_countValidators as $validator) {
+ $validator->validate($this->_actualCount);
+ }
+ }
+
+ /**
+ * Check if passed arguments match an argument expectation
+ *
+ * @param array $args
+ * @return bool
+ */
+ public function matchArgs(array $args)
+ {
+ if (empty($this->_expectedArgs) && !$this->_noArgsExpectation) {
+ return true;
+ }
+ $expected = is_array($this->_expectedArgs) ? count($this->_expectedArgs) : 0;
+ if (count($args) !== $expected) {
+ return false;
+ }
+ $argCount = count($args);
+ for ($i=0; $i<$argCount; $i++) {
+ $param =& $args[$i];
+ if (!$this->_matchArg($this->_expectedArgs[$i], $param)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Check if passed argument matches an argument expectation
+ *
+ * @param array $args
+ * @return bool
+ */
+ protected function _matchArg($expected, &$actual)
+ {
+ if ($expected === $actual) {
+ return true;
+ }
+ if (!is_object($expected) && !is_object($actual) && $expected == $actual) {
+ return true;
+ }
+ if (is_string($expected) && !is_array($actual) && !is_object($actual)) {
+ # push/pop an error handler here to to make sure no error/exception thrown if $expected is not a regex
+ set_error_handler(function () {
+ });
+ $result = preg_match($expected, (string) $actual);
+ restore_error_handler();
+
+ if ($result) {
+ return true;
+ }
+ }
+ if (is_string($expected) && is_object($actual)) {
+ $result = $actual instanceof $expected;
+ if ($result) {
+ return true;
+ }
+ }
+ if ($expected instanceof \Mockery\Matcher\MatcherAbstract) {
+ return $expected->match($actual);
+ }
+ if (is_a($expected, '\Hamcrest\Matcher') || is_a($expected, '\Hamcrest_Matcher')) {
+ return $expected->matches($actual);
+ }
+ return false;
+ }
+
+ /**
+ * Expected argument setter for the expectation
+ *
+ * @param mixed ...
+ * @return self
+ */
+ public function with()
+ {
+ return $this->withArgs(func_get_args());
+ }
+
+ /**
+ * Expected arguments for the expectation passed as an array
+ *
+ * @param array $args
+ * @return self
+ */
+ public function withArgs(array $args)
+ {
+ if (empty($args)) {
+ return $this->withNoArgs();
+ }
+ $this->_expectedArgs = $args;
+ $this->_noArgsExpectation = false;
+ return $this;
+ }
+
+ /**
+ * Set with() as no arguments expected
+ *
+ * @return self
+ */
+ public function withNoArgs()
+ {
+ $this->_noArgsExpectation = true;
+ $this->_expectedArgs = null;
+ return $this;
+ }
+
+ /**
+ * Set expectation that any arguments are acceptable
+ *
+ * @return self
+ */
+ public function withAnyArgs()
+ {
+ $this->_expectedArgs = array();
+ return $this;
+ }
+
+ /**
+ * Set a return value, or sequential queue of return values
+ *
+ * @param mixed ...
+ * @return self
+ */
+ public function andReturn()
+ {
+ $this->_returnQueue = func_get_args();
+ return $this;
+ }
+
+ /**
+ * Return this mock, like a fluent interface
+ *
+ * @return self
+ */
+ public function andReturnSelf()
+ {
+ return $this->andReturn($this->_mock);
+ }
+
+ /**
+ * Set a sequential queue of return values with an array
+ *
+ * @param array $values
+ * @return self
+ */
+ public function andReturnValues(array $values)
+ {
+ call_user_func_array(array($this, 'andReturn'), $values);
+ return $this;
+ }
+
+ /**
+ * Set a closure or sequence of closures with which to generate return
+ * values. The arguments passed to the expected method are passed to the
+ * closures as parameters.
+ *
+ * @param callable ...
+ * @return self
+ */
+ public function andReturnUsing()
+ {
+ $this->_closureQueue = func_get_args();
+ return $this;
+ }
+
+ /**
+ * Return a self-returning black hole object.
+ *
+ * @return self
+ */
+ public function andReturnUndefined()
+ {
+ $this->andReturn(new \Mockery\Undefined);
+ return $this;
+ }
+
+ /**
+ * Return null. This is merely a language construct for Mock describing.
+ *
+ * @return self
+ */
+ public function andReturnNull()
+ {
+ return $this;
+ }
+
+ /**
+ * Set Exception class and arguments to that class to be thrown
+ *
+ * @param string $exception
+ * @param string $message
+ * @param int $code
+ * @param Exception $previous
+ * @return self
+ */
+ public function andThrow($exception, $message = '', $code = 0, \Exception $previous = null)
+ {
+ $this->_throw = true;
+ if (is_object($exception)) {
+ $this->andReturn($exception);
+ } else {
+ $this->andReturn(new $exception($message, $code, $previous));
+ }
+ return $this;
+ }
+
+ /**
+ * Set Exception classes to be thrown
+ *
+ * @param array $exceptions
+ * @return self
+ */
+ public function andThrowExceptions(array $exceptions)
+ {
+ $this->_throw = true;
+ foreach ($exceptions as $exception) {
+ if (!is_object($exception)) {
+ throw new Exception('You must pass an array of exception objects to andThrowExceptions');
+ }
+ }
+ return $this->andReturnValues($exceptions);
+ }
+
+ /**
+ * Register values to be set to a public property each time this expectation occurs
+ *
+ * @param string $name
+ * @param mixed $value
+ * @return self
+ */
+ public function andSet($name, $value)
+ {
+ $values = func_get_args();
+ array_shift($values);
+ $this->_setQueue[$name] = $values;
+ return $this;
+ }
+
+ /**
+ * Alias to andSet(). Allows the natural English construct
+ * - set('foo', 'bar')->andReturn('bar')
+ *
+ * @param string $name
+ * @param mixed $value
+ * @return self
+ */
+ public function set($name, $value)
+ {
+ return call_user_func_array(array($this, 'andSet'), func_get_args());
+ }
+
+ /**
+ * Indicates this expectation should occur zero or more times
+ *
+ * @return self
+ */
+ public function zeroOrMoreTimes()
+ {
+ $this->atLeast()->never();
+ }
+
+ /**
+ * Indicates the number of times this expectation should occur
+ *
+ * @param int $limit
+ * @return self
+ */
+ public function times($limit = null)
+ {
+ if (is_null($limit)) {
+ return $this;
+ }
+ $this->_countValidators[] = new $this->_countValidatorClass($this, $limit);
+ $this->_countValidatorClass = 'Mockery\CountValidator\Exact';
+ return $this;
+ }
+
+ /**
+ * Indicates that this expectation is never expected to be called
+ *
+ * @return self
+ */
+ public function never()
+ {
+ return $this->times(0);
+ }
+
+ /**
+ * Indicates that this expectation is expected exactly once
+ *
+ * @return self
+ */
+ public function once()
+ {
+ return $this->times(1);
+ }
+
+ /**
+ * Indicates that this expectation is expected exactly twice
+ *
+ * @return self
+ */
+ public function twice()
+ {
+ return $this->times(2);
+ }
+
+ /**
+ * Sets next count validator to the AtLeast instance
+ *
+ * @return self
+ */
+ public function atLeast()
+ {
+ $this->_countValidatorClass = 'Mockery\CountValidator\AtLeast';
+ return $this;
+ }
+
+ /**
+ * Sets next count validator to the AtMost instance
+ *
+ * @return self
+ */
+ public function atMost()
+ {
+ $this->_countValidatorClass = 'Mockery\CountValidator\AtMost';
+ return $this;
+ }
+
+ /**
+ * Shorthand for setting minimum and maximum constraints on call counts
+ *
+ * @param int $minimum
+ * @param int $maximum
+ */
+ public function between($minimum, $maximum)
+ {
+ return $this->atLeast()->times($minimum)->atMost()->times($maximum);
+ }
+
+ /**
+ * Indicates that this expectation must be called in a specific given order
+ *
+ * @param string $group Name of the ordered group
+ * @return self
+ */
+ public function ordered($group = null)
+ {
+ if ($this->_globally) {
+ $this->_globalOrderNumber = $this->_defineOrdered($group, $this->_mock->mockery_getContainer());
+ } else {
+ $this->_orderNumber = $this->_defineOrdered($group, $this->_mock);
+ }
+ $this->_globally = false;
+ return $this;
+ }
+
+ /**
+ * Indicates call order should apply globally
+ *
+ * @return self
+ */
+ public function globally()
+ {
+ $this->_globally = true;
+ return $this;
+ }
+
+ /**
+ * Setup the ordering tracking on the mock or mock container
+ *
+ * @param string $group
+ * @param object $ordering
+ * @return int
+ */
+ protected function _defineOrdered($group, $ordering)
+ {
+ $groups = $ordering->mockery_getGroups();
+ if (is_null($group)) {
+ $result = $ordering->mockery_allocateOrder();
+ } elseif (isset($groups[$group])) {
+ $result = $groups[$group];
+ } else {
+ $result = $ordering->mockery_allocateOrder();
+ $ordering->mockery_setGroup($group, $result);
+ }
+ return $result;
+ }
+
+ /**
+ * Return order number
+ *
+ * @return int
+ */
+ public function getOrderNumber()
+ {
+ return $this->_orderNumber;
+ }
+
+ /**
+ * Mark this expectation as being a default
+ *
+ * @return self
+ */
+ public function byDefault()
+ {
+ $director = $this->_mock->mockery_getExpectationsFor($this->_name);
+ if (!empty($director)) {
+ $director->makeExpectationDefault($this);
+ }
+ return $this;
+ }
+
+ /**
+ * Return the parent mock of the expectation
+ *
+ * @return \Mockery\MockInterface
+ */
+ public function getMock()
+ {
+ return $this->_mock;
+ }
+
+ /**
+ * Flag this expectation as calling the original class method with the
+ * any provided arguments instead of using a return value queue.
+ *
+ * @return self
+ */
+ public function passthru()
+ {
+ if ($this->_mock instanceof Mock) {
+ throw new Exception(
+ 'Mock Objects not created from a loaded/existing class are '
+ . 'incapable of passing method calls through to a parent class'
+ );
+ }
+ $this->_passthru = true;
+ return $this;
+ }
+
+ /**
+ * Cloning logic
+ *
+ */
+ public function __clone()
+ {
+ $newValidators = array();
+ $countValidators = $this->_countValidators;
+ foreach ($countValidators as $validator) {
+ $newValidators[] = clone $validator;
+ }
+ $this->_countValidators = $newValidators;
+ }
+
+ public function getName()
+ {
+ return $this->_name;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/ExpectationDirector.php b/vendor/mockery/mockery/library/Mockery/ExpectationDirector.php
new file mode 100644
index 000000000..b5c894d65
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/ExpectationDirector.php
@@ -0,0 +1,203 @@
+_name = $name;
+ $this->_mock = $mock;
+ }
+
+ /**
+ * Add a new expectation to the director
+ *
+ * @param Mutateme\Expectation $expectation
+ */
+ public function addExpectation(\Mockery\Expectation $expectation)
+ {
+ $this->_expectations[] = $expectation;
+ }
+
+ /**
+ * Handle a method call being directed by this instance
+ *
+ * @param array $args
+ * @return mixed
+ */
+ public function call(array $args)
+ {
+ $expectation = $this->findExpectation($args);
+ if (is_null($expectation)) {
+ $exception = new \Mockery\Exception\NoMatchingExpectationException(
+ 'No matching handler found for '
+ . $this->_mock->mockery_getName() . '::'
+ . \Mockery::formatArgs($this->_name, $args)
+ . '. Either the method was unexpected or its arguments matched'
+ . ' no expected argument list for this method'
+ . PHP_EOL . PHP_EOL
+ . \Mockery::formatObjects($args)
+ );
+ $exception->setMock($this->_mock)
+ ->setMethodName($this->_name)
+ ->setActualArguments($args);
+ throw $exception;
+ }
+ return $expectation->verifyCall($args);
+ }
+
+ /**
+ * Verify all expectations of the director
+ *
+ * @throws \Mockery\CountValidator\Exception
+ * @return void
+ */
+ public function verify()
+ {
+ if (!empty($this->_expectations)) {
+ foreach ($this->_expectations as $exp) {
+ $exp->verify();
+ }
+ } else {
+ foreach ($this->_defaults as $exp) {
+ $exp->verify();
+ }
+ }
+ }
+
+ /**
+ * Attempt to locate an expectation matching the provided args
+ *
+ * @param array $args
+ * @return mixed
+ */
+ public function findExpectation(array $args)
+ {
+ if (!empty($this->_expectations)) {
+ return $this->_findExpectationIn($this->_expectations, $args);
+ } else {
+ return $this->_findExpectationIn($this->_defaults, $args);
+ }
+ }
+
+ /**
+ * Make the given expectation a default for all others assuming it was
+ * correctly created last
+ *
+ * @param \Mockery\Expectation
+ */
+ public function makeExpectationDefault(\Mockery\Expectation $expectation)
+ {
+ $last = end($this->_expectations);
+ if ($last === $expectation) {
+ array_pop($this->_expectations);
+ array_unshift($this->_defaults, $expectation);
+ } else {
+ throw new \Mockery\Exception(
+ 'Cannot turn a previously defined expectation into a default'
+ );
+ }
+ }
+
+ /**
+ * Search current array of expectations for a match
+ *
+ * @param array $expectations
+ * @param array $args
+ * @return mixed
+ */
+ protected function _findExpectationIn(array $expectations, array $args)
+ {
+ foreach ($expectations as $exp) {
+ if ($exp->matchArgs($args) && $exp->isEligible()) {
+ return $exp;
+ }
+ }
+ foreach ($expectations as $exp) {
+ if ($exp->matchArgs($args)) {
+ return $exp;
+ }
+ }
+ }
+
+ /**
+ * Return all expectations assigned to this director
+ *
+ * @return array
+ */
+ public function getExpectations()
+ {
+ return $this->_expectations;
+ }
+
+ /**
+ * Return the number of expectations assigned to this director.
+ *
+ * @return int
+ */
+ public function getExpectationCount()
+ {
+ return count($this->getExpectations());
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/ExpectationInterface.php b/vendor/mockery/mockery/library/Mockery/ExpectationInterface.php
new file mode 100644
index 000000000..a5b4660de
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/ExpectationInterface.php
@@ -0,0 +1,39 @@
+generator = $generator;
+ }
+
+ public function generate(MockConfiguration $config)
+ {
+ $hash = $config->getHash();
+ if (isset($this->cache[$hash])) {
+ return $this->cache[$hash];
+ }
+
+ $definition = $this->generator->generate($config);
+ $this->cache[$hash] = $definition;
+
+ return $definition;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/DefinedTargetClass.php b/vendor/mockery/mockery/library/Mockery/Generator/DefinedTargetClass.php
new file mode 100644
index 000000000..2c0ab9639
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/DefinedTargetClass.php
@@ -0,0 +1,90 @@
+rfc = $rfc;
+ }
+
+ public static function factory($name)
+ {
+ return new self(new \ReflectionClass($name));
+ }
+
+ public function getName()
+ {
+ return $this->rfc->getName();
+ }
+
+ public function isAbstract()
+ {
+ return $this->rfc->isAbstract();
+ }
+
+ public function isFinal()
+ {
+ return $this->rfc->isFinal();
+ }
+
+ public function getMethods()
+ {
+ return array_map(function ($method) {
+ return new Method($method);
+ }, $this->rfc->getMethods());
+ }
+
+ public function getInterfaces()
+ {
+ $class = __CLASS__;
+ return array_map(function ($interface) use ($class) {
+ return new $class($interface);
+ }, $this->rfc->getInterfaces());
+ }
+
+ public function __toString()
+ {
+ return $this->getName();
+ }
+
+ public function getNamespaceName()
+ {
+ return $this->rfc->getNamespaceName();
+ }
+
+ public function inNamespace()
+ {
+ return $this->rfc->inNamespace();
+ }
+
+ public function getShortName()
+ {
+ return $this->rfc->getShortName();
+ }
+
+ public function implementsInterface($interface)
+ {
+ return $this->rfc->implementsInterface($interface);
+ }
+
+ public function hasInternalAncestor()
+ {
+ if ($this->rfc->isInternal()) {
+ return true;
+ }
+
+ $child = $this->rfc;
+ while ($parent = $child->getParentClass()) {
+ if ($parent->isInternal()) {
+ return true;
+ }
+ $child = $parent;
+ }
+
+ return false;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/Generator.php b/vendor/mockery/mockery/library/Mockery/Generator/Generator.php
new file mode 100644
index 000000000..5c5d0d3e1
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/Generator.php
@@ -0,0 +1,9 @@
+method = $method;
+ }
+
+ public function __call($method, $args)
+ {
+ return call_user_func_array(array($this->method, $method), $args);
+ }
+
+ public function getParameters()
+ {
+ return array_map(function ($parameter) {
+ return new Parameter($parameter);
+ }, $this->method->getParameters());
+ }
+
+ public function getReturnType()
+ {
+ if (version_compare(PHP_VERSION, '7.0.0-dev') >= 0 && $this->method->hasReturnType()) {
+ $returnType = (string) $this->method->getReturnType();
+
+ if ('self' === $returnType) {
+ $returnType = "\\".$this->method->getDeclaringClass()->getName();
+ }
+
+ if (version_compare(PHP_VERSION, '7.1.0-dev') >= 0 && $this->method->getReturnType()->allowsNull()) {
+ $returnType = '?'.$returnType;
+ }
+
+ return $returnType;
+ }
+ return '';
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/MockConfiguration.php b/vendor/mockery/mockery/library/Mockery/Generator/MockConfiguration.php
new file mode 100644
index 000000000..27aa5bd26
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/MockConfiguration.php
@@ -0,0 +1,460 @@
+addTargets($targets);
+ $this->blackListedMethods = $blackListedMethods;
+ $this->whiteListedMethods = $whiteListedMethods;
+ $this->name = $name;
+ $this->instanceMock = $instanceMock;
+ $this->parameterOverrides = $parameterOverrides;
+ }
+
+ /**
+ * Attempt to create a hash of the configuration, in order to allow caching
+ *
+ * @TODO workout if this will work
+ *
+ * @return string
+ */
+ public function getHash()
+ {
+ $vars = array(
+ 'targetClassName' => $this->targetClassName,
+ 'targetInterfaceNames' => $this->targetInterfaceNames,
+ 'name' => $this->name,
+ 'blackListedMethods' => $this->blackListedMethods,
+ 'whiteListedMethod' => $this->whiteListedMethods,
+ 'instanceMock' => $this->instanceMock,
+ 'parameterOverrides' => $this->parameterOverrides,
+ );
+
+ return md5(serialize($vars));
+ }
+
+ /**
+ * Gets a list of methods from the classes, interfaces and objects and
+ * filters them appropriately. Lot's of filtering going on, perhaps we could
+ * have filter classes to iterate through
+ */
+ public function getMethodsToMock()
+ {
+ $methods = $this->getAllMethods();
+
+ foreach ($methods as $key => $method) {
+ if ($method->isFinal()) {
+ unset($methods[$key]);
+ }
+ }
+
+ /**
+ * Whitelist trumps everything else
+ */
+ if (count($this->getWhiteListedMethods())) {
+ $whitelist = array_map('strtolower', $this->getWhiteListedMethods());
+ $methods = array_filter($methods, function ($method) use ($whitelist) {
+ return $method->isAbstract() || in_array(strtolower($method->getName()), $whitelist);
+ });
+
+ return $methods;
+ }
+
+ /**
+ * Remove blacklisted methods
+ */
+ if (count($this->getBlackListedMethods())) {
+ $blacklist = array_map('strtolower', $this->getBlackListedMethods());
+ $methods = array_filter($methods, function ($method) use ($blacklist) {
+ return !in_array(strtolower($method->getName()), $blacklist);
+ });
+ }
+
+ /**
+ * Internal objects can not be instantiated with newInstanceArgs and if
+ * they implement Serializable, unserialize will have to be called. As
+ * such, we can't mock it and will need a pass to add a dummy
+ * implementation
+ */
+ if ($this->getTargetClass()
+ && $this->getTargetClass()->implementsInterface("Serializable")
+ && $this->getTargetClass()->hasInternalAncestor()) {
+ $methods = array_filter($methods, function ($method) {
+ return $method->getName() !== "unserialize";
+ });
+ }
+
+ return array_values($methods);
+ }
+
+ /**
+ * We declare the __call method to handle undefined stuff, if the class
+ * we're mocking has also defined it, we need to comply with their interface
+ */
+ public function requiresCallTypeHintRemoval()
+ {
+ foreach ($this->getAllMethods() as $method) {
+ if ("__call" === $method->getName()) {
+ $params = $method->getParameters();
+ return !$params[1]->isArray();
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * We declare the __callStatic method to handle undefined stuff, if the class
+ * we're mocking has also defined it, we need to comply with their interface
+ */
+ public function requiresCallStaticTypeHintRemoval()
+ {
+ foreach ($this->getAllMethods() as $method) {
+ if ("__callStatic" === $method->getName()) {
+ $params = $method->getParameters();
+ return !$params[1]->isArray();
+ }
+ }
+
+ return false;
+ }
+
+ public function rename($className)
+ {
+ $targets = array();
+
+ if ($this->targetClassName) {
+ $targets[] = $this->targetClassName;
+ }
+
+ if ($this->targetInterfaceNames) {
+ $targets = array_merge($targets, $this->targetInterfaceNames);
+ }
+
+ if ($this->targetObject) {
+ $targets[] = $this->targetObject;
+ }
+
+ return new self(
+ $targets,
+ $this->blackListedMethods,
+ $this->whiteListedMethods,
+ $className,
+ $this->instanceMock,
+ $this->parameterOverrides
+ );
+ }
+
+ protected function addTarget($target)
+ {
+ if (is_object($target)) {
+ $this->setTargetObject($target);
+ $this->setTargetClassName(get_class($target));
+ return $this;
+ }
+
+ if ($target[0] !== "\\") {
+ $target = "\\" . $target;
+ }
+
+ if (class_exists($target)) {
+ $this->setTargetClassName($target);
+ return $this;
+ }
+
+ if (interface_exists($target)) {
+ $this->addTargetInterfaceName($target);
+ return $this;
+ }
+
+ /**
+ * Default is to set as class, or interface if class already set
+ *
+ * Don't like this condition, can't remember what the default
+ * targetClass is for
+ */
+ if ($this->getTargetClassName()) {
+ $this->addTargetInterfaceName($target);
+ return $this;
+ }
+
+ $this->setTargetClassName($target);
+ }
+
+ protected function addTargets($interfaces)
+ {
+ foreach ($interfaces as $interface) {
+ $this->addTarget($interface);
+ }
+ }
+
+ public function getTargetClassName()
+ {
+ return $this->targetClassName;
+ }
+
+ public function getTargetClass()
+ {
+ if ($this->targetClass) {
+ return $this->targetClass;
+ }
+
+ if (!$this->targetClassName) {
+ return null;
+ }
+
+ if (class_exists($this->targetClassName)) {
+ $dtc = DefinedTargetClass::factory($this->targetClassName);
+
+ if ($this->getTargetObject() == false && $dtc->isFinal()) {
+ throw new \Mockery\Exception(
+ 'The class ' . $this->targetClassName . ' is marked final and its methods'
+ . ' cannot be replaced. Classes marked final can be passed in'
+ . ' to \Mockery::mock() as instantiated objects to create a'
+ . ' partial mock, but only if the mock is not subject to type'
+ . ' hinting checks.'
+ );
+ }
+
+ $this->targetClass = $dtc;
+ } else {
+ $this->targetClass = new UndefinedTargetClass($this->targetClassName);
+ }
+
+ return $this->targetClass;
+ }
+
+ public function getTargetInterfaces()
+ {
+ if (!empty($this->targetInterfaces)) {
+ return $this->targetInterfaces;
+ }
+
+ foreach ($this->targetInterfaceNames as $targetInterface) {
+ if (!interface_exists($targetInterface)) {
+ $this->targetInterfaces[] = new UndefinedTargetClass($targetInterface);
+ return;
+ }
+
+ $dtc = DefinedTargetClass::factory($targetInterface);
+ $extendedInterfaces = array_keys($dtc->getInterfaces());
+ $extendedInterfaces[] = $targetInterface;
+
+ $traversableFound = false;
+ $iteratorShiftedToFront = false;
+ foreach ($extendedInterfaces as $interface) {
+ if (!$traversableFound && preg_match("/^\\?Iterator(|Aggregate)$/i", $interface)) {
+ break;
+ }
+
+ if (preg_match("/^\\\\?IteratorAggregate$/i", $interface)) {
+ $this->targetInterfaces[] = DefinedTargetClass::factory("\\IteratorAggregate");
+ $iteratorShiftedToFront = true;
+ } elseif (preg_match("/^\\\\?Iterator$/i", $interface)) {
+ $this->targetInterfaces[] = DefinedTargetClass::factory("\\Iterator");
+ $iteratorShiftedToFront = true;
+ } elseif (preg_match("/^\\\\?Traversable$/i", $interface)) {
+ $traversableFound = true;
+ }
+ }
+
+ if ($traversableFound && !$iteratorShiftedToFront) {
+ $this->targetInterfaces[] = DefinedTargetClass::factory("\\IteratorAggregate");
+ }
+
+ /**
+ * We never straight up implement Traversable
+ */
+ if (!preg_match("/^\\\\?Traversable$/i", $targetInterface)) {
+ $this->targetInterfaces[] = $dtc;
+ }
+ }
+ $this->targetInterfaces = array_unique($this->targetInterfaces); // just in case
+ return $this->targetInterfaces;
+ }
+
+ public function getTargetObject()
+ {
+ return $this->targetObject;
+ }
+
+ public function getName()
+ {
+ return $this->name;
+ }
+
+ /**
+ * Generate a suitable name based on the config
+ */
+ public function generateName()
+ {
+ $name = 'Mockery_' . static::$mockCounter++;
+
+ if ($this->getTargetObject()) {
+ $name .= "_" . str_replace("\\", "_", get_class($this->getTargetObject()));
+ }
+
+ if ($this->getTargetClass()) {
+ $name .= "_" . str_replace("\\", "_", $this->getTargetClass()->getName());
+ }
+
+ if ($this->getTargetInterfaces()) {
+ $name .= array_reduce($this->getTargetInterfaces(), function ($tmpname, $i) {
+ $tmpname .= '_' . str_replace("\\", "_", $i->getName());
+ return $tmpname;
+ }, '');
+ }
+
+ return $name;
+ }
+
+ public function getShortName()
+ {
+ $parts = explode("\\", $this->getName());
+ return array_pop($parts);
+ }
+
+ public function getNamespaceName()
+ {
+ $parts = explode("\\", $this->getName());
+ array_pop($parts);
+
+ if (count($parts)) {
+ return implode("\\", $parts);
+ }
+
+ return "";
+ }
+
+ public function getBlackListedMethods()
+ {
+ return $this->blackListedMethods;
+ }
+
+ public function getWhiteListedMethods()
+ {
+ return $this->whiteListedMethods;
+ }
+
+ public function isInstanceMock()
+ {
+ return $this->instanceMock;
+ }
+
+ public function getParameterOverrides()
+ {
+ return $this->parameterOverrides;
+ }
+
+ protected function setTargetClassName($targetClassName)
+ {
+ $this->targetClassName = $targetClassName;
+ }
+
+ protected function getAllMethods()
+ {
+ if ($this->allMethods) {
+ return $this->allMethods;
+ }
+
+ $classes = $this->getTargetInterfaces();
+
+ if ($this->getTargetClass()) {
+ $classes[] = $this->getTargetClass();
+ }
+
+ $methods = array();
+ foreach ($classes as $class) {
+ $methods = array_merge($methods, $class->getMethods());
+ }
+
+ $names = array();
+ $methods = array_filter($methods, function ($method) use (&$names) {
+ if (in_array($method->getName(), $names)) {
+ return false;
+ }
+
+ $names[] = $method->getName();
+ return true;
+ });
+
+ return $this->allMethods = $methods;
+ }
+
+ /**
+ * If we attempt to implement Traversable, we must ensure we are also
+ * implementing either Iterator or IteratorAggregate, and that whichever one
+ * it is comes before Traversable in the list of implements.
+ */
+ protected function addTargetInterfaceName($targetInterface)
+ {
+ $this->targetInterfaceNames[] = $targetInterface;
+ }
+
+
+ protected function setTargetObject($object)
+ {
+ $this->targetObject = $object;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/MockConfigurationBuilder.php b/vendor/mockery/mockery/library/Mockery/Generator/MockConfigurationBuilder.php
new file mode 100644
index 000000000..1a7512e73
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/MockConfigurationBuilder.php
@@ -0,0 +1,124 @@
+targets[] = $target;
+
+ return $this;
+ }
+
+ public function addTargets($targets)
+ {
+ foreach ($targets as $target) {
+ $this->addTarget($target);
+ }
+
+ return $this;
+ }
+
+ public function setName($name)
+ {
+ $this->name = $name;
+ return $this;
+ }
+
+ public function addBlackListedMethod($blackListedMethod)
+ {
+ $this->blackListedMethods[] = $blackListedMethod;
+ return $this;
+ }
+
+ public function addBlackListedMethods(array $blackListedMethods)
+ {
+ foreach ($blackListedMethods as $method) {
+ $this->addBlackListedMethod($method);
+ }
+ return $this;
+ }
+
+ public function setBlackListedMethods(array $blackListedMethods)
+ {
+ $this->blackListedMethods = $blackListedMethods;
+ return $this;
+ }
+
+ public function addWhiteListedMethod($whiteListedMethod)
+ {
+ $this->whiteListedMethods[] = $whiteListedMethod;
+ return $this;
+ }
+
+ public function addWhiteListedMethods(array $whiteListedMethods)
+ {
+ foreach ($whiteListedMethods as $method) {
+ $this->addWhiteListedMethod($method);
+ }
+ return $this;
+ }
+
+ public function setWhiteListedMethods(array $whiteListedMethods)
+ {
+ $this->whiteListedMethods = $whiteListedMethods;
+ return $this;
+ }
+
+ public function setInstanceMock($instanceMock)
+ {
+ $this->instanceMock = (bool) $instanceMock;
+ }
+
+ public function setParameterOverrides(array $overrides)
+ {
+ $this->parameterOverrides = $overrides;
+ }
+
+ public function getMockConfiguration()
+ {
+ return new MockConfiguration(
+ $this->targets,
+ $this->blackListedMethods,
+ $this->whiteListedMethods,
+ $this->name,
+ $this->instanceMock,
+ $this->parameterOverrides
+ );
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/MockDefinition.php b/vendor/mockery/mockery/library/Mockery/Generator/MockDefinition.php
new file mode 100644
index 000000000..29c8e207c
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/MockDefinition.php
@@ -0,0 +1,33 @@
+getName()) {
+ throw new \InvalidArgumentException("MockConfiguration must contain a name");
+ }
+ $this->config = $config;
+ $this->code = $code;
+ }
+
+ public function getConfig()
+ {
+ return $this->config;
+ }
+
+ public function getClassName()
+ {
+ return $this->config->getName();
+ }
+
+ public function getCode()
+ {
+ return $this->code;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/Parameter.php b/vendor/mockery/mockery/library/Mockery/Generator/Parameter.php
new file mode 100644
index 000000000..4e08710b4
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/Parameter.php
@@ -0,0 +1,101 @@
+rfp = $rfp;
+ }
+
+ public function __call($method, array $args)
+ {
+ return call_user_func_array(array($this->rfp, $method), $args);
+ }
+
+ public function getClass()
+ {
+ return new DefinedTargetClass($this->rfp->getClass());
+ }
+
+ public function getTypeHintAsString()
+ {
+ if (method_exists($this->rfp, 'getTypehintText')) {
+ // Available in HHVM
+ $typehint = $this->rfp->getTypehintText();
+
+ // not exhaustive, but will do for now
+ if (in_array($typehint, array('int', 'integer', 'float', 'string', 'bool', 'boolean'))) {
+ return '';
+ }
+
+ return $typehint;
+ }
+
+ if ($this->rfp->isArray()) {
+ return 'array';
+ }
+
+ /*
+ * PHP < 5.4.1 has some strange behaviour with a typehint of self and
+ * subclass signatures, so we risk the regexp instead
+ */
+ if ((version_compare(PHP_VERSION, '5.4.1') >= 0)) {
+ try {
+ if ($this->rfp->getClass()) {
+ return $this->getOptionalSign() . $this->rfp->getClass()->getName();
+ }
+ } catch (\ReflectionException $re) {
+ // noop
+ }
+ }
+
+ if (version_compare(PHP_VERSION, '7.0.0-dev') >= 0 && $this->rfp->hasType()) {
+ return $this->getOptionalSign() . $this->rfp->getType();
+ }
+
+ if (preg_match('/^Parameter #[0-9]+ \[ \<(required|optional)\> (?\S+ )?.*\$' . $this->rfp->getName() . ' .*\]$/', $this->rfp->__toString(), $typehintMatch)) {
+ if (!empty($typehintMatch['typehint'])) {
+ return $typehintMatch['typehint'];
+ }
+ }
+
+ return '';
+ }
+
+ private function getOptionalSign()
+ {
+ if (version_compare(PHP_VERSION, '7.1.0-dev', '>=') && $this->rfp->allowsNull() && !$this->rfp->isVariadic()) {
+ return '?';
+ }
+
+ return '';
+ }
+
+ /**
+ * Some internal classes have funny looking definitions...
+ */
+ public function getName()
+ {
+ $name = $this->rfp->getName();
+ if (!$name || $name == '...') {
+ $name = 'arg' . static::$parameterCounter++;
+ }
+
+ return $name;
+ }
+
+
+ /**
+ * Variadics only introduced in 5.6
+ */
+ public function isVariadic()
+ {
+ return version_compare(PHP_VERSION, '5.6.0') >= 0 && $this->rfp->isVariadic();
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/CallTypeHintPass.php b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/CallTypeHintPass.php
new file mode 100644
index 000000000..4341486a0
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/CallTypeHintPass.php
@@ -0,0 +1,29 @@
+requiresCallTypeHintRemoval()) {
+ $code = str_replace(
+ 'public function __call($method, array $args)',
+ 'public function __call($method, $args)',
+ $code
+ );
+ }
+
+ if ($config->requiresCallStaticTypeHintRemoval()) {
+ $code = str_replace(
+ 'public static function __callStatic($method, array $args)',
+ 'public static function __callStatic($method, $args)',
+ $code
+ );
+ }
+
+ return $code;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassNamePass.php b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassNamePass.php
new file mode 100644
index 000000000..d8ec67fad
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassNamePass.php
@@ -0,0 +1,31 @@
+getNamespaceName();
+
+ $namespace = ltrim($namespace, "\\");
+
+ $className = $config->getShortName();
+
+ $code = str_replace(
+ 'namespace Mockery;',
+ $namespace ? 'namespace ' . $namespace . ';' : '',
+ $code
+ );
+
+ $code = str_replace(
+ 'class Mock',
+ 'class ' . $className,
+ $code
+ );
+
+ return $code;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassPass.php b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassPass.php
new file mode 100644
index 000000000..b1a975040
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/ClassPass.php
@@ -0,0 +1,50 @@
+getTargetClass();
+
+ if (!$target) {
+ return $code;
+ }
+
+ if ($target->isFinal()) {
+ return $code;
+ }
+
+ $className = ltrim($target->getName(), "\\");
+ if (!class_exists($className)) {
+ $targetCode = 'inNamespace()) {
+ $targetCode.= 'namespace ' . $target->getNamespaceName(). '; ';
+ }
+
+ $targetCode.= 'class ' . $target->getShortName() . ' {} ';
+
+ /*
+ * We could eval here, but it doesn't play well with the way
+ * PHPUnit tries to backup global state and the require definition
+ * loader
+ */
+ $tmpfname = tempnam(sys_get_temp_dir(), "Mockery");
+ file_put_contents($tmpfname, $targetCode);
+ require $tmpfname;
+ \Mockery::registerFileForCleanUp($tmpfname);
+ }
+
+ $code = str_replace(
+ "implements MockInterface",
+ "extends \\" . $className . " implements MockInterface",
+ $code
+ );
+
+ return $code;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InstanceMockPass.php b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InstanceMockPass.php
new file mode 100644
index 000000000..e3bbf7dd4
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InstanceMockPass.php
@@ -0,0 +1,57 @@
+_mockery_ignoreVerification = false;
+ \$associatedRealObject = \Mockery::fetchMock(__CLASS__);
+
+ foreach (get_object_vars(\$this) as \$attr => \$val) {
+ if (\$attr !== "_mockery_ignoreVerification" && \$attr !== "_mockery_expectations") {
+ \$this->\$attr = \$associatedRealObject->\$attr;
+ }
+ }
+
+ \$directors = \$associatedRealObject->mockery_getExpectations();
+ foreach (\$directors as \$method=>\$director) {
+ \$expectations = \$director->getExpectations();
+ // get the director method needed
+ \$existingDirector = \$this->mockery_getExpectationsFor(\$method);
+ if (!\$existingDirector) {
+ \$existingDirector = new \Mockery\ExpectationDirector(\$method, \$this);
+ \$this->mockery_setExpectationsFor(\$method, \$existingDirector);
+ }
+ foreach (\$expectations as \$expectation) {
+ \$clonedExpectation = clone \$expectation;
+ \$existingDirector->addExpectation(\$clonedExpectation);
+ }
+ }
+ \Mockery::getContainer()->rememberMock(\$this);
+ }
+MOCK;
+
+ public function apply($code, MockConfiguration $config)
+ {
+ if ($config->isInstanceMock()) {
+ $code = $this->appendToClass($code, static::INSTANCE_MOCK_CODE);
+ }
+
+ return $code;
+ }
+
+ protected function appendToClass($class, $code)
+ {
+ $lastBrace = strrpos($class, "}");
+ $class = substr($class, 0, $lastBrace) . $code . "\n }\n";
+ return $class;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InterfacePass.php b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InterfacePass.php
new file mode 100644
index 000000000..152c7363a
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/InterfacePass.php
@@ -0,0 +1,23 @@
+getTargetInterfaces(), function ($code, $i) {
+ return $code . ", \\" . $i->getName();
+ }, "");
+
+ $code = str_replace(
+ "implements MockInterface",
+ "implements MockInterface" . $interfaces,
+ $code
+ );
+
+ return $code;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/MethodDefinitionPass.php b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/MethodDefinitionPass.php
new file mode 100644
index 000000000..8b8762969
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/MethodDefinitionPass.php
@@ -0,0 +1,155 @@
+getMethodsToMock() as $method) {
+ if ($method->isPublic()) {
+ $methodDef = 'public';
+ } elseif ($method->isProtected()) {
+ $methodDef = 'protected';
+ } else {
+ $methodDef = 'private';
+ }
+
+ if ($method->isStatic()) {
+ $methodDef .= ' static';
+ }
+
+ $methodDef .= ' function ';
+ $methodDef .= $method->returnsReference() ? ' & ' : '';
+ $methodDef .= $method->getName();
+ $methodDef .= $this->renderParams($method, $config);
+ $methodDef .= $this->renderReturnType($method);
+ $methodDef .= $this->renderMethodBody($method, $config);
+
+ $code = $this->appendToClass($code, $methodDef);
+ }
+
+ return $code;
+ }
+
+ protected function renderParams(Method $method, $config)
+ {
+ $class = $method->getDeclaringClass();
+ if ($class->isInternal()) {
+ $overrides = $config->getParameterOverrides();
+
+ if (isset($overrides[strtolower($class->getName())][$method->getName()])) {
+ return '(' . implode(',', $overrides[strtolower($class->getName())][$method->getName()]) . ')';
+ }
+ }
+
+ $methodParams = array();
+ $params = $method->getParameters();
+ foreach ($params as $param) {
+ $paramDef = $param->getTypeHintAsString();
+ $paramDef .= $param->isPassedByReference() ? '&' : '';
+ $paramDef .= $param->isVariadic() ? '...' : '';
+ $paramDef .= '$' . $param->getName();
+
+ if (!$param->isVariadic()) {
+ if (false !== $param->isDefaultValueAvailable()) {
+ $paramDef .= ' = ' . var_export($param->getDefaultValue(), true);
+ } elseif ($param->isOptional()) {
+ $paramDef .= ' = null';
+ }
+ }
+
+ $methodParams[] = $paramDef;
+ }
+ return '(' . implode(', ', $methodParams) . ')';
+ }
+
+ protected function renderReturnType(Method $method)
+ {
+ $type = $method->getReturnType();
+ return $type ? sprintf(': %s', $type) : '';
+ }
+
+ protected function appendToClass($class, $code)
+ {
+ $lastBrace = strrpos($class, "}");
+ $class = substr($class, 0, $lastBrace) . $code . "\n }\n";
+ return $class;
+ }
+
+ private function renderMethodBody($method, $config)
+ {
+ /** @var \ReflectionMethod $method */
+ $invoke = $method->isStatic() ? 'static::_mockery_handleStaticMethodCall' : '$this->_mockery_handleMethodCall';
+ $body = <<getDeclaringClass();
+ $class_name = strtolower($class->getName());
+ $overrides = $config->getParameterOverrides();
+ if (isset($overrides[$class_name][$method->getName()])) {
+ $params = array_values($overrides[$class_name][$method->getName()]);
+ $paramCount = count($params);
+ for ($i = 0; $i < $paramCount; ++$i) {
+ $param = $params[$i];
+ if (strpos($param, '&') !== false) {
+ if (($stripDefaultValue = strpos($param, '=')) !== false) {
+ $param = trim(substr($param, 0, $stripDefaultValue));
+ }
+ $body .= << $i) {
+ \$argv[$i] = {$param};
+}
+
+BODY;
+ }
+ }
+ } else {
+ /** @var \ReflectionParameter[] $params */
+ $params = array_values($method->getParameters());
+ $paramCount = count($params);
+ for ($i = 0; $i < $paramCount; ++$i) {
+ $param = $params[$i];
+ if (!$param->isPassedByReference()) {
+ continue;
+ }
+ $body .= << $i) {
+ \$argv[$i] =& \${$param->getName()};
+}
+
+BODY;
+ }
+ }
+
+ $body .= $this->getReturnStatement($method, $invoke);
+
+ return $body;
+ }
+
+ private function getReturnStatement($method, $invoke)
+ {
+ if ($method->getReturnType() === 'void') {
+ return << '/public function __wakeup\(\)\s+\{.*?\}/sm',
+ );
+
+ public function apply($code, MockConfiguration $config)
+ {
+ $target = $config->getTargetClass();
+
+ if (!$target) {
+ return $code;
+ }
+
+ foreach ($target->getMethods() as $method) {
+ if ($method->isFinal() && isset($this->methods[$method->getName()])) {
+ $code = preg_replace($this->methods[$method->getName()], '', $code);
+ }
+ }
+
+ return $code;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/RemoveUnserializeForInternalSerializableClassesPass.php b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/RemoveUnserializeForInternalSerializableClassesPass.php
new file mode 100644
index 000000000..ea73180b3
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulation/Pass/RemoveUnserializeForInternalSerializableClassesPass.php
@@ -0,0 +1,40 @@
+getTargetClass();
+
+ if (!$target) {
+ return $code;
+ }
+
+ if (!$target->hasInternalAncestor() || !$target->implementsInterface("Serializable")) {
+ return $code;
+ }
+
+ $code = $this->appendToClass($code, self::DUMMY_METHOD_DEFINITION);
+
+ return $code;
+ }
+
+ protected function appendToClass($class, $code)
+ {
+ $lastBrace = strrpos($class, "}");
+ $class = substr($class, 0, $lastBrace) . $code . "\n }\n";
+ return $class;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/StringManipulationGenerator.php b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulationGenerator.php
new file mode 100644
index 000000000..cbed92243
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/StringManipulationGenerator.php
@@ -0,0 +1,34 @@
+passes = $passes;
+ }
+
+ public function generate(MockConfiguration $config)
+ {
+ $code = file_get_contents(__DIR__ . '/../Mock.php');
+ $className = $config->getName() ?: $config->generateName();
+
+ $namedConfig = $config->rename($className);
+
+ foreach ($this->passes as $pass) {
+ $code = $pass->apply($code, $namedConfig);
+ }
+
+ return new MockDefinition($namedConfig, $code);
+ }
+
+ public function addPass(Pass $pass)
+ {
+ $this->passes[] = $pass;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Generator/TargetClass.php b/vendor/mockery/mockery/library/Mockery/Generator/TargetClass.php
new file mode 100644
index 000000000..46dc198f6
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Generator/TargetClass.php
@@ -0,0 +1,33 @@
+name = $name;
+ }
+
+ public function getName()
+ {
+ return $this->name;
+ }
+
+ public function isAbstract()
+ {
+ return false;
+ }
+
+ public function isFinal()
+ {
+ return false;
+ }
+
+ public function getMethods()
+ {
+ return array();
+ }
+
+ public function getNamespaceName()
+ {
+ $parts = explode("\\", ltrim($this->getName(), "\\"));
+ array_pop($parts);
+ return implode("\\", $parts);
+ }
+
+ public function inNamespace()
+ {
+ return $this->getNamespaceName() !== '';
+ }
+
+ public function getShortName()
+ {
+ $parts = explode("\\", $this->getName());
+ return array_pop($parts);
+ }
+
+ public function implementsInterface($interface)
+ {
+ return false;
+ }
+
+ public function hasInternalAncestor()
+ {
+ return false;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Instantiator.php b/vendor/mockery/mockery/library/Mockery/Instantiator.php
new file mode 100644
index 000000000..f396fd8ca
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Instantiator.php
@@ -0,0 +1,214 @@
+.
+ */
+
+namespace Mockery;
+
+use Closure;
+use ReflectionClass;
+use UnexpectedValueException;
+use InvalidArgumentException;
+
+/**
+ * This is a trimmed down version of https://github.com/doctrine/instantiator,
+ * basically without the caching
+ *
+ * @author Marco Pivetta
+ */
+final class Instantiator
+{
+ /**
+ * Markers used internally by PHP to define whether {@see \unserialize} should invoke
+ * the method {@see \Serializable::unserialize()} when dealing with classes implementing
+ * the {@see \Serializable} interface.
+ */
+ const SERIALIZATION_FORMAT_USE_UNSERIALIZER = 'C';
+ const SERIALIZATION_FORMAT_AVOID_UNSERIALIZER = 'O';
+
+ /**
+ * {@inheritDoc}
+ */
+ public function instantiate($className)
+ {
+ $factory = $this->buildFactory($className);
+ $instance = $factory();
+ $reflection = new ReflectionClass($instance);
+
+ return $instance;
+ }
+
+ /**
+ * @internal
+ * @private
+ *
+ * Builds a {@see \Closure} capable of instantiating the given $className without
+ * invoking its constructor.
+ * This method is only exposed as public because of PHP 5.3 compatibility. Do not
+ * use this method in your own code
+ *
+ * @param string $className
+ *
+ * @return Closure
+ */
+ public function buildFactory($className)
+ {
+ $reflectionClass = $this->getReflectionClass($className);
+
+ if ($this->isInstantiableViaReflection($reflectionClass)) {
+ return function () use ($reflectionClass) {
+ return $reflectionClass->newInstanceWithoutConstructor();
+ };
+ }
+
+ $serializedString = sprintf(
+ '%s:%d:"%s":0:{}',
+ $this->getSerializationFormat($reflectionClass),
+ strlen($className),
+ $className
+ );
+
+ $this->attemptInstantiationViaUnSerialization($reflectionClass, $serializedString);
+
+ return function () use ($serializedString) {
+ return unserialize($serializedString);
+ };
+ }
+
+ /**
+ * @param string $className
+ *
+ * @return ReflectionClass
+ *
+ * @throws InvalidArgumentException
+ */
+ private function getReflectionClass($className)
+ {
+ if (! class_exists($className)) {
+ throw new InvalidArgumentException("Class:$className does not exist");
+ }
+
+ $reflection = new ReflectionClass($className);
+
+ if ($reflection->isAbstract()) {
+ throw new InvalidArgumentException("Class:$className is an abstract class");
+ }
+
+ return $reflection;
+ }
+
+ /**
+ * @param ReflectionClass $reflectionClass
+ * @param string $serializedString
+ *
+ * @throws UnexpectedValueException
+ *
+ * @return void
+ */
+ private function attemptInstantiationViaUnSerialization(ReflectionClass $reflectionClass, $serializedString)
+ {
+ set_error_handler(function ($code, $message, $file, $line) use ($reflectionClass, & $error) {
+ $msg = sprintf(
+ 'Could not produce an instance of "%s" via un-serialization, since an error was triggered in file "%s" at line "%d"',
+ $reflectionClass->getName(),
+ $file,
+ $line
+ );
+
+ $error = new UnexpectedValueException($msg, 0, new \Exception($message, $code));
+ });
+
+ try {
+ unserialize($serializedString);
+ } catch (\Exception $exception) {
+ restore_error_handler();
+
+ throw new UnexpectedValueException("An exception was raised while trying to instantiate an instance of \"{$reflectionClass->getName()}\" via un-serialization", 0, $exception);
+ }
+
+ restore_error_handler();
+
+ if ($error) {
+ throw $error;
+ }
+ }
+
+ /**
+ * @param ReflectionClass $reflectionClass
+ *
+ * @return bool
+ */
+ private function isInstantiableViaReflection(ReflectionClass $reflectionClass)
+ {
+ if (\PHP_VERSION_ID >= 50600) {
+ return ! ($reflectionClass->isInternal() && $reflectionClass->isFinal());
+ }
+
+ return \PHP_VERSION_ID >= 50400 && ! $this->hasInternalAncestors($reflectionClass);
+ }
+
+ /**
+ * Verifies whether the given class is to be considered internal
+ *
+ * @param ReflectionClass $reflectionClass
+ *
+ * @return bool
+ */
+ private function hasInternalAncestors(ReflectionClass $reflectionClass)
+ {
+ do {
+ if ($reflectionClass->isInternal()) {
+ return true;
+ }
+ } while ($reflectionClass = $reflectionClass->getParentClass());
+
+ return false;
+ }
+
+ /**
+ * Verifies if the given PHP version implements the `Serializable` interface serialization
+ * with an incompatible serialization format. If that's the case, use serialization marker
+ * "C" instead of "O".
+ *
+ * @link http://news.php.net/php.internals/74654
+ *
+ * @param ReflectionClass $reflectionClass
+ *
+ * @return string the serialization format marker, either self::SERIALIZATION_FORMAT_USE_UNSERIALIZER
+ * or self::SERIALIZATION_FORMAT_AVOID_UNSERIALIZER
+ */
+ private function getSerializationFormat(ReflectionClass $reflectionClass)
+ {
+ if ($this->isPhpVersionWithBrokenSerializationFormat()
+ && $reflectionClass->implementsInterface('Serializable')
+ ) {
+ return self::SERIALIZATION_FORMAT_USE_UNSERIALIZER;
+ }
+
+ return self::SERIALIZATION_FORMAT_AVOID_UNSERIALIZER;
+ }
+
+ /**
+ * Checks whether the current PHP runtime uses an incompatible serialization format
+ *
+ * @return bool
+ */
+ private function isPhpVersionWithBrokenSerializationFormat()
+ {
+ return PHP_VERSION_ID === 50429 || PHP_VERSION_ID === 50513;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Loader.php b/vendor/mockery/mockery/library/Mockery/Loader.php
new file mode 100644
index 000000000..1afa86076
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Loader.php
@@ -0,0 +1,155 @@
+register();
+ *
+ * @author Jonathan H. Wage
+ * @author Roman S. Borschel
+ * @author Matthew Weier O'Phinney
+ * @author Kris Wallsmith
+ * @author Fabien Potencier
+ */
+
+namespace Mockery;
+
+class Loader
+{
+ private $_fileExtension = '.php';
+ private $_namespace;
+ private $_includePath;
+ private $_namespaceSeparator = '\\';
+
+ /**
+ * Creates a new Loader that loads classes of the
+ * specified namespace.
+ *
+ * @param string $ns The namespace to use.
+ */
+ public function __construct($ns = 'Mockery', $includePath = null)
+ {
+ $this->_namespace = $ns;
+ $this->_includePath = $includePath;
+ }
+
+ /**
+ * Sets the namespace separator used by classes in the namespace of this class loader.
+ *
+ * @param string $sep The separator to use.
+ */
+ public function setNamespaceSeparator($sep)
+ {
+ $this->_namespaceSeparator = $sep;
+ }
+
+ /**
+ * Gets the namespace seperator used by classes in the namespace of this class loader.
+ *
+ * @return void
+ */
+ public function getNamespaceSeparator()
+ {
+ return $this->_namespaceSeparator;
+ }
+
+ /**
+ * Sets the base include path for all class files in the namespace of this class loader.
+ *
+ * @param string $includePath
+ */
+ public function setIncludePath($includePath)
+ {
+ $this->_includePath = $includePath;
+ }
+
+ /**
+ * Gets the base include path for all class files in the namespace of this class loader.
+ *
+ * @return string $includePath
+ */
+ public function getIncludePath()
+ {
+ return $this->_includePath;
+ }
+
+ /**
+ * Sets the file extension of class files in the namespace of this class loader.
+ *
+ * @param string $fileExtension
+ */
+ public function setFileExtension($fileExtension)
+ {
+ $this->_fileExtension = $fileExtension;
+ }
+
+ /**
+ * Gets the file extension of class files in the namespace of this class loader.
+ *
+ * @return string $fileExtension
+ */
+ public function getFileExtension()
+ {
+ return $this->_fileExtension;
+ }
+
+ /**
+ * Installs this class loader on the SPL autoload stack.
+ *
+ * @param bool $prepend If true, prepend autoloader on the autoload stack
+ */
+ public function register($prepend = false)
+ {
+ spl_autoload_register(array($this, 'loadClass'), true, $prepend);
+ }
+
+ /**
+ * Uninstalls this class loader from the SPL autoloader stack.
+ */
+ public function unregister()
+ {
+ spl_autoload_unregister(array($this, 'loadClass'));
+ }
+
+ /**
+ * Loads the given class or interface.
+ *
+ * @param string $className The name of the class to load.
+ * @return void
+ */
+ public function loadClass($className)
+ {
+ if ($className === 'Mockery') {
+ require $this->getFullPath('Mockery.php');
+ return;
+ }
+ if (null === $this->_namespace
+ || $this->_namespace.$this->_namespaceSeparator === substr($className, 0, strlen($this->_namespace.$this->_namespaceSeparator))) {
+ $fileName = '';
+ $namespace = '';
+ if (false !== ($lastNsPos = strripos($className, $this->_namespaceSeparator))) {
+ $namespace = substr($className, 0, $lastNsPos);
+ $className = substr($className, $lastNsPos + 1);
+ $fileName = str_replace($this->_namespaceSeparator, DIRECTORY_SEPARATOR, $namespace) . DIRECTORY_SEPARATOR;
+ }
+ $fileName .= str_replace('_', DIRECTORY_SEPARATOR, $className) . $this->_fileExtension;
+ require $this->getFullPath($fileName);
+ }
+ }
+
+ /**
+ * Returns full path for $fileName if _includePath is set, or leaves as-is for PHP's internal search in 'require'.
+ *
+ * @param string $fileName relative to include path.
+ * @return string
+ */
+ private function getFullPath($fileName)
+ {
+ return ($this->_includePath !== null ? $this->_includePath . DIRECTORY_SEPARATOR : '') . $fileName;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Loader/EvalLoader.php b/vendor/mockery/mockery/library/Mockery/Loader/EvalLoader.php
new file mode 100644
index 000000000..b9d172afd
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Loader/EvalLoader.php
@@ -0,0 +1,18 @@
+getClassName(), false)) {
+ return;
+ }
+
+ eval("?>" . $definition->getCode());
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Loader/Loader.php b/vendor/mockery/mockery/library/Mockery/Loader/Loader.php
new file mode 100644
index 000000000..d74018173
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Loader/Loader.php
@@ -0,0 +1,10 @@
+path = $path;
+ }
+
+ public function load(MockDefinition $definition)
+ {
+ if (class_exists($definition->getClassName(), false)) {
+ return;
+ }
+
+ $tmpfname = tempnam($this->path, "Mockery");
+ file_put_contents($tmpfname, $definition->getCode());
+
+ require $tmpfname;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/Any.php b/vendor/mockery/mockery/library/Mockery/Matcher/Any.php
new file mode 100644
index 000000000..7b145457f
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/Any.php
@@ -0,0 +1,46 @@
+';
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/AnyOf.php b/vendor/mockery/mockery/library/Mockery/Matcher/AnyOf.php
new file mode 100644
index 000000000..e95daafb8
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/AnyOf.php
@@ -0,0 +1,51 @@
+_expected as $exp) {
+ if ($actual === $exp || $actual == $exp) {
+ return true;
+ }
+ }
+ return false;
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return '';
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/Closure.php b/vendor/mockery/mockery/library/Mockery/Matcher/Closure.php
new file mode 100644
index 000000000..145f44b2a
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/Closure.php
@@ -0,0 +1,48 @@
+_expected;
+ $result = $closure($actual);
+ return $result === true;
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return '';
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/Contains.php b/vendor/mockery/mockery/library/Mockery/Matcher/Contains.php
new file mode 100644
index 000000000..649987d5a
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/Contains.php
@@ -0,0 +1,65 @@
+_expected as $exp) {
+ $match = false;
+ foreach ($values as $val) {
+ if ($exp === $val || $exp == $val) {
+ $match = true;
+ break;
+ }
+ }
+ if ($match === false) {
+ return false;
+ }
+ }
+ return true;
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ $return = '_expected as $v) {
+ $elements[] = (string) $v;
+ }
+ $return .= implode(', ', $elements) . ']>';
+ return $return;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/Ducktype.php b/vendor/mockery/mockery/library/Mockery/Matcher/Ducktype.php
new file mode 100644
index 000000000..93d8ab150
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/Ducktype.php
@@ -0,0 +1,54 @@
+_expected as $method) {
+ if (!method_exists($actual, $method)) {
+ return false;
+ }
+ }
+ return true;
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return '_expected) . ']>';
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/HasKey.php b/vendor/mockery/mockery/library/Mockery/Matcher/HasKey.php
new file mode 100644
index 000000000..ecad4e53e
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/HasKey.php
@@ -0,0 +1,47 @@
+_expected, array_keys($actual));
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ $return = '_expected . ']>';
+ return $return;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/HasValue.php b/vendor/mockery/mockery/library/Mockery/Matcher/HasValue.php
new file mode 100644
index 000000000..2d7edff06
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/HasValue.php
@@ -0,0 +1,47 @@
+_expected, $actual);
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ $return = '_expected . ']>';
+ return $return;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/MatcherAbstract.php b/vendor/mockery/mockery/library/Mockery/Matcher/MatcherAbstract.php
new file mode 100644
index 000000000..14903b64d
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/MatcherAbstract.php
@@ -0,0 +1,59 @@
+_expected = $expected;
+ }
+
+ /**
+ * Check if the actual value matches the expected.
+ * Actual passed by reference to preserve reference trail (where applicable)
+ * back to the original method parameter.
+ *
+ * @param mixed $actual
+ * @return bool
+ */
+ abstract public function match(&$actual);
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ abstract public function __toString();
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/MustBe.php b/vendor/mockery/mockery/library/Mockery/Matcher/MustBe.php
new file mode 100644
index 000000000..f5b3aeed4
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/MustBe.php
@@ -0,0 +1,50 @@
+_expected === $actual;
+ } else {
+ return $this->_expected == $actual;
+ }
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return '';
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/Not.php b/vendor/mockery/mockery/library/Mockery/Matcher/Not.php
new file mode 100644
index 000000000..375d1baf7
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/Not.php
@@ -0,0 +1,47 @@
+_expected;
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return '';
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/NotAnyOf.php b/vendor/mockery/mockery/library/Mockery/Matcher/NotAnyOf.php
new file mode 100644
index 000000000..cbc2c4293
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/NotAnyOf.php
@@ -0,0 +1,51 @@
+_expected as $exp) {
+ if ($actual === $exp || $actual == $exp) {
+ return false;
+ }
+ }
+ return true;
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return '';
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/Subset.php b/vendor/mockery/mockery/library/Mockery/Matcher/Subset.php
new file mode 100644
index 000000000..3b8ae30d9
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/Subset.php
@@ -0,0 +1,60 @@
+_expected as $k=>$v) {
+ if (!array_key_exists($k, $actual)) {
+ return false;
+ }
+ if ($actual[$k] !== $v) {
+ return false;
+ }
+ }
+ return true;
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ $return = '_expected as $k=>$v) {
+ $elements[] = $k . '=' . (string) $v;
+ }
+ $return .= implode(', ', $elements) . ']>';
+ return $return;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Matcher/Type.php b/vendor/mockery/mockery/library/Mockery/Matcher/Type.php
new file mode 100644
index 000000000..cc3bf9a63
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Matcher/Type.php
@@ -0,0 +1,53 @@
+_expected);
+ if (function_exists($function)) {
+ return $function($actual);
+ } elseif (is_string($this->_expected)
+ && (class_exists($this->_expected) || interface_exists($this->_expected))) {
+ return $actual instanceof $this->_expected;
+ }
+ return false;
+ }
+
+ /**
+ * Return a string representation of this Matcher
+ *
+ * @return string
+ */
+ public function __toString()
+ {
+ return '<' . ucfirst($this->_expected) . '>';
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/MethodCall.php b/vendor/mockery/mockery/library/Mockery/MethodCall.php
new file mode 100644
index 000000000..bc79b5f40
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/MethodCall.php
@@ -0,0 +1,25 @@
+method = $method;
+ $this->args = $args;
+ }
+
+ public function getMethod()
+ {
+ return $this->method;
+ }
+
+ public function getArgs()
+ {
+ return $this->args;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Mock.php b/vendor/mockery/mockery/library/Mockery/Mock.php
new file mode 100644
index 000000000..c1875211f
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Mock.php
@@ -0,0 +1,758 @@
+_mockery_container = $container;
+ if (!is_null($partialObject)) {
+ $this->_mockery_partial = $partialObject;
+ }
+
+ if (!\Mockery::getConfiguration()->mockingNonExistentMethodsAllowed()) {
+ foreach ($this->mockery_getMethods() as $method) {
+ if ($method->isPublic() && !$method->isStatic()) {
+ $this->_mockery_mockableMethods[] = $method->getName();
+ }
+ }
+ }
+ }
+
+ /**
+ * Set expected method calls
+ *
+ * @param mixed
+ * @return \Mockery\Expectation
+ */
+ public function shouldReceive()
+ {
+ /** @var array $nonPublicMethods */
+ $nonPublicMethods = $this->getNonPublicMethods();
+
+ $self = $this;
+ $allowMockingProtectedMethods = $this->_mockery_allowMockingProtectedMethods;
+
+ $lastExpectation = \Mockery::parseShouldReturnArgs(
+ $this, func_get_args(), function ($method) use ($self, $nonPublicMethods, $allowMockingProtectedMethods) {
+ $rm = $self->mockery_getMethod($method);
+ if ($rm) {
+ if ($rm->isPrivate()) {
+ throw new \InvalidArgumentException("$method() cannot be mocked as it is a private method");
+ }
+ if (!$allowMockingProtectedMethods && $rm->isProtected()) {
+ throw new \InvalidArgumentException("$method() cannot be mocked as it a protected method and mocking protected methods is not allowed for this mock");
+ }
+ }
+
+ $director = $self->mockery_getExpectationsFor($method);
+ if (!$director) {
+ $director = new \Mockery\ExpectationDirector($method, $self);
+ $self->mockery_setExpectationsFor($method, $director);
+ }
+ $expectation = new \Mockery\Expectation($self, $method);
+ $director->addExpectation($expectation);
+ return $expectation;
+ }
+ );
+ return $lastExpectation;
+ }
+
+ /**
+ * Shortcut method for setting an expectation that a method should not be called.
+ *
+ * @param mixed
+ * @return \Mockery\Expectation
+ */
+ public function shouldNotReceive()
+ {
+ $expectation = call_user_func_array(array($this, 'shouldReceive'), func_get_args());
+ $expectation->never();
+ return $expectation;
+ }
+
+ /**
+ * Allows additional methods to be mocked that do not explicitly exist on mocked class
+ * @param String $method name of the method to be mocked
+ * @return Mock
+ */
+ public function shouldAllowMockingMethod($method)
+ {
+ $this->_mockery_mockableMethods[] = $method;
+ return $this;
+ }
+
+ /**
+ * Set mock to ignore unexpected methods and return Undefined class
+ * @param mixed $returnValue the default return value for calls to missing functions on this mock
+ * @return Mock
+ */
+ public function shouldIgnoreMissing($returnValue = null)
+ {
+ $this->_mockery_ignoreMissing = true;
+ $this->_mockery_defaultReturnValue = $returnValue;
+ return $this;
+ }
+
+ public function asUndefined()
+ {
+ $this->_mockery_ignoreMissing = true;
+ $this->_mockery_defaultReturnValue = new \Mockery\Undefined;
+ return $this;
+ }
+
+ /**
+ * @return Mock
+ */
+ public function shouldAllowMockingProtectedMethods()
+ {
+ $this->_mockery_allowMockingProtectedMethods = true;
+ return $this;
+ }
+
+
+ /**
+ * Set mock to defer unexpected methods to it's parent
+ *
+ * This is particularly useless for this class, as it doesn't have a parent,
+ * but included for completeness
+ *
+ * @return Mock
+ */
+ public function shouldDeferMissing()
+ {
+ $this->_mockery_deferMissing = true;
+ return $this;
+ }
+
+ /**
+ * Create an obviously worded alias to shouldDeferMissing()
+ *
+ * @return Mock
+ */
+ public function makePartial()
+ {
+ return $this->shouldDeferMissing();
+ }
+
+ /**
+ * Accepts a closure which is executed with an object recorder which proxies
+ * to the partial source object. The intent being to record the
+ * interactions of a concrete object as a set of expectations on the
+ * current mock object. The partial may then be passed to a second process
+ * to see if it fulfils the same (or exact same) contract as the original.
+ *
+ * @param Closure $closure
+ */
+ public function shouldExpect(\Closure $closure)
+ {
+ $recorder = new \Mockery\Recorder($this, $this->_mockery_partial);
+ $this->_mockery_disableExpectationMatching = true;
+ $closure($recorder);
+ $this->_mockery_disableExpectationMatching = false;
+ return $this;
+ }
+
+ /**
+ * In the event shouldReceive() accepting one or more methods/returns,
+ * this method will switch them from normal expectations to default
+ * expectations
+ *
+ * @return self
+ */
+ public function byDefault()
+ {
+ foreach ($this->_mockery_expectations as $director) {
+ $exps = $director->getExpectations();
+ foreach ($exps as $exp) {
+ $exp->byDefault();
+ }
+ }
+ return $this;
+ }
+
+ /**
+ * Capture calls to this mock
+ */
+ public function __call($method, array $args)
+ {
+ return $this->_mockery_handleMethodCall($method, $args);
+ }
+
+ public static function __callStatic($method, array $args)
+ {
+ return self::_mockery_handleStaticMethodCall($method, $args);
+ }
+
+ /**
+ * Forward calls to this magic method to the __call method
+ */
+ public function __toString()
+ {
+ return $this->__call('__toString', array());
+ }
+
+ /**public function __set($name, $value)
+ {
+ $this->_mockery_mockableProperties[$name] = $value;
+ return $this;
+ }
+
+ public function __get($name)
+ {
+ if (isset($this->_mockery_mockableProperties[$name])) {
+ return $this->_mockery_mockableProperties[$name];
+ } elseif(isset($this->{$name})) {
+ return $this->{$name};
+ }
+ throw new \InvalidArgumentException (
+ 'Property ' . __CLASS__ . '::' . $name . ' does not exist on this mock object'
+ );
+ }**/
+
+ /**
+ * Iterate across all expectation directors and validate each
+ *
+ * @throws \Mockery\CountValidator\Exception
+ * @return void
+ */
+ public function mockery_verify()
+ {
+ if ($this->_mockery_verified) {
+ return true;
+ }
+ if (isset($this->_mockery_ignoreVerification)
+ && $this->_mockery_ignoreVerification == true) {
+ return true;
+ }
+ $this->_mockery_verified = true;
+ foreach ($this->_mockery_expectations as $director) {
+ $director->verify();
+ }
+ }
+
+ /**
+ * Tear down tasks for this mock
+ *
+ * @return void
+ */
+ public function mockery_teardown()
+ {
+ }
+
+ /**
+ * Fetch the next available allocation order number
+ *
+ * @return int
+ */
+ public function mockery_allocateOrder()
+ {
+ $this->_mockery_allocatedOrder += 1;
+ return $this->_mockery_allocatedOrder;
+ }
+
+ /**
+ * Set ordering for a group
+ *
+ * @param mixed $group
+ * @param int $order
+ */
+ public function mockery_setGroup($group, $order)
+ {
+ $this->_mockery_groups[$group] = $order;
+ }
+
+ /**
+ * Fetch array of ordered groups
+ *
+ * @return array
+ */
+ public function mockery_getGroups()
+ {
+ return $this->_mockery_groups;
+ }
+
+ /**
+ * Set current ordered number
+ *
+ * @param int $order
+ */
+ public function mockery_setCurrentOrder($order)
+ {
+ $this->_mockery_currentOrder = $order;
+ return $this->_mockery_currentOrder;
+ }
+
+ /**
+ * Get current ordered number
+ *
+ * @return int
+ */
+ public function mockery_getCurrentOrder()
+ {
+ return $this->_mockery_currentOrder;
+ }
+
+ /**
+ * Validate the current mock's ordering
+ *
+ * @param string $method
+ * @param int $order
+ * @throws \Mockery\Exception
+ * @return void
+ */
+ public function mockery_validateOrder($method, $order)
+ {
+ if ($order < $this->_mockery_currentOrder) {
+ $exception = new \Mockery\Exception\InvalidOrderException(
+ 'Method ' . __CLASS__ . '::' . $method . '()'
+ . ' called out of order: expected order '
+ . $order . ', was ' . $this->_mockery_currentOrder
+ );
+ $exception->setMock($this)
+ ->setMethodName($method)
+ ->setExpectedOrder($order)
+ ->setActualOrder($this->_mockery_currentOrder);
+ throw $exception;
+ }
+ $this->mockery_setCurrentOrder($order);
+ }
+
+ /**
+ * Gets the count of expectations for this mock
+ *
+ * @return int
+ */
+ public function mockery_getExpectationCount()
+ {
+ $count = 0;
+ foreach ($this->_mockery_expectations as $director) {
+ $count += $director->getExpectationCount();
+ }
+ return $count;
+ }
+
+ /**
+ * Return the expectations director for the given method
+ *
+ * @var string $method
+ * @return \Mockery\ExpectationDirector|null
+ */
+ public function mockery_setExpectationsFor($method, \Mockery\ExpectationDirector $director)
+ {
+ $this->_mockery_expectations[$method] = $director;
+ }
+
+ /**
+ * Return the expectations director for the given method
+ *
+ * @var string $method
+ * @return \Mockery\ExpectationDirector|null
+ */
+ public function mockery_getExpectationsFor($method)
+ {
+ if (isset($this->_mockery_expectations[$method])) {
+ return $this->_mockery_expectations[$method];
+ }
+ }
+
+ /**
+ * Find an expectation matching the given method and arguments
+ *
+ * @var string $method
+ * @var array $args
+ * @return \Mockery\Expectation|null
+ */
+ public function mockery_findExpectation($method, array $args)
+ {
+ if (!isset($this->_mockery_expectations[$method])) {
+ return null;
+ }
+ $director = $this->_mockery_expectations[$method];
+
+ return $director->findExpectation($args);
+ }
+
+ /**
+ * Return the container for this mock
+ *
+ * @return \Mockery\Container
+ */
+ public function mockery_getContainer()
+ {
+ return $this->_mockery_container;
+ }
+
+ /**
+ * Return the name for this mock
+ *
+ * @return string
+ */
+ public function mockery_getName()
+ {
+ return __CLASS__;
+ }
+
+ /**
+ * @return array
+ */
+ public function mockery_getMockableProperties()
+ {
+ return $this->_mockery_mockableProperties;
+ }
+
+ public function __isset($name)
+ {
+ if (false === stripos($name, '_mockery_') && method_exists(get_parent_class($this), '__isset')) {
+ return parent::__isset($name);
+ }
+ }
+
+ public function mockery_getExpectations()
+ {
+ return $this->_mockery_expectations;
+ }
+
+ /**
+ * Calls a parent class method and returns the result. Used in a passthru
+ * expectation where a real return value is required while still taking
+ * advantage of expectation matching and call count verification.
+ *
+ * @param string $name
+ * @param array $args
+ * @return mixed
+ */
+ public function mockery_callSubjectMethod($name, array $args)
+ {
+ return call_user_func_array('parent::' . $name, $args);
+ }
+
+ /**
+ * @return string[]
+ */
+ public function mockery_getMockableMethods()
+ {
+ return $this->_mockery_mockableMethods;
+ }
+
+ /**
+ * @return bool
+ */
+ public function mockery_isAnonymous()
+ {
+ $rfc = new \ReflectionClass($this);
+ return false === $rfc->getParentClass();
+ }
+
+ public function __wakeup()
+ {
+ /**
+ * This does not add __wakeup method support. It's a blind method and any
+ * expected __wakeup work will NOT be performed. It merely cuts off
+ * annoying errors where a __wakeup exists but is not essential when
+ * mocking
+ */
+ }
+
+ public function mockery_getMethod($name)
+ {
+ foreach ($this->mockery_getMethods() as $method) {
+ if ($method->getName() == $name) {
+ return $method;
+ }
+ }
+
+ return null;
+ }
+
+ public function shouldHaveReceived($method, $args = null)
+ {
+ $expectation = new \Mockery\VerificationExpectation($this, $method);
+ if (null !== $args) {
+ $expectation->withArgs($args);
+ }
+ $expectation->atLeast()->once();
+ $director = new \Mockery\VerificationDirector($this->_mockery_getReceivedMethodCalls(), $expectation);
+ $director->verify();
+ return $director;
+ }
+
+ public function shouldNotHaveReceived($method, $args = null)
+ {
+ $expectation = new \Mockery\VerificationExpectation($this, $method);
+ if (null !== $args) {
+ $expectation->withArgs($args);
+ }
+ $expectation->never();
+ $director = new \Mockery\VerificationDirector($this->_mockery_getReceivedMethodCalls(), $expectation);
+ $director->verify();
+ return null;
+ }
+
+ protected static function _mockery_handleStaticMethodCall($method, array $args)
+ {
+ try {
+ $associatedRealObject = \Mockery::fetchMock(__CLASS__);
+ return $associatedRealObject->__call($method, $args);
+ } catch (\BadMethodCallException $e) {
+ throw new \BadMethodCallException(
+ 'Static method ' . $associatedRealObject->mockery_getName() . '::' . $method
+ . '() does not exist on this mock object'
+ );
+ }
+ }
+
+ protected function _mockery_getReceivedMethodCalls()
+ {
+ return $this->_mockery_receivedMethodCalls ?: $this->_mockery_receivedMethodCalls = new \Mockery\ReceivedMethodCalls();
+ }
+
+ protected function _mockery_handleMethodCall($method, array $args)
+ {
+ $this->_mockery_getReceivedMethodCalls()->push(new \Mockery\MethodCall($method, $args));
+
+ $rm = $this->mockery_getMethod($method);
+ if ($rm && $rm->isProtected() && !$this->_mockery_allowMockingProtectedMethods) {
+ if ($rm->isAbstract()) {
+ return;
+ }
+
+ try {
+ $prototype = $rm->getPrototype();
+ if ($prototype->isAbstract()) {
+ return;
+ }
+ } catch (\ReflectionException $re) {
+ // noop - there is no hasPrototype method
+ }
+
+ return call_user_func_array("parent::$method", $args);
+ }
+
+ if (isset($this->_mockery_expectations[$method])
+ && !$this->_mockery_disableExpectationMatching) {
+ $handler = $this->_mockery_expectations[$method];
+
+ try {
+ return $handler->call($args);
+ } catch (\Mockery\Exception\NoMatchingExpectationException $e) {
+ if (!$this->_mockery_ignoreMissing && !$this->_mockery_deferMissing) {
+ throw $e;
+ }
+ }
+ }
+
+ if (!is_null($this->_mockery_partial) && method_exists($this->_mockery_partial, $method)) {
+ return call_user_func_array(array($this->_mockery_partial, $method), $args);
+ } elseif ($this->_mockery_deferMissing && is_callable("parent::$method")) {
+ return call_user_func_array("parent::$method", $args);
+ } elseif ($method === '__toString') {
+ // __toString is special because we force its addition to the class API regardless of the
+ // original implementation. Thus, we should always return a string rather than honor
+ // _mockery_ignoreMissing and break the API with an error.
+ return sprintf("%s#%s", __CLASS__, spl_object_hash($this));
+ } elseif ($this->_mockery_ignoreMissing) {
+ if (\Mockery::getConfiguration()->mockingNonExistentMethodsAllowed() || (method_exists($this->_mockery_partial, $method) || is_callable("parent::$method"))) {
+ if ($this->_mockery_defaultReturnValue instanceof \Mockery\Undefined) {
+ return call_user_func_array(array($this->_mockery_defaultReturnValue, $method), $args);
+ } else {
+ return $this->_mockery_defaultReturnValue;
+ }
+ }
+ }
+ throw new \BadMethodCallException(
+ 'Method ' . __CLASS__ . '::' . $method . '() does not exist on this mock object'
+ );
+ }
+
+ protected function mockery_getMethods()
+ {
+ if (static::$_mockery_methods) {
+ return static::$_mockery_methods;
+ }
+
+ $methods = array();
+
+ if (isset($this->_mockery_partial)) {
+ $reflected = new \ReflectionObject($this->_mockery_partial);
+ $methods = $reflected->getMethods();
+ } else {
+ $reflected = new \ReflectionClass($this);
+ foreach ($reflected->getMethods() as $method) {
+ try {
+ $methods[] = $method->getPrototype();
+ } catch (\ReflectionException $re) {
+ /**
+ * For some reason, private methods don't have a prototype
+ */
+ if ($method->isPrivate()) {
+ $methods[] = $method;
+ }
+ }
+ }
+ }
+
+ return static::$_mockery_methods = $methods;
+ }
+
+ /**
+ * @return array
+ */
+ private function getNonPublicMethods()
+ {
+ return array_map(
+ function ($method) {
+ return $method->getName();
+ },
+ array_filter($this->mockery_getMethods(), function ($method) {
+ return !$method->isPublic();
+ })
+ );
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/MockInterface.php b/vendor/mockery/mockery/library/Mockery/MockInterface.php
new file mode 100644
index 000000000..a5112924d
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/MockInterface.php
@@ -0,0 +1,242 @@
+methodCalls[] = $methodCall;
+ }
+
+ public function verify(Expectation $expectation)
+ {
+ foreach ($this->methodCalls as $methodCall) {
+ if ($methodCall->getMethod() !== $expectation->getName()) {
+ continue;
+ }
+
+ if (!$expectation->matchArgs($methodCall->getArgs())) {
+ continue;
+ }
+
+ $expectation->verifyCall($methodCall->getArgs());
+ }
+
+ $expectation->verify();
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Recorder.php b/vendor/mockery/mockery/library/Mockery/Recorder.php
new file mode 100644
index 000000000..b9210f105
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Recorder.php
@@ -0,0 +1,103 @@
+_mock = $mock;
+ $this->_subject = $subject;
+ }
+
+ /**
+ * Sets the recorded into strict mode where method calls are more strictly
+ * matched against the argument and call count and ordering is also
+ * set as enforceable.
+ *
+ * @return void
+ */
+ public function shouldBeStrict()
+ {
+ $this->_strict = true;
+ }
+
+ /**
+ * Intercept all calls on the subject, and use the call details to create
+ * a new expectation. The actual return value is then returned after being
+ * recorded.
+ *
+ * @param string $method
+ * @param array $args
+ * @return mixed
+ */
+ public function __call($method, array $args)
+ {
+ $return = call_user_func_array(array($this->_subject, $method), $args);
+ $expectation = $this->_mock->shouldReceive($method)->andReturn($return);
+ if ($this->_strict) {
+ $exactArgs = array();
+ foreach ($args as $arg) {
+ $exactArgs[] = \Mockery::mustBe($arg);
+ }
+ $expectation->once()->ordered();
+ call_user_func_array(array($expectation, 'with'), $exactArgs);
+ } else {
+ call_user_func_array(array($expectation, 'with'), $args);
+ }
+ return $return;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/Undefined.php b/vendor/mockery/mockery/library/Mockery/Undefined.php
new file mode 100644
index 000000000..e0fe424ed
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/Undefined.php
@@ -0,0 +1,47 @@
+receivedMethodCalls = $receivedMethodCalls;
+ $this->expectation = $expectation;
+ }
+
+ public function verify()
+ {
+ return $this->receivedMethodCalls->verify($this->expectation);
+ }
+
+ public function with()
+ {
+ return $this->cloneApplyAndVerify("with", func_get_args());
+ }
+
+ public function withArgs(array $args)
+ {
+ return $this->cloneApplyAndVerify("withArgs", array($args));
+ }
+
+ public function withNoArgs()
+ {
+ return $this->cloneApplyAndVerify("withNoArgs", array());
+ }
+
+ public function withAnyArgs()
+ {
+ return $this->cloneApplyAndVerify("withAnyArgs", array());
+ }
+
+ public function times($limit = null)
+ {
+ return $this->cloneWithoutCountValidatorsApplyAndVerify("times", array($limit));
+ }
+
+ public function once()
+ {
+ return $this->cloneWithoutCountValidatorsApplyAndVerify("once", array());
+ }
+
+ public function twice()
+ {
+ return $this->cloneWithoutCountValidatorsApplyAndVerify("twice", array());
+ }
+
+ public function atLeast()
+ {
+ return $this->cloneWithoutCountValidatorsApplyAndVerify("atLeast", array());
+ }
+
+ public function atMost()
+ {
+ return $this->cloneWithoutCountValidatorsApplyAndVerify("atMost", array());
+ }
+
+ public function between($minimum, $maximum)
+ {
+ return $this->cloneWithoutCountValidatorsApplyAndVerify("between", array($minimum, $maximum));
+ }
+
+ protected function cloneWithoutCountValidatorsApplyAndVerify($method, $args)
+ {
+ $expectation = clone $this->expectation;
+ $expectation->clearCountValidators();
+ call_user_func_array(array($expectation, $method), $args);
+ $director = new VerificationDirector($this->receivedMethodCalls, $expectation);
+ $director->verify();
+ return $director;
+ }
+
+ protected function cloneApplyAndVerify($method, $args)
+ {
+ $expectation = clone $this->expectation;
+ call_user_func_array(array($expectation, $method), $args);
+ $director = new VerificationDirector($this->receivedMethodCalls, $expectation);
+ $director->verify();
+ return $director;
+ }
+}
diff --git a/vendor/mockery/mockery/library/Mockery/VerificationExpectation.php b/vendor/mockery/mockery/library/Mockery/VerificationExpectation.php
new file mode 100644
index 000000000..660c31fbc
--- /dev/null
+++ b/vendor/mockery/mockery/library/Mockery/VerificationExpectation.php
@@ -0,0 +1,17 @@
+_countValidators = array();
+ }
+
+ public function __clone()
+ {
+ parent::__clone();
+ $this->_actualCount = 0;
+ }
+}
diff --git a/vendor/mockery/mockery/library/helpers.php b/vendor/mockery/mockery/library/helpers.php
new file mode 100644
index 000000000..ed2a85112
--- /dev/null
+++ b/vendor/mockery/mockery/library/helpers.php
@@ -0,0 +1,41 @@
+
+
+ Mockery
+ pear.survivethedeepend.com
+ Mockery is a simple yet flexible mock object framework for use in unit testing.
+ Mockery is a simple yet flexible PHP mock object framework for use in unit testing with PHPUnit, PHPSpec or any other testing framework. Its core goal is to offer a test double framework with a succint API capable of clearly defining all possible object operations and interactions using a human readable Domain Specific Language (DSL). Designed as a drop in alternative to PHPUnit's phpunit-mock-objects library, Mockery is easy to integrate with PHPUnit and can operate alongside phpunit-mock-objects without the World ending.
+
+ Pádraic Brady
+ padraic
+ padraic.brady@yahoo.com
+ yes
+
+
+ Dave Marshall
+ davedevelopment
+ dave.marshall@atstsolutions.co.uk
+ yes
+
+ 2014-04-29
+ 20:26:00
+
+ 0.9.1
+ 0.9.1
+
+
+ stable
+ stable
+
+ BSD
+ http://github.com/padraic/mockery#readme
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 5.3.2
+
+
+ 1.4.0
+
+
+
+
+ Hamcrest
+ hamcrest.googlecode.com/svn/pear
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/vendor/mockery/mockery/phpunit.xml.dist b/vendor/mockery/mockery/phpunit.xml.dist
new file mode 100644
index 000000000..f1d0e0979
--- /dev/null
+++ b/vendor/mockery/mockery/phpunit.xml.dist
@@ -0,0 +1,37 @@
+
+
+>
+
+
+ ./tests
+ ./tests/Mockery/MockingVariadicArgumentsTest.php
+ ./tests/Mockery/MockingParameterAndReturnTypesTest.php
+ ./tests/Mockery/MockingVariadicArgumentsTest.php
+ ./tests/Mockery/MockingParameterAndReturnTypesTest.php
+
+
+
+
+ ./library/
+
+ ./library/Mockery/Adapter/Phpunit/MockeryPHPUnitIntegration.php
+
+
+
+
+
+
+
diff --git a/vendor/mockery/mockery/tests/Bootstrap.php b/vendor/mockery/mockery/tests/Bootstrap.php
new file mode 100644
index 000000000..f685167a5
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Bootstrap.php
@@ -0,0 +1,85 @@
+=')) {
+
+ /*
+ * Add Mutateme library/ directory to the PHPUnit code coverage
+ * whitelist. This has the effect that only production code source files
+ * appear in the code coverage report and that all production code source
+ * files, even those that are not covered by a test yet, are processed.
+ */
+ PHPUnit_Util_Filter::addDirectoryToWhitelist($library);
+
+ /*
+ * Omit from code coverage reports the contents of the tests directory
+ */
+ foreach (array('.php', '.phtml', '.csv', '.inc') as $suffix) {
+ PHPUnit_Util_Filter::addDirectoryToFilter($tests, $suffix);
+ }
+ PHPUnit_Util_Filter::addDirectoryToFilter(PEAR_INSTALL_DIR);
+ PHPUnit_Util_Filter::addDirectoryToFilter(PHP_LIBDIR);
+}
+
+require __DIR__.'/../vendor/autoload.php';
+
+/*
+ * Unset global variables that are no longer needed.
+ */
+unset($root, $library, $tests, $path);
diff --git a/vendor/mockery/mockery/tests/Mockery/AdhocTest.php b/vendor/mockery/mockery/tests/Mockery/AdhocTest.php
new file mode 100644
index 000000000..79381ebb0
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/AdhocTest.php
@@ -0,0 +1,90 @@
+container = new \Mockery\Container(\Mockery::getDefaultGenerator(), \Mockery::getDefaultLoader());
+ }
+
+ public function teardown()
+ {
+ $this->container->mockery_close();
+ }
+
+ public function testSimplestMockCreation()
+ {
+ $m = $this->container->mock('MockeryTest_NameOfExistingClass');
+ $this->assertTrue($m instanceof MockeryTest_NameOfExistingClass);
+ }
+
+ public function testMockeryInterfaceForClass()
+ {
+ $m = $this->container->mock('SplFileInfo');
+ $this->assertTrue($m instanceof \Mockery\MockInterface);
+ }
+
+ public function testMockeryInterfaceForNonExistingClass()
+ {
+ $m = $this->container->mock('ABC_IDontExist');
+ $this->assertTrue($m instanceof \Mockery\MockInterface);
+ }
+
+ public function testMockeryInterfaceForInterface()
+ {
+ $m = $this->container->mock('MockeryTest_NameOfInterface');
+ $this->assertTrue($m instanceof \Mockery\MockInterface);
+ }
+
+ public function testMockeryInterfaceForAbstract()
+ {
+ $m = $this->container->mock('MockeryTest_NameOfAbstract');
+ $this->assertTrue($m instanceof \Mockery\MockInterface);
+ }
+
+ public function testInvalidCountExceptionThrowsRuntimeExceptionOnIllegalComparativeSymbol()
+ {
+ $this->setExpectedException('Mockery\Exception\RuntimeException');
+ $e = new \Mockery\Exception\InvalidCountException;
+ $e->setExpectedCountComparative('X');
+ }
+}
+
+class MockeryTest_NameOfExistingClass
+{
+}
+
+interface MockeryTest_NameOfInterface
+{
+ public function foo();
+}
+
+abstract class MockeryTest_NameOfAbstract
+{
+ abstract public function foo();
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/ContainerTest.php b/vendor/mockery/mockery/tests/Mockery/ContainerTest.php
new file mode 100644
index 000000000..03c20af86
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/ContainerTest.php
@@ -0,0 +1,1768 @@
+container = new Mockery\Container(Mockery::getDefaultGenerator(), new Mockery\Loader\EvalLoader());
+ }
+
+ public function teardown()
+ {
+ $this->container->mockery_close();
+ }
+
+ public function testSimplestMockCreation()
+ {
+ $m = $this->container->mock();
+ $m->shouldReceive('foo')->andReturn('bar');
+ $this->assertEquals('bar', $m->foo());
+ }
+
+ public function testGetKeyOfDemeterMockShouldReturnKeyWhenMatchingMock()
+ {
+ $m = $this->container->mock();
+ $m->shouldReceive('foo->bar');
+ $this->assertRegExp(
+ '/Mockery_(\d+)__demeter_foo/',
+ $this->container->getKeyOfDemeterMockFor('foo')
+ );
+ }
+ public function testGetKeyOfDemeterMockShouldReturnNullWhenNoMatchingMock()
+ {
+ $method = 'unknownMethod';
+ $this->assertNull($this->container->getKeyOfDemeterMockFor($method));
+
+ $m = $this->container->mock();
+ $m->shouldReceive('method');
+ $this->assertNull($this->container->getKeyOfDemeterMockFor($method));
+
+ $m->shouldReceive('foo->bar');
+ $this->assertNull($this->container->getKeyOfDemeterMockFor($method));
+ }
+
+
+ public function testNamedMocksAddNameToExceptions()
+ {
+ $m = $this->container->mock('Foo');
+ $m->shouldReceive('foo')->with(1)->andReturn('bar');
+ try {
+ $m->foo();
+ } catch (\Mockery\Exception $e) {
+ $this->assertTrue((bool) preg_match("/Foo/", $e->getMessage()));
+ }
+ }
+
+ public function testSimpleMockWithArrayDefs()
+ {
+ $m = $this->container->mock(array('foo'=>1, 'bar'=>2));
+ $this->assertEquals(1, $m->foo());
+ $this->assertEquals(2, $m->bar());
+ }
+
+ public function testSimpleMockWithArrayDefsCanBeOverridden()
+ {
+ // eg. In shared test setup
+ $m = $this->container->mock(array('foo' => 1, 'bar' => 2));
+
+ // and then overridden in one test
+ $m->shouldReceive('foo')->with('baz')->once()->andReturn(2);
+ $m->shouldReceive('bar')->with('baz')->once()->andReturn(42);
+
+ $this->assertEquals(2, $m->foo('baz'));
+ $this->assertEquals(42, $m->bar('baz'));
+ }
+
+ public function testNamedMockWithArrayDefs()
+ {
+ $m = $this->container->mock('Foo', array('foo'=>1, 'bar'=>2));
+ $this->assertEquals(1, $m->foo());
+ $this->assertEquals(2, $m->bar());
+ try {
+ $m->f();
+ } catch (BadMethodCallException $e) {
+ $this->assertTrue((bool) preg_match("/Foo/", $e->getMessage()));
+ }
+ }
+
+ public function testNamedMockWithArrayDefsCanBeOverridden()
+ {
+ // eg. In shared test setup
+ $m = $this->container->mock('Foo', array('foo' => 1));
+
+ // and then overridden in one test
+ $m->shouldReceive('foo')->with('bar')->once()->andReturn(2);
+
+ $this->assertEquals(2, $m->foo('bar'));
+
+ try {
+ $m->f();
+ } catch (BadMethodCallException $e) {
+ $this->assertTrue((bool) preg_match("/Foo/", $e->getMessage()));
+ }
+ }
+
+ public function testNamedMockMultipleInterfaces()
+ {
+ $m = $this->container->mock('stdClass, ArrayAccess, Countable', array('foo'=>1, 'bar'=>2));
+ $this->assertEquals(1, $m->foo());
+ $this->assertEquals(2, $m->bar());
+ try {
+ $m->f();
+ } catch (BadMethodCallException $e) {
+ $this->assertTrue((bool) preg_match("/stdClass/", $e->getMessage()));
+ $this->assertTrue((bool) preg_match("/ArrayAccess/", $e->getMessage()));
+ $this->assertTrue((bool) preg_match("/Countable/", $e->getMessage()));
+ }
+ }
+
+ public function testNamedMockWithConstructorArgs()
+ {
+ $m = $this->container->mock("MockeryTest_ClassConstructor2[foo]", array($param1 = new stdClass()));
+ $m->shouldReceive("foo")->andReturn(123);
+ $this->assertEquals(123, $m->foo());
+ $this->assertEquals($param1, $m->getParam1());
+ }
+
+ public function testNamedMockWithConstructorArgsAndArrayDefs()
+ {
+ $m = $this->container->mock(
+ "MockeryTest_ClassConstructor2[foo]",
+ array($param1 = new stdClass()),
+ array("foo" => 123)
+ );
+ $this->assertEquals(123, $m->foo());
+ $this->assertEquals($param1, $m->getParam1());
+ }
+
+ public function testNamedMockWithConstructorArgsWithInternalCallToMockedMethod()
+ {
+ $m = $this->container->mock("MockeryTest_ClassConstructor2[foo]", array($param1 = new stdClass()));
+ $m->shouldReceive("foo")->andReturn(123);
+ $this->assertEquals(123, $m->bar());
+ }
+
+ public function testNamedMockWithConstructorArgsButNoQuickDefsShouldLeaveConstructorIntact()
+ {
+ $m = $this->container->mock("MockeryTest_ClassConstructor2", array($param1 = new stdClass()));
+ $m->shouldDeferMissing();
+ $this->assertEquals($param1, $m->getParam1());
+ }
+
+ public function testNamedMockWithShouldDeferMissing()
+ {
+ $m = $this->container->mock("MockeryTest_ClassConstructor2", array($param1 = new stdClass()));
+ $m->shouldDeferMissing();
+ $this->assertEquals('foo', $m->bar());
+ $m->shouldReceive("bar")->andReturn(123);
+ $this->assertEquals(123, $m->bar());
+ }
+
+ /**
+ * @expectedException BadMethodCallException
+ */
+ public function testNamedMockWithShouldDeferMissingThrowsIfNotAvailable()
+ {
+ $m = $this->container->mock("MockeryTest_ClassConstructor2", array($param1 = new stdClass()));
+ $m->shouldDeferMissing();
+ $m->foorbar123();
+ }
+
+ public function testMockingAKnownConcreteClassSoMockInheritsClassType()
+ {
+ $m = $this->container->mock('stdClass');
+ $m->shouldReceive('foo')->andReturn('bar');
+ $this->assertEquals('bar', $m->foo());
+ $this->assertTrue($m instanceof stdClass);
+ }
+
+ public function testMockingAKnownUserClassSoMockInheritsClassType()
+ {
+ $m = $this->container->mock('MockeryTest_TestInheritedType');
+ $this->assertTrue($m instanceof MockeryTest_TestInheritedType);
+ }
+
+ public function testMockingAConcreteObjectCreatesAPartialWithoutError()
+ {
+ $m = $this->container->mock(new stdClass);
+ $m->shouldReceive('foo')->andReturn('bar');
+ $this->assertEquals('bar', $m->foo());
+ $this->assertTrue($m instanceof stdClass);
+ }
+
+ public function testCreatingAPartialAllowsDynamicExpectationsAndPassesThroughUnexpectedMethods()
+ {
+ $m = $this->container->mock(new MockeryTestFoo);
+ $m->shouldReceive('bar')->andReturn('bar');
+ $this->assertEquals('bar', $m->bar());
+ $this->assertEquals('foo', $m->foo());
+ $this->assertTrue($m instanceof MockeryTestFoo);
+ }
+
+ public function testCreatingAPartialAllowsExpectationsToInterceptCallsToImplementedMethods()
+ {
+ $m = $this->container->mock(new MockeryTestFoo2);
+ $m->shouldReceive('bar')->andReturn('baz');
+ $this->assertEquals('baz', $m->bar());
+ $this->assertEquals('foo', $m->foo());
+ $this->assertTrue($m instanceof MockeryTestFoo2);
+ }
+
+ public function testBlockForwardingToPartialObject()
+ {
+ $m = $this->container->mock(new MockeryTestBar1, array('foo'=>1, Mockery\Container::BLOCKS => array('method1')));
+ $this->assertSame($m, $m->method1());
+ }
+
+ public function testPartialWithArrayDefs()
+ {
+ $m = $this->container->mock(new MockeryTestBar1, array('foo'=>1, Mockery\Container::BLOCKS => array('method1')));
+ $this->assertEquals(1, $m->foo());
+ }
+
+ public function testPassingClosureAsFinalParameterUsedToDefineExpectations()
+ {
+ $m = $this->container->mock('foo', function ($m) {
+ $m->shouldReceive('foo')->once()->andReturn('bar');
+ });
+ $this->assertEquals('bar', $m->foo());
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testMockingAKnownConcreteFinalClassThrowsErrors_OnlyPartialMocksCanMockFinalElements()
+ {
+ $m = $this->container->mock('MockeryFoo3');
+ }
+
+ public function testMockingAKnownConcreteClassWithFinalMethodsThrowsNoException()
+ {
+ $m = $this->container->mock('MockeryFoo4');
+ }
+
+ /**
+ * @group finalclass
+ */
+ public function testFinalClassesCanBePartialMocks()
+ {
+ $m = $this->container->mock(new MockeryFoo3);
+ $m->shouldReceive('foo')->andReturn('baz');
+ $this->assertEquals('baz', $m->foo());
+ $this->assertFalse($m instanceof MockeryFoo3);
+ }
+
+ public function testSplClassWithFinalMethodsCanBeMocked()
+ {
+ $m = $this->container->mock('SplFileInfo');
+ $m->shouldReceive('foo')->andReturn('baz');
+ $this->assertEquals('baz', $m->foo());
+ $this->assertTrue($m instanceof SplFileInfo);
+ }
+
+ public function testSplClassWithFinalMethodsCanBeMockedMultipleTimes()
+ {
+ $this->container->mock('SplFileInfo');
+ $m = $this->container->mock('SplFileInfo');
+ $m->shouldReceive('foo')->andReturn('baz');
+ $this->assertEquals('baz', $m->foo());
+ $this->assertTrue($m instanceof SplFileInfo);
+ }
+
+ public function testClassesWithFinalMethodsCanBeProxyPartialMocks()
+ {
+ $m = $this->container->mock(new MockeryFoo4);
+ $m->shouldReceive('foo')->andReturn('baz');
+ $this->assertEquals('baz', $m->foo());
+ $this->assertEquals('bar', $m->bar());
+ $this->assertTrue($m instanceof MockeryFoo4);
+ }
+
+ public function testClassesWithFinalMethodsCanBeProperPartialMocks()
+ {
+ $m = $this->container->mock('MockeryFoo4[bar]');
+ $m->shouldReceive('bar')->andReturn('baz');
+ $this->assertEquals('baz', $m->foo());
+ $this->assertEquals('baz', $m->bar());
+ $this->assertTrue($m instanceof MockeryFoo4);
+ }
+
+ public function testClassesWithFinalMethodsCanBeProperPartialMocksButFinalMethodsNotPartialed()
+ {
+ $m = $this->container->mock('MockeryFoo4[foo]');
+ $m->shouldReceive('foo')->andReturn('foo');
+ $this->assertEquals('baz', $m->foo()); // partial expectation ignored - will fail callcount assertion
+ $this->assertTrue($m instanceof MockeryFoo4);
+ }
+
+ public function testSplfileinfoClassMockPassesUserExpectations()
+ {
+ $file = $this->container->mock('SplFileInfo[getFilename,getPathname,getExtension,getMTime]', array(__FILE__));
+ $file->shouldReceive('getFilename')->once()->andReturn('foo');
+ $file->shouldReceive('getPathname')->once()->andReturn('path/to/foo');
+ $file->shouldReceive('getExtension')->once()->andReturn('css');
+ $file->shouldReceive('getMTime')->once()->andReturn(time());
+ }
+
+ public function testCanMockInterface()
+ {
+ $m = $this->container->mock('MockeryTest_Interface');
+ $this->assertTrue($m instanceof MockeryTest_Interface);
+ }
+
+ public function testCanMockSpl()
+ {
+ $m = $this->container->mock('\\SplFixedArray');
+ $this->assertTrue($m instanceof SplFixedArray);
+ }
+
+ public function testCanMockInterfaceWithAbstractMethod()
+ {
+ $m = $this->container->mock('MockeryTest_InterfaceWithAbstractMethod');
+ $this->assertTrue($m instanceof MockeryTest_InterfaceWithAbstractMethod);
+ $m->shouldReceive('foo')->andReturn(1);
+ $this->assertEquals(1, $m->foo());
+ }
+
+ public function testCanMockAbstractWithAbstractProtectedMethod()
+ {
+ $m = $this->container->mock('MockeryTest_AbstractWithAbstractMethod');
+ $this->assertTrue($m instanceof MockeryTest_AbstractWithAbstractMethod);
+ }
+
+ public function testCanMockInterfaceWithPublicStaticMethod()
+ {
+ $m = $this->container->mock('MockeryTest_InterfaceWithPublicStaticMethod');
+ $this->assertTrue($m instanceof MockeryTest_InterfaceWithPublicStaticMethod);
+ }
+
+ public function testCanMockClassWithConstructor()
+ {
+ $m = $this->container->mock('MockeryTest_ClassConstructor');
+ $this->assertTrue($m instanceof MockeryTest_ClassConstructor);
+ }
+
+ public function testCanMockClassWithConstructorNeedingClassArgs()
+ {
+ $m = $this->container->mock('MockeryTest_ClassConstructor2');
+ $this->assertTrue($m instanceof MockeryTest_ClassConstructor2);
+ }
+
+ /**
+ * @group partial
+ */
+ public function testCanPartiallyMockANormalClass()
+ {
+ $m = $this->container->mock('MockeryTest_PartialNormalClass[foo]');
+ $this->assertTrue($m instanceof MockeryTest_PartialNormalClass);
+ $m->shouldReceive('foo')->andReturn('cba');
+ $this->assertEquals('abc', $m->bar());
+ $this->assertEquals('cba', $m->foo());
+ }
+
+ /**
+ * @group partial
+ */
+ public function testCanPartiallyMockAnAbstractClass()
+ {
+ $m = $this->container->mock('MockeryTest_PartialAbstractClass[foo]');
+ $this->assertTrue($m instanceof MockeryTest_PartialAbstractClass);
+ $m->shouldReceive('foo')->andReturn('cba');
+ $this->assertEquals('abc', $m->bar());
+ $this->assertEquals('cba', $m->foo());
+ }
+
+ /**
+ * @group partial
+ */
+ public function testCanPartiallyMockANormalClassWith2Methods()
+ {
+ $m = $this->container->mock('MockeryTest_PartialNormalClass2[foo, baz]');
+ $this->assertTrue($m instanceof MockeryTest_PartialNormalClass2);
+ $m->shouldReceive('foo')->andReturn('cba');
+ $m->shouldReceive('baz')->andReturn('cba');
+ $this->assertEquals('abc', $m->bar());
+ $this->assertEquals('cba', $m->foo());
+ $this->assertEquals('cba', $m->baz());
+ }
+
+ /**
+ * @group partial
+ */
+ public function testCanPartiallyMockAnAbstractClassWith2Methods()
+ {
+ $m = $this->container->mock('MockeryTest_PartialAbstractClass2[foo,baz]');
+ $this->assertTrue($m instanceof MockeryTest_PartialAbstractClass2);
+ $m->shouldReceive('foo')->andReturn('cba');
+ $m->shouldReceive('baz')->andReturn('cba');
+ $this->assertEquals('abc', $m->bar());
+ $this->assertEquals('cba', $m->foo());
+ $this->assertEquals('cba', $m->baz());
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ * @group partial
+ */
+ public function testThrowsExceptionIfSettingExpectationForNonMockedMethodOfPartialMock()
+ {
+ $this->markTestSkipped('For now...');
+ $m = $this->container->mock('MockeryTest_PartialNormalClass[foo]');
+ $this->assertTrue($m instanceof MockeryTest_PartialNormalClass);
+ $m->shouldReceive('bar')->andReturn('cba');
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ * @group partial
+ */
+ public function testThrowsExceptionIfClassOrInterfaceForPartialMockDoesNotExist()
+ {
+ $m = $this->container->mock('MockeryTest_PartialNormalClassXYZ[foo]');
+ }
+
+ /**
+ * @group issue/4
+ */
+ public function testCanMockClassContainingMagicCallMethod()
+ {
+ $m = $this->container->mock('MockeryTest_Call1');
+ $this->assertTrue($m instanceof MockeryTest_Call1);
+ }
+
+ /**
+ * @group issue/4
+ */
+ public function testCanMockClassContainingMagicCallMethodWithoutTypeHinting()
+ {
+ $m = $this->container->mock('MockeryTest_Call2');
+ $this->assertTrue($m instanceof MockeryTest_Call2);
+ }
+
+ /**
+ * @group issue/14
+ */
+ public function testCanMockClassContainingAPublicWakeupMethod()
+ {
+ $m = $this->container->mock('MockeryTest_Wakeup1');
+ $this->assertTrue($m instanceof MockeryTest_Wakeup1);
+ }
+
+ /**
+ * @group issue/18
+ */
+ public function testCanMockClassUsingMagicCallMethodsInPlaceOfNormalMethods()
+ {
+ $m = Mockery::mock('Gateway');
+ $m->shouldReceive('iDoSomethingReallyCoolHere');
+ $m->iDoSomethingReallyCoolHere();
+ }
+
+ /**
+ * @group issue/18
+ */
+ public function testCanPartialMockObjectUsingMagicCallMethodsInPlaceOfNormalMethods()
+ {
+ $m = Mockery::mock(new Gateway);
+ $m->shouldReceive('iDoSomethingReallyCoolHere');
+ $m->iDoSomethingReallyCoolHere();
+ }
+
+ /**
+ * @group issue/13
+ */
+ public function testCanMockClassWhereMethodHasReferencedParameter()
+ {
+ $m = Mockery::mock(new MockeryTest_MethodParamRef);
+ }
+
+ /**
+ * @group issue/13
+ */
+ public function testCanPartiallyMockObjectWhereMethodHasReferencedParameter()
+ {
+ $m = Mockery::mock(new MockeryTest_MethodParamRef2);
+ }
+
+ /**
+ * @group issue/11
+ */
+ public function testMockingAKnownConcreteClassCanBeGrantedAnArbitraryClassType()
+ {
+ $m = $this->container->mock('alias:MyNamespace\MyClass');
+ $m->shouldReceive('foo')->andReturn('bar');
+ $this->assertEquals('bar', $m->foo());
+ $this->assertTrue($m instanceof MyNamespace\MyClass);
+ }
+
+ /**
+ * @group issue/15
+ */
+ public function testCanMockMultipleInterfaces()
+ {
+ $m = $this->container->mock('MockeryTest_Interface1, MockeryTest_Interface2');
+ $this->assertTrue($m instanceof MockeryTest_Interface1);
+ $this->assertTrue($m instanceof MockeryTest_Interface2);
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testMockingMultipleInterfacesThrowsExceptionWhenGivenNonExistingClassOrInterface()
+ {
+ $m = $this->container->mock('DoesNotExist, MockeryTest_Interface2');
+ $this->assertTrue($m instanceof MockeryTest_Interface1);
+ $this->assertTrue($m instanceof MockeryTest_Interface2);
+ }
+
+ /**
+ * @group issue/15
+ */
+ public function testCanMockClassAndApplyMultipleInterfaces()
+ {
+ $m = $this->container->mock('MockeryTestFoo, MockeryTest_Interface1, MockeryTest_Interface2');
+ $this->assertTrue($m instanceof MockeryTestFoo);
+ $this->assertTrue($m instanceof MockeryTest_Interface1);
+ $this->assertTrue($m instanceof MockeryTest_Interface2);
+ }
+
+ /**
+ * @group issue/7
+ *
+ * Noted: We could complicate internally, but a blind class is better built
+ * with a real class noted up front (stdClass is a perfect choice it is
+ * behaviourless). Fine, it's a muddle - but we need to draw a line somewhere.
+ */
+ public function testCanMockStaticMethods()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('alias:MyNamespace\MyClass2');
+ $m->shouldReceive('staticFoo')->andReturn('bar');
+ $this->assertEquals('bar', \MyNameSpace\MyClass2::staticFoo());
+ Mockery::resetContainer();
+ }
+
+ /**
+ * @group issue/7
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testMockedStaticMethodsObeyMethodCounting()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('alias:MyNamespace\MyClass3');
+ $m->shouldReceive('staticFoo')->once()->andReturn('bar');
+ $this->container->mockery_verify();
+ Mockery::resetContainer();
+ }
+
+ /**
+ * @expectedException BadMethodCallException
+ */
+ public function testMockedStaticThrowsExceptionWhenMethodDoesNotExist()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('alias:MyNamespace\StaticNoMethod');
+ $this->assertEquals('bar', MyNameSpace\StaticNoMethod::staticFoo());
+ Mockery::resetContainer();
+ }
+
+ /**
+ * @group issue/17
+ */
+ public function testMockingAllowsPublicPropertyStubbingOnRealClass()
+ {
+ $m = $this->container->mock('MockeryTestFoo');
+ $m->foo = 'bar';
+ $this->assertEquals('bar', $m->foo);
+ //$this->assertTrue(array_key_exists('foo', $m->mockery_getMockableProperties()));
+ }
+
+ /**
+ * @group issue/17
+ */
+ public function testMockingAllowsPublicPropertyStubbingOnNamedMock()
+ {
+ $m = $this->container->mock('Foo');
+ $m->foo = 'bar';
+ $this->assertEquals('bar', $m->foo);
+ //$this->assertTrue(array_key_exists('foo', $m->mockery_getMockableProperties()));
+ }
+
+ /**
+ * @group issue/17
+ */
+ public function testMockingAllowsPublicPropertyStubbingOnPartials()
+ {
+ $m = $this->container->mock(new stdClass);
+ $m->foo = 'bar';
+ $this->assertEquals('bar', $m->foo);
+ //$this->assertTrue(array_key_exists('foo', $m->mockery_getMockableProperties()));
+ }
+
+ /**
+ * @group issue/17
+ */
+ public function testMockingDoesNotStubNonStubbedPropertiesOnPartials()
+ {
+ $m = $this->container->mock(new MockeryTest_ExistingProperty);
+ $this->assertEquals('bar', $m->foo);
+ $this->assertFalse(array_key_exists('foo', $m->mockery_getMockableProperties()));
+ }
+
+ public function testCreationOfInstanceMock()
+ {
+ $m = $this->container->mock('overload:MyNamespace\MyClass4');
+ $this->assertTrue($m instanceof MyNamespace\MyClass4);
+ }
+
+ public function testInstantiationOfInstanceMock()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('overload:MyNamespace\MyClass5');
+ $instance = new MyNamespace\MyClass5;
+ $this->assertTrue($instance instanceof MyNamespace\MyClass5);
+ Mockery::resetContainer();
+ }
+
+ public function testInstantiationOfInstanceMockImportsExpectations()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('overload:MyNamespace\MyClass6');
+ $m->shouldReceive('foo')->andReturn('bar');
+ $instance = new MyNamespace\MyClass6;
+ $this->assertEquals('bar', $instance->foo());
+ Mockery::resetContainer();
+ }
+
+ public function testInstantiationOfInstanceMocksIgnoresVerificationOfOriginMock()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('overload:MyNamespace\MyClass7');
+ $m->shouldReceive('foo')->once()->andReturn('bar');
+ $this->container->mockery_verify();
+ Mockery::resetContainer(); //should not throw an exception
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testInstantiationOfInstanceMocksAddsThemToContainerForVerification()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('overload:MyNamespace\MyClass8');
+ $m->shouldReceive('foo')->once();
+ $instance = new MyNamespace\MyClass8;
+ $this->container->mockery_verify();
+ Mockery::resetContainer();
+ }
+
+ public function testInstantiationOfInstanceMocksDoesNotHaveCountValidatorCrossover()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('overload:MyNamespace\MyClass9');
+ $m->shouldReceive('foo')->once();
+ $instance1 = new MyNamespace\MyClass9;
+ $instance2 = new MyNamespace\MyClass9;
+ $instance1->foo();
+ $instance2->foo();
+ $this->container->mockery_verify();
+ Mockery::resetContainer();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testInstantiationOfInstanceMocksDoesNotHaveCountValidatorCrossover2()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('overload:MyNamespace\MyClass10');
+ $m->shouldReceive('foo')->once();
+ $instance1 = new MyNamespace\MyClass10;
+ $instance2 = new MyNamespace\MyClass10;
+ $instance1->foo();
+ $this->container->mockery_verify();
+ Mockery::resetContainer();
+ }
+
+ public function testCreationOfInstanceMockWithFullyQualifiedName()
+ {
+ $m = $this->container->mock('overload:\MyNamespace\MyClass11');
+ $this->assertTrue($m instanceof MyNamespace\MyClass11);
+ }
+
+ public function testInstanceMocksShouldIgnoreMissing()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('overload:MyNamespace\MyClass12');
+ $m->shouldIgnoreMissing();
+
+ $instance = new MyNamespace\MyClass12();
+ $instance->foo();
+
+ Mockery::resetContainer();
+ }
+
+ /**
+ * @group issue/451
+ */
+ public function testSettingPropertyOnInstanceMockWillSetItOnActualInstance()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('overload:MyNamespace\MyClass13');
+ $m->shouldReceive('foo')->andSet('bar', 'baz');
+ $instance = new MyNamespace\MyClass13;
+ $instance->foo();
+ $this->assertEquals('baz', $m->bar);
+ $this->assertEquals('baz', $instance->bar);
+ Mockery::resetContainer();
+ }
+
+ public function testMethodParamsPassedByReferenceHaveReferencePreserved()
+ {
+ $m = $this->container->mock('MockeryTestRef1');
+ $m->shouldReceive('foo')->with(
+ Mockery::on(function (&$a) {
+ $a += 1;
+ return true;
+ }),
+ Mockery::any()
+ );
+ $a = 1;
+ $b = 1;
+ $m->foo($a, $b);
+ $this->assertEquals(2, $a);
+ $this->assertEquals(1, $b);
+ }
+
+ /**
+ * Meant to test the same logic as
+ * testCanOverrideExpectedParametersOfExtensionPHPClassesToPreserveRefs,
+ * but:
+ * - doesn't require an extension
+ * - isn't actually known to be used
+ */
+ public function testCanOverrideExpectedParametersOfInternalPHPClassesToPreserveRefs()
+ {
+ Mockery::getConfiguration()->setInternalClassMethodParamMap(
+ 'DateTime', 'modify', array('&$string')
+ );
+ // @ used to avoid E_STRICT for incompatible signature
+ @$m = $this->container->mock('DateTime');
+ $this->assertInstanceOf("Mockery\MockInterface", $m, "Mocking failed, remove @ error suppresion to debug");
+ $m->shouldReceive('modify')->with(
+ Mockery::on(function (&$string) {
+ $string = 'foo';
+ return true;
+ })
+ );
+ $data ='bar';
+ $m->modify($data);
+ $this->assertEquals('foo', $data);
+ $this->container->mockery_verify();
+ Mockery::resetContainer();
+ Mockery::getConfiguration()->resetInternalClassMethodParamMaps();
+ }
+
+ /**
+ * Real world version of
+ * testCanOverrideExpectedParametersOfInternalPHPClassesToPreserveRefs
+ */
+ public function testCanOverrideExpectedParametersOfExtensionPHPClassesToPreserveRefs()
+ {
+ if (!class_exists('MongoCollection', false)) {
+ $this->markTestSkipped('ext/mongo not installed');
+ }
+ Mockery::getConfiguration()->setInternalClassMethodParamMap(
+ 'MongoCollection', 'insert', array('&$data', '$options')
+ );
+ // @ used to avoid E_STRICT for incompatible signature
+ @$m = $this->container->mock('MongoCollection');
+ $this->assertInstanceOf("Mockery\MockInterface", $m, "Mocking failed, remove @ error suppresion to debug");
+ $m->shouldReceive('insert')->with(
+ Mockery::on(function (&$data) {
+ $data['_id'] = 123;
+ return true;
+ }),
+ Mockery::type('array')
+ );
+ $data = array('a'=>1,'b'=>2);
+ $m->insert($data, array());
+ $this->assertTrue(isset($data['_id']));
+ $this->assertEquals(123, $data['_id']);
+ $this->container->mockery_verify();
+ Mockery::resetContainer();
+ Mockery::getConfiguration()->resetInternalClassMethodParamMaps();
+ }
+
+ public function testCanCreateNonOverridenInstanceOfPreviouslyOverridenInternalClasses()
+ {
+ Mockery::getConfiguration()->setInternalClassMethodParamMap(
+ 'DateTime', 'modify', array('&$string')
+ );
+ // @ used to avoid E_STRICT for incompatible signature
+ @$m = $this->container->mock('DateTime');
+ $this->assertInstanceOf("Mockery\MockInterface", $m, "Mocking failed, remove @ error suppresion to debug");
+ $rc = new ReflectionClass($m);
+ $rm = $rc->getMethod('modify');
+ $params = $rm->getParameters();
+ $this->assertTrue($params[0]->isPassedByReference());
+
+ Mockery::getConfiguration()->resetInternalClassMethodParamMaps();
+
+ $m = $this->container->mock('DateTime');
+ $this->assertInstanceOf("Mockery\MockInterface", $m, "Mocking failed");
+ $rc = new ReflectionClass($m);
+ $rm = $rc->getMethod('modify');
+ $params = $rm->getParameters();
+ $this->assertFalse($params[0]->isPassedByReference());
+
+ Mockery::resetContainer();
+ Mockery::getConfiguration()->resetInternalClassMethodParamMaps();
+ }
+
+ /**
+ * @group abstract
+ */
+ public function testCanMockAbstractClassWithAbstractPublicMethod()
+ {
+ $m = $this->container->mock('MockeryTest_AbstractWithAbstractPublicMethod');
+ $this->assertTrue($m instanceof MockeryTest_AbstractWithAbstractPublicMethod);
+ }
+
+ /**
+ * @issue issue/21
+ */
+ public function testClassDeclaringIssetDoesNotThrowException()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('MockeryTest_IssetMethod');
+ $this->container->mockery_verify();
+ Mockery::resetContainer();
+ }
+
+ /**
+ * @issue issue/21
+ */
+ public function testClassDeclaringUnsetDoesNotThrowException()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('MockeryTest_UnsetMethod');
+ $this->container->mockery_verify();
+ Mockery::resetContainer();
+ }
+
+ /**
+ * @issue issue/35
+ */
+ public function testCallingSelfOnlyReturnsLastMockCreatedOrCurrentMockBeingProgrammedSinceTheyAreOneAndTheSame()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('MockeryTestFoo');
+ $this->assertFalse($this->container->self() instanceof MockeryTestFoo2);
+ //$m = $this->container->mock('MockeryTestFoo2');
+ //$this->assertTrue($this->container->self() instanceof MockeryTestFoo2);
+ //$m = $this->container->mock('MockeryTestFoo');
+ //$this->assertFalse(Mockery::self() instanceof MockeryTestFoo2);
+ //$this->assertTrue(Mockery::self() instanceof MockeryTestFoo);
+ Mockery::resetContainer();
+ }
+
+ /**
+ * @issue issue/89
+ */
+ public function testCreatingMockOfClassWithExistingToStringMethodDoesntCreateClassWithTwoToStringMethods()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('MockeryTest_WithToString'); // this would fatal
+ $m->shouldReceive("__toString")->andReturn('dave');
+ $this->assertEquals("dave", "$m");
+ }
+
+ public function testGetExpectationCount_freshContainer()
+ {
+ $this->assertEquals(0, $this->container->mockery_getExpectationCount());
+ }
+
+ public function testGetExpectationCount_simplestMock()
+ {
+ $m = $this->container->mock();
+ $m->shouldReceive('foo')->andReturn('bar');
+ $this->assertEquals(1, $this->container->mockery_getExpectationCount());
+ }
+
+ public function testMethodsReturningParamsByReferenceDoesNotErrorOut()
+ {
+ $this->container->mock('MockeryTest_ReturnByRef');
+ $mock = $this->container->mock('MockeryTest_ReturnByRef');
+ $mock->shouldReceive("get")->andReturn($var = 123);
+ $this->assertSame($var, $mock->get());
+ }
+
+ public function testMockCallableTypeHint()
+ {
+ if (PHP_VERSION_ID >= 50400) {
+ $this->container->mock('MockeryTest_MockCallableTypeHint');
+ }
+ }
+
+ public function testCanMockClassWithReservedWordMethod()
+ {
+ if (!extension_loaded("redis")) {
+ $this->markTestSkipped("phpredis not installed");
+ }
+
+ $this->container->mock("Redis");
+ }
+
+ public function testUndeclaredClassIsDeclared()
+ {
+ $this->assertFalse(class_exists("BlahBlah"));
+ $mock = $this->container->mock("BlahBlah");
+ $this->assertInstanceOf("BlahBlah", $mock);
+ }
+
+ public function testUndeclaredClassWithNamespaceIsDeclared()
+ {
+ $this->assertFalse(class_exists("MyClasses\Blah\BlahBlah"));
+ $mock = $this->container->mock("MyClasses\Blah\BlahBlah");
+ $this->assertInstanceOf("MyClasses\Blah\BlahBlah", $mock);
+ }
+
+ public function testUndeclaredClassWithNamespaceIncludingLeadingOperatorIsDeclared()
+ {
+ $this->assertFalse(class_exists("\MyClasses\DaveBlah\BlahBlah"));
+ $mock = $this->container->mock("\MyClasses\DaveBlah\BlahBlah");
+ $this->assertInstanceOf("\MyClasses\DaveBlah\BlahBlah", $mock);
+ }
+
+ public function testMockingPhpredisExtensionClassWorks()
+ {
+ if (!class_exists('Redis')) {
+ $this->markTestSkipped('PHPRedis extension required for this test');
+ }
+ $m = $this->container->mock('Redis');
+ }
+
+ public function testIssetMappingUsingProxiedPartials_CheckNoExceptionThrown()
+ {
+ $var = $this->container->mock(new MockeryTestIsset_Bar());
+ $mock = $this->container->mock(new MockeryTestIsset_Foo($var));
+ $mock->shouldReceive('bar')->once();
+ $mock->bar();
+ $this->container->mockery_teardown(); // closed by teardown()
+ }
+
+ /**
+ * @group traversable1
+ */
+ public function testCanMockInterfacesExtendingTraversable()
+ {
+ $mock = $this->container->mock('MockeryTest_InterfaceWithTraversable');
+ $this->assertInstanceOf('MockeryTest_InterfaceWithTraversable', $mock);
+ $this->assertInstanceOf('ArrayAccess', $mock);
+ $this->assertInstanceOf('Countable', $mock);
+ $this->assertInstanceOf('Traversable', $mock);
+ }
+
+ /**
+ * @group traversable2
+ */
+ public function testCanMockInterfacesAlongsideTraversable()
+ {
+ $mock = $this->container->mock('stdClass, ArrayAccess, Countable, Traversable');
+ $this->assertInstanceOf('stdClass', $mock);
+ $this->assertInstanceOf('ArrayAccess', $mock);
+ $this->assertInstanceOf('Countable', $mock);
+ $this->assertInstanceOf('Traversable', $mock);
+ }
+
+ public function testInterfacesCanHaveAssertions()
+ {
+ Mockery::setContainer($this->container);
+ $m = $this->container->mock('stdClass, ArrayAccess, Countable, Traversable');
+ $m->shouldReceive('foo')->once();
+ $m->foo();
+ $this->container->mockery_verify();
+ Mockery::resetContainer();
+ }
+
+ public function testMockingIteratorAggregateDoesNotImplementIterator()
+ {
+ $mock = $this->container->mock('MockeryTest_ImplementsIteratorAggregate');
+ $this->assertInstanceOf('IteratorAggregate', $mock);
+ $this->assertInstanceOf('Traversable', $mock);
+ $this->assertNotInstanceOf('Iterator', $mock);
+ }
+
+ public function testMockingInterfaceThatExtendsIteratorDoesNotImplementIterator()
+ {
+ $mock = $this->container->mock('MockeryTest_InterfaceThatExtendsIterator');
+ $this->assertInstanceOf('Iterator', $mock);
+ $this->assertInstanceOf('Traversable', $mock);
+ }
+
+ public function testMockingInterfaceThatExtendsIteratorAggregateDoesNotImplementIterator()
+ {
+ $mock = $this->container->mock('MockeryTest_InterfaceThatExtendsIteratorAggregate');
+ $this->assertInstanceOf('IteratorAggregate', $mock);
+ $this->assertInstanceOf('Traversable', $mock);
+ $this->assertNotInstanceOf('Iterator', $mock);
+ }
+
+ public function testMockingIteratorAggregateDoesNotImplementIteratorAlongside()
+ {
+ $mock = $this->container->mock('IteratorAggregate');
+ $this->assertInstanceOf('IteratorAggregate', $mock);
+ $this->assertInstanceOf('Traversable', $mock);
+ $this->assertNotInstanceOf('Iterator', $mock);
+ }
+
+ public function testMockingIteratorDoesNotImplementIteratorAlongside()
+ {
+ $mock = $this->container->mock('Iterator');
+ $this->assertInstanceOf('Iterator', $mock);
+ $this->assertInstanceOf('Traversable', $mock);
+ }
+
+ public function testMockingIteratorDoesNotImplementIterator()
+ {
+ $mock = $this->container->mock('MockeryTest_ImplementsIterator');
+ $this->assertInstanceOf('Iterator', $mock);
+ $this->assertInstanceOf('Traversable', $mock);
+ }
+
+ public function testMockeryCloseForIllegalIssetFileInclude()
+ {
+ $m = Mockery::mock('StdClass')
+ ->shouldReceive('get')
+ ->andReturn(false)
+ ->getMock();
+ $m->get();
+ Mockery::close();
+ }
+
+ public function testMockeryShouldDistinguishBetweenConstructorParamsAndClosures()
+ {
+ $obj = new MockeryTestFoo();
+ $mock = $this->container->mock('MockeryTest_ClassMultipleConstructorParams[dave]',
+ array( &$obj, 'foo' ));
+ }
+
+ /** @group nette */
+ public function testMockeryShouldNotMockCallstaticMagicMethod()
+ {
+ $mock = $this->container->mock('MockeryTest_CallStatic');
+ }
+
+ /**
+ * @issue issue/139
+ */
+ public function testCanMockClassWithOldStyleConstructorAndArguments()
+ {
+ $mock = $this->container->mock('MockeryTest_OldStyleConstructor');
+ }
+
+ /** @group issue/144 */
+ public function testMockeryShouldInterpretEmptyArrayAsConstructorArgs()
+ {
+ $mock = $this->container->mock("EmptyConstructorTest", array());
+ $this->assertSame(0, $mock->numberOfConstructorArgs);
+ }
+
+ /** @group issue/144 */
+ public function testMockeryShouldCallConstructorByDefaultWhenRequestingPartials()
+ {
+ $mock = $this->container->mock("EmptyConstructorTest[foo]");
+ $this->assertSame(0, $mock->numberOfConstructorArgs);
+ }
+
+ /** @group issue/158 */
+ public function testMockeryShouldRespectInterfaceWithMethodParamSelf()
+ {
+ $this->container->mock('MockeryTest_InterfaceWithMethodParamSelf');
+ }
+
+ /** @group issue/162 */
+ public function testMockeryDoesntTryAndMockLowercaseToString()
+ {
+ $this->container->mock('MockeryTest_Lowercase_ToString');
+ }
+
+ /** @group issue/175 */
+ public function testExistingStaticMethodMocking()
+ {
+ Mockery::setContainer($this->container);
+ $mock = $this->container->mock('MockeryTest_PartialStatic[mockMe]');
+
+ $mock->shouldReceive('mockMe')->with(5)->andReturn(10);
+
+ $this->assertEquals(10, $mock::mockMe(5));
+ $this->assertEquals(3, $mock::keepMe(3));
+ }
+
+ /**
+ * @group issue/154
+ * @expectedException InvalidArgumentException
+ * @expectedExceptionMessage protectedMethod() cannot be mocked as it a protected method and mocking protected methods is not allowed for this mock
+ */
+ public function testShouldThrowIfAttemptingToStubProtectedMethod()
+ {
+ $mock = $this->container->mock('MockeryTest_WithProtectedAndPrivate');
+ $mock->shouldReceive("protectedMethod");
+ }
+
+ /**
+ * @group issue/154
+ * @expectedException InvalidArgumentException
+ * @expectedExceptionMessage privateMethod() cannot be mocked as it is a private method
+ */
+ public function testShouldThrowIfAttemptingToStubPrivateMethod()
+ {
+ $mock = $this->container->mock('MockeryTest_WithProtectedAndPrivate');
+ $mock->shouldReceive("privateMethod");
+ }
+
+ public function testWakeupMagicIsNotMockedToAllowSerialisationInstanceHack()
+ {
+ $mock = $this->container->mock('DateTime');
+ }
+
+ /**
+ * @group issue/154
+ */
+ public function testCanMockMethodsWithRequiredParamsThatHaveDefaultValues()
+ {
+ $mock = $this->container->mock('MockeryTest_MethodWithRequiredParamWithDefaultValue');
+ $mock->shouldIgnoreMissing();
+ $mock->foo(null, 123);
+ }
+
+ /**
+ * @test
+ * @group issue/294
+ * @expectedException Mockery\Exception\RuntimeException
+ * @expectedExceptionMessage Could not load mock DateTime, class already exists
+ */
+ public function testThrowsWhenNamedMockClassExistsAndIsNotMockery()
+ {
+ $builder = new MockConfigurationBuilder();
+ $builder->setName("DateTime");
+ $mock = $this->container->mock($builder);
+ }
+
+ /**
+ * @expectedException Mockery\Exception\NoMatchingExpectationException
+ * @expectedExceptionMessage MyTestClass::foo(resource(...))
+ */
+ public function testHandlesMethodWithArgumentExpectationWhenCalledWithResource()
+ {
+ $mock = $this->container->mock('MyTestClass');
+ $mock->shouldReceive('foo')->with(array('yourself' => 21));
+
+ $mock->foo(fopen('php://memory', 'r'));
+ }
+
+ /**
+ * @expectedException Mockery\Exception\NoMatchingExpectationException
+ * @expectedExceptionMessage MyTestClass::foo(array('myself'=>'array(...)',))
+ */
+ public function testHandlesMethodWithArgumentExpectationWhenCalledWithCircularArray()
+ {
+ $testArray = array();
+ $testArray['myself'] =& $testArray;
+
+ $mock = $this->container->mock('MyTestClass');
+ $mock->shouldReceive('foo')->with(array('yourself' => 21));
+
+ $mock->foo($testArray);
+ }
+
+ /**
+ * @expectedException Mockery\Exception\NoMatchingExpectationException
+ * @expectedExceptionMessage MyTestClass::foo(array('a_scalar'=>2,'an_array'=>'array(...)',))
+ */
+ public function testHandlesMethodWithArgumentExpectationWhenCalledWithNestedArray()
+ {
+ $testArray = array();
+ $testArray['a_scalar'] = 2;
+ $testArray['an_array'] = array(1, 2, 3);
+
+ $mock = $this->container->mock('MyTestClass');
+ $mock->shouldReceive('foo')->with(array('yourself' => 21));
+
+ $mock->foo($testArray);
+ }
+
+ /**
+ * @expectedException Mockery\Exception\NoMatchingExpectationException
+ * @expectedExceptionMessage MyTestClass::foo(array('a_scalar'=>2,'an_object'=>'object(stdClass)',))
+ */
+ public function testHandlesMethodWithArgumentExpectationWhenCalledWithNestedObject()
+ {
+ $testArray = array();
+ $testArray['a_scalar'] = 2;
+ $testArray['an_object'] = new stdClass();
+
+ $mock = $this->container->mock('MyTestClass');
+ $mock->shouldReceive('foo')->with(array('yourself' => 21));
+
+ $mock->foo($testArray);
+ }
+
+ /**
+ * @expectedException Mockery\Exception\NoMatchingExpectationException
+ * @expectedExceptionMessage MyTestClass::foo(array('a_scalar'=>2,'a_closure'=>'object(Closure
+ */
+ public function testHandlesMethodWithArgumentExpectationWhenCalledWithNestedClosure()
+ {
+ $testArray = array();
+ $testArray['a_scalar'] = 2;
+ $testArray['a_closure'] = function () {
+ };
+
+ $mock = $this->container->mock('MyTestClass');
+ $mock->shouldReceive('foo')->with(array('yourself' => 21));
+
+ $mock->foo($testArray);
+ }
+
+ /**
+ * @expectedException Mockery\Exception\NoMatchingExpectationException
+ * @expectedExceptionMessage MyTestClass::foo(array('a_scalar'=>2,'a_resource'=>'resource(...)',))
+ */
+ public function testHandlesMethodWithArgumentExpectationWhenCalledWithNestedResource()
+ {
+ $testArray = array();
+ $testArray['a_scalar'] = 2;
+ $testArray['a_resource'] = fopen('php://memory', 'r');
+
+ $mock = $this->container->mock('MyTestClass');
+ $mock->shouldReceive('foo')->with(array('yourself' => 21));
+
+ $mock->foo($testArray);
+ }
+
+ /**
+ * @test
+ * @group issue/339
+ */
+ public function canMockClassesThatDescendFromInternalClasses()
+ {
+ $mock = $this->container->mock("MockeryTest_ClassThatDescendsFromInternalClass");
+ $this->assertInstanceOf("DateTime", $mock);
+ }
+
+ /**
+ * @test
+ * @group issue/339
+ */
+ public function canMockClassesThatImplementSerializable()
+ {
+ $mock = $this->container->mock("MockeryTest_ClassThatImplementsSerializable");
+ $this->assertInstanceOf("Serializable", $mock);
+ }
+
+ /**
+ * @test
+ * @group issue/346
+ */
+ public function canMockInternalClassesThatImplementSerializable()
+ {
+ $mock = $this->container->mock("ArrayObject");
+ $this->assertInstanceOf("Serializable", $mock);
+ }
+}
+
+class MockeryTest_CallStatic
+{
+ public static function __callStatic($method, $args)
+ {
+ }
+}
+
+class MockeryTest_ClassMultipleConstructorParams
+{
+ public function __construct($a, $b)
+ {
+ }
+
+ public function dave()
+ {
+ }
+}
+
+interface MockeryTest_InterfaceWithTraversable extends ArrayAccess, Traversable, Countable
+{
+ public function self();
+}
+
+class MockeryTestIsset_Bar
+{
+ public function doSomething()
+ {
+ }
+}
+
+class MockeryTestIsset_Foo
+{
+ private $var;
+
+ public function __construct($var)
+ {
+ $this->var = $var;
+ }
+
+ public function __get($name)
+ {
+ $this->var->doSomething();
+ }
+
+ public function __isset($name)
+ {
+ return (bool) strlen($this->__get($name));
+ }
+}
+
+class MockeryTest_IssetMethod
+{
+ protected $_properties = array();
+
+ public function __construct()
+ {
+ }
+
+ public function __isset($property)
+ {
+ return isset($this->_properties[$property]);
+ }
+}
+
+class MockeryTest_UnsetMethod
+{
+ protected $_properties = array();
+
+ public function __construct()
+ {
+ }
+
+ public function __unset($property)
+ {
+ unset($this->_properties[$property]);
+ }
+}
+
+class MockeryTestFoo
+{
+ public function foo()
+ {
+ return 'foo';
+ }
+}
+
+class MockeryTestFoo2
+{
+ public function foo()
+ {
+ return 'foo';
+ }
+
+ public function bar()
+ {
+ return 'bar';
+ }
+}
+
+final class MockeryFoo3
+{
+ public function foo()
+ {
+ return 'baz';
+ }
+}
+
+class MockeryFoo4
+{
+ final public function foo()
+ {
+ return 'baz';
+ }
+
+ public function bar()
+ {
+ return 'bar';
+ }
+}
+
+interface MockeryTest_Interface
+{
+}
+interface MockeryTest_Interface1
+{
+}
+interface MockeryTest_Interface2
+{
+}
+
+interface MockeryTest_InterfaceWithAbstractMethod
+{
+ public function set();
+}
+
+interface MockeryTest_InterfaceWithPublicStaticMethod
+{
+ public static function self();
+}
+
+abstract class MockeryTest_AbstractWithAbstractMethod
+{
+ abstract protected function set();
+}
+
+class MockeryTest_WithProtectedAndPrivate
+{
+ protected function protectedMethod()
+ {
+ }
+
+ private function privateMethod()
+ {
+ }
+}
+
+class MockeryTest_ClassConstructor
+{
+ public function __construct($param1)
+ {
+ }
+}
+
+class MockeryTest_ClassConstructor2
+{
+ protected $param1;
+
+ public function __construct(stdClass $param1)
+ {
+ $this->param1 = $param1;
+ }
+
+ public function getParam1()
+ {
+ return $this->param1;
+ }
+
+ public function foo()
+ {
+ return 'foo';
+ }
+
+ public function bar()
+ {
+ return $this->foo();
+ }
+}
+
+class MockeryTest_Call1
+{
+ public function __call($method, array $params)
+ {
+ }
+}
+
+class MockeryTest_Call2
+{
+ public function __call($method, $params)
+ {
+ }
+}
+
+class MockeryTest_Wakeup1
+{
+ public function __construct()
+ {
+ }
+
+ public function __wakeup()
+ {
+ }
+}
+
+class MockeryTest_ExistingProperty
+{
+ public $foo = 'bar';
+}
+
+abstract class MockeryTest_AbstractWithAbstractPublicMethod
+{
+ abstract public function foo($a, $b);
+}
+
+// issue/18
+class SoCool
+{
+ public function iDoSomethingReallyCoolHere()
+ {
+ return 3;
+ }
+}
+
+class Gateway
+{
+ public function __call($method, $args)
+ {
+ $m = new SoCool();
+ return call_user_func_array(array($m, $method), $args);
+ }
+}
+
+class MockeryTestBar1
+{
+ public function method1()
+ {
+ return $this;
+ }
+}
+
+class MockeryTest_ReturnByRef
+{
+ public $i = 0;
+
+ public function &get()
+ {
+ return $this->$i;
+ }
+}
+
+class MockeryTest_MethodParamRef
+{
+ public function method1(&$foo)
+ {
+ return true;
+ }
+}
+class MockeryTest_MethodParamRef2
+{
+ public function method1(&$foo)
+ {
+ return true;
+ }
+}
+class MockeryTestRef1
+{
+ public function foo(&$a, $b)
+ {
+ }
+}
+
+class MockeryTest_PartialNormalClass
+{
+ public function foo()
+ {
+ return 'abc';
+ }
+
+ public function bar()
+ {
+ return 'abc';
+ }
+}
+
+abstract class MockeryTest_PartialAbstractClass
+{
+ abstract public function foo();
+
+ public function bar()
+ {
+ return 'abc';
+ }
+}
+
+class MockeryTest_PartialNormalClass2
+{
+ public function foo()
+ {
+ return 'abc';
+ }
+
+ public function bar()
+ {
+ return 'abc';
+ }
+
+ public function baz()
+ {
+ return 'abc';
+ }
+}
+
+abstract class MockeryTest_PartialAbstractClass2
+{
+ abstract public function foo();
+
+ public function bar()
+ {
+ return 'abc';
+ }
+
+ abstract public function baz();
+}
+
+class MockeryTest_TestInheritedType
+{
+}
+
+if (PHP_VERSION_ID >= 50400) {
+ class MockeryTest_MockCallableTypeHint
+ {
+ public function foo(callable $baz)
+ {
+ $baz();
+ }
+
+ public function bar(callable $callback = null)
+ {
+ $callback();
+ }
+ }
+}
+
+class MockeryTest_WithToString
+{
+ public function __toString()
+ {
+ }
+}
+
+class MockeryTest_ImplementsIteratorAggregate implements IteratorAggregate
+{
+ public function getIterator()
+ {
+ return new ArrayIterator(array());
+ }
+}
+
+class MockeryTest_ImplementsIterator implements Iterator
+{
+ public function rewind()
+ {
+ }
+
+ public function current()
+ {
+ }
+
+ public function key()
+ {
+ }
+
+ public function next()
+ {
+ }
+
+ public function valid()
+ {
+ }
+}
+
+class MockeryTest_OldStyleConstructor
+{
+ public function MockeryTest_OldStyleConstructor($arg)
+ {
+ }
+}
+
+class EmptyConstructorTest
+{
+ public $numberOfConstructorArgs;
+
+ public function __construct()
+ {
+ $this->numberOfConstructorArgs = count(func_get_args());
+ }
+
+ public function foo()
+ {
+ }
+}
+
+interface MockeryTest_InterfaceWithMethodParamSelf
+{
+ public function foo(self $bar);
+}
+
+class MockeryTest_Lowercase_ToString
+{
+ public function __tostring()
+ {
+ }
+}
+
+class MockeryTest_PartialStatic
+{
+ public static function mockMe($a)
+ {
+ return $a;
+ }
+
+ public static function keepMe($b)
+ {
+ return $b;
+ }
+}
+
+class MockeryTest_MethodWithRequiredParamWithDefaultValue
+{
+ public function foo(DateTime $bar = null, $baz)
+ {
+ }
+}
+
+interface MockeryTest_InterfaceThatExtendsIterator extends Iterator
+{
+ public function foo();
+}
+
+interface MockeryTest_InterfaceThatExtendsIteratorAggregate extends IteratorAggregate
+{
+ public function foo();
+}
+
+class MockeryTest_ClassThatDescendsFromInternalClass extends DateTime
+{
+}
+
+class MockeryTest_ClassThatImplementsSerializable implements Serializable
+{
+ public function serialize()
+ {
+ }
+
+ public function unserialize($serialized)
+ {
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/DemeterChainTest.php b/vendor/mockery/mockery/tests/Mockery/DemeterChainTest.php
new file mode 100644
index 000000000..deed5eefe
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/DemeterChainTest.php
@@ -0,0 +1,170 @@
+mock */
+ private $mock;
+
+ public function setUp()
+ {
+ $this->mock = $this->mock = Mockery::mock('stdClass')->shouldIgnoreMissing();
+ }
+
+ public function tearDown()
+ {
+ $this->mock->mockery_getContainer()->mockery_close();
+ }
+
+ public function testTwoChains()
+ {
+ $this->mock->shouldReceive('getElement->getFirst')
+ ->once()
+ ->andReturn('something');
+
+ $this->mock->shouldReceive('getElement->getSecond')
+ ->once()
+ ->andReturn('somethingElse');
+
+ $this->assertEquals(
+ 'something',
+ $this->mock->getElement()->getFirst()
+ );
+ $this->assertEquals(
+ 'somethingElse',
+ $this->mock->getElement()->getSecond()
+ );
+ $this->mock->mockery_getContainer()->mockery_close();
+ }
+
+ public function testTwoChainsWithExpectedParameters()
+ {
+ $this->mock->shouldReceive('getElement->getFirst')
+ ->once()
+ ->with('parameter')
+ ->andReturn('something');
+
+ $this->mock->shouldReceive('getElement->getSecond')
+ ->once()
+ ->with('secondParameter')
+ ->andReturn('somethingElse');
+
+ $this->assertEquals(
+ 'something',
+ $this->mock->getElement()->getFirst('parameter')
+ );
+ $this->assertEquals(
+ 'somethingElse',
+ $this->mock->getElement()->getSecond('secondParameter')
+ );
+ $this->mock->mockery_getContainer()->mockery_close();
+ }
+
+ public function testThreeChains()
+ {
+ $this->mock->shouldReceive('getElement->getFirst')
+ ->once()
+ ->andReturn('something');
+
+ $this->mock->shouldReceive('getElement->getSecond')
+ ->once()
+ ->andReturn('somethingElse');
+
+ $this->assertEquals(
+ 'something',
+ $this->mock->getElement()->getFirst()
+ );
+ $this->assertEquals(
+ 'somethingElse',
+ $this->mock->getElement()->getSecond()
+ );
+ $this->mock->shouldReceive('getElement->getFirst')
+ ->once()
+ ->andReturn('somethingNew');
+ $this->assertEquals(
+ 'somethingNew',
+ $this->mock->getElement()->getFirst()
+ );
+ }
+
+ public function testManyChains()
+ {
+ $this->mock->shouldReceive('getElements->getFirst')
+ ->once()
+ ->andReturn('something');
+
+ $this->mock->shouldReceive('getElements->getSecond')
+ ->once()
+ ->andReturn('somethingElse');
+
+ $this->mock->getElements()->getFirst();
+ $this->mock->getElements()->getSecond();
+ }
+
+ public function testTwoNotRelatedChains()
+ {
+ $this->mock->shouldReceive('getElement->getFirst')
+ ->once()
+ ->andReturn('something');
+
+ $this->mock->shouldReceive('getOtherElement->getSecond')
+ ->once()
+ ->andReturn('somethingElse');
+
+ $this->assertEquals(
+ 'somethingElse',
+ $this->mock->getOtherElement()->getSecond()
+ );
+ $this->assertEquals(
+ 'something',
+ $this->mock->getElement()->getFirst()
+ );
+ }
+
+ public function testDemeterChain()
+ {
+ $this->mock->shouldReceive('getElement->getFirst')
+ ->once()
+ ->andReturn('somethingElse');
+
+ $this->assertEquals('somethingElse', $this->mock->getElement()->getFirst());
+ }
+
+ public function testMultiLevelDemeterChain()
+ {
+ $this->mock->shouldReceive('levelOne->levelTwo->getFirst')
+ ->andReturn('first');
+
+ $this->mock->shouldReceive('levelOne->levelTwo->getSecond')
+ ->andReturn('second');
+
+ $this->assertEquals(
+ 'second',
+ $this->mock->levelOne()->levelTwo()->getSecond()
+ );
+ $this->assertEquals(
+ 'first',
+ $this->mock->levelOne()->levelTwo()->getFirst()
+ );
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/ExpectationTest.php b/vendor/mockery/mockery/tests/Mockery/ExpectationTest.php
new file mode 100644
index 000000000..6d1ddf4d5
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/ExpectationTest.php
@@ -0,0 +1,2040 @@
+container = new \Mockery\Container(\Mockery::getDefaultGenerator(), \Mockery::getDefaultLoader());
+ $this->mock = $this->container->mock('foo');
+ }
+
+ public function teardown()
+ {
+ \Mockery::getConfiguration()->allowMockingNonExistentMethods(true);
+ $this->container->mockery_close();
+ }
+
+ public function testReturnsNullWhenNoArgs()
+ {
+ $this->mock->shouldReceive('foo');
+ $this->assertNull($this->mock->foo());
+ }
+
+ public function testReturnsNullWhenSingleArg()
+ {
+ $this->mock->shouldReceive('foo');
+ $this->assertNull($this->mock->foo(1));
+ }
+
+ public function testReturnsNullWhenManyArgs()
+ {
+ $this->mock->shouldReceive('foo');
+ $this->assertNull($this->mock->foo('foo', array(), new stdClass));
+ }
+
+ public function testReturnsNullIfNullIsReturnValue()
+ {
+ $this->mock->shouldReceive('foo')->andReturn(null);
+ $this->assertNull($this->mock->foo());
+ }
+
+ public function testReturnsNullForMockedExistingClassIfAndreturnnullCalled()
+ {
+ $mock = $this->container->mock('MockeryTest_Foo');
+ $mock->shouldReceive('foo')->andReturn(null);
+ $this->assertNull($mock->foo());
+ }
+
+ public function testReturnsNullForMockedExistingClassIfNullIsReturnValue()
+ {
+ $mock = $this->container->mock('MockeryTest_Foo');
+ $mock->shouldReceive('foo')->andReturnNull();
+ $this->assertNull($mock->foo());
+ }
+
+ public function testReturnsSameValueForAllIfNoArgsExpectationAndNoneGiven()
+ {
+ $this->mock->shouldReceive('foo')->andReturn(1);
+ $this->assertEquals(1, $this->mock->foo());
+ }
+
+ public function testSetsPublicPropertyWhenRequested()
+ {
+ $this->mock->bar = null;
+ $this->mock->shouldReceive('foo')->andSet('bar', 'baz');
+ $this->assertNull($this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('baz', $this->mock->bar);
+ }
+
+ public function testSetsPublicPropertyWhenRequestedUsingAlias()
+ {
+ $this->mock->bar = null;
+ $this->mock->shouldReceive('foo')->set('bar', 'baz');
+ $this->assertNull($this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('baz', $this->mock->bar);
+ }
+
+ public function testSetsPublicPropertiesWhenRequested()
+ {
+ $this->mock->bar = null;
+ $this->mock->shouldReceive('foo')->andSet('bar', 'baz', 'bazz', 'bazzz');
+ $this->assertNull($this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('baz', $this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('bazz', $this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('bazzz', $this->mock->bar);
+ }
+
+ public function testSetsPublicPropertiesWhenRequestedUsingAlias()
+ {
+ $this->mock->bar = null;
+ $this->mock->shouldReceive('foo')->set('bar', 'baz', 'bazz', 'bazzz');
+ $this->assertAttributeEmpty('bar', $this->mock);
+ $this->mock->foo();
+ $this->assertEquals('baz', $this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('bazz', $this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('bazzz', $this->mock->bar);
+ }
+
+ public function testSetsPublicPropertiesWhenRequestedMoreTimesThanSetValues()
+ {
+ $this->mock->bar = null;
+ $this->mock->shouldReceive('foo')->andSet('bar', 'baz', 'bazz');
+ $this->assertNull($this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('baz', $this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('bazz', $this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('bazz', $this->mock->bar);
+ }
+
+ public function testSetsPublicPropertiesWhenRequestedMoreTimesThanSetValuesUsingAlias()
+ {
+ $this->mock->bar = null;
+ $this->mock->shouldReceive('foo')->andSet('bar', 'baz', 'bazz');
+ $this->assertNull($this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('baz', $this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('bazz', $this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('bazz', $this->mock->bar);
+ }
+
+ public function testSetsPublicPropertiesWhenRequestedMoreTimesThanSetValuesWithDirectSet()
+ {
+ $this->mock->bar = null;
+ $this->mock->shouldReceive('foo')->andSet('bar', 'baz', 'bazz');
+ $this->assertNull($this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('baz', $this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('bazz', $this->mock->bar);
+ $this->mock->bar = null;
+ $this->mock->foo();
+ $this->assertNull($this->mock->bar);
+ }
+
+ public function testSetsPublicPropertiesWhenRequestedMoreTimesThanSetValuesWithDirectSetUsingAlias()
+ {
+ $this->mock->bar = null;
+ $this->mock->shouldReceive('foo')->set('bar', 'baz', 'bazz');
+ $this->assertNull($this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('baz', $this->mock->bar);
+ $this->mock->foo();
+ $this->assertEquals('bazz', $this->mock->bar);
+ $this->mock->bar = null;
+ $this->mock->foo();
+ $this->assertNull($this->mock->bar);
+ }
+
+ public function testReturnsSameValueForAllIfNoArgsExpectationAndSomeGiven()
+ {
+ $this->mock->shouldReceive('foo')->andReturn(1);
+ $this->assertEquals(1, $this->mock->foo('foo'));
+ }
+
+ public function testReturnsValueFromSequenceSequentially()
+ {
+ $this->mock->shouldReceive('foo')->andReturn(1, 2, 3);
+ $this->mock->foo('foo');
+ $this->assertEquals(2, $this->mock->foo('foo'));
+ }
+
+ public function testReturnsValueFromSequenceSequentiallyAndRepeatedlyReturnsFinalValueOnExtraCalls()
+ {
+ $this->mock->shouldReceive('foo')->andReturn(1, 2, 3);
+ $this->mock->foo('foo');
+ $this->mock->foo('foo');
+ $this->assertEquals(3, $this->mock->foo('foo'));
+ $this->assertEquals(3, $this->mock->foo('foo'));
+ }
+
+ public function testReturnsValueFromSequenceSequentiallyAndRepeatedlyReturnsFinalValueOnExtraCallsWithManyAndReturnCalls()
+ {
+ $this->mock->shouldReceive('foo')->andReturn(1)->andReturn(2, 3);
+ $this->mock->foo('foo');
+ $this->mock->foo('foo');
+ $this->assertEquals(3, $this->mock->foo('foo'));
+ $this->assertEquals(3, $this->mock->foo('foo'));
+ }
+
+ public function testReturnsValueOfClosure()
+ {
+ $this->mock->shouldReceive('foo')->with(5)->andReturnUsing(function ($v) {return $v+1;});
+ $this->assertEquals(6, $this->mock->foo(5));
+ }
+
+ public function testReturnsUndefined()
+ {
+ $this->mock->shouldReceive('foo')->andReturnUndefined();
+ $this->assertTrue($this->mock->foo() instanceof \Mockery\Undefined);
+ }
+
+ public function testReturnsValuesSetAsArray()
+ {
+ $this->mock->shouldReceive('foo')->andReturnValues(array(1, 2, 3));
+ $this->assertEquals(1, $this->mock->foo());
+ $this->assertEquals(2, $this->mock->foo());
+ $this->assertEquals(3, $this->mock->foo());
+ }
+
+ /**
+ * @expectedException OutOfBoundsException
+ */
+ public function testThrowsException()
+ {
+ $this->mock->shouldReceive('foo')->andThrow(new OutOfBoundsException);
+ $this->mock->foo();
+ }
+
+ /**
+ * @expectedException OutOfBoundsException
+ */
+ public function testThrowsExceptionBasedOnArgs()
+ {
+ $this->mock->shouldReceive('foo')->andThrow('OutOfBoundsException');
+ $this->mock->foo();
+ }
+
+ public function testThrowsExceptionBasedOnArgsWithMessage()
+ {
+ $this->mock->shouldReceive('foo')->andThrow('OutOfBoundsException', 'foo');
+ try {
+ $this->mock->foo();
+ } catch (OutOfBoundsException $e) {
+ $this->assertEquals('foo', $e->getMessage());
+ }
+ }
+
+ /**
+ * @expectedException OutOfBoundsException
+ */
+ public function testThrowsExceptionSequentially()
+ {
+ $this->mock->shouldReceive('foo')->andThrow(new Exception)->andThrow(new OutOfBoundsException);
+ try {
+ $this->mock->foo();
+ } catch (Exception $e) {
+ }
+ $this->mock->foo();
+ }
+
+ public function testAndThrowExceptions()
+ {
+ $this->mock->shouldReceive('foo')->andThrowExceptions(array(
+ new OutOfBoundsException,
+ new InvalidArgumentException,
+ ));
+
+ try {
+ $this->mock->foo();
+ throw new Exception("Expected OutOfBoundsException, non thrown");
+ } catch (\Exception $e) {
+ $this->assertInstanceOf("OutOfBoundsException", $e, "Wrong or no exception thrown: {$e->getMessage()}");
+ }
+
+ try {
+ $this->mock->foo();
+ throw new Exception("Expected InvalidArgumentException, non thrown");
+ } catch (\Exception $e) {
+ $this->assertInstanceOf("InvalidArgumentException", $e, "Wrong or no exception thrown: {$e->getMessage()}");
+ }
+ }
+
+ /**
+ * @expectedException Mockery\Exception
+ * @expectedExceptionMessage You must pass an array of exception objects to andThrowExceptions
+ */
+ public function testAndThrowExceptionsCatchNonExceptionArgument()
+ {
+ $this->mock
+ ->shouldReceive('foo')
+ ->andThrowExceptions(array('NotAnException'));
+ }
+
+ public function testMultipleExpectationsWithReturns()
+ {
+ $this->mock->shouldReceive('foo')->with(1)->andReturn(10);
+ $this->mock->shouldReceive('bar')->with(2)->andReturn(20);
+ $this->assertEquals(10, $this->mock->foo(1));
+ $this->assertEquals(20, $this->mock->bar(2));
+ }
+
+ public function testExpectsNoArguments()
+ {
+ $this->mock->shouldReceive('foo')->withNoArgs();
+ $this->mock->foo();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testExpectsNoArgumentsThrowsExceptionIfAnyPassed()
+ {
+ $this->mock->shouldReceive('foo')->withNoArgs();
+ $this->mock->foo(1);
+ }
+
+ public function testExpectsArgumentsArray()
+ {
+ $this->mock->shouldReceive('foo')->withArgs(array(1, 2));
+ $this->mock->foo(1, 2);
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testExpectsArgumentsArrayThrowsExceptionIfPassedEmptyArray()
+ {
+ $this->mock->shouldReceive('foo')->withArgs(array());
+ $this->mock->foo(1, 2);
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testExpectsArgumentsArrayThrowsExceptionIfNoArgumentsPassed()
+ {
+ $this->mock->shouldReceive('foo')->with();
+ $this->mock->foo(1);
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testExpectsArgumentsArrayThrowsExceptionIfPassedWrongArguments()
+ {
+ $this->mock->shouldReceive('foo')->withArgs(array(1, 2));
+ $this->mock->foo(3, 4);
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ * @expectedExceptionMessageRegExp /foo\(NULL\)/
+ */
+ public function testExpectsStringArgumentExceptionMessageDifferentiatesBetweenNullAndEmptyString()
+ {
+ $this->mock->shouldReceive('foo')->withArgs(array('a string'));
+ $this->mock->foo(null);
+ }
+
+ public function testExpectsAnyArguments()
+ {
+ $this->mock->shouldReceive('foo')->withAnyArgs();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 'k', new stdClass);
+ }
+
+ public function testExpectsArgumentMatchingRegularExpression()
+ {
+ $this->mock->shouldReceive('foo')->with('/bar/i');
+ $this->mock->foo('xxBARxx');
+ }
+
+ public function testExpectsArgumentMatchingObjectType()
+ {
+ $this->mock->shouldReceive('foo')->with('\stdClass');
+ $this->mock->foo(new stdClass);
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testThrowsExceptionOnNoArgumentMatch()
+ {
+ $this->mock->shouldReceive('foo')->with(1);
+ $this->mock->foo(2);
+ }
+
+ public function testNeverCalled()
+ {
+ $this->mock->shouldReceive('foo')->never();
+ $this->container->mockery_verify();
+ }
+
+ public function testShouldNotReceive()
+ {
+ $this->mock->shouldNotReceive('foo');
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception\InvalidCountException
+ */
+ public function testShouldNotReceiveThrowsExceptionIfMethodCalled()
+ {
+ $this->mock->shouldNotReceive('foo');
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception\InvalidCountException
+ */
+ public function testShouldNotReceiveWithArgumentThrowsExceptionIfMethodCalled()
+ {
+ $this->mock->shouldNotReceive('foo')->with(2);
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testNeverCalledThrowsExceptionOnCall()
+ {
+ $this->mock->shouldReceive('foo')->never();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testCalledOnce()
+ {
+ $this->mock->shouldReceive('foo')->once();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testCalledOnceThrowsExceptionIfNotCalled()
+ {
+ $this->mock->shouldReceive('foo')->once();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testCalledOnceThrowsExceptionIfCalledTwice()
+ {
+ $this->mock->shouldReceive('foo')->once();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testCalledTwice()
+ {
+ $this->mock->shouldReceive('foo')->twice();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testCalledTwiceThrowsExceptionIfNotCalled()
+ {
+ $this->mock->shouldReceive('foo')->twice();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testCalledOnceThrowsExceptionIfCalledThreeTimes()
+ {
+ $this->mock->shouldReceive('foo')->twice();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testCalledZeroOrMoreTimesAtZeroCalls()
+ {
+ $this->mock->shouldReceive('foo')->zeroOrMoreTimes();
+ $this->container->mockery_verify();
+ }
+
+ public function testCalledZeroOrMoreTimesAtThreeCalls()
+ {
+ $this->mock->shouldReceive('foo')->zeroOrMoreTimes();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testTimesCountCalls()
+ {
+ $this->mock->shouldReceive('foo')->times(4);
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testTimesCountCallThrowsExceptionOnTooFewCalls()
+ {
+ $this->mock->shouldReceive('foo')->times(2);
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testTimesCountCallThrowsExceptionOnTooManyCalls()
+ {
+ $this->mock->shouldReceive('foo')->times(2);
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testCalledAtLeastOnceAtExactlyOneCall()
+ {
+ $this->mock->shouldReceive('foo')->atLeast()->once();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testCalledAtLeastOnceAtExactlyThreeCalls()
+ {
+ $this->mock->shouldReceive('foo')->atLeast()->times(3);
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testCalledAtLeastThrowsExceptionOnTooFewCalls()
+ {
+ $this->mock->shouldReceive('foo')->atLeast()->twice();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testCalledAtMostOnceAtExactlyOneCall()
+ {
+ $this->mock->shouldReceive('foo')->atMost()->once();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testCalledAtMostAtExactlyThreeCalls()
+ {
+ $this->mock->shouldReceive('foo')->atMost()->times(3);
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testCalledAtLeastThrowsExceptionOnTooManyCalls()
+ {
+ $this->mock->shouldReceive('foo')->atMost()->twice();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testExactCountersOverrideAnyPriorSetNonExactCounters()
+ {
+ $this->mock->shouldReceive('foo')->atLeast()->once()->once();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testComboOfLeastAndMostCallsWithOneCall()
+ {
+ $this->mock->shouldReceive('foo')->atleast()->once()->atMost()->twice();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testComboOfLeastAndMostCallsWithTwoCalls()
+ {
+ $this->mock->shouldReceive('foo')->atleast()->once()->atMost()->twice();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testComboOfLeastAndMostCallsThrowsExceptionAtTooFewCalls()
+ {
+ $this->mock->shouldReceive('foo')->atleast()->once()->atMost()->twice();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testComboOfLeastAndMostCallsThrowsExceptionAtTooManyCalls()
+ {
+ $this->mock->shouldReceive('foo')->atleast()->once()->atMost()->twice();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testCallCountingOnlyAppliesToMatchedExpectations()
+ {
+ $this->mock->shouldReceive('foo')->with(1)->once();
+ $this->mock->shouldReceive('foo')->with(2)->twice();
+ $this->mock->shouldReceive('foo')->with(3);
+ $this->mock->foo(1);
+ $this->mock->foo(2);
+ $this->mock->foo(2);
+ $this->mock->foo(3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testCallCountingThrowsExceptionOnAnyMismatch()
+ {
+ $this->mock->shouldReceive('foo')->with(1)->once();
+ $this->mock->shouldReceive('foo')->with(2)->twice();
+ $this->mock->shouldReceive('foo')->with(3);
+ $this->mock->shouldReceive('bar');
+ $this->mock->foo(1);
+ $this->mock->foo(2);
+ $this->mock->foo(3);
+ $this->mock->bar();
+ $this->container->mockery_verify();
+ }
+
+ public function testOrderedCallsWithoutError()
+ {
+ $this->mock->shouldReceive('foo')->ordered();
+ $this->mock->shouldReceive('bar')->ordered();
+ $this->mock->foo();
+ $this->mock->bar();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testOrderedCallsWithOutOfOrderError()
+ {
+ $this->mock->shouldReceive('foo')->ordered();
+ $this->mock->shouldReceive('bar')->ordered();
+ $this->mock->bar();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testDifferentArgumentsAndOrderingsPassWithoutException()
+ {
+ $this->mock->shouldReceive('foo')->with(1)->ordered();
+ $this->mock->shouldReceive('foo')->with(2)->ordered();
+ $this->mock->foo(1);
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testDifferentArgumentsAndOrderingsThrowExceptionWhenInWrongOrder()
+ {
+ $this->mock->shouldReceive('foo')->with(1)->ordered();
+ $this->mock->shouldReceive('foo')->with(2)->ordered();
+ $this->mock->foo(2);
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+
+ public function testUnorderedCallsIgnoredForOrdering()
+ {
+ $this->mock->shouldReceive('foo')->with(1)->ordered();
+ $this->mock->shouldReceive('foo')->with(2);
+ $this->mock->shouldReceive('foo')->with(3)->ordered();
+ $this->mock->foo(2);
+ $this->mock->foo(1);
+ $this->mock->foo(2);
+ $this->mock->foo(3);
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ public function testOrderingOfDefaultGrouping()
+ {
+ $this->mock->shouldReceive('foo')->ordered();
+ $this->mock->shouldReceive('bar')->ordered();
+ $this->mock->foo();
+ $this->mock->bar();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testOrderingOfDefaultGroupingThrowsExceptionOnWrongOrder()
+ {
+ $this->mock->shouldReceive('foo')->ordered();
+ $this->mock->shouldReceive('bar')->ordered();
+ $this->mock->bar();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testOrderingUsingNumberedGroups()
+ {
+ $this->mock->shouldReceive('start')->ordered(1);
+ $this->mock->shouldReceive('foo')->ordered(2);
+ $this->mock->shouldReceive('bar')->ordered(2);
+ $this->mock->shouldReceive('final')->ordered();
+ $this->mock->start();
+ $this->mock->bar();
+ $this->mock->foo();
+ $this->mock->bar();
+ $this->mock->final();
+ $this->container->mockery_verify();
+ }
+
+ public function testOrderingUsingNamedGroups()
+ {
+ $this->mock->shouldReceive('start')->ordered('start');
+ $this->mock->shouldReceive('foo')->ordered('foobar');
+ $this->mock->shouldReceive('bar')->ordered('foobar');
+ $this->mock->shouldReceive('final')->ordered();
+ $this->mock->start();
+ $this->mock->bar();
+ $this->mock->foo();
+ $this->mock->bar();
+ $this->mock->final();
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @group 2A
+ */
+ public function testGroupedUngroupedOrderingDoNotOverlap()
+ {
+ $s = $this->mock->shouldReceive('start')->ordered();
+ $m = $this->mock->shouldReceive('mid')->ordered('foobar');
+ $e = $this->mock->shouldReceive('end')->ordered();
+ $this->assertTrue($s->getOrderNumber() < $m->getOrderNumber());
+ $this->assertTrue($m->getOrderNumber() < $e->getOrderNumber());
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testGroupedOrderingThrowsExceptionWhenCallsDisordered()
+ {
+ $this->mock->shouldReceive('foo')->ordered('first');
+ $this->mock->shouldReceive('bar')->ordered('second');
+ $this->mock->bar();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testExpectationMatchingWithNoArgsOrderings()
+ {
+ $this->mock->shouldReceive('foo')->withNoArgs()->once()->ordered();
+ $this->mock->shouldReceive('bar')->withNoArgs()->once()->ordered();
+ $this->mock->shouldReceive('foo')->withNoArgs()->once()->ordered();
+ $this->mock->foo();
+ $this->mock->bar();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testExpectationMatchingWithAnyArgsOrderings()
+ {
+ $this->mock->shouldReceive('foo')->withAnyArgs()->once()->ordered();
+ $this->mock->shouldReceive('bar')->withAnyArgs()->once()->ordered();
+ $this->mock->shouldReceive('foo')->withAnyArgs()->once()->ordered();
+ $this->mock->foo();
+ $this->mock->bar();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testEnsuresOrderingIsNotCrossMockByDefault()
+ {
+ $this->mock->shouldReceive('foo')->ordered();
+ $mock2 = $this->container->mock('bar');
+ $mock2->shouldReceive('bar')->ordered();
+ $mock2->bar();
+ $this->mock->foo();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testEnsuresOrderingIsCrossMockWhenGloballyFlagSet()
+ {
+ $this->mock->shouldReceive('foo')->globally()->ordered();
+ $mock2 = $this->container->mock('bar');
+ $mock2->shouldReceive('bar')->globally()->ordered();
+ $mock2->bar();
+ $this->mock->foo();
+ }
+
+ public function testExpectationCastToStringFormatting()
+ {
+ $exp = $this->mock->shouldReceive('foo')->with(1, 'bar', new stdClass, array('Spam' => 'Ham', 'Bar' => 'Baz'));
+ $this->assertEquals('[foo(1, "bar", object(stdClass), array(\'Spam\'=>\'Ham\',\'Bar\'=>\'Baz\',))]', (string) $exp);
+ }
+
+ public function testLongExpectationCastToStringFormatting()
+ {
+ $exp = $this->mock->shouldReceive('foo')->with(array('Spam' => 'Ham', 'Bar' => 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'Bar', 'Baz', 'End'));
+ $this->assertEquals("[foo(array('Spam'=>'Ham','Bar'=>'Baz',0=>'Bar',1=>'Baz',2=>'Bar',3=>'Baz',4=>'Bar',5=>'Baz',6=>'Bar',7=>'Baz',8=>'Bar',9=>'Baz',10=>'Bar',11=>'Baz',12=>'Bar',13=>'Baz',14=>'Bar',15=>'Baz',16=>'Bar',17=>'Baz',18=>'Bar',19=>'Baz',20=>'Bar',21=>'Baz',22=>'Bar',23=>'Baz',24=>'Bar',25=>'Baz',26=>'Bar',27=>'Baz',28=>'Bar',29=>'Baz',30=>'Bar',31=>'Baz',32=>'Bar',33=>'Baz',34=>'Bar',35=>'Baz',36=>'Bar',37=>'Baz',38=>'Bar',39=>'Baz',40=>'Bar',41=>'Baz',42=>'Bar',43=>'Baz',44=>'Bar',45=>'Baz',46=>'Baz',47=>'Bar',48=>'Baz',49=>'Bar',50=>'Baz',51=>'Bar',52=>'Baz',53=>'Bar',54=>'Baz',55=>'Bar',56=>'Baz',57=>'Baz',58=>'Bar',59=>'Baz',60=>'Bar',61=>'Baz',62=>'Bar',63=>'Baz',64=>'Bar',65=>'Baz',66=>'Bar',67=>'Baz',68=>'Baz',69=>'Bar',70=>'Baz',71=>'Bar',72=>'Baz',73=>'Bar',74=>'Baz',75=>'Bar',76=>'Baz',77=>'Bar',78=>'Baz',79=>'Baz',80=>'Bar',81=>'Baz',82=>'Bar',83=>'Baz',84=>'Bar',85=>'Baz',86=>'Bar',87=>'Baz',88=>'Bar',89=>'Baz',90=>'Baz',91=>'Bar',92=>'Baz',93=>'Bar',94=>'Baz',95=>'Bar',96=>'Baz',97=>'Ba...))]", (string) $exp);
+ }
+
+ public function testMultipleExpectationCastToStringFormatting()
+ {
+ $exp = $this->mock->shouldReceive('foo', 'bar')->with(1);
+ $this->assertEquals('[foo(1), bar(1)]', (string) $exp);
+ }
+
+ public function testGroupedOrderingWithLimitsAllowsMultipleReturnValues()
+ {
+ $this->mock->shouldReceive('foo')->with(2)->once()->andReturn('first');
+ $this->mock->shouldReceive('foo')->with(2)->twice()->andReturn('second/third');
+ $this->mock->shouldReceive('foo')->with(2)->andReturn('infinity');
+ $this->assertEquals('first', $this->mock->foo(2));
+ $this->assertEquals('second/third', $this->mock->foo(2));
+ $this->assertEquals('second/third', $this->mock->foo(2));
+ $this->assertEquals('infinity', $this->mock->foo(2));
+ $this->assertEquals('infinity', $this->mock->foo(2));
+ $this->assertEquals('infinity', $this->mock->foo(2));
+ $this->container->mockery_verify();
+ }
+
+ public function testExpectationsCanBeMarkedAsDefaults()
+ {
+ $this->mock->shouldReceive('foo')->andReturn('bar')->byDefault();
+ $this->assertEquals('bar', $this->mock->foo());
+ $this->container->mockery_verify();
+ }
+
+ public function testDefaultExpectationsValidatedInCorrectOrder()
+ {
+ $this->mock->shouldReceive('foo')->with(1)->once()->andReturn('first')->byDefault();
+ $this->mock->shouldReceive('foo')->with(2)->once()->andReturn('second')->byDefault();
+ $this->assertEquals('first', $this->mock->foo(1));
+ $this->assertEquals('second', $this->mock->foo(2));
+ $this->container->mockery_verify();
+ }
+
+ public function testDefaultExpectationsAreReplacedByLaterConcreteExpectations()
+ {
+ $this->mock->shouldReceive('foo')->andReturn('bar')->once()->byDefault();
+ $this->mock->shouldReceive('foo')->andReturn('bar')->twice();
+ $this->mock->foo();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testDefaultExpectationsCanBeChangedByLaterExpectations()
+ {
+ $this->mock->shouldReceive('foo')->with(1)->andReturn('bar')->once()->byDefault();
+ $this->mock->shouldReceive('foo')->with(2)->andReturn('baz')->once();
+ try {
+ $this->mock->foo(1);
+ $this->fail('Expected exception not thrown');
+ } catch (\Mockery\Exception $e) {
+ }
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testDefaultExpectationsCanBeOrdered()
+ {
+ $this->mock->shouldReceive('foo')->ordered()->byDefault();
+ $this->mock->shouldReceive('bar')->ordered()->byDefault();
+ $this->mock->bar();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testDefaultExpectationsCanBeOrderedAndReplaced()
+ {
+ $this->mock->shouldReceive('foo')->ordered()->byDefault();
+ $this->mock->shouldReceive('bar')->ordered()->byDefault();
+ $this->mock->shouldReceive('bar')->ordered();
+ $this->mock->shouldReceive('foo')->ordered();
+ $this->mock->bar();
+ $this->mock->foo();
+ $this->container->mockery_verify();
+ }
+
+ public function testByDefaultOperatesFromMockConstruction()
+ {
+ $container = new \Mockery\Container(\Mockery::getDefaultGenerator(), \Mockery::getDefaultLoader());
+ $mock = $container->mock('f', array('foo'=>'rfoo', 'bar'=>'rbar', 'baz'=>'rbaz'))->byDefault();
+ $mock->shouldReceive('foo')->andReturn('foobar');
+ $this->assertEquals('foobar', $mock->foo());
+ $this->assertEquals('rbar', $mock->bar());
+ $this->assertEquals('rbaz', $mock->baz());
+ $mock->mockery_verify();
+ }
+
+ public function testByDefaultOnAMockDoesSquatWithoutExpectations()
+ {
+ $container = new \Mockery\Container(\Mockery::getDefaultGenerator(), \Mockery::getDefaultLoader());
+ $mock = $container->mock('f')->byDefault();
+ }
+
+ public function testDefaultExpectationsCanBeOverridden()
+ {
+ $this->mock->shouldReceive('foo')->with('test')->andReturn('bar')->byDefault();
+ $this->mock->shouldReceive('foo')->with('test')->andReturn('newbar')->byDefault();
+ $this->mock->foo('test');
+ $this->assertEquals('newbar', $this->mock->foo('test'));
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testByDefaultPreventedFromSettingDefaultWhenDefaultingExpectationWasReplaced()
+ {
+ $exp = $this->mock->shouldReceive('foo')->andReturn(1);
+ $this->mock->shouldReceive('foo')->andReturn(2);
+ $exp->byDefault();
+ }
+
+ /**
+ * Argument Constraint Tests
+ */
+
+ public function testAnyConstraintMatchesAnyArg()
+ {
+ $this->mock->shouldReceive('foo')->with(1, Mockery::any())->twice();
+ $this->mock->foo(1, 2);
+ $this->mock->foo(1, 'str');
+ $this->container->mockery_verify();
+ }
+
+ public function testAnyConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::any())->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ public function testArrayConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('array'))->once();
+ $this->mock->foo(array());
+ $this->container->mockery_verify();
+ }
+
+ public function testArrayConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('array'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testArrayConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('array'))->once();
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+
+ public function testBoolConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('bool'))->once();
+ $this->mock->foo(true);
+ $this->container->mockery_verify();
+ }
+
+ public function testBoolConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('bool'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testBoolConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('bool'))->once();
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+
+ public function testCallableConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('callable'))->once();
+ $this->mock->foo(function () {return 'f';});
+ $this->container->mockery_verify();
+ }
+
+ public function testCallableConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('callable'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testCallableConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('callable'))->once();
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+
+ public function testDoubleConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('double'))->once();
+ $this->mock->foo(2.25);
+ $this->container->mockery_verify();
+ }
+
+ public function testDoubleConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('double'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testDoubleConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('double'))->once();
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+
+ public function testFloatConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('float'))->once();
+ $this->mock->foo(2.25);
+ $this->container->mockery_verify();
+ }
+
+ public function testFloatConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('float'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testFloatConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('float'))->once();
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+
+ public function testIntConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('int'))->once();
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ public function testIntConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('int'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testIntConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('int'))->once();
+ $this->mock->foo('f');
+ $this->container->mockery_verify();
+ }
+
+ public function testLongConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('long'))->once();
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ public function testLongConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('long'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testLongConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('long'))->once();
+ $this->mock->foo('f');
+ $this->container->mockery_verify();
+ }
+
+ public function testNullConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('null'))->once();
+ $this->mock->foo(null);
+ $this->container->mockery_verify();
+ }
+
+ public function testNullConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('null'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testNullConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('null'))->once();
+ $this->mock->foo('f');
+ $this->container->mockery_verify();
+ }
+
+ public function testNumericConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('numeric'))->once();
+ $this->mock->foo('2');
+ $this->container->mockery_verify();
+ }
+
+ public function testNumericConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('numeric'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testNumericConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('numeric'))->once();
+ $this->mock->foo('f');
+ $this->container->mockery_verify();
+ }
+
+ public function testObjectConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('stdClass'))->once();
+ $this->mock->foo(new stdClass);
+ $this->container->mockery_verify();
+ }
+
+ public function testObjectConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('stdClass`'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testObjectConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('stdClass'))->once();
+ $this->mock->foo('f');
+ $this->container->mockery_verify();
+ }
+
+ public function testRealConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('real'))->once();
+ $this->mock->foo(2.25);
+ $this->container->mockery_verify();
+ }
+
+ public function testRealConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('real'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testRealConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('real'))->once();
+ $this->mock->foo('f');
+ $this->container->mockery_verify();
+ }
+
+ public function testResourceConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('resource'))->once();
+ $r = fopen(dirname(__FILE__) . '/_files/file.txt', 'r');
+ $this->mock->foo($r);
+ $this->container->mockery_verify();
+ }
+
+ public function testResourceConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('resource'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testResourceConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('resource'))->once();
+ $this->mock->foo('f');
+ $this->container->mockery_verify();
+ }
+
+ public function testScalarConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('scalar'))->once();
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ public function testScalarConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('scalar'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testScalarConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('scalar'))->once();
+ $this->mock->foo(array());
+ $this->container->mockery_verify();
+ }
+
+ public function testStringConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('string'))->once();
+ $this->mock->foo('2');
+ $this->container->mockery_verify();
+ }
+
+ public function testStringConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('string'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testStringConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('string'))->once();
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+
+ public function testClassConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('stdClass'))->once();
+ $this->mock->foo(new stdClass);
+ $this->container->mockery_verify();
+ }
+
+ public function testClassConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::type('stdClass'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testClassConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::type('stdClass'))->once();
+ $this->mock->foo(new Exception);
+ $this->container->mockery_verify();
+ }
+
+ public function testDucktypeConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::ducktype('quack', 'swim'))->once();
+ $this->mock->foo(new Mockery_Duck);
+ $this->container->mockery_verify();
+ }
+
+ public function testDucktypeConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::ducktype('quack', 'swim'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testDucktypeConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::ducktype('quack', 'swim'))->once();
+ $this->mock->foo(new Mockery_Duck_Nonswimmer);
+ $this->container->mockery_verify();
+ }
+
+ public function testArrayContentConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::subset(array('a'=>1, 'b'=>2)))->once();
+ $this->mock->foo(array('a'=>1, 'b'=>2, 'c'=>3));
+ $this->container->mockery_verify();
+ }
+
+ public function testArrayContentConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::subset(array('a'=>1, 'b'=>2)))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testArrayContentConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::subset(array('a'=>1, 'b'=>2)))->once();
+ $this->mock->foo(array('a'=>1, 'c'=>3));
+ $this->container->mockery_verify();
+ }
+
+ public function testContainsConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::contains(1, 2))->once();
+ $this->mock->foo(array('a'=>1, 'b'=>2, 'c'=>3));
+ $this->container->mockery_verify();
+ }
+
+ public function testContainsConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::contains(1, 2))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testContainsConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::contains(1, 2))->once();
+ $this->mock->foo(array('a'=>1, 'c'=>3));
+ $this->container->mockery_verify();
+ }
+
+ public function testHasKeyConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::hasKey('c'))->once();
+ $this->mock->foo(array('a'=>1, 'b'=>2, 'c'=>3));
+ $this->container->mockery_verify();
+ }
+
+ public function testHasKeyConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::hasKey('a'))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, array('a'=>1), 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testHasKeyConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::hasKey('c'))->once();
+ $this->mock->foo(array('a'=>1, 'b'=>3));
+ $this->container->mockery_verify();
+ }
+
+ public function testHasValueConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::hasValue(1))->once();
+ $this->mock->foo(array('a'=>1, 'b'=>2, 'c'=>3));
+ $this->container->mockery_verify();
+ }
+
+ public function testHasValueConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::hasValue(1))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, array('a'=>1), 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testHasValueConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::hasValue(2))->once();
+ $this->mock->foo(array('a'=>1, 'b'=>3));
+ $this->container->mockery_verify();
+ }
+
+ public function testOnConstraintMatchesArgument_ClosureEvaluatesToTrue()
+ {
+ $function = function ($arg) {return $arg % 2 == 0;};
+ $this->mock->shouldReceive('foo')->with(Mockery::on($function))->once();
+ $this->mock->foo(4);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testOnConstraintThrowsExceptionWhenConstraintUnmatched_ClosureEvaluatesToFalse()
+ {
+ $function = function ($arg) {return $arg % 2 == 0;};
+ $this->mock->shouldReceive('foo')->with(Mockery::on($function))->once();
+ $this->mock->foo(5);
+ $this->container->mockery_verify();
+ }
+
+ public function testMustBeConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::mustBe(2))->once();
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ public function testMustBeConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::mustBe(2))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testMustBeConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::mustBe(2))->once();
+ $this->mock->foo('2');
+ $this->container->mockery_verify();
+ }
+
+ public function testMustBeConstraintMatchesObjectArgumentWithEqualsComparisonNotIdentical()
+ {
+ $a = new stdClass;
+ $a->foo = 1;
+ $b = new stdClass;
+ $b->foo = 1;
+ $this->mock->shouldReceive('foo')->with(Mockery::mustBe($a))->once();
+ $this->mock->foo($b);
+ $this->container->mockery_verify();
+ }
+
+ public function testMustBeConstraintNonMatchingCaseWithObject()
+ {
+ $a = new stdClass;
+ $a->foo = 1;
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::mustBe($a))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, $a, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testMustBeConstraintThrowsExceptionWhenConstraintUnmatchedWithObject()
+ {
+ $a = new stdClass;
+ $a->foo = 1;
+ $b = new stdClass;
+ $b->foo = 2;
+ $this->mock->shouldReceive('foo')->with(Mockery::mustBe($a))->once();
+ $this->mock->foo($b);
+ $this->container->mockery_verify();
+ }
+
+ public function testMatchPrecedenceBasedOnExpectedCallsFavouringExplicitMatch()
+ {
+ $this->mock->shouldReceive('foo')->with(1)->once();
+ $this->mock->shouldReceive('foo')->with(Mockery::any())->never();
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+
+ public function testMatchPrecedenceBasedOnExpectedCallsFavouringAnyMatch()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::any())->once();
+ $this->mock->shouldReceive('foo')->with(1)->never();
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+
+ public function testReturnNullIfIgnoreMissingMethodsSet()
+ {
+ $this->mock->shouldIgnoreMissing();
+ $this->assertNull($this->mock->g(1, 2));
+ }
+
+ public function testReturnUndefinedIfIgnoreMissingMethodsSet()
+ {
+ $this->mock->shouldIgnoreMissing()->asUndefined();
+ $this->assertTrue($this->mock->g(1, 2) instanceof \Mockery\Undefined);
+ }
+
+ public function testReturnAsUndefinedAllowsForInfiniteSelfReturningChain()
+ {
+ $this->mock->shouldIgnoreMissing()->asUndefined();
+ $this->assertTrue($this->mock->g(1, 2)->a()->b()->c() instanceof \Mockery\Undefined);
+ }
+
+ public function testShouldIgnoreMissingFluentInterface()
+ {
+ $this->assertTrue($this->mock->shouldIgnoreMissing() instanceof \Mockery\MockInterface);
+ }
+
+ public function testShouldIgnoreMissingAsUndefinedFluentInterface()
+ {
+ $this->assertTrue($this->mock->shouldIgnoreMissing()->asUndefined() instanceof \Mockery\MockInterface);
+ }
+
+ public function testShouldIgnoreMissingAsDefinedProxiesToUndefinedAllowingToString()
+ {
+ $this->mock->shouldIgnoreMissing()->asUndefined();
+ $string = "Method call: {$this->mock->g()}";
+ $string = "Mock: {$this->mock}";
+ }
+
+ public function testShouldIgnoreMissingDefaultReturnValue()
+ {
+ $this->mock->shouldIgnoreMissing(1);
+ $this->assertEquals(1, $this->mock->a());
+ }
+
+ /** @issue #253 */
+ public function testShouldIgnoreMissingDefaultSelfAndReturnsSelf()
+ {
+ $this->mock->shouldIgnoreMissing($this->container->self());
+ $this->assertSame($this->mock, $this->mock->a()->b());
+ }
+
+ public function testToStringMagicMethodCanBeMocked()
+ {
+ $this->mock->shouldReceive("__toString")->andReturn('dave');
+ $this->assertEquals("{$this->mock}", "dave");
+ }
+
+ public function testOptionalMockRetrieval()
+ {
+ $m = $this->container->mock('f')->shouldReceive('foo')->with(1)->andReturn(3)->mock();
+ $this->assertTrue($m instanceof \Mockery\MockInterface);
+ }
+
+ public function testNotConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::not(1))->once();
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ public function testNotConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::not(2))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testNotConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::not(2))->once();
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ public function testAnyOfConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::anyOf(1, 2))->twice();
+ $this->mock->foo(2);
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+
+ public function testAnyOfConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::anyOf(1, 2))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 2, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testAnyOfConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::anyOf(1, 2))->once();
+ $this->mock->foo(3);
+ $this->container->mockery_verify();
+ }
+
+ public function testNotAnyOfConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::notAnyOf(1, 2))->once();
+ $this->mock->foo(3);
+ $this->container->mockery_verify();
+ }
+
+ public function testNotAnyOfConstraintNonMatchingCase()
+ {
+ $this->mock->shouldReceive('foo')->times(3);
+ $this->mock->shouldReceive('foo')->with(1, Mockery::notAnyOf(1, 2))->never();
+ $this->mock->foo();
+ $this->mock->foo(1);
+ $this->mock->foo(1, 4, 3);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testNotAnyOfConstraintThrowsExceptionWhenConstraintUnmatched()
+ {
+ $this->mock->shouldReceive('foo')->with(Mockery::notAnyOf(1, 2))->once();
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testGlobalConfigMayForbidMockingNonExistentMethodsOnClasses()
+ {
+ \Mockery::getConfiguration()->allowMockingNonExistentMethods(false);
+ $mock = $this->container->mock('stdClass');
+ $mock->shouldReceive('foo');
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ * @expectedExceptionMessage Mockery's configuration currently forbids mocking
+ */
+ public function testGlobalConfigMayForbidMockingNonExistentMethodsOnAutoDeclaredClasses()
+ {
+ \Mockery::getConfiguration()->allowMockingNonExistentMethods(false);
+ $mock = $this->container->mock('SomeMadeUpClass');
+ $mock->shouldReceive('foo');
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testGlobalConfigMayForbidMockingNonExistentMethodsOnObjects()
+ {
+ \Mockery::getConfiguration()->allowMockingNonExistentMethods(false);
+ $mock = $this->container->mock(new stdClass);
+ $mock->shouldReceive('foo');
+ }
+
+ public function testAnExampleWithSomeExpectationAmends()
+ {
+ $service = $this->container->mock('MyService');
+ $service->shouldReceive('login')->with('user', 'pass')->once()->andReturn(true);
+ $service->shouldReceive('hasBookmarksTagged')->with('php')->once()->andReturn(false);
+ $service->shouldReceive('addBookmark')->with('/^http:/', \Mockery::type('string'))->times(3)->andReturn(true);
+ $service->shouldReceive('hasBookmarksTagged')->with('php')->once()->andReturn(true);
+
+ $this->assertTrue($service->login('user', 'pass'));
+ $this->assertFalse($service->hasBookmarksTagged('php'));
+ $this->assertTrue($service->addBookmark('http://example.com/1', 'some_tag1'));
+ $this->assertTrue($service->addBookmark('http://example.com/2', 'some_tag2'));
+ $this->assertTrue($service->addBookmark('http://example.com/3', 'some_tag3'));
+ $this->assertTrue($service->hasBookmarksTagged('php'));
+
+ $this->container->mockery_verify();
+ }
+
+ public function testAnExampleWithSomeExpectationAmendsOnCallCounts()
+ {
+ $service = $this->container->mock('MyService');
+ $service->shouldReceive('login')->with('user', 'pass')->once()->andReturn(true);
+ $service->shouldReceive('hasBookmarksTagged')->with('php')->once()->andReturn(false);
+ $service->shouldReceive('addBookmark')->with('/^http:/', \Mockery::type('string'))->times(3)->andReturn(true);
+ $service->shouldReceive('hasBookmarksTagged')->with('php')->twice()->andReturn(true);
+
+ $this->assertTrue($service->login('user', 'pass'));
+ $this->assertFalse($service->hasBookmarksTagged('php'));
+ $this->assertTrue($service->addBookmark('http://example.com/1', 'some_tag1'));
+ $this->assertTrue($service->addBookmark('http://example.com/2', 'some_tag2'));
+ $this->assertTrue($service->addBookmark('http://example.com/3', 'some_tag3'));
+ $this->assertTrue($service->hasBookmarksTagged('php'));
+ $this->assertTrue($service->hasBookmarksTagged('php'));
+
+ $this->container->mockery_verify();
+ }
+
+ public function testAnExampleWithSomeExpectationAmendsOnCallCounts_PHPUnitTest()
+ {
+ $service = $this->getMock('MyService2');
+ $service->expects($this->once())->method('login')->with('user', 'pass')->will($this->returnValue(true));
+ $service->expects($this->exactly(3))->method('hasBookmarksTagged')->with('php')
+ ->will($this->onConsecutiveCalls(false, true, true));
+ $service->expects($this->exactly(3))->method('addBookmark')
+ ->with($this->matchesRegularExpression('/^http:/'), $this->isType('string'))
+ ->will($this->returnValue(true));
+
+ $this->assertTrue($service->login('user', 'pass'));
+ $this->assertFalse($service->hasBookmarksTagged('php'));
+ $this->assertTrue($service->addBookmark('http://example.com/1', 'some_tag1'));
+ $this->assertTrue($service->addBookmark('http://example.com/2', 'some_tag2'));
+ $this->assertTrue($service->addBookmark('http://example.com/3', 'some_tag3'));
+ $this->assertTrue($service->hasBookmarksTagged('php'));
+ $this->assertTrue($service->hasBookmarksTagged('php'));
+ }
+
+ public function testMockedMethodsCallableFromWithinOriginalClass()
+ {
+ $mock = $this->container->mock('MockeryTest_InterMethod1[doThird]');
+ $mock->shouldReceive('doThird')->andReturn(true);
+ $this->assertTrue($mock->doFirst());
+ }
+
+ /**
+ * @group issue #20
+ */
+ public function testMockingDemeterChainsPassesMockeryExpectationToCompositeExpectation()
+ {
+ $mock = $this->container->mock('Mockery_Demeterowski');
+ $mock->shouldReceive('foo->bar->baz')->andReturn('Spam!');
+ $demeter = new Mockery_UseDemeter($mock);
+ $this->assertSame('Spam!', $demeter->doit());
+ }
+
+ /**
+ * @group issue #20 - with args in demeter chain
+ */
+ public function testMockingDemeterChainsPassesMockeryExpectationToCompositeExpectationWithArgs()
+ {
+ $mock = $this->container->mock('Mockery_Demeterowski');
+ $mock->shouldReceive('foo->bar->baz')->andReturn('Spam!');
+ $demeter = new Mockery_UseDemeter($mock);
+ $this->assertSame('Spam!', $demeter->doitWithArgs());
+ }
+
+ public function testPassthruEnsuresRealMethodCalledForReturnValues()
+ {
+ $mock = $this->container->mock('MockeryTest_SubjectCall1');
+ $mock->shouldReceive('foo')->once()->passthru();
+ $this->assertEquals('bar', $mock->foo());
+ $this->container->mockery_verify();
+ }
+
+ public function testShouldIgnoreMissingExpectationBasedOnArgs()
+ {
+ $mock = $this->container->mock("MyService2")->shouldIgnoreMissing();
+ $mock->shouldReceive("hasBookmarksTagged")->with("dave")->once();
+ $mock->hasBookmarksTagged("dave");
+ $mock->hasBookmarksTagged("padraic");
+ $this->container->mockery_verify();
+ }
+
+ public function testShouldDeferMissingExpectationBasedOnArgs()
+ {
+ $mock = $this->container->mock("MockeryTest_SubjectCall1")->shouldDeferMissing();
+
+ $this->assertEquals('bar', $mock->foo());
+ $this->assertEquals('bar', $mock->foo("baz"));
+ $this->assertEquals('bar', $mock->foo("qux"));
+
+ $mock->shouldReceive("foo")->with("baz")->twice()->andReturn('123');
+ $this->assertEquals('bar', $mock->foo());
+ $this->assertEquals('123', $mock->foo("baz"));
+ $this->assertEquals('bar', $mock->foo("qux"));
+
+ $mock->shouldReceive("foo")->withNoArgs()->once()->andReturn('456');
+ $this->assertEquals('456', $mock->foo());
+ $this->assertEquals('123', $mock->foo("baz"));
+ $this->assertEquals('bar', $mock->foo("qux"));
+
+ $this->container->mockery_verify();
+ }
+
+ public function testCanReturnSelf()
+ {
+ $this->mock->shouldReceive("foo")->andReturnSelf();
+ $this->assertSame($this->mock, $this->mock->foo());
+ }
+
+ public function testExpectationCanBeOverridden()
+ {
+ $this->mock->shouldReceive('foo')->once()->andReturn('green');
+ $this->mock->shouldReceive('foo')->andReturn('blue');
+ $this->assertEquals($this->mock->foo(), 'green');
+ $this->assertEquals($this->mock->foo(), 'blue');
+ }
+}
+
+class MockeryTest_SubjectCall1
+{
+ public function foo()
+ {
+ return 'bar';
+ }
+}
+
+class MockeryTest_InterMethod1
+{
+ public function doFirst()
+ {
+ return $this->doSecond();
+ }
+
+ private function doSecond()
+ {
+ return $this->doThird();
+ }
+
+ public function doThird()
+ {
+ return false;
+ }
+}
+
+class MyService2
+{
+ public function login($user, $pass)
+ {
+ }
+ public function hasBookmarksTagged($tag)
+ {
+ }
+ public function addBookmark($uri, $tag)
+ {
+ }
+}
+
+class Mockery_Duck
+{
+ public function quack()
+ {
+ }
+ public function swim()
+ {
+ }
+}
+
+class Mockery_Duck_Nonswimmer
+{
+ public function quack()
+ {
+ }
+}
+
+class Mockery_Demeterowski
+{
+ public function foo()
+ {
+ return $this;
+ }
+ public function bar()
+ {
+ return $this;
+ }
+ public function baz()
+ {
+ return 'Ham!';
+ }
+}
+
+class Mockery_UseDemeter
+{
+ public function __construct($demeter)
+ {
+ $this->demeter = $demeter;
+ }
+ public function doit()
+ {
+ return $this->demeter->foo()->bar()->baz();
+ }
+ public function doitWithArgs()
+ {
+ return $this->demeter->foo("foo")->bar("bar")->baz("baz");
+ }
+}
+
+class MockeryTest_Foo
+{
+ public function foo()
+ {
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/Fixtures/MethodWithNullableParameters.php b/vendor/mockery/mockery/tests/Mockery/Fixtures/MethodWithNullableParameters.php
new file mode 100644
index 000000000..17700e7e6
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/Fixtures/MethodWithNullableParameters.php
@@ -0,0 +1,49 @@
+assertTrue($target->hasInternalAncestor());
+
+ $target = new DefinedTargetClass(new \ReflectionClass("Mockery\MockeryTest_ClassThatExtendsArrayObject"));
+ $this->assertTrue($target->hasInternalAncestor());
+
+ $target = new DefinedTargetClass(new \ReflectionClass("Mockery\DefinedTargetClassTest"));
+ $this->assertFalse($target->hasInternalAncestor());
+ }
+}
+
+class MockeryTest_ClassThatExtendsArrayObject extends \ArrayObject
+{
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/Generator/MockConfigurationTest.php b/vendor/mockery/mockery/tests/Mockery/Generator/MockConfigurationTest.php
new file mode 100644
index 000000000..12aee9cad
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/Generator/MockConfigurationTest.php
@@ -0,0 +1,197 @@
+getMethodsToMock();
+ $this->assertEquals(1, count($methods));
+ $this->assertEquals("bar", $methods[0]->getName());
+ }
+
+ /**
+ * @test
+ */
+ public function blackListsAreCaseInsensitive()
+ {
+ $config = new MockConfiguration(array("Mockery\Generator\\TestSubject"), array("FOO"));
+
+ $methods = $config->getMethodsToMock();
+ $this->assertEquals(1, count($methods));
+ $this->assertEquals("bar", $methods[0]->getName());
+ }
+
+
+ /**
+ * @test
+ */
+ public function onlyWhiteListedMethodsShouldBeInListToBeMocked()
+ {
+ $config = new MockConfiguration(array("Mockery\Generator\\TestSubject"), array(), array('foo'));
+
+ $methods = $config->getMethodsToMock();
+ $this->assertEquals(1, count($methods));
+ $this->assertEquals("foo", $methods[0]->getName());
+ }
+
+ /**
+ * @test
+ */
+ public function whitelistOverRulesBlackList()
+ {
+ $config = new MockConfiguration(array("Mockery\Generator\\TestSubject"), array("foo"), array("foo"));
+
+ $methods = $config->getMethodsToMock();
+ $this->assertEquals(1, count($methods));
+ $this->assertEquals("foo", $methods[0]->getName());
+ }
+
+ /**
+ * @test
+ */
+ public function whiteListsAreCaseInsensitive()
+ {
+ $config = new MockConfiguration(array("Mockery\Generator\\TestSubject"), array(), array("FOO"));
+
+ $methods = $config->getMethodsToMock();
+ $this->assertEquals(1, count($methods));
+ $this->assertEquals("foo", $methods[0]->getName());
+ }
+
+ /**
+ * @test
+ */
+ public function finalMethodsAreExcluded()
+ {
+ $config = new MockConfiguration(array("Mockery\Generator\\ClassWithFinalMethod"));
+
+ $methods = $config->getMethodsToMock();
+ $this->assertEquals(1, count($methods));
+ $this->assertEquals("bar", $methods[0]->getName());
+ }
+
+ /**
+ * @test
+ */
+ public function shouldIncludeMethodsFromAllTargets()
+ {
+ $config = new MockConfiguration(array("Mockery\\Generator\\TestInterface", "Mockery\\Generator\\TestInterface2"));
+ $methods = $config->getMethodsToMock();
+ $this->assertEquals(2, count($methods));
+ }
+
+ /**
+ * @test
+ * @expectedException Mockery\Exception
+ */
+ public function shouldThrowIfTargetClassIsFinal()
+ {
+ $config = new MockConfiguration(array("Mockery\\Generator\\TestFinal"));
+ $config->getTargetClass();
+ }
+
+ /**
+ * @test
+ */
+ public function shouldTargetIteratorAggregateIfTryingToMockTraversable()
+ {
+ $config = new MockConfiguration(array("\\Traversable"));
+
+ $interfaces = $config->getTargetInterfaces();
+ $this->assertEquals(1, count($interfaces));
+ $first = array_shift($interfaces);
+ $this->assertEquals("IteratorAggregate", $first->getName());
+ }
+
+ /**
+ * @test
+ */
+ public function shouldTargetIteratorAggregateIfTraversableInTargetsTree()
+ {
+ $config = new MockConfiguration(array("Mockery\Generator\TestTraversableInterface"));
+
+ $interfaces = $config->getTargetInterfaces();
+ $this->assertEquals(2, count($interfaces));
+ $this->assertEquals("IteratorAggregate", $interfaces[0]->getName());
+ $this->assertEquals("Mockery\Generator\TestTraversableInterface", $interfaces[1]->getName());
+ }
+
+ /**
+ * @test
+ */
+ public function shouldBringIteratorToHeadOfTargetListIfTraversablePresent()
+ {
+ $config = new MockConfiguration(array("Mockery\Generator\TestTraversableInterface2"));
+
+ $interfaces = $config->getTargetInterfaces();
+ $this->assertEquals(2, count($interfaces));
+ $this->assertEquals("Iterator", $interfaces[0]->getName());
+ $this->assertEquals("Mockery\Generator\TestTraversableInterface2", $interfaces[1]->getName());
+ }
+
+ /**
+ * @test
+ */
+ public function shouldBringIteratorAggregateToHeadOfTargetListIfTraversablePresent()
+ {
+ $config = new MockConfiguration(array("Mockery\Generator\TestTraversableInterface3"));
+
+ $interfaces = $config->getTargetInterfaces();
+ $this->assertEquals(2, count($interfaces));
+ $this->assertEquals("IteratorAggregate", $interfaces[0]->getName());
+ $this->assertEquals("Mockery\Generator\TestTraversableInterface3", $interfaces[1]->getName());
+ }
+}
+
+interface TestTraversableInterface extends \Traversable
+{
+}
+interface TestTraversableInterface2 extends \Traversable, \Iterator
+{
+}
+interface TestTraversableInterface3 extends \Traversable, \IteratorAggregate
+{
+}
+
+final class TestFinal
+{
+}
+
+interface TestInterface
+{
+ public function foo();
+}
+
+interface TestInterface2
+{
+ public function bar();
+}
+
+class TestSubject
+{
+ public function foo()
+ {
+ }
+
+ public function bar()
+ {
+ }
+}
+
+class ClassWithFinalMethod
+{
+ final public function foo()
+ {
+ }
+
+ public function bar()
+ {
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/CallTypeHintPassTest.php b/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/CallTypeHintPassTest.php
new file mode 100644
index 000000000..a8bb1551e
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/CallTypeHintPassTest.php
@@ -0,0 +1,39 @@
+ true,
+ ))->shouldDeferMissing();
+ $code = $pass->apply(static::CODE, $config);
+ $this->assertContains('__call($method, $args)', $code);
+ }
+
+ /**
+ * @test
+ */
+ public function shouldRemoveCallStaticTypeHintIfRequired()
+ {
+ $pass = new CallTypeHintPass;
+ $config = m::mock("Mockery\Generator\MockConfiguration", array(
+ "requiresCallStaticTypeHintRemoval" => true,
+ ))->shouldDeferMissing();
+ $code = $pass->apply(static::CODE, $config);
+ $this->assertContains('__callStatic($method, $args)', $code);
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/ClassNamePassTest.php b/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/ClassNamePassTest.php
new file mode 100644
index 000000000..e283cce1f
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/ClassNamePassTest.php
@@ -0,0 +1,58 @@
+pass = new ClassNamePass();
+ }
+
+ /**
+ * @test
+ */
+ public function shouldRemoveNamespaceDefinition()
+ {
+ $config = new MockConfiguration(array(), array(), array(), "Dave\Dave");
+ $code = $this->pass->apply(static::CODE, $config);
+ $this->assertNotContains('namespace Mockery;', $code);
+ }
+
+ /**
+ * @test
+ */
+ public function shouldReplaceNamespaceIfClassNameIsNamespaced()
+ {
+ $config = new MockConfiguration(array(), array(), array(), "Dave\Dave");
+ $code = $this->pass->apply(static::CODE, $config);
+ $this->assertNotContains('namespace Mockery;', $code);
+ $this->assertContains('namespace Dave;', $code);
+ }
+
+ /**
+ * @test
+ */
+ public function shouldReplaceClassNameWithSpecifiedName()
+ {
+ $config = new MockConfiguration(array(), array(), array(), "Dave");
+ $code = $this->pass->apply(static::CODE, $config);
+ $this->assertContains('class Dave', $code);
+ }
+
+ /**
+ * @test
+ */
+ public function shouldRemoveLeadingBackslashesFromNamespace()
+ {
+ $config = new MockConfiguration(array(), array(), array(), "\Dave\Dave");
+ $code = $this->pass->apply(static::CODE, $config);
+ $this->assertContains('namespace Dave;', $code);
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/InstanceMockPassTest.php b/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/InstanceMockPassTest.php
new file mode 100644
index 000000000..23493de80
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/InstanceMockPassTest.php
@@ -0,0 +1,24 @@
+setInstanceMock(true);
+ $config = $builder->getMockConfiguration();
+ $pass = new InstanceMockPass;
+ $code = $pass->apply('class Dave { }', $config);
+ $this->assertContains('public function __construct', $code);
+ $this->assertContains('protected $_mockery_ignoreVerification', $code);
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/InterfacePassTest.php b/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/InterfacePassTest.php
new file mode 100644
index 000000000..ff248ca48
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/Generator/StringManipulation/Pass/InterfacePassTest.php
@@ -0,0 +1,46 @@
+ array(),
+ ));
+
+ $code = $pass->apply(static::CODE, $config);
+ $this->assertEquals(static::CODE, $code);
+ }
+
+ /**
+ * @test
+ */
+ public function shouldAddAnyInterfaceNamesToImplementsDefinition()
+ {
+ $pass = new InterfacePass;
+
+ $config = m::mock("Mockery\Generator\MockConfiguration", array(
+ "getTargetInterfaces" => array(
+ m::mock(array("getName" => "Dave\Dave")),
+ m::mock(array("getName" => "Paddy\Paddy")),
+ ),
+ ));
+
+ $code = $pass->apply(static::CODE, $config);
+
+ $this->assertContains("implements MockInterface, \Dave\Dave, \Paddy\Paddy", $code);
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/GlobalHelpersTest.php b/vendor/mockery/mockery/tests/Mockery/GlobalHelpersTest.php
new file mode 100644
index 000000000..57c667cb8
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/GlobalHelpersTest.php
@@ -0,0 +1,63 @@
+assertInstanceOf('Mockery\MockInterface', $double);
+ $this->setExpectedException('Exception');
+ $double->foo();
+ }
+
+ /** @test */
+ public function spy_creates_a_spy()
+ {
+ $double = spy();
+
+ $this->assertInstanceOf('Mockery\MockInterface', $double);
+ $double->foo();
+ }
+
+ /** @test */
+ public function named_mock_creates_a_named_mock()
+ {
+ $className = "Class".uniqid();
+ $double = namedMock($className);
+
+ $this->assertInstanceOf('Mockery\MockInterface', $double);
+ $this->assertInstanceOf($className, $double);
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/HamcrestExpectationTest.php b/vendor/mockery/mockery/tests/Mockery/HamcrestExpectationTest.php
new file mode 100644
index 000000000..07f702e69
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/HamcrestExpectationTest.php
@@ -0,0 +1,65 @@
+container = new \Mockery\Container(\Mockery::getDefaultGenerator(), \Mockery::getDefaultLoader());
+ $this->mock = $this->container->mock('foo');
+ }
+
+
+ public function tearDown()
+ {
+ \Mockery::getConfiguration()->allowMockingNonExistentMethods(true);
+ $this->container->mockery_close();
+ }
+
+ /** Just a quickie roundup of a few Hamcrest matchers to check nothing obvious out of place **/
+
+ public function testAnythingConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(anything())->once();
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ public function testGreaterThanConstraintMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(greaterThan(1))->once();
+ $this->mock->foo(2);
+ $this->container->mockery_verify();
+ }
+
+ /**
+ * @expectedException Mockery\Exception
+ */
+ public function testGreaterThanConstraintNotMatchesArgument()
+ {
+ $this->mock->shouldReceive('foo')->with(greaterThan(1))->once();
+ $this->mock->foo(1);
+ $this->container->mockery_verify();
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/Loader/EvalLoaderTest.php b/vendor/mockery/mockery/tests/Mockery/Loader/EvalLoaderTest.php
new file mode 100644
index 000000000..6081df4a8
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/Loader/EvalLoaderTest.php
@@ -0,0 +1,16 @@
+getLoader()->load($definition);
+
+ $this->assertTrue(class_exists($className));
+ }
+
+ abstract public function getLoader();
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/Loader/RequireLoaderTest.php b/vendor/mockery/mockery/tests/Mockery/Loader/RequireLoaderTest.php
new file mode 100644
index 000000000..1d32abb38
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/Loader/RequireLoaderTest.php
@@ -0,0 +1,16 @@
+register();
+ $expected = array($loader, 'loadClass');
+ $this->assertTrue(in_array($expected, spl_autoload_functions()));
+ }
+
+ public function tearDown()
+ {
+ spl_autoload_unregister('\Mockery\Loader::loadClass');
+ $loader = new \Mockery\Loader;
+ $loader->register();
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockClassWithFinalWakeupTest.php b/vendor/mockery/mockery/tests/Mockery/MockClassWithFinalWakeupTest.php
new file mode 100644
index 000000000..c2cb278c5
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockClassWithFinalWakeupTest.php
@@ -0,0 +1,96 @@
+
+ * @license http://github.com/padraic/mockery/blob/master/LICENSE New BSD License
+ */
+
+namespace test\Mockery;
+
+use Mockery\Adapter\Phpunit\MockeryTestCase;
+
+class MockClassWithFinalWakeupTest extends MockeryTestCase
+{
+
+ protected function setUp()
+ {
+ $this->container = new \Mockery\Container;
+ }
+
+ protected function tearDown()
+ {
+ $this->container->mockery_close();
+ }
+
+ /**
+ * @test
+ *
+ * Test that we are able to create partial mocks of classes that have
+ * a __wakeup method marked as final. As long as __wakeup is not one of the
+ * mocked methods.
+ */
+ public function testCreateMockForClassWithFinalWakeup()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithFinalWakeup");
+ $this->assertInstanceOf("test\Mockery\TestWithFinalWakeup", $mock);
+ $this->assertEquals('test\Mockery\TestWithFinalWakeup::__wakeup', $mock->__wakeup());
+
+ $mock = $this->container->mock('test\Mockery\SubclassWithFinalWakeup');
+ $this->assertInstanceOf('test\Mockery\SubclassWithFinalWakeup', $mock);
+ $this->assertEquals('test\Mockery\TestWithFinalWakeup::__wakeup', $mock->__wakeup());
+ }
+
+ public function testCreateMockForClassWithNonFinalWakeup()
+ {
+ $mock = $this->container->mock('test\Mockery\TestWithNonFinalWakeup');
+ $this->assertInstanceOf('test\Mockery\TestWithNonFinalWakeup', $mock);
+
+ // Make sure __wakeup is overridden and doesn't return anything.
+ $this->assertNull($mock->__wakeup());
+ }
+}
+
+class TestWithFinalWakeup
+{
+
+ public function foo()
+ {
+ return 'foo';
+ }
+
+ public function bar()
+ {
+ return 'bar';
+ }
+
+ final public function __wakeup()
+ {
+ return __METHOD__;
+ }
+}
+
+class SubclassWithFinalWakeup extends TestWithFinalWakeup
+{
+}
+
+class TestWithNonFinalWakeup
+{
+ public function __wakeup()
+ {
+ return __METHOD__;
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockClassWithUnknownTypeHintTest.php b/vendor/mockery/mockery/tests/Mockery/MockClassWithUnknownTypeHintTest.php
new file mode 100644
index 000000000..b2a59f762
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockClassWithUnknownTypeHintTest.php
@@ -0,0 +1,45 @@
+container = new \Mockery\Container;
+ }
+
+ protected function tearDown()
+ {
+ $this->container->mockery_close();
+ }
+
+ /** @test */
+ public function itShouldSuccessfullyBuildTheMock()
+ {
+ $this->container->mock("test\Mockery\HasUnknownClassAsTypeHintOnMethod");
+ }
+}
+
+class HasUnknownClassAsTypeHintOnMethod
+{
+ public function foo(\UnknownTestClass\Bar $bar)
+ {
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockTest.php b/vendor/mockery/mockery/tests/Mockery/MockTest.php
new file mode 100644
index 000000000..b9932cb55
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockTest.php
@@ -0,0 +1,193 @@
+container = new \Mockery\Container(\Mockery::getDefaultGenerator(), \Mockery::getDefaultLoader());
+ }
+
+ public function teardown()
+ {
+ $this->container->mockery_close();
+ }
+
+ public function testAnonymousMockWorksWithNotAllowingMockingOfNonExistentMethods()
+ {
+ \Mockery::getConfiguration()->allowMockingNonExistentMethods(false);
+ $m = $this->container->mock();
+ $m->shouldReceive("test123")->andReturn(true);
+ assertThat($m->test123(), equalTo(true));
+ \Mockery::getConfiguration()->allowMockingNonExistentMethods(true);
+ }
+
+ public function testMockWithNotAllowingMockingOfNonExistentMethodsCanBeGivenAdditionalMethodsToMockEvenIfTheyDontExistOnClass()
+ {
+ \Mockery::getConfiguration()->allowMockingNonExistentMethods(false);
+ $m = $this->container->mock('ExampleClassForTestingNonExistentMethod');
+ $m->shouldAllowMockingMethod('testSomeNonExistentMethod');
+ $m->shouldReceive("testSomeNonExistentMethod")->andReturn(true);
+ assertThat($m->testSomeNonExistentMethod(), equalTo(true));
+ \Mockery::getConfiguration()->allowMockingNonExistentMethods(true);
+ }
+
+ public function testShouldAllowMockingMethodReturnsMockInstance()
+ {
+ $m = Mockery::mock('someClass');
+ $this->assertInstanceOf('Mockery\MockInterface', $m->shouldAllowMockingMethod('testFunction'));
+ }
+
+ public function testShouldAllowMockingProtectedMethodReturnsMockInstance()
+ {
+ $m = Mockery::mock('someClass');
+ $this->assertInstanceOf('Mockery\MockInterface', $m->shouldAllowMockingProtectedMethods('testFunction'));
+ }
+
+ public function testMockAddsToString()
+ {
+ $mock = $this->container->mock('ClassWithNoToString');
+ assertThat(hasToString($mock));
+ }
+
+ public function testMockToStringMayBeDeferred()
+ {
+ $mock = $this->container->mock('ClassWithToString')->shouldDeferMissing();
+ assertThat((string)$mock, equalTo("foo"));
+ }
+
+ public function testMockToStringShouldIgnoreMissingAlwaysReturnsString()
+ {
+ $mock = $this->container->mock('ClassWithNoToString')->shouldIgnoreMissing();
+ assertThat(isNonEmptyString((string)$mock));
+
+ $mock->asUndefined();
+ assertThat(isNonEmptyString((string)$mock));
+ }
+
+ public function testShouldIgnoreMissing()
+ {
+ $mock = $this->container->mock('ClassWithNoToString')->shouldIgnoreMissing();
+ assertThat(nullValue($mock->nonExistingMethod()));
+ }
+
+ public function testShouldIgnoreDebugInfo()
+ {
+ $mock = $this->container->mock('ClassWithDebugInfo');
+
+ $mock->__debugInfo();
+ }
+
+ /**
+ * @expectedException Mockery\Exception
+ */
+ public function testShouldIgnoreMissingDisallowMockingNonExistentMethodsUsingGlobalConfiguration()
+ {
+ Mockery::getConfiguration()->allowMockingNonExistentMethods(false);
+ $mock = $this->container->mock('ClassWithMethods')->shouldIgnoreMissing();
+ $mock->shouldReceive('nonExistentMethod');
+ }
+
+ /**
+ * @expectedException BadMethodCallException
+ */
+ public function testShouldIgnoreMissingCallingNonExistentMethodsUsingGlobalConfiguration()
+ {
+ Mockery::getConfiguration()->allowMockingNonExistentMethods(false);
+ $mock = $this->container->mock('ClassWithMethods')->shouldIgnoreMissing();
+ $mock->nonExistentMethod();
+ }
+
+ public function testShouldIgnoreMissingCallingExistentMethods()
+ {
+ Mockery::getConfiguration()->allowMockingNonExistentMethods(false);
+ $mock = $this->container->mock('ClassWithMethods')->shouldIgnoreMissing();
+ assertThat(nullValue($mock->foo()));
+ $mock->shouldReceive('bar')->passthru();
+ assertThat($mock->bar(), equalTo('bar'));
+ }
+
+ public function testShouldIgnoreMissingCallingNonExistentMethods()
+ {
+ Mockery::getConfiguration()->allowMockingNonExistentMethods(true);
+ $mock = $this->container->mock('ClassWithMethods')->shouldIgnoreMissing();
+ assertThat(nullValue($mock->foo()));
+ assertThat(nullValue($mock->bar()));
+ assertThat(nullValue($mock->nonExistentMethod()));
+
+ $mock->shouldReceive(array('foo' => 'new_foo', 'nonExistentMethod' => 'result'));
+ $mock->shouldReceive('bar')->passthru();
+ assertThat($mock->foo(), equalTo('new_foo'));
+ assertThat($mock->bar(), equalTo('bar'));
+ assertThat($mock->nonExistentMethod(), equalTo('result'));
+ }
+
+ public function testCanMockException()
+ {
+ $exception = Mockery::mock('Exception');
+ $this->assertInstanceOf('Exception', $exception);
+ }
+}
+
+
+class ExampleClassForTestingNonExistentMethod
+{
+}
+
+class ClassWithToString
+{
+ public function __toString()
+ {
+ return 'foo';
+ }
+}
+
+class ClassWithNoToString
+{
+}
+
+class ClassWithMethods
+{
+ public function foo()
+ {
+ return 'foo';
+ }
+
+ public function bar()
+ {
+ return 'bar';
+ }
+}
+
+class ClassWithDebugInfo
+{
+ public function __debugInfo()
+ {
+ return array('test' => 'test');
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockeryCanMockMultipleInterfacesWhichOverlapTest.php b/vendor/mockery/mockery/tests/Mockery/MockeryCanMockMultipleInterfacesWhichOverlapTest.php
new file mode 100644
index 000000000..ac09ed449
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockeryCanMockMultipleInterfacesWhichOverlapTest.php
@@ -0,0 +1,66 @@
+mock('Mockery\Tests\Evenement_EventEmitter', 'Mockery\Tests\Chatroulette_ConnectionInterface');
+ }
+}
+
+interface Evenement_EventEmitterInterface
+{
+ public function on($name, $callback);
+}
+
+class Evenement_EventEmitter implements Evenement_EventEmitterInterface
+{
+ public function on($name, $callback)
+ {
+ }
+}
+
+interface React_StreamInterface extends Evenement_EventEmitterInterface
+{
+ public function close();
+}
+
+interface React_ReadableStreamInterface extends React_StreamInterface
+{
+ public function pause();
+}
+
+interface React_WritableStreamInterface extends React_StreamInterface
+{
+ public function write($data);
+}
+
+interface Chatroulette_ConnectionInterface extends React_ReadableStreamInterface, React_WritableStreamInterface
+{
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockingInternalModuleClassWithOptionalParameterByReferenceTest.php b/vendor/mockery/mockery/tests/Mockery/MockingInternalModuleClassWithOptionalParameterByReferenceTest.php
new file mode 100644
index 000000000..11c3ae555
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockingInternalModuleClassWithOptionalParameterByReferenceTest.php
@@ -0,0 +1,69 @@
+markTestSkipped('ext/memcache not installed');
+ }
+ parent::setUp();
+ }
+
+ protected function tearDown()
+ {
+ static::closeMockery();
+ parent::tearDown();
+ }
+
+ /**
+ * Regression for {@see https://github.com/mockery/mockery/issues/757 issue#757}
+ *
+ * @test
+ */
+ public function mockingInternalModuleClassWithOptionalParameterByReferenceMayNotBreakCodeGeneration()
+ {
+ // this works for macOS
+ \Mockery::getConfiguration()
+ ->setInternalClassMethodParamMap('Memcache', 'get', array('$id', '&$flags = null'));
+ // strange thing is, the reflected class under linux is MemcachePool not Memcache
+ \Mockery::getConfiguration()
+ ->setInternalClassMethodParamMap('MemcachePool', 'get', array('$id', '&$flags = null'));
+ $memcache = \Mockery::mock('Memcache');
+ $memcache->shouldReceive('get')
+ ->with(
+ $id = 'foobar',
+ \Mockery::on(
+ function (&$flags) {
+ $valid = null === $flags;
+ $flags = 255;
+ return $valid;
+ }
+ )
+ )
+ ->once()
+ ->andReturn($expected = time());
+ $paramFlags = null;
+ $this->assertSame($expected, $memcache->get($id, $paramFlags));
+ \Mockery::close();
+ $this->assertSame(255, $paramFlags);
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockingMethodsWithNullableParametersTest.php b/vendor/mockery/mockery/tests/Mockery/MockingMethodsWithNullableParametersTest.php
new file mode 100644
index 000000000..1e0836405
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockingMethodsWithNullableParametersTest.php
@@ -0,0 +1,185 @@
+container = new \Mockery\Container;
+ }
+
+ protected function tearDown()
+ {
+ $this->container->mockery_close();
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowNonNullableTypeToBeSet()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->shouldReceive('nonNullablePrimitive')->with('a string');
+ $mock->nonNullablePrimitive('a string');
+ }
+
+ /**
+ * @test
+ * @expectedException \TypeError
+ */
+ public function itShouldNotAllowNonNullToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->nonNullablePrimitive(null);
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowPrimitiveNullableToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->shouldReceive('nullablePrimitive')->with(null);
+ $mock->nullablePrimitive(null);
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowPrimitiveNullabeToBeSet()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->shouldReceive('nullablePrimitive')->with('a string');
+ $mock->nullablePrimitive('a string');
+ }
+ /**
+ * @test
+ */
+ public function itShouldAllowSelfToBeSet()
+ {
+ $obj = new \test\Mockery\Fixtures\MethodWithNullableParameters;
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->shouldReceive('nonNullableSelf')->with($obj);
+ $mock->nonNullableSelf($obj);
+ }
+
+ /**
+ * @test
+ * @expectedException \TypeError
+ */
+ public function itShouldNotAllowSelfToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->nonNullableSelf(null);
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowNullalbeSelfToBeSet()
+ {
+ $obj = new \test\Mockery\Fixtures\MethodWithNullableParameters;
+
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->shouldReceive('nullableSelf')->with($obj);
+ $mock->nullableSelf($obj);
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowNullableSelfToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->shouldReceive('nullableClass')->with(null);
+ $mock->nullableClass(null);
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowClassToBeSet()
+ {
+ $obj = new \test\Mockery\Fixtures\MethodWithNullableParameters;
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->shouldReceive('nonNullableClass')->with($obj);
+ $mock->nonNullableClass($obj);
+ }
+
+ /**
+ * @test
+ * @expectedException \TypeError
+ */
+ public function itShouldNotAllowClassToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->nonNullableClass(null);
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowNullalbeClassToBeSet()
+ {
+ $obj = new \test\Mockery\Fixtures\MethodWithNullableParameters;
+
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->shouldReceive('nullableClass')->with($obj);
+ $mock->nullableClass($obj);
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowNullableClassToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableParameters');
+
+ $mock->shouldReceive('nullableClass')->with(null);
+ $mock->nullableClass(null);
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockingNullableMethodsTest.php b/vendor/mockery/mockery/tests/Mockery/MockingNullableMethodsTest.php
new file mode 100644
index 000000000..26fbd3fd5
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockingNullableMethodsTest.php
@@ -0,0 +1,184 @@
+container = new \Mockery\Container;
+ }
+
+ protected function tearDown()
+ {
+ $this->container->mockery_close();
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowNonNullableTypeToBeSet()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nonNullablePrimitive')->andReturn('a string');
+ $mock->nonNullablePrimitive();
+ }
+
+ /**
+ * @test
+ * @expectedException \TypeError
+ */
+ public function itShouldNotAllowNonNullToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nonNullablePrimitive')->andReturn(null);
+ $mock->nonNullablePrimitive();
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowPrimitiveNullableToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nullablePrimitive')->andReturn(null);
+ $mock->nullablePrimitive();
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowPrimitiveNullabeToBeSet()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nullablePrimitive')->andReturn('a string');
+ $mock->nullablePrimitive();
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowSelfToBeSet()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nonNullableSelf')->andReturn(new MethodWithNullableReturnType());
+ $mock->nonNullableSelf();
+ }
+
+ /**
+ * @test
+ * @expectedException \TypeError
+ */
+ public function itShouldNotAllowSelfToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nonNullableSelf')->andReturn(null);
+ $mock->nonNullableSelf();
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowNullableSelfToBeSet()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nullableSelf')->andReturn(new MethodWithNullableReturnType());
+ $mock->nullableSelf();
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowNullableSelfToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nullableSelf')->andReturn(null);
+ $mock->nullableSelf();
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowClassToBeSet()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nonNullableClass')->andReturn(new MethodWithNullableReturnType());
+ $mock->nonNullableClass();
+ }
+
+ /**
+ * @test
+ * @expectedException \TypeError
+ */
+ public function itShouldNotAllowClassToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nonNullableClass')->andReturn(null);
+ $mock->nonNullableClass();
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowNullalbeClassToBeSet()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nullableClass')->andReturn(new MethodWithNullableReturnType());
+ $mock->nullableClass();
+ }
+
+ /**
+ * @test
+ */
+ public function itShouldAllowNullableClassToBeNull()
+ {
+ $mock = $this->container->mock('test\Mockery\Fixtures\MethodWithNullableReturnType');
+
+ $mock->shouldReceive('nullableClass')->andReturn(null);
+ $mock->nullableClass();
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockingParameterAndReturnTypesTest.php b/vendor/mockery/mockery/tests/Mockery/MockingParameterAndReturnTypesTest.php
new file mode 100644
index 000000000..d4cb36cd7
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockingParameterAndReturnTypesTest.php
@@ -0,0 +1,151 @@
+container = new \Mockery\Container;
+ }
+
+ public function teardown()
+ {
+ $this->container->mockery_close();
+ }
+
+ public function testMockingStringReturnType()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithParameterAndReturnType");
+
+ $mock->shouldReceive("returnString");
+ $this->assertSame("", $mock->returnString());
+ }
+
+ public function testMockingIntegerReturnType()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithParameterAndReturnType");
+
+ $mock->shouldReceive("returnInteger");
+ $this->assertEquals(0, $mock->returnInteger());
+ }
+
+ public function testMockingFloatReturnType()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithParameterAndReturnType");
+
+ $mock->shouldReceive("returnFloat");
+ $this->assertSame(0.0, $mock->returnFloat());
+ }
+
+ public function testMockingBooleanReturnType()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithParameterAndReturnType");
+
+ $mock->shouldReceive("returnBoolean");
+ $this->assertSame(false, $mock->returnBoolean());
+ }
+
+ public function testMockingArrayReturnType()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithParameterAndReturnType");
+
+ $mock->shouldReceive("returnArray");
+ $this->assertSame([], $mock->returnArray());
+ }
+
+ public function testMockingGeneratorReturnTyps()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithParameterAndReturnType");
+
+ $mock->shouldReceive("returnGenerator");
+ $this->assertInstanceOf("\Generator", $mock->returnGenerator());
+ }
+
+ public function testMockingCallableReturnType()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithParameterAndReturnType");
+
+ $mock->shouldReceive("returnCallable");
+ $this->assertTrue(is_callable($mock->returnCallable()));
+ }
+
+ public function testMockingClassReturnTypes()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithParameterAndReturnType");
+
+ $mock->shouldReceive("withClassReturnType");
+ $this->assertInstanceOf("test\Mockery\TestWithParameterAndReturnType", $mock->withClassReturnType());
+ }
+
+ public function testMockingParameterTypes()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithParameterAndReturnType");
+
+ $mock->shouldReceive("withScalarParameters");
+ $mock->withScalarParameters(1, 1.0, true, 'string');
+ }
+}
+
+
+abstract class TestWithParameterAndReturnType
+{
+ public function returnString(): string
+ {
+ }
+
+ public function returnInteger(): int
+ {
+ }
+
+ public function returnFloat(): float
+ {
+ }
+
+ public function returnBoolean(): bool
+ {
+ }
+
+ public function returnArray(): array
+ {
+ }
+
+ public function returnCallable(): callable
+ {
+ }
+
+ public function returnGenerator(): \Generator
+ {
+ }
+
+ public function withClassReturnType(): TestWithParameterAndReturnType
+ {
+ }
+
+ public function withScalarParameters(int $integer, float $float, bool $boolean, string $string)
+ {
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockingProtectedMethodsTest.php b/vendor/mockery/mockery/tests/Mockery/MockingProtectedMethodsTest.php
new file mode 100644
index 000000000..4f704f532
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockingProtectedMethodsTest.php
@@ -0,0 +1,122 @@
+container = new \Mockery\Container;
+ }
+
+ public function teardown()
+ {
+ $this->container->mockery_close();
+ }
+
+ /**
+ * @test
+ *
+ * This is a regression test, basically we don't want the mock handling
+ * interfering with calling protected methods partials
+ */
+ public function shouldAutomaticallyDeferCallsToProtectedMethodsForPartials()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithProtectedMethods[foo]");
+ $this->assertEquals("bar", $mock->bar());
+ }
+
+ /**
+ * @test
+ *
+ * This is a regression test, basically we don't want the mock handling
+ * interfering with calling protected methods partials
+ */
+ public function shouldAutomaticallyDeferCallsToProtectedMethodsForRuntimePartials()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithProtectedMethods")->shouldDeferMissing();
+ $this->assertEquals("bar", $mock->bar());
+ }
+
+ /** @test */
+ public function shouldAutomaticallyIgnoreAbstractProtectedMethods()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithProtectedMethods")->shouldDeferMissing();
+ $this->assertEquals(null, $mock->foo());
+ }
+
+ /** @test */
+ public function shouldAllowMockingProtectedMethods()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithProtectedMethods")
+ ->shouldDeferMissing()
+ ->shouldAllowMockingProtectedMethods();
+
+ $mock->shouldReceive("protectedBar")->andReturn("notbar");
+ $this->assertEquals("notbar", $mock->bar());
+ }
+
+ /** @test */
+ public function shouldAllowMockingProtectedMethodOnDefinitionTimePartial()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithProtectedMethods[protectedBar]")
+ ->shouldAllowMockingProtectedMethods();
+
+ $mock->shouldReceive("protectedBar")->andReturn("notbar");
+ $this->assertEquals("notbar", $mock->bar());
+ }
+
+ /** @test */
+ public function shouldAllowMockingAbstractProtectedMethods()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithProtectedMethods")
+ ->shouldDeferMissing()
+ ->shouldAllowMockingProtectedMethods();
+
+ $mock->shouldReceive("abstractProtected")->andReturn("abstractProtected");
+ $this->assertEquals("abstractProtected", $mock->foo());
+ }
+}
+
+
+abstract class TestWithProtectedMethods
+{
+ public function foo()
+ {
+ return $this->abstractProtected();
+ }
+
+ abstract protected function abstractProtected();
+
+ public function bar()
+ {
+ return $this->protectedBar();
+ }
+
+ protected function protectedBar()
+ {
+ return 'bar';
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockingVariadicArgumentsTest.php b/vendor/mockery/mockery/tests/Mockery/MockingVariadicArgumentsTest.php
new file mode 100644
index 000000000..39faa805d
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockingVariadicArgumentsTest.php
@@ -0,0 +1,56 @@
+container = new \Mockery\Container;
+ }
+
+ public function teardown()
+ {
+ $this->container->mockery_close();
+ }
+
+ /** @test */
+ public function shouldAllowMockingVariadicArguments()
+ {
+ $mock = $this->container->mock("test\Mockery\TestWithVariadicArguments");
+
+ $mock->shouldReceive("foo")->andReturn("notbar");
+ $this->assertEquals("notbar", $mock->foo());
+ }
+}
+
+
+abstract class TestWithVariadicArguments
+{
+ public function foo(...$bar)
+ {
+ return $bar;
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/MockingVoidMethodsTest.php b/vendor/mockery/mockery/tests/Mockery/MockingVoidMethodsTest.php
new file mode 100644
index 000000000..993efe66d
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/MockingVoidMethodsTest.php
@@ -0,0 +1,56 @@
+container = new \Mockery\Container;
+ }
+
+ public function teardown()
+ {
+ $this->container->mockery_close();
+ }
+
+ /** @test */
+ public function shouldAllowMockingVoidMethods()
+ {
+ $this->expectOutputString('1');
+
+ $mock = $this->container->mock('test\Mockery\Fixtures\VoidMethod');
+ $mock->shouldReceive("foo")->andReturnUsing(
+ function () {
+ echo 1;
+ }
+ );
+
+ $mock->foo();
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/NamedMockTest.php b/vendor/mockery/mockery/tests/Mockery/NamedMockTest.php
new file mode 100644
index 000000000..28dd2fdd0
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/NamedMockTest.php
@@ -0,0 +1,54 @@
+assertEquals("Mockery\Dave123", get_class($mock));
+ }
+
+ /** @test */
+ public function itCreatesPassesFurtherArgumentsJustLikeMock()
+ {
+ $mock = Mockery::namedMock("Mockery\Dave456", "DateTimeZone", array(
+ "getDave" => "dave"
+ ));
+
+ $this->assertInstanceOf("DateTimeZone", $mock);
+ $this->assertEquals("dave", $mock->getDave());
+ }
+
+ /**
+ * @test
+ * @expectedException Mockery\Exception
+ * @expectedExceptionMessage The mock named 'Mockery\Dave7' has been already defined with a different mock configuration
+ */
+ public function itShouldThrowIfAttemptingToRedefineNamedMock()
+ {
+ $mock = Mockery::namedMock("Mockery\Dave7");
+ $mock = Mockery::namedMock("Mockery\Dave7", "DateTime");
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/RecorderTest.php b/vendor/mockery/mockery/tests/Mockery/RecorderTest.php
new file mode 100644
index 000000000..ce8d3d3b6
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/RecorderTest.php
@@ -0,0 +1,206 @@
+container = new \Mockery\Container(\Mockery::getDefaultGenerator(), \Mockery::getDefaultLoader());
+ }
+
+ public function teardown()
+ {
+ $this->container->mockery_close();
+ }
+
+ public function testRecorderWithSimpleObject()
+ {
+ $mock = $this->container->mock(new MockeryTestSubject);
+ $mock->shouldExpect(function ($subject) {
+ $user = new MockeryTestSubjectUser($subject);
+ $user->doFoo();
+ });
+
+ $this->assertEquals(1, $mock->foo());
+ $mock->mockery_verify();
+ }
+
+ public function testArgumentsArePassedAsMethodExpectations()
+ {
+ $mock = $this->container->mock(new MockeryTestSubject);
+ $mock->shouldExpect(function ($subject) {
+ $user = new MockeryTestSubjectUser($subject);
+ $user->doBar();
+ });
+
+ $this->assertEquals(4, $mock->bar(2));
+ $mock->mockery_verify();
+ }
+
+ public function testArgumentsLooselyMatchedByDefault()
+ {
+ $mock = $this->container->mock(new MockeryTestSubject);
+ $mock->shouldExpect(function ($subject) {
+ $user = new MockeryTestSubjectUser($subject);
+ $user->doBar();
+ });
+
+ $this->assertEquals(4, $mock->bar('2'));
+ $mock->mockery_verify();
+ }
+
+ public function testMultipleMethodExpectations()
+ {
+ $mock = $this->container->mock(new MockeryTestSubject);
+ $mock->shouldExpect(function ($subject) {
+ $user = new MockeryTestSubjectUser($subject);
+ $user->doFoo();
+ $user->doBar();
+ });
+
+ $this->assertEquals(1, $mock->foo());
+ $this->assertEquals(4, $mock->bar(2));
+ $mock->mockery_verify();
+ }
+
+ public function testRecordingDoesNotSpecifyExactOrderByDefault()
+ {
+ $mock = $this->container->mock(new MockeryTestSubject);
+ $mock->shouldExpect(function ($subject) {
+ $user = new MockeryTestSubjectUser($subject);
+ $user->doFoo();
+ $user->doBar();
+ });
+
+ $this->assertEquals(4, $mock->bar(2));
+ $this->assertEquals(1, $mock->foo());
+ $mock->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testRecordingDoesSpecifyExactOrderInStrictMode()
+ {
+ $mock = $this->container->mock(new MockeryTestSubject);
+ $mock->shouldExpect(function ($subject) {
+ $subject->shouldBeStrict();
+ $user = new MockeryTestSubjectUser($subject);
+ $user->doFoo();
+ $user->doBar();
+ });
+
+ $mock->bar(2);
+ $mock->foo();
+ $mock->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testArgumentsAreMatchedExactlyUnderStrictMode()
+ {
+ $mock = $this->container->mock(new MockeryTestSubject);
+ $mock->shouldExpect(function ($subject) {
+ $subject->shouldBeStrict();
+ $user = new MockeryTestSubjectUser($subject);
+ $user->doBar();
+ });
+
+ $mock->bar('2');
+ }
+
+ /**
+ * @expectedException \Mockery\Exception
+ */
+ public function testThrowsExceptionWhenArgumentsNotExpected()
+ {
+ $mock = $this->container->mock(new MockeryTestSubject);
+ $mock->shouldExpect(function ($subject) {
+ $user = new MockeryTestSubjectUser($subject);
+ $user->doBar();
+ });
+
+ $mock->bar(4);
+ }
+
+ public function testCallCountUnconstrainedByDefault()
+ {
+ $mock = $this->container->mock(new MockeryTestSubject);
+ $mock->shouldExpect(function ($subject) {
+ $user = new MockeryTestSubjectUser($subject);
+ $user->doBar();
+ });
+
+ $mock->bar(2);
+ $this->assertEquals(4, $mock->bar(2));
+ $mock->mockery_verify();
+ }
+
+ /**
+ * @expectedException \Mockery\CountValidator\Exception
+ */
+ public function testCallCountConstrainedInStrictMode()
+ {
+ $mock = $this->container->mock(new MockeryTestSubject);
+ $mock->shouldExpect(function ($subject) {
+ $subject->shouldBeStrict();
+ $user = new MockeryTestSubjectUser($subject);
+ $user->doBar();
+ });
+
+ $mock->bar(2);
+ $mock->bar(2);
+ $mock->mockery_verify();
+ }
+}
+
+class MockeryTestSubject
+{
+ public function foo()
+ {
+ return 1;
+ }
+ public function bar($i)
+ {
+ return $i * 2;
+ }
+}
+
+class MockeryTestSubjectUser
+{
+ public $subject = null;
+ public function __construct($subject)
+ {
+ $this->subject = $subject;
+ }
+ public function doFoo()
+ {
+ return $this->subject->foo();
+ }
+ public function doBar()
+ {
+ return $this->subject->bar(2);
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/SpyTest.php b/vendor/mockery/mockery/tests/Mockery/SpyTest.php
new file mode 100644
index 000000000..dc8192cb0
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/SpyTest.php
@@ -0,0 +1,78 @@
+container = new \Mockery\Container;
+ }
+
+ public function teardown()
+ {
+ $this->container->mockery_close();
+ }
+
+ /** @test */
+ public function itVerifiesAMethodWasCalled()
+ {
+ $spy = m::spy();
+ $spy->myMethod();
+ $spy->shouldHaveReceived("myMethod");
+
+ $this->setExpectedException("Mockery\Exception\InvalidCountException");
+ $spy->shouldHaveReceived("someMethodThatWasNotCalled");
+ }
+
+ /** @test */
+ public function itVerifiesAMethodWasNotCalled()
+ {
+ $spy = m::spy();
+ $spy->shouldNotHaveReceived("myMethod");
+
+ $this->setExpectedException("Mockery\Exception\InvalidCountException");
+ $spy->myMethod();
+ $spy->shouldNotHaveReceived("myMethod");
+ }
+
+ /** @test */
+ public function itVerifiesAMethodWasNotCalledWithParticularArguments()
+ {
+ $spy = m::spy();
+ $spy->myMethod(123, 456);
+
+ $spy->shouldNotHaveReceived("myMethod", array(789, 10));
+
+ $this->setExpectedException("Mockery\Exception\InvalidCountException");
+ $spy->shouldNotHaveReceived("myMethod", array(123, 456));
+ }
+
+ /** @test */
+ public function itVerifiesAMethodWasCalledASpecificNumberOfTimes()
+ {
+ $spy = m::spy();
+ $spy->myMethod();
+ $spy->myMethod();
+ $spy->shouldHaveReceived("myMethod")->twice();
+
+ $this->setExpectedException("Mockery\Exception\InvalidCountException");
+ $spy->myMethod();
+ $spy->shouldHaveReceived("myMethod")->twice();
+ }
+
+ /** @test */
+ public function itVerifiesAMethodWasCalledWithSpecificArguments()
+ {
+ $spy = m::spy();
+ $spy->myMethod(123, "a string");
+ $spy->shouldHaveReceived("myMethod")->with(123, "a string");
+ $spy->shouldHaveReceived("myMethod", array(123, "a string"));
+
+ $this->setExpectedException("Mockery\Exception\InvalidCountException");
+ $spy->shouldHaveReceived("myMethod")->with(123);
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/Test/Generator/MockConfigurationBuilderTest.php b/vendor/mockery/mockery/tests/Mockery/Test/Generator/MockConfigurationBuilderTest.php
new file mode 100644
index 000000000..e077ba315
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/Test/Generator/MockConfigurationBuilderTest.php
@@ -0,0 +1,43 @@
+assertContains('abstract', $builder->getMockConfiguration()->getBlackListedMethods());
+
+ // need a builtin for this
+ $this->markTestSkipped("Need a builtin class with a method that is a reserved word");
+ }
+
+ /**
+ * @test
+ */
+ public function magicMethodsAreBlackListedByDefault()
+ {
+ $builder = new MockConfigurationBuilder;
+ $builder->addTarget("Mockery\Generator\ClassWithMagicCall");
+ $methods = $builder->getMockConfiguration()->getMethodsToMock();
+ $this->assertEquals(1, count($methods));
+ $this->assertEquals("foo", $methods[0]->getName());
+ }
+}
+
+class ClassWithMagicCall
+{
+ public function foo()
+ {
+ }
+ public function __call($method, $args)
+ {
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/WithFormatterExpectationTest.php b/vendor/mockery/mockery/tests/Mockery/WithFormatterExpectationTest.php
new file mode 100644
index 000000000..536405f80
--- /dev/null
+++ b/vendor/mockery/mockery/tests/Mockery/WithFormatterExpectationTest.php
@@ -0,0 +1,121 @@
+assertEquals(
+ $expected,
+ Mockery::formatObjects($args)
+ );
+ }
+
+ /**
+ * @expectedException Mockery\Exception\NoMatchingExpectationException
+ *
+ * Note that without the patch checked in with this test, rather than throwing
+ * an exception, the program will go into an infinite recursive loop
+ */
+ public function testFormatObjectsWithMockCalledInGetterDoesNotLeadToRecursion()
+ {
+ $mock = Mockery::mock('stdClass');
+ $mock->shouldReceive('doBar')->with('foo');
+ $obj = new ClassWithGetter($mock);
+ $obj->getFoo();
+ }
+
+ public function formatObjectsDataProvider()
+ {
+ return array(
+ array(
+ array(null),
+ ''
+ ),
+ array(
+ array('a string', 98768, array('a', 'nother', 'array')),
+ ''
+ ),
+ );
+ }
+
+ /** @test */
+ public function format_objects_should_not_call_getters_with_params()
+ {
+ $obj = new ClassWithGetterWithParam();
+ $string = Mockery::formatObjects(array($obj));
+
+ $this->assertNotContains('Missing argument 1 for', $string);
+ }
+
+ public function testFormatObjectsExcludesStaticProperties()
+ {
+ $obj = new ClassWithPublicStaticProperty();
+ $string = Mockery::formatObjects(array($obj));
+
+ $this->assertNotContains('excludedProperty', $string);
+ }
+
+ public function testFormatObjectsExcludesStaticGetters()
+ {
+ $obj = new ClassWithPublicStaticGetter();
+ $string = Mockery::formatObjects(array($obj));
+
+ $this->assertNotContains('getExcluded', $string);
+ }
+}
+
+class ClassWithGetter
+{
+ private $dep;
+
+ public function __construct($dep)
+ {
+ $this->dep = $dep;
+ }
+
+ public function getFoo()
+ {
+ return $this->dep->doBar('bar', $this);
+ }
+}
+
+class ClassWithGetterWithParam
+{
+ public function getBar($bar)
+ {
+ }
+}
+
+class ClassWithPublicStaticProperty
+{
+ public static $excludedProperty;
+}
+
+class ClassWithPublicStaticGetter
+{
+ public static function getExcluded()
+ {
+ }
+}
diff --git a/vendor/mockery/mockery/tests/Mockery/_files/file.txt b/vendor/mockery/mockery/tests/Mockery/_files/file.txt
new file mode 100644
index 000000000..e69de29bb
diff --git a/vendor/mockery/mockery/travis/after_success.sh b/vendor/mockery/mockery/travis/after_success.sh
new file mode 100644
index 000000000..f1553ec50
--- /dev/null
+++ b/vendor/mockery/mockery/travis/after_success.sh
@@ -0,0 +1,6 @@
+#!/bin/bash
+if [[ $TRAVIS_PHP_VERSION == "5.6" ]]; then
+ vendor/bin/coveralls -v
+ wget https://scrutinizer-ci.com/ocular.phar
+ php ocular.phar code-coverage:upload --format=php-clover ./build/logs/clover.xml
+fi
diff --git a/vendor/mockery/mockery/travis/before_script.sh b/vendor/mockery/mockery/travis/before_script.sh
new file mode 100644
index 000000000..102c39ad8
--- /dev/null
+++ b/vendor/mockery/mockery/travis/before_script.sh
@@ -0,0 +1,11 @@
+#!/bin/bash
+if [[ $TRAVIS_PHP_VERSION != "hhvm" \
+ && $TRAVIS_PHP_VERSION != "hhvm-nightly" \
+ && $TRAVIS_PHP_VERSION != "7.0" ]]; then
+ phpenv config-add ./travis/extra.ini
+ phpenv rehash
+fi
+
+if [[ $TRAVIS_PHP_VERSION == "5.6" ]]; then
+ sed '/MockeryPHPUnitIntegration/d' -i ./phpunit.xml.dist
+fi
diff --git a/vendor/mockery/mockery/travis/extra.ini b/vendor/mockery/mockery/travis/extra.ini
new file mode 100644
index 000000000..16e0ef2ef
--- /dev/null
+++ b/vendor/mockery/mockery/travis/extra.ini
@@ -0,0 +1,3 @@
+extension = "mongo.so"
+extension = "redis.so"
+extension = "memcache.so"
\ No newline at end of file
diff --git a/vendor/mockery/mockery/travis/install.sh b/vendor/mockery/mockery/travis/install.sh
new file mode 100644
index 000000000..6ccf4cff7
--- /dev/null
+++ b/vendor/mockery/mockery/travis/install.sh
@@ -0,0 +1,6 @@
+#!/bin/bash
+composer install -n
+
+if [[ $TRAVIS_PHP_VERSION == "5.6" ]]; then
+ composer require --dev satooshi/php-coveralls:~0.7@dev
+fi
diff --git a/vendor/mockery/mockery/travis/script.sh b/vendor/mockery/mockery/travis/script.sh
new file mode 100644
index 000000000..7ef810af3
--- /dev/null
+++ b/vendor/mockery/mockery/travis/script.sh
@@ -0,0 +1,8 @@
+#!/bin/bash
+if [[ $TRAVIS_PHP_VERSION != "hhvm" \
+ && $TRAVIS_PHP_VERSION != "hhvm-nightly" \
+ && $TRAVIS_PHP_VERSION != "7.0" ]]; then
+ vendor/bin/phpunit --coverage-text --coverage-clover ./build/logs/clover.xml
+else
+ vendor/bin/phpunit
+fi
diff --git a/vendor/monolog/monolog/CHANGELOG.md b/vendor/monolog/monolog/CHANGELOG.md
new file mode 100644
index 000000000..a92155ee3
--- /dev/null
+++ b/vendor/monolog/monolog/CHANGELOG.md
@@ -0,0 +1,432 @@
+### 1.27.1 (2022-06-09)
+
+ * Fixed MandrillHandler support for SwiftMailer 6 (#1676)
+ * Fixed StreamHandler chunk size (backport from #1552)
+
+### 1.27.0 (2022-03-13)
+
+ * Added $maxDepth / setMaxDepth to NormalizerFormatter / JsonFormatter to configure the maximum depth if the default of 9 does not work for you (#1633)
+
+### 1.26.1 (2021-05-28)
+
+ * Fixed PHP 8.1 deprecation warning
+
+### 1.26.0 (2020-12-14)
+
+ * Added $dateFormat and $removeUsedContextFields arguments to PsrLogMessageProcessor (backport from 2.x)
+
+### 1.25.5 (2020-07-23)
+
+ * Fixed array access on null in RavenHandler
+ * Fixed unique_id in WebProcessor not being disableable
+
+### 1.25.4 (2020-05-22)
+
+ * Fixed GitProcessor type error when there is no git repo present
+ * Fixed normalization of SoapFault objects containing deeply nested objects as "detail"
+ * Fixed support for relative paths in RotatingFileHandler
+
+### 1.25.3 (2019-12-20)
+
+ * Fixed formatting of resources in JsonFormatter
+ * Fixed RedisHandler failing to use MULTI properly when passed a proxied Redis instance (e.g. in Symfony with lazy services)
+ * Fixed FilterHandler triggering a notice when handleBatch was filtering all records passed to it
+ * Fixed Turkish locale messing up the conversion of level names to their constant values
+
+### 1.25.2 (2019-11-13)
+
+ * Fixed normalization of Traversables to avoid traversing them as not all of them are rewindable
+ * Fixed setFormatter/getFormatter to forward to the nested handler in FilterHandler, FingersCrossedHandler, BufferHandler and SamplingHandler
+ * Fixed BrowserConsoleHandler formatting when using multiple styles
+ * Fixed normalization of exception codes to be always integers even for PDOException which have them as numeric strings
+ * Fixed normalization of SoapFault objects containing non-strings as "detail"
+ * Fixed json encoding across all handlers to always attempt recovery of non-UTF-8 strings instead of failing the whole encoding
+
+### 1.25.1 (2019-09-06)
+
+ * Fixed forward-compatible interfaces to be compatible with Monolog 1.x too.
+
+### 1.25.0 (2019-09-06)
+
+ * Deprecated SlackbotHandler, use SlackWebhookHandler or SlackHandler instead
+ * Deprecated RavenHandler, use sentry/sentry 2.x and their Sentry\Monolog\Handler instead
+ * Deprecated HipChatHandler, migrate to Slack and use SlackWebhookHandler or SlackHandler instead
+ * Added forward-compatible interfaces and traits FormattableHandlerInterface, FormattableHandlerTrait, ProcessableHandlerInterface, ProcessableHandlerTrait. If you use modern PHP and want to make code compatible with Monolog 1 and 2 this can help. You will have to require at least Monolog 1.25 though.
+ * Added support for RFC3164 (outdated BSD syslog protocol) to SyslogUdpHandler
+ * Fixed issue in GroupHandler and WhatFailureGroupHandler where setting multiple processors would duplicate records
+ * Fixed issue in SignalHandler restarting syscalls functionality
+ * Fixed normalizers handling of exception backtraces to avoid serializing arguments in some cases
+ * Fixed ZendMonitorHandler to work with the latest Zend Server versions
+ * Fixed ChromePHPHandler to avoid sending more data than latest Chrome versions allow in headers (4KB down from 256KB).
+
+### 1.24.0 (2018-11-05)
+
+ * BC Notice: If you are extending any of the Monolog's Formatters' `normalize` method, make sure you add the new `$depth = 0` argument to your function signature to avoid strict PHP warnings.
+ * Added a `ResettableInterface` in order to reset/reset/clear/flush handlers and processors
+ * Added a `ProcessorInterface` as an optional way to label a class as being a processor (mostly useful for autowiring dependency containers)
+ * Added a way to log signals being received using Monolog\SignalHandler
+ * Added ability to customize error handling at the Logger level using Logger::setExceptionHandler
+ * Added InsightOpsHandler to migrate users of the LogEntriesHandler
+ * Added protection to NormalizerHandler against circular and very deep structures, it now stops normalizing at a depth of 9
+ * Added capture of stack traces to ErrorHandler when logging PHP errors
+ * Added RavenHandler support for a `contexts` context or extra key to forward that to Sentry's contexts
+ * Added forwarding of context info to FluentdFormatter
+ * Added SocketHandler::setChunkSize to override the default chunk size in case you must send large log lines to rsyslog for example
+ * Added ability to extend/override BrowserConsoleHandler
+ * Added SlackWebhookHandler::getWebhookUrl and SlackHandler::getToken to enable class extensibility
+ * Added SwiftMailerHandler::getSubjectFormatter to enable class extensibility
+ * Dropped official support for HHVM in test builds
+ * Fixed normalization of exception traces when call_user_func is used to avoid serializing objects and the data they contain
+ * Fixed naming of fields in Slack handler, all field names are now capitalized in all cases
+ * Fixed HipChatHandler bug where slack dropped messages randomly
+ * Fixed normalization of objects in Slack handlers
+ * Fixed support for PHP7's Throwable in NewRelicHandler
+ * Fixed race bug when StreamHandler sometimes incorrectly reported it failed to create a directory
+ * Fixed table row styling issues in HtmlFormatter
+ * Fixed RavenHandler dropping the message when logging exception
+ * Fixed WhatFailureGroupHandler skipping processors when using handleBatch
+ and implement it where possible
+ * Fixed display of anonymous class names
+
+### 1.23.0 (2017-06-19)
+
+ * Improved SyslogUdpHandler's support for RFC5424 and added optional `$ident` argument
+ * Fixed GelfHandler truncation to be per field and not per message
+ * Fixed compatibility issue with PHP <5.3.6
+ * Fixed support for headless Chrome in ChromePHPHandler
+ * Fixed support for latest Aws SDK in DynamoDbHandler
+ * Fixed support for SwiftMailer 6.0+ in SwiftMailerHandler
+
+### 1.22.1 (2017-03-13)
+
+ * Fixed lots of minor issues in the new Slack integrations
+ * Fixed support for allowInlineLineBreaks in LineFormatter when formatting exception backtraces
+
+### 1.22.0 (2016-11-26)
+
+ * Added SlackbotHandler and SlackWebhookHandler to set up Slack integration more easily
+ * Added MercurialProcessor to add mercurial revision and branch names to log records
+ * Added support for AWS SDK v3 in DynamoDbHandler
+ * Fixed fatal errors occuring when normalizing generators that have been fully consumed
+ * Fixed RollbarHandler to include a level (rollbar level), monolog_level (original name), channel and datetime (unix)
+ * Fixed RollbarHandler not flushing records automatically, calling close() explicitly is not necessary anymore
+ * Fixed SyslogUdpHandler to avoid sending empty frames
+ * Fixed a few PHP 7.0 and 7.1 compatibility issues
+
+### 1.21.0 (2016-07-29)
+
+ * Break: Reverted the addition of $context when the ErrorHandler handles regular php errors from 1.20.0 as it was causing issues
+ * Added support for more formats in RotatingFileHandler::setFilenameFormat as long as they have Y, m and d in order
+ * Added ability to format the main line of text the SlackHandler sends by explictly setting a formatter on the handler
+ * Added information about SoapFault instances in NormalizerFormatter
+ * Added $handleOnlyReportedErrors option on ErrorHandler::registerErrorHandler (default true) to allow logging of all errors no matter the error_reporting level
+
+### 1.20.0 (2016-07-02)
+
+ * Added FingersCrossedHandler::activate() to manually trigger the handler regardless of the activation policy
+ * Added StreamHandler::getUrl to retrieve the stream's URL
+ * Added ability to override addRow/addTitle in HtmlFormatter
+ * Added the $context to context information when the ErrorHandler handles a regular php error
+ * Deprecated RotatingFileHandler::setFilenameFormat to only support 3 formats: Y, Y-m and Y-m-d
+ * Fixed WhatFailureGroupHandler to work with PHP7 throwables
+ * Fixed a few minor bugs
+
+### 1.19.0 (2016-04-12)
+
+ * Break: StreamHandler will not close streams automatically that it does not own. If you pass in a stream (not a path/url), then it will not close it for you. You can retrieve those using getStream() if needed
+ * Added DeduplicationHandler to remove duplicate records from notifications across multiple requests, useful for email or other notifications on errors
+ * Added ability to use `%message%` and other LineFormatter replacements in the subject line of emails sent with NativeMailHandler and SwiftMailerHandler
+ * Fixed HipChatHandler handling of long messages
+
+### 1.18.2 (2016-04-02)
+
+ * Fixed ElasticaFormatter to use more precise dates
+ * Fixed GelfMessageFormatter sending too long messages
+
+### 1.18.1 (2016-03-13)
+
+ * Fixed SlackHandler bug where slack dropped messages randomly
+ * Fixed RedisHandler issue when using with the PHPRedis extension
+ * Fixed AmqpHandler content-type being incorrectly set when using with the AMQP extension
+ * Fixed BrowserConsoleHandler regression
+
+### 1.18.0 (2016-03-01)
+
+ * Added optional reduction of timestamp precision via `Logger->useMicrosecondTimestamps(false)`, disabling it gets you a bit of performance boost but reduces the precision to the second instead of microsecond
+ * Added possibility to skip some extra stack frames in IntrospectionProcessor if you have some library wrapping Monolog that is always adding frames
+ * Added `Logger->withName` to clone a logger (keeping all handlers) with a new name
+ * Added FluentdFormatter for the Fluentd unix socket protocol
+ * Added HandlerWrapper base class to ease the creation of handler wrappers, just extend it and override as needed
+ * Added support for replacing context sub-keys using `%context.*%` in LineFormatter
+ * Added support for `payload` context value in RollbarHandler
+ * Added setRelease to RavenHandler to describe the application version, sent with every log
+ * Added support for `fingerprint` context value in RavenHandler
+ * Fixed JSON encoding errors that would gobble up the whole log record, we now handle those more gracefully by dropping chars as needed
+ * Fixed write timeouts in SocketHandler and derivatives, set to 10sec by default, lower it with `setWritingTimeout()`
+ * Fixed PHP7 compatibility with regard to Exception/Throwable handling in a few places
+
+### 1.17.2 (2015-10-14)
+
+ * Fixed ErrorHandler compatibility with non-Monolog PSR-3 loggers
+ * Fixed SlackHandler handling to use slack functionalities better
+ * Fixed SwiftMailerHandler bug when sending multiple emails they all had the same id
+ * Fixed 5.3 compatibility regression
+
+### 1.17.1 (2015-08-31)
+
+ * Fixed RollbarHandler triggering PHP notices
+
+### 1.17.0 (2015-08-30)
+
+ * Added support for `checksum` and `release` context/extra values in RavenHandler
+ * Added better support for exceptions in RollbarHandler
+ * Added UidProcessor::getUid
+ * Added support for showing the resource type in NormalizedFormatter
+ * Fixed IntrospectionProcessor triggering PHP notices
+
+### 1.16.0 (2015-08-09)
+
+ * Added IFTTTHandler to notify ifttt.com triggers
+ * Added Logger::setHandlers() to allow setting/replacing all handlers
+ * Added $capSize in RedisHandler to cap the log size
+ * Fixed StreamHandler creation of directory to only trigger when the first log write happens
+ * Fixed bug in the handling of curl failures
+ * Fixed duplicate logging of fatal errors when both error and fatal error handlers are registered in monolog's ErrorHandler
+ * Fixed missing fatal errors records with handlers that need to be closed to flush log records
+ * Fixed TagProcessor::addTags support for associative arrays
+
+### 1.15.0 (2015-07-12)
+
+ * Added addTags and setTags methods to change a TagProcessor
+ * Added automatic creation of directories if they are missing for a StreamHandler to open a log file
+ * Added retry functionality to Loggly, Cube and Mandrill handlers so they retry up to 5 times in case of network failure
+ * Fixed process exit code being incorrectly reset to 0 if ErrorHandler::registerExceptionHandler was used
+ * Fixed HTML/JS escaping in BrowserConsoleHandler
+ * Fixed JSON encoding errors being silently suppressed (PHP 5.5+ only)
+
+### 1.14.0 (2015-06-19)
+
+ * Added PHPConsoleHandler to send record to Chrome's PHP Console extension and library
+ * Added support for objects implementing __toString in the NormalizerFormatter
+ * Added support for HipChat's v2 API in HipChatHandler
+ * Added Logger::setTimezone() to initialize the timezone monolog should use in case date.timezone isn't correct for your app
+ * Added an option to send formatted message instead of the raw record on PushoverHandler via ->useFormattedMessage(true)
+ * Fixed curl errors being silently suppressed
+
+### 1.13.1 (2015-03-09)
+
+ * Fixed regression in HipChat requiring a new token to be created
+
+### 1.13.0 (2015-03-05)
+
+ * Added Registry::hasLogger to check for the presence of a logger instance
+ * Added context.user support to RavenHandler
+ * Added HipChat API v2 support in the HipChatHandler
+ * Added NativeMailerHandler::addParameter to pass params to the mail() process
+ * Added context data to SlackHandler when $includeContextAndExtra is true
+ * Added ability to customize the Swift_Message per-email in SwiftMailerHandler
+ * Fixed SwiftMailerHandler to lazily create message instances if a callback is provided
+ * Fixed serialization of INF and NaN values in Normalizer and LineFormatter
+
+### 1.12.0 (2014-12-29)
+
+ * Break: HandlerInterface::isHandling now receives a partial record containing only a level key. This was always the intent and does not break any Monolog handler but is strictly speaking a BC break and you should check if you relied on any other field in your own handlers.
+ * Added PsrHandler to forward records to another PSR-3 logger
+ * Added SamplingHandler to wrap around a handler and include only every Nth record
+ * Added MongoDBFormatter to support better storage with MongoDBHandler (it must be enabled manually for now)
+ * Added exception codes in the output of most formatters
+ * Added LineFormatter::includeStacktraces to enable exception stack traces in logs (uses more than one line)
+ * Added $useShortAttachment to SlackHandler to minify attachment size and $includeExtra to append extra data
+ * Added $host to HipChatHandler for users of private instances
+ * Added $transactionName to NewRelicHandler and support for a transaction_name context value
+ * Fixed MandrillHandler to avoid outputing API call responses
+ * Fixed some non-standard behaviors in SyslogUdpHandler
+
+### 1.11.0 (2014-09-30)
+
+ * Break: The NewRelicHandler extra and context data are now prefixed with extra_ and context_ to avoid clashes. Watch out if you have scripts reading those from the API and rely on names
+ * Added WhatFailureGroupHandler to suppress any exception coming from the wrapped handlers and avoid chain failures if a logging service fails
+ * Added MandrillHandler to send emails via the Mandrillapp.com API
+ * Added SlackHandler to log records to a Slack.com account
+ * Added FleepHookHandler to log records to a Fleep.io account
+ * Added LogglyHandler::addTag to allow adding tags to an existing handler
+ * Added $ignoreEmptyContextAndExtra to LineFormatter to avoid empty [] at the end
+ * Added $useLocking to StreamHandler and RotatingFileHandler to enable flock() while writing
+ * Added support for PhpAmqpLib in the AmqpHandler
+ * Added FingersCrossedHandler::clear and BufferHandler::clear to reset them between batches in long running jobs
+ * Added support for adding extra fields from $_SERVER in the WebProcessor
+ * Fixed support for non-string values in PrsLogMessageProcessor
+ * Fixed SwiftMailer messages being sent with the wrong date in long running scripts
+ * Fixed minor PHP 5.6 compatibility issues
+ * Fixed BufferHandler::close being called twice
+
+### 1.10.0 (2014-06-04)
+
+ * Added Logger::getHandlers() and Logger::getProcessors() methods
+ * Added $passthruLevel argument to FingersCrossedHandler to let it always pass some records through even if the trigger level is not reached
+ * Added support for extra data in NewRelicHandler
+ * Added $expandNewlines flag to the ErrorLogHandler to create multiple log entries when a message has multiple lines
+
+### 1.9.1 (2014-04-24)
+
+ * Fixed regression in RotatingFileHandler file permissions
+ * Fixed initialization of the BufferHandler to make sure it gets flushed after receiving records
+ * Fixed ChromePHPHandler and FirePHPHandler's activation strategies to be more conservative
+
+### 1.9.0 (2014-04-20)
+
+ * Added LogEntriesHandler to send logs to a LogEntries account
+ * Added $filePermissions to tweak file mode on StreamHandler and RotatingFileHandler
+ * Added $useFormatting flag to MemoryProcessor to make it send raw data in bytes
+ * Added support for table formatting in FirePHPHandler via the table context key
+ * Added a TagProcessor to add tags to records, and support for tags in RavenHandler
+ * Added $appendNewline flag to the JsonFormatter to enable using it when logging to files
+ * Added sound support to the PushoverHandler
+ * Fixed multi-threading support in StreamHandler
+ * Fixed empty headers issue when ChromePHPHandler received no records
+ * Fixed default format of the ErrorLogHandler
+
+### 1.8.0 (2014-03-23)
+
+ * Break: the LineFormatter now strips newlines by default because this was a bug, set $allowInlineLineBreaks to true if you need them
+ * Added BrowserConsoleHandler to send logs to any browser's console via console.log() injection in the output
+ * Added FilterHandler to filter records and only allow those of a given list of levels through to the wrapped handler
+ * Added FlowdockHandler to send logs to a Flowdock account
+ * Added RollbarHandler to send logs to a Rollbar account
+ * Added HtmlFormatter to send prettier log emails with colors for each log level
+ * Added GitProcessor to add the current branch/commit to extra record data
+ * Added a Monolog\Registry class to allow easier global access to pre-configured loggers
+ * Added support for the new official graylog2/gelf-php lib for GelfHandler, upgrade if you can by replacing the mlehner/gelf-php requirement
+ * Added support for HHVM
+ * Added support for Loggly batch uploads
+ * Added support for tweaking the content type and encoding in NativeMailerHandler
+ * Added $skipClassesPartials to tweak the ignored classes in the IntrospectionProcessor
+ * Fixed batch request support in GelfHandler
+
+### 1.7.0 (2013-11-14)
+
+ * Added ElasticSearchHandler to send logs to an Elastic Search server
+ * Added DynamoDbHandler and ScalarFormatter to send logs to Amazon's Dynamo DB
+ * Added SyslogUdpHandler to send logs to a remote syslogd server
+ * Added LogglyHandler to send logs to a Loggly account
+ * Added $level to IntrospectionProcessor so it only adds backtraces when needed
+ * Added $version to LogstashFormatter to allow using the new v1 Logstash format
+ * Added $appName to NewRelicHandler
+ * Added configuration of Pushover notification retries/expiry
+ * Added $maxColumnWidth to NativeMailerHandler to change the 70 chars default
+ * Added chainability to most setters for all handlers
+ * Fixed RavenHandler batch processing so it takes the message from the record with highest priority
+ * Fixed HipChatHandler batch processing so it sends all messages at once
+ * Fixed issues with eAccelerator
+ * Fixed and improved many small things
+
+### 1.6.0 (2013-07-29)
+
+ * Added HipChatHandler to send logs to a HipChat chat room
+ * Added ErrorLogHandler to send logs to PHP's error_log function
+ * Added NewRelicHandler to send logs to NewRelic's service
+ * Added Monolog\ErrorHandler helper class to register a Logger as exception/error/fatal handler
+ * Added ChannelLevelActivationStrategy for the FingersCrossedHandler to customize levels by channel
+ * Added stack traces output when normalizing exceptions (json output & co)
+ * Added Monolog\Logger::API constant (currently 1)
+ * Added support for ChromePHP's v4.0 extension
+ * Added support for message priorities in PushoverHandler, see $highPriorityLevel and $emergencyLevel
+ * Added support for sending messages to multiple users at once with the PushoverHandler
+ * Fixed RavenHandler's support for batch sending of messages (when behind a Buffer or FingersCrossedHandler)
+ * Fixed normalization of Traversables with very large data sets, only the first 1000 items are shown now
+ * Fixed issue in RotatingFileHandler when an open_basedir restriction is active
+ * Fixed minor issues in RavenHandler and bumped the API to Raven 0.5.0
+ * Fixed SyslogHandler issue when many were used concurrently with different facilities
+
+### 1.5.0 (2013-04-23)
+
+ * Added ProcessIdProcessor to inject the PID in log records
+ * Added UidProcessor to inject a unique identifier to all log records of one request/run
+ * Added support for previous exceptions in the LineFormatter exception serialization
+ * Added Monolog\Logger::getLevels() to get all available levels
+ * Fixed ChromePHPHandler so it avoids sending headers larger than Chrome can handle
+
+### 1.4.1 (2013-04-01)
+
+ * Fixed exception formatting in the LineFormatter to be more minimalistic
+ * Fixed RavenHandler's handling of context/extra data, requires Raven client >0.1.0
+ * Fixed log rotation in RotatingFileHandler to work with long running scripts spanning multiple days
+ * Fixed WebProcessor array access so it checks for data presence
+ * Fixed Buffer, Group and FingersCrossed handlers to make use of their processors
+
+### 1.4.0 (2013-02-13)
+
+ * Added RedisHandler to log to Redis via the Predis library or the phpredis extension
+ * Added ZendMonitorHandler to log to the Zend Server monitor
+ * Added the possibility to pass arrays of handlers and processors directly in the Logger constructor
+ * Added `$useSSL` option to the PushoverHandler which is enabled by default
+ * Fixed ChromePHPHandler and FirePHPHandler issue when multiple instances are used simultaneously
+ * Fixed header injection capability in the NativeMailHandler
+
+### 1.3.1 (2013-01-11)
+
+ * Fixed LogstashFormatter to be usable with stream handlers
+ * Fixed GelfMessageFormatter levels on Windows
+
+### 1.3.0 (2013-01-08)
+
+ * Added PSR-3 compliance, the `Monolog\Logger` class is now an instance of `Psr\Log\LoggerInterface`
+ * Added PsrLogMessageProcessor that you can selectively enable for full PSR-3 compliance
+ * Added LogstashFormatter (combine with SocketHandler or StreamHandler to send logs to Logstash)
+ * Added PushoverHandler to send mobile notifications
+ * Added CouchDBHandler and DoctrineCouchDBHandler
+ * Added RavenHandler to send data to Sentry servers
+ * Added support for the new MongoClient class in MongoDBHandler
+ * Added microsecond precision to log records' timestamps
+ * Added `$flushOnOverflow` param to BufferHandler to flush by batches instead of losing
+ the oldest entries
+ * Fixed normalization of objects with cyclic references
+
+### 1.2.1 (2012-08-29)
+
+ * Added new $logopts arg to SyslogHandler to provide custom openlog options
+ * Fixed fatal error in SyslogHandler
+
+### 1.2.0 (2012-08-18)
+
+ * Added AmqpHandler (for use with AMQP servers)
+ * Added CubeHandler
+ * Added NativeMailerHandler::addHeader() to send custom headers in mails
+ * Added the possibility to specify more than one recipient in NativeMailerHandler
+ * Added the possibility to specify float timeouts in SocketHandler
+ * Added NOTICE and EMERGENCY levels to conform with RFC 5424
+ * Fixed the log records to use the php default timezone instead of UTC
+ * Fixed BufferHandler not being flushed properly on PHP fatal errors
+ * Fixed normalization of exotic resource types
+ * Fixed the default format of the SyslogHandler to avoid duplicating datetimes in syslog
+
+### 1.1.0 (2012-04-23)
+
+ * Added Monolog\Logger::isHandling() to check if a handler will
+ handle the given log level
+ * Added ChromePHPHandler
+ * Added MongoDBHandler
+ * Added GelfHandler (for use with Graylog2 servers)
+ * Added SocketHandler (for use with syslog-ng for example)
+ * Added NormalizerFormatter
+ * Added the possibility to change the activation strategy of the FingersCrossedHandler
+ * Added possibility to show microseconds in logs
+ * Added `server` and `referer` to WebProcessor output
+
+### 1.0.2 (2011-10-24)
+
+ * Fixed bug in IE with large response headers and FirePHPHandler
+
+### 1.0.1 (2011-08-25)
+
+ * Added MemoryPeakUsageProcessor and MemoryUsageProcessor
+ * Added Monolog\Logger::getName() to get a logger's channel name
+
+### 1.0.0 (2011-07-06)
+
+ * Added IntrospectionProcessor to get info from where the logger was called
+ * Fixed WebProcessor in CLI
+
+### 1.0.0-RC1 (2011-07-01)
+
+ * Initial release
diff --git a/vendor/monolog/monolog/LICENSE b/vendor/monolog/monolog/LICENSE
new file mode 100644
index 000000000..16473219b
--- /dev/null
+++ b/vendor/monolog/monolog/LICENSE
@@ -0,0 +1,19 @@
+Copyright (c) 2011-2016 Jordi Boggiano
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is furnished
+to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
diff --git a/vendor/monolog/monolog/README.md b/vendor/monolog/monolog/README.md
new file mode 100644
index 000000000..a578eb228
--- /dev/null
+++ b/vendor/monolog/monolog/README.md
@@ -0,0 +1,94 @@
+# Monolog - Logging for PHP [](https://travis-ci.org/Seldaek/monolog)
+
+[](https://packagist.org/packages/monolog/monolog)
+[](https://packagist.org/packages/monolog/monolog)
+
+
+Monolog sends your logs to files, sockets, inboxes, databases and various
+web services. See the complete list of handlers below. Special handlers
+allow you to build advanced logging strategies.
+
+This library implements the [PSR-3](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md)
+interface that you can type-hint against in your own libraries to keep
+a maximum of interoperability. You can also use it in your applications to
+make sure you can always use another compatible logger at a later time.
+As of 1.11.0 Monolog public APIs will also accept PSR-3 log levels.
+Internally Monolog still uses its own level scheme since it predates PSR-3.
+
+## Installation
+
+Install the latest version with
+
+```bash
+$ composer require monolog/monolog
+```
+
+## Basic Usage
+
+```php
+pushHandler(new StreamHandler('path/to/your.log', Logger::WARNING));
+
+// add records to the log
+$log->addWarning('Foo');
+$log->addError('Bar');
+```
+
+## Documentation
+
+- [Usage Instructions](doc/01-usage.md)
+- [Handlers, Formatters and Processors](doc/02-handlers-formatters-processors.md)
+- [Utility classes](doc/03-utilities.md)
+- [Extending Monolog](doc/04-extending.md)
+
+## Third Party Packages
+
+Third party handlers, formatters and processors are
+[listed in the wiki](https://github.com/Seldaek/monolog/wiki/Third-Party-Packages). You
+can also add your own there if you publish one.
+
+## About
+
+### Requirements
+
+- Monolog works with PHP 5.3 or above, and is also tested to work with HHVM.
+
+### Submitting bugs and feature requests
+
+Bugs and feature request are tracked on [GitHub](https://github.com/Seldaek/monolog/issues)
+
+### Framework Integrations
+
+- Frameworks and libraries using [PSR-3](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md)
+ can be used very easily with Monolog since it implements the interface.
+- [Symfony2](http://symfony.com) comes out of the box with Monolog.
+- [Silex](http://silex.sensiolabs.org/) comes out of the box with Monolog.
+- [Laravel 4 & 5](http://laravel.com/) come out of the box with Monolog.
+- [Lumen](http://lumen.laravel.com/) comes out of the box with Monolog.
+- [PPI](http://www.ppi.io/) comes out of the box with Monolog.
+- [CakePHP](http://cakephp.org/) is usable with Monolog via the [cakephp-monolog](https://github.com/jadb/cakephp-monolog) plugin.
+- [Slim](http://www.slimframework.com/) is usable with Monolog via the [Slim-Monolog](https://github.com/Flynsarmy/Slim-Monolog) log writer.
+- [XOOPS 2.6](http://xoops.org/) comes out of the box with Monolog.
+- [Aura.Web_Project](https://github.com/auraphp/Aura.Web_Project) comes out of the box with Monolog.
+- [Nette Framework](http://nette.org/en/) can be used with Monolog via [Kdyby/Monolog](https://github.com/Kdyby/Monolog) extension.
+- [Proton Micro Framework](https://github.com/alexbilbie/Proton) comes out of the box with Monolog.
+
+### Author
+
+Jordi Boggiano - -
+See also the list of [contributors](https://github.com/Seldaek/monolog/contributors) which participated in this project.
+
+### License
+
+Monolog is licensed under the MIT License - see the `LICENSE` file for details
+
+### Acknowledgements
+
+This library is heavily inspired by Python's [Logbook](https://logbook.readthedocs.io/en/stable/)
+library, although most concepts have been adjusted to fit to the PHP world.
diff --git a/vendor/monolog/monolog/composer.json b/vendor/monolog/monolog/composer.json
new file mode 100644
index 000000000..aecc40f39
--- /dev/null
+++ b/vendor/monolog/monolog/composer.json
@@ -0,0 +1,60 @@
+{
+ "name": "monolog/monolog",
+ "description": "Sends your logs to files, sockets, inboxes, databases and various web services",
+ "keywords": ["log", "logging", "psr-3"],
+ "homepage": "http://github.com/Seldaek/monolog",
+ "type": "library",
+ "license": "MIT",
+ "authors": [
+ {
+ "name": "Jordi Boggiano",
+ "email": "j.boggiano@seld.be",
+ "homepage": "http://seld.be"
+ }
+ ],
+ "require": {
+ "php": ">=5.3.0",
+ "psr/log": "~1.0"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.5",
+ "graylog2/gelf-php": "~1.0",
+ "sentry/sentry": "^0.13",
+ "ruflin/elastica": ">=0.90 <3.0",
+ "doctrine/couchdb": "~1.0@dev",
+ "aws/aws-sdk-php": "^2.4.9 || ^3.0",
+ "php-amqplib/php-amqplib": "~2.4",
+ "swiftmailer/swiftmailer": "^5.3|^6.0",
+ "php-console/php-console": "^3.1.3",
+ "phpstan/phpstan": "^0.12.59"
+ },
+ "suggest": {
+ "graylog2/gelf-php": "Allow sending log messages to a GrayLog2 server",
+ "sentry/sentry": "Allow sending log messages to a Sentry server",
+ "doctrine/couchdb": "Allow sending log messages to a CouchDB server",
+ "ruflin/elastica": "Allow sending log messages to an Elastic Search server",
+ "php-amqplib/php-amqplib": "Allow sending log messages to an AMQP server using php-amqplib",
+ "ext-amqp": "Allow sending log messages to an AMQP server (1.0+ required)",
+ "ext-mongo": "Allow sending log messages to a MongoDB server",
+ "mongodb/mongodb": "Allow sending log messages to a MongoDB server via PHP Driver",
+ "aws/aws-sdk-php": "Allow sending log messages to AWS services like DynamoDB",
+ "rollbar/rollbar": "Allow sending log messages to Rollbar",
+ "php-console/php-console": "Allow sending log messages to Google Chrome"
+ },
+ "autoload": {
+ "psr-4": {"Monolog\\": "src/Monolog"}
+ },
+ "autoload-dev": {
+ "psr-4": {"Monolog\\": "tests/Monolog"}
+ },
+ "provide": {
+ "psr/log-implementation": "1.0.0"
+ },
+ "scripts": {
+ "test": "vendor/bin/phpunit",
+ "phpstan": "vendor/bin/phpstan analyse"
+ },
+ "config": {
+ "lock": false
+ }
+}
diff --git a/vendor/monolog/monolog/phpstan.neon.dist b/vendor/monolog/monolog/phpstan.neon.dist
new file mode 100644
index 000000000..1fe45df73
--- /dev/null
+++ b/vendor/monolog/monolog/phpstan.neon.dist
@@ -0,0 +1,16 @@
+parameters:
+ level: 3
+
+ paths:
+ - src/
+# - tests/
+
+
+ ignoreErrors:
+ - '#zend_monitor_|ZEND_MONITOR_#'
+ - '#RollbarNotifier#'
+ - '#Predis\\Client#'
+ - '#^Cannot call method ltrim\(\) on int\|false.$#'
+ - '#^Access to an undefined property Raven_Client::\$context.$#'
+ - '#MongoDB\\(Client|Collection)#'
+ - '#Gelf\\IMessagePublisher#'
diff --git a/vendor/monolog/monolog/src/Monolog/ErrorHandler.php b/vendor/monolog/monolog/src/Monolog/ErrorHandler.php
new file mode 100644
index 000000000..5121c2cd0
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/ErrorHandler.php
@@ -0,0 +1,239 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog;
+
+use Psr\Log\LoggerInterface;
+use Psr\Log\LogLevel;
+use Monolog\Handler\AbstractHandler;
+
+/**
+ * Monolog error handler
+ *
+ * A facility to enable logging of runtime errors, exceptions and fatal errors.
+ *
+ * Quick setup: ErrorHandler::register($logger);
+ *
+ * @author Jordi Boggiano
+ */
+class ErrorHandler
+{
+ private $logger;
+
+ private $previousExceptionHandler;
+ private $uncaughtExceptionLevel;
+
+ private $previousErrorHandler;
+ private $errorLevelMap;
+ private $handleOnlyReportedErrors;
+
+ private $hasFatalErrorHandler;
+ private $fatalLevel;
+ private $reservedMemory;
+ private $lastFatalTrace;
+ private static $fatalErrors = array(E_ERROR, E_PARSE, E_CORE_ERROR, E_COMPILE_ERROR, E_USER_ERROR);
+
+ public function __construct(LoggerInterface $logger)
+ {
+ $this->logger = $logger;
+ }
+
+ /**
+ * Registers a new ErrorHandler for a given Logger
+ *
+ * By default it will handle errors, exceptions and fatal errors
+ *
+ * @param LoggerInterface $logger
+ * @param array|false $errorLevelMap an array of E_* constant to LogLevel::* constant mapping, or false to disable error handling
+ * @param int|false $exceptionLevel a LogLevel::* constant, or false to disable exception handling
+ * @param int|false $fatalLevel a LogLevel::* constant, or false to disable fatal error handling
+ * @return ErrorHandler
+ */
+ public static function register(LoggerInterface $logger, $errorLevelMap = array(), $exceptionLevel = null, $fatalLevel = null)
+ {
+ //Forces the autoloader to run for LogLevel. Fixes an autoload issue at compile-time on PHP5.3. See https://github.com/Seldaek/monolog/pull/929
+ class_exists('\\Psr\\Log\\LogLevel', true);
+
+ /** @phpstan-ignore-next-line */
+ $handler = new static($logger);
+ if ($errorLevelMap !== false) {
+ $handler->registerErrorHandler($errorLevelMap);
+ }
+ if ($exceptionLevel !== false) {
+ $handler->registerExceptionHandler($exceptionLevel);
+ }
+ if ($fatalLevel !== false) {
+ $handler->registerFatalHandler($fatalLevel);
+ }
+
+ return $handler;
+ }
+
+ public function registerExceptionHandler($level = null, $callPrevious = true)
+ {
+ $prev = set_exception_handler(array($this, 'handleException'));
+ $this->uncaughtExceptionLevel = $level;
+ if ($callPrevious && $prev) {
+ $this->previousExceptionHandler = $prev;
+ }
+ }
+
+ public function registerErrorHandler(array $levelMap = array(), $callPrevious = true, $errorTypes = -1, $handleOnlyReportedErrors = true)
+ {
+ $prev = set_error_handler(array($this, 'handleError'), $errorTypes);
+ $this->errorLevelMap = array_replace($this->defaultErrorLevelMap(), $levelMap);
+ if ($callPrevious) {
+ $this->previousErrorHandler = $prev ?: true;
+ }
+
+ $this->handleOnlyReportedErrors = $handleOnlyReportedErrors;
+ }
+
+ public function registerFatalHandler($level = null, $reservedMemorySize = 20)
+ {
+ register_shutdown_function(array($this, 'handleFatalError'));
+
+ $this->reservedMemory = str_repeat(' ', 1024 * $reservedMemorySize);
+ $this->fatalLevel = $level;
+ $this->hasFatalErrorHandler = true;
+ }
+
+ protected function defaultErrorLevelMap()
+ {
+ return array(
+ E_ERROR => LogLevel::CRITICAL,
+ E_WARNING => LogLevel::WARNING,
+ E_PARSE => LogLevel::ALERT,
+ E_NOTICE => LogLevel::NOTICE,
+ E_CORE_ERROR => LogLevel::CRITICAL,
+ E_CORE_WARNING => LogLevel::WARNING,
+ E_COMPILE_ERROR => LogLevel::ALERT,
+ E_COMPILE_WARNING => LogLevel::WARNING,
+ E_USER_ERROR => LogLevel::ERROR,
+ E_USER_WARNING => LogLevel::WARNING,
+ E_USER_NOTICE => LogLevel::NOTICE,
+ E_STRICT => LogLevel::NOTICE,
+ E_RECOVERABLE_ERROR => LogLevel::ERROR,
+ E_DEPRECATED => LogLevel::NOTICE,
+ E_USER_DEPRECATED => LogLevel::NOTICE,
+ );
+ }
+
+ /**
+ * @private
+ */
+ public function handleException($e)
+ {
+ $this->logger->log(
+ $this->uncaughtExceptionLevel === null ? LogLevel::ERROR : $this->uncaughtExceptionLevel,
+ sprintf('Uncaught Exception %s: "%s" at %s line %s', Utils::getClass($e), $e->getMessage(), $e->getFile(), $e->getLine()),
+ array('exception' => $e)
+ );
+
+ if ($this->previousExceptionHandler) {
+ call_user_func($this->previousExceptionHandler, $e);
+ }
+
+ exit(255);
+ }
+
+ /**
+ * @private
+ */
+ public function handleError($code, $message, $file = '', $line = 0, $context = array())
+ {
+ if ($this->handleOnlyReportedErrors && !(error_reporting() & $code)) {
+ return;
+ }
+
+ // fatal error codes are ignored if a fatal error handler is present as well to avoid duplicate log entries
+ if (!$this->hasFatalErrorHandler || !in_array($code, self::$fatalErrors, true)) {
+ $level = isset($this->errorLevelMap[$code]) ? $this->errorLevelMap[$code] : LogLevel::CRITICAL;
+ $this->logger->log($level, self::codeToString($code).': '.$message, array('code' => $code, 'message' => $message, 'file' => $file, 'line' => $line));
+ } else {
+ // http://php.net/manual/en/function.debug-backtrace.php
+ // As of 5.3.6, DEBUG_BACKTRACE_IGNORE_ARGS option was added.
+ // Any version less than 5.3.6 must use the DEBUG_BACKTRACE_IGNORE_ARGS constant value '2'.
+ $trace = debug_backtrace((PHP_VERSION_ID < 50306) ? 2 : DEBUG_BACKTRACE_IGNORE_ARGS);
+ array_shift($trace); // Exclude handleError from trace
+ $this->lastFatalTrace = $trace;
+ }
+
+ if ($this->previousErrorHandler === true) {
+ return false;
+ } elseif ($this->previousErrorHandler) {
+ return call_user_func($this->previousErrorHandler, $code, $message, $file, $line, $context);
+ }
+ }
+
+ /**
+ * @private
+ */
+ public function handleFatalError()
+ {
+ $this->reservedMemory = null;
+
+ $lastError = error_get_last();
+ if ($lastError && in_array($lastError['type'], self::$fatalErrors, true)) {
+ $this->logger->log(
+ $this->fatalLevel === null ? LogLevel::ALERT : $this->fatalLevel,
+ 'Fatal Error ('.self::codeToString($lastError['type']).'): '.$lastError['message'],
+ array('code' => $lastError['type'], 'message' => $lastError['message'], 'file' => $lastError['file'], 'line' => $lastError['line'], 'trace' => $this->lastFatalTrace)
+ );
+
+ if ($this->logger instanceof Logger) {
+ foreach ($this->logger->getHandlers() as $handler) {
+ if ($handler instanceof AbstractHandler) {
+ $handler->close();
+ }
+ }
+ }
+ }
+ }
+
+ private static function codeToString($code)
+ {
+ switch ($code) {
+ case E_ERROR:
+ return 'E_ERROR';
+ case E_WARNING:
+ return 'E_WARNING';
+ case E_PARSE:
+ return 'E_PARSE';
+ case E_NOTICE:
+ return 'E_NOTICE';
+ case E_CORE_ERROR:
+ return 'E_CORE_ERROR';
+ case E_CORE_WARNING:
+ return 'E_CORE_WARNING';
+ case E_COMPILE_ERROR:
+ return 'E_COMPILE_ERROR';
+ case E_COMPILE_WARNING:
+ return 'E_COMPILE_WARNING';
+ case E_USER_ERROR:
+ return 'E_USER_ERROR';
+ case E_USER_WARNING:
+ return 'E_USER_WARNING';
+ case E_USER_NOTICE:
+ return 'E_USER_NOTICE';
+ case E_STRICT:
+ return 'E_STRICT';
+ case E_RECOVERABLE_ERROR:
+ return 'E_RECOVERABLE_ERROR';
+ case E_DEPRECATED:
+ return 'E_DEPRECATED';
+ case E_USER_DEPRECATED:
+ return 'E_USER_DEPRECATED';
+ }
+
+ return 'Unknown PHP error';
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/ChromePHPFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/ChromePHPFormatter.php
new file mode 100644
index 000000000..9beda1e76
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/ChromePHPFormatter.php
@@ -0,0 +1,78 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+use Monolog\Logger;
+
+/**
+ * Formats a log message according to the ChromePHP array format
+ *
+ * @author Christophe Coevoet
+ */
+class ChromePHPFormatter implements FormatterInterface
+{
+ /**
+ * Translates Monolog log levels to Wildfire levels.
+ */
+ private $logLevels = array(
+ Logger::DEBUG => 'log',
+ Logger::INFO => 'info',
+ Logger::NOTICE => 'info',
+ Logger::WARNING => 'warn',
+ Logger::ERROR => 'error',
+ Logger::CRITICAL => 'error',
+ Logger::ALERT => 'error',
+ Logger::EMERGENCY => 'error',
+ );
+
+ /**
+ * {@inheritdoc}
+ */
+ public function format(array $record)
+ {
+ // Retrieve the line and file if set and remove them from the formatted extra
+ $backtrace = 'unknown';
+ if (isset($record['extra']['file'], $record['extra']['line'])) {
+ $backtrace = $record['extra']['file'].' : '.$record['extra']['line'];
+ unset($record['extra']['file'], $record['extra']['line']);
+ }
+
+ $message = array('message' => $record['message']);
+ if ($record['context']) {
+ $message['context'] = $record['context'];
+ }
+ if ($record['extra']) {
+ $message['extra'] = $record['extra'];
+ }
+ if (count($message) === 1) {
+ $message = reset($message);
+ }
+
+ return array(
+ $record['channel'],
+ $message,
+ $backtrace,
+ $this->logLevels[$record['level']],
+ );
+ }
+
+ public function formatBatch(array $records)
+ {
+ $formatted = array();
+
+ foreach ($records as $record) {
+ $formatted[] = $this->format($record);
+ }
+
+ return $formatted;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/ElasticaFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/ElasticaFormatter.php
new file mode 100644
index 000000000..4c556cf17
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/ElasticaFormatter.php
@@ -0,0 +1,89 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+use Elastica\Document;
+
+/**
+ * Format a log message into an Elastica Document
+ *
+ * @author Jelle Vink
+ */
+class ElasticaFormatter extends NormalizerFormatter
+{
+ /**
+ * @var string Elastic search index name
+ */
+ protected $index;
+
+ /**
+ * @var string Elastic search document type
+ */
+ protected $type;
+
+ /**
+ * @param string $index Elastic Search index name
+ * @param string $type Elastic Search document type
+ */
+ public function __construct($index, $type)
+ {
+ // elasticsearch requires a ISO 8601 format date with optional millisecond precision.
+ parent::__construct('Y-m-d\TH:i:s.uP');
+
+ $this->index = $index;
+ $this->type = $type;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function format(array $record)
+ {
+ $record = parent::format($record);
+
+ return $this->getDocument($record);
+ }
+
+ /**
+ * Getter index
+ * @return string
+ */
+ public function getIndex()
+ {
+ return $this->index;
+ }
+
+ /**
+ * Getter type
+ * @return string
+ */
+ public function getType()
+ {
+ return $this->type;
+ }
+
+ /**
+ * Convert a log message into an Elastica Document
+ *
+ * @param array $record Log message
+ * @return Document
+ */
+ protected function getDocument($record)
+ {
+ $document = new Document();
+ $document->setData($record);
+ $document->setType($this->type);
+ $document->setIndex($this->index);
+
+ return $document;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/FlowdockFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/FlowdockFormatter.php
new file mode 100644
index 000000000..5094af3c7
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/FlowdockFormatter.php
@@ -0,0 +1,116 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+/**
+ * formats the record to be used in the FlowdockHandler
+ *
+ * @author Dominik Liebler
+ */
+class FlowdockFormatter implements FormatterInterface
+{
+ /**
+ * @var string
+ */
+ private $source;
+
+ /**
+ * @var string
+ */
+ private $sourceEmail;
+
+ /**
+ * @param string $source
+ * @param string $sourceEmail
+ */
+ public function __construct($source, $sourceEmail)
+ {
+ $this->source = $source;
+ $this->sourceEmail = $sourceEmail;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function format(array $record)
+ {
+ $tags = array(
+ '#logs',
+ '#' . strtolower($record['level_name']),
+ '#' . $record['channel'],
+ );
+
+ foreach ($record['extra'] as $value) {
+ $tags[] = '#' . $value;
+ }
+
+ $subject = sprintf(
+ 'in %s: %s - %s',
+ $this->source,
+ $record['level_name'],
+ $this->getShortMessage($record['message'])
+ );
+
+ $record['flowdock'] = array(
+ 'source' => $this->source,
+ 'from_address' => $this->sourceEmail,
+ 'subject' => $subject,
+ 'content' => $record['message'],
+ 'tags' => $tags,
+ 'project' => $this->source,
+ );
+
+ return $record;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function formatBatch(array $records)
+ {
+ $formatted = array();
+
+ foreach ($records as $record) {
+ $formatted[] = $this->format($record);
+ }
+
+ return $formatted;
+ }
+
+ /**
+ * @param string $message
+ *
+ * @return string
+ */
+ public function getShortMessage($message)
+ {
+ static $hasMbString;
+
+ if (null === $hasMbString) {
+ $hasMbString = function_exists('mb_strlen');
+ }
+
+ $maxLength = 45;
+
+ if ($hasMbString) {
+ if (mb_strlen($message, 'UTF-8') > $maxLength) {
+ $message = mb_substr($message, 0, $maxLength - 4, 'UTF-8') . ' ...';
+ }
+ } else {
+ if (strlen($message) > $maxLength) {
+ $message = substr($message, 0, $maxLength - 4) . ' ...';
+ }
+ }
+
+ return $message;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/FluentdFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/FluentdFormatter.php
new file mode 100644
index 000000000..f8ead4756
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/FluentdFormatter.php
@@ -0,0 +1,88 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+use Monolog\Utils;
+
+/**
+ * Class FluentdFormatter
+ *
+ * Serializes a log message to Fluentd unix socket protocol
+ *
+ * Fluentd config:
+ *
+ *
+ * type unix
+ * path /var/run/td-agent/td-agent.sock
+ *
+ *
+ * Monolog setup:
+ *
+ * $logger = new Monolog\Logger('fluent.tag');
+ * $fluentHandler = new Monolog\Handler\SocketHandler('unix:///var/run/td-agent/td-agent.sock');
+ * $fluentHandler->setFormatter(new Monolog\Formatter\FluentdFormatter());
+ * $logger->pushHandler($fluentHandler);
+ *
+ * @author Andrius Putna
+ */
+class FluentdFormatter implements FormatterInterface
+{
+ /**
+ * @var bool $levelTag should message level be a part of the fluentd tag
+ */
+ protected $levelTag = false;
+
+ public function __construct($levelTag = false)
+ {
+ if (!function_exists('json_encode')) {
+ throw new \RuntimeException('PHP\'s json extension is required to use Monolog\'s FluentdUnixFormatter');
+ }
+
+ $this->levelTag = (bool) $levelTag;
+ }
+
+ public function isUsingLevelsInTag()
+ {
+ return $this->levelTag;
+ }
+
+ public function format(array $record)
+ {
+ $tag = $record['channel'];
+ if ($this->levelTag) {
+ $tag .= '.' . strtolower($record['level_name']);
+ }
+
+ $message = array(
+ 'message' => $record['message'],
+ 'context' => $record['context'],
+ 'extra' => $record['extra'],
+ );
+
+ if (!$this->levelTag) {
+ $message['level'] = $record['level'];
+ $message['level_name'] = $record['level_name'];
+ }
+
+ return Utils::jsonEncode(array($tag, $record['datetime']->getTimestamp(), $message));
+ }
+
+ public function formatBatch(array $records)
+ {
+ $message = '';
+ foreach ($records as $record) {
+ $message .= $this->format($record);
+ }
+
+ return $message;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/FormatterInterface.php b/vendor/monolog/monolog/src/Monolog/Formatter/FormatterInterface.php
new file mode 100644
index 000000000..b5de75111
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/FormatterInterface.php
@@ -0,0 +1,36 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+/**
+ * Interface for formatters
+ *
+ * @author Jordi Boggiano
+ */
+interface FormatterInterface
+{
+ /**
+ * Formats a log record.
+ *
+ * @param array $record A record to format
+ * @return mixed The formatted record
+ */
+ public function format(array $record);
+
+ /**
+ * Formats a set of log records.
+ *
+ * @param array $records A set of records to format
+ * @return mixed The formatted set of records
+ */
+ public function formatBatch(array $records);
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/GelfMessageFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/GelfMessageFormatter.php
new file mode 100644
index 000000000..2c1b0e86c
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/GelfMessageFormatter.php
@@ -0,0 +1,138 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+use Monolog\Logger;
+use Gelf\Message;
+
+/**
+ * Serializes a log message to GELF
+ * @see http://www.graylog2.org/about/gelf
+ *
+ * @author Matt Lehner
+ */
+class GelfMessageFormatter extends NormalizerFormatter
+{
+ const DEFAULT_MAX_LENGTH = 32766;
+
+ /**
+ * @var string the name of the system for the Gelf log message
+ */
+ protected $systemName;
+
+ /**
+ * @var string a prefix for 'extra' fields from the Monolog record (optional)
+ */
+ protected $extraPrefix;
+
+ /**
+ * @var string a prefix for 'context' fields from the Monolog record (optional)
+ */
+ protected $contextPrefix;
+
+ /**
+ * @var int max length per field
+ */
+ protected $maxLength;
+
+ /**
+ * Translates Monolog log levels to Graylog2 log priorities.
+ */
+ private $logLevels = array(
+ Logger::DEBUG => 7,
+ Logger::INFO => 6,
+ Logger::NOTICE => 5,
+ Logger::WARNING => 4,
+ Logger::ERROR => 3,
+ Logger::CRITICAL => 2,
+ Logger::ALERT => 1,
+ Logger::EMERGENCY => 0,
+ );
+
+ public function __construct($systemName = null, $extraPrefix = null, $contextPrefix = 'ctxt_', $maxLength = null)
+ {
+ parent::__construct('U.u');
+
+ $this->systemName = $systemName ?: gethostname();
+
+ $this->extraPrefix = $extraPrefix;
+ $this->contextPrefix = $contextPrefix;
+ $this->maxLength = is_null($maxLength) ? self::DEFAULT_MAX_LENGTH : $maxLength;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function format(array $record)
+ {
+ $record = parent::format($record);
+
+ if (!isset($record['datetime'], $record['message'], $record['level'])) {
+ throw new \InvalidArgumentException('The record should at least contain datetime, message and level keys, '.var_export($record, true).' given');
+ }
+
+ $message = new Message();
+ $message
+ ->setTimestamp($record['datetime'])
+ ->setShortMessage((string) $record['message'])
+ ->setHost($this->systemName)
+ ->setLevel($this->logLevels[$record['level']]);
+
+ // message length + system name length + 200 for padding / metadata
+ $len = 200 + strlen((string) $record['message']) + strlen($this->systemName);
+
+ if ($len > $this->maxLength) {
+ $message->setShortMessage(substr($record['message'], 0, $this->maxLength));
+ }
+
+ if (isset($record['channel'])) {
+ $message->setFacility($record['channel']);
+ }
+ if (isset($record['extra']['line'])) {
+ $message->setLine($record['extra']['line']);
+ unset($record['extra']['line']);
+ }
+ if (isset($record['extra']['file'])) {
+ $message->setFile($record['extra']['file']);
+ unset($record['extra']['file']);
+ }
+
+ foreach ($record['extra'] as $key => $val) {
+ $val = is_scalar($val) || null === $val ? $val : $this->toJson($val);
+ $len = strlen($this->extraPrefix . $key . $val);
+ if ($len > $this->maxLength) {
+ $message->setAdditional($this->extraPrefix . $key, substr($val, 0, $this->maxLength));
+ break;
+ }
+ $message->setAdditional($this->extraPrefix . $key, $val);
+ }
+
+ foreach ($record['context'] as $key => $val) {
+ $val = is_scalar($val) || null === $val ? $val : $this->toJson($val);
+ $len = strlen($this->contextPrefix . $key . $val);
+ if ($len > $this->maxLength) {
+ $message->setAdditional($this->contextPrefix . $key, substr($val, 0, $this->maxLength));
+ break;
+ }
+ $message->setAdditional($this->contextPrefix . $key, $val);
+ }
+
+ if (null === $message->getFile() && isset($record['context']['exception']['file'])) {
+ if (preg_match("/^(.+):([0-9]+)$/", $record['context']['exception']['file'], $matches)) {
+ $message->setFile($matches[1]);
+ $message->setLine($matches[2]);
+ }
+ }
+
+ return $message;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/HtmlFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/HtmlFormatter.php
new file mode 100644
index 000000000..9e8d2d018
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/HtmlFormatter.php
@@ -0,0 +1,142 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+use Monolog\Logger;
+use Monolog\Utils;
+
+/**
+ * Formats incoming records into an HTML table
+ *
+ * This is especially useful for html email logging
+ *
+ * @author Tiago Brito
+ */
+class HtmlFormatter extends NormalizerFormatter
+{
+ /**
+ * Translates Monolog log levels to html color priorities.
+ */
+ protected $logLevels = array(
+ Logger::DEBUG => '#cccccc',
+ Logger::INFO => '#468847',
+ Logger::NOTICE => '#3a87ad',
+ Logger::WARNING => '#c09853',
+ Logger::ERROR => '#f0ad4e',
+ Logger::CRITICAL => '#FF7708',
+ Logger::ALERT => '#C12A19',
+ Logger::EMERGENCY => '#000000',
+ );
+
+ /**
+ * @param string $dateFormat The format of the timestamp: one supported by DateTime::format
+ */
+ public function __construct($dateFormat = null)
+ {
+ parent::__construct($dateFormat);
+ }
+
+ /**
+ * Creates an HTML table row
+ *
+ * @param string $th Row header content
+ * @param string $td Row standard cell content
+ * @param bool $escapeTd false if td content must not be html escaped
+ * @return string
+ */
+ protected function addRow($th, $td = ' ', $escapeTd = true)
+ {
+ $th = htmlspecialchars($th, ENT_NOQUOTES, 'UTF-8');
+ if ($escapeTd) {
+ $td = ''.htmlspecialchars($td, ENT_NOQUOTES, 'UTF-8').' ';
+ }
+
+ return "\n$th: \n".$td." \n ";
+ }
+
+ /**
+ * Create a HTML h1 tag
+ *
+ * @param string $title Text to be in the h1
+ * @param int $level Error level
+ * @return string
+ */
+ protected function addTitle($title, $level)
+ {
+ $title = htmlspecialchars($title, ENT_NOQUOTES, 'UTF-8');
+
+ return ''.$title.' ';
+ }
+
+ /**
+ * Formats a log record.
+ *
+ * @param array $record A record to format
+ * @return mixed The formatted record
+ */
+ public function format(array $record)
+ {
+ $output = $this->addTitle($record['level_name'], $record['level']);
+ $output .= '';
+
+ $output .= $this->addRow('Message', (string) $record['message']);
+ $output .= $this->addRow('Time', $record['datetime']->format($this->dateFormat));
+ $output .= $this->addRow('Channel', $record['channel']);
+ if ($record['context']) {
+ $embeddedTable = '';
+ foreach ($record['context'] as $key => $value) {
+ $embeddedTable .= $this->addRow($key, $this->convertToString($value));
+ }
+ $embeddedTable .= '
';
+ $output .= $this->addRow('Context', $embeddedTable, false);
+ }
+ if ($record['extra']) {
+ $embeddedTable = '';
+ foreach ($record['extra'] as $key => $value) {
+ $embeddedTable .= $this->addRow($key, $this->convertToString($value));
+ }
+ $embeddedTable .= '
';
+ $output .= $this->addRow('Extra', $embeddedTable, false);
+ }
+
+ return $output.'
';
+ }
+
+ /**
+ * Formats a set of log records.
+ *
+ * @param array $records A set of records to format
+ * @return mixed The formatted set of records
+ */
+ public function formatBatch(array $records)
+ {
+ $message = '';
+ foreach ($records as $record) {
+ $message .= $this->format($record);
+ }
+
+ return $message;
+ }
+
+ protected function convertToString($data)
+ {
+ if (null === $data || is_scalar($data)) {
+ return (string) $data;
+ }
+
+ $data = $this->normalize($data);
+ if (version_compare(PHP_VERSION, '5.4.0', '>=')) {
+ return Utils::jsonEncode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE, true);
+ }
+
+ return str_replace('\\/', '/', Utils::jsonEncode($data, null, true));
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/JsonFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/JsonFormatter.php
new file mode 100644
index 000000000..4c5422d56
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/JsonFormatter.php
@@ -0,0 +1,214 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+use Exception;
+use Monolog\Utils;
+use Throwable;
+
+/**
+ * Encodes whatever record data is passed to it as json
+ *
+ * This can be useful to log to databases or remote APIs
+ *
+ * @author Jordi Boggiano
+ */
+class JsonFormatter extends NormalizerFormatter
+{
+ const BATCH_MODE_JSON = 1;
+ const BATCH_MODE_NEWLINES = 2;
+
+ protected $batchMode;
+ protected $appendNewline;
+
+ /**
+ * @var bool
+ */
+ protected $includeStacktraces = false;
+
+ /**
+ * @param int $batchMode
+ * @param bool $appendNewline
+ * @param int $maxDepth
+ */
+ public function __construct($batchMode = self::BATCH_MODE_JSON, $appendNewline = true, $maxDepth = 9)
+ {
+ parent::__construct(null, $maxDepth);
+ $this->batchMode = $batchMode;
+ $this->appendNewline = $appendNewline;
+ }
+
+ /**
+ * The batch mode option configures the formatting style for
+ * multiple records. By default, multiple records will be
+ * formatted as a JSON-encoded array. However, for
+ * compatibility with some API endpoints, alternative styles
+ * are available.
+ *
+ * @return int
+ */
+ public function getBatchMode()
+ {
+ return $this->batchMode;
+ }
+
+ /**
+ * True if newlines are appended to every formatted record
+ *
+ * @return bool
+ */
+ public function isAppendingNewlines()
+ {
+ return $this->appendNewline;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function format(array $record)
+ {
+ return $this->toJson($this->normalize($record), true) . ($this->appendNewline ? "\n" : '');
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function formatBatch(array $records)
+ {
+ switch ($this->batchMode) {
+ case static::BATCH_MODE_NEWLINES:
+ return $this->formatBatchNewlines($records);
+
+ case static::BATCH_MODE_JSON:
+ default:
+ return $this->formatBatchJson($records);
+ }
+ }
+
+ /**
+ * @param bool $include
+ */
+ public function includeStacktraces($include = true)
+ {
+ $this->includeStacktraces = $include;
+ }
+
+ /**
+ * Return a JSON-encoded array of records.
+ *
+ * @param array $records
+ * @return string
+ */
+ protected function formatBatchJson(array $records)
+ {
+ return $this->toJson($this->normalize($records), true);
+ }
+
+ /**
+ * Use new lines to separate records instead of a
+ * JSON-encoded array.
+ *
+ * @param array $records
+ * @return string
+ */
+ protected function formatBatchNewlines(array $records)
+ {
+ $instance = $this;
+
+ $oldNewline = $this->appendNewline;
+ $this->appendNewline = false;
+ array_walk($records, function (&$value, $key) use ($instance) {
+ $value = $instance->format($value);
+ });
+ $this->appendNewline = $oldNewline;
+
+ return implode("\n", $records);
+ }
+
+ /**
+ * Normalizes given $data.
+ *
+ * @param mixed $data
+ *
+ * @return mixed
+ */
+ protected function normalize($data, $depth = 0)
+ {
+ if ($depth > $this->maxDepth) {
+ return 'Over '.$this->maxDepth.' levels deep, aborting normalization';
+ }
+
+ if (is_array($data)) {
+ $normalized = array();
+
+ $count = 1;
+ foreach ($data as $key => $value) {
+ if ($count++ > 1000) {
+ $normalized['...'] = 'Over 1000 items ('.count($data).' total), aborting normalization';
+ break;
+ }
+
+ $normalized[$key] = $this->normalize($value, $depth+1);
+ }
+
+ return $normalized;
+ }
+
+ if ($data instanceof Exception || $data instanceof Throwable) {
+ return $this->normalizeException($data);
+ }
+
+ if (is_resource($data)) {
+ return parent::normalize($data);
+ }
+
+ return $data;
+ }
+
+ /**
+ * Normalizes given exception with or without its own stack trace based on
+ * `includeStacktraces` property.
+ *
+ * @param Exception|Throwable $e
+ *
+ * @return array
+ */
+ protected function normalizeException($e)
+ {
+ // TODO 2.0 only check for Throwable
+ if (!$e instanceof Exception && !$e instanceof Throwable) {
+ throw new \InvalidArgumentException('Exception/Throwable expected, got '.gettype($e).' / '.Utils::getClass($e));
+ }
+
+ $data = array(
+ 'class' => Utils::getClass($e),
+ 'message' => $e->getMessage(),
+ 'code' => (int) $e->getCode(),
+ 'file' => $e->getFile().':'.$e->getLine(),
+ );
+
+ if ($this->includeStacktraces) {
+ $trace = $e->getTrace();
+ foreach ($trace as $frame) {
+ if (isset($frame['file'])) {
+ $data['trace'][] = $frame['file'].':'.$frame['line'];
+ }
+ }
+ }
+
+ if ($previous = $e->getPrevious()) {
+ $data['previous'] = $this->normalizeException($previous);
+ }
+
+ return $data;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/LineFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/LineFormatter.php
new file mode 100644
index 000000000..acc1fd38f
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/LineFormatter.php
@@ -0,0 +1,181 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+use Monolog\Utils;
+
+/**
+ * Formats incoming records into a one-line string
+ *
+ * This is especially useful for logging to files
+ *
+ * @author Jordi Boggiano
+ * @author Christophe Coevoet
+ */
+class LineFormatter extends NormalizerFormatter
+{
+ const SIMPLE_FORMAT = "[%datetime%] %channel%.%level_name%: %message% %context% %extra%\n";
+
+ protected $format;
+ protected $allowInlineLineBreaks;
+ protected $ignoreEmptyContextAndExtra;
+ protected $includeStacktraces;
+
+ /**
+ * @param string $format The format of the message
+ * @param string $dateFormat The format of the timestamp: one supported by DateTime::format
+ * @param bool $allowInlineLineBreaks Whether to allow inline line breaks in log entries
+ * @param bool $ignoreEmptyContextAndExtra
+ */
+ public function __construct($format = null, $dateFormat = null, $allowInlineLineBreaks = false, $ignoreEmptyContextAndExtra = false)
+ {
+ $this->format = $format ?: static::SIMPLE_FORMAT;
+ $this->allowInlineLineBreaks = $allowInlineLineBreaks;
+ $this->ignoreEmptyContextAndExtra = $ignoreEmptyContextAndExtra;
+ parent::__construct($dateFormat);
+ }
+
+ public function includeStacktraces($include = true)
+ {
+ $this->includeStacktraces = $include;
+ if ($this->includeStacktraces) {
+ $this->allowInlineLineBreaks = true;
+ }
+ }
+
+ public function allowInlineLineBreaks($allow = true)
+ {
+ $this->allowInlineLineBreaks = $allow;
+ }
+
+ public function ignoreEmptyContextAndExtra($ignore = true)
+ {
+ $this->ignoreEmptyContextAndExtra = $ignore;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function format(array $record)
+ {
+ $vars = parent::format($record);
+
+ $output = $this->format;
+
+ foreach ($vars['extra'] as $var => $val) {
+ if (false !== strpos($output, '%extra.'.$var.'%')) {
+ $output = str_replace('%extra.'.$var.'%', $this->stringify($val), $output);
+ unset($vars['extra'][$var]);
+ }
+ }
+
+
+ foreach ($vars['context'] as $var => $val) {
+ if (false !== strpos($output, '%context.'.$var.'%')) {
+ $output = str_replace('%context.'.$var.'%', $this->stringify($val), $output);
+ unset($vars['context'][$var]);
+ }
+ }
+
+ if ($this->ignoreEmptyContextAndExtra) {
+ if (empty($vars['context'])) {
+ unset($vars['context']);
+ $output = str_replace('%context%', '', $output);
+ }
+
+ if (empty($vars['extra'])) {
+ unset($vars['extra']);
+ $output = str_replace('%extra%', '', $output);
+ }
+ }
+
+ foreach ($vars as $var => $val) {
+ if (false !== strpos($output, '%'.$var.'%')) {
+ $output = str_replace('%'.$var.'%', $this->stringify($val), $output);
+ }
+ }
+
+ // remove leftover %extra.xxx% and %context.xxx% if any
+ if (false !== strpos($output, '%')) {
+ $output = preg_replace('/%(?:extra|context)\..+?%/', '', $output);
+ }
+
+ return $output;
+ }
+
+ public function formatBatch(array $records)
+ {
+ $message = '';
+ foreach ($records as $record) {
+ $message .= $this->format($record);
+ }
+
+ return $message;
+ }
+
+ public function stringify($value)
+ {
+ return $this->replaceNewlines($this->convertToString($value));
+ }
+
+ protected function normalizeException($e)
+ {
+ // TODO 2.0 only check for Throwable
+ if (!$e instanceof \Exception && !$e instanceof \Throwable) {
+ throw new \InvalidArgumentException('Exception/Throwable expected, got '.gettype($e).' / '.Utils::getClass($e));
+ }
+
+ $previousText = '';
+ if ($previous = $e->getPrevious()) {
+ do {
+ $previousText .= ', '.Utils::getClass($previous).'(code: '.$previous->getCode().'): '.$previous->getMessage().' at '.$previous->getFile().':'.$previous->getLine();
+ } while ($previous = $previous->getPrevious());
+ }
+
+ $str = '[object] ('.Utils::getClass($e).'(code: '.$e->getCode().'): '.$e->getMessage().' at '.$e->getFile().':'.$e->getLine().$previousText.')';
+ if ($this->includeStacktraces) {
+ $str .= "\n[stacktrace]\n".$e->getTraceAsString()."\n";
+ }
+
+ return $str;
+ }
+
+ protected function convertToString($data)
+ {
+ if (null === $data || is_bool($data)) {
+ return var_export($data, true);
+ }
+
+ if (is_scalar($data)) {
+ return (string) $data;
+ }
+
+ if (version_compare(PHP_VERSION, '5.4.0', '>=')) {
+ return $this->toJson($data, true);
+ }
+
+ return str_replace('\\/', '/', $this->toJson($data, true));
+ }
+
+ protected function replaceNewlines($str)
+ {
+ if ($this->allowInlineLineBreaks) {
+ if (0 === strpos($str, '{')) {
+ return str_replace(array('\r', '\n'), array("\r", "\n"), $str);
+ }
+
+ return $str;
+ }
+
+ return str_replace(array("\r\n", "\r", "\n"), ' ', $str);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/LogglyFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/LogglyFormatter.php
new file mode 100644
index 000000000..401859bba
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/LogglyFormatter.php
@@ -0,0 +1,47 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+/**
+ * Encodes message information into JSON in a format compatible with Loggly.
+ *
+ * @author Adam Pancutt
+ */
+class LogglyFormatter extends JsonFormatter
+{
+ /**
+ * Overrides the default batch mode to new lines for compatibility with the
+ * Loggly bulk API.
+ *
+ * @param int $batchMode
+ */
+ public function __construct($batchMode = self::BATCH_MODE_NEWLINES, $appendNewline = false)
+ {
+ parent::__construct($batchMode, $appendNewline);
+ }
+
+ /**
+ * Appends the 'timestamp' parameter for indexing by Loggly.
+ *
+ * @see https://www.loggly.com/docs/automated-parsing/#json
+ * @see \Monolog\Formatter\JsonFormatter::format()
+ */
+ public function format(array $record)
+ {
+ if (isset($record["datetime"]) && ($record["datetime"] instanceof \DateTime)) {
+ $record["timestamp"] = $record["datetime"]->format("Y-m-d\TH:i:s.uO");
+ // TODO 2.0 unset the 'datetime' parameter, retained for BC
+ }
+
+ return parent::format($record);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/LogstashFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/LogstashFormatter.php
new file mode 100644
index 000000000..8f83bec04
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/LogstashFormatter.php
@@ -0,0 +1,166 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+/**
+ * Serializes a log message to Logstash Event Format
+ *
+ * @see http://logstash.net/
+ * @see https://github.com/logstash/logstash/blob/master/lib/logstash/event.rb
+ *
+ * @author Tim Mower
+ */
+class LogstashFormatter extends NormalizerFormatter
+{
+ const V0 = 0;
+ const V1 = 1;
+
+ /**
+ * @var string the name of the system for the Logstash log message, used to fill the @source field
+ */
+ protected $systemName;
+
+ /**
+ * @var string an application name for the Logstash log message, used to fill the @type field
+ */
+ protected $applicationName;
+
+ /**
+ * @var string a prefix for 'extra' fields from the Monolog record (optional)
+ */
+ protected $extraPrefix;
+
+ /**
+ * @var string a prefix for 'context' fields from the Monolog record (optional)
+ */
+ protected $contextPrefix;
+
+ /**
+ * @var int logstash format version to use
+ */
+ protected $version;
+
+ /**
+ * @param string $applicationName the application that sends the data, used as the "type" field of logstash
+ * @param string $systemName the system/machine name, used as the "source" field of logstash, defaults to the hostname of the machine
+ * @param string $extraPrefix prefix for extra keys inside logstash "fields"
+ * @param string $contextPrefix prefix for context keys inside logstash "fields", defaults to ctxt_
+ * @param int $version the logstash format version to use, defaults to 0
+ */
+ public function __construct($applicationName, $systemName = null, $extraPrefix = null, $contextPrefix = 'ctxt_', $version = self::V0)
+ {
+ // logstash requires a ISO 8601 format date with optional millisecond precision.
+ parent::__construct('Y-m-d\TH:i:s.uP');
+
+ $this->systemName = $systemName ?: gethostname();
+ $this->applicationName = $applicationName;
+ $this->extraPrefix = $extraPrefix;
+ $this->contextPrefix = $contextPrefix;
+ $this->version = $version;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function format(array $record)
+ {
+ $record = parent::format($record);
+
+ if ($this->version === self::V1) {
+ $message = $this->formatV1($record);
+ } else {
+ $message = $this->formatV0($record);
+ }
+
+ return $this->toJson($message) . "\n";
+ }
+
+ protected function formatV0(array $record)
+ {
+ if (empty($record['datetime'])) {
+ $record['datetime'] = gmdate('c');
+ }
+ $message = array(
+ '@timestamp' => $record['datetime'],
+ '@source' => $this->systemName,
+ '@fields' => array(),
+ );
+ if (isset($record['message'])) {
+ $message['@message'] = $record['message'];
+ }
+ if (isset($record['channel'])) {
+ $message['@tags'] = array($record['channel']);
+ $message['@fields']['channel'] = $record['channel'];
+ }
+ if (isset($record['level'])) {
+ $message['@fields']['level'] = $record['level'];
+ }
+ if ($this->applicationName) {
+ $message['@type'] = $this->applicationName;
+ }
+ if (isset($record['extra']['server'])) {
+ $message['@source_host'] = $record['extra']['server'];
+ }
+ if (isset($record['extra']['url'])) {
+ $message['@source_path'] = $record['extra']['url'];
+ }
+ if (!empty($record['extra'])) {
+ foreach ($record['extra'] as $key => $val) {
+ $message['@fields'][$this->extraPrefix . $key] = $val;
+ }
+ }
+ if (!empty($record['context'])) {
+ foreach ($record['context'] as $key => $val) {
+ $message['@fields'][$this->contextPrefix . $key] = $val;
+ }
+ }
+
+ return $message;
+ }
+
+ protected function formatV1(array $record)
+ {
+ if (empty($record['datetime'])) {
+ $record['datetime'] = gmdate('c');
+ }
+ $message = array(
+ '@timestamp' => $record['datetime'],
+ '@version' => 1,
+ 'host' => $this->systemName,
+ );
+ if (isset($record['message'])) {
+ $message['message'] = $record['message'];
+ }
+ if (isset($record['channel'])) {
+ $message['type'] = $record['channel'];
+ $message['channel'] = $record['channel'];
+ }
+ if (isset($record['level_name'])) {
+ $message['level'] = $record['level_name'];
+ }
+ if ($this->applicationName) {
+ $message['type'] = $this->applicationName;
+ }
+ if (!empty($record['extra'])) {
+ foreach ($record['extra'] as $key => $val) {
+ $message[$this->extraPrefix . $key] = $val;
+ }
+ }
+ if (!empty($record['context'])) {
+ foreach ($record['context'] as $key => $val) {
+ $message[$this->contextPrefix . $key] = $val;
+ }
+ }
+
+ return $message;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/MongoDBFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/MongoDBFormatter.php
new file mode 100644
index 000000000..bd9e4c02b
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/MongoDBFormatter.php
@@ -0,0 +1,107 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+use Monolog\Utils;
+
+/**
+ * Formats a record for use with the MongoDBHandler.
+ *
+ * @author Florian Plattner
+ */
+class MongoDBFormatter implements FormatterInterface
+{
+ private $exceptionTraceAsString;
+ private $maxNestingLevel;
+
+ /**
+ * @param int $maxNestingLevel 0 means infinite nesting, the $record itself is level 1, $record['context'] is 2
+ * @param bool $exceptionTraceAsString set to false to log exception traces as a sub documents instead of strings
+ */
+ public function __construct($maxNestingLevel = 3, $exceptionTraceAsString = true)
+ {
+ $this->maxNestingLevel = max($maxNestingLevel, 0);
+ $this->exceptionTraceAsString = (bool) $exceptionTraceAsString;
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public function format(array $record)
+ {
+ return $this->formatArray($record);
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public function formatBatch(array $records)
+ {
+ foreach ($records as $key => $record) {
+ $records[$key] = $this->format($record);
+ }
+
+ return $records;
+ }
+
+ protected function formatArray(array $record, $nestingLevel = 0)
+ {
+ if ($this->maxNestingLevel == 0 || $nestingLevel <= $this->maxNestingLevel) {
+ foreach ($record as $name => $value) {
+ if ($value instanceof \DateTime) {
+ $record[$name] = $this->formatDate($value, $nestingLevel + 1);
+ } elseif ($value instanceof \Exception) {
+ $record[$name] = $this->formatException($value, $nestingLevel + 1);
+ } elseif (is_array($value)) {
+ $record[$name] = $this->formatArray($value, $nestingLevel + 1);
+ } elseif (is_object($value)) {
+ $record[$name] = $this->formatObject($value, $nestingLevel + 1);
+ }
+ }
+ } else {
+ $record = '[...]';
+ }
+
+ return $record;
+ }
+
+ protected function formatObject($value, $nestingLevel)
+ {
+ $objectVars = get_object_vars($value);
+ $objectVars['class'] = Utils::getClass($value);
+
+ return $this->formatArray($objectVars, $nestingLevel);
+ }
+
+ protected function formatException(\Exception $exception, $nestingLevel)
+ {
+ $formattedException = array(
+ 'class' => Utils::getClass($exception),
+ 'message' => $exception->getMessage(),
+ 'code' => (int) $exception->getCode(),
+ 'file' => $exception->getFile() . ':' . $exception->getLine(),
+ );
+
+ if ($this->exceptionTraceAsString === true) {
+ $formattedException['trace'] = $exception->getTraceAsString();
+ } else {
+ $formattedException['trace'] = $exception->getTrace();
+ }
+
+ return $this->formatArray($formattedException, $nestingLevel);
+ }
+
+ protected function formatDate(\DateTime $value, $nestingLevel)
+ {
+ return new \MongoDate($value->getTimestamp());
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/NormalizerFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/NormalizerFormatter.php
new file mode 100644
index 000000000..010466b4a
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/NormalizerFormatter.php
@@ -0,0 +1,199 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+use Exception;
+use Monolog\Utils;
+
+/**
+ * Normalizes incoming records to remove objects/resources so it's easier to dump to various targets
+ *
+ * @author Jordi Boggiano
+ */
+class NormalizerFormatter implements FormatterInterface
+{
+ const SIMPLE_DATE = "Y-m-d H:i:s";
+
+ protected $dateFormat;
+ protected $maxDepth;
+
+ /**
+ * @param string $dateFormat The format of the timestamp: one supported by DateTime::format
+ * @param int $maxDepth
+ */
+ public function __construct($dateFormat = null, $maxDepth = 9)
+ {
+ $this->dateFormat = $dateFormat ?: static::SIMPLE_DATE;
+ $this->maxDepth = $maxDepth;
+ if (!function_exists('json_encode')) {
+ throw new \RuntimeException('PHP\'s json extension is required to use Monolog\'s NormalizerFormatter');
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function format(array $record)
+ {
+ return $this->normalize($record);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function formatBatch(array $records)
+ {
+ foreach ($records as $key => $record) {
+ $records[$key] = $this->format($record);
+ }
+
+ return $records;
+ }
+
+ /**
+ * @return int
+ */
+ public function getMaxDepth()
+ {
+ return $this->maxDepth;
+ }
+
+ /**
+ * @param int $maxDepth
+ */
+ public function setMaxDepth($maxDepth)
+ {
+ $this->maxDepth = $maxDepth;
+ }
+
+ protected function normalize($data, $depth = 0)
+ {
+ if ($depth > $this->maxDepth) {
+ return 'Over '.$this->maxDepth.' levels deep, aborting normalization';
+ }
+
+ if (null === $data || is_scalar($data)) {
+ if (is_float($data)) {
+ if (is_infinite($data)) {
+ return ($data > 0 ? '' : '-') . 'INF';
+ }
+ if (is_nan($data)) {
+ return 'NaN';
+ }
+ }
+
+ return $data;
+ }
+
+ if (is_array($data)) {
+ $normalized = array();
+
+ $count = 1;
+ foreach ($data as $key => $value) {
+ if ($count++ > 1000) {
+ $normalized['...'] = 'Over 1000 items ('.count($data).' total), aborting normalization';
+ break;
+ }
+
+ $normalized[$key] = $this->normalize($value, $depth+1);
+ }
+
+ return $normalized;
+ }
+
+ if ($data instanceof \DateTime) {
+ return $data->format($this->dateFormat);
+ }
+
+ if (is_object($data)) {
+ // TODO 2.0 only check for Throwable
+ if ($data instanceof Exception || (PHP_VERSION_ID > 70000 && $data instanceof \Throwable)) {
+ return $this->normalizeException($data);
+ }
+
+ // non-serializable objects that implement __toString stringified
+ if (method_exists($data, '__toString') && !$data instanceof \JsonSerializable) {
+ $value = $data->__toString();
+ } else {
+ // the rest is json-serialized in some way
+ $value = $this->toJson($data, true);
+ }
+
+ return sprintf("[object] (%s: %s)", Utils::getClass($data), $value);
+ }
+
+ if (is_resource($data)) {
+ return sprintf('[resource] (%s)', get_resource_type($data));
+ }
+
+ return '[unknown('.gettype($data).')]';
+ }
+
+ protected function normalizeException($e)
+ {
+ // TODO 2.0 only check for Throwable
+ if (!$e instanceof Exception && !$e instanceof \Throwable) {
+ throw new \InvalidArgumentException('Exception/Throwable expected, got '.gettype($e).' / '.Utils::getClass($e));
+ }
+
+ $data = array(
+ 'class' => Utils::getClass($e),
+ 'message' => $e->getMessage(),
+ 'code' => (int) $e->getCode(),
+ 'file' => $e->getFile().':'.$e->getLine(),
+ );
+
+ if ($e instanceof \SoapFault) {
+ if (isset($e->faultcode)) {
+ $data['faultcode'] = $e->faultcode;
+ }
+
+ if (isset($e->faultactor)) {
+ $data['faultactor'] = $e->faultactor;
+ }
+
+ if (isset($e->detail)) {
+ if (is_string($e->detail)) {
+ $data['detail'] = $e->detail;
+ } elseif (is_object($e->detail) || is_array($e->detail)) {
+ $data['detail'] = $this->toJson($e->detail, true);
+ }
+ }
+ }
+
+ $trace = $e->getTrace();
+ foreach ($trace as $frame) {
+ if (isset($frame['file'])) {
+ $data['trace'][] = $frame['file'].':'.$frame['line'];
+ }
+ }
+
+ if ($previous = $e->getPrevious()) {
+ $data['previous'] = $this->normalizeException($previous);
+ }
+
+ return $data;
+ }
+
+ /**
+ * Return the JSON representation of a value
+ *
+ * @param mixed $data
+ * @param bool $ignoreErrors
+ * @throws \RuntimeException if encoding fails and errors are not ignored
+ * @return string
+ */
+ protected function toJson($data, $ignoreErrors = false)
+ {
+ return Utils::jsonEncode($data, null, $ignoreErrors);
+ }
+}
\ No newline at end of file
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/ScalarFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/ScalarFormatter.php
new file mode 100644
index 000000000..5d345d53c
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/ScalarFormatter.php
@@ -0,0 +1,48 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+/**
+ * Formats data into an associative array of scalar values.
+ * Objects and arrays will be JSON encoded.
+ *
+ * @author Andrew Lawson
+ */
+class ScalarFormatter extends NormalizerFormatter
+{
+ /**
+ * {@inheritdoc}
+ */
+ public function format(array $record)
+ {
+ foreach ($record as $key => $value) {
+ $record[$key] = $this->normalizeValue($value);
+ }
+
+ return $record;
+ }
+
+ /**
+ * @param mixed $value
+ * @return mixed
+ */
+ protected function normalizeValue($value)
+ {
+ $normalized = $this->normalize($value);
+
+ if (is_array($normalized) || is_object($normalized)) {
+ return $this->toJson($normalized, true);
+ }
+
+ return $normalized;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Formatter/WildfireFormatter.php b/vendor/monolog/monolog/src/Monolog/Formatter/WildfireFormatter.php
new file mode 100644
index 000000000..65dba99c9
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Formatter/WildfireFormatter.php
@@ -0,0 +1,113 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Formatter;
+
+use Monolog\Logger;
+
+/**
+ * Serializes a log message according to Wildfire's header requirements
+ *
+ * @author Eric Clemmons (@ericclemmons)
+ * @author Christophe Coevoet
+ * @author Kirill chEbba Chebunin
+ */
+class WildfireFormatter extends NormalizerFormatter
+{
+ const TABLE = 'table';
+
+ /**
+ * Translates Monolog log levels to Wildfire levels.
+ */
+ private $logLevels = array(
+ Logger::DEBUG => 'LOG',
+ Logger::INFO => 'INFO',
+ Logger::NOTICE => 'INFO',
+ Logger::WARNING => 'WARN',
+ Logger::ERROR => 'ERROR',
+ Logger::CRITICAL => 'ERROR',
+ Logger::ALERT => 'ERROR',
+ Logger::EMERGENCY => 'ERROR',
+ );
+
+ /**
+ * {@inheritdoc}
+ */
+ public function format(array $record)
+ {
+ // Retrieve the line and file if set and remove them from the formatted extra
+ $file = $line = '';
+ if (isset($record['extra']['file'])) {
+ $file = $record['extra']['file'];
+ unset($record['extra']['file']);
+ }
+ if (isset($record['extra']['line'])) {
+ $line = $record['extra']['line'];
+ unset($record['extra']['line']);
+ }
+
+ $record = $this->normalize($record);
+ $message = array('message' => $record['message']);
+ $handleError = false;
+ if ($record['context']) {
+ $message['context'] = $record['context'];
+ $handleError = true;
+ }
+ if ($record['extra']) {
+ $message['extra'] = $record['extra'];
+ $handleError = true;
+ }
+ if (count($message) === 1) {
+ $message = reset($message);
+ }
+
+ if (isset($record['context'][self::TABLE])) {
+ $type = 'TABLE';
+ $label = $record['channel'] .': '. $record['message'];
+ $message = $record['context'][self::TABLE];
+ } else {
+ $type = $this->logLevels[$record['level']];
+ $label = $record['channel'];
+ }
+
+ // Create JSON object describing the appearance of the message in the console
+ $json = $this->toJson(array(
+ array(
+ 'Type' => $type,
+ 'File' => $file,
+ 'Line' => $line,
+ 'Label' => $label,
+ ),
+ $message,
+ ), $handleError);
+
+ // The message itself is a serialization of the above JSON object + it's length
+ return sprintf(
+ '%s|%s|',
+ strlen($json),
+ $json
+ );
+ }
+
+ public function formatBatch(array $records)
+ {
+ throw new \BadMethodCallException('Batch formatting does not make sense for the WildfireFormatter');
+ }
+
+ protected function normalize($data, $depth = 0)
+ {
+ if (is_object($data) && !$data instanceof \DateTime) {
+ return $data;
+ }
+
+ return parent::normalize($data, $depth);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/AbstractHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/AbstractHandler.php
new file mode 100644
index 000000000..cdd9f7d40
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/AbstractHandler.php
@@ -0,0 +1,196 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\FormatterInterface;
+use Monolog\Formatter\LineFormatter;
+use Monolog\Logger;
+use Monolog\ResettableInterface;
+
+/**
+ * Base Handler class providing the Handler structure
+ *
+ * @author Jordi Boggiano
+ */
+abstract class AbstractHandler implements HandlerInterface, ResettableInterface
+{
+ protected $level = Logger::DEBUG;
+ protected $bubble = true;
+
+ /**
+ * @var FormatterInterface
+ */
+ protected $formatter;
+ protected $processors = array();
+
+ /**
+ * @param int|string $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct($level = Logger::DEBUG, $bubble = true)
+ {
+ $this->setLevel($level);
+ $this->bubble = $bubble;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function isHandling(array $record)
+ {
+ return $record['level'] >= $this->level;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ foreach ($records as $record) {
+ $this->handle($record);
+ }
+ }
+
+ /**
+ * Closes the handler.
+ *
+ * This will be called automatically when the object is destroyed
+ */
+ public function close()
+ {
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function pushProcessor($callback)
+ {
+ if (!is_callable($callback)) {
+ throw new \InvalidArgumentException('Processors must be valid callables (callback or object with an __invoke method), '.var_export($callback, true).' given');
+ }
+ array_unshift($this->processors, $callback);
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function popProcessor()
+ {
+ if (!$this->processors) {
+ throw new \LogicException('You tried to pop from an empty processor stack.');
+ }
+
+ return array_shift($this->processors);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ $this->formatter = $formatter;
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function getFormatter()
+ {
+ if (!$this->formatter) {
+ $this->formatter = $this->getDefaultFormatter();
+ }
+
+ return $this->formatter;
+ }
+
+ /**
+ * Sets minimum logging level at which this handler will be triggered.
+ *
+ * @param int|string $level Level or level name
+ * @return self
+ */
+ public function setLevel($level)
+ {
+ $this->level = Logger::toMonologLevel($level);
+
+ return $this;
+ }
+
+ /**
+ * Gets minimum logging level at which this handler will be triggered.
+ *
+ * @return int
+ */
+ public function getLevel()
+ {
+ return $this->level;
+ }
+
+ /**
+ * Sets the bubbling behavior.
+ *
+ * @param bool $bubble true means that this handler allows bubbling.
+ * false means that bubbling is not permitted.
+ * @return self
+ */
+ public function setBubble($bubble)
+ {
+ $this->bubble = $bubble;
+
+ return $this;
+ }
+
+ /**
+ * Gets the bubbling behavior.
+ *
+ * @return bool true means that this handler allows bubbling.
+ * false means that bubbling is not permitted.
+ */
+ public function getBubble()
+ {
+ return $this->bubble;
+ }
+
+ public function __destruct()
+ {
+ try {
+ $this->close();
+ } catch (\Exception $e) {
+ // do nothing
+ } catch (\Throwable $e) {
+ // do nothing
+ }
+ }
+
+ public function reset()
+ {
+ foreach ($this->processors as $processor) {
+ if ($processor instanceof ResettableInterface) {
+ $processor->reset();
+ }
+ }
+ }
+
+ /**
+ * Gets the default formatter.
+ *
+ * @return FormatterInterface
+ */
+ protected function getDefaultFormatter()
+ {
+ return new LineFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/AbstractProcessingHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/AbstractProcessingHandler.php
new file mode 100644
index 000000000..e1e89530a
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/AbstractProcessingHandler.php
@@ -0,0 +1,68 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\ResettableInterface;
+
+/**
+ * Base Handler class providing the Handler structure
+ *
+ * Classes extending it should (in most cases) only implement write($record)
+ *
+ * @author Jordi Boggiano
+ * @author Christophe Coevoet
+ */
+abstract class AbstractProcessingHandler extends AbstractHandler
+{
+ /**
+ * {@inheritdoc}
+ */
+ public function handle(array $record)
+ {
+ if (!$this->isHandling($record)) {
+ return false;
+ }
+
+ $record = $this->processRecord($record);
+
+ $record['formatted'] = $this->getFormatter()->format($record);
+
+ $this->write($record);
+
+ return false === $this->bubble;
+ }
+
+ /**
+ * Writes the record down to the log of the implementing handler
+ *
+ * @param array $record
+ * @return void
+ */
+ abstract protected function write(array $record);
+
+ /**
+ * Processes a record.
+ *
+ * @param array $record
+ * @return array
+ */
+ protected function processRecord(array $record)
+ {
+ if ($this->processors) {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+ }
+
+ return $record;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/AbstractSyslogHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/AbstractSyslogHandler.php
new file mode 100644
index 000000000..8c76aca0b
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/AbstractSyslogHandler.php
@@ -0,0 +1,101 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Formatter\LineFormatter;
+
+/**
+ * Common syslog functionality
+ */
+abstract class AbstractSyslogHandler extends AbstractProcessingHandler
+{
+ protected $facility;
+
+ /**
+ * Translates Monolog log levels to syslog log priorities.
+ */
+ protected $logLevels = array(
+ Logger::DEBUG => LOG_DEBUG,
+ Logger::INFO => LOG_INFO,
+ Logger::NOTICE => LOG_NOTICE,
+ Logger::WARNING => LOG_WARNING,
+ Logger::ERROR => LOG_ERR,
+ Logger::CRITICAL => LOG_CRIT,
+ Logger::ALERT => LOG_ALERT,
+ Logger::EMERGENCY => LOG_EMERG,
+ );
+
+ /**
+ * List of valid log facility names.
+ */
+ protected $facilities = array(
+ 'auth' => LOG_AUTH,
+ 'authpriv' => LOG_AUTHPRIV,
+ 'cron' => LOG_CRON,
+ 'daemon' => LOG_DAEMON,
+ 'kern' => LOG_KERN,
+ 'lpr' => LOG_LPR,
+ 'mail' => LOG_MAIL,
+ 'news' => LOG_NEWS,
+ 'syslog' => LOG_SYSLOG,
+ 'user' => LOG_USER,
+ 'uucp' => LOG_UUCP,
+ );
+
+ /**
+ * @param mixed $facility
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct($facility = LOG_USER, $level = Logger::DEBUG, $bubble = true)
+ {
+ parent::__construct($level, $bubble);
+
+ if (!defined('PHP_WINDOWS_VERSION_BUILD')) {
+ $this->facilities['local0'] = LOG_LOCAL0;
+ $this->facilities['local1'] = LOG_LOCAL1;
+ $this->facilities['local2'] = LOG_LOCAL2;
+ $this->facilities['local3'] = LOG_LOCAL3;
+ $this->facilities['local4'] = LOG_LOCAL4;
+ $this->facilities['local5'] = LOG_LOCAL5;
+ $this->facilities['local6'] = LOG_LOCAL6;
+ $this->facilities['local7'] = LOG_LOCAL7;
+ } else {
+ $this->facilities['local0'] = 128; // LOG_LOCAL0
+ $this->facilities['local1'] = 136; // LOG_LOCAL1
+ $this->facilities['local2'] = 144; // LOG_LOCAL2
+ $this->facilities['local3'] = 152; // LOG_LOCAL3
+ $this->facilities['local4'] = 160; // LOG_LOCAL4
+ $this->facilities['local5'] = 168; // LOG_LOCAL5
+ $this->facilities['local6'] = 176; // LOG_LOCAL6
+ $this->facilities['local7'] = 184; // LOG_LOCAL7
+ }
+
+ // convert textual description of facility to syslog constant
+ if (array_key_exists(strtolower($facility), $this->facilities)) {
+ $facility = $this->facilities[strtolower($facility)];
+ } elseif (!in_array($facility, array_values($this->facilities), true)) {
+ throw new \UnexpectedValueException('Unknown facility value "'.$facility.'" given');
+ }
+
+ $this->facility = $facility;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new LineFormatter('%channel%.%level_name%: %message% %context% %extra%');
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/AmqpHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/AmqpHandler.php
new file mode 100644
index 000000000..e5a46bc0d
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/AmqpHandler.php
@@ -0,0 +1,148 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Formatter\JsonFormatter;
+use PhpAmqpLib\Message\AMQPMessage;
+use PhpAmqpLib\Channel\AMQPChannel;
+use AMQPExchange;
+
+class AmqpHandler extends AbstractProcessingHandler
+{
+ /**
+ * @var AMQPExchange|AMQPChannel $exchange
+ */
+ protected $exchange;
+
+ /**
+ * @var string
+ */
+ protected $exchangeName;
+
+ /**
+ * @param AMQPExchange|AMQPChannel $exchange AMQPExchange (php AMQP ext) or PHP AMQP lib channel, ready for use
+ * @param string $exchangeName
+ * @param int $level
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct($exchange, $exchangeName = 'log', $level = Logger::DEBUG, $bubble = true)
+ {
+ if ($exchange instanceof AMQPExchange) {
+ $exchange->setName($exchangeName);
+ } elseif ($exchange instanceof AMQPChannel) {
+ $this->exchangeName = $exchangeName;
+ } else {
+ throw new \InvalidArgumentException('PhpAmqpLib\Channel\AMQPChannel or AMQPExchange instance required');
+ }
+ $this->exchange = $exchange;
+
+ parent::__construct($level, $bubble);
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function write(array $record)
+ {
+ $data = $record["formatted"];
+ $routingKey = $this->getRoutingKey($record);
+
+ if ($this->exchange instanceof AMQPExchange) {
+ $this->exchange->publish(
+ $data,
+ $routingKey,
+ 0,
+ array(
+ 'delivery_mode' => 2,
+ 'content_type' => 'application/json',
+ )
+ );
+ } else {
+ $this->exchange->basic_publish(
+ $this->createAmqpMessage($data),
+ $this->exchangeName,
+ $routingKey
+ );
+ }
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public function handleBatch(array $records)
+ {
+ if ($this->exchange instanceof AMQPExchange) {
+ parent::handleBatch($records);
+
+ return;
+ }
+
+ foreach ($records as $record) {
+ if (!$this->isHandling($record)) {
+ continue;
+ }
+
+ $record = $this->processRecord($record);
+ $data = $this->getFormatter()->format($record);
+
+ $this->exchange->batch_basic_publish(
+ $this->createAmqpMessage($data),
+ $this->exchangeName,
+ $this->getRoutingKey($record)
+ );
+ }
+
+ $this->exchange->publish_batch();
+ }
+
+ /**
+ * Gets the routing key for the AMQP exchange
+ *
+ * @param array $record
+ * @return string
+ */
+ protected function getRoutingKey(array $record)
+ {
+ $routingKey = sprintf(
+ '%s.%s',
+ // TODO 2.0 remove substr call
+ substr($record['level_name'], 0, 4),
+ $record['channel']
+ );
+
+ return strtolower($routingKey);
+ }
+
+ /**
+ * @param string $data
+ * @return AMQPMessage
+ */
+ private function createAmqpMessage($data)
+ {
+ return new AMQPMessage(
+ (string) $data,
+ array(
+ 'delivery_mode' => 2,
+ 'content_type' => 'application/json',
+ )
+ );
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new JsonFormatter(JsonFormatter::BATCH_MODE_JSON, false);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/BrowserConsoleHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/BrowserConsoleHandler.php
new file mode 100644
index 000000000..68feb4808
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/BrowserConsoleHandler.php
@@ -0,0 +1,241 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\LineFormatter;
+
+/**
+ * Handler sending logs to browser's javascript console with no browser extension required
+ *
+ * @author Olivier Poitrey
+ */
+class BrowserConsoleHandler extends AbstractProcessingHandler
+{
+ protected static $initialized = false;
+ protected static $records = array();
+
+ /**
+ * {@inheritDoc}
+ *
+ * Formatted output may contain some formatting markers to be transferred to `console.log` using the %c format.
+ *
+ * Example of formatted string:
+ *
+ * You can do [[blue text]]{color: blue} or [[green background]]{background-color: green; color: white}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new LineFormatter('[[%channel%]]{macro: autolabel} [[%level_name%]]{font-weight: bold} %message%');
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function write(array $record)
+ {
+ // Accumulate records
+ static::$records[] = $record;
+
+ // Register shutdown handler if not already done
+ if (!static::$initialized) {
+ static::$initialized = true;
+ $this->registerShutdownFunction();
+ }
+ }
+
+ /**
+ * Convert records to javascript console commands and send it to the browser.
+ * This method is automatically called on PHP shutdown if output is HTML or Javascript.
+ */
+ public static function send()
+ {
+ $format = static::getResponseFormat();
+ if ($format === 'unknown') {
+ return;
+ }
+
+ if (count(static::$records)) {
+ if ($format === 'html') {
+ static::writeOutput('');
+ } elseif ($format === 'js') {
+ static::writeOutput(static::generateScript());
+ }
+ static::resetStatic();
+ }
+ }
+
+ public function close()
+ {
+ self::resetStatic();
+ }
+
+ public function reset()
+ {
+ self::resetStatic();
+ }
+
+ /**
+ * Forget all logged records
+ */
+ public static function resetStatic()
+ {
+ static::$records = array();
+ }
+
+ /**
+ * Wrapper for register_shutdown_function to allow overriding
+ */
+ protected function registerShutdownFunction()
+ {
+ if (PHP_SAPI !== 'cli') {
+ register_shutdown_function(array('Monolog\Handler\BrowserConsoleHandler', 'send'));
+ }
+ }
+
+ /**
+ * Wrapper for echo to allow overriding
+ *
+ * @param string $str
+ */
+ protected static function writeOutput($str)
+ {
+ echo $str;
+ }
+
+ /**
+ * Checks the format of the response
+ *
+ * If Content-Type is set to application/javascript or text/javascript -> js
+ * If Content-Type is set to text/html, or is unset -> html
+ * If Content-Type is anything else -> unknown
+ *
+ * @return string One of 'js', 'html' or 'unknown'
+ */
+ protected static function getResponseFormat()
+ {
+ // Check content type
+ foreach (headers_list() as $header) {
+ if (stripos($header, 'content-type:') === 0) {
+ // This handler only works with HTML and javascript outputs
+ // text/javascript is obsolete in favour of application/javascript, but still used
+ if (stripos($header, 'application/javascript') !== false || stripos($header, 'text/javascript') !== false) {
+ return 'js';
+ }
+ if (stripos($header, 'text/html') === false) {
+ return 'unknown';
+ }
+ break;
+ }
+ }
+
+ return 'html';
+ }
+
+ private static function generateScript()
+ {
+ $script = array();
+ foreach (static::$records as $record) {
+ $context = static::dump('Context', $record['context']);
+ $extra = static::dump('Extra', $record['extra']);
+
+ if (empty($context) && empty($extra)) {
+ $script[] = static::call_array('log', static::handleStyles($record['formatted']));
+ } else {
+ $script = array_merge($script,
+ array(static::call_array('groupCollapsed', static::handleStyles($record['formatted']))),
+ $context,
+ $extra,
+ array(static::call('groupEnd'))
+ );
+ }
+ }
+
+ return "(function (c) {if (c && c.groupCollapsed) {\n" . implode("\n", $script) . "\n}})(console);";
+ }
+
+ private static function handleStyles($formatted)
+ {
+ $args = array();
+ $format = '%c' . $formatted;
+ preg_match_all('/\[\[(.*?)\]\]\{([^}]*)\}/s', $format, $matches, PREG_OFFSET_CAPTURE | PREG_SET_ORDER);
+
+ foreach (array_reverse($matches) as $match) {
+ $args[] = '"font-weight: normal"';
+ $args[] = static::quote(static::handleCustomStyles($match[2][0], $match[1][0]));
+
+ $pos = $match[0][1];
+ $format = substr($format, 0, $pos) . '%c' . $match[1][0] . '%c' . substr($format, $pos + strlen($match[0][0]));
+ }
+
+ $args[] = static::quote('font-weight: normal');
+ $args[] = static::quote($format);
+
+ return array_reverse($args);
+ }
+
+ private static function handleCustomStyles($style, $string)
+ {
+ static $colors = array('blue', 'green', 'red', 'magenta', 'orange', 'black', 'grey');
+ static $labels = array();
+
+ return preg_replace_callback('/macro\s*:(.*?)(?:;|$)/', function ($m) use ($string, &$colors, &$labels) {
+ if (trim($m[1]) === 'autolabel') {
+ // Format the string as a label with consistent auto assigned background color
+ if (!isset($labels[$string])) {
+ $labels[$string] = $colors[count($labels) % count($colors)];
+ }
+ $color = $labels[$string];
+
+ return "background-color: $color; color: white; border-radius: 3px; padding: 0 2px 0 2px";
+ }
+
+ return $m[1];
+ }, $style);
+ }
+
+ private static function dump($title, array $dict)
+ {
+ $script = array();
+ $dict = array_filter($dict);
+ if (empty($dict)) {
+ return $script;
+ }
+ $script[] = static::call('log', static::quote('%c%s'), static::quote('font-weight: bold'), static::quote($title));
+ foreach ($dict as $key => $value) {
+ $value = json_encode($value);
+ if (empty($value)) {
+ $value = static::quote('');
+ }
+ $script[] = static::call('log', static::quote('%s: %o'), static::quote($key), $value);
+ }
+
+ return $script;
+ }
+
+ private static function quote($arg)
+ {
+ return '"' . addcslashes($arg, "\"\n\\") . '"';
+ }
+
+ private static function call()
+ {
+ $args = func_get_args();
+ $method = array_shift($args);
+
+ return static::call_array($method, $args);
+ }
+
+ private static function call_array($method, array $args)
+ {
+ return 'c.' . $method . '(' . implode(', ', $args) . ');';
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/BufferHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/BufferHandler.php
new file mode 100644
index 000000000..0957e5580
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/BufferHandler.php
@@ -0,0 +1,148 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\ResettableInterface;
+use Monolog\Formatter\FormatterInterface;
+
+/**
+ * Buffers all records until closing the handler and then pass them as batch.
+ *
+ * This is useful for a MailHandler to send only one mail per request instead of
+ * sending one per log message.
+ *
+ * @author Christophe Coevoet
+ */
+class BufferHandler extends AbstractHandler
+{
+ protected $handler;
+ protected $bufferSize = 0;
+ protected $bufferLimit;
+ protected $flushOnOverflow;
+ protected $buffer = array();
+ protected $initialized = false;
+
+ /**
+ * @param HandlerInterface $handler Handler.
+ * @param int $bufferLimit How many entries should be buffered at most, beyond that the oldest items are removed from the buffer.
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param bool $flushOnOverflow If true, the buffer is flushed when the max size has been reached, by default oldest entries are discarded
+ */
+ public function __construct(HandlerInterface $handler, $bufferLimit = 0, $level = Logger::DEBUG, $bubble = true, $flushOnOverflow = false)
+ {
+ parent::__construct($level, $bubble);
+ $this->handler = $handler;
+ $this->bufferLimit = (int) $bufferLimit;
+ $this->flushOnOverflow = $flushOnOverflow;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handle(array $record)
+ {
+ if ($record['level'] < $this->level) {
+ return false;
+ }
+
+ if (!$this->initialized) {
+ // __destructor() doesn't get called on Fatal errors
+ register_shutdown_function(array($this, 'close'));
+ $this->initialized = true;
+ }
+
+ if ($this->bufferLimit > 0 && $this->bufferSize === $this->bufferLimit) {
+ if ($this->flushOnOverflow) {
+ $this->flush();
+ } else {
+ array_shift($this->buffer);
+ $this->bufferSize--;
+ }
+ }
+
+ if ($this->processors) {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+ }
+
+ $this->buffer[] = $record;
+ $this->bufferSize++;
+
+ return false === $this->bubble;
+ }
+
+ public function flush()
+ {
+ if ($this->bufferSize === 0) {
+ return;
+ }
+
+ $this->handler->handleBatch($this->buffer);
+ $this->clear();
+ }
+
+ public function __destruct()
+ {
+ // suppress the parent behavior since we already have register_shutdown_function()
+ // to call close(), and the reference contained there will prevent this from being
+ // GC'd until the end of the request
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function close()
+ {
+ $this->flush();
+ }
+
+ /**
+ * Clears the buffer without flushing any messages down to the wrapped handler.
+ */
+ public function clear()
+ {
+ $this->bufferSize = 0;
+ $this->buffer = array();
+ }
+
+ public function reset()
+ {
+ $this->flush();
+
+ parent::reset();
+
+ if ($this->handler instanceof ResettableInterface) {
+ $this->handler->reset();
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ $this->handler->setFormatter($formatter);
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function getFormatter()
+ {
+ return $this->handler->getFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/ChromePHPHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/ChromePHPHandler.php
new file mode 100644
index 000000000..47120e545
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/ChromePHPHandler.php
@@ -0,0 +1,212 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\ChromePHPFormatter;
+use Monolog\Logger;
+use Monolog\Utils;
+
+/**
+ * Handler sending logs to the ChromePHP extension (http://www.chromephp.com/)
+ *
+ * This also works out of the box with Firefox 43+
+ *
+ * @author Christophe Coevoet
+ */
+class ChromePHPHandler extends AbstractProcessingHandler
+{
+ /**
+ * Version of the extension
+ */
+ const VERSION = '4.0';
+
+ /**
+ * Header name
+ */
+ const HEADER_NAME = 'X-ChromeLogger-Data';
+
+ /**
+ * Regular expression to detect supported browsers (matches any Chrome, or Firefox 43+)
+ */
+ const USER_AGENT_REGEX = '{\b(?:Chrome/\d+(?:\.\d+)*|HeadlessChrome|Firefox/(?:4[3-9]|[5-9]\d|\d{3,})(?:\.\d)*)\b}';
+
+ protected static $initialized = false;
+
+ /**
+ * Tracks whether we sent too much data
+ *
+ * Chrome limits the headers to 4KB, so when we sent 3KB we stop sending
+ *
+ * @var bool
+ */
+ protected static $overflowed = false;
+
+ protected static $json = array(
+ 'version' => self::VERSION,
+ 'columns' => array('label', 'log', 'backtrace', 'type'),
+ 'rows' => array(),
+ );
+
+ protected static $sendHeaders = true;
+
+ /**
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct($level = Logger::DEBUG, $bubble = true)
+ {
+ parent::__construct($level, $bubble);
+ if (!function_exists('json_encode')) {
+ throw new \RuntimeException('PHP\'s json extension is required to use Monolog\'s ChromePHPHandler');
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ $messages = array();
+
+ foreach ($records as $record) {
+ if ($record['level'] < $this->level) {
+ continue;
+ }
+ $messages[] = $this->processRecord($record);
+ }
+
+ if (!empty($messages)) {
+ $messages = $this->getFormatter()->formatBatch($messages);
+ self::$json['rows'] = array_merge(self::$json['rows'], $messages);
+ $this->send();
+ }
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new ChromePHPFormatter();
+ }
+
+ /**
+ * Creates & sends header for a record
+ *
+ * @see sendHeader()
+ * @see send()
+ * @param array $record
+ */
+ protected function write(array $record)
+ {
+ self::$json['rows'][] = $record['formatted'];
+
+ $this->send();
+ }
+
+ /**
+ * Sends the log header
+ *
+ * @see sendHeader()
+ */
+ protected function send()
+ {
+ if (self::$overflowed || !self::$sendHeaders) {
+ return;
+ }
+
+ if (!self::$initialized) {
+ self::$initialized = true;
+
+ self::$sendHeaders = $this->headersAccepted();
+ if (!self::$sendHeaders) {
+ return;
+ }
+
+ self::$json['request_uri'] = isset($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : '';
+ }
+
+ $json = Utils::jsonEncode(self::$json, null, true);
+ $data = base64_encode(utf8_encode($json));
+ if (strlen($data) > 3 * 1024) {
+ self::$overflowed = true;
+
+ $record = array(
+ 'message' => 'Incomplete logs, chrome header size limit reached',
+ 'context' => array(),
+ 'level' => Logger::WARNING,
+ 'level_name' => Logger::getLevelName(Logger::WARNING),
+ 'channel' => 'monolog',
+ 'datetime' => new \DateTime(),
+ 'extra' => array(),
+ );
+ self::$json['rows'][count(self::$json['rows']) - 1] = $this->getFormatter()->format($record);
+ $json = Utils::jsonEncode(self::$json, null, true);
+ $data = base64_encode(utf8_encode($json));
+ }
+
+ if (trim($data) !== '') {
+ $this->sendHeader(self::HEADER_NAME, $data);
+ }
+ }
+
+ /**
+ * Send header string to the client
+ *
+ * @param string $header
+ * @param string $content
+ */
+ protected function sendHeader($header, $content)
+ {
+ if (!headers_sent() && self::$sendHeaders) {
+ header(sprintf('%s: %s', $header, $content));
+ }
+ }
+
+ /**
+ * Verifies if the headers are accepted by the current user agent
+ *
+ * @return bool
+ */
+ protected function headersAccepted()
+ {
+ if (empty($_SERVER['HTTP_USER_AGENT'])) {
+ return false;
+ }
+
+ return preg_match(self::USER_AGENT_REGEX, $_SERVER['HTTP_USER_AGENT']);
+ }
+
+ /**
+ * BC getter for the sendHeaders property that has been made static
+ */
+ public function __get($property)
+ {
+ if ('sendHeaders' !== $property) {
+ throw new \InvalidArgumentException('Undefined property '.$property);
+ }
+
+ return static::$sendHeaders;
+ }
+
+ /**
+ * BC setter for the sendHeaders property that has been made static
+ */
+ public function __set($property, $value)
+ {
+ if ('sendHeaders' !== $property) {
+ throw new \InvalidArgumentException('Undefined property '.$property);
+ }
+
+ static::$sendHeaders = $value;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/CouchDBHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/CouchDBHandler.php
new file mode 100644
index 000000000..cc9869719
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/CouchDBHandler.php
@@ -0,0 +1,72 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\JsonFormatter;
+use Monolog\Logger;
+
+/**
+ * CouchDB handler
+ *
+ * @author Markus Bachmann
+ */
+class CouchDBHandler extends AbstractProcessingHandler
+{
+ private $options;
+
+ public function __construct(array $options = array(), $level = Logger::DEBUG, $bubble = true)
+ {
+ $this->options = array_merge(array(
+ 'host' => 'localhost',
+ 'port' => 5984,
+ 'dbname' => 'logger',
+ 'username' => null,
+ 'password' => null,
+ ), $options);
+
+ parent::__construct($level, $bubble);
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function write(array $record)
+ {
+ $basicAuth = null;
+ if ($this->options['username']) {
+ $basicAuth = sprintf('%s:%s@', $this->options['username'], $this->options['password']);
+ }
+
+ $url = 'http://'.$basicAuth.$this->options['host'].':'.$this->options['port'].'/'.$this->options['dbname'];
+ $context = stream_context_create(array(
+ 'http' => array(
+ 'method' => 'POST',
+ 'content' => $record['formatted'],
+ 'ignore_errors' => true,
+ 'max_redirects' => 0,
+ 'header' => 'Content-type: application/json',
+ ),
+ ));
+
+ if (false === @file_get_contents($url, null, $context)) {
+ throw new \RuntimeException(sprintf('Could not connect to %s', $url));
+ }
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new JsonFormatter(JsonFormatter::BATCH_MODE_JSON, false);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/CubeHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/CubeHandler.php
new file mode 100644
index 000000000..44928efb2
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/CubeHandler.php
@@ -0,0 +1,152 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Utils;
+
+/**
+ * Logs to Cube.
+ *
+ * @link http://square.github.com/cube/
+ * @author Wan Chen
+ */
+class CubeHandler extends AbstractProcessingHandler
+{
+ private $udpConnection;
+ private $httpConnection;
+ private $scheme;
+ private $host;
+ private $port;
+ private $acceptedSchemes = array('http', 'udp');
+
+ /**
+ * Create a Cube handler
+ *
+ * @throws \UnexpectedValueException when given url is not a valid url.
+ * A valid url must consist of three parts : protocol://host:port
+ * Only valid protocols used by Cube are http and udp
+ */
+ public function __construct($url, $level = Logger::DEBUG, $bubble = true)
+ {
+ $urlInfo = parse_url($url);
+
+ if (!isset($urlInfo['scheme'], $urlInfo['host'], $urlInfo['port'])) {
+ throw new \UnexpectedValueException('URL "'.$url.'" is not valid');
+ }
+
+ if (!in_array($urlInfo['scheme'], $this->acceptedSchemes)) {
+ throw new \UnexpectedValueException(
+ 'Invalid protocol (' . $urlInfo['scheme'] . ').'
+ . ' Valid options are ' . implode(', ', $this->acceptedSchemes));
+ }
+
+ $this->scheme = $urlInfo['scheme'];
+ $this->host = $urlInfo['host'];
+ $this->port = $urlInfo['port'];
+
+ parent::__construct($level, $bubble);
+ }
+
+ /**
+ * Establish a connection to an UDP socket
+ *
+ * @throws \LogicException when unable to connect to the socket
+ * @throws MissingExtensionException when there is no socket extension
+ */
+ protected function connectUdp()
+ {
+ if (!extension_loaded('sockets')) {
+ throw new MissingExtensionException('The sockets extension is required to use udp URLs with the CubeHandler');
+ }
+
+ $this->udpConnection = socket_create(AF_INET, SOCK_DGRAM, 0);
+ if (!$this->udpConnection) {
+ throw new \LogicException('Unable to create a socket');
+ }
+
+ if (!socket_connect($this->udpConnection, $this->host, $this->port)) {
+ throw new \LogicException('Unable to connect to the socket at ' . $this->host . ':' . $this->port);
+ }
+ }
+
+ /**
+ * Establish a connection to a http server
+ * @throws \LogicException when no curl extension
+ */
+ protected function connectHttp()
+ {
+ if (!extension_loaded('curl')) {
+ throw new \LogicException('The curl extension is needed to use http URLs with the CubeHandler');
+ }
+
+ $this->httpConnection = curl_init('http://'.$this->host.':'.$this->port.'/1.0/event/put');
+
+ if (!$this->httpConnection) {
+ throw new \LogicException('Unable to connect to ' . $this->host . ':' . $this->port);
+ }
+
+ curl_setopt($this->httpConnection, CURLOPT_CUSTOMREQUEST, "POST");
+ curl_setopt($this->httpConnection, CURLOPT_RETURNTRANSFER, true);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ $date = $record['datetime'];
+
+ $data = array('time' => $date->format('Y-m-d\TH:i:s.uO'));
+ unset($record['datetime']);
+
+ if (isset($record['context']['type'])) {
+ $data['type'] = $record['context']['type'];
+ unset($record['context']['type']);
+ } else {
+ $data['type'] = $record['channel'];
+ }
+
+ $data['data'] = $record['context'];
+ $data['data']['level'] = $record['level'];
+
+ if ($this->scheme === 'http') {
+ $this->writeHttp(Utils::jsonEncode($data));
+ } else {
+ $this->writeUdp(Utils::jsonEncode($data));
+ }
+ }
+
+ private function writeUdp($data)
+ {
+ if (!$this->udpConnection) {
+ $this->connectUdp();
+ }
+
+ socket_send($this->udpConnection, $data, strlen($data), 0);
+ }
+
+ private function writeHttp($data)
+ {
+ if (!$this->httpConnection) {
+ $this->connectHttp();
+ }
+
+ curl_setopt($this->httpConnection, CURLOPT_POSTFIELDS, '['.$data.']');
+ curl_setopt($this->httpConnection, CURLOPT_HTTPHEADER, array(
+ 'Content-Type: application/json',
+ 'Content-Length: ' . strlen('['.$data.']'),
+ ));
+
+ Curl\Util::execute($this->httpConnection, 5, false);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/Curl/Util.php b/vendor/monolog/monolog/src/Monolog/Handler/Curl/Util.php
new file mode 100644
index 000000000..48d30b358
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/Curl/Util.php
@@ -0,0 +1,57 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler\Curl;
+
+class Util
+{
+ private static $retriableErrorCodes = array(
+ CURLE_COULDNT_RESOLVE_HOST,
+ CURLE_COULDNT_CONNECT,
+ CURLE_HTTP_NOT_FOUND,
+ CURLE_READ_ERROR,
+ CURLE_OPERATION_TIMEOUTED,
+ CURLE_HTTP_POST_ERROR,
+ CURLE_SSL_CONNECT_ERROR,
+ );
+
+ /**
+ * Executes a CURL request with optional retries and exception on failure
+ *
+ * @param resource $ch curl handler
+ * @throws \RuntimeException
+ */
+ public static function execute($ch, $retries = 5, $closeAfterDone = true)
+ {
+ while ($retries--) {
+ if (curl_exec($ch) === false) {
+ $curlErrno = curl_errno($ch);
+
+ if (false === in_array($curlErrno, self::$retriableErrorCodes, true) || !$retries) {
+ $curlError = curl_error($ch);
+
+ if ($closeAfterDone) {
+ curl_close($ch);
+ }
+
+ throw new \RuntimeException(sprintf('Curl error (code %s): %s', $curlErrno, $curlError));
+ }
+
+ continue;
+ }
+
+ if ($closeAfterDone) {
+ curl_close($ch);
+ }
+ break;
+ }
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/DeduplicationHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/DeduplicationHandler.php
new file mode 100644
index 000000000..35b55cb4f
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/DeduplicationHandler.php
@@ -0,0 +1,169 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+
+/**
+ * Simple handler wrapper that deduplicates log records across multiple requests
+ *
+ * It also includes the BufferHandler functionality and will buffer
+ * all messages until the end of the request or flush() is called.
+ *
+ * This works by storing all log records' messages above $deduplicationLevel
+ * to the file specified by $deduplicationStore. When further logs come in at the end of the
+ * request (or when flush() is called), all those above $deduplicationLevel are checked
+ * against the existing stored logs. If they match and the timestamps in the stored log is
+ * not older than $time seconds, the new log record is discarded. If no log record is new, the
+ * whole data set is discarded.
+ *
+ * This is mainly useful in combination with Mail handlers or things like Slack or HipChat handlers
+ * that send messages to people, to avoid spamming with the same message over and over in case of
+ * a major component failure like a database server being down which makes all requests fail in the
+ * same way.
+ *
+ * @author Jordi Boggiano
+ */
+class DeduplicationHandler extends BufferHandler
+{
+ /**
+ * @var string
+ */
+ protected $deduplicationStore;
+
+ /**
+ * @var int
+ */
+ protected $deduplicationLevel;
+
+ /**
+ * @var int
+ */
+ protected $time;
+
+ /**
+ * @var bool
+ */
+ private $gc = false;
+
+ /**
+ * @param HandlerInterface $handler Handler.
+ * @param string $deduplicationStore The file/path where the deduplication log should be kept
+ * @param int $deduplicationLevel The minimum logging level for log records to be looked at for deduplication purposes
+ * @param int $time The period (in seconds) during which duplicate entries should be suppressed after a given log is sent through
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct(HandlerInterface $handler, $deduplicationStore = null, $deduplicationLevel = Logger::ERROR, $time = 60, $bubble = true)
+ {
+ parent::__construct($handler, 0, Logger::DEBUG, $bubble, false);
+
+ $this->deduplicationStore = $deduplicationStore === null ? sys_get_temp_dir() . '/monolog-dedup-' . substr(md5(__FILE__), 0, 20) .'.log' : $deduplicationStore;
+ $this->deduplicationLevel = Logger::toMonologLevel($deduplicationLevel);
+ $this->time = $time;
+ }
+
+ public function flush()
+ {
+ if ($this->bufferSize === 0) {
+ return;
+ }
+
+ $passthru = null;
+
+ foreach ($this->buffer as $record) {
+ if ($record['level'] >= $this->deduplicationLevel) {
+
+ $passthru = $passthru || !$this->isDuplicate($record);
+ if ($passthru) {
+ $this->appendRecord($record);
+ }
+ }
+ }
+
+ // default of null is valid as well as if no record matches duplicationLevel we just pass through
+ if ($passthru === true || $passthru === null) {
+ $this->handler->handleBatch($this->buffer);
+ }
+
+ $this->clear();
+
+ if ($this->gc) {
+ $this->collectLogs();
+ }
+ }
+
+ private function isDuplicate(array $record)
+ {
+ if (!file_exists($this->deduplicationStore)) {
+ return false;
+ }
+
+ $store = file($this->deduplicationStore, FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
+ if (!is_array($store)) {
+ return false;
+ }
+
+ $yesterday = time() - 86400;
+ $timestampValidity = $record['datetime']->getTimestamp() - $this->time;
+ $expectedMessage = preg_replace('{[\r\n].*}', '', $record['message']);
+
+ for ($i = count($store) - 1; $i >= 0; $i--) {
+ list($timestamp, $level, $message) = explode(':', $store[$i], 3);
+
+ if ($level === $record['level_name'] && $message === $expectedMessage && $timestamp > $timestampValidity) {
+ return true;
+ }
+
+ if ($timestamp < $yesterday) {
+ $this->gc = true;
+ }
+ }
+
+ return false;
+ }
+
+ private function collectLogs()
+ {
+ if (!file_exists($this->deduplicationStore)) {
+ return false;
+ }
+
+ $handle = fopen($this->deduplicationStore, 'rw+');
+ flock($handle, LOCK_EX);
+ $validLogs = array();
+
+ $timestampValidity = time() - $this->time;
+
+ while (!feof($handle)) {
+ $log = fgets($handle);
+ if (substr($log, 0, 10) >= $timestampValidity) {
+ $validLogs[] = $log;
+ }
+ }
+
+ ftruncate($handle, 0);
+ rewind($handle);
+ foreach ($validLogs as $log) {
+ fwrite($handle, $log);
+ }
+
+ flock($handle, LOCK_UN);
+ fclose($handle);
+
+ $this->gc = false;
+ }
+
+ private function appendRecord(array $record)
+ {
+ file_put_contents($this->deduplicationStore, $record['datetime']->getTimestamp() . ':' . $record['level_name'] . ':' . preg_replace('{[\r\n].*}', '', $record['message']) . "\n", FILE_APPEND);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/DoctrineCouchDBHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/DoctrineCouchDBHandler.php
new file mode 100644
index 000000000..b91ffec90
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/DoctrineCouchDBHandler.php
@@ -0,0 +1,45 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Formatter\NormalizerFormatter;
+use Doctrine\CouchDB\CouchDBClient;
+
+/**
+ * CouchDB handler for Doctrine CouchDB ODM
+ *
+ * @author Markus Bachmann
+ */
+class DoctrineCouchDBHandler extends AbstractProcessingHandler
+{
+ private $client;
+
+ public function __construct(CouchDBClient $client, $level = Logger::DEBUG, $bubble = true)
+ {
+ $this->client = $client;
+ parent::__construct($level, $bubble);
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function write(array $record)
+ {
+ $this->client->postDocument($record['formatted']);
+ }
+
+ protected function getDefaultFormatter()
+ {
+ return new NormalizerFormatter;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/DynamoDbHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/DynamoDbHandler.php
new file mode 100644
index 000000000..8846e0a08
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/DynamoDbHandler.php
@@ -0,0 +1,108 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Aws\Sdk;
+use Aws\DynamoDb\DynamoDbClient;
+use Aws\DynamoDb\Marshaler;
+use Monolog\Formatter\ScalarFormatter;
+use Monolog\Logger;
+
+/**
+ * Amazon DynamoDB handler (http://aws.amazon.com/dynamodb/)
+ *
+ * @link https://github.com/aws/aws-sdk-php/
+ * @author Andrew Lawson
+ */
+class DynamoDbHandler extends AbstractProcessingHandler
+{
+ const DATE_FORMAT = 'Y-m-d\TH:i:s.uO';
+
+ /**
+ * @var DynamoDbClient
+ */
+ protected $client;
+
+ /**
+ * @var string
+ */
+ protected $table;
+
+ /**
+ * @var int
+ */
+ protected $version;
+
+ /**
+ * @var Marshaler
+ */
+ protected $marshaler;
+
+ /**
+ * @param DynamoDbClient $client
+ * @param string $table
+ * @param int $level
+ * @param bool $bubble
+ */
+ public function __construct(DynamoDbClient $client, $table, $level = Logger::DEBUG, $bubble = true)
+ {
+ if (defined('Aws\Sdk::VERSION') && version_compare(Sdk::VERSION, '3.0', '>=')) {
+ $this->version = 3;
+ $this->marshaler = new Marshaler;
+ } else {
+ $this->version = 2;
+ }
+
+ $this->client = $client;
+ $this->table = $table;
+
+ parent::__construct($level, $bubble);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ $filtered = $this->filterEmptyFields($record['formatted']);
+ if ($this->version === 3) {
+ $formatted = $this->marshaler->marshalItem($filtered);
+ } else {
+ /** @phpstan-ignore-next-line */
+ $formatted = $this->client->formatAttributes($filtered);
+ }
+
+ $this->client->putItem(array(
+ 'TableName' => $this->table,
+ 'Item' => $formatted,
+ ));
+ }
+
+ /**
+ * @param array $record
+ * @return array
+ */
+ protected function filterEmptyFields(array $record)
+ {
+ return array_filter($record, function ($value) {
+ return !empty($value) || false === $value || 0 === $value;
+ });
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new ScalarFormatter(self::DATE_FORMAT);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/ElasticSearchHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/ElasticSearchHandler.php
new file mode 100644
index 000000000..bb0f83ebc
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/ElasticSearchHandler.php
@@ -0,0 +1,128 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\FormatterInterface;
+use Monolog\Formatter\ElasticaFormatter;
+use Monolog\Logger;
+use Elastica\Client;
+use Elastica\Exception\ExceptionInterface;
+
+/**
+ * Elastic Search handler
+ *
+ * Usage example:
+ *
+ * $client = new \Elastica\Client();
+ * $options = array(
+ * 'index' => 'elastic_index_name',
+ * 'type' => 'elastic_doc_type',
+ * );
+ * $handler = new ElasticSearchHandler($client, $options);
+ * $log = new Logger('application');
+ * $log->pushHandler($handler);
+ *
+ * @author Jelle Vink
+ */
+class ElasticSearchHandler extends AbstractProcessingHandler
+{
+ /**
+ * @var Client
+ */
+ protected $client;
+
+ /**
+ * @var array Handler config options
+ */
+ protected $options = array();
+
+ /**
+ * @param Client $client Elastica Client object
+ * @param array $options Handler configuration
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct(Client $client, array $options = array(), $level = Logger::DEBUG, $bubble = true)
+ {
+ parent::__construct($level, $bubble);
+ $this->client = $client;
+ $this->options = array_merge(
+ array(
+ 'index' => 'monolog', // Elastic index name
+ 'type' => 'record', // Elastic document type
+ 'ignore_error' => false, // Suppress Elastica exceptions
+ ),
+ $options
+ );
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function write(array $record)
+ {
+ $this->bulkSend(array($record['formatted']));
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ if ($formatter instanceof ElasticaFormatter) {
+ return parent::setFormatter($formatter);
+ }
+ throw new \InvalidArgumentException('ElasticSearchHandler is only compatible with ElasticaFormatter');
+ }
+
+ /**
+ * Getter options
+ * @return array
+ */
+ public function getOptions()
+ {
+ return $this->options;
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new ElasticaFormatter($this->options['index'], $this->options['type']);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ $documents = $this->getFormatter()->formatBatch($records);
+ $this->bulkSend($documents);
+ }
+
+ /**
+ * Use Elasticsearch bulk API to send list of documents
+ * @param array $documents
+ * @throws \RuntimeException
+ */
+ protected function bulkSend(array $documents)
+ {
+ try {
+ $this->client->addDocuments($documents);
+ } catch (ExceptionInterface $e) {
+ if (!$this->options['ignore_error']) {
+ throw new \RuntimeException("Error sending messages to Elasticsearch", 0, $e);
+ }
+ }
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/ErrorLogHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/ErrorLogHandler.php
new file mode 100644
index 000000000..b2986b0fe
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/ErrorLogHandler.php
@@ -0,0 +1,82 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\LineFormatter;
+use Monolog\Logger;
+
+/**
+ * Stores to PHP error_log() handler.
+ *
+ * @author Elan Ruusamäe
+ */
+class ErrorLogHandler extends AbstractProcessingHandler
+{
+ const OPERATING_SYSTEM = 0;
+ const SAPI = 4;
+
+ protected $messageType;
+ protected $expandNewlines;
+
+ /**
+ * @param int $messageType Says where the error should go.
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param bool $expandNewlines If set to true, newlines in the message will be expanded to be take multiple log entries
+ */
+ public function __construct($messageType = self::OPERATING_SYSTEM, $level = Logger::DEBUG, $bubble = true, $expandNewlines = false)
+ {
+ parent::__construct($level, $bubble);
+
+ if (false === in_array($messageType, self::getAvailableTypes())) {
+ $message = sprintf('The given message type "%s" is not supported', print_r($messageType, true));
+ throw new \InvalidArgumentException($message);
+ }
+
+ $this->messageType = $messageType;
+ $this->expandNewlines = $expandNewlines;
+ }
+
+ /**
+ * @return array With all available types
+ */
+ public static function getAvailableTypes()
+ {
+ return array(
+ self::OPERATING_SYSTEM,
+ self::SAPI,
+ );
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new LineFormatter('[%datetime%] %channel%.%level_name%: %message% %context% %extra%');
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ if ($this->expandNewlines) {
+ $lines = preg_split('{[\r\n]+}', (string) $record['formatted']);
+ foreach ($lines as $line) {
+ error_log($line, $this->messageType);
+ }
+ } else {
+ error_log((string) $record['formatted'], $this->messageType);
+ }
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/FilterHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/FilterHandler.php
new file mode 100644
index 000000000..949f22718
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/FilterHandler.php
@@ -0,0 +1,172 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Formatter\FormatterInterface;
+
+/**
+ * Simple handler wrapper that filters records based on a list of levels
+ *
+ * It can be configured with an exact list of levels to allow, or a min/max level.
+ *
+ * @author Hennadiy Verkh
+ * @author Jordi Boggiano
+ */
+class FilterHandler extends AbstractHandler
+{
+ /**
+ * Handler or factory callable($record, $this)
+ *
+ * @var callable|\Monolog\Handler\HandlerInterface
+ */
+ protected $handler;
+
+ /**
+ * Minimum level for logs that are passed to handler
+ *
+ * @var int[]
+ */
+ protected $acceptedLevels;
+
+ /**
+ * Whether the messages that are handled can bubble up the stack or not
+ *
+ * @var bool
+ */
+ protected $bubble;
+
+ /**
+ * @param callable|HandlerInterface $handler Handler or factory callable($record|null, $filterHandler).
+ * @param int|array $minLevelOrList A list of levels to accept or a minimum level if maxLevel is provided
+ * @param int $maxLevel Maximum level to accept, only used if $minLevelOrList is not an array
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct($handler, $minLevelOrList = Logger::DEBUG, $maxLevel = Logger::EMERGENCY, $bubble = true)
+ {
+ $this->handler = $handler;
+ $this->bubble = $bubble;
+ $this->setAcceptedLevels($minLevelOrList, $maxLevel);
+
+ if (!$this->handler instanceof HandlerInterface && !is_callable($this->handler)) {
+ throw new \RuntimeException("The given handler (".json_encode($this->handler).") is not a callable nor a Monolog\Handler\HandlerInterface object");
+ }
+ }
+
+ /**
+ * @return array
+ */
+ public function getAcceptedLevels()
+ {
+ return array_flip($this->acceptedLevels);
+ }
+
+ /**
+ * @param int|string|array $minLevelOrList A list of levels to accept or a minimum level or level name if maxLevel is provided
+ * @param int|string $maxLevel Maximum level or level name to accept, only used if $minLevelOrList is not an array
+ */
+ public function setAcceptedLevels($minLevelOrList = Logger::DEBUG, $maxLevel = Logger::EMERGENCY)
+ {
+ if (is_array($minLevelOrList)) {
+ $acceptedLevels = array_map('Monolog\Logger::toMonologLevel', $minLevelOrList);
+ } else {
+ $minLevelOrList = Logger::toMonologLevel($minLevelOrList);
+ $maxLevel = Logger::toMonologLevel($maxLevel);
+ $acceptedLevels = array_values(array_filter(Logger::getLevels(), function ($level) use ($minLevelOrList, $maxLevel) {
+ return $level >= $minLevelOrList && $level <= $maxLevel;
+ }));
+ }
+ $this->acceptedLevels = array_flip($acceptedLevels);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function isHandling(array $record)
+ {
+ return isset($this->acceptedLevels[$record['level']]);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handle(array $record)
+ {
+ if (!$this->isHandling($record)) {
+ return false;
+ }
+
+ if ($this->processors) {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+ }
+
+ $this->getHandler($record)->handle($record);
+
+ return false === $this->bubble;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ $filtered = array();
+ foreach ($records as $record) {
+ if ($this->isHandling($record)) {
+ $filtered[] = $record;
+ }
+ }
+
+ if (count($filtered) > 0) {
+ $this->getHandler($filtered[count($filtered) - 1])->handleBatch($filtered);
+ }
+ }
+
+ /**
+ * Return the nested handler
+ *
+ * If the handler was provided as a factory callable, this will trigger the handler's instantiation.
+ *
+ * @return HandlerInterface
+ */
+ public function getHandler(array $record = null)
+ {
+ if (!$this->handler instanceof HandlerInterface) {
+ $this->handler = call_user_func($this->handler, $record, $this);
+ if (!$this->handler instanceof HandlerInterface) {
+ throw new \RuntimeException("The factory callable should return a HandlerInterface");
+ }
+ }
+
+ return $this->handler;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ $this->getHandler()->setFormatter($formatter);
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function getFormatter()
+ {
+ return $this->getHandler()->getFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php b/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php
new file mode 100644
index 000000000..aaca12ccd
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php
@@ -0,0 +1,28 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler\FingersCrossed;
+
+/**
+ * Interface for activation strategies for the FingersCrossedHandler.
+ *
+ * @author Johannes M. Schmitt
+ */
+interface ActivationStrategyInterface
+{
+ /**
+ * Returns whether the given record activates the handler.
+ *
+ * @param array $record
+ * @return bool
+ */
+ public function isHandlerActivated(array $record);
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php b/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php
new file mode 100644
index 000000000..2a2a64d94
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php
@@ -0,0 +1,59 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler\FingersCrossed;
+
+use Monolog\Logger;
+
+/**
+ * Channel and Error level based monolog activation strategy. Allows to trigger activation
+ * based on level per channel. e.g. trigger activation on level 'ERROR' by default, except
+ * for records of the 'sql' channel; those should trigger activation on level 'WARN'.
+ *
+ * Example:
+ *
+ *
+ * $activationStrategy = new ChannelLevelActivationStrategy(
+ * Logger::CRITICAL,
+ * array(
+ * 'request' => Logger::ALERT,
+ * 'sensitive' => Logger::ERROR,
+ * )
+ * );
+ * $handler = new FingersCrossedHandler(new StreamHandler('php://stderr'), $activationStrategy);
+ *
+ *
+ * @author Mike Meessen
+ */
+class ChannelLevelActivationStrategy implements ActivationStrategyInterface
+{
+ private $defaultActionLevel;
+ private $channelToActionLevel;
+
+ /**
+ * @param int $defaultActionLevel The default action level to be used if the record's category doesn't match any
+ * @param array $channelToActionLevel An array that maps channel names to action levels.
+ */
+ public function __construct($defaultActionLevel, $channelToActionLevel = array())
+ {
+ $this->defaultActionLevel = Logger::toMonologLevel($defaultActionLevel);
+ $this->channelToActionLevel = array_map('Monolog\Logger::toMonologLevel', $channelToActionLevel);
+ }
+
+ public function isHandlerActivated(array $record)
+ {
+ if (isset($this->channelToActionLevel[$record['channel']])) {
+ return $record['level'] >= $this->channelToActionLevel[$record['channel']];
+ }
+
+ return $record['level'] >= $this->defaultActionLevel;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php b/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php
new file mode 100644
index 000000000..6e630852f
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php
@@ -0,0 +1,34 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler\FingersCrossed;
+
+use Monolog\Logger;
+
+/**
+ * Error level based activation strategy.
+ *
+ * @author Johannes M. Schmitt
+ */
+class ErrorLevelActivationStrategy implements ActivationStrategyInterface
+{
+ private $actionLevel;
+
+ public function __construct($actionLevel)
+ {
+ $this->actionLevel = Logger::toMonologLevel($actionLevel);
+ }
+
+ public function isHandlerActivated(array $record)
+ {
+ return $record['level'] >= $this->actionLevel;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossedHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossedHandler.php
new file mode 100644
index 000000000..cdabc4458
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/FingersCrossedHandler.php
@@ -0,0 +1,207 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Handler\FingersCrossed\ErrorLevelActivationStrategy;
+use Monolog\Handler\FingersCrossed\ActivationStrategyInterface;
+use Monolog\Logger;
+use Monolog\ResettableInterface;
+use Monolog\Formatter\FormatterInterface;
+
+/**
+ * Buffers all records until a certain level is reached
+ *
+ * The advantage of this approach is that you don't get any clutter in your log files.
+ * Only requests which actually trigger an error (or whatever your actionLevel is) will be
+ * in the logs, but they will contain all records, not only those above the level threshold.
+ *
+ * You can find the various activation strategies in the
+ * Monolog\Handler\FingersCrossed\ namespace.
+ *
+ * @author Jordi Boggiano
+ */
+class FingersCrossedHandler extends AbstractHandler
+{
+ protected $handler;
+ protected $activationStrategy;
+ protected $buffering = true;
+ protected $bufferSize;
+ protected $buffer = array();
+ protected $stopBuffering;
+ protected $passthruLevel;
+
+ /**
+ * @param callable|HandlerInterface $handler Handler or factory callable($record|null, $fingersCrossedHandler).
+ * @param int|ActivationStrategyInterface $activationStrategy Strategy which determines when this handler takes action
+ * @param int $bufferSize How many entries should be buffered at most, beyond that the oldest items are removed from the buffer.
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param bool $stopBuffering Whether the handler should stop buffering after being triggered (default true)
+ * @param int $passthruLevel Minimum level to always flush to handler on close, even if strategy not triggered
+ */
+ public function __construct($handler, $activationStrategy = null, $bufferSize = 0, $bubble = true, $stopBuffering = true, $passthruLevel = null)
+ {
+ if (null === $activationStrategy) {
+ $activationStrategy = new ErrorLevelActivationStrategy(Logger::WARNING);
+ }
+
+ // convert simple int activationStrategy to an object
+ if (!$activationStrategy instanceof ActivationStrategyInterface) {
+ $activationStrategy = new ErrorLevelActivationStrategy($activationStrategy);
+ }
+
+ $this->handler = $handler;
+ $this->activationStrategy = $activationStrategy;
+ $this->bufferSize = $bufferSize;
+ $this->bubble = $bubble;
+ $this->stopBuffering = $stopBuffering;
+
+ if ($passthruLevel !== null) {
+ $this->passthruLevel = Logger::toMonologLevel($passthruLevel);
+ }
+
+ if (!$this->handler instanceof HandlerInterface && !is_callable($this->handler)) {
+ throw new \RuntimeException("The given handler (".json_encode($this->handler).") is not a callable nor a Monolog\Handler\HandlerInterface object");
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function isHandling(array $record)
+ {
+ return true;
+ }
+
+ /**
+ * Manually activate this logger regardless of the activation strategy
+ */
+ public function activate()
+ {
+ if ($this->stopBuffering) {
+ $this->buffering = false;
+ }
+ $this->getHandler(end($this->buffer) ?: null)->handleBatch($this->buffer);
+ $this->buffer = array();
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handle(array $record)
+ {
+ if ($this->processors) {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+ }
+
+ if ($this->buffering) {
+ $this->buffer[] = $record;
+ if ($this->bufferSize > 0 && count($this->buffer) > $this->bufferSize) {
+ array_shift($this->buffer);
+ }
+ if ($this->activationStrategy->isHandlerActivated($record)) {
+ $this->activate();
+ }
+ } else {
+ $this->getHandler($record)->handle($record);
+ }
+
+ return false === $this->bubble;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function close()
+ {
+ $this->flushBuffer();
+ }
+
+ public function reset()
+ {
+ $this->flushBuffer();
+
+ parent::reset();
+
+ if ($this->getHandler() instanceof ResettableInterface) {
+ $this->getHandler()->reset();
+ }
+ }
+
+ /**
+ * Clears the buffer without flushing any messages down to the wrapped handler.
+ *
+ * It also resets the handler to its initial buffering state.
+ */
+ public function clear()
+ {
+ $this->buffer = array();
+ $this->reset();
+ }
+
+ /**
+ * Resets the state of the handler. Stops forwarding records to the wrapped handler.
+ */
+ private function flushBuffer()
+ {
+ if (null !== $this->passthruLevel) {
+ $level = $this->passthruLevel;
+ $this->buffer = array_filter($this->buffer, function ($record) use ($level) {
+ return $record['level'] >= $level;
+ });
+ if (count($this->buffer) > 0) {
+ $this->getHandler(end($this->buffer) ?: null)->handleBatch($this->buffer);
+ }
+ }
+
+ $this->buffer = array();
+ $this->buffering = true;
+ }
+
+ /**
+ * Return the nested handler
+ *
+ * If the handler was provided as a factory callable, this will trigger the handler's instantiation.
+ *
+ * @return HandlerInterface
+ */
+ public function getHandler(array $record = null)
+ {
+ if (!$this->handler instanceof HandlerInterface) {
+ $this->handler = call_user_func($this->handler, $record, $this);
+ if (!$this->handler instanceof HandlerInterface) {
+ throw new \RuntimeException("The factory callable should return a HandlerInterface");
+ }
+ }
+
+ return $this->handler;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ $this->getHandler()->setFormatter($formatter);
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function getFormatter()
+ {
+ return $this->getHandler()->getFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/FirePHPHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/FirePHPHandler.php
new file mode 100644
index 000000000..2a171bd82
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/FirePHPHandler.php
@@ -0,0 +1,195 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\WildfireFormatter;
+
+/**
+ * Simple FirePHP Handler (http://www.firephp.org/), which uses the Wildfire protocol.
+ *
+ * @author Eric Clemmons (@ericclemmons)
+ */
+class FirePHPHandler extends AbstractProcessingHandler
+{
+ /**
+ * WildFire JSON header message format
+ */
+ const PROTOCOL_URI = 'http://meta.wildfirehq.org/Protocol/JsonStream/0.2';
+
+ /**
+ * FirePHP structure for parsing messages & their presentation
+ */
+ const STRUCTURE_URI = 'http://meta.firephp.org/Wildfire/Structure/FirePHP/FirebugConsole/0.1';
+
+ /**
+ * Must reference a "known" plugin, otherwise headers won't display in FirePHP
+ */
+ const PLUGIN_URI = 'http://meta.firephp.org/Wildfire/Plugin/FirePHP/Library-FirePHPCore/0.3';
+
+ /**
+ * Header prefix for Wildfire to recognize & parse headers
+ */
+ const HEADER_PREFIX = 'X-Wf';
+
+ /**
+ * Whether or not Wildfire vendor-specific headers have been generated & sent yet
+ */
+ protected static $initialized = false;
+
+ /**
+ * Shared static message index between potentially multiple handlers
+ * @var int
+ */
+ protected static $messageIndex = 1;
+
+ protected static $sendHeaders = true;
+
+ /**
+ * Base header creation function used by init headers & record headers
+ *
+ * @param array $meta Wildfire Plugin, Protocol & Structure Indexes
+ * @param string $message Log message
+ * @return array Complete header string ready for the client as key and message as value
+ */
+ protected function createHeader(array $meta, $message)
+ {
+ $header = sprintf('%s-%s', self::HEADER_PREFIX, join('-', $meta));
+
+ return array($header => $message);
+ }
+
+ /**
+ * Creates message header from record
+ *
+ * @see createHeader()
+ * @param array $record
+ * @return array
+ */
+ protected function createRecordHeader(array $record)
+ {
+ // Wildfire is extensible to support multiple protocols & plugins in a single request,
+ // but we're not taking advantage of that (yet), so we're using "1" for simplicity's sake.
+ return $this->createHeader(
+ array(1, 1, 1, self::$messageIndex++),
+ $record['formatted']
+ );
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new WildfireFormatter();
+ }
+
+ /**
+ * Wildfire initialization headers to enable message parsing
+ *
+ * @see createHeader()
+ * @see sendHeader()
+ * @return array
+ */
+ protected function getInitHeaders()
+ {
+ // Initial payload consists of required headers for Wildfire
+ return array_merge(
+ $this->createHeader(array('Protocol', 1), self::PROTOCOL_URI),
+ $this->createHeader(array(1, 'Structure', 1), self::STRUCTURE_URI),
+ $this->createHeader(array(1, 'Plugin', 1), self::PLUGIN_URI)
+ );
+ }
+
+ /**
+ * Send header string to the client
+ *
+ * @param string $header
+ * @param string $content
+ */
+ protected function sendHeader($header, $content)
+ {
+ if (!headers_sent() && self::$sendHeaders) {
+ header(sprintf('%s: %s', $header, $content));
+ }
+ }
+
+ /**
+ * Creates & sends header for a record, ensuring init headers have been sent prior
+ *
+ * @see sendHeader()
+ * @see sendInitHeaders()
+ * @param array $record
+ */
+ protected function write(array $record)
+ {
+ if (!self::$sendHeaders) {
+ return;
+ }
+
+ // WildFire-specific headers must be sent prior to any messages
+ if (!self::$initialized) {
+ self::$initialized = true;
+
+ self::$sendHeaders = $this->headersAccepted();
+ if (!self::$sendHeaders) {
+ return;
+ }
+
+ foreach ($this->getInitHeaders() as $header => $content) {
+ $this->sendHeader($header, $content);
+ }
+ }
+
+ $header = $this->createRecordHeader($record);
+ if (trim(current($header)) !== '') {
+ $this->sendHeader(key($header), current($header));
+ }
+ }
+
+ /**
+ * Verifies if the headers are accepted by the current user agent
+ *
+ * @return bool
+ */
+ protected function headersAccepted()
+ {
+ if (!empty($_SERVER['HTTP_USER_AGENT']) && preg_match('{\bFirePHP/\d+\.\d+\b}', $_SERVER['HTTP_USER_AGENT'])) {
+ return true;
+ }
+
+ return isset($_SERVER['HTTP_X_FIREPHP_VERSION']);
+ }
+
+ /**
+ * BC getter for the sendHeaders property that has been made static
+ */
+ public function __get($property)
+ {
+ if ('sendHeaders' !== $property) {
+ throw new \InvalidArgumentException('Undefined property '.$property);
+ }
+
+ return static::$sendHeaders;
+ }
+
+ /**
+ * BC setter for the sendHeaders property that has been made static
+ */
+ public function __set($property, $value)
+ {
+ if ('sendHeaders' !== $property) {
+ throw new \InvalidArgumentException('Undefined property '.$property);
+ }
+
+ static::$sendHeaders = $value;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/FleepHookHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/FleepHookHandler.php
new file mode 100644
index 000000000..c43c0134f
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/FleepHookHandler.php
@@ -0,0 +1,126 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\LineFormatter;
+use Monolog\Logger;
+
+/**
+ * Sends logs to Fleep.io using Webhook integrations
+ *
+ * You'll need a Fleep.io account to use this handler.
+ *
+ * @see https://fleep.io/integrations/webhooks/ Fleep Webhooks Documentation
+ * @author Ando Roots
+ */
+class FleepHookHandler extends SocketHandler
+{
+ const FLEEP_HOST = 'fleep.io';
+
+ const FLEEP_HOOK_URI = '/hook/';
+
+ /**
+ * @var string Webhook token (specifies the conversation where logs are sent)
+ */
+ protected $token;
+
+ /**
+ * Construct a new Fleep.io Handler.
+ *
+ * For instructions on how to create a new web hook in your conversations
+ * see https://fleep.io/integrations/webhooks/
+ *
+ * @param string $token Webhook token
+ * @param bool|int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @throws MissingExtensionException
+ */
+ public function __construct($token, $level = Logger::DEBUG, $bubble = true)
+ {
+ if (!extension_loaded('openssl')) {
+ throw new MissingExtensionException('The OpenSSL PHP extension is required to use the FleepHookHandler');
+ }
+
+ $this->token = $token;
+
+ $connectionString = 'ssl://' . self::FLEEP_HOST . ':443';
+ parent::__construct($connectionString, $level, $bubble);
+ }
+
+ /**
+ * Returns the default formatter to use with this handler
+ *
+ * Overloaded to remove empty context and extra arrays from the end of the log message.
+ *
+ * @return LineFormatter
+ */
+ protected function getDefaultFormatter()
+ {
+ return new LineFormatter(null, null, true, true);
+ }
+
+ /**
+ * Handles a log record
+ *
+ * @param array $record
+ */
+ public function write(array $record)
+ {
+ parent::write($record);
+ $this->closeSocket();
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ * @return string
+ */
+ protected function generateDataStream($record)
+ {
+ $content = $this->buildContent($record);
+
+ return $this->buildHeader($content) . $content;
+ }
+
+ /**
+ * Builds the header of the API Call
+ *
+ * @param string $content
+ * @return string
+ */
+ private function buildHeader($content)
+ {
+ $header = "POST " . self::FLEEP_HOOK_URI . $this->token . " HTTP/1.1\r\n";
+ $header .= "Host: " . self::FLEEP_HOST . "\r\n";
+ $header .= "Content-Type: application/x-www-form-urlencoded\r\n";
+ $header .= "Content-Length: " . strlen($content) . "\r\n";
+ $header .= "\r\n";
+
+ return $header;
+ }
+
+ /**
+ * Builds the body of API call
+ *
+ * @param array $record
+ * @return string
+ */
+ private function buildContent($record)
+ {
+ $dataArray = array(
+ 'message' => $record['formatted'],
+ );
+
+ return http_build_query($dataArray);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/FlowdockHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/FlowdockHandler.php
new file mode 100644
index 000000000..f0f010cbf
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/FlowdockHandler.php
@@ -0,0 +1,128 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Utils;
+use Monolog\Formatter\FlowdockFormatter;
+use Monolog\Formatter\FormatterInterface;
+
+/**
+ * Sends notifications through the Flowdock push API
+ *
+ * This must be configured with a FlowdockFormatter instance via setFormatter()
+ *
+ * Notes:
+ * API token - Flowdock API token
+ *
+ * @author Dominik Liebler
+ * @see https://www.flowdock.com/api/push
+ */
+class FlowdockHandler extends SocketHandler
+{
+ /**
+ * @var string
+ */
+ protected $apiToken;
+
+ /**
+ * @param string $apiToken
+ * @param bool|int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ *
+ * @throws MissingExtensionException if OpenSSL is missing
+ */
+ public function __construct($apiToken, $level = Logger::DEBUG, $bubble = true)
+ {
+ if (!extension_loaded('openssl')) {
+ throw new MissingExtensionException('The OpenSSL PHP extension is required to use the FlowdockHandler');
+ }
+
+ parent::__construct('ssl://api.flowdock.com:443', $level, $bubble);
+ $this->apiToken = $apiToken;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ if (!$formatter instanceof FlowdockFormatter) {
+ throw new \InvalidArgumentException('The FlowdockHandler requires an instance of Monolog\Formatter\FlowdockFormatter to function correctly');
+ }
+
+ return parent::setFormatter($formatter);
+ }
+
+ /**
+ * Gets the default formatter.
+ *
+ * @return FormatterInterface
+ */
+ protected function getDefaultFormatter()
+ {
+ throw new \InvalidArgumentException('The FlowdockHandler must be configured (via setFormatter) with an instance of Monolog\Formatter\FlowdockFormatter to function correctly');
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ */
+ protected function write(array $record)
+ {
+ parent::write($record);
+
+ $this->closeSocket();
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ * @return string
+ */
+ protected function generateDataStream($record)
+ {
+ $content = $this->buildContent($record);
+
+ return $this->buildHeader($content) . $content;
+ }
+
+ /**
+ * Builds the body of API call
+ *
+ * @param array $record
+ * @return string
+ */
+ private function buildContent($record)
+ {
+ return Utils::jsonEncode($record['formatted']['flowdock']);
+ }
+
+ /**
+ * Builds the header of the API Call
+ *
+ * @param string $content
+ * @return string
+ */
+ private function buildHeader($content)
+ {
+ $header = "POST /v1/messages/team_inbox/" . $this->apiToken . " HTTP/1.1\r\n";
+ $header .= "Host: api.flowdock.com\r\n";
+ $header .= "Content-Type: application/json\r\n";
+ $header .= "Content-Length: " . strlen($content) . "\r\n";
+ $header .= "\r\n";
+
+ return $header;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/FormattableHandlerInterface.php b/vendor/monolog/monolog/src/Monolog/Handler/FormattableHandlerInterface.php
new file mode 100644
index 000000000..3e2f1b28a
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/FormattableHandlerInterface.php
@@ -0,0 +1,39 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\FormatterInterface;
+
+/**
+ * Interface to describe loggers that have a formatter
+ *
+ * This interface is present in monolog 1.x to ease forward compatibility.
+ *
+ * @author Jordi Boggiano
+ */
+interface FormattableHandlerInterface
+{
+ /**
+ * Sets the formatter.
+ *
+ * @param FormatterInterface $formatter
+ * @return HandlerInterface self
+ */
+ public function setFormatter(FormatterInterface $formatter): HandlerInterface;
+
+ /**
+ * Gets the formatter.
+ *
+ * @return FormatterInterface
+ */
+ public function getFormatter(): FormatterInterface;
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/FormattableHandlerTrait.php b/vendor/monolog/monolog/src/Monolog/Handler/FormattableHandlerTrait.php
new file mode 100644
index 000000000..e9ec5e776
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/FormattableHandlerTrait.php
@@ -0,0 +1,63 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\FormatterInterface;
+use Monolog\Formatter\LineFormatter;
+
+/**
+ * Helper trait for implementing FormattableInterface
+ *
+ * This trait is present in monolog 1.x to ease forward compatibility.
+ *
+ * @author Jordi Boggiano
+ */
+trait FormattableHandlerTrait
+{
+ /**
+ * @var FormatterInterface
+ */
+ protected $formatter;
+
+ /**
+ * {@inheritdoc}
+ * @suppress PhanTypeMismatchReturn
+ */
+ public function setFormatter(FormatterInterface $formatter): HandlerInterface
+ {
+ $this->formatter = $formatter;
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function getFormatter(): FormatterInterface
+ {
+ if (!$this->formatter) {
+ $this->formatter = $this->getDefaultFormatter();
+ }
+
+ return $this->formatter;
+ }
+
+ /**
+ * Gets the default formatter.
+ *
+ * Overwrite this if the LineFormatter is not a good default for your handler.
+ */
+ protected function getDefaultFormatter(): FormatterInterface
+ {
+ return new LineFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/GelfHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/GelfHandler.php
new file mode 100644
index 000000000..b6cde7c65
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/GelfHandler.php
@@ -0,0 +1,65 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Gelf\IMessagePublisher;
+use Gelf\PublisherInterface;
+use Gelf\Publisher;
+use InvalidArgumentException;
+use Monolog\Logger;
+use Monolog\Formatter\GelfMessageFormatter;
+
+/**
+ * Handler to send messages to a Graylog2 (http://www.graylog2.org) server
+ *
+ * @author Matt Lehner
+ * @author Benjamin Zikarsky
+ */
+class GelfHandler extends AbstractProcessingHandler
+{
+ /**
+ * @var Publisher|PublisherInterface|IMessagePublisher the publisher object that sends the message to the server
+ */
+ protected $publisher;
+
+ /**
+ * @param PublisherInterface|IMessagePublisher|Publisher $publisher a publisher object
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct($publisher, $level = Logger::DEBUG, $bubble = true)
+ {
+ parent::__construct($level, $bubble);
+
+ if (!$publisher instanceof Publisher && !$publisher instanceof IMessagePublisher && !$publisher instanceof PublisherInterface) {
+ throw new InvalidArgumentException('Invalid publisher, expected a Gelf\Publisher, Gelf\IMessagePublisher or Gelf\PublisherInterface instance');
+ }
+
+ $this->publisher = $publisher;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ $this->publisher->publish($record['formatted']);
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new GelfMessageFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/GroupHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/GroupHandler.php
new file mode 100644
index 000000000..0d461f9c7
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/GroupHandler.php
@@ -0,0 +1,117 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\FormatterInterface;
+use Monolog\ResettableInterface;
+
+/**
+ * Forwards records to multiple handlers
+ *
+ * @author Lenar Lõhmus
+ */
+class GroupHandler extends AbstractHandler
+{
+ protected $handlers;
+
+ /**
+ * @param array $handlers Array of Handlers.
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct(array $handlers, $bubble = true)
+ {
+ foreach ($handlers as $handler) {
+ if (!$handler instanceof HandlerInterface) {
+ throw new \InvalidArgumentException('The first argument of the GroupHandler must be an array of HandlerInterface instances.');
+ }
+ }
+
+ $this->handlers = $handlers;
+ $this->bubble = $bubble;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function isHandling(array $record)
+ {
+ foreach ($this->handlers as $handler) {
+ if ($handler->isHandling($record)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handle(array $record)
+ {
+ if ($this->processors) {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+ }
+
+ foreach ($this->handlers as $handler) {
+ $handler->handle($record);
+ }
+
+ return false === $this->bubble;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ if ($this->processors) {
+ $processed = array();
+ foreach ($records as $record) {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+ $processed[] = $record;
+ }
+ $records = $processed;
+ }
+
+ foreach ($this->handlers as $handler) {
+ $handler->handleBatch($records);
+ }
+ }
+
+ public function reset()
+ {
+ parent::reset();
+
+ foreach ($this->handlers as $handler) {
+ if ($handler instanceof ResettableInterface) {
+ $handler->reset();
+ }
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ foreach ($this->handlers as $handler) {
+ $handler->setFormatter($formatter);
+ }
+
+ return $this;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/HandlerInterface.php b/vendor/monolog/monolog/src/Monolog/Handler/HandlerInterface.php
new file mode 100644
index 000000000..8d5a4a095
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/HandlerInterface.php
@@ -0,0 +1,90 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\FormatterInterface;
+
+/**
+ * Interface that all Monolog Handlers must implement
+ *
+ * @author Jordi Boggiano
+ */
+interface HandlerInterface
+{
+ /**
+ * Checks whether the given record will be handled by this handler.
+ *
+ * This is mostly done for performance reasons, to avoid calling processors for nothing.
+ *
+ * Handlers should still check the record levels within handle(), returning false in isHandling()
+ * is no guarantee that handle() will not be called, and isHandling() might not be called
+ * for a given record.
+ *
+ * @param array $record Partial log record containing only a level key
+ *
+ * @return bool
+ */
+ public function isHandling(array $record);
+
+ /**
+ * Handles a record.
+ *
+ * All records may be passed to this method, and the handler should discard
+ * those that it does not want to handle.
+ *
+ * The return value of this function controls the bubbling process of the handler stack.
+ * Unless the bubbling is interrupted (by returning true), the Logger class will keep on
+ * calling further handlers in the stack with a given log record.
+ *
+ * @param array $record The record to handle
+ * @return bool true means that this handler handled the record, and that bubbling is not permitted.
+ * false means the record was either not processed or that this handler allows bubbling.
+ */
+ public function handle(array $record);
+
+ /**
+ * Handles a set of records at once.
+ *
+ * @param array $records The records to handle (an array of record arrays)
+ */
+ public function handleBatch(array $records);
+
+ /**
+ * Adds a processor in the stack.
+ *
+ * @param callable $callback
+ * @return self
+ */
+ public function pushProcessor($callback);
+
+ /**
+ * Removes the processor on top of the stack and returns it.
+ *
+ * @return callable
+ */
+ public function popProcessor();
+
+ /**
+ * Sets the formatter.
+ *
+ * @param FormatterInterface $formatter
+ * @return self
+ */
+ public function setFormatter(FormatterInterface $formatter);
+
+ /**
+ * Gets the formatter.
+ *
+ * @return FormatterInterface
+ */
+ public function getFormatter();
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/HandlerWrapper.php b/vendor/monolog/monolog/src/Monolog/Handler/HandlerWrapper.php
new file mode 100644
index 000000000..55e649868
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/HandlerWrapper.php
@@ -0,0 +1,116 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\ResettableInterface;
+use Monolog\Formatter\FormatterInterface;
+
+/**
+ * This simple wrapper class can be used to extend handlers functionality.
+ *
+ * Example: A custom filtering that can be applied to any handler.
+ *
+ * Inherit from this class and override handle() like this:
+ *
+ * public function handle(array $record)
+ * {
+ * if ($record meets certain conditions) {
+ * return false;
+ * }
+ * return $this->handler->handle($record);
+ * }
+ *
+ * @author Alexey Karapetov
+ */
+class HandlerWrapper implements HandlerInterface, ResettableInterface
+{
+ /**
+ * @var HandlerInterface
+ */
+ protected $handler;
+
+ /**
+ * HandlerWrapper constructor.
+ * @param HandlerInterface $handler
+ */
+ public function __construct(HandlerInterface $handler)
+ {
+ $this->handler = $handler;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function isHandling(array $record)
+ {
+ return $this->handler->isHandling($record);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handle(array $record)
+ {
+ return $this->handler->handle($record);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ return $this->handler->handleBatch($records);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function pushProcessor($callback)
+ {
+ $this->handler->pushProcessor($callback);
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function popProcessor()
+ {
+ return $this->handler->popProcessor();
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ $this->handler->setFormatter($formatter);
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function getFormatter()
+ {
+ return $this->handler->getFormatter();
+ }
+
+ public function reset()
+ {
+ if ($this->handler instanceof ResettableInterface) {
+ return $this->handler->reset();
+ }
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/HipChatHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/HipChatHandler.php
new file mode 100644
index 000000000..30258e36e
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/HipChatHandler.php
@@ -0,0 +1,367 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+
+/**
+ * Sends notifications through the hipchat api to a hipchat room
+ *
+ * Notes:
+ * API token - HipChat API token
+ * Room - HipChat Room Id or name, where messages are sent
+ * Name - Name used to send the message (from)
+ * notify - Should the message trigger a notification in the clients
+ * version - The API version to use (HipChatHandler::API_V1 | HipChatHandler::API_V2)
+ *
+ * @author Rafael Dohms
+ * @see https://www.hipchat.com/docs/api
+ */
+class HipChatHandler extends SocketHandler
+{
+ /**
+ * Use API version 1
+ */
+ const API_V1 = 'v1';
+
+ /**
+ * Use API version v2
+ */
+ const API_V2 = 'v2';
+
+ /**
+ * The maximum allowed length for the name used in the "from" field.
+ */
+ const MAXIMUM_NAME_LENGTH = 15;
+
+ /**
+ * The maximum allowed length for the message.
+ */
+ const MAXIMUM_MESSAGE_LENGTH = 9500;
+
+ /**
+ * @var string
+ */
+ private $token;
+
+ /**
+ * @var string
+ */
+ private $room;
+
+ /**
+ * @var string
+ */
+ private $name;
+
+ /**
+ * @var bool
+ */
+ private $notify;
+
+ /**
+ * @var string
+ */
+ private $format;
+
+ /**
+ * @var string
+ */
+ private $host;
+
+ /**
+ * @var string
+ */
+ private $version;
+
+ /**
+ * @param string $token HipChat API Token
+ * @param string $room The room that should be alerted of the message (Id or Name)
+ * @param string $name Name used in the "from" field.
+ * @param bool $notify Trigger a notification in clients or not
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param bool $useSSL Whether to connect via SSL.
+ * @param string $format The format of the messages (default to text, can be set to html if you have html in the messages)
+ * @param string $host The HipChat server hostname.
+ * @param string $version The HipChat API version (default HipChatHandler::API_V1)
+ */
+ public function __construct($token, $room, $name = 'Monolog', $notify = false, $level = Logger::CRITICAL, $bubble = true, $useSSL = true, $format = 'text', $host = 'api.hipchat.com', $version = self::API_V1)
+ {
+ @trigger_error('The Monolog\Handler\HipChatHandler class is deprecated. You should migrate to Slack and the SlackWebhookHandler / SlackbotHandler, see https://www.atlassian.com/partnerships/slack', E_USER_DEPRECATED);
+
+ if ($version == self::API_V1 && !$this->validateStringLength($name, static::MAXIMUM_NAME_LENGTH)) {
+ throw new \InvalidArgumentException('The supplied name is too long. HipChat\'s v1 API supports names up to 15 UTF-8 characters.');
+ }
+
+ $connectionString = $useSSL ? 'ssl://'.$host.':443' : $host.':80';
+ parent::__construct($connectionString, $level, $bubble);
+
+ $this->token = $token;
+ $this->name = $name;
+ $this->notify = $notify;
+ $this->room = $room;
+ $this->format = $format;
+ $this->host = $host;
+ $this->version = $version;
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ * @return string
+ */
+ protected function generateDataStream($record)
+ {
+ $content = $this->buildContent($record);
+
+ return $this->buildHeader($content) . $content;
+ }
+
+ /**
+ * Builds the body of API call
+ *
+ * @param array $record
+ * @return string
+ */
+ private function buildContent($record)
+ {
+ $dataArray = array(
+ 'notify' => $this->version == self::API_V1 ?
+ ($this->notify ? 1 : 0) :
+ ($this->notify ? 'true' : 'false'),
+ 'message' => $record['formatted'],
+ 'message_format' => $this->format,
+ 'color' => $this->getAlertColor($record['level']),
+ );
+
+ if (!$this->validateStringLength($dataArray['message'], static::MAXIMUM_MESSAGE_LENGTH)) {
+ if (function_exists('mb_substr')) {
+ $dataArray['message'] = mb_substr($dataArray['message'], 0, static::MAXIMUM_MESSAGE_LENGTH).' [truncated]';
+ } else {
+ $dataArray['message'] = substr($dataArray['message'], 0, static::MAXIMUM_MESSAGE_LENGTH).' [truncated]';
+ }
+ }
+
+ // if we are using the legacy API then we need to send some additional information
+ if ($this->version == self::API_V1) {
+ $dataArray['room_id'] = $this->room;
+ }
+
+ // append the sender name if it is set
+ // always append it if we use the v1 api (it is required in v1)
+ if ($this->version == self::API_V1 || $this->name !== null) {
+ $dataArray['from'] = (string) $this->name;
+ }
+
+ return http_build_query($dataArray);
+ }
+
+ /**
+ * Builds the header of the API Call
+ *
+ * @param string $content
+ * @return string
+ */
+ private function buildHeader($content)
+ {
+ if ($this->version == self::API_V1) {
+ $header = "POST /v1/rooms/message?format=json&auth_token={$this->token} HTTP/1.1\r\n";
+ } else {
+ // needed for rooms with special (spaces, etc) characters in the name
+ $room = rawurlencode($this->room);
+ $header = "POST /v2/room/{$room}/notification?auth_token={$this->token} HTTP/1.1\r\n";
+ }
+
+ $header .= "Host: {$this->host}\r\n";
+ $header .= "Content-Type: application/x-www-form-urlencoded\r\n";
+ $header .= "Content-Length: " . strlen($content) . "\r\n";
+ $header .= "\r\n";
+
+ return $header;
+ }
+
+ /**
+ * Assigns a color to each level of log records.
+ *
+ * @param int $level
+ * @return string
+ */
+ protected function getAlertColor($level)
+ {
+ switch (true) {
+ case $level >= Logger::ERROR:
+ return 'red';
+ case $level >= Logger::WARNING:
+ return 'yellow';
+ case $level >= Logger::INFO:
+ return 'green';
+ case $level == Logger::DEBUG:
+ return 'gray';
+ default:
+ return 'yellow';
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ */
+ protected function write(array $record)
+ {
+ parent::write($record);
+ $this->finalizeWrite();
+ }
+
+ /**
+ * Finalizes the request by reading some bytes and then closing the socket
+ *
+ * If we do not read some but close the socket too early, hipchat sometimes
+ * drops the request entirely.
+ */
+ protected function finalizeWrite()
+ {
+ $res = $this->getResource();
+ if (is_resource($res)) {
+ @fread($res, 2048);
+ }
+ $this->closeSocket();
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ if (count($records) == 0) {
+ return true;
+ }
+
+ $batchRecords = $this->combineRecords($records);
+
+ $handled = false;
+ foreach ($batchRecords as $batchRecord) {
+ if ($this->isHandling($batchRecord)) {
+ $this->write($batchRecord);
+ $handled = true;
+ }
+ }
+
+ if (!$handled) {
+ return false;
+ }
+
+ return false === $this->bubble;
+ }
+
+ /**
+ * Combines multiple records into one. Error level of the combined record
+ * will be the highest level from the given records. Datetime will be taken
+ * from the first record.
+ *
+ * @param array $records
+ * @return array
+ */
+ private function combineRecords(array $records)
+ {
+ $batchRecord = null;
+ $batchRecords = array();
+ $messages = array();
+ $formattedMessages = array();
+ $level = 0;
+ $levelName = null;
+ $datetime = null;
+
+ foreach ($records as $record) {
+ $record = $this->processRecord($record);
+
+ if ($record['level'] > $level) {
+ $level = $record['level'];
+ $levelName = $record['level_name'];
+ }
+
+ if (null === $datetime) {
+ $datetime = $record['datetime'];
+ }
+
+ $messages[] = $record['message'];
+ $messageStr = implode(PHP_EOL, $messages);
+ $formattedMessages[] = $this->getFormatter()->format($record);
+ $formattedMessageStr = implode('', $formattedMessages);
+
+ $batchRecord = array(
+ 'message' => $messageStr,
+ 'formatted' => $formattedMessageStr,
+ 'context' => array(),
+ 'extra' => array(),
+ );
+
+ if (!$this->validateStringLength($batchRecord['formatted'], static::MAXIMUM_MESSAGE_LENGTH)) {
+ // Pop the last message and implode the remaining messages
+ $lastMessage = array_pop($messages);
+ $lastFormattedMessage = array_pop($formattedMessages);
+ $batchRecord['message'] = implode(PHP_EOL, $messages);
+ $batchRecord['formatted'] = implode('', $formattedMessages);
+
+ $batchRecords[] = $batchRecord;
+ $messages = array($lastMessage);
+ $formattedMessages = array($lastFormattedMessage);
+
+ $batchRecord = null;
+ }
+ }
+
+ if (null !== $batchRecord) {
+ $batchRecords[] = $batchRecord;
+ }
+
+ // Set the max level and datetime for all records
+ foreach ($batchRecords as &$batchRecord) {
+ $batchRecord = array_merge(
+ $batchRecord,
+ array(
+ 'level' => $level,
+ 'level_name' => $levelName,
+ 'datetime' => $datetime,
+ )
+ );
+ }
+
+ return $batchRecords;
+ }
+
+ /**
+ * Validates the length of a string.
+ *
+ * If the `mb_strlen()` function is available, it will use that, as HipChat
+ * allows UTF-8 characters. Otherwise, it will fall back to `strlen()`.
+ *
+ * Note that this might cause false failures in the specific case of using
+ * a valid name with less than 16 characters, but 16 or more bytes, on a
+ * system where `mb_strlen()` is unavailable.
+ *
+ * @param string $str
+ * @param int $length
+ *
+ * @return bool
+ */
+ private function validateStringLength($str, $length)
+ {
+ if (function_exists('mb_strlen')) {
+ return (mb_strlen($str) <= $length);
+ }
+
+ return (strlen($str) <= $length);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/IFTTTHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/IFTTTHandler.php
new file mode 100644
index 000000000..f4d3b97eb
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/IFTTTHandler.php
@@ -0,0 +1,70 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Utils;
+
+/**
+ * IFTTTHandler uses cURL to trigger IFTTT Maker actions
+ *
+ * Register a secret key and trigger/event name at https://ifttt.com/maker
+ *
+ * value1 will be the channel from monolog's Logger constructor,
+ * value2 will be the level name (ERROR, WARNING, ..)
+ * value3 will be the log record's message
+ *
+ * @author Nehal Patel
+ */
+class IFTTTHandler extends AbstractProcessingHandler
+{
+ private $eventName;
+ private $secretKey;
+
+ /**
+ * @param string $eventName The name of the IFTTT Maker event that should be triggered
+ * @param string $secretKey A valid IFTTT secret key
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct($eventName, $secretKey, $level = Logger::ERROR, $bubble = true)
+ {
+ $this->eventName = $eventName;
+ $this->secretKey = $secretKey;
+
+ parent::__construct($level, $bubble);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function write(array $record)
+ {
+ $postData = array(
+ "value1" => $record["channel"],
+ "value2" => $record["level_name"],
+ "value3" => $record["message"],
+ );
+ $postString = Utils::jsonEncode($postData);
+
+ $ch = curl_init();
+ curl_setopt($ch, CURLOPT_URL, "https://maker.ifttt.com/trigger/" . $this->eventName . "/with/key/" . $this->secretKey);
+ curl_setopt($ch, CURLOPT_POST, true);
+ curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
+ curl_setopt($ch, CURLOPT_POSTFIELDS, $postString);
+ curl_setopt($ch, CURLOPT_HTTPHEADER, array(
+ "Content-Type: application/json",
+ ));
+
+ Curl\Util::execute($ch);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/InsightOpsHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/InsightOpsHandler.php
new file mode 100644
index 000000000..8f683dce5
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/InsightOpsHandler.php
@@ -0,0 +1,62 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+ namespace Monolog\Handler;
+
+ use Monolog\Logger;
+
+/**
+ * Inspired on LogEntriesHandler.
+ *
+ * @author Robert Kaufmann III
+ * @author Gabriel Machado
+ */
+class InsightOpsHandler extends SocketHandler
+{
+ /**
+ * @var string
+ */
+ protected $logToken;
+
+ /**
+ * @param string $token Log token supplied by InsightOps
+ * @param string $region Region where InsightOps account is hosted. Could be 'us' or 'eu'.
+ * @param bool $useSSL Whether or not SSL encryption should be used
+ * @param int $level The minimum logging level to trigger this handler
+ * @param bool $bubble Whether or not messages that are handled should bubble up the stack.
+ *
+ * @throws MissingExtensionException If SSL encryption is set to true and OpenSSL is missing
+ */
+ public function __construct($token, $region = 'us', $useSSL = true, $level = Logger::DEBUG, $bubble = true)
+ {
+ if ($useSSL && !extension_loaded('openssl')) {
+ throw new MissingExtensionException('The OpenSSL PHP plugin is required to use SSL encrypted connection for InsightOpsHandler');
+ }
+
+ $endpoint = $useSSL
+ ? 'ssl://' . $region . '.data.logs.insight.rapid7.com:443'
+ : $region . '.data.logs.insight.rapid7.com:80';
+
+ parent::__construct($endpoint, $level, $bubble);
+ $this->logToken = $token;
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ * @return string
+ */
+ protected function generateDataStream($record)
+ {
+ return $this->logToken . ' ' . $record['formatted'];
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/LogEntriesHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/LogEntriesHandler.php
new file mode 100644
index 000000000..ea89fb3ed
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/LogEntriesHandler.php
@@ -0,0 +1,55 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+
+/**
+ * @author Robert Kaufmann III
+ */
+class LogEntriesHandler extends SocketHandler
+{
+ /**
+ * @var string
+ */
+ protected $logToken;
+
+ /**
+ * @param string $token Log token supplied by LogEntries
+ * @param bool $useSSL Whether or not SSL encryption should be used.
+ * @param int $level The minimum logging level to trigger this handler
+ * @param bool $bubble Whether or not messages that are handled should bubble up the stack.
+ *
+ * @throws MissingExtensionException If SSL encryption is set to true and OpenSSL is missing
+ */
+ public function __construct($token, $useSSL = true, $level = Logger::DEBUG, $bubble = true, $host = 'data.logentries.com')
+ {
+ if ($useSSL && !extension_loaded('openssl')) {
+ throw new MissingExtensionException('The OpenSSL PHP plugin is required to use SSL encrypted connection for LogEntriesHandler');
+ }
+
+ $endpoint = $useSSL ? 'ssl://' . $host . ':443' : $host . ':80';
+ parent::__construct($endpoint, $level, $bubble);
+ $this->logToken = $token;
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ * @return string
+ */
+ protected function generateDataStream($record)
+ {
+ return $this->logToken . ' ' . $record['formatted'];
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/LogglyHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/LogglyHandler.php
new file mode 100644
index 000000000..bcd62e1c5
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/LogglyHandler.php
@@ -0,0 +1,102 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Formatter\LogglyFormatter;
+
+/**
+ * Sends errors to Loggly.
+ *
+ * @author Przemek Sobstel
+ * @author Adam Pancutt
+ * @author Gregory Barchard
+ */
+class LogglyHandler extends AbstractProcessingHandler
+{
+ const HOST = 'logs-01.loggly.com';
+ const ENDPOINT_SINGLE = 'inputs';
+ const ENDPOINT_BATCH = 'bulk';
+
+ protected $token;
+
+ protected $tag = array();
+
+ public function __construct($token, $level = Logger::DEBUG, $bubble = true)
+ {
+ if (!extension_loaded('curl')) {
+ throw new \LogicException('The curl extension is needed to use the LogglyHandler');
+ }
+
+ $this->token = $token;
+
+ parent::__construct($level, $bubble);
+ }
+
+ public function setTag($tag)
+ {
+ $tag = !empty($tag) ? $tag : array();
+ $this->tag = is_array($tag) ? $tag : array($tag);
+ }
+
+ public function addTag($tag)
+ {
+ if (!empty($tag)) {
+ $tag = is_array($tag) ? $tag : array($tag);
+ $this->tag = array_unique(array_merge($this->tag, $tag));
+ }
+ }
+
+ protected function write(array $record)
+ {
+ $this->send($record["formatted"], self::ENDPOINT_SINGLE);
+ }
+
+ public function handleBatch(array $records)
+ {
+ $level = $this->level;
+
+ $records = array_filter($records, function ($record) use ($level) {
+ return ($record['level'] >= $level);
+ });
+
+ if ($records) {
+ $this->send($this->getFormatter()->formatBatch($records), self::ENDPOINT_BATCH);
+ }
+ }
+
+ protected function send($data, $endpoint)
+ {
+ $url = sprintf("https://%s/%s/%s/", self::HOST, $endpoint, $this->token);
+
+ $headers = array('Content-Type: application/json');
+
+ if (!empty($this->tag)) {
+ $headers[] = 'X-LOGGLY-TAG: '.implode(',', $this->tag);
+ }
+
+ $ch = curl_init();
+
+ curl_setopt($ch, CURLOPT_URL, $url);
+ curl_setopt($ch, CURLOPT_POST, true);
+ curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
+ curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
+ curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
+
+ Curl\Util::execute($ch);
+ }
+
+ protected function getDefaultFormatter()
+ {
+ return new LogglyFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/MailHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/MailHandler.php
new file mode 100644
index 000000000..9e2328385
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/MailHandler.php
@@ -0,0 +1,67 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+/**
+ * Base class for all mail handlers
+ *
+ * @author Gyula Sallai
+ */
+abstract class MailHandler extends AbstractProcessingHandler
+{
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ $messages = array();
+
+ foreach ($records as $record) {
+ if ($record['level'] < $this->level) {
+ continue;
+ }
+ $messages[] = $this->processRecord($record);
+ }
+
+ if (!empty($messages)) {
+ $this->send((string) $this->getFormatter()->formatBatch($messages), $messages);
+ }
+ }
+
+ /**
+ * Send a mail with the given content
+ *
+ * @param string $content formatted email body to be sent
+ * @param array $records the array of log records that formed this content
+ */
+ abstract protected function send($content, array $records);
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ $this->send((string) $record['formatted'], array($record));
+ }
+
+ protected function getHighestRecord(array $records)
+ {
+ $highestRecord = null;
+ foreach ($records as $record) {
+ if ($highestRecord === null || $highestRecord['level'] < $record['level']) {
+ $highestRecord = $record;
+ }
+ }
+
+ return $highestRecord;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/MandrillHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/MandrillHandler.php
new file mode 100644
index 000000000..de039a869
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/MandrillHandler.php
@@ -0,0 +1,72 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+
+/**
+ * MandrillHandler uses cURL to send the emails to the Mandrill API
+ *
+ * @author Adam Nicholson
+ */
+class MandrillHandler extends MailHandler
+{
+ protected $message;
+ protected $apiKey;
+
+ /**
+ * @param string $apiKey A valid Mandrill API key
+ * @param callable|\Swift_Message $message An example message for real messages, only the body will be replaced
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct($apiKey, $message, $level = Logger::ERROR, $bubble = true)
+ {
+ parent::__construct($level, $bubble);
+
+ if (!$message instanceof \Swift_Message && is_callable($message)) {
+ $message = call_user_func($message);
+ }
+ if (!$message instanceof \Swift_Message) {
+ throw new \InvalidArgumentException('You must provide either a Swift_Message instance or a callable returning it');
+ }
+ $this->message = $message;
+ $this->apiKey = $apiKey;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function send($content, array $records)
+ {
+ $message = clone $this->message;
+ $message->setBody($content);
+ if (version_compare(\Swift::VERSION, '6.0.0', '>=')) {
+ $message->setDate(new \DateTimeImmutable());
+ } else {
+ $message->setDate(time());
+ }
+
+ $ch = curl_init();
+
+ curl_setopt($ch, CURLOPT_URL, 'https://mandrillapp.com/api/1.0/messages/send-raw.json');
+ curl_setopt($ch, CURLOPT_POST, 1);
+ curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
+ curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query(array(
+ 'key' => $this->apiKey,
+ 'raw_message' => (string) $message,
+ 'async' => false,
+ )));
+
+ Curl\Util::execute($ch);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/MissingExtensionException.php b/vendor/monolog/monolog/src/Monolog/Handler/MissingExtensionException.php
new file mode 100644
index 000000000..4724a7e2d
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/MissingExtensionException.php
@@ -0,0 +1,21 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+/**
+ * Exception can be thrown if an extension for an handler is missing
+ *
+ * @author Christian Bergau
+ */
+class MissingExtensionException extends \Exception
+{
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/MongoDBHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/MongoDBHandler.php
new file mode 100644
index 000000000..56fe755b9
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/MongoDBHandler.php
@@ -0,0 +1,59 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Formatter\NormalizerFormatter;
+
+/**
+ * Logs to a MongoDB database.
+ *
+ * usage example:
+ *
+ * $log = new Logger('application');
+ * $mongodb = new MongoDBHandler(new \Mongo("mongodb://localhost:27017"), "logs", "prod");
+ * $log->pushHandler($mongodb);
+ *
+ * @author Thomas Tourlourat
+ */
+class MongoDBHandler extends AbstractProcessingHandler
+{
+ protected $mongoCollection;
+
+ public function __construct($mongo, $database, $collection, $level = Logger::DEBUG, $bubble = true)
+ {
+ if (!($mongo instanceof \MongoClient || $mongo instanceof \Mongo || $mongo instanceof \MongoDB\Client)) {
+ throw new \InvalidArgumentException('MongoClient, Mongo or MongoDB\Client instance required');
+ }
+
+ $this->mongoCollection = $mongo->selectCollection($database, $collection);
+
+ parent::__construct($level, $bubble);
+ }
+
+ protected function write(array $record)
+ {
+ if ($this->mongoCollection instanceof \MongoDB\Collection) {
+ $this->mongoCollection->insertOne($record["formatted"]);
+ } else {
+ $this->mongoCollection->save($record["formatted"]);
+ }
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new NormalizerFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/NativeMailerHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/NativeMailerHandler.php
new file mode 100644
index 000000000..d7807fd11
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/NativeMailerHandler.php
@@ -0,0 +1,185 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Formatter\LineFormatter;
+
+/**
+ * NativeMailerHandler uses the mail() function to send the emails
+ *
+ * @author Christophe Coevoet
+ * @author Mark Garrett
+ */
+class NativeMailerHandler extends MailHandler
+{
+ /**
+ * The email addresses to which the message will be sent
+ * @var array
+ */
+ protected $to;
+
+ /**
+ * The subject of the email
+ * @var string
+ */
+ protected $subject;
+
+ /**
+ * Optional headers for the message
+ * @var array
+ */
+ protected $headers = array();
+
+ /**
+ * Optional parameters for the message
+ * @var array
+ */
+ protected $parameters = array();
+
+ /**
+ * The wordwrap length for the message
+ * @var int
+ */
+ protected $maxColumnWidth;
+
+ /**
+ * The Content-type for the message
+ * @var string
+ */
+ protected $contentType = 'text/plain';
+
+ /**
+ * The encoding for the message
+ * @var string
+ */
+ protected $encoding = 'utf-8';
+
+ /**
+ * @param string|array $to The receiver of the mail
+ * @param string $subject The subject of the mail
+ * @param string $from The sender of the mail
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param int $maxColumnWidth The maximum column width that the message lines will have
+ */
+ public function __construct($to, $subject, $from, $level = Logger::ERROR, $bubble = true, $maxColumnWidth = 70)
+ {
+ parent::__construct($level, $bubble);
+ $this->to = is_array($to) ? $to : array($to);
+ $this->subject = $subject;
+ $this->addHeader(sprintf('From: %s', $from));
+ $this->maxColumnWidth = $maxColumnWidth;
+ }
+
+ /**
+ * Add headers to the message
+ *
+ * @param string|array $headers Custom added headers
+ * @return self
+ */
+ public function addHeader($headers)
+ {
+ foreach ((array) $headers as $header) {
+ if (strpos($header, "\n") !== false || strpos($header, "\r") !== false) {
+ throw new \InvalidArgumentException('Headers can not contain newline characters for security reasons');
+ }
+ $this->headers[] = $header;
+ }
+
+ return $this;
+ }
+
+ /**
+ * Add parameters to the message
+ *
+ * @param string|array $parameters Custom added parameters
+ * @return self
+ */
+ public function addParameter($parameters)
+ {
+ $this->parameters = array_merge($this->parameters, (array) $parameters);
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function send($content, array $records)
+ {
+ $content = wordwrap($content, $this->maxColumnWidth);
+ $headers = ltrim(implode("\r\n", $this->headers) . "\r\n", "\r\n");
+ $headers .= 'Content-type: ' . $this->getContentType() . '; charset=' . $this->getEncoding() . "\r\n";
+ if ($this->getContentType() == 'text/html' && false === strpos($headers, 'MIME-Version:')) {
+ $headers .= 'MIME-Version: 1.0' . "\r\n";
+ }
+
+ $subject = $this->subject;
+ if ($records) {
+ $subjectFormatter = new LineFormatter($this->subject);
+ $subject = $subjectFormatter->format($this->getHighestRecord($records));
+ }
+
+ $parameters = implode(' ', $this->parameters);
+ foreach ($this->to as $to) {
+ mail($to, $subject, $content, $headers, $parameters);
+ }
+ }
+
+ /**
+ * @return string $contentType
+ */
+ public function getContentType()
+ {
+ return $this->contentType;
+ }
+
+ /**
+ * @return string $encoding
+ */
+ public function getEncoding()
+ {
+ return $this->encoding;
+ }
+
+ /**
+ * @param string $contentType The content type of the email - Defaults to text/plain. Use text/html for HTML
+ * messages.
+ * @return self
+ */
+ public function setContentType($contentType)
+ {
+ if (strpos($contentType, "\n") !== false || strpos($contentType, "\r") !== false) {
+ throw new \InvalidArgumentException('The content type can not contain newline characters to prevent email header injection');
+ }
+
+ $this->contentType = $contentType;
+
+ return $this;
+ }
+
+ /**
+ * @param string $encoding
+ * @return self
+ */
+ public function setEncoding($encoding)
+ {
+ if (strpos($encoding, "\n") !== false || strpos($encoding, "\r") !== false) {
+ throw new \InvalidArgumentException('The encoding can not contain newline characters to prevent email header injection');
+ }
+
+ $this->encoding = $encoding;
+
+ return $this;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/NewRelicHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/NewRelicHandler.php
new file mode 100644
index 000000000..64dc1381a
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/NewRelicHandler.php
@@ -0,0 +1,205 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Utils;
+use Monolog\Formatter\NormalizerFormatter;
+
+/**
+ * Class to record a log on a NewRelic application.
+ * Enabling New Relic High Security mode may prevent capture of useful information.
+ *
+ * This handler requires a NormalizerFormatter to function and expects an array in $record['formatted']
+ *
+ * @see https://docs.newrelic.com/docs/agents/php-agent
+ * @see https://docs.newrelic.com/docs/accounts-partnerships/accounts/security/high-security
+ */
+class NewRelicHandler extends AbstractProcessingHandler
+{
+ /**
+ * Name of the New Relic application that will receive logs from this handler.
+ *
+ * @var string
+ */
+ protected $appName;
+
+ /**
+ * Name of the current transaction
+ *
+ * @var string
+ */
+ protected $transactionName;
+
+ /**
+ * Some context and extra data is passed into the handler as arrays of values. Do we send them as is
+ * (useful if we are using the API), or explode them for display on the NewRelic RPM website?
+ *
+ * @var bool
+ */
+ protected $explodeArrays;
+
+ /**
+ * {@inheritDoc}
+ *
+ * @param string $appName
+ * @param bool $explodeArrays
+ * @param string $transactionName
+ */
+ public function __construct(
+ $level = Logger::ERROR,
+ $bubble = true,
+ $appName = null,
+ $explodeArrays = false,
+ $transactionName = null
+ ) {
+ parent::__construct($level, $bubble);
+
+ $this->appName = $appName;
+ $this->explodeArrays = $explodeArrays;
+ $this->transactionName = $transactionName;
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function write(array $record)
+ {
+ if (!$this->isNewRelicEnabled()) {
+ throw new MissingExtensionException('The newrelic PHP extension is required to use the NewRelicHandler');
+ }
+
+ if ($appName = $this->getAppName($record['context'])) {
+ $this->setNewRelicAppName($appName);
+ }
+
+ if ($transactionName = $this->getTransactionName($record['context'])) {
+ $this->setNewRelicTransactionName($transactionName);
+ unset($record['formatted']['context']['transaction_name']);
+ }
+
+ if (isset($record['context']['exception']) && ($record['context']['exception'] instanceof \Exception || (PHP_VERSION_ID >= 70000 && $record['context']['exception'] instanceof \Throwable))) {
+ newrelic_notice_error($record['message'], $record['context']['exception']);
+ unset($record['formatted']['context']['exception']);
+ } else {
+ newrelic_notice_error($record['message']);
+ }
+
+ if (isset($record['formatted']['context']) && is_array($record['formatted']['context'])) {
+ foreach ($record['formatted']['context'] as $key => $parameter) {
+ if (is_array($parameter) && $this->explodeArrays) {
+ foreach ($parameter as $paramKey => $paramValue) {
+ $this->setNewRelicParameter('context_' . $key . '_' . $paramKey, $paramValue);
+ }
+ } else {
+ $this->setNewRelicParameter('context_' . $key, $parameter);
+ }
+ }
+ }
+
+ if (isset($record['formatted']['extra']) && is_array($record['formatted']['extra'])) {
+ foreach ($record['formatted']['extra'] as $key => $parameter) {
+ if (is_array($parameter) && $this->explodeArrays) {
+ foreach ($parameter as $paramKey => $paramValue) {
+ $this->setNewRelicParameter('extra_' . $key . '_' . $paramKey, $paramValue);
+ }
+ } else {
+ $this->setNewRelicParameter('extra_' . $key, $parameter);
+ }
+ }
+ }
+ }
+
+ /**
+ * Checks whether the NewRelic extension is enabled in the system.
+ *
+ * @return bool
+ */
+ protected function isNewRelicEnabled()
+ {
+ return extension_loaded('newrelic');
+ }
+
+ /**
+ * Returns the appname where this log should be sent. Each log can override the default appname, set in this
+ * handler's constructor, by providing the appname in it's context.
+ *
+ * @param array $context
+ * @return null|string
+ */
+ protected function getAppName(array $context)
+ {
+ if (isset($context['appname'])) {
+ return $context['appname'];
+ }
+
+ return $this->appName;
+ }
+
+ /**
+ * Returns the name of the current transaction. Each log can override the default transaction name, set in this
+ * handler's constructor, by providing the transaction_name in it's context
+ *
+ * @param array $context
+ *
+ * @return null|string
+ */
+ protected function getTransactionName(array $context)
+ {
+ if (isset($context['transaction_name'])) {
+ return $context['transaction_name'];
+ }
+
+ return $this->transactionName;
+ }
+
+ /**
+ * Sets the NewRelic application that should receive this log.
+ *
+ * @param string $appName
+ */
+ protected function setNewRelicAppName($appName)
+ {
+ newrelic_set_appname($appName);
+ }
+
+ /**
+ * Overwrites the name of the current transaction
+ *
+ * @param string $transactionName
+ */
+ protected function setNewRelicTransactionName($transactionName)
+ {
+ newrelic_name_transaction($transactionName);
+ }
+
+ /**
+ * @param string $key
+ * @param mixed $value
+ */
+ protected function setNewRelicParameter($key, $value)
+ {
+ if (null === $value || is_scalar($value)) {
+ newrelic_add_custom_parameter($key, $value);
+ } else {
+ newrelic_add_custom_parameter($key, Utils::jsonEncode($value, null, true));
+ }
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new NormalizerFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/NullHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/NullHandler.php
new file mode 100644
index 000000000..4b8458833
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/NullHandler.php
@@ -0,0 +1,45 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+
+/**
+ * Blackhole
+ *
+ * Any record it can handle will be thrown away. This can be used
+ * to put on top of an existing stack to override it temporarily.
+ *
+ * @author Jordi Boggiano
+ */
+class NullHandler extends AbstractHandler
+{
+ /**
+ * @param int $level The minimum logging level at which this handler will be triggered
+ */
+ public function __construct($level = Logger::DEBUG)
+ {
+ parent::__construct($level, false);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handle(array $record)
+ {
+ if ($record['level'] < $this->level) {
+ return false;
+ }
+
+ return true;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/PHPConsoleHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/PHPConsoleHandler.php
new file mode 100644
index 000000000..d0a8b43e7
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/PHPConsoleHandler.php
@@ -0,0 +1,243 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Exception;
+use Monolog\Formatter\LineFormatter;
+use Monolog\Logger;
+use Monolog\Utils;
+use PhpConsole\Connector;
+use PhpConsole\Handler;
+use PhpConsole\Helper;
+
+/**
+ * Monolog handler for Google Chrome extension "PHP Console"
+ *
+ * Display PHP error/debug log messages in Google Chrome console and notification popups, executes PHP code remotely
+ *
+ * Usage:
+ * 1. Install Google Chrome extension https://chrome.google.com/webstore/detail/php-console/nfhmhhlpfleoednkpnnnkolmclajemef
+ * 2. See overview https://github.com/barbushin/php-console#overview
+ * 3. Install PHP Console library https://github.com/barbushin/php-console#installation
+ * 4. Example (result will looks like http://i.hizliresim.com/vg3Pz4.png)
+ *
+ * $logger = new \Monolog\Logger('all', array(new \Monolog\Handler\PHPConsoleHandler()));
+ * \Monolog\ErrorHandler::register($logger);
+ * echo $undefinedVar;
+ * $logger->addDebug('SELECT * FROM users', array('db', 'time' => 0.012));
+ * PC::debug($_SERVER); // PHP Console debugger for any type of vars
+ *
+ * @author Sergey Barbushin https://www.linkedin.com/in/barbushin
+ */
+class PHPConsoleHandler extends AbstractProcessingHandler
+{
+ private $options = array(
+ 'enabled' => true, // bool Is PHP Console server enabled
+ 'classesPartialsTraceIgnore' => array('Monolog\\'), // array Hide calls of classes started with...
+ 'debugTagsKeysInContext' => array(0, 'tag'), // bool Is PHP Console server enabled
+ 'useOwnErrorsHandler' => false, // bool Enable errors handling
+ 'useOwnExceptionsHandler' => false, // bool Enable exceptions handling
+ 'sourcesBasePath' => null, // string Base path of all project sources to strip in errors source paths
+ 'registerHelper' => true, // bool Register PhpConsole\Helper that allows short debug calls like PC::debug($var, 'ta.g.s')
+ 'serverEncoding' => null, // string|null Server internal encoding
+ 'headersLimit' => null, // int|null Set headers size limit for your web-server
+ 'password' => null, // string|null Protect PHP Console connection by password
+ 'enableSslOnlyMode' => false, // bool Force connection by SSL for clients with PHP Console installed
+ 'ipMasks' => array(), // array Set IP masks of clients that will be allowed to connect to PHP Console: array('192.168.*.*', '127.0.0.1')
+ 'enableEvalListener' => false, // bool Enable eval request to be handled by eval dispatcher(if enabled, 'password' option is also required)
+ 'dumperDetectCallbacks' => false, // bool Convert callback items in dumper vars to (callback SomeClass::someMethod) strings
+ 'dumperLevelLimit' => 5, // int Maximum dumped vars array or object nested dump level
+ 'dumperItemsCountLimit' => 100, // int Maximum dumped var same level array items or object properties number
+ 'dumperItemSizeLimit' => 5000, // int Maximum length of any string or dumped array item
+ 'dumperDumpSizeLimit' => 500000, // int Maximum approximate size of dumped vars result formatted in JSON
+ 'detectDumpTraceAndSource' => false, // bool Autodetect and append trace data to debug
+ 'dataStorage' => null, // PhpConsole\Storage|null Fixes problem with custom $_SESSION handler(see http://goo.gl/Ne8juJ)
+ );
+
+ /** @var Connector */
+ private $connector;
+
+ /**
+ * @param array $options See \Monolog\Handler\PHPConsoleHandler::$options for more details
+ * @param Connector|null $connector Instance of \PhpConsole\Connector class (optional)
+ * @param int $level
+ * @param bool $bubble
+ * @throws Exception
+ */
+ public function __construct(array $options = array(), Connector $connector = null, $level = Logger::DEBUG, $bubble = true)
+ {
+ if (!class_exists('PhpConsole\Connector')) {
+ throw new Exception('PHP Console library not found. See https://github.com/barbushin/php-console#installation');
+ }
+ parent::__construct($level, $bubble);
+ $this->options = $this->initOptions($options);
+ $this->connector = $this->initConnector($connector);
+ }
+
+ private function initOptions(array $options)
+ {
+ $wrongOptions = array_diff(array_keys($options), array_keys($this->options));
+ if ($wrongOptions) {
+ throw new Exception('Unknown options: ' . implode(', ', $wrongOptions));
+ }
+
+ return array_replace($this->options, $options);
+ }
+
+ private function initConnector(Connector $connector = null)
+ {
+ if (!$connector) {
+ if ($this->options['dataStorage']) {
+ Connector::setPostponeStorage($this->options['dataStorage']);
+ }
+ $connector = Connector::getInstance();
+ }
+
+ if ($this->options['registerHelper'] && !Helper::isRegistered()) {
+ Helper::register();
+ }
+
+ if ($this->options['enabled'] && $connector->isActiveClient()) {
+ if ($this->options['useOwnErrorsHandler'] || $this->options['useOwnExceptionsHandler']) {
+ $handler = Handler::getInstance();
+ $handler->setHandleErrors($this->options['useOwnErrorsHandler']);
+ $handler->setHandleExceptions($this->options['useOwnExceptionsHandler']);
+ $handler->start();
+ }
+ if ($this->options['sourcesBasePath']) {
+ $connector->setSourcesBasePath($this->options['sourcesBasePath']);
+ }
+ if ($this->options['serverEncoding']) {
+ $connector->setServerEncoding($this->options['serverEncoding']);
+ }
+ if ($this->options['password']) {
+ $connector->setPassword($this->options['password']);
+ }
+ if ($this->options['enableSslOnlyMode']) {
+ $connector->enableSslOnlyMode();
+ }
+ if ($this->options['ipMasks']) {
+ $connector->setAllowedIpMasks($this->options['ipMasks']);
+ }
+ if ($this->options['headersLimit']) {
+ $connector->setHeadersLimit($this->options['headersLimit']);
+ }
+ if ($this->options['detectDumpTraceAndSource']) {
+ $connector->getDebugDispatcher()->detectTraceAndSource = true;
+ }
+ $dumper = $connector->getDumper();
+ $dumper->levelLimit = $this->options['dumperLevelLimit'];
+ $dumper->itemsCountLimit = $this->options['dumperItemsCountLimit'];
+ $dumper->itemSizeLimit = $this->options['dumperItemSizeLimit'];
+ $dumper->dumpSizeLimit = $this->options['dumperDumpSizeLimit'];
+ $dumper->detectCallbacks = $this->options['dumperDetectCallbacks'];
+ if ($this->options['enableEvalListener']) {
+ $connector->startEvalRequestsListener();
+ }
+ }
+
+ return $connector;
+ }
+
+ public function getConnector()
+ {
+ return $this->connector;
+ }
+
+ public function getOptions()
+ {
+ return $this->options;
+ }
+
+ public function handle(array $record)
+ {
+ if ($this->options['enabled'] && $this->connector->isActiveClient()) {
+ return parent::handle($record);
+ }
+
+ return !$this->bubble;
+ }
+
+ /**
+ * Writes the record down to the log of the implementing handler
+ *
+ * @param array $record
+ * @return void
+ */
+ protected function write(array $record)
+ {
+ if ($record['level'] < Logger::NOTICE) {
+ $this->handleDebugRecord($record);
+ } elseif (isset($record['context']['exception']) && $record['context']['exception'] instanceof Exception) {
+ $this->handleExceptionRecord($record);
+ } else {
+ $this->handleErrorRecord($record);
+ }
+ }
+
+ private function handleDebugRecord(array $record)
+ {
+ $tags = $this->getRecordTags($record);
+ $message = $record['message'];
+ if ($record['context']) {
+ $message .= ' ' . Utils::jsonEncode($this->connector->getDumper()->dump(array_filter($record['context'])), null, true);
+ }
+ $this->connector->getDebugDispatcher()->dispatchDebug($message, $tags, $this->options['classesPartialsTraceIgnore']);
+ }
+
+ private function handleExceptionRecord(array $record)
+ {
+ $this->connector->getErrorsDispatcher()->dispatchException($record['context']['exception']);
+ }
+
+ private function handleErrorRecord(array $record)
+ {
+ $context = $record['context'];
+
+ $this->connector->getErrorsDispatcher()->dispatchError(
+ isset($context['code']) ? $context['code'] : null,
+ isset($context['message']) ? $context['message'] : $record['message'],
+ isset($context['file']) ? $context['file'] : null,
+ isset($context['line']) ? $context['line'] : null,
+ $this->options['classesPartialsTraceIgnore']
+ );
+ }
+
+ private function getRecordTags(array &$record)
+ {
+ $tags = null;
+ if (!empty($record['context'])) {
+ $context = & $record['context'];
+ foreach ($this->options['debugTagsKeysInContext'] as $key) {
+ if (!empty($context[$key])) {
+ $tags = $context[$key];
+ if ($key === 0) {
+ array_shift($context);
+ } else {
+ unset($context[$key]);
+ }
+ break;
+ }
+ }
+ }
+
+ return $tags ?: strtolower($record['level_name']);
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new LineFormatter('%message%');
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/ProcessableHandlerInterface.php b/vendor/monolog/monolog/src/Monolog/Handler/ProcessableHandlerInterface.php
new file mode 100644
index 000000000..66a3d83ae
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/ProcessableHandlerInterface.php
@@ -0,0 +1,40 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Processor\ProcessorInterface;
+
+/**
+ * Interface to describe loggers that have processors
+ *
+ * This interface is present in monolog 1.x to ease forward compatibility.
+ *
+ * @author Jordi Boggiano
+ */
+interface ProcessableHandlerInterface
+{
+ /**
+ * Adds a processor in the stack.
+ *
+ * @param ProcessorInterface|callable $callback
+ * @return HandlerInterface self
+ */
+ public function pushProcessor($callback): HandlerInterface;
+
+ /**
+ * Removes the processor on top of the stack and returns it.
+ *
+ * @throws \LogicException In case the processor stack is empty
+ * @return callable
+ */
+ public function popProcessor(): callable;
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/ProcessableHandlerTrait.php b/vendor/monolog/monolog/src/Monolog/Handler/ProcessableHandlerTrait.php
new file mode 100644
index 000000000..09f32a12c
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/ProcessableHandlerTrait.php
@@ -0,0 +1,73 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\ResettableInterface;
+
+/**
+ * Helper trait for implementing ProcessableInterface
+ *
+ * This trait is present in monolog 1.x to ease forward compatibility.
+ *
+ * @author Jordi Boggiano
+ */
+trait ProcessableHandlerTrait
+{
+ /**
+ * @var callable[]
+ */
+ protected $processors = [];
+
+ /**
+ * {@inheritdoc}
+ * @suppress PhanTypeMismatchReturn
+ */
+ public function pushProcessor($callback): HandlerInterface
+ {
+ array_unshift($this->processors, $callback);
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function popProcessor(): callable
+ {
+ if (!$this->processors) {
+ throw new \LogicException('You tried to pop from an empty processor stack.');
+ }
+
+ return array_shift($this->processors);
+ }
+
+ /**
+ * Processes a record.
+ */
+ protected function processRecord(array $record): array
+ {
+ foreach ($this->processors as $processor) {
+ $record = $processor($record);
+ }
+
+ return $record;
+ }
+
+ protected function resetProcessors(): void
+ {
+ foreach ($this->processors as $processor) {
+ if ($processor instanceof ResettableInterface) {
+ $processor->reset();
+ }
+ }
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/PsrHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/PsrHandler.php
new file mode 100644
index 000000000..a99e6ab71
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/PsrHandler.php
@@ -0,0 +1,56 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Psr\Log\LoggerInterface;
+
+/**
+ * Proxies log messages to an existing PSR-3 compliant logger.
+ *
+ * @author Michael Moussa
+ */
+class PsrHandler extends AbstractHandler
+{
+ /**
+ * PSR-3 compliant logger
+ *
+ * @var LoggerInterface
+ */
+ protected $logger;
+
+ /**
+ * @param LoggerInterface $logger The underlying PSR-3 compliant logger to which messages will be proxied
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct(LoggerInterface $logger, $level = Logger::DEBUG, $bubble = true)
+ {
+ parent::__construct($level, $bubble);
+
+ $this->logger = $logger;
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public function handle(array $record)
+ {
+ if (!$this->isHandling($record)) {
+ return false;
+ }
+
+ $this->logger->log(strtolower($record['level_name']), $record['message'], $record['context']);
+
+ return false === $this->bubble;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/PushoverHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/PushoverHandler.php
new file mode 100644
index 000000000..f27bb3da0
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/PushoverHandler.php
@@ -0,0 +1,185 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+
+/**
+ * Sends notifications through the pushover api to mobile phones
+ *
+ * @author Sebastian Göttschkes
+ * @see https://www.pushover.net/api
+ */
+class PushoverHandler extends SocketHandler
+{
+ private $token;
+ private $users;
+ private $title;
+ private $user;
+ private $retry;
+ private $expire;
+
+ private $highPriorityLevel;
+ private $emergencyLevel;
+ private $useFormattedMessage = false;
+
+ /**
+ * All parameters that can be sent to Pushover
+ * @see https://pushover.net/api
+ * @var array
+ */
+ private $parameterNames = array(
+ 'token' => true,
+ 'user' => true,
+ 'message' => true,
+ 'device' => true,
+ 'title' => true,
+ 'url' => true,
+ 'url_title' => true,
+ 'priority' => true,
+ 'timestamp' => true,
+ 'sound' => true,
+ 'retry' => true,
+ 'expire' => true,
+ 'callback' => true,
+ );
+
+ /**
+ * Sounds the api supports by default
+ * @see https://pushover.net/api#sounds
+ * @var array
+ */
+ private $sounds = array(
+ 'pushover', 'bike', 'bugle', 'cashregister', 'classical', 'cosmic', 'falling', 'gamelan', 'incoming',
+ 'intermission', 'magic', 'mechanical', 'pianobar', 'siren', 'spacealarm', 'tugboat', 'alien', 'climb',
+ 'persistent', 'echo', 'updown', 'none',
+ );
+
+ /**
+ * @param string $token Pushover api token
+ * @param string|array $users Pushover user id or array of ids the message will be sent to
+ * @param string $title Title sent to the Pushover API
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param bool $useSSL Whether to connect via SSL. Required when pushing messages to users that are not
+ * the pushover.net app owner. OpenSSL is required for this option.
+ * @param int $highPriorityLevel The minimum logging level at which this handler will start
+ * sending "high priority" requests to the Pushover API
+ * @param int $emergencyLevel The minimum logging level at which this handler will start
+ * sending "emergency" requests to the Pushover API
+ * @param int $retry The retry parameter specifies how often (in seconds) the Pushover servers will send the same notification to the user.
+ * @param int $expire The expire parameter specifies how many seconds your notification will continue to be retried for (every retry seconds).
+ */
+ public function __construct($token, $users, $title = null, $level = Logger::CRITICAL, $bubble = true, $useSSL = true, $highPriorityLevel = Logger::CRITICAL, $emergencyLevel = Logger::EMERGENCY, $retry = 30, $expire = 25200)
+ {
+ $connectionString = $useSSL ? 'ssl://api.pushover.net:443' : 'api.pushover.net:80';
+ parent::__construct($connectionString, $level, $bubble);
+
+ $this->token = $token;
+ $this->users = (array) $users;
+ $this->title = $title ?: gethostname();
+ $this->highPriorityLevel = Logger::toMonologLevel($highPriorityLevel);
+ $this->emergencyLevel = Logger::toMonologLevel($emergencyLevel);
+ $this->retry = $retry;
+ $this->expire = $expire;
+ }
+
+ protected function generateDataStream($record)
+ {
+ $content = $this->buildContent($record);
+
+ return $this->buildHeader($content) . $content;
+ }
+
+ private function buildContent($record)
+ {
+ // Pushover has a limit of 512 characters on title and message combined.
+ $maxMessageLength = 512 - strlen($this->title);
+
+ $message = ($this->useFormattedMessage) ? $record['formatted'] : $record['message'];
+ $message = substr($message, 0, $maxMessageLength);
+
+ $timestamp = $record['datetime']->getTimestamp();
+
+ $dataArray = array(
+ 'token' => $this->token,
+ 'user' => $this->user,
+ 'message' => $message,
+ 'title' => $this->title,
+ 'timestamp' => $timestamp,
+ );
+
+ if (isset($record['level']) && $record['level'] >= $this->emergencyLevel) {
+ $dataArray['priority'] = 2;
+ $dataArray['retry'] = $this->retry;
+ $dataArray['expire'] = $this->expire;
+ } elseif (isset($record['level']) && $record['level'] >= $this->highPriorityLevel) {
+ $dataArray['priority'] = 1;
+ }
+
+ // First determine the available parameters
+ $context = array_intersect_key($record['context'], $this->parameterNames);
+ $extra = array_intersect_key($record['extra'], $this->parameterNames);
+
+ // Least important info should be merged with subsequent info
+ $dataArray = array_merge($extra, $context, $dataArray);
+
+ // Only pass sounds that are supported by the API
+ if (isset($dataArray['sound']) && !in_array($dataArray['sound'], $this->sounds)) {
+ unset($dataArray['sound']);
+ }
+
+ return http_build_query($dataArray);
+ }
+
+ private function buildHeader($content)
+ {
+ $header = "POST /1/messages.json HTTP/1.1\r\n";
+ $header .= "Host: api.pushover.net\r\n";
+ $header .= "Content-Type: application/x-www-form-urlencoded\r\n";
+ $header .= "Content-Length: " . strlen($content) . "\r\n";
+ $header .= "\r\n";
+
+ return $header;
+ }
+
+ protected function write(array $record)
+ {
+ foreach ($this->users as $user) {
+ $this->user = $user;
+
+ parent::write($record);
+ $this->closeSocket();
+ }
+
+ $this->user = null;
+ }
+
+ public function setHighPriorityLevel($value)
+ {
+ $this->highPriorityLevel = $value;
+ }
+
+ public function setEmergencyLevel($value)
+ {
+ $this->emergencyLevel = $value;
+ }
+
+ /**
+ * Use the formatted message?
+ * @param bool $value
+ */
+ public function useFormattedMessage($value)
+ {
+ $this->useFormattedMessage = (bool) $value;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/RavenHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/RavenHandler.php
new file mode 100644
index 000000000..b0298fa6c
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/RavenHandler.php
@@ -0,0 +1,234 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\LineFormatter;
+use Monolog\Formatter\FormatterInterface;
+use Monolog\Logger;
+use Raven_Client;
+
+/**
+ * Handler to send messages to a Sentry (https://github.com/getsentry/sentry) server
+ * using sentry-php (https://github.com/getsentry/sentry-php)
+ *
+ * @author Marc Abramowitz
+ */
+class RavenHandler extends AbstractProcessingHandler
+{
+ /**
+ * Translates Monolog log levels to Raven log levels.
+ */
+ protected $logLevels = array(
+ Logger::DEBUG => Raven_Client::DEBUG,
+ Logger::INFO => Raven_Client::INFO,
+ Logger::NOTICE => Raven_Client::INFO,
+ Logger::WARNING => Raven_Client::WARNING,
+ Logger::ERROR => Raven_Client::ERROR,
+ Logger::CRITICAL => Raven_Client::FATAL,
+ Logger::ALERT => Raven_Client::FATAL,
+ Logger::EMERGENCY => Raven_Client::FATAL,
+ );
+
+ /**
+ * @var string should represent the current version of the calling
+ * software. Can be any string (git commit, version number)
+ */
+ protected $release;
+
+ /**
+ * @var Raven_Client the client object that sends the message to the server
+ */
+ protected $ravenClient;
+
+ /**
+ * @var FormatterInterface The formatter to use for the logs generated via handleBatch()
+ */
+ protected $batchFormatter;
+
+ /**
+ * @param Raven_Client $ravenClient
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct(Raven_Client $ravenClient, $level = Logger::DEBUG, $bubble = true)
+ {
+ @trigger_error('The Monolog\Handler\RavenHandler class is deprecated. You should rather upgrade to the sentry/sentry 2.x and use Sentry\Monolog\Handler, see https://github.com/getsentry/sentry-php/blob/master/src/Monolog/Handler.php', E_USER_DEPRECATED);
+
+ parent::__construct($level, $bubble);
+
+ $this->ravenClient = $ravenClient;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ $level = $this->level;
+
+ // filter records based on their level
+ $records = array_filter($records, function ($record) use ($level) {
+ return $record['level'] >= $level;
+ });
+
+ if (!$records) {
+ return;
+ }
+
+ // the record with the highest severity is the "main" one
+ $record = array_reduce($records, function ($highest, $record) {
+ if (null === $highest || $record['level'] > $highest['level']) {
+ return $record;
+ }
+
+ return $highest;
+ });
+
+ // the other ones are added as a context item
+ $logs = array();
+ foreach ($records as $r) {
+ $logs[] = $this->processRecord($r);
+ }
+
+ if ($logs) {
+ $record['context']['logs'] = (string) $this->getBatchFormatter()->formatBatch($logs);
+ }
+
+ $this->handle($record);
+ }
+
+ /**
+ * Sets the formatter for the logs generated by handleBatch().
+ *
+ * @param FormatterInterface $formatter
+ */
+ public function setBatchFormatter(FormatterInterface $formatter)
+ {
+ $this->batchFormatter = $formatter;
+ }
+
+ /**
+ * Gets the formatter for the logs generated by handleBatch().
+ *
+ * @return FormatterInterface
+ */
+ public function getBatchFormatter()
+ {
+ if (!$this->batchFormatter) {
+ $this->batchFormatter = $this->getDefaultBatchFormatter();
+ }
+
+ return $this->batchFormatter;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ $previousUserContext = false;
+ $options = array();
+ $options['level'] = $this->logLevels[$record['level']];
+ $options['tags'] = array();
+ if (!empty($record['extra']['tags'])) {
+ $options['tags'] = array_merge($options['tags'], $record['extra']['tags']);
+ unset($record['extra']['tags']);
+ }
+ if (!empty($record['context']['tags'])) {
+ $options['tags'] = array_merge($options['tags'], $record['context']['tags']);
+ unset($record['context']['tags']);
+ }
+ if (!empty($record['context']['fingerprint'])) {
+ $options['fingerprint'] = $record['context']['fingerprint'];
+ unset($record['context']['fingerprint']);
+ }
+ if (!empty($record['context']['logger'])) {
+ $options['logger'] = $record['context']['logger'];
+ unset($record['context']['logger']);
+ } else {
+ $options['logger'] = $record['channel'];
+ }
+ foreach ($this->getExtraParameters() as $key) {
+ foreach (array('extra', 'context') as $source) {
+ if (!empty($record[$source][$key])) {
+ $options[$key] = $record[$source][$key];
+ unset($record[$source][$key]);
+ }
+ }
+ }
+ if (!empty($record['context'])) {
+ $options['extra']['context'] = $record['context'];
+ if (!empty($record['context']['user'])) {
+ $previousUserContext = $this->ravenClient->context->user;
+ $this->ravenClient->user_context($record['context']['user']);
+ unset($options['extra']['context']['user']);
+ }
+ }
+ if (!empty($record['extra'])) {
+ $options['extra']['extra'] = $record['extra'];
+ }
+
+ if (!empty($this->release) && !isset($options['release'])) {
+ $options['release'] = $this->release;
+ }
+
+ if (isset($record['context']['exception']) && ($record['context']['exception'] instanceof \Exception || (PHP_VERSION_ID >= 70000 && $record['context']['exception'] instanceof \Throwable))) {
+ $options['message'] = $record['formatted'];
+ $this->ravenClient->captureException($record['context']['exception'], $options);
+ } else {
+ $this->ravenClient->captureMessage($record['formatted'], array(), $options);
+ }
+
+ if ($previousUserContext !== false) {
+ $this->ravenClient->user_context($previousUserContext);
+ }
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new LineFormatter('[%channel%] %message%');
+ }
+
+ /**
+ * Gets the default formatter for the logs generated by handleBatch().
+ *
+ * @return FormatterInterface
+ */
+ protected function getDefaultBatchFormatter()
+ {
+ return new LineFormatter();
+ }
+
+ /**
+ * Gets extra parameters supported by Raven that can be found in "extra" and "context"
+ *
+ * @return array
+ */
+ protected function getExtraParameters()
+ {
+ return array('contexts', 'checksum', 'release', 'event_id');
+ }
+
+ /**
+ * @param string $value
+ * @return self
+ */
+ public function setRelease($value)
+ {
+ $this->release = $value;
+
+ return $this;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/RedisHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/RedisHandler.php
new file mode 100644
index 000000000..3725db242
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/RedisHandler.php
@@ -0,0 +1,98 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\LineFormatter;
+use Monolog\Logger;
+
+/**
+ * Logs to a Redis key using rpush
+ *
+ * usage example:
+ *
+ * $log = new Logger('application');
+ * $redis = new RedisHandler(new Predis\Client("tcp://localhost:6379"), "logs", "prod");
+ * $log->pushHandler($redis);
+ *
+ * @author Thomas Tourlourat
+ */
+class RedisHandler extends AbstractProcessingHandler
+{
+ private $redisClient;
+ private $redisKey;
+ protected $capSize;
+
+ /**
+ * @param \Predis\Client|\Redis $redis The redis instance
+ * @param string $key The key name to push records to
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param int|false $capSize Number of entries to limit list size to
+ */
+ public function __construct($redis, $key, $level = Logger::DEBUG, $bubble = true, $capSize = false)
+ {
+ if (!(($redis instanceof \Predis\Client) || ($redis instanceof \Redis))) {
+ throw new \InvalidArgumentException('Predis\Client or Redis instance required');
+ }
+
+ $this->redisClient = $redis;
+ $this->redisKey = $key;
+ $this->capSize = $capSize;
+
+ parent::__construct($level, $bubble);
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function write(array $record)
+ {
+ if ($this->capSize) {
+ $this->writeCapped($record);
+ } else {
+ $this->redisClient->rpush($this->redisKey, $record["formatted"]);
+ }
+ }
+
+ /**
+ * Write and cap the collection
+ * Writes the record to the redis list and caps its
+ *
+ * @param array $record associative record array
+ * @return void
+ */
+ protected function writeCapped(array $record)
+ {
+ if ($this->redisClient instanceof \Redis) {
+ $mode = defined('\Redis::MULTI') ? \Redis::MULTI : 1;
+ $this->redisClient->multi($mode)
+ ->rpush($this->redisKey, $record["formatted"])
+ ->ltrim($this->redisKey, -$this->capSize, -1)
+ ->exec();
+ } else {
+ $redisKey = $this->redisKey;
+ $capSize = $this->capSize;
+ $this->redisClient->transaction(function ($tx) use ($record, $redisKey, $capSize) {
+ $tx->rpush($redisKey, $record["formatted"]);
+ $tx->ltrim($redisKey, -$capSize, -1);
+ });
+ }
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected function getDefaultFormatter()
+ {
+ return new LineFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/RollbarHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/RollbarHandler.php
new file mode 100644
index 000000000..65073ffe3
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/RollbarHandler.php
@@ -0,0 +1,144 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use RollbarNotifier;
+use Exception;
+use Monolog\Logger;
+
+/**
+ * Sends errors to Rollbar
+ *
+ * If the context data contains a `payload` key, that is used as an array
+ * of payload options to RollbarNotifier's report_message/report_exception methods.
+ *
+ * Rollbar's context info will contain the context + extra keys from the log record
+ * merged, and then on top of that a few keys:
+ *
+ * - level (rollbar level name)
+ * - monolog_level (monolog level name, raw level, as rollbar only has 5 but monolog 8)
+ * - channel
+ * - datetime (unix timestamp)
+ *
+ * @author Paul Statezny
+ */
+class RollbarHandler extends AbstractProcessingHandler
+{
+ /**
+ * Rollbar notifier
+ *
+ * @var RollbarNotifier
+ */
+ protected $rollbarNotifier;
+
+ protected $levelMap = array(
+ Logger::DEBUG => 'debug',
+ Logger::INFO => 'info',
+ Logger::NOTICE => 'info',
+ Logger::WARNING => 'warning',
+ Logger::ERROR => 'error',
+ Logger::CRITICAL => 'critical',
+ Logger::ALERT => 'critical',
+ Logger::EMERGENCY => 'critical',
+ );
+
+ /**
+ * Records whether any log records have been added since the last flush of the rollbar notifier
+ *
+ * @var bool
+ */
+ private $hasRecords = false;
+
+ protected $initialized = false;
+
+ /**
+ * @param RollbarNotifier $rollbarNotifier RollbarNotifier object constructed with valid token
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct(RollbarNotifier $rollbarNotifier, $level = Logger::ERROR, $bubble = true)
+ {
+ $this->rollbarNotifier = $rollbarNotifier;
+
+ parent::__construct($level, $bubble);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ if (!$this->initialized) {
+ // __destructor() doesn't get called on Fatal errors
+ register_shutdown_function(array($this, 'close'));
+ $this->initialized = true;
+ }
+
+ $context = $record['context'];
+ $payload = array();
+ if (isset($context['payload'])) {
+ $payload = $context['payload'];
+ unset($context['payload']);
+ }
+ $context = array_merge($context, $record['extra'], array(
+ 'level' => $this->levelMap[$record['level']],
+ 'monolog_level' => $record['level_name'],
+ 'channel' => $record['channel'],
+ 'datetime' => $record['datetime']->format('U'),
+ ));
+
+ if (isset($context['exception']) && $context['exception'] instanceof Exception) {
+ $payload['level'] = $context['level'];
+ $exception = $context['exception'];
+ unset($context['exception']);
+
+ $this->rollbarNotifier->report_exception($exception, $context, $payload);
+ } else {
+ $this->rollbarNotifier->report_message(
+ $record['message'],
+ $context['level'],
+ $context,
+ $payload
+ );
+ }
+
+ $this->hasRecords = true;
+ }
+
+ public function flush()
+ {
+ if ($this->hasRecords) {
+ $this->rollbarNotifier->flush();
+ $this->hasRecords = false;
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function close()
+ {
+ $this->flush();
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function reset()
+ {
+ $this->flush();
+
+ parent::reset();
+ }
+
+
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/RotatingFileHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/RotatingFileHandler.php
new file mode 100644
index 000000000..b8253ba0f
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/RotatingFileHandler.php
@@ -0,0 +1,191 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Utils;
+
+/**
+ * Stores logs to files that are rotated every day and a limited number of files are kept.
+ *
+ * This rotation is only intended to be used as a workaround. Using logrotate to
+ * handle the rotation is strongly encouraged when you can use it.
+ *
+ * @author Christophe Coevoet
+ * @author Jordi Boggiano
+ */
+class RotatingFileHandler extends StreamHandler
+{
+ const FILE_PER_DAY = 'Y-m-d';
+ const FILE_PER_MONTH = 'Y-m';
+ const FILE_PER_YEAR = 'Y';
+
+ protected $filename;
+ protected $maxFiles;
+ protected $mustRotate;
+ protected $nextRotation;
+ protected $filenameFormat;
+ protected $dateFormat;
+
+ /**
+ * @param string $filename
+ * @param int $maxFiles The maximal amount of files to keep (0 means unlimited)
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param int|null $filePermission Optional file permissions (default (0644) are only for owner read/write)
+ * @param bool $useLocking Try to lock log file before doing any writes
+ */
+ public function __construct($filename, $maxFiles = 0, $level = Logger::DEBUG, $bubble = true, $filePermission = null, $useLocking = false)
+ {
+ $this->filename = Utils::canonicalizePath($filename);
+ $this->maxFiles = (int) $maxFiles;
+ $this->nextRotation = new \DateTime('tomorrow');
+ $this->filenameFormat = '{filename}-{date}';
+ $this->dateFormat = 'Y-m-d';
+
+ parent::__construct($this->getTimedFilename(), $level, $bubble, $filePermission, $useLocking);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function close()
+ {
+ parent::close();
+
+ if (true === $this->mustRotate) {
+ $this->rotate();
+ }
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function reset()
+ {
+ parent::reset();
+
+ if (true === $this->mustRotate) {
+ $this->rotate();
+ }
+ }
+
+ public function setFilenameFormat($filenameFormat, $dateFormat)
+ {
+ if (!preg_match('{^Y(([/_.-]?m)([/_.-]?d)?)?$}', $dateFormat)) {
+ trigger_error(
+ 'Invalid date format - format must be one of '.
+ 'RotatingFileHandler::FILE_PER_DAY ("Y-m-d"), RotatingFileHandler::FILE_PER_MONTH ("Y-m") '.
+ 'or RotatingFileHandler::FILE_PER_YEAR ("Y"), or you can set one of the '.
+ 'date formats using slashes, underscores and/or dots instead of dashes.',
+ E_USER_DEPRECATED
+ );
+ }
+ if (substr_count($filenameFormat, '{date}') === 0) {
+ trigger_error(
+ 'Invalid filename format - format should contain at least `{date}`, because otherwise rotating is impossible.',
+ E_USER_DEPRECATED
+ );
+ }
+ $this->filenameFormat = $filenameFormat;
+ $this->dateFormat = $dateFormat;
+ $this->url = $this->getTimedFilename();
+ $this->close();
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ // on the first record written, if the log is new, we should rotate (once per day)
+ if (null === $this->mustRotate) {
+ $this->mustRotate = !file_exists($this->url);
+ }
+
+ if ($this->nextRotation < $record['datetime']) {
+ $this->mustRotate = true;
+ $this->close();
+ }
+
+ parent::write($record);
+ }
+
+ /**
+ * Rotates the files.
+ */
+ protected function rotate()
+ {
+ // update filename
+ $this->url = $this->getTimedFilename();
+ $this->nextRotation = new \DateTime('tomorrow');
+
+ // skip GC of old logs if files are unlimited
+ if (0 === $this->maxFiles) {
+ return;
+ }
+
+ $logFiles = glob($this->getGlobPattern());
+ if ($this->maxFiles >= count($logFiles)) {
+ // no files to remove
+ return;
+ }
+
+ // Sorting the files by name to remove the older ones
+ usort($logFiles, function ($a, $b) {
+ return strcmp($b, $a);
+ });
+
+ foreach (array_slice($logFiles, $this->maxFiles) as $file) {
+ if (is_writable($file)) {
+ // suppress errors here as unlink() might fail if two processes
+ // are cleaning up/rotating at the same time
+ set_error_handler(function ($errno, $errstr, $errfile, $errline) {});
+ unlink($file);
+ restore_error_handler();
+ }
+ }
+
+ $this->mustRotate = false;
+ }
+
+ protected function getTimedFilename()
+ {
+ $fileInfo = pathinfo($this->filename);
+ $timedFilename = str_replace(
+ array('{filename}', '{date}'),
+ array($fileInfo['filename'], date($this->dateFormat)),
+ $fileInfo['dirname'] . '/' . $this->filenameFormat
+ );
+
+ if (!empty($fileInfo['extension'])) {
+ $timedFilename .= '.'.$fileInfo['extension'];
+ }
+
+ return $timedFilename;
+ }
+
+ protected function getGlobPattern()
+ {
+ $fileInfo = pathinfo($this->filename);
+ $glob = str_replace(
+ array('{filename}', '{date}'),
+ array($fileInfo['filename'], '[0-9][0-9][0-9][0-9]*'),
+ $fileInfo['dirname'] . '/' . $this->filenameFormat
+ );
+ if (!empty($fileInfo['extension'])) {
+ $glob .= '.'.$fileInfo['extension'];
+ }
+
+ return $glob;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/SamplingHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/SamplingHandler.php
new file mode 100644
index 000000000..b547ed7da
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/SamplingHandler.php
@@ -0,0 +1,113 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\FormatterInterface;
+
+/**
+ * Sampling handler
+ *
+ * A sampled event stream can be useful for logging high frequency events in
+ * a production environment where you only need an idea of what is happening
+ * and are not concerned with capturing every occurrence. Since the decision to
+ * handle or not handle a particular event is determined randomly, the
+ * resulting sampled log is not guaranteed to contain 1/N of the events that
+ * occurred in the application, but based on the Law of large numbers, it will
+ * tend to be close to this ratio with a large number of attempts.
+ *
+ * @author Bryan Davis
+ * @author Kunal Mehta
+ */
+class SamplingHandler extends AbstractHandler
+{
+ /**
+ * @var callable|HandlerInterface $handler
+ */
+ protected $handler;
+
+ /**
+ * @var int $factor
+ */
+ protected $factor;
+
+ /**
+ * @param callable|HandlerInterface $handler Handler or factory callable($record|null, $samplingHandler).
+ * @param int $factor Sample factor
+ */
+ public function __construct($handler, $factor)
+ {
+ parent::__construct();
+ $this->handler = $handler;
+ $this->factor = $factor;
+
+ if (!$this->handler instanceof HandlerInterface && !is_callable($this->handler)) {
+ throw new \RuntimeException("The given handler (".json_encode($this->handler).") is not a callable nor a Monolog\Handler\HandlerInterface object");
+ }
+ }
+
+ public function isHandling(array $record)
+ {
+ return $this->getHandler($record)->isHandling($record);
+ }
+
+ public function handle(array $record)
+ {
+ if ($this->isHandling($record) && mt_rand(1, $this->factor) === 1) {
+ if ($this->processors) {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+ }
+
+ $this->getHandler($record)->handle($record);
+ }
+
+ return false === $this->bubble;
+ }
+
+ /**
+ * Return the nested handler
+ *
+ * If the handler was provided as a factory callable, this will trigger the handler's instantiation.
+ *
+ * @return HandlerInterface
+ */
+ public function getHandler(array $record = null)
+ {
+ if (!$this->handler instanceof HandlerInterface) {
+ $this->handler = call_user_func($this->handler, $record, $this);
+ if (!$this->handler instanceof HandlerInterface) {
+ throw new \RuntimeException("The factory callable should return a HandlerInterface");
+ }
+ }
+
+ return $this->handler;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ $this->getHandler()->setFormatter($formatter);
+
+ return $this;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function getFormatter()
+ {
+ return $this->getHandler()->getFormatter();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/Slack/SlackRecord.php b/vendor/monolog/monolog/src/Monolog/Handler/Slack/SlackRecord.php
new file mode 100644
index 000000000..39455501f
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/Slack/SlackRecord.php
@@ -0,0 +1,299 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler\Slack;
+
+use Monolog\Logger;
+use Monolog\Utils;
+use Monolog\Formatter\NormalizerFormatter;
+use Monolog\Formatter\FormatterInterface;
+
+/**
+ * Slack record utility helping to log to Slack webhooks or API.
+ *
+ * @author Greg Kedzierski
+ * @author Haralan Dobrev
+ * @see https://api.slack.com/incoming-webhooks
+ * @see https://api.slack.com/docs/message-attachments
+ */
+class SlackRecord
+{
+ const COLOR_DANGER = 'danger';
+
+ const COLOR_WARNING = 'warning';
+
+ const COLOR_GOOD = 'good';
+
+ const COLOR_DEFAULT = '#e3e4e6';
+
+ /**
+ * Slack channel (encoded ID or name)
+ * @var string|null
+ */
+ private $channel;
+
+ /**
+ * Name of a bot
+ * @var string|null
+ */
+ private $username;
+
+ /**
+ * User icon e.g. 'ghost', 'http://example.com/user.png'
+ * @var string
+ */
+ private $userIcon;
+
+ /**
+ * Whether the message should be added to Slack as attachment (plain text otherwise)
+ * @var bool
+ */
+ private $useAttachment;
+
+ /**
+ * Whether the the context/extra messages added to Slack as attachments are in a short style
+ * @var bool
+ */
+ private $useShortAttachment;
+
+ /**
+ * Whether the attachment should include context and extra data
+ * @var bool
+ */
+ private $includeContextAndExtra;
+
+ /**
+ * Dot separated list of fields to exclude from slack message. E.g. ['context.field1', 'extra.field2']
+ * @var array
+ */
+ private $excludeFields;
+
+ /**
+ * @var FormatterInterface
+ */
+ private $formatter;
+
+ /**
+ * @var NormalizerFormatter
+ */
+ private $normalizerFormatter;
+
+ public function __construct($channel = null, $username = null, $useAttachment = true, $userIcon = null, $useShortAttachment = false, $includeContextAndExtra = false, array $excludeFields = array(), FormatterInterface $formatter = null)
+ {
+ $this->channel = $channel;
+ $this->username = $username;
+ $this->userIcon = trim($userIcon, ':');
+ $this->useAttachment = $useAttachment;
+ $this->useShortAttachment = $useShortAttachment;
+ $this->includeContextAndExtra = $includeContextAndExtra;
+ $this->excludeFields = $excludeFields;
+ $this->formatter = $formatter;
+
+ if ($this->includeContextAndExtra) {
+ $this->normalizerFormatter = new NormalizerFormatter();
+ }
+ }
+
+ public function getSlackData(array $record)
+ {
+ $dataArray = array();
+ $record = $this->excludeFields($record);
+
+ if ($this->username) {
+ $dataArray['username'] = $this->username;
+ }
+
+ if ($this->channel) {
+ $dataArray['channel'] = $this->channel;
+ }
+
+ if ($this->formatter && !$this->useAttachment) {
+ $message = $this->formatter->format($record);
+ } else {
+ $message = $record['message'];
+ }
+
+ if ($this->useAttachment) {
+ $attachment = array(
+ 'fallback' => $message,
+ 'text' => $message,
+ 'color' => $this->getAttachmentColor($record['level']),
+ 'fields' => array(),
+ 'mrkdwn_in' => array('fields'),
+ 'ts' => $record['datetime']->getTimestamp()
+ );
+
+ if ($this->useShortAttachment) {
+ $attachment['title'] = $record['level_name'];
+ } else {
+ $attachment['title'] = 'Message';
+ $attachment['fields'][] = $this->generateAttachmentField('Level', $record['level_name']);
+ }
+
+
+ if ($this->includeContextAndExtra) {
+ foreach (array('extra', 'context') as $key) {
+ if (empty($record[$key])) {
+ continue;
+ }
+
+ if ($this->useShortAttachment) {
+ $attachment['fields'][] = $this->generateAttachmentField(
+ $key,
+ $record[$key]
+ );
+ } else {
+ // Add all extra fields as individual fields in attachment
+ $attachment['fields'] = array_merge(
+ $attachment['fields'],
+ $this->generateAttachmentFields($record[$key])
+ );
+ }
+ }
+ }
+
+ $dataArray['attachments'] = array($attachment);
+ } else {
+ $dataArray['text'] = $message;
+ }
+
+ if ($this->userIcon) {
+ if (filter_var($this->userIcon, FILTER_VALIDATE_URL)) {
+ $dataArray['icon_url'] = $this->userIcon;
+ } else {
+ $dataArray['icon_emoji'] = ":{$this->userIcon}:";
+ }
+ }
+
+ return $dataArray;
+ }
+
+ /**
+ * Returned a Slack message attachment color associated with
+ * provided level.
+ *
+ * @param int $level
+ * @return string
+ */
+ public function getAttachmentColor($level)
+ {
+ switch (true) {
+ case $level >= Logger::ERROR:
+ return self::COLOR_DANGER;
+ case $level >= Logger::WARNING:
+ return self::COLOR_WARNING;
+ case $level >= Logger::INFO:
+ return self::COLOR_GOOD;
+ default:
+ return self::COLOR_DEFAULT;
+ }
+ }
+
+ /**
+ * Stringifies an array of key/value pairs to be used in attachment fields
+ *
+ * @param array $fields
+ *
+ * @return string
+ */
+ public function stringify($fields)
+ {
+ $normalized = $this->normalizerFormatter->format($fields);
+ $prettyPrintFlag = defined('JSON_PRETTY_PRINT') ? JSON_PRETTY_PRINT : 128;
+ $flags = 0;
+ if (PHP_VERSION_ID >= 50400) {
+ $flags = JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE;
+ }
+
+ $hasSecondDimension = count(array_filter($normalized, 'is_array'));
+ $hasNonNumericKeys = !count(array_filter(array_keys($normalized), 'is_numeric'));
+
+ return $hasSecondDimension || $hasNonNumericKeys
+ ? Utils::jsonEncode($normalized, $prettyPrintFlag | $flags)
+ : Utils::jsonEncode($normalized, $flags);
+ }
+
+ /**
+ * Sets the formatter
+ *
+ * @param FormatterInterface $formatter
+ */
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ $this->formatter = $formatter;
+ }
+
+ /**
+ * Generates attachment field
+ *
+ * @param string $title
+ * @param string|array $value
+ *
+ * @return array
+ */
+ private function generateAttachmentField($title, $value)
+ {
+ $value = is_array($value)
+ ? sprintf('```%s```', $this->stringify($value))
+ : $value;
+
+ return array(
+ 'title' => ucfirst($title),
+ 'value' => $value,
+ 'short' => false
+ );
+ }
+
+ /**
+ * Generates a collection of attachment fields from array
+ *
+ * @param array $data
+ *
+ * @return array
+ */
+ private function generateAttachmentFields(array $data)
+ {
+ $fields = array();
+ foreach ($this->normalizerFormatter->format($data) as $key => $value) {
+ $fields[] = $this->generateAttachmentField($key, $value);
+ }
+
+ return $fields;
+ }
+
+ /**
+ * Get a copy of record with fields excluded according to $this->excludeFields
+ *
+ * @param array $record
+ *
+ * @return array
+ */
+ private function excludeFields(array $record)
+ {
+ foreach ($this->excludeFields as $field) {
+ $keys = explode('.', $field);
+ $node = &$record;
+ $lastKey = end($keys);
+ foreach ($keys as $key) {
+ if (!isset($node[$key])) {
+ break;
+ }
+ if ($lastKey === $key) {
+ unset($node[$key]);
+ break;
+ }
+ $node = &$node[$key];
+ }
+ }
+
+ return $record;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/SlackHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/SlackHandler.php
new file mode 100644
index 000000000..88c4c4d00
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/SlackHandler.php
@@ -0,0 +1,221 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\FormatterInterface;
+use Monolog\Logger;
+use Monolog\Utils;
+use Monolog\Handler\Slack\SlackRecord;
+
+/**
+ * Sends notifications through Slack API
+ *
+ * @author Greg Kedzierski
+ * @see https://api.slack.com/
+ */
+class SlackHandler extends SocketHandler
+{
+ /**
+ * Slack API token
+ * @var string
+ */
+ private $token;
+
+ /**
+ * Instance of the SlackRecord util class preparing data for Slack API.
+ * @var SlackRecord
+ */
+ private $slackRecord;
+
+ /**
+ * @param string $token Slack API token
+ * @param string $channel Slack channel (encoded ID or name)
+ * @param string|null $username Name of a bot
+ * @param bool $useAttachment Whether the message should be added to Slack as attachment (plain text otherwise)
+ * @param string|null $iconEmoji The emoji name to use (or null)
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param bool $useShortAttachment Whether the the context/extra messages added to Slack as attachments are in a short style
+ * @param bool $includeContextAndExtra Whether the attachment should include context and extra data
+ * @param array $excludeFields Dot separated list of fields to exclude from slack message. E.g. ['context.field1', 'extra.field2']
+ * @throws MissingExtensionException If no OpenSSL PHP extension configured
+ */
+ public function __construct($token, $channel, $username = null, $useAttachment = true, $iconEmoji = null, $level = Logger::CRITICAL, $bubble = true, $useShortAttachment = false, $includeContextAndExtra = false, array $excludeFields = array())
+ {
+ if (!extension_loaded('openssl')) {
+ throw new MissingExtensionException('The OpenSSL PHP extension is required to use the SlackHandler');
+ }
+
+ parent::__construct('ssl://slack.com:443', $level, $bubble);
+
+ $this->slackRecord = new SlackRecord(
+ $channel,
+ $username,
+ $useAttachment,
+ $iconEmoji,
+ $useShortAttachment,
+ $includeContextAndExtra,
+ $excludeFields,
+ $this->formatter
+ );
+
+ $this->token = $token;
+ }
+
+ public function getSlackRecord()
+ {
+ return $this->slackRecord;
+ }
+
+ public function getToken()
+ {
+ return $this->token;
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ * @return string
+ */
+ protected function generateDataStream($record)
+ {
+ $content = $this->buildContent($record);
+
+ return $this->buildHeader($content) . $content;
+ }
+
+ /**
+ * Builds the body of API call
+ *
+ * @param array $record
+ * @return string
+ */
+ private function buildContent($record)
+ {
+ $dataArray = $this->prepareContentData($record);
+
+ return http_build_query($dataArray);
+ }
+
+ /**
+ * Prepares content data
+ *
+ * @param array $record
+ * @return array
+ */
+ protected function prepareContentData($record)
+ {
+ $dataArray = $this->slackRecord->getSlackData($record);
+ $dataArray['token'] = $this->token;
+
+ if (!empty($dataArray['attachments'])) {
+ $dataArray['attachments'] = Utils::jsonEncode($dataArray['attachments']);
+ }
+
+ return $dataArray;
+ }
+
+ /**
+ * Builds the header of the API Call
+ *
+ * @param string $content
+ * @return string
+ */
+ private function buildHeader($content)
+ {
+ $header = "POST /api/chat.postMessage HTTP/1.1\r\n";
+ $header .= "Host: slack.com\r\n";
+ $header .= "Content-Type: application/x-www-form-urlencoded\r\n";
+ $header .= "Content-Length: " . strlen($content) . "\r\n";
+ $header .= "\r\n";
+
+ return $header;
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ */
+ protected function write(array $record)
+ {
+ parent::write($record);
+ $this->finalizeWrite();
+ }
+
+ /**
+ * Finalizes the request by reading some bytes and then closing the socket
+ *
+ * If we do not read some but close the socket too early, slack sometimes
+ * drops the request entirely.
+ */
+ protected function finalizeWrite()
+ {
+ $res = $this->getResource();
+ if (is_resource($res)) {
+ @fread($res, 2048);
+ }
+ $this->closeSocket();
+ }
+
+ /**
+ * Returned a Slack message attachment color associated with
+ * provided level.
+ *
+ * @param int $level
+ * @return string
+ * @deprecated Use underlying SlackRecord instead
+ */
+ protected function getAttachmentColor($level)
+ {
+ trigger_error(
+ 'SlackHandler::getAttachmentColor() is deprecated. Use underlying SlackRecord instead.',
+ E_USER_DEPRECATED
+ );
+
+ return $this->slackRecord->getAttachmentColor($level);
+ }
+
+ /**
+ * Stringifies an array of key/value pairs to be used in attachment fields
+ *
+ * @param array $fields
+ * @return string
+ * @deprecated Use underlying SlackRecord instead
+ */
+ protected function stringify($fields)
+ {
+ trigger_error(
+ 'SlackHandler::stringify() is deprecated. Use underlying SlackRecord instead.',
+ E_USER_DEPRECATED
+ );
+
+ return $this->slackRecord->stringify($fields);
+ }
+
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ parent::setFormatter($formatter);
+ $this->slackRecord->setFormatter($formatter);
+
+ return $this;
+ }
+
+ public function getFormatter()
+ {
+ $formatter = parent::getFormatter();
+ $this->slackRecord->setFormatter($formatter);
+
+ return $formatter;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/SlackWebhookHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/SlackWebhookHandler.php
new file mode 100644
index 000000000..b87be99a8
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/SlackWebhookHandler.php
@@ -0,0 +1,121 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\FormatterInterface;
+use Monolog\Logger;
+use Monolog\Utils;
+use Monolog\Handler\Slack\SlackRecord;
+
+/**
+ * Sends notifications through Slack Webhooks
+ *
+ * @author Haralan Dobrev
+ * @see https://api.slack.com/incoming-webhooks
+ */
+class SlackWebhookHandler extends AbstractProcessingHandler
+{
+ /**
+ * Slack Webhook token
+ * @var string
+ */
+ private $webhookUrl;
+
+ /**
+ * Instance of the SlackRecord util class preparing data for Slack API.
+ * @var SlackRecord
+ */
+ private $slackRecord;
+
+ /**
+ * @param string $webhookUrl Slack Webhook URL
+ * @param string|null $channel Slack channel (encoded ID or name)
+ * @param string|null $username Name of a bot
+ * @param bool $useAttachment Whether the message should be added to Slack as attachment (plain text otherwise)
+ * @param string|null $iconEmoji The emoji name to use (or null)
+ * @param bool $useShortAttachment Whether the the context/extra messages added to Slack as attachments are in a short style
+ * @param bool $includeContextAndExtra Whether the attachment should include context and extra data
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param array $excludeFields Dot separated list of fields to exclude from slack message. E.g. ['context.field1', 'extra.field2']
+ */
+ public function __construct($webhookUrl, $channel = null, $username = null, $useAttachment = true, $iconEmoji = null, $useShortAttachment = false, $includeContextAndExtra = false, $level = Logger::CRITICAL, $bubble = true, array $excludeFields = array())
+ {
+ parent::__construct($level, $bubble);
+
+ $this->webhookUrl = $webhookUrl;
+
+ $this->slackRecord = new SlackRecord(
+ $channel,
+ $username,
+ $useAttachment,
+ $iconEmoji,
+ $useShortAttachment,
+ $includeContextAndExtra,
+ $excludeFields,
+ $this->formatter
+ );
+ }
+
+ public function getSlackRecord()
+ {
+ return $this->slackRecord;
+ }
+
+ public function getWebhookUrl()
+ {
+ return $this->webhookUrl;
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ */
+ protected function write(array $record)
+ {
+ $postData = $this->slackRecord->getSlackData($record);
+ $postString = Utils::jsonEncode($postData);
+
+ $ch = curl_init();
+ $options = array(
+ CURLOPT_URL => $this->webhookUrl,
+ CURLOPT_POST => true,
+ CURLOPT_RETURNTRANSFER => true,
+ CURLOPT_HTTPHEADER => array('Content-type: application/json'),
+ CURLOPT_POSTFIELDS => $postString
+ );
+ if (defined('CURLOPT_SAFE_UPLOAD')) {
+ $options[CURLOPT_SAFE_UPLOAD] = true;
+ }
+
+ curl_setopt_array($ch, $options);
+
+ Curl\Util::execute($ch);
+ }
+
+ public function setFormatter(FormatterInterface $formatter)
+ {
+ parent::setFormatter($formatter);
+ $this->slackRecord->setFormatter($formatter);
+
+ return $this;
+ }
+
+ public function getFormatter()
+ {
+ $formatter = parent::getFormatter();
+ $this->slackRecord->setFormatter($formatter);
+
+ return $formatter;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/SlackbotHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/SlackbotHandler.php
new file mode 100644
index 000000000..d3352ea0f
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/SlackbotHandler.php
@@ -0,0 +1,84 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+
+/**
+ * Sends notifications through Slack's Slackbot
+ *
+ * @author Haralan Dobrev
+ * @see https://slack.com/apps/A0F81R8ET-slackbot
+ * @deprecated According to Slack the API used on this handler it is deprecated.
+ * Therefore this handler will be removed on 2.x
+ * Slack suggests to use webhooks instead. Please contact slack for more information.
+ */
+class SlackbotHandler extends AbstractProcessingHandler
+{
+ /**
+ * The slug of the Slack team
+ * @var string
+ */
+ private $slackTeam;
+
+ /**
+ * Slackbot token
+ * @var string
+ */
+ private $token;
+
+ /**
+ * Slack channel name
+ * @var string
+ */
+ private $channel;
+
+ /**
+ * @param string $slackTeam Slack team slug
+ * @param string $token Slackbot token
+ * @param string $channel Slack channel (encoded ID or name)
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct($slackTeam, $token, $channel, $level = Logger::CRITICAL, $bubble = true)
+ {
+ @trigger_error('SlackbotHandler is deprecated and will be removed on 2.x', E_USER_DEPRECATED);
+ parent::__construct($level, $bubble);
+
+ $this->slackTeam = $slackTeam;
+ $this->token = $token;
+ $this->channel = $channel;
+ }
+
+ /**
+ * {@inheritdoc}
+ *
+ * @param array $record
+ */
+ protected function write(array $record)
+ {
+ $slackbotUrl = sprintf(
+ 'https://%s.slack.com/services/hooks/slackbot?token=%s&channel=%s',
+ $this->slackTeam,
+ $this->token,
+ $this->channel
+ );
+
+ $ch = curl_init();
+ curl_setopt($ch, CURLOPT_URL, $slackbotUrl);
+ curl_setopt($ch, CURLOPT_POST, true);
+ curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
+ curl_setopt($ch, CURLOPT_POSTFIELDS, $record['message']);
+
+ Curl\Util::execute($ch);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/SocketHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/SocketHandler.php
new file mode 100644
index 000000000..db50d97fe
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/SocketHandler.php
@@ -0,0 +1,385 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+
+/**
+ * Stores to any socket - uses fsockopen() or pfsockopen().
+ *
+ * @author Pablo de Leon Belloc
+ * @see http://php.net/manual/en/function.fsockopen.php
+ */
+class SocketHandler extends AbstractProcessingHandler
+{
+ private $connectionString;
+ private $connectionTimeout;
+ private $resource;
+ private $timeout = 0;
+ private $writingTimeout = 10;
+ private $lastSentBytes = null;
+ private $chunkSize = null;
+ private $persistent = false;
+ private $errno;
+ private $errstr;
+ private $lastWritingAt;
+
+ /**
+ * @param string $connectionString Socket connection string
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct($connectionString, $level = Logger::DEBUG, $bubble = true)
+ {
+ parent::__construct($level, $bubble);
+ $this->connectionString = $connectionString;
+ $this->connectionTimeout = (float) ini_get('default_socket_timeout');
+ }
+
+ /**
+ * Connect (if necessary) and write to the socket
+ *
+ * @param array $record
+ *
+ * @throws \UnexpectedValueException
+ * @throws \RuntimeException
+ */
+ protected function write(array $record)
+ {
+ $this->connectIfNotConnected();
+ $data = $this->generateDataStream($record);
+ $this->writeToSocket($data);
+ }
+
+ /**
+ * We will not close a PersistentSocket instance so it can be reused in other requests.
+ */
+ public function close()
+ {
+ if (!$this->isPersistent()) {
+ $this->closeSocket();
+ }
+ }
+
+ /**
+ * Close socket, if open
+ */
+ public function closeSocket()
+ {
+ if (is_resource($this->resource)) {
+ fclose($this->resource);
+ $this->resource = null;
+ }
+ }
+
+ /**
+ * Set socket connection to nbe persistent. It only has effect before the connection is initiated.
+ *
+ * @param bool $persistent
+ */
+ public function setPersistent($persistent)
+ {
+ $this->persistent = (bool) $persistent;
+ }
+
+ /**
+ * Set connection timeout. Only has effect before we connect.
+ *
+ * @param float $seconds
+ *
+ * @see http://php.net/manual/en/function.fsockopen.php
+ */
+ public function setConnectionTimeout($seconds)
+ {
+ $this->validateTimeout($seconds);
+ $this->connectionTimeout = (float) $seconds;
+ }
+
+ /**
+ * Set write timeout. Only has effect before we connect.
+ *
+ * @param float $seconds
+ *
+ * @see http://php.net/manual/en/function.stream-set-timeout.php
+ */
+ public function setTimeout($seconds)
+ {
+ $this->validateTimeout($seconds);
+ $this->timeout = (float) $seconds;
+ }
+
+ /**
+ * Set writing timeout. Only has effect during connection in the writing cycle.
+ *
+ * @param float $seconds 0 for no timeout
+ */
+ public function setWritingTimeout($seconds)
+ {
+ $this->validateTimeout($seconds);
+ $this->writingTimeout = (float) $seconds;
+ }
+
+ /**
+ * Set chunk size. Only has effect during connection in the writing cycle.
+ *
+ * @param float $bytes
+ */
+ public function setChunkSize($bytes)
+ {
+ $this->chunkSize = $bytes;
+ }
+
+ /**
+ * Get current connection string
+ *
+ * @return string
+ */
+ public function getConnectionString()
+ {
+ return $this->connectionString;
+ }
+
+ /**
+ * Get persistent setting
+ *
+ * @return bool
+ */
+ public function isPersistent()
+ {
+ return $this->persistent;
+ }
+
+ /**
+ * Get current connection timeout setting
+ *
+ * @return float
+ */
+ public function getConnectionTimeout()
+ {
+ return $this->connectionTimeout;
+ }
+
+ /**
+ * Get current in-transfer timeout
+ *
+ * @return float
+ */
+ public function getTimeout()
+ {
+ return $this->timeout;
+ }
+
+ /**
+ * Get current local writing timeout
+ *
+ * @return float
+ */
+ public function getWritingTimeout()
+ {
+ return $this->writingTimeout;
+ }
+
+ /**
+ * Get current chunk size
+ *
+ * @return float
+ */
+ public function getChunkSize()
+ {
+ return $this->chunkSize;
+ }
+
+ /**
+ * Check to see if the socket is currently available.
+ *
+ * UDP might appear to be connected but might fail when writing. See http://php.net/fsockopen for details.
+ *
+ * @return bool
+ */
+ public function isConnected()
+ {
+ return is_resource($this->resource)
+ && !feof($this->resource); // on TCP - other party can close connection.
+ }
+
+ /**
+ * Wrapper to allow mocking
+ */
+ protected function pfsockopen()
+ {
+ return @pfsockopen($this->connectionString, -1, $this->errno, $this->errstr, $this->connectionTimeout);
+ }
+
+ /**
+ * Wrapper to allow mocking
+ */
+ protected function fsockopen()
+ {
+ return @fsockopen($this->connectionString, -1, $this->errno, $this->errstr, $this->connectionTimeout);
+ }
+
+ /**
+ * Wrapper to allow mocking
+ *
+ * @see http://php.net/manual/en/function.stream-set-timeout.php
+ */
+ protected function streamSetTimeout()
+ {
+ $seconds = floor($this->timeout);
+ $microseconds = round(($this->timeout - $seconds) * 1e6);
+
+ return stream_set_timeout($this->resource, $seconds, $microseconds);
+ }
+
+ /**
+ * Wrapper to allow mocking
+ *
+ * @see http://php.net/manual/en/function.stream-set-chunk-size.php
+ */
+ protected function streamSetChunkSize()
+ {
+ return stream_set_chunk_size($this->resource, $this->chunkSize);
+ }
+
+ /**
+ * Wrapper to allow mocking
+ */
+ protected function fwrite($data)
+ {
+ return @fwrite($this->resource, $data);
+ }
+
+ /**
+ * Wrapper to allow mocking
+ */
+ protected function streamGetMetadata()
+ {
+ return stream_get_meta_data($this->resource);
+ }
+
+ private function validateTimeout($value)
+ {
+ $ok = filter_var($value, FILTER_VALIDATE_FLOAT);
+ if ($ok === false || $value < 0) {
+ throw new \InvalidArgumentException("Timeout must be 0 or a positive float (got $value)");
+ }
+ }
+
+ private function connectIfNotConnected()
+ {
+ if ($this->isConnected()) {
+ return;
+ }
+ $this->connect();
+ }
+
+ protected function generateDataStream($record)
+ {
+ return (string) $record['formatted'];
+ }
+
+ /**
+ * @return resource|null
+ */
+ protected function getResource()
+ {
+ return $this->resource;
+ }
+
+ private function connect()
+ {
+ $this->createSocketResource();
+ $this->setSocketTimeout();
+ $this->setStreamChunkSize();
+ }
+
+ private function createSocketResource()
+ {
+ if ($this->isPersistent()) {
+ $resource = $this->pfsockopen();
+ } else {
+ $resource = $this->fsockopen();
+ }
+ if (!$resource) {
+ throw new \UnexpectedValueException("Failed connecting to $this->connectionString ($this->errno: $this->errstr)");
+ }
+ $this->resource = $resource;
+ }
+
+ private function setSocketTimeout()
+ {
+ if (!$this->streamSetTimeout()) {
+ throw new \UnexpectedValueException("Failed setting timeout with stream_set_timeout()");
+ }
+ }
+
+ private function setStreamChunkSize()
+ {
+ if ($this->chunkSize && !$this->streamSetChunkSize()) {
+ throw new \UnexpectedValueException("Failed setting chunk size with stream_set_chunk_size()");
+ }
+ }
+
+ private function writeToSocket($data)
+ {
+ $length = strlen($data);
+ $sent = 0;
+ $this->lastSentBytes = $sent;
+ while ($this->isConnected() && $sent < $length) {
+ if (0 == $sent) {
+ $chunk = $this->fwrite($data);
+ } else {
+ $chunk = $this->fwrite(substr($data, $sent));
+ }
+ if ($chunk === false) {
+ throw new \RuntimeException("Could not write to socket");
+ }
+ $sent += $chunk;
+ $socketInfo = $this->streamGetMetadata();
+ if ($socketInfo['timed_out']) {
+ throw new \RuntimeException("Write timed-out");
+ }
+
+ if ($this->writingIsTimedOut($sent)) {
+ throw new \RuntimeException("Write timed-out, no data sent for `{$this->writingTimeout}` seconds, probably we got disconnected (sent $sent of $length)");
+ }
+ }
+ if (!$this->isConnected() && $sent < $length) {
+ throw new \RuntimeException("End-of-file reached, probably we got disconnected (sent $sent of $length)");
+ }
+ }
+
+ private function writingIsTimedOut($sent)
+ {
+ $writingTimeout = (int) floor($this->writingTimeout);
+ if (0 === $writingTimeout) {
+ return false;
+ }
+
+ if ($sent !== $this->lastSentBytes) {
+ $this->lastWritingAt = time();
+ $this->lastSentBytes = $sent;
+
+ return false;
+ } else {
+ usleep(100);
+ }
+
+ if ((time() - $this->lastWritingAt) >= $writingTimeout) {
+ $this->closeSocket();
+
+ return true;
+ }
+
+ return false;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/StreamHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/StreamHandler.php
new file mode 100644
index 000000000..74a613cb1
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/StreamHandler.php
@@ -0,0 +1,194 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Utils;
+
+/**
+ * Stores to any stream resource
+ *
+ * Can be used to store into php://stderr, remote and local files, etc.
+ *
+ * @author Jordi Boggiano
+ */
+class StreamHandler extends AbstractProcessingHandler
+{
+ /** @private 512KB */
+ const CHUNK_SIZE = 524288;
+
+ /** @var resource|null */
+ protected $stream;
+ protected $url;
+ private $errorMessage;
+ protected $filePermission;
+ protected $useLocking;
+ private $dirCreated;
+
+ /**
+ * @param resource|string $stream
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param int|null $filePermission Optional file permissions (default (0644) are only for owner read/write)
+ * @param bool $useLocking Try to lock log file before doing any writes
+ *
+ * @throws \Exception If a missing directory is not buildable
+ * @throws \InvalidArgumentException If stream is not a resource or string
+ */
+ public function __construct($stream, $level = Logger::DEBUG, $bubble = true, $filePermission = null, $useLocking = false)
+ {
+ parent::__construct($level, $bubble);
+ if (is_resource($stream)) {
+ $this->stream = $stream;
+ $this->streamSetChunkSize();
+ } elseif (is_string($stream)) {
+ $this->url = Utils::canonicalizePath($stream);
+ } else {
+ throw new \InvalidArgumentException('A stream must either be a resource or a string.');
+ }
+
+ $this->filePermission = $filePermission;
+ $this->useLocking = $useLocking;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function close()
+ {
+ if ($this->url && is_resource($this->stream)) {
+ fclose($this->stream);
+ }
+ $this->stream = null;
+ $this->dirCreated = null;
+ }
+
+ /**
+ * Return the currently active stream if it is open
+ *
+ * @return resource|null
+ */
+ public function getStream()
+ {
+ return $this->stream;
+ }
+
+ /**
+ * Return the stream URL if it was configured with a URL and not an active resource
+ *
+ * @return string|null
+ */
+ public function getUrl()
+ {
+ return $this->url;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ if (!is_resource($this->stream)) {
+ if (null === $this->url || '' === $this->url) {
+ throw new \LogicException('Missing stream url, the stream can not be opened. This may be caused by a premature call to close().');
+ }
+ $this->createDir();
+ $this->errorMessage = null;
+ set_error_handler(array($this, 'customErrorHandler'));
+ $this->stream = fopen($this->url, 'a');
+ if ($this->filePermission !== null) {
+ @chmod($this->url, $this->filePermission);
+ }
+ restore_error_handler();
+ if (!is_resource($this->stream)) {
+ $this->stream = null;
+
+ throw new \UnexpectedValueException(sprintf('The stream or file "%s" could not be opened in append mode: '.$this->errorMessage, $this->url));
+ }
+ $this->streamSetChunkSize();
+ }
+
+ if ($this->useLocking) {
+ // ignoring errors here, there's not much we can do about them
+ flock($this->stream, LOCK_EX);
+ }
+
+ $this->streamWrite($this->stream, $record);
+
+ if ($this->useLocking) {
+ flock($this->stream, LOCK_UN);
+ }
+ }
+
+ /**
+ * Write to stream
+ * @param resource $stream
+ * @param array $record
+ */
+ protected function streamWrite($stream, array $record)
+ {
+ fwrite($stream, (string) $record['formatted']);
+ }
+
+ protected function streamSetChunkSize()
+ {
+ if (version_compare(PHP_VERSION, '5.4.0', '>=')) {
+ return stream_set_chunk_size($this->stream, self::CHUNK_SIZE);
+ }
+
+ return false;
+ }
+
+ private function customErrorHandler($code, $msg)
+ {
+ $this->errorMessage = preg_replace('{^(fopen|mkdir)\(.*?\): }', '', $msg);
+ }
+
+ /**
+ * @param string $stream
+ *
+ * @return null|string
+ */
+ private function getDirFromStream($stream)
+ {
+ $pos = strpos($stream, '://');
+ if ($pos === false) {
+ return dirname($stream);
+ }
+
+ if ('file://' === substr($stream, 0, 7)) {
+ return dirname(substr($stream, 7));
+ }
+
+ return null;
+ }
+
+ private function createDir()
+ {
+ // Do not try to create dir if it has already been tried.
+ if ($this->dirCreated) {
+ return;
+ }
+
+ $dir = $this->getDirFromStream($this->url);
+ if (null !== $dir && !is_dir($dir)) {
+ $this->errorMessage = null;
+ set_error_handler(array($this, 'customErrorHandler'));
+ $status = mkdir($dir, 0777, true);
+ restore_error_handler();
+ if (false === $status && !is_dir($dir)) {
+ throw new \UnexpectedValueException(sprintf('There is no existing directory at "%s" and its not buildable: '.$this->errorMessage, $dir));
+ }
+ }
+ $this->dirCreated = true;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/SwiftMailerHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/SwiftMailerHandler.php
new file mode 100644
index 000000000..ac7b16ff8
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/SwiftMailerHandler.php
@@ -0,0 +1,111 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Formatter\FormatterInterface;
+use Monolog\Formatter\LineFormatter;
+use Swift;
+
+/**
+ * SwiftMailerHandler uses Swift_Mailer to send the emails
+ *
+ * @author Gyula Sallai
+ */
+class SwiftMailerHandler extends MailHandler
+{
+ protected $mailer;
+ private $messageTemplate;
+
+ /**
+ * @param \Swift_Mailer $mailer The mailer to use
+ * @param callable|\Swift_Message $message An example message for real messages, only the body will be replaced
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ */
+ public function __construct(\Swift_Mailer $mailer, $message, $level = Logger::ERROR, $bubble = true)
+ {
+ parent::__construct($level, $bubble);
+
+ $this->mailer = $mailer;
+ $this->messageTemplate = $message;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function send($content, array $records)
+ {
+ $this->mailer->send($this->buildMessage($content, $records));
+ }
+
+ /**
+ * Gets the formatter for the Swift_Message subject.
+ *
+ * @param string $format The format of the subject
+ * @return FormatterInterface
+ */
+ protected function getSubjectFormatter($format)
+ {
+ return new LineFormatter($format);
+ }
+
+ /**
+ * Creates instance of Swift_Message to be sent
+ *
+ * @param string $content formatted email body to be sent
+ * @param array $records Log records that formed the content
+ * @return \Swift_Message
+ */
+ protected function buildMessage($content, array $records)
+ {
+ $message = null;
+ if ($this->messageTemplate instanceof \Swift_Message) {
+ $message = clone $this->messageTemplate;
+ $message->generateId();
+ } elseif (is_callable($this->messageTemplate)) {
+ $message = call_user_func($this->messageTemplate, $content, $records);
+ }
+
+ if (!$message instanceof \Swift_Message) {
+ throw new \InvalidArgumentException('Could not resolve message as instance of Swift_Message or a callable returning it');
+ }
+
+ if ($records) {
+ $subjectFormatter = $this->getSubjectFormatter($message->getSubject());
+ $message->setSubject($subjectFormatter->format($this->getHighestRecord($records)));
+ }
+
+ $message->setBody($content);
+ if (version_compare(Swift::VERSION, '6.0.0', '>=')) {
+ $message->setDate(new \DateTimeImmutable());
+ } else {
+ $message->setDate(time());
+ }
+
+ return $message;
+ }
+
+ /**
+ * BC getter, to be removed in 2.0
+ */
+ public function __get($name)
+ {
+ if ($name === 'message') {
+ trigger_error('SwiftMailerHandler->message is deprecated, use ->buildMessage() instead to retrieve the message', E_USER_DEPRECATED);
+
+ return $this->buildMessage(null, array());
+ }
+
+ throw new \InvalidArgumentException('Invalid property '.$name);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/SyslogHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/SyslogHandler.php
new file mode 100644
index 000000000..f770c8028
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/SyslogHandler.php
@@ -0,0 +1,67 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+
+/**
+ * Logs to syslog service.
+ *
+ * usage example:
+ *
+ * $log = new Logger('application');
+ * $syslog = new SyslogHandler('myfacility', 'local6');
+ * $formatter = new LineFormatter("%channel%.%level_name%: %message% %extra%");
+ * $syslog->setFormatter($formatter);
+ * $log->pushHandler($syslog);
+ *
+ * @author Sven Paulus
+ */
+class SyslogHandler extends AbstractSyslogHandler
+{
+ protected $ident;
+ protected $logopts;
+
+ /**
+ * @param string $ident
+ * @param mixed $facility
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param int $logopts Option flags for the openlog() call, defaults to LOG_PID
+ */
+ public function __construct($ident, $facility = LOG_USER, $level = Logger::DEBUG, $bubble = true, $logopts = LOG_PID)
+ {
+ parent::__construct($facility, $level, $bubble);
+
+ $this->ident = $ident;
+ $this->logopts = $logopts;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function close()
+ {
+ closelog();
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ if (!openlog($this->ident, $this->logopts, $this->facility)) {
+ throw new \LogicException('Can\'t open syslog for ident "'.$this->ident.'" and facility "'.$this->facility.'"');
+ }
+ syslog($this->logLevels[$record['level']], (string) $record['formatted']);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/SyslogUdp/UdpSocket.php b/vendor/monolog/monolog/src/Monolog/Handler/SyslogUdp/UdpSocket.php
new file mode 100644
index 000000000..3bff085bf
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/SyslogUdp/UdpSocket.php
@@ -0,0 +1,56 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler\SyslogUdp;
+
+class UdpSocket
+{
+ const DATAGRAM_MAX_LENGTH = 65023;
+
+ protected $ip;
+ protected $port;
+ protected $socket;
+
+ public function __construct($ip, $port = 514)
+ {
+ $this->ip = $ip;
+ $this->port = $port;
+ $this->socket = socket_create(AF_INET, SOCK_DGRAM, SOL_UDP);
+ }
+
+ public function write($line, $header = "")
+ {
+ $this->send($this->assembleMessage($line, $header));
+ }
+
+ public function close()
+ {
+ if (is_resource($this->socket)) {
+ socket_close($this->socket);
+ $this->socket = null;
+ }
+ }
+
+ protected function send($chunk)
+ {
+ if (!is_resource($this->socket)) {
+ throw new \LogicException('The UdpSocket to '.$this->ip.':'.$this->port.' has been closed and can not be written to anymore');
+ }
+ socket_sendto($this->socket, $chunk, strlen($chunk), $flags = 0, $this->ip, $this->port);
+ }
+
+ protected function assembleMessage($line, $header)
+ {
+ $chunkSize = self::DATAGRAM_MAX_LENGTH - strlen($header);
+
+ return $header . substr($line, 0, $chunkSize);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/SyslogUdpHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/SyslogUdpHandler.php
new file mode 100644
index 000000000..4dfd5f5ec
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/SyslogUdpHandler.php
@@ -0,0 +1,124 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Logger;
+use Monolog\Handler\SyslogUdp\UdpSocket;
+
+/**
+ * A Handler for logging to a remote syslogd server.
+ *
+ * @author Jesper Skovgaard Nielsen
+ * @author Dominik Kukacka
+ */
+class SyslogUdpHandler extends AbstractSyslogHandler
+{
+ const RFC3164 = 0;
+ const RFC5424 = 1;
+
+ private $dateFormats = array(
+ self::RFC3164 => 'M d H:i:s',
+ self::RFC5424 => \DateTime::RFC3339,
+ );
+
+ protected $socket;
+ protected $ident;
+ protected $rfc;
+
+ /**
+ * @param string $host
+ * @param int $port
+ * @param mixed $facility
+ * @param int $level The minimum logging level at which this handler will be triggered
+ * @param bool $bubble Whether the messages that are handled can bubble up the stack or not
+ * @param string $ident Program name or tag for each log message.
+ * @param int $rfc RFC to format the message for.
+ */
+ public function __construct($host, $port = 514, $facility = LOG_USER, $level = Logger::DEBUG, $bubble = true, $ident = 'php', $rfc = self::RFC5424)
+ {
+ parent::__construct($facility, $level, $bubble);
+
+ $this->ident = $ident;
+ $this->rfc = $rfc;
+
+ $this->socket = new UdpSocket($host, $port ?: 514);
+ }
+
+ protected function write(array $record)
+ {
+ $lines = $this->splitMessageIntoLines($record['formatted']);
+
+ $header = $this->makeCommonSyslogHeader($this->logLevels[$record['level']]);
+
+ foreach ($lines as $line) {
+ $this->socket->write($line, $header);
+ }
+ }
+
+ public function close()
+ {
+ $this->socket->close();
+ }
+
+ private function splitMessageIntoLines($message)
+ {
+ if (is_array($message)) {
+ $message = implode("\n", $message);
+ }
+
+ return preg_split('/$\R?^/m', $message, -1, PREG_SPLIT_NO_EMPTY);
+ }
+
+ /**
+ * Make common syslog header (see rfc5424 or rfc3164)
+ */
+ protected function makeCommonSyslogHeader($severity)
+ {
+ $priority = $severity + $this->facility;
+
+ if (!$pid = getmypid()) {
+ $pid = '-';
+ }
+
+ if (!$hostname = gethostname()) {
+ $hostname = '-';
+ }
+
+ $date = $this->getDateTime();
+
+ if ($this->rfc === self::RFC3164) {
+ return "<$priority>" .
+ $date . " " .
+ $hostname . " " .
+ $this->ident . "[" . $pid . "]: ";
+ } else {
+ return "<$priority>1 " .
+ $date . " " .
+ $hostname . " " .
+ $this->ident . " " .
+ $pid . " - - ";
+ }
+ }
+
+ protected function getDateTime()
+ {
+ return date($this->dateFormats[$this->rfc]);
+ }
+
+ /**
+ * Inject your own socket, mainly used for testing
+ */
+ public function setSocket($socket)
+ {
+ $this->socket = $socket;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/TestHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/TestHandler.php
new file mode 100644
index 000000000..478db0ac0
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/TestHandler.php
@@ -0,0 +1,177 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+/**
+ * Used for testing purposes.
+ *
+ * It records all records and gives you access to them for verification.
+ *
+ * @author Jordi Boggiano
+ *
+ * @method bool hasEmergency($record)
+ * @method bool hasAlert($record)
+ * @method bool hasCritical($record)
+ * @method bool hasError($record)
+ * @method bool hasWarning($record)
+ * @method bool hasNotice($record)
+ * @method bool hasInfo($record)
+ * @method bool hasDebug($record)
+ *
+ * @method bool hasEmergencyRecords()
+ * @method bool hasAlertRecords()
+ * @method bool hasCriticalRecords()
+ * @method bool hasErrorRecords()
+ * @method bool hasWarningRecords()
+ * @method bool hasNoticeRecords()
+ * @method bool hasInfoRecords()
+ * @method bool hasDebugRecords()
+ *
+ * @method bool hasEmergencyThatContains($message)
+ * @method bool hasAlertThatContains($message)
+ * @method bool hasCriticalThatContains($message)
+ * @method bool hasErrorThatContains($message)
+ * @method bool hasWarningThatContains($message)
+ * @method bool hasNoticeThatContains($message)
+ * @method bool hasInfoThatContains($message)
+ * @method bool hasDebugThatContains($message)
+ *
+ * @method bool hasEmergencyThatMatches($message)
+ * @method bool hasAlertThatMatches($message)
+ * @method bool hasCriticalThatMatches($message)
+ * @method bool hasErrorThatMatches($message)
+ * @method bool hasWarningThatMatches($message)
+ * @method bool hasNoticeThatMatches($message)
+ * @method bool hasInfoThatMatches($message)
+ * @method bool hasDebugThatMatches($message)
+ *
+ * @method bool hasEmergencyThatPasses($message)
+ * @method bool hasAlertThatPasses($message)
+ * @method bool hasCriticalThatPasses($message)
+ * @method bool hasErrorThatPasses($message)
+ * @method bool hasWarningThatPasses($message)
+ * @method bool hasNoticeThatPasses($message)
+ * @method bool hasInfoThatPasses($message)
+ * @method bool hasDebugThatPasses($message)
+ */
+class TestHandler extends AbstractProcessingHandler
+{
+ protected $records = array();
+ protected $recordsByLevel = array();
+ private $skipReset = false;
+
+ public function getRecords()
+ {
+ return $this->records;
+ }
+
+ public function clear()
+ {
+ $this->records = array();
+ $this->recordsByLevel = array();
+ }
+
+ public function reset()
+ {
+ if (!$this->skipReset) {
+ $this->clear();
+ }
+ }
+
+ public function setSkipReset($skipReset)
+ {
+ $this->skipReset = $skipReset;
+ }
+
+ public function hasRecords($level)
+ {
+ return isset($this->recordsByLevel[$level]);
+ }
+
+ /**
+ * @param string|array $record Either a message string or an array containing message and optionally context keys that will be checked against all records
+ * @param int $level Logger::LEVEL constant value
+ */
+ public function hasRecord($record, $level)
+ {
+ if (is_string($record)) {
+ $record = array('message' => $record);
+ }
+
+ return $this->hasRecordThatPasses(function ($rec) use ($record) {
+ if ($rec['message'] !== $record['message']) {
+ return false;
+ }
+ if (isset($record['context']) && $rec['context'] !== $record['context']) {
+ return false;
+ }
+ return true;
+ }, $level);
+ }
+
+ public function hasRecordThatContains($message, $level)
+ {
+ return $this->hasRecordThatPasses(function ($rec) use ($message) {
+ return strpos($rec['message'], $message) !== false;
+ }, $level);
+ }
+
+ public function hasRecordThatMatches($regex, $level)
+ {
+ return $this->hasRecordThatPasses(function ($rec) use ($regex) {
+ return preg_match($regex, $rec['message']) > 0;
+ }, $level);
+ }
+
+ public function hasRecordThatPasses($predicate, $level)
+ {
+ if (!is_callable($predicate)) {
+ throw new \InvalidArgumentException("Expected a callable for hasRecordThatSucceeds");
+ }
+
+ if (!isset($this->recordsByLevel[$level])) {
+ return false;
+ }
+
+ foreach ($this->recordsByLevel[$level] as $i => $rec) {
+ if (call_user_func($predicate, $rec, $i)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ $this->recordsByLevel[$record['level']][] = $record;
+ $this->records[] = $record;
+ }
+
+ public function __call($method, $args)
+ {
+ if (preg_match('/(.*)(Debug|Info|Notice|Warning|Error|Critical|Alert|Emergency)(.*)/', $method, $matches) > 0) {
+ $genericMethod = $matches[1] . ('Records' !== $matches[3] ? 'Record' : '') . $matches[3];
+ $level = constant('Monolog\Logger::' . strtoupper($matches[2]));
+ if (method_exists($this, $genericMethod)) {
+ $args[] = $level;
+
+ return call_user_func_array(array($this, $genericMethod), $args);
+ }
+ }
+
+ throw new \BadMethodCallException('Call to undefined method ' . get_class($this) . '::' . $method . '()');
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/WhatFailureGroupHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/WhatFailureGroupHandler.php
new file mode 100644
index 000000000..7d7622a39
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/WhatFailureGroupHandler.php
@@ -0,0 +1,72 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+/**
+ * Forwards records to multiple handlers suppressing failures of each handler
+ * and continuing through to give every handler a chance to succeed.
+ *
+ * @author Craig D'Amelio
+ */
+class WhatFailureGroupHandler extends GroupHandler
+{
+ /**
+ * {@inheritdoc}
+ */
+ public function handle(array $record)
+ {
+ if ($this->processors) {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+ }
+
+ foreach ($this->handlers as $handler) {
+ try {
+ $handler->handle($record);
+ } catch (\Exception $e) {
+ // What failure?
+ } catch (\Throwable $e) {
+ // What failure?
+ }
+ }
+
+ return false === $this->bubble;
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function handleBatch(array $records)
+ {
+ if ($this->processors) {
+ $processed = array();
+ foreach ($records as $record) {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+ $processed[] = $record;
+ }
+ $records = $processed;
+ }
+
+ foreach ($this->handlers as $handler) {
+ try {
+ $handler->handleBatch($records);
+ } catch (\Exception $e) {
+ // What failure?
+ } catch (\Throwable $e) {
+ // What failure?
+ }
+ }
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Handler/ZendMonitorHandler.php b/vendor/monolog/monolog/src/Monolog/Handler/ZendMonitorHandler.php
new file mode 100644
index 000000000..a20aeae01
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Handler/ZendMonitorHandler.php
@@ -0,0 +1,101 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Handler;
+
+use Monolog\Formatter\NormalizerFormatter;
+use Monolog\Logger;
+
+/**
+ * Handler sending logs to Zend Monitor
+ *
+ * @author Christian Bergau
+ * @author Jason Davis
+ */
+class ZendMonitorHandler extends AbstractProcessingHandler
+{
+ /**
+ * Monolog level / ZendMonitor Custom Event priority map
+ *
+ * @var array
+ */
+ protected $levelMap = array();
+
+ /**
+ * Construct
+ *
+ * @param int $level
+ * @param bool $bubble
+ * @throws MissingExtensionException
+ */
+ public function __construct($level = Logger::DEBUG, $bubble = true)
+ {
+ if (!function_exists('zend_monitor_custom_event')) {
+ throw new MissingExtensionException(
+ 'You must have Zend Server installed with Zend Monitor enabled in order to use this handler'
+ );
+ }
+ //zend monitor constants are not defined if zend monitor is not enabled.
+ $this->levelMap = array(
+ Logger::DEBUG => \ZEND_MONITOR_EVENT_SEVERITY_INFO,
+ Logger::INFO => \ZEND_MONITOR_EVENT_SEVERITY_INFO,
+ Logger::NOTICE => \ZEND_MONITOR_EVENT_SEVERITY_INFO,
+ Logger::WARNING => \ZEND_MONITOR_EVENT_SEVERITY_WARNING,
+ Logger::ERROR => \ZEND_MONITOR_EVENT_SEVERITY_ERROR,
+ Logger::CRITICAL => \ZEND_MONITOR_EVENT_SEVERITY_ERROR,
+ Logger::ALERT => \ZEND_MONITOR_EVENT_SEVERITY_ERROR,
+ Logger::EMERGENCY => \ZEND_MONITOR_EVENT_SEVERITY_ERROR,
+ );
+ parent::__construct($level, $bubble);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ protected function write(array $record)
+ {
+ $this->writeZendMonitorCustomEvent(
+ Logger::getLevelName($record['level']),
+ $record['message'],
+ $record['formatted'],
+ $this->levelMap[$record['level']]
+ );
+ }
+
+ /**
+ * Write to Zend Monitor Events
+ * @param string $type Text displayed in "Class Name (custom)" field
+ * @param string $message Text displayed in "Error String"
+ * @param mixed $formatted Displayed in Custom Variables tab
+ * @param int $severity Set the event severity level (-1,0,1)
+ */
+ protected function writeZendMonitorCustomEvent($type, $message, $formatted, $severity)
+ {
+ zend_monitor_custom_event($type, $message, $formatted, $severity);
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function getDefaultFormatter()
+ {
+ return new NormalizerFormatter();
+ }
+
+ /**
+ * Get the level map
+ *
+ * @return array
+ */
+ public function getLevelMap()
+ {
+ return $this->levelMap;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Logger.php b/vendor/monolog/monolog/src/Monolog/Logger.php
new file mode 100644
index 000000000..7d26b2916
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Logger.php
@@ -0,0 +1,796 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog;
+
+use Monolog\Handler\HandlerInterface;
+use Monolog\Handler\StreamHandler;
+use Psr\Log\LoggerInterface;
+use Psr\Log\InvalidArgumentException;
+use Exception;
+
+/**
+ * Monolog log channel
+ *
+ * It contains a stack of Handlers and a stack of Processors,
+ * and uses them to store records that are added to it.
+ *
+ * @author Jordi Boggiano
+ */
+class Logger implements LoggerInterface, ResettableInterface
+{
+ /**
+ * Detailed debug information
+ */
+ const DEBUG = 100;
+
+ /**
+ * Interesting events
+ *
+ * Examples: User logs in, SQL logs.
+ */
+ const INFO = 200;
+
+ /**
+ * Uncommon events
+ */
+ const NOTICE = 250;
+
+ /**
+ * Exceptional occurrences that are not errors
+ *
+ * Examples: Use of deprecated APIs, poor use of an API,
+ * undesirable things that are not necessarily wrong.
+ */
+ const WARNING = 300;
+
+ /**
+ * Runtime errors
+ */
+ const ERROR = 400;
+
+ /**
+ * Critical conditions
+ *
+ * Example: Application component unavailable, unexpected exception.
+ */
+ const CRITICAL = 500;
+
+ /**
+ * Action must be taken immediately
+ *
+ * Example: Entire website down, database unavailable, etc.
+ * This should trigger the SMS alerts and wake you up.
+ */
+ const ALERT = 550;
+
+ /**
+ * Urgent alert.
+ */
+ const EMERGENCY = 600;
+
+ /**
+ * Monolog API version
+ *
+ * This is only bumped when API breaks are done and should
+ * follow the major version of the library
+ *
+ * @var int
+ */
+ const API = 1;
+
+ /**
+ * Logging levels from syslog protocol defined in RFC 5424
+ *
+ * @var array $levels Logging levels
+ */
+ protected static $levels = array(
+ self::DEBUG => 'DEBUG',
+ self::INFO => 'INFO',
+ self::NOTICE => 'NOTICE',
+ self::WARNING => 'WARNING',
+ self::ERROR => 'ERROR',
+ self::CRITICAL => 'CRITICAL',
+ self::ALERT => 'ALERT',
+ self::EMERGENCY => 'EMERGENCY',
+ );
+
+ /**
+ * @var \DateTimeZone
+ */
+ protected static $timezone;
+
+ /**
+ * @var string
+ */
+ protected $name;
+
+ /**
+ * The handler stack
+ *
+ * @var HandlerInterface[]
+ */
+ protected $handlers;
+
+ /**
+ * Processors that will process all log records
+ *
+ * To process records of a single handler instead, add the processor on that specific handler
+ *
+ * @var callable[]
+ */
+ protected $processors;
+
+ /**
+ * @var bool
+ */
+ protected $microsecondTimestamps = true;
+
+ /**
+ * @var callable
+ */
+ protected $exceptionHandler;
+
+ /**
+ * @param string $name The logging channel
+ * @param HandlerInterface[] $handlers Optional stack of handlers, the first one in the array is called first, etc.
+ * @param callable[] $processors Optional array of processors
+ */
+ public function __construct($name, array $handlers = array(), array $processors = array())
+ {
+ $this->name = $name;
+ $this->setHandlers($handlers);
+ $this->processors = $processors;
+ }
+
+ /**
+ * @return string
+ */
+ public function getName()
+ {
+ return $this->name;
+ }
+
+ /**
+ * Return a new cloned instance with the name changed
+ *
+ * @return static
+ */
+ public function withName($name)
+ {
+ $new = clone $this;
+ $new->name = $name;
+
+ return $new;
+ }
+
+ /**
+ * Pushes a handler on to the stack.
+ *
+ * @param HandlerInterface $handler
+ * @return $this
+ */
+ public function pushHandler(HandlerInterface $handler)
+ {
+ array_unshift($this->handlers, $handler);
+
+ return $this;
+ }
+
+ /**
+ * Pops a handler from the stack
+ *
+ * @return HandlerInterface
+ */
+ public function popHandler()
+ {
+ if (!$this->handlers) {
+ throw new \LogicException('You tried to pop from an empty handler stack.');
+ }
+
+ return array_shift($this->handlers);
+ }
+
+ /**
+ * Set handlers, replacing all existing ones.
+ *
+ * If a map is passed, keys will be ignored.
+ *
+ * @param HandlerInterface[] $handlers
+ * @return $this
+ */
+ public function setHandlers(array $handlers)
+ {
+ $this->handlers = array();
+ foreach (array_reverse($handlers) as $handler) {
+ $this->pushHandler($handler);
+ }
+
+ return $this;
+ }
+
+ /**
+ * @return HandlerInterface[]
+ */
+ public function getHandlers()
+ {
+ return $this->handlers;
+ }
+
+ /**
+ * Adds a processor on to the stack.
+ *
+ * @param callable $callback
+ * @return $this
+ */
+ public function pushProcessor($callback)
+ {
+ if (!is_callable($callback)) {
+ throw new \InvalidArgumentException('Processors must be valid callables (callback or object with an __invoke method), '.var_export($callback, true).' given');
+ }
+ array_unshift($this->processors, $callback);
+
+ return $this;
+ }
+
+ /**
+ * Removes the processor on top of the stack and returns it.
+ *
+ * @return callable
+ */
+ public function popProcessor()
+ {
+ if (!$this->processors) {
+ throw new \LogicException('You tried to pop from an empty processor stack.');
+ }
+
+ return array_shift($this->processors);
+ }
+
+ /**
+ * @return callable[]
+ */
+ public function getProcessors()
+ {
+ return $this->processors;
+ }
+
+ /**
+ * Control the use of microsecond resolution timestamps in the 'datetime'
+ * member of new records.
+ *
+ * Generating microsecond resolution timestamps by calling
+ * microtime(true), formatting the result via sprintf() and then parsing
+ * the resulting string via \DateTime::createFromFormat() can incur
+ * a measurable runtime overhead vs simple usage of DateTime to capture
+ * a second resolution timestamp in systems which generate a large number
+ * of log events.
+ *
+ * @param bool $micro True to use microtime() to create timestamps
+ */
+ public function useMicrosecondTimestamps($micro)
+ {
+ $this->microsecondTimestamps = (bool) $micro;
+ }
+
+ /**
+ * Adds a log record.
+ *
+ * @param int $level The logging level
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function addRecord($level, $message, array $context = array())
+ {
+ if (!$this->handlers) {
+ $this->pushHandler(new StreamHandler('php://stderr', static::DEBUG));
+ }
+
+ $levelName = static::getLevelName($level);
+
+ // check if any handler will handle this message so we can return early and save cycles
+ $handlerKey = null;
+ reset($this->handlers);
+ while ($handler = current($this->handlers)) {
+ if ($handler->isHandling(array('level' => $level))) {
+ $handlerKey = key($this->handlers);
+ break;
+ }
+
+ next($this->handlers);
+ }
+
+ if (null === $handlerKey) {
+ return false;
+ }
+
+ if (!static::$timezone) {
+ static::$timezone = new \DateTimeZone(date_default_timezone_get() ?: 'UTC');
+ }
+
+ // php7.1+ always has microseconds enabled, so we do not need this hack
+ if ($this->microsecondTimestamps && PHP_VERSION_ID < 70100) {
+ $ts = \DateTime::createFromFormat('U.u', sprintf('%.6F', microtime(true)), static::$timezone);
+ } else {
+ $ts = new \DateTime('now', static::$timezone);
+ }
+ $ts->setTimezone(static::$timezone);
+
+ $record = array(
+ 'message' => (string) $message,
+ 'context' => $context,
+ 'level' => $level,
+ 'level_name' => $levelName,
+ 'channel' => $this->name,
+ 'datetime' => $ts,
+ 'extra' => array(),
+ );
+
+ try {
+ foreach ($this->processors as $processor) {
+ $record = call_user_func($processor, $record);
+ }
+
+ while ($handler = current($this->handlers)) {
+ if (true === $handler->handle($record)) {
+ break;
+ }
+
+ next($this->handlers);
+ }
+ } catch (Exception $e) {
+ $this->handleException($e, $record);
+ }
+
+ return true;
+ }
+
+ /**
+ * Ends a log cycle and frees all resources used by handlers.
+ *
+ * Closing a Handler means flushing all buffers and freeing any open resources/handles.
+ * Handlers that have been closed should be able to accept log records again and re-open
+ * themselves on demand, but this may not always be possible depending on implementation.
+ *
+ * This is useful at the end of a request and will be called automatically on every handler
+ * when they get destructed.
+ */
+ public function close()
+ {
+ foreach ($this->handlers as $handler) {
+ if (method_exists($handler, 'close')) {
+ $handler->close();
+ }
+ }
+ }
+
+ /**
+ * Ends a log cycle and resets all handlers and processors to their initial state.
+ *
+ * Resetting a Handler or a Processor means flushing/cleaning all buffers, resetting internal
+ * state, and getting it back to a state in which it can receive log records again.
+ *
+ * This is useful in case you want to avoid logs leaking between two requests or jobs when you
+ * have a long running process like a worker or an application server serving multiple requests
+ * in one process.
+ */
+ public function reset()
+ {
+ foreach ($this->handlers as $handler) {
+ if ($handler instanceof ResettableInterface) {
+ $handler->reset();
+ }
+ }
+
+ foreach ($this->processors as $processor) {
+ if ($processor instanceof ResettableInterface) {
+ $processor->reset();
+ }
+ }
+ }
+
+ /**
+ * Adds a log record at the DEBUG level.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function addDebug($message, array $context = array())
+ {
+ return $this->addRecord(static::DEBUG, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the INFO level.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function addInfo($message, array $context = array())
+ {
+ return $this->addRecord(static::INFO, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the NOTICE level.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function addNotice($message, array $context = array())
+ {
+ return $this->addRecord(static::NOTICE, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the WARNING level.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function addWarning($message, array $context = array())
+ {
+ return $this->addRecord(static::WARNING, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the ERROR level.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function addError($message, array $context = array())
+ {
+ return $this->addRecord(static::ERROR, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the CRITICAL level.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function addCritical($message, array $context = array())
+ {
+ return $this->addRecord(static::CRITICAL, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the ALERT level.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function addAlert($message, array $context = array())
+ {
+ return $this->addRecord(static::ALERT, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the EMERGENCY level.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function addEmergency($message, array $context = array())
+ {
+ return $this->addRecord(static::EMERGENCY, $message, $context);
+ }
+
+ /**
+ * Gets all supported logging levels.
+ *
+ * @return array Assoc array with human-readable level names => level codes.
+ */
+ public static function getLevels()
+ {
+ return array_flip(static::$levels);
+ }
+
+ /**
+ * Gets the name of the logging level.
+ *
+ * @param int $level
+ * @return string
+ */
+ public static function getLevelName($level)
+ {
+ if (!isset(static::$levels[$level])) {
+ throw new InvalidArgumentException('Level "'.$level.'" is not defined, use one of: '.implode(', ', array_keys(static::$levels)));
+ }
+
+ return static::$levels[$level];
+ }
+
+ /**
+ * Converts PSR-3 levels to Monolog ones if necessary
+ *
+ * @param string|int $level Level number (monolog) or name (PSR-3)
+ * @return int
+ */
+ public static function toMonologLevel($level)
+ {
+ if (is_string($level)) {
+ // Contains chars of all log levels and avoids using strtoupper() which may have
+ // strange results depending on locale (for example, "i" will become "İ")
+ $upper = strtr($level, 'abcdefgilmnortuwy', 'ABCDEFGILMNORTUWY');
+ if (defined(__CLASS__.'::'.$upper)) {
+ return constant(__CLASS__ . '::' . $upper);
+ }
+ }
+
+ return $level;
+ }
+
+ /**
+ * Checks whether the Logger has a handler that listens on the given level
+ *
+ * @param int $level
+ * @return bool
+ */
+ public function isHandling($level)
+ {
+ $record = array(
+ 'level' => $level,
+ );
+
+ foreach ($this->handlers as $handler) {
+ if ($handler->isHandling($record)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Set a custom exception handler
+ *
+ * @param callable $callback
+ * @return $this
+ */
+ public function setExceptionHandler($callback)
+ {
+ if (!is_callable($callback)) {
+ throw new \InvalidArgumentException('Exception handler must be valid callable (callback or object with an __invoke method), '.var_export($callback, true).' given');
+ }
+ $this->exceptionHandler = $callback;
+
+ return $this;
+ }
+
+ /**
+ * @return callable
+ */
+ public function getExceptionHandler()
+ {
+ return $this->exceptionHandler;
+ }
+
+ /**
+ * Delegates exception management to the custom exception handler,
+ * or throws the exception if no custom handler is set.
+ */
+ protected function handleException(Exception $e, array $record)
+ {
+ if (!$this->exceptionHandler) {
+ throw $e;
+ }
+
+ call_user_func($this->exceptionHandler, $e, $record);
+ }
+
+ /**
+ * Adds a log record at an arbitrary level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param mixed $level The log level
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function log($level, $message, array $context = array())
+ {
+ $level = static::toMonologLevel($level);
+
+ return $this->addRecord($level, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the DEBUG level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function debug($message, array $context = array())
+ {
+ return $this->addRecord(static::DEBUG, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the INFO level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function info($message, array $context = array())
+ {
+ return $this->addRecord(static::INFO, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the NOTICE level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function notice($message, array $context = array())
+ {
+ return $this->addRecord(static::NOTICE, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the WARNING level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function warn($message, array $context = array())
+ {
+ return $this->addRecord(static::WARNING, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the WARNING level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function warning($message, array $context = array())
+ {
+ return $this->addRecord(static::WARNING, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the ERROR level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function err($message, array $context = array())
+ {
+ return $this->addRecord(static::ERROR, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the ERROR level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function error($message, array $context = array())
+ {
+ return $this->addRecord(static::ERROR, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the CRITICAL level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function crit($message, array $context = array())
+ {
+ return $this->addRecord(static::CRITICAL, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the CRITICAL level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function critical($message, array $context = array())
+ {
+ return $this->addRecord(static::CRITICAL, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the ALERT level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function alert($message, array $context = array())
+ {
+ return $this->addRecord(static::ALERT, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the EMERGENCY level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function emerg($message, array $context = array())
+ {
+ return $this->addRecord(static::EMERGENCY, $message, $context);
+ }
+
+ /**
+ * Adds a log record at the EMERGENCY level.
+ *
+ * This method allows for compatibility with common interfaces.
+ *
+ * @param string $message The log message
+ * @param array $context The log context
+ * @return bool Whether the record has been processed
+ */
+ public function emergency($message, array $context = array())
+ {
+ return $this->addRecord(static::EMERGENCY, $message, $context);
+ }
+
+ /**
+ * Set the timezone to be used for the timestamp of log records.
+ *
+ * This is stored globally for all Logger instances
+ *
+ * @param \DateTimeZone $tz Timezone object
+ */
+ public static function setTimezone(\DateTimeZone $tz)
+ {
+ self::$timezone = $tz;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/GitProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/GitProcessor.php
new file mode 100644
index 000000000..cdf5ec736
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/GitProcessor.php
@@ -0,0 +1,64 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+use Monolog\Logger;
+
+/**
+ * Injects Git branch and Git commit SHA in all records
+ *
+ * @author Nick Otter
+ * @author Jordi Boggiano
+ */
+class GitProcessor implements ProcessorInterface
+{
+ private $level;
+ private static $cache;
+
+ public function __construct($level = Logger::DEBUG)
+ {
+ $this->level = Logger::toMonologLevel($level);
+ }
+
+ /**
+ * @param array $record
+ * @return array
+ */
+ public function __invoke(array $record)
+ {
+ // return if the level is not high enough
+ if ($record['level'] < $this->level) {
+ return $record;
+ }
+
+ $record['extra']['git'] = self::getGitInfo();
+
+ return $record;
+ }
+
+ private static function getGitInfo()
+ {
+ if (self::$cache) {
+ return self::$cache;
+ }
+
+ $branches = `git branch -v --no-abbrev`;
+ if ($branches && preg_match('{^\* (.+?)\s+([a-f0-9]{40})(?:\s|$)}m', $branches, $matches)) {
+ return self::$cache = array(
+ 'branch' => $matches[1],
+ 'commit' => $matches[2],
+ );
+ }
+
+ return self::$cache = array();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/IntrospectionProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/IntrospectionProcessor.php
new file mode 100644
index 000000000..6ae192a23
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/IntrospectionProcessor.php
@@ -0,0 +1,112 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+use Monolog\Logger;
+
+/**
+ * Injects line/file:class/function where the log message came from
+ *
+ * Warning: This only works if the handler processes the logs directly.
+ * If you put the processor on a handler that is behind a FingersCrossedHandler
+ * for example, the processor will only be called once the trigger level is reached,
+ * and all the log records will have the same file/line/.. data from the call that
+ * triggered the FingersCrossedHandler.
+ *
+ * @author Jordi Boggiano
+ */
+class IntrospectionProcessor implements ProcessorInterface
+{
+ private $level;
+
+ private $skipClassesPartials;
+
+ private $skipStackFramesCount;
+
+ private $skipFunctions = array(
+ 'call_user_func',
+ 'call_user_func_array',
+ );
+
+ public function __construct($level = Logger::DEBUG, array $skipClassesPartials = array(), $skipStackFramesCount = 0)
+ {
+ $this->level = Logger::toMonologLevel($level);
+ $this->skipClassesPartials = array_merge(array('Monolog\\'), $skipClassesPartials);
+ $this->skipStackFramesCount = $skipStackFramesCount;
+ }
+
+ /**
+ * @param array $record
+ * @return array
+ */
+ public function __invoke(array $record)
+ {
+ // return if the level is not high enough
+ if ($record['level'] < $this->level) {
+ return $record;
+ }
+
+ /*
+ * http://php.net/manual/en/function.debug-backtrace.php
+ * As of 5.3.6, DEBUG_BACKTRACE_IGNORE_ARGS option was added.
+ * Any version less than 5.3.6 must use the DEBUG_BACKTRACE_IGNORE_ARGS constant value '2'.
+ */
+ $trace = debug_backtrace((PHP_VERSION_ID < 50306) ? 2 : DEBUG_BACKTRACE_IGNORE_ARGS);
+
+ // skip first since it's always the current method
+ array_shift($trace);
+ // the call_user_func call is also skipped
+ array_shift($trace);
+
+ $i = 0;
+
+ while ($this->isTraceClassOrSkippedFunction($trace, $i)) {
+ if (isset($trace[$i]['class'])) {
+ foreach ($this->skipClassesPartials as $part) {
+ if (strpos($trace[$i]['class'], $part) !== false) {
+ $i++;
+ continue 2;
+ }
+ }
+ } elseif (in_array($trace[$i]['function'], $this->skipFunctions)) {
+ $i++;
+ continue;
+ }
+
+ break;
+ }
+
+ $i += $this->skipStackFramesCount;
+
+ // we should have the call source now
+ $record['extra'] = array_merge(
+ $record['extra'],
+ array(
+ 'file' => isset($trace[$i - 1]['file']) ? $trace[$i - 1]['file'] : null,
+ 'line' => isset($trace[$i - 1]['line']) ? $trace[$i - 1]['line'] : null,
+ 'class' => isset($trace[$i]['class']) ? $trace[$i]['class'] : null,
+ 'function' => isset($trace[$i]['function']) ? $trace[$i]['function'] : null,
+ )
+ );
+
+ return $record;
+ }
+
+ private function isTraceClassOrSkippedFunction(array $trace, $index)
+ {
+ if (!isset($trace[$index])) {
+ return false;
+ }
+
+ return isset($trace[$index]['class']) || in_array($trace[$index]['function'], $this->skipFunctions);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/MemoryPeakUsageProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/MemoryPeakUsageProcessor.php
new file mode 100644
index 000000000..0543e9292
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/MemoryPeakUsageProcessor.php
@@ -0,0 +1,35 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+/**
+ * Injects memory_get_peak_usage in all records
+ *
+ * @see Monolog\Processor\MemoryProcessor::__construct() for options
+ * @author Rob Jensen
+ */
+class MemoryPeakUsageProcessor extends MemoryProcessor
+{
+ /**
+ * @param array $record
+ * @return array
+ */
+ public function __invoke(array $record)
+ {
+ $bytes = memory_get_peak_usage($this->realUsage);
+ $formatted = $this->formatBytes($bytes);
+
+ $record['extra']['memory_peak_usage'] = $formatted;
+
+ return $record;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/MemoryProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/MemoryProcessor.php
new file mode 100644
index 000000000..2a379a302
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/MemoryProcessor.php
@@ -0,0 +1,63 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+/**
+ * Some methods that are common for all memory processors
+ *
+ * @author Rob Jensen
+ */
+abstract class MemoryProcessor implements ProcessorInterface
+{
+ /**
+ * @var bool If true, get the real size of memory allocated from system. Else, only the memory used by emalloc() is reported.
+ */
+ protected $realUsage;
+
+ /**
+ * @var bool If true, then format memory size to human readable string (MB, KB, B depending on size)
+ */
+ protected $useFormatting;
+
+ /**
+ * @param bool $realUsage Set this to true to get the real size of memory allocated from system.
+ * @param bool $useFormatting If true, then format memory size to human readable string (MB, KB, B depending on size)
+ */
+ public function __construct($realUsage = true, $useFormatting = true)
+ {
+ $this->realUsage = (bool) $realUsage;
+ $this->useFormatting = (bool) $useFormatting;
+ }
+
+ /**
+ * Formats bytes into a human readable string if $this->useFormatting is true, otherwise return $bytes as is
+ *
+ * @param int $bytes
+ * @return string|int Formatted string if $this->useFormatting is true, otherwise return $bytes as is
+ */
+ protected function formatBytes($bytes)
+ {
+ $bytes = (int) $bytes;
+
+ if (!$this->useFormatting) {
+ return $bytes;
+ }
+
+ if ($bytes > 1024 * 1024) {
+ return round($bytes / 1024 / 1024, 2).' MB';
+ } elseif ($bytes > 1024) {
+ return round($bytes / 1024, 2).' KB';
+ }
+
+ return $bytes . ' B';
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/MemoryUsageProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/MemoryUsageProcessor.php
new file mode 100644
index 000000000..2783d656b
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/MemoryUsageProcessor.php
@@ -0,0 +1,35 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+/**
+ * Injects memory_get_usage in all records
+ *
+ * @see Monolog\Processor\MemoryProcessor::__construct() for options
+ * @author Rob Jensen
+ */
+class MemoryUsageProcessor extends MemoryProcessor
+{
+ /**
+ * @param array $record
+ * @return array
+ */
+ public function __invoke(array $record)
+ {
+ $bytes = memory_get_usage($this->realUsage);
+ $formatted = $this->formatBytes($bytes);
+
+ $record['extra']['memory_usage'] = $formatted;
+
+ return $record;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/MercurialProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/MercurialProcessor.php
new file mode 100644
index 000000000..2f5b32659
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/MercurialProcessor.php
@@ -0,0 +1,63 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+use Monolog\Logger;
+
+/**
+ * Injects Hg branch and Hg revision number in all records
+ *
+ * @author Jonathan A. Schweder
+ */
+class MercurialProcessor implements ProcessorInterface
+{
+ private $level;
+ private static $cache;
+
+ public function __construct($level = Logger::DEBUG)
+ {
+ $this->level = Logger::toMonologLevel($level);
+ }
+
+ /**
+ * @param array $record
+ * @return array
+ */
+ public function __invoke(array $record)
+ {
+ // return if the level is not high enough
+ if ($record['level'] < $this->level) {
+ return $record;
+ }
+
+ $record['extra']['hg'] = self::getMercurialInfo();
+
+ return $record;
+ }
+
+ private static function getMercurialInfo()
+ {
+ if (self::$cache) {
+ return self::$cache;
+ }
+
+ $result = explode(' ', trim(`hg id -nb`));
+ if (count($result) >= 3) {
+ return self::$cache = array(
+ 'branch' => $result[1],
+ 'revision' => $result[2],
+ );
+ }
+
+ return self::$cache = array();
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/ProcessIdProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/ProcessIdProcessor.php
new file mode 100644
index 000000000..66b80fbbd
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/ProcessIdProcessor.php
@@ -0,0 +1,31 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+/**
+ * Adds value of getmypid into records
+ *
+ * @author Andreas Hörnicke
+ */
+class ProcessIdProcessor implements ProcessorInterface
+{
+ /**
+ * @param array $record
+ * @return array
+ */
+ public function __invoke(array $record)
+ {
+ $record['extra']['process_id'] = getmypid();
+
+ return $record;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/ProcessorInterface.php b/vendor/monolog/monolog/src/Monolog/Processor/ProcessorInterface.php
new file mode 100644
index 000000000..7e64d4dfa
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/ProcessorInterface.php
@@ -0,0 +1,25 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+/**
+ * An optional interface to allow labelling Monolog processors.
+ *
+ * @author Nicolas Grekas
+ */
+interface ProcessorInterface
+{
+ /**
+ * @return array The processed records
+ */
+ public function __invoke(array $records);
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/PsrLogMessageProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/PsrLogMessageProcessor.php
new file mode 100644
index 000000000..a318af7e4
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/PsrLogMessageProcessor.php
@@ -0,0 +1,81 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+use Monolog\Utils;
+
+/**
+ * Processes a record's message according to PSR-3 rules
+ *
+ * It replaces {foo} with the value from $context['foo']
+ *
+ * @author Jordi Boggiano
+ */
+class PsrLogMessageProcessor implements ProcessorInterface
+{
+ const SIMPLE_DATE = "Y-m-d\TH:i:s.uP";
+
+ /** @var string|null */
+ private $dateFormat;
+
+ /** @var bool */
+ private $removeUsedContextFields;
+
+ /**
+ * @param string|null $dateFormat The format of the timestamp: one supported by DateTime::format
+ * @param bool $removeUsedContextFields If set to true the fields interpolated into message gets unset
+ */
+ public function __construct($dateFormat = null, $removeUsedContextFields = false)
+ {
+ $this->dateFormat = $dateFormat;
+ $this->removeUsedContextFields = $removeUsedContextFields;
+ }
+
+ /**
+ * @param array $record
+ * @return array
+ */
+ public function __invoke(array $record)
+ {
+ if (false === strpos($record['message'], '{')) {
+ return $record;
+ }
+
+ $replacements = array();
+ foreach ($record['context'] as $key => $val) {
+ $placeholder = '{' . $key . '}';
+ if (strpos($record['message'], $placeholder) === false) {
+ continue;
+ }
+
+ if (is_null($val) || is_scalar($val) || (is_object($val) && method_exists($val, "__toString"))) {
+ $replacements[$placeholder] = $val;
+ } elseif ($val instanceof \DateTime) {
+ $replacements[$placeholder] = $val->format($this->dateFormat ?: static::SIMPLE_DATE);
+ } elseif (is_object($val)) {
+ $replacements[$placeholder] = '[object '.Utils::getClass($val).']';
+ } elseif (is_array($val)) {
+ $replacements[$placeholder] = 'array'.Utils::jsonEncode($val, null, true);
+ } else {
+ $replacements[$placeholder] = '['.gettype($val).']';
+ }
+
+ if ($this->removeUsedContextFields) {
+ unset($record['context'][$key]);
+ }
+ }
+
+ $record['message'] = strtr($record['message'], $replacements);
+
+ return $record;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/TagProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/TagProcessor.php
new file mode 100644
index 000000000..615a4d991
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/TagProcessor.php
@@ -0,0 +1,44 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+/**
+ * Adds a tags array into record
+ *
+ * @author Martijn Riemers
+ */
+class TagProcessor implements ProcessorInterface
+{
+ private $tags;
+
+ public function __construct(array $tags = array())
+ {
+ $this->setTags($tags);
+ }
+
+ public function addTags(array $tags = array())
+ {
+ $this->tags = array_merge($this->tags, $tags);
+ }
+
+ public function setTags(array $tags = array())
+ {
+ $this->tags = $tags;
+ }
+
+ public function __invoke(array $record)
+ {
+ $record['extra']['tags'] = $this->tags;
+
+ return $record;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/UidProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/UidProcessor.php
new file mode 100644
index 000000000..d1f708cf2
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/UidProcessor.php
@@ -0,0 +1,59 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+use Monolog\ResettableInterface;
+
+/**
+ * Adds a unique identifier into records
+ *
+ * @author Simon Mönch
+ */
+class UidProcessor implements ProcessorInterface, ResettableInterface
+{
+ private $uid;
+
+ public function __construct($length = 7)
+ {
+ if (!is_int($length) || $length > 32 || $length < 1) {
+ throw new \InvalidArgumentException('The uid length must be an integer between 1 and 32');
+ }
+
+
+ $this->uid = $this->generateUid($length);
+ }
+
+ public function __invoke(array $record)
+ {
+ $record['extra']['uid'] = $this->uid;
+
+ return $record;
+ }
+
+ /**
+ * @return string
+ */
+ public function getUid()
+ {
+ return $this->uid;
+ }
+
+ public function reset()
+ {
+ $this->uid = $this->generateUid(strlen($this->uid));
+ }
+
+ private function generateUid($length)
+ {
+ return substr(hash('md5', uniqid('', true)), 0, $length);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Processor/WebProcessor.php b/vendor/monolog/monolog/src/Monolog/Processor/WebProcessor.php
new file mode 100644
index 000000000..2e8dfae1b
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Processor/WebProcessor.php
@@ -0,0 +1,113 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog\Processor;
+
+/**
+ * Injects url/method and remote IP of the current web request in all records
+ *
+ * @author Jordi Boggiano
+ */
+class WebProcessor implements ProcessorInterface
+{
+ /**
+ * @var array|\ArrayAccess
+ */
+ protected $serverData;
+
+ /**
+ * Default fields
+ *
+ * Array is structured as [key in record.extra => key in $serverData]
+ *
+ * @var array
+ */
+ protected $extraFields = array(
+ 'url' => 'REQUEST_URI',
+ 'ip' => 'REMOTE_ADDR',
+ 'http_method' => 'REQUEST_METHOD',
+ 'server' => 'SERVER_NAME',
+ 'referrer' => 'HTTP_REFERER',
+ );
+
+ /**
+ * @param array|\ArrayAccess $serverData Array or object w/ ArrayAccess that provides access to the $_SERVER data
+ * @param array|null $extraFields Field names and the related key inside $serverData to be added. If not provided it defaults to: url, ip, http_method, server, referrer
+ */
+ public function __construct($serverData = null, array $extraFields = null)
+ {
+ if (null === $serverData) {
+ $this->serverData = &$_SERVER;
+ } elseif (is_array($serverData) || $serverData instanceof \ArrayAccess) {
+ $this->serverData = $serverData;
+ } else {
+ throw new \UnexpectedValueException('$serverData must be an array or object implementing ArrayAccess.');
+ }
+
+ if (isset($this->serverData['UNIQUE_ID'])) {
+ $this->extraFields['unique_id'] = 'UNIQUE_ID';
+ }
+
+ if (null !== $extraFields) {
+ if (isset($extraFields[0])) {
+ foreach (array_keys($this->extraFields) as $fieldName) {
+ if (!in_array($fieldName, $extraFields)) {
+ unset($this->extraFields[$fieldName]);
+ }
+ }
+ } else {
+ $this->extraFields = $extraFields;
+ }
+ }
+ }
+
+ /**
+ * @param array $record
+ * @return array
+ */
+ public function __invoke(array $record)
+ {
+ // skip processing if for some reason request data
+ // is not present (CLI or wonky SAPIs)
+ if (!isset($this->serverData['REQUEST_URI'])) {
+ return $record;
+ }
+
+ $record['extra'] = $this->appendExtraFields($record['extra']);
+
+ return $record;
+ }
+
+ /**
+ * @param string $extraName
+ * @param string $serverName
+ * @return $this
+ */
+ public function addExtraField($extraName, $serverName)
+ {
+ $this->extraFields[$extraName] = $serverName;
+
+ return $this;
+ }
+
+ /**
+ * @param array $extra
+ * @return array
+ */
+ private function appendExtraFields(array $extra)
+ {
+ foreach ($this->extraFields as $extraName => $serverName) {
+ $extra[$extraName] = isset($this->serverData[$serverName]) ? $this->serverData[$serverName] : null;
+ }
+
+ return $extra;
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Registry.php b/vendor/monolog/monolog/src/Monolog/Registry.php
new file mode 100644
index 000000000..159b751cd
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Registry.php
@@ -0,0 +1,134 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog;
+
+use InvalidArgumentException;
+
+/**
+ * Monolog log registry
+ *
+ * Allows to get `Logger` instances in the global scope
+ * via static method calls on this class.
+ *
+ *
+ * $application = new Monolog\Logger('application');
+ * $api = new Monolog\Logger('api');
+ *
+ * Monolog\Registry::addLogger($application);
+ * Monolog\Registry::addLogger($api);
+ *
+ * function testLogger()
+ * {
+ * Monolog\Registry::api()->addError('Sent to $api Logger instance');
+ * Monolog\Registry::application()->addError('Sent to $application Logger instance');
+ * }
+ *
+ *
+ * @author Tomas Tatarko
+ */
+class Registry
+{
+ /**
+ * List of all loggers in the registry (by named indexes)
+ *
+ * @var Logger[]
+ */
+ private static $loggers = array();
+
+ /**
+ * Adds new logging channel to the registry
+ *
+ * @param Logger $logger Instance of the logging channel
+ * @param string|null $name Name of the logging channel ($logger->getName() by default)
+ * @param bool $overwrite Overwrite instance in the registry if the given name already exists?
+ * @throws \InvalidArgumentException If $overwrite set to false and named Logger instance already exists
+ */
+ public static function addLogger(Logger $logger, $name = null, $overwrite = false)
+ {
+ $name = $name ?: $logger->getName();
+
+ if (isset(self::$loggers[$name]) && !$overwrite) {
+ throw new InvalidArgumentException('Logger with the given name already exists');
+ }
+
+ self::$loggers[$name] = $logger;
+ }
+
+ /**
+ * Checks if such logging channel exists by name or instance
+ *
+ * @param string|Logger $logger Name or logger instance
+ */
+ public static function hasLogger($logger)
+ {
+ if ($logger instanceof Logger) {
+ $index = array_search($logger, self::$loggers, true);
+
+ return false !== $index;
+ } else {
+ return isset(self::$loggers[$logger]);
+ }
+ }
+
+ /**
+ * Removes instance from registry by name or instance
+ *
+ * @param string|Logger $logger Name or logger instance
+ */
+ public static function removeLogger($logger)
+ {
+ if ($logger instanceof Logger) {
+ if (false !== ($idx = array_search($logger, self::$loggers, true))) {
+ unset(self::$loggers[$idx]);
+ }
+ } else {
+ unset(self::$loggers[$logger]);
+ }
+ }
+
+ /**
+ * Clears the registry
+ */
+ public static function clear()
+ {
+ self::$loggers = array();
+ }
+
+ /**
+ * Gets Logger instance from the registry
+ *
+ * @param string $name Name of the requested Logger instance
+ * @throws \InvalidArgumentException If named Logger instance is not in the registry
+ * @return Logger Requested instance of Logger
+ */
+ public static function getInstance($name)
+ {
+ if (!isset(self::$loggers[$name])) {
+ throw new InvalidArgumentException(sprintf('Requested "%s" logger instance is not in the registry', $name));
+ }
+
+ return self::$loggers[$name];
+ }
+
+ /**
+ * Gets Logger instance from the registry via static method call
+ *
+ * @param string $name Name of the requested Logger instance
+ * @param array $arguments Arguments passed to static method call
+ * @throws \InvalidArgumentException If named Logger instance is not in the registry
+ * @return Logger Requested instance of Logger
+ */
+ public static function __callStatic($name, $arguments)
+ {
+ return self::getInstance($name);
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/ResettableInterface.php b/vendor/monolog/monolog/src/Monolog/ResettableInterface.php
new file mode 100644
index 000000000..635bc77dc
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/ResettableInterface.php
@@ -0,0 +1,31 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog;
+
+/**
+ * Handler or Processor implementing this interface will be reset when Logger::reset() is called.
+ *
+ * Resetting ends a log cycle gets them back to their initial state.
+ *
+ * Resetting a Handler or a Processor means flushing/cleaning all buffers, resetting internal
+ * state, and getting it back to a state in which it can receive log records again.
+ *
+ * This is useful in case you want to avoid logs leaking between two requests or jobs when you
+ * have a long running process like a worker or an application server serving multiple requests
+ * in one process.
+ *
+ * @author Grégoire Pineau
+ */
+interface ResettableInterface
+{
+ public function reset();
+}
diff --git a/vendor/monolog/monolog/src/Monolog/SignalHandler.php b/vendor/monolog/monolog/src/Monolog/SignalHandler.php
new file mode 100644
index 000000000..d87018fed
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/SignalHandler.php
@@ -0,0 +1,115 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog;
+
+use Psr\Log\LoggerInterface;
+use Psr\Log\LogLevel;
+use ReflectionExtension;
+
+/**
+ * Monolog POSIX signal handler
+ *
+ * @author Robert Gust-Bardon
+ */
+class SignalHandler
+{
+ private $logger;
+
+ private $previousSignalHandler = array();
+ private $signalLevelMap = array();
+ private $signalRestartSyscalls = array();
+
+ public function __construct(LoggerInterface $logger)
+ {
+ $this->logger = $logger;
+ }
+
+ public function registerSignalHandler($signo, $level = LogLevel::CRITICAL, $callPrevious = true, $restartSyscalls = true, $async = true)
+ {
+ if (!extension_loaded('pcntl') || !function_exists('pcntl_signal')) {
+ return $this;
+ }
+
+ if ($callPrevious) {
+ if (function_exists('pcntl_signal_get_handler')) {
+ $handler = pcntl_signal_get_handler($signo);
+ if ($handler === false) {
+ return $this;
+ }
+ $this->previousSignalHandler[$signo] = $handler;
+ } else {
+ $this->previousSignalHandler[$signo] = true;
+ }
+ } else {
+ unset($this->previousSignalHandler[$signo]);
+ }
+ $this->signalLevelMap[$signo] = $level;
+ $this->signalRestartSyscalls[$signo] = $restartSyscalls;
+
+ if (function_exists('pcntl_async_signals') && $async !== null) {
+ pcntl_async_signals($async);
+ }
+
+ pcntl_signal($signo, array($this, 'handleSignal'), $restartSyscalls);
+
+ return $this;
+ }
+
+ public function handleSignal($signo, array $siginfo = null)
+ {
+ static $signals = array();
+
+ if (!$signals && extension_loaded('pcntl')) {
+ $pcntl = new ReflectionExtension('pcntl');
+ $constants = $pcntl->getConstants();
+ if (!$constants) {
+ // HHVM 3.24.2 returns an empty array.
+ $constants = get_defined_constants(true);
+ $constants = $constants['Core'];
+ }
+ foreach ($constants as $name => $value) {
+ if (substr($name, 0, 3) === 'SIG' && $name[3] !== '_' && is_int($value)) {
+ $signals[$value] = $name;
+ }
+ }
+ unset($constants);
+ }
+
+ $level = isset($this->signalLevelMap[$signo]) ? $this->signalLevelMap[$signo] : LogLevel::CRITICAL;
+ $signal = isset($signals[$signo]) ? $signals[$signo] : $signo;
+ $context = isset($siginfo) ? $siginfo : array();
+ $this->logger->log($level, sprintf('Program received signal %s', $signal), $context);
+
+ if (!isset($this->previousSignalHandler[$signo])) {
+ return;
+ }
+
+ if ($this->previousSignalHandler[$signo] === true || $this->previousSignalHandler[$signo] === SIG_DFL) {
+ if (extension_loaded('pcntl') && function_exists('pcntl_signal') && function_exists('pcntl_sigprocmask') && function_exists('pcntl_signal_dispatch')
+ && extension_loaded('posix') && function_exists('posix_getpid') && function_exists('posix_kill')) {
+ $restartSyscalls = isset($this->signalRestartSyscalls[$signo]) ? $this->signalRestartSyscalls[$signo] : true;
+ pcntl_signal($signo, SIG_DFL, $restartSyscalls);
+ pcntl_sigprocmask(SIG_UNBLOCK, array($signo), $oldset);
+ posix_kill(posix_getpid(), $signo);
+ pcntl_signal_dispatch();
+ pcntl_sigprocmask(SIG_SETMASK, $oldset);
+ pcntl_signal($signo, array($this, 'handleSignal'), $restartSyscalls);
+ }
+ } elseif (is_callable($this->previousSignalHandler[$signo])) {
+ if (PHP_VERSION_ID >= 70100) {
+ $this->previousSignalHandler[$signo]($signo, $siginfo);
+ } else {
+ $this->previousSignalHandler[$signo]($signo);
+ }
+ }
+ }
+}
diff --git a/vendor/monolog/monolog/src/Monolog/Utils.php b/vendor/monolog/monolog/src/Monolog/Utils.php
new file mode 100644
index 000000000..7f1ba129e
--- /dev/null
+++ b/vendor/monolog/monolog/src/Monolog/Utils.php
@@ -0,0 +1,189 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Monolog;
+
+class Utils
+{
+ /**
+ * @internal
+ */
+ public static function getClass($object)
+ {
+ $class = \get_class($object);
+
+ return 'c' === $class[0] && 0 === strpos($class, "class@anonymous\0") ? get_parent_class($class).'@anonymous' : $class;
+ }
+
+ /**
+ * Makes sure if a relative path is passed in it is turned into an absolute path
+ *
+ * @param string $streamUrl stream URL or path without protocol
+ *
+ * @return string
+ */
+ public static function canonicalizePath($streamUrl)
+ {
+ $prefix = '';
+ if ('file://' === substr($streamUrl, 0, 7)) {
+ $streamUrl = substr($streamUrl, 7);
+ $prefix = 'file://';
+ }
+
+ // other type of stream, not supported
+ if (false !== strpos($streamUrl, '://')) {
+ return $streamUrl;
+ }
+
+ // already absolute
+ if (substr($streamUrl, 0, 1) === '/' || substr($streamUrl, 1, 1) === ':' || substr($streamUrl, 0, 2) === '\\\\') {
+ return $prefix.$streamUrl;
+ }
+
+ $streamUrl = getcwd() . '/' . $streamUrl;
+
+ return $prefix.$streamUrl;
+ }
+
+ /**
+ * Return the JSON representation of a value
+ *
+ * @param mixed $data
+ * @param int $encodeFlags flags to pass to json encode, defaults to JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE
+ * @param bool $ignoreErrors whether to ignore encoding errors or to throw on error, when ignored and the encoding fails, "null" is returned which is valid json for null
+ * @throws \RuntimeException if encoding fails and errors are not ignored
+ * @return string
+ */
+ public static function jsonEncode($data, $encodeFlags = null, $ignoreErrors = false)
+ {
+ if (null === $encodeFlags && version_compare(PHP_VERSION, '5.4.0', '>=')) {
+ $encodeFlags = JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE;
+ }
+
+ if ($ignoreErrors) {
+ $json = @json_encode($data, $encodeFlags);
+ if (false === $json) {
+ return 'null';
+ }
+
+ return $json;
+ }
+
+ $json = json_encode($data, $encodeFlags);
+ if (false === $json) {
+ $json = self::handleJsonError(json_last_error(), $data);
+ }
+
+ return $json;
+ }
+
+ /**
+ * Handle a json_encode failure.
+ *
+ * If the failure is due to invalid string encoding, try to clean the
+ * input and encode again. If the second encoding attempt fails, the
+ * inital error is not encoding related or the input can't be cleaned then
+ * raise a descriptive exception.
+ *
+ * @param int $code return code of json_last_error function
+ * @param mixed $data data that was meant to be encoded
+ * @param int $encodeFlags flags to pass to json encode, defaults to JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE
+ * @throws \RuntimeException if failure can't be corrected
+ * @return string JSON encoded data after error correction
+ */
+ public static function handleJsonError($code, $data, $encodeFlags = null)
+ {
+ if ($code !== JSON_ERROR_UTF8) {
+ self::throwEncodeError($code, $data);
+ }
+
+ if (is_string($data)) {
+ self::detectAndCleanUtf8($data);
+ } elseif (is_array($data)) {
+ array_walk_recursive($data, array('Monolog\Utils', 'detectAndCleanUtf8'));
+ } else {
+ self::throwEncodeError($code, $data);
+ }
+
+ if (null === $encodeFlags && version_compare(PHP_VERSION, '5.4.0', '>=')) {
+ $encodeFlags = JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE;
+ }
+
+ $json = json_encode($data, $encodeFlags);
+
+ if ($json === false) {
+ self::throwEncodeError(json_last_error(), $data);
+ }
+
+ return $json;
+ }
+
+ /**
+ * Throws an exception according to a given code with a customized message
+ *
+ * @param int $code return code of json_last_error function
+ * @param mixed $data data that was meant to be encoded
+ * @throws \RuntimeException
+ */
+ private static function throwEncodeError($code, $data)
+ {
+ switch ($code) {
+ case JSON_ERROR_DEPTH:
+ $msg = 'Maximum stack depth exceeded';
+ break;
+ case JSON_ERROR_STATE_MISMATCH:
+ $msg = 'Underflow or the modes mismatch';
+ break;
+ case JSON_ERROR_CTRL_CHAR:
+ $msg = 'Unexpected control character found';
+ break;
+ case JSON_ERROR_UTF8:
+ $msg = 'Malformed UTF-8 characters, possibly incorrectly encoded';
+ break;
+ default:
+ $msg = 'Unknown error';
+ }
+
+ throw new \RuntimeException('JSON encoding failed: '.$msg.'. Encoding: '.var_export($data, true));
+ }
+
+ /**
+ * Detect invalid UTF-8 string characters and convert to valid UTF-8.
+ *
+ * Valid UTF-8 input will be left unmodified, but strings containing
+ * invalid UTF-8 codepoints will be reencoded as UTF-8 with an assumed
+ * original encoding of ISO-8859-15. This conversion may result in
+ * incorrect output if the actual encoding was not ISO-8859-15, but it
+ * will be clean UTF-8 output and will not rely on expensive and fragile
+ * detection algorithms.
+ *
+ * Function converts the input in place in the passed variable so that it
+ * can be used as a callback for array_walk_recursive.
+ *
+ * @param mixed $data Input to check and convert if needed, passed by ref
+ * @private
+ */
+ public static function detectAndCleanUtf8(&$data)
+ {
+ if (is_string($data) && !preg_match('//u', $data)) {
+ $data = preg_replace_callback(
+ '/[\x80-\xFF]+/',
+ function ($m) { return utf8_encode($m[0]); },
+ $data
+ );
+ $data = str_replace(
+ array('¤', '¦', '¨', '´', '¸', '¼', '½', '¾'),
+ array('€', 'Š', 'š', 'Ž', 'ž', 'Œ', 'œ', 'Ÿ'),
+ $data
+ );
+ }
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/.editorconfig b/vendor/mtdowling/cron-expression/.editorconfig
new file mode 100644
index 000000000..1492202b4
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/.editorconfig
@@ -0,0 +1,16 @@
+root = true
+
+[*]
+charset = utf-8
+end_of_line = lf
+insert_final_newline = true
+indent_style = space
+indent_size = 4
+trim_trailing_whitespace = true
+
+[*.md]
+trim_trailing_whitespace = false
+
+[*.yml]
+indent_style = space
+indent_size = 2
diff --git a/vendor/mtdowling/cron-expression/CHANGELOG.md b/vendor/mtdowling/cron-expression/CHANGELOG.md
new file mode 100644
index 000000000..8ddab9057
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/CHANGELOG.md
@@ -0,0 +1,36 @@
+# Change Log
+
+## [1.2.0] - 2017-01-22
+### Added
+- Added IDE, CodeSniffer, and StyleCI.IO support
+
+### Changed
+- Switched to PSR-4 Autoloading
+
+### Fixed
+- 0 step expressions are handled better
+- Fixed `DayOfMonth` validation to be more strict
+- Typos
+
+## [1.1.0] - 2016-01-26
+### Added
+- Support for non-hourly offset timezones
+- Checks for valid expressions
+
+### Changed
+- Max Iterations no longer hardcoded for `getRunDate()`
+- Supports DateTimeImmutable for newer PHP verions
+
+### Fixed
+- Fixed looping bug for PHP 7 when determining the last specified weekday of a month
+
+## [1.0.3] - 2013-11-23
+### Added
+- Now supports expressions with any number of extra spaces, tabs, or newlines
+
+### Changed
+- Using static instead of self in `CronExpression::factory`
+
+### Fixed
+- Fixes issue [#28](https://github.com/mtdowling/cron-expression/issues/28) where PHP increments of ranges were failing due to PHP casting hyphens to 0
+- Only set default timezone if the given $currentTime is not a DateTime instance ([#34](https://github.com/mtdowling/cron-expression/issues/34))
diff --git a/vendor/mtdowling/cron-expression/LICENSE b/vendor/mtdowling/cron-expression/LICENSE
new file mode 100644
index 000000000..c6d88ac6c
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/LICENSE
@@ -0,0 +1,19 @@
+Copyright (c) 2011 Michael Dowling and contributors
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
diff --git a/vendor/mtdowling/cron-expression/README.md b/vendor/mtdowling/cron-expression/README.md
new file mode 100644
index 000000000..c9e3bf3e5
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/README.md
@@ -0,0 +1,71 @@
+PHP Cron Expression Parser
+==========================
+
+[](https://packagist.org/packages/mtdowling/cron-expression) [](https://packagist.org/packages/mtdowling/cron-expression) [](http://travis-ci.org/mtdowling/cron-expression)
+
+The PHP cron expression parser can parse a CRON expression, determine if it is
+due to run, calculate the next run date of the expression, and calculate the previous
+run date of the expression. You can calculate dates far into the future or past by
+skipping n number of matching dates.
+
+The parser can handle increments of ranges (e.g. */12, 2-59/3), intervals (e.g. 0-9),
+lists (e.g. 1,2,3), W to find the nearest weekday for a given day of the month, L to
+find the last day of the month, L to find the last given weekday of a month, and hash
+(#) to find the nth weekday of a given month.
+
+Installing
+==========
+
+Add the dependency to your project:
+
+```bash
+composer require mtdowling/cron-expression
+```
+
+Usage
+=====
+```php
+isDue();
+echo $cron->getNextRunDate()->format('Y-m-d H:i:s');
+echo $cron->getPreviousRunDate()->format('Y-m-d H:i:s');
+
+// Works with complex expressions
+$cron = Cron\CronExpression::factory('3-59/15 2,6-12 */15 1 2-5');
+echo $cron->getNextRunDate()->format('Y-m-d H:i:s');
+
+// Calculate a run date two iterations into the future
+$cron = Cron\CronExpression::factory('@daily');
+echo $cron->getNextRunDate(null, 2)->format('Y-m-d H:i:s');
+
+// Calculate a run date relative to a specific time
+$cron = Cron\CronExpression::factory('@monthly');
+echo $cron->getNextRunDate('2010-01-12 00:00:00')->format('Y-m-d H:i:s');
+```
+
+CRON Expressions
+================
+
+A CRON expression is a string representing the schedule for a particular command to execute. The parts of a CRON schedule are as follows:
+
+ * * * * * *
+ - - - - - -
+ | | | | | |
+ | | | | | + year [optional]
+ | | | | +----- day of week (0 - 7) (Sunday=0 or 7)
+ | | | +---------- month (1 - 12)
+ | | +--------------- day of month (1 - 31)
+ | +-------------------- hour (0 - 23)
+ +------------------------- min (0 - 59)
+
+Requirements
+============
+
+- PHP 5.3+
+- PHPUnit is required to run the unit tests
+- Composer is required to run the unit tests
\ No newline at end of file
diff --git a/vendor/mtdowling/cron-expression/composer.json b/vendor/mtdowling/cron-expression/composer.json
new file mode 100644
index 000000000..d68c9ec1c
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/composer.json
@@ -0,0 +1,29 @@
+{
+ "name": "mtdowling/cron-expression",
+ "type": "library",
+ "description": "CRON for PHP: Calculate the next or previous run date and determine if a CRON expression is due",
+ "keywords": ["cron", "schedule"],
+ "license": "MIT",
+ "authors": [{
+ "name": "Michael Dowling",
+ "email": "mtdowling@gmail.com",
+ "homepage": "https://github.com/mtdowling"
+ }],
+ "require": {
+ "php": ">=5.3.2"
+ },
+ "require-dev": {
+ "phpunit/phpunit": "~4.0|~5.0"
+ },
+ "autoload": {
+ "psr-4": {
+ "Cron\\": "src/Cron/"
+ }
+ },
+ "autoload-dev": {
+ "psr-4": {
+ "Tests\\": "tests/Cron/"
+ }
+ },
+ "abandoned": "dragonmantank/cron-expression"
+}
diff --git a/vendor/mtdowling/cron-expression/src/Cron/AbstractField.php b/vendor/mtdowling/cron-expression/src/Cron/AbstractField.php
new file mode 100644
index 000000000..cd2410ab6
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/src/Cron/AbstractField.php
@@ -0,0 +1,148 @@
+isIncrementsOfRanges($value)) {
+ return $this->isInIncrementsOfRanges($dateValue, $value);
+ } elseif ($this->isRange($value)) {
+ return $this->isInRange($dateValue, $value);
+ }
+
+ return $value == '*' || $dateValue == $value;
+ }
+
+ /**
+ * Check if a value is a range
+ *
+ * @param string $value Value to test
+ *
+ * @return bool
+ */
+ public function isRange($value)
+ {
+ return strpos($value, '-') !== false;
+ }
+
+ /**
+ * Check if a value is an increments of ranges
+ *
+ * @param string $value Value to test
+ *
+ * @return bool
+ */
+ public function isIncrementsOfRanges($value)
+ {
+ return strpos($value, '/') !== false;
+ }
+
+ /**
+ * Test if a value is within a range
+ *
+ * @param string $dateValue Set date value
+ * @param string $value Value to test
+ *
+ * @return bool
+ */
+ public function isInRange($dateValue, $value)
+ {
+ $parts = array_map('trim', explode('-', $value, 2));
+
+ return $dateValue >= $parts[0] && $dateValue <= $parts[1];
+ }
+
+ /**
+ * Test if a value is within an increments of ranges (offset[-to]/step size)
+ *
+ * @param string $dateValue Set date value
+ * @param string $value Value to test
+ *
+ * @return bool
+ */
+ public function isInIncrementsOfRanges($dateValue, $value)
+ {
+ $parts = array_map('trim', explode('/', $value, 2));
+ $stepSize = isset($parts[1]) ? (int) $parts[1] : 0;
+
+ if ($stepSize === 0) {
+ return false;
+ }
+
+ if (($parts[0] == '*' || $parts[0] === '0')) {
+ return (int) $dateValue % $stepSize == 0;
+ }
+
+ $range = explode('-', $parts[0], 2);
+ $offset = $range[0];
+ $to = isset($range[1]) ? $range[1] : $dateValue;
+ // Ensure that the date value is within the range
+ if ($dateValue < $offset || $dateValue > $to) {
+ return false;
+ }
+
+ if ($dateValue > $offset && 0 === $stepSize) {
+ return false;
+ }
+
+ for ($i = $offset; $i <= $to; $i+= $stepSize) {
+ if ($i == $dateValue) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Returns a range of values for the given cron expression
+ *
+ * @param string $expression The expression to evaluate
+ * @param int $max Maximum offset for range
+ *
+ * @return array
+ */
+ public function getRangeForExpression($expression, $max)
+ {
+ $values = array();
+
+ if ($this->isRange($expression) || $this->isIncrementsOfRanges($expression)) {
+ if (!$this->isIncrementsOfRanges($expression)) {
+ list ($offset, $to) = explode('-', $expression);
+ $stepSize = 1;
+ }
+ else {
+ $range = array_map('trim', explode('/', $expression, 2));
+ $stepSize = isset($range[1]) ? $range[1] : 0;
+ $range = $range[0];
+ $range = explode('-', $range, 2);
+ $offset = $range[0];
+ $to = isset($range[1]) ? $range[1] : $max;
+ }
+ $offset = $offset == '*' ? 0 : $offset;
+ for ($i = $offset; $i <= $to; $i += $stepSize) {
+ $values[] = $i;
+ }
+ sort($values);
+ }
+ else {
+ $values = array($expression);
+ }
+
+ return $values;
+ }
+
+}
diff --git a/vendor/mtdowling/cron-expression/src/Cron/CronExpression.php b/vendor/mtdowling/cron-expression/src/Cron/CronExpression.php
new file mode 100644
index 000000000..d69b4154e
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/src/Cron/CronExpression.php
@@ -0,0 +1,389 @@
+ '0 0 1 1 *',
+ '@annually' => '0 0 1 1 *',
+ '@monthly' => '0 0 1 * *',
+ '@weekly' => '0 0 * * 0',
+ '@daily' => '0 0 * * *',
+ '@hourly' => '0 * * * *'
+ );
+
+ if (isset($mappings[$expression])) {
+ $expression = $mappings[$expression];
+ }
+
+ return new static($expression, $fieldFactory ?: new FieldFactory());
+ }
+
+ /**
+ * Validate a CronExpression.
+ *
+ * @param string $expression The CRON expression to validate.
+ *
+ * @return bool True if a valid CRON expression was passed. False if not.
+ * @see \Cron\CronExpression::factory
+ */
+ public static function isValidExpression($expression)
+ {
+ try {
+ self::factory($expression);
+ } catch (InvalidArgumentException $e) {
+ return false;
+ }
+
+ return true;
+ }
+
+ /**
+ * Parse a CRON expression
+ *
+ * @param string $expression CRON expression (e.g. '8 * * * *')
+ * @param FieldFactory $fieldFactory Factory to create cron fields
+ */
+ public function __construct($expression, FieldFactory $fieldFactory)
+ {
+ $this->fieldFactory = $fieldFactory;
+ $this->setExpression($expression);
+ }
+
+ /**
+ * Set or change the CRON expression
+ *
+ * @param string $value CRON expression (e.g. 8 * * * *)
+ *
+ * @return CronExpression
+ * @throws \InvalidArgumentException if not a valid CRON expression
+ */
+ public function setExpression($value)
+ {
+ $this->cronParts = preg_split('/\s/', $value, -1, PREG_SPLIT_NO_EMPTY);
+ if (count($this->cronParts) < 5) {
+ throw new InvalidArgumentException(
+ $value . ' is not a valid CRON expression'
+ );
+ }
+
+ foreach ($this->cronParts as $position => $part) {
+ $this->setPart($position, $part);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Set part of the CRON expression
+ *
+ * @param int $position The position of the CRON expression to set
+ * @param string $value The value to set
+ *
+ * @return CronExpression
+ * @throws \InvalidArgumentException if the value is not valid for the part
+ */
+ public function setPart($position, $value)
+ {
+ if (!$this->fieldFactory->getField($position)->validate($value)) {
+ throw new InvalidArgumentException(
+ 'Invalid CRON field value ' . $value . ' at position ' . $position
+ );
+ }
+
+ $this->cronParts[$position] = $value;
+
+ return $this;
+ }
+
+ /**
+ * Set max iteration count for searching next run dates
+ *
+ * @param int $maxIterationCount Max iteration count when searching for next run date
+ *
+ * @return CronExpression
+ */
+ public function setMaxIterationCount($maxIterationCount)
+ {
+ $this->maxIterationCount = $maxIterationCount;
+
+ return $this;
+ }
+
+ /**
+ * Get a next run date relative to the current date or a specific date
+ *
+ * @param string|\DateTime $currentTime Relative calculation date
+ * @param int $nth Number of matches to skip before returning a
+ * matching next run date. 0, the default, will return the current
+ * date and time if the next run date falls on the current date and
+ * time. Setting this value to 1 will skip the first match and go to
+ * the second match. Setting this value to 2 will skip the first 2
+ * matches and so on.
+ * @param bool $allowCurrentDate Set to TRUE to return the current date if
+ * it matches the cron expression.
+ *
+ * @return \DateTime
+ * @throws \RuntimeException on too many iterations
+ */
+ public function getNextRunDate($currentTime = 'now', $nth = 0, $allowCurrentDate = false)
+ {
+ return $this->getRunDate($currentTime, $nth, false, $allowCurrentDate);
+ }
+
+ /**
+ * Get a previous run date relative to the current date or a specific date
+ *
+ * @param string|\DateTime $currentTime Relative calculation date
+ * @param int $nth Number of matches to skip before returning
+ * @param bool $allowCurrentDate Set to TRUE to return the
+ * current date if it matches the cron expression
+ *
+ * @return \DateTime
+ * @throws \RuntimeException on too many iterations
+ * @see \Cron\CronExpression::getNextRunDate
+ */
+ public function getPreviousRunDate($currentTime = 'now', $nth = 0, $allowCurrentDate = false)
+ {
+ return $this->getRunDate($currentTime, $nth, true, $allowCurrentDate);
+ }
+
+ /**
+ * Get multiple run dates starting at the current date or a specific date
+ *
+ * @param int $total Set the total number of dates to calculate
+ * @param string|\DateTime $currentTime Relative calculation date
+ * @param bool $invert Set to TRUE to retrieve previous dates
+ * @param bool $allowCurrentDate Set to TRUE to return the
+ * current date if it matches the cron expression
+ *
+ * @return array Returns an array of run dates
+ */
+ public function getMultipleRunDates($total, $currentTime = 'now', $invert = false, $allowCurrentDate = false)
+ {
+ $matches = array();
+ for ($i = 0; $i < max(0, $total); $i++) {
+ try {
+ $matches[] = $this->getRunDate($currentTime, $i, $invert, $allowCurrentDate);
+ } catch (RuntimeException $e) {
+ break;
+ }
+ }
+
+ return $matches;
+ }
+
+ /**
+ * Get all or part of the CRON expression
+ *
+ * @param string $part Specify the part to retrieve or NULL to get the full
+ * cron schedule string.
+ *
+ * @return string|null Returns the CRON expression, a part of the
+ * CRON expression, or NULL if the part was specified but not found
+ */
+ public function getExpression($part = null)
+ {
+ if (null === $part) {
+ return implode(' ', $this->cronParts);
+ } elseif (array_key_exists($part, $this->cronParts)) {
+ return $this->cronParts[$part];
+ }
+
+ return null;
+ }
+
+ /**
+ * Helper method to output the full expression.
+ *
+ * @return string Full CRON expression
+ */
+ public function __toString()
+ {
+ return $this->getExpression();
+ }
+
+ /**
+ * Determine if the cron is due to run based on the current date or a
+ * specific date. This method assumes that the current number of
+ * seconds are irrelevant, and should be called once per minute.
+ *
+ * @param string|\DateTime $currentTime Relative calculation date
+ *
+ * @return bool Returns TRUE if the cron is due to run or FALSE if not
+ */
+ public function isDue($currentTime = 'now')
+ {
+ if ('now' === $currentTime) {
+ $currentDate = date('Y-m-d H:i');
+ $currentTime = strtotime($currentDate);
+ } elseif ($currentTime instanceof DateTime) {
+ $currentDate = clone $currentTime;
+ // Ensure time in 'current' timezone is used
+ $currentDate->setTimezone(new DateTimeZone(date_default_timezone_get()));
+ $currentDate = $currentDate->format('Y-m-d H:i');
+ $currentTime = strtotime($currentDate);
+ } elseif ($currentTime instanceof DateTimeImmutable) {
+ $currentDate = DateTime::createFromFormat('U', $currentTime->format('U'));
+ $currentDate->setTimezone(new DateTimeZone(date_default_timezone_get()));
+ $currentDate = $currentDate->format('Y-m-d H:i');
+ $currentTime = strtotime($currentDate);
+ } else {
+ $currentTime = new DateTime($currentTime);
+ $currentTime->setTime($currentTime->format('H'), $currentTime->format('i'), 0);
+ $currentDate = $currentTime->format('Y-m-d H:i');
+ $currentTime = $currentTime->getTimeStamp();
+ }
+
+ try {
+ return $this->getNextRunDate($currentDate, 0, true)->getTimestamp() == $currentTime;
+ } catch (Exception $e) {
+ return false;
+ }
+ }
+
+ /**
+ * Get the next or previous run date of the expression relative to a date
+ *
+ * @param string|\DateTime $currentTime Relative calculation date
+ * @param int $nth Number of matches to skip before returning
+ * @param bool $invert Set to TRUE to go backwards in time
+ * @param bool $allowCurrentDate Set to TRUE to return the
+ * current date if it matches the cron expression
+ *
+ * @return \DateTime
+ * @throws \RuntimeException on too many iterations
+ */
+ protected function getRunDate($currentTime = null, $nth = 0, $invert = false, $allowCurrentDate = false)
+ {
+ if ($currentTime instanceof DateTime) {
+ $currentDate = clone $currentTime;
+ } elseif ($currentTime instanceof DateTimeImmutable) {
+ $currentDate = DateTime::createFromFormat('U', $currentTime->format('U'));
+ $currentDate->setTimezone($currentTime->getTimezone());
+ } else {
+ $currentDate = new DateTime($currentTime ?: 'now');
+ $currentDate->setTimezone(new DateTimeZone(date_default_timezone_get()));
+ }
+
+ $currentDate->setTime($currentDate->format('H'), $currentDate->format('i'), 0);
+ $nextRun = clone $currentDate;
+ $nth = (int) $nth;
+
+ // We don't have to satisfy * or null fields
+ $parts = array();
+ $fields = array();
+ foreach (self::$order as $position) {
+ $part = $this->getExpression($position);
+ if (null === $part || '*' === $part) {
+ continue;
+ }
+ $parts[$position] = $part;
+ $fields[$position] = $this->fieldFactory->getField($position);
+ }
+
+ // Set a hard limit to bail on an impossible date
+ for ($i = 0; $i < $this->maxIterationCount; $i++) {
+
+ foreach ($parts as $position => $part) {
+ $satisfied = false;
+ // Get the field object used to validate this part
+ $field = $fields[$position];
+ // Check if this is singular or a list
+ if (strpos($part, ',') === false) {
+ $satisfied = $field->isSatisfiedBy($nextRun, $part);
+ } else {
+ foreach (array_map('trim', explode(',', $part)) as $listPart) {
+ if ($field->isSatisfiedBy($nextRun, $listPart)) {
+ $satisfied = true;
+ break;
+ }
+ }
+ }
+
+ // If the field is not satisfied, then start over
+ if (!$satisfied) {
+ $field->increment($nextRun, $invert, $part);
+ continue 2;
+ }
+ }
+
+ // Skip this match if needed
+ if ((!$allowCurrentDate && $nextRun == $currentDate) || --$nth > -1) {
+ $this->fieldFactory->getField(0)->increment($nextRun, $invert, isset($parts[0]) ? $parts[0] : null);
+ continue;
+ }
+
+ return $nextRun;
+ }
+
+ // @codeCoverageIgnoreStart
+ throw new RuntimeException('Impossible CRON expression');
+ // @codeCoverageIgnoreEnd
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/src/Cron/DayOfMonthField.php b/vendor/mtdowling/cron-expression/src/Cron/DayOfMonthField.php
new file mode 100644
index 000000000..53e15bc41
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/src/Cron/DayOfMonthField.php
@@ -0,0 +1,173 @@
+
+ */
+class DayOfMonthField extends AbstractField
+{
+ /**
+ * Get the nearest day of the week for a given day in a month
+ *
+ * @param int $currentYear Current year
+ * @param int $currentMonth Current month
+ * @param int $targetDay Target day of the month
+ *
+ * @return \DateTime Returns the nearest date
+ */
+ private static function getNearestWeekday($currentYear, $currentMonth, $targetDay)
+ {
+ $tday = str_pad($targetDay, 2, '0', STR_PAD_LEFT);
+ $target = DateTime::createFromFormat('Y-m-d', "$currentYear-$currentMonth-$tday");
+ $currentWeekday = (int) $target->format('N');
+
+ if ($currentWeekday < 6) {
+ return $target;
+ }
+
+ $lastDayOfMonth = $target->format('t');
+
+ foreach (array(-1, 1, -2, 2) as $i) {
+ $adjusted = $targetDay + $i;
+ if ($adjusted > 0 && $adjusted <= $lastDayOfMonth) {
+ $target->setDate($currentYear, $currentMonth, $adjusted);
+ if ($target->format('N') < 6 && $target->format('m') == $currentMonth) {
+ return $target;
+ }
+ }
+ }
+ }
+
+ public function isSatisfiedBy(DateTime $date, $value)
+ {
+ // ? states that the field value is to be skipped
+ if ($value == '?') {
+ return true;
+ }
+
+ $fieldValue = $date->format('d');
+
+ // Check to see if this is the last day of the month
+ if ($value == 'L') {
+ return $fieldValue == $date->format('t');
+ }
+
+ // Check to see if this is the nearest weekday to a particular value
+ if (strpos($value, 'W')) {
+ // Parse the target day
+ $targetDay = substr($value, 0, strpos($value, 'W'));
+ // Find out if the current day is the nearest day of the week
+ return $date->format('j') == self::getNearestWeekday(
+ $date->format('Y'),
+ $date->format('m'),
+ $targetDay
+ )->format('j');
+ }
+
+ return $this->isSatisfied($date->format('d'), $value);
+ }
+
+ public function increment(DateTime $date, $invert = false)
+ {
+ if ($invert) {
+ $date->modify('previous day');
+ $date->setTime(23, 59);
+ } else {
+ $date->modify('next day');
+ $date->setTime(0, 0);
+ }
+
+ return $this;
+ }
+
+ /**
+ * Validates that the value is valid for the Day of the Month field
+ * Days of the month can contain values of 1-31, *, L, or ? by default. This can be augmented with lists via a ',',
+ * ranges via a '-', or with a '[0-9]W' to specify the closest weekday.
+ *
+ * @param string $value
+ * @return bool
+ */
+ public function validate($value)
+ {
+ // Allow wildcards and a single L
+ if ($value === '?' || $value === '*' || $value === 'L') {
+ return true;
+ }
+
+ // If you only contain numbers and are within 1-31
+ if ((bool) preg_match('/^\d{1,2}$/', $value) && ($value >= 1 && $value <= 31)) {
+ return true;
+ }
+
+ // If you have a -, we will deal with each of your chunks
+ if ((bool) preg_match('/-/', $value)) {
+ // We cannot have a range within a list or vice versa
+ if ((bool) preg_match('/,/', $value)) {
+ return false;
+ }
+
+ $chunks = explode('-', $value);
+ foreach ($chunks as $chunk) {
+ if (!$this->validate($chunk)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ // If you have a comma, we will deal with each value
+ if ((bool) preg_match('/,/', $value)) {
+ // We cannot have a range within a list or vice versa
+ if ((bool) preg_match('/-/', $value)) {
+ return false;
+ }
+
+ $chunks = explode(',', $value);
+ foreach ($chunks as $chunk) {
+ if (!$this->validate($chunk)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ // If you contain a /, we'll deal with it
+ if ((bool) preg_match('/\//', $value)) {
+ $chunks = explode('/', $value);
+ foreach ($chunks as $chunk) {
+ if (!$this->validate($chunk)) {
+ return false;
+ }
+ }
+ return true;
+ }
+
+ // If you end in W, make sure that it has a numeric in front of it
+ if ((bool) preg_match('/^\d{1,2}W$/', $value)) {
+ return true;
+ }
+
+ return false;
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/src/Cron/DayOfWeekField.php b/vendor/mtdowling/cron-expression/src/Cron/DayOfWeekField.php
new file mode 100644
index 000000000..83e2f4c16
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/src/Cron/DayOfWeekField.php
@@ -0,0 +1,141 @@
+convertLiterals($value);
+
+ $currentYear = $date->format('Y');
+ $currentMonth = $date->format('m');
+ $lastDayOfMonth = $date->format('t');
+
+ // Find out if this is the last specific weekday of the month
+ if (strpos($value, 'L')) {
+ $weekday = str_replace('7', '0', substr($value, 0, strpos($value, 'L')));
+ $tdate = clone $date;
+ $tdate->setDate($currentYear, $currentMonth, $lastDayOfMonth);
+ while ($tdate->format('w') != $weekday) {
+ $tdateClone = new DateTime();
+ $tdate = $tdateClone
+ ->setTimezone($tdate->getTimezone())
+ ->setDate($currentYear, $currentMonth, --$lastDayOfMonth);
+ }
+
+ return $date->format('j') == $lastDayOfMonth;
+ }
+
+ // Handle # hash tokens
+ if (strpos($value, '#')) {
+ list($weekday, $nth) = explode('#', $value);
+
+ // 0 and 7 are both Sunday, however 7 matches date('N') format ISO-8601
+ if ($weekday === '0') {
+ $weekday = 7;
+ }
+
+ // Validate the hash fields
+ if ($weekday < 0 || $weekday > 7) {
+ throw new InvalidArgumentException("Weekday must be a value between 0 and 7. {$weekday} given");
+ }
+ if ($nth > 5) {
+ throw new InvalidArgumentException('There are never more than 5 of a given weekday in a month');
+ }
+ // The current weekday must match the targeted weekday to proceed
+ if ($date->format('N') != $weekday) {
+ return false;
+ }
+
+ $tdate = clone $date;
+ $tdate->setDate($currentYear, $currentMonth, 1);
+ $dayCount = 0;
+ $currentDay = 1;
+ while ($currentDay < $lastDayOfMonth + 1) {
+ if ($tdate->format('N') == $weekday) {
+ if (++$dayCount >= $nth) {
+ break;
+ }
+ }
+ $tdate->setDate($currentYear, $currentMonth, ++$currentDay);
+ }
+
+ return $date->format('j') == $currentDay;
+ }
+
+ // Handle day of the week values
+ if (strpos($value, '-')) {
+ $parts = explode('-', $value);
+ if ($parts[0] == '7') {
+ $parts[0] = '0';
+ } elseif ($parts[1] == '0') {
+ $parts[1] = '7';
+ }
+ $value = implode('-', $parts);
+ }
+
+ // Test to see which Sunday to use -- 0 == 7 == Sunday
+ $format = in_array(7, str_split($value)) ? 'N' : 'w';
+ $fieldValue = $date->format($format);
+
+ return $this->isSatisfied($fieldValue, $value);
+ }
+
+ public function increment(DateTime $date, $invert = false)
+ {
+ if ($invert) {
+ $date->modify('-1 day');
+ $date->setTime(23, 59, 0);
+ } else {
+ $date->modify('+1 day');
+ $date->setTime(0, 0, 0);
+ }
+
+ return $this;
+ }
+
+ public function validate($value)
+ {
+ $value = $this->convertLiterals($value);
+
+ foreach (explode(',', $value) as $expr) {
+ if (!preg_match('/^(\*|[0-7](L?|#[1-5]))([\/\,\-][0-7]+)*$/', $expr)) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ private function convertLiterals($string)
+ {
+ return str_ireplace(
+ array('SUN', 'MON', 'TUE', 'WED', 'THU', 'FRI', 'SAT'),
+ range(0, 6),
+ $string
+ );
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/src/Cron/FieldFactory.php b/vendor/mtdowling/cron-expression/src/Cron/FieldFactory.php
new file mode 100644
index 000000000..fa0e6fe23
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/src/Cron/FieldFactory.php
@@ -0,0 +1,57 @@
+fields[$position])) {
+ switch ($position) {
+ case 0:
+ $this->fields[$position] = new MinutesField();
+ break;
+ case 1:
+ $this->fields[$position] = new HoursField();
+ break;
+ case 2:
+ $this->fields[$position] = new DayOfMonthField();
+ break;
+ case 3:
+ $this->fields[$position] = new MonthField();
+ break;
+ case 4:
+ $this->fields[$position] = new DayOfWeekField();
+ break;
+ case 5:
+ $this->fields[$position] = new YearField();
+ break;
+ default:
+ throw new InvalidArgumentException(
+ $position . ' is not a valid position'
+ );
+ }
+ }
+
+ return $this->fields[$position];
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/src/Cron/FieldInterface.php b/vendor/mtdowling/cron-expression/src/Cron/FieldInterface.php
new file mode 100644
index 000000000..be37b9389
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/src/Cron/FieldInterface.php
@@ -0,0 +1,40 @@
+isSatisfied($date->format('H'), $value);
+ }
+
+ public function increment(DateTime $date, $invert = false, $parts = null)
+ {
+ // Change timezone to UTC temporarily. This will
+ // allow us to go back or forwards and hour even
+ // if DST will be changed between the hours.
+ if (is_null($parts) || $parts == '*') {
+ $timezone = $date->getTimezone();
+ $date->setTimezone(new DateTimeZone('UTC'));
+ if ($invert) {
+ $date->modify('-1 hour');
+ } else {
+ $date->modify('+1 hour');
+ }
+ $date->setTimezone($timezone);
+
+ $date->setTime($date->format('H'), $invert ? 59 : 0);
+ return $this;
+ }
+
+ $parts = strpos($parts, ',') !== false ? explode(',', $parts) : array($parts);
+ $hours = array();
+ foreach ($parts as $part) {
+ $hours = array_merge($hours, $this->getRangeForExpression($part, 23));
+ }
+
+ $current_hour = $date->format('H');
+ $position = $invert ? count($hours) - 1 : 0;
+ if (count($hours) > 1) {
+ for ($i = 0; $i < count($hours) - 1; $i++) {
+ if ((!$invert && $current_hour >= $hours[$i] && $current_hour < $hours[$i + 1]) ||
+ ($invert && $current_hour > $hours[$i] && $current_hour <= $hours[$i + 1])) {
+ $position = $invert ? $i : $i + 1;
+ break;
+ }
+ }
+ }
+
+ $hour = $hours[$position];
+ if ((!$invert && $date->format('H') >= $hour) || ($invert && $date->format('H') <= $hour)) {
+ $date->modify(($invert ? '-' : '+') . '1 day');
+ $date->setTime($invert ? 23 : 0, $invert ? 59 : 0);
+ }
+ else {
+ $date->setTime($hour, $invert ? 59 : 0);
+ }
+
+ return $this;
+ }
+
+ public function validate($value)
+ {
+ return (bool) preg_match('/^[\*,\/\-0-9]+$/', $value);
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/src/Cron/MinutesField.php b/vendor/mtdowling/cron-expression/src/Cron/MinutesField.php
new file mode 100644
index 000000000..d8432b55e
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/src/Cron/MinutesField.php
@@ -0,0 +1,62 @@
+isSatisfied($date->format('i'), $value);
+ }
+
+ public function increment(DateTime $date, $invert = false, $parts = null)
+ {
+ if (is_null($parts)) {
+ if ($invert) {
+ $date->modify('-1 minute');
+ } else {
+ $date->modify('+1 minute');
+ }
+ return $this;
+ }
+
+ $parts = strpos($parts, ',') !== false ? explode(',', $parts) : array($parts);
+ $minutes = array();
+ foreach ($parts as $part) {
+ $minutes = array_merge($minutes, $this->getRangeForExpression($part, 59));
+ }
+
+ $current_minute = $date->format('i');
+ $position = $invert ? count($minutes) - 1 : 0;
+ if (count($minutes) > 1) {
+ for ($i = 0; $i < count($minutes) - 1; $i++) {
+ if ((!$invert && $current_minute >= $minutes[$i] && $current_minute < $minutes[$i + 1]) ||
+ ($invert && $current_minute > $minutes[$i] && $current_minute <= $minutes[$i + 1])) {
+ $position = $invert ? $i : $i + 1;
+ break;
+ }
+ }
+ }
+
+ if ((!$invert && $current_minute >= $minutes[$position]) || ($invert && $current_minute <= $minutes[$position])) {
+ $date->modify(($invert ? '-' : '+') . '1 hour');
+ $date->setTime($date->format('H'), $invert ? 59 : 0);
+ }
+ else {
+ $date->setTime($date->format('H'), $minutes[$position]);
+ }
+
+ return $this;
+ }
+
+ public function validate($value)
+ {
+ return (bool) preg_match('/^[\*,\/\-0-9]+$/', $value);
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/src/Cron/MonthField.php b/vendor/mtdowling/cron-expression/src/Cron/MonthField.php
new file mode 100644
index 000000000..0205c171a
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/src/Cron/MonthField.php
@@ -0,0 +1,44 @@
+isSatisfied($date->format('m'), $value);
+ }
+
+ public function increment(DateTime $date, $invert = false)
+ {
+ if ($invert) {
+ $date->modify('last day of previous month');
+ $date->setTime(23, 59);
+ } else {
+ $date->modify('first day of next month');
+ $date->setTime(0, 0);
+ }
+
+ return $this;
+ }
+
+ public function validate($value)
+ {
+ return (bool) preg_match('/^[\*,\/\-0-9A-Z]+$/', $value);
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/src/Cron/YearField.php b/vendor/mtdowling/cron-expression/src/Cron/YearField.php
new file mode 100644
index 000000000..db244fba2
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/src/Cron/YearField.php
@@ -0,0 +1,37 @@
+isSatisfied($date->format('Y'), $value);
+ }
+
+ public function increment(DateTime $date, $invert = false)
+ {
+ if ($invert) {
+ $date->modify('-1 year');
+ $date->setDate($date->format('Y'), 12, 31);
+ $date->setTime(23, 59, 0);
+ } else {
+ $date->modify('+1 year');
+ $date->setDate($date->format('Y'), 1, 1);
+ $date->setTime(0, 0, 0);
+ }
+
+ return $this;
+ }
+
+ public function validate($value)
+ {
+ return (bool) preg_match('/^[\*,\/\-0-9]+$/', $value);
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/tests/Cron/AbstractFieldTest.php b/vendor/mtdowling/cron-expression/tests/Cron/AbstractFieldTest.php
new file mode 100644
index 000000000..a1d653b27
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/tests/Cron/AbstractFieldTest.php
@@ -0,0 +1,86 @@
+
+ */
+class AbstractFieldTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @covers Cron\AbstractField::isRange
+ */
+ public function testTestsIfRange()
+ {
+ $f = new DayOfWeekField();
+ $this->assertTrue($f->isRange('1-2'));
+ $this->assertFalse($f->isRange('2'));
+ }
+
+ /**
+ * @covers Cron\AbstractField::isIncrementsOfRanges
+ */
+ public function testTestsIfIncrementsOfRanges()
+ {
+ $f = new DayOfWeekField();
+ $this->assertFalse($f->isIncrementsOfRanges('1-2'));
+ $this->assertTrue($f->isIncrementsOfRanges('1/2'));
+ $this->assertTrue($f->isIncrementsOfRanges('*/2'));
+ $this->assertTrue($f->isIncrementsOfRanges('3-12/2'));
+ }
+
+ /**
+ * @covers Cron\AbstractField::isInRange
+ */
+ public function testTestsIfInRange()
+ {
+ $f = new DayOfWeekField();
+ $this->assertTrue($f->isInRange('1', '1-2'));
+ $this->assertTrue($f->isInRange('2', '1-2'));
+ $this->assertTrue($f->isInRange('5', '4-12'));
+ $this->assertFalse($f->isInRange('3', '4-12'));
+ $this->assertFalse($f->isInRange('13', '4-12'));
+ }
+
+ /**
+ * @covers Cron\AbstractField::isInIncrementsOfRanges
+ */
+ public function testTestsIfInIncrementsOfRanges()
+ {
+ $f = new DayOfWeekField();
+ $this->assertTrue($f->isInIncrementsOfRanges('3', '3-59/2'));
+ $this->assertTrue($f->isInIncrementsOfRanges('13', '3-59/2'));
+ $this->assertTrue($f->isInIncrementsOfRanges('15', '3-59/2'));
+ $this->assertTrue($f->isInIncrementsOfRanges('14', '*/2'));
+ $this->assertFalse($f->isInIncrementsOfRanges('2', '3-59/13'));
+ $this->assertFalse($f->isInIncrementsOfRanges('14', '*/13'));
+ $this->assertFalse($f->isInIncrementsOfRanges('14', '3-59/2'));
+ $this->assertFalse($f->isInIncrementsOfRanges('3', '2-59'));
+ $this->assertFalse($f->isInIncrementsOfRanges('3', '2'));
+ $this->assertFalse($f->isInIncrementsOfRanges('3', '*'));
+ $this->assertFalse($f->isInIncrementsOfRanges('0', '*/0'));
+ $this->assertFalse($f->isInIncrementsOfRanges('1', '*/0'));
+
+ $this->assertTrue($f->isInIncrementsOfRanges('4', '4/10'));
+ $this->assertTrue($f->isInIncrementsOfRanges('14', '4/10'));
+ $this->assertTrue($f->isInIncrementsOfRanges('34', '4/10'));
+ }
+
+ /**
+ * @covers Cron\AbstractField::isSatisfied
+ */
+ public function testTestsIfSatisfied()
+ {
+ $f = new DayOfWeekField();
+ $this->assertTrue($f->isSatisfied('12', '3-13'));
+ $this->assertTrue($f->isSatisfied('15', '3-59/12'));
+ $this->assertTrue($f->isSatisfied('12', '*'));
+ $this->assertTrue($f->isSatisfied('12', '12'));
+ $this->assertFalse($f->isSatisfied('12', '3-11'));
+ $this->assertFalse($f->isSatisfied('12', '3-59/13'));
+ $this->assertFalse($f->isSatisfied('12', '11'));
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/tests/Cron/CronExpressionTest.php b/vendor/mtdowling/cron-expression/tests/Cron/CronExpressionTest.php
new file mode 100644
index 000000000..f6fedb989
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/tests/Cron/CronExpressionTest.php
@@ -0,0 +1,414 @@
+
+ */
+class CronExpressionTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @covers Cron\CronExpression::factory
+ */
+ public function testFactoryRecognizesTemplates()
+ {
+ $this->assertEquals('0 0 1 1 *', CronExpression::factory('@annually')->getExpression());
+ $this->assertEquals('0 0 1 1 *', CronExpression::factory('@yearly')->getExpression());
+ $this->assertEquals('0 0 * * 0', CronExpression::factory('@weekly')->getExpression());
+ }
+
+ /**
+ * @covers Cron\CronExpression::__construct
+ * @covers Cron\CronExpression::getExpression
+ * @covers Cron\CronExpression::__toString
+ */
+ public function testParsesCronSchedule()
+ {
+ // '2010-09-10 12:00:00'
+ $cron = CronExpression::factory('1 2-4 * 4,5,6 */3');
+ $this->assertEquals('1', $cron->getExpression(CronExpression::MINUTE));
+ $this->assertEquals('2-4', $cron->getExpression(CronExpression::HOUR));
+ $this->assertEquals('*', $cron->getExpression(CronExpression::DAY));
+ $this->assertEquals('4,5,6', $cron->getExpression(CronExpression::MONTH));
+ $this->assertEquals('*/3', $cron->getExpression(CronExpression::WEEKDAY));
+ $this->assertEquals('1 2-4 * 4,5,6 */3', $cron->getExpression());
+ $this->assertEquals('1 2-4 * 4,5,6 */3', (string) $cron);
+ $this->assertNull($cron->getExpression('foo'));
+
+ try {
+ $cron = CronExpression::factory('A 1 2 3 4');
+ $this->fail('Validation exception not thrown');
+ } catch (InvalidArgumentException $e) {
+ }
+ }
+
+ /**
+ * @covers Cron\CronExpression::__construct
+ * @covers Cron\CronExpression::getExpression
+ * @dataProvider scheduleWithDifferentSeparatorsProvider
+ */
+ public function testParsesCronScheduleWithAnySpaceCharsAsSeparators($schedule, array $expected)
+ {
+ $cron = CronExpression::factory($schedule);
+ $this->assertEquals($expected[0], $cron->getExpression(CronExpression::MINUTE));
+ $this->assertEquals($expected[1], $cron->getExpression(CronExpression::HOUR));
+ $this->assertEquals($expected[2], $cron->getExpression(CronExpression::DAY));
+ $this->assertEquals($expected[3], $cron->getExpression(CronExpression::MONTH));
+ $this->assertEquals($expected[4], $cron->getExpression(CronExpression::WEEKDAY));
+ $this->assertEquals($expected[5], $cron->getExpression(CronExpression::YEAR));
+ }
+
+ /**
+ * Data provider for testParsesCronScheduleWithAnySpaceCharsAsSeparators
+ *
+ * @return array
+ */
+ public static function scheduleWithDifferentSeparatorsProvider()
+ {
+ return array(
+ array("*\t*\t*\t*\t*\t*", array('*', '*', '*', '*', '*', '*')),
+ array("* * * * * *", array('*', '*', '*', '*', '*', '*')),
+ array("* \t * \t * \t * \t * \t *", array('*', '*', '*', '*', '*', '*')),
+ array("*\t \t*\t \t*\t \t*\t \t*\t \t*", array('*', '*', '*', '*', '*', '*')),
+ );
+ }
+
+ /**
+ * @covers Cron\CronExpression::__construct
+ * @covers Cron\CronExpression::setExpression
+ * @covers Cron\CronExpression::setPart
+ * @expectedException InvalidArgumentException
+ */
+ public function testInvalidCronsWillFail()
+ {
+ // Only four values
+ $cron = CronExpression::factory('* * * 1');
+ }
+
+ /**
+ * @covers Cron\CronExpression::setPart
+ * @expectedException InvalidArgumentException
+ */
+ public function testInvalidPartsWillFail()
+ {
+ // Only four values
+ $cron = CronExpression::factory('* * * * *');
+ $cron->setPart(1, 'abc');
+ }
+
+ /**
+ * Data provider for cron schedule
+ *
+ * @return array
+ */
+ public function scheduleProvider()
+ {
+ return array(
+ array('*/2 */2 * * *', '2015-08-10 21:47:27', '2015-08-10 22:00:00', false),
+ array('* * * * *', '2015-08-10 21:50:37', '2015-08-10 21:50:00', true),
+ array('* 20,21,22 * * *', '2015-08-10 21:50:00', '2015-08-10 21:50:00', true),
+ // Handles CSV values
+ array('* 20,22 * * *', '2015-08-10 21:50:00', '2015-08-10 22:00:00', false),
+ // CSV values can be complex
+ array('* 5,21-22 * * *', '2015-08-10 21:50:00', '2015-08-10 21:50:00', true),
+ array('7-9 * */9 * *', '2015-08-10 22:02:33', '2015-08-18 00:07:00', false),
+ // 15th minute, of the second hour, every 15 days, in January, every Friday
+ array('1 * * * 7', '2015-08-10 21:47:27', '2015-08-16 00:01:00', false),
+ // Test with exact times
+ array('47 21 * * *', strtotime('2015-08-10 21:47:30'), '2015-08-10 21:47:00', true),
+ // Test Day of the week (issue #1)
+ // According cron implementation, 0|7 = sunday, 1 => monday, etc
+ array('* * * * 0', strtotime('2011-06-15 23:09:00'), '2011-06-19 00:00:00', false),
+ array('* * * * 7', strtotime('2011-06-15 23:09:00'), '2011-06-19 00:00:00', false),
+ array('* * * * 1', strtotime('2011-06-15 23:09:00'), '2011-06-20 00:00:00', false),
+ // Should return the sunday date as 7 equals 0
+ array('0 0 * * MON,SUN', strtotime('2011-06-15 23:09:00'), '2011-06-19 00:00:00', false),
+ array('0 0 * * 1,7', strtotime('2011-06-15 23:09:00'), '2011-06-19 00:00:00', false),
+ array('0 0 * * 0-4', strtotime('2011-06-15 23:09:00'), '2011-06-16 00:00:00', false),
+ array('0 0 * * 7-4', strtotime('2011-06-15 23:09:00'), '2011-06-16 00:00:00', false),
+ array('0 0 * * 4-7', strtotime('2011-06-15 23:09:00'), '2011-06-16 00:00:00', false),
+ array('0 0 * * 7-3', strtotime('2011-06-15 23:09:00'), '2011-06-19 00:00:00', false),
+ array('0 0 * * 3-7', strtotime('2011-06-15 23:09:00'), '2011-06-16 00:00:00', false),
+ array('0 0 * * 3-7', strtotime('2011-06-18 23:09:00'), '2011-06-19 00:00:00', false),
+ // Test lists of values and ranges (Abhoryo)
+ array('0 0 * * 2-7', strtotime('2011-06-20 23:09:00'), '2011-06-21 00:00:00', false),
+ array('0 0 * * 0,2-6', strtotime('2011-06-20 23:09:00'), '2011-06-21 00:00:00', false),
+ array('0 0 * * 2-7', strtotime('2011-06-18 23:09:00'), '2011-06-19 00:00:00', false),
+ array('0 0 * * 4-7', strtotime('2011-07-19 00:00:00'), '2011-07-21 00:00:00', false),
+ // Test increments of ranges
+ array('0-12/4 * * * *', strtotime('2011-06-20 12:04:00'), '2011-06-20 12:04:00', true),
+ array('4-59/2 * * * *', strtotime('2011-06-20 12:04:00'), '2011-06-20 12:04:00', true),
+ array('4-59/2 * * * *', strtotime('2011-06-20 12:06:00'), '2011-06-20 12:06:00', true),
+ array('4-59/3 * * * *', strtotime('2011-06-20 12:06:00'), '2011-06-20 12:07:00', false),
+ //array('0 0 * * 0,2-6', strtotime('2011-06-20 23:09:00'), '2011-06-21 00:00:00', false),
+ // Test Day of the Week and the Day of the Month (issue #1)
+ array('0 0 1 1 0', strtotime('2011-06-15 23:09:00'), '2012-01-01 00:00:00', false),
+ array('0 0 1 JAN 0', strtotime('2011-06-15 23:09:00'), '2012-01-01 00:00:00', false),
+ array('0 0 1 * 0', strtotime('2011-06-15 23:09:00'), '2012-01-01 00:00:00', false),
+ array('0 0 L * *', strtotime('2011-07-15 00:00:00'), '2011-07-31 00:00:00', false),
+ // Test the W day of the week modifier for day of the month field
+ array('0 0 2W * *', strtotime('2011-07-01 00:00:00'), '2011-07-01 00:00:00', true),
+ array('0 0 1W * *', strtotime('2011-05-01 00:00:00'), '2011-05-02 00:00:00', false),
+ array('0 0 1W * *', strtotime('2011-07-01 00:00:00'), '2011-07-01 00:00:00', true),
+ array('0 0 3W * *', strtotime('2011-07-01 00:00:00'), '2011-07-04 00:00:00', false),
+ array('0 0 16W * *', strtotime('2011-07-01 00:00:00'), '2011-07-15 00:00:00', false),
+ array('0 0 28W * *', strtotime('2011-07-01 00:00:00'), '2011-07-28 00:00:00', false),
+ array('0 0 30W * *', strtotime('2011-07-01 00:00:00'), '2011-07-29 00:00:00', false),
+ array('0 0 31W * *', strtotime('2011-07-01 00:00:00'), '2011-07-29 00:00:00', false),
+ // Test the year field
+ array('* * * * * 2012', strtotime('2011-05-01 00:00:00'), '2012-01-01 00:00:00', false),
+ // Test the last weekday of a month
+ array('* * * * 5L', strtotime('2011-07-01 00:00:00'), '2011-07-29 00:00:00', false),
+ array('* * * * 6L', strtotime('2011-07-01 00:00:00'), '2011-07-30 00:00:00', false),
+ array('* * * * 7L', strtotime('2011-07-01 00:00:00'), '2011-07-31 00:00:00', false),
+ array('* * * * 1L', strtotime('2011-07-24 00:00:00'), '2011-07-25 00:00:00', false),
+ array('* * * * TUEL', strtotime('2011-07-24 00:00:00'), '2011-07-26 00:00:00', false),
+ array('* * * 1 5L', strtotime('2011-12-25 00:00:00'), '2012-01-27 00:00:00', false),
+ // Test the hash symbol for the nth weekday of a given month
+ array('* * * * 5#2', strtotime('2011-07-01 00:00:00'), '2011-07-08 00:00:00', false),
+ array('* * * * 5#1', strtotime('2011-07-01 00:00:00'), '2011-07-01 00:00:00', true),
+ array('* * * * 3#4', strtotime('2011-07-01 00:00:00'), '2011-07-27 00:00:00', false),
+ );
+ }
+
+ /**
+ * @covers Cron\CronExpression::isDue
+ * @covers Cron\CronExpression::getNextRunDate
+ * @covers Cron\DayOfMonthField
+ * @covers Cron\DayOfWeekField
+ * @covers Cron\MinutesField
+ * @covers Cron\HoursField
+ * @covers Cron\MonthField
+ * @covers Cron\YearField
+ * @covers Cron\CronExpression::getRunDate
+ * @dataProvider scheduleProvider
+ */
+ public function testDeterminesIfCronIsDue($schedule, $relativeTime, $nextRun, $isDue)
+ {
+ $relativeTimeString = is_int($relativeTime) ? date('Y-m-d H:i:s', $relativeTime) : $relativeTime;
+
+ // Test next run date
+ $cron = CronExpression::factory($schedule);
+ if (is_string($relativeTime)) {
+ $relativeTime = new DateTime($relativeTime);
+ } elseif (is_int($relativeTime)) {
+ $relativeTime = date('Y-m-d H:i:s', $relativeTime);
+ }
+ $this->assertEquals($isDue, $cron->isDue($relativeTime));
+ $next = $cron->getNextRunDate($relativeTime, 0, true);
+ $this->assertEquals(new DateTime($nextRun), $next);
+ }
+
+ /**
+ * @covers Cron\CronExpression::isDue
+ */
+ public function testIsDueHandlesDifferentDates()
+ {
+ $cron = CronExpression::factory('* * * * *');
+ $this->assertTrue($cron->isDue());
+ $this->assertTrue($cron->isDue('now'));
+ $this->assertTrue($cron->isDue(new DateTime('now')));
+ $this->assertTrue($cron->isDue(date('Y-m-d H:i')));
+ }
+
+ /**
+ * @covers Cron\CronExpression::isDue
+ */
+ public function testIsDueHandlesDifferentTimezones()
+ {
+ $cron = CronExpression::factory('0 15 * * 3'); //Wednesday at 15:00
+ $date = '2014-01-01 15:00'; //Wednesday
+ $utc = new DateTimeZone('UTC');
+ $amsterdam = new DateTimeZone('Europe/Amsterdam');
+ $tokyo = new DateTimeZone('Asia/Tokyo');
+
+ date_default_timezone_set('UTC');
+ $this->assertTrue($cron->isDue(new DateTime($date, $utc)));
+ $this->assertFalse($cron->isDue(new DateTime($date, $amsterdam)));
+ $this->assertFalse($cron->isDue(new DateTime($date, $tokyo)));
+
+ date_default_timezone_set('Europe/Amsterdam');
+ $this->assertFalse($cron->isDue(new DateTime($date, $utc)));
+ $this->assertTrue($cron->isDue(new DateTime($date, $amsterdam)));
+ $this->assertFalse($cron->isDue(new DateTime($date, $tokyo)));
+
+ date_default_timezone_set('Asia/Tokyo');
+ $this->assertFalse($cron->isDue(new DateTime($date, $utc)));
+ $this->assertFalse($cron->isDue(new DateTime($date, $amsterdam)));
+ $this->assertTrue($cron->isDue(new DateTime($date, $tokyo)));
+ }
+
+ /**
+ * @covers Cron\CronExpression::getPreviousRunDate
+ */
+ public function testCanGetPreviousRunDates()
+ {
+ $cron = CronExpression::factory('* * * * *');
+ $next = $cron->getNextRunDate('now');
+ $two = $cron->getNextRunDate('now', 1);
+ $this->assertEquals($next, $cron->getPreviousRunDate($two));
+
+ $cron = CronExpression::factory('* */2 * * *');
+ $next = $cron->getNextRunDate('now');
+ $two = $cron->getNextRunDate('now', 1);
+ $this->assertEquals($next, $cron->getPreviousRunDate($two));
+
+ $cron = CronExpression::factory('* * * */2 *');
+ $next = $cron->getNextRunDate('now');
+ $two = $cron->getNextRunDate('now', 1);
+ $this->assertEquals($next, $cron->getPreviousRunDate($two));
+ }
+
+ /**
+ * @covers Cron\CronExpression::getMultipleRunDates
+ */
+ public function testProvidesMultipleRunDates()
+ {
+ $cron = CronExpression::factory('*/2 * * * *');
+ $this->assertEquals(array(
+ new DateTime('2008-11-09 00:00:00'),
+ new DateTime('2008-11-09 00:02:00'),
+ new DateTime('2008-11-09 00:04:00'),
+ new DateTime('2008-11-09 00:06:00')
+ ), $cron->getMultipleRunDates(4, '2008-11-09 00:00:00', false, true));
+ }
+
+ /**
+ * @covers Cron\CronExpression::getMultipleRunDates
+ * @covers Cron\CronExpression::setMaxIterationCount
+ */
+ public function testProvidesMultipleRunDatesForTheFarFuture() {
+ // Fails with the default 1000 iteration limit
+ $cron = CronExpression::factory('0 0 12 1 * */2');
+ $cron->setMaxIterationCount(2000);
+ $this->assertEquals(array(
+ new DateTime('2016-01-12 00:00:00'),
+ new DateTime('2018-01-12 00:00:00'),
+ new DateTime('2020-01-12 00:00:00'),
+ new DateTime('2022-01-12 00:00:00'),
+ new DateTime('2024-01-12 00:00:00'),
+ new DateTime('2026-01-12 00:00:00'),
+ new DateTime('2028-01-12 00:00:00'),
+ new DateTime('2030-01-12 00:00:00'),
+ new DateTime('2032-01-12 00:00:00'),
+ ), $cron->getMultipleRunDates(9, '2015-04-28 00:00:00', false, true));
+ }
+
+ /**
+ * @covers Cron\CronExpression
+ */
+ public function testCanIterateOverNextRuns()
+ {
+ $cron = CronExpression::factory('@weekly');
+ $nextRun = $cron->getNextRunDate("2008-11-09 08:00:00");
+ $this->assertEquals($nextRun, new DateTime("2008-11-16 00:00:00"));
+
+ // true is cast to 1
+ $nextRun = $cron->getNextRunDate("2008-11-09 00:00:00", true, true);
+ $this->assertEquals($nextRun, new DateTime("2008-11-16 00:00:00"));
+
+ // You can iterate over them
+ $nextRun = $cron->getNextRunDate($cron->getNextRunDate("2008-11-09 00:00:00", 1, true), 1, true);
+ $this->assertEquals($nextRun, new DateTime("2008-11-23 00:00:00"));
+
+ // You can skip more than one
+ $nextRun = $cron->getNextRunDate("2008-11-09 00:00:00", 2, true);
+ $this->assertEquals($nextRun, new DateTime("2008-11-23 00:00:00"));
+ $nextRun = $cron->getNextRunDate("2008-11-09 00:00:00", 3, true);
+ $this->assertEquals($nextRun, new DateTime("2008-11-30 00:00:00"));
+ }
+
+ /**
+ * @covers Cron\CronExpression::getRunDate
+ */
+ public function testSkipsCurrentDateByDefault()
+ {
+ $cron = CronExpression::factory('* * * * *');
+ $current = new DateTime('now');
+ $next = $cron->getNextRunDate($current);
+ $nextPrev = $cron->getPreviousRunDate($next);
+ $this->assertEquals($current->format('Y-m-d H:i:00'), $nextPrev->format('Y-m-d H:i:s'));
+ }
+
+ /**
+ * @covers Cron\CronExpression::getRunDate
+ * @ticket 7
+ */
+ public function testStripsForSeconds()
+ {
+ $cron = CronExpression::factory('* * * * *');
+ $current = new DateTime('2011-09-27 10:10:54');
+ $this->assertEquals('2011-09-27 10:11:00', $cron->getNextRunDate($current)->format('Y-m-d H:i:s'));
+ }
+
+ /**
+ * @covers Cron\CronExpression::getRunDate
+ */
+ public function testFixesPhpBugInDateIntervalMonth()
+ {
+ $cron = CronExpression::factory('0 0 27 JAN *');
+ $this->assertEquals('2011-01-27 00:00:00', $cron->getPreviousRunDate('2011-08-22 00:00:00')->format('Y-m-d H:i:s'));
+ }
+
+ public function testIssue29()
+ {
+ $cron = CronExpression::factory('@weekly');
+ $this->assertEquals(
+ '2013-03-10 00:00:00',
+ $cron->getPreviousRunDate('2013-03-17 00:00:00')->format('Y-m-d H:i:s')
+ );
+ }
+
+ /**
+ * @see https://github.com/mtdowling/cron-expression/issues/20
+ */
+ public function testIssue20() {
+ $e = CronExpression::factory('* * * * MON#1');
+ $this->assertTrue($e->isDue(new DateTime('2014-04-07 00:00:00')));
+ $this->assertFalse($e->isDue(new DateTime('2014-04-14 00:00:00')));
+ $this->assertFalse($e->isDue(new DateTime('2014-04-21 00:00:00')));
+
+ $e = CronExpression::factory('* * * * SAT#2');
+ $this->assertFalse($e->isDue(new DateTime('2014-04-05 00:00:00')));
+ $this->assertTrue($e->isDue(new DateTime('2014-04-12 00:00:00')));
+ $this->assertFalse($e->isDue(new DateTime('2014-04-19 00:00:00')));
+
+ $e = CronExpression::factory('* * * * SUN#3');
+ $this->assertFalse($e->isDue(new DateTime('2014-04-13 00:00:00')));
+ $this->assertTrue($e->isDue(new DateTime('2014-04-20 00:00:00')));
+ $this->assertFalse($e->isDue(new DateTime('2014-04-27 00:00:00')));
+ }
+
+ /**
+ * @covers Cron\CronExpression::getRunDate
+ */
+ public function testKeepOriginalTime()
+ {
+ $now = new \DateTime;
+ $strNow = $now->format(DateTime::ISO8601);
+ $cron = CronExpression::factory('0 0 * * *');
+ $cron->getPreviousRunDate($now);
+ $this->assertEquals($strNow, $now->format(DateTime::ISO8601));
+ }
+
+ /**
+ * @covers Cron\CronExpression::__construct
+ * @covers Cron\CronExpression::factory
+ * @covers Cron\CronExpression::isValidExpression
+ * @covers Cron\CronExpression::setExpression
+ * @covers Cron\CronExpression::setPart
+ */
+ public function testValidationWorks()
+ {
+ // Invalid. Only four values
+ $this->assertFalse(CronExpression::isValidExpression('* * * 1'));
+ // Valid
+ $this->assertTrue(CronExpression::isValidExpression('* * * * 1'));
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/tests/Cron/DayOfMonthFieldTest.php b/vendor/mtdowling/cron-expression/tests/Cron/DayOfMonthFieldTest.php
new file mode 100644
index 000000000..eff04557f
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/tests/Cron/DayOfMonthFieldTest.php
@@ -0,0 +1,61 @@
+
+ */
+class DayOfMonthFieldTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @covers Cron\DayOfMonthField::validate
+ */
+ public function testValidatesField()
+ {
+ $f = new DayOfMonthField();
+ $this->assertTrue($f->validate('1'));
+ $this->assertTrue($f->validate('*'));
+ $this->assertTrue($f->validate('5W,L'));
+ $this->assertFalse($f->validate('1.'));
+ }
+
+ /**
+ * @covers Cron\DayOfMonthField::isSatisfiedBy
+ */
+ public function testChecksIfSatisfied()
+ {
+ $f = new DayOfMonthField();
+ $this->assertTrue($f->isSatisfiedBy(new DateTime(), '?'));
+ }
+
+ /**
+ * @covers Cron\DayOfMonthField::increment
+ */
+ public function testIncrementsDate()
+ {
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f = new DayOfMonthField();
+ $f->increment($d);
+ $this->assertEquals('2011-03-16 00:00:00', $d->format('Y-m-d H:i:s'));
+
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f->increment($d, true);
+ $this->assertEquals('2011-03-14 23:59:00', $d->format('Y-m-d H:i:s'));
+ }
+
+ /**
+ * Day of the month cannot accept a 0 value, it must be between 1 and 31
+ * See Github issue #120
+ *
+ * @since 2017-01-22
+ */
+ public function testDoesNotAccept0Date()
+ {
+ $f = new DayOfMonthField();
+ $this->assertFalse($f->validate(0));
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/tests/Cron/DayOfWeekFieldTest.php b/vendor/mtdowling/cron-expression/tests/Cron/DayOfWeekFieldTest.php
new file mode 100644
index 000000000..182d5e906
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/tests/Cron/DayOfWeekFieldTest.php
@@ -0,0 +1,117 @@
+
+ */
+class DayOfWeekFieldTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @covers Cron\DayOfWeekField::validate
+ */
+ public function testValidatesField()
+ {
+ $f = new DayOfWeekField();
+ $this->assertTrue($f->validate('1'));
+ $this->assertTrue($f->validate('*'));
+ $this->assertTrue($f->validate('*/3,1,1-12'));
+ $this->assertTrue($f->validate('SUN-2'));
+ $this->assertFalse($f->validate('1.'));
+ }
+
+ /**
+ * @covers Cron\DayOfWeekField::isSatisfiedBy
+ */
+ public function testChecksIfSatisfied()
+ {
+ $f = new DayOfWeekField();
+ $this->assertTrue($f->isSatisfiedBy(new DateTime(), '?'));
+ }
+
+ /**
+ * @covers Cron\DayOfWeekField::increment
+ */
+ public function testIncrementsDate()
+ {
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f = new DayOfWeekField();
+ $f->increment($d);
+ $this->assertEquals('2011-03-16 00:00:00', $d->format('Y-m-d H:i:s'));
+
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f->increment($d, true);
+ $this->assertEquals('2011-03-14 23:59:00', $d->format('Y-m-d H:i:s'));
+ }
+
+ /**
+ * @covers Cron\DayOfWeekField::isSatisfiedBy
+ * @expectedException InvalidArgumentException
+ * @expectedExceptionMessage Weekday must be a value between 0 and 7. 12 given
+ */
+ public function testValidatesHashValueWeekday()
+ {
+ $f = new DayOfWeekField();
+ $this->assertTrue($f->isSatisfiedBy(new DateTime(), '12#1'));
+ }
+
+ /**
+ * @covers Cron\DayOfWeekField::isSatisfiedBy
+ * @expectedException InvalidArgumentException
+ * @expectedExceptionMessage There are never more than 5 of a given weekday in a month
+ */
+ public function testValidatesHashValueNth()
+ {
+ $f = new DayOfWeekField();
+ $this->assertTrue($f->isSatisfiedBy(new DateTime(), '3#6'));
+ }
+
+ /**
+ * @covers Cron\DayOfWeekField::validate
+ */
+ public function testValidateWeekendHash()
+ {
+ $f = new DayOfWeekField();
+ $this->assertTrue($f->validate('MON#1'));
+ $this->assertTrue($f->validate('TUE#2'));
+ $this->assertTrue($f->validate('WED#3'));
+ $this->assertTrue($f->validate('THU#4'));
+ $this->assertTrue($f->validate('FRI#5'));
+ $this->assertTrue($f->validate('SAT#1'));
+ $this->assertTrue($f->validate('SUN#3'));
+ $this->assertTrue($f->validate('MON#1,MON#3'));
+ }
+
+ /**
+ * @covers Cron\DayOfWeekField::isSatisfiedBy
+ */
+ public function testHandlesZeroAndSevenDayOfTheWeekValues()
+ {
+ $f = new DayOfWeekField();
+ $this->assertTrue($f->isSatisfiedBy(new DateTime('2011-09-04 00:00:00'), '0-2'));
+ $this->assertTrue($f->isSatisfiedBy(new DateTime('2011-09-04 00:00:00'), '6-0'));
+
+ $this->assertTrue($f->isSatisfiedBy(new DateTime('2014-04-20 00:00:00'), 'SUN'));
+ $this->assertTrue($f->isSatisfiedBy(new DateTime('2014-04-20 00:00:00'), 'SUN#3'));
+ $this->assertTrue($f->isSatisfiedBy(new DateTime('2014-04-20 00:00:00'), '0#3'));
+ $this->assertTrue($f->isSatisfiedBy(new DateTime('2014-04-20 00:00:00'), '7#3'));
+ }
+
+ /**
+ * @see https://github.com/mtdowling/cron-expression/issues/47
+ */
+ public function testIssue47() {
+ $f = new DayOfWeekField();
+ $this->assertFalse($f->validate('mon,'));
+ $this->assertFalse($f->validate('mon-'));
+ $this->assertFalse($f->validate('*/2,'));
+ $this->assertFalse($f->validate('-mon'));
+ $this->assertFalse($f->validate(',1'));
+ $this->assertFalse($f->validate('*-'));
+ $this->assertFalse($f->validate(',-'));
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/tests/Cron/FieldFactoryTest.php b/vendor/mtdowling/cron-expression/tests/Cron/FieldFactoryTest.php
new file mode 100644
index 000000000..f34cc9b58
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/tests/Cron/FieldFactoryTest.php
@@ -0,0 +1,43 @@
+
+ */
+class FieldFactoryTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @covers Cron\FieldFactory::getField
+ */
+ public function testRetrievesFieldInstances()
+ {
+ $mappings = array(
+ 0 => 'Cron\MinutesField',
+ 1 => 'Cron\HoursField',
+ 2 => 'Cron\DayOfMonthField',
+ 3 => 'Cron\MonthField',
+ 4 => 'Cron\DayOfWeekField',
+ 5 => 'Cron\YearField'
+ );
+
+ $f = new FieldFactory();
+
+ foreach ($mappings as $position => $class) {
+ $this->assertEquals($class, get_class($f->getField($position)));
+ }
+ }
+
+ /**
+ * @covers Cron\FieldFactory::getField
+ * @expectedException InvalidArgumentException
+ */
+ public function testValidatesFieldPosition()
+ {
+ $f = new FieldFactory();
+ $f->getField(-1);
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/tests/Cron/HoursFieldTest.php b/vendor/mtdowling/cron-expression/tests/Cron/HoursFieldTest.php
new file mode 100644
index 000000000..d2d8a22a6
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/tests/Cron/HoursFieldTest.php
@@ -0,0 +1,75 @@
+
+ */
+class HoursFieldTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @covers Cron\HoursField::validate
+ */
+ public function testValidatesField()
+ {
+ $f = new HoursField();
+ $this->assertTrue($f->validate('1'));
+ $this->assertTrue($f->validate('*'));
+ $this->assertTrue($f->validate('*/3,1,1-12'));
+ }
+
+ /**
+ * @covers Cron\HoursField::increment
+ */
+ public function testIncrementsDate()
+ {
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f = new HoursField();
+ $f->increment($d);
+ $this->assertEquals('2011-03-15 12:00:00', $d->format('Y-m-d H:i:s'));
+
+ $d->setTime(11, 15, 0);
+ $f->increment($d, true);
+ $this->assertEquals('2011-03-15 10:59:00', $d->format('Y-m-d H:i:s'));
+ }
+
+ /**
+ * @covers Cron\HoursField::increment
+ */
+ public function testIncrementsDateWithThirtyMinuteOffsetTimezone()
+ {
+ $tz = date_default_timezone_get();
+ date_default_timezone_set('America/St_Johns');
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f = new HoursField();
+ $f->increment($d);
+ $this->assertEquals('2011-03-15 12:00:00', $d->format('Y-m-d H:i:s'));
+
+ $d->setTime(11, 15, 0);
+ $f->increment($d, true);
+ $this->assertEquals('2011-03-15 10:59:00', $d->format('Y-m-d H:i:s'));
+ date_default_timezone_set($tz);
+ }
+
+ /**
+ * @covers Cron\HoursField::increment
+ */
+ public function testIncrementDateWithFifteenMinuteOffsetTimezone()
+ {
+ $tz = date_default_timezone_get();
+ date_default_timezone_set('Asia/Kathmandu');
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f = new HoursField();
+ $f->increment($d);
+ $this->assertEquals('2011-03-15 12:00:00', $d->format('Y-m-d H:i:s'));
+
+ $d->setTime(11, 15, 0);
+ $f->increment($d, true);
+ $this->assertEquals('2011-03-15 10:59:00', $d->format('Y-m-d H:i:s'));
+ date_default_timezone_set($tz);
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/tests/Cron/MinutesFieldTest.php b/vendor/mtdowling/cron-expression/tests/Cron/MinutesFieldTest.php
new file mode 100644
index 000000000..af3fef7ff
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/tests/Cron/MinutesFieldTest.php
@@ -0,0 +1,37 @@
+
+ */
+class MinutesFieldTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @covers Cron\MinutesField::validate
+ */
+ public function testValidatesField()
+ {
+ $f = new MinutesField();
+ $this->assertTrue($f->validate('1'));
+ $this->assertTrue($f->validate('*'));
+ $this->assertTrue($f->validate('*/3,1,1-12'));
+ }
+
+ /**
+ * @covers Cron\MinutesField::increment
+ */
+ public function testIncrementsDate()
+ {
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f = new MinutesField();
+ $f->increment($d);
+ $this->assertEquals('2011-03-15 11:16:00', $d->format('Y-m-d H:i:s'));
+ $f->increment($d, true);
+ $this->assertEquals('2011-03-15 11:15:00', $d->format('Y-m-d H:i:s'));
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/tests/Cron/MonthFieldTest.php b/vendor/mtdowling/cron-expression/tests/Cron/MonthFieldTest.php
new file mode 100644
index 000000000..2d9b0ad2d
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/tests/Cron/MonthFieldTest.php
@@ -0,0 +1,81 @@
+
+ */
+class MonthFieldTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @covers Cron\MonthField::validate
+ */
+ public function testValidatesField()
+ {
+ $f = new MonthField();
+ $this->assertTrue($f->validate('12'));
+ $this->assertTrue($f->validate('*'));
+ $this->assertTrue($f->validate('*/10,2,1-12'));
+ $this->assertFalse($f->validate('1.fix-regexp'));
+ }
+
+ /**
+ * @covers Cron\MonthField::increment
+ */
+ public function testIncrementsDate()
+ {
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f = new MonthField();
+ $f->increment($d);
+ $this->assertEquals('2011-04-01 00:00:00', $d->format('Y-m-d H:i:s'));
+
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f->increment($d, true);
+ $this->assertEquals('2011-02-28 23:59:00', $d->format('Y-m-d H:i:s'));
+ }
+
+ /**
+ * @covers Cron\MonthField::increment
+ */
+ public function testIncrementsDateWithThirtyMinuteTimezone()
+ {
+ $tz = date_default_timezone_get();
+ date_default_timezone_set('America/St_Johns');
+ $d = new DateTime('2011-03-31 11:59:59');
+ $f = new MonthField();
+ $f->increment($d);
+ $this->assertEquals('2011-04-01 00:00:00', $d->format('Y-m-d H:i:s'));
+
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f->increment($d, true);
+ $this->assertEquals('2011-02-28 23:59:00', $d->format('Y-m-d H:i:s'));
+ date_default_timezone_set($tz);
+ }
+
+
+ /**
+ * @covers Cron\MonthField::increment
+ */
+ public function testIncrementsYearAsNeeded()
+ {
+ $f = new MonthField();
+ $d = new DateTime('2011-12-15 00:00:00');
+ $f->increment($d);
+ $this->assertEquals('2012-01-01 00:00:00', $d->format('Y-m-d H:i:s'));
+ }
+
+ /**
+ * @covers Cron\MonthField::increment
+ */
+ public function testDecrementsYearAsNeeded()
+ {
+ $f = new MonthField();
+ $d = new DateTime('2011-01-15 00:00:00');
+ $f->increment($d, true);
+ $this->assertEquals('2010-12-31 23:59:00', $d->format('Y-m-d H:i:s'));
+ }
+}
diff --git a/vendor/mtdowling/cron-expression/tests/Cron/YearFieldTest.php b/vendor/mtdowling/cron-expression/tests/Cron/YearFieldTest.php
new file mode 100644
index 000000000..b5059ecec
--- /dev/null
+++ b/vendor/mtdowling/cron-expression/tests/Cron/YearFieldTest.php
@@ -0,0 +1,37 @@
+
+ */
+class YearFieldTest extends PHPUnit_Framework_TestCase
+{
+ /**
+ * @covers Cron\YearField::validate
+ */
+ public function testValidatesField()
+ {
+ $f = new YearField();
+ $this->assertTrue($f->validate('2011'));
+ $this->assertTrue($f->validate('*'));
+ $this->assertTrue($f->validate('*/10,2012,1-12'));
+ }
+
+ /**
+ * @covers Cron\YearField::increment
+ */
+ public function testIncrementsDate()
+ {
+ $d = new DateTime('2011-03-15 11:15:00');
+ $f = new YearField();
+ $f->increment($d);
+ $this->assertEquals('2012-01-01 00:00:00', $d->format('Y-m-d H:i:s'));
+ $f->increment($d, true);
+ $this->assertEquals('2011-12-31 23:59:00', $d->format('Y-m-d H:i:s'));
+ }
+}
diff --git a/vendor/myclabs/deep-copy/.gitattributes b/vendor/myclabs/deep-copy/.gitattributes
new file mode 100644
index 000000000..8018068b4
--- /dev/null
+++ b/vendor/myclabs/deep-copy/.gitattributes
@@ -0,0 +1,7 @@
+# Auto detect text files and perform LF normalization
+* text=auto
+
+*.png binary
+
+tests/ export-ignore
+phpunit.xml.dist export-ignore
diff --git a/vendor/myclabs/deep-copy/.gitignore b/vendor/myclabs/deep-copy/.gitignore
new file mode 100644
index 000000000..eef72f754
--- /dev/null
+++ b/vendor/myclabs/deep-copy/.gitignore
@@ -0,0 +1,3 @@
+/composer.phar
+/composer.lock
+/vendor/*
diff --git a/vendor/myclabs/deep-copy/.travis.yml b/vendor/myclabs/deep-copy/.travis.yml
new file mode 100644
index 000000000..89dc02af6
--- /dev/null
+++ b/vendor/myclabs/deep-copy/.travis.yml
@@ -0,0 +1,40 @@
+language: php
+
+sudo: false
+
+php:
+ - '5.6'
+ - '7.0'
+ - '7.1'
+ - nightly
+
+matrix:
+ fast_finish: true
+ include:
+ - php: '5.6'
+ env: COMPOSER_FLAGS="--prefer-lowest"
+ allow_failures:
+ - php: nightly
+
+cache:
+ directories:
+ - $HOME/.composer/cache/files
+
+before_install:
+ - |
+ if [ "$TRAVIS_PHP_VERSION" = "nightly" ]; then
+ COMPOSER_FLAGS="$COMPOSER_FLAGS --ignore-platform-reqs"
+ fi;
+
+install:
+ - composer update --no-interaction --no-progress --no-suggest --prefer-dist $COMPOSER_FLAGS
+ - wget https://github.com/satooshi/php-coveralls/releases/download/v1.0.0/coveralls.phar
+
+before_script:
+ - mkdir -p build/logs
+
+script:
+ - vendor/bin/phpunit --coverage-clover build/logs/clover.xml
+
+after_script:
+ - php coveralls.phar -v
diff --git a/vendor/myclabs/deep-copy/LICENSE b/vendor/myclabs/deep-copy/LICENSE
new file mode 100644
index 000000000..c3e835001
--- /dev/null
+++ b/vendor/myclabs/deep-copy/LICENSE
@@ -0,0 +1,20 @@
+The MIT License (MIT)
+
+Copyright (c) 2013 My C-Sense
+
+Permission is hereby granted, free of charge, to any person obtaining a copy of
+this software and associated documentation files (the "Software"), to deal in
+the Software without restriction, including without limitation the rights to
+use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
+the Software, and to permit persons to whom the Software is furnished to do so,
+subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
+FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
+COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
+IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
diff --git a/vendor/myclabs/deep-copy/README.md b/vendor/myclabs/deep-copy/README.md
new file mode 100644
index 000000000..7f010df2a
--- /dev/null
+++ b/vendor/myclabs/deep-copy/README.md
@@ -0,0 +1,372 @@
+# DeepCopy
+
+DeepCopy helps you create deep copies (clones) of your objects. It is designed to handle cycles in the association graph.
+
+[](https://travis-ci.org/myclabs/DeepCopy)
+[](https://coveralls.io/r/myclabs/DeepCopy?branch=master)
+[](https://scrutinizer-ci.com/g/myclabs/DeepCopy/)
+[](https://packagist.org/packages/myclabs/deep-copy)
+
+
+## Table of Contents
+
+1. [How](#how)
+1. [Why](#why)
+ 1. [Using simply `clone`](#using-simply-clone)
+ 1. [Overridding `__clone()`](#overridding-__clone)
+ 1. [With `DeepCopy`](#with-deepcopy)
+1. [How it works](#how-it-works)
+1. [Going further](#going-further)
+ 1. [Matchers](#matchers)
+ 1. [Property name](#property-name)
+ 1. [Specific property](#specific-property)
+ 1. [Type](#type)
+ 1. [Filters](#filters)
+ 1. [`SetNullFilter`](#setnullfilter-filter)
+ 1. [`KeepFilter`](#keepfilter-filter)
+ 1. [`DoctrineCollectionFilter`](#doctrinecollectionfilter-filter)
+ 1. [`DoctrineEmptyCollectionFilter`](#doctrineemptycollectionfilter-filter)
+ 1. [`DoctrineProxyFilter`](#doctrineproxyfilter-filter)
+ 1. [`ReplaceFilter`](#replacefilter-type-filter)
+ 1. [`ShallowCopyFilter`](#doctrinecollectionfilter-type-filter)
+1. [Edge cases](#edge-cases)
+1. [Contributing](#contributing)
+ 1. [Tests](#tests)
+
+
+## How?
+
+Install with Composer:
+
+```json
+composer require myclabs/deep-copy
+```
+
+Use simply:
+
+```php
+use DeepCopy\DeepCopy;
+
+$copier = new DeepCopy();
+$myCopy = $copier->copy($myObject);
+```
+
+
+## Why?
+
+- How do you create copies of your objects?
+
+```php
+$myCopy = clone $myObject;
+```
+
+- How do you create **deep** copies of your objects (i.e. copying also all the objects referenced in the properties)?
+
+You use [`__clone()`](http://www.php.net/manual/en/language.oop5.cloning.php#object.clone) and implement the behavior
+yourself.
+
+- But how do you handle **cycles** in the association graph?
+
+Now you're in for a big mess :(
+
+
+
+
+### Using simply `clone`
+
+
+
+
+### Overridding `__clone()`
+
+
+
+
+### With `DeepCopy`
+
+
+
+
+## How it works
+
+DeepCopy recursively traverses all the object's properties and clones them. To avoid cloning the same object twice it
+keeps a hash map of all instances and thus preserves the object graph.
+
+To use it:
+
+```php
+use function DeepCopy\deep_copy;
+
+$copy = deep_copy($var);
+```
+
+Alternatively, you can create your own `DeepCopy` instance to configure it differently for example:
+
+```php
+use DeepCopy\DeepCopy;
+
+$copier = new DeepCopy(true);
+
+$copy = $copier->copy($var);
+```
+
+You may want to roll your own deep copy function:
+
+```php
+namespace Acme;
+
+use DeepCopy\DeepCopy;
+
+function deep_copy($var)
+{
+ static $copier = null;
+
+ if (null === $copier) {
+ $copier = new DeepCopy(true);
+ }
+
+ return $copier->copy($var);
+}
+```
+
+
+## Going further
+
+You can add filters to customize the copy process.
+
+The method to add a filter is `DeepCopy\DeepCopy::addFilter($filter, $matcher)`,
+with `$filter` implementing `DeepCopy\Filter\Filter`
+and `$matcher` implementing `DeepCopy\Matcher\Matcher`.
+
+We provide some generic filters and matchers.
+
+
+### Matchers
+
+ - `DeepCopy\Matcher` applies on a object attribute.
+ - `DeepCopy\TypeMatcher` applies on any element found in graph, including array elements.
+
+
+#### Property name
+
+The `PropertyNameMatcher` will match a property by its name:
+
+```php
+use DeepCopy\Matcher\PropertyNameMatcher;
+
+// Will apply a filter to any property of any objects named "id"
+$matcher = new PropertyNameMatcher('id');
+```
+
+
+#### Specific property
+
+The `PropertyMatcher` will match a specific property of a specific class:
+
+```php
+use DeepCopy\Matcher\PropertyMatcher;
+
+// Will apply a filter to the property "id" of any objects of the class "MyClass"
+$matcher = new PropertyMatcher('MyClass', 'id');
+```
+
+
+#### Type
+
+The `TypeMatcher` will match any element by its type (instance of a class or any value that could be parameter of
+[gettype()](http://php.net/manual/en/function.gettype.php) function):
+
+```php
+use DeepCopy\TypeMatcher\TypeMatcher;
+
+// Will apply a filter to any object that is an instance of Doctrine\Common\Collections\Collection
+$matcher = new TypeMatcher('Doctrine\Common\Collections\Collection');
+```
+
+
+### Filters
+
+- `DeepCopy\Filter` applies a transformation to the object attribute matched by `DeepCopy\Matcher`
+- `DeepCopy\TypeFilter` applies a transformation to any element matched by `DeepCopy\TypeMatcher`
+
+
+#### `SetNullFilter` (filter)
+
+Let's say for example that you are copying a database record (or a Doctrine entity), so you want the copy not to have
+any ID:
+
+```php
+use DeepCopy\DeepCopy;
+use DeepCopy\Filter\SetNullFilter;
+use DeepCopy\Matcher\PropertyNameMatcher;
+
+$object = MyClass::load(123);
+echo $object->id; // 123
+
+$copier = new DeepCopy();
+$copier->addFilter(new SetNullFilter(), new PropertyNameMatcher('id'));
+
+$copy = $copier->copy($object);
+
+echo $copy->id; // null
+```
+
+
+#### `KeepFilter` (filter)
+
+If you want a property to remain untouched (for example, an association to an object):
+
+```php
+use DeepCopy\DeepCopy;
+use DeepCopy\Filter\KeepFilter;
+use DeepCopy\Matcher\PropertyMatcher;
+
+$copier = new DeepCopy();
+$copier->addFilter(new KeepFilter(), new PropertyMatcher('MyClass', 'category'));
+
+$copy = $copier->copy($object);
+// $copy->category has not been touched
+```
+
+
+#### `DoctrineCollectionFilter` (filter)
+
+If you use Doctrine and want to copy an entity, you will need to use the `DoctrineCollectionFilter`:
+
+```php
+use DeepCopy\DeepCopy;
+use DeepCopy\Filter\Doctrine\DoctrineCollectionFilter;
+use DeepCopy\Matcher\PropertyTypeMatcher;
+
+$copier = new DeepCopy();
+$copier->addFilter(new DoctrineCollectionFilter(), new PropertyTypeMatcher('Doctrine\Common\Collections\Collection'));
+
+$copy = $copier->copy($object);
+```
+
+
+#### `DoctrineEmptyCollectionFilter` (filter)
+
+If you use Doctrine and want to copy an entity who contains a `Collection` that you want to be reset, you can use the
+`DoctrineEmptyCollectionFilter`
+
+```php
+use DeepCopy\DeepCopy;
+use DeepCopy\Filter\Doctrine\DoctrineEmptyCollectionFilter;
+use DeepCopy\Matcher\PropertyMatcher;
+
+$copier = new DeepCopy();
+$copier->addFilter(new DoctrineEmptyCollectionFilter(), new PropertyMatcher('MyClass', 'myProperty'));
+
+$copy = $copier->copy($object);
+
+// $copy->myProperty will return an empty collection
+```
+
+
+#### `DoctrineProxyFilter` (filter)
+
+If you use Doctrine and use cloning on lazy loaded entities, you might encounter errors mentioning missing fields on a
+Doctrine proxy class (...\\\_\_CG\_\_\Proxy).
+You can use the `DoctrineProxyFilter` to load the actual entity behind the Doctrine proxy class.
+**Make sure, though, to put this as one of your very first filters in the filter chain so that the entity is loaded
+before other filters are applied!**
+
+```php
+use DeepCopy\DeepCopy;
+use DeepCopy\Filter\Doctrine\DoctrineProxyFilter;
+use DeepCopy\Matcher\Doctrine\DoctrineProxyMatcher;
+
+$copier = new DeepCopy();
+$copier->addFilter(new DoctrineProxyFilter(), new DoctrineProxyMatcher());
+
+$copy = $copier->copy($object);
+
+// $copy should now contain a clone of all entities, including those that were not yet fully loaded.
+```
+
+
+#### `ReplaceFilter` (type filter)
+
+1. If you want to replace the value of a property:
+
+```php
+use DeepCopy\DeepCopy;
+use DeepCopy\Filter\ReplaceFilter;
+use DeepCopy\Matcher\PropertyMatcher;
+
+$copier = new DeepCopy();
+$callback = function ($currentValue) {
+ return $currentValue . ' (copy)'
+};
+$copier->addFilter(new ReplaceFilter($callback), new PropertyMatcher('MyClass', 'title'));
+
+$copy = $copier->copy($object);
+
+// $copy->title will contain the data returned by the callback, e.g. 'The title (copy)'
+```
+
+2. If you want to replace whole element:
+
+```php
+use DeepCopy\DeepCopy;
+use DeepCopy\TypeFilter\ReplaceFilter;
+use DeepCopy\TypeMatcher\TypeMatcher;
+
+$copier = new DeepCopy();
+$callback = function (MyClass $myClass) {
+ return get_class($myClass);
+};
+$copier->addTypeFilter(new ReplaceFilter($callback), new TypeMatcher('MyClass'));
+
+$copy = $copier->copy([new MyClass, 'some string', new MyClass]);
+
+// $copy will contain ['MyClass', 'some string', 'MyClass']
+```
+
+
+The `$callback` parameter of the `ReplaceFilter` constructor accepts any PHP callable.
+
+
+#### `ShallowCopyFilter` (type filter)
+
+Stop *DeepCopy* from recursively copying element, using standard `clone` instead:
+
+```php
+use DeepCopy\DeepCopy;
+use DeepCopy\TypeFilter\ShallowCopyFilter;
+use DeepCopy\TypeMatcher\TypeMatcher;
+use Mockery as m;
+
+$this->deepCopy = new DeepCopy();
+$this->deepCopy->addTypeFilter(
+ new ShallowCopyFilter,
+ new TypeMatcher(m\MockInterface::class)
+);
+
+$myServiceWithMocks = new MyService(m::mock(MyDependency1::class), m::mock(MyDependency2::class));
+// All mocks will be just cloned, not deep copied
+```
+
+
+## Edge cases
+
+The following structures cannot be deep-copied with PHP Reflection. As a result they are shallow cloned and filters are
+not applied. There is two ways for you to handle them:
+
+- Implement your own `__clone()` method
+- Use a filter with a type matcher
+
+
+## Contributing
+
+DeepCopy is distributed under the MIT license.
+
+
+### Tests
+
+Running the tests is simple:
+
+```php
+vendor/bin/phpunit
+```
diff --git a/vendor/myclabs/deep-copy/composer.json b/vendor/myclabs/deep-copy/composer.json
new file mode 100644
index 000000000..d5d3a7798
--- /dev/null
+++ b/vendor/myclabs/deep-copy/composer.json
@@ -0,0 +1,35 @@
+{
+ "name": "myclabs/deep-copy",
+ "type": "library",
+ "description": "Create deep copies (clones) of your objects",
+ "keywords": ["clone", "copy", "duplicate", "object", "object graph"],
+ "license": "MIT",
+
+ "autoload": {
+ "psr-4": {
+ "DeepCopy\\": "src/DeepCopy/"
+ },
+ "files": [
+ "src/DeepCopy/deep_copy.php"
+ ]
+ },
+ "autoload-dev": {
+ "psr-4": {
+ "DeepCopy\\": "fixtures/",
+ "DeepCopyTest\\": "tests/DeepCopyTest/"
+ }
+ },
+
+ "require": {
+ "php": "^5.6 || ^7.0"
+ },
+ "require-dev": {
+ "doctrine/collections": "^1.0",
+ "doctrine/common": "^2.6",
+ "phpunit/phpunit": "^4.1"
+ },
+
+ "config": {
+ "sort-packages": true
+ }
+}
diff --git a/vendor/myclabs/deep-copy/doc/clone.png b/vendor/myclabs/deep-copy/doc/clone.png
new file mode 100644
index 0000000000000000000000000000000000000000..376afd491257d44a8c3772b0b7b0bd7b6c747086
GIT binary patch
literal 12380
zcmdsddpy)z_y3H+sH*yKN#S8~ckxM4S7|e)t&gnvlA(!El
zawkGAW5_8nLd1-_j>}+%k;{y`-yS;8d7kI{{XOUTe*gRZ{zxy|XYalCTI>B@Ywxvw
zHa9)D>APLuK_HM#7ta4+0fE4X5D4_z25~SlvHAB^@E;Usaqbi(w^4o+{341qG%OZc3(!$BZYHNt<;TJLmM2t?!Sg&z#90?^|W+?cY>oXut0Db^h_j9z$A`*Tvs{+ZgKAZ)Bjk7k#vBZ^VbaA9o+cZo76#
z^Sk}cFKI-W2~JO8C2XM*)8T^j7{7EmE3^HnOT(*VWkO+A*44{4ZT6fbo_8bis-r)U
zsmdoD1%Z&E65uEhm<%8M6yL{%LLidoSuhA>XH-5M0@2*#EDeD;8N5Y+3FQ9=C)7qI
zFLSY3QX3(|=3Vd%{=21cRD_j>W@a$7O5S~OPg`XiHNQ5>$a22UEacad2TTxTWISv^
z1!ti17I9j|WT;ku<<(fqQ37PxRca)w0Xn{cD0v~8msLM-bF?Mxa`0rBLeR`75%Rbe
zeCF~n882M^X?7+_O2}YPou=
z^G%r6H+@UP+BPMQM%Skx4H>mar-Vg8C-Y>k%z`_{rSaPoM8eXGS$+w9`RUo$xT<14PholFT;BZ2mzOzJSgC90ST5(&GJ>WP`W&o+mpK^yfI4He
zFDtGPHg}IccklAEN=|NhCbe*V1@E;LB6X)eR2L@CX1B3l^v=A{b}a1K?caUVHDO6V
z4^0dFh{wesQ+7K??wxHP)Xr%Np1@@>w9u2ccgS}K3wpB7E>BVD6$?n?HCLZK4!_~C
zx>8(1^PDBvO$)qN`QB~g77Ftp&RKW8a8LEg{ZkuXA9x?id|{$%LMX$Xx1_U^iJ4R;
zaZMj3NGG{PL0<5y)=G3rF5OpE>|O`5C8T0N&e6f}~0H?wQJY#nYHFZa{0o5)SgjC9Rhb7DO6
z-EmNejM<|?+4VLN6U0lVgBsPpAeFcclBmc+g5d)dG#@>ZR2>ybp(I5jP84G>M_^4`<-V=4}Q?)o3?;5
zdg%f!{Ww_X7XD6)>nf%DLnMx&rua*2{nbhD33d0`yZ|2yVRKsj
zHE(qxuT3d2Lr}p+wT%xS_@<9Epbxt@%fIiS2ejSqn|rT~E;Pv<&^RZ4MVmYQWWRJ(
zVqhH1exi@L+EK6C?TjzgUVT5w1u|3i5J(YMMBJfu90tcU#U
zm@bf-{^TRYNZpp;?Ea=xV$H+BAAco1?7X{f{f`TK+h8mTFbs@-#|^-FHo*$+b1-cI^#|Twn-vq@?^sP?ouTJ-8m<5lG;TUNtMV?o_d3%x9RD#v`fo?la
z`xWn;kn!F%zEWe8kpdnEyO~HEt6gVc;2*ObT6>RwU+{BeA8B>DZM>b6;~mTyo6e=L
zEQFDknWP*qrsbMz4#{gWSAxre$A%NU_1^dn8Toa!1Ct7Is|LV+jP~1rn+DO&FTp;T
zUr0symcEzkos1a6qt-=kgyOh;%&=a&6@9fo-BUqz{FUBxe3Sh35nd2mC#$PXg>tvs
zm!X!`^zl&zgQ8(mGM=_(On0d`msRw}Ku*_;^*7JVtn;>SJ)2~#J5kQ79K+YP1wPYf
zG(JDGCT^R2K4*Dxv2S%nQ2}$R+4!5sWbLP4$WbWOF?)vA_hk_anL<9ghjd~t3Y5?t
zmj57`%6QI-&`ZuMu2JI{Ub(F;%O>*Zl02$H&`Zqf;+wA-{4kswxLO%v&C8BSs0>;f
zP@oU5BF}x>?jC?^4}qPO^`7`Bsb89MBsV9
zwKM-2-=EhBE(^8r=Lm@SF{(CJ@PFC(X%OZwN76DJDue9)qb%!sNUwUM;*zR_Sx8WOml#9fdYZ9}mM{HY0YnN_oBc5)sD9qp$Q!m<62j
zOK6`3`M~ld@y7CUJZxAQIHG-6hhJJK+P}vSZbqoL%v9i|PSJ*l4N@8WuZ|SJK_FpF
z@w7T+$xky2Y>Ada2;S80p0H%9c74|KpD^0+Q7|7@tNS8>*Cem0?;J_{+R3csKiyxL
zv#{K^x_o)-@*;h8aqKwiGY7M}&?X=-)Jm*M;tL^8>ewXM$|!YZw4dMQt>2B&8<1@}
zF?RZ@A{UjZmk9G7&PLjq;uRPr@=JkfmeK4&1E&@a$WlESX7n
z{RDFDaS396D)$E?#l|f)pIou=R5eQZn;%5UrTaeb%XaH4t2mOp*^9-t7y24Q`gI%}mHbzD0W)?($lqzB$+XOje`L!TW8xZe
z{-+#AyuC>BvRe5*ZuP;IaK@!KOFF)mjZN10^YeDl{)zgWBd7@{yiNj>X2C9Tqxr
z21L*zH%bSss$A58%70B9H;V4PJFJVkH!76`xslmzF!b6F-;oz9m+neEay$II#g?TNxa#>G%DwMBgIh
z6?I;PZUk#G^}vjC;!ViGMU{-<
zOEAT|KbvTP@-N$AOX@aR)t@Z?w5n?mQaPn#w~BJ5#zjg59J-Sa-zsrLse2IfWtc=#
zc7uH2iIUxn3@+F*LK_P5vV_*-AN>4;Y_muk44!9=?4=x*AZoty_V4X}QkVo`Ja&5Q
zL@B(PkX>jTCp#{#^0KaS{0-SAL|Fu3tjw)`mTjhE*Y5fx$q7$}%=T*rc^WD1$omEBdD~gP1{lhlX
zFG~eAYC0Vio5=cBm7eoG@;fGd`;UKNRmzV6;UDT4dD-9#h6JO&vQB+Z{P4)1Y;$*J
zwB1Tda`G(`tys!+r?*yUC~S@Ta_cREsPrY5d#K=5bfYOa;=XWOmtr}))0gm#^UPi6okm+~Uuc_mxF$K?PFnFl-l46m%LJgny)EiH
zmtTDnw{`L>drWW_eS!xY!D>&`(+P+xYqU#Hyv$rBpo1}j)h7W8?#(Ao+w6i
zykdoN9~Qo>l6fMRexslFNKL}z!^Fsl$j$CoQiksDWTzq^&x6Zqyp
zjNl5kM28?>5UGYD*(>!UN8rMjk%Kz11p`f6&JI(cDcN`G=noTNJ1(_%C|PCaEk3or
z?P!NpW{tnU0L{zBZJSJyev7E7Gffwzac8b8hglO2X>Eht_%*wbQC;TSoNnFfhkyId
zD~-w)I1qKGDuXV*iC6)9yz6+r;tElP89wBTTvXb#kCmnm)YG`hYFM$qdP;&QsdO%&
zaBF?XzH@}dM~1nQ8wheNGbBWt7HWi?rlScYJ1kpVWxBrd2wh-bWy~^_76erJf`t`z
zUKX78{am7tbjKhR4CUWb3^Zw>_18Jvf+V^0*N>7D5st+BqPn)n!R`74?zN=suBn|v
z>9kO(_ZI8u5xqC#4iD+98@RkNV6=%KDWg?Q@E6
z@!u*AFiBw&N<)89Rqxc9@a~Txv%UMP1Hw_;)tpngueE%d>4~3IBkdYzpur3ed|9K{
zE}0jXy;2^J%W&lzMr(kfA}M6}z*fHPA?(kws#vl5sz=qEM@}z{2#sX0W+diI-3TPd
zUOjcDOM-wKg8pr=!aTax3#_3>f(G#PIFNuBCkeG!C@
zymRE4`iEKE58SF)Rm$d}!`oQSf~j4`dp>Y-9sYJHYxJZ}9wS8Q79|Bul$<_XEx(y>
zD~}C-Z_y4>nk?P6qge5D$il#NKv^7aw}G3iQB~F*Kd5y27QXEhc{g>PV#&jYFd}GK
zhpD_OI5wIoj6{G5aj=-74_4Gx&&wa(3i-a4v`JFx$>x>4>
z$as<*2YXsns~t&f?EH>XwI67&x`X=FjjUF4QQWFZL8VW*R;)sP!`4aiv<%-ioI6r)
z+O%ctrd!-Wm}zfB@MCBFrbUzXju^Rg0GJ!K%bO~e{Cj!c{m>ms+)p$~JvaEsPqTAc
z{ZE{02R^3zHoHgr;fKUk+B+Vcu7VBk<9<4Z4dh!QvmSk^^G+Lt|jk#`;7&EJkw4Eot{aJ??v2#`YQGDjZV1`EmX^|7_-u
zDm50e$=z?rrOyR}^LRjXQ!8sY;@1G8YZ8M>kNli}&c-+1QZ~h5;?x&Hb*_oGFh~Hl
z>d+X~A#{5*JFA_`^0l}-(Srr`z*cTi)Lw&k9r4T7BE1XKXVzD?ipchry}WYl*3GAq
zXt$jVyPbT?Kp|V*tXAh~0F~itPwGr{Bh~wd3=A4Ybjmm0KgD{M;cIsp|K>I#!RUi(
zP5iTo#l1EDAmWGo-1B-(Bo~!MimtM+lhZQNQY4wZQS*D}$g5hf-OeSXV3iqmgq8cM
zky!C*-S;nh43xU|i3UpLPdq16*bm8YF3dS{e*sKgr>9~Q`_gTLhYdPMDlUSwX1}(1
zd~RXbQ(daeiU(W*Fk3@fMU~zbeq7J3kC(-@PvnVK_+G%=771ny#4t%{0imLuX&h6(
zIQ>DQ_31b3}EUj*;(y#3r7b&S*|@mKpxN)IVp*RLg-axC#8bz~oel
zbAqSLBm~^|UTy8jpd1mCML2uOsxbD%mk2J{VJTncU(2O~tfRVks5A}+FJe3MH_gW}
z$WS~WBIWw{Fv)0%kmggTF3KJ{x9JEWScx@+{b)d|9L})nrAAVm*nV}nAm7soJJb(t
z0Fj*ID`6|E?)dn$M=N_^18f*@+z^+L12Q2|!?0uJv1lsW4WwG7PYXH8cOlb2_RP`v
zZT@D@;K;Dc;>}Ct&yUyx(|(Q^v6zpOOV=#XWlmLO?Y?yY+9c~rE)GW(U!^k7e=145
zbbz9Lb;I~2adw5*@ilw>n6w+G1H64UhMh)+H}7zc%=rK@j~L}nrfL%#SG#aW|Hr
z0>)(+plG4L?0vd@%E1JKAtlF>*(y@x5DB7#t$4GRsH@K%bkT{$L}u-uV0zW~uw7J_
ze0T%V;k
zQr`#jj0ly4i$i0-hj|iu(Swrq$bFaT~%1ih|o+&-U)dSE4H>pV%JP#g4ed{
z$BFFww}6eHbL%!TGy|&|-USJyM>SM}{AvR+(fFY_1-jR}rp0wcjgsXynPfDl3T_W&
zp+>#>j@Xh5*TPFg;DJ+kL>A
zT<(#okS%I$Gu52g{dTAXnL}B60#Y5D}Gn&
zhZC)a-o6*?)$_VRBALtpamHDR3Wql)$$=KS)2q
zv-lvC_l6!y5zNa4KyKX2KX(~fpJ>Qzt|mNjqOe;);4m!@HQG3I!vzhO3h>#YEHsv=
zE(CAL8rUUU!Pxx!eer}3)B9@N8zb5xIxOaGi|gDxj03!oH6PCmB15`6TjfRTI90gs
z$c{4n6L0O6OrxR4n;w85Gyc1{3XaiqMIHIE38s7ynukArr3&Wc^%kKjYf*3h*jdci
z&TidM;vL`(LAz5kftsLDVk7$-A~beAsP)X3i!gGz(FHA((($s(xw&}WZtY+
zv2G=yXYit6!6QvnH&ub0EI}kT#{cpaT!>_UFe?wOzm>E*;R56U_SDv;oeU8FBTLBe
zs>d6M#2aPe2fYh*WiK*LmbZGPXgOlp_dmaLWoghk@|w;arVDZb1dQG=NSN|}c-xz7
zWN@J7q6maxe!J%acqE7s-bErl_k7?LFI8?8x7`kvCI|1~j_<`P#qN!?6mQf$TNL`*
z3S5+Z@$Exy)Aa+E2)H(T1cO#U+FB4%Ll7hM>Bc~qri`<9lWWw$Fw>P|teL&1uZe#I
zHd10Kx!PixcXbhj8`;EhOGI=Uvm@ee3GIu;)W}jBvE}za1Y0k)vufgROWR1G$
zWfi!&%mH1~@u69ZjR6Fcn8JR9GK3$RUve%nG!7#!OfZHH$AbjJKGm&mzyZ-Esy|F&
zngn()R7cB9I$YgYr655+sj(ws`~bkw#biK@AmQelAr_~CCgtCpfJ#Fe%~*1Aem}5}fQ)k;I8%hp
z$b5@r#oHe`V(6hZ;1c3CALo|?@j2=2?KIT#R#eY$FhGfw1VCv8h|~$&Jh+cQi(z6`
zW*2lEB?5*7$JK-jpJT~AIkM4j-qH111MlT=tJwP5f(LTxK4|bswvW^{pPZ?{Y}$6*
zB*?wU_qOoGpFlGtFCsS<`jq26vbZw7p){F3XnYk(X0q{IRFllf6Rk?rY
z80X>v$c?-C+Hs>jkgaI`ncI#bd|_6X(jfE|BfQ#|G~LxHzTQdo{ut&nG8|IAm%GUo
z)A+sX0bSsP;E93~_Q@zYYzSGZfsLGgYOG+dKlymIaZxaz34_Gl%h&!%G({$`V8v~p
z>_c3v7VP&6YYC=r?4If!fsfhV$uA{zp6TfWHyIIrEOT3CE;a~h711AF6kZ&C+fgs}
z%cqk%vES!0rV<MeK<(&0fs|4HELnXeHTGQORF8b0Pwo>(TTn`Z|Z
zNysnRjC4=ltNJBl$sef`#W-=LUhueDqwk!j<{@EJk}PQy$>;e-J*zlg&q+;0ddx1I
zIM_c_bss2{@jX}V2U*FjvG%!(bt#nmSf27KZ&dR{PC=u3O{!eFfun>!0mUx5+}_tn
zAYgC1t&ob2OwO-N1^Oe8K@LTOz1=nw1?7FTlViywe`L7ZTp~#JMH^=87msW!3;iz9
z1g+Z2#G(5LI(Y(!J7QpKv(>Uq`j*ABvOSlEME6#o|46`4sR
z@*$;uXjRB&{&uJ3^GgY!#9w3h6&o^)wdOH~Ftv4i?Akk$wsEIkNs`+;s=bD0FQfe>
z&;-w6KU6R(`PM=9O~bsz(LAw=AleeCq8RE#+CWTFJ-1|>zxbeU?tvn#+Xa-TYN~S`
zOiRI|W7+s?tvMx4dn|mK!8uy(fr^SL3`}#!wlc%eDsbFXU~-68rl>A<2~knaV8-l_z&GEm*pAyDyvz;G(4UXiC){GJ
zUcTLXB>C(8Fdbe+;jT#;5#Z%}!fB0dBHbFxEgCuPV{Ptb!q*Zf*{MKBeK{(V^c7B;
zgx}>68(a`L*90pO^r>e|9f+n9*Du@QEx`g%xL1mZ%LlhMC05#0S@Md124+46gPd#C
zUv3R6pD1H^C_vJ8X>n1D9ZiT|y(+%G4-?k#Xjea|#wac^F{I_{P1@Z)lL_?sgtoj-
zmemgKP4u+3R_e-34O1|nusS!!S$#8Bx&s0MSM=@XNFoI~VMCg=k=EeU2huvDD1n`=
z$=1ueP}>^P_)AxOV-QjG)k!nAl~JP?;E}}c0VxhUWP)vt+SAouc~)8s(%>5;4%2;|ynmZgqH7y{P{
znvOs}R_D%>+~t0_KB(3iMwX8L-xpr*=lP#4EUb@M{^i0Ug7W{V#KCNxzDs|#@OtCU
zzm?d-N?6X7$^}k!q-`s8?zb>A(n4!n9up_DmP}yPh1sXfiWi+Q3s96I*(@g}8w(8;
zAw}$4XfG+t0c}^$+6=v-RZ{c#e#ApStyfM-+vYWqR;J$1qt!IOT;TA=YMw
z)6V)m%BR>{^dA{HT%t5XzMgbzKks?jmk2qjN>IAGOuuUOht0i1rW1PF&*@D)YOCVk
z-cixt|K+Yiu9tRB32oeyDH&*!htBcpvRs$cU`$x#t2RbYJyy))e7=eLf}<{WAH%N3
zHpAD=?qS82AZE-u^T25{LBGKt^B(F<*wSK~S~j*zFI6lJY2#EDlrv=~uO
zv#D*w)`VWGo{85_`M0M-9w65M0`y)wZd%`ONf2IsOW$jS~IN?xBP@mimHY
znE@PKLC?M2fv6Z#^G42%0!J7jjs^0dt+3-*6szzzA($Sd)}Y(p&De9CHAt#i#XYal
zpt~qfPZ{uP(RiS07@{jmF6s$;WozxIGeBw5
zy2tDJIy&<%nbh>!sZxT2r=qFZAw392O6~D|ETw*>5fhBGM)0VybXdPt6KW3!_fp%M
zFd)}w`ww#+_i@u=kM7wu!+PQHHr^OXoqF<8o?xOYC~ZQm)i2+eG@%SwtuRpZ1vHW<
zF;b*8auMD(ZPm_2&Gm=1<@H$(y-E*WH5&g_M#PfFCucWZktP<6pUrHEzJr2*CwXT2
z3ug@velD73-{WP^IsLnxUWwb#tGJLRqwz9f2a6YxoUhD?~_?#S>qe{71
zIdVqBKDe)>H_*ec{Lwlsu46{WzxP(F343L!6lkcpf)~uwaY(R9Ud(VPm@fkb)(=#d
z5gNQ=>~fxc1IJ%(4MlI!&&tlTj7{#o`+G}}UpWGB?(xB4)gdIc9vbO;I@XUSAdhnN
z{h7zMYXm^Eanczd2UaySgG!kZn=NR0wDy*{d)=6*`g2!6pzrP6EIl~&%$Jt`~g7qM`J}(
zwW%Jk?&~p74U%OZ{}@qioqA8?`pyp@q0Tpqar9@kNz>YGO`Otoa``V&&rR*VI|gj{
z0`$?YpEe_j^6z8dlH+Bk{L37ev~J4D1OH|Y04#7_`dG@pIn%%HBb?LYPyM%ZKu*!K)^zg^0{v?q;sP?J
zcN!s={;je=nq-9mo}*sGrn+N*mB16HWuY+gd`>211_M6V%-dUo{^)^O?DP=d)K=_d
z8fZWggK%T>Uq1a?!v*P)JP5g`Ga=u9v_+}y67cvdN@PJD&{2=^96E(p3(2
z+V=j*0gZK+V~+0sHRmWIP1k$(jbLF_aZ#VlDO99|z=)UT!K|z5;qC^i8NTTscc-^s
z;S4dES{h}KteLg=Iv1%&gQJU@9(4{M4pGV$(qCB*wvR3rzN`ENrtvfykS4tuArC$_
zilMk5Xn8XU@Q5_vwFFbTy9nG6v@!-K3_;ji{D5KTxBtf=&+LL}IjeU-X1c|EhAgBX
zuVrMjuwlLwv~6S0rR*?ib%gvgzsnyBN*={PukxU6&Fa#Yg$UQnxcHMbPd*PPIvQbJ
zEugs5k}KuOT;)$lMmxoi7y4nO_ypJA9=R%;uEwn5fo7e4{%n8Z%iAdB&Bz+!&8}1i
z7gmoT7$H0X*_=Snm_i#6ZVNPnnk2f_T>Az}G{
znmKGGs>7UA`DNwxU$HTTh?CFMv6iAJxkFiz!hf8}mA{4$W8^Q3IK+cABy-(ADT$Ql
zFI<~-^jYLT&2$Pkm})N`~=hx$)-ytyLvSL*naf{OOuv-Pg?FZJxJ%t^(t
z7h@e+<5rX@o2xLpM|-$tr)P+)DQ{Vg!0A+WYgibg6YosCd+4XuAM;7=PPB3ea?+cv
z9!(D^?W3fK@vSGbY`obMM7D=sS@nk}D`ZQE?BD>V
z2+XoX%5g=M<4Lm&N>t)ZcKcf)8IGuGINrycN3Q3D>B#Y*v!ns*|s?a
zPr9#9-+ZS|XEN{b-oXnhwbVPOz8ct?qN7E!-bB{I+%9}^kZ0~by=yRVGyoo-NfGnG
zU-;Ban~7Fhq3u6z5m2kw_)VPVK%5Md9L(Bsj78d
zvWOpa?$mmp5#R6AqS)CmUoXWz%b2ek2=<^vQ%3QaFbch5$vY{vYXYXV11QgL}Qs>7MpNmRWD%)_P1_;TIgh4jz`%4EQ*
zEZ8W2^G9B1r%xxL?Ebw`%jU-SsWLtrG7J-qnZd7}l+xG9Nhq?z&T=Kv9Kf
zIn1I(h@@E-QD4&X*bi^HtrT@N6*&I|>r)g1r3XV7o9~}$EY;a-1Cw~KPH-D_u+!;j
zZNQYxg71dlvCPRz)o&5#SnbiGy})K>OGipy9dtkB0SA@r-U)0Bi`7G9&%eJDrIZ}z
z9cX>dtIy^efBDora%}&rm)A!a6D95JNmp2M`6KEXr!jb~Sc&;@`LCfC1lC;UzB?oL
z8#maJ(Kj||B~!ij(5ZogbIeNbLG8t1WlR!P$$W{%YQb&YgUr6WcITc6$HvNgF-p2&qJ3eQ$B`?;!~6|7e*Z|VjS2^Y2Trxa8yC&+QJC&LZwl++I$nKJ8!uQOUL?GG?YA9muDfd`X?wNdH%}*1qyQX2oreipP)+!7ugE3RF4e#{Nc@H
z<*FsNuKSbjFqxB-?(18%nrKNb>DC`Z5+c54r^D9|RSfip%+z&`+>hVyTY1hicW1&<
zE>R_OMNQA_rTTT2mU!>xwN%@?lwEh)Yp;=`b)*4-obT0S4?D8A)KY_YG0T*QUq0mo
zmJC-GNx}ivs01Mbtfh`HxY!n$>)3a=gT$EYG7#am*pWQhU#-IQh>l@jqqQe9EA;e1sQArJ$i}Y_
z(FUCLjtas2aIt}s`e<6aYRn{=oO{C`;so-1?JUBj0t!)phkW91>pmgB1SbHz9=6hU-
zze0uj<7rf_%>28RBQ+DnDa8nf(E08%$IItb2)jh{4Rd5Cb9C`+%3IRj-#ENbUd}|O
zn`?z2_QVeGGwqstpvA5**JkVN1os-B@f8E;{ssQm{
z9<@4?Dqk$R9U-5Yo%^0vmGVwo1PUh|KaeuYkvwo3y(Mm1A(I~Eb)&2kDsP>YuWYl4
z%-l&>9iDY@Hj{#Qd8dn6%N|}7PT3n$k(?P%7DN5=ICR}?ym%;`)2T55MNGFQsdUQ!
z7BDjqx=?T?0qnIJA>SR;*n3j#lmK!?hZt#km!-?HQCUgCG})>R)wv5He|#VJ12qu{
zD$l@RRny#@!uq#9T`7vn-zs31zWgDI#yJ;=B*k9hifB+&i0YACX#i5S;x2-@N#H{J
zu}P5@>obsy&q7J6pW|5uXHsDg{M%)wd`syzNP0Eju@;|{m5Lxl*l|8dnJ!bh%i&P>
zb3^X5!PV~r;(ZvVCl@$r3E=YdJn2!5-RfmXPp@C@H70r5oCbF`y;AMOWn5;lwim~J
zKVivWm5jh4r2|(Vw@|q9Hr9F6NyPQ9wn*$NbG?d-zwB$NobG2)>tPW>pVnd?hfvq%
zo+lU2WIv8)q)z36%ah2F{nwhe?1$op5;7k2n;u@lU#Jkb?qXv?TX6tJM{p~&!@IaN
zQjrzvXL@FVe!v1iG>ARibKYkM6xA`aGd%NlDwiy{w64hfTv7kZ8xnbZTytt{@KkE?
zjY|gng{}7D=W9-Mufg>V0mEsHEhy}LH*+ly{19K}KV_s(tUWY5wjE08o{>#II4C0Y
ze6tKf-nW}*rI+b(GphhPqsQ4UZ#7viXD``PG_2WoaXA3J9&$YV@vGy|p8DgK^+Pk!
zAk?*9R`IRx(5bn1l#8%I@Vwv^7u%J9e??=HdDX
z!}~(UR)oCm+vWXda}IU0sO}a};mFYAOP!Cm3Ka8Skspg7k)G%7Te0`TKnpL)W_|zq
zM_ruS3T)YE7aHx<$uM2Eu(tY*kDo9$)h{Es@rI-^Yop`?=Lh}x!zR3zd!DVqHG%^q
z+LDfaw7b0Kx%+E|Rrew@cQ-;_V&qz%S`d(+B;T&aMlpZ)orKbj`EvgC_hh+m8gs_(
zg(Pq_wBRN_8cmS=ZppBywJu5K{Dpvmcc?xH%d!4I_It?DFQdv^*Qc
zC((_0S|`hgC@;bAnADiAYI{aGFY=7^{8z6G7ZuHYqG+`mL{Iur(xL3K0;-KP)rNN#
zh*-=t%t?My2bwz8Liv>`H0z9ZdY-es^-|U+Xv(L8-!?v&XxnmI79nrUpi2kK?68d%
zk7cGqy`2~h?C2_ju$$toHbQQwoInu)7;f5XO
z%z|KuHK>5M?{|4F1yW#m}v4Bc+Lt}(5-p+(8D5KWckY2Dg?oR#k?a)a#rCl
z+%zKR6^GVAL==PwTor#IW4!|GL5}{k7HM=YUkrKJi<+_7TcQW4IxDzKq9=XViq
z7`TI|bJ#>l2a(ret>o?-fWHpU_GDd$)PDnwEG8G|s)a=RE_GfNIGs?BwkUd>I_sn{cV1QEmpsrvoJypE*f
zLJkn>;qK*r^W+0F5l^|!kn2h6Xz{hLazb}c;pH|wgmz%upbsQH8DpkvmBakFh7W%s
zVz}N^-i`+%sJRK;8ZY2eTAdWDQ230bj?CX!{qSPK`48NrFF`{xiZm(G01?BXlw8F5
z-`c&+rVI1oA~20J*9)v%kAm#VB45&_iK6%#Hchz2%OjwXP4gTt#am>am#bwRZabkR
zSLz>gOM@Xyh&O81-LmxOBXmBRg!b@~ac9fa4@55vmrLCR@rlH!Hou%nQ0{a=OJe6X
zPKO^iUFN*pP7xxUOXnfoQWHDSNa|J7&k)@X5*LcdR#E6W9DWC*Q&~{l&_e2cz(3hjAY#f(2qemO)QDK%^$B?tEN7hd-%zj~h_ifA(C`&h#m
z6BFT23n^~|C^E{iGvUX3W>t6x(i`s)e
zv%c_BeE;^{g1qFRjw>Y+mRhSs!`fpn;dY+WSoYqZ&nIB=^_#MtX1rt)!zEgCm8j*o
zW9X2NG&--Q?_#Rn#rTd}$>H5|V&~=`?+`;>GLqVp$R<@+uU{^@tBU7w^}Ok)2ghB{
z^B3-~p5r6840vQ6;uh3x$m5;j`jh)SGJRE
zqJ>r}By1``uCQCh9W^}gp;8PbPaC}Z_9}^>HvJ1i#y3Ye?oAn43E{!h#z0!%DCAx>
zUsC?b!WUKOH-E7}toJlpu{CtN*%g3e^FW>8u=SOyW|GbAO&VtUoF;e1-F7K6V~)Q>
zarwnkJKF0F2#@`3ACUHL22;s#fu&rkYUg?9gAxwg@)us793)~GkI&+N?RwX=-K-Ow
zwiCxq?;W5WmN&anvBOW*9i!!vWbSfW{YS3*X$ipBI
z#l1(0J&p5PWrR1j(t7HIw$Jc$jFgSuZwE-!!JE;aqZJW7DS{b{Q
zN5STvJe4qh!h7X0PBWFJ?R#=3K`BCI?@Qh&Lv-}|wU_o}&j&LKb01t+2JwV@Zsz*z
zL3Bj>a4<U6IUZc
zd`eQs29m}mmlKjH^VlBB{yrZoeUwlaywK}hN`O24@#7tS0&=10od-l~a)-@NpjBD(
zNSju5u!->mgTibt;v3&d@Y+v*o_s|r?DYX*w6t@I1>?e9j43`4o7zoAAZr=2SskO*
zwLVXRGc*wsTm2I`*^<>7Z)4b0C+?SzD2;uAoatGC*6|X)4q;0wQRBS8R7%}Ruv+lz
zYCnDRV;$Ei`TKMDD*fp9p(z7=pC8ehu|6>BWgPKy6cNR^+k(YfQ-d=K*0}9Y8NV_Q
zl@|~Wrqa@zgr
z6>Af@xXKFo&?uh?99&6eRIHuAmGT#+yi5yPyrlE_QVxbq!?S6nX=+pbv{Ia(^~RUs
zb3rC1`NXEfw6WCH1RPVlXQHDtugN4`aT9hyinUb4w;t+z4Lr%dSi
zP<@Pc5A}dWO?JBu@}w5@4y|RDi1WY1NaS3YupP9iX_FMKoZH8_g86)f<}&DnL}Ii)
zOnGDaf}umwp>3S$8FpK62H_-PA}7&7Jpx>``3(bz8GUJS?t3b+Cvq~zm+d~;Z
zQkQ&)11B@e`@^=)BXZs^=;Y&@KsFYNi|ONJhy8IrQmD`|bUuEW!3qu8`a8T&BgK)5
z?)wY#c;a$-pBk-D&G<}WEIp`{6MT0mxFZYmxVr9$JdLzLx`B^!GXy|vLZ_b_BH`T9
z&%eD|hOym&`HN-nJ{LY-US>e2M+Y>8p^tW9QAZJZdWsRk71$2&;g-n@a&NLoz>#o0
zfe2w$tWDQN)X^2&Oavn0Mck1ear3k7I*E|miP6)j{~atA=b!y|U~8pNOAj)){$}5Q
zf@RGe`{m!j{sXJArrOc}hE-Th?{4ZO{2SPRVwEwr>0hx5i}=fj1OEzE6crN0pxu=P
z#i2g4HXY8F=8~}ag30!%R9Ig*m&FN|UUl>2GXe&SuWp9LvC^A>P31T%ZljK3n0gS
zpqO5FvK9mm#lBqU7iKHA6*&tSSo`6)~o&x+pFz-9k{6FB}%9o^xz=HmO<
zPRXrP54|5PItSF+F*Go}IN!d5M&AT=+dj^#T(EUd{(&okPE}DWK>%9jxmDtE$|_TWiak-$tSMw=#PNW7LPxnP0Yp1WursmJafajLRc
zgdej?Td*=c+&?g~bNXKsfJSS)COzv;
z^_<6JXUw6i-?T4|>Zu*;Z>6_tz~*!hyaZf`^3S*|Zgv4}vR7UIMSIvn8BOr~aJy`
zSw#y_x=x~cMZ?0h6o}{@_2|KgxMOh@i7)n)f^s6qHsEyjp?Zodz~)vD4mYy!t^I2W
zF=kyI@7%g93Hzo>(XTAKhCXr(^m_0nd~#3J4G_31+>u?{jM6z|n@-eWrN{YosaDyS15a4(ShF{)kKV2^^RRiKE+lcoX!@FJ-s}+b;_8uP8phaN
zw0bIh?bm$_LfLzXi!VxB)_4?2b#WUN97Wt&SX>TE2aTS}8Eo2q_JXNOD+b`VtoEl)iS~PfhH!idl~?URmU4%Nf!D2K
ze3_J~Sm5#oNyohl>l&(U{w)%8iY4V4V)jvQlu@!nY;Q>Eq_Y-5=~~GL6BezvS)f$z
zs0XsPZA;idy^u~SwbJ4%|1$H7
zuHX3I!W#C|IHInIVa(Ac16ZwL(4J3qsf)bG@p^{vvJsv~gdB
zM^7#hvt)5VzAs0!$Uo&vNjsZ0=%@~h_zfuj7}M_sFvE;$zR(x?yd4+rr2umtN%8g?
znbo-Y)l0g@X2DxviR?OizgKh2jym^tZRVMPKJl;ioJSem^xd9e?XmgZTwI}ad%Z@0
zLaqI8OGX!*VP4gKH~X0#{Z@|kD-R@RmKc9%SIAm=o5oD5mzBoX7@EVpz@gjD(Br;Y
zb&)3G7syCRu0X#6?zU4R6lL<~V9s9%Cx{mt&QY7_A
zy|jJK20uZ`s*t0ll@UKbQ?@)K@h#a!P0p58WL>U6!skZ7`EwcO+9eLb17NhZax
z7l#iTNt$fG8TT!_zucmAdt*;4d5tPWwk#7-C~fzicj>t&`8AQ-i*%3L79te8AcTjq
zEw#C03(plHsW$Mw{5@@zRnrGT%JB2uK8wSNrb|9;{pt>{nehu7LX);mNYa}_r_fFc
z?qn>bwYI$q1uOFzAKCAorn}$<&D+$Vw)pbdT)NzFm~+>6y>`bajaCCil;JsXQeTGn
zC^J#(zh##BML)`iz(=!bll0=fZkb=7LD@1{ONRu4&B&`!+oC0MCk#OJYbNAz-3P=(
z*{qZY4CQm(2ge1F|8qSWa>C#&A)+d63AB53#YqqXc7u;4Q;W`pt>Gx*q@F;ANCjBI
zZFCHA5*&rlXi2xf1B015P}*hsH-~%@Nxfr5(mzy-*F3SjQ>(dry6ergK!$P_!(%OLwsC)6?Z&=$H*M;MjZ!n%g&dK7v5pMpV~QJ+CiJy
zin!BSE0v=yBvC@^)ueH&Jx5P}_F-mrMS&Dq&AMOl1?1Ov?>5Ve`$eI^|AQlf8wkfOE^G+-r!
zljkmrl4gnM=V|p$3SufDFiRFf0iE~a=X!O;9a%dTmo8%6!<;mG!5wfkb
z*uFM_*Bbf+PhAe;5hO80LEGo{kH4nrc(ep@5{wQy!&vqKEO+2eR>D)T2YCE~Acc3rYRI*4kE^uJYZJV1?I;jUFuYA3jL{bs
zjafVZE?63+fzdt~;t60NqaDzIR0G>>hNpA^{jdy>u3+XJyqC0Q2?=)&mcdJYcm$((
zxfYB*?tn*|!RQT4@=L%G?#cKmb
zI92IZLvW4S9rp|-3)x=nfQy|DG$AG^N%4xb0L+kBK^?cOKsj|sNHNnMR|IoJ+HM)b
zbA(>u_sdR#8Y~F4D-^3C__k@xN$*Gt;u(P{hCB>}9F5?{(5-_Ea#ijn_dsQjU`0WK
zC=7zqtI@BJFsr>Vn=+XC<&_lcRcT4lg7|v02dorAzMBtY?C=Ki
zF(HOJ_3U>Pnd-1C{ysTx-ddMddX7nN!-$2e81+GmER|xlf>nDEoGKW
z_V`}u&@UewS4)4Nh{vf~@)sV2P3u3Xex)yE_}5eerop``4*E+r^dwQOk}FX?OAI%=T25?|a?zLNbOf3Edlww{l2=vx0&3E~wfYK-C(^8!!Me>XlGbrlDcSUpy7{KL~kFDv7CiUYf-j9-~;I-*x
za`-EdU=*42OVyK=!Jvy$nK@5cD#CbnTK6p#M{H035RMIEVsb}y64yu23*-U7jJ+$f28_N
zxC9tR{EkOjdWX3oJ;A~Eg=!1$)Bb>{=aVyo?e>Axcviak52FA%k2dg*1a->hgWS(5=$i~bDrXYf8kZz
z^g9n4l+}{^46fAa?CP)A=csGHr*HqkoEW9%G)aEnzV0Sag4JgE`ny>B_9_0fsOvb@
zVQ@`O7Yw%oU90aw7b9iLXmq~E5kJ{m;lXeT8Oyv<`g?#PoWFz1E|+%lK+tF!Ws00a
z!MmWHT9+IU=$*!X5wkCpF;}XR+E*yTe=EY>Z+m$>ly)J@ONqjWwRFhh#&8g$9$
z_Ib~>tK9q{MO8j>9DEm5m(I;r$z1A`?K8y?4qJOZnB;u%704(Mv8-x)XJtuks}Add`YS>%81fy^TJ<&l>4~Ch;htCumrsQq@YmRPjW@x9Gh~f&
zulFuWKk3*jon!2qwb?#0Or5fm;LaH--qBoMcg#CbGm;Ww}II-
z-jquG>p1$S=)ZIs`k}i&(K+@i>%WTWe(#%B{cUEDgfA#RQXt59Kk^Hpv!rez`LDSJ
z31>5$LzXh%y?(;xd7#my6GTFhqSB-q
zI-*obK$>(I2rZNVLVytRPQbbM&AoT-ygT3fzW4s{!|d#{_A0;iTWg<{@GAz|&;#5D
z004mMT+%WE00;&E7%YBd0#_K7-)ez>7~GAte+Ke#ytCkkAK>Tp&jY}_D3)#Oece(HpkOPX+XMVoStN7u$
zqDBX|B7^J+gIDL?T~0=QiMaMd%p*w07l!CFQW;CJ7f&7B$FU{)D1Ro_f)+v{RQJLb
z{T*)hIO8b!rR2br$z#oV0WaQE;?0%@hL!F?K|MrekcmNc06@*Lf<^$>;2S>x
zK&oL}Xp=||>tPS|UQoG~3F
zkoqu<|MYUOFxv3V+@qmd8r4QrPTZUr-&g@U01v;L2YUG