Abstract controller class. Controllers should only be created using a Request.
Controllers methods will be automatically called in the following order by the request:
$controller = new Controller_Foo($request);
$controller->before();
$controller->action_bar();
$controller->after();
The controller action should add the output it creates to
$this->response->body($output), typically in the form of a View, during the
"action" part of execution.
Class declared in APPPATH/classes/controller/welcome.php on line 3.
Request $requestRequest that created the controller
Response $responseThe response that will be returned from controller
public function action_index()
{
	$this->response->body('hello, world!');
}Creates a new controller instance. Each controller must be constructed with the request object that created it.
Request
$request
required - Request that created the controllerResponse
$response
required - The request's responsevoidpublic function __construct(Request $request, Response $response)
{
	// Assign the request to the controller
	$this->request = $request;
	// Assign a response to the controller
	$this->response = $response;
}Automatically executed after the controller action. Can be used to apply transformation to the request response, add extra output, and execute other custom code.
voidpublic function after()
{
	// Nothing by default
}Automatically executed before the controller action. Can be used to set class properties, do authorization checks, and execute other custom code.
voidpublic function before()
{
	// Nothing by default
}