diff options
author | Christian Schneider | 2024-04-30 10:00:32 +0200 |
---|---|---|
committer | Christian Schneider | 2024-04-30 10:11:11 +0200 |
commit | 9238b32da3afc88b80b1d51a15844fa0c1e8a9f6 (patch) | |
tree | 12f9e292d9ff7226ca459be684a437f4648b0752 /it_url.class | |
parent | c3cf4d435f0d7d2a43ee3707addf6e9794df0774 (diff) | |
download | itools-9238b32da3afc88b80b1d51a15844fa0c1e8a9f6.tar.gz itools-9238b32da3afc88b80b1d51a15844fa0c1e8a9f6.tar.bz2 itools-9238b32da3afc88b80b1d51a15844fa0c1e8a9f6.zip |
Fix is_reachable fetching always twice if content longer than 1000 bytes, make retry test having to retry more often to test that code path
Diffstat (limited to 'it_url.class')
-rw-r--r-- | it_url.class | 18 |
1 files changed, 10 insertions, 8 deletions
diff --git a/it_url.class b/it_url.class index a94975d..83ea9fb 100644 --- a/it_url.class +++ b/it_url.class @@ -305,17 +305,15 @@ function request($p=array()) // FIXME 2025-01 NG just use CURLOPT_MAXFILESIZE if we have curl 8.4 + $content = ""; if ($p['maxlength'] && !$p['writefunction']) { - $content = ""; $opts[CURLOPT_WRITEFUNCTION] = function ($dummy, $data) use ($p, &$content) { - static $total = 0; - $size = strlen($data); - $total += $size; - if ($total > $p['maxlength']) - return 0; - $content .= $data; - return $size; + static $space; + $write = min($space ?? $p['maxlength'], strlen($data)); + $content .= substr($data, 0, $write); + $space -= $write; + return $write; }; } @@ -341,6 +339,10 @@ function request($p=array()) $url->parse_http_header($url->header); + # Change result status for content longer than maxlength to 204 as we do not return partial data but still want to indicate success e.g. for is_reachable + if ($p['maxlength'] && $url->result == 200 && strlen($content) && !$got) + $url->result = 204; + if ($p['filemtime'] && ($url->result == 304)) { $result = true; # Not modified, success but no data |