import json

def _load_annotation(path):
    all_annotations = []
    difficulty = []
    with open(path, 'r') as f:
        for line in f:
            if line.strip() == '':
                continue
            line = json.loads(line.strip())
            if "subgoals" in line and "subgoals_1" not in line:
                all_annotations.append(line["subgoals"])
            else:
                annotation = []
                for key in line:
                    if "subgoals" in key:
                        annotation.append(line[key])
                all_annotations.append(annotation)
            
            if "difficulty" in line:
                difficulty.append(line["difficulty"])
            else:
                raise ValueError("No difficulty in annotation file")
    return all_annotations, difficulty

def get_all_environment_configs():
    iter_num = 0
    # initial config
    seed = 1234
    env_num_per_task = 4
    label_path = "./verl/environments/babyai/test.jsonl"
    game_level = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 24, 25, 27, 28, 29, 31, 32]

    env_configs = []
    seeds = range(seed, seed + env_num_per_task)
    obs_to_reward_list, difficulties = _load_annotation(label_path)
    assert len(game_level) * env_num_per_task == len(obs_to_reward_list)

    for level in game_level:
        for seed in seeds:
            env_configs.append({
                "game_id": f"level_{level}_seed_{seed}",
                "game_level": level,
                "game_name": all_levels[level],
                "seed": seed,
                "obs_to_reward": obs_to_reward_list[iter_num],
                "difficulty": difficulties[iter_num]
            })
            iter_num += 1
            
    return env_configs

all_levels = {
    1: "BabyAI-GoToRedBallGrey-v0",
    2: "BabyAI-GoToRedBall-v0",
    3: "BabyAI-GoToRedBallNoDists-v0",
    4: "BabyAI-GoToObjS6-v0",
    5: "BabyAI-GoToLocalS8N7-v0",
    6: "BabyAI-GoToObjMazeS7-v0",
    7: "BabyAI-GoToImpUnlock-v0",
    8: "BabyAI-GoToSeqS5R2-v0",
    9: "BabyAI-GoToRedBlueBall-v0",
    10: "BabyAI-GoToDoor-v0",
    11: "BabyAI-GoToObjDoor-v0",
    12: "BabyAI-Open-v0",
    13: "BabyAI-OpenRedDoor-v0",
    14: "BabyAI-OpenDoorLoc-v0",
    15: "BabyAI-OpenRedBlueDoorsDebug-v0",
    16: "BabyAI-OpenDoorsOrderN4Debug-v0",
    17: "BabyAI-Pickup-v0",
    18: "BabyAI-UnblockPickup-v0",
    19: "BabyAI-PickupLoc-v0",
    20: "BabyAI-PickupDistDebug-v0",
    21: "BabyAI-PickupAbove-v0",
    22: "BabyAI-PutNextLocalS6N4-v0",
    23: "BabyAI-PutNextS7N4Carrying-v0",
    24: "BabyAI-Unlock-v0",
    25: "BabyAI-UnlockLocalDist-v0",
    26: "BabyAI-KeyInBox-v0",
    27: "BabyAI-UnlockPickupDist-v0",
    28: "BabyAI-BlockedUnlockPickup-v0",
    29: "BabyAI-UnlockToUnlock-v0",
    30: "BabyAI-ActionObjDoor-v0",
    31: "BabyAI-FindObjS7-v0",
    32: "BabyAI-KeyCorridorS6R3-v0",
    33: "BabyAI-OneRoomS20-v0",
    34: "BabyAI-MoveTwoAcrossS8N9-v0",
    35: "BabyAI-SynthS5R2-v0",
    36: "BabyAI-SynthLoc-v0",
    37: "BabyAI-SynthSeq-v0",
    38: "BabyAI-MiniBossLevel-v0",
    39: "BabyAI-BossLevel-v0",
    40: "BabyAI-BossLevelNoUnlock-v0"
}


if __name__ == "__main__":
    env_configs = get_all_environment_configs()
    for config in env_configs:
        for x in config["obs_to_reward"]:
            if isinstance(x, list):
                breakpoint()
    breakpoint()