From 0d05d66c0ff2cfeea70239af67e83e6a85e1a668 Mon Sep 17 00:00:00 2001 From: Yasen Pramatarov Date: Tue, 17 Dec 2024 16:41:23 +0200 Subject: [PATCH] Default whitelist IPs on table createion --- app/classes/ratelimitrer.php | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/app/classes/ratelimitrer.php b/app/classes/ratelimitrer.php index c7cd03d..4619bfb 100644 --- a/app/classes/ratelimitrer.php +++ b/app/classes/ratelimitrer.php @@ -35,6 +35,23 @@ class RateLimiter { UNIQUE KEY unique_ip (ip_address) )"; $this->db->exec($sql); + + // Default IPs to whitelist (local interface and private networks IPs) + $defaultIps = [ + ['127.0.0.1', false, 'localhost IPv4'], + ['::1', false, 'localhost IPv6'], + ['10.0.0.0/8', true, 'Private network (Class A)'], + ['172.16.0.0/12', true, 'Private network (Class B)'], + ['192.168.0.0/16', true, 'Private network (Class C)'] + ]; + + // Insert default whitelisted IPs if they don't exist + $stmt = $this->db->prepare("INSERT IGNORE INTO {$this->whitelistTable} + (ip_address, is_network, description, created_by) + VALUES (?, ?, ?, 'system')"); + foreach ($defaultIps as $ip) { + $stmt->execute([$ip[0], $ip[1], $ip[2]]); + } } // Check if IP is whitelisted