HEX
Server: Apache/2
System: Linux s01 6.1.0-34-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.135-1 (2025-04-25) x86_64
User: beestg (1003)
PHP: 8.3.25
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: /home/beestg/public_html/wp-content/plugins/mailpoet/lib/Statistics/UserAgentsRepository.php
<?php declare(strict_types = 1);

namespace MailPoet\Statistics;

if (!defined('ABSPATH')) exit;


use MailPoet\Doctrine\Repository;
use MailPoet\Entities\UserAgentEntity;

/**
 * @extends Repository<UserAgentEntity>
 */
class UserAgentsRepository extends Repository {
  protected function getEntityClassName() {
    return UserAgentEntity::class;
  }

  public function findOrCreate(string $userAgent): UserAgentEntity {
    $hash = (string)crc32($userAgent);
    $userAgentEntity = $this->findOneBy(['hash' => $hash]);
    return $userAgentEntity ?? $this->create($userAgent);
  }

  public function create(string $userAgent): UserAgentEntity {
    $userAgentEntity = new UserAgentEntity($userAgent);

    $this->entityManager->getConnection()->executeStatement(
      'INSERT INTO ' . $this->getTableName() . ' (user_agent, hash) VALUES (:user_agent, :hash) ON DUPLICATE KEY UPDATE id = id',
      [
        'user_agent' => $userAgentEntity->getUserAgent(),
        'hash' => $userAgentEntity->getHash(),
      ]
    );

    /** @var UserAgentEntity $userAgentEntity */
    $userAgentEntity = $this->findOneBy(['hash' => $userAgentEntity->getHash()]);
    return $userAgentEntity;
  }
}