PHP 8.2.31
Preview: SubscriberIPsRepository.php Size: 1.76 KB
/home/nshryvcy/himaltourism.com/wp-content/plugins/mailpoet/lib/Subscribers/SubscriberIPsRepository.php

<?php // phpcs:ignore SlevomatCodingStandard.TypeHints.DeclareStrictTypes.DeclareStrictTypesMissing

namespace MailPoet\Subscribers;

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


use MailPoet\Doctrine\Repository;
use MailPoet\Entities\SubscriberIPEntity;
use MailPoetVendor\Carbon\Carbon;

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

  public function findOneByIPAndCreatedAtAfterTimeInSeconds(string $ip, int $seconds): ?SubscriberIPEntity {
    return $this->entityManager->createQueryBuilder()
      ->select('sip')
      ->from(SubscriberIPEntity::class, 'sip')
      ->where('sip.ip = :ip')
      ->andWhere('sip.createdAt >= :timeThreshold')
      ->setParameter('ip', $ip)
      ->setParameter('timeThreshold', (new Carbon())->subSeconds($seconds))
      ->setMaxResults(1)
      ->getQuery()
      ->getOneOrNullResult();
  }

  public function getCountByIPAndCreatedAtAfterTimeInSeconds(string $ip, int $seconds): int {
    return $this->entityManager->createQueryBuilder()
      ->select('COUNT(sip)')
      ->from(SubscriberIPEntity::class, 'sip')
      ->where('sip.ip = :ip')
      ->andWhere('sip.createdAt >= :timeThreshold')
      ->setParameter('ip', $ip)
      ->setParameter('timeThreshold', (new Carbon())->subSeconds($seconds))
      ->getQuery()
      ->getSingleScalarResult();
  }

  public function deleteCreatedAtBeforeTimeInSeconds(int $seconds): int {
    return (int)$this->entityManager->createQueryBuilder()
      ->delete()
      ->from(SubscriberIPEntity::class, 'sip')
      ->where('sip.createdAt < :timeThreshold')
      ->setParameter('timeThreshold', (new Carbon())->subSeconds($seconds))
      ->getQuery()
      ->execute();
  }
}

Directory Contents

Dirs: 3 × Files: 20

Name Size Perms Modified Actions
- drwxr-xr-x 2023-04-04 05:35:40
Edit Download
- drwxr-xr-x 2023-04-04 05:35:40
Edit Download
- drwxr-xr-x 2023-04-04 05:35:40
Edit Download
3.17 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
7.19 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
7.10 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
0 B lrw-r--r-- 2023-04-04 05:35:40
Edit Download
1.32 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
3.24 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
2.53 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
1.16 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
4.83 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
1.19 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
1.76 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
15.01 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
2.41 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
11.32 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
4.56 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
4.54 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
4.58 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
17.28 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
10.16 KB lrw-r--r-- 2023-04-04 05:35:40
Edit Download
370 B lrw-r--r-- 2023-04-04 05:35:40
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).