o
    ɶdL                     @   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	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d0d1 Zejd2d1 Zed3d4 Zejd5d4 Zed6d7 Zejd8d7 Zd9d: Z d;d< Z!d=d> Z"d?S )@TriggerzA
    Trigger the deployment pipeline to deploy the artifact.
    GITHUBGITLABGITLAB_SERVERBITBUCKET_CLOUDBITBUCKET_SERVERVBSDEVOPS_CODE_REPOSITORYACTIVEDELETINGc                 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| _d| _d| _dS )a  
        Initializes a new Trigger 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.devops.models.GitlabTrigger`
        * :class:`~oci.devops.models.VbsTrigger`
        * :class:`~oci.devops.models.BitbucketServerTrigger`
        * :class:`~oci.devops.models.GitlabServerTrigger`
        * :class:`~oci.devops.models.GithubTrigger`
        * :class:`~oci.devops.models.DevopsCodeRepositoryTrigger`
        * :class:`~oci.devops.models.BitbucketCloudTrigger`

        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 Trigger.
        :type id: str

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

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

        :param project_id:
            The value to assign to the project_id property of this Trigger.
        :type project_id: str

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

        :param trigger_source:
            The value to assign to the trigger_source property of this Trigger.
            Allowed values for this property are: "GITHUB", "GITLAB", "GITLAB_SERVER", "BITBUCKET_CLOUD", "BITBUCKET_SERVER", "VBS", "DEVOPS_CODE_REPOSITORY", 'UNKNOWN_ENUM_VALUE'.
            Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
        :type trigger_source: str

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

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

        :param lifecycle_state:
            The value to assign to the lifecycle_state property of this Trigger.
            Allowed values for this property are: "ACTIVE", "DELETING", '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 Trigger.
        :type lifecycle_details: str

        :param actions:
            The value to assign to the actions property of this Trigger.
        :type actions: list[oci.devops.models.TriggerAction]

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

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

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

        strdatetimezlist[TriggerAction]zdict(str, str)zdict(str, dict(str, object)))iddisplay_namedescription
project_idcompartment_idtrigger_sourcetime_createdtime_updatedlifecycle_statelifecycle_detailsactionsfreeform_tagsdefined_tagssystem_tagsr   ZdisplayNamer   Z	projectIdZcompartmentIdtriggerSourceZtimeCreatedZtimeUpdatedZlifecycleStateZlifecycleDetailsr   ZfreeformTagsZdefinedTagsZ
systemTagsN)Zswagger_typesZattribute_map_id_display_name_description_project_id_compartment_id_trigger_source_time_created_time_updated_lifecycle_state_lifecycle_details_actions_freeform_tags_defined_tags_system_tags)selfkwargs r1   =usr/lib/python3.10/site-packages/oci/devops/models/trigger.py__init__6   sX   M
zTrigger.__init__c                 C   s`   | d }|dkr
dS |dkrdS |dkrdS |dkrd	S |d
kr"dS |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GitlabTriggerr   Z
VbsTriggerr   ZBitbucketServerTriggerr	   ZGitlabServerTriggerr   ZGithubTriggerr   ZDevopsCodeRepositoryTriggerr
   ZBitbucketCloudTriggerr   r1   )Zobject_dictionarytyper1   r1   r2   get_subtype   s    zTrigger.get_subtypec                 C      | j S )z
        **[Required]** Gets the id of this Trigger.
        Unique identifier that is immutable on creation.


        :return: The id of this Trigger.
        :rtype: str
        r!   r/   r1   r1   r2   r         
z
Trigger.idc                 C   
   || _ dS )z
        Sets the id of this Trigger.
        Unique identifier that is immutable on creation.


        :param id: The id of this Trigger.
        :type: str
        Nr7   )r/   r   r1   r1   r2   r         

