xlabs/natsbundle

Nats wrapper bundle

Installs: 524

Dependents: 1

Suggesters: 0

Security: 0

Type:symfony-bundle

2.0.4 2020-12-07 21:11 UTC

This package is auto-updated.

Last update: 2024-12-08 05:45:18 UTC


README

A NATS postback wrapper.

Installation

Install through composer:

php -d memory_limit=-1 composer.phar require xlabs/natsbundle

In your AppKernel

public function registerbundles()
{
    return [
    	...
    	...
    	new XLabs\NatsBundle\XLabsNatsBundle(),
    ];
}

Routing

Append to main routing file:

# app/config/routing.yml
  
x_labs_nats:
    resource: .
    type: xlabs_nats_routing

Configuration sample

Default values are shown below:

# app/config/config.yml
  
x_labs_nats:
    postback_url: /your/nats/postback/url
    allowed_ips: ['127.0.0.1', '192.168.1.10', '60.58.43.125', ...]
    api:
        url: https://<nats_domain>/api
        username: USERNAME
        key: APIKEY

Note: $_SERVER['SERVER_ADDR'] value is allowed by default, so no need to include it in the 'allowed_ips' array.

Event listeners

The following events take place when a nats postback is reached:

  • nats_postback.OnAdd.event (ADD)
  • nats_postback.OnManualAdd.event (MANUALADD)
  • nats_postback.OnActivate.event (ACTIVATE)
  • nats_postback.OnChange.event (CHANGE)
  • nats_postback.OnCheck.event (CHECK)
  • nats_postback.OnDelete.event (DELETE)
  • nats_postback.OnExpire.event (EXPIRE)
  • nats_postback.OnTrialToFull.event (TRIALTOFULL)
  • nats_postback.OnRebill.event (REBILL POST)

If you want to register an event listener for any of them:

# YourBundle/Resources/config/services.yml
    ...
    custom_listener_for_nats_onAdd.event_listener:
        class:  YourBundle\EventListener\MyListener
        tags:
            - { name: kernel.event_listener, event: nats_postback.OnAdd.event, method: onAdd }
namespace YourBundle\EventListener;

use Symfony\Component\EventDispatcher\Event;

class MyListener extends Event
{
    public function onAdd(Event $event)
    {
        $params = $event->getParams(); // all params sent by nats
        
        ...

        /* Dont forget to set the response, based on Nats documentation:
            http://tmmwiki.com/index.php/NATS4_Site_User_Management
            OK|message
            NOTOK|message
            ERROR|message
        */
        $event->setResponse('OK');
    }
}

If no response is set in the listener, 'OK' will be the default output.