Add server details link
Change-Id: I39b1f2f9a38670ba58eb1a6dabb878083d4f689e
This commit is contained in:
parent
79b15f8353
commit
70af5a07aa
|
@ -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"))
|
||||
|
|
|
@ -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
|
|
@ -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>
|
|
@ -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'),
|
||||
]
|
||||
|
|
|
@ -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)
|
||||
|
|
Loading…
Reference in New Issue