phpsoftbox/cli-app 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

phpsoftbox/cli-app

Composer 安装命令:

composer require phpsoftbox/cli-app

包简介

Console application component (CliApp) for PhpSoftBox Framework

README 文档

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']);

Автокомплит для Bash

Чтобы включить автокомплит для команды psb в Bash, добавьте в ваш .bashrc или .bash_profile:

source path/to/vendor/bin/_psb_completion

или скопируйте файл в стандартную директорию с завершениями (если она есть):

cp vendor/bin/_psb_completion /usr/local/etc/bash_completion.d/psb

После этого при вводе psb + TAB будут предложены доступные команды.

Документация

  • docs/index.md — оглавление
  • Основные темы: структура команд, сигнатуры и парсер, запрос/ответ, IO-хелперы, события, загрузка команд из директорий.

统计信息

  • 总下载量: 210
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 51
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-02-05

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固