. * * @author Daniil Gentili * @copyright 2016-2023 Daniil Gentili * @license https://opensource.org/licenses/AGPL-3.0 AGPLv3 * @link https://docs.madelineproto.xyz MadelineProto documentation */ namespace danog\MadelineProto\EventHandler; use danog\MadelineProto\Ipc\IpcCapable; use danog\MadelineProto\MTProto; use JsonSerializable; /** * Represents a generic media. */ abstract class Media extends IpcCapable implements JsonSerializable { /** Media filesize */ public readonly int $size; /** Media file name */ public readonly string $fileName; /** Media file extension */ public readonly string $fileExt; /** Media creation date */ public readonly int $creationDate; /** Media MIME type */ public readonly string $mimeType; /** Time-to-live of media */ public readonly ?int $ttl; /** @var list Thumbnails */ public readonly array $thumbs; /** @var list Video thumbnails */ public readonly array $videoThumbs; /** Whether the media should be hidden behind a spoiler */ public readonly bool $spoiler; /** File ID in bot API format (always present even for users) */ public readonly string $botApiFileId; /** Unique file ID in bot API format (always present even for users) */ public readonly string $botApiFileUniqueId; /** @internal Media location */ public readonly array $location; /** @internal */ public function __construct( MTProto $API, array $rawMedia, /** Whether this media is protected */ public readonly bool $protected ) { parent::__construct($API); [ 'name' => $name, 'ext' => $this->fileExt, 'mime' => $this->mimeType, 'size' => $this->size, 'InputFileLocation' => $this->location ] = $API->getDownloadInfo($rawMedia); $this->fileName = $name.$this->fileExt; [ 'file_id' => $this->botApiFileId, 'file_unique_id' => $this->botApiFileUniqueId ] = $API->extractBotAPIFile($API->MTProtoToBotAPI($rawMedia)); $this->creationDate = ($rawMedia['document'] ?? $rawMedia['photo'])['date']; $this->ttl = $rawMedia['ttl_seconds'] ?? null; $this->spoiler = $rawMedia['spoiler'] ?? false; } /** * Gets a download link for any file up to 4GB. * * @param string|null $scriptUrl Optional path to custom download script (not needed when running via web) */ public function getDownloadLink(?string $scriptUrl = null): string { return $this->getClient()->getDownloadLink($this, $scriptUrl); } /** @internal */ public function jsonSerialize(): mixed { $v = \get_object_vars($this); unset($v['API'], $v['session'], $v['location']); $v['_'] = static::class; return $v; } }