
    keJi!                     j   d dl mZmZ d dlmZmZmZ d dlZd dlm	Z	 d dl
mZmZmZ d dlmZmZ d dlmZ d dlmZmZ d d	lmZmZmZ d d
lmZmZ d dlmZmZm Z m!Z! d dl"m#Z#m$Z$m%Z%m&Z&m'Z' d dl(m)Z)m*Z*m+Z+m,Z,m-Z-m.Z.m/Z/ d dl0m1Z1 dZ2defdZ3e G d d                      Z4e G d d                      Z5dS )    )	dataclassfield)ListTypeUnionN)Optional)ConnectionPoolRedisRedisCluster)ExponentialWithJitterBackoff	NoBackoff)WeightedList)EventDispatcherEventDispatcherInterface)DEFAULT_GRACE_PERIODCircuitBreakerPBCircuitBreakerAdapter)Database	Databases)DEFAULT_FAILOVER_ATTEMPTSDEFAULT_FAILOVER_DELAYFailoverStrategyWeightBasedFailoverStrategy)DEFAULT_FAILURE_RATE_THRESHOLD!DEFAULT_FAILURES_DETECTION_WINDOWDEFAULT_MIN_NUM_FAILURESCommandFailureDetectorFailureDetector)DEFAULT_HEALTH_CHECK_DELAYDEFAULT_HEALTH_CHECK_INTERVALDEFAULT_HEALTH_CHECK_POLICYDEFAULT_HEALTH_CHECK_PROBESHealthCheckHealthCheckPoliciesPingHealthCheck)Retryx   returnc                      t                      S N)r        Z/var/www/html/movieo_spanner_bot/venv/lib/python3.11/site-packages/redis/multidb/config.pydefault_event_dispatcherr.   ,   s    r,   c                       e Zd ZU dZdZeed<    ee          Z	eed<   dZ
ee         ed<   dZee         ed<   dZee         ed	<   eZeed
<   dZee         ed<   defdZdS )DatabaseConfiga  
    Dataclass representing the configuration for a database connection.

    This class is used to store configuration settings for a database connection,
    including client options, connection sourcing details, circuit breaker settings,
    and cluster-specific properties. It provides a structure for defining these
    attributes and allows for the creation of customized configurations for various
    database setups.

    Attributes:
        weight (float): Weight of the database to define the active one.
        client_kwargs (dict): Additional parameters for the database client connection.
        from_url (Optional[str]): Redis URL way of connecting to the database.
        from_pool (Optional[ConnectionPool]): A pre-configured connection pool to use.
        circuit (Optional[CircuitBreaker]): Custom circuit breaker implementation.
        grace_period (float): Grace period after which we need to check if the circuit could be closed again.
        health_check_url (Optional[str]): URL for health checks. Cluster FQDN is typically used
            on public Redis Enterprise endpoints.

    Methods:
        default_circuit_breaker:
            Generates and returns a default CircuitBreaker instance adapted for use.
    g      ?weightdefault_factoryclient_kwargsNfrom_url	from_poolcircuitgrace_periodhealth_check_urlr(   c                 T    t          j        | j                  }t          |          S )N)reset_timeout)	pybreakerr   r8   r   )selfcircuit_breakers     r-   default_circuit_breakerz&DatabaseConfig.default_circuit_breakerR   s&    #2ARSSS&777r,   )__name__
