Source code for cement.core.controller

"""Cement core controller module."""

from abc import abstractmethod
from ..core.interface import Interface
from ..core.handler import Handler
from ..utils.misc import minimal_logger

LOG = minimal_logger(__name__)


[docs] class ControllerInterface(Interface): """ This class defines the Controller Interface. Handlers that implement this interface must provide the methods and attributes defined below. In general, most implementations should sub-class from the provided :class:`ControllerHandler` base class as a starting point. """
[docs] class Meta: """Interface meta-data.""" #: The string identifier of the interface. interface = 'controller'
[docs] @abstractmethod def _dispatch(self): """ Reads the application object's data to dispatch a command from this controller. For example, reading ``self.app.pargs`` to determine what command was passed, and then executing that command function. Note that Cement does *not* parse arguments when calling ``_dispatch()`` on a controller, as it expects the controller to handle parsing arguments (I.e. ``self.app.args.parse()``). Returns: unknown: The result of the executed controller function, or ``None`` if no controller function is called. """ pass # pragma: nocover
[docs] class ControllerHandler(ControllerInterface, Handler): """Controller handler implementation.""" pass # pragma: nocover