Files
remote_ip/app/common/Service/Repository.php

42 lines
1.1 KiB
PHP
Raw Normal View History

2023-06-16 21:44:35 -04:00
<?php
namespace ProVM\Service;
use PDO;
use Psr\Log\LoggerInterface;
class Repository
{
2023-06-18 19:20:06 -04:00
public function __construct(protected Connector $connector, protected string $table, protected LoggerInterface $logger) {}
2023-06-16 21:44:35 -04:00
public function update(string $ip): void
{
$this->logger->debug('Updating Database');
$old_ip = $this->getOld();
2023-06-18 19:20:06 -04:00
$this->logger->debug("Old IP: {$old_ip}");
2023-06-16 21:44:35 -04:00
if ($old_ip === $ip) {
$this->logger->debug('No change in IP');
return;
}
2023-06-18 19:20:06 -04:00
$this->doUpdate($ip);
2023-06-16 21:44:35 -04:00
$this->logger->debug('Updated IP');
}
protected function getOld(): string
{
$query = "SELECT `ip` FROM `{$this->table}` WHERE `host` = ?";
2023-06-18 19:20:06 -04:00
$statement = $this->connector->connect()->prepare($query);
2023-06-16 21:44:35 -04:00
$statement->execute(['vialdelamaza']);
return $statement->fetch()['ip'];
}
protected function doUpdate(string $ip): void
{
$query = "UPDATE `remote_ip` SET `ip` = ?, `updated` = CURRENT_TIMESTAMP() WHERE `host` = ?";
2023-06-18 19:20:06 -04:00
$statement = $this->connector->connect()->prepare($query);
2023-06-16 21:44:35 -04:00
$statement->execute([$ip, 'vialdelamaza']);
}
}