From mboxrd@z Thu Jan 1 00:00:00 1970 From: Leo Hofmann To: development@lists.ipfire.org Subject: Re: [PATCH 1/2] Improve indentation and HTML output of PrintActualLeases & leasesort Date: Mon, 26 Oct 2020 10:52:31 +0100 Message-ID: <29cdc9c5-3517-fce9-15d5-0b8119289c60@leo-andres.de> In-Reply-To: <166A3248-86CB-48BE-8B14-E277D821E5C4@ipfire.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============8831724858270478263==" List-Id: --===============8831724858270478263== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Hi Michael, thank you for reviewing & merging my patch! I agree, this was an interesting read. I think the web interface code could b= e improved. Feel free to point me to other issues, maybe I can contribute mor= e. Best regards, Leo Am 23.10.2020 um 12:07 schrieb Michael Tremer: > Hey Leo-Andres, > > Thank you for splitting the patch. This was easier to review. > > It is still interesting code and it is very interesting too that all the DH= CP stuff is in header.pl. > > But that is outside the scope of this patch. > > I will merge it. Thank you! > > Best, > -Michael > >> On 21 Oct 2020, at 11:48, Leo-Andres Hofmann wro= te: >> >> Signed-off-by: Leo-Andres Hofmann >> --- >> config/cfgroot/header.pl | 159 +++++++++++++++++++-------------------- >> 1 file changed, 79 insertions(+), 80 deletions(-) >> >> diff --git a/config/cfgroot/header.pl b/config/cfgroot/header.pl >> index 1046f5992..6322cfebe 100644 >> --- a/config/cfgroot/header.pl >> +++ b/config/cfgroot/header.pl >> @@ -403,66 +403,65 @@ sub PrintActualLeases >> <= b>$tr{'mac address'} >> $tr{'hostname'} >> $tr{'lease expires'} (local time d/m/y) >> -Add to fix leases >> +Add to fix leases >> >> END >> ; >> >> open(LEASES,"/var/state/dhcp/dhcpd.leases") or die "Can't open dhcpd.= leases"; >> - while ($line =3D ) { >> - next if( $line =3D~ /^\s*#/ ); >> - chomp($line); >> - @temp =3D split (' ', $line); >> - >> - if ($line =3D~ /^\s*lease/) { >> - $ip =3D $temp[1]; >> - #All field are not necessarily read. Clear everything >> - $endtime =3D 0; >> - $ether =3D ""; >> - $hostname =3D ""; >> - } >> + while (my $line =3D ) { >> + next if( $line =3D~ /^\s*#/ ); >> + chomp($line); >> + @temp =3D split (' ', $line); >> + >> + if ($line =3D~ /^\s*lease/) { >> + $ip =3D $temp[1]; >> + #All field are not necessarily read. Clear everything >> + $endtime =3D 0; >> + $ether =3D ""; >> + $hostname =3D ""; >> + } >> >> - if ($line =3D~ /^\s*ends/) { >> - $line =3D~ /(\d+)\/(\d+)\/(\d+) (\d+):(\d+):(\d+)/; >> - $endtime =3D timegm($6, $5, $4, $3, $2 - 1, $1 - 1900); >> - } >> + if ($line =3D~ /^\s*ends/) { >> + $line =3D~ /(\d+)\/(\d+)\/(\d+) (\d+):(\d+):(\d+)/; >> + $endtime =3D timegm($6, $5, $4, $3, $2 - 1, $1 - 1900); >> + } >> >> - if ($line =3D~ /^\s*hardware ethernet/) { >> - $ether =3D $temp[2]; >> - $ether =3D~ s/;//g; >> - } >> + if ($line =3D~ /^\s*hardware ethernet/) { >> + $ether =3D $temp[2]; >> + $ether =3D~ s/;//g; >> + } >> >> - if ($line =3D~ /^\s*client-hostname/) { >> - $hostname =3D "$temp[1] $temp[2] $temp[3]"; >> - $hostname =3D~ s/;//g; >> - $hostname =3D~ s/\"//g; >> - } >> + if ($line =3D~ /^\s*client-hostname/) { >> + $hostname =3D "$temp[1] $temp[2] $temp[3]"; >> + $hostname =3D~ s/;//g; >> + $hostname =3D~ s/\"//g; >> + } >> >> - if ($line eq "}") { >> - @record =3D ('IPADDR',$ip,'ENDTIME',$endtime,'ETHER',$ether,'HOSTNAM= E',$hostname); >> - $record =3D {}; # create a reference to= empty hash >> - %{$record} =3D @record; # populate that hash with @= record >> - $entries{$record->{'IPADDR'}} =3D $record; # add this to a hash o= f hashes >> - } >> + if ($line eq "}") { >> + @record =3D ('IPADDR',$ip,'ENDTIME',$endtime,'ETHER',$ether,'HOSTNAME'= ,$hostname); >> + $record =3D {}; # create a reference to empty hash >> + %{$record} =3D @record; # populate that hash with @record >> + $entries{$record->{'IPADDR'}} =3D $record; # add this to a hash of has= hes >> + } >> } >> close(LEASES); >> >> my $id =3D 0; >> - my $col=3D""; >> + my $col =3D ""; >> foreach my $key (sort leasesort keys %entries) { >> - print "
\n"; >> - my $hostname =3D &cleanhtml($entries{$key}->{HOSTNAME},"y"); >> + print "\n"; >> + my $hostname =3D &cleanhtml($entries{$key}->{HOSTNAME},"y"); >> >> - if ($id % 2) { >> - print ""; >> - $col=3D"bgcolor=3D'$table1colour'"; >> - } >> - else { >> - print ""; >> - $col=3D"bgcolor=3D'$table2colour'"; >> - } >> + if ($id % 2) { >> + print ""; >> + $col=3D"bgcolor=3D'$table1colour'"; >> + } else { >> + print ""; >> + $col=3D"bgcolor=3D'$table2colour'"; >> + } >> >> - print <> + print <> {IPADDR}' />$entries{$key}->{IPADDR} >> {ETHER}' />$entries{$key}->{ETHER} >>  $hostname >> @@ -470,20 +469,20 @@ END >> END >> ; >> >> - ($sec, $min, $hour, $mday, $mon, $year, $wday, $yday, $dst) =3D localtim= e ($entries{$key}->{ENDTIME}); >> - $enddate =3D sprintf ("%02d/%02d/%d %02d:%02d:%02d",$mday,$mon+1,$year+1= 900,$hour,$min,$sec); >> + ($sec, $min, $hour, $mday, $mon, $year, $wday, $yday, $dst) =3D localti= me ($entries{$key}->{ENDTIME}); >> + $enddate =3D sprintf ("%02d/%02d/%d %02d:%02d:%02d",$mday,$mon+1,$year+= 1900,$hour,$min,$sec); >> >> - if ($entries{$key}->{ENDTIME} < time() ){ >> - print "$enddate"; >> - } else { >> - print "$enddate"; >> - } >> - print <> + if ($entries{$key}->{ENDTIME} < time() ){ >> + print "$enddate"; >> + } else { >> + print "$enddate"; >> + } >> + print <> >> >> END >> ; >> - $id++; >> + $id++; >> } >> >> print ""; >> @@ -493,34 +492,34 @@ END >> >> # This sub is used during display of actives leases >> sub leasesort { >> - if (rindex ($dhcpsettings{'SORT_LEASELIST'},'Rev') !=3D -1) >> - { >> - $qs=3Dsubstr ($dhcpsettings{'SORT_LEASELIST'},0,length($dhcpsetti= ngs{'SORT_LEASELIST'})-3); >> - if ($qs eq 'IPADDR') { >> - @a =3D split(/\./,$entries{$a}->{$qs}); >> - @b =3D split(/\./,$entries{$b}->{$qs}); >> - ($b[0]<=3D>$a[0]) || >> - ($b[1]<=3D>$a[1]) || >> - ($b[2]<=3D>$a[2]) || >> - ($b[3]<=3D>$a[3]); >> - }else { >> - $entries{$b}->{$qs} cmp $entries{$a}->{$qs}; >> - } >> - } >> - else #not reverse >> - { >> - $qs=3D$dhcpsettings{'SORT_LEASELIST'}; >> - if ($qs eq 'IPADDR') { >> - @a =3D split(/\./,$entries{$a}->{$qs}); >> - @b =3D split(/\./,$entries{$b}->{$qs}); >> - ($a[0]<=3D>$b[0]) || >> - ($a[1]<=3D>$b[1]) || >> - ($a[2]<=3D>$b[2]) || >> - ($a[3]<=3D>$b[3]); >> - }else { >> - $entries{$a}->{$qs} cmp $entries{$b}->{$qs}; >> + if (rindex ($dhcpsettings{'SORT_LEASELIST'},'Rev') !=3D -1) >> + { >> + $qs=3Dsubstr ($dhcpsettings{'SORT_LEASELIST'},0,length($dhcpsettings{'S= ORT_LEASELIST'})-3); >> + if ($qs eq 'IPADDR') { >> + @a =3D split(/\./,$entries{$a}->{$qs}); >> + @b =3D split(/\./,$entries{$b}->{$qs}); >> + ($b[0]<=3D>$a[0]) || >> + ($b[1]<=3D>$a[1]) || >> + ($b[2]<=3D>$a[2]) || >> + ($b[3]<=3D>$a[3]); >> + } else { >> + $entries{$b}->{$qs} cmp $entries{$a}->{$qs}; >> + } >> + } >> + else #not reverse >> + { >> + $qs=3D$dhcpsettings{'SORT_LEASELIST'}; >> + if ($qs eq 'IPADDR') { >> + @a =3D split(/\./,$entries{$a}->{$qs}); >> + @b =3D split(/\./,$entries{$b}->{$qs}); >> + ($a[0]<=3D>$b[0]) || >> + ($a[1]<=3D>$b[1]) || >> + ($a[2]<=3D>$b[2]) || >> + ($a[3]<=3D>$b[3]); >> + } else { >> + $entries{$a}->{$qs} cmp $entries{$b}->{$qs}; >> + } >> } >> - } >> } >> >> sub colorize { >> --=20 >> 2.27.0.windows.1 >> >> --===============8831724858270478263==--