Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
itminedu
kamaki
Commits
2bfb3db3
Commit
2bfb3db3
authored
Mar 15, 2013
by
Stavros Sachtouris
Browse files
Move compute_rest_api to compute.rest_api
kamaki.clients.compute_rest_api --> kamaki.clients.compute.rest_api
parent
630dea9b
Changes
1
Hide whitespace changes
Inline
Side-by-side
kamaki/clients/compute/rest_api.py
0 → 100644
View file @
2bfb3db3
# 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
)
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment