ignaciocastro0713/cqbus-mediator

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

Maintainers

Package info

github.com/IgnacioCastro0713/cqbus-mediator

pkg:composer/ignaciocastro0713/cqbus-mediator

Statistics

Installs: 78

Dependents: 0

Suggesters: 0

Stars: 3

Open Issues: 0

v7.0.1 2026-04-23 05:00 UTC

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.