* @package be.bastelstu.chat * @subpackage system.chat.command */ final class CommandHandler { /** * char that indicates a command * @var string */ const COMMAND_CHAR = '/'; /** * message text * @var string */ private $text = ''; /** * current room * @var \chat\data\room\Room */ private $room = null; /** * Initialises the CommandHandler * * @param string $text * @param \chat\data\room\Room $room */ public function __construct($text, \chat\data\room\Room $room = null) { $this->text = $text; $this->room = $room; } /** * Returns the alias map. Key is the alias, value is the target. * * @return array */ public static function getAliasMap() { $result = array(); foreach (explode("\n", StringUtil::unifyNewlines(StringUtil::toLowerCase(CHAT_COMMAND_ALIASES))) as $line) { list($key, $val) = explode(':', $line, 2); $result[$key] = $val; } return $result; } /** * Checks whether the given text is a command. */ public function isCommand($text = null) { if ($text === null) $text = $this->text; return StringUtil::startsWith($text, static::COMMAND_CHAR); } /** * Returns the whole message. * * @return string */ public function getText() { return $this->text; } /** * Returns the current room. * * @return \chat\data\room\Room */ public function getRoom() { return $this->room; } /** * Returns the parameter-string. * * @return string */ public function getParameters() { $parts = explode(' ', StringUtil::substring($this->text, StringUtil::length(static::COMMAND_CHAR)), 2); if (!isset($parts[1])) return ''; return $parts[1]; } /** * Loads the command. */ public function loadCommand() { $parts = explode(' ', StringUtil::substring($this->text, StringUtil::length(static::COMMAND_CHAR)), 2); if ($this->isCommand($parts[0])) { return new commands\PlainCommand($this); } $aliases = self::getAliasMap(); if (isset($aliases[$parts[0]])) $parts[0] = $aliases[$parts[0]]; $class = '\chat\system\command\commands\\'.ucfirst(strtolower($parts[0])).'Command'; if (!class_exists($class)) { throw new NotFoundException(); } return new $class($this); } }