
    vKg%                         S SK r S SKJr  S SKJr  S SKJr  SSKJr  SSK	J
r
  SSKJrJr  \ R                  " \5      r " S	 S
5      r " S S\5      r " S S5      r " S S5      rg)    N)
xform_name)ActionDocstring)inject_attribute   )Action)create_request_parameters)
RawHandlerResourceHandlerc                   (    \ rS rSrSrSS jrS rSrg)ServiceAction   au  
A class representing a callable action on a resource, for example
``sqs.get_queue_by_name(...)`` or ``s3.Bucket('foo').delete()``.
The action may construct parameters from existing resource identifiers
and may return either a raw response or a new resource instance.

:type action_model: :py:class`~boto3.resources.model.Action`
:param action_model: The action model.

:type factory: ResourceFactory
:param factory: The factory that created the resource class to which
                this action is attached.

:type service_context: :py:class:`~boto3.utils.ServiceContext`
:param service_context: Context about the AWS service
Nc                     Xl         UR                  nU(       a1  [        UR                  UUUUR                  R
                  S9U l        g [        UR                  5      U l        g )N)search_pathfactoryresource_modelservice_contextoperation_name)_action_modelresourcer
   pathrequest	operation_response_handlerr	   )selfaction_modelr   r   resource_response_models        V/var/www/highfloat_scraper/venv/lib/python3.13/site-packages/boto3/resources/action.py__init__ServiceAction.__init__.   s\    ) #/"7"7"%43886 /+33==&D" &00A0A%BD"    c                    [        U R                  R                  R                  5      n[	        XR                  R                  5      nUR                  U5        [        R                  SUR                  R                  UU5        [        UR                  R                  U5      " U0 UD6n[        R                  SU5        U R                  XU5      $ )a  
Perform the action's request operation after building operation
parameters and build any defined resources from the response.

:type parent: :py:class:`~boto3.resources.base.ServiceResource`
:param parent: The resource instance to which this action is attached.
:rtype: dict or ServiceResource or list(ServiceResource)
:return: The response, either as a raw dict or resource instance(s).
Calling %s:%s with %rResponse: %r)r   r   r   r   r   updateloggerdebugmetaservice_namegetattrclientr   )r   parentargskwargsr   paramsresponses          r   __call__ServiceAction.__call__?   s     $D$6$6$>$>$H$HI
 +63E3E3M3MNf#KK$$		
 6;;--~>OO^X.%%fh??r    )r   r   )NN__name__
__module____qualname____firstlineno____doc__r   r0   __static_attributes__ r    r   r   r      s    "C"@r    r   c                       \ rS rSrSrS rSrg)BatchAction_   a  
An action which operates on a batch of items in a collection, typically
a single page of results from the collection's underlying service
operation call. For example, this allows you to delete up to 999
S3 objects in a single operation rather than calling ``.delete()`` on
each one individually.

:type action_model: :py:class`~boto3.resources.model.Action`
:param action_model: The action model.

:type factory: ResourceFactory
:param factory: The factory that created the resource class to which
                this action is attached.

