phpsoftbox / cli-app
Console application component (CliApp) for PhpSoftBox Framework
Installs: 16
Dependents: 18
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/phpsoftbox/cli-app
Requires
- php: ^8.4
- psr/container: ^2.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.93
- phpsoftbox/cs-fixer: ^1.0.1
- phpunit/phpunit: ^11.2
This package is auto-updated.
Last update: 2026-02-06 10:48:40 UTC
README
Команды описываются обычными PHP-файлами, которые возвращают CommandDefinition (через фабрику Command::define()),
а сам раннер умеет разбирать argv, спрашивать пользователя (ask/confirm/secret), рисовать таблицы и прогресс, рассылать
события и работать как с DI-контейнером (PSR-11), так и без него.
По умолчанию реестр команд (AbstractCommandRegistry) добавляет команду list,
которая выводит все зарегистрированные команды по namespace (часть до :).
Отключить можно так: new InMemoryCommandRegistry(withDefaultCommands: false).
Entrypoint psb
После установки пакета доступен vendor/bin/psb. Он ищет конфиг по PSB_CLI_APP_CONFIG_PATH (если задана),
иначе config/cli-app.php и ожидает получить CliApp, RunnerInterface или CliAppConfig.
Если файла нет — сканирует ./console и ./commands.
Установка
composer require phpsoftbox/cli-app
Быстрый старт
<?php use PhpSoftBox\CliApp\CliApp; use PhpSoftBox\CliApp\Command\Command; use PhpSoftBox\CliApp\Command\{ArgumentDefinition as Arg}; use PhpSoftBox\CliApp\Io\ConsoleIo; use PhpSoftBox\CliApp\Command\InMemoryCommandRegistry; use PhpSoftBox\CliApp\Response; use PhpSoftBox\CliApp\Runner\Runner; $registry = new InMemoryCommandRegistry(); $registry->register(Command::define( name: 'hello', description: 'Приветствие', signature: [new Arg('name', 'Кого приветствовать')], handler: function (Runner $runner) { $name = $runner->request()->param('name'); $runner->io()->writeln("Hello, $name", 'success'); return Response::SUCCESS; }, )); $app = new CliApp($registry, new ConsoleIo()); $app->runner()->run('hello', ['world']);
Документация
- docs/index.md — оглавление
- Основные темы: структура команд, сигнатуры и парсер, запрос/ответ, IO-хелперы, события, загрузка команд из директорий.