定制 ignaciocastro0713/cqbus-mediator 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

ignaciocastro0713/cqbus-mediator

最新稳定版本:v7.0.1

Composer 安装命令:

composer require ignaciocastro0713/cqbus-mediator

包简介

A modern CQRS Mediator for Laravel using PHP 8 Attributes, auto-discovery, and routing pipelines.

README 文档

README

run-tests PHPStan codecov Documentation

A zero-configuration Command/Query Bus for Laravel

Decouple your controllers from business logic using the Mediator pattern (CQRS) and PHP 8 Attributes — with zero boilerplate.

📖 Read the Documentation

The Problem

Controllers that mix HTTP, business logic, and side effects are hard to test and maintain.

❌ Before — everything tangled in one place ✅ After — each concern in its own place
class UserController extends Controller
{
    public function register(Request $request)
    {
        $request->validate([
            'email' => 'required|email',
            'password' => 'required',
        ]);

        DB::beginTransaction();
        try {
            $user = User::create($request->all());
            Mail::to($user)->send(new WelcomeEmail());
            Log::info("User registered");
            DB::commit();
            return response()->json($user, 201);
        } catch (\Exception $e) {
            DB::rollBack();
            throw $e;
        }
    }
}
#[Api]
class RegisterUserAction
{
    use AsAction;

    public function __construct(
        private readonly Mediator $mediator
    ) {}

    public static function route(Router $router): void
    {
        $router->post('/register');
    }

    public function handle(RegisterUserRequest $request): JsonResponse
    {
        // Handler runs the logic
        $user = $this->mediator->send($request);

        // Notifications handle side effects
        $this->mediator->publish(new UserRegisteredEvent($user));

        return response()->json($user, 201);
    }
}

Features

⚡ Zero Config Handlers are auto-discovered via #[RequestHandler] and #[Notification] attributes. No registration needed.

📢 Event Bus Publish events to multiple notification handlers, with priority control over execution order.

🎮 Attribute Routing Define routes directly on Action classes with #[Api], #[Prefix], #[Middleware], and more.

🔗 Pipelines Apply middleware-like logic (transactions, logging) globally or per-handler via #[Pipeline].

🧪 Testing Fakes Assert dispatched requests without executing business logic — built-in, no setup required.

🚀 Production Cache Eliminate discovery overhead (~2,500x faster boot) with php artisan mediator:cache.

Installation

composer require ignaciocastro0713/cqbus-mediator

The package is auto-discovered. Optionally publish the config file:

php artisan vendor:publish --tag=mediator-config

Quick Start

The package supports two patterns:

Pattern Method Direction Use for
Command / Query send() 1-to-1 Business logic that reads or writes
Event Bus publish() 1-to-N Side effects (emails, logs, etc.)

1. Scaffold your classes

php artisan make:mediator-handler RegisterUserHandler --action

Generates RegisterUserRequest, RegisterUserHandler, and RegisterUserAction in one go.

2. Write your Handler

#[RequestHandler(RegisterUserRequest::class)]
class RegisterUserHandler
{
    public function handle(RegisterUserRequest $request): User
    {
        return User::create($request->validated());
    }
}

3. Dispatch from your Action

$user = $this->mediator->send($request);

The Mediator discovers and routes to the correct handler automatically.

Documentation

📦 Installation 🧠 Core Concepts ⚡ Commands & Queries
📢 Event Bus 🎮 Routing & Actions 🔗 Pipelines
🧪 Testing 📋 Console Commands 🚀 Production & Performance

Requirements

  • PHP 8.2+
  • Laravel 11.0+

Contributing

Feel free to open issues or submit pull requests on the GitHub repository.

License

This package is open-sourced software licensed under the MIT license.

统计信息

  • 总下载量: 86
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 4
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-07-21

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固