* @version 0.0.0 * @copyright Copyright (c) 2007, 2008 Roland Haeder, 2009 - 2011 Hub Developer Team * @license GNU GPL 3.0 or any newer version * @link http://www.ship-simu.org * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ class HubMasterNode extends BaseHubNode implements NodeHelper, Registerable { /** * Protected constructor * * @return void */ protected function __construct () { // Call parent constructor parent::__construct(__CLASS__); } /** * Creates an instance of this hub-node class * * @param $requestInstance An instance of a Requestable class * @return $nodeInstance An instance of this hub-node class */ public static final function createHubMasterNode (Requestable $requestInstance) { // Get a new instance $nodeInstance = new HubMasterNode(); // Set the request instance $nodeInstance->setRequestInstance($requestInstance); // Return the instance return $nodeInstance; } /** * Method to "bootstrap" the node. This step does also apply provided * command-line arguments stored in the request instance. The regular node * should communicate with the bootstrap-nodes at this point. * * @return void * @todo Implement this method */ public function doBootstrapping () { $this->partialStub(); } /** * Initializes hub-specific queues * * @return void * @todo Unfinished method */ public function initQueues () { // Call generic queues every hub may have, like the core queue parent::initGenericQueues(); $this->partialStub('Please add some more hub-specific queues.'); } /** * Add some node-specific filters * * @return void */ public function addExtraNodeFilters () { // Get the application instance from registry $applicationInstance = Registry::getRegistry()->getInstance('app'); // Get the controller from the application $controllerInstance = $applicationInstance->getControllerInstance(); // Self-announcement task $controllerInstance->addActivationFilter(ObjectFactory::createObjectByConfiguredName('node_activation_self_announcement_task_filter')); // @TODO Add some filters here $this->partialStub('Add some filters here.'); } } // [EOF] ?>