Source code for discord_http.file

import io

__all__ = (
    "File",
)


[docs] class File: def __init__( self, data: io.BufferedIOBase | str, filename: str | None = None, *, spoiler: bool = False, title: str | None = None, description: str | None = None, duration_secs: int | None = None, waveform: str | None = None ): self.spoiler = spoiler self.title = title self.description = description self.duration_secs = duration_secs self.waveform = waveform self._filename = filename if isinstance(data, io.IOBase): if not (data.seekable() and data.readable()): raise ValueError(f"File buffer {data!r} must be seekable and readable") if not filename: raise ValueError("Filename must be specified when passing a file buffer") self.data: io.BufferedIOBase = data self._original_pos = data.tell() self._owner = False else: if not self._filename: self._filename = data self.data = open(data, "rb") self._original_pos = 0 self._owner = True self._closer = self.data.close self.data.close = lambda: None def __str__(self) -> str: return self.filename def __repr__(self) -> str: return f"<File filename='{self.filename}'>" @property def filename(self) -> str: """ `str`: The filename of the file """ return f"{'SPOILER_' if self.spoiler else ''}{self._filename}"
[docs] def reset(self, *, seek: int | bool = True) -> None: """ Reset the file buffer to the original position """ if seek: self.data.seek(self._original_pos)
[docs] def close(self) -> None: """ Close the file buffer """ self.data.close = self._closer if self._owner: self.data.close()
[docs] def to_dict(self, index: int) -> dict: """ `dict`: The file as a dictionary """ payload = { "id": index, "filename": self.filename } if self.title: payload["title"] = self.title if self.description: payload["description"] = self.description if self.duration_secs: payload["duration_secs"] = self.duration_secs if self.waveform: payload["waveform"] = self.waveform return payload