From: "Peter Müller" <peter.mueller@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: [PATCH 1/7] pakfire.cgi: Separate command processing and HTML generation
Date: Sun, 08 May 2022 13:11:20 +0000 [thread overview]
Message-ID: <61786b3c-d543-8f0d-cc54-c783a32e7a21@ipfire.org> (raw)
In-Reply-To: <20220508120952.52-1-hofmann@leo-andres.de>
[-- Attachment #1: Type: text/plain, Size: 5088 bytes --]
Acked-by: Peter Müller <peter.muelle(a)ipfire.org>
> Move most of the command execution away from the HTML output.
> This makes it easier to modify or extend individual commands.
>
> Also load Pakfire settings earlier to ensure that they are
> available during command execution.
>
> Signed-off-by: Leo-Andres Hofmann <hofmann(a)leo-andres.de>
> ---
> html/cgi-bin/pakfire.cgi | 61 +++++++++++++++++++++-------------------
> 1 file changed, 32 insertions(+), 29 deletions(-)
>
> diff --git a/html/cgi-bin/pakfire.cgi b/html/cgi-bin/pakfire.cgi
> index 65c67fb90..b908ec6a0 100644
> --- a/html/cgi-bin/pakfire.cgi
> +++ b/html/cgi-bin/pakfire.cgi
> @@ -39,11 +39,12 @@ my %mainsettings = ();
>
> # Load general settings
> &General::readhash("${General::swroot}/main/settings", \%mainsettings);
> +&General::readhash("${General::swroot}/pakfire/settings", \%pakfiresettings);
> &General::readhash("/srv/web/ipfire/html/themes/ipfire/include/colors.txt", \%color);
>
> # Get CGI request data
> $cgiparams{'ACTION'} = '';
> -$cgiparams{'VALID'} = '';
> +$cgiparams{'FORCE'} = '';
>
> $cgiparams{'INSPAKS'} = '';
> $cgiparams{'DELPAKS'} = '';
> @@ -94,6 +95,35 @@ if($cgiparams{'ACTION'} eq 'json-getstatus') {
> exit;
> }
>
> +### Process Pakfire install/update commands ###
> +if(($cgiparams{'ACTION'} ne '') && (! &_is_pakfire_busy())) {
> + if(($cgiparams{'ACTION'} eq 'install') && ($cgiparams{'FORCE'} eq 'on')) {
> + my @pkgs = split(/\|/, $cgiparams{'INSPAKS'});
> + &General::system_background("/usr/local/bin/pakfire", "install", "--non-interactive", "--no-colors", @pkgs);
> + } elsif(($cgiparams{'ACTION'} eq 'remove') && ($cgiparams{'FORCE'} eq 'on')) {
> + my @pkgs = split(/\|/, $cgiparams{'DELPAKS'});
> + &General::system_background("/usr/local/bin/pakfire", "remove", "--non-interactive", "--no-colors", @pkgs);
> + } elsif($cgiparams{'ACTION'} eq 'update') {
> + &General::system_background("/usr/local/bin/pakfire", "update", "--force", "--no-colors");
> + } elsif($cgiparams{'ACTION'} eq 'upgrade') {
> + &General::system_background("/usr/local/bin/pakfire", "upgrade", "-y", "--no-colors");
> + } elsif($cgiparams{'ACTION'} eq $Lang::tr{'save'}) {
> + $pakfiresettings{"TREE"} = $cgiparams{"TREE"};
> +
> + # Check for valid input
> + if ($pakfiresettings{"TREE"} !~ m/^(stable|testing|unstable)$/) {
> + $errormessage .= $Lang::tr{'pakfire invalid tree'};
> + }
> +
> + unless ($errormessage) {
> + &General::writehash("${General::swroot}/pakfire/settings", \%pakfiresettings);
> +
> + # Update lists
> + &General::system_background("/usr/local/bin/pakfire", "update", "--force", "--no-colors");
> + }
> + }
> +}
> +
> ### Start pakfire page ###
> &Header::showhttpheaders();
>
> @@ -185,9 +215,6 @@ END
> # Process Pakfire commands
> if (($cgiparams{'ACTION'} eq 'install') && (! &_is_pakfire_busy())) {
> my @pkgs = split(/\|/, $cgiparams{'INSPAKS'});
> - if ("$cgiparams{'FORCE'}" eq "on") {
> - &General::system_background("/usr/local/bin/pakfire", "install", "--non-interactive", "--no-colors", @pkgs);
> - } else {
> &Header::openbox("100%", "center", $Lang::tr{'request'});
> my @output = &General::system_output("/usr/local/bin/pakfire", "resolvedeps", "--no-colors", @pkgs);
> print <<END;
> @@ -222,12 +249,9 @@ END
> &Header::closebigbox();
> &Header::closepage();
> exit;
> - }
> +
> } elsif (($cgiparams{'ACTION'} eq 'remove') && (! &_is_pakfire_busy())) {
> my @pkgs = split(/\|/, $cgiparams{'DELPAKS'});
> - if ("$cgiparams{'FORCE'}" eq "on") {
> - &General::system_background("/usr/local/bin/pakfire", "remove", "--non-interactive", "--no-colors", @pkgs);
> - } else {
> &Header::openbox("100%", "center", $Lang::tr{'request'});
> my @output = &General::system_output("/usr/local/bin/pakfire", "resolvedeps", "--no-colors", @pkgs);
> print <<END;
> @@ -262,30 +286,9 @@ END
> &Header::closebigbox();
> &Header::closepage();
> exit;
> - }
> -
> -} elsif (($cgiparams{'ACTION'} eq 'update') && (! &_is_pakfire_busy())) {
> - &General::system_background("/usr/local/bin/pakfire", "update", "--force", "--no-colors");
> -} elsif (($cgiparams{'ACTION'} eq 'upgrade') && (! &_is_pakfire_busy())) {
> - &General::system_background("/usr/local/bin/pakfire", "upgrade", "-y", "--no-colors");
> -} elsif ($cgiparams{'ACTION'} eq "$Lang::tr{'save'}") {
> - $pakfiresettings{"TREE"} = $cgiparams{"TREE"};
> -
> - # Check for valid input
> - if ($pakfiresettings{"TREE"} !~ m/^(stable|testing|unstable)$/) {
> - $errormessage .= $Lang::tr{'pakfire invalid tree'};
> - }
> -
> - unless ($errormessage) {
> - &General::writehash("${General::swroot}/pakfire/settings", \%pakfiresettings);
>
> - # Update lists
> - &General::system_background("/usr/local/bin/pakfire", "update", "--force", "--no-colors");
> - }
> }
>
> -&General::readhash("${General::swroot}/pakfire/settings", \%pakfiresettings);
> -
> my %selected=();
> my %checked=();
>
prev parent reply other threads:[~2022-05-08 13:11 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-05-08 12:09 Leo-Andres Hofmann
2022-05-08 12:09 ` [PATCH 2/7] pakfire.cgi: Fix indentation Leo-Andres Hofmann
2022-05-08 13:11 ` Peter Müller
2022-05-08 12:09 ` [PATCH 3/7] pakfire.cgi: Show error and log messages earlier Leo-Andres Hofmann
2022-05-08 13:12 ` Peter Müller
2022-05-08 12:09 ` [PATCH 4/7] pakfire.cgi: Notify user if Pakfire is already performing a task Leo-Andres Hofmann
2022-05-08 13:12 ` Peter Müller
2022-05-08 12:09 ` [PATCH 5/7] pakfire.cgi: Implement Post/Redirect/Get pattern Leo-Andres Hofmann
2022-05-08 13:12 ` Peter Müller
2022-05-12 9:30 ` Michael Tremer
2022-05-20 9:47 ` hofmann
2022-05-08 12:09 ` [PATCH 6/7] pakfire.cgi: Discard tac stderr output Leo-Andres Hofmann
2022-05-08 13:12 ` Peter Müller
2022-05-08 12:09 ` [PATCH 7/7] pakfire.cgi: Cosmetic fixes Leo-Andres Hofmann
2022-05-08 13:12 ` Peter Müller
2022-05-08 13:11 ` Peter Müller [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=61786b3c-d543-8f0d-cc54-c783a32e7a21@ipfire.org \
--to=peter.mueller@ipfire.org \
--cc=development@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox