+END
+;
+&Header::closebox();
+
+# DHCP DNS update support (RFC2136)
+&Header::openbox('100%', 'left', $Lang::tr{'dhcp dns update'});
+
+my %checked = ();
+$checked{'DNS_UPDATE_ENABLED'}{'on'} = ( $dhcpsettings{'DNS_UPDATE_ENABLED'} ne 'on') ? '' : "checked='checked'";
+
+print <
+
+
$Lang::tr{'dhcp dns enable update'}
+
+
+
+
+
+
+END
+;
+ my @domains = ();
+
+ # Print options for each interface.
+ foreach my $itf (@ITFs) {
+ # Check if DHCP for this interface is enabled.
+ if ($dhcpsettings{"ENABLE_${itf}"} eq 'on') {
+ # Check for same domain name.
+ next if ($dhcpsettings{"DOMAIN_NAME_${itf}"} ~~ @domains);
+ my $lc_itf = lc($itf);
+
+ # Select previously configured update algorithm.
+ my %selected = ();
+ $selected{'DNS_UPDATE_ALGO_${inf}'}{$dhcpsettings{'DNS_UPDATE_ALGO_${inf}'}} = 'selected';
+
+print <
+
+
+
+
$dhcpsettings{"DOMAIN_NAME_${itf}"}
+
+
+
$Lang::tr{'dhcp dns key name'}:
+
+
$Lang::tr{'dhcp dns update secret'}:
+
+
$Lang::tr{'dhcp dns update algo'}:
+
+
+
+
+END
+;
+ }
+
+ # Store configured domain based on the interface
+ # in the temporary variable.
+ push(@domains, $dhcpsettings{"DOMAIN_NAME_${itf}"});
+}
+print <
+
+
+
+
+
+
END
;
@@ -623,13 +705,13 @@ if ($opt ne '') {
}
print <
-
$Lang::tr{'dhcp advopt name'}:
+
$Lang::tr{'dhcp advopt name'}:
-
$Lang::tr{'dhcp advopt value'}:
+
$Lang::tr{'dhcp advopt value'}:
$opt
$Lang::tr{'enabled'}
-
$Lang::tr{'dhcp advopt scope'}:
+
$Lang::tr{'dhcp advopt scope'}:
END
;
@@ -650,8 +732,8 @@ print <
-
$Lang::tr{'dhcp advopt scope help'}
-
+
$Lang::tr{'dhcp advopt scope help'}
+
@@ -828,30 +910,30 @@ if ($dhcpsettings{'KEY2'} ne '') {
}
print <
-
$Lang::tr{'mac address'}:
+
$Lang::tr{'mac address'}:
-
$Lang::tr{'ip address'}:
+
$Lang::tr{'ip address'}:
-
$Lang::tr{'remark'}:
+
$Lang::tr{'remark'}:
$Lang::tr{'enabled'}
$Lang::tr{'dhcp bootp pxe data'}
-
next-server:
+
next-server:
-
filename:
+
filename:
-
root path:
+
root path:
-
$Lang::tr{'this field may be blank'}
-
+
$Lang::tr{'required field'}
+
@@ -862,17 +944,35 @@ END
;
#Edited line number (KEY2) passed until cleared by 'save' or 'remove' or 'new sort order'
+# Search for static leases
+my $search_query = $dhcpsettings{'q'};
+
+if (scalar @current2 >= 10) {
+ print <
+
+
END
;
@@ -904,6 +1004,7 @@ foreach my $line (@current2) {
}
$key = 0;
+my $col="";
foreach my $line (@current2) {
my $gif = '';
my $gdesc = '';
@@ -918,12 +1019,23 @@ foreach my $line (@current2) {
$gdesc = $Lang::tr{'click to enable'};
}
+ # Skip all entries that do not match the search query
+ if ($search_query ne "") {
+ if (!grep(/$search_query/, @temp)) {
+ $key++;
+ next;
+ }
+ }
+
if ($dhcpsettings{'KEY2'} eq $key) {
- print "