X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/ae60b2a3949e96357477cc04f90fd0873cee8a92..187d054620e6e005bed835fbdcb34a0098ffe98e:/src/api/urls.py diff --git a/src/api/urls.py b/src/api/urls.py index 910d362f5..8a9965d75 100644 --- a/src/api/urls.py +++ b/src/api/urls.py @@ -17,6 +17,7 @@ book_list_resource = CsrfExemptResource(handler=handlers.BooksHandler, authentic ebook_list_resource = Resource(handler=handlers.EBooksHandler) # book_list_resource = Resource(handler=handlers.BooksHandler) book_resource = Resource(handler=handlers.BookDetailHandler) +filter_book_resource = Resource(handler=handlers.FilterBooksHandler) collection_resource = Resource(handler=handlers.CollectionDetailHandler) collection_list_resource = Resource(handler=handlers.CollectionsHandler) @@ -30,6 +31,10 @@ fragment_list_resource = Resource(handler=handlers.FragmentsHandler) picture_resource = CsrfExemptResource(handler=handlers.PictureHandler, authentication=auth) +tags_re = r'^(?P(?:(?:[a-z0-9-]+/){2}){0,6})' +paginate_re = r'(?:before/(?P[a-z0-9-]+)/)?(?:after/(?P[a-z0-9-]+)/)?(?:count/(?P[0-9]+)/)?$' + + @ssi_included def incl(request, model, pk, emitter_format): resource = { @@ -58,8 +63,8 @@ urlpatterns = patterns( incl, name='api_include'), # info boxes (used by mobile app) - url(r'book/(?P\d*?)/info\.html$', 'catalogue.views.book_info'), - url(r'tag/(?P\d*?)/info\.html$', 'catalogue.views.tag_info'), + url(r'book/(?P\d*?)/info\.html$', 'catalogue.views.book_info'), + url(r'tag/(?P\d*?)/info\.html$', 'catalogue.views.tag_info'), # books by collections url(r'^collections/$', collection_list_resource, name="api_collections"), @@ -73,19 +78,25 @@ urlpatterns = patterns( fragment_resource, name="api_fragment"), # books by tags - url(r'^(?P(?:(?:[a-z0-9-]+/){2}){0,6})books/$', + url(tags_re + r'books/' + paginate_re, book_list_resource, name='api_book_list'), - url(r'^(?P(?:(?:[a-z0-9-]+/){2}){0,6})ebooks/$', + url(tags_re + r'ebooks/' + paginate_re, ebook_list_resource, name='api_ebook_list'), - url(r'^(?P(?:(?:[a-z0-9-]+/){2}){0,6})parent_books/$', + url(tags_re + r'parent_books/' + paginate_re, book_list_resource, {"top_level": True}, name='api_parent_book_list'), - url(r'^(?P(?:(?:[a-z0-9-]+/){2}){0,6})parent_ebooks/$', + url(tags_re + r'parent_ebooks/' + paginate_re, ebook_list_resource, {"top_level": True}, name='api_parent_ebook_list'), - url(r'^(?P(?:(?:[a-z0-9-]+/){2}){0,6})audiobooks/$', + url(tags_re + r'audiobooks/' + paginate_re, book_list_resource, {"audiobooks": True}, name='api_audiobook_list'), - url(r'^(?P(?:(?:[a-z0-9-]+/){2}){0,6})daisy/$', + url(tags_re + r'daisy/' + paginate_re, book_list_resource, {"daisy": True}, name='api_daisy_list'), + url(r'^recommended/' + paginate_re, book_list_resource, {"recommended": True}, name='api_recommended_list'), + url(r'^newest/', book_list_resource, {"newest": True, "count": 20}, name='api_newest_list'), + url(r'^filter-books/(?:title-part/(?P[^/]+)/)?(?:author-part/(?P[^/]+)/)?' + r'(?:lektura/(?P(?:true|false))/)?(?:audiobook/(?P(?:true|false))/)?' + + paginate_re, filter_book_resource, name='api_filter_books'), + url(r'^pictures/$', picture_resource), # fragments by book, tags, themes