o
    ɶd                     @   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                   @   sx   e 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dd Zdd Zdd ZdS )	Operationz
    The operation object.
    	PROCEDUREAPIc                 K   s(   ddd| _ ddd| _d| _d| _dS )ar  
        Initializes a new Operation 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.data_integration.models.OperationFromProcedure`
        * :class:`~oci.data_integration.models.OperationFromApi`

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

        :param model_type:
            The value to assign to the model_type property of this Operation.
            Allowed values for this property are: "PROCEDURE", "API"
        :type model_type: str

        :param metadata:
            The value to assign to the metadata property of this Operation.
        :type metadata: oci.data_integration.models.ObjectMetadata

        strZObjectMetadata)
model_typemetadata	modelTyper   N)Zswagger_typesZattribute_map_model_type	_metadata)selfkwargs r   Iusr/lib/python3.10/site-packages/oci/data_integration/models/operation.py__init__   s   
zOperation.__init__c                 C   s$   | d }|dkr
dS |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OperationFromProcedurer   ZOperationFromApir   r   )Zobject_dictionarytyper   r   r   get_subtype;   s   zOperation.get_subtypec                 C      | j S )z
        **[Required]** Gets the model_type of this Operation.
        The operation type.

        Allowed values for this property are: "PROCEDURE", "API"


        :return: The model_type of this Operation.
        :rtype: str
        )r   r   r   r   r   r
   K   s   zOperation.model_typec                 C   s*   ddg}t ||std||| _dS )z
        Sets the model_type of this Operation.
        The operation type.


        :param model_type: The model_type of this Operation.
        :type: str
        r   r   z:Invalid value for `model_type`, must be None or one of {0}N)r   
ValueErrorformatr   )r   r
   Zallowed_valuesr   r   r   r
   Y   s   


c                 C   r   )z
        Gets the metadata of this Operation.

        :return: The metadata of this Operation.
        :rtype: oci.data_integration.models.ObjectMetadata
        r   r   r   r   r   r   k   s   zOperation.metadatac                 C   s
   || _ dS )z
        Sets the metadata of this Operation.

        :param metadata: The metadata of this Operation.
        :type: oci.data_integration.models.ObjectMetadata
        Nr   )r   r   r   r   r   r   u   s   
c                 C   s   t | S N)r   r   r   r   r   __repr__   s   zOperation.__repr__c                 C   s   |d u rdS | j |j kS )NF)__dict__r   otherr   r   r   __eq__   s   zOperation.__eq__c                 C   s
   | |k S r   r   r   r   r   r   __ne__   s   
zOperation.__ne__N)__name__
__module____qualname____doc__ZMODEL_TYPE_PROCEDUREZMODEL_TYPE_APIr   staticmethodr   propertyr
   setterr   r   r    r!   r   r   r   r   r      s$    !



	
	r   N)Zoci.utilr   r   r   Zoci.decoratorsr   objectr   r   r   r   r   <module>   s   