Files
python-saharaclient/saharaclient/api/httpclient.py
Andrew Lazarev 3a83103324 Added SSL-related parameters to the client
Change-Id: Id2c80a6031ca269b1fd864caf46bd75a85a6637a
Blueprint: sahara-support-https
Closes-Bug: #1359408
2015-01-22 14:33:50 -08:00

55 lines
1.9 KiB
Python

# Copyright (c) 2013 Mirantis Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
# implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import requests
class HTTPClient(object):
def __init__(self, base_url, token, insecure=False, cacert=None):
self.base_url = base_url
self.token = token
if insecure:
self.verify_cert = False
else:
if cacert:
self.verify_cert = cacert
else:
self.verify_cert = True
def get(self, url):
return requests.get(self.base_url + url,
headers={'x-auth-token': self.token},
verify=self.verify_cert)
def post(self, url, body, json=True):
headers = {'x-auth-token': self.token}
if json:
headers['content-type'] = 'application/json'
return requests.post(self.base_url + url, body, headers=headers,
verify=self.verify_cert)
def put(self, url, body, json=True):
headers = {'x-auth-token': self.token}
if json:
headers['content-type'] = 'application/json'
return requests.put(self.base_url + url, body, headers=headers,
verify=self.verify_cert)
def delete(self, url):
return requests.delete(self.base_url + url,
headers={'x-auth-token': self.token},
verify=self.verify_cert)