
Add dcmanager system-peer management api. Test Plan: 1. PASS - Verify that cloud manage system-peer through api successfully. 2. PASS - Add system peer with invalid UUID, manager_endpoint, systemcontroller_gateway_address, administrative_state, heartbeat_interval 3. PASS - Update system peer with invalid administrative_state, heartbeat_interval 4. PASS - Get system peer with UUID, name 5. PASS - Delete system peer with UUID, name CLI example: dcmanager system-peer add --peer_uuid $(uuidgen) --peer_name dc-0 --manager_endpoint http://128.128.128.1:5000/v3 (The peer_uuid get from the peer site with command `system show`) dcmanager system-peer list dcmanager system-peer update --administrative_state enabled 1 dcmanager system-peer show 1 dcmanager system-peer delete 1 Story: 2010852 Task: 48482 Change-Id: I349cd24bccc732eb8ed56df9346185cfce7b2570 Signed-off-by: Zhang Rong(Jon) <rong.zhang@windriver.com>
66 lines
1.7 KiB
Python
Executable File
66 lines
1.7 KiB
Python
Executable File
# Copyright (c) 2023 Wind River Systems, Inc.
|
|
#
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
#
|
|
|
|
from dcmanager.api.policies import base
|
|
from oslo_policy import policy
|
|
|
|
POLICY_ROOT = 'dc_api:system_peers:%s'
|
|
|
|
|
|
system_peers_rules = [
|
|
policy.DocumentedRuleDefault(
|
|
name=POLICY_ROOT % 'create',
|
|
check_str='rule:' + base.ADMIN_IN_SYSTEM_PROJECTS,
|
|
description="Create system peer.",
|
|
operations=[
|
|
{
|
|
'method': 'POST',
|
|
'path': '/v1.0/system-peers'
|
|
}
|
|
]
|
|
),
|
|
policy.DocumentedRuleDefault(
|
|
name=POLICY_ROOT % 'delete',
|
|
check_str='rule:' + base.ADMIN_IN_SYSTEM_PROJECTS,
|
|
description="Delete system peer.",
|
|
operations=[
|
|
{
|
|
'method': 'DELETE',
|
|
'path': '/v1.0/system-peers/{system_peer}'
|
|
}
|
|
]
|
|
),
|
|
policy.DocumentedRuleDefault(
|
|
name=POLICY_ROOT % 'get',
|
|
check_str='rule:' + base.READER_IN_SYSTEM_PROJECTS,
|
|
description="Get system peers.",
|
|
operations=[
|
|
{
|
|
'method': 'GET',
|
|
'path': '/v1.0/system-peers'
|
|
},
|
|
{
|
|
'method': 'GET',
|
|
'path': '/v1.0/system-peers/{system_peer}'
|
|
}
|
|
]
|
|
),
|
|
policy.DocumentedRuleDefault(
|
|
name=POLICY_ROOT % 'modify',
|
|
check_str='rule:' + base.ADMIN_IN_SYSTEM_PROJECTS,
|
|
description="Modify system peer.",
|
|
operations=[
|
|
{
|
|
'method': 'PATCH',
|
|
'path': '/v1.0/system-peers/{system_peer}'
|
|
}
|
|
]
|
|
)
|
|
]
|
|
|
|
|
|
def list_rules():
|
|
return system_peers_rules
|