| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  | from __future__ import annotations | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import logging | 
					
						
							|  |  |  | import os | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-11 17:20:39 +02:00
										 |  |  | from bot.message.inboundMessage import InboundMessage | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-08 15:25:47 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | # noinspection SpellCheckingInspection | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  | class Logger: | 
					
						
							|  |  |  |     action_logger: str = 'action-logger' | 
					
						
							|  |  |  |     action_logger_file: str = '/var/log/bot/action.log' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     main_logger: str = 'main-logger' | 
					
						
							|  |  |  |     main_logger_file: str = '/var/log/bot/app.log' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-08 15:25:47 +02:00
										 |  |  |     def __init__(self): | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  |         self.configure(self.action_logger, self.action_logger_file, logging.INFO) | 
					
						
							|  |  |  |         self.configure(self.main_logger, self.main_logger_file, logging.ERROR) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def configure(self, logger_name, log_file, level) -> None: | 
					
						
							|  |  |  |         directory = os.path.dirname(log_file) | 
					
						
							|  |  |  |         if not os.path.exists(directory): | 
					
						
							|  |  |  |             os.makedirs(directory) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         logger = logging.getLogger(logger_name) | 
					
						
							| 
									
										
										
										
											2021-10-13 18:40:24 +02:00
										 |  |  |         logger.propagate = False | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  |         file_handler = logging.FileHandler(log_file, mode='w') | 
					
						
							| 
									
										
										
										
											2021-10-13 18:40:24 +02:00
										 |  |  |         formatter = logging.Formatter('%(asctime)s [%(levelname)s]: %(message)s', datefmt='%H:%M:%S %Y/%m/%d') | 
					
						
							|  |  |  |         file_handler.setFormatter(formatter) | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  |         stream_handler = logging.StreamHandler() | 
					
						
							| 
									
										
										
										
											2021-10-13 18:40:24 +02:00
										 |  |  |         stream_handler.setFormatter(formatter) | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         logger.setLevel(level) | 
					
						
							|  |  |  |         logger.addHandler(file_handler) | 
					
						
							|  |  |  |         logger.addHandler(stream_handler) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-08 15:25:47 +02:00
										 |  |  |     @staticmethod | 
					
						
							|  |  |  |     def register() -> None: | 
					
						
							|  |  |  |         Logger() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  |     @staticmethod | 
					
						
							| 
									
										
										
										
											2021-10-11 17:20:39 +02:00
										 |  |  |     def get(logger_name: str) -> logging.Logger: | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  |         return logging.getLogger(logger_name) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-08 15:25:47 +02:00
										 |  |  |     @staticmethod | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  |     def info(message: str) -> None: | 
					
						
							| 
									
										
										
										
											2021-10-11 17:20:39 +02:00
										 |  |  |         Logger.get(Logger.action_logger).info(message) | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-08 15:25:47 +02:00
										 |  |  |     @staticmethod | 
					
						
							| 
									
										
										
										
											2021-10-05 19:20:04 +02:00
										 |  |  |     def error(message: str) -> None: | 
					
						
							| 
									
										
										
										
											2021-10-11 17:20:39 +02:00
										 |  |  |         Logger.get(Logger.main_logger).error(message) | 
					
						
							| 
									
										
										
										
											2021-10-08 15:25:47 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     @staticmethod | 
					
						
							| 
									
										
										
										
											2021-10-11 17:20:39 +02:00
										 |  |  |     def exception(exception: Exception) -> None: | 
					
						
							|  |  |  |         Logger.get(Logger.main_logger).exception(exception) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @staticmethod | 
					
						
							|  |  |  |     def action(inbound: InboundMessage, action: str) -> None: | 
					
						
							|  |  |  |         Logger.info(f'User {inbound.username}({inbound.user_id}) called {action.upper()} for {inbound.chat_id}') |