summaryrefslogtreecommitdiff
path: root/packages/ddclient/patches/z1_duckdns-ipv4-ipv6-pr588.patch
diff options
context:
space:
mode:
authorChristian Breunig <christian@breunig.cc>2023-11-06 21:34:45 +0100
committerGitHub <noreply@github.com>2023-11-06 21:34:45 +0100
commitaeda9f37f569e4b9b19cf17748a502fa70d70e77 (patch)
tree933612a23f040a86fb2ba4af3a8788f955dbcd5a /packages/ddclient/patches/z1_duckdns-ipv4-ipv6-pr588.patch
parent74b06c308bb6316704d58a5a4386c8dda3c363f2 (diff)
parentf3cc9f58b60a8b9d69fe741e6e6811d06bd82a15 (diff)
downloadvyos-build-aeda9f37f569e4b9b19cf17748a502fa70d70e77.tar.gz
vyos-build-aeda9f37f569e4b9b19cf17748a502fa70d70e77.zip
Merge pull request #453 from indrajitr/ddclient-bump-311
ddclient: T5708: Upgrade to ddclient 3.11.1
Diffstat (limited to 'packages/ddclient/patches/z1_duckdns-ipv4-ipv6-pr588.patch')
-rw-r--r--packages/ddclient/patches/z1_duckdns-ipv4-ipv6-pr588.patch67
1 files changed, 67 insertions, 0 deletions
diff --git a/packages/ddclient/patches/z1_duckdns-ipv4-ipv6-pr588.patch b/packages/ddclient/patches/z1_duckdns-ipv4-ipv6-pr588.patch
new file mode 100644
index 00000000..e80d16d7
--- /dev/null
+++ b/packages/ddclient/patches/z1_duckdns-ipv4-ipv6-pr588.patch
@@ -0,0 +1,67 @@
+From 3a224b66a4fa5758427dfe131a33e6337eebeff7 Mon Sep 17 00:00:00 2001
+From: Indrajit Raychaudhuri <irc@indrajit.com>
+Date: Thu, 2 Nov 2023 18:56:31 -0500
+Subject: [PATCH] duckdns: Adjust script to support simultaneous IPv4 and IPv6
+ updates
+
+Ref: ddclient/ddclient#588
+---
+ ddclient.in | 25 ++++++++++++++-----------
+ 1 file changed, 14 insertions(+), 11 deletions(-)
+
+diff --git a/ddclient.in b/ddclient.in
+index f38db33f..1d8a16a2 100755
+--- a/ddclient.in
++++ b/ddclient.in
+@@ -6477,8 +6477,10 @@ sub nic_duckdns_update {
+ ## update each configured host
+ ## should improve to update in one pass
+ foreach my $h (@_) {
+- my $ip = delete $config{$h}{'wantip'};
+- info("setting IP address to %s for %s", $ip, $h);
++ my $ipv4 = delete $config{$h}{'wantipv4'};
++ my $ipv6 = delete $config{$h}{'wantipv6'};
++ info("setting IPv4 address to %s for %s", $ipv4, $h) if $ipv4;
++ info("setting IPv6 address to %s for %s", $ipv6, $h) if $ipv6;
+ verbose("UPDATE:", "updating %s", $h);
+
+ # Set the URL that we're going to to update
+@@ -6488,13 +6490,8 @@ sub nic_duckdns_update {
+ $url .= $h;
+ $url .= "&token=";
+ $url .= $config{$h}{'password'};
+- if (is_ipv6($ip)) {
+- $url .= "&ipv6=";
+- } else {
+- $url .= "&ip=";
+- }
+- $url .= $ip;
+-
++ $url .= "&ip=$ipv4" if $ipv4;
++ $url .= "&ipv6=$ipv6" if $ipv6;
+
+ # Try to get URL
+ my $reply = geturl(proxy => opt('proxy'), url => $url);
+@@ -6512,14 +6509,20 @@ sub nic_duckdns_update {
+
+ foreach $line (@reply) {
+ if ($line eq 'OK') {
+- $config{$h}{'ip'} = $ip;
++ $config{$h}{'ipv4'} = $ipv4 if $ipv4;
++ $config{$h}{'ipv6'} = $ipv6 if $ipv6;
+ $config{$h}{'mtime'} = $now;
+ $config{$h}{'status'} = 'good';
++ $config{$h}{'status-ipv4'} = 'good' if $ipv4;
++ $config{$h}{'status-ipv6'} = 'good' if $ipv6;
+ $state = 'result';
+- success("updating %s: good: IP address set to %s", $h, $ip);
++ success("updating %s: good: IPv4 address set to %s", $h, $ipv4) if $ipv4;
++ success("updating %s: good: IPv6 address set to %s", $h, $ipv6) if $ipv6;
+
+ } elsif ($line eq 'KO') {
+ $config{$h}{'status'} = 'failed';
++ $config{$h}{'status-ipv4'} = 'failed' if $ipv4;
++ $config{$h}{'status-ipv6'} = 'failed' if $ipv6;
+ $state = 'result';
+ failed("updating %s: Server said: '%s'", $h, $line);
+ }