o
    ɶdP                     @   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
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/d0 Zejd1d0 Zed2d3 Zejd4d3 Zed5d6 Zejd7d6 Zd8d9 Zd:d; Z d<d= Z!d>S )?
ConnectionzK
    The properties that define a connection to external repositories.
    GITHUB_ACCESS_TOKENGITLAB_ACCESS_TOKENGITLAB_SERVER_ACCESS_TOKENBITBUCKET_SERVER_ACCESS_TOKENBITBUCKET_CLOUD_APP_PASSWORDVBS_ACCESS_TOKEN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 Connection 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.BitbucketServerAccessTokenConnection`
        * :class:`~oci.devops.models.GitlabAccessTokenConnection`
        * :class:`~oci.devops.models.GithubAccessTokenConnection`
        * :class:`~oci.devops.models.BitbucketCloudAppPasswordConnection`
        * :class:`~oci.devops.models.GitlabServerAccessTokenConnection`
        * :class:`~oci.devops.models.VbsAccessTokenConnection`

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

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

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

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

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

        :param connection_type:
            The value to assign to the connection_type property of this Connection.
            Allowed values for this property are: "GITHUB_ACCESS_TOKEN", "GITLAB_ACCESS_TOKEN", "GITLAB_SERVER_ACCESS_TOKEN", "BITBUCKET_SERVER_ACCESS_TOKEN", "BITBUCKET_CLOUD_APP_PASSWORD", "VBS_ACCESS_TOKEN", 'UNKNOWN_ENUM_VALUE'.
            Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
        :type connection_type: str

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

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

        :param last_connection_validation_result:
            The value to assign to the last_connection_validation_result property of this Connection.
        :type last_connection_validation_result: oci.devops.models.ConnectionValidationResult

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

        :param lifecycle_state:
            The value to assign to the lifecycle_state property of this Connection.
            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 freeform_tags:
            The value to assign to the freeform_tags property of this Connection.
        :type freeform_tags: dict(str, str)

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

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

        strdatetimeZConnectionValidationResultzdict(str, str)zdict(str, dict(str, object)))iddescriptiondisplay_namecompartment_id
project_idconnection_typetime_createdtime_updated!last_connection_validation_resultlifecycle_detailslifecycle_statefreeform_tagsdefined_tagssystem_tagsr   r   ZdisplayNameZcompartmentIdZ	projectIdconnectionTypeZtimeCreatedZtimeUpdatedZlastConnectionValidationResultZlifecycleDetailsZlifecycleStateZfreeformTagsZdefinedTagsZ
systemTagsN)Zswagger_typesZattribute_map_id_description_display_name_compartment_id_project_id_connection_type_time_created_time_updated"_last_connection_validation_result_lifecycle_details_lifecycle_state_freeform_tags_defined_tags_system_tags)selfkwargs r0   @usr/lib/python3.10/site-packages/oci/devops/models/connection.py__init__2   sX   L
zConnection.__init__c                 C   sT   | 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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$BitbucketServerAccessTokenConnectionr   ZGitlabAccessTokenConnectionr   ZGithubAccessTokenConnectionr   Z#BitbucketCloudAppPasswordConnectionr	   Z!GitlabServerAccessTokenConnectionr   ZVbsAccessTokenConnectionr   r0   )Zobject_dictionarytyper0   r0   r1   get_subtype   s   zConnection.get_subtypec                 C      | j S )z
        **[Required]** Gets the id of this Connection.
        Unique identifier that is immutable on creation.


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


        :param id: The id of this Connection.
        :type: str
        Nr6   )r.   r   r0   r0   r1   r         

c                 C   r5   )z
        Gets the description of this Connection.
        Optional description about the connection.


        :return: The description of this Connection.
        :rtype: str
        r!   r7   r0   r0   r1   r      r8   zConnection.descriptionc                 C   r9   )z
        Sets the description of this Connection.
        Optional description about the connection.


        :param description: The description of this Connection.
        :type: str
        Nr;   )r.   r   r0   r0   r1   r      r:   c                 C   r5   )a  
        Gets the display_name of this Connection.
        Connection display name, which can be renamed and is not necessarily unique. Avoid entering confidential information.


        :return: The display_name of this Connection.
        :rtype: str
        r"   r7   r0   r0   r1   r      r8   zConnection.display_namec                 C   r9   )a  
        Sets the display_name of this Connection.
        Connection display name, which can be renamed and is not necessarily unique. Avoid entering confidential information.


        :param display_name: The display_name of this Connection.
        :type: str
        Nr<   )r.   r   r0   r0   r1   r     r:   c                 C   r5   )z
        **[Required]** Gets the compartment_id of this Connection.
        The OCID of the compartment containing the connection.


        :return: The compartment_id of this Connection.
        :rtype: str
        r#   r7   r0   r0   r1   r     r8   zConnection.compartment_idc                 C   r9   )z
        Sets the compartment_id of this Connection.
        The OCID of the compartment containing the connection.


        :param compartment_id: The compartment_id of this Connection.
        :type: str
        Nr=   )r.   r   r0   r0   r1   r     r:   c                 C   r5   )z
        **[Required]** Gets the project_id of this Connection.
        The OCID of the DevOps project.


        :return: The project_id of this Connection.
        :rtype: str
        r$   r7   r0   r0   r1   r   *  r8   zConnection.project_idc                 C   r9   )z
        Sets the project_id of this Connection.
        The OCID of the DevOps project.


        :param project_id: The project_id of this Connection.
        :type: str
        Nr>   )r.   r   r0   r0   r1   r   6  r:   c                 C   r5   )a   
        **[Required]** Gets the connection_type of this Connection.
        The type of connection.

        Allowed values for this property are: "GITHUB_ACCESS_TOKEN", "GITLAB_ACCESS_TOKEN", "GITLAB_SERVER_ACCESS_TOKEN", "BITBUCKET_SERVER_ACCESS_TOKEN", "BITBUCKET_CLOUD_APP_PASSWORD", "VBS_ACCESS_TOKEN", 'UNKNOWN_ENUM_VALUE'.
        Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.


        :return: The connection_type of this Connection.
        :rtype: str
        )r%   r7   r0   r0   r1   r   B     zConnection.connection_typec                 C   s    g d}t ||sd}|| _dS )z
        Sets the connection_type of this Connection.
        The type of connection.


        :param connection_type: The connection_type of this Connection.
        :type: str
        )r   r   r	   r
   r   r   UNKNOWN_ENUM_VALUEN)r   r%   )r.   r   allowed_valuesr0   r0   r1   r   Q     


c                 C   r5   )a  
        Gets the time_created of this Connection.
        The time the connection was created. Format defined by `RFC3339`__.

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


        :return: The time_created of this Connection.
        :rtype: datetime
        r&   r7   r0   r0   r1   r   `     zConnection.time_createdc                 C   r9   )a  
        Sets the time_created of this Connection.
        The time the connection was created. Format defined by `RFC3339`__.

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


        :param time_created: The time_created of this Connection.
        :type: datetime
        NrC   )r.   r   r0   r0   r1   r   n     