c                 C   r6   )z
        Gets the display_name of this Trigger.
        Trigger display name. Avoid entering confidential information.


        :return: The display_name of this Trigger.
        :rtype: str
        r"   r8   r1   r1   r2   r      r9   zTrigger.display_namec                 C   r:   )z
        Sets the display_name of this Trigger.
        Trigger display name. Avoid entering confidential information.


        :param display_name: The display_name of this Trigger.
        :type: str
        Nr<   )r/   r   r1   r1   r2   r      r;   c                 C   r6   )z
        Gets the description of this Trigger.
        Description about the trigger.


        :return: The description of this Trigger.
        :rtype: str
        r#   r8   r1   r1   r2   r     r9   zTrigger.descriptionc                 C   r:   )z
        Sets the description of this Trigger.
        Description about the trigger.


        :param description: The description of this Trigger.
        :type: str
        Nr=   )r/   r   r1   r1   r2   r     r;   c                 C   r6   )z
        **[Required]** Gets the project_id of this Trigger.
        The OCID of the DevOps project to which the trigger belongs to.


        :return: The project_id of this Trigger.
        :rtype: str
        r$   r8   r1   r1   r2   r     r9   zTrigger.project_idc                 C   r:   )z
        Sets the project_id of this Trigger.
        The OCID of the DevOps project to which the trigger belongs to.


        :param project_id: The project_id of this Trigger.
        :type: str
        Nr>   )r/   r   r1   r1   r2   r   &  r;   c                 C   r6   )z
        **[Required]** Gets the compartment_id of this Trigger.
        The OCID of the compartment that contains the trigger.


        :return: The compartment_id of this Trigger.
        :rtype: str
        r%   r8   r1   r1   r2   r   2  r9   zTrigger.compartment_idc                 C   r:   )z
        Sets the compartment_id of this Trigger.
        The OCID of the compartment that contains the trigger.


        :param compartment_id: The compartment_id of this Trigger.
        :type: str
        Nr?   )r/   r   r1   r1   r2   r   >  r;   c                 C   r6   )a  
        **[Required]** Gets the trigger_source of this Trigger.
        Source of the trigger.

        Allowed values for this property are: "GITHUB", "GITLAB", "GITLAB_SERVER", "BITBUCKET_CLOUD", "BITBUCKET_SERVER", "VBS", "DEVOPS_CODE_REPOSITORY", 'UNKNOWN_ENUM_VALUE'.
        Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.


        :return: The trigger_source of this Trigger.
        :rtype: str
        )r&   r8   r1   r1   r2   r   J     zTrigger.trigger_sourcec                 C   s    g d}t ||sd}|| _dS )z
        Sets the trigger_source of this Trigger.
        Source of the trigger.


        :param trigger_source: The trigger_source of this Trigger.
        :type: str
        )r   r   r	   r
   r   r   r   UNKNOWN_ENUM_VALUEN)r   r&   )r/   r   allowed_valuesr1   r1   r2   r   Y     


c                 C   r6   )a	  
        Gets the time_created of this Trigger.
        The time the trigger was created. Format defined by `RFC3339`__.

        __ https://datatracker.ietf.org/doc/html/rfc3339


        :return: The time_created of this Trigger.
        :rtype: datetime
        r'   r8   r1   r1   r2   r   h     zTrigger.time_createdc                 C   r:   )a  
        Sets the time_created of this Trigger.
        The time the trigger was created. Format defined by `RFC3339`__.

        __ https://datatracker.ietf.org/doc/html/rfc3339


        :param time_created: The time_created of this Trigger.
        :type: datetime
        NrD   )r/   r   r1   r1   r2   r   v     
