repod/lib/Core/EpisodeAction/EpisodeActionExtraData.php

141 lines
3.1 KiB
PHP
Raw Permalink Normal View History

2023-08-24 12:48:10 +02:00
<?php
declare(strict_types=1);
namespace OCA\RePod\Core\EpisodeAction;
use OCA\GPodderSync\Core\EpisodeAction\EpisodeAction;
/**
* Base: https://github.com/pbek/nextcloud-nextpod/blob/main/lib/Core/EpisodeAction/EpisodeActionExtraData.php.
* Specs: https://github.com/Podcast-Standards-Project/PSP-1-Podcast-RSS-Specification/blob/main/README.md#required-item-elements.
2023-08-24 12:48:10 +02:00
*
* @psalm-import-type EpisodeActionType from EpisodeAction
*
* @psalm-type EpisodeActionExtraDataType = array{
* title: string,
* url: ?string,
* name: string,
* link: ?string,
* image: ?string,
* author: ?string,
* description: ?string,
2023-08-24 12:48:10 +02:00
* fetchedAtUnix: int,
* guid: string,
* type: ?string,
* size: ?int,
* pubDate: ?\DateTime,
2024-01-16 19:46:02 +01:00
* duration: ?string,
* action: ?EpisodeActionType
2023-08-24 12:48:10 +02:00
* }
*/
2024-11-10 13:18:53 +01:00
class EpisodeActionExtraData implements \JsonSerializable, \Stringable
2023-08-24 12:48:10 +02:00
{
public function __construct(
2024-11-12 10:11:21 +01:00
private readonly string $title,
private readonly ?string $url,
private readonly string $name,
private readonly ?string $link,
private readonly ?string $image,
private readonly ?string $author,
2024-11-12 10:11:21 +01:00
private readonly ?string $description,
private readonly int $fetchedAtUnix,
private readonly string $guid,
private readonly ?string $type,
private readonly ?int $size,
private readonly ?\DateTime $pubDate,
private readonly ?string $duration,
private readonly ?EpisodeAction $action
) {}
2023-08-24 12:48:10 +02:00
2023-12-23 16:25:20 +00:00
public function __toString(): string {
return $this->url ?? '/no episodeUrl/';
}
2024-01-15 10:13:39 +01:00
public function getTitle(): string {
return $this->title;
}
public function getUrl(): ?string {
return $this->url;
}
public function getName(): string {
return $this->name;
2023-08-24 12:48:10 +02:00
}
public function getLink(): ?string {
return $this->link;
}
public function getImage(): ?string {
return $this->image;
}
public function getAuthor(): ?string {
return $this->author;
}
public function getDescription(): ?string {
return $this->description;
}
public function getFetchedAtUnix(): int {
return $this->fetchedAtUnix;
2023-08-28 17:44:17 +02:00
}
public function getGuid(): string {
return $this->guid;
2023-08-24 19:03:11 +02:00
}
public function getType(): ?string {
return $this->type;
2023-08-24 19:03:11 +02:00
}
public function getSize(): ?int {
return $this->size;
2023-08-24 19:03:11 +02:00
}
public function getPubDate(): ?\DateTime {
return $this->pubDate;
2023-08-29 12:04:14 +02:00
}
2024-01-16 19:46:02 +01:00
public function getDuration(): ?string {
return $this->duration;
}
public function getAction(): ?EpisodeAction {
return $this->action;
2023-08-24 12:48:10 +02:00
}
/**
* @return EpisodeActionExtraDataType
*/
2023-12-23 16:25:20 +00:00
public function toArray(): array {
2023-08-24 12:48:10 +02:00
return
[
'title' => $this->title,
'url' => $this->url,
'name' => $this->name,
'link' => $this->link,
'image' => $this->image,
'author' => $this->author,
'description' => $this->description,
2023-08-24 12:48:10 +02:00
'fetchedAtUnix' => $this->fetchedAtUnix,
'guid' => $this->guid,
'type' => $this->type,
'size' => $this->size,
'pubDate' => $this->pubDate,
'duration' => $this->duration,
2024-11-10 13:18:53 +01:00
'action' => $this->action instanceof EpisodeAction ? $this->action->toArray() : null,
2023-08-24 12:48:10 +02:00
];
}
/**
* @return EpisodeActionExtraDataType
*/
2023-12-23 16:25:20 +00:00
public function jsonSerialize(): mixed {
2023-08-24 12:48:10 +02:00
return $this->toArray();
}
}