o
    ɶdF                     @   s8   d dl mZmZmZ d dlmZ eG dd deZdS )    )formatted_flat_dictNONE_SENTINEL#value_allowed_none_or_none_sentinel)init_model_state_from_kwargsc                   @   s  e Zd ZdZdZdZdZdZdZdZ	dZ
d	d
 Zedd Zedd Zejdd Zedd Zejdd Zedd Zejdd Zedd Zejdd Zedd Zejdd Zedd Zejdd Zedd  Zejd!d  Zed"d# Zejd$d# Zed%d& Zejd'd& Zed(d) Zejd*d) Zed+d, Zejd-d, Zed.d/ Zejd0d/ Zed1d2 Zejd3d2 Zd4d5 Zd6d7 Zd8d9 Zd:S );OpsiConfigurationz
    OPSI configuration.
    UX_CONFIGURATIONCREATINGUPDATINGACTIVEDELETINGDELETEDFAILEDc                 K   s   dddddddddddddd| _ ddd	d
dddddddddd| _d| _d| _d| _d| _d| _d| _d| _d| _	d| _
d| _d| _d| _d| _dS )a  
        Initializes a new OpsiConfiguration object with values from keyword arguments. This class has the following subclasses and if you are using this class as input
        to a service operations then you should favor using a subclass over the base class:

        * :class:`~oci.opsi.models.OpsiUxConfiguration`

        The following keyword arguments are supported (corresponding to the getters/setters of this class):

        :param id:
            The value to assign to the id property of this OpsiConfiguration.
        :type id: str

        :param compartment_id:
            The value to assign to the compartment_id property of this OpsiConfiguration.
        :type compartment_id: str

        :param opsi_config_type:
            The value to assign to the opsi_config_type property of this OpsiConfiguration.
            Allowed values for this property are: "UX_CONFIGURATION", 'UNKNOWN_ENUM_VALUE'.
            Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
        :type opsi_config_type: str

        :param display_name:
            The value to assign to the display_name property of this OpsiConfiguration.
        :type display_name: str

        :param description:
            The value to assign to the description property of this OpsiConfiguration.
        :type description: str

        :param freeform_tags:
            The value to assign to the freeform_tags property of this OpsiConfiguration.
        :type freeform_tags: dict(str, str)

        :param defined_tags:
            The value to assign to the defined_tags property of this OpsiConfiguration.
        :type defined_tags: dict(str, dict(str, object))

        :param system_tags:
            The value to assign to the system_tags property of this OpsiConfiguration.
        :type system_tags: dict(str, dict(str, object))

        :param time_created:
            The value to assign to the time_created property of this OpsiConfiguration.
        :type time_created: datetime

        :param time_updated:
            The value to assign to the time_updated property of this OpsiConfiguration.
        :type time_updated: datetime

        :param lifecycle_state:
            The value to assign to the lifecycle_state property of this OpsiConfiguration.
            Allowed values for this property are: "CREATING", "UPDATING", "ACTIVE", "DELETING", "DELETED", "FAILED", 'UNKNOWN_ENUM_VALUE'.
            Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
        :type lifecycle_state: str

        :param lifecycle_details:
            The value to assign to the lifecycle_details property of this OpsiConfiguration.
        :type lifecycle_details: str

        :param config_items:
            The value to assign to the config_items property of this OpsiConfiguration.
        :type config_items: list[oci.opsi.models.OpsiConfigurationConfigurationItemSummary]

        strzdict(str, str)zdict(str, dict(str, object))datetimez/list[OpsiConfigurationConfigurationItemSummary])idcompartment_idopsi_config_typedisplay_namedescriptionfreeform_tagsdefined_tagssystem_tagstime_createdtime_updatedlifecycle_statelifecycle_detailsconfig_itemsr   ZcompartmentIdopsiConfigTypeZdisplayNamer   ZfreeformTagsZdefinedTagsZ
systemTagsZtimeCreatedZtimeUpdatedZlifecycleStateZlifecycleDetailsZconfigItemsN)Zswagger_typesZattribute_map_id_compartment_id_opsi_config_type_display_name_description_freeform_tags_defined_tags_system_tags_time_created_time_updated_lifecycle_state_lifecycle_details_config_items)selfkwargs r-   Fusr/lib/python3.10/site-packages/oci/opsi/models/opsi_configuration.py__init__.   sR   C
zOpsiConfiguration.__init__c                 C   s   | d }|dkr
dS dS )z
        Given the hash representation of a subtype of this class,
        use the info in the hash to return the class of the subtype.
        r   r   ZOpsiUxConfigurationr   r-   )Zobject_dictionarytyper-   r-   r.   get_subtype   s   zOpsiConfiguration.get_subtypec                 C      | j S )a
  
        Gets the id of this OpsiConfiguration.
        `OCID`__ of OPSI configuration resource.

        __ https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm


        :return: The id of this OpsiConfiguration.
        :rtype: str
        r   r+   r-   r-   r.   r         zOpsiConfiguration.idc                 C   
   || _ dS )a  
        Sets the id of this OpsiConfiguration.
        `OCID`__ of OPSI configuration resource.

        __ https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm


        :param id: The id of this OpsiConfiguration.
        :type: str
        Nr3   )r+   r   r-   r-   r.   r         
