deegitalbe/laravel-trustup-model-broadcast

Basic versioned php package.

v1.0.0 2022-12-21 13:57 UTC

This package is auto-updated.

Last update: 2024-04-21 16:53:08 UTC


README

This package is used to dispatch configured models created, updated or deleted events to our websocket microservice.

Installation

Configure websocket package

Make sure you configured websocket package first

Install package using composer

composer require deegitalbe/laravel-trustup-model-broadcast

.env configuration

Add these information to your .env file.

TRUSTUP_MODEL_BROADCAST_APP_KEY=

Usage

Configure your model

use Illuminate\Database\Eloquent\Model;
use Deegitalbe\LaravelTrustupModelBroadcast\Traits\Models\IsTrustupBroadcastModel;
use Deegitalbe\LaravelTrustupModelBroadcast\Contracts\Models\TrustupBroadcastModelContract;

class YourModel extends Model implements TrustupBroadcastModelContract
{
    use IsTrustupBroadcastModel;

    /**
     * Getting attributes sent along when broadcasing events.
     
     * @param string $eventName Laravel model event that should be broadcasted (created, updated, deleted, ...)
     * @return array<string, mixed>
     */
    public function getTrustupModelBroadcastEventAttributes(string $eventName): array
    {
        return [
            // Your attributes ...
        ];
    }
}

Keep in mind your event won't broadcast if your model is unable to provide professional authorization key.

Customization

Professional authorization key

By default this package use model attribute professional_authorization_key. To customize this behavior, just override trait method.

    /**
     * Getting model key used when broadcasting model events.
     * 
     * By default if null, event would not broadcast.
     * 
     * @return ?string
     */
    public function getTrustupModelBroadcastProfessionalAuthorizationKey(): ?string
    {
        return "your-value";
    }