
    `f#5                         d Z ddlZddlZddlZddlZddlmZ ddlmZ ddlm	Z	 ddl
mZmZ ddlmZ ddlmZ dd	lmZ d
Z ee          Zd Zd Zd Z ed          Z e            ZdZ G d d          ZdS )z'Implementation of the Observer pattern.    N)
WeakMethod)retry_over_time)CDeprecationWarning)PromiseProxyProxy)fun_accepts_kwargs)
get_logger)humanize_seconds)Signalc                     t          | t                    r|                                 } t          | t          t          f          r| S t          | d          rt          | j                  S t          |           S )N__func__)
isinstancer   _get_current_objectbytesstrhasattridr   )targets    N/var/www/html/env/lib/python3.11/site-packages/celery/utils/dispatch/signal.py_make_idr      sn    &%   .++--&5#,'' vz"" #&/"""f::    c                 x    	 | j          | j         t          | j        fS # t          $ r t          j        | fcY S w xY w)a  Get weakref constructor appropriate for `obj`.  `obj` may be a bound method.

    Bound method objects must be special-cased because they're usually garbage
    collected immediately, even if the instance they're bound to persists.

    Returns:
        a (weakref constructor, main object) tuple. `weakref constructor` is
        either :class:`weakref.ref` or :class:`weakref.WeakMethod`.  `main
        object` is the instance that `obj` is bound to if it is a bound method;
        otherwise `main object` is simply `obj.
    )r   __self__r   AttributeErrorweakrefref)objs    r   _boundmethod_safe_weakrefr       sP     3<''      {C s    99c                 d    |r|t          |          fS t          |           t          |          fS N)r   )receiversenderdispatch_uids      r   _make_lookup_keyr$   6   s8     6hv..//""HV$4$455r   zDCould not process signal receiver %(receiver)s. Retrying %(when)s...c                   n    e Zd ZdZdZddZd Zd Zd Z	 	 ddZ	dd	Z
