Add a new policy for cold-migrate with host

We add a new specific policy when a host value is provided for cold-migrate,
but by default it will only be an admin-only rule in order to not change
the behaviour.

Change-Id: I128242d5f689fdd08d74b1dcba861177174753ff
Implements: blueprint cold-migrate-to-host-policy
This commit is contained in:
Sylvain Bauza 2023-04-26 14:09:01 +02:00
parent b9ac827491
commit 2d320f9b00
7 changed files with 41 additions and 6 deletions

View File

@ -75,8 +75,9 @@ automatically confirms the migrate operation after the configured interval.
.. _resize_confirm_window: https://docs.openstack.org/nova/latest/configuration/config.html#DEFAULT.resize_confirm_window .. _resize_confirm_window: https://docs.openstack.org/nova/latest/configuration/config.html#DEFAULT.resize_confirm_window
Policy defaults enable only users with the administrative role to There are two different policies for this action, depending on whether the host
perform this operation. Cloud providers can change these permissions parameter is set. Both defaults enable only users with the administrative role
to perform this operation. Cloud providers can change these permissions
through the ``policy.json`` file. through the ``policy.json`` file.
Normal response codes: 202 Normal response codes: 202

View File

@ -46,14 +46,17 @@ class MigrateServerController(wsgi.Controller):
instance = common.get_instance(self.compute_api, context, id, instance = common.get_instance(self.compute_api, context, id,
expected_attrs=['flavor', 'services']) expected_attrs=['flavor', 'services'])
context.can(ms_policies.POLICY_ROOT % 'migrate',
target={'project_id': instance.project_id})
host_name = None host_name = None
if (api_version_request.is_supported(req, min_version='2.56') and if (api_version_request.is_supported(req, min_version='2.56') and
body['migrate'] is not None): body['migrate'] is not None):
host_name = body['migrate'].get('host') host_name = body['migrate'].get('host')
if host_name:
context.can(ms_policies.POLICY_ROOT % 'migrate:host',
target={'project_id': instance.project_id})
else:
context.can(ms_policies.POLICY_ROOT % 'migrate',
target={'project_id': instance.project_id})
try: try:
self.compute_api.resize(req.environ['nova.context'], instance, self.compute_api.resize(req.environ['nova.context'], instance,
host_name=host_name) host_name=host_name)

View File

@ -25,7 +25,18 @@ migrate_server_policies = [
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name=POLICY_ROOT % 'migrate', name=POLICY_ROOT % 'migrate',
check_str=base.ADMIN, check_str=base.ADMIN,
description="Cold migrate a server to a host", description="Cold migrate a server without specifying a host",
operations=[
{
'method': 'POST',
'path': '/servers/{server_id}/action (migrate)'
}
],
scope_types=['project']),
policy.DocumentedRuleDefault(
name=POLICY_ROOT % 'migrate:host',
check_str=base.ADMIN,
description="Cold migrate a server to a specified host",
operations=[ operations=[
{ {
'method': 'POST', 'method': 'POST',

View File

@ -125,6 +125,7 @@ policy_data = """
"os_compute_api:os-lock-server:lock": "", "os_compute_api:os-lock-server:lock": "",
"os_compute_api:os-lock-server:unlock": "", "os_compute_api:os-lock-server:unlock": "",
"os_compute_api:os-migrate-server:migrate": "", "os_compute_api:os-migrate-server:migrate": "",
"os_compute_api:os-migrate-server:migrate:host": "",
"os_compute_api:os-migrate-server:migrate_live": "", "os_compute_api:os-migrate-server:migrate_live": "",
"os_compute_api:os-migrations:index": "", "os_compute_api:os-migrations:index": "",
"os_compute_api:os-multinic:add": "", "os_compute_api:os-multinic:add": "",

View File

@ -62,6 +62,16 @@ class MigrateServerPolicyTest(base.BasePolicyTest):
self.req, self.instance.uuid, self.req, self.instance.uuid,
body={'migrate': None}) body={'migrate': None})
@mock.patch('nova.compute.api.API.resize')
def test_migrate_server_host_policy(self, mock_resize):
rule_name = ms_policies.POLICY_ROOT % 'migrate:host'
# the host parameter was added by the 2.56 microversion.
req = fakes.HTTPRequest.blank('', version='2.56')
self.common_policy_auth(self.project_admin_authorized_contexts,
rule_name, self.controller._migrate,
req, self.instance.uuid,
body={'migrate': {"host": "hostname"}})
@mock.patch('nova.compute.api.API.live_migrate') @mock.patch('nova.compute.api.API.live_migrate')
def test_migrate_live_server_policy(self, mock_live_migrate): def test_migrate_live_server_policy(self, mock_live_migrate):
rule_name = ms_policies.POLICY_ROOT % 'migrate_live' rule_name = ms_policies.POLICY_ROOT % 'migrate_live'
@ -122,11 +132,13 @@ class MigrateServerOverridePolicyTest(
def setUp(self): def setUp(self):
super(MigrateServerOverridePolicyTest, self).setUp() super(MigrateServerOverridePolicyTest, self).setUp()
rule_migrate = ms_policies.POLICY_ROOT % 'migrate' rule_migrate = ms_policies.POLICY_ROOT % 'migrate'
rule_migrate_host = ms_policies.POLICY_ROOT % 'migrate:host'
rule_live_migrate = ms_policies.POLICY_ROOT % 'migrate_live' rule_live_migrate = ms_policies.POLICY_ROOT % 'migrate_live'
# NOTE(gmann): override the rule to project member and verify it # NOTE(gmann): override the rule to project member and verify it
# work as policy is system and project scoped. # work as policy is system and project scoped.
self.policy.set_rules({ self.policy.set_rules({
rule_migrate: base_policy.PROJECT_MEMBER, rule_migrate: base_policy.PROJECT_MEMBER,
rule_migrate_host: base_policy.PROJECT_MEMBER,
rule_live_migrate: base_policy.PROJECT_MEMBER}, rule_live_migrate: base_policy.PROJECT_MEMBER},
overwrite=False) overwrite=False)

View File

@ -350,6 +350,7 @@ class RealRolePolicyTestCase(test.NoDBTestCase):
"os_compute_api:os-instance-actions:events", "os_compute_api:os-instance-actions:events",
"os_compute_api:os-lock-server:unlock:unlock_override", "os_compute_api:os-lock-server:unlock:unlock_override",
"os_compute_api:os-migrate-server:migrate", "os_compute_api:os-migrate-server:migrate",
"os_compute_api:os-migrate-server:migrate:host",
"os_compute_api:os-migrate-server:migrate_live", "os_compute_api:os-migrate-server:migrate_live",
"os_compute_api:os-quota-sets:update", "os_compute_api:os-quota-sets:update",
"os_compute_api:os-quota-sets:delete", "os_compute_api:os-quota-sets:delete",

View File

@ -0,0 +1,6 @@
---
features:
- A new `os_compute_api:os-migrate-server:migrate:host` policy is created,
being by default only an admin-only policy. This will help operators to
have different policies between cold-migrate without providing a host or
not.