| | """ |
| | Initialize Default Source Pools |
| | Creates intelligent source pools based on provider categories |
| | """ |
| |
|
| | import sys |
| | import os |
| |
|
| | |
| | sys.path.insert(0, os.path.dirname(os.path.dirname(os.path.abspath(__file__)))) |
| |
|
| | from database.db_manager import db_manager |
| | from monitoring.source_pool_manager import SourcePoolManager |
| | from utils.logger import setup_logger |
| |
|
| | logger = setup_logger("init_pools") |
| |
|
| |
|
| | def init_default_pools(): |
| | """ |
| | Initialize default source pools for all categories |
| | """ |
| | logger.info("=" * 60) |
| | logger.info("Initializing Default Source Pools") |
| | logger.info("=" * 60) |
| |
|
| | |
| | db_manager.init_database() |
| |
|
| | |
| | session = db_manager.get_session() |
| | pool_manager = SourcePoolManager(session) |
| |
|
| | |
| | pool_configs = [ |
| | { |
| | "name": "Market Data Pool", |
| | "category": "market_data", |
| | "description": "Pool for market data APIs (CoinGecko, CoinMarketCap, etc.)", |
| | "rotation_strategy": "priority", |
| | "providers": [ |
| | {"name": "CoinGecko", "priority": 3, "weight": 1}, |
| | {"name": "CoinMarketCap", "priority": 2, "weight": 1}, |
| | {"name": "Binance", "priority": 1, "weight": 1}, |
| | ] |
| | }, |
| | { |
| | "name": "Blockchain Explorers Pool", |
| | "category": "blockchain_explorers", |
| | "description": "Pool for blockchain explorer APIs", |
| | "rotation_strategy": "round_robin", |
| | "providers": [ |
| | {"name": "Etherscan", "priority": 1, "weight": 1}, |
| | {"name": "BscScan", "priority": 1, "weight": 1}, |
| | {"name": "TronScan", "priority": 1, "weight": 1}, |
| | ] |
| | }, |
| | { |
| | "name": "News Sources Pool", |
| | "category": "news", |
| | "description": "Pool for news and media APIs", |
| | "rotation_strategy": "round_robin", |
| | "providers": [ |
| | {"name": "CryptoPanic", "priority": 2, "weight": 1}, |
| | {"name": "NewsAPI", "priority": 1, "weight": 1}, |
| | ] |
| | }, |
| | { |
| | "name": "Sentiment Analysis Pool", |
| | "category": "sentiment", |
| | "description": "Pool for sentiment analysis APIs", |
| | "rotation_strategy": "least_used", |
| | "providers": [ |
| | {"name": "AlternativeMe", "priority": 1, "weight": 1}, |
| | ] |
| | }, |
| | { |
| | "name": "RPC Nodes Pool", |
| | "category": "rpc_nodes", |
| | "description": "Pool for RPC node providers", |
| | "rotation_strategy": "priority", |
| | "providers": [ |
| | {"name": "Infura", "priority": 2, "weight": 1}, |
| | {"name": "Alchemy", "priority": 1, "weight": 1}, |
| | ] |
| | }, |
| | ] |
| |
|
| | created_pools = [] |
| |
|
| | for config in pool_configs: |
| | try: |
| | |
| | from database.models import SourcePool |
| | existing_pool = session.query(SourcePool).filter_by(name=config["name"]).first() |
| |
|
| | if existing_pool: |
| | logger.info(f"Pool '{config['name']}' already exists, skipping") |
| | continue |
| |
|
| | |
| | pool = pool_manager.create_pool( |
| | name=config["name"], |
| | category=config["category"], |
| | description=config["description"], |
| | rotation_strategy=config["rotation_strategy"] |
| | ) |
| |
|
| | logger.info(f"Created pool: {pool.name}") |
| |
|
| | |
| | added_count = 0 |
| | for provider_config in config["providers"]: |
| | |
| | provider = db_manager.get_provider(name=provider_config["name"]) |
| |
|
| | if provider: |
| | pool_manager.add_to_pool( |
| | pool_id=pool.id, |
| | provider_id=provider.id, |
| | priority=provider_config["priority"], |
| | weight=provider_config["weight"] |
| | ) |
| | logger.info( |
| | f" Added {provider.name} to pool " |
| | f"(priority: {provider_config['priority']})" |
| | ) |
| | added_count += 1 |
| | else: |
| | logger.warning( |
| | f" Provider '{provider_config['name']}' not found, skipping" |
| | ) |
| |
|
| | created_pools.append({ |
| | "name": pool.name, |
| | "members": added_count |
| | }) |
| |
|
| | except Exception as e: |
| | logger.error(f"Error creating pool '{config['name']}': {e}", exc_info=True) |
| |
|
| | session.close() |
| |
|
| | |
| | logger.info("=" * 60) |
| | logger.info("Pool Initialization Complete") |
| | logger.info(f"Created {len(created_pools)} pools:") |
| | for pool in created_pools: |
| | logger.info(f" - {pool['name']}: {pool['members']} members") |
| | logger.info("=" * 60) |
| |
|
| | return created_pools |
| |
|
| |
|
| | if __name__ == "__main__": |
| | init_default_pools() |
| |
|