mirror of
				https://github.com/alchemy-fr/Phraseanet.git
				synced 2025-10-26 11:23:13 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			114 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace Alchemy\Phrasea\Model\Repositories;
 | |
| 
 | |
| use Alchemy\Phrasea\Core\PhraseaTokens;
 | |
| use Alchemy\Phrasea\Model\Entities\WorkerRunningJob;
 | |
| use Doctrine\ORM\EntityRepository;
 | |
| 
 | |
| class WorkerRunningJobRepository extends EntityRepository
 | |
| {
 | |
|     /**
 | |
|      *  return true if we can create subdef
 | |
|      * @param $subdefName
 | |
|      * @param $recordId
 | |
|      * @param $databoxId
 | |
|      * @return bool
 | |
|      */
 | |
|     public function canCreateSubdef($subdefName, $recordId, $databoxId)
 | |
|     {
 | |
|         $rsm = $this->createResultSetMappingBuilder('w');
 | |
|         $rsm->addScalarResult('work_on','work_on');
 | |
| 
 | |
|         $sql = 'SELECT work_on
 | |
|             FROM WorkerRunningJob
 | |
|             WHERE ((work & :write_meta) > 0 OR ((work & :make_subdef) > 0 AND work_on = :work_on) ) 
 | |
|             AND record_id = :record_id 
 | |
|             AND databox_id = :databox_id
 | |
|             AND status = :status';
 | |
| 
 | |
|         $query = $this->_em->createNativeQuery($sql, $rsm);
 | |
|         $query->setParameters([
 | |
|             'write_meta' => PhraseaTokens::WRITE_META,
 | |
|             'make_subdef'=> PhraseaTokens::MAKE_SUBDEF,
 | |
|             'work_on'    => $subdefName,
 | |
|             'record_id'  => $recordId,
 | |
|             'databox_id' => $databoxId,
 | |
|             'status'     => WorkerRunningJob::RUNNING
 | |
|             ]
 | |
|         );
 | |
| 
 | |
|         return count($query->getResult()) == 0;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * return true if we can write meta
 | |
|      *
 | |
|      * @param $subdefName
 | |
|      * @param $recordId
 | |
|      * @param $databoxId
 | |
|      * @return bool
 | |
|      */
 | |
|     public function canWriteMetadata($subdefName, $recordId, $databoxId)
 | |
|     {
 | |
|         $rsm = $this->createResultSetMappingBuilder('w');
 | |
|         $rsm->addScalarResult('work_on','work_on');
 | |
| 
 | |
|         $sql = 'SELECT work_on
 | |
|             FROM WorkerRunningJob
 | |
|             WHERE ((work & :make_subdef) > 0 OR ((work & :write_meta) > 0 AND work_on = :work_on) ) 
 | |
|             AND record_id = :record_id 
 | |
|             AND databox_id = :databox_id
 | |
|             AND status = :status';
 | |
| 
 | |
|         $query = $this->_em->createNativeQuery($sql, $rsm);
 | |
|         $query->setParameters([
 | |
|                 'make_subdef'=> PhraseaTokens::MAKE_SUBDEF,
 | |
|                 'write_meta' => PhraseaTokens::WRITE_META,
 | |
|                 'work_on'    => $subdefName,
 | |
|                 'record_id'  => $recordId,
 | |
|                 'databox_id' => $databoxId,
 | |
|                 'status'     => WorkerRunningJob::RUNNING
 | |
|             ]
 | |
|         );
 | |
| 
 | |
|         return count($query->getResult()) == 0;
 | |
|     }
 | |
| 
 | |
|     public function truncateWorkerTable()
 | |
|     {
 | |
|         $connection = $this->_em->getConnection();
 | |
|         $platform = $connection->getDatabasePlatform();
 | |
|         $this->_em->beginTransaction();
 | |
|         try {
 | |
|         $connection->executeUpdate($platform->getTruncateTableSQL('WorkerRunningJob'));
 | |
|         } catch (\Exception $e) {
 | |
|             $this->_em->rollback();
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function deleteFinishedWorks()
 | |
|     {
 | |
|         $this->_em->beginTransaction();
 | |
|         try {
 | |
|             $this->_em->getConnection()->delete('WorkerRunningJob', ['status' => WorkerRunningJob::FINISHED]);
 | |
|             $this->_em->commit();
 | |
|         } catch (\Exception $e) {
 | |
|             $this->_em->rollback();
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function getEntityManager()
 | |
|     {
 | |
|         return parent::getEntityManager();
 | |
|     }
 | |
| 
 | |
|     public function reconnect()
 | |
|     {
 | |
|         if($this->_em->getConnection()->ping() === false) {
 | |
|             $this->_em->getConnection()->close();
 | |
|             $this->_em->getConnection()->connect();
 | |
|         }
 | |
|     }
 | |
| }
 | 
