|
import socketio |
|
import redis |
|
from redis import asyncio as aioredis |
|
from urllib.parse import urlparse |
|
|
|
|
|
def parse_redis_service_url(redis_url): |
|
parsed_url = urlparse(redis_url) |
|
if parsed_url.scheme != "redis": |
|
raise ValueError("Invalid Redis URL scheme. Must be 'redis'.") |
|
|
|
return { |
|
"username": parsed_url.username or None, |
|
"password": parsed_url.password or None, |
|
"service": parsed_url.hostname or "mymaster", |
|
"port": parsed_url.port or 6379, |
|
"db": int(parsed_url.path.lstrip("/") or 0), |
|
} |
|
|
|
|
|
def get_redis_connection(redis_url, redis_sentinels, decode_responses=True): |
|
if redis_sentinels: |
|
redis_config = parse_redis_service_url(redis_url) |
|
sentinel = redis.sentinel.Sentinel( |
|
redis_sentinels, |
|
port=redis_config["port"], |
|
db=redis_config["db"], |
|
username=redis_config["username"], |
|
password=redis_config["password"], |
|
decode_responses=decode_responses, |
|
) |
|
|
|
|
|
return sentinel.master_for(redis_config["service"]) |
|
else: |
|
|
|
return redis.Redis.from_url(redis_url, decode_responses=decode_responses) |
|
|
|
|
|
def get_sentinels_from_env(sentinel_hosts_env, sentinel_port_env): |
|
if sentinel_hosts_env: |
|
sentinel_hosts = sentinel_hosts_env.split(",") |
|
sentinel_port = int(sentinel_port_env) |
|
return [(host, sentinel_port) for host in sentinel_hosts] |
|
return [] |
|
|
|
|
|
def get_sentinel_url_from_env(redis_url, sentinel_hosts_env, sentinel_port_env): |
|
redis_config = parse_redis_service_url(redis_url) |
|
username = redis_config["username"] or "" |
|
password = redis_config["password"] or "" |
|
auth_part = "" |
|
if username or password: |
|
auth_part = f"{username}:{password}@" |
|
hosts_part = ",".join( |
|
f"{host}:{sentinel_port_env}" for host in sentinel_hosts_env.split(",") |
|
) |
|
return f"redis+sentinel://{auth_part}{hosts_part}/{redis_config['db']}/{redis_config['service']}" |
|
|