1
0
Fork 0
mirror of https://github.com/fernwerker/ownDynDNS.git synced 2025-07-09 21:55:13 +02:00

modified: README.md

new file:   dnsapi.php
	new file:   update.php
initial commit with working update.php and dnsapi.php by netcup
This commit is contained in:
Felix Kretschmer 2018-08-06 21:13:49 +02:00
parent 824533494a
commit 5aeaa214c5
3 changed files with 1552 additions and 1 deletions

View file

@ -1,2 +1,36 @@
# owndyndns
Own DynDNS Application for DNS API
Self-hosted dynamic DNS php script for FRITZ!Box and netcup DNS API
## Authors
* Felix Kretschmer
* Philipp Tempel
## Usage
### Installation
* Copy all files to your webspace
* Edit the first lines of update.php
* username -> The username for your FRITZ!Box to authenticate (so not everyone can update your DNS)
* password -> password for your FRITZ!Box
* debug -> enables debug mode and generates output of update.php (normal operation has no output)
* apiKey -> API key which is generated in netcup CCP
* apiPassword -> API password which is generated in netcup CCP
* Create each host record in your netcup CCP before using the script. The script does not create non-existent records.
### FRITZ!Box Settings
* Go to "Internet" -> "DynDNS"
* Choose "custom"
* Update-URL: https://<url of your webspace>/update.php?user=<username>&password=<pass>&ipv4=<ipaddr>&ipv6=<ip6addr>&domain=<domain>
* only the url needs to be adjusted, the rest is automatically filled by the FRITZ!Box
* http or https is possible if valid SSL certificate (e.g. Let's Encrypt)
* Domainname: <host record that is supposed to be updated>
* Username: <username as defined in update.php>
* Password: <password as definied in update.php>
## References
* DNS API Documentation: https://ccp.netcup.net/run/webservice/servers/endpoint.php
* dnsapi.php is provided by netcup
## License
Published under GNU General Public License v3.0
&copy; Felix Kretschmer, 2018

1372
dnsapi.php Normal file

File diff suppressed because it is too large Load diff

145
update.php Executable file
View file

@ -0,0 +1,145 @@
<?php
require_once "dnsapi.php";
//
// CONFIG SECTION
// Info:
// Hostname record needs to exist before script is working
// This script will not create missing hostnames in the DNS zone
//
$username = "dyndns.username";
$password = "secret";
$dataFile = "data.json";
$debug = false;
// netcup API information
$apiKey = "netcup DNS API Key";
$apiPassword = "netcup DNS API Password";
$customerId = "netcup customer id";
//
// NO CONFIGURATION BEYOND THIS LINE
//
$getUsername = $_GET['user'];
$getPassword = $_GET['password'];
$getDomain = $_GET['domain'];
$getIpv4 = $_GET['ipv4'];
$getIpv6 = $_GET['ipv6'];
// FUNCTIONS
// is called to write dataFile and exit
function write_and_exit(){
global $dataFile, $data;
if(!@file_put_contents($dataFile, json_encode($data))){
echo("[ERROR] unable to write $dataFile <br>");
}
exit();
}
// is called to append log to data object and enable debug output
function logging($text){
global $data, $debug, $getDomain;
array_push($data[$getDomain]['log'], $text);
if($debug == true){
echo("[DEBUG] $text <br>");
}
}
// function to get domain and reduce host from it
function reduceHost($domain){
$domainParts = explode('.', $domain);
array_shift($domainParts);
$tld = implode('.', $domainParts);
return $tld;
}
// INIT
if($debug == true){
error_reporting( E_ALL );
ini_set('display_errors', 1);
}
// PRESET VALIDATION
// get data from object, create if not existent
if(file_exists($dataFile)){
$data = json_decode(@file_get_contents($dataFile), true);
} else {
touch($dataFile);
}
// check for domain parameter and exit if NULL
if(empty($getDomain)){
logging("no domain given. exiting...");
write_and_exit();
}
// init log array
$data[$getDomain]['log'] = [];
// authenticate, store number of failed logins
if($getUsername != $username or $getPassword != $password){
logging("authentication failed. exiting...");
$data[$getDomain]['failed_logins']++;
write_and_exit();
} else {
$data[$getDomain]['failed_logins']=0;
}
// DOMAIN SPECIFIC PROCESSING
// write current timestamp to data array
$data[$getDomain]['timestamp'] = time();
// validate IP addresses (v4 and v6) and write to data array
if(filter_var($getIpv4, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4)){
logging("valid IPv4");
// write to data array
$data[$getDomain]['ipv4'] = $getIpv4;
} else {
logging("no valid IPv4");
// write to data array
$data[$getDomain]['ipv4'] = NULL;
}
if(filter_var($getIpv6, FILTER_VALIDATE_IP, FILTER_FLAG_IPV6)){
logging("valid IPv6");
// write to data array
$data[$getDomain]['ipv6'] = $getIpv6;
} else {
logging("no valid IPv6");
// write to data array
$data[$getDomain]['ipv6'] = NULL;
}
if($data[$getDomain]['ipv4'] == NULL && $data[$getDomain]['ipv6'] == NULL){
logging("no valid IP found");
write_and_exit();
}
// broadcast new IP to DNS API
$clientRequestId = md5($getDomain);
$dnsClient = new DomainWebserviceSoapClient();
$clientHandle = $dnsClient->login($customerId, $apiKey, $apiPassword, $clientRequestId);
$infoHandle = $dnsClient->infoDnsRecords(reduceHost($getDomain), $customerId, $apiKey, $clientHandle->responsedata->apisessionid, $clientRequestId);#
$dnsrecords = $infoHandle->responsedata->dnsrecords;
foreach($dnsrecords as $key => &$record){
// write IPv4 update set if valid address and existent record
if($record->hostname == explode('.', "$getDomain")[0] && $record->type == "A" && $data[$getDomain]['ipv4'] != NULL){
$record->destination = $data[$getDomain]['ipv4'];
}
// write IPv6 update set if valid address and existent record
if($record->hostname == explode('.', "$getDomain")[0] && $record->type == "AAAA" && $data[$getDomain]['ipv6'] != NULL){
$record->destination = $data[$getDomain]['ipv6'];
}
}
//$clientHandle->clientrequestid = md5(microtime(true));
$recordSet = new Dnsrecordset();
$recordSet->dnsrecords = $dnsrecords;
$updateHandle = $dnsClient->updateDnsRecords(reduceHost($getDomain), $customerId, $apiKey, $clientHandle->responsedata->apisessionid, $clientRequestId, $recordSet);
logging("dns recordset updated");
$result = $dnsClient->logout($customerId, $apiKey, $clientHandle->responsedata->apisessionid, $clientRequestId);
logging("api logout");
// finish
write_and_exit();
?>