real-ban-plugin/Plugin.php

128 lines
3.3 KiB
PHP
Raw Normal View History

2014-10-21 14:56:43 +04:00
<?php
/*
* This file is a part of Mibew Real Ban Plugin.
*
2014-10-22 17:32:38 +04:00
* Copyright 2014 Dmitriy Simushev <simushevds@gmail.com>.
2014-10-21 14:56:43 +04:00
*
* 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;
2014-10-22 17:50:37 +04:00
use Mibew\Ban;
2014-10-21 14:56:43 +04:00
use Mibew\EventDispatcher\EventDispatcher;
use Mibew\EventDispatcher\Events;
use Mibew\Plugin\AbstractPlugin;
use Mibew\Plugin\PluginInterface;
use Mibew\Settings;
2014-10-21 14:56:43 +04:00
/**
* 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()
{
if (!Settings::get('enableban')) {
// Bans are disabled. The plugin should do nothing in this case.
return;
}
2014-10-21 14:56:43 +04:00
$dispatcher = EventDispatcher::getInstance();
$dispatcher->attachListener(Events::USERS_UPDATE_THREADS_ALTER, $this, 'alterThreads');
2014-10-22 17:50:37 +04:00
$dispatcher->attachListener(Events::USERS_UPDATE_VISITORS_ALTER, $this, 'alterVisitors');
2014-10-21 14:56:43 +04:00
}
/**
* 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)
{
2014-10-22 17:40:44 +04:00
$threads = array();
foreach ($args['threads'] as $thread) {
2014-10-21 14:56:43 +04:00
if ($thread['ban']) {
2014-10-22 17:40:44 +04:00
// Skip banned threads
continue;
2014-10-21 14:56:43 +04:00
}
2014-10-22 17:40:44 +04:00
$threads[] = $thread;
2014-10-21 14:56:43 +04:00
}
2014-10-22 17:40:44 +04:00
$args['threads'] = $threads;
2014-10-21 14:56:43 +04:00
}
2014-10-22 17:50:37 +04:00
/**
* 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;
}
2014-11-18 15:23:03 +03:00
/**
* Specify version of the plugin.
*
* @return string Plugin's version.
*/
public static function getVersion()
{
2014-12-19 18:24:46 +03:00
return '1.0.0';
2014-11-18 15:23:03 +03:00
}
2014-10-21 14:56:43 +04:00
}