X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=rest%2Fcreate.py;h=afb62b7470cabfcc9dced2c45cfd5ee58b91d885;hb=refs%2Fheads%2Ffibre;hp=eaad539d7e36c06c8c62da4c96af2841df7d04b9;hpb=4a6fd9e9944195beea99aaf437d41b9fbdcd6419;p=unfold.git diff --git a/rest/create.py b/rest/create.py index eaad539d..afb62b74 100644 --- a/rest/create.py +++ b/rest/create.py @@ -1,5 +1,3 @@ -from manifold.core.query import Query - from django.views.generic.base import TemplateView from django.shortcuts import render_to_response @@ -9,60 +7,43 @@ from django.http import HttpResponse from manifold.core.query import Query, AnalyzedQuery from manifoldapi.manifoldapi import execute_query -from string import join -import decimal -import datetime -import json +from rest import ObjectRequest, error, success -# handles serialization of datetime in json -DateEncoder = lambda obj: obj.strftime("%B %d, %Y %H:%M:%S") if isinstance(obj, datetime.datetime) else None +from string import join -# support converting decimal in json -json.encoder.FLOAT_REPR = lambda o: format(o, '.2f') +import json -# handles decimal numbers serialization in json -class DecimalEncoder(json.JSONEncoder): - def _iterencode(self, o, markers=None): - if isinstance(o, decimal.Decimal): - return (str(o) for o in [o]) - return super(DecimalEncoder, self)._iterencode(o, markers) def dispatch(request, object_type, object_name): - object_filters = {} - object_params = {} - result = {} + o = ObjectRequest(request, object_type, object_name) if request.method == 'POST': - req_items = request.POST.items() + req_items = request.POST elif request.method == 'GET': - return HttpResponse(json.dumps({'error' : 'only post request is supported'}), content_type="application/json") - - query = Query.create(object_type) + #return error('only post request is supported') + req_items = request.GET + print req_items + for el in req_items.items(): + # Filters not used for create + if el[0].startswith('filters'): + o.filters[el[0][8:-1]] = el[1] + elif el[0].startswith('params'): + #o.params[el[0][7:-1]] = el[1] + o.params.append({el[0][7:-1]:el[1]}) + elif el[0].startswith('fields'): + o.fields=req_items.getlist('fields[]') + elif el[0].startswith('options'): + o.options = req_items.getlist('options[]') + + try: + response = o.create() + + if response : + return success('record created') + else : + return error('an error has occurred') + + except Exception, e: + return error(str(e)) -# No filters for create -# if object_filters : -# for k, f in object_filters.iteritems() : -# query.filter_by(k, '==', f) -# -# # DEBUG -# print object_filters - - if object_params : - query.set(object_params.iteritems()) - else : - return HttpResponse(json.dumps({'error' : 'params are required for create'}), content_type="application/json") - - # DEBUG - print object_params - - result = execute_query(request, query) - - # DEBUG - print result - - if result : - return HttpResponse(json.dumps({'error' : 'an error has occurred'}), content_type="application/json") - else : - return HttpResponse(json.dumps({'success' : 'record updated'}), content_type="application/json") -