o
    ɶd9                     @   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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d'd& Zed(d) Zejd*d) Zd+d, Zd-d. Zd/d0 Zd1S )2ProjectSummaryz!
    Summary of the project.
    c                 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 ProjectSummary object with values from keyword arguments.
        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 ProjectSummary.
        :type id: str

        :param name:
            The value to assign to the name property of this ProjectSummary.
        :type name: str

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

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

        :param namespace:
            The value to assign to the namespace property of this ProjectSummary.
        :type namespace: str

        :param notification_config:
            The value to assign to the notification_config property of this ProjectSummary.
        :type notification_config: oci.devops.models.NotificationConfig

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

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

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

        :param lifecycle_state:
            The value to assign to the lifecycle_state property of this ProjectSummary.
        :type lifecycle_state: str

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

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

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

        strZNotificationConfigdatetimezdict(str, str)zdict(str, dict(str, object)))idnamedescriptioncompartment_id	namespacenotification_configtime_createdtime_updatedlifecycle_detailslifecycle_statefreeform_tagsdefined_tagssystem_tagsr	   r
   r   ZcompartmentIdr   ZnotificationConfigZtimeCreatedZtimeUpdatedZlifecycleDetailsZlifecycleStateZfreeformTagsZdefinedTagsZ
systemTagsN)Zswagger_typesZattribute_map_id_name_description_compartment_id
_namespace_notification_config_time_created_time_updated_lifecycle_details_lifecycle_state_freeform_tags_defined_tags_system_tags)selfkwargs r%   Eusr/lib/python3.10/site-packages/oci/devops/models/project_summary.py__init__   sR   ;
zProjectSummary.__init__c                 C      | j S )z
        **[Required]** Gets the id of this ProjectSummary.
        Unique identifier that is immutable on creation.


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


        :param id: The id of this ProjectSummary.
        :type: str
        Nr)   )r#   r	   r%   r%   r&   r	         

c                 C   r(   )z
        **[Required]** Gets the name of this ProjectSummary.
        Project name (case-sensitive).


        :return: The name of this ProjectSummary.
        :rtype: str
        r   r*   r%   r%   r&   r
      r+   zProjectSummary.namec                 C   r,   )z
        Sets the name of this ProjectSummary.
        Project name (case-sensitive).


        :param name: The name of this ProjectSummary.
        :type: str
        Nr.   )r#   r
   r%   r%   r&   r
      r-   c                 C   r(   )z
        Gets the description of this ProjectSummary.
        Project description.


        :return: The description of this ProjectSummary.
        :rtype: str
        r   r*   r%   r%   r&   r      r+   zProjectSummary.descriptionc                 C   r,   )z
        Sets the description of this ProjectSummary.
        Project description.


        :param description: The description of this ProjectSummary.
        :type: str
        Nr/   )r#   r   r%   r%   r&   r      r-   c                 C   r(   )z
        **[Required]** Gets the compartment_id of this ProjectSummary.
        The OCID of the compartment where the project is created.


        :return: The compartment_id of this ProjectSummary.
        :rtype: str
        r   r*   r%   r%   r&   r      r+   zProjectSummary.compartment_idc                 C   r,   )z
        Sets the compartment_id of this ProjectSummary.
        The OCID of the compartment where the project is created.


        :param compartment_id: The compartment_id of this ProjectSummary.
        :type: str
        Nr0   )r#   r   r%   r%   r&   r      r-   c                 C   r(   )z
        Gets the namespace of this ProjectSummary.
        Namespace associated with the project.


        :return: The namespace of this ProjectSummary.
        :rtype: str
        r   r*   r%   r%   r&   r      r+   zProjectSummary.namespacec                 C   r,   )z
        Sets the namespace of this ProjectSummary.
        Namespace associated with the project.


        :param namespace: The namespace of this ProjectSummary.
        :type: str
        Nr1   )r#   r   r%   r%   r&   r      r-   c                 C   r(   )z
        Gets the notification_config of this ProjectSummary.

        :return: The notification_config of this ProjectSummary.
        :rtype: oci.devops.models.NotificationConfig
        r   r*   r%   r%   r&   r      s   z"ProjectSummary.notification_configc                 C   r,   )z
        Sets the notification_config of this ProjectSummary.

        :param notification_config: The notification_config of this ProjectSummary.
        :type: oci.devops.models.NotificationConfig
        Nr2   )r#   r   r%   r%   r&   r      s   
