X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/f4921ca797953ddab6b35786864b2dd523190503..39b34a512dc030509c4c0161a8d9e336b8c82d24:/apps/apiclient/__init__.py diff --git a/apps/apiclient/__init__.py b/apps/apiclient/__init__.py index 7913ac3c..485bf606 100644 --- a/apps/apiclient/__init__.py +++ b/apps/apiclient/__init__.py @@ -1,10 +1,12 @@ +# -*- coding: utf-8 -*- +import json import urllib -from django.utils import simplejson import oauth2 from apiclient.models import OAuthConnection from apiclient.settings import WL_CONSUMER_KEY, WL_CONSUMER_SECRET, WL_API_URL +from django.conf import settings if WL_CONSUMER_KEY and WL_CONSUMER_SECRET: @@ -22,25 +24,29 @@ class NotAuthorizedError(BaseException): def api_call(user, path, data=None): - # what if not verified? conn = OAuthConnection.get(user) if not conn.access: raise NotAuthorizedError("No WL authorization for user %s." % user) token = oauth2.Token(conn.token, conn.token_secret) client = oauth2.Client(wl_consumer, token) if data is not None: + data = json.dumps(data) + data = urllib.urlencode({"data": data}) resp, content = client.request( - "%s%s.json" % (WL_API_URL, path), + "%s%s" % (WL_API_URL, path), method="POST", - body=urllib.urlencode(data)) + body=data) else: - resp, content = client.request( - "%s%s.json" % (WL_API_URL, path)) + resp, content = client.request("%s%s" % (WL_API_URL, path)) status = resp['status'] + if status == '200': - return simplejson.loads(content) + return json.loads(content) elif status.startswith('2'): return + elif settings.DEBUG: + raise ApiError(content) + elif status == '401': + raise ApiError('User not authorized for publishing.') else: - raise ApiError("WL API call error") - + raise ApiError("WL API call error [code %s]" % status)