k4ever/k4ever/api2/urls.py

64 lines
2.7 KiB
Python
Raw Normal View History

2011-09-28 10:51:32 +02:00
from django.conf.urls.defaults import *
from piston.resource import Resource
from piston.authentication import HttpBasicAuthentication
from api2.authentication import DjangoAuthentication, MultiAuthentication
2011-09-28 10:51:32 +02:00
from api2.handlers import *
from api2.decorators import fix_mime
import piston.utils
# piston does not understand mimetypes with charsets, HACK: fix content_type
piston.utils.Mimer.content_type = fix_mime(piston.utils.Mimer.content_type)
2011-09-28 10:51:32 +02:00
class CsrfExemptResource(Resource):
2011-10-06 18:09:35 +02:00
""" Except a :class:`Resource` from djangos CSRF-Framework.
This idea is taken from
http://www.robertshady.com/content/creating-very-basic-api-using-python-django-and-piston
"""
def __init__(self, handler, authentication = None):
2011-09-29 00:26:39 +02:00
super( CsrfExemptResource, self ).__init__( handler, authentication )
self.csrf_exempt = getattr( self.handler, 'csrf_exempt', True )
# build authenticatiooors
basicAuth = HttpBasicAuthentication(realm="Freitagsrundenkassensystemapi")
djangoAuth = DjangoAuthentication()
multiAuth = MultiAuthentication([basicAuth, djangoAuth])
ad = {'authentication': multiAuth}
2011-09-28 10:51:32 +02:00
2011-09-29 00:26:39 +02:00
buyableItemRes = CsrfExemptResource(handler=BuyableItemHandler, **ad)
buyableTypeRes = CsrfExemptResource(handler=BuyableTypeHandler, **ad)
2011-10-02 17:58:54 +02:00
historyRes = CsrfExemptResource(handler=HistoryHandler, **ad)
imgSizesRes = CsrfExemptResource(handler=ImgSizesHandler, **ad)
imgThumbRes = CsrfExemptResource(handler=ImgThumbHandler, **ad)
2011-09-28 10:51:32 +02:00
2011-09-29 00:26:39 +02:00
transactionTransactRes = CsrfExemptResource(handler=TransactionTransactHandler, **ad)
transactionTypeRes = CsrfExemptResource(handler=TransactionTypeHandler, **ad)
transactionVirtualRes = CsrfExemptResource(handler=TransactionVirtualHandler, **ad)
2011-09-29 23:38:25 +02:00
accountBalanceRes = CsrfExemptResource(handler=AccountBalanceHandler, **ad)
2011-09-29 14:14:29 +02:00
authBlobRes = CsrfExemptResource(handler=AuthBlobHandler, **ad)
2011-09-30 22:29:02 +02:00
authUserRes = CsrfExemptResource(handler=AuthUserHandler, **ad)
2011-09-29 14:14:29 +02:00
configRes = CsrfExemptResource(handler=ConfigHandler, **ad)
2011-09-29 00:26:39 +02:00
2011-09-28 10:51:32 +02:00
urlpatterns = patterns('',
2011-09-30 01:24:41 +02:00
url(r'buyable/item/?$', buyableItemRes),
url(r'buyable/item/(?P<itemId>\d+)/?$', buyableItemRes),
url(r'buyable/item/bulkbuy/?$', buyableItemRes, {'bulkBuy': True}),
2011-09-30 01:24:41 +02:00
url(r'buyable/types/?$', buyableTypeRes),
2011-10-02 17:58:54 +02:00
url(r'buyable/history/?$', historyRes),
url(r'buyable/img/sizes/?$', imgSizesRes),
url(r'buyable/img/thumb/(?P<itemId>\d+)/(?P<xSize>\d+)x(?P<ySize>\d+)/?$', imgThumbRes),
2011-09-28 10:51:32 +02:00
2011-09-30 01:24:41 +02:00
url(r'account/transactions/transact/?$', transactionTransactRes),
url(r'account/transactions/types/?$', transactionTypeRes),
url(r'account/transactions/virtual/?$', transactionVirtualRes),
2011-09-30 01:24:41 +02:00
url(r'account/balance/?$', accountBalanceRes),
2011-09-28 10:51:32 +02:00
2011-09-30 01:24:41 +02:00
url(r'auth/blob/?$', authBlobRes),
2011-09-30 22:29:02 +02:00
url(r'auth/user/?$', authUserRes),
2011-09-30 01:24:41 +02:00
url(r'config/?$', configRes),
2011-09-28 10:51:32 +02:00
)