mirror of
				https://github.com/alchemy-fr/Phraseanet.git
				synced 2025-10-25 10:53:14 +00:00 
			
		
		
		
	 12912a309a
			
		
	
	12912a309a
	
	
	
		
			
			fix : console build-subdefs can build non existing subdefs, ex. after adding a new subdef name in admin.
		
			
				
	
	
		
			199 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			199 lines
		
	
	
		
			6.9 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\Command;
 | |
| 
 | |
| use Alchemy\Phrasea\Exception\InvalidArgumentException;
 | |
| use Alchemy\Phrasea\Media\SubdefGenerator;
 | |
| use Doctrine\DBAL\Connection;
 | |
| use Doctrine\DBAL\SQLParserUtils;
 | |
| use Symfony\Component\Console\Input\InputArgument;
 | |
| use Symfony\Component\Console\Input\InputOption;
 | |
| use Symfony\Component\Console\Input\InputInterface;
 | |
| use Symfony\Component\Console\Output\OutputInterface;
 | |
| use Symfony\Component\Console\Helper\HelperSet;
 | |
| use Symfony\Component\Console\Helper\ProgressBar;
 | |
| use media_subdef;
 | |
| class BuildSubdefs extends Command
 | |
| {
 | |
|     /**
 | |
|      * Constructor
 | |
|      */
 | |
|     public function __construct($name = null)
 | |
|     {
 | |
|         parent::__construct($name);
 | |
| 
 | |
|         $this->setDescription('Build subviews for given subview names and record types');
 | |
|         $this->addArgument('databox', InputArgument::REQUIRED, 'The databox id');
 | |
|         $this->addArgument('type', InputArgument::REQUIRED, 'Types of the document to rebuild');
 | |
|         $this->addArgument('subdefs', InputArgument::REQUIRED, 'Names of sub-definition to re-build');
 | |
|         $this->addOption('max_record', 'max', InputOption::VALUE_OPTIONAL, 'Max record id');
 | |
|         $this->addOption('min_record', 'min', InputOption::VALUE_OPTIONAL, 'Min record id');
 | |
|         $this->addOption('with-substitution', 'wsubstit', InputOption::VALUE_NONE, 'Regenerate subdefs for substituted records as well');
 | |
|         $this->addOption('substitution-only', 'substito', InputOption::VALUE_NONE, 'Regenerate subdefs for substituted records only');
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * {@inheritdoc}
 | |
|      */
 | |
|     protected function doExecute(InputInterface $input, OutputInterface $output)
 | |
|     {
 | |
|         $availableTypes = array('document', 'audio', 'video', 'image', 'flash', 'map');
 | |
| 
 | |
|         $typesOption =  $input->getArgument('type');
 | |
| 
 | |
|         $recordsType = explode(',', $typesOption);
 | |
|         $recordsType = array_filter($recordsType, function($type) use($availableTypes) {
 | |
|             return in_array($type, $availableTypes);
 | |
|         });
 | |
| 
 | |
|         if (count($recordsType) === 0) {
 | |
|             $output->write(sprintf('Invalid records type provided %s', implode(', ', $availableTypes)));
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         $subdefsOption = $input->getArgument('subdefs');
 | |
|         $subdefsName = explode(',', $subdefsOption);
 | |
| 
 | |
|         if (count($subdefsOption) === 0) {
 | |
|             $output->write('No subdef options provided');
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         $sqlCount = "SELECT COUNT(DISTINCT(r.record_id)) AS nb_records"
 | |
|             . " FROM record r LEFT JOIN subdef s ON (r.record_id = s.record_id AND s.name IN (?))"
 | |
|             . " WHERE r.type IN (?)";
 | |
| 
 | |
|         $types = array(Connection::PARAM_STR_ARRAY, Connection::PARAM_STR_ARRAY);
 | |
|         $params = array($subdefsName, $recordsType);
 | |
| 
 | |
|         if (null !== $min = $input->getOption('min_record')) {
 | |
|             $sqlCount .= " AND (r.record_id >= ?)";
 | |
| 
 | |
|             $params[] = (int) $min;
 | |
|             $types[] = \PDO::PARAM_INT;
 | |
|         }
 | |
| 
 | |
|         if (null !== $max = $input->getOption('max_record')) {
 | |
|             $sqlCount .= " AND (r.record_id <= ?)";
 | |
| 
 | |
|             $params[] = (int) $max;
 | |
|             $types[] = \PDO::PARAM_INT;
 | |
|         }
 | |
| 
 | |
|         $substitutionOnly = $input->getOption('substitution-only');
 | |
|         $withSubstitution = $input->getOption('with-substitution');
 | |
| 
 | |
|         if (false === $withSubstitution) {
 | |
|             if (true === $substitutionOnly) {
 | |
|                 $sqlCount .= " AND (ISNULL(s.substit) OR s.substit = 1)";
 | |
|             } else  {
 | |
|                 $sqlCount .= " AND (ISNULL(s.substit) OR s.substit = 0)";
 | |
|             }
 | |
|         } elseif ($substitutionOnly) {
 | |
|             throw new InvalidArgumentException('Conflict, you can not ask for --substitution-only && --with-substitution parameters at the same time');
 | |
|         }
 | |
| 
 | |
|         list($sqlCount, $stmtParams) = SQLParserUtils::expandListParameters($sqlCount, $params, $types);
 | |
| 
 | |
|         $databox = $this->container->findDataboxById($input->getArgument('databox'));
 | |
| 
 | |
|         $output->writeln($sqlCount);
 | |
| 
 | |
|         $connection = $databox->get_connection();
 | |
|         $stmt = $connection->prepare($sqlCount);
 | |
|         $stmt->execute($stmtParams);
 | |
|         $row = $stmt->fetch();
 | |
|         $totalRecords = $row['nb_records'];
 | |
| 
 | |
|         if ($totalRecords === 0) {
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         /** @var HelperSet $helperSet */
 | |
|         $helperSet = $this->getHelperSet();
 | |
| 
 | |
|         /** @var ProgressBar $progress */
 | |
|         $progress = $helperSet->get('progress');
 | |
| 
 | |
|         $progress->start($output, $totalRecords);
 | |
| 
 | |
|         $progress->display();
 | |
| 
 | |
|         $sql = "SELECT DISTINCT(r.record_id)"
 | |
|             . " FROM record r LEFT JOIN subdef s ON (r.record_id = s.record_id AND s.name IN (?))"
 | |
|             . " WHERE r.type IN (?)";
 | |
| 
 | |
|         $types = array(Connection::PARAM_STR_ARRAY, Connection::PARAM_STR_ARRAY);
 | |
|         $params = array($subdefsName, $recordsType);
 | |
| 
 | |
|         if ($min) {
 | |
|             $sql .= " AND (r.record_id >= ?)";
 | |
| 
 | |
|             $params[] = (int) $min;
 | |
|             $types[] = \PDO::PARAM_INT;
 | |
|         }
 | |
|         if ($max) {
 | |
|             $sql .= " AND (r.record_id <= ?)";
 | |
| 
 | |
|             $params[] = (int) $max;
 | |
|             $types[] = \PDO::PARAM_INT;
 | |
|         }
 | |
| 
 | |
|         if (false === $withSubstitution) {
 | |
|             if (true === $substitutionOnly) {
 | |
|                 $sql .= " AND (ISNULL(s.substit) OR s.substit = 1)";
 | |
|             } else  {
 | |
|                 $sql .= " AND (ISNULL(s.substit) OR s.substit = 0)";
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         list($sql, $stmtParams) = SQLParserUtils::expandListParameters($sql, $params, $types);
 | |
| 
 | |
|         $connection = $databox->get_connection();
 | |
|         $stmt = $connection->prepare($sql);
 | |
|         $stmt->execute($stmtParams);
 | |
|         $rows = $stmt->fetchAll(\PDO::FETCH_ASSOC);
 | |
| 
 | |
|         foreach ($rows as $row) {
 | |
|             $output->write(sprintf(' (#%s)', $row['record_id']));
 | |
| 
 | |
|             $record = new \record_adapter($this->container, $databox->get_sbas_id(), $row['record_id']);
 | |
| 
 | |
|             /** @var media_subdef[] $subdefs */
 | |
|             $subdefs = array_filter($record->get_subdefs(), function(media_subdef $subdef) use ($subdefsName) {
 | |
|                 return in_array($subdef->get_name(), $subdefsName);
 | |
|             });
 | |
| 
 | |
|             foreach ($subdefs as $subdef) {
 | |
|                 $subdef->remove_file();
 | |
|                 if (($withSubstitution && $subdef->is_substituted()) || $substitutionOnly) {
 | |
|                     $subdef->set_substituted(false);
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             /** @var SubdefGenerator $subdefGenerator */
 | |
|             $subdefGenerator = $this->container['subdef.generator'];
 | |
|             $subdefGenerator->generateSubdefs($record, $subdefsName);
 | |
| 
 | |
|             $stmt->closeCursor();
 | |
| 
 | |
|             $progress->advance();
 | |
|         }
 | |
| 
 | |
|         unset($rows, $record, $stmt, $connection);
 | |
| 
 | |
|         $progress->finish();
 | |
|     }
 | |
| }
 |