Skip to content
This repository has been archived by the owner on Dec 30, 2024. It is now read-only.

Commit

Permalink
refactor: enhance image creation function with environment variable h…
Browse files Browse the repository at this point in the history
…andling
  • Loading branch information
FuseFairy committed Feb 2, 2024
1 parent f422497 commit 3336b4f
Showing 1 changed file with 11 additions and 8 deletions.
19 changes: 11 additions & 8 deletions src/image/image_create.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,15 @@
import discord
import asyncio
import requests
import os
from PIL import Image
from io import BytesIO
from re_edge_gpt import ImageGenAsync
from src.log import setup_logger
from src.image.button_view import ButtonView
from dotenv import load_dotenv

load_dotenv()

logger = setup_logger(__name__)

Expand All @@ -17,13 +21,12 @@ async def create_image(interaction: discord.Interaction, users_chatbot: dict, pr
user_id = interaction.user.id
username = interaction.user
channel = interaction.channel
prompts = f"> **{prompt}** - <@{str(interaction.user.id)}> (***BingImageCreator***)\n\n"
prompts = f"> **{prompt}** - <@{str(user_id)}> (***BingImageCreator***)\n\n"

logger.info(f"\x1b[31m{username}\x1b[0m'{prompt}' ({channel}) [BingImageCreator]")
logger.info(f"\x1b[31m{username}\x1b[0m'{prompt}' ({channel}) [BingImageCreator]")

# Fetches image links
async_gen = ImageGenAsync(auth_cookie=auth_cookie, quiet=True)
images = await async_gen.get_images(prompt=prompt, timeout=300)
images = await async_gen.get_images(prompt=prompt, timeout=int(os.getenv("IMAGE_TIMEOUT")), max_generate_time_sec=int(os.getenv("IMAGE_MAX_CREATE_SEC")))
images = [file for file in images if not file.endswith('.svg')]
new_image = await concatenate_images(images)
image_data = BytesIO()
Expand All @@ -32,11 +35,11 @@ async def create_image(interaction: discord.Interaction, users_chatbot: dict, pr

await interaction.followup.send(prompts, file=discord.File(fp=image_data, filename='new_image.png'), view=ButtonView(interaction, prompt, images, users_chatbot, user_id))
except asyncio.TimeoutError:
await interaction.followup.send("> **Error: Request timed out.**")
logger.error("Error while create image: Request timed out.")
await interaction.followup.send("> **ErrorRequest timed out.**")
logger.error("Error while create imageRequest timed out.")
except Exception as e:
await interaction.followup.send(f"> **Error: {e}**")
logger.error(f"Error while create image: {e}")
await interaction.followup.send(f"> **Error{e}**")
logger.error(f"Error while create image{e}")

async def concatenate_images(image_urls):
images = [Image.open(BytesIO(requests.get(url).content)) for url in image_urls]
Expand Down

0 comments on commit 3336b4f

Please sign in to comment.