- streamlined way of managing query parameters

This commit is contained in:
Gilles Crettenand
2015-06-15 12:12:45 +02:00
parent c967a3ec1d
commit d797f62c47
2 changed files with 19 additions and 15 deletions

View File

@@ -13,7 +13,7 @@ use BSR\Lib\WebService;
class NetBiblio extends WebService
{
/** @var string $version version number */
public static $version = '1.0.1';
public static $version = '1.0.2';
private $login = '';
private $client = 'website';
@@ -616,9 +616,10 @@ class NetBiblio extends WebService
throw new WebException("CallArg", "Argument must be valid JSON.", -42);
}
// The iOS and Android applications still uses 'category' and 'producer'
// shortcuts and the iOS app still uses 'category'
$compatibility = array(
'category' => 'genre',
'genre' => 'genreCode',
'category' => 'genreCode',
'producer' => 'producerCode'
);
foreach($compatibility as $old => $new) {
@@ -645,26 +646,29 @@ class NetBiblio extends WebService
$bs->addQuery($queryArray['queryText'], $type);
}
if(isset($queryArray['genre']) && is_array($queryArray['genre'])) {
if(($key = array_search('J', $queryArray['genre'])) !== false) {
unset($queryArray['genre']['J']);
if(isset($queryArray['genreCode']) && is_array($queryArray['genreCode'])) {
// Jeunesse is a particular genre with it's own way of being searched
if(($key = array_search('J', $queryArray['genreCode'])) !== false) {
unset($queryArray['genreCode']['J']);
$queryArray['jeunesse'] = array('filtrer' => 'filtrer');
}
$selectedGenres = array_filter($queryArray['genre'], function ($c) {
return $c != '0';
});
$bs->addOrQuery($selectedGenres, 'genreCode');
}
if(isset($queryArray['jeunesse']) && $queryArray['jeunesse']['filtrer'] === 'filtrer') {
$bs->addQuery(1, 'jeunesse');
}
$availableFields = array('producerCode', 'author', 'reader', 'motsMatieres');
$availableFields = array('producerCode', 'genreCode', 'author', 'reader', 'motsMatieres');
foreach($availableFields as $q) {
if(isset($queryArray[$q]) && strlen($queryArray[$q]) > 0) {
$bs->addQuery($queryArray[$q], $q);
if(isset($queryArray[$q]) && (
(is_string($queryArray[$q]) && strlen($queryArray[$q]) > 0) ||
(is_array($queryArray[$q]) && count($queryArray[$q]) > 0)
)) {
if(is_array($queryArray[$q])) {
$bs->addOrQuery($queryArray[$q], $q);
} else {
$bs->addQuery($queryArray[$q], $q);
}
}
}