fnp
/
wolnelektury.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
7628e12
)
api: filter books by preview
author
Jan Szejko
<janek37@gmail.com>
Tue, 5 Jun 2018 08:29:06 +0000
(10:29 +0200)
committer
Jan Szejko
<janek37@gmail.com>
Tue, 5 Jun 2018 08:29:06 +0000
(10:29 +0200)
src/api/handlers.py
patch
|
blob
|
history
diff --git
a/src/api/handlers.py
b/src/api/handlers.py
index
b37a6d9
..
7772820
100644
(file)
--- a/
src/api/handlers.py
+++ b/
src/api/handlers.py
@@
-323,20
+323,21
@@
class FilterBooksHandler(AnonymousBooksHandler):
fields = book_tag_categories + [
'href', 'title', 'url', 'cover', 'cover_thumb', 'simple_thumb', 'slug', 'key']
fields = book_tag_categories + [
'href', 'title', 'url', 'cover', 'cover_thumb', 'simple_thumb', 'slug', 'key']
+ def parse_bool(self, s):
+ if s in ('true', 'false'):
+ return s == 'true'
+ else:
+ return None
+
def read(self, request):
key_sep = '$'
search_string = request.GET.get('search')
def read(self, request):
key_sep = '$'
search_string = request.GET.get('search')
- is_lektura = request.GET.get('lektura')
- is_audiobook = request.GET.get('audiobook')
+ is_lektura = self.parse_bool(request.GET.get('lektura'))
+ is_audiobook = self.parse_bool(request.GET.get('audiobook'))
+ preview = self.parse_bool(request.GET.get('preview'))
after = request.GET.get('after')
count = int(request.GET.get('count', 50))
after = request.GET.get('after')
count = int(request.GET.get('count', 50))
- if is_lektura in ('true', 'false'):
- is_lektura = is_lektura == 'true'
- else:
- is_lektura = None
- if is_audiobook in ('true', 'false'):
- is_audiobook = is_audiobook == 'true'
books = Book.objects.distinct().order_by('slug')
if is_lektura is not None:
books = books.filter(has_audience=is_lektura)
books = Book.objects.distinct().order_by('slug')
if is_lektura is not None:
books = books.filter(has_audience=is_lektura)
@@
-345,6
+346,8
@@
class FilterBooksHandler(AnonymousBooksHandler):
books = books.filter(media__type='mp3')
else:
books = books.exclude(media__type='mp3')
books = books.filter(media__type='mp3')
else:
books = books.exclude(media__type='mp3')
+ if preview is not None:
+ books = books.filter(preview=preview)
for key in request.GET:
if key in category_singular:
category = category_singular[key]
for key in request.GET:
if key in category_singular:
category = category_singular[key]