2021-06-27 13:19:26 +02:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace OCA\GPodderSync\Core\EpisodeAction;
|
|
|
|
|
|
|
|
class EpisodeActionReader {
|
2021-08-23 13:30:18 +02:00
|
|
|
|
|
|
|
const EPISODEACTION_IDENTIFIER = 'EpisodeAction{';
|
|
|
|
|
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-24 13:09:43 +02:00
|
|
|
public function fromString(string $episodeActionsString): array {
|
2021-08-23 01:11:16 +02:00
|
|
|
|
2021-08-23 13:30:18 +02:00
|
|
|
$episodeActions = [];
|
2021-08-23 01:11:16 +02:00
|
|
|
|
2021-08-24 13:09:43 +02:00
|
|
|
$episodeActionStrings = explode(self::EPISODEACTION_IDENTIFIER, $episodeActionsString);
|
|
|
|
array_shift($episodeActionStrings);
|
|
|
|
|
|
|
|
foreach($episodeActionStrings as $episodeActionString) {
|
2021-08-23 01:11:16 +02:00
|
|
|
|
|
|
|
preg_match(
|
|
|
|
'/EpisodeAction{(podcast=\')(?<podcast>.*?)(\', episode=\')(?<episode>.*?)(\', action=)(?<action>.*?)(, timestamp=)(?<timestamp>.*?)(, started=)(?<started>.*?)(, position=)(?<position>.*?)(, total=)(?<total>.*?)}]*/',
|
2021-08-24 13:09:43 +02:00
|
|
|
self::EPISODEACTION_IDENTIFIER . $episodeActionString,
|
2021-08-23 01:11:16 +02:00
|
|
|
$matches
|
|
|
|
);
|
|
|
|
|
2021-08-23 13:30:18 +02:00
|
|
|
$episodeActions[] = new EpisodeAction(
|
2021-08-23 01:11:16 +02:00
|
|
|
$matches["podcast"],
|
|
|
|
$matches["episode"],
|
|
|
|
$matches["action"],
|
|
|
|
$matches["timestamp"],
|
|
|
|
(int)$matches["started"],
|
|
|
|
(int)$matches["position"],
|
|
|
|
(int)$matches["total"],
|
2021-08-23 13:30:18 +02:00
|
|
|
);
|
2021-08-23 01:11:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $episodeActions;
|
2021-06-27 13:19:26 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|