import discord
import logging
import os
import asyncio
import subprocess
from huggingface_hub import InferenceClient
from PIL import Image
import io

# 로깅 설정
logging.basicConfig(level=logging.DEBUG, format='%(asctime)s:%(levelname)s:%(name)s: %(message)s', handlers=[logging.StreamHandler()])

# 인텐트 설정
intents = discord.Intents.default()
intents.message_content = True
intents.messages = True
intents.guilds = True
intents.guild_messages = True

# 추론 API 클라이언트 설정
hf_client = InferenceClient(token=os.getenv("HF_TOKEN"))

# 특정 채널 ID
SPECIFIC_CHANNEL_ID = int(os.getenv("DISCORD_CHANNEL_ID"))

class MyClient(discord.Client):
    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        self.is_processing = False

    async def on_ready(self):
        logging.info(f'{self.user} has logged in!')
        subprocess.Popen(["python", "web.py"])  # Start the web.py server as a separate process
        logging.info("Web.py server has been started.")

    async def on_message(self, message):
        if message.author == self.user or not message.content:
            return
        if message.channel.id != SPECIFIC_CHANNEL_ID and not isinstance(message.channel, discord.Thread):
            return
        if self.is_processing:
            return
        self.is_processing = True
        try:
            image_path = await generate_image(message.content)
            if image_path:
                await send_image(message.channel, image_path)
            else:
                await message.channel.send("Failed to generate the image.")
        finally:
            self.is_processing = False

async def generate_image(prompt):
    try:
        # 모델 호출
        response = hf_client(inputs=prompt)
        image_data = response['images'][0]  # 응답에서 이미지 데이터 추출
        image_bytes = io.BytesIO(base64.b64decode(image_data))
        image = Image.open(image_bytes)
        image_path = "output.png"
        image.save(image_path)
        return image_path
    except Exception as e:
        logging.error(f"Failed to generate image: {str(e)}")
        return None



async def send_image(channel, image_path):
    file = discord.File(image_path)
    await channel.send(file=file)

if __name__ == "__main__":
    discord_client = MyClient(intents=intents)
    discord_client.run(os.getenv('DISCORD_TOKEN'))