mirror of
https://github.com/nextcloud/server.git
synced 2026-06-08 16:26:59 -04:00
Merge pull request #34412 from nextcloud/fix/create-address-book-write-read-transactional
Wrap address book creation causal read in a transaction
This commit is contained in:
commit
b57115df3f
1 changed files with 23 additions and 13 deletions
|
|
@ -45,6 +45,7 @@ use OCA\DAV\Events\AddressBookUpdatedEvent;
|
|||
use OCA\DAV\Events\CardCreatedEvent;
|
||||
use OCA\DAV\Events\CardDeletedEvent;
|
||||
use OCA\DAV\Events\CardUpdatedEvent;
|
||||
use OCP\AppFramework\Db\TTransactional;
|
||||
use OCP\DB\QueryBuilder\IQueryBuilder;
|
||||
use OCP\EventDispatcher\IEventDispatcher;
|
||||
use OCP\IDBConnection;
|
||||
|
|
@ -60,6 +61,9 @@ use Sabre\VObject\Component\VCard;
|
|||
use Sabre\VObject\Reader;
|
||||
|
||||
class CardDavBackend implements BackendInterface, SyncSupport {
|
||||
|
||||
use TTransactional;
|
||||
|
||||
public const PERSONAL_ADDRESSBOOK_URI = 'contacts';
|
||||
public const PERSONAL_ADDRESSBOOK_NAME = 'Contacts';
|
||||
|
||||
|
|
@ -420,20 +424,26 @@ class CardDavBackend implements BackendInterface, SyncSupport {
|
|||
$values['displayname'] = $url;
|
||||
}
|
||||
|
||||
$query = $this->db->getQueryBuilder();
|
||||
$query->insert('addressbooks')
|
||||
->values([
|
||||
'uri' => $query->createParameter('uri'),
|
||||
'displayname' => $query->createParameter('displayname'),
|
||||
'description' => $query->createParameter('description'),
|
||||
'principaluri' => $query->createParameter('principaluri'),
|
||||
'synctoken' => $query->createParameter('synctoken'),
|
||||
])
|
||||
->setParameters($values)
|
||||
->execute();
|
||||
[$addressBookId, $addressBookRow] = $this->atomic(function() use ($values) {
|
||||
$query = $this->db->getQueryBuilder();
|
||||
$query->insert('addressbooks')
|
||||
->values([
|
||||
'uri' => $query->createParameter('uri'),
|
||||
'displayname' => $query->createParameter('displayname'),
|
||||
'description' => $query->createParameter('description'),
|
||||
'principaluri' => $query->createParameter('principaluri'),
|
||||
'synctoken' => $query->createParameter('synctoken'),
|
||||
])
|
||||
->setParameters($values)
|
||||
->execute();
|
||||
|
||||
$addressBookId = $query->getLastInsertId();
|
||||
return [
|
||||
$addressBookId,
|
||||
$this->getAddressBookById($addressBookId),
|
||||
];
|
||||
}, $this->db);
|
||||
|
||||
$addressBookId = $query->getLastInsertId();
|
||||
$addressBookRow = $this->getAddressBookById($addressBookId);
|
||||
$this->dispatcher->dispatchTyped(new AddressBookCreatedEvent($addressBookId, $addressBookRow));
|
||||
|
||||
return $addressBookId;
|
||||
|
|
|
|||
Loading…
Reference in a new issue