bfg/web-hooker

Installs: 22

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 2

Forks: 1

Open Issues: 0

Type:bfg-app

2.2.2 2022-09-15 08:49 UTC

This package is auto-updated.

Last update: 2025-01-15 13:30:43 UTC


README

Install

composer require bfg/web-hooker

Description

Compact Laravel WebHook core for simple of begin

Usage

Importantly! You should have queues for processing hooks.

Publish

Migrations

php artisan vendor:publish --tag=web-hooker-migrations

Configs

php artisan vendor:publish --tag=web-hooker-config

Migrate

A mandatory stage is to create a table in the database, so after the publication of migration, will launch them.

php artisan migrate

Http request type

You need to make sure that the type.http_request setting is included in the config/webhooker.php file in the true value.

Before usage, you should use the trait on your model there you want to use for hooks:

<?php

namespace App\Models;

use Bfg\WebHooker\Traits\WebHooked;
use Illuminate\Foundation\Auth\User as Authenticatable;

class User extends Authenticatable
{
    use WebHooked;
}

Create your own event, which is a standard Laravel functionality.

php artisan make:event YouEvent

In the construct of your event, you can accept the Hook model and a payload.

...
    /**
     * Create a new event instance.
     *
     * @return void
     */
    public function __construct(
        public WebHook $hook,
        public array $payload,
    ) {
        //
    }
...

Create the organizer class by using the Bfg\WebHooker\WebHookOrganizerInterface interface:

<?php

namespace App\WebHook\Organizers;

use Bfg\WebHooker\Models\WebHook;
use Bfg\WebHooker\WebHookOrganizerInterface;

class YouOrganizer implements WebHookOrganizerInterface
{
    /**
     * Generate the event for hook emit
     * @param  WebHook  $hook
     * @return string
     */
    function event(WebHook $hook): string
    {
        return YouEvent::class;
    }

    /**
     * Method for remote subscribe
     *  
     * To return the truth if the subscription was successful, 
     * otherwise there will be a repeated request for the next iteration.
     *
     * @param  WebHook  $hook
     * @return bool
     */
    public function subscribe(WebHook $hook): bool
    {
        // Request to subscribe
        // Link for request: $hook->route_response
        return true;
    }

    /**
     * Method for remote unsubscribe
     *
     * To return the truth if the unsubscription was successful, 
     * otherwise there will be a repeated request for the next iteration.
     * 
     * @param  WebHook  $hook
     * @return bool
     */
    public function unsubscribe(WebHook $hook): bool
    {
        // Request to unsubscribe
        return true;
    }
}

Or you can use the command for create a organizer:

php artisan make:organizer YouOrganizer

For get a request link for hook, you can use the $hook->route_response parameter.

You can now create bridges for some separate entry in the database or model.

$webhook = \App\Models\User::first()->assignBridge(
    organizer: YouOrganizer::class,
    settings: [] // Optional
): \Bfg\WebHooker\Models\WebHook;

or

$webhook = \App\Models\User::assignBridgework(
    organizer: YouOrganizer::class,
    settings: [] // Optional
): \Bfg\WebHooker\Models\WebHook;

If you want to postpone the signature for some time, you can use the subscribeDelay method:

/** @var \Bfg\WebHooker\Models\WebHook $webhook */
$webhook->subscribeDelay(
    now()->addHour()
);

If you want to indicate the time of the unsubscribing, you can also indicate through the unsubscribeDelay method:

/** @var \Bfg\WebHooker\Models\WebHook $webhook */
$webhook->unsubscribeDelay(
    now()->addHours(2)
);

To launch subscription and unsubscribing procedures, you need to configure your schedule on the webhook:associate command with an interval of one minute:

$schedule->command('webhook:associate')->everyMinute();

Open signature type

You need to make sure that the type.websocket_open_signature setting is included in the config/webhooker.php file in the true value.

If you install a beyondcode/laravel-websockets package, you have the opportunity to create fast hooks that can take data on the socket. What you need to use this type:

composer require beyondcode/laravel-websockets

Create the organizer:

php artisan make:organizer YouOrganizer

Create the special bridge:

$webhook = \App\Models\User::assignBridgework(
    organizer: YouOrganizer::class,
    settings: []
)->setTypeWebsocketOpenSignature(): \Bfg\WebHooker\Models\WebHook;

Server:

php artisan websockets:serve

Client:

const hookSocket = new WebSocket("ws://0.0.0.0:6001/hook/{PUSHER_APP_KEY}/{WEBHOOK_HASH}");
hookSocket.send('Any data');

Open client type

You need to make sure that the type.websocket_open_client setting is included in the config/webhooker.php file in the true value.

This type is designed as a client that creates local client connections with asynchronous TCPs (web socket servers).

Create the organizer:

php artisan make:organizer BinanceOrganizer --client

Carefully study how the organizer is built, without it the client’s server will ignore this hook

<?php

namespace App\WebHook\Organizers;

use Bfg\WebHooker\Models\WebHook;
use Bfg\WebHooker\WebHookOrganizerAbstract;

class BinanceOrganizer extends WebHookOrganizerAbstract
{
    /**
     * Generate the event for hook emit
     * @param  WebHook  $hook
     * @return string
     */
    function event(WebHook $hook): string
    {
        return YouEvent::class;
    }

    /**
     * The websocket host for connection
     * @param  WebHook  $hook
     * @return string
     */
    function host(WebHook $hook): string
    {
        return "wss://stream.binance.com:9443/ws/btcusdt@depth";
    }
}

After the link to the server is indicated, you can customize your organizer a little:

...
    /**
     * Send a message when creating the first connection
     *
     * @param  WebHook  $hook
     * @return array
     */
    public function onConnectMessage(WebHook $hook): array
    {
        return [
            'method' => 'SUBSCRIBE',
            'params' => [
                'btcusdt@aggTrade',
                'btcusdt@depth'
            ],
            'id' => $hook->id
        ];
    }
    
    /**
     * Send message when disconnect from server
     *
     * @param  WebHook  $hook
     * @return array
     */
    public function onDisconnectMessage(WebHook $hook): array
    {
        return [
            'method' => 'UNSUBSCRIBE',
            'params' => [
                'btcusdt@aggTrade',
                'btcusdt@depth'
            ],
            'id' => $hook->id
        ];
    }
    
    /**
     * Send message when add hook to client’s server
     *
     * @param  WebHook  $hook
     * @return array
     */
    public function onAddMessage(WebHook $hook): array
    {
        return [];
    }
    
    /**
     * Checks an incoming message for authenticity for this hook
     *
     * @param  WebHook  $hook
     * @param  array  $payload
     * @return bool
     */
    public function isSelfMessage(WebHook $hook, array $payload): bool
    {
        return true;
    }

In order to prepare your payload, you can declare the preparePayload method in your organizer:

...    
    public function preparePayload(WebHook $hook, array $payload): array
    {
        return $payload;
    }
...

Create the special bridge:

$webhook = \App\Models\User::assignBridgework(
    organizer: BinanceOrganizer::class,
    settings: []
)->setTypeWebsocketOpenClient(): \Bfg\WebHooker\Models\WebHook;

Run the server of client connection

php artisan webhook:open-client

Supervisor

[program:webhook-open-client]
directory=/path/to/you/project
command=php artisan webhook:open-client
autostart=true
autorestart=true
user=root
numprocs=1
redirect_stderr=true
stdout_logfile=/path/to/you/project/webhook-open-client.log