Skip to content
Snippets Groups Projects
Select Git revision
  • 3405c4b1c0d204a64081f9d66889e7e2766e6410
  • master default protected
  • php84
  • detached7
  • detached6
  • detached5
  • detached
  • detached2
  • detached3
  • detached4
  • 4.x
  • origin/1.0.3
  • origin/1.0.2
  • 6.1.0
  • 6.0.6
  • 6.0.5
  • 6.0.4
  • 6.0.3
  • 6.0.2
  • 6.0.1
  • 6.0.0
  • 4.0.3
  • 4.0.2
  • 4.0.1
  • 4.0
  • 3.1.7
  • 3.1.6
  • 3.1.5
  • 3.1.4
  • 3.1.3
  • 3.1.2
  • 3.1.1
  • 3.1.0
33 results

ImportController.php

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    UpdateBddCommand.php 2.21 KiB
    <?php
    
    namespace Unicaen\BddAdmin\Command;
    
    use Symfony\Component\Console\Command\Command;
    use Symfony\Component\Console\Input\InputInterface;
    use Symfony\Component\Console\Output\OutputInterface;
    use Symfony\Component\Console\Style\SymfonyStyle;
    use Unicaen\BddAdmin\BddAwareTrait;
    use Unicaen\BddAdmin\Ddl\Ddl;
    
    /**
     * Description of UpdateBddCommand
     *
     * @author Laurent Lécluse <laurent.lecluse at unicaen.fr>
     */
    class UpdateBddCommand extends Command
    {
        use BddAwareTrait;
        
        protected function execute(InputInterface $input, OutputInterface $output): int
        {
            $io = new SymfonyStyle($input, $output);
            $bdd = $this->getBdd()->setLogger($io);
    
            $io->title('Mise à jour de la base de données');
            $io->info('Mise à jour des définitions de la base de données. Merci de patienter ...');
    
            $ref = $bdd->getRefDdl();
    
            // Construction de la config de DDL pour filtrer
            $filters = [];
            foreach ($ref as $ddlClass => $objects) {
                foreach ($objects as $object => $objectDdl) {
                    $filters[$ddlClass]['includes'][] = $object;
                }
            }
    
            $tablesDep = [
                Ddl::INDEX,
                Ddl::PRIMARY_CONSTRAINT,
                Ddl::REF_CONSTRAINT,
                Ddl::UNIQUE_CONSTRAINT,
            ];
    
            foreach ($tablesDep as $tableDep) {
                $objects = $bdd->manager($tableDep)->get();
                foreach ($objects as $obj) {
                    if (in_array($obj['table'], $filters['table']['includes'])) {
                        $filters[$tableDep]['includes'][] = $obj['name'];
                    }
                }
            }
    
            // Initialisation et lancement de la pré-migration
            //$mm = new MigrationManager($oa, $ref, $filters);
            //$mm->migration('before');
    
    
            // Mise à jour de la BDD (structures)
            $bdd->alter($ref, $filters, true);
    
    
            // Mise à jour des séquences
            $bdd->majSequences($ref);
    
    
            // Mise à jour des données
            //$bdd->logBegin('Contrôle et mise à jour des données');
            //$bdd->dataUpdater()->run('update');
            //$bdd->logEnd('Données à jour');
    
    
    
            // Post-migration
            //$mm->migration('after');
    
            return Command::SUCCESS;
        }
    }