mirror of
				https://github.com/avatao-content/baseimage-tutorial-framework
				synced 2025-10-26 05:22:55 +00:00 
			
		
		
		
	Fix inotify event logs triggering themselves (infinite log recursion)
This commit is contained in:
		| @@ -1,6 +1,7 @@ | |||||||
| # Copyright (C) 2018 Avatao.com Innovative Learning Kft. | # Copyright (C) 2018 Avatao.com Innovative Learning Kft. | ||||||
| # All Rights Reserved. See LICENSE file for details. | # All Rights Reserved. See LICENSE file for details. | ||||||
|  |  | ||||||
|  | import logging | ||||||
| from os.path import dirname | from os.path import dirname | ||||||
|  |  | ||||||
| from watchdog.events import PatternMatchingEventHandler as PatternMatchingWatchdogEventHandler | from watchdog.events import PatternMatchingEventHandler as PatternMatchingWatchdogEventHandler | ||||||
| @@ -12,6 +13,7 @@ from tfw.mixins import ObserverMixin, SupervisorLogMixin | |||||||
|  |  | ||||||
| class LogMonitor(ObserverMixin): | class LogMonitor(ObserverMixin): | ||||||
|     def __init__(self, process_name): |     def __init__(self, process_name): | ||||||
|  |         self.prevent_log_recursion() | ||||||
|         ObserverMixin.__init__(self) |         ObserverMixin.__init__(self) | ||||||
|         event_handler = SendLogWatchdogEventHandler(process_name) |         event_handler = SendLogWatchdogEventHandler(process_name) | ||||||
|         self.observer.schedule( |         self.observer.schedule( | ||||||
| @@ -19,6 +21,11 @@ class LogMonitor(ObserverMixin): | |||||||
|             event_handler.path |             event_handler.path | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|  |     @staticmethod | ||||||
|  |     def prevent_log_recursion(): | ||||||
|  |         # This is done to prevent inotify event logs triggering themselves (infinite log recursion) | ||||||
|  |         logging.getLogger('watchdog.observers.inotify_buffer').propagate = False | ||||||
|  |  | ||||||
|  |  | ||||||
| class SendLogWatchdogEventHandler(PatternMatchingWatchdogEventHandler, SupervisorLogMixin): | class SendLogWatchdogEventHandler(PatternMatchingWatchdogEventHandler, SupervisorLogMixin): | ||||||
|     def __init__(self, process_name): |     def __init__(self, process_name): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user