Sin descripción

SettingsRepository.php 1.4KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. <?php
  2. namespace MailPoet\Settings;
  3. if (!defined('ABSPATH')) exit;
  4. use MailPoet\Doctrine\Repository;
  5. use MailPoet\Entities\SettingEntity;
  6. use MailPoet\WP\Functions as WPFunctions;
  7. use MailPoetVendor\Carbon\Carbon;
  8. /**
  9. * @extends Repository<SettingEntity>
  10. */
  11. class SettingsRepository extends Repository {
  12. public function findOneByName($name) {
  13. return $this->doctrineRepository->findOneBy(['name' => $name]);
  14. }
  15. public function createOrUpdateByName($name, $value) {
  16. // Temporarily use low-level INSERT ... ON DUPLICATE KEY UPDATE query to avoid race conditions
  17. // between entity fetch and creation with multiple concurrent requests. This will be replaced
  18. // by a code solving atomicity of create-or-update on entity (ORM) level in a follow-up ticket.
  19. $now = Carbon::createFromTimestamp(WPFunctions::get()->currentTime('timestamp'));
  20. $tableName = $this->entityManager->getClassMetadata(SettingEntity::class)->getTableName();
  21. $this->entityManager->getConnection()->executeUpdate("
  22. INSERT INTO $tableName (name, value, created_at, updated_at)
  23. VALUES (:name, :value, :now, :now)
  24. ON DUPLICATE KEY UPDATE value = :value, updated_at = :now
  25. ", [
  26. 'name' => $name,
  27. 'value' => is_array($value) ? serialize($value) : $value,
  28. 'now' => $now,
  29. ]);
  30. $this->entityManager->getUnitOfWork()->clear(SettingEntity::class);
  31. }
  32. protected function getEntityClassName() {
  33. return SettingEntity::class;
  34. }
  35. }