#!/usr/bin/python3 # -*- coding: utf-8 -*- # 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. # # Authors: # @author: David Blaisonneau # @author: Arnaud Morin from opensteak.foreman_objects.item import ForemanItem from opensteak.foreman_objects.itemOverrideValues import ItemOverrideValues class ItemSmartClassParameter(ForemanItem): """ ItemSmartClassParameter class Represent the content of a foreman smart class parameter as a dict """ objName = 'smart_class_parameters' payloadObj = 'smart_class_parameter' def __init__(self, api, key, *args, **kwargs): """ Function __init__ Represent the content of a foreman object as a dict @param api: The foreman api @param key: The object Key @param *args, **kwargs: the dict representation @return RETURN: Itself """ ForemanItem.__init__(self, api, key, self.objName, self.payloadObj, *args, **kwargs) self.update({'override_values': list(map(lambda x: ItemOverrideValues(self.api, x['id'], self.objName, key, x), self['override_values']))}) def __setitem__(self, key, attributes): """ Function __setitem__ Set a parameter of a foreman object as a dict @param key: The key to modify @param attribute: The data @return RETURN: The API result """ payload = {self.payloadObj: {key: attributes}} return self.api.set(self.objName, self.key, payload)