import os
import psycopg2

from pathlib import Path
from typing import Optional


def find_first_sql(root: str | Path) -> Optional[Path]:
    root = Path(root).expanduser().resolve()
    if not root.is_dir():
        raise ValueError(f"{root} is not a directory")

    for current_dir, dirs, files in os.walk(root, followlinks=False):
        # prune unwanted sub-trees
        dirs[:] = [d for d in dirs if d != "node_modules"]
        for f in files:
            if f.lower().endswith(".sql"):
                return Path(current_dir) / f
    return None


def initialize_db(sql_file):
    """
    Connects to the PostgreSQL database and executes the SQL schema file.
    
    Args:
        sql_file (str): Path to the SQL file containing the database schema
    """
    # Get database configuration from environment variables
    db_config = {
        'host': os.getenv('DB_HOST', 'localhost'),
        'port': os.getenv('DB_PORT', 5432),
        'user': os.getenv('DB_USERNAME', 'myappuser'),
        'password': os.getenv('DB_PASSWORD', 'myapppassword'),
        'database': os.getenv('DB_NAME', 'myapp')
    }
    
    # Connect to the database
    try:
        connection = psycopg2.connect(**db_config)
        cursor = connection.cursor()
        
        # Read the SQL file
        with open(sql_file, 'r', encoding='utf-8') as file:
            sql_commands = file.read()
        
        # Execute the SQL commands
        cursor.execute(sql_commands)
        
        # Commit the changes
        connection.commit()
        
        print("Database schema initialized successfully!")
        
    except psycopg2.Error as e:
        print(f"Error initializing database: {e}")
        
    finally:
        # Close the cursor and connection
        if cursor:
            cursor.close()
        if connection:
            connection.close()

if __name__ == "__main__":
    # Example usage
    # initialize_db(r"E:\Qwen-Code\workspaces\Qwen3-Coder-480B-A35B-Instruct-FP8_fullstack\000002\backend\schema.sql")
    print(find_first_sql(r"E:\Qwen-Code\workspaces\Qwen3-Coder-480B-A35B-Instruct-FP8_fullstack\000002\frontend"))