victormgomes / async-api
Automatically generate documentation for the AsyncAPI specification based on Laravel events
Fund package maintenance!
Requires
- php: ^8.4
- illuminate/console: ^11.0||^12.0||^13.0
- illuminate/contracts: ^11.0||^12.0||^13.0
- illuminate/filesystem: ^11.0||^12.0||^13.0
- illuminate/routing: ^11.0||^12.0||^13.0
- illuminate/support: ^11.0||^12.0||^13.0
- illuminate/view: ^11.0||^12.0||^13.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.8
- orchestra/testbench: ^10.0.0||^9.0.0
- pestphp/pest: ^4.0
- pestphp/pest-plugin-arch: ^4.0
- pestphp/pest-plugin-laravel: ^4.0
- phpstan/extension-installer: ^1.4
- phpstan/phpstan-deprecation-rules: ^2.0
- phpstan/phpstan-phpunit: ^2.0
- spatie/laravel-ray: ^1.35
This package is auto-updated.
Last update: 2026-04-28 08:01:18 UTC
README
Automatically generate documentation for the AsyncAPI specification based on Laravel events
Introduction
In modern event-driven architectures, documenting WebSocket interfaces is as crucial as documenting REST APIs. Async-API bridges this gap for Laravel applications by automating the generation of AsyncAPI specifications.
Why use this package?
- Zero-Effort Documentation: Stop maintaining manual AsyncAPI files. Document your events directly in your PHP code.
- Attribute-Based: Uses modern PHP 8 attributes for a clean and declarative developer experience.
- Schema Integration: Automatically extracts payload schemas from DTOs or models, ensuring your documentation always matches your code.
- Seamless Integration: Works perfectly with Laravel's broadcasting system.
Support us
We invest a lot of resources into creating best in class open source packages. You can support us by sponsoring us on GitHub.
Installation
You can install the package via composer:
composer require victormgomes/async-api
You can publish the config file with:
php artisan vendor:publish --tag="async-api-config"
Usage
Simply add the #[AsyncApi] attribute to your event classes. You can specify a DTO class to automatically generate the schema for the message payload.
use Victormgomes\AsyncApi\Attributes\AsyncApi; #[AsyncApi(dto: ChatPresenceDTO::class)] class ChatPresence implements ShouldBroadcast { // ... }
The package will then discover these attributes and compile them into a standardized AsyncAPI specification.
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.