setFormatter($consoleFormatter); $log->pushHandler($consoleHandler); // Set up the file handler $fileHandler = new RotatingFileHandler($logFilePath, 0, Logger::DEBUG); $fileFormatter = new LineFormatter( "[%datetime%] %channel%.%level_name%: %message% %context% %extra%\n", "Y-m-d H:i:s.u" // Date format ); $fileHandler->setFormatter($fileFormatter); $log->pushHandler($fileHandler); return $log; } function mapContactToVCard($contactDetails, $role, $c) { return [ 'objectClassName' => 'entity', 'handle' => ['C' . $contactDetails['identifier'] . '-' . $c['roid']], 'roles' => [$role], 'remarks' => [ [ "description" => [ "This object's data has been partially omitted for privacy.", "Only the registrar managing the record can view personal contact data." ], "links" => [ [ "href" => "https://namingo.org", "rel" => "alternate", "type" => "text/html" ] ], "title" => "REDACTED FOR PRIVACY", "type" => "Details are withheld due to privacy restrictions." ], [ "description" => [ "To obtain contact information for the domain registrant, please refer to the Registrar of Record's RDDS service as indicated in this report." ], "title" => "EMAIL REDACTED FOR PRIVACY", "type" => "Details are withheld due to privacy restrictions." ], ], 'vcardArray' => [ "vcard", [ ['version', new stdClass(), 'text', '4.0'], ["fn", new stdClass(), 'text', $contactDetails['name']], ["org", $contactDetails['org']], ["adr", [ "", // Post office box $contactDetails['street1'], // Extended address $contactDetails['street2'], // Street address $contactDetails['city'], // Locality $contactDetails['sp'], // Region $contactDetails['pc'], // Postal code $contactDetails['cc'] // Country name ]], ["tel", $contactDetails['voice'], ["type" => "voice"]], ["tel", $contactDetails['fax'], ["type" => "fax"]], ["email", $contactDetails['email']], ] ], ]; } function isIpWhitelisted($ip, $pdo) { $stmt = $pdo->prepare("SELECT COUNT(*) FROM registrar_whitelist WHERE addr = ?"); $stmt->execute([$ip]); $count = $stmt->fetchColumn(); return $count > 0; } // Function to update the permitted IPs from the database function updatePermittedIPs($pool, $permittedIPsTable) { $pdo = $pool->get(); $query = "SELECT addr FROM registrar_whitelist"; $stmt = $pdo->query($query); $permittedIPs = $stmt->fetchAll(PDO::FETCH_COLUMN, 0); $pool->put($pdo); // Manually clear the table by removing each entry foreach ($permittedIPsTable as $key => $value) { $permittedIPsTable->del($key); } // Insert new values foreach ($permittedIPs as $ip) { $permittedIPsTable->set($ip, ['addr' => $ip]); } }