Reduce duplicate definitions about quota sets

Use unified definitions of "quota sets" instead of dispersed
    duplicated definitions.

Change-Id: I7de5bd77d187e7353c154ea89a8b259c309f0faa
This commit is contained in:
Wu Wenxiang 2013-03-18 21:38:26 +08:00
parent a53d6491a9
commit e765f4e588
4 changed files with 10 additions and 17 deletions

View File

@ -23,6 +23,8 @@ from openstack_dashboard.api import keystone
from openstack_dashboard.usage import quotas from openstack_dashboard.usage import quotas
from .tables import QuotasTable, ServicesTable from .tables import QuotasTable, ServicesTable
from openstack_dashboard.api.base import is_service_enabled from openstack_dashboard.api.base import is_service_enabled
from openstack_dashboard.dashboards.admin.projects.workflows import \
CINDER_QUOTA_FIELDS
class DefaultQuotasTab(tabs.TableTab): class DefaultQuotasTab(tabs.TableTab):
@ -35,7 +37,7 @@ class DefaultQuotasTab(tabs.TableTab):
request = self.tab_group.request request = self.tab_group.request
disabled_quotas = [] disabled_quotas = []
if not is_service_enabled(self.request, 'volume'): if not is_service_enabled(self.request, 'volume'):
disabled_quotas.extend(['volumes', 'gigabytes']) disabled_quotas.extend(CINDER_QUOTA_FIELDS)
try: try:
quota_set = quotas.get_default_quota_data(request, disabled_quotas) quota_set = quotas.get_default_quota_data(request, disabled_quotas)
data = quota_set.items data = quota_set.items

View File

@ -33,13 +33,10 @@ from openstack_dashboard.usage import quotas
from openstack_dashboard.dashboards.admin.users.views import CreateView from openstack_dashboard.dashboards.admin.users.views import CreateView
from .forms import CreateUser from .forms import CreateUser
from .tables import TenantsTable, TenantUsersTable, AddUsersTable from .tables import TenantsTable, TenantUsersTable, AddUsersTable
from .workflows import CreateProject, UpdateProject, NOVA_QUOTA_FIELDS, \ from .workflows import CreateProject, UpdateProject, QUOTA_FIELDS
CINDER_QUOTA_FIELDS
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
QUOTA_FIELDS = NOVA_QUOTA_FIELDS + CINDER_QUOTA_FIELDS
PROJECT_INFO_FIELDS = ("name", PROJECT_INFO_FIELDS = ("name",
"description", "description",
"enabled") "enabled")

View File

@ -48,6 +48,8 @@ NOVA_QUOTA_FIELDS = ("metadata_items",
CINDER_QUOTA_FIELDS = ("volumes", CINDER_QUOTA_FIELDS = ("volumes",
"gigabytes",) "gigabytes",)
QUOTA_FIELDS = NOVA_QUOTA_FIELDS + CINDER_QUOTA_FIELDS
class UpdateProjectQuotaAction(workflows.Action): class UpdateProjectQuotaAction(workflows.Action):
ifcb_label = _("Injected File Content Bytes") ifcb_label = _("Injected File Content Bytes")
@ -78,17 +80,7 @@ class UpdateProjectQuotaAction(workflows.Action):
class UpdateProjectQuota(workflows.Step): class UpdateProjectQuota(workflows.Step):
action_class = UpdateProjectQuotaAction action_class = UpdateProjectQuotaAction
depends_on = ("project_id",) depends_on = ("project_id",)
contributes = ("metadata_items", contributes = QUOTA_FIELDS
"cores",
"instances",
"injected_files",
"injected_file_content_bytes",
"volumes",
"gigabytes",
"ram",
"floating_ips",
"security_groups",
"security_group_rules")
class CreateProjectInfoAction(workflows.Action): class CreateProjectInfoAction(workflows.Action):

View File

@ -6,6 +6,8 @@ from horizon.utils.memoized import memoized
from openstack_dashboard.api import nova, cinder, network from openstack_dashboard.api import nova, cinder, network
from openstack_dashboard.api.base import is_service_enabled, QuotaSet from openstack_dashboard.api.base import is_service_enabled, QuotaSet
from openstack_dashboard.dashboards.admin.projects.workflows import \
CINDER_QUOTA_FIELDS
class QuotaUsage(dict): class QuotaUsage(dict):
@ -85,7 +87,7 @@ def tenant_quota_usages(request):
# Get our quotas and construct our usage object. # Get our quotas and construct our usage object.
disabled_quotas = [] disabled_quotas = []
if not is_service_enabled(request, 'volume'): if not is_service_enabled(request, 'volume'):
disabled_quotas.extend(['volumes', 'gigabytes']) disabled_quotas.extend(CINDER_QUOTA_FIELDS)
usages = QuotaUsage() usages = QuotaUsage()
for quota in get_tenant_quota_data(request, disabled_quotas): for quota in get_tenant_quota_data(request, disabled_quotas):