import os
import psycopg2

from pathlib import Path
from typing import Optional


def find_first_sql(directory: str | Path) -> Optional[Path]:
    root = Path(directory).expanduser().resolve()
    print(f"Finding sql file in {root}")

    if not root.is_dir():
        raise ValueError(f"{root} is not a directory")

    # Depth-first, lexicographical order
    for file in os.listdir(root):
        if file.endswith(".sql"):
            print(f"Found sql file: {str(root / file)}")
            return root / file


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"D:\research\WebGen-Bench\Qwen-Code-Fullstack-Fork\workspaces\Qwen3-Coder-30B-A3B-Instruct_fullstack\000002\neighborhood-mapper"))