Server IP : 172.67.158.161 / Your IP : 18.216.209.235 Web Server : LiteSpeed System : Linux business53.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : giankuin ( 1871) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /proc/self/root/proc/thread-self/root/proc/thread-self/root/home/giankuin/thietke365.net/wp-content/plugins/mailpoet/lib/Settings/ |
Upload File : |
<?php // phpcs:ignore SlevomatCodingStandard.TypeHints.DeclareStrictTypes.DeclareStrictTypesMissing namespace MailPoet\Settings; if (!defined('ABSPATH')) exit; use MailPoet\Doctrine\Repository; use MailPoet\Entities\SettingEntity; use MailPoet\WP\Functions as WPFunctions; use MailPoetVendor\Carbon\Carbon; /** * @extends Repository<SettingEntity> */ class SettingsRepository extends Repository { public function findOneByName($name) { return $this->doctrineRepository->findOneBy(['name' => $name]); } public function createOrUpdateByName($name, $value) { // Temporarily use low-level INSERT ... ON DUPLICATE KEY UPDATE query to avoid race conditions // between entity fetch and creation with multiple concurrent requests. This will be replaced // by a code solving atomicity of create-or-update on entity (ORM) level in a follow-up ticket. $now = Carbon::createFromTimestamp(WPFunctions::get()->currentTime('timestamp')); $tableName = $this->entityManager->getClassMetadata(SettingEntity::class)->getTableName(); $this->entityManager->getConnection()->executeStatement(" INSERT INTO $tableName (name, value, created_at, updated_at) VALUES (:name, :value, :now, :now) ON DUPLICATE KEY UPDATE value = :value, updated_at = :now ", [ 'name' => $name, 'value' => is_array($value) ? serialize($value) : $value, 'now' => $now, ]); $this->entityManager->getUnitOfWork()->clear(SettingEntity::class); } protected function getEntityClassName() { return SettingEntity::class; } }