30 lines
		
	
	
	
		
			1,011 B
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
	
		
			1,011 B
		
	
	
	
		
			Python
		
	
	
	
	
	
| import logging
 | |
| 
 | |
| from app import app
 | |
| from data.database import UseThenDisconnect
 | |
| from data.model.repository import find_repository_with_garbage, garbage_collect_repo
 | |
| from workers.worker import Worker
 | |
| 
 | |
| logger = logging.getLogger(__name__)
 | |
| 
 | |
| class GarbageCollectionWorker(Worker):
 | |
|   def __init__(self):
 | |
|     super(GarbageCollectionWorker, self).__init__()
 | |
|     self.add_operation(self._garbage_collection_repos, 30)
 | |
| 
 | |
|   def _garbage_collection_repos(self):
 | |
|     """ Performs garbage collection on repositories. """
 | |
|     with UseThenDisconnect(app.config):
 | |
|       repository = find_repository_with_garbage()
 | |
|       if repository is None:
 | |
|         logger.debug('No repository with garbage found')
 | |
|         return
 | |
| 
 | |
|       logger.debug('Starting GC of repository #%s (%s)', repository.id, repository.name)
 | |
|       garbage_collect_repo(repository)
 | |
|       logger.debug('Finished GC of repository #%s (%s)', repository.id, repository.name)
 | |
|       return
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|   worker = GarbageCollectionWorker()
 | |
|   worker.start()
 |