Mercurial > hg > orthanc
diff Resources/Samples/Python/RestToolbox.py @ 340:61f6a3d66b85
changes loop sample
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Thu, 17 Jan 2013 15:54:02 +0100 |
parents | |
children | b51c67f28b33 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Resources/Samples/Python/RestToolbox.py Thu Jan 17 15:54:02 2013 +0100 @@ -0,0 +1,67 @@ +import hashlib +import httplib2 +import json +import os.path +import Image +import zipfile +from urllib import urlencode + +def DoGet(uri, data = {}): + d = '' + if len(data.keys()) > 0: + d = '?' + urlencode(data) + + h = httplib2.Http() + resp, content = h.request(uri + d, 'GET') + if not (resp.status in [ 200 ]): + raise Exception(resp.status) + else: + try: + return json.loads(content) + except: + return content + + +def _DoPutOrPost(uri, method, data, contentType): + h = httplib2.Http() + + if isinstance(data, str): + body = data + if len(contentType) != 0: + headers = { 'content-type' : contentType } + else: + body = json.dumps(data) + headers = { 'content-type' : 'application/json' } + + resp, content = h.request( + uri, method, + body = body, + headers = headers) + + if not (resp.status in [ 200, 302 ]): + raise Exception(resp.status) + else: + try: + return json.loads(content) + except: + return content + + +def DoDelete(uri): + h = httplib2.Http() + resp, content = h.request(uri, 'DELETE') + if not (resp.status in [ 200 ]): + raise Exception(resp.status) + else: + try: + return json.loads(content) + except: + return content + + +def DoPut(uri, data = {}, contentType = ''): + return _DoPutOrPost(uri, 'PUT', data, contentType) + + +def DoPost(uri, data = {}, contentType = ''): + return _DoPutOrPost(uri, 'POST', data, contentType)