2011-12-27 13:58:28 +01:00
|
|
|
<?php
|
2013-01-26 22:46:54 +01:00
|
|
|
namespace chat\system\command;
|
2011-12-27 13:58:28 +01:00
|
|
|
use \wcf\util\StringUtil;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Handles commands
|
2014-02-28 17:06:50 +01:00
|
|
|
*
|
2011-12-27 13:58:28 +01:00
|
|
|
* @author Tim Düsterhus
|
2014-02-27 23:05:09 +01:00
|
|
|
* @copyright 2010-2014 Tim Düsterhus
|
2011-12-27 13:58:28 +01:00
|
|
|
* @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
|
2013-01-19 20:36:40 +01:00
|
|
|
* @package be.bastelstu.chat
|
2012-03-24 22:37:47 +01:00
|
|
|
* @subpackage system.chat.command
|
2011-12-27 13:58:28 +01:00
|
|
|
*/
|
2012-02-04 12:32:56 +01:00
|
|
|
final class CommandHandler {
|
2012-10-20 16:23:00 +02:00
|
|
|
/**
|
|
|
|
* char that indicates a command
|
2013-06-17 23:48:59 +02:00
|
|
|
* @var string
|
2012-10-20 16:23:00 +02:00
|
|
|
*/
|
2011-12-27 13:58:28 +01:00
|
|
|
const COMMAND_CHAR = '/';
|
2012-10-20 16:23:00 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* message text
|
2013-06-17 23:48:59 +02:00
|
|
|
* @var string
|
2012-10-20 16:23:00 +02:00
|
|
|
*/
|
2012-02-04 12:32:56 +01:00
|
|
|
private $text = '';
|
2011-12-27 13:58:28 +01:00
|
|
|
|
2013-03-11 17:17:58 +01:00
|
|
|
/**
|
|
|
|
* current room
|
2013-06-17 23:48:59 +02:00
|
|
|
* @var \chat\data\room\Room
|
2013-03-11 17:17:58 +01:00
|
|
|
*/
|
|
|
|
private $room = null;
|
|
|
|
|
2011-12-27 13:58:28 +01:00
|
|
|
/**
|
|
|
|
* Initialises the CommandHandler
|
|
|
|
*
|
2013-03-11 17:17:58 +01:00
|
|
|
* @param string $text
|
|
|
|
* @param \chat\data\room\Room $room
|
2011-12-27 13:58:28 +01:00
|
|
|
*/
|
2013-03-11 17:17:58 +01:00
|
|
|
public function __construct($text, \chat\data\room\Room $room = null) {
|
2011-12-27 13:58:28 +01:00
|
|
|
$this->text = $text;
|
2013-03-11 17:17:58 +01:00
|
|
|
$this->room = $room;
|
2013-06-17 23:56:28 +02:00
|
|
|
|
|
|
|
$aliases = self::getAliasMap();
|
|
|
|
foreach ($aliases as $search => $replace) {
|
2013-06-18 00:13:24 +02:00
|
|
|
$this->text = \wcf\system\Regex::compile('^'.preg_quote(self::COMMAND_CHAR.$search).'( |$)')->replace($this->text, self::COMMAND_CHAR.$replace.' ');
|
2013-06-17 23:56:28 +02:00
|
|
|
}
|
2013-06-18 00:13:24 +02:00
|
|
|
|
|
|
|
$this->text = \wcf\system\Regex::compile('^//')->replace($this->text, '/plain ');
|
2011-12-27 13:58:28 +01:00
|
|
|
}
|
|
|
|
|
2013-06-17 23:48:59 +02:00
|
|
|
/**
|
|
|
|
* Returns the alias map. Key is the alias, value is the target.
|
|
|
|
*
|
|
|
|
* @return array<string>
|
|
|
|
*/
|
|
|
|
public static function getAliasMap() {
|
2014-03-10 18:32:56 +01:00
|
|
|
if (StringUtil::trim(CHAT_COMMAND_ALIASES) === '') return array();
|
|
|
|
|
2013-10-01 00:16:19 +02:00
|
|
|
try {
|
|
|
|
$result = array();
|
|
|
|
foreach (explode("\n", StringUtil::unifyNewlines(StringUtil::toLowerCase(CHAT_COMMAND_ALIASES))) as $line) {
|
|
|
|
list($key, $val) = explode(':', $line, 2);
|
|
|
|
|
2014-03-10 18:32:56 +01:00
|
|
|
$result[StringUtil::trim($key)] = StringUtil::trim($val);
|
2013-10-01 00:16:19 +02:00
|
|
|
}
|
2013-06-17 23:48:59 +02:00
|
|
|
|
2013-10-01 00:16:19 +02:00
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
catch (\wcf\system\exception\SystemException $e) {
|
|
|
|
throw new \wcf\system\exception\SystemException("Invalid alias specified: '".$line."'");
|
2013-06-17 23:48:59 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-12-27 13:58:28 +01:00
|
|
|
/**
|
|
|
|
* Checks whether the given text is a command.
|
|
|
|
*/
|
|
|
|
public function isCommand($text = null) {
|
|
|
|
if ($text === null) $text = $this->text;
|
2012-10-20 16:23:00 +02:00
|
|
|
|
|
|
|
return StringUtil::startsWith($text, static::COMMAND_CHAR);
|
2011-12-27 13:58:28 +01:00
|
|
|
}
|
|
|
|
|
2012-02-04 12:32:56 +01:00
|
|
|
/**
|
|
|
|
* Returns the whole message.
|
2014-02-28 17:06:50 +01:00
|
|
|
*
|
2012-02-04 12:32:56 +01:00
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getText() {
|
|
|
|
return $this->text;
|
|
|
|
}
|
|
|
|
|
2013-03-11 17:17:58 +01:00
|
|
|
/**
|
|
|
|
* Returns the current room.
|
|
|
|
*
|
|
|
|
* @return \chat\data\room\Room
|
|
|
|
*/
|
|
|
|
public function getRoom() {
|
|
|
|
return $this->room;
|
|
|
|
}
|
|
|
|
|
2011-12-27 14:32:28 +01:00
|
|
|
/**
|
|
|
|
* Returns the parameter-string.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getParameters() {
|
2013-08-19 23:23:26 +02:00
|
|
|
$parts = explode(' ', mb_substr($this->text, mb_strlen(static::COMMAND_CHAR)), 2);
|
2011-12-27 14:32:28 +01:00
|
|
|
|
2012-02-04 12:32:56 +01:00
|
|
|
if (!isset($parts[1])) return '';
|
2011-12-27 14:32:28 +01:00
|
|
|
return $parts[1];
|
|
|
|
}
|
|
|
|
|
2011-12-27 13:58:28 +01:00
|
|
|
/**
|
|
|
|
* Loads the command.
|
|
|
|
*/
|
|
|
|
public function loadCommand() {
|
2013-08-19 23:23:26 +02:00
|
|
|
$parts = explode(' ', mb_substr($this->text, mb_strlen(static::COMMAND_CHAR)), 2);
|
2011-12-27 13:58:28 +01:00
|
|
|
|
2013-01-26 22:46:54 +01:00
|
|
|
$class = '\chat\system\command\commands\\'.ucfirst(strtolower($parts[0])).'Command';
|
2011-12-27 13:58:28 +01:00
|
|
|
if (!class_exists($class)) {
|
2013-06-18 00:28:56 +02:00
|
|
|
throw new NotFoundException($parts[0]);
|
2011-12-27 13:58:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return new $class($this);
|
|
|
|
}
|
|
|
|
}
|