my $interactive = 1;
- &Pakfire::logger("### IPFire Pakfire $Conf::version started!");
+ &Pakfire::logger("PAKFIRE INFO: IPFire Pakfire $Conf::version started!");
&Pakfire::checkcryptodb;
### Check if we are running as root
my $user = qx(whoami);
chomp($user);
unless ( "$user" eq "root" ) {
- &Pakfire::message("You must run pakfire as user root!");
+ &Pakfire::message("PAKFIRE ERROR: You must run pakfire as user root!");
exit 1;
}
+ unless ( -e "/var/ipfire/red/active" ) {
+ &Pakfire::message("PAKFIRE ERROR: You need to be online to run pakfire!");
+ exit 2;
+ }
+
+ ### Check if we are started by another name
+ #
+ if ( $0 =~ /pakfire-update$/ ) {
+ &Pakfire::message("CRON INFO: Running an update");
+ $ARGV[0] = "update";
+ $interactive = 0;
+ } elsif ( $0 =~ /pakfire-upgrade$/ ) {
+ &Pakfire::message("CRON INFO: Running an upgrade");
+ $ARGV[0] = "upgrade";
+ $interactive = 0;
+ }
+
unless (@ARGV) {
&Pakfire::usage;
}
+
+ foreach (@ARGV) {
+ if ("$_" =~ "^-") {
+ # Turn off interactive mode
+ $interactive = 0 if ("$_" eq "--non-interactive");
+ $interactive = 0 if ("$_" eq "-y");
+
+ # Turn off shell colors - Bad for displaying in webinterface
+ $Pakfire::enable_colors = 0 if ("$_" eq "--no-colors");
+ }
+ }
if ("$ARGV[0]" eq "install") {
- &Pakfire::lock("on");
shift;
+
+ ### Make sure that the list is not outdated.
+ &Pakfire::dbgetlist("noforce");
+
+ open(FILE, "<$Conf::dbdir/lists/packages_list.db");
+ my @db = <FILE>;
+ close(FILE);
+
+ my $dep;
my @deps;
+ my $pak;
my @paks;
my @temp;
- foreach (@ARGV) {
- if ("$_" =~ "^--") {
- $interactive = 0 if ("$_" eq "--non-interactive");
- } else {
- push(@paks,$_);
+ my @templine;
+ my $found = 0;
+ my $return;
+ my @all;
+ foreach $pak (@ARGV) {
+ unless ("$pak" =~ "^-") {
+ $return = &Pakfire::isinstalled($pak);
+ if ($return eq 0) {
+ &Pakfire::message("PAKFIRE INFO: $pak is already installed");
+ next;
+ }
+ $found = 0;
+ foreach (@db) {
+ @templine = split(/;/,$_);
+ if ("$templine[0]" eq "$pak" ) {
+ push(@paks,$pak);
+ push(@all,$pak);
+ @temp = &Pakfire::resolvedeps("$pak");
+ foreach $dep (@temp) {
+ push(@deps,$dep) if $dep;
+ push(@all,$dep) if $dep;
+ }
+ $found = 1;
+ break;
+ }
+ }
+ if ($found == 0) {
+ &Pakfire::message("");
+ &Pakfire::message("PAKFIRE WARN: The pak \"$pak\" is not known. Please try running \"pakfire update\".");
+ }
}
}
- foreach (@paks) {
- @temp = &Pakfire::resolvedeps("$_");
- foreach (@temp) { push(@deps,$_) if $_; }
- }
- my @all;
- foreach (@paks) {
- push(@all,$_);
- }
- foreach (@deps) {
- push(@all,$_);
+ unless (@paks) {
+ &Pakfire::message("PAKFIRE ERROR: No packages to install. Exiting...");
+ exit 1;
}
- &Pakfire::message("\n\n### Packages to install:");
- foreach (sort @paks) {
- my $size = &Pakfire::getsize("$_");
+ &Pakfire::message("");
+ &Pakfire::message("");
+ &Pakfire::message("PAKFIRE INFO: Packages to install:");
+ foreach $pak (sort @paks) {
+ my $size = &Pakfire::getsize("$pak");
$size = &Pakfire::beautifysize($size);
- &Pakfire::message("# $_ \t\t - $size");
+ &Pakfire::message("PAKFIRE INFO: $pak \t - $size");
}
- &Pakfire::message("\n### Packages to install for dependencies:");
- foreach (sort @deps) {
- my $size = &Pakfire::getsize("$_");
+ if (@deps) {
+ my %sort = map{ $_, 1 } @deps;
+ @deps = sort keys %sort;
+ &Pakfire::message("");
+ &Pakfire::message("PAKFIRE INFO: Packages to install for dependencies:");
+ }
+ foreach $dep (sort @deps) {
+ my $size = &Pakfire::getsize("$dep");
$size = &Pakfire::beautifysize($size);
- &Pakfire::message("# $_ \t\t - $size");
+ &Pakfire::message("PAKFIRE INFO: $dep \t - $size");
+ }
+
+ my $totalsize;
+ foreach $pak (@all) {
+ $totalsize = ($totalsize + &Pakfire::getsize("$pak"));
}
-
- my $totalsize = &Pakfire::addsizes("@all");
$totalsize = &Pakfire::beautifysize($totalsize);
- &Pakfire::message("\n### Download size: \t ~ $totalsize");
+ &Pakfire::message("");
+ &Pakfire::message("PAKFIRE INFO: Total size: \t ~ $totalsize");
+ &Pakfire::message("");
if ($interactive) {
- &Pakfire::message("Is this okay? [y/N]");
+ &Pakfire::message("PAKFIRE INFO: Is this okay? [y/N]");
my $ret = <STDIN>;
chomp($ret);
- &Pakfire::logger("Answer: $ret");
+ &Pakfire::logger("PAKFIRE INFO: Answer: $ret");
if ( $ret ne "y" ) {
- &Pakfire::message("Installation aborted.");
+ &Pakfire::message("PAKFIRE ERROR: Installation aborted.");
exit 1;
}
+ } else {
+ &Pakfire::logger("PAKFIRE INFO: Interaction skipped.");
}
+
+ my %sort = map{ $_, 1 } @all;
+ @all = sort keys %sort;
### Download first
- foreach (sort @all) {
- &Pakfire::message("# --> Downloading: $_");
- &Pakfire::getpak("$_", "");
+ foreach $pak (sort @all) {
+ &Pakfire::getpak("$pak", "");
}
- foreach (sort @all) {
- &Pakfire::setuppak("$_");
+ &Pakfire::message("");
+
+ foreach $pak (sort @all) {
+ &Pakfire::setuppak("$pak") if ($pak ne "");
}
- &Pakfire::lock("off");
} elsif ("$ARGV[0]" eq "remove") {
+ shift;
+
+ my @paks;
+ my $pak;
+ foreach $pak (@ARGV) {
+ unless ("$pak" =~ "^-") {
+ $return = &Pakfire::isinstalled($pak);
+ if ($return ne 0) {
+ &Pakfire::message("PAKFIRE WARN: $pak is not installed");
+ next;
+ }
+ push(@paks, $pak);
+ }
+ }
+
+ unless (@paks) {
+ &Pakfire::message("PAKFIRE ERROR: No packages to remove. Exiting...");
+ exit 1;
+ }
+
+ &Pakfire::message("");
+ &Pakfire::message("");
+ &Pakfire::message("PAKFIRE INFO: Packages to remove:");
+ foreach $pak (sort @paks) {
+ my $size = &Pakfire::getsize("$pak");
+ $size = &Pakfire::beautifysize($size);
+ &Pakfire::message("PAKFIRE INFO: $pak \t - $size");
+ }
+
+ if ($interactive) {
+ &Pakfire::message("PAKFIRE INFO: Is this okay? [y/N]");
+ my $ret = <STDIN>;
+ chomp($ret);
+ &Pakfire::logger("PAKFIRE INFO: Answer: $ret");
+ if ( $ret ne "y" ) {
+ &Pakfire::message("PAKFIRE ERROR: Installation aborted.");
+ exit 1;
+ }
+ }
+
+ foreach $pak (@paks) {
+ &Pakfire::removepak("$pak");
+ }
} elsif ("$ARGV[0]" eq "update") {
- my $force = "noforce";
&Pakfire::makeuuid();
&Pakfire::senduuid();
&Pakfire::getmirrors();
- $force = "force" if ("$ARGV[1]" eq "--force");
- &Pakfire::dbgetlist("$force");
+ &Pakfire::dbgetlist("noforce");
+ &Pakfire::getcoredb();
+
+ } elsif ("$ARGV[0]" eq "upgrade") {
+ &Pakfire::upgradecore();
+ my @upgradepaks = &Pakfire::dblist("upgrade", "noweb");
+ my @temp;
+
+ foreach (@upgradepaks) {
+ @temp = &Pakfire::resolvedeps("$_");
+ foreach (@temp) { push(@upgradepaks,$_) if $_; }
+ }
+
+ if (@upgradepaks) {
+ &Pakfire::message("");
+ &Pakfire::message("PAKFIRE UPGR: We are going to install all packages listed above.");
+ if ($interactive) {
+ &Pakfire::message("PAKFIRE INFO: Is this okay? [y/N]");
+ my $ret = <STDIN>;
+ chomp($ret);
+ &Pakfire::logger("PAKFIRE INFO: Answer: $ret");
+ if ( $ret ne "y" ) {
+ &Pakfire::message("PAKFIRE ERROR: Installation aborted.");
+ exit 1;
+ }
+ }
+ }
+
+ ### Download first
+ foreach (sort @upgradepaks) {
+ &Pakfire::getpak("$_", "");
+ }
+
+ foreach (sort @upgradepaks) {
+ &Pakfire::upgradepak("$_");
+ }
} elsif ("$ARGV[0]" eq "list") {
- &Pakfire::dblist("all", "noweb");
+ if ("$ARGV[1]" =~ /installed|notinstalled/) {
+ &Pakfire::dblist("$ARGV[1]", "noweb");
+ } else {
+ &Pakfire::message("PAKFIRE WARN: Not a known option $ARGV[1]") if ($ARGV[1]);
+ &Pakfire::dblist("all", "noweb");
+ }
} elsif ("$ARGV[0]" eq "resolvedeps") {
foreach (@ARGV) {
next if ("$_" eq "resolvedeps");
+ next if ("$_" =~ "^-");
&Pakfire::resolvedeps("$_");
}
-
} else {
&Pakfire::usage;
}
+
+&Pakfire::logger("PAKFIRE INFO: Pakfire has finished. Closing.");
+
+exit 0;