init
This commit is contained in:
23
vendor/bin/carbon
vendored
Executable file
23
vendor/bin/carbon
vendored
Executable file
@@ -0,0 +1,23 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
use Carbon\Cli\Invoker;
|
||||
|
||||
$dir = __DIR__.'/..';
|
||||
|
||||
if (!file_exists($dir.'/autoload.php')) {
|
||||
$dir = __DIR__.'/../vendor';
|
||||
}
|
||||
|
||||
if (!file_exists($dir.'/autoload.php')) {
|
||||
$dir = __DIR__.'/../../..';
|
||||
}
|
||||
|
||||
if (!file_exists($dir.'/autoload.php')) {
|
||||
echo 'Autoload not found.';
|
||||
exit(1);
|
||||
}
|
||||
|
||||
require $dir.'/autoload.php';
|
||||
|
||||
exit((new Invoker())(...$argv) ? 0 : 1);
|
||||
94
vendor/bin/patch-type-declarations
vendored
Executable file
94
vendor/bin/patch-type-declarations
vendored
Executable file
@@ -0,0 +1,94 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (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.
|
||||
*/
|
||||
|
||||
if (\in_array('-h', $argv) || \in_array('--help', $argv)) {
|
||||
echo implode(PHP_EOL, [
|
||||
' Patches type declarations based on "@return" PHPDoc and triggers deprecations for',
|
||||
' incompatible method declarations.',
|
||||
'',
|
||||
' This assists you to make your package compatible with Symfony 6, but it can be used',
|
||||
' for any class/package.',
|
||||
'',
|
||||
' Available configuration via environment variables:',
|
||||
' SYMFONY_PATCH_TYPE_DECLARATIONS',
|
||||
' An url-encoded string to change the behavior of the script. Available parameters:',
|
||||
' - "force": any value enables deprecation notices - can be any of:',
|
||||
' - "phpdoc" to patch only docblock annotations',
|
||||
' - "2" to add all possible return types',
|
||||
' - "1" to add return types but only to tests/final/internal/private methods',
|
||||
' - "php": the target version of PHP - e.g. "7.1" doesn\'t generate "object" types',
|
||||
' - "deprecations": "1" to trigger a deprecation notice when a child class misses a',
|
||||
' return type while the parent declares an "@return" annotation',
|
||||
'',
|
||||
' SYMFONY_PATCH_TYPE_EXCLUDE',
|
||||
' A regex matched against the full path to the class - any match will be excluded',
|
||||
'',
|
||||
' Example: "SYMFONY_PATCH_TYPE_DECLARATIONS=php=7.4 ./patch-type-declarations"',
|
||||
]);
|
||||
exit;
|
||||
}
|
||||
|
||||
if (false === getenv('SYMFONY_PATCH_TYPE_DECLARATIONS')) {
|
||||
putenv('SYMFONY_PATCH_TYPE_DECLARATIONS=force=2');
|
||||
echo 'No SYMFONY_PATCH_TYPE_DECLARATIONS env var set, patching type declarations in all methods (run the command with "-h" for more information).'.PHP_EOL;
|
||||
}
|
||||
|
||||
if (is_file($autoload = __DIR__.'/../../../../autoload.php')) {
|
||||
// noop
|
||||
} elseif (is_file($autoload = __DIR__.'/../../../../../../../autoload.php')) {
|
||||
// noop
|
||||
} else {
|
||||
echo PHP_EOL.' /!\ Cannot find the Composer autoloader, did you forget to run "composer install"?'.PHP_EOL;
|
||||
exit(1);
|
||||
}
|
||||
|
||||
if (is_file($phpunitAutoload = dirname($autoload).'/bin/.phpunit/phpunit/vendor/autoload.php')) {
|
||||
require $phpunitAutoload;
|
||||
}
|
||||
|
||||
$loader = require $autoload;
|
||||
|
||||
Symfony\Component\ErrorHandler\DebugClassLoader::enable();
|
||||
|
||||
$deprecations = [];
|
||||
set_error_handler(function ($type, $msg, $file, $line, $context = []) use (&$deprecations) {
|
||||
if (\E_USER_DEPRECATED !== $type) {
|
||||
return;
|
||||
}
|
||||
|
||||
[,,,,, $class,] = explode('"', $msg);
|
||||
$deprecations[$class][] = $msg;
|
||||
});
|
||||
|
||||
$exclude = getenv('SYMFONY_PATCH_TYPE_EXCLUDE') ?: null;
|
||||
foreach ($loader->getClassMap() as $class => $file) {
|
||||
if (str_contains($file = realpath($file), \DIRECTORY_SEPARATOR.'vendor'.\DIRECTORY_SEPARATOR)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if ($exclude && preg_match($exclude, $file)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
class_exists($class);
|
||||
}
|
||||
|
||||
Symfony\Component\ErrorHandler\DebugClassLoader::checkClasses();
|
||||
|
||||
foreach ($deprecations as $class => $classDeprecations) {
|
||||
echo $class.' ('.\count($classDeprecations).')'.PHP_EOL;
|
||||
echo implode(PHP_EOL, $classDeprecations).PHP_EOL.PHP_EOL;
|
||||
}
|
||||
|
||||
if ($deprecations && str_contains(getenv('SYMFONY_PATCH_TYPE_DECLARATIONS') ?? '', 'force')) {
|
||||
echo 'These deprecations might be fixed by the patch script, run this again to check for type deprecations.'.PHP_EOL;
|
||||
}
|
||||
205
vendor/bin/php-parse
vendored
Executable file
205
vendor/bin/php-parse
vendored
Executable file
@@ -0,0 +1,205 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
foreach ([__DIR__ . '/../../../autoload.php', __DIR__ . '/../vendor/autoload.php'] as $file) {
|
||||
if (file_exists($file)) {
|
||||
require $file;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
ini_set('xdebug.max_nesting_level', 3000);
|
||||
|
||||
// Disable Xdebug var_dump() output truncation
|
||||
ini_set('xdebug.var_display_max_children', -1);
|
||||
ini_set('xdebug.var_display_max_data', -1);
|
||||
ini_set('xdebug.var_display_max_depth', -1);
|
||||
|
||||
list($operations, $files, $attributes) = parseArgs($argv);
|
||||
|
||||
/* Dump nodes by default */
|
||||
if (empty($operations)) {
|
||||
$operations[] = 'dump';
|
||||
}
|
||||
|
||||
if (empty($files)) {
|
||||
showHelp("Must specify at least one file.");
|
||||
}
|
||||
|
||||
$lexer = new PhpParser\Lexer\Emulative(['usedAttributes' => [
|
||||
'startLine', 'endLine', 'startFilePos', 'endFilePos', 'comments'
|
||||
]]);
|
||||
$parser = (new PhpParser\ParserFactory)->create(
|
||||
PhpParser\ParserFactory::PREFER_PHP7,
|
||||
$lexer
|
||||
);
|
||||
$dumper = new PhpParser\NodeDumper([
|
||||
'dumpComments' => true,
|
||||
'dumpPositions' => $attributes['with-positions'],
|
||||
]);
|
||||
$prettyPrinter = new PhpParser\PrettyPrinter\Standard;
|
||||
|
||||
$traverser = new PhpParser\NodeTraverser();
|
||||
$traverser->addVisitor(new PhpParser\NodeVisitor\NameResolver);
|
||||
|
||||
foreach ($files as $file) {
|
||||
if (strpos($file, '<?php') === 0) {
|
||||
$code = $file;
|
||||
fwrite(STDERR, "====> Code $code\n");
|
||||
} else {
|
||||
if (!file_exists($file)) {
|
||||
fwrite(STDERR, "File $file does not exist.\n");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
$code = file_get_contents($file);
|
||||
fwrite(STDERR, "====> File $file:\n");
|
||||
}
|
||||
|
||||
if ($attributes['with-recovery']) {
|
||||
$errorHandler = new PhpParser\ErrorHandler\Collecting;
|
||||
$stmts = $parser->parse($code, $errorHandler);
|
||||
foreach ($errorHandler->getErrors() as $error) {
|
||||
$message = formatErrorMessage($error, $code, $attributes['with-column-info']);
|
||||
fwrite(STDERR, $message . "\n");
|
||||
}
|
||||
if (null === $stmts) {
|
||||
continue;
|
||||
}
|
||||
} else {
|
||||
try {
|
||||
$stmts = $parser->parse($code);
|
||||
} catch (PhpParser\Error $error) {
|
||||
$message = formatErrorMessage($error, $code, $attributes['with-column-info']);
|
||||
fwrite(STDERR, $message . "\n");
|
||||
exit(1);
|
||||
}
|
||||
}
|
||||
|
||||
foreach ($operations as $operation) {
|
||||
if ('dump' === $operation) {
|
||||
fwrite(STDERR, "==> Node dump:\n");
|
||||
echo $dumper->dump($stmts, $code), "\n";
|
||||
} elseif ('pretty-print' === $operation) {
|
||||
fwrite(STDERR, "==> Pretty print:\n");
|
||||
echo $prettyPrinter->prettyPrintFile($stmts), "\n";
|
||||
} elseif ('json-dump' === $operation) {
|
||||
fwrite(STDERR, "==> JSON dump:\n");
|
||||
echo json_encode($stmts, JSON_PRETTY_PRINT), "\n";
|
||||
} elseif ('var-dump' === $operation) {
|
||||
fwrite(STDERR, "==> var_dump():\n");
|
||||
var_dump($stmts);
|
||||
} elseif ('resolve-names' === $operation) {
|
||||
fwrite(STDERR, "==> Resolved names.\n");
|
||||
$stmts = $traverser->traverse($stmts);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function formatErrorMessage(PhpParser\Error $e, $code, $withColumnInfo) {
|
||||
if ($withColumnInfo && $e->hasColumnInfo()) {
|
||||
return $e->getMessageWithColumnInfo($code);
|
||||
} else {
|
||||
return $e->getMessage();
|
||||
}
|
||||
}
|
||||
|
||||
function showHelp($error = '') {
|
||||
if ($error) {
|
||||
fwrite(STDERR, $error . "\n\n");
|
||||
}
|
||||
fwrite($error ? STDERR : STDOUT, <<<OUTPUT
|
||||
Usage: php-parse [operations] file1.php [file2.php ...]
|
||||
or: php-parse [operations] "<?php code"
|
||||
Turn PHP source code into an abstract syntax tree.
|
||||
|
||||
Operations is a list of the following options (--dump by default):
|
||||
|
||||
-d, --dump Dump nodes using NodeDumper
|
||||
-p, --pretty-print Pretty print file using PrettyPrinter\Standard
|
||||
-j, --json-dump Print json_encode() result
|
||||
--var-dump var_dump() nodes (for exact structure)
|
||||
-N, --resolve-names Resolve names using NodeVisitor\NameResolver
|
||||
-c, --with-column-info Show column-numbers for errors (if available)
|
||||
-P, --with-positions Show positions in node dumps
|
||||
-r, --with-recovery Use parsing with error recovery
|
||||
-h, --help Display this page
|
||||
|
||||
Example:
|
||||
php-parse -d -p -N -d file.php
|
||||
|
||||
Dumps nodes, pretty prints them, then resolves names and dumps them again.
|
||||
|
||||
|
||||
OUTPUT
|
||||
);
|
||||
exit($error ? 1 : 0);
|
||||
}
|
||||
|
||||
function parseArgs($args) {
|
||||
$operations = [];
|
||||
$files = [];
|
||||
$attributes = [
|
||||
'with-column-info' => false,
|
||||
'with-positions' => false,
|
||||
'with-recovery' => false,
|
||||
];
|
||||
|
||||
array_shift($args);
|
||||
$parseOptions = true;
|
||||
foreach ($args as $arg) {
|
||||
if (!$parseOptions) {
|
||||
$files[] = $arg;
|
||||
continue;
|
||||
}
|
||||
|
||||
switch ($arg) {
|
||||
case '--dump':
|
||||
case '-d':
|
||||
$operations[] = 'dump';
|
||||
break;
|
||||
case '--pretty-print':
|
||||
case '-p':
|
||||
$operations[] = 'pretty-print';
|
||||
break;
|
||||
case '--json-dump':
|
||||
case '-j':
|
||||
$operations[] = 'json-dump';
|
||||
break;
|
||||
case '--var-dump':
|
||||
$operations[] = 'var-dump';
|
||||
break;
|
||||
case '--resolve-names':
|
||||
case '-N';
|
||||
$operations[] = 'resolve-names';
|
||||
break;
|
||||
case '--with-column-info':
|
||||
case '-c';
|
||||
$attributes['with-column-info'] = true;
|
||||
break;
|
||||
case '--with-positions':
|
||||
case '-P':
|
||||
$attributes['with-positions'] = true;
|
||||
break;
|
||||
case '--with-recovery':
|
||||
case '-r':
|
||||
$attributes['with-recovery'] = true;
|
||||
break;
|
||||
case '--help':
|
||||
case '-h';
|
||||
showHelp();
|
||||
break;
|
||||
case '--':
|
||||
$parseOptions = false;
|
||||
break;
|
||||
default:
|
||||
if ($arg[0] === '-') {
|
||||
showHelp("Invalid operation $arg.");
|
||||
} else {
|
||||
$files[] = $arg;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return [$operations, $files, $attributes];
|
||||
}
|
||||
98
vendor/bin/phpunit
vendored
Executable file
98
vendor/bin/phpunit
vendored
Executable file
@@ -0,0 +1,98 @@
|
||||
#!/usr/bin/env php
|
||||
<?php declare(strict_types=1);
|
||||
/*
|
||||
* This file is part of PHPUnit.
|
||||
*
|
||||
* (c) Sebastian Bergmann <sebastian@phpunit.de>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
if (!version_compare(PHP_VERSION, PHP_VERSION, '=')) {
|
||||
fwrite(
|
||||
STDERR,
|
||||
sprintf(
|
||||
'%s declares an invalid value for PHP_VERSION.' . PHP_EOL .
|
||||
'This breaks fundamental functionality such as version_compare().' . PHP_EOL .
|
||||
'Please use a different PHP interpreter.' . PHP_EOL,
|
||||
|
||||
PHP_BINARY
|
||||
)
|
||||
);
|
||||
|
||||
die(1);
|
||||
}
|
||||
|
||||
if (version_compare('7.3.0', PHP_VERSION, '>')) {
|
||||
fwrite(
|
||||
STDERR,
|
||||
sprintf(
|
||||
'This version of PHPUnit requires PHP >= 7.3.' . PHP_EOL .
|
||||
'You are using PHP %s (%s).' . PHP_EOL,
|
||||
PHP_VERSION,
|
||||
PHP_BINARY
|
||||
)
|
||||
);
|
||||
|
||||
die(1);
|
||||
}
|
||||
|
||||
foreach (['dom', 'json', 'libxml', 'mbstring', 'tokenizer', 'xml', 'xmlwriter'] as $extension) {
|
||||
if (extension_loaded($extension)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
fwrite(
|
||||
STDERR,
|
||||
sprintf(
|
||||
'PHPUnit requires the "%s" extension.' . PHP_EOL,
|
||||
$extension
|
||||
)
|
||||
);
|
||||
|
||||
die(1);
|
||||
}
|
||||
|
||||
if (!ini_get('date.timezone')) {
|
||||
ini_set('date.timezone', 'UTC');
|
||||
}
|
||||
|
||||
if (isset($GLOBALS['_composer_autoload_path'])) {
|
||||
define('PHPUNIT_COMPOSER_INSTALL', $GLOBALS['_composer_autoload_path']);
|
||||
|
||||
unset($GLOBALS['_composer_autoload_path']);
|
||||
} else {
|
||||
foreach (array(__DIR__ . '/../../autoload.php', __DIR__ . '/../vendor/autoload.php', __DIR__ . '/vendor/autoload.php') as $file) {
|
||||
if (file_exists($file)) {
|
||||
define('PHPUNIT_COMPOSER_INSTALL', $file);
|
||||
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
unset($file);
|
||||
}
|
||||
|
||||
if (!defined('PHPUNIT_COMPOSER_INSTALL')) {
|
||||
fwrite(
|
||||
STDERR,
|
||||
'You need to set up the project dependencies using Composer:' . PHP_EOL . PHP_EOL .
|
||||
' composer install' . PHP_EOL . PHP_EOL .
|
||||
'You can learn all about Composer on https://getcomposer.org/.' . PHP_EOL
|
||||
);
|
||||
|
||||
die(1);
|
||||
}
|
||||
|
||||
$options = getopt('', array('prepend:'));
|
||||
|
||||
if (isset($options['prepend'])) {
|
||||
require $options['prepend'];
|
||||
}
|
||||
|
||||
unset($options);
|
||||
|
||||
require PHPUNIT_COMPOSER_INSTALL;
|
||||
|
||||
PHPUnit\TextUI\Command::main();
|
||||
BIN
vendor/bin/pint
vendored
Executable file
BIN
vendor/bin/pint
vendored
Executable file
Binary file not shown.
148
vendor/bin/psysh
vendored
Executable file
148
vendor/bin/psysh
vendored
Executable file
@@ -0,0 +1,148 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of Psy Shell.
|
||||
*
|
||||
* (c) 2012-2022 Justin Hileman
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
// Try to find an autoloader for a local psysh version.
|
||||
// We'll wrap this whole mess in a Closure so it doesn't leak any globals.
|
||||
call_user_func(function () {
|
||||
$cwd = null;
|
||||
|
||||
// Find the cwd arg (if present)
|
||||
$argv = isset($_SERVER['argv']) ? $_SERVER['argv'] : array();
|
||||
foreach ($argv as $i => $arg) {
|
||||
if ($arg === '--cwd') {
|
||||
if ($i >= count($argv) - 1) {
|
||||
fwrite(STDERR, 'Missing --cwd argument.' . PHP_EOL);
|
||||
exit(1);
|
||||
}
|
||||
$cwd = $argv[$i + 1];
|
||||
break;
|
||||
}
|
||||
|
||||
if (preg_match('/^--cwd=/', $arg)) {
|
||||
$cwd = substr($arg, 6);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Or fall back to the actual cwd
|
||||
if (!isset($cwd)) {
|
||||
$cwd = getcwd();
|
||||
}
|
||||
|
||||
$cwd = str_replace('\\', '/', $cwd);
|
||||
|
||||
$chunks = explode('/', $cwd);
|
||||
while (!empty($chunks)) {
|
||||
$path = implode('/', $chunks);
|
||||
$prettyPath = $path;
|
||||
if (isset($_SERVER['HOME']) && $_SERVER['HOME']) {
|
||||
$prettyPath = preg_replace('/^' . preg_quote($_SERVER['HOME'], '/') . '/', '~', $path);
|
||||
}
|
||||
|
||||
// Find composer.json
|
||||
if (is_file($path . '/composer.json')) {
|
||||
if ($cfg = json_decode(file_get_contents($path . '/composer.json'), true)) {
|
||||
if (isset($cfg['name']) && $cfg['name'] === 'psy/psysh') {
|
||||
// We're inside the psysh project. Let's use the local Composer autoload.
|
||||
if (is_file($path . '/vendor/autoload.php')) {
|
||||
if (realpath($path) !== realpath(__DIR__ . '/..')) {
|
||||
fwrite(STDERR, 'Using local PsySH version at ' . $prettyPath . PHP_EOL);
|
||||
}
|
||||
|
||||
require $path . '/vendor/autoload.php';
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Or a composer.lock
|
||||
if (is_file($path . '/composer.lock')) {
|
||||
if ($cfg = json_decode(file_get_contents($path . '/composer.lock'), true)) {
|
||||
foreach (array_merge($cfg['packages'], $cfg['packages-dev']) as $pkg) {
|
||||
if (isset($pkg['name']) && $pkg['name'] === 'psy/psysh') {
|
||||
// We're inside a project which requires psysh. We'll use the local Composer autoload.
|
||||
if (is_file($path . '/vendor/autoload.php')) {
|
||||
if (realpath($path . '/vendor') !== realpath(__DIR__ . '/../../..')) {
|
||||
fwrite(STDERR, 'Using local PsySH version at ' . $prettyPath . PHP_EOL);
|
||||
}
|
||||
|
||||
require $path . '/vendor/autoload.php';
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
array_pop($chunks);
|
||||
}
|
||||
});
|
||||
|
||||
// We didn't find an autoloader for a local version, so use the autoloader that
|
||||
// came with this script.
|
||||
if (!class_exists('Psy\Shell')) {
|
||||
/* <<< */
|
||||
if (is_file(__DIR__ . '/../vendor/autoload.php')) {
|
||||
require __DIR__ . '/../vendor/autoload.php';
|
||||
} elseif (is_file(__DIR__ . '/../../../autoload.php')) {
|
||||
require __DIR__ . '/../../../autoload.php';
|
||||
} else {
|
||||
fwrite(STDERR, 'PsySH dependencies not found, be sure to run `composer install`.' . PHP_EOL);
|
||||
fwrite(STDERR, 'See https://getcomposer.org to get Composer.' . PHP_EOL);
|
||||
exit(1);
|
||||
}
|
||||
/* >>> */
|
||||
}
|
||||
|
||||
// If the psysh binary was included directly, assume they just wanted an
|
||||
// autoloader and bail early.
|
||||
//
|
||||
// Keep this PHP 5.3 and 5.4 code around for a while in case someone is using a
|
||||
// globally installed psysh as a bin launcher for older local versions.
|
||||
if (version_compare(PHP_VERSION, '5.3.6', '<')) {
|
||||
$trace = debug_backtrace();
|
||||
} elseif (version_compare(PHP_VERSION, '5.4.0', '<')) {
|
||||
$trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS);
|
||||
} else {
|
||||
$trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 2);
|
||||
}
|
||||
|
||||
if (Psy\Shell::isIncluded($trace)) {
|
||||
unset($trace);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
// Clean up after ourselves.
|
||||
unset($trace);
|
||||
|
||||
// If the local version is too old, we can't do this
|
||||
if (!function_exists('Psy\bin')) {
|
||||
$argv = isset($_SERVER['argv']) ? $_SERVER['argv'] : array();
|
||||
$first = array_shift($argv);
|
||||
if (preg_match('/php(\.exe)?$/', $first)) {
|
||||
array_shift($argv);
|
||||
}
|
||||
array_unshift($argv, 'vendor/bin/psysh');
|
||||
|
||||
fwrite(STDERR, 'A local PsySH dependency was found, but it cannot be loaded. Please update to' . PHP_EOL);
|
||||
fwrite(STDERR, 'the latest version, or run the local copy directly, e.g.:' . PHP_EOL);
|
||||
fwrite(STDERR, PHP_EOL);
|
||||
fwrite(STDERR, ' ' . implode(' ', $argv) . PHP_EOL);
|
||||
exit(1);
|
||||
}
|
||||
|
||||
// And go!
|
||||
call_user_func(Psy\bin());
|
||||
486
vendor/bin/sail
vendored
Executable file
486
vendor/bin/sail
vendored
Executable file
@@ -0,0 +1,486 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
UNAMEOUT="$(uname -s)"
|
||||
|
||||
# Verify operating system is supported...
|
||||
case "${UNAMEOUT}" in
|
||||
Linux*) MACHINE=linux;;
|
||||
Darwin*) MACHINE=mac;;
|
||||
*) MACHINE="UNKNOWN"
|
||||
esac
|
||||
|
||||
if [ "$MACHINE" == "UNKNOWN" ]; then
|
||||
echo "Unsupported operating system [$(uname -s)]. Laravel Sail supports macOS, Linux, and Windows (WSL2)." >&2
|
||||
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Determine if stdout is a terminal...
|
||||
if test -t 1; then
|
||||
# Determine if colors are supported...
|
||||
ncolors=$(tput colors)
|
||||
|
||||
if test -n "$ncolors" && test "$ncolors" -ge 8; then
|
||||
BOLD="$(tput bold)"
|
||||
YELLOW="$(tput setaf 3)"
|
||||
GREEN="$(tput setaf 2)"
|
||||
NC="$(tput sgr0)"
|
||||
fi
|
||||
fi
|
||||
|
||||
# Function that prints the available commands...
|
||||
function display_help {
|
||||
echo "Laravel Sail"
|
||||
echo
|
||||
echo "${YELLOW}Usage:${NC}" >&2
|
||||
echo " sail COMMAND [options] [arguments]"
|
||||
echo
|
||||
echo "Unknown commands are passed to the docker-compose binary."
|
||||
echo
|
||||
echo "${YELLOW}docker-compose Commands:${NC}"
|
||||
echo " ${GREEN}sail up${NC} Start the application"
|
||||
echo " ${GREEN}sail up -d${NC} Start the application in the background"
|
||||
echo " ${GREEN}sail stop${NC} Stop the application"
|
||||
echo " ${GREEN}sail restart${NC} Restart the application"
|
||||
echo " ${GREEN}sail ps${NC} Display the status of all containers"
|
||||
echo
|
||||
echo "${YELLOW}Artisan Commands:${NC}"
|
||||
echo " ${GREEN}sail artisan ...${NC} Run an Artisan command"
|
||||
echo " ${GREEN}sail artisan queue:work${NC}"
|
||||
echo
|
||||
echo "${YELLOW}PHP Commands:${NC}"
|
||||
echo " ${GREEN}sail php ...${NC} Run a snippet of PHP code"
|
||||
echo " ${GREEN}sail php -v${NC}"
|
||||
echo
|
||||
echo "${YELLOW}Composer Commands:${NC}"
|
||||
echo " ${GREEN}sail composer ...${NC} Run a Composer command"
|
||||
echo " ${GREEN}sail composer require laravel/sanctum${NC}"
|
||||
echo
|
||||
echo "${YELLOW}Node Commands:${NC}"
|
||||
echo " ${GREEN}sail node ...${NC} Run a Node command"
|
||||
echo " ${GREEN}sail node --version${NC}"
|
||||
echo
|
||||
echo "${YELLOW}NPM Commands:${NC}"
|
||||
echo " ${GREEN}sail npm ...${NC} Run a npm command"
|
||||
echo " ${GREEN}sail npx${NC} Run a npx command"
|
||||
echo " ${GREEN}sail npm run prod${NC}"
|
||||
echo
|
||||
echo "${YELLOW}Yarn Commands:${NC}"
|
||||
echo " ${GREEN}sail yarn ...${NC} Run a Yarn command"
|
||||
echo " ${GREEN}sail yarn run prod${NC}"
|
||||
echo
|
||||
echo "${YELLOW}Database Commands:${NC}"
|
||||
echo " ${GREEN}sail mysql${NC} Start a MySQL CLI session within the 'mysql' container"
|
||||
echo " ${GREEN}sail mariadb${NC} Start a MySQL CLI session within the 'mariadb' container"
|
||||
echo " ${GREEN}sail psql${NC} Start a PostgreSQL CLI session within the 'pgsql' container"
|
||||
echo " ${GREEN}sail redis${NC} Start a Redis CLI session within the 'redis' container"
|
||||
echo
|
||||
echo "${YELLOW}Debugging:${NC}"
|
||||
echo " ${GREEN}sail debug ...${NC} Run an Artisan command in debug mode"
|
||||
echo " ${GREEN}sail debug queue:work${NC}"
|
||||
echo
|
||||
echo "${YELLOW}Running Tests:${NC}"
|
||||
echo " ${GREEN}sail test${NC} Run the PHPUnit tests via the Artisan test command"
|
||||
echo " ${GREEN}sail phpunit ...${NC} Run PHPUnit"
|
||||
echo " ${GREEN}sail pint ...${NC} Run Pint"
|
||||
echo " ${GREEN}sail dusk${NC} Run the Dusk tests (Requires the laravel/dusk package)"
|
||||
echo " ${GREEN}sail dusk:fails${NC} Re-run previously failed Dusk tests (Requires the laravel/dusk package)"
|
||||
echo
|
||||
echo "${YELLOW}Container CLI:${NC}"
|
||||
echo " ${GREEN}sail shell${NC} Start a shell session within the application container"
|
||||
echo " ${GREEN}sail bash${NC} Alias for 'sail shell'"
|
||||
echo " ${GREEN}sail root-shell${NC} Start a root shell session within the application container"
|
||||
echo " ${GREEN}sail root-bash${NC} Alias for 'sail root-shell'"
|
||||
echo " ${GREEN}sail tinker${NC} Start a new Laravel Tinker session"
|
||||
echo
|
||||
echo "${YELLOW}Sharing:${NC}"
|
||||
echo " ${GREEN}sail share${NC} Share the application publicly via a temporary URL"
|
||||
echo
|
||||
echo "${YELLOW}Binaries:${NC}"
|
||||
echo " ${GREEN}sail bin ...${NC} Run Composer binary scripts from the vendor/bin directory"
|
||||
echo
|
||||
echo "${YELLOW}Customization:${NC}"
|
||||
echo " ${GREEN}sail artisan sail:publish${NC} Publish the Sail configuration files"
|
||||
echo " ${GREEN}sail build --no-cache${NC} Rebuild all of the Sail containers"
|
||||
|
||||
exit 1
|
||||
}
|
||||
|
||||
# Proxy the "help" command...
|
||||
if [ $# -gt 0 ]; then
|
||||
if [ "$1" == "help" ] || [ "$1" == "-h" ] || [ "$1" == "-help" ] || [ "$1" == "--help" ]; then
|
||||
display_help
|
||||
fi
|
||||
else
|
||||
display_help
|
||||
fi
|
||||
|
||||
# Source the ".env" file so Laravel's environment variables are available...
|
||||
if [ -f ./.env ]; then
|
||||
source ./.env
|
||||
fi
|
||||
|
||||
# Define environment variables...
|
||||
export APP_PORT=${APP_PORT:-80}
|
||||
export APP_SERVICE=${APP_SERVICE:-"laravel.test"}
|
||||
export DB_PORT=${DB_PORT:-3306}
|
||||
export WWWUSER=${WWWUSER:-$UID}
|
||||
export WWWGROUP=${WWWGROUP:-$(id -g)}
|
||||
|
||||
export SAIL_FILES=${SAIL_FILES:-""}
|
||||
export SAIL_SHARE_DASHBOARD=${SAIL_SHARE_DASHBOARD:-4040}
|
||||
export SAIL_SHARE_SERVER_HOST=${SAIL_SHARE_SERVER_HOST:-"laravel-sail.site"}
|
||||
export SAIL_SHARE_SERVER_PORT=${SAIL_SHARE_SERVER_PORT:-8080}
|
||||
export SAIL_SHARE_SUBDOMAIN=${SAIL_SHARE_SUBDOMAIN:-""}
|
||||
|
||||
# Function that outputs Sail is not running...
|
||||
function sail_is_not_running {
|
||||
echo "${BOLD}Sail is not running.${NC}" >&2
|
||||
echo "" >&2
|
||||
echo "${BOLD}You may Sail using the following commands:${NC} './vendor/bin/sail up' or './vendor/bin/sail up -d'" >&2
|
||||
|
||||
exit 1
|
||||
}
|
||||
|
||||
# Define Docker Compose command prefix...
|
||||
docker compose &> /dev/null
|
||||
if [ $? == 0 ]; then
|
||||
DOCKER_COMPOSE=(docker compose)
|
||||
else
|
||||
DOCKER_COMPOSE=(docker-compose)
|
||||
fi
|
||||
|
||||
if [ -n "$SAIL_FILES" ]; then
|
||||
# Convert SAIL_FILES to an array...
|
||||
IFS=':' read -ra SAIL_FILES <<< "$SAIL_FILES"
|
||||
|
||||
for FILE in "${SAIL_FILES[@]}"; do
|
||||
if [ -f "$FILE" ]; then
|
||||
DOCKER_COMPOSE+=(-f "$FILE")
|
||||
else
|
||||
echo "${BOLD}Unable to find Docker Compose file: '${FILE}'${NC}" >&2
|
||||
|
||||
exit 1
|
||||
fi
|
||||
done
|
||||
fi
|
||||
|
||||
EXEC="yes"
|
||||
|
||||
if [ -z "$SAIL_SKIP_CHECKS" ]; then
|
||||
# Ensure that Docker is running...
|
||||
if ! docker info > /dev/null 2>&1; then
|
||||
echo "${BOLD}Docker is not running.${NC}" >&2
|
||||
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Determine if Sail is currently up...
|
||||
if "${DOCKER_COMPOSE[@]}" ps "$APP_SERVICE" 2>&1 | grep 'Exit\|exited'; then
|
||||
echo "${BOLD}Shutting down old Sail processes...${NC}" >&2
|
||||
|
||||
"${DOCKER_COMPOSE[@]}" down > /dev/null 2>&1
|
||||
|
||||
EXEC="no"
|
||||
elif [ -z "$("${DOCKER_COMPOSE[@]}" ps -q)" ]; then
|
||||
EXEC="no"
|
||||
fi
|
||||
fi
|
||||
|
||||
ARGS=()
|
||||
|
||||
# Proxy PHP commands to the "php" binary on the application container...
|
||||
if [ "$1" == "php" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" "php" "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy vendor binary commands on the application container...
|
||||
elif [ "$1" == "bin" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" ./vendor/bin/"$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy docker-compose commands to the docker-compose binary on the application container...
|
||||
elif [ "$1" == "docker-compose" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" "${DOCKER_COMPOSE[@]}")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy Composer commands to the "composer" binary on the application container...
|
||||
elif [ "$1" == "composer" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" "composer" "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy Artisan commands to the "artisan" binary on the application container...
|
||||
elif [ "$1" == "artisan" ] || [ "$1" == "art" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" php artisan "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy the "debug" command to the "php artisan" binary on the application container with xdebug enabled...
|
||||
elif [ "$1" == "debug" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail -e XDEBUG_SESSION=1)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" php artisan "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy the "test" command to the "php artisan test" Artisan command...
|
||||
elif [ "$1" == "test" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" php artisan test "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy the "phpunit" command to "php vendor/bin/phpunit"...
|
||||
elif [ "$1" == "phpunit" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" php vendor/bin/phpunit "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy the "pint" command to "php vendor/bin/pint"...
|
||||
elif [ "$1" == "pint" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" php vendor/bin/pint "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy the "dusk" command to the "php artisan dusk" Artisan command...
|
||||
elif [ "$1" == "dusk" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=(-e "APP_URL=http://${APP_SERVICE}")
|
||||
ARGS+=(-e "DUSK_DRIVER_URL=http://selenium:4444/wd/hub")
|
||||
ARGS+=("$APP_SERVICE" php artisan dusk "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy the "dusk:fails" command to the "php artisan dusk:fails" Artisan command...
|
||||
elif [ "$1" == "dusk:fails" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=(-e "APP_URL=http://${APP_SERVICE}")
|
||||
ARGS+=(-e "DUSK_DRIVER_URL=http://selenium:4444/wd/hub")
|
||||
ARGS+=("$APP_SERVICE" php artisan dusk:fails "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Initiate a Laravel Tinker session within the application container...
|
||||
elif [ "$1" == "tinker" ] ; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" php artisan tinker)
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy Node commands to the "node" binary on the application container...
|
||||
elif [ "$1" == "node" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" node "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy NPM commands to the "npm" binary on the application container...
|
||||
elif [ "$1" == "npm" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" npm "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy NPX commands to the "npx" binary on the application container...
|
||||
elif [ "$1" == "npx" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" npx "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Proxy YARN commands to the "yarn" binary on the application container...
|
||||
elif [ "$1" == "yarn" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" yarn "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Initiate a MySQL CLI terminal session within the "mysql" container...
|
||||
elif [ "$1" == "mysql" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=(mysql bash -c)
|
||||
ARGS+=("MYSQL_PWD=\${MYSQL_PASSWORD} mysql -u \${MYSQL_USER} \${MYSQL_DATABASE}")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Initiate a MySQL CLI terminal session within the "mariadb" container...
|
||||
elif [ "$1" == "mariadb" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=(mariadb bash -c)
|
||||
ARGS+=("MYSQL_PWD=\${MYSQL_PASSWORD} mysql -u \${MYSQL_USER} \${MYSQL_DATABASE}")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Initiate a PostgreSQL CLI terminal session within the "pgsql" container...
|
||||
elif [ "$1" == "psql" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=(pgsql bash -c)
|
||||
ARGS+=("PGPASSWORD=\${PGPASSWORD} psql -U \${POSTGRES_USER} \${POSTGRES_DB}")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Initiate a Bash shell within the application container...
|
||||
elif [ "$1" == "shell" ] || [ "$1" == "bash" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec -u sail)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" bash "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Initiate a root user Bash shell within the application container...
|
||||
elif [ "$1" == "root-shell" ] || [ "$1" == "root-bash" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=("$APP_SERVICE" bash "$@")
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Initiate a Redis CLI terminal session within the "redis" container...
|
||||
elif [ "$1" == "redis" ] ; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
ARGS+=(exec)
|
||||
[ ! -t 0 ] && ARGS+=(-T)
|
||||
ARGS+=(redis redis-cli)
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Share the site...
|
||||
elif [ "$1" == "share" ]; then
|
||||
shift 1
|
||||
|
||||
if [ "$EXEC" == "yes" ]; then
|
||||
docker run --init --rm -p "$SAIL_SHARE_DASHBOARD":4040 -t beyondcodegmbh/expose-server:latest share http://host.docker.internal:"$APP_PORT" \
|
||||
--server-host="$SAIL_SHARE_SERVER_HOST" \
|
||||
--server-port="$SAIL_SHARE_SERVER_PORT" \
|
||||
--auth="$SAIL_SHARE_TOKEN" \
|
||||
--subdomain="$SAIL_SHARE_SUBDOMAIN" \
|
||||
"$@"
|
||||
|
||||
exit
|
||||
else
|
||||
sail_is_not_running
|
||||
fi
|
||||
|
||||
# Pass unknown commands to the "docker-compose" binary...
|
||||
else
|
||||
ARGS+=("$@")
|
||||
fi
|
||||
|
||||
# Run Docker Compose with the defined arguments...
|
||||
"${DOCKER_COMPOSE[@]}" "${ARGS[@]}"
|
||||
63
vendor/bin/var-dump-server
vendored
Executable file
63
vendor/bin/var-dump-server
vendored
Executable file
@@ -0,0 +1,63 @@
|
||||
#!/usr/bin/env php
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (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.
|
||||
*/
|
||||
|
||||
/**
|
||||
* Starts a dump server to collect and output dumps on a single place with multiple formats support.
|
||||
*
|
||||
* @author Maxime Steinhausser <maxime.steinhausser@gmail.com>
|
||||
*/
|
||||
|
||||
use Psr\Log\LoggerInterface;
|
||||
use Symfony\Component\Console\Application;
|
||||
use Symfony\Component\Console\Input\ArgvInput;
|
||||
use Symfony\Component\Console\Input\InputOption;
|
||||
use Symfony\Component\Console\Logger\ConsoleLogger;
|
||||
use Symfony\Component\Console\Output\ConsoleOutput;
|
||||
use Symfony\Component\VarDumper\Command\ServerDumpCommand;
|
||||
use Symfony\Component\VarDumper\Server\DumpServer;
|
||||
|
||||
function includeIfExists(string $file): bool
|
||||
{
|
||||
return file_exists($file) && include $file;
|
||||
}
|
||||
|
||||
if (
|
||||
!includeIfExists(__DIR__ . '/../../../../autoload.php') &&
|
||||
!includeIfExists(__DIR__ . '/../../vendor/autoload.php') &&
|
||||
!includeIfExists(__DIR__ . '/../../../../../../vendor/autoload.php')
|
||||
) {
|
||||
fwrite(STDERR, 'Install dependencies using Composer.'.PHP_EOL);
|
||||
exit(1);
|
||||
}
|
||||
|
||||
if (!class_exists(Application::class)) {
|
||||
fwrite(STDERR, 'You need the "symfony/console" component in order to run the VarDumper server.'.PHP_EOL);
|
||||
exit(1);
|
||||
}
|
||||
|
||||
$input = new ArgvInput();
|
||||
$output = new ConsoleOutput();
|
||||
$defaultHost = '127.0.0.1:9912';
|
||||
$host = $input->getParameterOption(['--host'], $_SERVER['VAR_DUMPER_SERVER'] ?? $defaultHost, true);
|
||||
$logger = interface_exists(LoggerInterface::class) ? new ConsoleLogger($output->getErrorOutput()) : null;
|
||||
|
||||
$app = new Application();
|
||||
|
||||
$app->getDefinition()->addOption(
|
||||
new InputOption('--host', null, InputOption::VALUE_REQUIRED, 'The address the server should listen to', $defaultHost)
|
||||
);
|
||||
|
||||
$app->add($command = new ServerDumpCommand(new DumpServer($host, $logger)))
|
||||
->getApplication()
|
||||
->setDefaultCommand($command->getName(), true)
|
||||
->run($input, $output)
|
||||
;
|
||||
Reference in New Issue
Block a user