setName('Core:PurgeRegistration') ->setDescription('Purge Registration') ->setHelp('This command Purge the obsolete Registration') ->addArgument('cronid', InputArgument::OPTIONAL, 'ID Cron Job') ->addArgument('lastchance', InputArgument::OPTIONAL, 'Lastchance to run the cron') ; } protected function execute(InputInterface $input, OutputInterface $output) { $this->container = $this->getApplication()->getKernel()->getContainer(); $this->em = $this->container->get('doctrine')->getEntityManager(); $this->output = $output; $this->filesystem = new Filesystem(); $this->rootlog = $this->container->get('kernel')->getRootDir()."/../var/logs/"; $this->writelnred(''); $this->writelnred('== Core:PurgeRegistration'); $this->writelnred('=========================================================================================================='); $now=new \DateTime('now'); $this->writeln(''); $this->writeln('== PURGE OBSOLETE REGISTRATION ======================'); $datas = $this->em ->createQueryBuilder() ->select('table') ->from('CadolesCoreBundle:Registration','table') ->where('table.keyexpire<:now') ->setParameter("now",$now->format("Y-m-d H:i:s")) ->getQuery() ->getResult(); foreach($datas as $data) { $this->writeln(' - Inscription supprimée = '.$data->getkeyexpire()->format("Y-m-d H:i:s")." >> ".$data->getUsername()); $this->em->remove($data); $this->em->flush(); } $this->writeln(''); return 1; } private function writelnred($string) { $this->output->writeln(''.$string.''); $this->filesystem->appendToFile($this->rootlog.'cron.log', $string."\n"); } private function writeln($string) { $this->output->writeln($string); $this->filesystem->appendToFile($this->rootlog.'cron.log', $string."\n"); } }