[COMPOSER] Add new php-ffmpeg package
This commit is contained in:
		| @@ -29,6 +29,7 @@ | |||||||
|         "openid/php-openid": "^2.3", |         "openid/php-openid": "^2.3", | ||||||
|         "paragonie/constant_time_encoding": "^1.0.4", |         "paragonie/constant_time_encoding": "^1.0.4", | ||||||
|         "pear/console_getopt": "^1.4", |         "pear/console_getopt": "^1.4", | ||||||
|  |         "php-ffmpeg/php-ffmpeg": "^0.16", | ||||||
|         "phpseclib/phpseclib": "dev-master#f815e43077da67d3dd5b4d18a45753f5b79c1ab9", |         "phpseclib/phpseclib": "dev-master#f815e43077da67d3dd5b4d18a45753f5b79c1ab9", | ||||||
|         "predis/predis": "^1.1", |         "predis/predis": "^1.1", | ||||||
|         "stomp-php/stomp-php": "^4.5.1" |         "stomp-php/stomp-php": "^4.5.1" | ||||||
|   | |||||||
							
								
								
									
										617
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										617
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							| @@ -4,8 +4,70 @@ | |||||||
|         "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", |         "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", | ||||||
|         "This file is @generated automatically" |         "This file is @generated automatically" | ||||||
|     ], |     ], | ||||||
|     "content-hash": "9ada0acf1c46320bb59933b35031a551", |     "content-hash": "4e2a2a7254378e2dc8be73be627b766b", | ||||||
|     "packages": [ |     "packages": [ | ||||||
|  |         { | ||||||
|  |             "name": "alchemy/binary-driver", | ||||||
|  |             "version": "v5.2.0", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/alchemy-fr/BinaryDriver.git", | ||||||
|  |                 "reference": "e0615cdff315e6b4b05ada67906df6262a020d22" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/alchemy-fr/BinaryDriver/zipball/e0615cdff315e6b4b05ada67906df6262a020d22", | ||||||
|  |                 "reference": "e0615cdff315e6b4b05ada67906df6262a020d22", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "evenement/evenement": "^3.0|^2.0|^1.0", | ||||||
|  |                 "php": ">=5.5", | ||||||
|  |                 "psr/log": "^1.0", | ||||||
|  |                 "symfony/process": "^2.3|^3.0|^4.0|^5.0" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "phpunit/phpunit": "^4.0|^5.0" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Alchemy": "src" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Nicolas Le Goff", | ||||||
|  |                     "email": "legoff.n@gmail.com" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Romain Neutron", | ||||||
|  |                     "email": "imprec@gmail.com", | ||||||
|  |                     "homepage": "http://www.lickmychip.com/" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Phraseanet Team", | ||||||
|  |                     "email": "info@alchemy.fr", | ||||||
|  |                     "homepage": "http://www.phraseanet.com/" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Jens Hausdorf", | ||||||
|  |                     "email": "mail@jens-hausdorf.de", | ||||||
|  |                     "homepage": "https://jens-hausdorf.de", | ||||||
|  |                     "role": "Maintainer" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "A set of tools to build binary drivers", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "binary", | ||||||
|  |                 "driver" | ||||||
|  |             ], | ||||||
|  |             "time": "2020-02-12T19:35:11+00:00" | ||||||
|  |         }, | ||||||
|         { |         { | ||||||
|             "name": "apereo/phpcas", |             "name": "apereo/phpcas", | ||||||
|             "version": "1.3.8", |             "version": "1.3.8", | ||||||
| @@ -202,6 +264,102 @@ | |||||||
|             ], |             ], | ||||||
|             "time": "2019-11-03T00:18:51+00:00" |             "time": "2019-11-03T00:18:51+00:00" | ||||||
|         }, |         }, | ||||||
|  |         { | ||||||
|  |             "name": "doctrine/cache", | ||||||
|  |             "version": "1.10.2", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/doctrine/cache.git", | ||||||
|  |                 "reference": "13e3381b25847283a91948d04640543941309727" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/doctrine/cache/zipball/13e3381b25847283a91948d04640543941309727", | ||||||
|  |                 "reference": "13e3381b25847283a91948d04640543941309727", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": "~7.1 || ^8.0" | ||||||
|  |             }, | ||||||
|  |             "conflict": { | ||||||
|  |                 "doctrine/common": ">2.2,<2.4" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "alcaeus/mongo-php-adapter": "^1.1", | ||||||
|  |                 "doctrine/coding-standard": "^6.0", | ||||||
|  |                 "mongodb/mongodb": "^1.1", | ||||||
|  |                 "phpunit/phpunit": "^7.0", | ||||||
|  |                 "predis/predis": "~1.0" | ||||||
|  |             }, | ||||||
|  |             "suggest": { | ||||||
|  |                 "alcaeus/mongo-php-adapter": "Required to use legacy MongoDB driver" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "1.9.x-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-4": { | ||||||
|  |                     "Doctrine\\Common\\Cache\\": "lib/Doctrine/Common/Cache" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "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" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "PHP Doctrine Cache library is a popular cache implementation that supports many different drivers such as redis, memcache, apc, mongodb and others.", | ||||||
|  |             "homepage": "https://www.doctrine-project.org/projects/cache.html", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "abstraction", | ||||||
|  |                 "apcu", | ||||||
|  |                 "cache", | ||||||
|  |                 "caching", | ||||||
|  |                 "couchdb", | ||||||
|  |                 "memcached", | ||||||
|  |                 "php", | ||||||
|  |                 "redis", | ||||||
|  |                 "xcache" | ||||||
|  |             ], | ||||||
|  |             "funding": [ | ||||||
|  |                 { | ||||||
|  |                     "url": "https://www.doctrine-project.org/sponsorship.html", | ||||||
|  |                     "type": "custom" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "url": "https://www.patreon.com/phpdoctrine", | ||||||
|  |                     "type": "patreon" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "url": "https://tidelift.com/funding/github/packagist/doctrine%2Fcache", | ||||||
|  |                     "type": "tidelift" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "time": "2020-07-07T18:54:01+00:00" | ||||||
|  |         }, | ||||||
|         { |         { | ||||||
|             "name": "embed/embed", |             "name": "embed/embed", | ||||||
|             "version": "v3.4.8", |             "version": "v3.4.8", | ||||||
| @@ -256,6 +414,49 @@ | |||||||
|             ], |             ], | ||||||
|             "time": "2020-07-03T15:04:01+00:00" |             "time": "2020-07-03T15:04:01+00:00" | ||||||
|         }, |         }, | ||||||
|  |         { | ||||||
|  |             "name": "evenement/evenement", | ||||||
|  |             "version": "v3.0.1", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/igorw/evenement.git", | ||||||
|  |                 "reference": "531bfb9d15f8aa57454f5f0285b18bec903b8fb7" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/igorw/evenement/zipball/531bfb9d15f8aa57454f5f0285b18bec903b8fb7", | ||||||
|  |                 "reference": "531bfb9d15f8aa57454f5f0285b18bec903b8fb7", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=7.0" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "phpunit/phpunit": "^6.0" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Evenement": "src" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Igor Wiedler", | ||||||
|  |                     "email": "igor@wiedler.ch" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Événement is a very simple event dispatching library for PHP", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "event-dispatcher", | ||||||
|  |                 "event-emitter" | ||||||
|  |             ], | ||||||
|  |             "time": "2017-07-23T21:35:13+00:00" | ||||||
|  |         }, | ||||||
|         { |         { | ||||||
|             "name": "ezyang/htmlpurifier", |             "name": "ezyang/htmlpurifier", | ||||||
|             "version": "v4.13.0", |             "version": "v4.13.0", | ||||||
| @@ -792,6 +993,46 @@ | |||||||
|             ], |             ], | ||||||
|             "time": "2019-12-02T02:32:27+00:00" |             "time": "2019-12-02T02:32:27+00:00" | ||||||
|         }, |         }, | ||||||
|  |         { | ||||||
|  |             "name": "neutron/temporary-filesystem", | ||||||
|  |             "version": "2.4", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/romainneutron/Temporary-Filesystem.git", | ||||||
|  |                 "reference": "3c55497da8d7762fb4dcabc91d54a5de510e3c99" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/romainneutron/Temporary-Filesystem/zipball/3c55497da8d7762fb4dcabc91d54a5de510e3c99", | ||||||
|  |                 "reference": "3c55497da8d7762fb4dcabc91d54a5de510e3c99", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": "^5.6 || ^7.0", | ||||||
|  |                 "symfony/filesystem": "^2.3 || ^3.0 || ^4.0 || ^5.0" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "symfony/phpunit-bridge": "^5.0.4" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Neutron": "src" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Romain Neutron", | ||||||
|  |                     "email": "imprec@gmail.com" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Symfony filesystem extension to handle temporary files", | ||||||
|  |             "time": "2020-02-17T15:27:36+00:00" | ||||||
|  |         }, | ||||||
|         { |         { | ||||||
|             "name": "openid/php-openid", |             "name": "openid/php-openid", | ||||||
|             "version": "2.3.0", |             "version": "2.3.0", | ||||||
| @@ -1000,6 +1241,90 @@ | |||||||
|             "description": "More info available on: http://pear.php.net/package/Console_Getopt", |             "description": "More info available on: http://pear.php.net/package/Console_Getopt", | ||||||
|             "time": "2019-11-20T18:27:48+00:00" |             "time": "2019-11-20T18:27:48+00:00" | ||||||
|         }, |         }, | ||||||
|  |         { | ||||||
|  |             "name": "php-ffmpeg/php-ffmpeg", | ||||||
|  |             "version": "v0.16", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/PHP-FFMpeg/PHP-FFMpeg.git", | ||||||
|  |                 "reference": "4175c02b7d9f7e1a02cec2ba73474266ba2c5fa1" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/PHP-FFMpeg/PHP-FFMpeg/zipball/4175c02b7d9f7e1a02cec2ba73474266ba2c5fa1", | ||||||
|  |                 "reference": "4175c02b7d9f7e1a02cec2ba73474266ba2c5fa1", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "alchemy/binary-driver": "^1.5 || ~2.0.0 || ^5.0", | ||||||
|  |                 "doctrine/cache": "^1.0", | ||||||
|  |                 "evenement/evenement": "^3.0 || ^2.0 || ^1.0", | ||||||
|  |                 "neutron/temporary-filesystem": "^2.1.1", | ||||||
|  |                 "php": "^5.3.9 || ^7.0" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "sami/sami": "~1.0", | ||||||
|  |                 "silex/silex": "~1.0", | ||||||
|  |                 "symfony/phpunit-bridge": "^5.0.4" | ||||||
|  |             }, | ||||||
|  |             "suggest": { | ||||||
|  |                 "php-ffmpeg/extras": "A compilation of common audio & video drivers for PHP-FFMpeg" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "0.7-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "FFMpeg": "src" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Romain Neutron", | ||||||
|  |                     "email": "imprec@gmail.com", | ||||||
|  |                     "homepage": "http://www.lickmychip.com/" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Phraseanet Team", | ||||||
|  |                     "email": "info@alchemy.fr", | ||||||
|  |                     "homepage": "http://www.phraseanet.com/" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Patrik Karisch", | ||||||
|  |                     "email": "patrik@karisch.guru", | ||||||
|  |                     "homepage": "http://www.karisch.guru" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Romain Biard", | ||||||
|  |                     "email": "romain.biard@gmail.com", | ||||||
|  |                     "homepage": "https://www.strime.io/" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Jens Hausdorf", | ||||||
|  |                     "email": "hello@jens-hausdorf.de", | ||||||
|  |                     "homepage": "https://jens-hausdorf.de" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "FFMpeg PHP, an Object Oriented library to communicate with AVconv / ffmpeg", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "audio", | ||||||
|  |                 "audio processing", | ||||||
|  |                 "avconv", | ||||||
|  |                 "avprobe", | ||||||
|  |                 "ffmpeg", | ||||||
|  |                 "ffprobe", | ||||||
|  |                 "video", | ||||||
|  |                 "video processing" | ||||||
|  |             ], | ||||||
|  |             "time": "2020-03-29T09:57:10+00:00" | ||||||
|  |         }, | ||||||
|         { |         { | ||||||
|             "name": "phpseclib/phpseclib", |             "name": "phpseclib/phpseclib", | ||||||
|             "version": "dev-master", |             "version": "dev-master", | ||||||
| @@ -1194,6 +1519,53 @@ | |||||||
|             ], |             ], | ||||||
|             "time": "2016-08-06T14:39:51+00:00" |             "time": "2016-08-06T14:39:51+00:00" | ||||||
|         }, |         }, | ||||||
|  |         { | ||||||
|  |             "name": "psr/log", | ||||||
|  |             "version": "1.1.3", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/php-fig/log.git", | ||||||
|  |                 "reference": "0f73288fd15629204f9d42b7055f72dacbe811fc" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/php-fig/log/zipball/0f73288fd15629204f9d42b7055f72dacbe811fc", | ||||||
|  |                 "reference": "0f73288fd15629204f9d42b7055f72dacbe811fc", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.0" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "1.1.x-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-4": { | ||||||
|  |                     "Psr\\Log\\": "Psr/Log/" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "PHP-FIG", | ||||||
|  |                     "homepage": "http://www.php-fig.org/" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Common interface for logging libraries", | ||||||
|  |             "homepage": "https://github.com/php-fig/log", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "log", | ||||||
|  |                 "psr", | ||||||
|  |                 "psr-3" | ||||||
|  |             ], | ||||||
|  |             "time": "2020-03-23T09:12:05+00:00" | ||||||
|  |         }, | ||||||
|         { |         { | ||||||
|             "name": "ralouphie/getallheaders", |             "name": "ralouphie/getallheaders", | ||||||
|             "version": "3.0.3", |             "version": "3.0.3", | ||||||
| @@ -1302,6 +1674,104 @@ | |||||||
|                 } |                 } | ||||||
|             ], |             ], | ||||||
|             "time": "2020-06-15T18:01:49+00:00" |             "time": "2020-06-15T18:01:49+00:00" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "symfony/filesystem", | ||||||
|  |             "version": "v3.0.9", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/symfony/filesystem.git", | ||||||
|  |                 "reference": "b2da5009d9bacbd91d83486aa1f44c793a8c380d" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/symfony/filesystem/zipball/b2da5009d9bacbd91d83486aa1f44c793a8c380d", | ||||||
|  |                 "reference": "b2da5009d9bacbd91d83486aa1f44c793a8c380d", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.5.9" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "3.0-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-4": { | ||||||
|  |                     "Symfony\\Component\\Filesystem\\": "" | ||||||
|  |                 }, | ||||||
|  |                 "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 Filesystem Component", | ||||||
|  |             "homepage": "https://symfony.com", | ||||||
|  |             "time": "2016-07-20T05:43:46+00:00" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "symfony/process", | ||||||
|  |             "version": "v2.8.52", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/symfony/process.git", | ||||||
|  |                 "reference": "c3591a09c78639822b0b290d44edb69bf9f05dc8" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/symfony/process/zipball/c3591a09c78639822b0b290d44edb69bf9f05dc8", | ||||||
|  |                 "reference": "c3591a09c78639822b0b290d44edb69bf9f05dc8", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.9" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "2.8-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "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", | ||||||
|  |             "time": "2018-11-11T11:18:13+00:00" | ||||||
|         } |         } | ||||||
|     ], |     ], | ||||||
|     "packages-dev": [ |     "packages-dev": [ | ||||||
| @@ -3356,53 +3826,6 @@ | |||||||
|             ], |             ], | ||||||
|             "time": "2017-02-14T16:28:37+00:00" |             "time": "2017-02-14T16:28:37+00:00" | ||||||
|         }, |         }, | ||||||
|         { |  | ||||||
|             "name": "psr/log", |  | ||||||
|             "version": "1.1.3", |  | ||||||
|             "source": { |  | ||||||
|                 "type": "git", |  | ||||||
|                 "url": "https://github.com/php-fig/log.git", |  | ||||||
|                 "reference": "0f73288fd15629204f9d42b7055f72dacbe811fc" |  | ||||||
|             }, |  | ||||||
|             "dist": { |  | ||||||
|                 "type": "zip", |  | ||||||
|                 "url": "https://api.github.com/repos/php-fig/log/zipball/0f73288fd15629204f9d42b7055f72dacbe811fc", |  | ||||||
|                 "reference": "0f73288fd15629204f9d42b7055f72dacbe811fc", |  | ||||||
|                 "shasum": "" |  | ||||||
|             }, |  | ||||||
|             "require": { |  | ||||||
|                 "php": ">=5.3.0" |  | ||||||
|             }, |  | ||||||
|             "type": "library", |  | ||||||
|             "extra": { |  | ||||||
|                 "branch-alias": { |  | ||||||
|                     "dev-master": "1.1.x-dev" |  | ||||||
|                 } |  | ||||||
|             }, |  | ||||||
|             "autoload": { |  | ||||||
|                 "psr-4": { |  | ||||||
|                     "Psr\\Log\\": "Psr/Log/" |  | ||||||
|                 } |  | ||||||
|             }, |  | ||||||
|             "notification-url": "https://packagist.org/downloads/", |  | ||||||
|             "license": [ |  | ||||||
|                 "MIT" |  | ||||||
|             ], |  | ||||||
|             "authors": [ |  | ||||||
|                 { |  | ||||||
|                     "name": "PHP-FIG", |  | ||||||
|                     "homepage": "http://www.php-fig.org/" |  | ||||||
|                 } |  | ||||||
|             ], |  | ||||||
|             "description": "Common interface for logging libraries", |  | ||||||
|             "homepage": "https://github.com/php-fig/log", |  | ||||||
|             "keywords": [ |  | ||||||
|                 "log", |  | ||||||
|                 "psr", |  | ||||||
|                 "psr-3" |  | ||||||
|             ], |  | ||||||
|             "time": "2020-03-23T09:12:05+00:00" |  | ||||||
|         }, |  | ||||||
|         { |         { | ||||||
|             "name": "psr/simple-cache", |             "name": "psr/simple-cache", | ||||||
|             "version": "1.0.1", |             "version": "1.0.1", | ||||||
| @@ -4375,55 +4798,6 @@ | |||||||
|             "homepage": "https://symfony.com", |             "homepage": "https://symfony.com", | ||||||
|             "time": "2018-11-21T14:20:20+00:00" |             "time": "2018-11-21T14:20:20+00:00" | ||||||
|         }, |         }, | ||||||
|         { |  | ||||||
|             "name": "symfony/filesystem", |  | ||||||
|             "version": "v3.0.9", |  | ||||||
|             "source": { |  | ||||||
|                 "type": "git", |  | ||||||
|                 "url": "https://github.com/symfony/filesystem.git", |  | ||||||
|                 "reference": "b2da5009d9bacbd91d83486aa1f44c793a8c380d" |  | ||||||
|             }, |  | ||||||
|             "dist": { |  | ||||||
|                 "type": "zip", |  | ||||||
|                 "url": "https://api.github.com/repos/symfony/filesystem/zipball/b2da5009d9bacbd91d83486aa1f44c793a8c380d", |  | ||||||
|                 "reference": "b2da5009d9bacbd91d83486aa1f44c793a8c380d", |  | ||||||
|                 "shasum": "" |  | ||||||
|             }, |  | ||||||
|             "require": { |  | ||||||
|                 "php": ">=5.5.9" |  | ||||||
|             }, |  | ||||||
|             "type": "library", |  | ||||||
|             "extra": { |  | ||||||
|                 "branch-alias": { |  | ||||||
|                     "dev-master": "3.0-dev" |  | ||||||
|                 } |  | ||||||
|             }, |  | ||||||
|             "autoload": { |  | ||||||
|                 "psr-4": { |  | ||||||
|                     "Symfony\\Component\\Filesystem\\": "" |  | ||||||
|                 }, |  | ||||||
|                 "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 Filesystem Component", |  | ||||||
|             "homepage": "https://symfony.com", |  | ||||||
|             "time": "2016-07-20T05:43:46+00:00" |  | ||||||
|         }, |  | ||||||
|         { |         { | ||||||
|             "name": "symfony/finder", |             "name": "symfony/finder", | ||||||
|             "version": "v2.8.52", |             "version": "v2.8.52", | ||||||
| @@ -4699,55 +5073,6 @@ | |||||||
|             ], |             ], | ||||||
|             "time": "2020-07-14T12:35:20+00:00" |             "time": "2020-07-14T12:35:20+00:00" | ||||||
|         }, |         }, | ||||||
|         { |  | ||||||
|             "name": "symfony/process", |  | ||||||
|             "version": "v2.8.52", |  | ||||||
|             "source": { |  | ||||||
|                 "type": "git", |  | ||||||
|                 "url": "https://github.com/symfony/process.git", |  | ||||||
|                 "reference": "c3591a09c78639822b0b290d44edb69bf9f05dc8" |  | ||||||
|             }, |  | ||||||
|             "dist": { |  | ||||||
|                 "type": "zip", |  | ||||||
|                 "url": "https://api.github.com/repos/symfony/process/zipball/c3591a09c78639822b0b290d44edb69bf9f05dc8", |  | ||||||
|                 "reference": "c3591a09c78639822b0b290d44edb69bf9f05dc8", |  | ||||||
|                 "shasum": "" |  | ||||||
|             }, |  | ||||||
|             "require": { |  | ||||||
|                 "php": ">=5.3.9" |  | ||||||
|             }, |  | ||||||
|             "type": "library", |  | ||||||
|             "extra": { |  | ||||||
|                 "branch-alias": { |  | ||||||
|                     "dev-master": "2.8-dev" |  | ||||||
|                 } |  | ||||||
|             }, |  | ||||||
|             "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", |  | ||||||
|             "time": "2018-11-11T11:18:13+00:00" |  | ||||||
|         }, |  | ||||||
|         { |         { | ||||||
|             "name": "symfony/stopwatch", |             "name": "symfony/stopwatch", | ||||||
|             "version": "v2.8.52", |             "version": "v2.8.52", | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								vendor/alchemy/binary-driver/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								vendor/alchemy/binary-driver/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | /vendor/ | ||||||
|  | composer.lock | ||||||
							
								
								
									
										26
									
								
								vendor/alchemy/binary-driver/.travis.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								vendor/alchemy/binary-driver/.travis.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | language: php | ||||||
|  | dist: trusty | ||||||
|  |  | ||||||
|  | sudo: false | ||||||
|  |  | ||||||
|  | php: | ||||||
|  |   - 7.0 | ||||||
|  |   - 7.1 | ||||||
|  |   - 7.2 | ||||||
|  |   - 7.3 | ||||||
|  |  | ||||||
|  | matrix: | ||||||
|  |   include: | ||||||
|  |     - php: 7.0 | ||||||
|  |       env: COMPOSER_REQUIRE="symfony/process:^2.0" | ||||||
|  |     - php: 7.0 | ||||||
|  |       env: COMPOSER_REQUIRE="symfony/process:^3.0" | ||||||
|  |     - php: 7.2 | ||||||
|  |       env: COMPOSER_REQUIRE="symfony/process:^5.0" | ||||||
|  |     - php: 7.3 | ||||||
|  |       env: COMPOSER_REQUIRE="symfony/process:^5.0" | ||||||
|  |  | ||||||
|  | before_script: | ||||||
|  |   - composer self-update | ||||||
|  |   - if [ -n "$COMPOSER_REQUIRE" ]; then composer require --no-update $COMPOSER_REQUIRE; fi | ||||||
|  |   - composer update $COMPOSER_OPTIONS | ||||||
							
								
								
									
										64
									
								
								vendor/alchemy/binary-driver/CHANGELOG.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								vendor/alchemy/binary-driver/CHANGELOG.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | |||||||
|  | CHANGELOG | ||||||
|  | --------- | ||||||
|  | * 1.6.0 (2015-03-02) | ||||||
|  |   * BC Break: bump minimum PHP versions  | ||||||
|  |   * Allow use of evenement v2.0 (thanks @patkar for the P/R) | ||||||
|  |  | ||||||
|  | * 1.5.0 (2013-06-21) | ||||||
|  |  | ||||||
|  |   * BC Break : ConfigurationInterface::get does not throw exceptions anymore | ||||||
|  |     in case the key does not exist. Second argument is a default value to return | ||||||
|  |     in case the key does not exist. | ||||||
|  |  | ||||||
|  | * 1.4.1 (2013-05-23) | ||||||
|  |  | ||||||
|  |   * Add third parameter to BinaryInterface::command method to pass a listener or | ||||||
|  |     an array of listener that will be registered just the time of the command. | ||||||
|  |  | ||||||
|  | * 1.4.0 (2013-05-11) | ||||||
|  |  | ||||||
|  |   * Extract process run management to ProcessRunner. | ||||||
|  |   * Add support for process listeners. | ||||||
|  |   * Provides bundled DebugListener. | ||||||
|  |   * Add BinaryInterface::command method. | ||||||
|  |   * BC break : ProcessRunnerInterface::run now takes an SplObjectStorage containing | ||||||
|  |     listeners as second argument. | ||||||
|  |   * BC break : BinaryInterface no longer implements LoggerAwareInterface | ||||||
|  |     as it is now supported by ProcessRunner. | ||||||
|  |  | ||||||
|  | * 1.3.4 (2013-04-26) | ||||||
|  |  | ||||||
|  |   * Add BinaryDriver::run method. | ||||||
|  |  | ||||||
|  | * 1.3.3 (2013-04-26) | ||||||
|  |  | ||||||
|  |   * Add BinaryDriver::createProcessMock method. | ||||||
|  |  | ||||||
|  | * 1.3.2 (2013-04-26) | ||||||
|  |  | ||||||
|  |   * Add BinaryDriverTestCase for testing BinaryDriver implementations. | ||||||
|  |  | ||||||
|  | * 1.3.1 (2013-04-24) | ||||||
|  |  | ||||||
|  |   * Add timeouts handling | ||||||
|  |  | ||||||
|  | * 1.3.0 (2013-04-24) | ||||||
|  |  | ||||||
|  |   * Add BinaryInterface and AbstractBinary | ||||||
|  |  | ||||||
|  | * 1.2.1 (2013-04-24) | ||||||
|  |  | ||||||
|  |   * Add ConfigurationAwareInterface | ||||||
|  |   * Add ProcessBuilderAwareInterface | ||||||
|  |  | ||||||
|  | * 1.2.0 (2013-04-24) | ||||||
|  |  | ||||||
|  |   * Add BinaryDriver\Configuration | ||||||
|  |  | ||||||
|  | * 1.1.0 (2013-04-24) | ||||||
|  |  | ||||||
|  |   * Add support for timeouts via `setTimeout` method | ||||||
|  |  | ||||||
|  | * 1.0.0 (2013-04-23) | ||||||
|  |  | ||||||
|  |   * First stable version. | ||||||
							
								
								
									
										21
									
								
								vendor/alchemy/binary-driver/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/alchemy/binary-driver/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | BinaryDriver is released with MIT License : | ||||||
|  |  | ||||||
|  | Copyright (c) 2013 Alchemy | ||||||
|  |  | ||||||
|  | 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. | ||||||
							
								
								
									
										190
									
								
								vendor/alchemy/binary-driver/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										190
									
								
								vendor/alchemy/binary-driver/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,190 @@ | |||||||
|  | # Binary Driver | ||||||
|  |  | ||||||
|  | Binary-Driver is a set of PHP tools to build binary drivers. | ||||||
|  |  | ||||||
|  | [](https://travis-ci.org/alchemy-fr/BinaryDriver) | ||||||
|  |  | ||||||
|  | ## Why ? | ||||||
|  |  | ||||||
|  | You may wonder *Why building a library while I can use `exec` or | ||||||
|  | [symfony/process](https://github.com/symfony/Process) ?*. | ||||||
|  |  | ||||||
|  | Here is a simple answer : | ||||||
|  |  | ||||||
|  |  - If you use `exec`, `passthru`, `system`, `proc_open` or any low level process | ||||||
|  |    handling in PHP, you should have a look to [symfony/process](https://github.com/symfony/Process) | ||||||
|  |    component that will provide an OO portable, testable and secure interface to | ||||||
|  |    deal with this. It seems easy at first approach, but if you look at this | ||||||
|  |    component [unit tests](https://github.com/symfony/Process/tree/master/Tests), | ||||||
|  |    you will see that handling process in a simple interface can easily become a | ||||||
|  |    nightmare. | ||||||
|  |  | ||||||
|  |  - If you already use symfony/process, and want to build binary drivers, you | ||||||
|  |    will always have the same common set of methods and objects to configure, log, | ||||||
|  |    debug, and generate processes. | ||||||
|  |    This library is a base to implement any binary driver with this common set of | ||||||
|  |    needs. | ||||||
|  |  | ||||||
|  | ## AbstractBinary | ||||||
|  |  | ||||||
|  | `AbstractBinary` provides an abstract class to build a binary driver. It implements | ||||||
|  | `BinaryInterface`. | ||||||
|  |  | ||||||
|  | Implementation example : | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | use Alchemy\BinaryDriver\AbstractBinary; | ||||||
|  |  | ||||||
|  | class LsDriver extends AbstractBinary | ||||||
|  | { | ||||||
|  |     public function getName() | ||||||
|  |     { | ||||||
|  |         return 'ls driver'; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | $parser = new LsParser(); | ||||||
|  |  | ||||||
|  | $driver = Driver::load('ls'); | ||||||
|  | // will return the output of `ls -a -l` | ||||||
|  | $parser->parse($driver->command(array('-a', '-l'))); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Binary detection troubleshooting | ||||||
|  |  | ||||||
|  | If you are using Nginx with PHP-fpm, executable detection may not work because of an empty `$_ENV['path']`.  | ||||||
|  | To avoid having an empty `PATH` environment variable, add the following line to your `fastcgi_params`  | ||||||
|  | config file (replace `/your/current/path/` with the output of `printenv PATH`) : | ||||||
|  |  | ||||||
|  | ``` | ||||||
|  | fastcgi_param    PATH    /your/current/path | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Logging | ||||||
|  |  | ||||||
|  | You can log events with a `Psr\Log\LoggerInterface` by passing it in the load | ||||||
|  | method as second argument : | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | $logger = new Monolog\Logger('driver'); | ||||||
|  | $driver = Driver::load('ls', $logger); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Listeners | ||||||
|  |  | ||||||
|  | You can add custom listeners on processes. | ||||||
|  | Listeners are built on top of [Evenement](https://github.com/igorw/evenement) | ||||||
|  | and must implement `Alchemy\BinaryDriver\ListenerInterface`. | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  |  | ||||||
|  | class DebugListener extends EventEmitter implements ListenerInterface | ||||||
|  | { | ||||||
|  |     public function handle($type, $data) | ||||||
|  |     { | ||||||
|  |         foreach (explode(PHP_EOL, $data) as $line) { | ||||||
|  |             $this->emit($type === Process::ERR ? 'error' : 'out', array($line)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function forwardedEvents() | ||||||
|  |     { | ||||||
|  |         // forward 'error' events to the BinaryInterface | ||||||
|  |         return array('error'); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | $listener = new DebugListener(); | ||||||
|  |  | ||||||
|  | $driver = CustomImplementation::load('php'); | ||||||
|  |  | ||||||
|  | // adds listener | ||||||
|  | $driver->listen($listener); | ||||||
|  |  | ||||||
|  | $driver->on('error', function ($line) { | ||||||
|  |     echo '[ERROR] ' . $line . PHP_EOL; | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | // removes listener | ||||||
|  | $driver->unlisten($listener); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Bundled listeners | ||||||
|  |  | ||||||
|  | The debug listener is a simple listener to catch `stderr` and `stdout` outputs ; | ||||||
|  | read the implementation for customization. | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | use Alchemy\BinaryDriver\Listeners\DebugListener; | ||||||
|  |  | ||||||
|  | $driver = CustomImplementation::load('php'); | ||||||
|  | $driver->listen(new DebugListener()); | ||||||
|  |  | ||||||
|  | $driver->on('debug', function ($line) { | ||||||
|  |     echo $line; | ||||||
|  | }); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## ProcessBuilderFactory | ||||||
|  |  | ||||||
|  | ProcessBuilderFactory ease spawning processes by generating Symfony [Process] | ||||||
|  | (http://symfony.com/doc/master/components/process.html) objects. | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | use Alchemy\BinaryDriver\ProcessBuilderFactory; | ||||||
|  |  | ||||||
|  | $factory = new ProcessBuilderFactory('/usr/bin/php'); | ||||||
|  |  | ||||||
|  | // return a Symfony\Component\Process\Process | ||||||
|  | $process = $factory->create('-v'); | ||||||
|  |  | ||||||
|  | // echoes '/usr/bin/php' '-v' | ||||||
|  | echo $process->getCommandLine(); | ||||||
|  |  | ||||||
|  | $process = $factory->create(array('-r', 'echo "Hello !";')); | ||||||
|  |  | ||||||
|  | // echoes '/usr/bin/php' '-r' 'echo "Hello !";' | ||||||
|  | echo $process->getCommandLine(); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## Configuration | ||||||
|  |  | ||||||
|  | A simple configuration object, providing an `ArrayAccess` and `IteratorAggregate` | ||||||
|  | interface. | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | use Alchemy\BinaryDriver\Configuration; | ||||||
|  |  | ||||||
|  | $conf = new Configuration(array('timeout' => 0)); | ||||||
|  |  | ||||||
|  | echo $conf->get('timeout'); | ||||||
|  |  | ||||||
|  | if ($conf->has('param')) { | ||||||
|  |     $conf->remove('param'); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | $conf->set('timeout', 20); | ||||||
|  |  | ||||||
|  | $conf->all(); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Same example using the `ArrayAccess` interface : | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | use Alchemy\BinaryDriver\Configuration; | ||||||
|  |  | ||||||
|  | $conf = new Configuration(array('timeout' => 0)); | ||||||
|  |  | ||||||
|  | echo $conf['timeout']; | ||||||
|  |  | ||||||
|  | if (isset($conf['param'])) { | ||||||
|  |     unset($conf['param']); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | $conf['timeout'] = 20; | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## License | ||||||
|  |  | ||||||
|  | This project is released under the MIT license. | ||||||
							
								
								
									
										43
									
								
								vendor/alchemy/binary-driver/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								vendor/alchemy/binary-driver/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | |||||||
|  | { | ||||||
|  |     "name": "alchemy/binary-driver", | ||||||
|  |     "type": "library", | ||||||
|  |     "description": "A set of tools to build binary drivers", | ||||||
|  |     "keywords": ["binary", "driver"], | ||||||
|  |     "license": "MIT", | ||||||
|  |     "authors": [ | ||||||
|  |         { | ||||||
|  |             "name": "Nicolas Le Goff", | ||||||
|  |             "email": "legoff.n@gmail.com" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "Romain Neutron", | ||||||
|  |             "email": "imprec@gmail.com", | ||||||
|  |             "homepage": "http://www.lickmychip.com/" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "Phraseanet Team", | ||||||
|  |             "email": "info@alchemy.fr", | ||||||
|  |             "homepage": "http://www.phraseanet.com/" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "Jens Hausdorf", | ||||||
|  |             "email": "mail@jens-hausdorf.de", | ||||||
|  |             "homepage": "https://jens-hausdorf.de", | ||||||
|  |             "role": "Maintainer" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "require": { | ||||||
|  |         "php"                 : ">=5.5", | ||||||
|  |         "evenement/evenement" : "^3.0|^2.0|^1.0", | ||||||
|  |         "psr/log"             : "^1.0", | ||||||
|  |         "symfony/process"     : "^2.3|^3.0|^4.0|^5.0" | ||||||
|  |     }, | ||||||
|  |     "require-dev": { | ||||||
|  |         "phpunit/phpunit"     : "^4.0|^5.0" | ||||||
|  |     }, | ||||||
|  |     "autoload": { | ||||||
|  |         "psr-0": { | ||||||
|  |             "Alchemy": "src" | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										31
									
								
								vendor/alchemy/binary-driver/phpunit.xml.dist
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/alchemy/binary-driver/phpunit.xml.dist
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <phpunit backupGlobals="false" | ||||||
|  |          backupStaticAttributes="false" | ||||||
|  |          colors="true" | ||||||
|  |          convertErrorsToExceptions="true" | ||||||
|  |          convertNoticesToExceptions="true" | ||||||
|  |          convertWarningsToExceptions="true" | ||||||
|  |          processIsolation="false" | ||||||
|  |          stopOnFailure="false" | ||||||
|  |          syntaxCheck="true" | ||||||
|  |          verbose="false" | ||||||
|  |          bootstrap="tests/bootstrap.php" | ||||||
|  | > | ||||||
|  |     <php> | ||||||
|  |       <ini name="display_errors" value="on"/> | ||||||
|  |     </php> | ||||||
|  |  | ||||||
|  |     <testsuites> | ||||||
|  |         <testsuite> | ||||||
|  |             <directory>tests</directory> | ||||||
|  |         </testsuite> | ||||||
|  |     </testsuites> | ||||||
|  |     <filter> | ||||||
|  |       <blacklist> | ||||||
|  |         <directory>vendor</directory> | ||||||
|  |         <directory>tests</directory> | ||||||
|  |       </blacklist> | ||||||
|  |     </filter> | ||||||
|  |  | ||||||
|  | </phpunit> | ||||||
|  |  | ||||||
							
								
								
									
										218
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/AbstractBinary.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										218
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/AbstractBinary.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,218 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\Exception\ExecutableNotFoundException; | ||||||
|  | use Alchemy\BinaryDriver\Exception\ExecutionFailureException; | ||||||
|  | use Alchemy\BinaryDriver\Listeners\Listeners; | ||||||
|  | use Alchemy\BinaryDriver\Listeners\ListenerInterface; | ||||||
|  | use Evenement\EventEmitter; | ||||||
|  | use Psr\Log\LoggerInterface; | ||||||
|  | use Psr\Log\NullLogger; | ||||||
|  | use Symfony\Component\Process\ExecutableFinder; | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  |  | ||||||
|  | abstract class AbstractBinary extends EventEmitter implements BinaryInterface | ||||||
|  | { | ||||||
|  |     /** @var ConfigurationInterface */ | ||||||
|  |     protected $configuration; | ||||||
|  |  | ||||||
|  |     /** @var ProcessBuilderFactoryInterface */ | ||||||
|  |     protected $factory; | ||||||
|  |  | ||||||
|  |     /** @var ProcessRunner */ | ||||||
|  |     private $processRunner; | ||||||
|  |  | ||||||
|  |     /** @var Listeners */ | ||||||
|  |     private $listenersManager; | ||||||
|  |  | ||||||
|  |     public function __construct(ProcessBuilderFactoryInterface $factory, LoggerInterface $logger, ConfigurationInterface $configuration) | ||||||
|  |     { | ||||||
|  |         $this->factory = $factory; | ||||||
|  |         $this->configuration = $configuration; | ||||||
|  |         $this->processRunner = new ProcessRunner($logger, $this->getName()); | ||||||
|  |         $this->listenersManager = new Listeners(); | ||||||
|  |         $this->applyProcessConfiguration(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function listen(ListenerInterface $listener) | ||||||
|  |     { | ||||||
|  |         $this->listenersManager->register($listener, $this); | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function unlisten(ListenerInterface $listener) | ||||||
|  |     { | ||||||
|  |         $this->listenersManager->unregister($listener, $this); | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function getConfiguration() | ||||||
|  |     { | ||||||
|  |         return $this->configuration; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      * | ||||||
|  |      * @return BinaryInterface | ||||||
|  |      */ | ||||||
|  |     public function setConfiguration(ConfigurationInterface $configuration) | ||||||
|  |     { | ||||||
|  |         $this->configuration = $configuration; | ||||||
|  |         $this->applyProcessConfiguration(); | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function getProcessBuilderFactory() | ||||||
|  |     { | ||||||
|  |         return $this->factory; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      * | ||||||
|  |      * @return BinaryInterface | ||||||
|  |      */ | ||||||
|  |     public function setProcessBuilderFactory(ProcessBuilderFactoryInterface $factory) | ||||||
|  |     { | ||||||
|  |         $this->factory = $factory; | ||||||
|  |         $this->applyProcessConfiguration(); | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function getProcessRunner() | ||||||
|  |     { | ||||||
|  |         return $this->processRunner; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function setProcessRunner(ProcessRunnerInterface $runner) | ||||||
|  |     { | ||||||
|  |         $this->processRunner = $runner; | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function command($command, $bypassErrors = false, $listeners = null) | ||||||
|  |     { | ||||||
|  |         if (!is_array($command)) { | ||||||
|  |             $command = array($command); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return $this->run($this->factory->create($command), $bypassErrors, $listeners); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public static function load($binaries, LoggerInterface $logger = null, $configuration = array()) | ||||||
|  |     { | ||||||
|  |         $finder = new ExecutableFinder(); | ||||||
|  |         $binary = null; | ||||||
|  |         $binaries = is_array($binaries) ? $binaries : array($binaries); | ||||||
|  |  | ||||||
|  |         foreach ($binaries as $candidate) { | ||||||
|  |             if (file_exists($candidate) && is_executable($candidate)) { | ||||||
|  |                 $binary = $candidate; | ||||||
|  |                 break; | ||||||
|  |             } | ||||||
|  |             if (null !== $binary = $finder->find($candidate)) { | ||||||
|  |                 break; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (null === $binary) { | ||||||
|  |             throw new ExecutableNotFoundException(sprintf( | ||||||
|  |                 'Executable not found, proposed : %s', implode(', ', $binaries) | ||||||
|  |             )); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (null === $logger) { | ||||||
|  |             $logger = new NullLogger(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $configuration = $configuration instanceof ConfigurationInterface ? $configuration : new Configuration($configuration); | ||||||
|  |  | ||||||
|  |         return new static(new ProcessBuilderFactory($binary), $logger, $configuration); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Returns the name of the driver | ||||||
|  |      * | ||||||
|  |      * @return string | ||||||
|  |      */ | ||||||
|  |     abstract public function getName(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Executes a process, logs events | ||||||
|  |      * | ||||||
|  |      * @param Process                 $process | ||||||
|  |      * @param Boolean                 $bypassErrors Set to true to disable throwing ExecutionFailureExceptions | ||||||
|  |      * @param ListenerInterface|array $listeners    A listener or an array of listener to register for this unique run | ||||||
|  |      * | ||||||
|  |      * @return string The Process output | ||||||
|  |      * | ||||||
|  |      * @throws ExecutionFailureException in case of process failure. | ||||||
|  |      */ | ||||||
|  |     protected function run(Process $process, $bypassErrors = false, $listeners = null) | ||||||
|  |     { | ||||||
|  |         if (null !== $listeners) { | ||||||
|  |             if (!is_array($listeners)) { | ||||||
|  |                 $listeners = array($listeners); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             $listenersManager = clone $this->listenersManager; | ||||||
|  |  | ||||||
|  |             foreach ($listeners as $listener) { | ||||||
|  |                 $listenersManager->register($listener, $this); | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|  |             $listenersManager = $this->listenersManager; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return $this->processRunner->run($process, $listenersManager->storage, $bypassErrors); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private function applyProcessConfiguration() | ||||||
|  |     { | ||||||
|  |         if ($this->configuration->has('timeout')) { | ||||||
|  |             $this->factory->setTimeout($this->configuration->get('timeout')); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										76
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/BinaryDriverTestCase.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/BinaryDriverTestCase.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,76 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Psr\Log\LoggerInterface; | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Convenient PHPUnit methods for testing BinaryDriverInterface implementations. | ||||||
|  |  */ | ||||||
|  | class BinaryDriverTestCase extends \PHPUnit_Framework_TestCase | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * @return ProcessBuilderFactoryInterface | ||||||
|  |      */ | ||||||
|  |     public function createProcessBuilderFactoryMock() | ||||||
|  |     { | ||||||
|  |         return $this->getMock('Alchemy\BinaryDriver\ProcessBuilderFactoryInterface'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @param integer $runs        The number of runs expected | ||||||
|  |      * @param Boolean $success     True if the process expects to be successfull | ||||||
|  |      * @param string  $commandLine The commandline executed | ||||||
|  |      * @param string  $output      The process output | ||||||
|  |      * @param string  $error       The process error output | ||||||
|  |      * | ||||||
|  |      * @return Process | ||||||
|  |      */ | ||||||
|  |     public function createProcessMock($runs = 1, $success = true, $commandLine = null, $output = null, $error = null, $callback = false) | ||||||
|  |     { | ||||||
|  |         $process = $this->getMockBuilder('Symfony\Component\Process\Process') | ||||||
|  |             ->disableOriginalConstructor() | ||||||
|  |             ->getMock(); | ||||||
|  |  | ||||||
|  |         $builder = $process->expects($this->exactly($runs)) | ||||||
|  |             ->method('run'); | ||||||
|  |  | ||||||
|  |         if (true === $callback) { | ||||||
|  |             $builder->with($this->isInstanceOf('Closure')); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $process->expects($this->any()) | ||||||
|  |             ->method('isSuccessful') | ||||||
|  |             ->will($this->returnValue($success)); | ||||||
|  |  | ||||||
|  |         foreach (array( | ||||||
|  |             'getOutput' => $output, | ||||||
|  |             'getErrorOutput' => $error, | ||||||
|  |             'getCommandLine' => $commandLine, | ||||||
|  |         ) as $command => $value) { | ||||||
|  |             $process | ||||||
|  |                 ->expects($this->any()) | ||||||
|  |                 ->method($command) | ||||||
|  |                 ->will($this->returnValue($value)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return $process; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @return LoggerInterface | ||||||
|  |      */ | ||||||
|  |     public function createLoggerMock() | ||||||
|  |     { | ||||||
|  |         return $this->getMock('Psr\Log\LoggerInterface'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @return ConfigurationInterface | ||||||
|  |      */ | ||||||
|  |     public function createConfigurationMock() | ||||||
|  |     { | ||||||
|  |         return $this->getMock('Alchemy\BinaryDriver\ConfigurationInterface'); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										67
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/BinaryInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/BinaryInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\Exception\ExecutableNotFoundException; | ||||||
|  | use Alchemy\BinaryDriver\Exception\ExecutionFailureException; | ||||||
|  | use Alchemy\BinaryDriver\Listeners\ListenerInterface; | ||||||
|  | use Psr\Log\LoggerInterface; | ||||||
|  | use Evenement\EventEmitterInterface; | ||||||
|  |  | ||||||
|  | interface BinaryInterface extends ConfigurationAwareInterface, ProcessBuilderFactoryAwareInterface, ProcessRunnerAwareInterface, EventEmitterInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Adds a listener to the binary driver | ||||||
|  |      * | ||||||
|  |      * @param ListenerInterface $listener | ||||||
|  |      * | ||||||
|  |      * @return BinaryInterface | ||||||
|  |      */ | ||||||
|  |     public function listen(ListenerInterface $listener); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Removes a listener from the binary driver | ||||||
|  |      * | ||||||
|  |      * @param ListenerInterface $listener | ||||||
|  |      * | ||||||
|  |      * @return BinaryInterface | ||||||
|  |      */ | ||||||
|  |     public function unlisten(ListenerInterface $listener); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Runs a command against the driver. | ||||||
|  |      * | ||||||
|  |      * Calling this method on a `ls` driver with the command `-a` would run `ls -a`. | ||||||
|  |      * | ||||||
|  |      * @param array|string            $command      A command or an array of command | ||||||
|  |      * @param Boolean                 $bypassErrors If set to true, an erronous process will not throw an exception | ||||||
|  |      * @param ListenerInterface|array $listeners    A listener or an array of listeners to register for this unique run | ||||||
|  |      * | ||||||
|  |      * @return string The command output | ||||||
|  |      * | ||||||
|  |      * @throws ExecutionFailureException in case of process failure. | ||||||
|  |      */ | ||||||
|  |     public function command($command, $bypassErrors = false, $listeners = null); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Loads a binary | ||||||
|  |      * | ||||||
|  |      * @param string|array                 $binaries      A binary name or an array of binary names | ||||||
|  |      * @param null|LoggerInterface        $logger        A Logger | ||||||
|  |      * @param array|ConfigurationInterface $configuration The configuration | ||||||
|  |      * | ||||||
|  |      * @throws ExecutableNotFoundException In case none of the binaries were found | ||||||
|  |      * | ||||||
|  |      * @return BinaryInterface | ||||||
|  |      */ | ||||||
|  |     public static function load($binaries, LoggerInterface $logger = null, $configuration = array()); | ||||||
|  | } | ||||||
							
								
								
									
										107
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Configuration.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Configuration.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | class Configuration implements ConfigurationInterface | ||||||
|  | { | ||||||
|  |     private $data; | ||||||
|  |  | ||||||
|  |     public function __construct(array $data = array()) | ||||||
|  |     { | ||||||
|  |         $this->data = $data; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function getIterator() | ||||||
|  |     { | ||||||
|  |         return new \ArrayIterator($this->data); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function get($key, $default = null) | ||||||
|  |     { | ||||||
|  |         return isset($this->data[$key]) ? $this->data[$key] : $default; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function set($key, $value) | ||||||
|  |     { | ||||||
|  |         $this->data[$key] = $value; | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function has($key) | ||||||
|  |     { | ||||||
|  |         return array_key_exists($key, $this->data); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function remove($key) | ||||||
|  |     { | ||||||
|  |         $value = $this->get($key); | ||||||
|  |         unset($this->data[$key]); | ||||||
|  |  | ||||||
|  |         return $value; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function all() | ||||||
|  |     { | ||||||
|  |         return $this->data; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function offsetExists($offset) | ||||||
|  |     { | ||||||
|  |         return $this->has($offset); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function offsetGet($offset) | ||||||
|  |     { | ||||||
|  |         return $this->get($offset); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function offsetSet($offset, $value) | ||||||
|  |     { | ||||||
|  |         $this->set($offset, $value); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function offsetUnset($offset) | ||||||
|  |     { | ||||||
|  |         $this->remove($offset); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										29
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ConfigurationAwareInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ConfigurationAwareInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | interface ConfigurationAwareInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Returns the configuration | ||||||
|  |      * | ||||||
|  |      * @return ConfigurationInterface | ||||||
|  |      */ | ||||||
|  |     public function getConfiguration(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Set the configuration | ||||||
|  |      * | ||||||
|  |      * @param ConfigurationInterface $configuration | ||||||
|  |      */ | ||||||
|  |     public function setConfiguration(ConfigurationInterface $configuration); | ||||||
|  | } | ||||||
							
								
								
									
										58
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ConfigurationInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ConfigurationInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | interface ConfigurationInterface extends \ArrayAccess, \IteratorAggregate | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Returns the value given a key from configuration | ||||||
|  |      * | ||||||
|  |      * @param string $key | ||||||
|  |      * @param mixed  $default The default value in case the key does not exist | ||||||
|  |      * | ||||||
|  |      * @return mixed | ||||||
|  |      */ | ||||||
|  |     public function get($key, $default = null); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Set a value to configuration | ||||||
|  |      * | ||||||
|  |      * @param string $key   The key | ||||||
|  |      * @param mixed  $value The value corresponding to the key | ||||||
|  |      */ | ||||||
|  |     public function set($key, $value); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Tells if Configuration contains `$key` | ||||||
|  |      * | ||||||
|  |      * @param string $key | ||||||
|  |      * | ||||||
|  |      * @return Boolean | ||||||
|  |      */ | ||||||
|  |     public function has($key); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Removes a value given a key | ||||||
|  |      * | ||||||
|  |      * @param string $key | ||||||
|  |      * | ||||||
|  |      * @return mixed The previous value | ||||||
|  |      */ | ||||||
|  |     public function remove($key); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Returns all values set in the configuration | ||||||
|  |      * | ||||||
|  |      * @return array | ||||||
|  |      */ | ||||||
|  |     public function all(); | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Exception/ExceptionInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Exception/ExceptionInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver\Exception; | ||||||
|  |  | ||||||
|  | interface ExceptionInterface | ||||||
|  | { | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Exception/ExecutableNotFoundException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Exception/ExecutableNotFoundException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver\Exception; | ||||||
|  |  | ||||||
|  | class ExecutableNotFoundException extends \RuntimeException implements ExceptionInterface | ||||||
|  | { | ||||||
|  | } | ||||||
							
								
								
									
										37
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Exception/ExecutionFailureException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Exception/ExecutionFailureException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver\Exception; | ||||||
|  |  | ||||||
|  | class ExecutionFailureException extends \RuntimeException implements ExceptionInterface | ||||||
|  | { | ||||||
|  |     /** @var string */ | ||||||
|  |     protected $command; | ||||||
|  |  | ||||||
|  |     /** @var string */ | ||||||
|  |     protected $errorOutput; | ||||||
|  |  | ||||||
|  |     public function __construct($binaryName, $command, $errorOutput = null, $code = 0, $previous = null) | ||||||
|  |     { | ||||||
|  |         $message = sprintf("%s failed to execute command %s:\n\nError Output:\n\n %s", $binaryName, $command, $errorOutput); | ||||||
|  |         parent::__construct($message, $code, $previous); | ||||||
|  |         $this->command = $command; | ||||||
|  |         $this->errorOutput = $errorOutput; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function getCommand(){ | ||||||
|  |         return $this->command; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function getErrorOutput(){ | ||||||
|  |         return $this->errorOutput; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Exception/InvalidArgumentException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Exception/InvalidArgumentException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver\Exception; | ||||||
|  |  | ||||||
|  | class InvalidArgumentException extends \InvalidArgumentException implements ExceptionInterface | ||||||
|  | { | ||||||
|  | } | ||||||
							
								
								
									
										58
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Listeners/DebugListener.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Listeners/DebugListener.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver\Listeners; | ||||||
|  |  | ||||||
|  | use Evenement\EventEmitter; | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  |  | ||||||
|  | class DebugListener extends EventEmitter implements ListenerInterface | ||||||
|  | { | ||||||
|  |     private $prefixOut; | ||||||
|  |     private $prefixErr; | ||||||
|  |     private $eventOut; | ||||||
|  |     private $eventErr; | ||||||
|  |  | ||||||
|  |     public function __construct($prefixOut = '[OUT] ', $prefixErr = '[ERROR] ', $eventOut = 'debug', $eventErr = 'debug') | ||||||
|  |     { | ||||||
|  |         $this->prefixOut = $prefixOut; | ||||||
|  |         $this->prefixErr = $prefixErr; | ||||||
|  |         $this->eventOut = $eventOut; | ||||||
|  |         $this->eventErr = $eventErr; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function handle($type, $data) | ||||||
|  |     { | ||||||
|  |         if (Process::ERR === $type) { | ||||||
|  |             $this->emitLines($this->eventErr, $this->prefixErr, $data); | ||||||
|  |         } elseif (Process::OUT === $type) { | ||||||
|  |             $this->emitLines($this->eventOut, $this->prefixOut, $data); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function forwardedEvents() | ||||||
|  |     { | ||||||
|  |         return array_unique(array($this->eventErr, $this->eventOut)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private function emitLines($event, $prefix, $lines) | ||||||
|  |     { | ||||||
|  |         foreach (explode("\n", $lines) as $line) { | ||||||
|  |             $this->emit($event, array($prefix . $line)); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Listeners/ListenerInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Listeners/ListenerInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver\Listeners; | ||||||
|  |  | ||||||
|  | use Evenement\EventEmitterInterface; | ||||||
|  |  | ||||||
|  | interface ListenerInterface extends EventEmitterInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Handle the output of a ProcessRunner | ||||||
|  |      * | ||||||
|  |      * @param string $type The data type, one of Process::ERR, Process::OUT constants | ||||||
|  |      * @param string $data The output | ||||||
|  |      */ | ||||||
|  |     public function handle($type, $data); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * An array of events that should be forwarded to BinaryInterface | ||||||
|  |      * | ||||||
|  |      * @return array | ||||||
|  |      */ | ||||||
|  |     public function forwardedEvents(); | ||||||
|  | } | ||||||
							
								
								
									
										88
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Listeners/Listeners.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/Listeners/Listeners.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,88 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver\Listeners; | ||||||
|  |  | ||||||
|  | use SplObjectStorage; | ||||||
|  | use Evenement\EventEmitter; | ||||||
|  |  | ||||||
|  | class Listeners extends EventEmitter | ||||||
|  | { | ||||||
|  |     /** @var SplObjectStorage */ | ||||||
|  |     public $storage; | ||||||
|  |  | ||||||
|  |     public function __construct() | ||||||
|  |     { | ||||||
|  |         $this->storage = new SplObjectStorage(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function __clone() | ||||||
|  |     { | ||||||
|  |         $storage = $this->storage; | ||||||
|  |         $this->storage = new SplObjectStorage(); | ||||||
|  |         $this->storage->addAll($storage); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Registers a listener, pass the listener events to the target. | ||||||
|  |      * | ||||||
|  |      * @param ListenerInterface $listener | ||||||
|  |      * @param null|EventEmitter $target | ||||||
|  |      * | ||||||
|  |      * @return ListenersInterface | ||||||
|  |      */ | ||||||
|  |     public function register(ListenerInterface $listener, EventEmitter $target = null) | ||||||
|  |     { | ||||||
|  |         $EElisteners = array(); | ||||||
|  |  | ||||||
|  |         if (null !== $target) { | ||||||
|  |             $EElisteners = $this->forwardEvents($listener, $target, $listener->forwardedEvents()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $this->storage->attach($listener, $EElisteners); | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Unregisters a listener, removes the listener events from the target. | ||||||
|  |      * | ||||||
|  |      * @param ListenerInterface $listener | ||||||
|  |      * | ||||||
|  |      * @return ListenersInterface | ||||||
|  |      * | ||||||
|  |      * @throws InvalidArgumentException In case the listener is not registered | ||||||
|  |      */ | ||||||
|  |     public function unregister(ListenerInterface $listener) | ||||||
|  |     { | ||||||
|  |         if (!isset($this->storage[$listener])) { | ||||||
|  |             throw new InvalidArgumentException('Listener is not registered.'); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         foreach ($this->storage[$listener] as $event => $EElistener) { | ||||||
|  |             $listener->removeListener($event, $EElistener); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $this->storage->detach($listener); | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private function forwardEvents($source, $target, array $events) | ||||||
|  |     { | ||||||
|  |         $EElisteners = array(); | ||||||
|  |  | ||||||
|  |         foreach ($events as $event) { | ||||||
|  |             $listener = $this->createListener($event, $target); | ||||||
|  |             $source->on($event, $EElisteners[$event] = $listener); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return $EElisteners; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private function createListener($event, $target) | ||||||
|  |     { | ||||||
|  |         return function () use ($event, $target) { | ||||||
|  |             $target->emit($event, func_get_args()); | ||||||
|  |         }; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										186
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessBuilderFactory.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										186
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessBuilderFactory.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,186 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\Exception\InvalidArgumentException; | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  | use Symfony\Component\Process\ProcessBuilder; | ||||||
|  |  | ||||||
|  | class ProcessBuilderFactory implements ProcessBuilderFactoryInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * The binary path | ||||||
|  |      * | ||||||
|  |      * @var String | ||||||
|  |      */ | ||||||
|  |     protected $binary; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * The timeout for the generated processes | ||||||
|  |      * | ||||||
|  |      * @var integer|float | ||||||
|  |      */ | ||||||
|  |     private $timeout; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * An internal ProcessBuilder. | ||||||
|  |      * | ||||||
|  |      * Note that this one is used only if Symfony ProcessBuilder has method | ||||||
|  |      * setPrefix (2.3) | ||||||
|  |      * | ||||||
|  |      * @var ProcessBuilder | ||||||
|  |      */ | ||||||
|  |     private $builder; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Tells whether Symfony LTS ProcessBuilder should be emulated or not. | ||||||
|  |      * | ||||||
|  |      * This symfony version provided a brand new ::setPrefix method. | ||||||
|  |      * | ||||||
|  |      * @var Boolean | ||||||
|  |      */ | ||||||
|  |     public static $emulateSfLTS; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Constructor | ||||||
|  |      * | ||||||
|  |      * @param String $binary The path to the binary | ||||||
|  |      * | ||||||
|  |      * @throws InvalidArgumentException In case binary path is invalid | ||||||
|  |      */ | ||||||
|  |     public function __construct($binary) | ||||||
|  |     { | ||||||
|  |         $this->detectEmulation(); | ||||||
|  |  | ||||||
|  |         if (!self::$emulateSfLTS) { | ||||||
|  |             $this->builder = new ProcessBuilder(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $this->useBinary($binary); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Covenient method for unit testing | ||||||
|  |      * | ||||||
|  |      * @return type | ||||||
|  |      */ | ||||||
|  |     public function getBuilder() | ||||||
|  |     { | ||||||
|  |         return $this->builder; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Covenient method for unit testing | ||||||
|  |      * | ||||||
|  |      * @param  ProcessBuilder        $builder | ||||||
|  |      * @return ProcessBuilderFactory | ||||||
|  |      */ | ||||||
|  |     public function setBuilder(ProcessBuilder $builder) | ||||||
|  |     { | ||||||
|  |         $this->builder = $builder; | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @inheritdoc | ||||||
|  |      */ | ||||||
|  |     public function getBinary() | ||||||
|  |     { | ||||||
|  |         return $this->binary; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @inheritdoc | ||||||
|  |      */ | ||||||
|  |     public function useBinary($binary) | ||||||
|  |     { | ||||||
|  |         if (!is_executable($binary)) { | ||||||
|  |             throw new InvalidArgumentException(sprintf('`%s` is not an executable binary', $binary)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $this->binary = $binary; | ||||||
|  |  | ||||||
|  |         if (!static::$emulateSfLTS) { | ||||||
|  |             $this->builder->setPrefix($binary); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @inheritdoc | ||||||
|  |      */ | ||||||
|  |     public function setTimeout($timeout) | ||||||
|  |     { | ||||||
|  |         $this->timeout = $timeout; | ||||||
|  |  | ||||||
|  |         if (!static::$emulateSfLTS) { | ||||||
|  |             $this->builder->setTimeout($this->timeout); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @inheritdoc | ||||||
|  |      */ | ||||||
|  |     public function getTimeout() | ||||||
|  |     { | ||||||
|  |         return $this->timeout; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @inheritdoc | ||||||
|  |      */ | ||||||
|  |     public function create($arguments = array()) | ||||||
|  |     { | ||||||
|  |         if (null === $this->binary) { | ||||||
|  |             throw new InvalidArgumentException('No binary set'); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (!is_array($arguments)) { | ||||||
|  |             $arguments = array($arguments); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (static::$emulateSfLTS) { | ||||||
|  |             array_unshift($arguments, $this->binary); | ||||||
|  |             if (method_exists('Symfony\Component\Process\ProcessUtils', 'escapeArgument')) { | ||||||
|  |                 $script = implode(' ', array_map(array('Symfony\Component\Process\ProcessUtils', 'escapeArgument'), $arguments)); | ||||||
|  |             } else { | ||||||
|  |                 $script = $arguments; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             $env = array_replace($_ENV, $_SERVER); | ||||||
|  |             $env = array_filter($env, function ($value) { | ||||||
|  |                 return !is_array($value); | ||||||
|  |             }); | ||||||
|  |  | ||||||
|  |             return new Process($script, null, $env, null, $this->timeout); | ||||||
|  |         } else { | ||||||
|  |             return $this->builder | ||||||
|  |                 ->setArguments($arguments) | ||||||
|  |                 ->getProcess(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private function detectEmulation() | ||||||
|  |     { | ||||||
|  |         if (null !== static::$emulateSfLTS) { | ||||||
|  |             return $this; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         static::$emulateSfLTS = !method_exists('Symfony\Component\Process\ProcessBuilder', 'setPrefix'); | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										29
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessBuilderFactoryAwareInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessBuilderFactoryAwareInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | interface ProcessBuilderFactoryAwareInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Returns the current process builder factory | ||||||
|  |      * | ||||||
|  |      * @return ProcessBuilderFactoryInterface | ||||||
|  |      */ | ||||||
|  |     public function getProcessBuilderFactory(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Set a process builder factory | ||||||
|  |      * | ||||||
|  |      * @param ProcessBuilderFactoryInterface $factory | ||||||
|  |      */ | ||||||
|  |     public function setProcessBuilderFactory(ProcessBuilderFactoryInterface $factory); | ||||||
|  | } | ||||||
							
								
								
									
										65
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessBuilderFactoryInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessBuilderFactoryInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\Exception\InvalidArgumentException; | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  |  | ||||||
|  | interface ProcessBuilderFactoryInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Returns a new instance of Symfony Process | ||||||
|  |      * | ||||||
|  |      * @param string|array $arguments An argument or an array of arguments | ||||||
|  |      * | ||||||
|  |      * @return Process | ||||||
|  |      * | ||||||
|  |      * @throws InvalidArgumentException | ||||||
|  |      */ | ||||||
|  |     public function create($arguments = array()); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Returns the path to the binary that is used | ||||||
|  |      * | ||||||
|  |      * @return String | ||||||
|  |      */ | ||||||
|  |     public function getBinary(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Sets the path to the binary | ||||||
|  |      * | ||||||
|  |      * @param String $binary A path to a binary | ||||||
|  |      * | ||||||
|  |      * @return ProcessBuilderFactoryInterface | ||||||
|  |      * | ||||||
|  |      * @throws InvalidArgumentException In case binary is not executable | ||||||
|  |      */ | ||||||
|  |     public function useBinary($binary); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Set the default timeout to apply on created processes. | ||||||
|  |      * | ||||||
|  |      * @param integer|float $timeout | ||||||
|  |      * | ||||||
|  |      * @return ProcessBuilderFactoryInterface | ||||||
|  |      * | ||||||
|  |      * @throws InvalidArgumentException In case the timeout is not valid | ||||||
|  |      */ | ||||||
|  |     public function setTimeout($timeout); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Returns the current timeout applied to the created processes. | ||||||
|  |      * | ||||||
|  |      * @return integer|float | ||||||
|  |      */ | ||||||
|  |     public function getTimeout(); | ||||||
|  | } | ||||||
							
								
								
									
										102
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessRunner.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessRunner.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,102 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\Exception\ExecutionFailureException; | ||||||
|  | use Psr\Log\LoggerInterface; | ||||||
|  | use SplObjectStorage; | ||||||
|  | use Symfony\Component\Process\Exception\RuntimeException; | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  |  | ||||||
|  | class ProcessRunner implements ProcessRunnerInterface | ||||||
|  | { | ||||||
|  |     /** @var LoggerInterface */ | ||||||
|  |     private $logger; | ||||||
|  |  | ||||||
|  |     /** @var string */ | ||||||
|  |     private $name; | ||||||
|  |  | ||||||
|  |     public function __construct(LoggerInterface $logger, $name) | ||||||
|  |     { | ||||||
|  |         $this->logger = $logger; | ||||||
|  |         $this->name = $name; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      * | ||||||
|  |      * @return ProcessRunner | ||||||
|  |      */ | ||||||
|  |     public function setLogger(LoggerInterface $logger) | ||||||
|  |     { | ||||||
|  |         $this->logger = $logger; | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @return LoggerInterface | ||||||
|  |      */ | ||||||
|  |     public function getLogger() | ||||||
|  |     { | ||||||
|  |         return $this->logger; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function run(Process $process, SplObjectStorage $listeners, $bypassErrors) | ||||||
|  |     { | ||||||
|  |         $this->logger->info(sprintf( | ||||||
|  |             '%s running command %s', $this->name, $process->getCommandLine() | ||||||
|  |         )); | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             $process->run($this->buildCallback($listeners)); | ||||||
|  |         } catch (RuntimeException $e) { | ||||||
|  |             if (!$bypassErrors) { | ||||||
|  |                 $this->doExecutionFailure($process->getCommandLine(), $process->getErrorOutput(), $e); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |         if (!$bypassErrors && !$process->isSuccessful()) { | ||||||
|  |             $this->doExecutionFailure($process->getCommandLine(), $process->getErrorOutput()); | ||||||
|  |         } elseif (!$process->isSuccessful()) { | ||||||
|  |             $this->logger->error($this->createErrorMessage($process->getCommandLine(), $process->getErrorOutput())); | ||||||
|  |             return; | ||||||
|  |         } else { | ||||||
|  |             $this->logger->info(sprintf('%s executed command successfully', $this->name)); | ||||||
|  |             return $process->getOutput(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private function buildCallback(SplObjectStorage $listeners) | ||||||
|  |     { | ||||||
|  |         return function ($type, $data) use ($listeners) { | ||||||
|  |             foreach ($listeners as $listener) { | ||||||
|  |                 $listener->handle($type, $data); | ||||||
|  |             } | ||||||
|  |         }; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private function doExecutionFailure($command, $errorOutput, \Exception $e = null) | ||||||
|  |     { | ||||||
|  |         $this->logger->error($this->createErrorMessage($command, $errorOutput)); | ||||||
|  |         throw new ExecutionFailureException($this->name, $command, $errorOutput, | ||||||
|  |             $e ? $e->getCode() : 0, $e ?: null); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private function createErrorMessage($command, $errorOutput){ | ||||||
|  |         return sprintf('%s failed to execute command %s: %s', $this->name, $command, $errorOutput); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										29
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessRunnerAwareInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessRunnerAwareInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | interface ProcessRunnerAwareInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Returns the current process runner | ||||||
|  |      * | ||||||
|  |      * @return ProcessRunnerInterface | ||||||
|  |      */ | ||||||
|  |     public function getProcessRunner(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Sets a process runner | ||||||
|  |      * | ||||||
|  |      * @param ProcessRunnerInterface $runner | ||||||
|  |      */ | ||||||
|  |     public function setProcessRunner(ProcessRunnerInterface $runner); | ||||||
|  | } | ||||||
							
								
								
									
										33
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessRunnerInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								vendor/alchemy/binary-driver/src/Alchemy/BinaryDriver/ProcessRunnerInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\Exception\ExecutionFailureException; | ||||||
|  | use Psr\Log\LoggerAwareInterface; | ||||||
|  | use SplObjectStorage; | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  |  | ||||||
|  | interface ProcessRunnerInterface extends LoggerAwareInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Executes a process, logs events | ||||||
|  |      * | ||||||
|  |      * @param Process          $process | ||||||
|  |      * @param SplObjectStorage $listeners    Some listeners | ||||||
|  |      * @param Boolean          $bypassErrors Set to true to disable throwing ExecutionFailureExceptions | ||||||
|  |      * | ||||||
|  |      * @return string The Process output | ||||||
|  |      * | ||||||
|  |      * @throws ExecutionFailureException in case of process failure. | ||||||
|  |      */ | ||||||
|  |     public function run(Process $process, SplObjectStorage $listeners, $bypassErrors); | ||||||
|  | } | ||||||
							
								
								
									
										300
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/AbstractBinaryTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										300
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/AbstractBinaryTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,300 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\Tests\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\AbstractBinary; | ||||||
|  | use Alchemy\BinaryDriver\BinaryDriverTestCase; | ||||||
|  | use Alchemy\BinaryDriver\Configuration; | ||||||
|  | use Alchemy\BinaryDriver\Exception\ExecutableNotFoundException; | ||||||
|  | use Alchemy\BinaryDriver\Listeners\ListenerInterface; | ||||||
|  | use Symfony\Component\Process\ExecutableFinder; | ||||||
|  |  | ||||||
|  | class AbstractBinaryTest extends BinaryDriverTestCase | ||||||
|  | { | ||||||
|  |     protected function getPhpBinary() | ||||||
|  |     { | ||||||
|  |         $finder = new ExecutableFinder(); | ||||||
|  |         $php = $finder->find('php'); | ||||||
|  |  | ||||||
|  |         if (null === $php) { | ||||||
|  |             $this->markTestSkipped('Unable to find a php binary'); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return $php; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testSimpleLoadWithBinaryPath() | ||||||
|  |     { | ||||||
|  |         $php = $this->getPhpBinary(); | ||||||
|  |         $imp = Implementation::load($php); | ||||||
|  |         $this->assertInstanceOf('Alchemy\Tests\BinaryDriver\Implementation', $imp); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($php, $imp->getProcessBuilderFactory()->getBinary()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testMultipleLoadWithBinaryPath() | ||||||
|  |     { | ||||||
|  |         $php = $this->getPhpBinary(); | ||||||
|  |         $imp = Implementation::load(array('/zz/path/to/unexisting/command', $php)); | ||||||
|  |         $this->assertInstanceOf('Alchemy\Tests\BinaryDriver\Implementation', $imp); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($php, $imp->getProcessBuilderFactory()->getBinary()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testSimpleLoadWithBinaryName() | ||||||
|  |     { | ||||||
|  |         $php = $this->getPhpBinary(); | ||||||
|  |         $imp = Implementation::load('php'); | ||||||
|  |         $this->assertInstanceOf('Alchemy\Tests\BinaryDriver\Implementation', $imp); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($php, $imp->getProcessBuilderFactory()->getBinary()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testMultipleLoadWithBinaryName() | ||||||
|  |     { | ||||||
|  |         $php = $this->getPhpBinary(); | ||||||
|  |         $imp = Implementation::load(array('bachibouzouk', 'php')); | ||||||
|  |         $this->assertInstanceOf('Alchemy\Tests\BinaryDriver\Implementation', $imp); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($php, $imp->getProcessBuilderFactory()->getBinary()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testLoadWithMultiplePathExpectingAFailure() | ||||||
|  |     { | ||||||
|  |         $this->setExpectedException(ExecutableNotFoundException::class); | ||||||
|  |  | ||||||
|  |         Implementation::load(array('bachibouzouk', 'moribon')); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testLoadWithUniquePathExpectingAFailure() | ||||||
|  |     { | ||||||
|  |         $this->setExpectedException(ExecutableNotFoundException::class); | ||||||
|  |  | ||||||
|  |         Implementation::load('bachibouzouk'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testLoadWithCustomLogger() | ||||||
|  |     { | ||||||
|  |         $logger = $this->getMock('Psr\Log\LoggerInterface'); | ||||||
|  |         $imp = Implementation::load('php', $logger); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($logger, $imp->getProcessRunner()->getLogger()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testLoadWithCustomConfigurationAsArray() | ||||||
|  |     { | ||||||
|  |         $conf = array('timeout' => 200); | ||||||
|  |         $imp = Implementation::load('php', null, $conf); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($conf, $imp->getConfiguration()->all()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testLoadWithCustomConfigurationAsObject() | ||||||
|  |     { | ||||||
|  |         $conf = $this->getMock('Alchemy\BinaryDriver\ConfigurationInterface'); | ||||||
|  |         $imp = Implementation::load('php', null, $conf); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($conf, $imp->getConfiguration()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testProcessBuilderFactoryGetterAndSetters() | ||||||
|  |     { | ||||||
|  |         $imp = Implementation::load('php'); | ||||||
|  |         $factory = $this->getMock('Alchemy\BinaryDriver\ProcessBuilderFactoryInterface'); | ||||||
|  |  | ||||||
|  |         $imp->setProcessBuilderFactory($factory); | ||||||
|  |         $this->assertEquals($factory, $imp->getProcessBuilderFactory()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testConfigurationGetterAndSetters() | ||||||
|  |     { | ||||||
|  |         $imp = Implementation::load('php'); | ||||||
|  |         $conf = $this->getMock('Alchemy\BinaryDriver\ConfigurationInterface'); | ||||||
|  |  | ||||||
|  |         $imp->setConfiguration($conf); | ||||||
|  |         $this->assertEquals($conf, $imp->getConfiguration()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testTimeoutIsSetOnConstruction() | ||||||
|  |     { | ||||||
|  |         $imp = Implementation::load('php', null, array('timeout' => 42)); | ||||||
|  |         $this->assertEquals(42, $imp->getProcessBuilderFactory()->getTimeout()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testTimeoutIsSetOnConfigurationSetting() | ||||||
|  |     { | ||||||
|  |         $imp = Implementation::load('php', null); | ||||||
|  |         $imp->setConfiguration(new Configuration(array('timeout' => 42))); | ||||||
|  |         $this->assertEquals(42, $imp->getProcessBuilderFactory()->getTimeout()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testTimeoutIsSetOnProcessBuilderSetting() | ||||||
|  |     { | ||||||
|  |         $imp = Implementation::load('php', null, array('timeout' => 42)); | ||||||
|  |  | ||||||
|  |         $factory = $this->getMock('Alchemy\BinaryDriver\ProcessBuilderFactoryInterface'); | ||||||
|  |         $factory->expects($this->once()) | ||||||
|  |             ->method('setTimeout') | ||||||
|  |             ->with(42); | ||||||
|  |  | ||||||
|  |         $imp->setProcessBuilderFactory($factory); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testListenRegistersAListener() | ||||||
|  |     { | ||||||
|  |         $imp = Implementation::load('php'); | ||||||
|  |  | ||||||
|  |         $listeners = $this->getMockBuilder('Alchemy\BinaryDriver\Listeners\Listeners') | ||||||
|  |             ->disableOriginalConstructor() | ||||||
|  |             ->getMock(); | ||||||
|  |  | ||||||
|  |         $listener = $this->getMock('Alchemy\BinaryDriver\Listeners\ListenerInterface'); | ||||||
|  |  | ||||||
|  |         $listeners->expects($this->once()) | ||||||
|  |             ->method('register') | ||||||
|  |             ->with($this->equalTo($listener), $this->equalTo($imp)); | ||||||
|  |  | ||||||
|  |         $reflexion = new \ReflectionClass('Alchemy\BinaryDriver\AbstractBinary'); | ||||||
|  |         $prop = $reflexion->getProperty('listenersManager'); | ||||||
|  |         $prop->setAccessible(true); | ||||||
|  |         $prop->setValue($imp, $listeners); | ||||||
|  |  | ||||||
|  |         $imp->listen($listener); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @dataProvider provideCommandParameters | ||||||
|  |      */ | ||||||
|  |     public function testCommandRunsAProcess($parameters, $bypassErrors, $expectedParameters, $output) | ||||||
|  |     { | ||||||
|  |         $imp = Implementation::load('php'); | ||||||
|  |         $factory = $this->getMock('Alchemy\BinaryDriver\ProcessBuilderFactoryInterface'); | ||||||
|  |         $processRunner = $this->getMock('Alchemy\BinaryDriver\ProcessRunnerInterface'); | ||||||
|  |  | ||||||
|  |         $process = $this->getMockBuilder('Symfony\Component\Process\Process') | ||||||
|  |             ->disableOriginalConstructor() | ||||||
|  |             ->getMock(); | ||||||
|  |  | ||||||
|  |         $processRunner->expects($this->once()) | ||||||
|  |             ->method('run') | ||||||
|  |             ->with($this->equalTo($process), $this->isInstanceOf('SplObjectStorage'), $this->equalTo($bypassErrors)) | ||||||
|  |             ->will($this->returnValue($output)); | ||||||
|  |  | ||||||
|  |         $factory->expects($this->once()) | ||||||
|  |             ->method('create') | ||||||
|  |             ->with($expectedParameters) | ||||||
|  |             ->will($this->returnValue($process)); | ||||||
|  |  | ||||||
|  |         $imp->setProcessBuilderFactory($factory); | ||||||
|  |         $imp->setProcessRunner($processRunner); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($output, $imp->command($parameters, $bypassErrors)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @dataProvider provideCommandWithListenersParameters | ||||||
|  |      */ | ||||||
|  |     public function testCommandWithTemporaryListeners($parameters, $bypassErrors, $expectedParameters, $output, $count, $listeners) | ||||||
|  |     { | ||||||
|  |         $imp = Implementation::load('php'); | ||||||
|  |         $factory = $this->getMock('Alchemy\BinaryDriver\ProcessBuilderFactoryInterface'); | ||||||
|  |         $processRunner = $this->getMock('Alchemy\BinaryDriver\ProcessRunnerInterface'); | ||||||
|  |  | ||||||
|  |         $process = $this->getMockBuilder('Symfony\Component\Process\Process') | ||||||
|  |             ->disableOriginalConstructor() | ||||||
|  |             ->getMock(); | ||||||
|  |  | ||||||
|  |         $firstStorage = $secondStorage = null; | ||||||
|  |  | ||||||
|  |         $processRunner->expects($this->exactly(2)) | ||||||
|  |             ->method('run') | ||||||
|  |             ->with($this->equalTo($process), $this->isInstanceOf('SplObjectStorage'), $this->equalTo($bypassErrors)) | ||||||
|  |             ->will($this->returnCallback(function ($process, $storage, $errors) use ($output, &$firstStorage, &$secondStorage) { | ||||||
|  |                 if (null === $firstStorage) { | ||||||
|  |                     $firstStorage = $storage; | ||||||
|  |                 } else { | ||||||
|  |                     $secondStorage = $storage; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 return $output; | ||||||
|  |             })); | ||||||
|  |  | ||||||
|  |         $factory->expects($this->exactly(2)) | ||||||
|  |             ->method('create') | ||||||
|  |             ->with($expectedParameters) | ||||||
|  |             ->will($this->returnValue($process)); | ||||||
|  |  | ||||||
|  |         $imp->setProcessBuilderFactory($factory); | ||||||
|  |         $imp->setProcessRunner($processRunner); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($output, $imp->command($parameters, $bypassErrors, $listeners)); | ||||||
|  |         $this->assertCount($count, $firstStorage); | ||||||
|  |         $this->assertEquals($output, $imp->command($parameters, $bypassErrors)); | ||||||
|  |         $this->assertCount(0, $secondStorage); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function provideCommandWithListenersParameters() | ||||||
|  |     { | ||||||
|  |         return array( | ||||||
|  |             array('-a', false, array('-a'), 'loubda', 2, array($this->getMockListener(), $this->getMockListener())), | ||||||
|  |             array('-a', false, array('-a'), 'loubda', 1, array($this->getMockListener())), | ||||||
|  |             array('-a', false, array('-a'), 'loubda', 1, $this->getMockListener()), | ||||||
|  |             array('-a', false, array('-a'), 'loubda', 0, array()), | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function provideCommandParameters() | ||||||
|  |     { | ||||||
|  |         return array( | ||||||
|  |             array('-a', false, array('-a'), 'loubda'), | ||||||
|  |             array('-a', true, array('-a'), 'loubda'), | ||||||
|  |             array('-a -b', false, array('-a -b'), 'loubda'), | ||||||
|  |             array(array('-a'), false, array('-a'), 'loubda'), | ||||||
|  |             array(array('-a'), true, array('-a'), 'loubda'), | ||||||
|  |             array(array('-a', '-b'), false, array('-a', '-b'), 'loubda'), | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testUnlistenUnregistersAListener() | ||||||
|  |     { | ||||||
|  |         $imp = Implementation::load('php'); | ||||||
|  |  | ||||||
|  |         $listeners = $this->getMockBuilder('Alchemy\BinaryDriver\Listeners\Listeners') | ||||||
|  |             ->disableOriginalConstructor() | ||||||
|  |             ->getMock(); | ||||||
|  |  | ||||||
|  |         $listener = $this->getMock('Alchemy\BinaryDriver\Listeners\ListenerInterface'); | ||||||
|  |  | ||||||
|  |         $listeners->expects($this->once()) | ||||||
|  |             ->method('unregister') | ||||||
|  |             ->with($this->equalTo($listener), $this->equalTo($imp)); | ||||||
|  |  | ||||||
|  |         $reflexion = new \ReflectionClass('Alchemy\BinaryDriver\AbstractBinary'); | ||||||
|  |         $prop = $reflexion->getProperty('listenersManager'); | ||||||
|  |         $prop->setAccessible(true); | ||||||
|  |         $prop->setValue($imp, $listeners); | ||||||
|  |  | ||||||
|  |         $imp->unlisten($listener); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @return \PHPUnit_Framework_MockObject_MockObject | ||||||
|  |      */ | ||||||
|  |     private function getMockListener() | ||||||
|  |     { | ||||||
|  |         $listener = $this->getMock(ListenerInterface::class); | ||||||
|  |         $listener->expects($this->any()) | ||||||
|  |             ->method('forwardedEvents') | ||||||
|  |             ->willReturn(array()); | ||||||
|  |  | ||||||
|  |         return $listener; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class Implementation extends AbstractBinary | ||||||
|  | { | ||||||
|  |     public function getName() | ||||||
|  |     { | ||||||
|  |         return 'Implementation'; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,97 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\Tests\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Symfony\Component\Process\ExecutableFinder; | ||||||
|  | use Alchemy\BinaryDriver\ProcessBuilderFactory; | ||||||
|  |  | ||||||
|  | abstract class AbstractProcessBuilderFactoryTest extends \PHPUnit_Framework_TestCase | ||||||
|  | { | ||||||
|  |     public static $phpBinary; | ||||||
|  |  | ||||||
|  |     private $original; | ||||||
|  |     /** | ||||||
|  |      * @return ProcessBuilderFactory | ||||||
|  |      */ | ||||||
|  |     abstract protected function getProcessBuilderFactory($binary); | ||||||
|  |  | ||||||
|  |     public function setUp() | ||||||
|  |     { | ||||||
|  |         ProcessBuilderFactory::$emulateSfLTS = null; | ||||||
|  |         if (null === static::$phpBinary) { | ||||||
|  |             $this->markTestSkipped('Unable to detect php binary, skipping'); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static function setUpBeforeClass() | ||||||
|  |     { | ||||||
|  |         $finder = new ExecutableFinder(); | ||||||
|  |         static::$phpBinary = $finder->find('php'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testThatBinaryIsSetOnConstruction() | ||||||
|  |     { | ||||||
|  |         $factory = $this->getProcessBuilderFactory(static::$phpBinary); | ||||||
|  |         $this->assertEquals(static::$phpBinary, $factory->getBinary()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testGetSetBinary() | ||||||
|  |     { | ||||||
|  |         $finder = new ExecutableFinder(); | ||||||
|  |         $phpUnit = $finder->find('phpunit'); | ||||||
|  |  | ||||||
|  |         if (null === $phpUnit) { | ||||||
|  |             $this->markTestSkipped('Unable to detect phpunit binary, skipping'); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $factory = $this->getProcessBuilderFactory(static::$phpBinary); | ||||||
|  |         $factory->useBinary($phpUnit); | ||||||
|  |         $this->assertEquals($phpUnit, $factory->getBinary()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @expectedException Alchemy\BinaryDriver\Exception\InvalidArgumentException | ||||||
|  |      */ | ||||||
|  |     public function testUseNonExistantBinary() | ||||||
|  |     { | ||||||
|  |         $factory = $this->getProcessBuilderFactory(static::$phpBinary); | ||||||
|  |         $factory->useBinary('itissureitdoesnotexist'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testCreateShouldReturnAProcess() | ||||||
|  |     { | ||||||
|  |         $factory = $this->getProcessBuilderFactory(static::$phpBinary); | ||||||
|  |         $process = $factory->create(); | ||||||
|  |  | ||||||
|  |         $this->assertInstanceOf('Symfony\Component\Process\Process', $process); | ||||||
|  |         $this->assertEquals("'".static::$phpBinary."'", $process->getCommandLine()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testCreateWithStringArgument() | ||||||
|  |     { | ||||||
|  |         $factory = $this->getProcessBuilderFactory(static::$phpBinary); | ||||||
|  |         $process = $factory->create('-v'); | ||||||
|  |  | ||||||
|  |         $this->assertInstanceOf('Symfony\Component\Process\Process', $process); | ||||||
|  |         $this->assertEquals("'".static::$phpBinary."' '-v'", $process->getCommandLine()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testCreateWithArrayArgument() | ||||||
|  |     { | ||||||
|  |         $factory = $this->getProcessBuilderFactory(static::$phpBinary); | ||||||
|  |         $process = $factory->create(array('-r', 'echo "Hello !";')); | ||||||
|  |  | ||||||
|  |         $this->assertInstanceOf('Symfony\Component\Process\Process', $process); | ||||||
|  |         $this->assertEquals("'".static::$phpBinary."' '-r' 'echo \"Hello !\";'", $process->getCommandLine()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testCreateWithTimeout() | ||||||
|  |     { | ||||||
|  |         $factory = $this->getProcessBuilderFactory(static::$phpBinary); | ||||||
|  |         $factory->setTimeout(200); | ||||||
|  |         $process = $factory->create(array('-i')); | ||||||
|  |  | ||||||
|  |         $this->assertInstanceOf('Symfony\Component\Process\Process', $process); | ||||||
|  |         $this->assertEquals(200, $process->getTimeout()); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										78
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/ConfigurationTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/ConfigurationTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,78 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\Tests\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\Configuration; | ||||||
|  |  | ||||||
|  | class ConfigurationTest extends \PHPUnit_Framework_TestCase | ||||||
|  | { | ||||||
|  |     public function testArrayAccessImplementation() | ||||||
|  |     { | ||||||
|  |         $configuration = new Configuration(array('key' => 'value')); | ||||||
|  |  | ||||||
|  |         $this->assertTrue(isset($configuration['key'])); | ||||||
|  |         $this->assertEquals('value', $configuration['key']); | ||||||
|  |  | ||||||
|  |         $this->assertFalse(isset($configuration['key2'])); | ||||||
|  |         unset($configuration['key']); | ||||||
|  |         $this->assertFalse(isset($configuration['key'])); | ||||||
|  |  | ||||||
|  |         $configuration['key2'] = 'value2'; | ||||||
|  |         $this->assertTrue(isset($configuration['key2'])); | ||||||
|  |         $this->assertEquals('value2', $configuration['key2']); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testGetOnNonExistentKeyShouldReturnDefaultValue() | ||||||
|  |     { | ||||||
|  |         $conf = new Configuration(); | ||||||
|  |         $this->assertEquals('booba', $conf->get('hooba', 'booba')); | ||||||
|  |         $this->assertEquals(null, $conf->get('hooba')); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testSetHasGetRemove() | ||||||
|  |     { | ||||||
|  |         $configuration = new Configuration(array('key' => 'value')); | ||||||
|  |  | ||||||
|  |         $this->assertTrue($configuration->has('key')); | ||||||
|  |         $this->assertEquals('value', $configuration->get('key')); | ||||||
|  |  | ||||||
|  |         $this->assertFalse($configuration->has('key2')); | ||||||
|  |         $configuration->remove('key'); | ||||||
|  |         $this->assertFalse($configuration->has('key')); | ||||||
|  |  | ||||||
|  |         $configuration->set('key2', 'value2'); | ||||||
|  |         $this->assertTrue($configuration->has('key2')); | ||||||
|  |         $this->assertEquals('value2', $configuration->get('key2')); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testIterator() | ||||||
|  |     { | ||||||
|  |         $data = array( | ||||||
|  |             'key1' => 'value1', | ||||||
|  |             'key2' => 'value2', | ||||||
|  |             'key3' => 'value3', | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $captured = array(); | ||||||
|  |         $conf = new Configuration($data); | ||||||
|  |  | ||||||
|  |         foreach ($conf as $key => $value) { | ||||||
|  |             $captured[$key] = $value; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $this->assertEquals($data, $captured); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testAll() | ||||||
|  |     { | ||||||
|  |         $data = array( | ||||||
|  |             'key1' => 'value1', | ||||||
|  |             'key2' => 'value2', | ||||||
|  |             'key3' => 'value3', | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $conf = new Configuration($data); | ||||||
|  |         $this->assertEquals($data, $conf->all()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,33 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\Tests\BinaryDriver\Exceptions; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\BinaryDriverTestCase; | ||||||
|  | use Alchemy\BinaryDriver\Exception\ExecutionFailureException; | ||||||
|  | use Alchemy\BinaryDriver\ProcessRunner; | ||||||
|  |  | ||||||
|  | class ExecutionFailureExceptionTest extends BinaryDriverTestCase | ||||||
|  | { | ||||||
|  |     public function getProcessRunner($logger) | ||||||
|  |     { | ||||||
|  |         return new ProcessRunner($logger, 'test-runner'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testGetExceptionInfo(){ | ||||||
|  |  | ||||||
|  |         $logger = $this->createLoggerMock(); | ||||||
|  |         $runner = $this->getProcessRunner($logger); | ||||||
|  |  | ||||||
|  |         $process = $this->createProcessMock(1, false, '--helloworld--', null, "Error Output", true); | ||||||
|  |         try{ | ||||||
|  |             $runner->run($process, new \SplObjectStorage(), false); | ||||||
|  |             $this->fail('An exception should have been raised'); | ||||||
|  |         } | ||||||
|  |         catch (ExecutionFailureException $e){ | ||||||
|  |             $this->assertEquals("--helloworld--", $e->getCommand()); | ||||||
|  |             $this->assertEquals("Error Output", $e->getErrorOutput()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										54
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/LTSProcessBuilder.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/LTSProcessBuilder.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\Tests\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\ProcessBuilderFactory; | ||||||
|  | use LogicException; | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  | use Symfony\Component\Process\ProcessBuilder; | ||||||
|  |  | ||||||
|  | class LTSProcessBuilder extends ProcessBuilder | ||||||
|  | { | ||||||
|  |     private $arguments; | ||||||
|  |     private $prefix; | ||||||
|  |     private $timeout; | ||||||
|  |  | ||||||
|  |     public function __construct(array $arguments = array()) | ||||||
|  |     { | ||||||
|  |         $this->arguments = $arguments; | ||||||
|  |         parent::__construct($arguments); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function setArguments(array $arguments) | ||||||
|  |     { | ||||||
|  |         $this->arguments = $arguments; | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function setPrefix($prefix) | ||||||
|  |     { | ||||||
|  |         $this->prefix = $prefix; | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function setTimeout($timeout) | ||||||
|  |     { | ||||||
|  |         $this->timeout = $timeout; | ||||||
|  |  | ||||||
|  |         return $this; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function getProcess() | ||||||
|  |     { | ||||||
|  |         if (!$this->prefix && !count($this->arguments)) { | ||||||
|  |             throw new LogicException('You must add() command arguments before calling getProcess().'); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $args = $this->prefix ? array_merge(array($this->prefix), $this->arguments) : $this->arguments; | ||||||
|  |         $script = implode(' ', array_map('escapeshellarg', $args)); | ||||||
|  |  | ||||||
|  |         return new Process($script, null, null, null, $this->timeout); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										28
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/LTSProcessBuilderFactoryTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/LTSProcessBuilderFactoryTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\Tests\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\ProcessBuilderFactory; | ||||||
|  |  | ||||||
|  | class LTSProcessBuilderFactoryTest extends AbstractProcessBuilderFactoryTest | ||||||
|  | { | ||||||
|  |     public function setUp() | ||||||
|  |     { | ||||||
|  |         if (!class_exists('Symfony\Component\Process\ProcessBuilder')) { | ||||||
|  |             $this->markTestSkipped('ProcessBuilder is not available.'); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         parent::setUp(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected function getProcessBuilderFactory($binary) | ||||||
|  |     { | ||||||
|  |         $factory = new ProcessBuilderFactory($binary); | ||||||
|  |         $factory->setBuilder(new LTSProcessBuilder()); | ||||||
|  |         ProcessBuilderFactory::$emulateSfLTS = false; | ||||||
|  |         $factory->useBinary($binary); | ||||||
|  |  | ||||||
|  |         return $factory; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										33
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/Listeners/DebugListenerTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/Listeners/DebugListenerTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\Tests\BinaryDriver\Listeners; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\Listeners\DebugListener; | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  |  | ||||||
|  | class DebugListenerTest extends \PHPUnit_Framework_TestCase | ||||||
|  | { | ||||||
|  |     public function testHandle() | ||||||
|  |     { | ||||||
|  |         $listener = new DebugListener(); | ||||||
|  |  | ||||||
|  |         $lines = array(); | ||||||
|  |         $listener->on('debug', function ($line) use (&$lines) { | ||||||
|  |             $lines[] = $line; | ||||||
|  |         }); | ||||||
|  |         $listener->handle(Process::ERR, "first line\nsecond line"); | ||||||
|  |         $listener->handle(Process::OUT, "cool output"); | ||||||
|  |         $listener->handle('unknown', "lalala"); | ||||||
|  |         $listener->handle(Process::OUT, "another output\n"); | ||||||
|  |  | ||||||
|  |         $expected = array( | ||||||
|  |             '[ERROR] first line', | ||||||
|  |             '[ERROR] second line', | ||||||
|  |             '[OUT] cool output', | ||||||
|  |             '[OUT] another output', | ||||||
|  |             '[OUT] ', | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($expected, $lines); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										92
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/Listeners/ListenersTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/Listeners/ListenersTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,92 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\Tests\BinaryDriver\Listeners; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\Listeners\Listeners; | ||||||
|  | use Evenement\EventEmitter; | ||||||
|  | use Alchemy\BinaryDriver\Listeners\ListenerInterface; | ||||||
|  |  | ||||||
|  | class ListenersTest extends \PHPUnit_Framework_TestCase | ||||||
|  | { | ||||||
|  |     public function testRegister() | ||||||
|  |     { | ||||||
|  |         $listener = new MockListener(); | ||||||
|  |  | ||||||
|  |         $listeners = new Listeners(); | ||||||
|  |         $listeners->register($listener); | ||||||
|  |  | ||||||
|  |         $n = 0; | ||||||
|  |         $listener->on('received', function ($type, $data) use (&$n, &$capturedType, &$capturedData) { | ||||||
|  |             $n++; | ||||||
|  |             $capturedData = $data; | ||||||
|  |             $capturedType = $type; | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         $type = 'type'; | ||||||
|  |         $data = 'data'; | ||||||
|  |  | ||||||
|  |         $listener->handle($type, $data); | ||||||
|  |         $listener->handle($type, $data); | ||||||
|  |  | ||||||
|  |         $listeners->unregister($listener); | ||||||
|  |  | ||||||
|  |         $listener->handle($type, $data); | ||||||
|  |  | ||||||
|  |         $this->assertEquals(3, $n); | ||||||
|  |         $this->assertEquals($type, $capturedType); | ||||||
|  |         $this->assertEquals($data, $capturedData); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testRegisterAndForwardThenUnregister() | ||||||
|  |     { | ||||||
|  |         $listener = new MockListener(); | ||||||
|  |         $target = new EventEmitter(); | ||||||
|  |  | ||||||
|  |         $n = 0; | ||||||
|  |         $target->on('received', function ($type, $data) use (&$n, &$capturedType, &$capturedData) { | ||||||
|  |             $n++; | ||||||
|  |             $capturedData = $data; | ||||||
|  |             $capturedType = $type; | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         $m = 0; | ||||||
|  |         $listener->on('received', function ($type, $data) use (&$m, &$capturedType2, &$capturedData2) { | ||||||
|  |             $m++; | ||||||
|  |             $capturedData2 = $data; | ||||||
|  |             $capturedType2 = $type; | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         $listeners = new Listeners(); | ||||||
|  |         $listeners->register($listener, $target); | ||||||
|  |  | ||||||
|  |         $type = 'type'; | ||||||
|  |         $data = 'data'; | ||||||
|  |  | ||||||
|  |         $listener->handle($type, $data); | ||||||
|  |         $listener->handle($type, $data); | ||||||
|  |  | ||||||
|  |         $listeners->unregister($listener, $target); | ||||||
|  |  | ||||||
|  |         $listener->handle($type, $data); | ||||||
|  |  | ||||||
|  |         $this->assertEquals(2, $n); | ||||||
|  |         $this->assertEquals(3, $m); | ||||||
|  |         $this->assertEquals($type, $capturedType); | ||||||
|  |         $this->assertEquals($data, $capturedData); | ||||||
|  |         $this->assertEquals($type, $capturedType2); | ||||||
|  |         $this->assertEquals($data, $capturedData2); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class MockListener extends EventEmitter implements ListenerInterface | ||||||
|  | { | ||||||
|  |     public function handle($type, $data) | ||||||
|  |     { | ||||||
|  |         $this->emit('received', array($type, $data)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function forwardedEvents() | ||||||
|  |     { | ||||||
|  |         return array('received'); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,15 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace Alchemy\Tests\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\ProcessBuilderFactory; | ||||||
|  |  | ||||||
|  | class NONLTSProcessBuilderFactoryTest extends AbstractProcessBuilderFactoryTest | ||||||
|  | { | ||||||
|  |     protected function getProcessBuilderFactory($binary) | ||||||
|  |     { | ||||||
|  |         ProcessBuilderFactory::$emulateSfLTS = true; | ||||||
|  |  | ||||||
|  |         return new ProcessBuilderFactory($binary); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										208
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/ProcessRunnerTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										208
									
								
								vendor/alchemy/binary-driver/tests/Alchemy/Tests/BinaryDriver/ProcessRunnerTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,208 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of Alchemy\BinaryDriver. | ||||||
|  |  * | ||||||
|  |  * (c) Alchemy <info@alchemy.fr> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Alchemy\Tests\BinaryDriver; | ||||||
|  |  | ||||||
|  | use Alchemy\BinaryDriver\ProcessRunner; | ||||||
|  | use Alchemy\BinaryDriver\BinaryDriverTestCase; | ||||||
|  | use Alchemy\BinaryDriver\Exception\ExecutionFailureException; | ||||||
|  | use Alchemy\BinaryDriver\Listeners\ListenerInterface; | ||||||
|  | use Evenement\EventEmitter; | ||||||
|  | use Symfony\Component\Process\Exception\RuntimeException as ProcessRuntimeException; | ||||||
|  |  | ||||||
|  | class ProcessRunnerTest extends BinaryDriverTestCase | ||||||
|  | { | ||||||
|  |     public function getProcessRunner($logger) | ||||||
|  |     { | ||||||
|  |         return new ProcessRunner($logger, 'test-runner'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testRunSuccessFullProcess() | ||||||
|  |     { | ||||||
|  |         $logger = $this->createLoggerMock(); | ||||||
|  |         $runner = $this->getProcessRunner($logger); | ||||||
|  |  | ||||||
|  |         $process = $this->createProcessMock(1, true, '--helloworld--', "Kikoo Romain", null, true); | ||||||
|  |  | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->never()) | ||||||
|  |             ->method('error'); | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->exactly(2)) | ||||||
|  |             ->method('info'); | ||||||
|  |  | ||||||
|  |         $this->assertEquals('Kikoo Romain', $runner->run($process, new \SplObjectStorage(), false)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testRunSuccessFullProcessBypassingErrors() | ||||||
|  |     { | ||||||
|  |         $logger = $this->createLoggerMock(); | ||||||
|  |         $runner = $this->getProcessRunner($logger); | ||||||
|  |  | ||||||
|  |         $process = $this->createProcessMock(1, true, '--helloworld--', "Kikoo Romain", null, true); | ||||||
|  |  | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->never()) | ||||||
|  |             ->method('error'); | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->exactly(2)) | ||||||
|  |             ->method('info'); | ||||||
|  |  | ||||||
|  |         $this->assertEquals('Kikoo Romain', $runner->run($process, new \SplObjectStorage(), true)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testRunFailingProcess() | ||||||
|  |     { | ||||||
|  |         $logger = $this->createLoggerMock(); | ||||||
|  |         $runner = $this->getProcessRunner($logger); | ||||||
|  |  | ||||||
|  |         $process = $this->createProcessMock(1, false, '--helloworld--', null, null, true); | ||||||
|  |  | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->once()) | ||||||
|  |             ->method('error'); | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->once()) | ||||||
|  |             ->method('info'); | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             $runner->run($process, new \SplObjectStorage(), false); | ||||||
|  |             $this->fail('An exception should have been raised'); | ||||||
|  |         } catch (ExecutionFailureException $e) { | ||||||
|  |  | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testRunFailingProcessWithException() | ||||||
|  |     { | ||||||
|  |         $logger = $this->createLoggerMock(); | ||||||
|  |         $runner = $this->getProcessRunner($logger); | ||||||
|  |  | ||||||
|  |         $exception = new ProcessRuntimeException('Process Failed'); | ||||||
|  |         $process = $this->getMockBuilder('Symfony\Component\Process\Process') | ||||||
|  |             ->disableOriginalConstructor() | ||||||
|  |             ->getMock(); | ||||||
|  |         $process->expects($this->once()) | ||||||
|  |             ->method('run') | ||||||
|  |             ->will($this->throwException($exception)); | ||||||
|  |  | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->once()) | ||||||
|  |             ->method('error'); | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->once()) | ||||||
|  |             ->method('info'); | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             $runner->run($process, new \SplObjectStorage(), false); | ||||||
|  |             $this->fail('An exception should have been raised'); | ||||||
|  |         } catch (ExecutionFailureException $e) { | ||||||
|  |             $this->assertEquals($exception, $e->getPrevious()); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testRunfailingProcessBypassingErrors() | ||||||
|  |     { | ||||||
|  |         $logger = $this->createLoggerMock(); | ||||||
|  |         $runner = $this->getProcessRunner($logger); | ||||||
|  |  | ||||||
|  |         $process = $this->createProcessMock(1, false, '--helloworld--', 'Hello output', null, true); | ||||||
|  |  | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->once()) | ||||||
|  |             ->method('error'); | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->once()) | ||||||
|  |             ->method('info'); | ||||||
|  |  | ||||||
|  |         $this->assertNull($runner->run($process, new \SplObjectStorage(), true)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testRunFailingProcessWithExceptionBypassingErrors() | ||||||
|  |     { | ||||||
|  |         $logger = $this->createLoggerMock(); | ||||||
|  |         $runner = $this->getProcessRunner($logger); | ||||||
|  |  | ||||||
|  |         $exception = new ProcessRuntimeException('Process Failed'); | ||||||
|  |         $process = $this->getMockBuilder('Symfony\Component\Process\Process') | ||||||
|  |             ->disableOriginalConstructor() | ||||||
|  |             ->getMock(); | ||||||
|  |         $process->expects($this->once()) | ||||||
|  |             ->method('run') | ||||||
|  |             ->will($this->throwException($exception)); | ||||||
|  |  | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->once()) | ||||||
|  |             ->method('error'); | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->once()) | ||||||
|  |             ->method('info'); | ||||||
|  |  | ||||||
|  |         $this->assertNull($runner->run($process, new \SplObjectStorage(), true)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testRunSuccessFullProcessWithHandlers() | ||||||
|  |     { | ||||||
|  |         $logger = $this->createLoggerMock(); | ||||||
|  |         $runner = $this->getProcessRunner($logger); | ||||||
|  |  | ||||||
|  |         $capturedCallback = null; | ||||||
|  |  | ||||||
|  |         $process = $this->createProcessMock(1, true, '--helloworld--', "Kikoo Romain", null, true); | ||||||
|  |         $process->expects($this->once()) | ||||||
|  |             ->method('run') | ||||||
|  |             ->with($this->isInstanceOf('Closure')) | ||||||
|  |             ->will($this->returnCallback(function ($callback) use (&$capturedCallback) { | ||||||
|  |                 $capturedCallback = $callback; | ||||||
|  |             })); | ||||||
|  |  | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->never()) | ||||||
|  |             ->method('error'); | ||||||
|  |         $logger | ||||||
|  |             ->expects($this->exactly(2)) | ||||||
|  |             ->method('info'); | ||||||
|  |  | ||||||
|  |         $listener = new TestListener(); | ||||||
|  |         $storage = new \SplObjectStorage(); | ||||||
|  |         $storage->attach($listener); | ||||||
|  |  | ||||||
|  |         $capturedType = $capturedData = null; | ||||||
|  |  | ||||||
|  |         $listener->on('received', function ($type, $data) use (&$capturedType, &$capturedData) { | ||||||
|  |             $capturedData = $data; | ||||||
|  |             $capturedType = $type; | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         $this->assertEquals('Kikoo Romain', $runner->run($process, $storage, false)); | ||||||
|  |  | ||||||
|  |         $type = 'err'; | ||||||
|  |         $data = 'data'; | ||||||
|  |  | ||||||
|  |         $capturedCallback($type, $data); | ||||||
|  |  | ||||||
|  |         $this->assertEquals($data, $capturedData); | ||||||
|  |         $this->assertEquals($type, $capturedType); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class TestListener extends EventEmitter implements ListenerInterface | ||||||
|  | { | ||||||
|  |     public function handle($type, $data) | ||||||
|  |     { | ||||||
|  |         return $this->emit('received', array($type, $data)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function forwardedEvents() | ||||||
|  |     { | ||||||
|  |         return array(); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										4
									
								
								vendor/alchemy/binary-driver/tests/bootstrap.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								vendor/alchemy/binary-driver/tests/bootstrap.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | $loader = require __DIR__.'/../vendor/autoload.php'; | ||||||
|  | $loader->add('Alchemy\Tests', __DIR__); | ||||||
							
								
								
									
										1
									
								
								vendor/bin/phpdoc
									
									
									
									
										vendored
									
									
										Symbolic link
									
								
							
							
						
						
									
										1
									
								
								vendor/bin/phpdoc
									
									
									
									
										vendored
									
									
										Symbolic link
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | ../phpdocumentor/phpdocumentor/bin/phpdoc | ||||||
							
								
								
									
										1
									
								
								vendor/bin/phpdoc.php
									
									
									
									
										vendored
									
									
										Symbolic link
									
								
							
							
						
						
									
										1
									
								
								vendor/bin/phpdoc.php
									
									
									
									
										vendored
									
									
										Symbolic link
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | ../phpdocumentor/phpdocumentor/bin/phpdoc.php | ||||||
							
								
								
									
										1
									
								
								vendor/bin/phpunit
									
									
									
									
										vendored
									
									
										Symbolic link
									
								
							
							
						
						
									
										1
									
								
								vendor/bin/phpunit
									
									
									
									
										vendored
									
									
										Symbolic link
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | ../phpunit/phpunit/phpunit | ||||||
							
								
								
									
										1
									
								
								vendor/bin/psysh
									
									
									
									
										vendored
									
									
										Symbolic link
									
								
							
							
						
						
									
										1
									
								
								vendor/bin/psysh
									
									
									
									
										vendored
									
									
										Symbolic link
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | ../psy/psysh/bin/psysh | ||||||
							
								
								
									
										7
									
								
								vendor/cilex/cilex/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								vendor/cilex/cilex/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | vendor | ||||||
|  | phpunit.xml | ||||||
|  | cilex.phar | ||||||
|  | .idea | ||||||
|  | composer.phar | ||||||
|  | .vagrant | ||||||
|  | docs/.build | ||||||
							
								
								
									
										32
									
								
								vendor/cilex/cilex/.puppet/manifests/manifest.pp
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								vendor/cilex/cilex/.puppet/manifests/manifest.pp
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | group { "puppet": | ||||||
|  |     ensure => "present", | ||||||
|  | } | ||||||
|  |  | ||||||
|  | node default { | ||||||
|  |     exec { "apt-get update": | ||||||
|  |       command => "/usr/bin/apt-get update" | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     package{["git", "python-setuptools", "wget", "make", "texlive-latex-recommended", "texlive-latex-extra", "texlive-fonts-recommended", "openjdk-6-jre", "php5-cli", "php5-xdebug"]: | ||||||
|  |         ensure  => present, | ||||||
|  |         require => Exec["apt-get update"] | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     exec { "sudo easy_install -U sphinx": | ||||||
|  |         command => "/usr/bin/sudo /usr/bin/easy_install -U sphinx", | ||||||
|  |         require => [ Package["python-setuptools"] ], | ||||||
|  |         timeout => 0 | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     exec { "get-composer": | ||||||
|  |         command => "/usr/bin/wget -N http://getcomposer.org/composer.phar", | ||||||
|  |         require => Package["wget"], | ||||||
|  |         cwd     => "/vagrant" | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     exec { "composer-install": | ||||||
|  |         command => "/usr/bin/php composer.phar install --dev", | ||||||
|  |         require => Exec["get-composer"], | ||||||
|  |         cwd     => "/vagrant" | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										13
									
								
								vendor/cilex/cilex/.travis.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								vendor/cilex/cilex/.travis.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | language: php | ||||||
|  | php: | ||||||
|  |   - 5.3 | ||||||
|  |   - 5.4 | ||||||
|  |  | ||||||
|  | before_script: | ||||||
|  |   - composer install | ||||||
|  |  | ||||||
|  | script: phpunit --coverage-text | ||||||
|  |  | ||||||
|  | notifications: | ||||||
|  |   email: | ||||||
|  |     - mike.vanriel@naenius.com | ||||||
							
								
								
									
										19
									
								
								vendor/cilex/cilex/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								vendor/cilex/cilex/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | Copyright (c) 2012 Mike van Riel | ||||||
|  |  | ||||||
|  | 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. | ||||||
							
								
								
									
										70
									
								
								vendor/cilex/cilex/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								vendor/cilex/cilex/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | |||||||
|  | Cilex, a simple Command Line Interface framework | ||||||
|  | ================================================ | ||||||
|  |  | ||||||
|  | Cilex is a simple command line application framework to develop simple tools | ||||||
|  | based on [Symfony2][1] components: | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | <?php | ||||||
|  | require_once __DIR__.'/cilex.phar'; | ||||||
|  |  | ||||||
|  | $app = new \Cilex\Application('Cilex'); | ||||||
|  | $app->command(new \Cilex\Command\GreetCommand()); | ||||||
|  | $app->run(); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Cilex works with PHP 5.3.3 or later and is heavily inspired on the [Silex][2] | ||||||
|  | web micro-framework by Fabien Potencier. | ||||||
|  |  | ||||||
|  | ## Installation | ||||||
|  |  | ||||||
|  |  1. `git clone` _this_ repository. | ||||||
|  |  2. Download composer: `curl -s https://getcomposer.org/installer | php` | ||||||
|  |  3. Install Cilex' dependencies: `php composer.phar install` | ||||||
|  |  4. Create the phar: `php ./compile` | ||||||
|  |  | ||||||
|  | <!-- | ||||||
|  | ## More Information | ||||||
|  |  | ||||||
|  | Read the [documentation][4] for more information. | ||||||
|  | --> | ||||||
|  |  | ||||||
|  | ## Usage | ||||||
|  |  | ||||||
|  |  - Download composer: `curl -s https://getcomposer.org/installer | php` | ||||||
|  |  - Add to your dependencies:  `php composer.phar require cilex/cilex dev-master` | ||||||
|  |  - Update the dependencies | ||||||
|  |  - Create a `run.php` file | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | <?php | ||||||
|  | if (!$loader = include __DIR__.'/vendor/autoload.php') { | ||||||
|  |     die('You must set up the project dependencies.'); | ||||||
|  | } | ||||||
|  | $app = new \Cilex\Application('Cilex'); | ||||||
|  | $app->command(new \Cilex\Command\GreetCommand()); | ||||||
|  | $app->run(); | ||||||
|  | ``` | ||||||
|  |  - `php run.php` | ||||||
|  |  - enjoy a lot. | ||||||
|  |  | ||||||
|  | ## License | ||||||
|  |  | ||||||
|  | Cilex is licensed under the MIT license. | ||||||
|  |  | ||||||
|  | [1]: http://symfony.com | ||||||
|  | [2]: http://silex.sensiolabs.org | ||||||
|  | [3]: http://cilex.github.com/get/cilex.phar | ||||||
|  | [4]: http://cilex.github.com/documentation | ||||||
|  |  | ||||||
|  | ## FAQ | ||||||
|  |  | ||||||
|  | Q: How do I pass configuration into the application? | ||||||
|  |  | ||||||
|  | A: You can do this by adding the following line, where $configPath is the path to the configuration file you want to use: | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | $app->register(new \Cilex\Provider\ConfigServiceProvider(), array('config.path' => $configPath)); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | The formats currently supported are: YAML, XML and JSON | ||||||
							
								
								
									
										13
									
								
								vendor/cilex/cilex/Vagrantfile
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								vendor/cilex/cilex/Vagrantfile
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | # -*- mode: ruby -*- | ||||||
|  | # vi: set ft=ruby : | ||||||
|  |  | ||||||
|  | Vagrant::Config.run do |config| | ||||||
|  |   config.vm.box     = "precise64" | ||||||
|  |   config.vm.box_url = "http://files.vagrantup.com/precise64.box" | ||||||
|  |  | ||||||
|  |   config.vm.provision :puppet do |puppet| | ||||||
|  |      puppet.manifests_path = ".puppet/manifests" | ||||||
|  |      puppet.manifest_file  = "manifest.pp" | ||||||
|  |      puppet.options        = [ '--verbose' ] | ||||||
|  |   end | ||||||
|  | end | ||||||
							
								
								
									
										13
									
								
								vendor/cilex/cilex/bin/compile
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								vendor/cilex/cilex/bin/compile
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | #!/usr/bin/env php | ||||||
|  | <?php | ||||||
|  | $autoload = __DIR__ . '/../vendor/autoload.php'; | ||||||
|  | if (!file_exists($autoload)) { | ||||||
|  |     echo "Please run `php composer.phar install` first." . PHP_EOL; | ||||||
|  |     exit(1); | ||||||
|  | } | ||||||
|  | require_once $autoload; | ||||||
|  |  | ||||||
|  | use Cilex\Compiler; | ||||||
|  |  | ||||||
|  | $compiler = new Compiler(); | ||||||
|  | $compiler->compile(); | ||||||
							
								
								
									
										32
									
								
								vendor/cilex/cilex/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								vendor/cilex/cilex/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |     "name":        "cilex/cilex", | ||||||
|  |     "description": "The PHP micro-framework for Command line tools based on the Symfony2 Components", | ||||||
|  |     "keywords":    ["microframework","cli"], | ||||||
|  |     "homepage":    "http://cilex.github.com", | ||||||
|  |     "license":     "MIT", | ||||||
|  |     "autoload":{ | ||||||
|  |         "psr-0":{ "Cilex": "src/" } | ||||||
|  |     }, | ||||||
|  |     "authors":[ | ||||||
|  |         { "name":  "Mike van Riel", "email": "mike.vanriel@naenius.com" } | ||||||
|  |     ], | ||||||
|  |     "require":{ | ||||||
|  |         "php":                            ">=5.3.3", | ||||||
|  |         "pimple/pimple":                  "~1.0", | ||||||
|  |         "symfony/process":                "~2.1", | ||||||
|  |         "symfony/finder":                 "~2.1", | ||||||
|  |         "cilex/console-service-provider": "1.*" | ||||||
|  |     }, | ||||||
|  |     "require-dev":{ | ||||||
|  |         "symfony/validator": "~2.1", | ||||||
|  |         "phpunit/phpunit":   "3.7.*" | ||||||
|  |     }, | ||||||
|  |     "suggest":{ | ||||||
|  |         "monolog/monolog":   ">=1.0.0", | ||||||
|  |         "symfony/yaml":      ">=1.0.0", | ||||||
|  |         "symfony/validator": ">=1.0.0" | ||||||
|  |     }, | ||||||
|  |     "extra":{ | ||||||
|  |         "branch-alias": { "dev-master": "1.0-dev" } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										884
									
								
								vendor/cilex/cilex/composer.lock
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										884
									
								
								vendor/cilex/cilex/composer.lock
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,884 @@ | |||||||
|  | { | ||||||
|  |     "_readme": [ | ||||||
|  |         "This file locks the dependencies of your project to a known state", | ||||||
|  |         "Read more about it at http://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file" | ||||||
|  |     ], | ||||||
|  |     "hash": "028ed7b39a4c2a5ccba9e34589868ee4", | ||||||
|  |     "packages": [ | ||||||
|  |         { | ||||||
|  |             "name": "cilex/console-service-provider", | ||||||
|  |             "version": "1.0.0", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/Cilex/console-service-provider.git", | ||||||
|  |                 "reference": "1.0.0" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/Cilex/console-service-provider/zipball/1.0.0", | ||||||
|  |                 "reference": "1.0.0", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3", | ||||||
|  |                 "pimple/pimple": "1.*@dev", | ||||||
|  |                 "symfony/console": "~2.1" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "cilex/cilex": "1.*@dev", | ||||||
|  |                 "silex/silex": "1.*@dev" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "1.0-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Cilex\\Provider\\Console": "src" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Beau Simensen", | ||||||
|  |                     "email": "beau@dflydev.com", | ||||||
|  |                     "homepage": "http://beausimensen.com" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Mike van Riel", | ||||||
|  |                     "email": "mike.vanriel@naenius.com" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Console Service Provider", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "cilex", | ||||||
|  |                 "console", | ||||||
|  |                 "pimple", | ||||||
|  |                 "service-provider", | ||||||
|  |                 "silex" | ||||||
|  |             ], | ||||||
|  |             "time": "2012-12-19 10:50:58" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "pimple/pimple", | ||||||
|  |             "version": "v1.1.1", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/fabpot/Pimple.git", | ||||||
|  |                 "reference": "2019c145fe393923f3441b23f29bbdfaa5c58c4d" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/fabpot/Pimple/zipball/2019c145fe393923f3441b23f29bbdfaa5c58c4d", | ||||||
|  |                 "reference": "2019c145fe393923f3441b23f29bbdfaa5c58c4d", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.0" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "1.1.x-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Pimple": "lib/" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Fabien Potencier", | ||||||
|  |                     "email": "fabien@symfony.com", | ||||||
|  |                     "homepage": "http://fabien.potencier.org", | ||||||
|  |                     "role": "Lead Developer" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Pimple is a simple Dependency Injection Container for PHP 5.3", | ||||||
|  |             "homepage": "http://pimple.sensiolabs.org", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "container", | ||||||
|  |                 "dependency injection" | ||||||
|  |             ], | ||||||
|  |             "time": "2013-11-22 08:30:29" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "symfony/console", | ||||||
|  |             "version": "v2.4.2", | ||||||
|  |             "target-dir": "Symfony/Component/Console", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/symfony/Console.git", | ||||||
|  |                 "reference": "940f217cbc3c8a33e5403e7c595495c4884400fe" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/symfony/Console/zipball/940f217cbc3c8a33e5403e7c595495c4884400fe", | ||||||
|  |                 "reference": "940f217cbc3c8a33e5403e7c595495c4884400fe", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "symfony/event-dispatcher": "~2.1" | ||||||
|  |             }, | ||||||
|  |             "suggest": { | ||||||
|  |                 "symfony/event-dispatcher": "" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "2.4-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Symfony\\Component\\Console\\": "" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Fabien Potencier", | ||||||
|  |                     "email": "fabien@symfony.com", | ||||||
|  |                     "homepage": "http://fabien.potencier.org", | ||||||
|  |                     "role": "Lead Developer" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Symfony Community", | ||||||
|  |                     "homepage": "http://symfony.com/contributors" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Symfony Console Component", | ||||||
|  |             "homepage": "http://symfony.com", | ||||||
|  |             "time": "2014-02-11 13:52:09" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "symfony/finder", | ||||||
|  |             "version": "v2.4.2", | ||||||
|  |             "target-dir": "Symfony/Component/Finder", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/symfony/Finder.git", | ||||||
|  |                 "reference": "b6735d1fc16da13c4c7dddfe78366a4a098cf011" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/symfony/Finder/zipball/b6735d1fc16da13c4c7dddfe78366a4a098cf011", | ||||||
|  |                 "reference": "b6735d1fc16da13c4c7dddfe78366a4a098cf011", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "2.4-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Symfony\\Component\\Finder\\": "" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Fabien Potencier", | ||||||
|  |                     "email": "fabien@symfony.com", | ||||||
|  |                     "homepage": "http://fabien.potencier.org", | ||||||
|  |                     "role": "Lead Developer" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Symfony Community", | ||||||
|  |                     "homepage": "http://symfony.com/contributors" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Symfony Finder Component", | ||||||
|  |             "homepage": "http://symfony.com", | ||||||
|  |             "time": "2014-01-07 13:28:54" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "symfony/process", | ||||||
|  |             "version": "v2.4.2", | ||||||
|  |             "target-dir": "Symfony/Component/Process", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/symfony/Process.git", | ||||||
|  |                 "reference": "c175448bac997556f8ab972908a4e14c7291fb03" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/symfony/Process/zipball/c175448bac997556f8ab972908a4e14c7291fb03", | ||||||
|  |                 "reference": "c175448bac997556f8ab972908a4e14c7291fb03", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "2.4-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Symfony\\Component\\Process\\": "" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Fabien Potencier", | ||||||
|  |                     "email": "fabien@symfony.com", | ||||||
|  |                     "homepage": "http://fabien.potencier.org", | ||||||
|  |                     "role": "Lead Developer" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Symfony Community", | ||||||
|  |                     "homepage": "http://symfony.com/contributors" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Symfony Process Component", | ||||||
|  |             "homepage": "http://symfony.com", | ||||||
|  |             "time": "2014-02-11 13:52:09" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "packages-dev": [ | ||||||
|  |         { | ||||||
|  |             "name": "phpunit/php-code-coverage", | ||||||
|  |             "version": "1.2.17", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/sebastianbergmann/php-code-coverage.git", | ||||||
|  |                 "reference": "6ef2bf3a1c47eca07ea95f0d8a902a6340390b34" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/6ef2bf3a1c47eca07ea95f0d8a902a6340390b34", | ||||||
|  |                 "reference": "6ef2bf3a1c47eca07ea95f0d8a902a6340390b34", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3", | ||||||
|  |                 "phpunit/php-file-iterator": ">=1.3.0@stable", | ||||||
|  |                 "phpunit/php-text-template": ">=1.2.0@stable", | ||||||
|  |                 "phpunit/php-token-stream": ">=1.1.3@stable" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "phpunit/phpunit": "3.7.*@dev" | ||||||
|  |             }, | ||||||
|  |             "suggest": { | ||||||
|  |                 "ext-dom": "*", | ||||||
|  |                 "ext-xdebug": ">=2.0.5" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "1.2.x-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "classmap": [ | ||||||
|  |                     "PHP/" | ||||||
|  |                 ] | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "include-path": [ | ||||||
|  |                 "" | ||||||
|  |             ], | ||||||
|  |             "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" | ||||||
|  |             ], | ||||||
|  |             "time": "2014-03-28 10:53:45" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "phpunit/php-file-iterator", | ||||||
|  |             "version": "1.3.4", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/sebastianbergmann/php-file-iterator.git", | ||||||
|  |                 "reference": "acd690379117b042d1c8af1fafd61bde001bf6bb" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/acd690379117b042d1c8af1fafd61bde001bf6bb", | ||||||
|  |                 "reference": "acd690379117b042d1c8af1fafd61bde001bf6bb", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "autoload": { | ||||||
|  |                 "classmap": [ | ||||||
|  |                     "File/" | ||||||
|  |                 ] | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "include-path": [ | ||||||
|  |                 "" | ||||||
|  |             ], | ||||||
|  |             "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" | ||||||
|  |             ], | ||||||
|  |             "time": "2013-10-10 15:34:57" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "phpunit/php-text-template", | ||||||
|  |             "version": "1.2.0", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/sebastianbergmann/php-text-template.git", | ||||||
|  |                 "reference": "206dfefc0ffe9cebf65c413e3d0e809c82fbf00a" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/sebastianbergmann/php-text-template/zipball/206dfefc0ffe9cebf65c413e3d0e809c82fbf00a", | ||||||
|  |                 "reference": "206dfefc0ffe9cebf65c413e3d0e809c82fbf00a", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "autoload": { | ||||||
|  |                 "classmap": [ | ||||||
|  |                     "Text/" | ||||||
|  |                 ] | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "include-path": [ | ||||||
|  |                 "" | ||||||
|  |             ], | ||||||
|  |             "license": [ | ||||||
|  |                 "BSD-3-Clause" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Sebastian Bergmann", | ||||||
|  |                     "email": "sb@sebastian-bergmann.de", | ||||||
|  |                     "role": "lead" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Simple template engine.", | ||||||
|  |             "homepage": "https://github.com/sebastianbergmann/php-text-template/", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "template" | ||||||
|  |             ], | ||||||
|  |             "time": "2014-01-30 17:20:04" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "phpunit/php-timer", | ||||||
|  |             "version": "1.0.5", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/sebastianbergmann/php-timer.git", | ||||||
|  |                 "reference": "19689d4354b295ee3d8c54b4f42c3efb69cbc17c" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/sebastianbergmann/php-timer/zipball/19689d4354b295ee3d8c54b4f42c3efb69cbc17c", | ||||||
|  |                 "reference": "19689d4354b295ee3d8c54b4f42c3efb69cbc17c", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "autoload": { | ||||||
|  |                 "classmap": [ | ||||||
|  |                     "PHP/" | ||||||
|  |                 ] | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "include-path": [ | ||||||
|  |                 "" | ||||||
|  |             ], | ||||||
|  |             "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" | ||||||
|  |             ], | ||||||
|  |             "time": "2013-08-02 07:42:54" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "phpunit/php-token-stream", | ||||||
|  |             "version": "1.2.2", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/sebastianbergmann/php-token-stream.git", | ||||||
|  |                 "reference": "ad4e1e23ae01b483c16f600ff1bebec184588e32" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/sebastianbergmann/php-token-stream/zipball/ad4e1e23ae01b483c16f600ff1bebec184588e32", | ||||||
|  |                 "reference": "ad4e1e23ae01b483c16f600ff1bebec184588e32", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "ext-tokenizer": "*", | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "1.2-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "classmap": [ | ||||||
|  |                     "PHP/" | ||||||
|  |                 ] | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "include-path": [ | ||||||
|  |                 "" | ||||||
|  |             ], | ||||||
|  |             "license": [ | ||||||
|  |                 "BSD-3-Clause" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Sebastian Bergmann", | ||||||
|  |                     "email": "sb@sebastian-bergmann.de", | ||||||
|  |                     "role": "lead" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Wrapper around PHP's tokenizer extension.", | ||||||
|  |             "homepage": "https://github.com/sebastianbergmann/php-token-stream/", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "tokenizer" | ||||||
|  |             ], | ||||||
|  |             "time": "2014-03-03 05:10:30" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "phpunit/phpunit", | ||||||
|  |             "version": "3.7.34", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/sebastianbergmann/phpunit.git", | ||||||
|  |                 "reference": "248d6ce95e6ca7f0e3135252c0b984bbe1f52f19" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/248d6ce95e6ca7f0e3135252c0b984bbe1f52f19", | ||||||
|  |                 "reference": "248d6ce95e6ca7f0e3135252c0b984bbe1f52f19", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "ext-dom": "*", | ||||||
|  |                 "ext-pcre": "*", | ||||||
|  |                 "ext-reflection": "*", | ||||||
|  |                 "ext-spl": "*", | ||||||
|  |                 "php": ">=5.3.3", | ||||||
|  |                 "phpunit/php-code-coverage": "~1.2", | ||||||
|  |                 "phpunit/php-file-iterator": "~1.3", | ||||||
|  |                 "phpunit/php-text-template": "~1.1", | ||||||
|  |                 "phpunit/php-timer": "~1.0", | ||||||
|  |                 "phpunit/phpunit-mock-objects": "~1.2", | ||||||
|  |                 "symfony/yaml": "~2.0" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "pear-pear.php.net/pear": "1.9.4" | ||||||
|  |             }, | ||||||
|  |             "suggest": { | ||||||
|  |                 "ext-json": "*", | ||||||
|  |                 "ext-simplexml": "*", | ||||||
|  |                 "ext-tokenizer": "*", | ||||||
|  |                 "phpunit/php-invoker": "~1.1" | ||||||
|  |             }, | ||||||
|  |             "bin": [ | ||||||
|  |                 "composer/bin/phpunit" | ||||||
|  |             ], | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "3.7.x-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "classmap": [ | ||||||
|  |                     "PHPUnit/" | ||||||
|  |                 ] | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "include-path": [ | ||||||
|  |                 "", | ||||||
|  |                 "../../symfony/yaml/" | ||||||
|  |             ], | ||||||
|  |             "license": [ | ||||||
|  |                 "BSD-3-Clause" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Sebastian Bergmann", | ||||||
|  |                     "email": "sebastian@phpunit.de", | ||||||
|  |                     "role": "lead" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "The PHP Unit Testing framework.", | ||||||
|  |             "homepage": "http://www.phpunit.de/", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "phpunit", | ||||||
|  |                 "testing", | ||||||
|  |                 "xunit" | ||||||
|  |             ], | ||||||
|  |             "time": "2014-03-28 11:04:36" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "phpunit/phpunit-mock-objects", | ||||||
|  |             "version": "1.2.3", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "git://github.com/sebastianbergmann/phpunit-mock-objects.git", | ||||||
|  |                 "reference": "1.2.3" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://github.com/sebastianbergmann/phpunit-mock-objects/archive/1.2.3.zip", | ||||||
|  |                 "reference": "1.2.3", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3", | ||||||
|  |                 "phpunit/php-text-template": ">=1.1.1@stable" | ||||||
|  |             }, | ||||||
|  |             "suggest": { | ||||||
|  |                 "ext-soap": "*" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "autoload": { | ||||||
|  |                 "classmap": [ | ||||||
|  |                     "PHPUnit/" | ||||||
|  |                 ] | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "include-path": [ | ||||||
|  |                 "" | ||||||
|  |             ], | ||||||
|  |             "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" | ||||||
|  |             ], | ||||||
|  |             "time": "2013-01-13 10:24:48" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "symfony/property-access", | ||||||
|  |             "version": "v2.4.2", | ||||||
|  |             "target-dir": "Symfony/Component/PropertyAccess", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/symfony/PropertyAccess.git", | ||||||
|  |                 "reference": "37fe0c2dc494b47db4b0850e9dcba3a27cc45c0c" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/symfony/PropertyAccess/zipball/37fe0c2dc494b47db4b0850e9dcba3a27cc45c0c", | ||||||
|  |                 "reference": "37fe0c2dc494b47db4b0850e9dcba3a27cc45c0c", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "2.4-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Symfony\\Component\\PropertyAccess\\": "" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Fabien Potencier", | ||||||
|  |                     "email": "fabien@symfony.com", | ||||||
|  |                     "homepage": "http://fabien.potencier.org", | ||||||
|  |                     "role": "Lead Developer" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Symfony Community", | ||||||
|  |                     "homepage": "http://symfony.com/contributors" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Symfony PropertyAccess Component", | ||||||
|  |             "homepage": "http://symfony.com", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "access", | ||||||
|  |                 "array", | ||||||
|  |                 "extraction", | ||||||
|  |                 "index", | ||||||
|  |                 "injection", | ||||||
|  |                 "object", | ||||||
|  |                 "property", | ||||||
|  |                 "property path", | ||||||
|  |                 "reflection" | ||||||
|  |             ], | ||||||
|  |             "time": "2014-02-11 15:39:28" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "symfony/translation", | ||||||
|  |             "version": "v2.4.2", | ||||||
|  |             "target-dir": "Symfony/Component/Translation", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/symfony/Translation.git", | ||||||
|  |                 "reference": "b00fd07417e493e08488e87bcebeb9681fc7323b" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/symfony/Translation/zipball/b00fd07417e493e08488e87bcebeb9681fc7323b", | ||||||
|  |                 "reference": "b00fd07417e493e08488e87bcebeb9681fc7323b", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "symfony/config": "~2.0", | ||||||
|  |                 "symfony/yaml": "~2.2" | ||||||
|  |             }, | ||||||
|  |             "suggest": { | ||||||
|  |                 "symfony/config": "", | ||||||
|  |                 "symfony/yaml": "" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "2.4-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Symfony\\Component\\Translation\\": "" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Fabien Potencier", | ||||||
|  |                     "email": "fabien@symfony.com", | ||||||
|  |                     "homepage": "http://fabien.potencier.org", | ||||||
|  |                     "role": "Lead Developer" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Symfony Community", | ||||||
|  |                     "homepage": "http://symfony.com/contributors" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Symfony Translation Component", | ||||||
|  |             "homepage": "http://symfony.com", | ||||||
|  |             "time": "2014-02-03 17:15:33" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "symfony/validator", | ||||||
|  |             "version": "v2.4.2", | ||||||
|  |             "target-dir": "Symfony/Component/Validator", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/symfony/Validator.git", | ||||||
|  |                 "reference": "64d7a54f97a5f53a98864a7461822e341f9416b5" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/symfony/Validator/zipball/64d7a54f97a5f53a98864a7461822e341f9416b5", | ||||||
|  |                 "reference": "64d7a54f97a5f53a98864a7461822e341f9416b5", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3", | ||||||
|  |                 "symfony/property-access": "~2.2", | ||||||
|  |                 "symfony/translation": "~2.0" | ||||||
|  |             }, | ||||||
|  |             "require-dev": { | ||||||
|  |                 "doctrine/annotations": "~1.0", | ||||||
|  |                 "doctrine/cache": "~1.0", | ||||||
|  |                 "symfony/config": "~2.2", | ||||||
|  |                 "symfony/http-foundation": "~2.1", | ||||||
|  |                 "symfony/intl": "~2.3", | ||||||
|  |                 "symfony/yaml": "~2.0" | ||||||
|  |             }, | ||||||
|  |             "suggest": { | ||||||
|  |                 "doctrine/annotations": "For using the annotation mapping. You will also need doctrine/cache.", | ||||||
|  |                 "doctrine/cache": "For using the default cached annotation reader", | ||||||
|  |                 "symfony/config": "", | ||||||
|  |                 "symfony/http-foundation": "", | ||||||
|  |                 "symfony/intl": "", | ||||||
|  |                 "symfony/yaml": "" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "2.4-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Symfony\\Component\\Validator\\": "" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Fabien Potencier", | ||||||
|  |                     "email": "fabien@symfony.com", | ||||||
|  |                     "homepage": "http://fabien.potencier.org", | ||||||
|  |                     "role": "Lead Developer" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Symfony Community", | ||||||
|  |                     "homepage": "http://symfony.com/contributors" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Symfony Validator Component", | ||||||
|  |             "homepage": "http://symfony.com", | ||||||
|  |             "time": "2014-02-11 13:52:09" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "symfony/yaml", | ||||||
|  |             "version": "v2.4.2", | ||||||
|  |             "target-dir": "Symfony/Component/Yaml", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/symfony/Yaml.git", | ||||||
|  |                 "reference": "bb6ddaf8956139d1b8c360b4b713ed0138e876b3" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://api.github.com/repos/symfony/Yaml/zipball/bb6ddaf8956139d1b8c360b4b713ed0138e876b3", | ||||||
|  |                 "reference": "bb6ddaf8956139d1b8c360b4b713ed0138e876b3", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "2.4-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Symfony\\Component\\Yaml\\": "" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Fabien Potencier", | ||||||
|  |                     "email": "fabien@symfony.com", | ||||||
|  |                     "homepage": "http://fabien.potencier.org", | ||||||
|  |                     "role": "Lead Developer" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Symfony Community", | ||||||
|  |                     "homepage": "http://symfony.com/contributors" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Symfony Yaml Component", | ||||||
|  |             "homepage": "http://symfony.com", | ||||||
|  |             "time": "2014-01-07 13:28:54" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "aliases": [ | ||||||
|  |  | ||||||
|  |     ], | ||||||
|  |     "minimum-stability": "stable", | ||||||
|  |     "stability-flags": [ | ||||||
|  |  | ||||||
|  |     ], | ||||||
|  |     "platform": { | ||||||
|  |         "php": ">=5.3.3" | ||||||
|  |     }, | ||||||
|  |     "platform-dev": [ | ||||||
|  |  | ||||||
|  |     ] | ||||||
|  | } | ||||||
							
								
								
									
										
											BIN
										
									
								
								vendor/cilex/cilex/docs/.static/logo.png
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								vendor/cilex/cilex/docs/.static/logo.png
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 4.0 KiB | 
							
								
								
									
										153
									
								
								vendor/cilex/cilex/docs/Makefile
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										153
									
								
								vendor/cilex/cilex/docs/Makefile
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,153 @@ | |||||||
|  | # Makefile for Sphinx documentation | ||||||
|  | # | ||||||
|  |  | ||||||
|  | # You can set these variables from the command line. | ||||||
|  | SPHINXOPTS    = | ||||||
|  | SPHINXBUILD   = sphinx-build | ||||||
|  | PAPER         = | ||||||
|  | BUILDDIR      = .build | ||||||
|  |  | ||||||
|  | # 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) source | ||||||
|  |  | ||||||
|  | .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 <target>' where <target> 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 "  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 "  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/Cilex.qhcp" | ||||||
|  | 	@echo "To view the help file:" | ||||||
|  | 	@echo "# assistant -collectionFile $(BUILDDIR)/qthelp/Cilex.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/Cilex" | ||||||
|  | 	@echo "# ln -s $(BUILDDIR)/devhelp $$HOME/.local/share/devhelp/Cilex" | ||||||
|  | 	@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." | ||||||
|  |  | ||||||
|  | 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." | ||||||
							
								
								
									
										45
									
								
								vendor/cilex/cilex/docs/conf.py
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								vendor/cilex/cilex/docs/conf.py
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | |||||||
|  | import sys, os | ||||||
|  |  | ||||||
|  | templates_path = ['.templates'] | ||||||
|  | source_suffix = '.rst' | ||||||
|  | master_doc = 'index' | ||||||
|  | project = u'Cilex' | ||||||
|  | copyright = u'2013, Mike van Riel' | ||||||
|  |  | ||||||
|  | version = '1.0' | ||||||
|  | release = '1.0.0-alpha1' | ||||||
|  | pygments_style = 'sphinx' | ||||||
|  |  | ||||||
|  | html_theme = 'agogo' | ||||||
|  | html_static_path = ['.static'] | ||||||
|  | htmlhelp_basename = 'Cilexdoc' | ||||||
|  |  | ||||||
|  | # -- Options for LaTeX output -------------------------------------------------- | ||||||
|  |  | ||||||
|  | latex_elements = { | ||||||
|  |     'papersize': 'a4paper', | ||||||
|  |     'pointsize': '10pt', | ||||||
|  | } | ||||||
|  |  | ||||||
|  | # (source start file, target name, title, author, documentclass [howto/manual]). | ||||||
|  | latex_documents = [ | ||||||
|  |   ('index', 'Cilex.tex', u'Cilex Documentation', u'Mike van Riel', 'manual'), | ||||||
|  | ] | ||||||
|  |  | ||||||
|  | latex_logo = '.static/logo.png' | ||||||
|  |  | ||||||
|  | # -- Options for manual page output -------------------------------------------- | ||||||
|  |  | ||||||
|  | # (source start file, name, description, authors, manual section). | ||||||
|  | man_pages = [ | ||||||
|  |     ('index', 'cilex', u'Cilex Documentation', [u'Mike van Riel'], 1) | ||||||
|  | ] | ||||||
|  |  | ||||||
|  | # -- Options for Texinfo output ------------------------------------------------ | ||||||
|  |  | ||||||
|  | # (source start file, target name, title, author, dir menu entry, description, | ||||||
|  | # category) | ||||||
|  | texinfo_documents = [ | ||||||
|  |   ('index', 'Cilex', u'Cilex Documentation', u'Mike van Riel', 'Cilex', 'One line description of project.', | ||||||
|  |    'Miscellaneous'), | ||||||
|  | ] | ||||||
							
								
								
									
										9
									
								
								vendor/cilex/cilex/docs/index.rst
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								vendor/cilex/cilex/docs/index.rst
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | Cilex' documentation | ||||||
|  | ==================== | ||||||
|  |  | ||||||
|  | Contents: | ||||||
|  |  | ||||||
|  | .. toctree:: | ||||||
|  |    :maxdepth: 2 | ||||||
|  |  | ||||||
|  |    usage | ||||||
							
								
								
									
										82
									
								
								vendor/cilex/cilex/docs/usage.rst
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								vendor/cilex/cilex/docs/usage.rst
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,82 @@ | |||||||
|  | Usage | ||||||
|  | ===== | ||||||
|  |  | ||||||
|  | Installation | ||||||
|  | ------------ | ||||||
|  |  | ||||||
|  | The easiest way to get started is to use Composer_ using the following steps: | ||||||
|  |  | ||||||
|  | 1. Create a file name ``composer.json`` with the following contents: | ||||||
|  |  | ||||||
|  |    .. code-block:: json | ||||||
|  |  | ||||||
|  |       { | ||||||
|  |           "require": { | ||||||
|  |               "cilex/cilex": "1.0.*@dev" | ||||||
|  |           } | ||||||
|  |       } | ||||||
|  |  | ||||||
|  | 2. Download Composer_ and install the project | ||||||
|  |  | ||||||
|  |    .. code-block:: bash | ||||||
|  |  | ||||||
|  |       $ curl -s http://getcomposer.org/installer | php | ||||||
|  |       $ php composer.phar install | ||||||
|  |  | ||||||
|  | Upgrading | ||||||
|  | --------- | ||||||
|  |  | ||||||
|  | Cilex can be upgraded using Composer_ by calling the update command: | ||||||
|  |  | ||||||
|  |    .. code-block:: bash | ||||||
|  |  | ||||||
|  |       $ php composer.phar update | ||||||
|  |  | ||||||
|  | Bootstrap | ||||||
|  | --------- | ||||||
|  |  | ||||||
|  | The simplest example of a Cilex application is by including the autoloader, instantiating the Cilex application class | ||||||
|  | and calling the ``run`` method. The following example demonstrates this principle: | ||||||
|  |  | ||||||
|  | .. code-block:: php | ||||||
|  |  | ||||||
|  |    <?php | ||||||
|  |    // application.php | ||||||
|  |  | ||||||
|  |    require_once __DIR__ . '/vendor/autoload.php'; | ||||||
|  |  | ||||||
|  |    $app = new \Cilex\Application('NameOfMyApplication'); | ||||||
|  |  | ||||||
|  |    // list of commands | ||||||
|  |  | ||||||
|  |    $app->run(); | ||||||
|  |  | ||||||
|  | Calling your new application is as simple as the following line: | ||||||
|  |  | ||||||
|  | .. code-block:: bash | ||||||
|  |  | ||||||
|  |    $ php application.php | ||||||
|  |  | ||||||
|  | Even without actual commands you are greeted with an informative description what to do next: | ||||||
|  |  | ||||||
|  | .. code-block:: bash | ||||||
|  |  | ||||||
|  |     NameOfMyApplication version | ||||||
|  |  | ||||||
|  |     Usage: | ||||||
|  |       [options] command [arguments] | ||||||
|  |  | ||||||
|  |     Options: | ||||||
|  |       --help           -h Display this help message. | ||||||
|  |       --quiet          -q Do not output any message. | ||||||
|  |       --verbose        -v Increase verbosity of messages. | ||||||
|  |       --version        -V Display this application version. | ||||||
|  |       --ansi              Force ANSI output. | ||||||
|  |       --no-ansi           Disable ANSI output. | ||||||
|  |       --no-interaction -n Do not ask any interactive question. | ||||||
|  |  | ||||||
|  |     Available commands: | ||||||
|  |       help   Displays help for a command | ||||||
|  |       list   Lists commands | ||||||
|  |  | ||||||
|  | .. _Composer: http://getcomposer.org | ||||||
							
								
								
									
										6
									
								
								vendor/cilex/cilex/example.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								vendor/cilex/cilex/example.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | <?php | ||||||
|  | require_once __DIR__ . '/vendor/autoload.php'; | ||||||
|  |  | ||||||
|  | $app = new \Cilex\Application('Cilex'); | ||||||
|  | //$app->command(new \Cilex\Command\GreetCommand()); | ||||||
|  | $app->run(); | ||||||
							
								
								
									
										19
									
								
								vendor/cilex/cilex/phpunit.xml.dist
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								vendor/cilex/cilex/phpunit.xml.dist
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  |  | ||||||
|  | <phpunit backupGlobals="false" | ||||||
|  |     backupStaticAttributes="false" | ||||||
|  |     colors="true" | ||||||
|  |     convertErrorsToExceptions="true" | ||||||
|  |     convertNoticesToExceptions="true" | ||||||
|  |     convertWarningsToExceptions="true" | ||||||
|  |     processIsolation="false" | ||||||
|  |     stopOnFailure="false" | ||||||
|  |     syntaxCheck="false" | ||||||
|  |     bootstrap="vendor/autoload.php" | ||||||
|  |     > | ||||||
|  |     <testsuites> | ||||||
|  |         <testsuite name="Cilex Test Suite"> | ||||||
|  |             <directory>./tests/Cilex/</directory> | ||||||
|  |         </testsuite> | ||||||
|  |     </testsuites> | ||||||
|  | </phpunit> | ||||||
							
								
								
									
										111
									
								
								vendor/cilex/cilex/src/Cilex/Application.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										111
									
								
								vendor/cilex/cilex/src/Cilex/Application.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,111 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex; | ||||||
|  |  | ||||||
|  | use \Symfony\Component\Console; | ||||||
|  | use \Cilex\Provider\Console\ConsoleServiceProvider; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * The Cilex framework class. | ||||||
|  |  * | ||||||
|  |  * @author Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * @api | ||||||
|  |  */ | ||||||
|  | class Application extends \Pimple | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Version number for Cilex | ||||||
|  |      */ | ||||||
|  |     const VERSION = '1.0.0'; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Registers the autoloader and necessary components. | ||||||
|  |      * | ||||||
|  |      * @param string      $name    Name for this application. | ||||||
|  |      * @param string|null $version Version number for this application. | ||||||
|  |      */ | ||||||
|  |     public function __construct($name, $version = null, array $values = array()) | ||||||
|  |     { | ||||||
|  |         parent::__construct(); | ||||||
|  |  | ||||||
|  |         $consoleConfig = array('console.name' => $name); | ||||||
|  |         if (null !== $version) { | ||||||
|  |             $consoleConfig['console.version'] = $version; | ||||||
|  |         } | ||||||
|  |         $this->register(new ConsoleServiceProvider(), $consoleConfig); | ||||||
|  |  | ||||||
|  |         foreach ($values as $key => $value) { | ||||||
|  |             $this[$key] = $value; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Executes this application. | ||||||
|  |      * | ||||||
|  |      * @param bool $interactive runs in an interactive shell if true. | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function run($interactive = false) | ||||||
|  |     { | ||||||
|  |         $app = $this['console']; | ||||||
|  |         if ($interactive) { | ||||||
|  |             $app = new Console\Shell($app); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $app->run(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Adds a command object. | ||||||
|  |      * | ||||||
|  |      * If a command with the same name already exists, it will be overridden. | ||||||
|  |      * | ||||||
|  |      * @param \Cilex\Command\Command $command A Command object | ||||||
|  |      * | ||||||
|  |      * @api | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function command(Console\Command\Command $command) | ||||||
|  |     { | ||||||
|  |         $this['console']->add($command); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Registers a service provider. | ||||||
|  |      * | ||||||
|  |      * @param \Cilex\ServiceProviderInterface|\Silex\ServiceProviderInterface $provider | ||||||
|  |      *     A ServiceProviderInterface instance | ||||||
|  |      * @param mixed[]                                                         $values | ||||||
|  |      *     An array of values that customizes the provider | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function register($provider, array $values = array()) | ||||||
|  |     { | ||||||
|  |         if ((!$provider instanceof \Cilex\ServiceProviderInterface) | ||||||
|  |             && (!$provider instanceof \Silex\ServiceProviderInterface) | ||||||
|  |         ) { | ||||||
|  |             throw new \InvalidArgumentException( | ||||||
|  |                 'Extensions should implement either Cilex or Silex\' ServiceProviderInterface' | ||||||
|  |             ); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $provider->register($this); | ||||||
|  |  | ||||||
|  |         foreach ($values as $key => $value) { | ||||||
|  |             $this[$key] = $value; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										55
									
								
								vendor/cilex/cilex/src/Cilex/Command/Command.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								vendor/cilex/cilex/src/Cilex/Command/Command.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Command; | ||||||
|  |  | ||||||
|  | use \Symfony\Component\Console; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Base class for Cilex commands. | ||||||
|  |  * | ||||||
|  |  * @author Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * @api | ||||||
|  |  */ | ||||||
|  | abstract class Command extends Console\Command\Command | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Returns the application container. | ||||||
|  |      * | ||||||
|  |      * @return \Cilex\Application | ||||||
|  |      */ | ||||||
|  |     public function getContainer() | ||||||
|  |     { | ||||||
|  |         return $this->getApplication()->getContainer(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Returns a service contained in the application container or null if none | ||||||
|  |      * is found with that name. | ||||||
|  |      * | ||||||
|  |      * This is a convenience method used to retrieve an element from the | ||||||
|  |      * Application container without having to assign the results of the | ||||||
|  |      * getContainer() method in every call. | ||||||
|  |      * | ||||||
|  |      * @param string $name Name of the service | ||||||
|  |      * | ||||||
|  |      * @see self::getContainer() | ||||||
|  |      * | ||||||
|  |      * @api | ||||||
|  |      * | ||||||
|  |      * @return \stdClass|null | ||||||
|  |      */ | ||||||
|  |     public function getService($name) | ||||||
|  |     { | ||||||
|  |         return $this->getApplication()->getService($name); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										41
									
								
								vendor/cilex/cilex/src/Cilex/Command/DemoInfoCommand.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								vendor/cilex/cilex/src/Cilex/Command/DemoInfoCommand.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Command; | ||||||
|  |  | ||||||
|  | use Symfony\Component\Console\Input\InputInterface; | ||||||
|  | use Symfony\Component\Console\Output\OutputInterface; | ||||||
|  | use Symfony\Component\Console\Command\Command as BaseCommand; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Example command for testing purposes. | ||||||
|  |  */ | ||||||
|  | class DemoInfoCommand extends BaseCommand | ||||||
|  | { | ||||||
|  |     protected function configure() | ||||||
|  |     { | ||||||
|  |         $this | ||||||
|  |             ->setName('demo:info') | ||||||
|  |             ->setDescription('Get Application Information'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected function execute(InputInterface $input, OutputInterface $output) | ||||||
|  |     { | ||||||
|  |         // This is a contrived example to show accessing services | ||||||
|  |         // from the container without needing the command itself | ||||||
|  |         // to extend from anything but Symfony Console's base Command. | ||||||
|  |  | ||||||
|  |         $app = $this->getApplication()->getService('console'); | ||||||
|  |  | ||||||
|  |         $output->writeln('Name: ' . $app->getName()); | ||||||
|  |         $output->writeln('Version: ' . $app->getVersion()); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										47
									
								
								vendor/cilex/cilex/src/Cilex/Command/GreetCommand.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								vendor/cilex/cilex/src/Cilex/Command/GreetCommand.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Command; | ||||||
|  |  | ||||||
|  | use Symfony\Component\Console\Input\InputArgument; | ||||||
|  | use Symfony\Component\Console\Input\InputInterface; | ||||||
|  | use Symfony\Component\Console\Input\InputOption; | ||||||
|  | use Symfony\Component\Console\Output\OutputInterface; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Example command for testing purposes. | ||||||
|  |  */ | ||||||
|  | class GreetCommand extends Command | ||||||
|  | { | ||||||
|  |     protected function configure() | ||||||
|  |     { | ||||||
|  |         $this | ||||||
|  |             ->setName('demo:greet') | ||||||
|  |             ->setDescription('Greet someone') | ||||||
|  |             ->addArgument('name', InputArgument::OPTIONAL, 'Who do you want to greet?') | ||||||
|  |             ->addOption('yell', null, InputOption::VALUE_NONE, 'If set, the task will yell in uppercase letters'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected function execute(InputInterface $input, OutputInterface $output) | ||||||
|  |     { | ||||||
|  |         $text = 'Hello'; | ||||||
|  |         $name = $input->getArgument('name'); | ||||||
|  |         if ($name) { | ||||||
|  |             $text .= ' '.$name; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if ($input->getOption('yell')) { | ||||||
|  |             $text = strtoupper($text); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $output->writeln($text); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										184
									
								
								vendor/cilex/cilex/src/Cilex/Compiler.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										184
									
								
								vendor/cilex/cilex/src/Cilex/Compiler.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,184 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex; | ||||||
|  |  | ||||||
|  | use Symfony\Component\Finder\Finder; | ||||||
|  | use Symfony\Component\Process\Process; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * The Compiler class compiles the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * This is an adapted version of the Silex\Compiler class. | ||||||
|  |  * | ||||||
|  |  * @author Fabien Potencier <fabien@symfony.com> | ||||||
|  |  * @author Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  */ | ||||||
|  | class Compiler | ||||||
|  | { | ||||||
|  |     protected $version; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Compiles the Cilex source code into one single Phar file. | ||||||
|  |      * | ||||||
|  |      * @param string $pharFile Name of the output Phar file | ||||||
|  |      */ | ||||||
|  |     public function compile($pharFile = 'cilex.phar') | ||||||
|  |     { | ||||||
|  |         if (file_exists($pharFile)) { | ||||||
|  |             unlink($pharFile); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $process = new Process('git log --pretty="%h %ci" -n1 HEAD'); | ||||||
|  |         if ($process->run() > 0) { | ||||||
|  |             throw new \RuntimeException('The git binary cannot be found.'); | ||||||
|  |         } | ||||||
|  |         $this->version = trim($process->getOutput()); | ||||||
|  |  | ||||||
|  |         $phar = new \Phar($pharFile, 0, 'cilex.phar'); | ||||||
|  |         $phar->setSignatureAlgorithm(\Phar::SHA1); | ||||||
|  |  | ||||||
|  |         $phar->startBuffering(); | ||||||
|  |  | ||||||
|  |         $finder = new Finder(); | ||||||
|  |         $finder->files() | ||||||
|  |             ->ignoreVCS(true) | ||||||
|  |             ->name('*.php') | ||||||
|  |             ->notName('Compiler.php') | ||||||
|  |             ->in(__DIR__.'/..') | ||||||
|  |             ->in(__DIR__.'/../../vendor/pimple/pimple/lib') | ||||||
|  |             ->in(__DIR__.'/../../vendor/cilex/console-service-provider') | ||||||
|  |             ->in(__DIR__.'/../../vendor/symfony/console/Symfony/Component/Console'); | ||||||
|  |  | ||||||
|  |         foreach ($finder as $file) { | ||||||
|  |             $this->addFile($phar, $file); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $this->addFile($phar, new \SplFileInfo(__DIR__.'/../../LICENSE'), false); | ||||||
|  |  | ||||||
|  |         $this->addFile($phar, new \SplFileInfo(__DIR__.'/../../vendor/autoload.php')); | ||||||
|  |         $this->addFile($phar, new \SplFileInfo(__DIR__.'/../../vendor/composer/ClassLoader.php')); | ||||||
|  |         $this->addFile($phar, new \SplFileInfo(__DIR__.'/../../vendor/composer/autoload_real.php')); | ||||||
|  |         $this->addFile($phar, new \SplFileInfo(__DIR__.'/../../vendor/composer/autoload_namespaces.php')); | ||||||
|  |         $this->addFile($phar, new \SplFileInfo(__DIR__.'/../../vendor/composer/autoload_classmap.php')); | ||||||
|  |  | ||||||
|  |         // Stubs | ||||||
|  |         $phar->setStub($this->getStub()); | ||||||
|  |  | ||||||
|  |         $phar->stopBuffering(); | ||||||
|  |  | ||||||
|  |         // $phar->compressFiles(\Phar::GZ); | ||||||
|  |  | ||||||
|  |         unset($phar); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected function addFile(\Phar $phar, \splFileInfo $file, $strip = true) | ||||||
|  |     { | ||||||
|  |         $path = str_replace(dirname(dirname(__DIR__)).DIRECTORY_SEPARATOR, '', $file->getRealPath()); | ||||||
|  |  | ||||||
|  |         $content = file_get_contents($file); | ||||||
|  |         if ($strip) { | ||||||
|  |             $content = self::stripWhitespace($content); | ||||||
|  |         } | ||||||
|  |         $content = str_replace('@package_version@', $this->version, $content); | ||||||
|  |  | ||||||
|  |         $phar->addFromString($path, $content); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected function getStub() | ||||||
|  |     { | ||||||
|  |         return <<<'EOF' | ||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | Phar::mapPhar('cilex.phar'); | ||||||
|  |  | ||||||
|  | require_once 'phar://cilex.phar/vendor/autoload.php'; | ||||||
|  |  | ||||||
|  | if ('cli' === php_sapi_name() && basename(__FILE__) === basename($_SERVER['argv'][0]) && isset($_SERVER['argv'][1])) { | ||||||
|  |     switch ($_SERVER['argv'][1]) { | ||||||
|  |         case 'update': | ||||||
|  |             $remoteFilename = 'http://cilex.github.com/get/cilex.phar'; | ||||||
|  |             $localFilename = __DIR__.'/cilex.phar'; | ||||||
|  |  | ||||||
|  |             file_put_contents($localFilename, file_get_contents($remoteFilename)); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case 'check': | ||||||
|  |             $latest = trim(file_get_contents('http://cilex.github.com/get/version')); | ||||||
|  |  | ||||||
|  |             if ($latest != Cilex\Application::VERSION) { | ||||||
|  |                 printf("A newer Cilex version is available (%s).\n", $latest); | ||||||
|  |             } else { | ||||||
|  |                 print("You are using the latest Cilex version.\n"); | ||||||
|  |             } | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         case 'version': | ||||||
|  |             printf("Cilex version %s\n", Cilex\Application::VERSION); | ||||||
|  |             break; | ||||||
|  |  | ||||||
|  |         default: | ||||||
|  |             printf("Unknown command '%s' (available commands: version, check, and update).\n", $_SERVER['argv'][1]); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     exit(0); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | __HALT_COMPILER(); | ||||||
|  | EOF; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Removes whitespace from a PHP source string while preserving line numbers. | ||||||
|  |      * | ||||||
|  |      * Based on Kernel::stripComments(), but keeps line numbers intact. | ||||||
|  |      * | ||||||
|  |      * @param string $source A PHP string | ||||||
|  |      * | ||||||
|  |      * @return string The PHP string with the whitespace removed | ||||||
|  |      */ | ||||||
|  |     public static function stripWhitespace($source) | ||||||
|  |     { | ||||||
|  |         if (!function_exists('token_get_all')) { | ||||||
|  |             return $source; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $output = ''; | ||||||
|  |         foreach (token_get_all($source) as $token) { | ||||||
|  |             if (is_string($token)) { | ||||||
|  |                 $output .= $token; | ||||||
|  |             } elseif (in_array($token[0], array(T_COMMENT, T_DOC_COMMENT))) { | ||||||
|  |                 $output .= str_repeat("\n", substr_count($token[1], "\n")); | ||||||
|  |             } elseif (T_WHITESPACE === $token[0]) { | ||||||
|  |                 // reduce wide spaces | ||||||
|  |                 $whitespace = preg_replace('{[ \t]+}', ' ', $token[1]); | ||||||
|  |                 // normalize newlines to \n | ||||||
|  |                 $whitespace = preg_replace('{(?:\r\n|\r|\n)}', "\n", $whitespace); | ||||||
|  |                 // trim leading spaces | ||||||
|  |                 $whitespace = preg_replace('{\n +}', "\n", $whitespace); | ||||||
|  |                 $output .= $whitespace; | ||||||
|  |             } else { | ||||||
|  |                 $output .= $token[1]; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return $output; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										68
									
								
								vendor/cilex/cilex/src/Cilex/Provider/ConfigServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								vendor/cilex/cilex/src/Cilex/Provider/ConfigServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Provider; | ||||||
|  |  | ||||||
|  | use Cilex\Application; | ||||||
|  | use Cilex\ServiceProviderInterface; | ||||||
|  | use Symfony\Component\Yaml; | ||||||
|  |  | ||||||
|  | class ConfigServiceProvider implements ServiceProviderInterface | ||||||
|  | { | ||||||
|  |     public function register(Application $app) | ||||||
|  |     { | ||||||
|  |         $app['config'] = $app->share( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 if (!file_exists($app['config.path'])) { | ||||||
|  |                     throw new \InvalidArgumentException( | ||||||
|  |                         $app['config.path'] . ' is not a valid path to the ' | ||||||
|  |                         .'configuration' | ||||||
|  |                     ); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 $fullpath = explode('.', $app['config.path']); | ||||||
|  |  | ||||||
|  |                 switch (strtolower(end($fullpath))) { | ||||||
|  |                     case 'php': | ||||||
|  |                         $result = include($app['config.path']); | ||||||
|  |                         break; | ||||||
|  |                     case 'yml': | ||||||
|  |                         $parser = new Yaml\Parser(); | ||||||
|  |                         $result = new \ArrayObject( | ||||||
|  |                             $parser->parse(file_get_contents($app['config.path'])) | ||||||
|  |                         ); | ||||||
|  |                         break; | ||||||
|  |                     case 'xml': | ||||||
|  |                         $result = simplexml_load_file($app['config.path']); | ||||||
|  |                         break; | ||||||
|  |                     case 'json': | ||||||
|  |                         $result = json_decode(file_get_contents($app['config.path'])); | ||||||
|  |  | ||||||
|  |                         if (null == $result) { | ||||||
|  |  | ||||||
|  |                             throw new \InvalidArgumentException( | ||||||
|  |                                 'Unable to decode the configuration file: ' . $app['config.path'] | ||||||
|  |                             ); | ||||||
|  |                         } | ||||||
|  |                         break; | ||||||
|  |                     default: | ||||||
|  |                         throw new \InvalidArgumentException( | ||||||
|  |                             'Unable to load configuration; the provided file extension was not recognized. ' | ||||||
|  |                             .'Only yml, xml or json allowed' | ||||||
|  |                         ); | ||||||
|  |                         break; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 return $result; | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										148
									
								
								vendor/cilex/cilex/src/Cilex/Provider/DoctrineServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										148
									
								
								vendor/cilex/cilex/src/Cilex/Provider/DoctrineServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,148 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Provider; | ||||||
|  |  | ||||||
|  | use Cilex\Application; | ||||||
|  | use Cilex\ServiceProviderInterface; | ||||||
|  | use Doctrine\DBAL\DriverManager; | ||||||
|  | use Doctrine\DBAL\Configuration; | ||||||
|  | use Doctrine\Common\EventManager; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Doctrine DBAL Provider. | ||||||
|  |  * | ||||||
|  |  * This Service Provider is an adaptation of the DoctrineServiceProvider for | ||||||
|  |  * Silex written by Fabien Potencier. | ||||||
|  |  * | ||||||
|  |  * @author Fabien Potencier <fabien@symfony.com> | ||||||
|  |  * @author Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  */ | ||||||
|  | class DoctrineServiceProvider implements ServiceProviderInterface | ||||||
|  | { | ||||||
|  |     public function register(Application $app) | ||||||
|  |     { | ||||||
|  |         $app['db.default_options'] = array( | ||||||
|  |             'driver'   => 'pdo_mysql', | ||||||
|  |             'dbname'   => null, | ||||||
|  |             'host'     => 'localhost', | ||||||
|  |             'user'     => 'root', | ||||||
|  |             'password' => null, | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['dbs.options.initializer'] = $app->protect( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 static $initialized = false; | ||||||
|  |  | ||||||
|  |                 if ($initialized) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 $initialized = true; | ||||||
|  |  | ||||||
|  |                 if (!isset($app['dbs.options'])) { | ||||||
|  |                     $app['dbs.options'] = array('default' => isset($app['db.options']) ? $app['db.options'] : array()); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 $tmp = $app['dbs.options']; | ||||||
|  |                 foreach ($tmp as $name => &$options) { | ||||||
|  |                     $options = array_replace($app['db.default_options'], $options); | ||||||
|  |  | ||||||
|  |                     if (!isset($app['dbs.default'])) { | ||||||
|  |                         $app['dbs.default'] = $name; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 $app['dbs.options'] = $tmp; | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['dbs'] = $app->share( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 $app['dbs.options.initializer'](); | ||||||
|  |  | ||||||
|  |                 $dbs = new \Pimple(); | ||||||
|  |                 foreach ($app['dbs.options'] as $name => $options) { | ||||||
|  |                     if ($app['dbs.default'] === $name) { | ||||||
|  |                         // we use shortcuts here in case the default has been overriden | ||||||
|  |                         $config = $app['db.config']; | ||||||
|  |                         $manager = $app['db.event_manager']; | ||||||
|  |                     } else { | ||||||
|  |                         $config = $app['dbs.config'][$name]; | ||||||
|  |                         $manager = $app['dbs.event_manager'][$name]; | ||||||
|  |                     } | ||||||
|  |  | ||||||
|  |                     $dbs[$name] = DriverManager::getConnection($options, $config, $manager); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 return $dbs; | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['dbs.config'] = $app->share( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 $app['dbs.options.initializer'](); | ||||||
|  |  | ||||||
|  |                 $configs = new \Pimple(); | ||||||
|  |                 foreach ($app['dbs.options'] as $name => $options) { | ||||||
|  |                     $configs[$name] = new Configuration(); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 return $configs; | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['dbs.event_manager'] = $app->share( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 $app['dbs.options.initializer'](); | ||||||
|  |  | ||||||
|  |                 $managers = new \Pimple(); | ||||||
|  |                 foreach ($app['dbs.options'] as $name => $options) { | ||||||
|  |                     $managers[$name] = new EventManager(); | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 return $managers; | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         // shortcuts for the "first" DB | ||||||
|  |         $app['db'] = $app->share( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 $dbs = $app['dbs']; | ||||||
|  |  | ||||||
|  |                 return $dbs[$app['dbs.default']]; | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['db.config'] = $app->share( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 $dbs = $app['dbs.config']; | ||||||
|  |  | ||||||
|  |                 return $dbs[$app['dbs.default']]; | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['db.event_manager'] = $app->share( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 $dbs = $app['dbs.event_manager']; | ||||||
|  |  | ||||||
|  |                 return $dbs[$app['dbs.default']]; | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         if (isset($app['db.dbal.class_path'])) { | ||||||
|  |             $app['autoloader']->registerNamespace('Doctrine\\DBAL', $app['db.dbal.class_path']); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (isset($app['db.common.class_path'])) { | ||||||
|  |             $app['autoloader']->registerNamespace('Doctrine\\Common', $app['db.common.class_path']); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										62
									
								
								vendor/cilex/cilex/src/Cilex/Provider/MonologServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								vendor/cilex/cilex/src/Cilex/Provider/MonologServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Provider; | ||||||
|  |  | ||||||
|  | use Monolog\Logger; | ||||||
|  | use Monolog\Handler\StreamHandler; | ||||||
|  |  | ||||||
|  | use Cilex\Application; | ||||||
|  | use Cilex\ServiceProviderInterface; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Monolog Provider. | ||||||
|  |  * | ||||||
|  |  * This class is an adaptation of the Silex MonologServiceProvider written by | ||||||
|  |  * Fabien Potencier. | ||||||
|  |  * | ||||||
|  |  * @author Fabien Potencier <fabien@symfony.com> | ||||||
|  |  * @author Mike van Riel <mike.vanvriel@naenius.com> | ||||||
|  |  */ | ||||||
|  | class MonologServiceProvider implements ServiceProviderInterface | ||||||
|  | { | ||||||
|  |     public function register(Application $app) | ||||||
|  |     { | ||||||
|  |         $app['monolog'] = $app->share( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 $log = new Logger(isset($app['monolog.name']) ? $app['monolog.name'] : 'myapp'); | ||||||
|  |                 $app['monolog.configure']($log); | ||||||
|  |  | ||||||
|  |                 return $log; | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['monolog.configure'] = $app->protect( | ||||||
|  |             function ($log) use ($app) { | ||||||
|  |                 $log->pushHandler($app['monolog.handler']); | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['monolog.handler'] = function () use ($app) { | ||||||
|  |             return new StreamHandler($app['monolog.logfile'], $app['monolog.level']); | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         if (!isset($app['monolog.level'])) { | ||||||
|  |             $app['monolog.level'] = function () { | ||||||
|  |                 return Logger::DEBUG; | ||||||
|  |             }; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (isset($app['monolog.class_path'])) { | ||||||
|  |             $app['autoloader']->registerNamespace('Monolog', $app['monolog.class_path']); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										72
									
								
								vendor/cilex/cilex/src/Cilex/Provider/ValidatorServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								vendor/cilex/cilex/src/Cilex/Provider/ValidatorServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,72 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Fabien Potencier <fabien@symfony.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Provider; | ||||||
|  |  | ||||||
|  | use Cilex\Application; | ||||||
|  | use Cilex\ServiceProviderInterface; | ||||||
|  |  | ||||||
|  | use Symfony\Component\Validator\Validator; | ||||||
|  | use Symfony\Component\Validator\Mapping\ClassMetadataFactory; | ||||||
|  | use Symfony\Component\Validator\Mapping\Loader\StaticMethodLoader; | ||||||
|  | use Symfony\Component\Validator\ConstraintValidatorFactory; | ||||||
|  | use Symfony\Component\Validator\DefaultTranslator; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Symfony Validator component Provider. | ||||||
|  |  * | ||||||
|  |  * This class is an adaptation of the Silex MonologServiceProvider written by | ||||||
|  |  * Fabien Potencier. | ||||||
|  |  * | ||||||
|  |  * @author Fabien Potencier <fabien@symfony.com> | ||||||
|  |  * @author Mike van Riel <mike.vanvriel@naenius.com> | ||||||
|  |  */ | ||||||
|  | class ValidatorServiceProvider implements ServiceProviderInterface | ||||||
|  | { | ||||||
|  |     public function register(Application $app) | ||||||
|  |     { | ||||||
|  |         $app['validator'] = $app->share( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 return new Validator( | ||||||
|  |                     $app['validator.mapping.class_metadata_factory'], | ||||||
|  |                     $app['validator.validator_factory'], | ||||||
|  |                     $app['validator.default_translator'] | ||||||
|  |                 ); | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['validator.mapping.class_metadata_factory'] = $app->share( | ||||||
|  |             function () use ($app) { | ||||||
|  |                 return new ClassMetadataFactory(new StaticMethodLoader()); | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['validator.validator_factory'] = $app->share( | ||||||
|  |             function () { | ||||||
|  |                 return new ConstraintValidatorFactory(); | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app['validator.default_translator'] = $app->share( | ||||||
|  |             function () { | ||||||
|  |                 if (!class_exists('Symfony\\Component\\Validator\\DefaultTranslator')){ | ||||||
|  |                     return array(); | ||||||
|  |                 } | ||||||
|  |                  | ||||||
|  |                 return new DefaultTranslator(); | ||||||
|  |             } | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         if (isset($app['validator.class_path'])) { | ||||||
|  |             $app['autoloader']->registerNamespace('Symfony\\Component\\Validator', $app['validator.class_path']); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										27
									
								
								vendor/cilex/cilex/src/Cilex/ServiceProviderInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								vendor/cilex/cilex/src/Cilex/ServiceProviderInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Interface that must implement all Cilex service providers. | ||||||
|  |  * | ||||||
|  |  * @author Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  */ | ||||||
|  | interface ServiceProviderInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Registers services on the given app. | ||||||
|  |      * | ||||||
|  |      * @param Application $app An Application instance | ||||||
|  |      */ | ||||||
|  |     public function register(Application $app); | ||||||
|  | } | ||||||
							
								
								
									
										99
									
								
								vendor/cilex/cilex/tests/Cilex/Tests/ApplicationTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								vendor/cilex/cilex/tests/Cilex/Tests/ApplicationTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,99 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Tests; | ||||||
|  |  | ||||||
|  | use \Cilex\Application; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Mock class used to test the register method. | ||||||
|  |  */ | ||||||
|  | class ServiceProviderMock implements \Cilex\ServiceProviderInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Mock method to satisfy interface | ||||||
|  |      * | ||||||
|  |      * @param \Cilex\Application $app | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     function register(\Cilex\Application $app) | ||||||
|  |     { | ||||||
|  |         $app['mock.param'] = false; | ||||||
|  |         $app['mock'] = $this; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Application test cases. | ||||||
|  |  * | ||||||
|  |  * @author Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  */ | ||||||
|  | class ApplicationTest extends \PHPUnit_Framework_TestCase | ||||||
|  | { | ||||||
|  |     const NAME    = 'Test'; | ||||||
|  |     const VERSION = '1.0.1'; | ||||||
|  |  | ||||||
|  |     /** @var \Cilex\Application */ | ||||||
|  |     protected $fixture = null; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Sets up the test fixture. | ||||||
|  |      */ | ||||||
|  |     public function setUp() | ||||||
|  |     { | ||||||
|  |         $this->fixture = new Application(self::NAME, self::VERSION); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Tests whether the constructor instantiates the correct dependencies and | ||||||
|  |      * correctly sets the name on the Console's Application. | ||||||
|  |      */ | ||||||
|  |     public function testConstruct() | ||||||
|  |     { | ||||||
|  |         $this->assertInstanceOf( | ||||||
|  |             '\\Symfony\\Component\\Console\\Application', | ||||||
|  |             $this->fixture['console'] | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $this->assertEquals(self::NAME, $this->fixture['console']->getName()); | ||||||
|  |         $this->assertEquals(self::VERSION, $this->fixture['console']->getVersion()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Tests the command method to see if the command is properly set and the | ||||||
|  |      * Cilex application is added as container. | ||||||
|  |      */ | ||||||
|  |     public function testCommand() | ||||||
|  |     { | ||||||
|  |         $this->assertFalse($this->fixture['console']->has('demo:greet')); | ||||||
|  |         $this->fixture->command(new \Cilex\Command\GreetCommand()); | ||||||
|  |         $this->assertTrue($this->fixture['console']->has('demo:greet')); | ||||||
|  |  | ||||||
|  |         $this->assertSame( | ||||||
|  |             $this->fixture, | ||||||
|  |             $this->fixture['console']->get('demo:greet')->getContainer() | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Tests whether the register method applies the provided parameters to this | ||||||
|  |      * application and correctly registers the ServiceProvider. | ||||||
|  |      */ | ||||||
|  |     public function testRegister() | ||||||
|  |     { | ||||||
|  |         $provider = new ServiceProviderMock(); | ||||||
|  |         $this->fixture->register($provider, array('mock.param' => true)); | ||||||
|  |  | ||||||
|  |         $this->assertTrue($this->fixture['mock.param']); | ||||||
|  |         $this->assertSame($this->fixture['mock'], $provider); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										61
									
								
								vendor/cilex/cilex/tests/Cilex/Tests/Command/CommandTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								vendor/cilex/cilex/tests/Cilex/Tests/Command/CommandTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Tests\Command; | ||||||
|  |  | ||||||
|  | use \Cilex\Command; | ||||||
|  |  | ||||||
|  | class CommandMock extends Command\Command {} | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Command\Command test cases. | ||||||
|  |  * | ||||||
|  |  * @author Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  */ | ||||||
|  | class CommandTest extends \PHPUnit_Framework_TestCase | ||||||
|  | { | ||||||
|  |     /** @var \Cilex\Command\Command */ | ||||||
|  |     protected $fixture = null; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Sets up the test fixture. | ||||||
|  |      */ | ||||||
|  |     public function setUp() | ||||||
|  |     { | ||||||
|  |         $this->fixture = new CommandMock('demo:test'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Tests the getContainer method. | ||||||
|  |      */ | ||||||
|  |     public function testContainer() | ||||||
|  |     { | ||||||
|  |         $app = new \Cilex\Application('Test'); | ||||||
|  |         $app->command($this->fixture); | ||||||
|  |  | ||||||
|  |         $this->assertSame($app, $this->fixture->getContainer()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Tests whether the getService method correctly retrieves an element from | ||||||
|  |      * the container. | ||||||
|  |      */ | ||||||
|  |     public function testGetService() | ||||||
|  |     { | ||||||
|  |         $app = new \Cilex\Application('Test'); | ||||||
|  |         $app->command($this->fixture); | ||||||
|  |  | ||||||
|  |         $this->assertInstanceOf( | ||||||
|  |             '\Symfony\Component\Console\Application', | ||||||
|  |             $this->fixture->getService('console') | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										136
									
								
								vendor/cilex/cilex/tests/Cilex/Tests/Provider/ConfigServerProviderTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										136
									
								
								vendor/cilex/cilex/tests/Cilex/Tests/Provider/ConfigServerProviderTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,136 @@ | |||||||
|  | <?php | ||||||
|  | /** | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  * | ||||||
|  |  * @author Ben Selby <benmatselby@gmail.com> | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Tests\Provider; | ||||||
|  |  | ||||||
|  | use Cilex\Application; | ||||||
|  | use Cilex\Provider\ConfigServiceProvider; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Test file for ConfigServiceProvider | ||||||
|  |  * | ||||||
|  |  * @author Ben Selby <benmatselby@gmail.com> | ||||||
|  |  */ | ||||||
|  | class ConfigServiceProviderTest extends \PHPUnit_Framework_TestCase | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Test that an exception is thrown if the config path is not present | ||||||
|  |      * or valid | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function testRegisterWillThrowExceptionIfConfigPathIsNotThere() | ||||||
|  |     { | ||||||
|  |         $this->setExpectedException( | ||||||
|  |             'InvalidArgumentException', | ||||||
|  |             __DIR__.'/../../../data/unknownfile is not a valid path to the configuration' | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app = new Application('Test'); | ||||||
|  |  | ||||||
|  |         $app->register( | ||||||
|  |             new ConfigServiceProvider(), | ||||||
|  |             array( | ||||||
|  |                 'config.path' =>  __DIR__.'/../../../data/unknownfile' | ||||||
|  |             ) | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $config = $app['config']; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Test that the config provider can parse a json | ||||||
|  |      * configuration file | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function testRegisterCanParseAJsonConfigFile() | ||||||
|  |     { | ||||||
|  |         $app = new Application('Test'); | ||||||
|  |  | ||||||
|  |         $app->register( | ||||||
|  |             new ConfigServiceProvider(), | ||||||
|  |             array( | ||||||
|  |                 'config.path' =>  __DIR__.'/../../../data/config.json' | ||||||
|  |             ) | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $config = $app['config']; | ||||||
|  |         $this->assertEquals($config->key, 'value'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testCanParseAPhpConfigFile() | ||||||
|  |     { | ||||||
|  |         $app = new Application('Test'); | ||||||
|  |  | ||||||
|  |         $app->register( | ||||||
|  |             new ConfigServiceProvider(), | ||||||
|  |             array( | ||||||
|  |                 'config.path' => __DIR__.'/../../../data/config.php' | ||||||
|  |             ) | ||||||
|  |         ); | ||||||
|  |         $config = $app['config']; | ||||||
|  |         $this->assertEquals($config['key'], 'value'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Test that the config provider can throw an exception if | ||||||
|  |      * the json configuration file is invalid | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function testRegisterThrowsExceptionInCaseOfInvalidJsonConfigFile() | ||||||
|  |     { | ||||||
|  |         $configPath = __DIR__.'/../../../data/config-invalid.json'; | ||||||
|  |  | ||||||
|  |         $this->setExpectedException( | ||||||
|  |             'InvalidArgumentException', | ||||||
|  |             'Unable to decode the configuration file: ' . $configPath | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app = new Application('Test'); | ||||||
|  |  | ||||||
|  |         $app->register( | ||||||
|  |             new ConfigServiceProvider(), | ||||||
|  |             array( | ||||||
|  |                 'config.path' =>  $configPath | ||||||
|  |             ) | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $config = $app['config']; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Test that register will throw an exception if an unknown | ||||||
|  |      * format is passed in | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function testRegisterThrowsExceptionIfAnUnknownFormatIsPassed() | ||||||
|  |     { | ||||||
|  |         $this->setExpectedException( | ||||||
|  |             'InvalidArgumentException', | ||||||
|  |             'Unable to load configuration; the provided file extension was not recognized. Only yml, xml or json allowed' | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $app = new Application('Test'); | ||||||
|  |  | ||||||
|  |         $app->register( | ||||||
|  |             new ConfigServiceProvider(), | ||||||
|  |             array( | ||||||
|  |                 'config.path' =>  __DIR__.'/../../../data/config.unknownfiletype' | ||||||
|  |             ) | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         $config = $app['config']; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										52
									
								
								vendor/cilex/cilex/tests/Cilex/Tests/Provider/ValidatorServiceProviderTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								vendor/cilex/cilex/tests/Cilex/Tests/Provider/ValidatorServiceProviderTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Tests\Provider; | ||||||
|  |  | ||||||
|  | use Cilex\Application; | ||||||
|  | use Cilex\Provider\ValidatorServiceProvider; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * ValidatorServiceProvider. | ||||||
|  |  * | ||||||
|  |  * Originally provided with the Silex Framework; test has been adapted for Cilex. | ||||||
|  |  * | ||||||
|  |  * @author Javier Lopez <f12loalf@gmail.com> | ||||||
|  |  * @author Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  */ | ||||||
|  | class ValidatorServiceProviderTest extends \PHPUnit_Framework_TestCase | ||||||
|  | { | ||||||
|  |     public function setUp() | ||||||
|  |     { | ||||||
|  |         if (!is_dir(__DIR__.'/../../../../vendor/symfony/validator/Symfony/Component/Validator')) { | ||||||
|  |             $this->markTestSkipped('Validator submodule was not installed.'); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function testRegister() | ||||||
|  |     { | ||||||
|  |         $app = new Application('Test'); | ||||||
|  |  | ||||||
|  |         $app->register(new ValidatorServiceProvider(), array( | ||||||
|  |             'validator.class_path' =>  __DIR__.'/../../../../vendor/Symfony/Component/Validator' | ||||||
|  |         )); | ||||||
|  |  | ||||||
|  |         return $app; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @depends testRegister | ||||||
|  |      */ | ||||||
|  |     public function testValidatorServiceIsAValidator($app) | ||||||
|  |     { | ||||||
|  |         $this->assertInstanceOf('Symfony\Component\Validator\Validator', $app['validator']); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										4
									
								
								vendor/cilex/cilex/tests/data/config-invalid.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								vendor/cilex/cilex/tests/data/config-invalid.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | { | ||||||
|  |     "key": "value" | ||||||
|  |     "missing": "comma" | ||||||
|  | } | ||||||
							
								
								
									
										3
									
								
								vendor/cilex/cilex/tests/data/config.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								vendor/cilex/cilex/tests/data/config.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | { | ||||||
|  |     "key": "value" | ||||||
|  | } | ||||||
							
								
								
									
										4
									
								
								vendor/cilex/cilex/tests/data/config.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								vendor/cilex/cilex/tests/data/config.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | <?php | ||||||
|  | return array( | ||||||
|  | 	'key' => 'value' | ||||||
|  | ); | ||||||
							
								
								
									
										0
									
								
								vendor/cilex/cilex/tests/data/config.unknownfiletype
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								vendor/cilex/cilex/tests/data/config.unknownfiletype
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
								
								
									
										2
									
								
								vendor/cilex/console-service-provider/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								vendor/cilex/console-service-provider/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | vendor | ||||||
|  | .idea | ||||||
							
								
								
									
										163
									
								
								vendor/cilex/console-service-provider/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										163
									
								
								vendor/cilex/console-service-provider/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,163 @@ | |||||||
|  | Console Service Provider | ||||||
|  | ======================== | ||||||
|  |  | ||||||
|  | Provides [Console][symfony/console] as a service to [Pimple][pimple] applications. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Requirements | ||||||
|  | ------------ | ||||||
|  |  | ||||||
|  |  * PHP 5.3+ | ||||||
|  |  * Symfony Console ~2.1 | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Installation | ||||||
|  | ------------ | ||||||
|  |   | ||||||
|  | Through [Composer][composer] as [cilex/console-service-provider][cilex/console-service-provider]. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Usage | ||||||
|  | ----- | ||||||
|  |  | ||||||
|  | ### Pimple | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | <?php | ||||||
|  | use Cilex\Provider\Console\BaseConsoleServiceProvider; | ||||||
|  |  | ||||||
|  | $app = new Pimple; | ||||||
|  |  | ||||||
|  | $app['console.name'] = 'MyApp'; | ||||||
|  | $app['console.version'] = '1.0.5'; | ||||||
|  |  | ||||||
|  | $consoleServiceProvider = new BaseConsoleServiceProvider; | ||||||
|  | $consoleServiceProvider->register($app); | ||||||
|  |  | ||||||
|  | $app['console']->run(); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ### Silex | ||||||
|  |  | ||||||
|  | To use the Console Service Provider in a Silex application register the | ||||||
|  | Console Service Provider Silex adapter. | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | <?php | ||||||
|  | use Cilex\Provider\Console\Adapter\Silex\ConsoleServiceProvider; | ||||||
|  | use Silex\Application; | ||||||
|  |  | ||||||
|  | $app = new Application; | ||||||
|  |  | ||||||
|  | $app->register(new ConsoleServiceProvider(), array( | ||||||
|  |     'console.name' => 'MyApp', | ||||||
|  |     'console.version' => '1.0.5', | ||||||
|  | )); | ||||||
|  |  | ||||||
|  | $app['console']->run(); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ### Cilex | ||||||
|  |  | ||||||
|  | The Console Service Provider is baked into the Cilex Application itself so | ||||||
|  | there is no need to register it manually. | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | <?php | ||||||
|  | use Cilex\Application; | ||||||
|  |  | ||||||
|  | $app = new Application('MyApp', '1.0.5'); | ||||||
|  |  | ||||||
|  | $app->run(); | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Configuration | ||||||
|  | ------------- | ||||||
|  |  | ||||||
|  | ### Parameters | ||||||
|  |  | ||||||
|  |  * **console.name**: | ||||||
|  |    Name for the console application. | ||||||
|  |  * **console.version**: | ||||||
|  |    Version for the console application. | ||||||
|  |  * **console.class**: | ||||||
|  |    Class for the console application to be created. | ||||||
|  |  | ||||||
|  | ### Services | ||||||
|  |  | ||||||
|  |  * **console**: | ||||||
|  |    Console Application, instance `Symfony\Component\Console\Application`. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | The Console Service Provider Application Class | ||||||
|  | ---------------------------------------------- | ||||||
|  |  | ||||||
|  | By default Console Service Provider will instantiate an instance of | ||||||
|  | `Cilex\Pimple\Provider\Console\Application`. | ||||||
|  |  | ||||||
|  | ### Methods | ||||||
|  |  | ||||||
|  | #### getContainer() : \Pimple | ||||||
|  |  | ||||||
|  | Returns the Pimple container. | ||||||
|  |  | ||||||
|  | #### getService($name) : \stdClass|null | ||||||
|  |  | ||||||
|  | Returns a service contained in the application container or null if none | ||||||
|  | is found with that name. Convenience method to avoid repeated calls to | ||||||
|  | `getContainer()` or having to assign the container. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Accessing the Container and Services from Commands | ||||||
|  | -------------------------------------------------- | ||||||
|  |  | ||||||
|  | Here are some examples of accessing the Container and Services from a Command: | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | <?php | ||||||
|  |  | ||||||
|  | use Symfony\Component\Console\Command; | ||||||
|  | use Symfony\Component\Console\Input\InputInterface; | ||||||
|  | use Symfony\Component\Console\Output\OutputInterface; | ||||||
|  |  | ||||||
|  | class SomeCommand extends Command | ||||||
|  | { | ||||||
|  |     protected function configure() | ||||||
|  |     { | ||||||
|  |         // configure the command | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected function execute(InputInterface $input, OutputInterface $output) | ||||||
|  |     { | ||||||
|  |         // Direct access to the Container. | ||||||
|  |         $container = $this->getApplication()->getContainer(); | ||||||
|  |  | ||||||
|  |         // Direct access to a service. | ||||||
|  |         $service = $this->getApplication->getService('some.service'); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Future | ||||||
|  | ------ | ||||||
|  |  | ||||||
|  | In the event that Pimple Service Providers become a reality, `ConsoleServiceProvider` | ||||||
|  | will implement the appropriate interface. As soon as Cilex and Silex become Pimple | ||||||
|  | Service Provider aware, their respective adapter classes can be bypassed and the | ||||||
|  | core `ConsoleServiceProvider` can be used directly. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | License | ||||||
|  | ------- | ||||||
|  |  | ||||||
|  | MIT, see LICENSE. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | [symfony/console]: http://symfony.com/doc/current/components/console/introduction.html | ||||||
|  | [pimple]: http://pimple.sensiolabs.org | ||||||
|  | [composer]: http://getcomposer.org | ||||||
|  | [cilex/console-service-provider]: https://packagist.org/packages/cilex/console-service-provider | ||||||
							
								
								
									
										27
									
								
								vendor/cilex/console-service-provider/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								vendor/cilex/console-service-provider/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | { | ||||||
|  |     "name":        "cilex/console-service-provider", | ||||||
|  |     "description": "Console Service Provider", | ||||||
|  |     "keywords":    ["pimple", "cilex", "silex", "console", "service-provider"], | ||||||
|  |     "license":     "MIT", | ||||||
|  |     "authors": [ | ||||||
|  |         { "name":  "Mike van Riel", "email": "mike.vanriel@naenius.com" }, | ||||||
|  |         { "name": "Beau Simensen",  "email": "beau@dflydev.com" } | ||||||
|  |     ], | ||||||
|  |     "require": { | ||||||
|  |         "php":             ">=5.3.3", | ||||||
|  |         "pimple/pimple":   "1.*@dev", | ||||||
|  |         "symfony/console": "~2.1" | ||||||
|  |     }, | ||||||
|  |     "require-dev": { | ||||||
|  |         "cilex/cilex": "1.*@dev", | ||||||
|  |         "silex/silex": "1.*@dev" | ||||||
|  |     }, | ||||||
|  |     "autoload": { | ||||||
|  |         "psr-0": { "Cilex\\Provider\\Console": "src" } | ||||||
|  |     }, | ||||||
|  |     "extra": { | ||||||
|  |         "branch-alias": { | ||||||
|  |             "dev-master": "1.0-dev" | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										110
									
								
								vendor/cilex/console-service-provider/composer.lock
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								vendor/cilex/console-service-provider/composer.lock
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,110 @@ | |||||||
|  | { | ||||||
|  |     "hash": "52d1f50b5bb3e0f2626a352a0ed2a947", | ||||||
|  |     "packages": [ | ||||||
|  |         { | ||||||
|  |             "name": "pimple/pimple", | ||||||
|  |             "version": "dev-master", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "git://github.com/fabpot/Pimple.git", | ||||||
|  |                 "reference": "v1.0.1" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://github.com/fabpot/Pimple/archive/v1.0.1.zip", | ||||||
|  |                 "reference": "v1.0.1", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.0" | ||||||
|  |             }, | ||||||
|  |             "time": "2012-11-11 08:32:34", | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "1.0.x-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "installation-source": "source", | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Pimple": "lib/" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Fabien Potencier", | ||||||
|  |                     "email": "fabien@symfony.com" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Pimple is a simple Dependency Injection Container for PHP 5.3", | ||||||
|  |             "homepage": "http://pimple.sensiolabs.org", | ||||||
|  |             "keywords": [ | ||||||
|  |                 "dependency injection", | ||||||
|  |                 "container" | ||||||
|  |             ] | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "name": "symfony/console", | ||||||
|  |             "version": "v2.1.4", | ||||||
|  |             "target-dir": "Symfony/Component/Console", | ||||||
|  |             "source": { | ||||||
|  |                 "type": "git", | ||||||
|  |                 "url": "https://github.com/symfony/Console", | ||||||
|  |                 "reference": "v2.1.4" | ||||||
|  |             }, | ||||||
|  |             "dist": { | ||||||
|  |                 "type": "zip", | ||||||
|  |                 "url": "https://github.com/symfony/Console/archive/v2.1.4.zip", | ||||||
|  |                 "reference": "v2.1.4", | ||||||
|  |                 "shasum": "" | ||||||
|  |             }, | ||||||
|  |             "require": { | ||||||
|  |                 "php": ">=5.3.3" | ||||||
|  |             }, | ||||||
|  |             "time": "2012-11-09 08:52:51", | ||||||
|  |             "type": "library", | ||||||
|  |             "extra": { | ||||||
|  |                 "branch-alias": { | ||||||
|  |                     "dev-master": "2.1-dev" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "installation-source": "dist", | ||||||
|  |             "autoload": { | ||||||
|  |                 "psr-0": { | ||||||
|  |                     "Symfony\\Component\\Console": "" | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             "notification-url": "https://packagist.org/downloads/", | ||||||
|  |             "license": [ | ||||||
|  |                 "MIT" | ||||||
|  |             ], | ||||||
|  |             "authors": [ | ||||||
|  |                 { | ||||||
|  |                     "name": "Fabien Potencier", | ||||||
|  |                     "email": "fabien@symfony.com" | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "name": "Symfony Community", | ||||||
|  |                     "homepage": "http://symfony.com/contributors" | ||||||
|  |                 } | ||||||
|  |             ], | ||||||
|  |             "description": "Symfony Console Component", | ||||||
|  |             "homepage": "http://symfony.com" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  |     "packages-dev": null, | ||||||
|  |     "aliases": [ | ||||||
|  |  | ||||||
|  |     ], | ||||||
|  |     "minimum-stability": "stable", | ||||||
|  |     "stability-flags": { | ||||||
|  |         "pimple/pimple": 20, | ||||||
|  |         "cilex/cilex": 20, | ||||||
|  |         "silex/silex": 20 | ||||||
|  |     } | ||||||
|  | } | ||||||
| @@ -0,0 +1,40 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Provider\Console\Adapter\Silex; | ||||||
|  |  | ||||||
|  | use Cilex\Provider\Console\BaseConsoleServiceProvider; | ||||||
|  | use Silex\Application; | ||||||
|  | use Silex\ServiceProviderInterface; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Silex Console Service Provider adapter | ||||||
|  |  * | ||||||
|  |  * @author Beau Simensen <beau@dflydev.com> | ||||||
|  |  */ | ||||||
|  | class ConsoleServiceProvider implements ServiceProviderInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function boot(Application $app) | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function register(Application $app) | ||||||
|  |     { | ||||||
|  |         $serviceProvider = new BaseConsoleServiceProvider; | ||||||
|  |         $serviceProvider->register($app); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										54
									
								
								vendor/cilex/console-service-provider/src/Cilex/Provider/Console/BaseConsoleServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								vendor/cilex/console-service-provider/src/Cilex/Provider/Console/BaseConsoleServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Provider\Console; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Pimple Console Service Provider | ||||||
|  |  * | ||||||
|  |  * @author Beau Simensen <beau@dflydev.com> | ||||||
|  |  */ | ||||||
|  | class BaseConsoleServiceProvider | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function register(\Pimple $container) | ||||||
|  |     { | ||||||
|  |         foreach ($this->getDefaults() as $key => $value) { | ||||||
|  |             if (!isset($container[$key])) { | ||||||
|  |                 $container[$key] = $value; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         $container['console'] = $container->share(function() use ($container) { | ||||||
|  |             $class    = $container['console.class']; | ||||||
|  |             $instance = new $class( | ||||||
|  |                 isset($container['console.name']) ? $container['console.name'] : '', | ||||||
|  |                 isset($container['console.version']) ? $container['console.version'] : null | ||||||
|  |             ); | ||||||
|  |  | ||||||
|  |             if ($instance instanceof ContainerAwareApplication) { | ||||||
|  |                 $instance->setContainer($container); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             return $instance; | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     protected function getDefaults() | ||||||
|  |     { | ||||||
|  |         return array( | ||||||
|  |             'console.name' => 'Cilex Application', | ||||||
|  |             'console.class' => 'Cilex\Provider\Console\ContainerAwareApplication', | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								vendor/cilex/console-service-provider/src/Cilex/Provider/Console/ConsoleServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								vendor/cilex/console-service-provider/src/Cilex/Provider/Console/ConsoleServiceProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Provider\Console; | ||||||
|  |  | ||||||
|  | use Cilex\Application; | ||||||
|  | use Cilex\ServiceProviderInterface; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Cilex Console Service Provider | ||||||
|  |  * | ||||||
|  |  * @author Beau Simensen <beau@dflydev.com> | ||||||
|  |  */ | ||||||
|  | class ConsoleServiceProvider implements ServiceProviderInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * {@inheritdoc} | ||||||
|  |      */ | ||||||
|  |     public function register(Application $app) | ||||||
|  |     { | ||||||
|  |         $serviceProvider = new BaseConsoleServiceProvider(); | ||||||
|  |         $serviceProvider->register($app); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										77
									
								
								vendor/cilex/console-service-provider/src/Cilex/Provider/Console/ContainerAwareApplication.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								vendor/cilex/console-service-provider/src/Cilex/Provider/Console/ContainerAwareApplication.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * This file is part of the Cilex framework. | ||||||
|  |  * | ||||||
|  |  * (c) Mike van Riel <mike.vanriel@naenius.com> | ||||||
|  |  * | ||||||
|  |  * For the full copyright and license information, please view the LICENSE | ||||||
|  |  * file that was distributed with this source code. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | namespace Cilex\Provider\Console; | ||||||
|  |  | ||||||
|  | use Symfony\Component\Console\Application; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Cilex Pimple Console Application | ||||||
|  |  * | ||||||
|  |  * @author Beau Simensen <beau@dflydev.com> | ||||||
|  |  */ | ||||||
|  | class ContainerAwareApplication extends Application | ||||||
|  | { | ||||||
|  |     /** @var \Pimple */ | ||||||
|  |     private $container; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Constructor | ||||||
|  |      * | ||||||
|  |      * @param string  $name      The name of the application | ||||||
|  |      * @param string  $version   The version of the application | ||||||
|  |      */ | ||||||
|  |     public function __construct($name = 'UNKNOWN', $version = 'UNKNOWN') | ||||||
|  |     { | ||||||
|  |         parent::__construct($name, $version); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Sets a container instance onto this application. | ||||||
|  |      * | ||||||
|  |      * @param \Pimple $container | ||||||
|  |      * | ||||||
|  |      * @return void | ||||||
|  |      */ | ||||||
|  |     public function setContainer(\Pimple $container) | ||||||
|  |     { | ||||||
|  |         $this->container = $container; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the Container. | ||||||
|  |      * | ||||||
|  |      * @return \Pimple | ||||||
|  |      */ | ||||||
|  |     public function getContainer() | ||||||
|  |     { | ||||||
|  |         return $this->container; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Returns a service contained in the application container or null if none is found with that name. | ||||||
|  |      * | ||||||
|  |      * This is a convenience method used to retrieve an element from the Application container without having to assign | ||||||
|  |      * the results of the getContainer() method in every call. | ||||||
|  |      * | ||||||
|  |      * @param string $name Name of the service. | ||||||
|  |      * | ||||||
|  |      * @see self::getContainer() | ||||||
|  |      * | ||||||
|  |      * @api | ||||||
|  |      * | ||||||
|  |      * @return mixed|null | ||||||
|  |      */ | ||||||
|  |     public function getService($name) | ||||||
|  |     { | ||||||
|  |         return isset($this->container[$name]) ? $this->container[$name] : null; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										3672
									
								
								vendor/composer/autoload_classmap.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3672
									
								
								vendor/composer/autoload_classmap.php
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										10
									
								
								vendor/composer/autoload_files.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								vendor/composer/autoload_files.php
									
									
									
									
										vendored
									
									
								
							| @@ -6,11 +6,21 @@ $vendorDir = dirname(dirname(__FILE__)); | |||||||
| $baseDir = dirname($vendorDir); | $baseDir = dirname($vendorDir); | ||||||
|  |  | ||||||
| return array( | return array( | ||||||
|  |     '320cde22f66dd4f5d3fd621d3e88b98f' => $vendorDir . '/symfony/polyfill-ctype/bootstrap.php', | ||||||
|  |     '10a6847eba8a430a134fad89f4a30a26' => $vendorDir . '/zendframework/zend-cache/autoload/patternPluginManagerPolyfill.php', | ||||||
|  |     '0e6d7bf4a5811bfa5cf40c5ccd6fae6a' => $vendorDir . '/symfony/polyfill-mbstring/bootstrap.php', | ||||||
|     'e88992873b7765f9b5710cab95ba5dd7' => $vendorDir . '/hoa/consistency/Prelude.php', |     'e88992873b7765f9b5710cab95ba5dd7' => $vendorDir . '/hoa/consistency/Prelude.php', | ||||||
|  |     'fe1bcd0336136e435eaf197895daf81a' => $vendorDir . '/nikic/php-parser/lib/bootstrap.php', | ||||||
|  |     'd9d39f82a605ebe5918f683dd402334c' => $vendorDir . '/padraic/humbug_get_contents/src/function.php', | ||||||
|  |     '3a50d90d85c7fe889a94ae1114b921ce' => $vendorDir . '/padraic/humbug_get_contents/src/functions.php', | ||||||
|     '5255c38a0faeba867671b61dfda6d864' => $vendorDir . '/paragonie/random_compat/lib/random.php', |     '5255c38a0faeba867671b61dfda6d864' => $vendorDir . '/paragonie/random_compat/lib/random.php', | ||||||
|     '7b11c4dc42b3b3023073cb14e519683c' => $vendorDir . '/ralouphie/getallheaders/src/getallheaders.php', |     '7b11c4dc42b3b3023073cb14e519683c' => $vendorDir . '/ralouphie/getallheaders/src/getallheaders.php', | ||||||
|  |     '25072dd6e2470089de65ae7bf11d3109' => $vendorDir . '/symfony/polyfill-php72/bootstrap.php', | ||||||
|     'a0edc8309cc5e1d60e3047b5df6b7052' => $vendorDir . '/guzzlehttp/psr7/src/functions_include.php', |     'a0edc8309cc5e1d60e3047b5df6b7052' => $vendorDir . '/guzzlehttp/psr7/src/functions_include.php', | ||||||
|  |     '6124b4c8570aa390c21fafd04a26c69f' => $vendorDir . '/myclabs/deep-copy/src/DeepCopy/deep_copy.php', | ||||||
|  |     '667aeda72477189d0494fecd327c3641' => $vendorDir . '/symfony/var-dumper/Resources/functions/dump.php', | ||||||
|     '2cffec82183ee1cea088009cef9a6fc3' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier.composer.php', |     '2cffec82183ee1cea088009cef9a6fc3' => $vendorDir . '/ezyang/htmlpurifier/library/HTMLPurifier.composer.php', | ||||||
|     '757772e28a0943a9afe83def8db95bdf' => $vendorDir . '/mf2/mf2/Mf2/Parser.php', |     '757772e28a0943a9afe83def8db95bdf' => $vendorDir . '/mf2/mf2/Mf2/Parser.php', | ||||||
|     'decc78cc4436b1292c6c0d151b19445c' => $vendorDir . '/phpseclib/phpseclib/phpseclib/bootstrap.php', |     'decc78cc4436b1292c6c0d151b19445c' => $vendorDir . '/phpseclib/phpseclib/phpseclib/bootstrap.php', | ||||||
|  |     '801c31d8ed748cfa537fa45402288c95' => $vendorDir . '/psy/psysh/src/functions.php', | ||||||
| ); | ); | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								vendor/composer/autoload_namespaces.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								vendor/composer/autoload_namespaces.php
									
									
									
									
										vendored
									
									
								
							| @@ -6,6 +6,21 @@ $vendorDir = dirname(dirname(__FILE__)); | |||||||
| $baseDir = dirname($vendorDir); | $baseDir = dirname($vendorDir); | ||||||
|  |  | ||||||
| return array( | return array( | ||||||
|  |     'phpDocumentor' => array($vendorDir . '/phpdocumentor/fileset/src', $vendorDir . '/phpdocumentor/fileset/tests/unit', $vendorDir . '/phpdocumentor/graphviz/src', $vendorDir . '/phpdocumentor/graphviz/tests/unit', $vendorDir . '/phpdocumentor/phpdocumentor/src', $vendorDir . '/phpdocumentor/phpdocumentor/tests/unit', $vendorDir . '/phpdocumentor/reflection/src', $vendorDir . '/phpdocumentor/reflection/tests/unit', $vendorDir . '/phpdocumentor/reflection/tests/mocks', $vendorDir . '/phpdocumentor/reflection-docblock/src'), | ||||||
|  |     'Twig_' => array($vendorDir . '/twig/twig/lib'), | ||||||
|  |     'Pimple' => array($vendorDir . '/pimple/pimple/lib'), | ||||||
|  |     'PhpCollection' => array($vendorDir . '/phpcollection/phpcollection/src'), | ||||||
|  |     'Parsedown' => array($vendorDir . '/erusev/parsedown'), | ||||||
|  |     'Neutron' => array($vendorDir . '/neutron/temporary-filesystem/src'), | ||||||
|  |     'Metadata\\' => array($vendorDir . '/jms/metadata/src'), | ||||||
|  |     'JMS\\Serializer' => array($vendorDir . '/jms/serializer/src'), | ||||||
|  |     'JMS\\' => array($vendorDir . '/jms/parser-lib/src'), | ||||||
|     'HTMLPurifier' => array($vendorDir . '/ezyang/htmlpurifier/library'), |     'HTMLPurifier' => array($vendorDir . '/ezyang/htmlpurifier/library'), | ||||||
|  |     'FFMpeg' => array($vendorDir . '/php-ffmpeg/php-ffmpeg/src'), | ||||||
|  |     'Evenement' => array($vendorDir . '/evenement/evenement/src'), | ||||||
|     'Console' => array($vendorDir . '/pear/console_getopt'), |     'Console' => array($vendorDir . '/pear/console_getopt'), | ||||||
|  |     'Cilex\\Provider\\Console' => array($vendorDir . '/cilex/console-service-provider/src'), | ||||||
|  |     'Cilex\\Provider' => array($vendorDir . '/phpdocumentor/phpdocumentor/src'), | ||||||
|  |     'Cilex' => array($vendorDir . '/cilex/cilex/src'), | ||||||
|  |     'Alchemy' => array($vendorDir . '/alchemy/binary-driver/src'), | ||||||
| ); | ); | ||||||
|   | |||||||
							
								
								
									
										45
									
								
								vendor/composer/autoload_psr4.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										45
									
								
								vendor/composer/autoload_psr4.php
									
									
									
									
										vendored
									
									
								
							| @@ -7,18 +7,63 @@ $baseDir = dirname($vendorDir); | |||||||
|  |  | ||||||
| return array( | return array( | ||||||
|     'phpseclib\\' => array($vendorDir . '/phpseclib/phpseclib/phpseclib'), |     'phpseclib\\' => array($vendorDir . '/phpseclib/phpseclib/phpseclib'), | ||||||
|  |     'Zend\\Stdlib\\' => array($vendorDir . '/zendframework/zend-stdlib/src'), | ||||||
|  |     'Zend\\ServiceManager\\' => array($vendorDir . '/zendframework/zend-servicemanager/src'), | ||||||
|  |     'Zend\\Serializer\\' => array($vendorDir . '/zendframework/zend-serializer/src'), | ||||||
|  |     'Zend\\Json\\' => array($vendorDir . '/zendframework/zend-json/src'), | ||||||
|  |     'Zend\\I18n\\' => array($vendorDir . '/zendframework/zend-i18n/src'), | ||||||
|  |     'Zend\\Hydrator\\' => array($vendorDir . '/zendframework/zend-hydrator/src'), | ||||||
|  |     'Zend\\Filter\\' => array($vendorDir . '/zendframework/zend-filter/src'), | ||||||
|  |     'Zend\\EventManager\\' => array($vendorDir . '/zendframework/zend-eventmanager/src'), | ||||||
|  |     'Zend\\Config\\' => array($vendorDir . '/zendframework/zend-config/src'), | ||||||
|  |     'Zend\\Cache\\' => array($vendorDir . '/zendframework/zend-cache/src'), | ||||||
|  |     'XdgBaseDir\\' => array($vendorDir . '/dnoegel/php-xdg-base-dir/src'), | ||||||
|     'XMPPHP\\' => array($vendorDir . '/diogocomposer/xmpphp/XMPPHP'), |     'XMPPHP\\' => array($vendorDir . '/diogocomposer/xmpphp/XMPPHP'), | ||||||
|  |     'Webmozart\\Assert\\' => array($vendorDir . '/webmozart/assert/src'), | ||||||
|  |     'Twig\\' => array($vendorDir . '/twig/twig/src'), | ||||||
|  |     'Symfony\\Polyfill\\Php72\\' => array($vendorDir . '/symfony/polyfill-php72'), | ||||||
|  |     'Symfony\\Polyfill\\Mbstring\\' => array($vendorDir . '/symfony/polyfill-mbstring'), | ||||||
|  |     'Symfony\\Polyfill\\Ctype\\' => array($vendorDir . '/symfony/polyfill-ctype'), | ||||||
|  |     'Symfony\\Component\\VarDumper\\' => array($vendorDir . '/symfony/var-dumper'), | ||||||
|  |     'Symfony\\Component\\Validator\\' => array($vendorDir . '/symfony/validator'), | ||||||
|  |     'Symfony\\Component\\Translation\\' => array($vendorDir . '/symfony/translation'), | ||||||
|  |     'Symfony\\Component\\Stopwatch\\' => array($vendorDir . '/symfony/stopwatch'), | ||||||
|  |     'Symfony\\Component\\Process\\' => array($vendorDir . '/symfony/process'), | ||||||
|  |     'Symfony\\Component\\Finder\\' => array($vendorDir . '/symfony/finder'), | ||||||
|  |     'Symfony\\Component\\Filesystem\\' => array($vendorDir . '/symfony/filesystem'), | ||||||
|  |     'Symfony\\Component\\EventDispatcher\\' => array($vendorDir . '/symfony/event-dispatcher'), | ||||||
|  |     'Symfony\\Component\\Debug\\' => array($vendorDir . '/symfony/debug'), | ||||||
|  |     'Symfony\\Component\\Console\\' => array($vendorDir . '/symfony/console'), | ||||||
|  |     'Symfony\\Component\\Config\\' => array($vendorDir . '/symfony/config'), | ||||||
|     'Stomp\\' => array($vendorDir . '/stomp-php/stomp-php/src'), |     'Stomp\\' => array($vendorDir . '/stomp-php/stomp-php/src'), | ||||||
|  |     'Psy\\' => array($vendorDir . '/psy/psysh/src'), | ||||||
|  |     'Psr\\SimpleCache\\' => array($vendorDir . '/psr/simple-cache/src'), | ||||||
|  |     'Psr\\Log\\' => array($vendorDir . '/psr/log/Psr/Log'), | ||||||
|     'Psr\\Http\\Message\\' => array($vendorDir . '/psr/http-message/src'), |     'Psr\\Http\\Message\\' => array($vendorDir . '/psr/http-message/src'), | ||||||
|  |     'Psr\\Container\\' => array($vendorDir . '/psr/container/src'), | ||||||
|  |     'Psr\\Cache\\' => array($vendorDir . '/psr/cache/src'), | ||||||
|  |     'Prophecy\\' => array($vendorDir . '/phpspec/prophecy/src/Prophecy'), | ||||||
|     'Predis\\' => array($vendorDir . '/predis/predis/src'), |     'Predis\\' => array($vendorDir . '/predis/predis/src'), | ||||||
|  |     'PhpOption\\' => array($vendorDir . '/phpoption/phpoption/src/PhpOption'), | ||||||
|     'ParagonIE\\ConstantTime\\' => array($vendorDir . '/paragonie/constant_time_encoding/src'), |     'ParagonIE\\ConstantTime\\' => array($vendorDir . '/paragonie/constant_time_encoding/src'), | ||||||
|  |     'Monolog\\' => array($vendorDir . '/monolog/monolog/src/Monolog'), | ||||||
|     'Michelf\\' => array($vendorDir . '/michelf/php-markdown/Michelf'), |     'Michelf\\' => array($vendorDir . '/michelf/php-markdown/Michelf'), | ||||||
|     'Masterminds\\' => array($vendorDir . '/masterminds/html5/src'), |     'Masterminds\\' => array($vendorDir . '/masterminds/html5/src'), | ||||||
|  |     'JakubOnderka\\PhpConsoleHighlighter\\' => array($vendorDir . '/jakub-onderka/php-console-highlighter/src'), | ||||||
|  |     'JakubOnderka\\PhpConsoleColor\\' => array($vendorDir . '/jakub-onderka/php-console-color/src'), | ||||||
|     'Intervention\\Image\\' => array($vendorDir . '/intervention/image/src/Intervention/Image'), |     'Intervention\\Image\\' => array($vendorDir . '/intervention/image/src/Intervention/Image'), | ||||||
|  |     'Interop\\Container\\' => array($vendorDir . '/container-interop/container-interop/src/Interop/Container'), | ||||||
|  |     'Humbug\\SelfUpdate\\' => array($vendorDir . '/padraic/phar-updater/src'), | ||||||
|  |     'Humbug\\' => array($vendorDir . '/padraic/humbug_get_contents/src'), | ||||||
|     'Hoa\\Exception\\' => array($vendorDir . '/hoa/exception'), |     'Hoa\\Exception\\' => array($vendorDir . '/hoa/exception'), | ||||||
|     'Hoa\\Event\\' => array($vendorDir . '/hoa/event'), |     'Hoa\\Event\\' => array($vendorDir . '/hoa/event'), | ||||||
|     'Hoa\\Consistency\\' => array($vendorDir . '/hoa/consistency'), |     'Hoa\\Consistency\\' => array($vendorDir . '/hoa/consistency'), | ||||||
|     'GuzzleHttp\\Psr7\\' => array($vendorDir . '/guzzlehttp/psr7/src'), |     'GuzzleHttp\\Psr7\\' => array($vendorDir . '/guzzlehttp/psr7/src'), | ||||||
|     'Embed\\' => array($vendorDir . '/embed/embed/src'), |     'Embed\\' => array($vendorDir . '/embed/embed/src'), | ||||||
|  |     'Doctrine\\Instantiator\\' => array($vendorDir . '/doctrine/instantiator/src/Doctrine/Instantiator'), | ||||||
|  |     'Doctrine\\Common\\Lexer\\' => array($vendorDir . '/doctrine/lexer/lib/Doctrine/Common/Lexer'), | ||||||
|  |     'Doctrine\\Common\\Cache\\' => array($vendorDir . '/doctrine/cache/lib/Doctrine/Common/Cache'), | ||||||
|  |     'Doctrine\\Common\\Annotations\\' => array($vendorDir . '/doctrine/annotations/lib/Doctrine/Common/Annotations'), | ||||||
|  |     'DeepCopy\\' => array($vendorDir . '/myclabs/deep-copy/src/DeepCopy'), | ||||||
|     'Composer\\CaBundle\\' => array($vendorDir . '/composer/ca-bundle/src'), |     'Composer\\CaBundle\\' => array($vendorDir . '/composer/ca-bundle/src'), | ||||||
| ); | ); | ||||||
|   | |||||||
							
								
								
									
										4018
									
								
								vendor/composer/autoload_static.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4018
									
								
								vendor/composer/autoload_static.php
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										5107
									
								
								vendor/composer/installed.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5107
									
								
								vendor/composer/installed.json
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										3
									
								
								vendor/container-interop/container-interop/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								vendor/container-interop/container-interop/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | composer.lock | ||||||
|  | composer.phar | ||||||
|  | /vendor/ | ||||||
							
								
								
									
										20
									
								
								vendor/container-interop/container-interop/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								vendor/container-interop/container-interop/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | The MIT License (MIT) | ||||||
|  |  | ||||||
|  | Copyright (c) 2013 container-interop | ||||||
|  |  | ||||||
|  | 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. | ||||||
							
								
								
									
										148
									
								
								vendor/container-interop/container-interop/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										148
									
								
								vendor/container-interop/container-interop/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,148 @@ | |||||||
|  | # Container Interoperability | ||||||
|  |  | ||||||
|  | [](https://packagist.org/packages/container-interop/container-interop) | ||||||
|  | [](https://packagist.org/packages/container-interop/container-interop) | ||||||
|  |  | ||||||
|  | ## Deprecation warning! | ||||||
|  |  | ||||||
|  | Starting Feb. 13th 2017, container-interop is officially deprecated in favor of [PSR-11](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-11-container.md). | ||||||
|  | Container-interop has been the test-bed of PSR-11. From v1.2, container-interop directly extends PSR-11 interfaces. | ||||||
|  | Therefore, all containers implementing container-interop are now *de-facto* compatible with PSR-11. | ||||||
|  |  | ||||||
|  | - Projects implementing container-interop interfaces are encouraged to directly implement PSR-11 interfaces instead. | ||||||
|  | - Projects consuming container-interop interfaces are very strongly encouraged to directly type-hint on PSR-11 interfaces, in order to be compatible with PSR-11 containers that are not compatible with container-interop. | ||||||
|  |  | ||||||
|  | Regarding the delegate lookup feature, that is present in container-interop and not in PSR-11, the feature is actually a design pattern. It is therefore not deprecated. Documentation regarding this design pattern will be migrated from this repository into a separate website in the future. | ||||||
|  |  | ||||||
|  | ## About | ||||||
|  |  | ||||||
|  | *container-interop* tries to identify and standardize features in *container* objects (service locators, | ||||||
|  | dependency injection containers, etc.) to achieve interoperability. | ||||||
|  |  | ||||||
|  | Through discussions and trials, we try to create a standard, made of common interfaces but also recommendations. | ||||||
|  |  | ||||||
|  | If PHP projects that provide container implementations begin to adopt these common standards, then PHP | ||||||
|  | applications and projects that use containers can depend on the common interfaces instead of specific | ||||||
|  | implementations. This facilitates a high-level of interoperability and flexibility that allows users to consume | ||||||
|  | *any* container implementation that can be adapted to these interfaces. | ||||||
|  |  | ||||||
|  | The work done in this project is not officially endorsed by the [PHP-FIG](http://www.php-fig.org/), but it is being | ||||||
|  | worked on by members of PHP-FIG and other good developers. We adhere to the spirit and ideals of PHP-FIG, and hope | ||||||
|  | this project will pave the way for one or more future PSRs. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## Installation | ||||||
|  |  | ||||||
|  | You can install this package through Composer: | ||||||
|  |  | ||||||
|  | ```json | ||||||
|  | composer require container-interop/container-interop | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | The packages adheres to the [SemVer](http://semver.org/) specification, and there will be full backward compatibility | ||||||
|  | between minor versions. | ||||||
|  |  | ||||||
|  | ## Standards | ||||||
|  |  | ||||||
|  | ### Available | ||||||
|  |  | ||||||
|  | - [`ContainerInterface`](src/Interop/Container/ContainerInterface.php). | ||||||
|  | [Description](docs/ContainerInterface.md) [Meta Document](docs/ContainerInterface-meta.md). | ||||||
|  | Describes the interface of a container that exposes methods to read its entries. | ||||||
|  | - [*Delegate lookup feature*](docs/Delegate-lookup.md). | ||||||
|  | [Meta Document](docs/Delegate-lookup-meta.md). | ||||||
|  | Describes the ability for a container to delegate the lookup of its dependencies to a third-party container. This | ||||||
|  | feature lets several containers work together in a single application. | ||||||
|  |  | ||||||
|  | ### Proposed | ||||||
|  |  | ||||||
|  | View open [request for comments](https://github.com/container-interop/container-interop/labels/RFC) | ||||||
|  |  | ||||||
|  | ## Compatible projects | ||||||
|  |  | ||||||
|  | ### Projects implementing `ContainerInterface` | ||||||
|  |  | ||||||
|  | - [Acclimate](https://github.com/jeremeamia/acclimate-container): Adapters for | ||||||
|  |   Aura.Di, Laravel, Nette DI, Pimple, Symfony DI, ZF2 Service manager, ZF2 | ||||||
|  |   Dependency injection and any container using `ArrayAccess` | ||||||
|  | - [Aura.Di](https://github.com/auraphp/Aura.Di) | ||||||
|  | - [auryn-container-interop](https://github.com/elazar/auryn-container-interop) | ||||||
|  | - [Burlap](https://github.com/codeeverything/burlap) | ||||||
|  | - [Chernozem](https://github.com/pyrsmk/Chernozem) | ||||||
|  | - [Data Manager](https://github.com/chrismichaels84/data-manager) | ||||||
|  | - [Disco](https://github.com/bitexpert/disco) | ||||||
|  | - [InDI](https://github.com/idealogica/indi) | ||||||
|  | - [League/Container](http://container.thephpleague.com/) | ||||||
|  | - [Mouf](http://mouf-php.com) | ||||||
|  | - [Njasm Container](https://github.com/njasm/container) | ||||||
|  | - [PHP-DI](http://php-di.org) | ||||||
|  | - [Picotainer](https://github.com/thecodingmachine/picotainer) | ||||||
|  | - [PimpleInterop](https://github.com/moufmouf/pimple-interop) | ||||||
|  | - [Pimple3-ContainerInterop](https://github.com/Sam-Burns/pimple3-containerinterop) (using Pimple v3) | ||||||
|  | - [SitePoint Container](https://github.com/sitepoint/Container) | ||||||
|  | - [Thruster Container](https://github.com/ThrusterIO/container) (PHP7 only) | ||||||
|  | - [Ultra-Lite Container](https://github.com/ultra-lite/container) | ||||||
|  | - [Unbox](https://github.com/mindplay-dk/unbox) | ||||||
|  | - [XStatic](https://github.com/jeremeamia/xstatic) | ||||||
|  | - [Zend\ServiceManager](https://github.com/zendframework/zend-servicemanager) | ||||||
|  | - [Zit](https://github.com/inxilpro/Zit) | ||||||
|  |  | ||||||
|  | ### Projects implementing the *delegate lookup* feature | ||||||
|  |  | ||||||
|  | - [Aura.Di](https://github.com/auraphp/Aura.Di) | ||||||
|  | - [Burlap](https://github.com/codeeverything/burlap) | ||||||
|  | - [Chernozem](https://github.com/pyrsmk/Chernozem) | ||||||
|  | - [InDI](https://github.com/idealogica/indi) | ||||||
|  | - [League/Container](http://container.thephpleague.com/) | ||||||
|  | - [Mouf](http://mouf-php.com) | ||||||
|  | - [Picotainer](https://github.com/thecodingmachine/picotainer) | ||||||
|  | - [PHP-DI](http://php-di.org) | ||||||
|  | - [PimpleInterop](https://github.com/moufmouf/pimple-interop) | ||||||
|  | - [Ultra-Lite Container](https://github.com/ultra-lite/container) | ||||||
|  |  | ||||||
|  | ### Middlewares implementing `ContainerInterface` | ||||||
|  |  | ||||||
|  | - [Alias-Container](https://github.com/thecodingmachine/alias-container): add | ||||||
|  |   aliases support to any container | ||||||
|  | - [Prefixer-Container](https://github.com/thecodingmachine/prefixer-container): | ||||||
|  |   dynamically prefix identifiers | ||||||
|  | - [Lazy-Container](https://github.com/snapshotpl/lazy-container): lazy services | ||||||
|  |  | ||||||
|  | ### Projects using `ContainerInterface` | ||||||
|  |  | ||||||
|  | The list below contains only a sample of all the projects consuming `ContainerInterface`. For a more complete list have a look [here](http://packanalyst.com/class?q=Interop%5CContainer%5CContainerInterface). | ||||||
|  |  | ||||||
|  | | | Downloads | | ||||||
|  | | --- | --- | | ||||||
|  | | [Adroit](https://github.com/bitexpert/adroit) |  | | ||||||
|  | | [Behat](https://github.com/Behat/Behat/pull/974) |  | | ||||||
|  | | [blast-facades](https://github.com/phpthinktank/blast-facades): Minimize complexity and represent dependencies as facades. |  | | ||||||
|  | | [interop.silex.di](https://github.com/thecodingmachine/interop.silex.di): an extension to [Silex](http://silex.sensiolabs.org/) that adds support for any *container-interop* compatible container |  | | ||||||
|  | | [mindplay/walkway](https://github.com/mindplay-dk/walkway): a modular request router |  | | ||||||
|  | | [mindplay/middleman](https://github.com/mindplay-dk/middleman): minimalist PSR-7 middleware dispatcher |  | | ||||||
|  | | [PHP-DI/Invoker](https://github.com/PHP-DI/Invoker): extensible and configurable invoker/dispatcher |  | | ||||||
|  | | [Prophiler](https://github.com/fabfuel/prophiler) |  | | ||||||
|  | | [Silly](https://github.com/mnapoli/silly): CLI micro-framework |  | | ||||||
|  | | [Slim v3](https://github.com/slimphp/Slim) |  | | ||||||
|  | | [Splash](http://mouf-php.com/packages/mouf/mvc.splash-common/version/8.0-dev/README.md) |  | | ||||||
|  | | [Woohoo Labs. Harmony](https://github.com/woohoolabs/harmony): a flexible micro-framework |  | | ||||||
|  | | [zend-expressive](https://github.com/zendframework/zend-expressive) |  | | ||||||
|  |  | ||||||
|  |  | ||||||
|  | ## Workflow | ||||||
|  |  | ||||||
|  | Everyone is welcome to join and contribute. | ||||||
|  |  | ||||||
|  | The general workflow looks like this: | ||||||
|  |  | ||||||
|  | 1. Someone opens a discussion (GitHub issue) to suggest an interface | ||||||
|  | 1. Feedback is gathered | ||||||
|  | 1. The interface is added to a development branch | ||||||
|  | 1. We release alpha versions so that the interface can be experimented with | ||||||
|  | 1. Discussions and edits ensue until the interface is deemed stable by a general consensus | ||||||
|  | 1. A new minor version of the package is released | ||||||
|  |  | ||||||
|  | We try to not break BC by creating new interfaces instead of editing existing ones. | ||||||
|  |  | ||||||
|  | While we currently work on interfaces, we are open to anything that might help towards interoperability, may that | ||||||
|  | be code, best practices, etc. | ||||||
							
								
								
									
										15
									
								
								vendor/container-interop/container-interop/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								vendor/container-interop/container-interop/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | { | ||||||
|  |     "name": "container-interop/container-interop", | ||||||
|  |     "type": "library", | ||||||
|  |     "description": "Promoting the interoperability of container objects (DIC, SL, etc.)", | ||||||
|  |     "homepage": "https://github.com/container-interop/container-interop", | ||||||
|  |     "license": "MIT", | ||||||
|  |     "autoload": { | ||||||
|  |         "psr-4": { | ||||||
|  |             "Interop\\Container\\": "src/Interop/Container/" | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     "require": { | ||||||
|  |         "psr/container": "^1.0" | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										114
									
								
								vendor/container-interop/container-interop/docs/ContainerInterface-meta.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										114
									
								
								vendor/container-interop/container-interop/docs/ContainerInterface-meta.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,114 @@ | |||||||
|  | # ContainerInterface Meta Document | ||||||
|  |  | ||||||
|  | ## Introduction | ||||||
|  |  | ||||||
|  | This document describes the process and discussions that lead to the `ContainerInterface`. | ||||||
|  | Its goal is to explain the reasons behind each decision. | ||||||
|  |  | ||||||
|  | ## Goal | ||||||
|  |  | ||||||
|  | The goal set by `ContainerInterface` is to standardize how frameworks and libraries make use of a | ||||||
|  | container to obtain objects and parameters. | ||||||
|  |  | ||||||
|  | By standardizing such a behavior, frameworks and libraries using the `ContainerInterface` | ||||||
|  | could work with any compatible container. | ||||||
|  | That would allow end users to choose their own container based on their own preferences. | ||||||
|  |  | ||||||
|  | It is important to distinguish the two usages of a container: | ||||||
|  |  | ||||||
|  | - configuring entries | ||||||
|  | - fetching entries | ||||||
|  |  | ||||||
|  | Most of the time, those two sides are not used by the same party. | ||||||
|  | While it is often end users who tend to configure entries, it is generally the framework that fetch | ||||||
|  | entries to build the application. | ||||||
|  |  | ||||||
|  | This is why this interface focuses only on how entries can be fetched from a container. | ||||||
|  |  | ||||||
|  | ## Interface name | ||||||
|  |  | ||||||
|  | The interface name has been thoroughly discussed and was decided by a vote. | ||||||
|  |  | ||||||
|  | The list of options considered with their respective votes are: | ||||||
|  |  | ||||||
|  | - `ContainerInterface`: +8 | ||||||
|  | - `ProviderInterface`: +2 | ||||||
|  | - `LocatorInterface`: 0 | ||||||
|  | - `ReadableContainerInterface`: -5 | ||||||
|  | - `ServiceLocatorInterface`: -6 | ||||||
|  | - `ObjectFactory`: -6 | ||||||
|  | - `ObjectStore`: -8 | ||||||
|  | - `ConsumerInterface`: -9 | ||||||
|  |  | ||||||
|  | [Full results of the vote](https://github.com/container-interop/container-interop/wiki/%231-interface-name:-Vote) | ||||||
|  |  | ||||||
|  | The complete discussion can be read in [the issue #1](https://github.com/container-interop/container-interop/issues/1). | ||||||
|  |  | ||||||
|  | ## Interface methods | ||||||
|  |  | ||||||
|  | The choice of which methods the interface would contain was made after a statistical analysis of existing containers. | ||||||
|  | The results of this analysis are available [in this document](https://gist.github.com/mnapoli/6159681). | ||||||
|  |  | ||||||
|  | The summary of the analysis showed that: | ||||||
|  |  | ||||||
|  | - all containers offer a method to get an entry by its id | ||||||
|  | - a large majority name such method `get()` | ||||||
|  | - for all containers, the `get()` method has 1 mandatory parameter of type string | ||||||
|  | - some containers have an optional additional argument for `get()`, but it doesn't have the same purpose between containers | ||||||
|  | - a large majority of the containers offer a method to test if it can return an entry by its id | ||||||
|  | - a majority name such method `has()` | ||||||
|  | - for all containers offering `has()`, the method has exactly 1 parameter of type string | ||||||
|  | - a large majority of the containers throw an exception rather than returning null when an entry is not found in `get()` | ||||||
|  | - a large majority of the containers don't implement `ArrayAccess` | ||||||
|  |  | ||||||
|  | The question of whether to include methods to define entries has been discussed in | ||||||
|  | [issue #1](https://github.com/container-interop/container-interop/issues/1). | ||||||
|  | It has been judged that such methods do not belong in the interface described here because it is out of its scope | ||||||
|  | (see the "Goal" section). | ||||||
|  |  | ||||||
|  | As a result, the `ContainerInterface` contains two methods: | ||||||
|  |  | ||||||
|  | - `get()`, returning anything, with one mandatory string parameter. Should throw an exception if the entry is not found. | ||||||
|  | - `has()`, returning a boolean, with one mandatory string parameter. | ||||||
|  |  | ||||||
|  | ### Number of parameters in `get()` method | ||||||
|  |  | ||||||
|  | While `ContainerInterface` only defines one mandatory parameter in `get()`, it is not incompatible with | ||||||
|  | existing containers that have additional optional parameters. PHP allows an implementation to offer more parameters | ||||||
|  | as long as they are optional, because the implementation *does* satisfy the interface. | ||||||
|  |  | ||||||
|  | This issue has been discussed in [issue #6](https://github.com/container-interop/container-interop/issues/6). | ||||||
|  |  | ||||||
|  | ### Type of the `$id` parameter | ||||||
|  |  | ||||||
|  | The type of the `$id` parameter in `get()` and `has()` has been discussed in | ||||||
|  | [issue #6](https://github.com/container-interop/container-interop/issues/6). | ||||||
|  | While `string` is used in all the containers that were analyzed, it was suggested that allowing | ||||||
|  | anything (such as objects) could allow containers to offer a more advanced query API. | ||||||
|  |  | ||||||
|  | An example given was to use the container as an object builder. The `$id` parameter would then be an | ||||||
|  | object that would describe how to create an instance. | ||||||
|  |  | ||||||
|  | The conclusion of the discussion was that this was beyond the scope of getting entries from a container without | ||||||
|  | knowing how the container provided them, and it was more fit for a factory. | ||||||
|  |  | ||||||
|  | ## Contributors | ||||||
|  |  | ||||||
|  | Are listed here all people that contributed in the discussions or votes, by alphabetical order: | ||||||
|  |  | ||||||
|  | - [Amy Stephen](https://github.com/AmyStephen) | ||||||
|  | - [David Négrier](https://github.com/moufmouf) | ||||||
|  | - [Don Gilbert](https://github.com/dongilbert) | ||||||
|  | - [Jason Judge](https://github.com/judgej) | ||||||
|  | - [Jeremy Lindblom](https://github.com/jeremeamia) | ||||||
|  | - [Marco Pivetta](https://github.com/Ocramius) | ||||||
|  | - [Matthieu Napoli](https://github.com/mnapoli) | ||||||
|  | - [Paul M. Jones](https://github.com/pmjones) | ||||||
|  | - [Stephan Hochdörfer](https://github.com/shochdoerfer) | ||||||
|  | - [Taylor Otwell](https://github.com/taylorotwell) | ||||||
|  |  | ||||||
|  | ## Relevant links | ||||||
|  |  | ||||||
|  | - [`ContainerInterface.php`](https://github.com/container-interop/container-interop/blob/master/src/Interop/Container/ContainerInterface.php) | ||||||
|  | - [List of all issues](https://github.com/container-interop/container-interop/issues?labels=ContainerInterface&milestone=&page=1&state=closed) | ||||||
|  | - [Vote for the interface name](https://github.com/container-interop/container-interop/wiki/%231-interface-name:-Vote) | ||||||
							
								
								
									
										158
									
								
								vendor/container-interop/container-interop/docs/ContainerInterface.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								vendor/container-interop/container-interop/docs/ContainerInterface.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,158 @@ | |||||||
|  | Container interface | ||||||
|  | =================== | ||||||
|  |  | ||||||
|  | This document describes a common interface for dependency injection containers. | ||||||
|  |  | ||||||
|  | The goal set by `ContainerInterface` is to standardize how frameworks and libraries make use of a | ||||||
|  | container to obtain objects and parameters (called *entries* in the rest of this document). | ||||||
|  |  | ||||||
|  | The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", | ||||||
|  | "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be | ||||||
|  | interpreted as described in [RFC 2119][]. | ||||||
|  |  | ||||||
|  | The word `implementor` in this document is to be interpreted as someone | ||||||
|  | implementing the `ContainerInterface` in a dependency injection-related library or framework. | ||||||
|  | Users of dependency injections containers (DIC) are referred to as `user`. | ||||||
|  |  | ||||||
|  | [RFC 2119]: http://tools.ietf.org/html/rfc2119 | ||||||
|  |  | ||||||
|  | 1. Specification | ||||||
|  | ----------------- | ||||||
|  |  | ||||||
|  | ### 1.1 Basics | ||||||
|  |  | ||||||
|  | - The `Interop\Container\ContainerInterface` exposes two methods : `get` and `has`. | ||||||
|  |  | ||||||
|  | - `get` takes one mandatory parameter: an entry identifier. It MUST be a string. | ||||||
|  |   A call to `get` can return anything (a *mixed* value), or throws an exception if the identifier | ||||||
|  |   is not known to the container. Two successive calls to `get` with the same | ||||||
|  |   identifier SHOULD return the same value. However, depending on the `implementor` | ||||||
|  |   design and/or `user` configuration, different values might be returned, so | ||||||
|  |   `user` SHOULD NOT rely on getting the same value on 2 successive calls. | ||||||
|  |   While `ContainerInterface` only defines one mandatory parameter in `get()`, implementations | ||||||
|  |   MAY accept additional optional parameters. | ||||||
|  |  | ||||||
|  | - `has` takes one unique parameter: an entry identifier. It MUST return `true` | ||||||
|  |   if an entry identifier is known to the container and `false` if it is not. | ||||||
|  |   `has($id)` returning true does not mean that `get($id)` will not throw an exception. | ||||||
|  |   It does however mean that `get($id)` will not throw a `NotFoundException`. | ||||||
|  |  | ||||||
|  | ### 1.2 Exceptions | ||||||
|  |  | ||||||
|  | Exceptions directly thrown by the container MUST implement the | ||||||
|  | [`Interop\Container\Exception\ContainerException`](../src/Interop/Container/Exception/ContainerException.php). | ||||||
|  |  | ||||||
|  | A call to the `get` method with a non-existing id SHOULD throw a | ||||||
|  | [`Interop\Container\Exception\NotFoundException`](../src/Interop/Container/Exception/NotFoundException.php). | ||||||
|  |  | ||||||
|  | ### 1.3 Additional features | ||||||
|  |  | ||||||
|  | This section describes additional features that MAY be added to a container. Containers are not | ||||||
|  | required to implement these features to respect the ContainerInterface. | ||||||
|  |  | ||||||
|  | #### 1.3.1 Delegate lookup feature | ||||||
|  |  | ||||||
|  | The goal of the *delegate lookup* feature is to allow several containers to share entries. | ||||||
|  | Containers implementing this feature can perform dependency lookups in other containers. | ||||||
|  |  | ||||||
|  | Containers implementing this feature will offer a greater lever of interoperability | ||||||
|  | with other containers. Implementation of this feature is therefore RECOMMENDED. | ||||||
|  |  | ||||||
|  | A container implementing this feature: | ||||||
|  |  | ||||||
|  | - MUST implement the `ContainerInterface` | ||||||
|  | - MUST provide a way to register a delegate container (using a constructor parameter, or a setter, | ||||||
|  |   or any possible way). The delegate container MUST implement the `ContainerInterface`. | ||||||
|  |  | ||||||
|  | When a container is configured to use a delegate container for dependencies: | ||||||
|  |  | ||||||
|  | - Calls to the `get` method should only return an entry if the entry is part of the container. | ||||||
|  |   If the entry is not part of the container, an exception should be thrown | ||||||
|  |   (as requested by the `ContainerInterface`). | ||||||
|  | - Calls to the `has` method should only return `true` if the entry is part of the container. | ||||||
|  |   If the entry is not part of the container, `false` should be returned. | ||||||
|  | - If the fetched entry has dependencies, **instead** of performing | ||||||
|  |   the dependency lookup in the container, the lookup is performed on the *delegate container*. | ||||||
|  |  | ||||||
|  | Important! By default, the lookup SHOULD be performed on the delegate container **only**, not on the container itself. | ||||||
|  |  | ||||||
|  | It is however allowed for containers to provide exception cases for special entries, and a way to lookup | ||||||
|  | into the same container (or another container) instead of the delegate container. | ||||||
|  |  | ||||||
|  | 2. Package | ||||||
|  | ---------- | ||||||
|  |  | ||||||
|  | The interfaces and classes described as well as relevant exception are provided as part of the | ||||||
|  | [container-interop/container-interop](https://packagist.org/packages/container-interop/container-interop) package. | ||||||
|  |  | ||||||
|  | 3. `Interop\Container\ContainerInterface` | ||||||
|  | ----------------------------------------- | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | <?php | ||||||
|  | namespace Interop\Container; | ||||||
|  |  | ||||||
|  | use Interop\Container\Exception\ContainerException; | ||||||
|  | use Interop\Container\Exception\NotFoundException; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Describes the interface of a container that exposes methods to read its entries. | ||||||
|  |  */ | ||||||
|  | interface ContainerInterface | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * Finds an entry of the container by its identifier and returns it. | ||||||
|  |      * | ||||||
|  |      * @param string $id Identifier of the entry to look for. | ||||||
|  |      * | ||||||
|  |      * @throws NotFoundException  No entry was found for this identifier. | ||||||
|  |      * @throws ContainerException Error while retrieving the entry. | ||||||
|  |      * | ||||||
|  |      * @return mixed Entry. | ||||||
|  |      */ | ||||||
|  |     public function get($id); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Returns true if the container can return an entry for the given identifier. | ||||||
|  |      * Returns false otherwise. | ||||||
|  |      * | ||||||
|  |      * `has($id)` returning true does not mean that `get($id)` will not throw an exception. | ||||||
|  |      * It does however mean that `get($id)` will not throw a `NotFoundException`. | ||||||
|  |      * | ||||||
|  |      * @param string $id Identifier of the entry to look for. | ||||||
|  |      * | ||||||
|  |      * @return boolean | ||||||
|  |      */ | ||||||
|  |     public function has($id); | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | 4. `Interop\Container\Exception\ContainerException` | ||||||
|  | --------------------------------------------------- | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | <?php | ||||||
|  | namespace Interop\Container\Exception; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Base interface representing a generic exception in a container. | ||||||
|  |  */ | ||||||
|  | interface ContainerException | ||||||
|  | { | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | 5. `Interop\Container\Exception\NotFoundException` | ||||||
|  | --------------------------------------------------- | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | <?php | ||||||
|  | namespace Interop\Container\Exception; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * No entry was found in the container. | ||||||
|  |  */ | ||||||
|  | interface NotFoundException extends ContainerException | ||||||
|  | { | ||||||
|  | } | ||||||
|  | ``` | ||||||
							
								
								
									
										259
									
								
								vendor/container-interop/container-interop/docs/Delegate-lookup-meta.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										259
									
								
								vendor/container-interop/container-interop/docs/Delegate-lookup-meta.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,259 @@ | |||||||
|  | Delegate lookup feature Meta Document | ||||||
|  | ===================================== | ||||||
|  |  | ||||||
|  | 1. Summary | ||||||
|  | ---------- | ||||||
|  |  | ||||||
|  | This document describes the *delegate lookup feature*. | ||||||
|  | Containers are not required to implement this feature to respect the `ContainerInterface`. | ||||||
|  | However, containers implementing this feature will offer a greater lever of interoperability | ||||||
|  | with other containers, allowing multiple containers to share entries in the same application. | ||||||
|  | Implementation of this feature is therefore recommanded. | ||||||
|  |  | ||||||
|  | 2. Why Bother? | ||||||
|  | -------------- | ||||||
|  |  | ||||||
|  | The [`ContainerInterface`](../src/Interop/Container/ContainerInterface.php) ([meta doc](ContainerInterface.md)) | ||||||
|  | standardizes how frameworks and libraries make use of a container to obtain objects and parameters. | ||||||
|  |  | ||||||
|  | By standardizing such a behavior, frameworks and libraries relying on the `ContainerInterface` | ||||||
|  | could work with any compatible container. | ||||||
|  | That would allow end users to choose their own container based on their own preferences. | ||||||
|  |  | ||||||
|  | The `ContainerInterface` is also enough if we want to have several containers side-by-side in the same | ||||||
|  | application. For instance, this is what the [CompositeContainer](https://github.com/jeremeamia/acclimate-container/blob/master/src/CompositeContainer.php)  | ||||||
|  | class of [Acclimate](https://github.com/jeremeamia/acclimate-container) is designed for: | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | However, an instance in container 1 cannot reference an instance in container 2. | ||||||
|  |  | ||||||
|  | It would be better if an instance of container 1 could reference an instance in container 2, | ||||||
|  | and the opposite should be true.  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | In the sample above, entry 1 in container 1 is referencing entry 3 in container 2. | ||||||
|  |  | ||||||
|  | 3. Scope | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | ### 3.1 Goals | ||||||
|  |  | ||||||
|  | The goal of the *delegate lookup* feature is to allow several containers to share entries. | ||||||
|  |  | ||||||
|  | 4. Approaches | ||||||
|  | ------------- | ||||||
|  |  | ||||||
|  | ### 4.1 Chosen Approach | ||||||
|  |  | ||||||
|  | Containers implementing this feature can perform dependency lookups in other containers. | ||||||
|  |  | ||||||
|  | A container implementing this feature: | ||||||
|  |  | ||||||
|  | - must implement the `ContainerInterface` | ||||||
|  | - must provide a way to register a *delegate container* (using a constructor parameter, or a setter, or any | ||||||
|  | possible way). The *delegate container* must implement the `ContainerInterface`. | ||||||
|  |  | ||||||
|  | When a *delegate container* is configured on a container: | ||||||
|  |  | ||||||
|  | - Calls to the `get` method should only return an entry if the entry is part of the container. | ||||||
|  | If the entry is not part of the container, an exception should be thrown (as required in the `ContainerInterface`). | ||||||
|  | - Calls to the `has` method should only return *true* if the entry is part of the container. | ||||||
|  | If the entry is not part of the container, *false* should be returned. | ||||||
|  |  - Finally, the important part: if the entry we are fetching has dependencies, | ||||||
|  | **instead** of perfoming the dependency lookup in the container, the lookup is performed on the *delegate container*. | ||||||
|  |  | ||||||
|  | Important! By default, the lookup should be performed on the delegate container **only**, not on the container itself. | ||||||
|  |  | ||||||
|  | It is however allowed for containers to provide exception cases for special entries, and a way to lookup into  | ||||||
|  | the same container (or another container) instead of the delegate container. | ||||||
|  |  | ||||||
|  | ### 4.2 Typical usage | ||||||
|  |  | ||||||
|  | The *delegate container* will usually be a composite container. A composite container is a container that | ||||||
|  | contains several other containers. When performing a lookup on a composite container, the inner containers are  | ||||||
|  | queried until one container returns an entry. | ||||||
|  | An inner container implementing the *delegate lookup feature* will return entries it contains, but if these | ||||||
|  | entries have dependencies, the dependencies lookup calls will be performed on the composite container, giving | ||||||
|  | a chance to all containers to answer. | ||||||
|  |  | ||||||
|  | Interestingly enough, the order in which containers are added in the composite container matters. Indeed, | ||||||
|  | the first containers to be added in the composite container can "override" the entries of containers with | ||||||
|  | lower priority. | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | In the example above, "container 2" contains a controller "myController" and the controller is referencing an  | ||||||
|  | "entityManager" entry. "Container 1" contains also an entry named "entityManager". | ||||||
|  | Without the *delegate lookup* feature, when requesting the "myController" instance to container 2, it would take  | ||||||
|  | in charge the instanciation of both entries. | ||||||
|  |  | ||||||
|  | However, using the *delegate lookup* feature, here is what happens when we ask the composite container for the  | ||||||
|  | "myController" instance: | ||||||
|  |  | ||||||
|  | - The composite container asks container 1 if if contains the "myController" instance. The answer is no. | ||||||
|  | - The composite container asks container 2 if if contains the "myController" instance. The answer is yes. | ||||||
|  | - The composite container performs a `get` call on container 2 for the "myController" instance. | ||||||
|  | - Container 2 sees that "myController" has a dependency on "entityManager". | ||||||
|  | - Container 2 delegates the lookup of "entityManager" to the composite container. | ||||||
|  | - The composite container asks container 1 if if contains the "entityManager" instance. The answer is yes. | ||||||
|  | - The composite container performs a `get` call on container 1 for the "entityManager" instance. | ||||||
|  |  | ||||||
|  | In the end, we get a controller instanciated by container 2 that references an entityManager instanciated | ||||||
|  | by container 1. | ||||||
|  |  | ||||||
|  | ### 4.3 Alternative: the fallback strategy | ||||||
|  |  | ||||||
|  | The first proposed approach we tried was to perform all the lookups in the "local" container, | ||||||
|  | and if a lookup fails in the container, to use the delegate container. In this scenario, the | ||||||
|  | delegate container is used in "fallback" mode. | ||||||
|  |  | ||||||
|  | This strategy has been described in @moufmouf blog post: http://mouf-php.com/container-interop-whats-next (solution 1). | ||||||
|  | It was also discussed [here](https://github.com/container-interop/container-interop/pull/8#issuecomment-33570697) and | ||||||
|  | [here](https://github.com/container-interop/container-interop/pull/20#issuecomment-56599631). | ||||||
|  |  | ||||||
|  | Problems with this strategy: | ||||||
|  |  | ||||||
|  | - Heavy problem regarding infinite loops | ||||||
|  | - Unable to overload a container entry with the delegate container entry | ||||||
|  |  | ||||||
|  | ### 4.4 Alternative: force implementing an interface | ||||||
|  |  | ||||||
|  | The first proposed approach was to develop a `ParentAwareContainerInterface` interface. | ||||||
|  | It was proposed here: https://github.com/container-interop/container-interop/pull/8 | ||||||
|  |  | ||||||
|  | The interface would have had the behaviour of the delegate lookup feature but would have forced the addition of | ||||||
|  | a `setParentContainter` method: | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | interface ParentAwareContainerInterface extends ReadableContainerInterface { | ||||||
|  |     /** | ||||||
|  |      * Sets the parent container associated to that container. This container will call | ||||||
|  |      * the parent container to fetch dependencies. | ||||||
|  |      * | ||||||
|  |      * @param ContainerInterface $container | ||||||
|  |      */ | ||||||
|  |     public function setParentContainer(ContainerInterface $container); | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | The interface idea was first questioned by @Ocramius [here](https://github.com/container-interop/container-interop/pull/8#issuecomment-51721777). | ||||||
|  | @Ocramius expressed the idea that an interface should not contain setters, otherwise, it is forcing implementation | ||||||
|  | details on the class implementing the interface.  | ||||||
|  | Then @mnapoli made a proposal for a "convention" [here](https://github.com/container-interop/container-interop/pull/8#issuecomment-51841079), | ||||||
|  | this idea was further discussed until all participants in the discussion agreed to remove the interface idea | ||||||
|  | and replace it with a "standard" feature. | ||||||
|  |  | ||||||
|  | **Pros:** | ||||||
|  |  | ||||||
|  | If we had had an interface, we could have delegated the registration of the delegate/composite container to the | ||||||
|  | the delegate/composite container itself. | ||||||
|  | For instance: | ||||||
|  |  | ||||||
|  | ```php | ||||||
|  | $containerA = new ContainerA(); | ||||||
|  | $containerB = new ContainerB(); | ||||||
|  |  | ||||||
|  | $compositeContainer = new CompositeContainer([$containerA, $containerB]); | ||||||
|  |  | ||||||
|  | // The call to 'setParentContainer' is delegated to the CompositeContainer | ||||||
|  | // It is not the responsibility of the user anymore. | ||||||
|  | class CompositeContainer { | ||||||
|  | 	... | ||||||
|  | 	 | ||||||
|  | 	public function __construct($containers) { | ||||||
|  | 		foreach ($containers as $container) { | ||||||
|  | 			if ($container instanceof ParentAwareContainerInterface) { | ||||||
|  | 				$container->setParentContainer($this); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		... | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | ```  | ||||||
|  |  | ||||||
|  | **Cons:** | ||||||
|  |  | ||||||
|  | Cons have been extensively discussed [here](https://github.com/container-interop/container-interop/pull/8#issuecomment-51721777). | ||||||
|  | Basically, forcing a setter into an interface is a bad idea. Setters are similar to constructor arguments, | ||||||
|  | and it's a bad idea to standardize a constructor: how the delegate container is configured into a container is an implementation detail. This outweights the benefits of the interface. | ||||||
|  |  | ||||||
|  | ### 4.4 Alternative: no exception case for delegate lookups | ||||||
|  |  | ||||||
|  | Originally, the proposed wording for delegate lookup calls was: | ||||||
|  |  | ||||||
|  | > Important! The lookup MUST be performed on the delegate container **only**, not on the container itself. | ||||||
|  |  | ||||||
|  | This was later replaced by: | ||||||
|  |  | ||||||
|  | > Important! By default, the lookup SHOULD be performed on the delegate container **only**, not on the container itself. | ||||||
|  | > | ||||||
|  | > It is however allowed for containers to provide exception cases for special entries, and a way to lookup  | ||||||
|  | > into the same container (or another container) instead of the delegate container. | ||||||
|  |  | ||||||
|  | Exception cases have been allowed to avoid breaking dependencies with some services that must be provided | ||||||
|  | by the container (on @njasm proposal). This was proposed here: https://github.com/container-interop/container-interop/pull/20#issuecomment-56597235 | ||||||
|  |  | ||||||
|  | ### 4.5 Alternative: having one of the containers act as the composite container | ||||||
|  |  | ||||||
|  | In real-life scenarios, we usually have a big framework (Symfony 2, Zend Framework 2, etc...) and we want to | ||||||
|  | add another DI container to this container. Most of the time, the "big" framework will be responsible for | ||||||
|  | creating the controller's instances, using it's own DI container. Until *container-interop* is fully adopted, | ||||||
|  | the "big" framework will not be aware of the existence of a composite container that it should use instead | ||||||
|  | of its own container. | ||||||
|  |  | ||||||
|  | For this real-life use cases, @mnapoli and @moufmouf proposed to extend the "big" framework's DI container | ||||||
|  | to make it act as a composite container. | ||||||
|  |  | ||||||
|  | This has been discussed [here](https://github.com/container-interop/container-interop/pull/8#issuecomment-40367194)  | ||||||
|  | and [here](http://mouf-php.com/container-interop-whats-next#solution4). | ||||||
|  |  | ||||||
|  | This was implemented in Symfony 2 using: | ||||||
|  |  | ||||||
|  | - [interop.symfony.di](https://github.com/thecodingmachine/interop.symfony.di/tree/v0.1.0) | ||||||
|  | - [framework interop](https://github.com/mnapoli/framework-interop/) | ||||||
|  |  | ||||||
|  | This was implemented in Silex using: | ||||||
|  |  | ||||||
|  | - [interop.silex.di](https://github.com/thecodingmachine/interop.silex.di) | ||||||
|  |  | ||||||
|  | Having a container act as the composite container is not part of the delegate lookup standard because it is | ||||||
|  | simply a temporary design pattern used to make existing frameworks that do not support yet ContainerInterop | ||||||
|  | play nice with other DI containers. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 5. Implementations | ||||||
|  | ------------------ | ||||||
|  |  | ||||||
|  | The following projects already implement the delegate lookup feature: | ||||||
|  |  | ||||||
|  | - [Mouf](http://mouf-php.com), through the [`setDelegateLookupContainer` method](https://github.com/thecodingmachine/mouf/blob/2.0/src/Mouf/MoufManager.php#L2120) | ||||||
|  | - [PHP-DI](http://php-di.org/), through the [`$wrapperContainer` parameter of the constructor](https://github.com/mnapoli/PHP-DI/blob/master/src/DI/Container.php#L72) | ||||||
|  | - [pimple-interop](https://github.com/moufmouf/pimple-interop), through the [`$container` parameter of the constructor](https://github.com/moufmouf/pimple-interop/blob/master/src/Interop/Container/Pimple/PimpleInterop.php#L62) | ||||||
|  |  | ||||||
|  | 6. People | ||||||
|  | --------- | ||||||
|  |  | ||||||
|  | Are listed here all people that contributed in the discussions, by alphabetical order: | ||||||
|  |  | ||||||
|  | - [Alexandru Pătrănescu](https://github.com/drealecs) | ||||||
|  | - [Ben Peachey](https://github.com/potherca) | ||||||
|  | - [David Négrier](https://github.com/moufmouf) | ||||||
|  | - [Jeremy Lindblom](https://github.com/jeremeamia) | ||||||
|  | - [Marco Pivetta](https://github.com/Ocramius) | ||||||
|  | - [Matthieu Napoli](https://github.com/mnapoli) | ||||||
|  | - [Nelson J Morais](https://github.com/njasm) | ||||||
|  | - [Phil Sturgeon](https://github.com/philsturgeon) | ||||||
|  | - [Stephan Hochdörfer](https://github.com/shochdoerfer) | ||||||
|  |  | ||||||
|  | 7. Relevant Links | ||||||
|  | ----------------- | ||||||
|  |  | ||||||
|  | _**Note:** Order descending chronologically._ | ||||||
|  |  | ||||||
|  | - [Pull request on the delegate lookup feature](https://github.com/container-interop/container-interop/pull/20) | ||||||
|  | - [Pull request on the interface idea](https://github.com/container-interop/container-interop/pull/8) | ||||||
|  | - [Original article exposing the delegate lookup idea along many others](http://mouf-php.com/container-interop-whats-next) | ||||||
|  |  | ||||||
							
								
								
									
										60
									
								
								vendor/container-interop/container-interop/docs/Delegate-lookup.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								vendor/container-interop/container-interop/docs/Delegate-lookup.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | |||||||
|  | Delegate lookup feature | ||||||
|  | ======================= | ||||||
|  |  | ||||||
|  | This document describes a standard for dependency injection containers. | ||||||
|  |  | ||||||
|  | The goal set by the *delegate lookup* feature is to allow several containers to share entries. | ||||||
|  | Containers implementing this feature can perform dependency lookups in other containers. | ||||||
|  |  | ||||||
|  | Containers implementing this feature will offer a greater lever of interoperability | ||||||
|  | with other containers. Implementation of this feature is therefore RECOMMENDED. | ||||||
|  |  | ||||||
|  | The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", | ||||||
|  | "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be | ||||||
|  | interpreted as described in [RFC 2119][]. | ||||||
|  |  | ||||||
|  | The word `implementor` in this document is to be interpreted as someone | ||||||
|  | implementing the delegate lookup feature in a dependency injection-related library or framework. | ||||||
|  | Users of dependency injections containers (DIC) are referred to as `user`. | ||||||
|  |  | ||||||
|  | [RFC 2119]: http://tools.ietf.org/html/rfc2119 | ||||||
|  |  | ||||||
|  | 1. Vocabulary | ||||||
|  | ------------- | ||||||
|  |  | ||||||
|  | In a dependency injection container, the container is used to fetch entries. | ||||||
|  | Entries can have dependencies on other entries. Usually, these other entries are fetched by the container. | ||||||
|  |  | ||||||
|  | The *delegate lookup* feature is the ability for a container to fetch dependencies in | ||||||
|  | another container. In the rest of the document, the word "container" will reference the container | ||||||
|  | implemented by the implementor. The word "delegate container" will reference the container we are | ||||||
|  | fetching the dependencies from. | ||||||
|  |  | ||||||
|  | 2. Specification | ||||||
|  | ---------------- | ||||||
|  |  | ||||||
|  | A container implementing the *delegate lookup* feature: | ||||||
|  |  | ||||||
|  | - MUST implement the [`ContainerInterface`](ContainerInterface.md) | ||||||
|  | - MUST provide a way to register a delegate container (using a constructor parameter, or a setter, | ||||||
|  |   or any possible way). The delegate container MUST implement the [`ContainerInterface`](ContainerInterface.md). | ||||||
|  |  | ||||||
|  | When a container is configured to use a delegate container for dependencies: | ||||||
|  |  | ||||||
|  | - Calls to the `get` method should only return an entry if the entry is part of the container. | ||||||
|  |   If the entry is not part of the container, an exception should be thrown | ||||||
|  |   (as requested by the [`ContainerInterface`](ContainerInterface.md)). | ||||||
|  | - Calls to the `has` method should only return `true` if the entry is part of the container. | ||||||
|  |   If the entry is not part of the container, `false` should be returned. | ||||||
|  | - If the fetched entry has dependencies, **instead** of performing | ||||||
|  |   the dependency lookup in the container, the lookup is performed on the *delegate container*. | ||||||
|  |  | ||||||
|  | Important: By default, the dependency lookups SHOULD be performed on the delegate container **only**, not on the container itself. | ||||||
|  |  | ||||||
|  | It is however allowed for containers to provide exception cases for special entries, and a way to lookup | ||||||
|  | into the same container (or another container) instead of the delegate container. | ||||||
|  |  | ||||||
|  | 3. Package / Interface | ||||||
|  | ---------------------- | ||||||
|  |  | ||||||
|  | This feature is not tied to any code, interface or package. | ||||||
							
								
								
									
										
											BIN
										
									
								
								vendor/container-interop/container-interop/docs/images/interoperating_containers.png
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								vendor/container-interop/container-interop/docs/images/interoperating_containers.png
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 25 KiB | 
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user