123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- """Utilities for working with registries."""
- import httpx
- from reflex.config import environment
- from reflex.utils import console, net
- def latency(registry: str) -> int:
- """Get the latency of a registry.
- Args:
- registry (str): The URL of the registry.
- Returns:
- int: The latency of the registry in microseconds.
- """
- try:
- time_to_respond = net.get(registry, timeout=2).elapsed.microseconds
- except httpx.HTTPError:
- console.info(f"Failed to connect to {registry}.")
- return 10_000_000
- else:
- console.debug(f"Latency of {registry}: {time_to_respond}")
- return time_to_respond
- def average_latency(registry: str, attempts: int = 3) -> int:
- """Get the average latency of a registry.
- Args:
- registry: The URL of the registry.
- attempts: The number of attempts to make. Defaults to 10.
- Returns:
- The average latency of the registry in microseconds.
- """
- registry_latency = sum(latency(registry) for _ in range(attempts)) // attempts
- console.debug(f"Average latency of {registry}: {registry_latency}")
- return registry_latency
- def _get_best_registry() -> str:
- """Get the best registry based on latency.
- Returns:
- The best registry.
- """
- console.debug("Getting best registry...")
- registries = [
- "https://registry.npmjs.org",
- "https://r.cnpmjs.org",
- ]
- best_registry = min(registries, key=average_latency)
- console.debug(f"Best registry: {best_registry}")
- return best_registry
- def get_npm_registry() -> str:
- """Get npm registry. If environment variable is set, use it first.
- Returns:
- The npm registry.
- """
- return environment.NPM_CONFIG_REGISTRY.get() or _get_best_registry()
|