Source code for tornado_websockets.exceptions

# coding: utf-8


[docs]class TornadoWebSocketsError(Exception): """ Base exception of all django-tornado-websockets exceptions. """ pass
[docs]class WebSocketEventAlreadyBinded(TornadoWebSocketsError, NameError): """ Exception thrown when an user try to bind an already existing event for a given path. * ``event`` - name of the event under investigation. * ``path`` - path where the offence have taken place. """ def __init__(self, event, path): self.event = event self.path = path super(WebSocketEventAlreadyBinded, self).__init__(event, path) def __str__(self): return 'The event "%s" is already binded for "%s" path.' % (self.event, self.path)
[docs]class InvalidInstanceError(TornadoWebSocketsError, TypeError): """ Exception thrown when an instance is not the expected one. * ``actual_instance`` - actual instance which is trying to appear as ``expected_instance_name``. * ``expected_instance_name`` - name of expected instance. """ def __init__(self, actual_instance, expected_instance_name): self.actual_instance = actual_instance self.expected_instance_name = expected_instance_name super(InvalidInstanceError, self).__init__(actual_instance, expected_instance_name) def __str__(self): return 'Expected instance of "%s", got "%s" instead.' % ( self.expected_instance_name, repr(self.actual_instance) )
[docs]class EmitHandlerError(TornadoWebSocketsError): """ Exception thrown when an user try to emit an event without being in a function or class method decorated by :meth:`@WebSocket.on() <tornado_websockets.websocket.WebSocket.on>` decorator. * ``event`` - name of the event under investigation. * ``path`` - path where the offence have taken place. """ def __init__(self, event, path): self.event = event self.path = path super(EmitHandlerError, self).__init__(event, path) def __str__(self): return 'Can not emit "%s" event in "%s" path, emit() should be used in a function or class method' \ ' decorated by @WebSocket.on decorator.' % (self.event, self.path)
[docs]class NotCallableError(TornadoWebSocketsError): """ Exception thrown when an user try to use a decorator on a non-callable thing. * ``thing`` - « The Thing ». """ def __init__(self, thing): self.thing = thing super(NotCallableError, self).__init__(thing) def __str__(self): return 'Used @WebSocket.on decorator on a thing that is not callable, got: "%s".' % self.thing