return self.get("password")
def __call__(self):
+ self.update()
+
+ def update(self):
raise NotImplementedError
def send_request(self, *args, **kwargs):
return self.core.system.get_address(proto)
+class DDNSProviderDHS(DDNSProvider):
+ INFO = {
+ "handle" : "dhs.org",
+ "name" : "DHS International",
+ "website" : "http://dhs.org/",
+ "protocols" : ["ipv4",]
+ }
+
+ # No information about the used update api provided on webpage,
+ # grabed from source code of ez-ipudate.
+ url = "http://members.dhs.org/nic/hosts"
+
+ def update(self):
+ url = self.url % {
+ "username" : self.username,
+ "password" : self.password,
+ }
+
+ data = {
+ "domain" : self.hostname,
+ "ip" : self.get_address("ipv4"),
+ "hostcmd" : "edit",
+ "hostcmdstage" : "2",
+ "type" : "4",
+ }
+
+ # Send update to the server.
+ response = self.send_request(url, username=self.username, password=self.password,
+ data=data)
+
+ # Handle success messages.
+ if response.code == 200:
+ return
+
+ # Handle error codes.
+ elif response.code == "401":
+ raise DDNSAuthenticationError
+
+ # If we got here, some other update error happened.
+ raise DDNSUpdateError
+
+
+class DDNSProviderDNSpark(DDNSProvider):
+ INFO = {
+ "handle" : "dnspark.com",
+ "name" : "DNS Park",
+ "website" : "http://dnspark.com/",
+ "protocols" : ["ipv4",]
+ }
+
+ # Informations to the used api can be found here:
+ # https://dnspark.zendesk.com/entries/31229348-Dynamic-DNS-API-Documentation
+ url = "https://control.dnspark.com/api/dynamic/update.php"
+
+ def update(self):
+ url = self.url % {
+ "username" : self.username,
+ "password" : self.password,
+ }
+
+ data = {
+ "domain" : self.hostname,
+ "ip" : self.get_address("ipv4"),
+ }
+
+ # Send update to the server.
+ response = self.send_request(url, username=self.username, password=self.password,
+ data=data)
+
+ # Get the full response message.
+ output = response.read()
+
+ # Handle success messages.
+ if output.startswith("ok") or output.startswith("nochange"):
+ return
+
+ # Handle error codes.
+ if output == "unauth":
+ raise DDNSAuthenticationError
+ elif output == "abuse":
+ raise DDNSAbuseError
+ elif output == "blocked":
+ raise DDNSBlockedError
+ elif output == "nofqdn":
+ raise DDNSRequestError(_("No valid FQDN was given."))
+ elif output == "nohost":
+ raise DDNSRequestError(_("Invalid hostname specified."))
+ elif output == "notdyn":
+ raise DDNSRequestError(_("Hostname not marked as a dynamic host."))
+ elif output == "invalid":
+ raise DDNSRequestError(_("Invalid IP address has been sent."))
+
+ # If we got here, some other update error happened.
+ raise DDNSUpdateError
+
+
class DDNSProviderLightningWireLabs(DDNSProvider):
INFO = {
"handle" : "dns.lightningwirelabs.com",
"""
return self.get("token")
- def __call__(self):
+ def update(self):
data = {
"hostname" : self.hostname,
}
raise DDNSConfigurationError
# Send update to the server.
- response = self.send_request(url, data=data)
+ response = self.send_request(self.url, data=data)
# Handle success messages.
if response.code == 200:
return
# Handle error codes.
- if response.code == "403":
+ if response.code == 403:
raise DDNSAuthenticationError
- elif response.code == "400":
+ elif response.code == 400:
raise DDNSRequestError
# If we got here, some other update error happened.
url = "http://%(username)s:%(password)s@dynupdate.no-ip.com/nic/update"
- def __call__(self):
+ def update(self):
url = self.url % {
"username" : self.username,
"password" : self.password,
url = "https://carol.selfhost.de/update"
- def __call__(self):
+ def update(self):
data = {
"username" : self.username,
"password" : self.password,