__module____qualname____doc__r1   float__annotations__r   dictr4   r5   r   strr6   r	   r7   r   r   r8   r9   r?   r+   r,   r-   r0   r0   0   s          0 FE%555M4555"Hhsm"""*.Ix'...(,GXn%,,,.L%...&*hsm***8 8 8 8 8 8 8r,   r0   c                      e Zd ZU dZee         ed<   eZe	e
eef                  ed<    e edd          d          Zeed	<   d
Zeee                  ed<   eZeed<   eZeed<   eZeed<   d
Zeee                  ed<   eZeed<   eZeed<   e Z!eed<   e"Z#e$ed<   d
Z%ee&         ed<   e'Z(eed<   e)Z*eed<   e+Z,eed<    e-e.          Z/e0ed<   de1fdZ2dee         fdZ3dee         fdZ4de&fdZ5d
S )MultiDbConfiga  
    Configuration class for managing multiple database connections in a resilient and fail-safe manner.

    Attributes:
        databases_config: A list of database configurations.
        client_class: The client class used to manage database connections.
        command_retry: Retry strategy for executing database commands.
        failure_detectors: Optional list of additional failure detectors for monitoring database failures.
        min_num_failures: Minimal count of failures required for failover
        failure_rate_threshold: Percentage of failures required for failover
        failures_detection_window: Time interval for tracking database failures.
        health_checks: Optional list of additional health checks performed on databases.
        health_check_interval: Time interval for executing health checks.
        health_check_probes: Number of attempts to evaluate the health of a database.
        health_check_probes_delay: Delay between health check attempts.
        health_check_policy: Policy for determining database health based on health checks.
        failover_strategy: Optional strategy for handling database failover scenarios.
        failover_attempts: Number of retries allowed for failover operations.
        failover_delay: Delay between failover attempts.
        auto_fallback_interval: Time interval to trigger automatic fallback.
        event_dispatcher: Interface for dispatching events related to database operations.

    Methods:
        databases:
            Retrieves a collection of database clients managed by weighted configurations.
            Initializes database clients based on the provided configuration and removes
            redundant retry objects for lower-level clients to rely on global retry logic.

        default_failure_detectors:
            Returns the default list of failure detectors used to monitor database failures.

        default_health_checks:
            Returns the default list of health checks used to monitor database health
            with specific retry and backoff strategies.

        default_failover_strategy:
            Provides the default failover strategy used for handling failover scenarios
            with defined retry and backoff configurations.
    databases_configclient_class   
   )basecap   )backoffretriescommand_retryNfailure_detectorsmin_num_failuresfailure_rate_thresholdfailures_detection_windowhealth_checkshealth_check_intervalhealth_check_probeshealth_check_probes_delayhealth_check_policyfailover_strategyfailover_attemptsfailover_delayauto_fallback_intervalr2   event_dispatcherr(   c           	         t                      }| j        D ]&}|j                            dt	          dt                                i           |j        r | j        j        |j        fi |j        }no|j        rV|j        	                    t	          dt                                           | j                            |j                  }n | j        di |j        }|j
        |                                n|j
        }|                    t          |||j        |j                  |j                   (|S )Nretryr   )rR   rQ   )connection_pool)clientr7   r1   r9   r+   )r   rJ   r4   updater&   r   r5   rK   r6   	set_retryr7   r?   addr   r1   r9   )r=   	databasesdatabase_configre   r7   s        r-   ri   zMultiDbConfig.databases   s    NN	#4 "	 "	O )00%9;;???@   ' L3*3#, 0?0M  !* L)33!Y[[999   *44$3$= 5   +*KK_-JKK #*2  77999$, 
 MM!#*1%4%E	    &    r,   c                 F    t          | j        | j        | j                  gS )N)rU   rV   failure_detection_window)r   rU   rV   rW   r=   s    r-   default_failure_detectorsz'MultiDbConfig.default_failure_detectors   s0    "!%!6'+'B)-)G  
 	
r,   c                      t                      gS r*   )r%   rm   s    r-   default_health_checksz#MultiDbConfig.default_health_checks   s    
 	
r,   c                     t                      S r*   )r   rm   s    r-   default_failover_strategyz'MultiDbConfig.default_failover_strategy   s    *,,,r,   )6r@   rA   rB   rC   r   r0   rE   r
   rK   r   r   r   r&   r   rS   rT   r   r   r   rU   intr   rV   rD   r   rW   rX   r#   r    rY   r"   rZ   r   r[   r!   r\   r$   r]   r   r   r^   r   r_   DEFAULT_AUTO_FALLBACK_INTERVALr`   r   r.   ra   r   r   ri   rn   rp   rr   r+   r,   r-   rI   rI   W   s+        & &P >****5:L$uUL012::: 5,,!<<<a  M5    :>x_ 56===4c444$BEBBB'HuHHH15M8D-.555#@5@@@::::'AuAAA/J,JJJ48x 018886s6662NE222$BEBBB1602 2 2.   '9 ' ' ' 'R
4+@ 
 
 
 

tK'8 
 
 
 

-+; - - - - - -r,   rI   )6dataclassesr   r   typingr   r   r   r<   typing_extensionsr   redisr	   r
   r   redis.backoffr   r   redis.data_structurer   redis.eventr   r   redis.multidb.circuitr   r   r   redis.multidb.databaser   r   redis.multidb.failoverr   r   r   r   redis.multidb.failure_detectorr   r   r   r   r   redis.multidb.healthcheckr   r    r!   r"   r#   r$   r%   redis.retryr&   rt   r.   r0   rI   r+   r,   r-   <module>r      s   ( ( ( ( ( ( ( ( $ $ $ $ $ $ $ $ $ $     & & & & & & 5 5 5 5 5 5 5 5 5 5 A A A A A A A A - - - - - - A A A A A A A A         
 7 6 6 6 6 6 6 6                                               !$ ":     #8 #8 #8 #8 #8 #8 #8 #8L w- w- w- w- w- w- w- w- w- w-r,   