c                 C   r2   )a  
        Gets the compartment_id of this OpsiConfiguration.
        The `OCID`__ of the compartment.

        __ https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm


        :return: The compartment_id of this OpsiConfiguration.
        :rtype: str
        r   r4   r-   r-   r.   r      r5   z OpsiConfiguration.compartment_idc                 C   r6   )a'  
        Sets the compartment_id of this OpsiConfiguration.
        The `OCID`__ of the compartment.

        __ https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm


        :param compartment_id: The compartment_id of this OpsiConfiguration.
        :type: str
        Nr8   )r+   r   r-   r-   r.   r      r7   c                 C   r2   )a  
        **[Required]** Gets the opsi_config_type of this OpsiConfiguration.
        OPSI configuration type.

        Allowed values for this property are: "UX_CONFIGURATION", 'UNKNOWN_ENUM_VALUE'.
        Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.


        :return: The opsi_config_type of this OpsiConfiguration.
        :rtype: str
        )r    r4   r-   r-   r.   r         z"OpsiConfiguration.opsi_config_typec                 C   s   dg}t ||s
d}|| _dS )z
        Sets the opsi_config_type of this OpsiConfiguration.
        OPSI configuration type.


        :param opsi_config_type: The opsi_config_type of this OpsiConfiguration.
        :type: str
        r   UNKNOWN_ENUM_VALUEN)r   r    )r+   r   allowed_valuesr-   r-   r.   r      s   


c                 C   r2   )z
        Gets the display_name of this OpsiConfiguration.
        User-friendly display name for the OPSI configuration. The name does not have to be unique.


        :return: The display_name of this OpsiConfiguration.
        :rtype: str
        r!   r4   r-   r-   r.   r        
zOpsiConfiguration.display_namec                 C   r6   )a  
        Sets the display_name of this OpsiConfiguration.
        User-friendly display name for the OPSI configuration. The name does not have to be unique.


        :param display_name: The display_name of this OpsiConfiguration.
        :type: str
        Nr<   )r+   r   r-   r-   r.   r        

c                 C   r2   )z
        Gets the description of this OpsiConfiguration.
        Description of OPSI configuration.


        :return: The description of this OpsiConfiguration.
        :rtype: str
        r"   r4   r-   r-   r.   r     r=   zOpsiConfiguration.descriptionc                 C   r6   )z
        Sets the description of this OpsiConfiguration.
        Description of OPSI configuration.


        :param description: The description of this OpsiConfiguration.
        :type: str
        Nr?   )r+   r   r-   r-   r.   r   %  r>   c                 C   r2   )aI  
        Gets the freeform_tags of this OpsiConfiguration.
        Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only.
        Example: `{"bar-key": "value"}`


        :return: The freeform_tags of this OpsiConfiguration.
        :rtype: dict(str, str)
        r#   r4   r-   r-   r.   r   1     zOpsiConfiguration.freeform_tagsc                 C   r6   )aU  
        Sets the freeform_tags of this OpsiConfiguration.
        Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only.
        Example: `{"bar-key": "value"}`


        :param freeform_tags: The freeform_tags of this OpsiConfiguration.
        :type: dict(str, str)
        Nr@   )r+   r   r-   r-   r.   r   >     
