mirror of
https://github.com/vrana/adminer.git
synced 2026-02-28 01:21:25 +01:00
46 lines
1.6 KiB
PHP
46 lines
1.6 KiB
PHP
<?php
|
|
|
|
/** Check IP address and allow empty password
|
|
* @link https://www.adminer.org/plugins/#use
|
|
* @author Jakub Vrana, https://www.vrana.cz/
|
|
* @license https://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
|
|
* @license https://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other)
|
|
*/
|
|
class AdminerLoginIp extends Adminer\Plugin {
|
|
protected $ips, $forwarded_for;
|
|
|
|
/** Set allowed IP addresses
|
|
* @param list<string> $ips IP address prefixes
|
|
* @param list<string> $forwarded_for X-Forwarded-For prefixes if IP address matches, empty array means anything
|
|
*/
|
|
function __construct(array $ips, array $forwarded_for = array()) {
|
|
$this->ips = $ips;
|
|
$this->forwarded_for= $forwarded_for;
|
|
}
|
|
|
|
function login($login, $password) {
|
|
foreach ($this->ips as $ip) {
|
|
if (strncasecmp($_SERVER["REMOTE_ADDR"], $ip, strlen($ip)) == 0) {
|
|
if (!$this->forwarded_for) {
|
|
return true;
|
|
}
|
|
if ($_SERVER["HTTP_X_FORWARDED_FOR"]) {
|
|
foreach ($this->forwarded_for as $forwarded_for) {
|
|
if (strncasecmp(preg_replace('~.*, *~', '', $_SERVER["HTTP_X_FORWARDED_FOR"]), $forwarded_for, strlen($forwarded_for)) == 0) {
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
protected static $translations = array(
|
|
'cs' => array('' => 'Zkontroluje IP adresu a povolí prázdné heslo'),
|
|
'de' => array('' => 'Überprüft die IP-Adresse und lässt ein leeres Passwort zu'),
|
|
'pl' => array('' => 'Sprawdzaj adres IP i zezwakaj na puste hasło'),
|
|
'ro' => array('' => 'Verificați adresa IP și permiteți parola goală'),
|
|
);
|
|
}
|