Move compute_rest_api to compute.rest_api
authorStavros Sachtouris <saxtouri@admin.grnet.gr>
Fri, 15 Mar 2013 11:30:27 +0000 (13:30 +0200)
committerStavros Sachtouris <saxtouri@admin.grnet.gr>
Fri, 15 Mar 2013 11:30:27 +0000 (13:30 +0200)
kamaki.clients.compute_rest_api --> kamaki.clients.compute.rest_api

kamaki/clients/compute/rest_api.py [new file with mode: 0644]

diff --git a/kamaki/clients/compute/rest_api.py b/kamaki/clients/compute/rest_api.py
new file mode 100644 (file)
index 0000000..e68ffff
--- /dev/null
@@ -0,0 +1,239 @@
+# Copyright 2012 GRNET S.A. All rights reserved.
+#
+# Redistribution and use in source and binary forms, with or
+# without modification, are permitted provided that the following
+# conditions are met:
+#
+#   1. Redistributions of source code must retain the above
+#      copyright notice, this list of conditions and the following
+#      disclaimer.
+#
+#   2. Redistributions in binary form must reproduce the above
+#      copyright notice, this list of conditions and the following
+#      disclaimer in the documentation and/or other materials
+#      provided with the distribution.
+#
+# THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
+# OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
+# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
+# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+# The views and conclusions contained in the software and
+# documentation are those of the authors and should not be
+# interpreted as representing official policies, either expressed
+# or implied, of GRNET S.A.
+
+from kamaki.clients import Client
+from kamaki.clients.utils import path4url
+import json
+
+
+class ComputeClientApi(Client):
+
+    def servers_get(self, server_id='', command='', success=200, **kwargs):
+        """GET base_url/servers[/server_id][/command] request
+
+        :param server_id: integer (as int or str)
+
+        :param command: 'ips', 'stats', or ''
+
+        :param success: success code or list or tupple of accepted success
+            codes. if server response code is not in this list, a ClientError
+            raises
+
+        :returns: request response
+        """
+        path = path4url('servers', server_id, command)
+        return self.get(path, success=success, **kwargs)
+
+    def servers_delete(self, server_id='', command='', success=204, **kwargs):
+        """DEL ETE base_url/servers[/server_id][/command] request
+
+        :param server_id: integer (as int or str)
+
+        :param command: 'ips', 'stats', or ''
+
+        :param success: success code or list or tupple of accepted success
+            codes. if server response code is not in this list, a ClientError
+            raises
+
+        :returns: request response
+        """
+        path = path4url('servers', server_id, command)
+        return self.delete(path, success=success, **kwargs)
+
+    def servers_post(
+            self,
+            server_id='',
+            command='',
+            json_data=None,
+            success=202,
+            **kwargs):
+        """POST base_url/servers[/server_id]/[command] request
+
+        :param server_id: integer (as int or str)
+
+        :param command: 'ips', 'stats', or ''
+
+        :param json_data: a json-formated dict that will be send as data
+
+        :param success: success code or list or tupple of accepted success
+            codes. if server response code is not in this list, a ClientError
+            raises
+
+        :returns: request response
+        """
+        data = json_data
+        if json_data:
+            data = json.dumps(json_data)
+            self.set_header('Content-Type', 'application/json')
+            self.set_header('Content-Length', len(data))
+
+        path = path4url('servers', server_id, command)
+        return self.post(path, data=data, success=success, **kwargs)
+
+    def servers_put(
+            self,
+            server_id='',
+            command='',
+            json_data=None,
+            success=204,
+            **kwargs):
+        """PUT base_url/servers[/server_id]/[command] request
+
+        :param server_id: integer (as int or str)
+
+        :param command: 'ips', 'stats', or ''
+
+        :param json_data: a json-formated dict that will be send as data
+
+        :param success: success code or list or tupple of accepted success
+            codes. if server response code is not in this list, a ClientError
+            raises
+
+        :returns: request response
+        """
+        data = json_data
+        if json_data is not None:
+            data = json.dumps(json_data)
+            self.set_header('Content-Type', 'application/json')
+            self.set_header('Content-Length', len(data))
+
+        path = path4url('servers', server_id, command)
+        return self.put(path, data=data, success=success, **kwargs)
+
+    def flavors_get(self, flavor_id='', command='', success=200, **kwargs):
+        """GET base_url[/flavor_id][/command]
+
+        :param flavor_id: integer (str or int)
+
+        :param command: flavor service command
+
+        :param success: success code or list or tupple of accepted success
+            codes. if server response code is not in this list, a ClientError
+            raises
+
+        :returns: request response
+        """
+        path = path4url('flavors', flavor_id, command)
+        return self.get(path, success=success, **kwargs)
+
+    def images_get(self, image_id='', command='', success=200, **kwargs):
+        """GET base_url[/image_id][/command]
+
+        :param image_id: string
+
+        :param command: image server command
+
+        :param success: success code or list or tupple of accepted success
+            codes. if server response code is not in this list, a ClientError
+            raises
+
+        :returns: request response
+        """
+        path = path4url('images', image_id, command)
+        return self.get(path, success=success, **kwargs)
+
+    def images_delete(self, image_id='', command='', success=204, **kwargs):
+        """DELETE base_url[/image_id][/command]
+
+        :param image_id: string
+
+        :param command: image server command
+
+        :param success: success code or list or tuple of accepted success
+            codes. if server response code is not in this list, a ClientError
+            raises
+
+        :returns: request response
+        """
+        path = path4url('images', image_id, command)
+        return self.delete(path, success=success, **kwargs)
+
+    def images_post(
+            self,
+            image_id='',
+            command='',
+            json_data=None,
+            success=201,
+            **kwargs):
+        """POST base_url/images[/image_id]/[command] request
+
+        :param image_id: string
+
+        :param command: image server command
+
+        :param json_data: (dict) will be send as data
+
+        :param success: success code or list or tuple of accepted success
+            codes. if server response code is not in this list, a ClientError
+            raises
+
+        :returns: request response
+        """
+        data = json_data
+        if json_data is not None:
+            data = json.dumps(json_data)
+            self.set_header('Content-Type', 'application/json')
+            self.set_header('Content-Length', len(data))
+
+        path = path4url('images', image_id, command)
+        return self.post(path, data=data, success=success, **kwargs)
+
+    def images_put(
+            self,
+            image_id='',
+            command='',
+            json_data=None,
+            success=201,
+            **kwargs):
+        """PUT base_url/images[/image_id]/[command] request
+
+        :param image_id: string
+
+        :param command: image server command
+
+        :param json_data: (dict) will be send as data
+
+        :param success: success code or list or tuple of accepted success
+            codes. if server response code is not in this list, a ClientError
+            raises
+
+        :returns: request response
+        """
+        data = json_data
+        if json_data is not None:
+            data = json.dumps(json_data)
+            self.set_header('Content-Type', 'application/json')
+            self.set_header('Content-Length', len(data))
+
+        path = path4url('images', image_id, command)
+        return self.put(path, data=data, success=success, **kwargs)