]>
git.ipfire.org Git - ipfire-2.x.git/blob - src/pakfire/lib/functions.pl
2 ###############################################################################
4 # IPFire.org - A linux based firewall #
5 # Copyright (C) 2007-2015 IPFire Team <info@ipfire.org> #
7 # This program is free software: you can redistribute it and/or modify #
8 # it under the terms of the GNU General Public License as published by #
9 # the Free Software Foundation, either version 3 of the License, or #
10 # (at your option) any later version. #
12 # This program is distributed in the hope that it will be useful, #
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of #
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
15 # GNU General Public License for more details. #
17 # You should have received a copy of the GNU General Public License #
18 # along with this program. If not, see <http://www.gnu.org/licenses/>. #
20 ###############################################################################
22 require "/opt/pakfire/etc/pakfire.conf" ;
23 require "/var/ipfire/general-functions.pl" ;
37 my $myid = "179740DC4D8C47DC63C099C74BDE364C64D96617" ; # Our own gpg-key paks@ipfire.org
39 # A small color-hash :D
41 $color { 'normal' } = " \033 [0m" ;
42 $color { 'black' } = " \033 [0;30m" ;
43 $color { 'darkgrey' } = " \033 [1;30m" ;
44 $color { 'blue' } = " \033 [0;34m" ;
45 $color { 'lightblue' } = " \033 [1;34m" ;
46 $color { 'green' } = " \033 [0;32m" ;
47 $color { 'lightgreen' } = " \033 [1;32m" ;
48 $color { 'cyan' } = " \033 [0;36m" ;
49 $color { 'lightcyan' } = " \033 [1;36m" ;
50 $color { 'red' } = " \033 [0;31m" ;
51 $color { 'lightred' } = " \033 [1;31m" ;
52 $color { 'purple' } = " \033 [0;35m" ;
53 $color { 'lightpurple' } = " \033 [1;35m" ;
54 $color { 'brown' } = " \033 [0;33m" ;
55 $color { 'lightgrey' } = " \033 [0;37m" ;
56 $color { 'yellow' } = " \033 [1;33m" ;
57 $color { 'white' } = " \033 [1;37m" ;
58 our $enable_colors = 1 ;
64 my %pakfiresettings = ();
65 & General
:: readhash
( "${General::swroot}/pakfire/settings" , \
%pakfiresettings );
71 if ( $enable_colors == 1 ) {
72 if ( " $message " =~ /ERROR/ ) {
73 $message = " $color {'red'} $message $color {'normal'}" ;
74 } elsif ( " $message " =~ /INFO/ ) {
75 $message = " $color {'cyan'} $message $color {'normal'}" ;
76 } elsif ( " $message " =~ /WARN/ ) {
77 $message = " $color {'yellow'} $message $color {'normal'}" ;
78 } elsif ( " $message " =~ /RESV/ ) {
79 $message = " $color {'purple'} $message $color {'normal'}" ;
80 } elsif ( " $message " =~ /INST/ ) {
81 $message = " $color {'green'} $message $color {'normal'}" ;
82 } elsif ( " $message " =~ /REMV/ ) {
83 $message = " $color {'lightred'} $message $color {'normal'}" ;
84 } elsif ( " $message " =~ /UPGR/ ) {
85 $message = " $color {'lightblue'} $message $color {'normal'}" ;
95 #system("echo \"`date`: $log\" >> /var/log/pakfire.log");
96 system ( "logger -t pakfire \" $log \" " );
101 & Pakfire
:: message
( "Usage: pakfire <install|remove> [options] <pak(s)>" );
102 & Pakfire
:: message
( " <update> - Contacts the servers for new lists of paks." );
103 & Pakfire
:: message
( " <upgrade> - Installs the latest version of all paks." );
104 & Pakfire
:: message
( " <list> - Outputs a short list with all available paks." );
105 & Pakfire
:: message
( "" );
106 & Pakfire
:: message
( " Global options:" );
107 & Pakfire
:: message
( " --non-interactive --> Enables the non-interactive mode." );
108 & Pakfire
:: message
( " You won't see any question here." );
109 & Pakfire
:: message
( " -y --> Short for --non-interactive." );
110 & Pakfire
:: message
( " --no-colors --> Turns off the wonderful colors." );
111 & Pakfire
:: message
( "" );
118 $p = Net
:: Ping
-> new ( "icmp" );
119 if ( $p -> ping ( $host )) {
120 logger
( "PING INFO: $host is alive" );
123 logger
( "PING INFO: $host is unreachable" );
132 my ( @server , $host , $proto , $file , $i );
136 $bfile = basename
( " $getfile " );
138 logger
( "DOWNLOAD STARTED: $getfile " ) unless ( $bfile =~ /^counter\?.*/ );
141 while (( $allok == 0 ) && $i < 5 ) {
144 if ( " $gethost " eq "" ) {
145 @server = selectmirror
();
148 $file = " $server [2]/ $getfile " ;
154 $proto = "HTTP" unless $proto ;
156 unless ( $bfile =~ /^counter\?.*/ ) {
157 logger
( "DOWNLOAD INFO: Host: $host ( $proto ) - File: $file " );
160 my $ua = LWP
:: UserAgent
-> new ;
161 $ua -> agent ( "Pakfire/ $Conf ::version" );
164 my %proxysettings =();
165 & General
:: readhash
( "${General::swroot}/proxy/advanced/settings" , \
%proxysettings );
167 if ( $proxysettings { 'UPSTREAM_PROXY' }) {
168 logger
( "DOWNLOAD INFO: Upstream proxy: \" $proxysettings {'UPSTREAM_PROXY'} \" " ) unless ( $bfile =~ /^counter.py\?.*/ );
169 if ( $proxysettings { 'UPSTREAM_USER' }) {
170 $ua -> proxy ( "http" , "http:// $proxysettings {'UPSTREAM_USER'}: $proxysettings {'UPSTREAM_PASSWORD'}@" . " $proxysettings {'UPSTREAM_PROXY'}/" );
171 logger
( "DOWNLOAD INFO: Logging in with: \" $proxysettings {'UPSTREAM_USER'} \" - \" $proxysettings {'UPSTREAM_PASSWORD'} \" " ) unless ( $bfile =~ /^counter.py\?.*/ );
173 $ua -> proxy ( "http" , "http:// $proxysettings {'UPSTREAM_PROXY'}/" );
178 my $url = "http:// $host / $file " ;
181 unless ( $bfile =~ /^counter.py\?.*/ ) {
182 my $result = $ua -> head ( $url );
183 my $remote_headers = $result -> headers ;
184 $total_size = $remote_headers -> content_length ;
185 logger
( "DOWNLOAD INFO: $file has size of $total_size bytes" );
187 $response = $ua -> get ( $url , ':content_cb' => \
& callback
);
190 $response = $ua -> get ( $url );
193 my $code = $response -> code ();
194 my $log = $response -> status_line ;
195 logger
( "DOWNLOAD INFO: HTTP-Status-Code: $code - $log " );
197 if ( $code eq "500" ) {
198 message
( "Giving up: There was no chance to get the file \" $getfile \" from any available server. \n There was an error on the way. Please fix it." );
202 if ( $response -> is_success ) {
203 unless ( $bfile =~ /^counter.py\?.*/ ) {
204 if ( open ( FILE
, "> $Conf ::tmpdir/ $bfile " )) {
205 print FILE
$final_data ;
207 logger
( "DOWNLOAD INFO: File received. Start checking signature..." );
208 if ( system ( "gpg --verify \" $Conf ::tmpdir/ $bfile \" &>/dev/null" ) eq 0 ) {
209 logger
( "DOWNLOAD INFO: Signature of $bfile is fine." );
210 move
( " $Conf ::tmpdir/ $bfile " , " $Conf ::cachedir/ $bfile " );
212 message
( "DOWNLOAD ERROR: The downloaded file ( $file ) wasn't verified by IPFire.org. Sorry - Exiting..." );
213 my $ntp = `ntpdate -q -t 10 pool.ntp.org 2>/dev/null | tail -1` ;
214 if ( $ntp !~ /time\ server(.*)offset(.*)/ ){ message
( "TIME ERROR: Unable to get the nettime, this may lead to the verification error." );}
215 else { $ntp =~ /time\ server(.*)offset(.*)/ ; message
( "TIME INFO: Time Server $1has $2 offset to localtime." );}
218 logger
( "DOWNLOAD FINISHED: $file " );
222 logger
( "DOWNLOAD ERROR: Could not open $Conf ::tmpdir/ $bfile for writing." );
228 logger
( "DOWNLOAD ERROR: $log " );
231 message
( "DOWNLOAD ERROR: There was no chance to get the file \" $getfile \" from any available server. \n May be you should run \" pakfire update \" to get some new servers." );
241 if ( - e
" $Conf ::dbdir/lists/server-list.db" ) {
242 my @stat = stat ( " $Conf ::dbdir/lists/server-list.db" );
244 $age = $time - $stat [ 9 ];
245 $force = "force" if ( " $age " >= "3600" );
246 logger
( "MIRROR INFO: server-list.db is $age seconds old. - DEBUG: $force " );
252 if ( " $force " eq "force" ) {
253 fetchfile
( " $Conf ::version/lists/server-list.db" , " $Conf ::mainserver" );
254 move
( " $Conf ::cachedir/server-list.db" , " $Conf ::dbdir/lists/server-list.db" );
264 if ( - e
" $Conf ::dbdir/lists/core-list.db" ) {
265 my @stat = stat ( " $Conf ::dbdir/lists/core-list.db" );
267 $age = $time - $stat [ 9 ];
268 $force = "force" if ( " $age " >= "3600" );
269 logger
( "CORE INFO: core-list.db is $age seconds old. - DEBUG: $force " );
275 if ( " $force " eq "force" ) {
276 fetchfile
( "lists/core-list.db" , "" );
277 move
( " $Conf ::cachedir/core-list.db" , " $Conf ::dbdir/lists/core-list.db" );
283 ### Check if there is a current server list and read it.
284 # If there is no list try to get one.
286 while (!( open ( FILE
, "< $Conf ::dbdir/lists/server-list.db" )) && ( $count lt 5 )) {
288 getmirrors
( "noforce" );
291 message
( "MIRROR ERROR: Could not find or download a server list" );
297 ### Count the number of the servers in the list
301 if ( " $_ " =~ /.*;.*;.*;/ ) {
306 logger
( "MIRROR INFO: $scount servers found in list" );
309 logger
( "MIRROR INFO: Could not find any servers. Falling back to main server $Conf ::mainserver" );
310 return ( "HTTP" , $Conf :: mainserver
, "/ $Conf ::version" );
313 ### Choose a random server and test if it is online
314 # If the check fails try a new server.
315 # This will never give up.
319 while ( $found == 0 ) {
320 $server = int ( rand ( $scount ) + 1 );
322 my ( $line , $proto , $path , $host );
324 foreach $line ( @newlines ) {
326 if ( $servers eq $server ) {
327 @templine = split ( /\;/ , $line );
328 $proto = $templine [ 0 ];
329 $host = $templine [ 1 ];
330 $path = $templine [ 2 ];
331 if ( $pakfiresettings { 'HEALTHCHECK' } eq "off" ) {
332 logger
( "PING INFO: Healthcheck is disabled" );
334 return ( $proto , $host , $path );
336 elsif ( pinghost
( " $host " )) {
338 return ( $proto , $host , $path );
342 $pingdelay = $pingdelay * 2 ;
343 if ( $pingdelay > 1200 ) {
353 ### Update the database if the file is older than one day.
354 # If you pass &Pakfire::dbgetlist(force) the list will be downloaded.
355 # Usage is always with an argument.
361 if ( - e
" $Conf ::dbdir/lists/packages_list.db" ) {
362 my @stat = stat ( " $Conf ::dbdir/lists/packages_list.db" );
364 $age = $time - $stat [ 9 ];
365 $force = "force" if ( " $age " >= "3600" );
366 logger
( "DB INFO: packages_list.db is $age seconds old. - DEBUG: $force " );
372 if ( " $force " eq "force" ) {
373 fetchfile
( "lists/packages_list.db" , "" );
374 move
( " $Conf ::cachedir/packages_list.db" , " $Conf ::dbdir/lists/packages_list.db" );
377 # Update the meta database if new packages was in the package list
382 my ( $name , $version , $release );
385 open ( FILE
, "< $Conf ::dbdir/lists/packages_list.db" );
389 opendir ( DIR
, " $Conf ::dbdir/meta" );
390 my @files = readdir ( DIR
);
392 foreach $file ( @files ) {
393 next if ( $file eq "." );
394 next if ( $file eq ".." );
395 next if ( $file eq "meta-" );
396 next if ( $file =~ /^old/ );
397 open ( FILE
, "< $Conf ::dbdir/meta/ $file " );
400 foreach $line ( @meta ) {
401 @templine = split ( /\: / , $line );
402 if ( " $templine [0]" eq "Name" ) {
403 $name = $templine [ 1 ];
405 } elsif ( " $templine [0]" eq "ProgVersion" ) {
406 $version = $templine [ 1 ];
408 } elsif ( " $templine [0]" eq "Release" ) {
409 $release = $templine [ 1 ];
413 foreach $prog ( @db ) {
414 @templine = split ( /\;/ , $prog );
415 if (( " $name " eq " $templine [0]" ) && ( " $release " ne " $templine [2]" )) {
416 move
( " $Conf ::dbdir/meta/meta- $name " , " $Conf ::dbdir/meta/old_meta- $name " );
417 fetchfile
( "meta/meta- $name " , "" );
418 move
( " $Conf ::cachedir/meta- $name " , " $Conf ::dbdir/meta/meta- $name " );
425 ### This subroutine lists the packages.
426 # You may also pass a filter: &Pakfire::dblist(filter)
427 # Usage is always with two arguments.
428 # filter may be: all, notinstalled, installed
436 my ( $name , $version , $release );
439 ### Make sure that the list is not outdated.
440 #dbgetlist("noforce");
442 open ( FILE
, "< $Conf ::dbdir/lists/packages_list.db" );
446 if ( " $filter " eq "upgrade" ) {
447 if ( " $forweb " ne "forweb" && " $forweb " ne "notice" ) { getcoredb
( "noforce" );}
448 eval ( `grep "core_" $Conf ::dbdir/lists/core-list.db` );
449 if ( " $core_release " > " $Conf ::core_mine" ) {
450 if ( " $forweb " eq "forweb" ) {
451 print "<option value= \" core \" >Core-Update -- $Conf ::version -- Release: $Conf ::core_mine -> $core_release </option> \n " ;
453 elsif ( " $forweb " eq "notice" ) {
454 print "<br /><br /><br /><a href='pakfire.cgi'> $Lang ::tr{'core notice 1'} $Conf ::core_mine $Lang ::tr{'core notice 2'} $core_release $Lang ::tr{'core notice 3'}</a>" ;
456 my $command = "Core-Update $Conf ::version \n Release: $Conf ::core_mine -> $core_release \n " ;
457 if ( " $Pakfire ::enable_colors" eq "1" ) {
458 print " $color {'lila'} $command $color {'normal'} \n " ;
465 opendir ( DIR
, " $Conf ::dbdir/installed" );
466 my @files = readdir ( DIR
);
468 foreach $file ( @files ) {
469 next if ( $file eq "." );
470 next if ( $file eq ".." );
471 next if ( $file =~ /^old/ );
472 open ( FILE
, "< $Conf ::dbdir/installed/ $file " );
475 foreach $line ( @meta ) {
476 @templine = split ( /\: / , $line );
477 if ( " $templine [0]" eq "Name" ) {
478 $name = $templine [ 1 ];
480 } elsif ( " $templine [0]" eq "ProgVersion" ) {
481 $version = $templine [ 1 ];
483 } elsif ( " $templine [0]" eq "Release" ) {
484 $release = $templine [ 1 ];
488 foreach $prog ( @db ) {
489 @templine = split ( /\;/ , $prog );
490 if (( " $name " eq " $templine [0]" ) && ( " $release " < " $templine [2]" && " $forweb " ne "notice" )) {
491 push ( @updatepaks , $name );
492 if ( " $forweb " eq "forweb" ) {
493 print "<option value= \" $name \" >Update: $name -- Version: $version -> $templine [1] -- Release: $release -> $templine [2]</option> \n " ;
495 my $command = "Update: $name \n Version: $version -> $templine [1] \n Release: $release -> $templine [2] \n " ;
496 if ( " $Pakfire ::enable_colors" eq "1" ) {
497 print " $color {'lila'} $command $color {'normal'} \n " ;
511 foreach $line ( sort @db ) {
512 next unless ( $line =~ /.*;.*;.*;/ );
515 @templine = split ( /\;/ , $line );
516 if ( " $filter " eq "notinstalled" ) {
517 next if ( - e
" $Conf ::dbdir/installed/meta- $templine [0]" );
518 } elsif ( " $filter " eq "installed" ) {
519 next unless ( - e
" $Conf ::dbdir/installed/meta- $templine [0]" );
521 if ( " $forweb " eq "forweb" )
523 if ( " $filter " eq "notinstalled" ) {
524 print "<option value= \" $templine [0] \" > $templine [0]- $templine [1]- $templine [2]</option> \n " ;
526 print "<option value= \" $templine [0] \" > $templine [0]</option> \n " ;
529 if ( " $Pakfire ::enable_colors" eq "1" ) {
530 if (& isinstalled
( " $templine [0]" )) {
531 $use_color = " $color {'red'}"
533 $use_color = " $color {'green'}"
536 print "${use_color}Name: $templine [0] \n ProgVersion: $templine [1] \n Release: $templine [2] $color {'normal'} \n\n " ;
539 print " $count packages total. \n " unless ( " $forweb " eq "forweb" );
543 sub resolvedeps_one
{
548 message
( "PAKFIRE RESV: $pak : Resolving dependencies..." );
550 open ( FILE
, "< $Conf ::dbdir/meta/meta- $pak " );
555 my ( @templine , @deps , @all );
556 foreach $line ( @file ) {
557 @templine = split ( /\: / , $line );
558 if ( " $templine [0]" eq "Dependencies" ) {
559 @deps = split ( / / , $templine [ 1 ]);
565 my $return = & isinstalled
( $_ );
567 message
( "PAKFIRE RESV: $pak : Dependency is already installed: $_ " );
569 message
( "PAKFIRE RESV: $pak : Need to install dependency: $_ " );
582 # Resolve all not yet installed dependencies of $pak
583 my @deps = & resolvedeps_one
( $pak );
586 # For each dependency, we check if more dependencies exist
588 my $dep = pop ( @deps );
590 my @subdeps = & resolvedeps_one
( $dep );
591 foreach my $subdep ( @subdeps ) {
592 # Skip the package we are currently resolving for
593 next if ( $pak eq $subdep );
595 # If the package is not already to be installed,
596 # we add it to the list (@all) and check if it has
597 # more dependencies on its own.
598 unless ( grep { $_ eq $subdep } @all ) {
599 push ( @deps , $subdep );
608 sub resolvedeps_recursive
{
612 foreach my $pkg ( @packages ) {
613 my @deps = & Pakfire
:: resolvedeps
( $pkg );
615 foreach my $dep ( @deps ) {
620 # Sort the result array and remove dupes
621 my %sort = map { $_ , 1 } @result ;
622 @result = keys %sort ;
631 logger
( "CLEANUP: $dir " );
633 if ( " $dir " eq "meta" ) {
634 $path = " $Conf ::dbdir/meta" ;
635 } elsif ( " $dir " eq "tmp" ) {
636 $path = " $Conf ::tmpdir" ;
640 my @files = readdir ( DIR
);
643 unless (( $_ eq "." ) || ( $_ eq ".." )) {
652 unless ( - e
" $Conf ::dbdir/meta/meta- $pak " ) {
653 fetchfile
( "meta/meta- $pak " , "" );
654 move
( " $Conf ::cachedir/meta- $pak " , " $Conf ::dbdir/meta/meta- $pak " );
657 if ( - z
" $Conf ::dbdir/meta/meta- $pak " ) {
658 fetchfile
( "meta/meta- $pak " , "" );
659 move
( " $Conf ::cachedir/meta- $pak " , " $Conf ::dbdir/meta/meta- $pak " );
662 open ( FILE
, "< $Conf ::dbdir/meta/meta- $pak " );
666 open ( FILE
, "> $Conf ::dbdir/meta/meta- $pak " );
669 $string =~ s/\r\n/\n/g ;
681 open ( FILE
, "< $Conf ::dbdir/meta/meta- $pak " );
687 foreach $line ( @file ) {
688 @templine = split ( /\: / , $line );
689 if ( " $templine [0]" eq "Size" ) {
702 my $file = getpak
( " $pak " , "noforce" );
704 logger
( "DECRYPT STARTED: $pak " );
705 my $return = system ( "cd $Conf ::tmpdir/ && gpg -d --batch --quiet --no-verbose --status-fd 2 --output - < $Conf ::cachedir/ $file 2>/dev/null | tar x" );
707 logger
( "DECRYPT FINISHED: $pak - Status: $return " );
708 if ( $return != 0 ) { exit 1 ; }
717 open ( FILE
, "< $Conf ::dbdir/meta/meta- $pak " );
724 foreach $line ( @file ) {
725 @templine = split ( /\: / , $line );
726 if ( " $templine [0]" eq "File" ) {
728 $file = $templine [ 1 ];
733 message
( "No filename given in meta-file." );
737 unless ( " $force " eq "force" ) {
738 if ( - e
" $Conf ::cachedir/ $file " ) {
743 fetchfile
( "paks/ $file " , "" );
750 message
( "PAKFIRE INST: $pak : Decrypting..." );
753 message
( "PAKFIRE INST: $pak : Copying files and running post-installation scripts..." );
754 my $return = system ( "cd $Conf ::tmpdir && NAME= $pak ./install.sh >> $Conf ::logdir/install- $pak .log 2>&1" );
756 if ( $pakfiresettings { 'UUID' } ne "off" ) {
757 fetchfile
( "counter.py?ver= $Conf ::version&uuid= $Conf ::uuid&ipak= $pak &return= $return " , " $Conf ::mainserver" );
760 move
( " $Conf ::tmpdir/ROOTFILES" , " $Conf ::dbdir/rootfiles/ $pak " );
762 copy
( " $Conf ::dbdir/meta/meta- $pak " , " $Conf ::dbdir/installed/" );
763 message
( "PAKFIRE INST: $pak : Finished." );
766 message
( "PAKFIRE ERROR: Returncode: $return . Sorry. Please search our forum to find a solution for this problem." );
773 getcoredb
( "noforce" );
774 eval ( `grep "core_" $Conf ::dbdir/lists/core-list.db` );
775 if ( " $core_release " > " $Conf ::core_mine" ) {
776 message
( "CORE UPGR: Upgrading from release $Conf ::core_mine to $core_release " );
778 my @seq = `seq $Conf ::core_mine $core_release ` ;
781 foreach $release ( @seq ) {
783 getpak
( "core-upgrade- $release " );
786 foreach $release ( @seq ) {
788 upgradepak
( "core-upgrade- $release " );
791 system ( "echo $core_release > $Conf ::coredir/mine" );
794 message
( "CORE ERROR: No new upgrades available. You are on release $Conf ::core_mine." );
800 if ( open ( FILE
, "< $Conf ::dbdir/installed/meta- $pak " ) ) {
811 message
( "PAKFIRE UPGR: $pak : Decrypting..." );
814 message
( "PAKFIRE UPGR: $pak : Upgrading files and running post-upgrading scripts..." );
815 my $return = system ( "cd $Conf ::tmpdir && NAME= $pak ./update.sh >> $Conf ::logdir/update- $pak .log 2>&1" );
817 if ( $pakfiresettings { 'UUID' } ne "off" ) {
818 fetchfile
( "counter.py?ver= $Conf ::version&uuid= $Conf ::uuid&upak= $pak &return= $return " , " $Conf ::mainserver" );
821 move
( " $Conf ::tmpdir/ROOTFILES" , " $Conf ::dbdir/rootfiles/ $pak " );
823 copy
( " $Conf ::dbdir/meta/meta- $pak " , " $Conf ::dbdir/installed/" );
824 message
( "PAKFIRE UPGR: $pak : Finished." );
827 message
( "PAKFIRE ERROR: Returncode: $return . Sorry. Please search our forum to find a solution for this problem." );
836 message
( "PAKFIRE REMV: $pak : Decrypting..." );
839 message
( "PAKFIRE REMV: $pak : Removing files and running post-removing scripts..." );
840 my $return = system ( "cd $Conf ::tmpdir && NAME= $pak ./uninstall.sh >> $Conf ::logdir/uninstall- $pak .log 2>&1" );
842 if ( $pakfiresettings { 'UUID' } ne "off" ) {
843 fetchfile
( "counter.py?ver= $Conf ::version&uuid= $Conf ::uuid&dpak= $pak &return= $return " , " $Conf ::mainserver" );
846 unlink ( " $Conf ::dbdir/rootfiles/ $pak " );
847 unlink ( " $Conf ::dbdir/installed/meta- $pak " );
849 message
( "PAKFIRE REMV: $pak : Finished." );
852 message
( "PAKFIRE ERROR: Returncode: $return . Sorry. Please search our forum to find a solution for this problem." );
860 #$size = $size / 1024;
863 if ( $size > 1023 * 1024 ) {
864 $size = ( $size / ( 1024 * 1024 ));
866 } elsif ( $size > 1023 ) {
867 $size = ( $size / 1024 );
872 $size = sprintf ( "%.2f" , $size );
873 my $string = " $size $unit " ;
878 unless ( - e
" $Conf ::dbdir/uuid" ) {
879 open ( FILE
, "</proc/sys/kernel/random/uuid" );
883 open ( FILE
, "> $Conf ::dbdir/uuid" );
892 if ( $pakfiresettings { 'UUID' } ne "off" ) {
893 unless ( " $Conf ::uuid" ) {
894 $Conf :: uuid
= `cat $Conf ::dbdir/uuid` ;
896 logger
( "Sending my uuid: $Conf ::uuid" );
897 fetchfile
( "counter.py?ver= $Conf ::version&uuid= $Conf ::uuid" , " $Conf ::mainserver" );
898 system ( "rm -f $Conf ::tmpdir/counter* 2>/dev/null" );
903 logger
( "CRYPTO INFO: Checking GnuPG Database" );
904 my $ret = system ( "gpg --list-keys | grep -q $myid " );
905 unless ( " $ret " eq "0" ) {
906 message
( "CRYPTO WARN: The GnuPG isn't configured correctly. Trying now to fix this." );
907 message
( "CRYPTO WARN: It's normal to see this on first execution." );
908 message
( "CRYPTO WARN: If this message is being shown repeatedly, check if time and date are set correctly, and if IPFire can connect via port 11371 TCP." );
909 my $command = "gpg --keyserver pgp.ipfire.org --always-trust --status-fd 2" ;
910 system ( " $command --recv-key $myid >> $Conf ::logdir/gnupg-database.log 2>&1" );
912 logger
( "CRYPTO INFO: Database is okay" );
917 my ( $data , $response , $protocol ) = @_ ;
918 $final_data .= $data ;
919 print progress_bar
( length ( $final_data ), $total_size , 30 , '=' );
923 my ( $got , $total , $width , $char ) = @_ ;
925 $width ||= 30 ; $char ||= '=' ;
926 my $len_bfile = length $bfile ;
927 if ( " $len_bfile " >= "17" ) {
928 $show_bfile = substr ( $bfile , 0 , 17 ). "..." ;
930 $show_bfile = $bfile ;
932 $progress = sprintf ( "%.2f%%" , 100 * $got /+ $total );
933 sprintf " $color {'lightgreen'}%-20s %7s |%-${width}s| %10s $color {'normal'} \r " , $show_bfile , $progress , $char x
(( $width - 1 )* $got / $total ). '>' , beautifysize
( $got );