From 61c83b812ca0b847a60cebac889fbe895002f13d Mon Sep 17 00:00:00 2001 From: Timur Sufiev Date: Mon, 30 Mar 2015 22:51:07 +0300 Subject: [PATCH] Move _update_project_quota into a common Workflow ancestor Both CreateProject and UpdateProject workflows use almost the same method _update_project_quota which is not very good. Reduce the duplication by introducing a common ancestor for these 2 workflow classes. Change-Id: I12a056cd3d3a8c8c67b3735f3337c1efbb4fd6f5 --- .../dashboards/identity/projects/workflows.py | 80 ++++++++----------- 1 file changed, 32 insertions(+), 48 deletions(-) diff --git a/openstack_dashboard/dashboards/identity/projects/workflows.py b/openstack_dashboard/dashboards/identity/projects/workflows.py index d5a837c22f..b359afae4d 100644 --- a/openstack_dashboard/dashboards/identity/projects/workflows.py +++ b/openstack_dashboard/dashboards/identity/projects/workflows.py @@ -372,7 +372,33 @@ class UpdateProjectGroups(workflows.UpdateMembersStep): return context -class CreateProject(workflows.Workflow): +class CommonQuotaWorkflow(workflows.Workflow): + def _update_project_quota(self, request, data, project_id): + # Update the project quota. + nova_data = dict( + [(key, data[key]) for key in quotas.NOVA_QUOTA_FIELDS]) + nova.tenant_quota_update(request, project_id, **nova_data) + + if base.is_service_enabled(request, 'volume'): + cinder_data = dict([(key, data[key]) for key in + quotas.CINDER_QUOTA_FIELDS]) + cinder.tenant_quota_update(request, + project_id, + **cinder_data) + + if api.base.is_service_enabled(request, 'network') and \ + api.neutron.is_quotas_extension_supported(request): + neutron_data = {} + disabled_quotas = quotas.get_disabled_quotas(request) + for key in quotas.NEUTRON_QUOTA_FIELDS: + if key not in disabled_quotas: + neutron_data[key] = data[key] + api.neutron.tenant_quota_update(request, + project_id, + **neutron_data) + + +class CreateProject(CommonQuotaWorkflow): slug = "create_project" name = _("Create Project") finalize_button_name = _("Create Project") @@ -481,29 +507,9 @@ class CreateProject(workflows.Workflow): % groups_to_add) def _update_project_quota(self, request, data, project_id): - # Update the project quota. - nova_data = dict( - [(key, data[key]) for key in quotas.NOVA_QUOTA_FIELDS]) try: - nova.tenant_quota_update(request, project_id, **nova_data) - - if base.is_service_enabled(request, 'volume'): - cinder_data = dict([(key, data[key]) for key in - quotas.CINDER_QUOTA_FIELDS]) - cinder.tenant_quota_update(request, - project_id, - **cinder_data) - - if api.base.is_service_enabled(request, 'network') and \ - api.neutron.is_quotas_extension_supported(request): - neutron_data = {} - disabled_quotas = quotas.get_disabled_quotas(request) - for key in quotas.NEUTRON_QUOTA_FIELDS: - if key not in disabled_quotas: - neutron_data[key] = data[key] - api.neutron.tenant_quota_update(request, - project_id, - **neutron_data) + super(CreateProject, self)._update_project_quota( + request, data, project_id) except Exception: exceptions.handle(request, _('Unable to set project quotas.')) @@ -558,7 +564,7 @@ class UpdateProjectInfo(workflows.Step): "enabled") -class UpdateProject(workflows.Workflow): +class UpdateProject(CommonQuotaWorkflow): slug = "update_project" name = _("Edit Project") finalize_button_name = _("Save") @@ -801,31 +807,9 @@ class UpdateProject(workflows.Workflow): return False def _update_project_quota(self, request, data, project_id): - # update the project quota - nova_data = dict( - [(key, data[key]) for key in quotas.NOVA_QUOTA_FIELDS]) try: - nova.tenant_quota_update(request, - project_id, - **nova_data) - - if base.is_service_enabled(request, 'volume'): - cinder_data = dict([(key, data[key]) for key in - quotas.CINDER_QUOTA_FIELDS]) - cinder.tenant_quota_update(request, - project_id, - **cinder_data) - - if api.base.is_service_enabled(request, 'network') and \ - api.neutron.is_quotas_extension_supported(request): - neutron_data = {} - disabled_quotas = quotas.get_disabled_quotas(request) - for key in quotas.NEUTRON_QUOTA_FIELDS: - if key not in disabled_quotas: - neutron_data[key] = data[key] - api.neutron.tenant_quota_update(request, - project_id, - **neutron_data) + super(UpdateProject, self)._update_project_quota( + request, data, project_id) return True except Exception: exceptions.handle(request, _('Modified project information and '