/[smecontribs]/rpms/smeserver-ddclient/contribs10/smeserver-ddclient-1.3.0-Update-SM2-code-for-new-services-and-protocols.patch
ViewVC logotype

Annotation of /rpms/smeserver-ddclient/contribs10/smeserver-ddclient-1.3.0-Update-SM2-code-for-new-services-and-protocols.patch

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.2 - (hide annotations) (download)
Mon Dec 4 08:48:10 2023 UTC (11 months, 3 weeks ago) by brianr
Branch: MAIN
Changes since 1.1: +228 -156 lines
* Fri Nov 10 2023 Brian Read <brianr@koozali.org> 1.3.0-28.sme
- Update template for deprecated commands and v3.11.1 ddclient [SME: 12427 ]
- Update SM2 code to show all new protocols etc

1 brianr 1.1 diff -urN smeserver-ddclient-1.3.0.old/root/usr/share/smanager/lib/SrvMngr/Controller/Ddclient.pm smeserver-ddclient-1.3.0/root/usr/share/smanager/lib/SrvMngr/Controller/Ddclient.pm
2     --- smeserver-ddclient-1.3.0.old/root/usr/share/smanager/lib/SrvMngr/Controller/Ddclient.pm 2023-11-10 16:11:05.915271983 +0000
3 brianr 1.2 +++ smeserver-ddclient-1.3.0/root/usr/share/smanager/lib/SrvMngr/Controller/Ddclient.pm 2023-12-01 17:16:00.000000000 +0000
4     @@ -114,57 +114,168 @@
5 brianr 1.1
6     my %ddc_datas = ();
7    
8     +sub get_devices_names {
9     + #
10     + # Router devices from which it can get ip address
11     + #
12     + my $devices = ( [
13 brianr 1.2 + [ '2wire' => '2Wire 1701HG Gateway' ],
14     + [ '3com-3c886a' => '3com 3c886a 56k Lan Modem' ],
15     + [ '3com-oc-remote812' => '3com OfficeConnect Remote 812' ],
16     + [ 'alcatel-510' => 'Alcatel Speed Touch 510' ],
17     + [ 'alcatel-530' => 'Alcatel/Thomson SpeedTouch 530' ],
18     + [ 'alcatel-stp' => 'Alcatel Speed Touch Pro' ],
19     + [ 'allnet-1298' => 'Allnet 1298' ],
20     + [ 'cayman-3220h' => 'Cayman 3220-H DSL' ],
21     + [ 'dlink-524' => 'D-Link DI-524' ],
22     + [ 'dlink-604' => 'D-Link DI-604' ],
23     + [ 'dlink-614' => 'D-Link DI-614+' ],
24     + [ 'e-tech' => 'E-tech Router' ],
25     + [ 'elsa-lancom-dsl10' => 'ELSA LanCom DSL/10 DSL FW' ],
26     + [ 'elsa-lancom-dsl10-ch01' => 'ELSA LanCom DSL/10 DSL FW (isdn ch01)' ],
27     + [ 'elsa-lancom-dsl10-ch02' => 'ELSA LanCom DSL/10 DSL FW (isdn ch01)' ],
28     + [ 'linksys' => 'Linksys FW' ],
29     + [ 'linksys-rv042-wan1' => 'Linksys RV042 Dual Homed Router WAN Port 2' ],
30     + [ 'linksys-rv042-wan2' => 'Linksys RV042 Dual Homed Router WAN Port 2' ],
31     + [ 'linksys-ver2' => 'Linksys FW version 2' ],
32     + [ 'linksys-ver3' => 'Linksys FW version 3' ],
33     + [ 'linksys-wcg200' => 'Linksys WCG200 FW' ],
34     + [ 'linksys-wrt854g' => 'Linksys WRT854G FW' ],
35     + [ 'maxgate-ugate3x00' => 'MaxGate UGATE-3x00 FW' ],
36     + [ 'netcomm-nb3' => 'NetComm NB3' ],
37     + [ 'netgear-dg834g' => 'netgear-dg834g' ],
38     + [ 'netgear-rp614' => 'Netgear RP614 FW' ],
39     + [ 'netgear-rt3xx' => 'Netgear FW' ],
40     + [ 'netgear-wgt624' => 'Netgear WGT624' ],
41     + [ 'netgear-wpn824' => 'Netgear WPN824 FW' ],
42     + [ 'netopia-r910' => 'Netopia R910 FW' ],
43     + [ 'olitec-SX200' => 'olitec-SX200' ],
44     + [ 'rtp300' => 'Linksys RTP300' ],
45     + [ 'siemens-ss4200' => 'Siemens SpeedStream 4200' ],
46     + [ 'sitecom-dc202' => 'Sitecom DC-202 FW' ],
47     + [ 'smc-barricade' => 'SMC Barricade FW' ],
48     + [ 'smc-barricade-7004vbr' => 'SMC Barricade FW (7004VBR model config)' ],
49     + [ 'smc-barricade-7401bra' => 'SMC Barricade 7401BRA FW' ],
50     + [ 'smc-barricade-alt' => 'SMC Barricade FW (alternate config)' ],
51     + [ 'sohoware-nbg800' => 'SOHOWare BroadGuard NBG800' ],
52     + [ 'sveasoft' => 'Sveasoft WRT54G/WRT54GS' ],
53     + [ 'thomson-st536v6' => 'Thomson SpeedTouch 536v6' ],
54     + [ 'thomson-tg782' => 'Thomson/Technicolor TG782' ],
55     + [ 'vigor-2200usb' => 'Vigor 2200 USB' ],
56     + [ 'watchguard-edge-x' => 'Watchguard Edge X FW' ],
57     + [ 'watchguard-soho' => 'Watchguard SOHO FW' ],
58     + [ 'westell-6100' => 'Westell C90-610015-06 DSL Router' ],
59     + [ 'xsense-aero' => 'Xsense Aero']
60 brianr 1.1 + ] );
61     + return $devices;
62     +
63     +
64     + # Automatic loading of the devices from the ddclient program - I can't get this to pass the results successfully to the template
65     + #my $output = `ddclient -list-devices`; # Run ddclient command to get devices output
66     + #my @lines;
67     + #foreach my $line (split /\n/, $output) {
68     + #$line =~ s/\s+//; # Remove leading whitespace
69     + #my ($field1, $field2) = split(' ', $line, 2);
70     + #push @lines, [$field2, $field1];
71     + #}
72     + #return \@lines; # Return a reference to the lines array
73     +}
74     +
75     +sub get_web_services_names {
76     + #
77     + # Web Services from which it can get ip address
78     + #
79     + my $webservices = ( [
80 brianr 1.2 + [ 'dyndnshttp://checkip.dyndns.org/' => 'dyndns' ],
81     + [ 'freednshttps://freedns.afraid.org/dynamic/check.php' => 'freedns' ],
82     + [ 'googledomainshttps://domains.google.com/checkip' => 'googledomains' ],
83     + [ 'hehttps://checkip.dns.he.net/' => 'he' ],
84     + [ 'ip4only.mehttps://ip4only.me/api/' => 'ip4only.me' ],
85     + [ 'ip6only.mehttps://ip6only.me/api/' => 'ip6only.me' ],
86     + [ 'ipify-ipv4https://api.ipify.org/' => 'ipify-ipv4' ],
87     + [ 'ipify-ipv6https://api6.ipify.org/' => 'ipify-ipv6' ],
88     + [ 'loopiahttps://dns.loopia.se/checkip/checkip.php' => 'loopia' ],
89     + [ 'myonlineportalhttps://myonlineportal.net/checkip' => 'myonlineportal' ],
90     + [ 'noip-ipv4http://ip1.dynupdate.no-ip.com/' => 'noip-ipv4' ],
91     + [ 'noip-ipv6http://ip1.dynupdate6.no-ip.com/' => 'noip-ipv6' ],
92     + [ 'nsupdate.info-ipv4https://ipv4.nsupdate.info/myip' => 'nsupdate.info-ipv4' ],
93     + [ 'nsupdate.info-ipv6https://ipv6.nsupdate.info/myip' => 'nsupdate.info-ipv6' ],
94     + [ 'zoneedithttps://dynamic.zoneedit.com/checkip.html' => 'zoneedit' ]
95 brianr 1.1 + ] );
96     + return $webservices
97     +
98     + #my $output = `ddclient -list-web-services`; # Run ddclient command to get web services output
99     + #my @lines;
100     + #foreach my $line (split /\n/, $output) {
101     + #$line =~ s/\s+//; # Remove leading whitespace
102     + #my ($field1, $field2) = split(' ', $line, 2);
103     + #push @lines, [$field2, $field1];
104     + #}
105     + #return \@lines; # Return a reference to the lines array
106     +}
107     +
108     sub get_dns_labels {
109     #
110     # dns service names
111     + # Return array with translated results as well.
112     + #
113     + # Note that "new" ones willl not have any description / translation, this can be added to /usr/share/smanager/lib/SrvMngr/I18N/Modules/Ddclient
114     #
115     my $c = shift;
116     - my $Labels = (
117 brianr 1.2 + my $dnsservices = ( [
118     + [ $c->l('1984') => '1984' ],
119     + [ $c->l('changeip') => 'changeip' ],
120     + [ $c->l('cloudflare') => 'cloudflare' ],
121     + [ $c->l('cloudns') => 'cloudns' ],
122     + [ $c->l('digitalocean') => 'digitalocean' ],
123     + [ $c->l('dinahosting') => 'dinahosting' ],
124     + [ $c->l('dnsexit') => 'dnsexit' ],
125     + [ $c->l('dnsmadeeasy') => 'dnsmadeeasy' ],
126     + [ $c->l('domeneshop') => 'domeneshop' ],
127     + [ $c->l('dondominio') => 'dondominio' ],
128     + [ $c->l('dslreports') => 'dslreports' ],
129     + [ $c->l('duckdns') => 'duckdns' ],
130     + [ $c->l('dyndns1') => 'dyndns1' ],
131     + [ $c->l('dyndns2') => 'dyndns2' ],
132     + [ $c->l('easydns') => 'easydns' ],
133     + [ $c->l('enom') => 'enom' ],
134     + [ $c->l('freedns') => 'freedns' ],
135     + [ $c->l('freemyip') => 'freemyip' ],
136     + [ $c->l('gandi') => 'gandi' ],
137     + [ $c->l('godaddy') => 'godaddy' ],
138     + [ $c->l('googledomains') => 'googledomains' ],
139     + [ $c->l('hetzner') => 'hetzner' ],
140     + [ $c->l('infomaniak') => 'infomaniak' ],
141     + [ $c->l('keysystems') => 'keysystems' ],
142     + [ $c->l('mythicdyn') => 'mythicdyn' ],
143     + [ $c->l('namecheap') => 'namecheap' ],
144     + [ $c->l('nfsn') => 'nfsn' ],
145     + [ $c->l('njalla') => 'njalla' ],
146     + [ $c->l('noip') => 'noip' ],
147     + [ $c->l('nsupdate') => 'nsupdate' ],
148     + [ $c->l('ovh') => 'ovh' ],
149     + [ $c->l('porkbun') => 'porkbun' ],
150     + [ $c->l('regfishde') => 'regfishde' ],
151     + [ $c->l('sitelutions') => 'sitelutions' ],
152     + [ $c->l('woima') => 'woima' ],
153     + [ $c->l('yandex') => 'yandex' ],
154     + [ $c->l('zoneedit') => 'zoneedit' ]
155     + ] );
156     + return $dnsservices;
157    
158 brianr 1.1 - # v3.11.1 labels
159     - [
160     - [$c->l('1984') '1984'],
161     - [$c->l('changeip') 'changeip'],
162     - [$c->l('cloudflare') 'cloudflare'],
163     - [$c->l('cloudns') 'cloudns'],,
164     - [$c->l('digitalocean') 'digitalocean'],
165     - [$c->l('dinahosting') 'dinahosting'],
166     - [$c->l('dnsexit2') 'dnsexit2'],
167     - [$c->l('dnsmadeeasy') 'dnsmadeeasy'],
168     - [$c->l('domeneshop') 'domeneshop'],
169     - [$c->l('dondominio') 'dondominio'],
170     - [$c->l('dslreports1') 'dslreports1'],
171     - [$c->l('duckdns') 'duckdns'],
172     - [$c->l('dyndns1') 'dyndns1'],
173     - [$c->l('dyndns2') 'dyndns2'],
174     - [$c->l('easydns') 'easydns'],
175     - [$c->l('enom') 'enom'],
176     - [$c->l('freedns') 'freedns'],
177     - [$c->l('freemyip') 'freemyip'],
178     - [$c->l('gandi') 'gandi'],
179     - [$c->l('godaddy') 'godaddy'],
180     - [$c->l('googledomains') 'googledomains'],
181     - [$c->l('hetzner') 'hetzner'],
182     - [$c->l('infomaniak') 'infomaniak'],
183     - [$c->l('keysystems') 'keysystems'],
184     - [$c->l('mythicdyn') 'mythicdyn'],
185     - [$c->l('namecheap') 'namecheap'],
186     - [$c->l('nfsn') 'nfsn'],
187     - [$c->l('njalla') 'njalla'],
188     - [$c->l('noip') 'noip'],
189     - [$c->l('nsupdate') 'nsupdate'],
190     - [$c->l('ovh') 'ovh'],
191     - [$c->l('porkbun') 'porkbun'],
192     - [$c->l('regfishde') 'regfishde'],
193     - [$c->l('sitelutions') 'sitelutions'],
194     - [$c->l('woima') 'woima'],
195     - [$c->l('yandex') 'yandex'],
196     - [$c->l('zoneedit1') 'zoneedit1']
197     - ]
198     - # end of v3.11.1 labels
199     -
200 brianr 1.2 -
201 brianr 1.1 - #[ [ $c->l('CUSTOMDNS'), 'CUSTOMDNS' ],
202     + #my $output = `ddclient -list-protocols`; # Run ddclient command and capture the output
203     + #my @protocols;
204     + #foreach my $line (split /\n/, $output) {
205     + #my ($protocol) = $line =~ /\s*(\S+)/;
206     + #next unless $protocol; # Skip if protocol is empty or contains only whitespace
207     + #my $custom_value = "$protocol.$c->l($protocol)"; # Additional column value using $c->l(protocol)
208     + #push @protocols, [$custom_value, $protocol];
209     + #}
210     + #return \@protocols; # Return a reference to the protocols array
211     +}
212     +
213     +# Pre 3.11.1 dns services
214     + #[ [ $c->l('CUSTOMDNS'), 'CUSTOMDNS' ],
215     #[ $c->l('DYNDNS1'), 'DYNDNS1' ],
216     #[ $c->l('DYNDNS2'), 'DYNDNS2' ],
217     #[ $c->l('DYNDNS3'), 'DYNDNS3' ],
218 brianr 1.2 @@ -196,9 +307,6 @@
219 brianr 1.1 #[ $c->l('OVH'), 'OVH' ],
220     #[ $c->l('CLOUDNS'), 'CLOUDNS' ]
221     #]
222     - );
223     - return $Labels;
224     -}
225    
226     sub main {
227     #
228 brianr 1.2 @@ -230,13 +338,15 @@
229     my $emptycust = ( scalar @FreeDomains == 0 );
230 brianr 1.1
231     my $Labels = (
232 brianr 1.2 - [ [ $c->l('SME external Interface'), "smeIF" ],
233 brianr 1.1 - [ $c->l('SME configuration DB'), "smeCMD" ],
234 brianr 1.2 - [ $c->l('web'), "web" ],
235     - [ $c->l('Interface'), "if" ],
236     - [ $c->l('IP'), "ip" ],
237     - [ $c->l('Command'), "cmd" ]
238     - ]
239     + [
240     + [ $c->l('SME external Interface') => "smeIF" ],
241     + [ $c->l('SME configuration DB') => 'smeCMD' ],
242     + [ $c->l('web') => 'web' ],
243     + [ $c->l('router') => 'router' ],
244     + [ $c->l('Interface') => 'if' ],
245     + [ $c->l('IP') => 'ip' ],
246     + [ $c->l('Command') => 'cmd' ]
247     + ]
248     );
249    
250     $c->stash(
251     @@ -246,6 +356,9 @@
252 brianr 1.1 domains => \@domains,
253     freedomains => \@FreeDomains,
254     methodlabels => $Labels,
255 brianr 1.2 + dnslabels => get_dns_labels($c),
256 brianr 1.1 + devices => get_devices_names($c),
257     + webservices => get_web_services_names($c),
258     emptydom => $emptydom,
259     emptycust => $emptycust
260     );
261 brianr 1.2 @@ -260,6 +373,7 @@
262     # Called to update the parameters relating to the Ip address of the server
263     #
264     my $c = shift;
265     + $ddc_datas{"first"} = '';
266     $ddc_datas{"success"} = pushParams($c);
267     do_display($c);
268     }
269     @@ -269,6 +383,7 @@
270 brianr 1.1 #Called to update/delete the ddclient for a specific inbuilt domain
271     #
272     my $c = shift;
273     + my $title = $c->l("MODIFY_TITLE");
274     my $retmsg;
275     if ( $c->param("Route") eq "ddclient2" ) { #Route is hidden field
276     $retmsg = performModifyCustom($c);
277 brianr 1.2 @@ -276,10 +391,11 @@
278     else {
279     $retmsg = performModifyDomain($c);
280     }
281     + $ddc_datas{"first"} = '';
282 brianr 1.1 if ( $retmsg eq "ok" ) {
283     my $dns = $c->param('dns');
284     my $domain = $c->param('domainname');
285     - $ddc_datas{"success"} = $c->l( "ddc_SUCCESSFULLY_MODIFIED", $domain,
286     + $ddc_datas{"success"} = $c->l( "SUCCESSFULLY_MODIFIED", $domain,
287     $c->l( '' . $dns ) );
288     do_display( $c, %ddc_datas );
289     }
290 brianr 1.2 @@ -296,7 +412,7 @@
291 brianr 1.1 # Create custom domain
292     #
293     my $c = shift;
294     - my $title = $c->l("ddc_CREATE_TITLE");
295     + my $title = $c->l("CREATE_TITLE");
296     my $modul = '';
297     my $trt = "NEW";
298    
299 brianr 1.2 @@ -305,18 +421,21 @@
300 brianr 1.1 title => $title,
301     modul => $modul,
302     ddc_datas => \%ddc_datas,
303     - dnslabels => get_dns_labels($c)
304     + dnslabels => get_dns_labels($c),
305     + devices => get_devices_names($c),
306     + webservices => get_web_services_names($c)
307     );
308     $c->render( template => 'ddclient' );
309     }
310 brianr 1.2
311     sub do_create_custom_actual {
312     my $c = shift;
313     + $ddc_datas{"first"} = '';
314     my $retmsg = performCreateCustom($c);
315 brianr 1.1 if ( $retmsg eq "ok" ) {
316     my $dns = $c->param('dns');
317     my $domain = $c->param('domainname');
318     - $ddc_datas{"success"} = $c->l( "ddc_SUCCESSFULLY_DELETED", $domain,
319     + $ddc_datas{"success"} = $c->l( "SUCCESSFULLY_DELETED", $domain,
320     $c->l( '' . $dns ) );
321     do_display( $c, %ddc_datas );
322     }
323 brianr 1.2 @@ -334,7 +453,7 @@
324 brianr 1.1 # Display delete or modify panel for custom domain
325     #
326     my $c = shift;
327     - my $title = $c->l("ddc_MODIFY_TITLE");
328     + my $title = $c->l("MODIFY_TITLE");
329     my $modul = '';
330     my $trt = $c->param("trt");
331    
332 brianr 1.2 @@ -349,7 +468,9 @@
333 brianr 1.1 title => $title,
334     modul => $modul,
335     ddc_datas => \%ddc_datas,
336     - dnslabels => get_dns_labels($c)
337     + dnslabels => get_dns_labels($c),
338     + devices => get_devices_names($c),
339     + webservices => get_web_services_names($c)
340     );
341     $c->render( template => 'ddclient' );
342     }
343 brianr 1.2 @@ -360,21 +481,23 @@
344 brianr 1.1 # param trt = MOD or DEL
345     #
346     my $c = shift;
347     - my $title = $c->l("ddc_MODIFY_TITLE");
348     + my $title = $c->l("MODIFY_TITLE");
349     my $modul = '';
350     my $trt = $c->param("trt");
351    
352     #Extract domain stuff from DB
353     my @results
354     = get_domain_table( $c, $c->param("Domain") ); #Returns just one row
355     - $ddc_datas{"Domain_details"} = $results[0];
356    
357     + $ddc_datas{"Domain_details"} = $results[0];
358     $ddc_datas{'trt'} = $trt;
359     $c->stash(
360     title => $title,
361     modul => $modul,
362     ddc_datas => \%ddc_datas,
363     - dnslabels => get_dns_labels($c)
364     + dnslabels => get_dns_labels($c),
365     + devices => get_devices_names($c),
366     + webservices => get_web_services_names($c)
367     );
368     $c->render( template => 'ddclient' );
369     }
370 brianr 1.2 @@ -386,10 +509,11 @@
371 brianr 1.1 #
372     my $c = shift;
373     my $route = $c->current_route;
374     - my $title = $c->l("ddc_REMOVE_TITLE");
375     + my $title = $c->l("REMOVE_TITLE");
376     my $modul = '';
377     my $retmsg = "";
378     my $domain = $c->param("Domain");
379 brianr 1.2 + $ddc_datas{"first"} = '';
380    
381     #Delete it and return to front summary panel - depends on route domain or custom
382     if ( $c->param("Route") eq "ddclient2" ) { #Route is hidden field
383     @@ -400,7 +524,7 @@
384 brianr 1.1 }
385    
386     if ( $retmsg eq "ok" ) {
387     - $ddc_datas{"success"} = $c->l( "ddc_SUCCESSFULLY_DELETED", $domain,
388     + $ddc_datas{"success"} = $c->l( "SUCCESSFULLY_DELETED", $domain,
389     $c->l( '' . $c->param("dns") ) );
390     }
391     else { $ddc_datas{"error"} = $retmsg; }
392 brianr 1.2 @@ -415,15 +539,16 @@
393 brianr 1.1 #
394     my $c = shift;
395     my $route = $c->current_route;
396     - my $title = $c->l("ddc_REMOVE_TITLE");
397     + my $title = $c->l("REMOVE_TITLE");
398     my $modul = '';
399     my $retmsg = "";
400     my $domain = $c->param("Domain");
401 brianr 1.2 + $ddc_datas{"first"} = '';
402    
403 brianr 1.1 #Delete it and return to front summary panel - depends on route domain or custom
404     $retmsg = performDeleteCustom( $c, $domain );
405     if ( $retmsg eq "ok" ) {
406     - $ddc_datas{"success"} = $c->l( "ddc_SUCCESSFULLY_DELETED", $domain );
407     + $ddc_datas{"success"} = $c->l( "SUCCESSFULLY_DELETED", $domain );
408     }
409     else { $ddc_datas{"error"} = $retmsg; }
410     do_display( $c, %ddc_datas );
411 brianr 1.2 @@ -588,6 +713,8 @@
412     my $retrieveinterface = $c->param('retrieveinterface');
413     my $retrievecmd = $c->param('retrievecmd');
414     my $retrieveip = $c->param('retrieveip');
415     +
416     + #print 1 / 0; #Crash
417    
418     my $ddclient = $db->get('ddclient');
419     $ddclient->set_prop( 'urlcheckip' => $urlcheckip );
420     @@ -616,7 +743,7 @@
421 brianr 1.1 #------------------------------------------------------------
422    
423     my $domainName = $c->param('domainName');
424     - if ( $domainName =~ /^([a-zA-Z0-9\-\.]+)$/ ) {
425     + if ( $domainName =~ /([a-zA-Z0-9\-\.]+)$/ ) {
426     $domainName = $1;
427     }
428     else {
429 brianr 1.2 @@ -624,7 +751,7 @@
430 brianr 1.1 }
431    
432     my $domainLogin = $c->param('login');
433     - if ( $domainLogin =~ /^([\-\'\w][\-\'\w\s\.\@]*)$/ ) {
434     + if ( $domainLogin =~ /([\-\'\w][\-\'\w\s\.\@]*)$/ ) {
435     $domainLogin = $1;
436     }
437     else {
438 brianr 1.2 @@ -632,7 +759,7 @@
439 brianr 1.1 }
440    
441     my $domainPassword = $c->param('password');
442     - if ( $domainPassword =~ /^(.*)$/ ) {
443     + if ( $domainPassword =~ /(.*)$/ ) {
444     $domainPassword = $1;
445     }
446     else {
447 brianr 1.2 @@ -646,7 +773,7 @@
448 brianr 1.1
449     my $dns = $c->param('dns');
450     if ( $dns eq 'CUSTOMDNS' ) {
451     - if ( $customDNS =~ /^([a-zA-Z0-9\-\.]+)$/ ) {
452     + if ( $customDNS =~ /([a-zA-Z0-9\-\.]+)$/ ) {
453     $customDNS = $1;
454     }
455     else
456 brianr 1.2 @@ -685,7 +812,7 @@
457 brianr 1.1 # Attempt to delete domain
458     #------------------------------------------------------------
459    
460     - if ( $domain =~ /^([a-zA-Z0-9\-\.]+)$/ ) {
461     + if ( $domain =~ /([a-zA-Z0-9\-\.]+)$/ ) {
462     $domain = $1;
463     }
464     else {
465 brianr 1.2 @@ -726,7 +853,7 @@
466 brianr 1.1 #------------------------------------------------------------
467    
468     my $domainName = $c->param('domainName');
469     - if ( $domainName =~ /^([a-zA-Z0-9\-\.]+)$/ ) {
470     + if ( $domainName =~ /([a-zA-Z0-9\-\.]+)$/ ) {
471     $domainName = $1;
472     }
473     else {
474 brianr 1.2 @@ -749,7 +876,7 @@
475 brianr 1.1
476     my $domainDesc = $c->param('desc');
477     my $domainLogin = $c->param('login');
478     - if ( $domainLogin =~ /^([\-\'\w][\-\'\w\s\.\@]*)$/ ) {
479     + if ( $domainLogin =~ /([\-\'\w][\-\'\w\s\.\@]*)$/ ) {
480     $domainLogin = $1;
481     }
482     else {
483 brianr 1.2 @@ -757,7 +884,7 @@
484 brianr 1.1 }
485    
486     my $domainPassword = $c->param('password');
487     - if ( $domainPassword =~ /^(.*)$/ ) {
488     + if ( $domainPassword =~ /(.*)$/ ) {
489     $domainPassword = $1;
490     }
491     else {
492 brianr 1.2 @@ -771,7 +898,7 @@
493 brianr 1.1
494     my $dns = $c->param('dns');
495     if ( $dns eq 'CUSTOMDNS' ) {
496     - if ( $customDNS =~ /^([a-zA-Z0-9\-\.]+)$/ ) {
497     + if ( $customDNS =~ /([a-zA-Z0-9\-\.]+)$/ ) {
498     $customDNS = $1;
499     }
500     else {
501 brianr 1.2 @@ -809,7 +936,7 @@
502 brianr 1.1 #------------------------------------------------------------
503    
504     my $domainName = $c->param('domainName');
505     - if ( $domainName =~ /^([a-zA-Z0-9\-\.]+)$/ ) {
506     + if ( $domainName =~ /([a-zA-Z0-9\-\.]+)$/ ) {
507     $domainName = $1;
508     }
509     else {
510 brianr 1.2 @@ -817,7 +944,7 @@
511 brianr 1.1 }
512    
513     my $domainLogin = $c->param('login');
514     - if ( $domainLogin =~ /^([\-\'\w][\-\'\w\s\.\@]*)$/ ) {
515     + if ( $domainLogin =~ /([\-\'\w][\-\'\w\s\.\@]*)$/ ) {
516     $domainLogin = $1;
517     }
518     else {
519 brianr 1.2 @@ -825,7 +952,7 @@
520 brianr 1.1 }
521    
522     my $domainPassword = $c->param('password');
523     - if ( $domainPassword =~ /^(.*)$/ ) {
524     + if ( $domainPassword =~ /(.*)$/ ) {
525     $domainPassword = $1;
526     }
527     else {
528 brianr 1.2 @@ -839,7 +966,7 @@
529 brianr 1.1
530     my $dns = $c->param('dns');
531     if ( $dns eq 'CUSTOMDNS' ) {
532     - if ( $customDNS =~ /^([a-zA-Z0-9\-\.]+)$/ ) {
533     + if ( $customDNS =~ /([a-zA-Z0-9\-\.]+)$/ ) {
534     $customDNS = $1;
535     }
536     else
537 brianr 1.2 @@ -878,7 +1005,7 @@
538 brianr 1.1 # Attempt to delete domain
539     #------------------------------------------------------------
540    
541     - if ( $domain =~ /^([a-zA-Z0-9\-\.]+)$/ ) {
542     + if ( $domain =~ /([a-zA-Z0-9\-\.]+)$/ ) {
543     $domain = $1;
544     }
545     else {
546     diff -urN smeserver-ddclient-1.3.0.old/root/usr/share/smanager/lib/SrvMngr/I18N/Modules/Ddclient/en.pm smeserver-ddclient-1.3.0/root/usr/share/smanager/lib/SrvMngr/I18N/Modules/Ddclient/en.pm
547     --- smeserver-ddclient-1.3.0.old/root/usr/share/smanager/lib/SrvMngr/I18N/Modules/Ddclient/en.pm 2023-11-10 16:11:05.916271986 +0000
548 brianr 1.2 +++ smeserver-ddclient-1.3.0/root/usr/share/smanager/lib/SrvMngr/I18N/Modules/Ddclient/en.pm 2023-12-01 16:35:00.000000000 +0000
549     @@ -80,7 +80,7 @@
550     'CLOUDNS'=>'CLOUDNS www.cloudns.net',
551     # End of Service descriptions
552    
553     -# v3.11.1 Service descriptions:
554     +# v3.11.x Service descriptions:
555     "1984" => "https://kb.1984hosting.com/doku.php?id=freedns",
556     "changeip" => "https://changeip.com",
557     "cloudflare" => "https://cloudflare.com",
558     @@ -118,7 +118,7 @@
559     "woima" => "http://woima.com",
560     "yandex" => "https://yandex.com",
561     "zoneedit" => "https://www.zoneedit.com/dynamic-dns/",
562     -# end of v3.11.1 Service descriptions:
563     +# end of v3.11.x Service descriptions:
564    
565     'CUSTOMDNS' => 'Custom Dynamic DNS Provider',
566     'CUSTOMDNS_LABEL' => 'Custom server Address',
567 brianr 1.1 @@ -136,8 +136,8 @@
568     'DESCRIPTION_LABEL' => 'Domain description',
569     'SUCCESSFULLY_MODIFIED_RETRIEVE_IP' => 'You have successfully modified the retrieve IP options.',
570     'RETRIEVE_METHOD' => 'Method to retrieve new IP:',
571     -'RETRIEVE_IF' => 'Local interface to get new IP, if selected interface method',
572     -'RETRIEVE_CMD' => 'Command to execute to get IP, if selected command method',
573     +'RETRIEVE_IF' => 'Local interface to get new IP',
574     +'RETRIEVE_CMD' => 'Command to execute to get IP',
575     'SME external Interface' => 'SME external interface',
576     'SME configuration DB' => 'SME configuration DB',
577     'web' => 'Web query',
578     diff -urN smeserver-ddclient-1.3.0.old/root/usr/share/smanager/themes/default/templates/partials/_ddc_create_cust.html.ep smeserver-ddclient-1.3.0/root/usr/share/smanager/themes/default/templates/partials/_ddc_create_cust.html.ep
579     --- smeserver-ddclient-1.3.0.old/root/usr/share/smanager/themes/default/templates/partials/_ddc_create_cust.html.ep 2020-06-28 09:57:52.000000000 +0100
580     +++ smeserver-ddclient-1.3.0/root/usr/share/smanager/themes/default/templates/partials/_ddc_create_cust.html.ep 2023-11-15 16:10:00.000000000 +0000
581     @@ -1,6 +1,6 @@
582     <div id='ddc_createcustom'>
583     <h2>
584     - %= l 'ddc_CUSTOM_DESCRIPTION'
585     + %= l 'CUSTOM_DESCRIPTION'
586     </h2><br>
587     % my $btn = l('ddc_APPLY');
588     %= form_for '/ddclient7' => (method => 'POST') => begin
589     diff -urN smeserver-ddclient-1.3.0.old/root/usr/share/smanager/themes/default/templates/partials/_ddc_modify_domain.html.ep smeserver-ddclient-1.3.0/root/usr/share/smanager/themes/default/templates/partials/_ddc_modify_domain.html.ep
590     --- smeserver-ddclient-1.3.0.old/root/usr/share/smanager/themes/default/templates/partials/_ddc_modify_domain.html.ep 2023-11-10 16:11:05.901271943 +0000
591     +++ smeserver-ddclient-1.3.0/root/usr/share/smanager/themes/default/templates/partials/_ddc_modify_domain.html.ep 2023-11-18 14:56:00.000000000 +0000
592     @@ -1,4 +1,9 @@
593     <div id='modifydomain'>
594     + <script>
595     + window.onload = function() {
596     + SelectInput();
597     + };
598     + </script>
599     <h2>
600     %= l 'CUSTOM_DESCRIPTION'
601     </h2><br>
602     @@ -24,20 +29,41 @@
603     %=l 'SERVERS_LABEL'
604     </span><span class=data>
605     % param dns=>$ddc_datas->{"Domain_details"}->{"dns"};
606     - %=select_field dns=>$dnslabels
607     + %=select_field dns=>$dnslabels,id=>"dns",onchange=>"SelectInput()",onload=>"SelectInput()"
608     + %= javascript begin
609     + function SelectInput() {
610     + var method = document.querySelector("#dns");
611     + const types=['custom'];
612     + types.forEach((type)=>{
613     + var service = document.querySelector(`.${type}`);
614     + if (service != null) {
615     + if (method.value == type) {
616     + service.style.display = 'block';
617     + } else {
618     + service.style.display = 'none';
619     + }
620     + }
621     + })
622     + }
623     + %end
624     </span><br>
625     - <span class=label>
626     +
627     + %# Dependant on the custom choice from above
628     + <div class=custom>
629     + <span class=label custom>
630     %=l 'CUSTOMDNS_LABEL'
631     - </span><span class=data>
632     + </span><span class=data custom>
633     % param customdns=>$ddc_datas->{"Domain_details"}->{"customdns"};
634     %=text_field 'customdns'
635     </span><br>
636     - <span class=label>
637     + <span class=label custom>
638     %=l 'CUSTOM_PROTOCOL_LABEL'
639     - </span><span class=data>
640     + </span><span class=data custom>
641     % param customprotocol=>$ddc_datas->{"Domain_details"}->{"customprotocol"};
642     %=text_field 'customprotocol'
643     </span><br>
644     + </div>
645     +
646     <span class=label>
647     %=l 'NAME_LABEL'
648     </span><span class=data>
649     diff -urN smeserver-ddclient-1.3.0.old/root/usr/share/smanager/themes/default/templates/partials/_ddc_paramlist.html.ep smeserver-ddclient-1.3.0/root/usr/share/smanager/themes/default/templates/partials/_ddc_paramlist.html.ep
650     --- smeserver-ddclient-1.3.0.old/root/usr/share/smanager/themes/default/templates/partials/_ddc_paramlist.html.ep 2023-11-10 16:11:05.902271946 +0000
651 brianr 1.2 +++ smeserver-ddclient-1.3.0/root/usr/share/smanager/themes/default/templates/partials/_ddc_paramlist.html.ep 2023-12-01 17:12:00.000000000 +0000
652 brianr 1.1 @@ -1,4 +1,9 @@
653     <div id='paramlist'>
654     + <script>
655     + window.onload = function() {
656     + SelectInput();
657     + };
658     + </script>
659     <h2>
660     %= l 'Params_for_IP_Retrieval'
661     </h2>
662 brianr 1.2 @@ -7,11 +12,11 @@
663     <span class=label>
664     %=l 'RETRIEVE_SSL'
665     </span><span class=data>
666     - % param retrievessl=>$ddc_datas->{"params"}->{"ssl"};
667     + % param retrievessl=>$ddc_datas->{"params"}->{"ssl"} unless param 'retrievessl';
668 brianr 1.1 %=select_field retrievessl=>[['Yes'=>'yes'],['No'=>'no']]
669     </span><br>
670     <span class=label>
671     - %=l 'RETRIEVE_DEAMONUPDATE'
672     + %=l 'RETRIEVE_DEAMONUPDATE'
673     </span><span class=data>
674     % param retrievedeamonupdate=>$ddc_datas->{"params"}->{"DeamonUpdate"};
675     %=number_field 'retrievedeamonupdate',min=>0
676 brianr 1.2 @@ -19,33 +24,88 @@
677     <span class=label>
678 brianr 1.1 %=l 'RETRIEVE_METHOD'
679     </span><span class=data>
680 brianr 1.2 - % param retrievemethod=>$ddc_datas->{"params"}->{"method"};
681 brianr 1.1 - %=select_field retrievemethod=>$methodlabels
682     - </span><br>
683     - <span class=label>
684 brianr 1.2 + % param retrievemethod=>$ddc_datas->{"params"}->{"method"} unless param 'retrievemethod';
685 brianr 1.1 + %=select_field retrievemethod=>$methodlabels,id=>"retrievemethod",onchange=>"SelectInput()"
686     + %= javascript begin
687     + function SelectInput() {
688     + var method = document.querySelector("#retrievemethod");
689 brianr 1.2 + const types=['smeIF','smeCMD','web','router','if','ip','cmd','custom'];
690 brianr 1.1 + types.forEach((type)=>{
691     + var service = document.querySelector(`.${type}`);
692     + if (service != null) {
693     + if (method.value == type) {
694     + service.style.display = 'block';
695     + } else {
696     + service.style.display = 'none';
697     + }
698     + }
699     + })
700     + }
701     + % end
702     + </span><br>
703     + %#
704     + %# From here the one that is shown depends on the choice above
705     + %#
706     + <div class = smeIF></div>
707     + <div class = smeIF></div>
708     + %# Only if "router" is chosen
709     + <div class = router>
710     + <span class=label>
711     + %=l 'Router type'
712     + </span><span class=data>
713 brianr 1.2 + % param retrieveinterface=>$ddc_datas->{"params"}->{"Extinterface"} unless param 'retrieveinterface';
714     + %=select_field retrieveinterface=>$devices
715 brianr 1.1 + </span><br>
716     + </div>
717     +
718     + %# Only if "web" is chosen"
719     + <div class = web>
720     + <span class=label>
721     + %=l 'Web service'
722     + </span><span class=data>
723 brianr 1.2 + % param retrieveurlcheckip=>$ddc_datas->{"params"}->{"urlcheckip"} unless param 'retrieveurlcheckip';
724     + %=select_field retrieveurlcheckip=>$dnslabels
725 brianr 1.1 + </div>
726     +
727     + %# Only if "Interface" is chosen
728     + <div class=if>
729     + <span class=label Interface>
730     %=l 'RETRIEVE_IF'
731     - </span><span class=data>
732 brianr 1.2 - % param retrieveinterface=>$ddc_datas->{"params"}->{"Extinterface"};
733 brianr 1.1 + </span><span class=data Interface>
734 brianr 1.2 + % param retrieveinterface=>$ddc_datas->{"params"}->{"Extinterface"} unless param 'retrieveinterface';
735 brianr 1.1 %=text_field 'retrieveinterface'
736     </span><br>
737     - <span class=label>
738     + </div>
739     +
740     + %# Only if "cmd" is chosen
741     + <div class=cmd>
742     + <span class=label cmd>
743     %=l 'RETRIEVE_CMD'
744     - </span><span class=data>
745 brianr 1.2 - % param retrievecmd=>$ddc_datas->{"params"}->{"cmd"};
746 brianr 1.1 + </span><span class=data cmd>
747 brianr 1.2 + % param retrievecmd=>$ddc_datas->{"params"}->{"cmd"} unless param 'retrievecmd';
748 brianr 1.1 %=text_field 'retrievecmd'
749     </span><br>
750     - <span class=label>
751     + </div>
752     +
753     + %# Only if "ip" is chosen
754     + <div class=ip>
755     + <span class=label ip>
756     %=l 'RETRIEVE_IP'
757     - </span><span class=data>
758 brianr 1.2 - % param retrieveip=>$ddc_datas->{"params"}->{"ForceIP"};
759 brianr 1.1 + </span><span class=data ip>
760 brianr 1.2 + % param retrieveip=>$ddc_datas->{"params"}->{"ForceIP"} unless param 'retrieveip';
761 brianr 1.1 %=text_field 'retrieveip'
762     </span><br>
763     - <span class=label>
764     + </div>
765     +
766     + %# Only if "custom web service"
767     + <div class=custom>
768     + <span class=label customweb>
769     %=l 'RETRIEVE_URLCHECKIP'
770     - </span><span class=data>
771 brianr 1.2 - % param retrieveurlcheckip=>$ddc_datas->{"params"}->{"urlcheckip"};
772 brianr 1.1 + </span><span class=data customweb>
773 brianr 1.2 + % param retrieveurlcheckip=>$ddc_datas->{"params"}->{"urlcheckip"} unless param 'retrieveurlcheckip';
774 brianr 1.1 %=text_field 'retrieveurlcheckip'
775     </span><br>
776     + </div>
777    
778     %= submit_button "$btn", class => 'action'
779     % end

admin@koozali.org
ViewVC Help
Powered by ViewVC 1.2.1 RSS 2.0 feed