# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
from datetime import datetime, timedelta
+import json
from django.conf import settings
from django.contrib.sites.models import Site
from django.core.urlresolvers import reverse
-from piston.handler import BaseHandler
+from piston.handler import AnonymousBaseHandler, BaseHandler
from piston.utils import rc
from api.helpers import timestamp
from api.models import Deleted
+from catalogue.forms import BookImportForm
from catalogue.models import Book, Tag, BookMedia, Fragment
+from stats.utils import piwik_track
API_BASE = WL_BASE = MEDIA_BASE = 'http://' + Site.objects.get_current().domain
'xml', 'html', 'pdf', 'epub', 'txt',
'media', 'url'] + category_singular.keys()
+ @piwik_track
def read(self, request, slug):
""" Returns details of a book, identified by a slug. """
return rc.NOT_FOUND
-class BooksHandler(BaseHandler):
+class AnonymousBooksHandler(AnonymousBaseHandler):
""" Main handler for Book objects.
Responsible for lists of Book objects
return WL_BASE + book.get_absolute_url()
+ @piwik_track
def read(self, request, tags, top_level=False):
""" Lists all books with given tags.
else:
return rc.NOT_FOUND
+ def create(self, request, tags, top_level=False):
+ return 'aaa'
+
@classmethod
def media(self, book):
""" Returns all media for a book. """
return book.media.all()
+class BooksHandler(BaseHandler):
+ model = Book
+ fields = ('slug', 'title')
+ anonymous = AnonymousBooksHandler
+
+ def create(self, request, tags, top_level=False):
+ if not request.user.has_perm('catalogue.add_book'):
+ return rc.FORBIDDEN
+
+ data = json.loads(request.POST.get('data'))
+ form = BookImportForm(data)
+ if form.is_valid():
+ form.save()
+ return rc.CREATED
+ else:
+ return rc.NOT_FOUND
+
# add categorized tags fields for Book
def _tags_getter(category):
@classmethod
fields = ['name', 'sort_key', 'description']
+ @piwik_track
def read(self, request, category, slug):
""" Returns details of a tag, identified by category and slug. """
model = Tag
fields = ['name', 'href']
+ @piwik_track
def read(self, request, category):
""" Lists all tags in the category (eg. all themes). """
class FragmentDetailHandler(BaseHandler):
fields = ['book', 'anchor', 'text', 'url', 'themes']
+ @piwik_track
def read(self, request, slug, anchor):
""" Returns details of a fragment, identified by book slug and anchor. """
categories = set(['author', 'epoch', 'kind', 'genre', 'book', 'theme'])
+ @piwik_track
def read(self, request, tags):
""" Lists all fragments with given book, tags, themes.
class BookChangesHandler(CatalogueHandler):
allowed_methods = ('GET',)
+ @piwik_track
def read(self, request, since):
return self.book_changes(request, since)
class TagChangesHandler(CatalogueHandler):
allowed_methods = ('GET',)
+ @piwik_track
def read(self, request, since):
return self.tag_changes(request, since)
class ChangesHandler(CatalogueHandler):
allowed_methods = ('GET',)
+ @piwik_track
def read(self, request, since):
return self.changes(request, since)