c                 C   r5   )a  
        Gets the time_updated of this Connection.
        The time the connection was updated. Format defined by `RFC3339`__.

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


        :return: The time_updated of this Connection.
        :rtype: datetime
        r'   r7   r0   r0   r1   r   |  rD   zConnection.time_updatedc                 C   r9   )a  
        Sets the time_updated of this Connection.
        The time the connection was updated. Format defined by `RFC3339`__.

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


        :param time_updated: The time_updated of this Connection.
        :type: datetime
        NrF   )r.   r   r0   r0   r1   r     rE   c                 C   r5   )z
        Gets the last_connection_validation_result of this Connection.

        :return: The last_connection_validation_result of this Connection.
        :rtype: oci.devops.models.ConnectionValidationResult
        r(   r7   r0   r0   r1   r     s   z,Connection.last_connection_validation_resultc                 C   r9   )z
        Sets the last_connection_validation_result of this Connection.

        :param last_connection_validation_result: The last_connection_validation_result of this Connection.
        :type: oci.devops.models.ConnectionValidationResult
        NrG   )r.   r   r0   r0   r1   r     s   
c                 C   r5   )a%  
        Gets the lifecycle_details of this Connection.
        A detailed message describing the current state. For example, can be used to provide actionable information for a resource in Failed state.


        :return: The lifecycle_details of this Connection.
        :rtype: str
        r)   r7   r0   r0   r1   r     r8   zConnection.lifecycle_detailsc                 C   r9   )a5  
        Sets the lifecycle_details of this Connection.
        A detailed message describing the current state. For example, can be used to provide actionable information for a resource in Failed state.


        :param lifecycle_details: The lifecycle_details of this Connection.
        :type: str
        NrH   )r.   r   r0   r0   r1   r     r:   c                 C   r5   )as  
        Gets the lifecycle_state of this Connection.
        The current state of the connection.

        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 Connection.
        :rtype: str
        )r*   r7   r0   r0   r1   r     r?   zConnection.lifecycle_statec                 C   s    ddg}t ||sd}|| _dS )z
        Sets the lifecycle_state of this Connection.
        The current state of the connection.


        :param lifecycle_state: The lifecycle_state of this Connection.
        :type: str
        r   r   r@   N)r   r*   )r.   r   rA   r0   r0   r1   r     rB   c                 C   r5   )a  
        Gets the freeform_tags of this Connection.
        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 Connection.
        :rtype: dict(str, str)
        r+   r7   r0   r0   r1   r     rD   zConnection.freeform_tagsc                 C   r9   )a  
        Sets the freeform_tags of this Connection.
        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 Connection.
        :type: dict(str, str)
        NrI   )r.   r   r0   r0   r1   r     rE   c                 C   r5   )a  
        Gets the defined_tags of this Connection.
        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 Connection.
        :rtype: dict(str, dict(str, object))
        r,   r7   r0   r0   r1   r     rD   zConnection.defined_tagsc                 C   r9   )a  
        Sets the defined_tags of this Connection.
        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 Connection.
        :type: dict(str, dict(str, object))
        NrJ   )r.   r   r0   r0   r1   r     rE   c                 C   r5   )a  
        Gets the system_tags of this Connection.
        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 Connection.
        :rtype: dict(str, dict(str, object))
        r-   r7   r0   r0   r1   r     rD   zConnection.system_tagsc                 C   r9   )a  
        Sets the system_tags of this Connection.
        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 Connection.
        :type: dict(str, dict(str, object))
        NrK   )r.   r   r0   r0   r1   r   (  rE   c                 C   s   t | S N)r   r7   r0   r0   r1   __repr__6  s   zConnection.__repr__c                 C   s   |d u rdS | j |j kS )NF)__dict__r.   otherr0   r0   r1   __eq__9  s   zConnection.__eq__c                 C   s
   | |k S rL   r0   rO   r0   r0   r1   __ne__?  s   
zConnection.__ne__N)"__name__
__module____qualname____doc__Z#CONNECTION_TYPE_GITHUB_ACCESS_TOKENZ#CONNECTION_TYPE_GITLAB_ACCESS_TOKENZ*CONNECTION_TYPE_GITLAB_SERVER_ACCESS_TOKENZ-CONNECTION_TYPE_BITBUCKET_SERVER_ACCESS_TOKENZ,CONNECTION_TYPE_BITBUCKET_CLOUD_APP_PASSWORDZ CONNECTION_TYPE_VBS_ACCESS_TOKENZLIFECYCLE_STATE_ACTIVEZLIFECYCLE_STATE_DELETINGr2   staticmethodr4   propertyr   setterr   r   r   r   r   r   r   r   r   r   r   r   r   rM   rQ   rR   r0   r0   r0   r1   r      s    |

















	
	









r   N)Zoci.utilr   r   r   Zoci.decoratorsr   objectr   r0   r0   r0   r1   <module>   s   