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ZdZd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d/d0 Zd1d2 Zd3d4 Zd5S )6	Migrationza
    A top-level container to track all aspects of a long-running migration workflow to OCI.
    CREATINGUPDATINGNEEDS_ATTENTIONACTIVEDELETINGDELETEDFAILEDc                 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S )a  
        Initializes a new Migration 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 Migration.
        :type id: str

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

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

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

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

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

        :param replication_schedule_id:
            The value to assign to the replication_schedule_id property of this Migration.
        :type replication_schedule_id: str

        :param is_completed:
            The value to assign to the is_completed property of this Migration.
        :type is_completed: bool

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

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

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

        strdatetimeboolzdict(str, str)zdict(str, dict(str, object)))iddisplay_namecompartment_idlifecycle_statelifecycle_detailstime_createdtime_updatedreplication_schedule_idis_completedfreeform_tagsdefined_tagssystem_tagsr   ZdisplayNameZcompartmentIdZlifecycleStateZlifecycleDetailsZtimeCreatedZtimeUpdatedZreplicationScheduleIdZisCompletedZfreeformTagsZdefinedTagsZ
systemTagsN)Zswagger_typesZattribute_map_id_display_name_compartment_id_lifecycle_state_lifecycle_details_time_created_time_updated_replication_schedule_id_is_completed_freeform_tags_defined_tags_system_tags)selfkwargs r+   Iusr/lib/python3.10/site-packages/oci/cloud_migrations/models/migration.py__init__.   sL   9
zMigration.__init__c                 C      | j S )z
        **[Required]** Gets the id of this Migration.
        Unique identifier that is immutable on creation


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


        :param id: The id of this Migration.
        :type: str
        Nr/   )r)   r   r+   r+   r,   r         

c                 C   r.   )z
        Gets the display_name of this Migration.
        Migration Identifier that can be renamed


        :return: The display_name of this Migration.
        :rtype: str
        r   r0   r+   r+   r,   r      r1   zMigration.display_namec                 C   r2   )z
        Sets the display_name of this Migration.
        Migration Identifier that can be renamed


        :param display_name: The display_name of this Migration.
        :type: str
        Nr4   )r)   r   r+   r+   r,   r      r3   c                 C   r.   )z
        **[Required]** Gets the compartment_id of this Migration.
        Compartment Identifier


        :return: The compartment_id of this Migration.
        :rtype: str
        r   r0   r+   r+   r,   r      r1   zMigration.compartment_idc                 C   r2   )z
        Sets the compartment_id of this Migration.
        Compartment Identifier


        :param compartment_id: The compartment_id of this Migration.
        :type: str
        Nr5   )r)   r   r+   r+   r,   r      r3   c                 C   r.   )a  
        **[Required]** Gets the lifecycle_state of this Migration.
        The current state of migration.

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


        :return: The lifecycle_state of this Migration.
        :rtype: str
        )r    r0   r+   r+   r,   r      s   zMigration.lifecycle_statec                 C   s    g d}t ||sd}|| _dS )z
        Sets the lifecycle_state of this Migration.
        The current state of migration.


        :param lifecycle_state: The lifecycle_state of this Migration.
        :type: str
        )r   r   r	   r
   r   r   r   ZUNKNOWN_ENUM_VALUEN)r   r    )r)   r   Zallowed_valuesr+   r+   r,   r      s   