d
 ZeZd Zd ZddZd Zd ZdS )r   a  Create new signal.

    Keyword Arguments:
        providing_args (List): A list of the arguments this signal can pass
            along in a :meth:`send` call.
        use_caching (bool): Enable receiver cache.
        name (str): Name of signal, used for debugging purposes.
    NFc                     g | _         t          ||ng           | _        t          j                    | _        || _        || _        |rt          j	                    ni | _
        d| _        d S )NF)	receiverssetproviding_args	threadingLocklockuse_cachingnamer   WeakKeyDictionarysender_receivers_cache_dead_receivers)selfr)   r-   r.   s       r   __init__zSignal.__init__T   sw    !,8NNbB BN$$	&	 ,7>G%'''B 	#  %r   c                 X    |                      ||                                ||          S )N)r"   weakr#   )connectr   )r2   funr"   r5   r#   s        r   _connect_proxyzSignal._connect_proxye   s3    ||2244L  
 
 	
r   c                      	 	 d fd	}|r4t          |d                   r  ||dd         i ||d                   S  ||i |S )a  Connect receiver to sender for signal.

        Arguments:
            receiver (Callable): A function or an instance method which is to
                receive signals.  Receivers must be hashable objects.

                if weak is :const:`True`, then receiver must be
                weak-referenceable.

                Receivers must be able to accept keyword arguments.

                If receivers have a `dispatch_uid` attribute, the receiver will
                not be added if another receiver already exists with that
                `dispatch_uid`.

            sender (Any): The sender to which the receiver should respond.
                Must either be a Python object, or :const:`None` to
                receive events from any sender.

            weak (bool): Whether to use weak references to the receiver.
                By default, the module will attempt to use weak references to
                the receiver objects.  If this parameter is false, then strong
                references will be used.

            dispatch_uid (Hashable): An identifier used to uniquely identify a
                particular instance of a receiver.  This will usually be a
                string, though it may be anything hashable.

            retry (bool): If the signal receiver raises an exception
                (e.g. ConnectionError), the receiver will be retried until it
                runs successfully. A strong ref to the receiver will be stored
                and the `weak` option will be ignored.
        NTFc                 "      fd}|S )Nc                     d}d }r$d|d<   st          |           |d<    ||           }                     | |d         |d                    | S )N)r#   r5   c                       fd}|S )Nc                  >    fd}t          t          | ||          S )Nc                     t          |          }t          t          |dd          dz  }t                              |           |S )Nin )r!   when)nextRECEIVER_RETRY_ERRORr
   loggererror)exc	intervalsretriesintervalerr_msg	retry_funs        r   on_errorzSignal.connect.<locals>._handle_options.<locals>._connect_signal.<locals>._retry_receiver.<locals>._try_receiver_over_time.<locals>.on_error   sP    '+IH&:-6)9(D#)N)N!P !P'PG #LL111#+Or   )r   	Exception)argskwargsrL   rK   s      r   _try_receiver_over_timezzSignal.connect.<locals>._handle_options.<locals>._connect_signal.<locals>._retry_receiver.<locals>._try_receiver_over_time   s>    , , , , ,  /y)T/5x A  A Ar    )rK   rP   s   ` r   _retry_receiverzYSignal.connect.<locals>._handle_options.<locals>._connect_signal.<locals>._retry_receiver   s)    
A 
A 
A 
A 
A 32r   Fr5   r#   )r   _connect_signal)r7   optionsrR   r#   retryr2   r"   r5   s      r   rS   z@Signal.connect.<locals>._handle_options.<locals>._connect_signal   s    +7#') )3 3 3   /&+GFO' @ 3;3--/)/#..C$$S&'&/%,^%<> > >
r   rQ   )r"   r5   r#   rU   rS   r2   s   ```` r   _handle_optionsz'Signal.connect.<locals>._handle_options   s=                     D #"r   r      )NTNF)callable)r2   rN   rO   rV   s   `   r   r6   zSignal.connectk   s    D BF"'%	# %	# %	# %	# %	# %	#N  	AHT!W%% 	A7??DH777Q@@@////r   c                 l   t          |          s
J d            t          |          st          d          t          |t                    r |                    | j        ||||           |S t          |||          }|r7t          |          \  }} ||          }t          j
        || j                   | j        5  |                                  | j        D ]\  }}	||k    r n| j                            ||f           | j                                         d d d            n# 1 swxY w Y   |S )Nz!Signal receivers must be callablez.Signal receiver must accept keyword arguments.)rX   r   
ValueErrorr   r   __then__r8   r$   r   r   finalize_remove_receiverr,   _clear_dead_receiversr'   appendr0   clear)
r2   r!   r"   r5   r#   
lookup_keyr   receiver_objectr_key_s
             r   rS   zSignal._connect_signal   s   !!FF#FFF!!(++ 	B@B B B fl++ 	OO#Xvt\   O%hEE
 	E#<X#F#F Cs8}}H_d.CDDDY 	0 	0&&((( N > >qJ&&E ' %%z8&<==='--///	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 s   >AD))D-0D-c                    |t          j        dt          d           t          |||          }d}| j        5  |                                  t          t          | j                            D ]$}| j        |         \  }}	||k    rd}| j        |=  n%| j	        
                                 ddd           n# 1 swxY w Y   |S )a8  Disconnect receiver from sender for signal.

        If weak references are used, disconnect needn't be called.
        The receiver will be removed from dispatch automatically.

        Arguments:
            receiver (Callable): The registered receiver to disconnect.
                May be none if `dispatch_uid` is specified.

            sender (Any): The registered sender to disconnect.

            weak (bool): The weakref state to disconnect.

            dispatch_uid (Hashable): The unique identifier of the receiver
                to disconnect.
        Nz+Passing `weak` to disconnect has no effect.   )
stacklevelFT)warningswarnr   r$   r,   r^   rangelenr'   r0   r`   )
r2   r!   r"   r5   r#   ra   disconnectedindexrc   rd   s
             r   
disconnectzSignal.disconnect   s&   $ M=#3 3 3 3 &hEE
Y 	0 	0&&(((s4>2233  !^E2
J&&#'Lu-E ' '--///	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 	0 s   A4B99B= B=c                 F    t          |                     |                    S r    )bool_live_receivers)r2   r"   s     r   has_listenerszSignal.has_listeners   s    D((00111r   c                    g }| j         r!| j                            |          t          u r|S |                     |          D ]}	  |d| |d|}|                    ||f           &# t          $ rk}t          |d          st          j	                    d         |_
        t                              d||           |                    ||f           Y d}~d}~ww xY w|S )uA  Send signal from sender to all connected receivers.

        If any receiver raises an error, the exception is returned as the
        corresponding response. (This is different from the "send" in
        Django signals. In Celery "send" and "send_robust" do the same thing.)

        Arguments:
            sender (Any): The sender of the signal.
                Either a specific object or :const:`None`.
            **named (Any): Named arguments which will be passed to receivers.

        Returns:
            List: of tuple pairs: `[(receiver, response), … ]`.
        )signalr"   __traceback__rf   zSignal handler %r raised: %rNrQ   )r'   r0   getNO_RECEIVERSrq   r_   rM   r   sysexc_inforu   rD   	exception)r2   r"   named	responsesr!   responserF   s          r   sendzSignal.send   s(    	~ 	+//77<GG,,V44 
	7 
	7H	7#8H4HH%HH   (H!56666  2 2 2sO44 :(+q(9C%  2HcC C C  (C111111112 s   A((
C2A!CCc                     | j         rbd| _         g }| j        D ]H}t          |d         t          j                  r |d                     3|                    |           I|| _        d S d S )NFrW   )r1   r'   r   r   ReferenceTyper_   )r2   new_receiversrs      r   r^   zSignal._clear_dead_receivers   s     	+#(D M^ ( (adG$9:: tqtvv~$$Q''''*DNNN	+ 	+r   c                 ^   d}| j         r,| j        s%| j                            |          }|t          u rg S || j        5  |                                  t          |          }g }| j        D ].\  \  }}}|t          k    s||k    r|
                    |           /| j         r|st          | j        |<   n
