/
usr
/
lib
/
python3.9
/
site-packages
/
oci
/
database_migration
/
__pycache__
/
Upload File
HOME
a ���f$� � @ s( d dl Z d dlmZ G dd� de�ZdS )� N)�WAIT_RESOURCE_NOT_FOUNDc @ s( e Zd ZdZdd� Zg i i fdd�Zg i i fdd�Zg i i fdd �Zg i i fd d�Zg i i fdd �Z g i i fdd�Z g i i fdd�Zg i i fdd�Zg i i fdd�Z g i i fdd�Zg i i fdd�Zg i i fdd�Zg i i fdd�Zg i i fdd�Zg i i fd d!�Zg i i fd"d#�Zg i i fd$d%�Zd&S )'�*DatabaseMigrationClientCompositeOperationsa� This class provides a wrapper around :py:class:`~oci.database_migration.DatabaseMigrationClient` and offers convenience methods for operations that would otherwise need to be chained together. For example, instead of performing an action on a resource (e.g. launching an instance, creating a load balancer) and then using a waiter to wait for the resource to enter a given state, you can call a single method in this class to accomplish the same functionality c K s || _ dS )z� Creates a new DatabaseMigrationClientCompositeOperations object :param DatabaseMigrationClient client: The service client which will be wrapped by this object N)�client)�selfr �kwargs� r �i/usr/lib/python3.9/site-packages/oci/database_migration/database_migration_client_composite_operations.py�__init__ s z3DatabaseMigrationClientCompositeOperations.__init__c s� | j j|fi |��}|s|S dd� |D �� |jj}z4tj| j | j �|�fd� fdd�i|��}|}|W S ttfy� } z6|j s�d|_ |j d |_ tj j|g|d��W Y d }~n>d }~0 ty� } ztj j|g|d��W Y d }~n d }~0 0 d S ) a� Calls :py:func:`~oci.database_migration.DatabaseMigrationClient.abort_job` and waits for the :py:class:`~oci.database_migration.models.Job` acted upon to enter the given state(s). :param str job_id: (required) The OCID of the job :param list[str] wait_for_states: An array of states to wait on. These should be valid values for :py:attr:`~oci.database_migration.models.Job.lifecycle_state` :param dict operation_kwargs: A dictionary of keyword arguments to pass to :py:func:`~oci.database_migration.DatabaseMigrationClient.abort_job` :param dict waiter_kwargs: A dictionary of keyword arguments to pass to the :py:func:`oci.wait_until` function. For example, you could pass ``max_interval_seconds`` or ``max_interval_seconds`` as dictionary keys to modify how long the waiter function will wait between retries and the maximum amount of time it will wait c S s g | ]}|� � �qS r ��lower��.0�wr r r � <listcomp>1 � z[DatabaseMigrationClientCompositeOperations.abort_job_and_wait_for_state.<locals>.<listcomp>�evaluate_responsec s t | jd�ot | jd��� � v S �NZlifecycle_state��getattr�datar ��r�Zlowered_wait_for_statesr r �<lambda>8 r zYDatabaseMigrationClientCompositeOperations.abort_job_and_wait_for_state.<locals>.<lambda>�� �a This composite operation is currently not supported in the SDK. Please use the operation from the service client and use waiters as an alternative. For more information on waiters, visit: "https://docs.oracle.com/en-us/iaas/tools/python/latest/api/waiters.html"�Zpartial_results�causeN) r Z abort_jobr �id�oci� wait_until�get_job� NameError� TypeError�args� exceptions�CompositeOperationError� Exception� r �job_id�wait_for_states�operation_kwargs� waiter_kwargs�operation_result� waiter_result�result_to_return�er r r �abort_job_and_wait_for_state s. � ��&zGDatabaseMigrationClientCompositeOperations.abort_job_and_wait_for_statec s� | j j||fi |��}|s|S dd� |D �� d|jvr:|S |jd }z4tj| j | j �|�fd� fdd�i|��}|} | W S ty� } ztjj|g| d��W Y d} ~ n d} ~ 0 0 dS ) at Calls :py:func:`~oci.database_migration.DatabaseMigrationClient.clone_migration` and waits for the :py:class:`~oci.database_migration.models.WorkRequest` to enter the given state(s). :param str migration_id: (required) The OCID of the migration :param oci.database_migration.models.CloneMigrationDetails clone_migration_details: (required) Clone Migration properties. :param list[str] wait_for_states: An array of states to wait on. These should be valid values for :py:attr:`~oci.database_migration.models.WorkRequest.status` :param dict operation_kwargs: A dictionary of keyword arguments to pass to :py:func:`~oci.database_migration.DatabaseMigrationClient.clone_migration` :param dict waiter_kwargs: A dictionary of keyword arguments to pass to the :py:func:`oci.wait_until` function. For example, you could pass ``max_interval_seconds`` or ``max_interval_seconds`` as dictionary keys to modify how long the waiter function will wait between retries and the maximum amount of time it will wait c S s g | ]}|� � �qS r r r r r r r ^ r zaDatabaseMigrationClientCompositeOperations.clone_migration_and_wait_for_state.<locals>.<listcomp>�opc-work-request-idr c s t | jd�ot | jd��� � v S �N�statusr r r r r r g r z_DatabaseMigrationClientCompositeOperations.clone_migration_and_wait_for_state.<locals>.<lambda>r N) r Zclone_migration�headersr r! �get_work_requestr( r&