phergie/phergie-irc-plugin-react-eventfilter

This package is abandoned and no longer maintained. No replacement package was suggested.

Phergie plugin for limiting processing of incoming events based on event metadata

2.2.0 2018-09-08 01:24 UTC

This package is not auto-updated.

Last update: 2020-03-15 05:12:10 UTC


README

This repo is being kept for posterity and will be archived in a readonly state. If you're interested it can be forked under a new Composer namespace/GitHub organization.

phergie/phergie-irc-plugin-react-eventfilter

Phergie plugin for limiting processing of incoming events based on event metadata.

Install

The recommended method of installation is through composer.

composer require phergie/phergie-irc-plugin-react-eventfilter

See Phergie documentation for more information on installing and enabling plugins.

Configuration

new \Phergie\Irc\Plugin\React\EventFilter\Plugin(array(

    // All configuration is required

    // Analogous to 'plugins' setting in bot configuration
    // All elements must implement \Phergie\Irc\Bot\React\PluginInterface
    'plugins' => array(
        // ...
    ),

    // Must reference an object that implements
    // \Phergie\Irc\Plugin\React\EventFilter\FilterInterface
    'filter' => new FooFilter,

))

The 'plugins' setting specifies a list of one or more plugins for which event processing will be limited.

The 'filter' setting specifies an object that determines which events will be forwarded to the plugins referenced by the 'plugins' setting.

Usage

This is an example bot configuration that includes the EventFilter plugin:

use Phergie\Irc\Connection;
use Phergie\Irc\Plugin\React\AutoJoin\Plugin as AutoJoinPlugin;
use Phergie\Irc\Plugin\React\EventFilter as Filters;
use Phergie\Irc\Plugin\React\EventFilter\Plugin as EventFilterPlugin;
use Phergie\Irc\Plugin\React\JoinPart\Plugin as JoinPartPlugin;
use Phergie\Irc\Plugin\React\Pong\Plugin as PongPlugin;
use Phergie\Irc\Plugin\React\Quit\Plugin as QuitPlugin;
use Phergie\Irc\Plugin\React\UserMode\Plugin as UserModePlugin;

// These objects are instantiated and assigned to variables here because they
// are referenced multiple times later in the configuration array.
$connection1 = new Connection(array(
    // ...
));
$userModePlugin = new UserModePlugin;

return array(

    'connections' => array(

        $connection1,

        new Connection(array(
            // ...
        ))

    ),

    'plugins' => array(

        // These plugins apply to all connections.
        new PongPlugin,
        $userModePlugin,

        // Because of the applied ConnectionFilter, the bot will automatically
        // join #channel1 only on $connection1.
        new EventFilterPlugin(array(
            'filter' => new Filters\ConnectionFilter(array($connection1)),
            'plugins' => array(
                new AutoJoinPlugin(array('channels' => '#channel1')),
            ),
        )),

        // Because of the applied UserModeFilter, in order to request that the
        // bot join or part a channel, the requesting user must have the op
        // mode in that channel.
        new EventFilterPlugin(array(
            'filter' => new Filters\UserModeFilter($userModePlugin, array('o')),
            'plugins' => array(
                new JoinPartPlugin,
            ),
        )),

        // Because of the applied UserFilter, only the user with the specified
        // user mask will be able to request that the bot terminate its
        // connection to a server.
        new EventFilterPlugin(array(
            'filter' => new Filters\UserFilter(array('nick1!user1@host1')),
            'plugins' => array(
                new QuitPlugin,
            ),
        )),

    ),

);

Supported Filters

All filters supported by this plugin are under the \Phergie\Irc\Plugin\React\EventFilter namespace.

Metadata Filters

These filters are based on metadata for incoming events.

ChannelFilter

Allows events that are either not channel-specific or originate from one of a specified list of channels.

new ChannelFilter(array(

    '#channel1',
    '&channel2',
    // ...

))

ConnectionFilter

Allows events that originate from one of a specified list of connections represented by objects that implement \Phergie\Irc\ConnectionInterface.

new ConnectionFilter(array(

    new \Phergie\Irc\Connection(array(
        // ...
    )),

    // ...
))

UserFilter

Allows events that are either not user-specific or originate from one of a specified list of users identified by strings containing user masks.

new UserFilter(array(

    'nick1!username1@host1',
    'nick2!username2@host2',
    // ...

))

UserModeFilter

Allows events that are either not user-specific or originate from users with any of a specified list of modes within the channel in which the events occur. This mode information is obtained using the UserMode plugin.

new UserModeFilter(

    // Pre-configured instance of \Phergie\Irc\Plugin\React\UserMode\Plugin
    $userMode,

    // List of letters corresponding to user modes for which to allow events
    array('o', 'v')

)

Common mode values:

  • q - owner
  • a - admin
  • o - op
  • h - halfop
  • v - voice

Boolean Filters

These filters are applied to other filters to combine or change their results in some way.

AndFilter

Allows events that pass all contained filters, equivalent to the boolean "and" operator.

new AndFilter(array(
    new ConnectionFilter(array($connection)),
    new ChannelFilter(array('#channel1', '&channel2')),
))

This example allows events that occur both within the specified channels and on the specified connection.

OrFilter

Allows events that pass any contained filters, equivalent to the boolean "or" operator.

new AndFilter(array(
    new UserFilter(array('nick1!user1@host1')),
    new UserModeFilter($userModePlugin, array('o')),
))

This example allows events that are initiated by a user either identified by the specified user mask or with the op user mode.

NotFilter

Allows events that do not pass the contained filter, equivalent to the boolean "not" operator.

new NotFilter(
    new UserFilter(array('nick1!user1@host1'))
)

This example allows events that do not originate from the user identified by the specified user mask, effectively functioning as a ban list with respect to functionality of the EventFilter plugin's contained plugins.

Custom Filters

Filters are merely classes that implement FilterInterface. This interface has a single method, filter(), which accepts an event object that implements EventInterface as its only parameter and returns one of the following values:

  • true if the event should be allowed
  • false if the event should be denied
  • null if the event should be ignored by the filter ("pass-through")

Tests

To run the unit test suite:

curl -s https://getcomposer.org/installer | php
php composer.phar install
./vendor/bin/phpunit

License

Released under the BSD License. See LICENSE.