Working with Controllers

IRequestHandler interface

When web application receives request from web server, it will be given request uri of resource that user is requesting. Dispatcher parses request uri to find matching route handler that will handle this request. If no handler available to handle it, HTTP 404 will be returned.

Interface IRequestHandler, declared in unit fano.pas, is basis of request handler implementation in Fano Framework. It consists of handleRequest() method that implementor class must provide.

function handleRequest(
    const request : IRequest;
    const response : IResponse;
    const args : IRouteArgsReader
) : IResponse;
  • request, current request object
  • response, response object
  • args, current route arguments. Read Working with Router for more information about purpose of this object.

handleRequest() should return instance of response that will be used as response to request. You can return response given by dispatcher or create entirely new response instance.

Fano Framework provides TAbstractController as base abstract class that implements IRequestHandler and also base controller in TController class which derived from TAbstractController class.

TAbstractController is an abstract class. You need to derive and implements its handleRequest() method to be able to use it. This class is useful, for example, in following situation:

  • you do not need to use view
  • you prefer to compose response by yourself, for example, to output JPEG image response.

TController is concrete class. It extends TAbstractController capability by adding view and view parameters to allow, for example, to use template.

But of course, you are free to implements your own. In fact, you are not required to use TAbstractController or TController at all. You can use any class as long as it implements IRequestHandler interface.

Using TController class

TController class is built-in class that provides ability for route handler to works with view and view parameters.

Except for simple route handler which display static view, very likely, you need to extend this class. TController by default, just calls render() method of IView, which is returning response from IView instance.

Creating TController class

TController constructor expects 2 parameters

constructor TController.create(
    const viewInst : IView;
    const viewParamsInst : IViewParameters
  • viewInst, view to be used, i.e., instance of class that implements IView interface.
  • ViewParamsInst, view parameters, i.e., instance of class that implements IViewParameters interface.

viewInst and viewParamsInst that you pass during class construction, will be available from inherited class as fView and fViewParams fields, respectively.

For more information regarding view and view parameters, read Working with Views.

Implements controller logic

handleRequest() is method that will be invoked by dispatcher to handle request, so you mostly do not call it directly. This method is part of IRequestHandler interface. Dispatcher will pass request and response instance to this method.

TController class provides basic implementation of this method, which is, to return view output. Fano Framework provides some built-in response class that you can use such HTML response, JSON response or binary response (for example to output image). Of course, you are free to implements your own output response.

Explore more