initialiseHandlers(); } /** * Do I have a specific task handling method? * * @param string $method The method to check for * * @return bool */ public function hasMethod($method) { $method = strtolower($method); return isset($this->handlers[$method]); } /** * Execute a JSON API method * * @param string $method The method's name * @param array $parameters The parameters to the method (optional) * * @return mixed * * @throws \RuntimeException When the method requested is not known to us */ public function execute($method, $parameters = array()) { if (!$this->hasMethod($method)) { throw new \RuntimeException("Invalid method $method", 405); } $method = strtolower($method); return $this->handlers[$method]->execute($parameters); } /** * Initialises the encapsulation handlers * * @return void */ protected function initialiseHandlers() { // Reset the array $this->handlers = array(); // Look all files in the Task handlers' directory $dh = new \DirectoryIterator(__DIR__ . '/Task'); /** @var \DirectoryIterator $entry */ foreach ($dh as $entry) { $fileName = $entry->getFilename(); // Ignore non-PHP files if (substr($fileName, -4) != '.php') { continue; } // Ignore the Base class if ($fileName == 'Base.php') { continue; } // Get the class name $className = '\\Solo\\Model\\Json\\Task\\' . substr($fileName, 0, -4); // Check if the class really exists if (!class_exists($className, true)) { continue; } /** @var TaskInterface $o */ $o = new $className; $name = $o->getMethodName(); $name = strtolower($name); $this->handlers[$name] = $o; } } }