You are here

class BanIpManager in Drupal 8

Same name and namespace in other branches
  1. 9 core/modules/ban/src/BanIpManager.php \Drupal\ban\BanIpManager
  2. 10 core/modules/ban/src/BanIpManager.php \Drupal\ban\BanIpManager

Ban IP manager.

Hierarchy

Expanded class hierarchy of BanIpManager

1 file declares its use of BanIpManager
IpAddressBlockingTest.php in core/modules/ban/tests/src/Functional/IpAddressBlockingTest.php
1 string reference to 'BanIpManager'
ban.services.yml in core/modules/ban/ban.services.yml
core/modules/ban/ban.services.yml
1 service uses BanIpManager
ban.ip_manager in core/modules/ban/ban.services.yml
Drupal\ban\BanIpManager

File

core/modules/ban/src/BanIpManager.php, line 10

Namespace

Drupal\ban
View source
class BanIpManager implements BanIpManagerInterface {

  /**
   * The database connection used to check the IP against.
   *
   * @var \Drupal\Core\Database\Connection
   */
  protected $connection;

  /**
   * Constructs a BanIpManager object.
   *
   * @param \Drupal\Core\Database\Connection $connection
   *   The database connection which will be used to check the IP against.
   */
  public function __construct(Connection $connection) {
    $this->connection = $connection;
  }

  /**
   * {@inheritdoc}
   */
  public function isBanned($ip) {
    return (bool) $this->connection
      ->query("SELECT * FROM {ban_ip} WHERE ip = :ip", [
      ':ip' => $ip,
    ])
      ->fetchField();
  }

  /**
   * {@inheritdoc}
   */
  public function findAll() {
    return $this->connection
      ->query('SELECT * FROM {ban_ip}');
  }

  /**
   * {@inheritdoc}
   */
  public function banIp($ip) {
    $this->connection
      ->merge('ban_ip')
      ->key([
      'ip' => $ip,
    ])
      ->fields([
      'ip' => $ip,
    ])
      ->execute();
  }

  /**
   * {@inheritdoc}
   */
  public function unbanIp($id) {
    $this->connection
      ->delete('ban_ip')
      ->condition('ip', $id)
      ->execute();
  }

  /**
   * {@inheritdoc}
   */
  public function findById($ban_id) {
    return $this->connection
      ->query("SELECT ip FROM {ban_ip} WHERE iid = :iid", [
      ':iid' => $ban_id,
    ])
      ->fetchField();
  }

}

Members

Namesort descending Modifiers Type Description Overrides
BanIpManager::$connection protected property The database connection used to check the IP against.
BanIpManager::banIp public function Bans an IP address. Overrides BanIpManagerInterface::banIp
BanIpManager::findAll public function Finds all banned IP addresses. Overrides BanIpManagerInterface::findAll
BanIpManager::findById public function Finds a banned IP address by its ID. Overrides BanIpManagerInterface::findById
BanIpManager::isBanned public function Returns if this IP address is banned. Overrides BanIpManagerInterface::isBanned
BanIpManager::unbanIp public function Unbans an IP address. Overrides BanIpManagerInterface::unbanIp
BanIpManager::__construct public function Constructs a BanIpManager object.