From mboxrd@z Thu Jan 1 00:00:00 1970 From: Michael Tremer To: development@lists.ipfire.org Subject: Re: [PATCH 2/5] ids-functions.pl: Allow "5" download attempts for each provider before fail. Date: Wed, 23 Mar 2022 09:28:04 +0000 Message-ID: <69B2E7ED-4F56-435A-81DE-CB7C2D7176D6@ipfire.org> In-Reply-To: <20220323040452.2609-2-stefan.schantl@ipfire.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============5777081232058938885==" List-Id: --===============5777081232058938885== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Hello, What is the rationale for five attempts? Why not three? -Michael > On 23 Mar 2022, at 04:04, Stefan Schantl wrot= e: >=20 > Signed-off-by: Stefan Schantl > --- > config/cfgroot/ids-functions.pl | 38 ++++++++++++++++++++++++--------- > 1 file changed, 28 insertions(+), 10 deletions(-) >=20 > diff --git a/config/cfgroot/ids-functions.pl b/config/cfgroot/ids-functions= .pl > index eb276030b..c8bc52b1b 100644 > --- a/config/cfgroot/ids-functions.pl > +++ b/config/cfgroot/ids-functions.pl > @@ -256,6 +256,10 @@ sub downloadruleset ($) { > # If no provider is given default to "all". > $provider //=3D 'all'; >=20 > + # The amount of download attempts before giving up and > + # logging an error. > + my $max_dl_attempts =3D 5; > + > # Hash to store the providers and access id's, for which rules should be d= ownloaded. > my %sheduled_providers =3D (); >=20 > @@ -364,19 +368,33 @@ sub downloadruleset ($) { > # Pass the requested url to the downloader. > my $request =3D HTTP::Request->new(GET =3D> $url); >=20 > - # Perform the request and save the output into the tmpfile. > - my $response =3D $downloader->request($request, $tmpfile); > + my $dl_attempt =3D 1; > + my $response; >=20 > - # Check if there was any error. > - unless ($response->is_success) { > - # Obtain error. > - my $error =3D $response->content; > + # Download and retry on failure. > + while ($dl_attempt <=3D $max_dl_attempts) { > + # Perform the request and save the output into the tmpfile. > + $response =3D $downloader->request($request, $tmpfile); >=20 > - # Log error message. > - &_log_to_syslog("Unable to download the ruleset. \($error\)"); > + # Check if the download was successfull. > + if($response->is_success) { > + # Break loop. > + last; >=20 > - # Return "1" - false. > - return 1; > + # Check if we ran out of download re-tries. > + } elsif ($dl_attempt eq $max_dl_attempts) { > + # Obtain error. > + my $error =3D $response->content; > + > + # Log error message. > + &_log_to_syslog("Unable to download the ruleset. \($error\)"); > + > + # Return "1" - false. > + return 1; > + } > + > + # Increase download attempt counter. > + $dl_attempt++; > } >=20 > # Obtain the connection headers. > --=20 > 2.30.2 >=20 --===============5777081232058938885==--