c                 C   r.   )a,  
        Gets the lifecycle_details of this Migration.
        A message describing the current state in more detail. For example, it can be used to provide actionable information for a resource in Failed state.


        :return: The lifecycle_details of this Migration.
        :rtype: str
        r!   r0   r+   r+   r,   r      r1   zMigration.lifecycle_detailsc                 C   r2   )a<  
        Sets the lifecycle_details of this Migration.
        A message describing the current state in more detail. For example, it can be used to provide actionable information for a resource in Failed state.


        :param lifecycle_details: The lifecycle_details of this Migration.
        :type: str
        Nr6   )r)   r   r+   r+   r,   r     r3   c                 C   r.   )z
        **[Required]** Gets the time_created of this Migration.
        The time when the migration project was created. An RFC3339 formatted datetime string


        :return: The time_created of this Migration.
        :rtype: datetime
        r"   r0   r+   r+   r,   r     r1   zMigration.time_createdc                 C   r2   )z
        Sets the time_created of this Migration.
        The time when the migration project was created. An RFC3339 formatted datetime string


        :param time_created: The time_created of this Migration.
        :type: datetime
        Nr7   )r)   r   r+   r+   r,   r     r3   c                 C   r.   )z
        Gets the time_updated of this Migration.
        The time when the migration project was updated. An RFC3339 formatted datetime string


        :return: The time_updated of this Migration.
        :rtype: datetime
        r#   r0   r+   r+   r,   r   '  r1   zMigration.time_updatedc                 C   r2   )z
        Sets the time_updated of this Migration.
        The time when the migration project was updated. An RFC3339 formatted datetime string


        :param time_updated: The time_updated of this Migration.
        :type: datetime
        Nr8   )r)   r   r+   r+   r,   r   3  r3   c                 C   r.   )z
        Gets the replication_schedule_id of this Migration.
        Replication schedule identifier


        :return: The replication_schedule_id of this Migration.
        :rtype: str
        r$   r0   r+   r+   r,   r   ?  r1   z!Migration.replication_schedule_idc                 C   r2   )z
        Sets the replication_schedule_id of this Migration.
        Replication schedule identifier


        :param replication_schedule_id: The replication_schedule_id of this Migration.
        :type: str
        Nr9   )r)   r   r+   r+   r,   r   K  r3   c                 C   r.   )z
        Gets the is_completed of this Migration.
        Indicates whether migration is marked as completed.


        :return: The is_completed of this Migration.
        :rtype: bool
        r%   r0   r+   r+   r,   r   W  r1   zMigration.is_completedc                 C   r2   )z
        Sets the is_completed of this Migration.
        Indicates whether migration is marked as completed.


        :param is_completed: The is_completed of this Migration.
        :type: bool
        Nr:   )r)   r   r+   r+   r,   r   c  r3   c                 C   r.   )a<  
        Gets the freeform_tags of this Migration.
        Simple key-value pair that is applied without any predefined name, type or scope. It exists only for cross-compatibility.
        Example: `{"bar-key": "value"}`


        :return: The freeform_tags of this Migration.
        :rtype: dict(str, str)
        r&   r0   r+   r+   r,   r   o     zMigration.freeform_tagsc                 C   r2   )aH  
        Sets the freeform_tags of this Migration.
        Simple key-value pair that is applied without any predefined name, type or scope. It exists only for cross-compatibility.
        Example: `{"bar-key": "value"}`


        :param freeform_tags: The freeform_tags of this Migration.
        :type: dict(str, str)
        Nr;   )r)   r   r+   r+   r,   r   |     
c                 C   r.   )a3  
        Gets the defined_tags of this Migration.
        Defined tags for this resource. Each key is predefined and scoped to a namespace.
        Example: `{"foo-namespace": {"bar-key": "value"}}`


        :return: The defined_tags of this Migration.
        :rtype: dict(str, dict(str, object))
        r'   r0   r+   r+   r,   r     r<   zMigration.defined_tagsc                 C   r2   )a>  
        Sets the defined_tags of this Migration.
        Defined tags for this resource. Each key is predefined and scoped to a namespace.
        Example: `{"foo-namespace": {"bar-key": "value"}}`


        :param defined_tags: The defined_tags of this Migration.
        :type: dict(str, dict(str, object))
        Nr>   )r)   r   r+   r+   r,   r     r=   c                 C   r.   )a0  
        Gets the system_tags of this Migration.
        Usage of system tag keys. These predefined keys are scoped to namespaces.
        Example: `{"orcl-cloud": {"free-tier-retained": "true"}}`


        :return: The system_tags of this Migration.
        :rtype: dict(str, dict(str, object))
        r(   r0   r+   r+   r,   r     r<   zMigration.system_tagsc                 C   r2   )a:  
        Sets the system_tags of this Migration.
        Usage of system tag keys. These predefined keys are scoped to namespaces.
        Example: `{"orcl-cloud": {"free-tier-retained": "true"}}`


        :param system_tags: The system_tags of this Migration.
        :type: dict(str, dict(str, object))
        Nr?   )r)   r   r+   r+   r,   r     r=   c                 C   s   t | S N)r   r0   r+   r+   r,   __repr__  s   zMigration.__repr__c                 C   s   |d u rdS | j |j kS )NF)__dict__r)   otherr+   r+   r,   __eq__  s   zMigration.__eq__c                 C   s
   | |k S r@   r+   rC   r+   r+   r,   __ne__  s   
zMigration.__ne__N)__name__
__module____qualname____doc__ZLIFECYCLE_STATE_CREATINGZLIFECYCLE_STATE_UPDATINGZLIFECYCLE_STATE_NEEDS_ATTENTIONZLIFECYCLE_STATE_ACTIVEZLIFECYCLE_STATE_DELETINGZLIFECYCLE_STATE_DELETEDZLIFECYCLE_STATE_FAILEDr-   propertyr   setterr   r   r   r   r   r   r   r   r   r   r   rA   rE   rF   r+   r+   r+   r,   r      sz    c























r   N)Zoci.utilr   r   r   Zoci.decoratorsr   objectr   r+   r+   r+   r,   <module>   s   