Update system signal handling
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				Docker Build and Push / build-and-push (push) Successful in 1m9s
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	Docker Build and Push / build-and-push (push) Successful in 1m9s
				
			This commit is contained in:
		| @@ -17,6 +17,9 @@ import discord | ||||
| from discord.ext import commands, tasks | ||||
| from discord import app_commands | ||||
| import os | ||||
| import sys | ||||
| import signal | ||||
| import types | ||||
| import aiohttp | ||||
| import asyncio | ||||
| import json | ||||
| @@ -923,7 +926,6 @@ class PterodactylBot(commands.Bot): | ||||
|         if self.pterodactyl_api: | ||||
|             await self.pterodactyl_api.close() | ||||
|         await super().close() | ||||
|         logger.info("Bot shutting down") | ||||
|  | ||||
| # ============================================== | ||||
| # DISCORD COMMANDS | ||||
| @@ -1089,17 +1091,66 @@ async def on_ready(): | ||||
|     except Exception as e: | ||||
|         logger.error(f"Command sync failed: {str(e)}") | ||||
|  | ||||
| # ============================================== | ||||
| # SYSTEM SIGNAL HANDLERS | ||||
| # ============================================== | ||||
|  | ||||
| def handle_sigint(signum: int, frame: types.FrameType) -> None: | ||||
|     """ | ||||
|     Handle SIGINT signals (Ctrl+C) by initiating graceful shutdown. | ||||
|      | ||||
|     Args: | ||||
|         signum: The signal number (signal.SIGINT) | ||||
|         frame: Current stack frame (unused but required by signal handler signature) | ||||
|     """ | ||||
|     logger.info("Received SIGINT (Ctrl+C), initiating graceful shutdown...") | ||||
|     raise KeyboardInterrupt | ||||
|  | ||||
| def handle_sigterm(signum: int, frame: types.FrameType) -> None: | ||||
|     """ | ||||
|     Handle SIGTERM signals (container stop) by initiating graceful shutdown. | ||||
|      | ||||
|     Args: | ||||
|         signum: The signal number (signal.SIGTERM) | ||||
|         frame: Current stack frame (unused but required by signal handler signature) | ||||
|     """ | ||||
|     logger.info("Received SIGTERM (container stop), initiating graceful shutdown...") | ||||
|     raise KeyboardInterrupt | ||||
|  | ||||
| # ============================================== | ||||
| # BOT STARTUP | ||||
| # ============================================== | ||||
|  | ||||
| if __name__ == "__main__": | ||||
|     """ | ||||
|     Main entry point for the bot application. | ||||
|      | ||||
|     Handles: | ||||
|     - Signal registration for graceful shutdowns (SIGINT/SIGTERM) | ||||
|     - Primary bot execution loop | ||||
|     - Error handling and crash reporting | ||||
|     - Resource cleanup on shutdown | ||||
|      | ||||
|     Flow: | ||||
|     1. Initialize signal handlers | ||||
|     2. Start bot with Discord token | ||||
|     3. Handle interrupts and exceptions | ||||
|     4. Execute final cleanup | ||||
|     """ | ||||
|     logger.info("Starting bot initialization") | ||||
|  | ||||
|     # Register signal handlers | ||||
|     signal.signal(signal.SIGINT, handle_sigint)   # For Ctrl+C | ||||
|     signal.signal(signal.SIGTERM, handle_sigterm)  # For container stop commands | ||||
|     logger.info("System signal handlers registered") | ||||
|  | ||||
|     try: | ||||
|         bot.run(DISCORD_TOKEN) | ||||
|     except KeyboardInterrupt: | ||||
|         logger.info("Bot shutting down due to keyboard interrupt") | ||||
|         logger.info("Bot shutting down") | ||||
|     except Exception as e: | ||||
|         logger.error(f"Bot crashed: {str(e)}") | ||||
|         sys.exit(1)  # Exit with error code for crash | ||||
|     finally: | ||||
|         logger.info("Bot shutdown complete") | ||||
|         sys.exit(0)  # Explicit clean exit | ||||
|   | ||||
		Reference in New Issue
	
	Block a user