nextcloud < v22.0 throws UniqueConstraintViolationException. This can be reverted after v21 reaches end of support
This commit is contained in:
parent
ab155ca94a
commit
57f0691b4c
|
@ -5,6 +5,7 @@ namespace OCA\GPodderSync\Controller;
|
||||||
|
|
||||||
use DateTime;
|
use DateTime;
|
||||||
use DateTimeZone;
|
use DateTimeZone;
|
||||||
|
use Doctrine\DBAL\Exception\UniqueConstraintViolationException;
|
||||||
use GuzzleHttp\Psr7\Response;
|
use GuzzleHttp\Psr7\Response;
|
||||||
use OCA\GPodderSync\Core\EpisodeAction\EpisodeActionReader;
|
use OCA\GPodderSync\Core\EpisodeAction\EpisodeActionReader;
|
||||||
use OCA\GPodderSync\Db\EpisodeAction\EpisodeActionEntity;
|
use OCA\GPodderSync\Db\EpisodeAction\EpisodeActionEntity;
|
||||||
|
@ -67,11 +68,11 @@ class EpisodeActionController extends Controller {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return $this->episodeActionWriter->save($episodeActionEntity);
|
return $this->episodeActionWriter->save($episodeActionEntity);
|
||||||
|
} catch (UniqueConstraintViolationException $uniqueConstraintViolationException) {
|
||||||
|
return $this->updateEpisodeAction($episodeAction, $episodeActionEntity);
|
||||||
} catch (\Exception $exception) {
|
} catch (\Exception $exception) {
|
||||||
if ($exception->getReason() === Exception::REASON_UNIQUE_CONSTRAINT_VIOLATION) {
|
if ($exception->getReason() === Exception::REASON_UNIQUE_CONSTRAINT_VIOLATION) {
|
||||||
$idEpisodeActionEntityToUpdate = $this->episodeActionRepository->findByEpisode($episodeAction->getEpisode(), $this->userId)->getId();
|
return $this->updateEpisodeAction($episodeAction, $episodeActionEntity);
|
||||||
$episodeActionEntity->setId($idEpisodeActionEntityToUpdate);
|
|
||||||
return $this->episodeActionWriter->update($episodeActionEntity);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -114,4 +115,17 @@ class EpisodeActionController extends Controller {
|
||||||
->setTimezone(new DateTimeZone('UTC'))
|
->setTimezone(new DateTimeZone('UTC'))
|
||||||
->format("Y-m-d\TH:i:s");
|
->format("Y-m-d\TH:i:s");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param \OCA\GPodderSync\Core\EpisodeAction\EpisodeAction $episodeAction
|
||||||
|
* @param EpisodeActionEntity $episodeActionEntity
|
||||||
|
*
|
||||||
|
* @return EpisodeActionEntity
|
||||||
|
*/
|
||||||
|
private function updateEpisodeAction(\OCA\GPodderSync\Core\EpisodeAction\EpisodeAction $episodeAction, EpisodeActionEntity $episodeActionEntity): EpisodeActionEntity
|
||||||
|
{
|
||||||
|
$idEpisodeActionEntityToUpdate = $this->episodeActionRepository->findByEpisode($episodeAction->getEpisode(), $this->userId)->getId();
|
||||||
|
$episodeActionEntity->setId($idEpisodeActionEntityToUpdate);
|
||||||
|
return $this->episodeActionWriter->update($episodeActionEntity);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,12 +3,14 @@ declare(strict_types=1);
|
||||||
|
|
||||||
namespace OCA\GPodderSync\Core\SubscriptionChange;
|
namespace OCA\GPodderSync\Core\SubscriptionChange;
|
||||||
|
|
||||||
|
use Doctrine\DBAL\Exception\UniqueConstraintViolationException;
|
||||||
use OCA\GPodderSync\Db\SubscriptionChange\SubscriptionChangeEntity;
|
use OCA\GPodderSync\Db\SubscriptionChange\SubscriptionChangeEntity;
|
||||||
use OCA\GPodderSync\Db\SubscriptionChange\SubscriptionChangeRepository;
|
use OCA\GPodderSync\Db\SubscriptionChange\SubscriptionChangeRepository;
|
||||||
use OCA\GPodderSync\Db\SubscriptionChange\SubscriptionChangeWriter;
|
use OCA\GPodderSync\Db\SubscriptionChange\SubscriptionChangeWriter;
|
||||||
use OCP\DB\Exception;
|
use OCP\DB\Exception;
|
||||||
|
|
||||||
class SubscriptionChangeSaver {
|
class SubscriptionChangeSaver
|
||||||
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var SubscriptionChangesReader
|
* @var SubscriptionChangesReader
|
||||||
|
@ -31,13 +33,15 @@ class SubscriptionChangeSaver {
|
||||||
SubscriptionChangeRequestParser $subscriptionChangeRequestParser,
|
SubscriptionChangeRequestParser $subscriptionChangeRequestParser,
|
||||||
SubscriptionChangeRepository $subscriptionChangeRepository,
|
SubscriptionChangeRepository $subscriptionChangeRepository,
|
||||||
SubscriptionChangeWriter $subscriptionChangeWriter
|
SubscriptionChangeWriter $subscriptionChangeWriter
|
||||||
) {
|
)
|
||||||
|
{
|
||||||
$this->subscriptionChangeRepository = $subscriptionChangeRepository;
|
$this->subscriptionChangeRepository = $subscriptionChangeRepository;
|
||||||
$this->subscriptionChangeWriter = $subscriptionChangeWriter;
|
$this->subscriptionChangeWriter = $subscriptionChangeWriter;
|
||||||
$this->subscriptionChangeRequestParser = $subscriptionChangeRequestParser;
|
$this->subscriptionChangeRequestParser = $subscriptionChangeRequestParser;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function saveSubscriptionChanges(array $urlsSubscribed, array $urlsUnsubscribed, string $userId): void {
|
public function saveSubscriptionChanges(array $urlsSubscribed, array $urlsUnsubscribed, string $userId): void
|
||||||
|
{
|
||||||
$subscriptionChanges = $this->subscriptionChangeRequestParser->createSubscriptionChangeList($urlsSubscribed, $urlsUnsubscribed);
|
$subscriptionChanges = $this->subscriptionChangeRequestParser->createSubscriptionChangeList($urlsSubscribed, $urlsUnsubscribed);
|
||||||
foreach ($subscriptionChanges as $urlChangedSubscriptionStatus) {
|
foreach ($subscriptionChanges as $urlChangedSubscriptionStatus) {
|
||||||
$subscriptionChangeEntity = new SubscriptionChangeEntity();
|
$subscriptionChangeEntity = new SubscriptionChangeEntity();
|
||||||
|
@ -48,15 +52,28 @@ class SubscriptionChangeSaver {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$this->subscriptionChangeWriter->create($subscriptionChangeEntity);
|
$this->subscriptionChangeWriter->create($subscriptionChangeEntity);
|
||||||
|
} catch (UniqueConstraintViolationException $uniqueConstraintViolationException) {
|
||||||
|
$this->updateSubscription($subscriptionChangeEntity, $userId);
|
||||||
} catch (\Exception $exception) {
|
} catch (\Exception $exception) {
|
||||||
if ($exception->getReason() === Exception::REASON_UNIQUE_CONSTRAINT_VIOLATION) {
|
if ($exception->getReason() === Exception::REASON_UNIQUE_CONSTRAINT_VIOLATION) {
|
||||||
|
$this->updateSubscription($subscriptionChangeEntity, $userId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param SubscriptionChangeEntity $subscriptionChangeEntity
|
||||||
|
* @param string $userId
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
private function updateSubscription(SubscriptionChangeEntity $subscriptionChangeEntity, string $userId): void
|
||||||
|
{
|
||||||
$idEpisodeActionEntityToUpdate = $this->subscriptionChangeRepository->findByUrl($subscriptionChangeEntity->getUrl(), $userId)->getId();
|
$idEpisodeActionEntityToUpdate = $this->subscriptionChangeRepository->findByUrl($subscriptionChangeEntity->getUrl(), $userId)->getId();
|
||||||
$subscriptionChangeEntity->setId($idEpisodeActionEntityToUpdate);
|
$subscriptionChangeEntity->setId($idEpisodeActionEntityToUpdate);
|
||||||
$this->subscriptionChangeWriter->update($subscriptionChangeEntity);
|
$this->subscriptionChangeWriter->update($subscriptionChangeEntity);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue