mirror of
				https://github.com/karl0ss/ai_image_frame_server.git
				synced 2025-10-26 12:14:08 +00:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			7f78912829
			...
			79c7e4d92c
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 79c7e4d92c | |||
| b072ec6c65 | 
| @ -1,5 +1,5 @@ | |||||||
| [tool.bumpversion] | [tool.bumpversion] | ||||||
| current_version = "0.2.8" | current_version = "0.2.9" | ||||||
| parse = "(?P<major>\\d+)\\.(?P<minor>\\d+)\\.(?P<patch>\\d+)" | parse = "(?P<major>\\d+)\\.(?P<minor>\\d+)\\.(?P<patch>\\d+)" | ||||||
| serialize = ["{major}.{minor}.{patch}"] | serialize = ["{major}.{minor}.{patch}"] | ||||||
| search = "{current_version}" | search = "{current_version}" | ||||||
|  | |||||||
| @ -103,7 +103,6 @@ def generate_image( | |||||||
|         # Generate image |         # Generate image | ||||||
|         logging.debug(f"Generating image: {file_name}") |         logging.debug(f"Generating image: {file_name}") | ||||||
|         results = api.queue_and_wait_images(wf, save_node) |         results = api.queue_and_wait_images(wf, save_node) | ||||||
|         rename_image() |  | ||||||
|          |          | ||||||
|         for _, image_data in results.items(): |         for _, image_data in results.items(): | ||||||
|             output_path = os.path.join( |             output_path = os.path.join( | ||||||
| @ -112,6 +111,7 @@ def generate_image( | |||||||
|             with open(output_path, "wb+") as f: |             with open(output_path, "wb+") as f: | ||||||
|                 f.write(image_data) |                 f.write(image_data) | ||||||
|             generate_thumbnail(output_path) |             generate_thumbnail(output_path) | ||||||
|  |         rename_image(f"{file_name}.png") | ||||||
| 
 | 
 | ||||||
|         logging.debug(f"Image generated successfully for UID: {file_name}") |         logging.debug(f"Image generated successfully for UID: {file_name}") | ||||||
| 
 | 
 | ||||||
| @ -143,7 +143,7 @@ def select_model(model: str) -> tuple[str, str]: | |||||||
| 
 | 
 | ||||||
| def create_image(prompt: str | None = None, model: str = "Random") -> None: | def create_image(prompt: str | None = None, model: str = "Random") -> None: | ||||||
|     """Generate an image with a chosen workflow (Random, FLUX*, or SDXL*).""" |     """Generate an image with a chosen workflow (Random, FLUX*, or SDXL*).""" | ||||||
| 
 |     from datetime import datetime | ||||||
|     if prompt is None: |     if prompt is None: | ||||||
|         prompt = create_prompt_on_openwebui(user_config["comfyui"]["prompt"]) |         prompt = create_prompt_on_openwebui(user_config["comfyui"]["prompt"]) | ||||||
| 
 | 
 | ||||||
| @ -154,9 +154,13 @@ def create_image(prompt: str | None = None, model: str = "Random") -> None: | |||||||
|     save_prompt(prompt) |     save_prompt(prompt) | ||||||
|     selected_workflow, model = select_model(model) |     selected_workflow, model = select_model(model) | ||||||
|      |      | ||||||
|  |     # Generate a unique filename using a timestamp | ||||||
|  |     timestamp = datetime.now().strftime("%Y%m%d-%H%M%S") | ||||||
|  |     file_name = f"{timestamp}_{random.getrandbits(32)}" | ||||||
|  | 
 | ||||||
|     if selected_workflow == "FLUX": |     if selected_workflow == "FLUX": | ||||||
|         generate_image( |         generate_image( | ||||||
|             file_name="image", |             file_name=file_name, | ||||||
|             comfy_prompt=prompt, |             comfy_prompt=prompt, | ||||||
|             workflow_path="./workflow_flux.json", |             workflow_path="./workflow_flux.json", | ||||||
|             prompt_node="Positive Prompt T5", |             prompt_node="Positive Prompt T5", | ||||||
| @ -169,6 +173,6 @@ def create_image(prompt: str | None = None, model: str = "Random") -> None: | |||||||
|             model=model |             model=model | ||||||
|         ) |         ) | ||||||
|     else:  # SDXL |     else:  # SDXL | ||||||
|         generate_image("image", comfy_prompt=prompt, model=model) |         generate_image(file_name, comfy_prompt=prompt, model=model) | ||||||
| 
 | 
 | ||||||
|     logging.info(f"{selected_workflow} generation started with prompt: {prompt}") |     logging.info(f"{selected_workflow} generation started with prompt: {prompt}") | ||||||
|  | |||||||
| @ -48,21 +48,41 @@ def load_config() -> configparser.ConfigParser: | |||||||
|         sys.exit(1) |         sys.exit(1) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def rename_image() -> str | None: | def rename_image(new_filename: str) -> str | None: | ||||||
|     """Renames 'image.png' in the output folder to a timestamped filename if it exists.""" |     """Renames the latest image in the output folder to a timestamped filename.""" | ||||||
|     old_path = os.path.join(user_config["comfyui"]["output_dir"], "image.png") |     output_dir = user_config["comfyui"]["output_dir"] | ||||||
|  |     image_png_path = os.path.join(output_dir, "image.png") | ||||||
|      |      | ||||||
|     if os.path.exists(old_path): |     # Check if image.png exists and is a favourite | ||||||
|         new_filename = f"{str(time.time())}.png" |     if os.path.exists(image_png_path): | ||||||
|         new_path = os.path.join(user_config["comfyui"]["output_dir"], new_filename) |         favourites = get_favourites() | ||||||
|         os.rename(old_path, new_path) |         if "image.png" in favourites: | ||||||
|         generate_thumbnail(new_path) |             # It's a favourite, so rename it to preserve it | ||||||
|         print(f"Renamed 'image.png' to '{new_filename}'") |             timestamped_filename = f"{datetime.now().strftime('%Y%m%d-%H%M%S')}.png" | ||||||
|         return new_filename |             timestamped_path = os.path.join(output_dir, timestamped_filename) | ||||||
|     else: |             os.rename(image_png_path, timestamped_path) | ||||||
|         print("No image.png found.") |              | ||||||
|  |             # Update favourites list | ||||||
|  |             favourites.remove("image.png") | ||||||
|  |             favourites.append(timestamped_filename) | ||||||
|  |             save_favourites(favourites) | ||||||
|  |             print(f"Preserved favourite 'image.png' as '{timestamped_filename}'") | ||||||
|  | 
 | ||||||
|  |     # Find the latest generated image (which is the new_filename) | ||||||
|  |     latest_image_path = os.path.join(output_dir, new_filename) | ||||||
|  |     if not os.path.exists(latest_image_path): | ||||||
|  |         print(f"Error: Newly generated image '{new_filename}' not found.") | ||||||
|         return None |         return None | ||||||
| 
 | 
 | ||||||
|  |     # Rename the latest image to "image.png" | ||||||
|  |     if os.path.exists(image_png_path): | ||||||
|  |         os.remove(image_png_path) # remove if it wasn't a favourite | ||||||
|  |          | ||||||
|  |     os.rename(latest_image_path, image_png_path) | ||||||
|  |     generate_thumbnail(image_png_path) | ||||||
|  |     print(f"Renamed '{new_filename}' to 'image.png'") | ||||||
|  |     return "image.png" | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| def get_details_from_png(path): | def get_details_from_png(path): | ||||||
|     try: |     try: | ||||||
| @ -112,5 +132,18 @@ def load_topics_from_config(): | |||||||
|     sorted_topics = sorted(topics, key=str.lower) |     sorted_topics = sorted(topics, key=str.lower) | ||||||
|     return sorted_topics |     return sorted_topics | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | favourites_file = "./favourites.json" | ||||||
|  | 
 | ||||||
|  | def get_favourites(): | ||||||
|  |     if not os.path.exists(favourites_file): | ||||||
|  |         return [] | ||||||
|  |     with open(favourites_file, 'r') as f: | ||||||
|  |         return json.load(f) | ||||||
|  | 
 | ||||||
|  | def save_favourites(favourites): | ||||||
|  |     with open(favourites_file, 'w') as f: | ||||||
|  |         json.dump(favourites, f) | ||||||
|  | 
 | ||||||
| user_config = load_config() | user_config = load_config() | ||||||
| output_folder = user_config["comfyui"]["output_dir"] | output_folder = user_config["comfyui"]["output_dir"] | ||||||
| @ -4,17 +4,7 @@ import json | |||||||
| 
 | 
 | ||||||
| bp = Blueprint("gallery_routes", __name__) | bp = Blueprint("gallery_routes", __name__) | ||||||
| image_folder = "./output" | image_folder = "./output" | ||||||
| favourites_file = "./favourites.json" | from libs.generic import get_favourites, save_favourites | ||||||
| 
 |  | ||||||
| def get_favourites(): |  | ||||||
|     if not os.path.exists(favourites_file): |  | ||||||
|         return [] |  | ||||||
|     with open(favourites_file, 'r') as f: |  | ||||||
|         return json.load(f) |  | ||||||
| 
 |  | ||||||
| def save_favourites(favourites): |  | ||||||
|     with open(favourites_file, 'w') as f: |  | ||||||
|         json.dump(favourites, f) |  | ||||||
| 
 | 
 | ||||||
| @bp.route("/images", methods=["GET"]) | @bp.route("/images", methods=["GET"]) | ||||||
| def gallery(): | def gallery(): | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user