Skip to content

phpsoftbox/cli-app

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PhpSoftBox CliApp

Команды описываются обычными 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-хелперы, события, загрузка команд из директорий.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages