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

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

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