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                   @   s^   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
dd Zdd Zdd ZdS )TaskDetailsa  
    An object that represents a task within the flow defined by the service connector.
    An example task is a filter for error logs.
    For more information about flows defined by service connectors, see
    `Service Connector Hub Overview`__.
    For configuration instructions, see
    `To create a service connector`__.

    __ https://docs.cloud.oracle.com/iaas/Content/service-connector-hub/overview.htm
    __ https://docs.cloud.oracle.com/iaas/Content/service-connector-hub/managingconnectors.htm#create
    functionlogRulec                 K   s   ddi| _ ddi| _d| _dS )a  
        Initializes a new TaskDetails 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.sch.models.FunctionTaskDetails`
        * :class:`~oci.sch.models.LogRuleTaskDetails`

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

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

        kindstrN)Zswagger_typesZattribute_map_kind)selfkwargs r   ?usr/lib/python3.10/site-packages/oci/sch/models/task_details.py__init__"   s
   
zTaskDetails.__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FunctionTaskDetailsr   ZLogRuleTaskDetailsr   r   )Zobject_dictionarytyper   r   r   get_subtype=   s   zTaskDetails.get_subtypec                 C   s   | j S )ab  
        **[Required]** Gets the kind of this TaskDetails.
        The type descriminator.

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


        :return: The kind of this TaskDetails.
        :rtype: str
        )r   r   r   r   r   r	   M   s   zTaskDetails.kindc                 C   s    ddg}t ||sd}|| _dS )z
        Sets the kind of this TaskDetails.
        The type descriminator.


        :param kind: The kind of this TaskDetails.
        :type: str
        r   r   ZUNKNOWN_ENUM_VALUEN)r   r   )r   r	   Zallowed_valuesr   r   r   r	   \   s   


c                 C   s   t | S N)r   r   r   r   r   __repr__k   s   zTaskDetails.__repr__c                 C   s   |d u rdS | j |j kS )NF)__dict__r   otherr   r   r   __eq__n   s   zTaskDetails.__eq__c                 C   s
   | |k S r   r   r   r   r   r   __ne__t   s   
zTaskDetails.__ne__N)__name__
__module____qualname____doc__ZKIND_FUNCTIONZKIND_LOG_RULEr   staticmethodr   propertyr	   setterr   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   