]> git.ipfire.org Git - people/pmueller/ipfire-2.x.git/blobdiff - src/scripts/setddns.pl
Updated strongswan (4.4.1).
[people/pmueller/ipfire-2.x.git] / src / scripts / setddns.pl
index 6fec966a4a44d7e36ec6fcd40c263d52900d333c..beb9af8b884ee7d530cb7a6cdf28992384ee9f5c 100644 (file)
@@ -75,7 +75,6 @@ if ( &General::IpInSubnet ($ip,'10.0.0.0','255.0.0.0') ||
     }
 }
 
-
 if ($ARGV[0] eq '-f') {
        unlink ($cachefile);    # next regular calls will try again if this force update fails.
 } else {
@@ -161,7 +160,7 @@ if ($ip ne $ipcache) {
                            my ($out, $response) = Net::SSLeay::get_http(  'www.cjb.net',
                                                                            80,
                                                                            "/cgi-bin/dynip.cgi?username=$settings{'LOGIN'}&password=$settings{'PASSWORD'}&ip=$ip",
-                                                                           Net::SSLeay::make_headers('User-Agent' => 'Ipcop' )
+                                                                           Net::SSLeay::make_headers('User-Agent' => 'IPFire' )
                                                                         );
 
                            if ($response =~ m%HTTP/1\.. 200 OK%) {
@@ -175,6 +174,33 @@ if ($ip ne $ipcache) {
                                &General::log("Dynamic DNS ip-update for cjb.net ($settings{'LOGIN'}) : failure (could not connect to server)");
                            }
                        }
+                       elsif ($settings{'SERVICE'} eq 'mydyn') {
+                           # use proxy ?
+                           my %proxysettings;
+                           &General::readhash("${General::swroot}/proxy/settings", \%proxysettings);
+                           if ($_=$proxysettings{'UPSTREAM_PROXY'}) {
+                               my ($peer, $peerport) = (/^(?:[a-zA-Z ]+\:\/\/)?(?:[A-Za-z0-9\_\.\-]*?(?:\:[A-Za-z0-9\_\.\-]*?)?\@)?([a-zA-Z0-9\.\_\-]*?)(?:\:([0-9]{1,5}))?(?:\/.*?)?$/);
+                               Net::SSLeay::set_proxy($peer,$peerport,$proxysettings{'UPSTREAM_USER'},$proxysettings{'UPSTREAM_PASSWORD'} );
+                           }
+
+                           my ($out, $response) = Net::SSLeay::get_http(  'www.mydyn.de',
+                                                                           80,
+                                                                           "/cgi-bin/update.pl?$settings{'LOGIN'}-$settings{'PASSWORD'}",
+                                                                           Net::SSLeay::make_headers('User-Agent' => 'IPFire' )
+                                                                       );
+
+                           if ($response =~ m%HTTP/1\.. 200 OK%) {
+                               if ( $out !~ m/The IP address of the subdomain/ ) {
+                                   &General::log("Dynamic DNS ip-update for mydyn.de ($settings{'LOGIN'}) : failure (bad password or login)");
+                               } else {
+                                   &General::log("Dynamic DNS ip-update for mydyn.de ($settings{'LOGIN'}) : success");
+                                   $success++;
+                               }
+                           } else {
+                               &General::log("Dynamic DNS ip-update for mydyn.de ($settings{'LOGIN'}) : failure (could not connect to server)");
+                           }
+
+                       }
                        elsif ($settings{'SERVICE'} eq 'selfhost') {
                            # use proxy ?
                            my %proxysettings;
@@ -187,7 +213,7 @@ if ($ip ne $ipcache) {
                            my ($out, $response) = Net::SSLeay::get_https(  'carol.selfhost.de',
                                                                            443,
                                                                            "/update?username=$settings{'LOGIN'}&password=$settings{'PASSWORD'}&textmodi=1",
-                                                                           Net::SSLeay::make_headers('User-Agent' => 'Ipcop' )
+                                                                           Net::SSLeay::make_headers('User-Agent' => 'IPFire' )
                                                                         );
 
                            if ($response =~ m%HTTP/1\.. 200 OK%) {
@@ -220,7 +246,7 @@ if ($ip ne $ipcache) {
                            my ($out, $response) = Net::SSLeay::get_https(  "www.dnspark.net",
                                                                            443,
                                                                            "/api/dynamic/update.php?hostname=$settings{'HOSTDOMAIN'}&ip=$ip",
-                                                                           Net::SSLeay::make_headers('User-Agent' => 'Ipcop',
+                                                                           Net::SSLeay::make_headers('User-Agent' => 'IPFire',
                                                                                                      'Authorization' => 'Basic ' . encode_base64("$settings{'LOGIN'}:$settings{'PASSWORD'}")
                                                                             )
                                                                         );
@@ -254,7 +280,7 @@ if ($ip ne $ipcache) {
                            my ($out, $response) = Net::SSLeay::get_http(  'dynamic.name-services.com',
                                                                            80,
                                                                            "/interface.asp?Command=SetDNSHost&Zone=$settings{'DOMAIN'}&DomainPassword=$settings{'PASSWORD'}&Address=$ip",
-                                                                           Net::SSLeay::make_headers('User-Agent' => 'Ipcop' )
+                                                                           Net::SSLeay::make_headers('User-Agent' => 'IPFire' )
                                                                         );
 
                            if ($response =~ m%HTTP/1\.. 200 OK%) {
@@ -347,7 +373,7 @@ if ($ip ne $ipcache) {
                            my ($out, $response) = Net::SSLeay::get_https(  'freedns.afraid.org',
                                                                            443,
                                                                            "/dynamic/update.php?$settings{'LOGIN'}",
-                                                                           Net::SSLeay::make_headers('User-Agent' => 'Ipcop' )
+                                                                           Net::SSLeay::make_headers('User-Agent' => 'IPFire' )
                                                                         );
                            #Valid responses from service are:
                             #Updated n host(s) <domain>
@@ -365,33 +391,31 @@ if ($ip ne $ipcache) {
                            }
                        }
                        elsif ($settings{'SERVICE'} eq 'regfish') {
-                           # use proxy ?
-                           my %proxysettings;
-                           &General::readhash("${General::swroot}/proxy/settings", \%proxysettings);
-                           if ($_=$proxysettings{'UPSTREAM_PROXY'}) {
-                               my ($peer, $peerport) = (/^(?:[a-zA-Z ]+\:\/\/)?(?:[A-Za-z0-9\_\.\-]*?(?:\:[A-Za-z0-9\_\.\-]*?)?\@)?([a-zA-Z0-9\.\_\-]*?)(?:\:([0-9]{1,5}))?(?:\/.*?)?$/);
-                               Net::SSLeay::set_proxy($peer,$peerport,$proxysettings{'UPSTREAM_USER'},$proxysettings{'UPSTREAM_PASSWORD'} );
-                           }
-
-
-                           my ($out, $response) = Net::SSLeay::get_https(  'www.regfish.com',
-                                                                           443,
-                                                                           "/dyndns/2/?fqdn=$settings{'DOMAIN'}&ipv4=$ip&forcehost=1&authtype=secure&token=$settings{'LOGIN'}",
-                                                                           Net::SSLeay::make_headers('User-Agent' => 'Ipcop' )
-                                                                        );
-                           #Valid responses from service are:
-                           #success|100|update succeeded!
-                           #success|101|no update needed at this time..
-                           if ($response =~ m%HTTP/1\.. 200 OK%) {
-                               if ( $out !~ m/(success\|(100|101)\|)/ig ) {
-                                   &General::log("Dynamic DNS ip-update for $settings{'DOMAIN'} : failure ($out)");
+                               # use proxy ?
+                               my %proxysettings;
+                               &General::readhash("${General::swroot}/proxy/settings", \%proxysettings);
+                               if ($_=$proxysettings{'UPSTREAM_PROXY'}) {
+                                       my ($peer, $peerport) = (/^(?:[a-zA-Z ]+\:\/\/)?(?:[A-Za-z0-9\_\.\-]*?(?:\:[A-Za-z0-9\_\.\-]*?)?\@)?([a-zA-Z0-9\.\_\-]*?)(?:\:([0-9]{1,5}))?(?:\/.*?)?$/);
+                                       Net::SSLeay::set_proxy($peer,$peerport,$proxysettings{'UPSTREAM_USER'},$proxysettings{'UPSTREAM_PASSWORD'} );
+                               }
+                               my ($out, $response) = Net::SSLeay::get_https(  'dyndns.regfish.de',
+                                                                               443,
+                                                                               "/?fqdn=$settings{'DOMAIN'}&ipv4=$ip&forcehost=1&authtype=secure&token=$settings{'LOGIN'}",
+                                                                               Net::SSLeay::make_headers('User-Agent' => 'Ipfire' )
+                                                                               );
+                               #Valid responses from service are:
+                               # success|100|update succeeded!
+                               # success|101|no update needed at this time..
+                               if ($response =~ m%HTTP/1\.. 200 OK%) {
+                                       if ( $out !~ m/(success\|(100|101)\|)/ig ) {
+                                               &General::log("Dynamic DNS ip-update for $settings{'DOMAIN'} : failure ($out)");
+                                       } else {
+                                               &General::log("Dynamic DNS ip-update for $settings{'DOMAIN'} : success");
+                                               $success++;
+                                       }
                                } else {
-                                   &General::log("Dynamic DNS ip-update for $settings{'DOMAIN'} : success");
-                                   $success++;
+                                       &General::log("Dynamic DNS ip-update for $settings{'DOMAIN'} : failure (could not connect to server)");
                                }
-                           } else {
-                               &General::log("Dynamic DNS ip-update for $settings{'DOMAIN'} : failure (could not connect to server)");
-                           }
                        }
                        elsif ($settings{'SERVICE'} eq 'ovh') {
                                my %proxysettings;
@@ -421,7 +445,7 @@ if ($ip ne $ipcache) {
                                $GET_CMD .= "Host: www.ovh.com\r\n";
                                chomp($code64 = encode_base64("$settings{'LOGIN'}:$settings{'PASSWORD'}"));
                                $GET_CMD .= "Authorization: Basic $code64\r\n";
-                               $GET_CMD .= "User-Agent: ipcop\r\n";
+                               $GET_CMD .= "User-Agent: ipfire\r\n";
                               #$GET_CMD .= "Content-Type: application/x-www-form-urlencoded\r\n";
                                $GET_CMD .= "\r\n";
                                print $sock "$GET_CMD";
@@ -465,7 +489,7 @@ if ($ip ne $ipcache) {
                            my ($out, $response) = Net::SSLeay::get_http(  'www.dtdns.com',
                                                                            80,
                                                                            "/api/autodns.cfm?id=$settings{'HOSTDOMAIN'}&pw=$settings{'PASSWORD'}",
-                                                                           Net::SSLeay::make_headers('User-Agent' => 'Ipcop' )
+                                                                           Net::SSLeay::make_headers('User-Agent' => 'IPFire' )
                                                                         );
                            #Valid responses from service are:
                            #   now points to
@@ -499,7 +523,7 @@ if ($ip ne $ipcache) {
                            my ($out, $response) = Net::SSLeay::get_http(  'dynserv.ca',
                                                                            80,
                                                                            "/dyn/dynengine.cgi?func=set&name=$settings{'LOGIN'}&pass=$settings{'PASSWORD'}&ip=$ip&domain=$settings{'DOMAIN'}",
-                                                                           Net::SSLeay::make_headers('User-Agent' => 'Ipcop' )
+                                                                           Net::SSLeay::make_headers('User-Agent' => 'IPFire' )
                                                                         );
                            #Valid responses from service are:
                            # 02 == Domain already exists, refreshing data for ... => xxx.xxx.xxx.xxx
@@ -601,7 +625,7 @@ old code for selfhost.de
                                my $GET_CMD;
                                $GET_CMD  = "GET https://carol.selfhost.de/update?username=$settings{'LOGIN'}&password=$settings{'PASSWORD'}&myip=$ip&textmodi=1 HTTP/1.1\r\n";
                                $GET_CMD .= "Host: carol.selfhost.de\r\n";
-                               $GET_CMD .= "User-Agent: ipcop\r\n";
+                               $GET_CMD .= "User-Agent: ipfire\r\n";
                                $GET_CMD .= "Connection: close\r\n\r\n";
                                print $sock "$GET_CMD";