2021-06-27 13:19:26 +02:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace OCA\GPodderSync\Core\EpisodeAction;
|
|
|
|
|
2021-08-23 02:45:38 +02:00
|
|
|
class EpisodeActionReader
|
|
|
|
{
|
2021-08-23 13:30:18 +02:00
|
|
|
|
2021-08-23 02:45:38 +02:00
|
|
|
const EPISODEACTION_IDENTIFIER = 'EpisodeAction{';
|
2021-08-23 13:30:18 +02:00
|
|
|
|
2021-08-23 01:11:16 +02:00
|
|
|
/**
|
2021-08-24 13:09:43 +02:00
|
|
|
* @param string $episodeActionsString
|
2021-08-23 13:30:18 +02:00
|
|
|
* @return EpisodeAction[]
|
2021-08-23 01:11:16 +02:00
|
|
|
*/
|
2021-08-23 02:45:38 +02:00
|
|
|
public function fromString(string $episodeActionsString): array
|
|
|
|
{
|
|
|
|
|
2021-08-23 01:11:16 +02:00
|
|
|
|
2021-08-23 02:45:38 +02:00
|
|
|
$patterns = [
|
|
|
|
'/EpisodeAction{(podcast=\')(?<podcast>.*?)(\', episode=\')(?<episode>.*?)(\', guid=\')(?<guid>.*?)(\', action=)(?<action>.*?)(, timestamp=)(?<timestamp>.*?)(, started=)(?<started>.*?)(, position=)(?<position>.*?)(, total=)(?<total>.*?)}]*/',
|
|
|
|
'/EpisodeAction{(podcast=\')(?<podcast>.*?)(\', episode=\')(?<episode>.*?)(\', action=)(?<action>.*?)(, timestamp=)(?<timestamp>.*?)(, started=)(?<started>.*?)(, position=)(?<position>.*?)(, total=)(?<total>.*?)}]*/',
|
|
|
|
];
|
2021-08-23 01:11:16 +02:00
|
|
|
|
2021-08-23 02:45:38 +02:00
|
|
|
$episodeActions = [];
|
|
|
|
|
|
|
|
$episodeActionStrings = explode(self::EPISODEACTION_IDENTIFIER, $episodeActionsString);
|
|
|
|
array_shift($episodeActionStrings);
|
|
|
|
|
|
|
|
foreach ($episodeActionStrings as $episodeActionString) {
|
|
|
|
foreach ($patterns as $pattern) {
|
|
|
|
preg_match(
|
|
|
|
$pattern,
|
|
|
|
self::EPISODEACTION_IDENTIFIER . $episodeActionString,
|
|
|
|
$matches
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($matches["action"] !== null) {
|
|
|
|
$episodeActions[] = new EpisodeAction(
|
|
|
|
$matches["podcast"],
|
|
|
|
$matches["episode"],
|
|
|
|
$matches["action"],
|
|
|
|
$matches["timestamp"],
|
|
|
|
(int)$matches["started"],
|
|
|
|
(int)$matches["position"],
|
|
|
|
(int)$matches["total"],
|
|
|
|
$matches["guid"] ?? null,
|
2021-10-05 20:45:06 +02:00
|
|
|
null,
|
2021-08-23 02:45:38 +02:00
|
|
|
);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2021-08-23 01:11:16 +02:00
|
|
|
return $episodeActions;
|
2021-06-27 13:19:26 +02:00
|
|
|
}
|
2021-10-04 17:59:05 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param $episodeActionsArray[]
|
|
|
|
* @return EpisodeAction[]
|
|
|
|
*/
|
|
|
|
public function fromArray(array $episodeActionsArray): array
|
|
|
|
{
|
|
|
|
$episodeActions = [];
|
|
|
|
|
|
|
|
foreach($episodeActionsArray as $episodeAction) {
|
|
|
|
$episodeActions[] = new EpisodeAction(
|
|
|
|
$episodeAction["podcast"],
|
|
|
|
$episodeAction["episode"],
|
|
|
|
$episodeAction["action"],
|
|
|
|
$episodeAction["timestamp"],
|
|
|
|
$episodeAction["started"],
|
|
|
|
$episodeAction["position"],
|
|
|
|
$episodeAction["total"],
|
|
|
|
$episodeAction["guid"] ?? null,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $episodeActions;
|
|
|
|
}
|
2021-06-27 13:19:26 +02:00
|
|
|
}
|