diff options
| author | Jenkins <jenkins@review.openstack.org> | 2013-06-05 02:12:47 +0000 |
|---|---|---|
| committer | Gerrit Code Review <review@openstack.org> | 2013-06-05 02:12:47 +0000 |
| commit | 30db9308f1b06fb184f272ff2e8625fdb3474bd9 (patch) | |
| tree | d6985889e1a1330a928a54b2a1fd08d45c464314 /nova/api | |
| parent | a1c151f0ff3b75cc3530b0959d09a28ea4ec0b28 (diff) | |
| parent | f5d790df0a16034d767749161c8abd2898e707b4 (diff) | |
| download | nova-30db9308f1b06fb184f272ff2e8625fdb3474bd9.tar.gz nova-30db9308f1b06fb184f272ff2e8625fdb3474bd9.tar.xz nova-30db9308f1b06fb184f272ff2e8625fdb3474bd9.zip | |
Merge "Launch_at and terminated_at on server(s) response"
Diffstat (limited to 'nova/api')
| -rw-r--r-- | nova/api/openstack/compute/contrib/server_usage.py | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/nova/api/openstack/compute/contrib/server_usage.py b/nova/api/openstack/compute/contrib/server_usage.py new file mode 100644 index 000000000..fb9dc9f6a --- /dev/null +++ b/nova/api/openstack/compute/contrib/server_usage.py @@ -0,0 +1,97 @@ +# Copyright 2013 Openstack Foundation +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may +# not use this file except in compliance with the License. You may obtain +# a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. + +from nova.api.openstack import extensions +from nova.api.openstack import wsgi +from nova.api.openstack import xmlutil +from nova import compute +from nova.openstack.common import log as logging + +LOG = logging.getLogger(__name__) +authorize = extensions.soft_extension_authorizer('compute', 'server_usage') + + +class ServerUsageController(wsgi.Controller): + def __init__(self, *args, **kwargs): + super(ServerUsageController, self).__init__(*args, **kwargs) + self.compute_api = compute.API() + + def _extend_server(self, server, instance): + for k in ['launched_at', 'terminated_at']: + key = "%s:%s" % (Server_usage.alias, k) + server[key] = instance[k] + + @wsgi.extends + def show(self, req, resp_obj, id): + context = req.environ['nova.context'] + if authorize(context): + # Attach our slave template to the response object + resp_obj.attach(xml=ServerUsageTemplate()) + server = resp_obj.obj['server'] + db_instance = req.get_db_instance(server['id']) + # server['id'] is guaranteed to be in the cache due to + # the core API adding it in its 'show' method. + self._extend_server(server, db_instance) + + @wsgi.extends + def detail(self, req, resp_obj): + context = req.environ['nova.context'] + if authorize(context): + # Attach our slave template to the response object + resp_obj.attach(xml=ServerUsagesTemplate()) + servers = list(resp_obj.obj['servers']) + for server in servers: + db_instance = req.get_db_instance(server['id']) + # server['id'] is guaranteed to be in the cache due to + # the core API adding it in its 'detail' method. + self._extend_server(server, db_instance) + + +class Server_usage(extensions.ExtensionDescriptor): + """Adds launched_at and terminated_at on Servers.""" + + name = "ServerUsage" + alias = "OS-SRV-USG" + namespace = ("http://docs.openstack.org/compute/ext/" + "server_usage/api/v1.1") + updated = "2013-04-29T00:00:00+00:00" + + def get_controller_extensions(self): + controller = ServerUsageController() + extension = extensions.ControllerExtension(self, 'servers', controller) + return [extension] + + +def make_server(elem): + elem.set('{%s}launched_at' % Server_usage.namespace, + '%s:launched_at' % Server_usage.alias) + elem.set('{%s}terminated_at' % Server_usage.namespace, + '%s:terminated_at' % Server_usage.alias) + + +class ServerUsageTemplate(xmlutil.TemplateBuilder): + def construct(self): + root = xmlutil.TemplateElement('server', selector='server') + make_server(root) + return xmlutil.SlaveTemplate(root, 1, nsmap={ + Server_usage.alias: Server_usage.namespace}) + + +class ServerUsagesTemplate(xmlutil.TemplateBuilder): + def construct(self): + root = xmlutil.TemplateElement('servers') + elem = xmlutil.SubTemplateElement(root, 'server', selector='servers') + make_server(elem) + return xmlutil.SlaveTemplate(root, 1, nsmap={ + Server_usage.alias: Server_usage.namespace}) |
