104 lines
3.0 KiB
Python
104 lines
3.0 KiB
Python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
|
|
# Copyright 2012 Nebula, 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.
|
|
|
|
import logging
|
|
|
|
from django.core.urlresolvers import reverse
|
|
from django.utils.translation import ugettext as _
|
|
|
|
from horizon import api
|
|
from horizon import tables
|
|
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
class DeleteGroup(tables.DeleteAction):
|
|
data_type_singular = _("Security Group")
|
|
data_type_plural = _("Security Groups")
|
|
|
|
def allowed(self, request, security_group=None):
|
|
if not security_group:
|
|
return True
|
|
return security_group.name != 'default'
|
|
|
|
def delete(self, request, obj_id):
|
|
api.security_group_delete(request, obj_id)
|
|
|
|
|
|
class CreateGroup(tables.LinkAction):
|
|
name = "create"
|
|
verbose_name = _("Create Security Group")
|
|
url = "horizon:nova:access_and_security:security_groups:create"
|
|
classes = ("ajax-modal",)
|
|
|
|
|
|
class EditRules(tables.LinkAction):
|
|
name = "edit_rules"
|
|
verbose_name = _("Edit Rules")
|
|
url = "horizon:nova:access_and_security:security_groups:edit_rules"
|
|
attrs = {"class": "ajax-modal"}
|
|
|
|
|
|
class SecurityGroupsTable(tables.DataTable):
|
|
name = tables.Column("name")
|
|
description = tables.Column("description")
|
|
|
|
def sanitize_id(self, obj_id):
|
|
return int(obj_id)
|
|
|
|
class Meta:
|
|
name = "security_groups"
|
|
verbose_name = _("Security Groups")
|
|
table_actions = (CreateGroup, DeleteGroup)
|
|
row_actions = (EditRules, DeleteGroup)
|
|
|
|
|
|
class DeleteRule(tables.DeleteAction):
|
|
data_type_singular = _("Rule")
|
|
data_type_plural = _("Rules")
|
|
|
|
def delete(self, request, obj_id):
|
|
api.security_group_rule_delete(request, obj_id)
|
|
|
|
def get_success_url(self, request):
|
|
return reverse("horizon:nova:access_and_security:index")
|
|
|
|
|
|
def get_cidr(rule):
|
|
return rule.ip_range['cidr']
|
|
|
|
|
|
class RulesTable(tables.DataTable):
|
|
protocol = tables.Column("ip_protocol",
|
|
verbose_name=_("IP Protocol"),
|
|
filters=(unicode.upper,))
|
|
from_port = tables.Column("from_port", verbose_name=_("From Port"))
|
|
to_port = tables.Column("to_port", verbose_name=_("To Port"))
|
|
cidr = tables.Column(get_cidr, verbose_name=_("CIDR"))
|
|
|
|
def sanitize_id(self, obj_id):
|
|
return int(obj_id)
|
|
|
|
def get_object_display(self, rule):
|
|
return unicode(rule)
|
|
|
|
class Meta:
|
|
name = "rules"
|
|
verbose_name = _("Security Group Rules")
|
|
table_actions = (DeleteRule,)
|
|
row_actions = (DeleteRule,)
|