Commit 4d2983cb by Calen Pennington

Merge pull request #587 from MITx/feature/victor/forum-anon-user-500

Add some rudimentary error checking to forum views
parents 46389550 f5754f6d
import requests
import json import json
import logging
import requests
import settings import settings
log = logging.getLogger('mitx.' + __name__)
def strip_none(dic): def strip_none(dic):
return dict([(k, v) for k, v in dic.iteritems() if v is not None]) return dict([(k, v) for k, v in dic.iteritems() if v is not None])
...@@ -18,15 +21,22 @@ def extract(dic, keys): ...@@ -18,15 +21,22 @@ def extract(dic, keys):
def merge_dict(dic1, dic2): def merge_dict(dic1, dic2):
return dict(dic1.items() + dic2.items()) return dict(dic1.items() + dic2.items())
def perform_request(method, url, data_or_params=None, *args, **kwargs): def perform_request(method, url, data_or_params=None, *args, **kwargs):
if data_or_params is None: if data_or_params is None:
data_or_params = {} data_or_params = {}
data_or_params['api_key'] = settings.API_KEY data_or_params['api_key'] = settings.API_KEY
if method in ['post', 'put', 'patch']: try:
response = requests.request(method, url, data=data_or_params) if method in ['post', 'put', 'patch']:
else: response = requests.request(method, url, data=data_or_params)
response = requests.request(method, url, params=data_or_params) else:
response = requests.request(method, url, params=data_or_params)
except Exception as err:
log.exception("Trying to call {method} on {url} with params {params}".format(
method=method, url=url, params=data_or_params))
# Reraise with a single exception type
raise CommentClientError(str(err))
if 200 < response.status_code < 500: if 200 < response.status_code < 500:
raise CommentClientError(response.text) raise CommentClientError(response.text)
elif response.status_code == 500: elif response.status_code == 500:
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment