import os
import json
from sklearn.metrics import roc_auc_score

def get_score(TP,FP,N):
    y_true = [0]*N + [1]*N
    y_scores = FP+TP
    auroc_score = roc_auc_score(y_true, y_scores)

    return auroc_score


def get_best_Z(w_water, wo_water, data_num):
    auroc = get_score(w_water,wo_water,data_num)
    
    return round(auroc,4)

def load_watermarking_data(basepath,file_name):
    wo_water = f"{file_name.replace('.json','')}_wo_watermark.json"

    with open(os.path.join(basepath,file_name), 'r', encoding='utf-8') as f:
        water = json.load(f) 
    with open(os.path.join(basepath,wo_water), 'r', encoding='utf-8') as f:
        wo_water = json.load(f)
        
    return water, wo_water

def get_auroc(args):
    attack_suffix = getattr(args, 'attack_suffix', None)
    if attack_suffix:
        result_dir = f"./results/auroc_attacked/{attack_suffix}/{args.dataset_name}/{args.model_name}_{args.model_size}/"
        zscore_dir = f"./results/zscore_attacked/{attack_suffix}/{args.dataset_name}/{args.model_name}_{args.model_size}/"
        suffix = f"_attacked_{attack_suffix}"
    else:
        result_dir = f"./results/auroc/{args.dataset_name}/{args.model_name}_{args.model_size}/"
        zscore_dir = f"./results/zscore/{args.dataset_name}/{args.model_name}_{args.model_size}/"
        suffix = ""

    os.makedirs(result_dir, exist_ok=True)
    savepath = os.path.join(result_dir, f"auroc_results{suffix}.txt")
    
    if not os.path.exists(savepath):
        with open(savepath, 'w', encoding='utf-8') as f:
            f.write("")
        exists_lines = []
    else:
        with open(savepath, 'r', encoding='utf-8') as f:
            exists_lines = f.readlines()

    exists_keys = set()
    for line in exists_lines:
        key = line.split("::")[0].strip()
        exists_keys.add(key)

    os.makedirs(zscore_dir, exist_ok=True)

    for file_name in os.listdir(zscore_dir):
        if 'prompt' in file_name:
            continue
        if 'wo_watermark' in file_name:
            continue

        key = f"{file_name}"
        if key in exists_keys:
            continue

        water, wo_water = load_watermarking_data(zscore_dir, file_name)
        best_auroc = get_best_Z(water, wo_water, len(water))[0]

        with open(savepath, 'a', encoding='utf-8') as f:
            f.write(f"{key} :: {best_auroc}\n")