juliomotol / laravel-channel-attributes
This is my package laravel-channel-attributes
Requires
- php: ^8.1
- illuminate/broadcasting: ^9.0
- illuminate/contracts: ^9.0
- spatie/laravel-package-tools: ^1.13.0
- symfony/finder: ^6.1
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^6.0
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^7.0
- pestphp/pest: ^1.21
- pestphp/pest-plugin-laravel: ^1.1
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- phpunit/phpunit: ^9.5
This package is auto-updated.
Last update: 2024-12-09 23:23:22 UTC
README
Automatically register channel routes using annotations/attributes!
This package is inspired by spatie/laravel-route-attributes
.
Already using
spatie/laravel-route-attributes
? Congrats, time to ditch that./routes
directory! (Assuming you're not using theconsole.php
)
use JulioMotol\ChannelAttributes\Attributes\Channel; #[Channel('foo')] class FooChannel { // }
This will be registered like:
Broadcast::channel('foo', FooChannel::class);
Installation
You can install the package via composer:
composer require juliomotol/laravel-channel-attributes
You can publish the config file with:
php artisan vendor:publish --tag="laravel-channel-attributes-config"
This is the contents of the published config file:
return [ /* * Automatic registration of channels will only happen if this setting is `true` */ 'enabled' => true, /* * Channels in these directories that have channel attributes will automatically be registered. * You can specify a different namespace other than `\App` by providing a different key. * * e.g ['\Domain\Post\Broadcasting' => base_path('domain/Post/Broadcasting')] */ 'directories' => [ app_path('Broadcasting'), ], ];
Usage
To add a channel to be registered automatically, simply add the JulioMotol\ChannelAttributes\Attributes\Channel
to a channel class
You can add options to channel by doing:
You can create a channel for a model by doing:
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.