import logging

logger = logging.getLogger("desktopenv.metric.general")


def check_htop_version(result: str) -> float:
    if "not found" in result:
        return 0
    else:
        return 1


def check_termcolor_version(result: str) -> float:
    if "termcolor" in result:
        return 1
    else:
        return 0


def check_git_config(result: str) -> float:
    if not result.strip():
        return 0
    else:
        return 1
    

def check_nodejs(result: str) -> float:
    if "not found" in result:
        return 0
    else:
        return 1
    

def check_env_editor(result: str) -> float:
    if not result.strip():
        return 0
    else:
        return 1
    

def check_service_active(result: str) -> float:
    if "inactive" in result.strip():
        return 1
    else:
        return 0


def check_terminal_cnt(result: str, rules) -> float:
    expected_cnt = rules["expected"]
    
    logger.info(f"expected cnt: {expected_cnt}")
    logger.info(f"result cnt: {int(result.strip()) - 2}")
    if int(result.strip()) >= expected_cnt:
        return 1
    else:
        return 0


def check_gnome_favorite_apps(apps_str: str, rule):
    # parse the string like "['thunderbird.desktop', 'vim.desktop', 'google-chrome.desktop']"
    # to a list of strings
    apps = eval(apps_str)

    expected_apps = rule["expected"]

    if len(apps) != len(expected_apps):
        return 0

    if set(apps) == set(expected_apps):
        return 1
    else:
        return 0


def is_utc_0(timedatectl_output):
    """
    Format as:
    Local time: Thu 2024-01-25 12:56:06 WET
           Universal time: Thu 2024-01-25 12:56:06 UTC
                 RTC time: Thu 2024-01-25 12:56:05
                Time zone: Atlantic/Faroe (WET, +0000)
System clock synchronized: yes
              NTP service: inactive
          RTC in local TZ: no
    """

    utc_line = timedatectl_output.split("\n")[3]

    if utc_line.endswith("+0000)"):
        return 1
    else:
        return 0


def check_text_enlarged(scaling_factor_str):
    scaling_factor = float(scaling_factor_str)
    if scaling_factor > 1.0:
        return 1
    else:
        return 0


def check_moved_jpgs(directory_list, rule):
    expected_jpgs = rule["expected"]
    moved_jpgs = [node['name'] for node in directory_list['children']]

    if len(moved_jpgs) != len(expected_jpgs):
        return 0

    if set(moved_jpgs) == set(expected_jpgs):
        return 1
    else:
        return 0


def is_in_vm_clickboard(config, terminal_output):
    print("terminal_output: ")
    print(terminal_output)
    print("config: ")
    print(config)
    expected_results = config["expected"]
    # check if terminal_output has expected results
    if not isinstance(expected_results, list):
        return 1 if expected_results in terminal_output else 0
    else:
        return 1 if all(result in terminal_output for result in expected_results) else 0
