39 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import logging
 | |
| import argparse
 | |
| 
 | |
| from app import image_diff_queue
 | |
| from data.model import DataModelException
 | |
| from endpoints.registry import process_image_changes
 | |
| from workers.worker import Worker
 | |
| 
 | |
| 
 | |
| root_logger = logging.getLogger('')
 | |
| root_logger.setLevel(logging.DEBUG)
 | |
| 
 | |
| FORMAT = '%(asctime)-15s - %(levelname)s - %(pathname)s - %(funcName)s - %(message)s'
 | |
| formatter = logging.Formatter(FORMAT)
 | |
| 
 | |
| logger = logging.getLogger(__name__)
 | |
| 
 | |
| 
 | |
| class DiffsWorker(Worker):
 | |
|   def process_queue_item(self, job_details):
 | |
|     image_id = job_details['image_id']
 | |
|     namespace = job_details['namespace']
 | |
|     repository = job_details['repository']
 | |
| 
 | |
|     try:
 | |
|       process_image_changes(namespace, repository, image_id)
 | |
|     except DataModelException:
 | |
|       # This exception is unrecoverable, and the item should continue and be
 | |
|       # marked as complete.
 | |
|       msg = ('Image does not exist in database \'%s\' for repo \'%s/\'%s\'' %
 | |
|              (image_id, namespace, repository))
 | |
|       logger.warning(msg)
 | |
| 
 | |
|     return True
 | |
| 
 | |
| logging.config.fileConfig('conf/logging.conf', disable_existing_loggers=False)  
 | |
| 
 | |
| worker = DiffsWorker(image_diff_queue)
 | |
| worker.start()
 |