joomla / controller
Joomla Controller Package
Installs: 86 197
Dependents: 4
Suggesters: 1
Security: 0
Stars: 2
Watchers: 14
Forks: 6
Open Issues: 0
Type:joomla-package
pkg:composer/joomla/controller
Requires
- php: ^8.3.0
Requires (Dev)
- joomla/application: ^4.0
- joomla/input: ^4.0
- phpstan/phpstan: ^2.1.17
- phpstan/phpstan-deprecation-rules: ^2.0.3
- phpunit/phpunit: ^12.0
- squizlabs/php_codesniffer: ~3.10.2
Suggests
- joomla/application: The joomla/application package is required to use Joomla\Controller\AbstractController
- joomla/input: The joomla/input package is required to use Joomla\Controller\AbstractController
This package is auto-updated.
Last update: 2025-10-15 12:10:39 UTC
README
Interfaces
Controller\ControllerInterface
Controller\ControllerInterface is an interface that requires a class to be implemented with the following methods:
- execute
- getApplication
- getInput
- setApplication
- setInput
Classes
Controller\AbstractController
Construction
The constructor for Controller\AbstractController takes an optional Joomla\Input\Input object and an optional Joomla\Application\AbstractApplication object. One or the other can be omitted but using getApplication or getInput without setting them will throw an exception.
Usage
The Controller\AbstractController class is abstract so cannot be used directly. The derived class must implement the execute method to satisfy the interface requirements. Note that the execute method no longer takes a "task" argument as each controller class. Multi-task controllers are still possible by overriding the execute method in derived classes. Each controller class should do just one sort of 'thing', such as saving, deleting, checking in, checking out and so on. However, controllers, or even models and views, have the liberty of invoking other controllers to allow for HMVC architectures.
namespace Examples; use Joomla\Application; use Joomla\Input; /** * My custom controller. * * @since 1.0 */ class MyController extends Controller\Base { /** * Executes the controller. * * @return void * * @since 1.0 * @throws \RuntimeException */ public function execute() { echo time(); } } // We'll assume we've already defined an application in this namespace. $app = new ExampleApplication; $input = new Input\Input; // Instantiate the controller. $controller = new MyController($input, $app); // Print the time. $controller->execute();
Serialization
The Controller\AbstractController class implements Serializable. When serializing, only the input property is serialized. When unserializing, the input variable is unserialized and the internal application property is loaded at runtime.
Installation via Composer
Add "joomla/controller": "~3.0" to the require block in your composer.json and then run composer install.
{
	"require": {
		"joomla/controller": "~3.0"
	}
}
Alternatively, you can simply run the following from the command line:
composer require joomla/controller "~3.0"
If you want to include the test sources, use
composer require --prefer-source joomla/controller "~3.0"