Add server details link

Change-Id: I39b1f2f9a38670ba58eb1a6dabb878083d4f689e
This commit is contained in:
Zhenguo Niu 2017-05-06 22:32:27 +08:00
parent 79b15f8353
commit 70af5a07aa
5 changed files with 147 additions and 2 deletions

View File

@ -76,6 +76,7 @@ class ServersTable(tables.DataTable):
)
name = tables.WrappingColumn(
"name",
link="horizon:project:servers:detail",
verbose_name=_("Server Name"))
image = tables.Column("image_uuid",
verbose_name=_("Image"))

View File

@ -0,0 +1,35 @@
# Copyright 2017 Huawei Technologies Co.,LTD.
# All Rights Reserved.
#
# 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 django.utils.translation import ugettext_lazy as _
from horizon import tabs
class OverviewTab(tabs.Tab):
name = _("Overview")
slug = "server_overview"
template_name = ("project/servers/"
"_detail_overview.html")
def get_context_data(self, request):
return {"server": self.tab_group.kwargs['server'],
"is_superuser": request.user.is_superuser}
class ServerDetailTabs(tabs.DetailTabsGroup):
slug = "server_details"
tabs = (OverviewTab,)
sticky = True

View File

@ -0,0 +1,58 @@
{% load i18n sizeformat %}
<div class="detail">
<dl class="dl-horizontal">
<dt>{% trans "Name" %}</dt>
<dd>{{ server.name }}</dd>
<dt>{% trans "ID" %}</dt>
<dd>{{ server.uuid }}</dd>
<dt>{% trans "Status" %}</dt>
<dd>{{ server.status|title }}</dd>
<dt>{% trans "Availability Zone" %}</dt>
<dd>{{ server.availability_zone|default:_("-") }}</dd>
<dt>{% trans "Created" %}</dt>
<dd>{{ server.created_at|parse_isotime }}</dd>
<dt>{% trans "Time Since Created" %}</dt>
<dd>{{ server.created_at|parse_isotime|timesince }}</dd>
{% if is_superuser %}
<dt>{% trans "Node" %}</dt>
{% endif %}
</dl>
{% if server.fault_info %}
<h4>{% trans "Fault" %}</h4>
<hr class="header_rule">
<dl class="dl-horizontal">
<dt>{% trans "Message" %}</dt>
<dd>{{ server.fault_info.message }}</dd>
<dt>{% trans "Code" %}</dt>
<dd>{{ server.fault_info.code }}</dd>
<dt>{% trans "Details" %}</dt>
<dd>{{ server.fault_info.details }}</dd>
</dl>
{% endif %}
<h4>{% trans "Metadata" %}</h4>
<hr class="header_rule">
<dl class="dl-horizontal">
{% if server.image_uuid %}
<dt>{% trans "Image" %}</dt>
<dd>
{% if server.image_uuid %}
<a href="{{ server.image_url }}">{{ server.image_uuid }}</a>
{% else %}
{% trans "-" %}
{% endif %}
</dd>
{% else %}
<dt>{% trans "Image" %}</dt>
<dd>{% trans "None" %}</dd>
{% endif %}
{% with default_item_value="<em>"|add:_("N/A")|add:"</em>" %}
{% for key, value in server.extra.items %}
<dt>{{ key|force_escape }}</dt>
<dd>{{ value|force_escape|default:default_item_value }}</dd>
{% endfor %}
{% endwith %}
</dl>
</div>

View File

@ -18,4 +18,6 @@ from mogan_ui.content.servers import views
urlpatterns = [
url(r'^$', views.IndexView.as_view(), name='index'),
url(r'^(?P<server_id>[^/]+)/$',
views.DetailView.as_view(), name='detail'),
]

View File

@ -13,17 +13,21 @@
# See the License for the specific language governing permissions and
# limitations under the License.
from django.core.urlresolvers import reverse
from django.utils.translation import ugettext_lazy as _
from mogan_ui.api import mogan
from mogan_ui.content.servers.tables import ServersTable
from mogan_ui.content.servers import tables as project_tables
from mogan_ui.content.servers import tabs as project_tabs
from horizon import exceptions
from horizon import tables
from horizon import tabs
from horizon.utils import memoized
class IndexView(tables.DataTableView):
table_class = ServersTable
table_class = project_tables.ServersTable
template_name = 'project/servers/index.html'
page_title = _("Servers")
@ -35,3 +39,48 @@ class IndexView(tables.DataTableView):
msg = _('Unable to retrieve servers.')
exceptions.handle(self.request, msg)
return servers
class DetailView(tabs.TabView):
tab_group_class = project_tabs.ServerDetailTabs
template_name = 'horizon/common/_detail.html'
redirect_url = 'horizon:project:servers:index'
page_title = "{{ server.name|default:server.uuid }}"
image_url = 'horizon:project:images:images:detail'
def get_context_data(self, **kwargs):
context = super(DetailView, self).get_context_data(**kwargs)
server = self.get_data()
if server.image_uuid:
server.image_url = reverse(self.image_url,
args=[server.image_uuid])
context["server"] = server
context["url"] = reverse(self.redirect_url)
context["actions"] = self._get_actions(server)
return context
def _get_actions(self, server):
table = project_tables.ServersTable(self.request)
return table.render_row_actions(server)
@memoized.memoized_method
def get_data(self):
server_id = self.kwargs['server_id']
try:
server = mogan.server_get(self.request, server_id)
except Exception:
redirect = reverse(self.redirect_url)
exceptions.handle(self.request,
_('Unable to retrieve details for '
'server "%s".') % server_id,
redirect=redirect)
# Not all exception types handled above will result in a redirect.
# Need to raise here just in case.
raise exceptions.Http302(redirect)
return server
def get_tabs(self, request, *args, **kwargs):
server = self.get_data()
return self.tab_group_class(request, server=server, **kwargs)