
Part of blueprint fwaas-horizon This commit creates cross links between FWaaS resources and resolves FWaaS resource UUID in tables to its name. This helps users to track FWaaS resources. This commit also improves an error handling when an error occurs during retrieving a resource detail via API call. While previously a detail page without item values is displayed, now the index page is displayed for such case. Closes-Bug: #1229433 Change-Id: I4357b5c275ab75163f0afc7158b4c1edb8cecd6c
209 lines
7.0 KiB
Python
209 lines
7.0 KiB
Python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
# Copyright 2013, Big Switch Networks, Inc.
|
|
#
|
|
# 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.
|
|
#
|
|
# @author: KC Wang, Big Switch Networks
|
|
|
|
import logging
|
|
|
|
from django.core.urlresolvers import reverse # noqa
|
|
from django.template import defaultfilters as filters
|
|
from django.utils.translation import ugettext_lazy as _ # noqa
|
|
|
|
from horizon import tables
|
|
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
class AddRuleLink(tables.LinkAction):
|
|
name = "addrule"
|
|
verbose_name = _("Add Rule")
|
|
url = "horizon:project:firewalls:addrule"
|
|
classes = ("ajax-modal", "btn-create",)
|
|
|
|
|
|
class AddPolicyLink(tables.LinkAction):
|
|
name = "addpolicy"
|
|
verbose_name = _("Add Policy")
|
|
url = "horizon:project:firewalls:addpolicy"
|
|
classes = ("ajax-modal", "btn-addpolicy",)
|
|
|
|
|
|
class AddFirewallLink(tables.LinkAction):
|
|
name = "addfirewall"
|
|
verbose_name = _("Create Firewall")
|
|
url = "horizon:project:firewalls:addfirewall"
|
|
classes = ("ajax-modal", "btn-addfirewall",)
|
|
|
|
|
|
class DeleteRuleLink(tables.DeleteAction):
|
|
name = "deleterule"
|
|
action_present = _("Delete")
|
|
action_past = _("Scheduled deletion of")
|
|
data_type_singular = _("Rule")
|
|
data_type_plural = _("Rules")
|
|
|
|
|
|
class DeletePolicyLink(tables.DeleteAction):
|
|
name = "deletepolicy"
|
|
action_present = _("Delete")
|
|
action_past = _("Scheduled deletion of")
|
|
data_type_singular = _("Policy")
|
|
data_type_plural = _("Policies")
|
|
|
|
|
|
class DeleteFirewallLink(tables.DeleteAction):
|
|
name = "deletefirewall"
|
|
action_present = _("Delete")
|
|
action_past = _("Scheduled deletion of")
|
|
data_type_singular = _("Firewall")
|
|
data_type_plural = _("Firewalls")
|
|
|
|
|
|
class UpdateRuleLink(tables.LinkAction):
|
|
name = "updaterule"
|
|
verbose_name = _("Edit Rule")
|
|
classes = ("ajax-modal", "btn-update",)
|
|
|
|
def get_link_url(self, rule):
|
|
base_url = reverse("horizon:project:firewalls:updaterule",
|
|
kwargs={'rule_id': rule.id})
|
|
return base_url
|
|
|
|
|
|
class UpdatePolicyLink(tables.LinkAction):
|
|
name = "updatepolicy"
|
|
verbose_name = _("Edit Policy")
|
|
classes = ("ajax-modal", "btn-update",)
|
|
|
|
def get_link_url(self, policy):
|
|
base_url = reverse("horizon:project:firewalls:updatepolicy",
|
|
kwargs={'policy_id': policy.id})
|
|
return base_url
|
|
|
|
|
|
class UpdateFirewallLink(tables.LinkAction):
|
|
name = "updatefirewall"
|
|
verbose_name = _("Edit Firewall")
|
|
classes = ("ajax-modal", "btn-update",)
|
|
|
|
def get_link_url(self, firewall):
|
|
base_url = reverse("horizon:project:firewalls:updatefirewall",
|
|
kwargs={'firewall_id': firewall.id})
|
|
return base_url
|
|
|
|
|
|
class InsertRuleToPolicyLink(tables.LinkAction):
|
|
name = "insertrule"
|
|
verbose_name = _("Insert Rule")
|
|
classes = ("ajax-modal", "btn-update",)
|
|
|
|
def get_link_url(self, policy):
|
|
base_url = reverse("horizon:project:firewalls:insertrule",
|
|
kwargs={'policy_id': policy.id})
|
|
return base_url
|
|
|
|
|
|
class RemoveRuleFromPolicyLink(tables.LinkAction):
|
|
name = "removerule"
|
|
verbose_name = _("Remove Rule")
|
|
classes = ("ajax-modal", "btn-update",)
|
|
|
|
def get_link_url(self, policy):
|
|
base_url = reverse("horizon:project:firewalls:removerule",
|
|
kwargs={'policy_id': policy.id})
|
|
return base_url
|
|
|
|
|
|
def get_rules_name(datum):
|
|
return ', '.join([rule.name or rule.id[:13]
|
|
for rule in datum.rules])
|
|
|
|
|
|
def get_policy_name(datum):
|
|
if datum.policy:
|
|
return datum.policy.name or datum.policy.id
|
|
|
|
|
|
def get_policy_link(datum):
|
|
return reverse('horizon:project:firewalls:policydetails',
|
|
kwargs={'policy_id': datum.policy.id})
|
|
|
|
|
|
class RulesTable(tables.DataTable):
|
|
name = tables.Column("name",
|
|
verbose_name=_("Name"),
|
|
link="horizon:project:firewalls:ruledetails")
|
|
protocol = tables.Column("protocol",
|
|
filters=(lambda v: filters.default(v, _("ANY")),
|
|
filters.upper,),
|
|
verbose_name=_("Protocol"))
|
|
source_ip_address = tables.Column("source_ip_address",
|
|
verbose_name=_("Source IP"))
|
|
source_port = tables.Column("source_port",
|
|
verbose_name=_("Source Port"))
|
|
destination_ip_address = tables.Column("destination_ip_address",
|
|
verbose_name=_("Destination IP"))
|
|
destination_port = tables.Column("destination_port",
|
|
verbose_name=_("Destination Port"))
|
|
action = tables.Column("action",
|
|
filters=(filters.upper,),
|
|
verbose_name=_("Action"))
|
|
enabled = tables.Column("enabled",
|
|
verbose_name=_("Enabled"))
|
|
firewall_policy_id = tables.Column(get_policy_name,
|
|
link=get_policy_link,
|
|
verbose_name=_("In Policy"))
|
|
|
|
class Meta:
|
|
name = "rulestable"
|
|
verbose_name = _("Rules")
|
|
table_actions = (AddRuleLink, DeleteRuleLink)
|
|
row_actions = (UpdateRuleLink, DeleteRuleLink)
|
|
|
|
|
|
class PoliciesTable(tables.DataTable):
|
|
name = tables.Column("name",
|
|
verbose_name=_("Name"),
|
|
link="horizon:project:firewalls:policydetails")
|
|
firewall_rules = tables.Column(get_rules_name,
|
|
verbose_name=_("Rules"))
|
|
audited = tables.Column("audited",
|
|
verbose_name=_("Audited"))
|
|
|
|
class Meta:
|
|
name = "policiestable"
|
|
verbose_name = _("Policies")
|
|
table_actions = (AddPolicyLink, DeletePolicyLink)
|
|
row_actions = (UpdatePolicyLink, InsertRuleToPolicyLink,
|
|
RemoveRuleFromPolicyLink, DeletePolicyLink)
|
|
|
|
|
|
class FirewallsTable(tables.DataTable):
|
|
name = tables.Column("name",
|
|
verbose_name=_("Name"),
|
|
link="horizon:project:firewalls:firewalldetails")
|
|
firewall_policy_id = tables.Column(get_policy_name,
|
|
link=get_policy_link,
|
|
verbose_name=_("Policy"))
|
|
status = tables.Column("status",
|
|
verbose_name=_("Status"))
|
|
|
|
class Meta:
|
|
name = "firewallstable"
|
|
verbose_name = _("Firewalls")
|
|
table_actions = (AddFirewallLink, DeleteFirewallLink)
|
|
row_actions = (UpdateFirewallLink, DeleteFirewallLink)
|