c                 C   r2   )aC  
        Gets the defined_tags of this OpsiConfiguration.
        Defined tags for this resource. Each key is predefined and scoped to a namespace.
        Example: `{"foo-namespace": {"bar-key": "value"}}`


        :return: The defined_tags of this OpsiConfiguration.
        :rtype: dict(str, dict(str, object))
        r$   r4   r-   r-   r.   r   K  rA   zOpsiConfiguration.defined_tagsc                 C   r6   )aN  
        Sets the defined_tags of this OpsiConfiguration.
        Defined tags for this resource. Each key is predefined and scoped to a namespace.
        Example: `{"foo-namespace": {"bar-key": "value"}}`


        :param defined_tags: The defined_tags of this OpsiConfiguration.
        :type: dict(str, dict(str, object))
        NrC   )r+   r   r-   r-   r.   r   X  rB   c                 C   r2   )aG  
        Gets the system_tags of this OpsiConfiguration.
        System tags for this resource. Each key is predefined and scoped to a namespace.
        Example: `{"orcl-cloud": {"free-tier-retained": "true"}}`


        :return: The system_tags of this OpsiConfiguration.
        :rtype: dict(str, dict(str, object))
        r%   r4   r-   r-   r.   r   e  rA   zOpsiConfiguration.system_tagsc                 C   r6   )aQ  
        Sets the system_tags of this OpsiConfiguration.
        System tags for this resource. Each key is predefined and scoped to a namespace.
        Example: `{"orcl-cloud": {"free-tier-retained": "true"}}`


        :param system_tags: The system_tags of this OpsiConfiguration.
        :type: dict(str, dict(str, object))
        NrD   )r+   r   r-   r-   r.   r   r  rB   c                 C   r2   )z
        Gets the time_created of this OpsiConfiguration.
        The time at which the resource was first created. An RFC3339 formatted datetime string


        :return: The time_created of this OpsiConfiguration.
        :rtype: datetime
        r&   r4   r-   r-   r.   r     r=   zOpsiConfiguration.time_createdc                 C   r6   )a  
        Sets the time_created of this OpsiConfiguration.
        The time at which the resource was first created. An RFC3339 formatted datetime string


        :param time_created: The time_created of this OpsiConfiguration.
        :type: datetime
        NrE   )r+   r   r-   r-   r.   r     r>   c                 C   r2   )z
        Gets the time_updated of this OpsiConfiguration.
        The time at which the resource was last updated. An RFC3339 formatted datetime string


        :return: The time_updated of this OpsiConfiguration.
        :rtype: datetime
        r'   r4   r-   r-   r.   r     r=   zOpsiConfiguration.time_updatedc                 C   r6   )a  
        Sets the time_updated of this OpsiConfiguration.
        The time at which the resource was last updated. An RFC3339 formatted datetime string


        :param time_updated: The time_updated of this OpsiConfiguration.
        :type: datetime
        NrF   )r+   r   r-   r-   r.   r     r>   c                 C   r2   )a  
        Gets the lifecycle_state of this OpsiConfiguration.
        OPSI configuration resource lifecycle state.

        Allowed values for this property are: "CREATING", "UPDATING", "ACTIVE", "DELETING", "DELETED", "FAILED", 'UNKNOWN_ENUM_VALUE'.
        Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.


        :return: The lifecycle_state of this OpsiConfiguration.
        :rtype: str
        )r(   r4   r-   r-   r.   r     r9   z!OpsiConfiguration.lifecycle_statec                 C   s    g d}t ||sd}|| _dS )z
        Sets the lifecycle_state of this OpsiConfiguration.
        OPSI configuration resource lifecycle state.


        :param lifecycle_state: The lifecycle_state of this OpsiConfiguration.
        :type: str
        )r   r	   r
   r   r   r   r:   N)r   r(   )r+   r   r;   r-   r-   r.   r     s   


c                 C   r2   )a9  
        Gets the lifecycle_details of this OpsiConfiguration.
        A message describing the current state in more detail. For example, can be used to provide actionable information for a resource in Failed state.


        :return: The lifecycle_details of this OpsiConfiguration.
        :rtype: str
        r)   r4   r-   r-   r.   r     r=   z#OpsiConfiguration.lifecycle_detailsc                 C   r6   )aI  
        Sets the lifecycle_details of this OpsiConfiguration.
        A message describing the current state in more detail. For example, can be used to provide actionable information for a resource in Failed state.


        :param lifecycle_details: The lifecycle_details of this OpsiConfiguration.
        :type: str
        NrG   )r+   r   r-   r-   r.   r     r>   c                 C   r2   )a  
        Gets the config_items of this OpsiConfiguration.
        Array of configuration item summary objects.


        :return: The config_items of this OpsiConfiguration.
        :rtype: list[oci.opsi.models.OpsiConfigurationConfigurationItemSummary]
        r*   r4   r-   r-   r.   r     r=   zOpsiConfiguration.config_itemsc                 C   r6   )a  
        Sets the config_items of this OpsiConfiguration.
        Array of configuration item summary objects.


        :param config_items: The config_items of this OpsiConfiguration.
        :type: list[oci.opsi.models.OpsiConfigurationConfigurationItemSummary]
        NrH   )r+   r   r-   r-   r.   r     r>   c                 C   s   t | S N)r   r4   r-   r-   r.   __repr__  s   zOpsiConfiguration.__repr__c                 C   s   |d u rdS | j |j kS )NF)__dict__r+   otherr-   r-   r.   __eq__   s   zOpsiConfiguration.__eq__c                 C   s
   | |k S rI   r-   rL   r-   r-   r.   __ne__  s   
zOpsiConfiguration.__ne__N) __name__
__module____qualname____doc__Z!OPSI_CONFIG_TYPE_UX_CONFIGURATIONZLIFECYCLE_STATE_CREATINGZLIFECYCLE_STATE_UPDATINGZLIFECYCLE_STATE_ACTIVEZLIFECYCLE_STATE_DELETINGZLIFECYCLE_STATE_DELETEDZLIFECYCLE_STATE_FAILEDr/   staticmethodr1   propertyr   setterr   r   r   r   r   r   r   r   r   r   r   r   rJ   rN   rO   r-   r-   r-   r.   r      s    p


























r   N)Zoci.utilr   r   r   Zoci.decoratorsr   objectr   r-   r-   r-   r.   <module>   s   