<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="stylesheet"
        integrity="sha384-GLhlTQ8iRABdZLl6O3oVMWSktQOp6b7In1Zl3/Jr59b6EGGoI1aFkw7cmDA6j6gD" crossorigin="anonymous">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.3.0/css/all.min.css"
        integrity="sha512-SzlrxWUlpfuzQ+pcUCosxcglQRNAq/DZjVsC0lE40xsADsfeQoEypE+enwcOiGjk/bSuGGKHEyjSoQ1zVisanQ=="
        crossorigin="anonymous" referrerpolicy="no-referrer" />
</head>
</html>
import re
from logger_config import get_logger


def get_csf_config_value(
    var_name: str, config_file="/etc/csf/csf.conf"
) -> str | None:
    logger = get_logger()
    try:
        with open(config_file, "r") as f:
            for line in f:
                # Strip whitespace and skip empty lines and comments
                line = line.strip()
                if not line or line.startswith("#"):
                    continue

                # Match pattern: VAR_NAME = "value" (with flexible whitespace)
                # This regex handles:
                # - Optional whitespace around = (e.g. VAR_NAME="value" or VAR_NAME= "value")
                # - Quoted values (double quotes, single quotes are not valid in CSF config)
                # - Captures the value inside quotes (e.g. "value")
                pattern = rf'^{re.escape(var_name)}\s*=\s*["]([^"]*)["]'
                match = re.match(pattern, line)

                if match:
                    return match.group(1)

        # Variable not found
        return None

    except FileNotFoundError:
        logger.error(f"Config file {config_file} not found")
        return None
    except PermissionError:
        logger.error(f"Permission denied reading {config_file}")
        return None
    except Exception as e:
        logger.error(f"Error reading config file: {e}")
        return None