c                 C   r6   )a	  
        Gets the time_updated of this Trigger.
        The time the trigger was updated. Format defined by `RFC3339`__.

        __ https://datatracker.ietf.org/doc/html/rfc3339


        :return: The time_updated of this Trigger.
        :rtype: datetime
        r(   r8   r1   r1   r2   r     rE   zTrigger.time_updatedc                 C   r:   )a  
        Sets the time_updated of this Trigger.
        The time the trigger was updated. Format defined by `RFC3339`__.

        __ https://datatracker.ietf.org/doc/html/rfc3339


        :param time_updated: The time_updated of this Trigger.
        :type: datetime
        NrG   )r/   r   r1   r1   r2   r     rF   c                 C   r6   )aj  
        Gets the lifecycle_state of this Trigger.
        The current state of the trigger.

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


        :return: The lifecycle_state of this Trigger.
        :rtype: str
        )r)   r8   r1   r1   r2   r     r@   zTrigger.lifecycle_statec                 C   s    ddg}t ||sd}|| _dS )z
        Sets the lifecycle_state of this Trigger.
        The current state of the trigger.


        :param lifecycle_state: The lifecycle_state of this Trigger.
        :type: str
        r   r   rA   N)r   r)   )r/   r   rB   r1   r1   r2   r     rC   c                 C   r6   )a%  
        Gets the lifecycle_details of this Trigger.
        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 Trigger.
        :rtype: str
        r*   r8   r1   r1   r2   r     r9   zTrigger.lifecycle_detailsc                 C   r:   )a5  
        Sets the lifecycle_details of this Trigger.
        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 Trigger.
        :type: str
        NrH   )r/   r   r1   r1   r2   r     r;   c                 C   r6   )z
        **[Required]** Gets the actions of this Trigger.
        The list of actions that are to be performed for this trigger.


        :return: The actions of this Trigger.
        :rtype: list[oci.devops.models.TriggerAction]
        r+   r8   r1   r1   r2   r     r9   zTrigger.actionsc                 C   r:   )z
        Sets the actions of this Trigger.
        The list of actions that are to be performed for this trigger.


        :param actions: The actions of this Trigger.
        :type: list[oci.devops.models.TriggerAction]
        NrI   )r/   r   r1   r1   r2   r     r;   c                 C   r6   )a  
        Gets the freeform_tags of this Trigger.
        Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only.  See `Resource Tags`__. Example: `{"bar-key": "value"}`

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


        :return: The freeform_tags of this Trigger.
        :rtype: dict(str, str)
        r,   r8   r1   r1   r2   r     rE   zTrigger.freeform_tagsc                 C   r:   )a  
        Sets the freeform_tags of this Trigger.
        Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only.  See `Resource Tags`__. Example: `{"bar-key": "value"}`

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


        :param freeform_tags: The freeform_tags of this Trigger.
        :type: dict(str, str)
        NrJ   )r/   r   r1   r1   r2   r     rF   c                 C   r6   )a  
        Gets the defined_tags of this Trigger.
        Defined tags for this resource. Each key is predefined and scoped to a namespace. See `Resource Tags`__. Example: `{"foo-namespace": {"bar-key": "value"}}`

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


        :return: The defined_tags of this Trigger.
        :rtype: dict(str, dict(str, object))
        r-   r8   r1   r1   r2   r   
  rE   zTrigger.defined_tagsc                 C   r:   )a  
        Sets the defined_tags of this Trigger.
        Defined tags for this resource. Each key is predefined and scoped to a namespace. See `Resource Tags`__. Example: `{"foo-namespace": {"bar-key": "value"}}`

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


        :param defined_tags: The defined_tags of this Trigger.
        :type: dict(str, dict(str, object))
        NrK   )r/   r   r1   r1   r2   r     rF   c                 C   r6   )a  
        Gets the system_tags of this Trigger.
        Usage of system tag keys. These predefined keys are scoped to namespaces. See `Resource Tags`__. Example: `{"orcl-cloud": {"free-tier-retained": "true"}}`

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


        :return: The system_tags of this Trigger.
        :rtype: dict(str, dict(str, object))
        r.   r8   r1   r1   r2   r   &  rE   zTrigger.system_tagsc                 C   r:   )a  
        Sets the system_tags of this Trigger.
        Usage of system tag keys. These predefined keys are scoped to namespaces. See `Resource Tags`__. Example: `{"orcl-cloud": {"free-tier-retained": "true"}}`

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


        :param system_tags: The system_tags of this Trigger.
        :type: dict(str, dict(str, object))
        NrL   )r/   r   r1   r1   r2   r   4  rF   c                 C   s   t | S N)r   r8   r1   r1   r2   __repr__B  s   zTrigger.__repr__c                 C   s   |d u rdS | j |j kS )NF)__dict__r/   otherr1   r1   r2   __eq__E  s   zTrigger.__eq__c                 C   s
   | |k S rM   r1   rP   r1   r1   r2   __ne__K  s   
zTrigger.__ne__N)#__name__
__module____qualname____doc__ZTRIGGER_SOURCE_GITHUBZTRIGGER_SOURCE_GITLABZTRIGGER_SOURCE_GITLAB_SERVERZTRIGGER_SOURCE_BITBUCKET_CLOUDZTRIGGER_SOURCE_BITBUCKET_SERVERZTRIGGER_SOURCE_VBSZ%TRIGGER_SOURCE_DEVOPS_CODE_REPOSITORYZLIFECYCLE_STATE_ACTIVEZLIFECYCLE_STATE_DELETINGr3   staticmethodr5   propertyr   setterr   r   r   r   r   r   r   r   r   r   r   r   r   rN   rR   rS   r1   r1   r1   r2   r      s    }




























r   N)Zoci.utilr   r   r   Zoci.decoratorsr   objectr   r1   r1   r1   r2   <module>   s   