X-Git-Url: https://git.cweiske.de/phinde.git/blobdiff_plain/cb78e8dbc0351660d0c5c15be2a7b9b969ad9dbe..d799ee3da63578c33bbdc74b6909e3924a6c80b4:/www/index.php?ds=inline diff --git a/www/index.php b/www/index.php index 6bdaf9d..c1acfdf 100644 --- a/www/index.php +++ b/www/index.php @@ -15,6 +15,14 @@ if (isset($_GET['page'])) { } //PEAR Pager begins at 1 $page = (int)$_GET['page'] - 1; + + if ($page >= 100) { + //Elasticsearch by default only allows 100 pages + // we do not want exceptions in our logs + header('HTTP/1.0 400 Bad Request'); + echo "List page number is too large\n"; + exit(1); + } } $perPage = 10;//$GLOBALS['phinde']['perPage']; @@ -35,11 +43,16 @@ if (preg_match('#site:([^ ]*)#', $query, $matches)) { $cleanQuery = $query; } -if (isset($_GET['sort']) && $_GET['sort'] == 'date') { - $sort = 'date'; - $baseLink .= '&sort=date'; +if (isset($_GET['sort']) + && ($_GET['sort'] === 'date' || $_GET['sort'] === 'score') +) { + $sortMode = $_GET['sort']; } else { - $sort = ''; + $sortMode = $GLOBALS['phinde']['defaultSort']; +} +$sort = $sortMode; +if ($sortMode !== $GLOBALS['phinde']['defaultSort']) { + $baseLink .= '&sort=' . $sortMode; } $filters = array(); @@ -93,7 +106,7 @@ $timeEnd = microtime(true); $pager = new Html_Pager( $res->hits->total, $perPage, $page + 1, - $baseLink + buildLink($baseLink, $filters, null, null) ); foreach ($res->hits->hits as &$hit) { @@ -115,8 +128,8 @@ foreach ($res->hits->hits as &$hit) { $doc->extra = new \stdClass(); $doc->extra->cleanUrl = preg_replace('#^.*://#', '', $doc->url); - if (isset($doc->modate)) { - $doc->extra->day = substr($doc->modate, 0, 10); + if (isset($doc->status->modate)) { + $doc->extra->day = substr($doc->status->modate, 0, 10); } } @@ -132,10 +145,17 @@ if ($site !== null) { $urlNoSite = null; } -$urlSortRelevance = buildLink( - str_replace('&sort=date', '', $baseLink), $filters, null, null +$urlSortBase = buildLink( + preg_replace('#&sort=[^&]+#', '', $baseLink), $filters, null, null ); -$urlSortDate = $urlSortRelevance . '&sort=date'; +$urlSorts = []; +foreach (['date', 'score'] as $sortMode) { + if ($sortMode === $GLOBALS['phinde']['defaultSort']) { + $urlSorts[$sortMode] = $urlSortBase; + } else { + $urlSorts[$sortMode] = $urlSortBase . '&sort=' . $sortMode; + } +} if (isset($_GET['format']) && $_GET['format'] == 'opensearch') { $template = 'opensearch'; @@ -161,8 +181,9 @@ render( 'activeFilters' => $activeFilters, 'pager' => $pager, 'sort' => $sort, - 'urlSortRelevance' => $urlSortRelevance, - 'urlSortDate' => $urlSortDate, + 'urlSorts' => $urlSorts, + 'hitTemplate' => 'search/' . $GLOBALS['phinde']['hitTemplate'], + 'sidebarinclude' => $GLOBALS['phinde']['sidebarinclude'], ) ); ?>