Browse Source

add max redirects config

PHP-GTK3
yggverse 6 months ago
parent
commit
26b4095eb8
  1. 1
      config.json
  2. 51
      src/Entity/Tab/Page.php
  3. 8
      src/Page/Redirect.gmi

1
config.json

@ -22,6 +22,7 @@
"follow": "follow":
{ {
"enabled":true, "enabled":true,
"max":5,
"code": "code":
[ [
30, 30,

51
src/Entity/Tab/Page.php

@ -367,7 +367,8 @@ class Page
private function _gemini( private function _gemini(
string $url, string $url,
int $code = 0 int $code = 0,
int $redirects = 0
): void ): void
{ {
// Track response time // Track response time
@ -423,23 +424,45 @@ class Page
); );
// Process redirect // Process redirect
if ($this->config->redirect->follow->enabled && in_array($response->getCode(), $this->config->redirect->follow->code)) if (in_array($response->getCode(), $this->config->redirect->follow->code))
{ {
$redirect = new \Yggverse\Net\Address( if ($this->config->redirect->follow->enabled)
$url {
); if ($redirects > $this->config->redirect->follow->max)
{
$this->_yoda(
'yoda://redirect'
);
$redirect->setPath( return;
$response->getMeta() }
);
$this->open( $redirect = new \Yggverse\Net\Address(
$redirect->get(), $url
false, );
$response->getCode()
); $redirect->setPath(
$response->getMeta()
);
$this->open(
$redirect->get(),
false,
$response->getCode(),
$redirects + 1
);
return;
}
else
{
$this->_yoda(
'yoda://redirect'
);
return; return;
}
} }
$this->content->set_markup( $this->content->set_markup(

8
src/Page/Redirect.gmi

@ -0,0 +1,8 @@
# Redirect issue
You see this message because page redirect could not be processed properly
## Possible reasons
* Max redirects reached
* Redirects disabled by settings
Loading…
Cancel
Save