Commit 2bfb3db3 authored by Stavros Sachtouris's avatar Stavros Sachtouris
Browse files

Move compute_rest_api to compute.rest_api

kamaki.clients.compute_rest_api --> kamaki.clients.compute.rest_api
parent 630dea9b
# 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)
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