gc-test / deal-commands
Framework-agnostic command processing package for CRM deals
Installs: 1
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/gc-test/deal-commands
Requires
- php: ^8.2
- ext-mbstring: *
- psr/log: ^3.0
Requires (Dev)
- composer/xdebug-handler: ^3.0
- ergebnis/composer-normalize: ^2.48
- friendsofphp/php-cs-fixer: ^3.88
- illuminate/support: ^12.0
- phpunit/phpunit: ^10.5
- savinmikhail/dist-size-optimizer: ^0.2.5
README
Цель
Разработать PHP пакет для обработки текстовых команд пользователя. Пакет должен быть независим от фреймворка, но легко интегрироваться с Laravel приложениями через Composer.
Контекст
Пакет будет использоваться в CRM-системе, где пользователи вводят текстовые команды для управления сделками. Все команды выполняются в контексте конкретной сделки.
Примеры команд для реализации
- /принято 500 офис — устанавливает свойство сделки #14 = 500, а #15 = офис
- /контакт — выводит служебное сообщение в сделку с текстом, содержащим контакт клиента по текущей сделке
- /причина_закрытия удалена транзакция — устанавливает свойство сделки #222 в "удалена транзакция"
- /причина — выводит служебное сообщение в сделку с текстом, содержащим свойство #222 текущей сделки
Требования
- Код должен быть написан на PHP 8+
- Пакет должен быть установлен через Composer
- Необходимо реализовать логирование вызовов команд
- Бизнес-логика должна быть изолирована от инфраструктуры
- Решение должно быть расширяемым для добавления новых команд
Ограничения
- Пакет должен быть написан на чистом PHP без прямых зависимостей от Laravel
Критерии оценки
- Архитектурное решение
- Чистота и стиль кода
- Наличие тестов
- Возможность расширения функциональности
- Правильность настройки Composer для использования в Laravel
Установка и интеграция с Laravel
- Установка
composer require gc-test/deal-commands
- Автодискавери
- Ничего добавлять в
config/app.php
не нужно: провайдер пакета подключится автоматически.
- Публикация конфига
php artisan vendor:publish --tag=deal-commands-config
- Настройка
config/deal-commands.php
'adapter' => App\Infrastructure\Crm\DealGateway::class,
'commands' => [
GcTest\DealCommands\Application\Commands\AcceptedCommand::class,
GcTest\DealCommands\Application\Commands\ContactCommand::class,
GcTest\DealCommands\Application\Commands\CloseReasonSetCommand::class,
GcTest\DealCommands\Application\Commands\CloseReasonShowCommand::class,
],
- Использование
use GcTest\DealCommands\Application\CommandProcessor;
use GcTest\DealCommands\Domain\Contracts\DealGatewayInterface;
$processor = app(CommandProcessor::class);
$gateway = app(DealGatewayInterface::class); // ваша реализация из конфига
$response = $processor->process($input, $gateway);