Files
openstacksdk/openstack/baremetal_introspection/v1/introspection_rule.py
Stephen Finucane f3ba347b06 baremetal: Add 'details' parameter to various 'find' proxy methods
In change I13f32e6ca9be9ed4eb42398aace47e3c5205a81f, we introduced
support for a 'details' parameter to various proxy methods that
supported it. Unfortunately there was a bug in the baremetal proxy layer
changes, which were using a mixin to modify the 'Resource.list' class
method to allow listing detailed responses easily via the resource
layer. This necessitated a revert, change
Icc70bbdc06b5f32722a93775aee2da4d7b7ca4ae.

Take another go at this by reverting the revert and making the necessary
changes to the mixin and proxy layer to make things compatible. We also
fix a class of bugs whereby certain resources have the mixin applied,
resulting in them attempting to use legacy path-based mechanism to
retrieve detailed resources (GET /resource/detail) despite not
supporting this.

Change-Id: I6acbcb4d9af35e68c04bb86e50c8844487bd7d6c
Signed-off-by: Stephen Finucane <stephenfin@redhat.com>
2025-04-04 13:31:55 +01:00

44 lines
1.5 KiB
Python

# 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.
from openstack import resource
class IntrospectionRule(resource.Resource):
resources_key = 'rules'
base_path = '/rules'
# capabilities
allow_create = True
allow_fetch = True
allow_commit = False
allow_delete = True
allow_list = True
# created via POST with ID
create_method = 'POST'
create_requires_id = True
#: The UUID of the resource.
id = resource.Body('uuid', alternate_id=True)
#: List of a logic statementd or operations in rules
conditions = resource.Body('conditions', type=list)
#: List of operations that will be performed if conditions of this rule
#: are fulfilled.
actions = resource.Body('actions', type=list)
#: Rule human-readable description
description = resource.Body('description')
#: Scope of an introspection rule
scope = resource.Body('scope')
#: A list of relative links, including the self and bookmark links.
links = resource.Body('links', type=list)