From 88e5212c44d56bca220a3d5456877402fee7d3d3 Mon Sep 17 00:00:00 2001
From: Pinga <121483313+getpinga@users.noreply.github.com>
Date: Mon, 28 Oct 2024 19:24:13 +0200
Subject: [PATCH] Added support for DNSSEC, fixed #15
---
epp.php | 194 ++++++++++++++++++++++++++++++++++++++
manageDNSSECDSRecords.tpl | 124 ++++++++++++++++++++++++
2 files changed, 318 insertions(+)
create mode 100644 manageDNSSECDSRecords.tpl
diff --git a/epp.php b/epp.php
index 12ce48e..b152394 100644
--- a/epp.php
+++ b/epp.php
@@ -1469,6 +1469,200 @@ function epp_RequestDelete($params = array())
return $return;
}
+function epp_manageDNSSECDSRecords($params = array())
+{
+ _epp_log(__FUNCTION__, $params);
+ $return = array();
+ try {
+ $s = _epp_startEppClient($params);
+
+ if (isset($_POST['command']) && ($_POST['command'] === 'secDNSadd')) {
+ $keyTag = $_POST['keyTag'];
+ $alg = $_POST['alg'];
+ $digestType = $_POST['digestType'];
+ $digest = $_POST['digest'];
+
+ $from = $to = array();
+ $from[] = '/{{ name }}/';
+ $to[] = htmlspecialchars($params['domainname']);
+
+ $from[] = '/{{ keyTag }}/';
+ $to[] = htmlspecialchars($keyTag);
+
+ $from[] = '/{{ alg }}/';
+ $to[] = htmlspecialchars($alg);
+
+ $from[] = '/{{ digestType }}/';
+ $to[] = htmlspecialchars($digestType);
+
+ $from[] = '/{{ digest }}/';
+ $to[] = htmlspecialchars($digest);
+
+ $from[] = '/{{ clTRID }}/';
+ $clTRID = str_replace('.', '', round(microtime(1), 3));
+ $to[] = htmlspecialchars($params['registrarprefix'] . '-domain-update-' . $clTRID);
+ $xml = preg_replace($from, $to, '
+
+
+
+
+ {{ name }}
+
+
+
+
+
+
+ {{ keyTag }}
+ {{ alg }}
+ {{ digestType }}
+ {{ digest }}
+
+
+
+
+ {{ clTRID }}
+
+');
+ $r = $s->write($xml, __FUNCTION__);
+ }
+
+ if (isset($_POST['command']) && ($_POST['command'] === 'secDNSrem')) {
+ $keyTag = $_POST['keyTag'];
+ $alg = $_POST['alg'];
+ $digestType = $_POST['digestType'];
+ $digest = $_POST['digest'];
+
+ $from = $to = array();
+ $from[] = '/{{ name }}/';
+ $to[] = htmlspecialchars($params['domainname']);
+
+ $from[] = '/{{ keyTag }}/';
+ $to[] = htmlspecialchars($keyTag);
+
+ $from[] = '/{{ alg }}/';
+ $to[] = htmlspecialchars($alg);
+
+ $from[] = '/{{ digestType }}/';
+ $to[] = htmlspecialchars($digestType);
+
+ $from[] = '/{{ digest }}/';
+ $to[] = htmlspecialchars($digest);
+
+ $from[] = '/{{ clTRID }}/';
+ $clTRID = str_replace('.', '', round(microtime(1), 3));
+ $to[] = htmlspecialchars($params['registrarprefix'] . '-domain-update-' . $clTRID);
+ $xml = preg_replace($from, $to, '
+
+
+
+
+ {{ name }}
+
+
+
+
+
+
+ {{ keyTag }}
+ {{ alg }}
+ {{ digestType }}
+ {{ digest }}
+
+
+
+
+ {{ clTRID }}
+
+');
+ $r = $s->write($xml, __FUNCTION__);
+ }
+
+ $from = $to = array();
+ $from[] = '/{{ name }}/';
+ $to[] = htmlspecialchars($params['domainname']);
+ $from[] = '/{{ clTRID }}/';
+ $clTRID = str_replace('.', '', round(microtime(1), 3));
+ $to[] = htmlspecialchars($params['registrarprefix'] . '-domain-info-' . $clTRID);
+ $xml = preg_replace($from, $to, '
+
+
+
+
+ {{ name }}
+
+
+ {{ clTRID }}
+
+');
+ $r = $s->write($xml, __FUNCTION__);
+
+ $secDNSdsData = array();
+ if ($r->response->extension && $r->response->extension->children('urn:ietf:params:xml:ns:secDNS-1.1')->infData) {
+ $DSRecords = 'YES';
+ $i = 0;
+ $r = $r->response->extension->children('urn:ietf:params:xml:ns:secDNS-1.1')->infData;
+ foreach($r->dsData as $dsData) {
+ $i++;
+ $secDNSdsData[$i]["domainid"] = (int)$params['domainid'];
+ $secDNSdsData[$i]["keyTag"] = (string)$dsData->keyTag;
+ $secDNSdsData[$i]["alg"] = (int)$dsData->alg;
+ $secDNSdsData[$i]["digestType"] = (int)$dsData->digestType;
+ $secDNSdsData[$i]["digest"] = (string)$dsData->digest;
+ }
+ }
+ else {
+ $DSRecords = "You don't have any DS records";
+ }
+
+ $return = array(
+ 'templatefile' => 'manageDNSSECDSRecords',
+ 'requirelogin' => true,
+ 'vars' => array(
+ 'DSRecords' => $DSRecords,
+ 'DSRecordslist' => $secDNSdsData
+ )
+ );
+ }
+
+ catch(exception $e) {
+ $return = array(
+ 'templatefile' => 'manageDNSSECDSRecords',
+ 'requirelogin' => true,
+ 'vars' => array(
+ 'error' => $e->getMessage()
+ )
+ );
+ }
+
+ if (!empty($s)) {
+ $s->logout($params['registrarprefix']);
+ }
+
+ return $return;
+}
+
+function epp_ClientAreaCustomButtonArray()
+{
+ $buttonarray = array(
+ Lang::Trans('Manage DNSSEC DS Records') => 'manageDNSSECDSRecords'
+ );
+
+ return $buttonarray;
+}
+
function epp_AdminCustomButtonArray($params = array())
{
_epp_log(__FUNCTION__, $params);
diff --git a/manageDNSSECDSRecords.tpl b/manageDNSSECDSRecords.tpl
new file mode 100644
index 0000000..95f66f4
--- /dev/null
+++ b/manageDNSSECDSRecords.tpl
@@ -0,0 +1,124 @@
+
+
+
Manage DNSSEC DS Records
+
+{if $error}
+
+ {$error}
+
+{else}
+ {if $DSRecords eq 'YES'}
+ {foreach $DSRecordslist as $item}
+
+ {/foreach}
+ {else}
+
+ {$DSRecords}
+
+ {/if}
+{/if}
+
+
+
+
+
+
+
+
\ No newline at end of file