3 namespace Org\Mxchange\CoreFramework\Tests\Controller;
5 // Import framework stuff
6 use Org\Mxchange\CoreFramework\Controller\BaseController;
7 use Org\Mxchange\CoreFramework\Controller\Controller;
8 use Org\Mxchange\CoreFramework\Factory\Object\ObjectFactory;
9 use Org\Mxchange\CoreFramework\Filter\Filterable;
10 use Org\Mxchange\CoreFramework\Request\Requestable;
11 use Org\Mxchange\CoreFramework\Resolver\Command\CommandResolver;
12 use Org\Mxchange\CoreFramework\Response\Responseable;
15 * The default controller with news for e.g. home or news page
17 * @author Roland Haeder <webmaster@shipsimu.org>
19 * @copyright Copyright (c) 2007, 2008 Roland Haeder, 2009 - 2023 Core Developer Team
20 * @license GNU GPL 3.0 or any newer version
21 * @link http://www.shipsimu.org
23 * This program is free software: you can redistribute it and/or modify
24 * it under the terms of the GNU General Public License as published by
25 * the Free Software Foundation, either version 3 of the License, or
26 * (at your option) any later version.
28 * This program is distributed in the hope that it will be useful,
29 * but WITHOUT ANY WARRANTY; without even the implied warranty of
30 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
31 * GNU General Public License for more details.
33 * You should have received a copy of the GNU General Public License
34 * along with this program. If not, see <http://www.gnu.org/licenses/>.
36 class TestsConsoleDefaultNewsController extends BaseController implements Controller {
38 * Protected constructor
42 private function __construct () {
43 // Call parent constructor
44 /* NOISY-DEBUG: */ self::createDebugInstance(__CLASS__, __LINE__)->traceMessage('TEST-CONSOLE-DEFAULT-NEWS-CONTROLLER: CONSTRUCTED!');
45 parent::__construct(__CLASS__);
47 // Init additional filter chains
48 foreach (['bootstrap', 'tests', BaseController::FILTER_CHAIN_SHUTDOWN] as $filterChain) {
50 /* NOISY-DEBUG: */ self::createDebugInstance(__CLASS__, __LINE__)->debugMessage(sprintf('TEST-CONSOLE-DEFAULT-NEWS-CONTROLLER: Initializing filterChain=%s ...', $filterChain));
51 $this->initFilterChain($filterChain);
55 /* NOISY-DEBUG: */ self::createDebugInstance(__CLASS__, __LINE__)->traceMessage('TEST-CONSOLE-DEFAULT-NEWS-CONTROLLER: EXIT!');
59 * Creates an instance of this class
61 * @param $resolverInstance An instance of a command resolver class
62 * @return $controllerInstance A prepared instance of this class
64 public static final function createTestsConsoleDefaultNewsController (CommandResolver $resolverInstance) {
65 // Create the instance
66 /* NOISY-DEBUG: */ self::createDebugInstance(__CLASS__, __LINE__)->traceMessage(sprintf('TEST-CONSOLE-DEFAULT-NEWS-CONTROLLER: resolverInstance=%s - CALLED!', $resolverInstance->__toString()));
67 $controllerInstance = new TestsConsoleDefaultNewsController();
69 // Set the command resolver
70 $controllerInstance->setResolverInstance($resolverInstance);
72 // Add news filters to this controller
73 $controllerInstance->addPreFilter(ObjectFactory::createObjectByConfiguredName('news_download_filter_class'));
74 $controllerInstance->addPreFilter(ObjectFactory::createObjectByConfiguredName('news_process_filter_class'));
76 // Return the prepared instance
77 /* NOISY-DEBUG: */ self::createDebugInstance(__CLASS__, __LINE__)->traceMessage(sprintf('TEST-CONSOLE-DEFAULT-NEWS-CONTROLLER: controllerInstance=%s - EXIT!', $controllerInstance->__toString()));
78 return $controllerInstance;
82 * Handles the given request and response
84 * @param $requestInstance An instance of a request class
85 * @param $responseInstance An instance of a response class
88 public function handleRequest (Requestable $requestInstance, Responseable $responseInstance) {
89 // Get the command instance from the resolver by sending a request instance to the resolver
90 /* NOISY-DEBUG: */ self::createDebugInstance(__CLASS__, __LINE__)->traceMessage(sprintf('TEST-CONSOLE-DEFAULT-NEWS-CONTROLLER: requestInstance=%s,responseInstance=%s - CALLED!', $requestInstance->__toString(), $responseInstance->__toString()));
91 $commandInstance = $this->getResolverInstance()->resolveCommandByRequest($requestInstance);
93 // Add more filters by the command
94 $commandInstance->addExtraFilters($this, $requestInstance);
96 // Run the pre filters
97 $this->executePreFilters($requestInstance, $responseInstance);
99 // This request was valid! :-D
100 /* NOISY-DEBUG: */ self::createDebugInstance(__CLASS__, __LINE__)->debugMessage('TEST-CONSOLE-DEFAULT-NEWS-CONTROLLER: Invoking requestInstance->setIsRequestValid(TRUE) ...');
101 $requestInstance->setIsRequestValid(TRUE);
103 // Execute the command
104 $commandInstance->execute($requestInstance, $responseInstance);
106 // Run the post filters
107 $this->executePostFilters($requestInstance, $responseInstance);
109 // Flush the response out
110 /* NOISY-DEBUG: */ self::createDebugInstance(__CLASS__, __LINE__)->traceMessage('TEST-CONSOLE-DEFAULT-NEWS-CONTROLLER: Invoking responseInstance->flushBuffer() ...');
111 $responseInstance->flushBuffer();
114 /* NOISY-DEBUG: */ self::createDebugInstance(__CLASS__, __LINE__)->traceMessage('TEST-CONSOLE-DEFAULT-NEWS-CONTROLLER: EXIT!');
118 * Add a bootstrap filter
120 * @param $filterInstance A Filterable class
123 public function addBootstrapFilter (Filterable $filterInstance) {
124 $this->addFilter('bootstrap', $filterInstance);
130 * @param $filterInstance A Filterable class
133 public function addTestsFilter (Filterable $filterInstance) {
134 $this->addFilter('tests', $filterInstance);
138 * Executes all bootstrap filters
140 * @param $requestInstance A Requestable class
141 * @param $responseInstance A Responseable class
144 public function executeBootstrapFilters (Requestable $requestInstance, Responseable $responseInstance) {
145 $this->executeFilters('bootstrap', $requestInstance, $responseInstance);
149 * Executes all tests filters
151 * @param $requestInstance A Requestable class
152 * @param $responseInstance A Responseable class
155 public function executeTestsFilters (Requestable $requestInstance, Responseable $responseInstance) {
156 $this->executeFilters('tests', $requestInstance, $responseInstance);