real-ban-plugin/Plugin.php

158 lines
4.4 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;
2015-03-18 15:14:22 +03:00
use Mibew\Thread;
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');
2015-03-18 15:14:22 +03:00
$dispatcher->attachListener(Events::THREAD_UPDATE, $this, 'handleThreadUpdate');
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
2015-03-18 15:14:22 +03:00
/**
* A handler for {@link \Mibew\EventDispatcher\Events::THREAD_UPDATE} event.
*
* When the thread is added to the awaiting queue the method sends
* notification about ban if it's needed.
*
* @param array $args Event arguments.
*/
public function handleThreadUpdate($args)
{
$thread = $args['thread'];
$orig_thread = $args['original_thread'];
if ($thread->state != $orig_thread->state && $thread->state == Thread::STATE_QUEUE) {
// State is change and the thread is in the awaiting queue now.
$ban = Ban::loadByAddress($thread->remote);
if ($ban && !$ban->isExpired()) {
// Operators could not see the user, because he is banned. A
// notification should be sent to let user know that he is
// banned.
$thread->postMessage(
Thread::KIND_INFO,
getlocal('Sorry, but your IP address is banned by some reasons. Try to use another way to contact the support.')
);
}
}
}
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
}