mirror of
https://github.com/nextcloud/server.git
synced 2026-06-11 01:30:50 -04:00
Merge pull request #53203 from nextcloud/backport/53198/stable30
[stable30] fix(user_status): Avoid unique constraint violations from parallel he…
This commit is contained in:
commit
93320cd157
1 changed files with 16 additions and 4 deletions
|
|
@ -167,7 +167,7 @@ class StatusService {
|
|||
$userStatus->setIsBackup(false);
|
||||
|
||||
if ($userStatus->getId() === null) {
|
||||
return $this->mapper->insert($userStatus);
|
||||
return $this->insertWithoutThrowingUniqueConstrain($userStatus);
|
||||
}
|
||||
|
||||
return $this->mapper->update($userStatus);
|
||||
|
|
@ -211,7 +211,7 @@ class StatusService {
|
|||
$userStatus->setStatusMessageTimestamp($this->timeFactory->now()->getTimestamp());
|
||||
|
||||
if ($userStatus->getId() === null) {
|
||||
return $this->mapper->insert($userStatus);
|
||||
return $this->insertWithoutThrowingUniqueConstrain($userStatus);
|
||||
}
|
||||
|
||||
return $this->mapper->update($userStatus);
|
||||
|
|
@ -313,7 +313,7 @@ class StatusService {
|
|||
if ($userStatus->getId() !== null) {
|
||||
return $this->mapper->update($userStatus);
|
||||
}
|
||||
return $this->mapper->insert($userStatus);
|
||||
return $this->insertWithoutThrowingUniqueConstrain($userStatus);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -360,7 +360,7 @@ class StatusService {
|
|||
$userStatus->setStatusMessageTimestamp($this->timeFactory->now()->getTimestamp());
|
||||
|
||||
if ($userStatus->getId() === null) {
|
||||
return $this->mapper->insert($userStatus);
|
||||
return $this->insertWithoutThrowingUniqueConstrain($userStatus);
|
||||
}
|
||||
|
||||
return $this->mapper->update($userStatus);
|
||||
|
|
@ -584,4 +584,16 @@ class StatusService {
|
|||
// For users that matched restore the previous status
|
||||
$this->mapper->restoreBackupStatuses($restoreIds);
|
||||
}
|
||||
|
||||
protected function insertWithoutThrowingUniqueConstrain(UserStatus $userStatus): UserStatus {
|
||||
try {
|
||||
return $this->mapper->insert($userStatus);
|
||||
} catch (Exception $e) {
|
||||
// Ignore if a parallel request already set the status
|
||||
if ($e->getReason() !== Exception::REASON_UNIQUE_CONSTRAINT_VIOLATION) {
|
||||
throw $e;
|
||||
}
|
||||
}
|
||||
return $userStatus;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in a new issue