from functools import cached_property
import json
import re
import subprocess
import tempfile
from pathlib import Path
import logging

from .challenge_utils import CATEGORY_FRIENDLY

logger = logging.getLogger("CTFChallenge")

category_friendly = {
    "rev": "reverse engineering",
    "pwn": "binary exploitation",
    "web": "web security",
    "crypto": "cryptography",
    "misc": "miscellaneous",
    "forensics": "forensics",
}

category_short = {
    "crypto": "cry",
    "forensics": "for",
    "misc": "msc",
    "pwn": "pwn",
    "rev": "rev",
    "web": "web",
}

class CTFChallenge:
    def __init__(self, challenge_id, challenge_server, flag_format, category):

        self.challenge_server_log = None
        self.challenge_server_output = None
        self.server = challenge_server
        self.id = challenge_id
        self.flag_format = flag_format
        self.category = category

    def get_compose_logs(self):
        return subprocess.check_output(
            ['docker', 'compose', '-f', self.chaldir / 'docker-compose.yml', 'logs'],
            text=True,
        )
    
    def get_server_logs(self):
        if self.disable_docker:
            return None
        if self.is_compose:
            return self.get_compose_logs()
        if not self.challenge_server_log:
            return None
        self.challenge_server_log.flush()
        self.challenge_server_log.seek(0)
        return self.challenge_server_log.read().decode('utf-8', errors='replace')


    @cached_property
    def category_friendly(self):
        return CATEGORY_FRIENDLY[self.category]

