X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/b2d72160e2a68991c66ea6017b871d7f42c0b29d..04b05946ab640eaf9135a73772b704dd41c323e7:/apps/api/urls.py?ds=inline diff --git a/apps/api/urls.py b/apps/api/urls.py index ada879c4..52b0ccc5 100644 --- a/apps/api/urls.py +++ b/apps/api/urls.py @@ -2,45 +2,87 @@ __author__="lreqc" __date__ ="$2009-09-17 16:16:54$" from django.conf.urls.defaults import * -from piston.resource import Resource +from api.resources import * -from api.handlers import * -from api.utils import TextEmitter, DjangoAuth +FORMAT = r"\.(?P<emitter_format>xml|json|yaml)" +DOC = r'(?P<docid>[^/]+)' +# REVISION = r'(?P<revision>latest|[0-9a-f]{40})' -authdata = {'authentication': DjangoAuth()} - -FORMAT_EXT = r"\.(?P<emitter_format>xml|json|yaml|django)$" - -library_resource = Resource(LibraryHandler, **authdata) -document_resource = Resource(DocumentHandler, **authdata) -document_text_resource = Resource(DocumentTextHandler, **authdata) +def urlpath(*args, **kwargs): + format = kwargs.get('format', True) + return r'^' + (r'/'.join(args)) + (FORMAT if format else '') + '$' urlpatterns = patterns('', # url(r'^hello$', hello_resource, {'emitter_format': 'json'}), # url(r'^hello\.(?P<emitter_format>.+)$', hello_resource), + # HTML Renderer service + url(r'^render$', 'api.views.render'), + + # Toolbar + url(r'^toolbar/buttons$', toolbar_buttons, {'emitter_format': 'json'}, + name="toolbar_buttons" + ), + + url(r'^toolbar/scriptlets$', scriptlets, {'emitter_format': 'json'}, + name="toolbar_scriptlets" + ), + + # Pull requests + url(r"^pull-requests$", pullrequest_collection, + {'emitter_format': 'json'}, name="pullrequest_list" ), + + url(r"^pull-requests/(?P<prq_id>\d+)$", pullrequest_rsrc, + {'emitter_format': 'json'}, name="pullrequest_view" ), + # Documents - url(r'^documents$', library_resource, {'emitter_format': 'json'}, - name="document_list_view"), + url(r'^documents$', library_resource, + {'emitter_format': 'json'}, name="document_list_view"), - url(r'^documents/(?P<docid>[^/]+)'+FORMAT_EXT, - document_resource, name="document_view_withformat"), + url(urlpath(r'documents'), library_resource, + name="document_list_view_withformat"), + + #url(urlpath(r'documents', DOC), + # document_resource, name="document_view_withformat"), - url(r'^documents/(?P<docid>[^/]+)$', + url(urlpath(r'documents', DOC, format=False), document_resource, {'emitter_format': 'json'}, name="document_view"), - - url(r'^documents/(?P<docid>[^/]+)/text$', - document_text_resource, {'emitter_format': 'rawxml'}, + + url(urlpath(r'documents', DOC, 'gallery', format=False), + document_gallery, {'emitter_format': 'json'}, + name="docgallery_view"), + + # XML + url(urlpath(r'documents', DOC, 'text', format=False), + document_text_resource, {'emitter_format': 'raw'}, name="doctext_view"), - url(r'^documents/(?P<docid>[^/]+)/dc$', - document_resource, {'emitter_format': 'json'}, - name="docdc_view"), + # HTML + url(urlpath(r'documents', DOC, 'html', format=False), + document_html_resource, {'emitter_format': 'raw'}, + name="dochtml_view"), - url(r'^documents/(?P<docid>[^/]+)/parts$', - document_resource, {'emitter_format': 'json'}, - name="docparts_view"), + # DC + #url(urlpath(r'documents', DOC, 'dc'), + # document_dc_resource, + # name="docdc_view_withformat"), + +# url(urlpath(r'documents', DOC, 'dc', format=False), +# document_dc_resource, {'emitter_format': 'json'}, +# name="docdc_view"), + + # MERGE + url(urlpath(r'documents', DOC, 'revision', format=False), + document_merge, {'emitter_format': 'json'}, name="docmerge_view"), + + url(r'documents/(?P<docid>[^/]+)/diff$', + diff_resource, {'emitter_format': 'raw'}, name="diff_resource"), + + +# url(r'^documents/(?P<docid>[^/]+)/parts$', +# document_resource, {'emitter_format': 'json'}, +# name="docparts_view"), # url(r'^posts/(?P<post_slug>[^/]+)/$', blogpost_resource), # url(r'^other/(?P<username>[^/]+)/(?P<data>.+)/$', arbitrary_resource),