:type service_context: :py:class:`~boto3.utils.ServiceContext`
:param service_context: Context about the AWS service
c           	      V   SnSn/ n[        U R                  R                  R                  5      nUR	                  5        H  n0 n	[        U5       HW  u  pUc  UR                  R                  nUc  UR                  R                  n[        UU R                  R                  U	U
S9  MY     U	(       d    U$ U	R                  U5        [        R                  SXGU	5        [        XW5      " U0 U	D6n[        R                  SU5        UR                  U R                  XU5      5        M     U$ )aI  
Perform the batch action's operation on every page of results
from the collection.

:type parent:
    :py:class:`~boto3.resources.collection.ResourceCollection`
:param parent: The collection iterator to which this action
               is attached.
:rtype: list(dict)
:return: A list of low-level response dicts from each call.
N)r.   indexr"   r#   )r   r   r   r   pages	enumerater'   r(   r*   r   r$   r%   r&   r)   appendr   )r   r+   r,   r-   r(   r*   	responsesr   pager.   r>   r   r/   s                r   r0   BatchAction.__call__r   s    	#D$6$6$>$>$H$HI
 LLNDF#,T?  '#+==#=#=L>%]]11F)&&..!	 $3    MM&!LL'v v6GGHLL2T33FHMNA #D r    r9   N)r3   r4   r5   r6   r7   r0   r8   r9   r    r   r;   r;   _   s    $6r    r;   c                   $    \ rS rSrSrS rS rSrg)WaiterAction   a  
A class representing a callable waiter action on a resource, for example
``s3.Bucket('foo').wait_until_bucket_exists()``.
The waiter action may construct parameters from existing resource
identifiers.

:type waiter_model: :py:class`~boto3.resources.model.Waiter`
:param waiter_model: The action waiter.
:type waiter_resource_name: string
:param waiter_resource_name: The name of the waiter action for the
                             resource. It usually begins with a
                             ``wait_until_``
c                     Xl         X l        g )N_waiter_model_waiter_resource_name)r   waiter_modelwaiter_resource_names      r   r   WaiterAction.__init__   s    )%9"r    c                    [        U R                  R                  5      n[        XR                  5      nUR	                  U5        [
        R                  SUR                  R                  U R                  U5        UR                  R                  nUR                  U5      nUR                  " S0 UD6n[
        R                  SU5        g)z
Perform the wait operation after building operation
parameters.

:type parent: :py:class:`~boto3.resources.base.ServiceResource`
:param parent: The resource instance to which this action is attached.
r"   r#   Nr9   )r   rJ   waiter_namer   r$   r%   r&   r'   r(   rK   r*   
get_waiterwait)	r   r+   r,   r-   client_waiter_namer.   r*   waiterr/   s	            r   r0   WaiterAction.__call__   s     ((:(:(F(FG
 +63E3EFf#KK$$&&		
 ##""#56;;((^X.r    rI   Nr2   r9   r    r   rF   rF      s    :/r    rF   c                   $    \ rS rSrSrS rS rSrg)CustomModeledAction   z3A custom, modeled action to inject into a resource.c                 4    Xl         X l        X0l        X@l        g)a  
:type action_name: str
:param action_name: The name of the action to inject, e.g.
    'delete_tags'

:type action_model: dict
:param action_model: A JSON definition of the action, as if it were
    part of the resource model.

:type function: function
:param function: The function to perform when the action is called.
    The first argument should be 'self', which will be the resource
    the function is to be called on.

:type event_emitter: :py:class:`botocore.hooks.BaseEventHooks`
:param event_emitter: The session event emitter.
N)namemodelfunctionemitter)r   action_namer   r\   event_emitters        r   r   CustomModeledAction.__init__   s    $  	!
 $r    c                 D   UR                  S5      S   n[        U R                  U R                  0 5      nU R                  U R                  l        [        UU R                  UUR                  SS9U R                  l	        [        XR                  U R                  5        g )N.F)resource_namer_   r   service_modelinclude_signature)rsplitr   rZ   r[   r\   r3   r   r]   re   r7   r   )r   class_attributesr   
event_namer-   rd   actions          r   injectCustomModeledAction.inject   s|    "))#.r2		4::r2!% /',,)77#!
 	)99dmmDr    )r]   r\   r[   rZ   N)r3   r4   r5   r6   r7   r   rk   r8   r9   r    r   rW   rW      s    =%.Er    rW   )loggingbotocorer   boto3.docs.docstringr   boto3.utilsr   r[   r   r.   r   r/   r	   r
   	getLoggerr3   r%   r   r;   rF   rW   r9   r    r   <module>rr      sa      0 (  - 1			8	$@@ @@FI- IX./ ./b%E %Er    