c                 C   r(   )a  
        Gets the time_created of this ProjectSummary.
        Time the project was created. Format defined by `RFC3339`__.

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


        :return: The time_created of this ProjectSummary.
        :rtype: datetime
        r   r*   r%   r%   r&   r        zProjectSummary.time_createdc                 C   r,   )a  
        Sets the time_created of this ProjectSummary.
        Time the project was created. Format defined by `RFC3339`__.

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


        :param time_created: The time_created of this ProjectSummary.
        :type: datetime
        Nr3   )r#   r   r%   r%   r&   r        
c                 C   r(   )a  
        Gets the time_updated of this ProjectSummary.
        Time the project was updated. Format defined by `RFC3339`__.

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


        :return: The time_updated of this ProjectSummary.
        :rtype: datetime
        r   r*   r%   r%   r&   r   "  r4   zProjectSummary.time_updatedc                 C   r,   )a  
        Sets the time_updated of this ProjectSummary.
        Time the project was updated. Format defined by `RFC3339`__.

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


        :param time_updated: The time_updated of this ProjectSummary.
        :type: datetime
        Nr6   )r#   r   r%   r%   r&   r   0  r5   c                 C   r(   )a-  
        Gets the lifecycle_details of this ProjectSummary.
        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 ProjectSummary.
        :rtype: str
        r   r*   r%   r%   r&   r   >  r+   z ProjectSummary.lifecycle_detailsc                 C   r,   )a=  
        Sets the lifecycle_details of this ProjectSummary.
        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 ProjectSummary.
        :type: str
        Nr7   )r#   r   r%   r%   r&   r   J  r-   c                 C   r(   )z
        Gets the lifecycle_state of this ProjectSummary.
        The current state of the project.


        :return: The lifecycle_state of this ProjectSummary.
        :rtype: str
        r   r*   r%   r%   r&   r   V  r+   zProjectSummary.lifecycle_statec                 C   r,   )z
        Sets the lifecycle_state of this ProjectSummary.
        The current state of the project.


        :param lifecycle_state: The lifecycle_state of this ProjectSummary.
        :type: str
        Nr8   )r#   r   r%   r%   r&   r   b  r-   c                 C   r(   )a  
        Gets the freeform_tags of this ProjectSummary.
        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 ProjectSummary.
        :rtype: dict(str, str)
        r    r*   r%   r%   r&   r   n  r4   zProjectSummary.freeform_tagsc                 C   r,   )a  
        Sets the freeform_tags of this ProjectSummary.
        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 ProjectSummary.
        :type: dict(str, str)
        Nr9   )r#   r   r%   r%   r&   r   |  r5   c                 C   r(   )a  
        Gets the defined_tags of this ProjectSummary.
        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 ProjectSummary.
        :rtype: dict(str, dict(str, object))
        r!   r*   r%   r%   r&   r     r4   zProjectSummary.defined_tagsc                 C   r,   )a  
        Sets the defined_tags of this ProjectSummary.
        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 ProjectSummary.
        :type: dict(str, dict(str, object))
        Nr:   )r#   r   r%   r%   r&   r     r5   c                 C   r(   )a  
        Gets the system_tags of this ProjectSummary.
        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 ProjectSummary.
        :rtype: dict(str, dict(str, object))
        r"   r*   r%   r%   r&   r     r4   zProjectSummary.system_tagsc                 C   r,   )a  
        Sets the system_tags of this ProjectSummary.
        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 ProjectSummary.
        :type: dict(str, dict(str, object))
        Nr;   )r#   r   r%   r%   r&   r     r5   c                 C   s   t | S N)r   r*   r%   r%   r&   __repr__  s   zProjectSummary.__repr__c                 C   s   |d u rdS | j |j kS )NF)__dict__r#   otherr%   r%   r&   __eq__  s   zProjectSummary.__eq__c                 C   s
   | |k S r<   r%   r?   r%   r%   r&   __ne__  s   
zProjectSummary.__ne__N)__name__
__module____qualname____doc__r'   propertyr	   setterr
   r   r   r   r   r   r   r   r   r   r   r   r=   rA   rB   r%   r%   r%   r&   r      st    h










	
	













r   N)Zoci.utilr   r   r   Zoci.decoratorsr   objectr   r%   r%   r%   r&   <module>   s   