From: Stefan Schantl <stefan.schantl@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: [PATCH] add ddns Provider key-systems.net
Date: Thu, 23 Jan 2020 11:54:43 +0100 [thread overview]
Message-ID: <5b11bb718a977d69a7726185d8ef2ef095126ddc.camel@ipfire.org> (raw)
In-Reply-To: <74ACA093-C896-4CB7-895F-B90F40A9151B@ipfire.org>
[-- Attachment #1: Type: text/plain, Size: 3534 bytes --]
Hello Christof,
thanks for your Patch.
I've merged it and corrected the "extra new line" issue.
Because we currently porting DDNS to python3, I also did a required
change.
Best regards,
-Stefan
> Hey Christof,
>
> Reviewed-by: Michael Tremer <michael.tremer(a)ipfire.org>
>
> > On 7 Jan 2020, at 16:35, Christof Weniger <ChristofWeniger(a)gmx.at>
> > wrote:
> >
> > Hi,
> >
> > sorry for the long delay. It's the time of the year, where I think
> > it might be easier to just move in with the childrens doctor
> > instead of daily vists :-(
>
> That doesn’t sound good :(
>
> > Michael thank you for your pointers and reviews.
>
> The patch however does!
>
> There is an extra newline after the class, but I guess we can accept
> it.
>
> I will leave it for Stefan to merge.
>
> Thanks.
>
> -Michael
>
> >
> > ---
> > README | 1 +
> > src/ddns/providers.py | 46
> > +++++++++++++++++++++++++++++++++++++++++++
> > 2 files changed, 47 insertions(+)
> >
> > diff --git a/README b/README
> > index c75c448..b6decb3 100644
> > --- a/README
> > +++ b/README
> > @@ -72,6 +72,7 @@ SUPPORTED PROVIDERS:
> > inwx.com|de|at|ch|es
> > itsdns.de
> > joker.com
> > + key-systems.net
> > loopia.se
> > myonlineportal.net
> > namecheap.com
> > diff --git a/src/ddns/providers.py b/src/ddns/providers.py
> > index 661fbcc..666740e 100644
> > --- a/src/ddns/providers.py
> > +++ b/src/ddns/providers.py
> > @@ -1204,6 +1204,52 @@ class DDNSProviderJoker(DDNSProtocolDynDNS2,
> > DDNSProvider):
> > url = "https://svc.joker.com/nic/update"
> >
> >
> > +class DDNSProviderKEYSYSTEMS(DDNSProvider):
> > + handle = "key-systems.net"
> > + name = "dynamicdns.key-systems.net"
> > + website = "https://domaindiscount24.com/"
> > + protocols = ("ipv4",)
> > +
> > + # There are only information provided by the domaindiscount24
> > how to
> > + # perform an update with HTTP APIs
> > + # https://www.domaindiscount24.com/faq/dynamic-dns
> > + # examples:
> > https://dynamicdns.key-systems.net/update.php?hostname=hostname&password=password&ip=auto
> > + #
> > https://dynamicdns.key-systems.net/update.php?hostname=hostname&password=password&ip=213.x.x.x&mx=213.x.x.x
> > +
> > + url = "https://dynamicdns.key-systems.net/update.php"
> > + can_remove_records = False
> > +
> > + def update_protocol(self, proto):
> > + address = self.get_address(proto)
> > + data = {
> > + "hostname" : self.hostname,
> > + "password" : self.password,
> > + "ip" : address,
> > + }
> > +
> > + # Send update to the server.
> > + response = self.send_request(self.url, data=data)
> > +
> > + # Get the full response message.
> > + output = response.read()
> > +
> > + # Handle success messages.
> > + if "code = 200" in output:
> > + return
> > +
> > + # Handle error messages.
> > + if "abuse prevention triggered" in output:
> > + raise DDNSAbuseError
> > + elif "invalid password" in output:
> > + raise DDNSAuthenticationError
> > + elif "Authorization failed" in output:
> > + raise DDNSRequestError(_("Invalid hostname
> > specified"))
> > +
> > + # If we got here, some other update error happened.
> > + raise DDNSUpdateError
> > +
> > +
> > +
> > class DDNSProviderGoogle(DDNSProtocolDynDNS2, DDNSProvider):
> > handle = "domains.google.com"
> > name = "Google Domains"
> > --
> > 2.17.1
> >
prev parent reply other threads:[~2020-01-23 10:54 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <97e435c3-36ba-0468-34a4-68081f4c4520@gmx.at>
2019-11-28 15:17 ` DDNS: add new Provider key-sytems.net (domaindiscount24) Michael Tremer
2020-01-07 16:35 ` [PATCH] add ddns Provider key-systems.net Christof Weniger
2020-01-07 20:47 ` Michael Tremer
2020-01-23 10:54 ` Stefan Schantl [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=5b11bb718a977d69a7726185d8ef2ef095126ddc.camel@ipfire.org \
--to=stefan.schantl@ipfire.org \
--cc=development@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox