Skip to content

Ksoft

API models for the ksoft endpoint.

GetKSoftBanResponse

A model response from ravyapi.api.endpoints.ksoft.KSoft.get_ban.

Attributes

data : dict[str, Any] The raw data returned from the Ravy API. found: bool Whether the user was found in the database. user_id : int | None The user's ID, if found. tag : str | None The user's tag, if found. reason : str | None Reason for the ban, if found. proof : str | None Evidence for the ban, if found. moderator : int | None User ID of the responsible moderator, if found. severe : bool | None Whether the ban is severe, if found. timestamp : str | None A timestamp of the ban, if found.

Source code in ravyapi/api/models/ksoft.py
class GetKSoftBanResponse:
    """A model response from `ravyapi.api.endpoints.ksoft.KSoft.get_ban`.

    Attributes
    ----------
    data : dict[str, Any]
        The raw data returned from the Ravy API.
    found: bool
        Whether the user was found in the database.
    user_id : int | None
        The user's ID, if found.
    tag : str | None
        The user's tag, if found.
    reason : str | None
        Reason for the ban, if found.
    proof : str | None
        Evidence for the ban, if found.
    moderator : int | None
        User ID of the responsible moderator, if found.
    severe : bool | None
        Whether the ban is severe, if found.
    timestamp : str | None
        A timestamp of the ban, if found.
    """

    __slots__: tuple[str, ...] = (
        "_data",
        "_found",
        "_user_id",
        "_tag",
        "_reason",
        "_proof",
        "_moderator",
        "_severe",
        "_timestamp",
    )

    def __init__(self, data: dict[str, Any]) -> None:
        self._data: dict[str, Any] = data
        self._found: bool = data["found"]
        user_id: str | None = data.get("id")
        self._user_id: int | None = int(user_id) if user_id else None
        self._tag: str | None = data.get("tag")
        self._reason: str | None = data.get("reason")
        self._proof: str | None = data.get("proof")
        moderator: str | None = data.get("moderator")
        self._moderator: int | None = int(moderator) if moderator else None
        self._severe: bool | None = data.get("severe")
        self._timestamp: str | None = data.get("timestamp")

    def __repr__(self) -> str:
        return (
            f"{self.__class__.__module__}.{self.__class__.__qualname__}"
            f"(found={self.found!r}, user_id={self.user_id!r}, tag={self.tag!r}, "
            f"reason={self.reason!r}, proof={self.proof!r}, moderator={self.moderator!r}, "
            f"severe={self.severe!r}, timestamp={self.timestamp!r})"
        )

    @property
    def data(self) -> dict[str, Any]:
        """The raw data returned from the Ravy API."""
        return self._data

    @property
    def found(self) -> bool:
        """Whether the user was found in the database."""
        return self._found

    @property
    def user_id(self) -> int | None:
        """The user's ID, if found."""
        return self._user_id

    @property
    def tag(self) -> str | None:
        """The user's tag, if found."""
        return self._tag

    @property
    def reason(self) -> str | None:
        """Reason for the ban, if found."""
        return self._reason

    @property
    def proof(self) -> str | None:
        """Evidence for the ban, if found."""
        return self._proof

    @property
    def moderator(self) -> int | None:
        """User ID of the responsible moderator, if found."""
        return self._moderator

    @property
    def severe(self) -> bool | None:
        """Whether the ban is severe, if found."""
        return self._severe

    @property
    def timestamp(self) -> str | None:
        """A timestamp of the ban, if found."""
        return self._timestamp

data property

The raw data returned from the Ravy API.

found property

Whether the user was found in the database.

moderator property

User ID of the responsible moderator, if found.

proof property

Evidence for the ban, if found.

reason property

Reason for the ban, if found.

severe property

Whether the ban is severe, if found.

tag property

The user's tag, if found.

timestamp property

A timestamp of the ban, if found.

user_id property

The user's ID, if found.