Source code for graphspace_python.api.client

import base64
import requests
import six
import inspect
from future.standard_library import install_aliases
install_aliases()

from graphspace_python.api.config import API_HOST
from graphspace_python.api.endpoint.graphs import Graphs
from graphspace_python.api.endpoint.layouts import Layouts
from graphspace_python.api.endpoint.groups import Groups
from graphspace_python.api.errors import ErrorHandler

[docs]class GraphSpace(object): """GraphSpace client class. Connects the user with GraphSpace. Makes request to the GraphSpace REST APIs and returns the response. Args: username (str): Email of the user. password (str): Password of the user. Example: Initialising a GraphSpace client can be done in the following way: >>> from graphspace_python.api.client import GraphSpace >>> graphspace = GraphSpace('user1@example.com', 'user1') Attributes: auth_token (str): Base64 encoded username and password. username (str): Email of user. api_host (str): Host address of GraphSpace REST API. """ _endpoints = [ Graphs, Layouts, Groups ] def __init__(self, username, password): """Construct a new 'GraphSpace' client object. Args: username (str): Email of the user. password (str): Password of the user. """ # self.auth_token = 'Basic %s' % base64.b64encode('{0}:{1}'.format(username, password)) self.auth_token = requests.auth.HTTPBasicAuth(username, password) self.username = username self.api_host = API_HOST self._error_handler = ErrorHandler() self._define_request_methods() def _define_request_methods(self): """Creates an instance of each endpoint and adds the public methods of each instance to the GraphSpace Client. It promotes modularity. """ endpoint_instances = [end(self) for end in self._endpoints] for endpoint in endpoint_instances: instance_methods = inspect.getmembers(endpoint, inspect.ismethod) self._add_instance_methods(instance_methods) def _add_instance_methods(self, instance_methods): """Adds the instance methods to GraphSpace client. Args: instance_methods (List[tuple]): List of (name, value) tuples where value is the instance of the bound method. """ for method in instance_methods: if method[0][0] is not '_': self.__setattr__(method[0], method[1])
[docs] def set_api_host(self, host): """Manually set host address of GraphSpace REST APIs. Args: host (str): Host address of GraphSpace APIs. Example: >>> from graphspace_python.api.client import GraphSpace >>> graphspace = GraphSpace('user1@example.com', 'user1') >>> graphspace.set_api_host('localhost:8000') """ self.api_host = host
def _check_error(self, response): """Checks if the response has any HTTPError and raise exception else returns the response json data. Args: response (object): Response object from API call. Raises: GraphSpaceError: If response has an error status code; raises a particular error according to the 'error_code' received in response. Returns: dict: Response dict, if response has no error. """ try: response.raise_for_status() except requests.exceptions.HTTPError as error: self._error_handler.raise_error(error, response.json()) else: return response.json() def _make_request(self, method, path, url_params={}, data={}, headers=None): """Calls the GraphSpace REST API for the given endpoint, for the given method, with the given data, url params and headers. Args: method (str): Method of request. path (str): Path of request. url_params (dict, optional): URL parameters for request. Defaults to empty dict. data (dict, optional): Payload. Defaults to empty dict. headers (dict, optional): Headers for the request. Defaults to None. Returns: dict: Response dict. """ if headers is None: headers = { 'Accept': 'application/json', 'Content-Type': 'application/json' } request_path = 'https://{0}{1}?{2}'.format( self.api_host, six.moves.urllib.parse.quote(path.encode('utf-8')), six.moves.urllib.parse.urlencode(url_params, doseq=True) ) if method == "GET": return self._check_error( requests.get(request_path, headers=headers, auth=self.auth_token) ) elif method == "POST": if headers.get('Content-Type') == 'application/json': return self._check_error( requests.post(request_path, json=data, headers=headers, auth=self.auth_token) ) else: return self._check_error( requests.post(request_path, data=data, headers=headers, auth=self.auth_token) ) elif method == "PUT": if headers.get('Content-Type') == 'application/json': return self._check_error( requests.put(request_path, json=data, headers=headers, auth=self.auth_token) ) else: return self._check_error( requests.put(request_path, data=data, headers=headers, auth=self.auth_token) ) elif method == "DELETE": return self._check_error( requests.delete(request_path, headers=headers, auth=self.auth_token) )