ruạṛ
a N��f@r � @ s( d dl Z d dlmZ G dd� de�ZdS )� N)�WAIT_RESOURCE_NOT_FOUNDc @ sZ e Zd ZdZdMdd�Zg i i fdd�Zg i i fdd�Zg i i fd d �Zg i i fdd�Zg i i fd d�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&�Zg i i fd'd(�Zg i i fd)d*�Zg i i fd+d,�Zg i i fd-d.�Zg i i fd/d0�Zg i i fd1d2�Zg i i fd3d4�Zg i i fd5d6�Zg i i fd7d8�Zg i i fd9d:�Zg i i fd;d<�Z g i i fd=d>�Z!g i i fd?d@�Z"g i i fdAdB�Z#g i i fdCdD�Z$g i i fdEdF�Z%g i i fdGdH�Z&g i i fdIdJ�Z'g i i fdKdL�Z(dS )N� ComputeClientCompositeOperationsa� This class provides a wrapper around :py:class:`~oci.core.ComputeClient` 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 Nc K s0 || _ |r|ntjj| j jfi | j j��| _dS )av Creates a new ComputeClientCompositeOperations object :param ComputeClient client: The service client which will be wrapped by this object :param oci.work_requests.WorkRequestClient work_request_client: (optional) The work request service client which will be used to wait for work request states. Default is None. N)�client�oci� work_requests�WorkRequestClient�_config�_kwargs�_work_request_client)�selfr �work_request_client�kwargs� r ��/sparta/input/_build_configuration/image_build+validate/lib/bmcenv/lib64/python3.9/site-packages/oci/core/compute_client_composite_operations.py�__init__ s z)ComputeClientCompositeOperations.__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.core.ComputeClient.attach_boot_volume` and waits for the :py:class:`~oci.core.models.BootVolumeAttachment` acted upon to enter the given state(s). :param oci.core.models.AttachBootVolumeDetails attach_boot_volume_details: (required) Attach boot volume request :param list[str] wait_for_states: An array of states to wait on. These should be valid values for :py:attr:`~oci.core.models.BootVolumeAttachment.lifecycle_state` :param dict operation_kwargs: A dictionary of keyword arguments to pass to :py:func:`~oci.core.ComputeClient.attach_boot_volume` :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>4 � zZComputeClientCompositeOperations.attach_boot_volume_and_wait_for_state.<locals>.<listcomp>�evaluate_responsec s t | jd�ot | jd��� � v S �N�lifecycle_state��getattr�datar ��r��lowered_wait_for_statesr r �<lambda>; r zXComputeClientCompositeOperations.attach_boot_volume_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"��partial_results�causeN) r �attach_boot_volumer �idr � wait_until�get_boot_volume_attachment� NameError� TypeError�args� exceptions�CompositeOperationError� Exception) r �attach_boot_volume_details�wait_for_states�operation_kwargs� waiter_kwargs�operation_result�boot_volume_attachment_id� waiter_result�result_to_return�er r r �%attach_boot_volume_and_wait_for_state s. � ��&zFComputeClientCompositeOperations.attach_boot_volume_and_wait_for_statec 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.core.ComputeClient.attach_vnic` and waits for the :py:class:`~oci.core.models.VnicAttachment` acted upon to enter the given state(s). :param oci.core.models.AttachVnicDetails attach_vnic_details: (required) Attach VNIC details. :param list[str] wait_for_states: An array of states to wait on. These should be valid values for :py:attr:`~oci.core.models.VnicAttachment.lifecycle_state` :param dict operation_kwargs: A dictionary of keyword arguments to pass to :py:func:`~oci.core.ComputeClient.attach_vnic` :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 zSComputeClientCompositeOperations.attach_vnic_and_wait_for_state.<locals>.<listcomp>r c s t | jd�ot | jd��� � v S r r r r r r r"