mirror of
https://github.com/loewexy/pdnsmanager.git
synced 2025-01-28 00:14:10 +01:00
133 lines
6.1 KiB
PHP
133 lines
6.1 KiB
PHP
<?php
|
|
/*
|
|
* Copyright 2016 Lukas Metzger <developer@lukas-metzger.com>.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
require_once '../config/config-default.php';
|
|
require_once '../lib/database.php';
|
|
require_once '../lib/update-serial.php';
|
|
if(filter_input(INPUT_SERVER, "REQUEST_METHOD") == "GET") {
|
|
if(filter_input(INPUT_GET, "action") == "updateRecord") {
|
|
$input_domain = filter_input(INPUT_GET, "domain");
|
|
$input_id = filter_input(INPUT_GET, "id");
|
|
$input_password = filter_input(INPUT_GET, "password");
|
|
$input_content = filter_input(INPUT_GET, "content");
|
|
$stmt = $db->prepare("SELECT security,record FROM remote WHERE type='password' AND id=:id LIMIT 1");
|
|
$stmt->bindValue(':id', $input_id, PDO::PARAM_INT);
|
|
$stmt->execute();
|
|
$stmt->bindColumn('security', $passwordHash);
|
|
$stmt->bindColumn('record', $record);
|
|
$stmt->fetch(PDO::FETCH_BOUND);
|
|
if(!password_verify($input_password, $passwordHash)) {
|
|
$return['status'] = "error";
|
|
$return['error'] = "Permission denied";
|
|
echo json_encode($return);
|
|
exit();
|
|
}
|
|
$stmt = $db->prepare("UPDATE records SET content=:content WHERE name=:name AND id=:id");
|
|
$stmt->bindValue(':content', $input_content, PDO::PARAM_STR);
|
|
$stmt->bindValue(':name', $input_domain, PDO::PARAM_STR);
|
|
$stmt->bindValue(':id', $record, PDO::PARAM_INT);
|
|
$stmt->execute();
|
|
$stmt = $db->prepare("SELECT domain_id FROM records WHERE id=:id LIMIT 1");
|
|
$stmt->bindValue(':id', $record, PDO::PARAM_INT);
|
|
$stmt->execute();
|
|
$domain_id = $stmt->fetchColumn();
|
|
update_serial($db, $domain_id);
|
|
$return['status'] = "success";
|
|
echo json_encode($return);
|
|
exit();
|
|
} else if(filter_input(INPUT_GET, "action") == "getIp") {
|
|
// If we are behind a proxy, return the first IP the request was forwarded for.
|
|
if(filter_input(INPUT_SERVER, "HTTP_X_FORWARDED_FOR") != null){
|
|
$return['ip'] = explode(",", filter_input(INPUT_SERVER, "HTTP_X_FORWARDED_FOR"))[0];
|
|
} else {
|
|
$return['ip'] = filter_input(INPUT_SERVER, "REMOTE_ADDR");
|
|
}
|
|
echo json_encode($return);
|
|
exit();
|
|
}
|
|
} else if(filter_input(INPUT_SERVER, "REQUEST_METHOD") == "POST") {
|
|
$input = json_decode(file_get_contents('php://input'));
|
|
if(isset($input->domain) && isset($input->id) && isset($input->content)) {
|
|
$stmt = $db->prepare("SELECT E.name,E.id FROM remote R JOIN records E ON R.record = E.id WHERE R.id=:id LIMIT 1");
|
|
$stmt->bindValue(':id', $input->id, PDO::PARAM_INT);
|
|
$stmt->execute();
|
|
$stmt->bindColumn('E.name', $domainName);
|
|
$stmt->bindColumn('E.id', $record);
|
|
$stmt->fetch(PDO::FETCH_BOUND);
|
|
if($domainName != $input->domain) {
|
|
$return['status'] = "error";
|
|
$return['error'] = "Id and domain do not match!";
|
|
echo json_encode($return);
|
|
exit();
|
|
}
|
|
if(isset($_GET['getNonce'])) {
|
|
$newNonce = base64_encode(openssl_random_pseudo_bytes(32));
|
|
$dbNonce = $newNonce . ":" . time();
|
|
$stmt = $db->prepare("UPDATE remote SET nonce=:nonce WHERE id=:id");
|
|
$stmt->bindValue(':nonce', $dbNonce, PDO::PARAM_STR);
|
|
$stmt->bindValue(':id', $input->id, PDO::PARAM_INT);
|
|
$stmt->execute();
|
|
$return['nonce'] = $newNonce;
|
|
echo json_encode($return);
|
|
exit();
|
|
} else if(isset($_GET['editRecord'])) {
|
|
$stmt = $db->prepare("SELECT security,nonce FROM remote WHERE id=:id LIMIT 1");
|
|
$stmt->bindValue(':id', $input->id, PDO::PARAM_INT);
|
|
$stmt->execute();
|
|
$stmt->bindColumn('security', $pubkey);
|
|
$stmt->bindColumn('nonce', $dbNonce);
|
|
$stmt->fetch(PDO::FETCH_BOUND);
|
|
$nonce = explode(":", $dbNonce);
|
|
if($dbNonce == NULL || (time() - $nonce[1]) > $config['nonce_lifetime']) {
|
|
$return['status'] = "error";
|
|
$return['error'] = "No valid nonce available!";
|
|
echo json_encode($return);
|
|
exit();
|
|
}
|
|
$verifyString = $input->domain . $input->id . $input->content . $nonce[0];
|
|
$signature = base64_decode($input->signature);
|
|
if(openssl_verify($verifyString, $signature, $pubkey, OPENSSL_ALGO_SHA512) != 1) {
|
|
$return['status'] = "error";
|
|
$return['error'] = "Bad signature!";
|
|
echo json_encode($return);
|
|
exit();
|
|
}
|
|
$stmt = $db->prepare("UPDATE records SET content=:content WHERE name=:name AND id=:id");
|
|
$stmt->bindValue(':content', $input->content, PDO::PARAM_STR);
|
|
$stmt->bindValue(':name', $input->domain, PDO::PARAM_STR);
|
|
$stmt->bindValue(':id', $record, PDO::PARAM_INT);
|
|
$stmt->execute();
|
|
$stmt = $db->prepare("SELECT domain_id FROM records WHERE id=:id LIMIT 1");
|
|
$stmt->bindValue(':id', $record, PDO::PARAM_INT);
|
|
$stmt->execute();
|
|
$domain_id = $stmt->fetchColumn();
|
|
update_serial($db, $domain_id);
|
|
$return['status'] = "success";
|
|
echo json_encode($return);
|
|
exit();
|
|
} else {
|
|
$return['status'] = "error";
|
|
$return['error'] = "Wrong action";
|
|
echo json_encode($return);
|
|
exit();
|
|
}
|
|
} else {
|
|
$return['status'] = "error";
|
|
$return['error'] = "Missing data";
|
|
echo json_encode($return);
|
|
exit();
|
|
}
|
|
}
|