|| j        |<   ddd           n# 1 swxY w Y   g }|D ]S}t          |t          j                  r" |            }||
                    |           >|
                    |           T|S )zFilter sequence of receivers to get resolved, live receivers.

        This checks for weak references and resolves them, then returning only
        live receivers.
        N)r-   r1   r0   rv   rw   r,   r^   r   r'   NONE_IDr_   r   r   r   )r2   r"   r'   	senderkeyreceiverkeyr_senderkeyr!   non_weak_receiverss           r   rq   zSignal._live_receivers+  s    	 	D$8 	377??I L((	 H H**,,,$V,,		<@N 3 38.[+"g--	1I1I!((222# H$ H>J3F;; ?H3F;H H H H H H H H H H H H H H H  ! 	4 	4H(G$9:: 4#8::'&--h777"))(3333!!s   A?C

CCc                     d| _         dS )z'Remove dead receivers from connections.TN)r1   )r2   r!   s     r   r]   zSignal._remove_receiverR  s      $r   c                 R    dt          |           j         d| j         d| j        dS )z``repr(signal)``.<z: z providing_args=>)type__name__r.   r)   r2   s    r   __repr__zSignal.__repr__\  s1    ]4::&]]$)]]TEX]]]]r   c                      t          |           S )z``str(signal)``.)reprr   s    r   __str__zSignal.__str__`  s    Dzzr   )NFN)NNNNr    )r   
__module____qualname____doc__r'   r3   r8   r6   rS   rn   rr   r~   send_robustr^   rq   r]   r   r   rQ   r   r   r   r   F   s         I% % % %"
 
 
K0 K0 K0Z  < ;? $# # # #J2 2 2 2  @ K	+ 	+ 	+%" %" %"N$ $ $ $^ ^ ^    r   r   )r   rx   r*   rh   r   r   kombu.utils.functionalr   celery.exceptionsr   celery.localr   r   celery.utils.functionalr   celery.utils.logr	   celery.utils.timer
   __all__r   rD   r   r   r$   r   objectrw   rC   r   rQ   r   r   <module>r      sU   - - 



             2 2 2 2 2 2 1 1 1 1 1 1 , , , , , , , , 6 6 6 6 6 6 ' ' ' ' ' ' . . . . . .
	H		       ,6 6 6 (4..vxx 
\ \ \ \ \ \ \ \ \ \r   