real-ban-plugin/Plugin.php
2014-12-19 15:24:46 +00:00

122 lines
3.1 KiB
PHP

<?php
/*
* This file is a part of Mibew Real Ban Plugin.
*
* Copyright 2014 Dmitriy Simushev <simushevds@gmail.com>.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @file The main file of Mibew:RealBan plugin.
*/
namespace Mibew\Mibew\Plugin\RealBan;
use Mibew\Ban;
use Mibew\EventDispatcher\EventDispatcher;
use Mibew\EventDispatcher\Events;
use Mibew\Plugin\AbstractPlugin;
use Mibew\Plugin\PluginInterface;
/**
* The main plugin's file definition.
*
* It only attaches handlers to some events.
*/
class Plugin extends AbstractPlugin implements PluginInterface
{
/**
* The plugin does not need extra initialization thus it is always ready to
* work.
*
* @return boolean
*/
public function initialized()
{
return true;
}
/**
* The main entry point of a plugin.
*/
public function run()
{
$dispatcher = EventDispatcher::getInstance();
$dispatcher->attachListener(Events::USERS_UPDATE_THREADS_ALTER, $this, 'alterThreads');
$dispatcher->attachListener(Events::USERS_UPDATE_VISITORS_ALTER, $this, 'alterVisitors');
}
/**
* Specify dependencies of the plugin.
*
* @return array List of dependencies
*/
public static function getDependencies()
{
// This plugin does not depend on others so return an empty array.
return array();
}
/**
* A handler for
* {@link \Mibew\EventDispatcher\Events::USERS_UPDATE_THREADS_ALTER} event.
*
* @param array $args Event arguments.
*/
public function alterThreads(&$args)
{
$threads = array();
foreach ($args['threads'] as $thread) {
if ($thread['ban']) {
// Skip banned threads
continue;
}
$threads[] = $thread;
}
$args['threads'] = $threads;
}
/**
* A handler for
* {@link \Mibew\EventDispatcher\Events::USERS_UPDATE_VISITORS_ALTER} event.
*
* @param array $args Event arguments.
*/
public function alterVisitors(&$args)
{
$visitors = array();
foreach ($args['visitors'] as $visitor) {
$ban = Ban::loadByAddress($visitor['userIp']);
if ($ban && !$ban->isExpired()) {
// Skip banned visitors
continue;
}
$visitors[] = $visitor;
}
$args['visitors'] = $visitors;
}
/**
* Specify version of the plugin.
*
* @return string Plugin's version.
*/
public static function getVersion()
{
return '1.0.0';
}
}