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
synnefo
Commits
ff39f3b6
Commit
ff39f3b6
authored
Mar 29, 2011
by
Vassilios Karakoidas
Browse files
All unit tests are executed in the refactored code
* All functionality is achieved through the logic layer
parent
acd52b30
Changes
2
Hide whitespace changes
Inline
Side-by-side
api/handlers.py
View file @
ff39f3b6
...
...
@@ -16,6 +16,8 @@ import string
import
logging
from
datetime
import
datetime
,
timedelta
from
logic
import
backend
,
utils
log
=
logging
.
getLogger
(
'synnefo.api.handlers'
)
try
:
...
...
@@ -101,7 +103,7 @@ class ServerHandler(BaseHandler):
try
:
server
=
VirtualMachine
.
objects
.
get
(
id
=
id
)
server
=
{
'status'
:
server
.
rsapi_state
,
server
=
{
'status'
:
utils
.
get_
rsapi_state
(
server
)
,
'flavorRef'
:
server
.
flavor
.
id
,
'name'
:
server
.
name
,
'id'
:
server
.
id
,
...
...
@@ -109,7 +111,7 @@ class ServerHandler(BaseHandler):
'created'
:
server
.
created
,
'updated'
:
server
.
updated
,
'hostId'
:
server
.
hostid
,
'progress'
:
server
.
rsapi_state
==
'ACTIVE'
and
100
or
0
,
'progress'
:
utils
.
get_
rsapi_state
(
server
)
==
'ACTIVE'
and
100
or
0
,
#'metadata': {'Server_Label': server.description },
'metadata'
:[{
'meta'
:
{
'key'
:
{
metadata
.
meta_key
:
metadata
.
meta_value
}}}
for
metadata
in
server
.
virtualmachinemetadata_set
.
all
()],
'addresses'
:
{
'public'
:
{
'ip'
:
{
'addr'
:
server
.
ipfour
},
'ip6'
:
{
'addr'
:
server
.
ipsix
}},
'private'
:
''
},
...
...
@@ -146,7 +148,7 @@ class ServerHandler(BaseHandler):
if
not
detail
:
return
{
"servers"
:
[
{
"id"
:
s
.
id
,
"name"
:
s
.
name
}
for
s
in
virtual_servers
]
}
else
:
virtual_servers_list
=
[{
'status'
:
server
.
rsapi_state
,
virtual_servers_list
=
[{
'status'
:
utils
.
get_
rsapi_state
(
server
)
,
'flavorRef'
:
server
.
flavor
.
id
,
'name'
:
server
.
name
,
'id'
:
server
.
id
,
...
...
@@ -154,7 +156,7 @@ class ServerHandler(BaseHandler):
'updated'
:
server
.
updated
,
'imageRef'
:
server
.
sourceimage
.
id
,
'hostId'
:
server
.
hostid
,
'progress'
:
server
.
rsapi_state
==
'ACTIVE'
and
100
or
0
,
'progress'
:
utils
.
get_
rsapi_state
(
server
)
==
'ACTIVE'
and
100
or
0
,
#'metadata': {'Server_Label': server.description },
'metadata'
:[{
'meta'
:
{
'key'
:
{
metadata
.
meta_key
:
metadata
.
meta_value
}}}
for
metadata
in
server
.
virtualmachinemetadata_set
.
all
()],
'addresses'
:
{
'public'
:
{
'ip'
:
{
'addr'
:
server
.
ipfour
},
'ip6'
:
{
'addr'
:
server
.
ipsix
}},
'private'
:
''
},
...
...
@@ -235,6 +237,7 @@ class ServerHandler(BaseHandler):
log
.
info
(
'created vm with %s cpus, %s ram and %s storage'
%
(
flavor
.
cpu
,
flavor
.
ram
,
flavor
.
disk
))
except
(
GanetiApiError
,
CertificateError
)
as
e
:
log
.
exception
(
'CreateInstance failed: %s'
%
e
)
# FIX: if the instance creation have failed, why it is saved in the db?
vm
.
deleted
=
True
vm
.
save
()
raise
fault
.
serviceUnavailable
...
...
@@ -301,7 +304,7 @@ class ServerHandler(BaseHandler):
try
:
vm
=
VirtualMachine
.
objects
.
get
(
id
=
id
)
#TODO: set the status to DESTROYED
vm
.
start_action
(
'DESTROY'
)
backend
.
start_action
(
vm
,
'DESTROY'
)
rapi
.
DeleteInstance
(
vm
.
backend_id
)
return
accepted
except
VirtualMachine
.
DoesNotExist
:
...
...
@@ -380,7 +383,7 @@ class ServerActionHandler(BaseHandler):
raise
fault
.
notImplemented
#test if we can get the vm
vm
=
VirtualMachine
.
objects
.
get
(
id
=
id
)
vm
.
start_action
(
action
)
backend
.
start_action
(
vm
,
action
)
if
reboot_request
:
rapi
.
RebootInstance
(
vm
.
backend_id
)
...
...
api/servers.py
View file @
ff39f3b6
...
...
@@ -16,6 +16,7 @@ from django.utils import simplejson as json
from
logging
import
getLogger
from
logic
import
utils
log
=
getLogger
(
'synnefo.api.servers'
)
rapi
=
GanetiRapiClient
(
*
settings
.
GANETI_CLUSTER_INFO
)
...
...
@@ -58,8 +59,8 @@ def address_to_dict(ipfour, ipsix):
def
server_to_dict
(
server
,
detail
=
False
):
d
=
dict
(
id
=
server
.
id
,
name
=
server
.
name
)
if
detail
:
d
[
'status'
]
=
server
.
rsapi_state
d
[
'progress'
]
=
100
if
server
.
rsapi_state
==
'ACTIVE'
else
0
d
[
'status'
]
=
utils
.
get_
rsapi_state
(
server
)
d
[
'progress'
]
=
100
if
utils
.
get_
rsapi_state
(
server
)
==
'ACTIVE'
else
0
d
[
'hostId'
]
=
server
.
hostid
d
[
'updated'
]
=
server
.
updated
.
isoformat
()
d
[
'created'
]
=
server
.
created
.
isoformat
()
...
...
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