mirror of
				https://github.com/alchemy-fr/Phraseanet.git
				synced 2025-10-26 03:13:12 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			73 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /*
 | |
|  * This file is part of Phraseanet
 | |
|  *
 | |
|  * (c) 2005-2014 Alchemy
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| 
 | |
| namespace Alchemy\Phrasea\Setup\Version\PreSchemaUpgrade;
 | |
| 
 | |
| use Alchemy\Phrasea\Application;
 | |
| use Doctrine\DBAL\Migrations\Configuration\Configuration;
 | |
| use Doctrine\ORM\EntityManager;
 | |
| use Doctrine\ORM\Query;
 | |
| use Doctrine\ORM\Query\ResultSetMapping;
 | |
| 
 | |
| class Upgrade39Tokens implements PreSchemaUpgradeInterface
 | |
| {
 | |
|     /**
 | |
|      * {@inheritdoc}
 | |
|      */
 | |
|     public function apply(EntityManager $em, \appbox $appbox, Configuration $conf)
 | |
|     {
 | |
|         $this->doBackupFeedsTable($em);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritdoc}
 | |
|      */
 | |
|     public function isApplyable(Application $app)
 | |
|     {
 | |
|         return $this->tableExists($app['orm.em'], 'tokens');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritdoc}
 | |
|      */
 | |
|     public function rollback(EntityManager $em, \appbox $appbox, Configuration $conf)
 | |
|     {
 | |
|         if ($this->tableExists($em, 'tokens_backup')) {
 | |
|             $em->getConnection()->executeUpdate('RENAME TABLE `tokens_backup` TO `tokens`');
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Checks whether the table exists or not.
 | |
|      *
 | |
|      * @param $tableName
 | |
|      *
 | |
|      * @return boolean
 | |
|      */
 | |
| 
 | |
|     private function tableExists(EntityManager $em, $table)
 | |
|     {
 | |
|         return (Boolean) $em->createNativeQuery(
 | |
|             'SHOW TABLE STATUS WHERE Name="'.$table.'" COLLATE utf8_bin ', (new ResultSetMapping())->addScalarResult('Name', 'Name')
 | |
|         )->getOneOrNullResult();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Renames feed table.
 | |
|      *
 | |
|      * @param EntityManager $em
 | |
|      */
 | |
|     private function doBackupFeedsTable(EntityManager $em)
 | |
|     {
 | |
|         $em->getConnection()->executeUpdate('RENAME TABLE `tokens` TO `tokens_backup`');
 | |
|     }
 | |
| }
 | 
