Source code for ding.interaction.exception.slave

from abc import ABCMeta
from enum import unique, IntEnum
from typing import Type

import enum_tools
from requests import HTTPError

from .base import ResponseException
from ..base import get_values_from_response


@enum_tools.documentation.document_enum
@unique
class SlaveErrorCode(IntEnum):
    """
    Overview:
        Error code for slave end
    """
    SUCCESS = 0  # doc: Slave request success

    SYSTEM_SHUTTING_DOWN = 101  # doc: Slave end is shutting down

    CHANNEL_NOT_FOUND = 201  # doc: No channel id given in request
    CHANNEL_INVALID = 202  # doc: Channel id given not match with slave end

    MASTER_TOKEN_NOT_FOUND = 301  # doc: No master token found in connection request from master
    MASTER_TOKEN_INVALID = 302  # doc: Master token auth failed in slave end

    SELF_TOKEN_NOT_FOUND = 401  # doc: No self token given in self request (such as ping, shutdown)
    SELF_TOKEN_INVALID = 402  # doc: Self token auth failed in slave end itself (such as ping, shutdown)

    SLAVE_ALREADY_CONNECTED = 501  # doc: Slave end has already connected to another master end
    SLAVE_NOT_CONNECTED = 502  # doc: Slave end not connected with master end yey
    SLAVE_CONNECTION_REFUSED = 503  # doc: Connection to slave end refused
    SLAVE_DISCONNECTION_REFUSED = 504  # doc: Disconnection to slave end refused

    TASK_ALREADY_EXIST = 601  # doc: Slave end is processing another task
    TASK_REFUSED = 602  # doc: Task for slave end refused


# noinspection DuplicatedCode
[docs]class SlaveResponseException(ResponseException, metaclass=ABCMeta): """ Overview: Response exception for slave client """
[docs] def __init__(self, error: HTTPError): """ Overview: Constructor Arguments: - error (:obj:`HTTPError`): Original http exception object """ ResponseException.__init__(self, error)
[docs]class SlaveSuccess(SlaveResponseException): pass
[docs]class SlaveSystemShuttingDown(SlaveResponseException): pass
[docs]class SlaveChannelNotFound(SlaveResponseException): pass
[docs]class SlaveChannelInvalid(SlaveResponseException): pass
[docs]class SlaveMasterTokenNotFound(SlaveResponseException): pass
[docs]class SlaveMasterTokenInvalid(SlaveResponseException): pass
[docs]class SlaveSelfTokenNotFound(SlaveResponseException): pass
[docs]class SlaveSelfTokenInvalid(SlaveResponseException): pass
[docs]class SlaveSlaveAlreadyConnected(SlaveResponseException): pass
[docs]class SlaveSlaveNotConnected(SlaveResponseException): pass
[docs]class SlaveSlaveConnectionRefused(SlaveResponseException): pass
[docs]class SlaveSlaveDisconnectionRefused(SlaveResponseException): pass
[docs]class SlaveTaskAlreadyExist(SlaveResponseException): pass
[docs]class SlaveTaskRefused(SlaveResponseException): pass
_PREFIX = ['slave']
[docs]def get_slave_exception_class_by_error_code(error_code: SlaveErrorCode) -> Type[SlaveResponseException]: """ Overview: Transform from slave error code to `SlaveResponseException` class Arguments: - error_code (:obj:`SlaveErrorCode`): Slave error code Returns: - exception_class (:obj:`Type[SlaveResponseException`): Slave response exception class """ class_name = ''.join([word.lower().capitalize() for word in (_PREFIX + error_code.name.split('_'))]) return eval(class_name)
[docs]def get_slave_exception_by_error(error: HTTPError) -> SlaveResponseException: """ Overview: Auto transform http error object to slave response exception object. Arguments: - error (:obj:`HTTPError`): Http error object Returns: - exception (:obj:`SlaveResponseException`): Slave response exception object """ _, _, code, _, _ = get_values_from_response(error.response) error_code = {v.value: v for k, v in SlaveErrorCode.__members__.items()}[code] return get_slave_exception_class_by_error_code(error_code)(error)