|
@@ -1158,8 +1158,12 @@ function admin_api($action, $data = null) {
|
|
case "edit":
|
|
case "edit":
|
|
$regen_key = $data['admin_api_regen_key'];
|
|
$regen_key = $data['admin_api_regen_key'];
|
|
$active = (isset($data['active'])) ? 1 : 0;
|
|
$active = (isset($data['active'])) ? 1 : 0;
|
|
|
|
+ $skip_ip_check = (isset($data['skip_ip_check'])) ? 1 : 0;
|
|
$allow_from = array_map('trim', preg_split( "/( |,|;|\n)/", $data['allow_from']));
|
|
$allow_from = array_map('trim', preg_split( "/( |,|;|\n)/", $data['allow_from']));
|
|
foreach ($allow_from as $key => $val) {
|
|
foreach ($allow_from as $key => $val) {
|
|
|
|
+ if (empty($val)) {
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
if (!filter_var($val, FILTER_VALIDATE_IP)) {
|
|
if (!filter_var($val, FILTER_VALIDATE_IP)) {
|
|
$_SESSION['return'][] = array(
|
|
$_SESSION['return'][] = array(
|
|
'type' => 'warning',
|
|
'type' => 'warning',
|
|
@@ -1171,7 +1175,7 @@ function admin_api($action, $data = null) {
|
|
}
|
|
}
|
|
}
|
|
}
|
|
$allow_from = implode(',', array_unique(array_filter($allow_from)));
|
|
$allow_from = implode(',', array_unique(array_filter($allow_from)));
|
|
- if (empty($allow_from)) {
|
|
|
|
|
|
+ if (empty($allow_from) && $skip_ip_check == 0) {
|
|
$_SESSION['return'][] = array(
|
|
$_SESSION['return'][] = array(
|
|
'type' => 'danger',
|
|
'type' => 'danger',
|
|
'log' => array(__FUNCTION__, $data),
|
|
'log' => array(__FUNCTION__, $data),
|
|
@@ -1189,20 +1193,31 @@ function admin_api($action, $data = null) {
|
|
$stmt = $pdo->query("SELECT `api_key` FROM `api`");
|
|
$stmt = $pdo->query("SELECT `api_key` FROM `api`");
|
|
$num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
|
|
$num_results = count($stmt->fetchAll(PDO::FETCH_ASSOC));
|
|
if (empty($num_results)) {
|
|
if (empty($num_results)) {
|
|
- $stmt = $pdo->prepare("INSERT INTO `api` (`api_key`, `active`, `allow_from`)
|
|
|
|
- VALUES (:api_key, :active, :allow_from);");
|
|
|
|
|
|
+ $stmt = $pdo->prepare("INSERT INTO `api` (`api_key`, `skip_ip_check`, `active`, `allow_from`)
|
|
|
|
+ VALUES (:api_key, :skip_ip_check, :active, :allow_from);");
|
|
$stmt->execute(array(
|
|
$stmt->execute(array(
|
|
':api_key' => $api_key,
|
|
':api_key' => $api_key,
|
|
|
|
+ ':skip_ip_check' => $skip_ip_check,
|
|
':active' => $active,
|
|
':active' => $active,
|
|
':allow_from' => $allow_from
|
|
':allow_from' => $allow_from
|
|
));
|
|
));
|
|
}
|
|
}
|
|
else {
|
|
else {
|
|
- $stmt = $pdo->prepare("UPDATE `api` SET `active` = :active, `allow_from` = :allow_from ;");
|
|
|
|
- $stmt->execute(array(
|
|
|
|
- ':active' => $active,
|
|
|
|
- ':allow_from' => $allow_from
|
|
|
|
- ));
|
|
|
|
|
|
+ if ($skip_ip_check == 0) {
|
|
|
|
+ $stmt = $pdo->prepare("UPDATE `api` SET `skip_ip_check` = :skip_ip_check, `active` = :active, `allow_from` = :allow_from ;");
|
|
|
|
+ $stmt->execute(array(
|
|
|
|
+ ':active' => $active,
|
|
|
|
+ ':skip_ip_check' => $skip_ip_check,
|
|
|
|
+ ':allow_from' => $allow_from
|
|
|
|
+ ));
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ $stmt = $pdo->prepare("UPDATE `api` SET `skip_ip_check` = :skip_ip_check, `active` = :active ;");
|
|
|
|
+ $stmt->execute(array(
|
|
|
|
+ ':active' => $active,
|
|
|
|
+ ':skip_ip_check' => $skip_ip_check
|
|
|
|
+ ));
|
|
|
|
+ }
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case "regen_key":
|
|
case "regen_key":
|