Proyectos de Subversion LeadersLinked - Services

Rev

Rev 179 | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
<?php
345 www 2
declare(strict_types = 1);
1 efrain 3
namespace LeadersLinked\Command;
4
 
5
use Symfony\Component\Console\Command\Command;
6
use Symfony\Component\Console\Input\InputInterface;
7
use Symfony\Component\Console\Output\OutputInterface;
8
use Laminas\Db\Adapter\AdapterInterface;
9
use Laminas\Log\LoggerInterface;
10
use LeadersLinked\Mapper\FeedMapper;
11
use Laminas\Mvc\I18n\Translator;
12
use LeadersLinked\Cache\CacheInterface;
13
 
14
class CheckPreviewPosterForFeedCommand extends Command
15
{
345 www 16
 
1 efrain 17
    /**
18
     *
19
     * @var \Laminas\Db\Adapter\AdapterInterface
20
     */
21
    private $adapter;
345 www 22
 
1 efrain 23
    /**
24
     *
25
     * @var \LeadersLinked\Cache\CacheInterface
26
     */
27
    private $cache;
345 www 28
 
1 efrain 29
    /**
30
     *
31
     * @var \Laminas\Log\LoggerInterface
32
     */
33
    private $logger;
345 www 34
 
1 efrain 35
    /**
36
     *
37
     * @var array
38
     */
39
    private $config;
345 www 40
 
1 efrain 41
    /**
42
     *
43
     * @var \Laminas\Mvc\I18n\Translator
44
     */
45
    private $translator;
345 www 46
 
1 efrain 47
    /**
48
     *
49
     * @param \Laminas\Db\Adapter\AdapterInterface $adapter
50
     * @param \LeadersLinked\Cache\CacheInterface $cache
345 www 51
     * @param
52
     *            \Laminas\Log\LoggerInterface
1 efrain 53
     * @param array $config
54
     * @param \Laminas\Mvc\I18n\Translator $translator
55
     */
56
    public function __construct($adapter, $cache, $logger, $config, $translator)
57
    {
345 www 58
        $this->adapter = $adapter;
59
        $this->cache = $cache;
60
        $this->logger = $logger;
61
        $this->config = $config;
62
        $this->translator = $translator;
63
 
1 efrain 64
        parent::__construct();
65
    }
345 www 66
 
67
    protected function execute(InputInterface $input, OutputInterface $output): int
1 efrain 68
    {
69
        $output->writeln('Cargando los feed');
345 www 70
 
1 efrain 71
        $feedMapper = FeedMapper::getInstance($this->adapter);
72
        $feeds = $feedMapper->fetchAllTypeVideo();
345 www 73
 
1 efrain 74
        $size = $this->config['leaderslinked.image_sizes.feed_image_size'];
345 www 75
        foreach ($feeds as $feed) {
1 efrain 76
            $target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;
345 www 77
            if (! file_exists($target_path)) {
179 efrain 78
                mkdir($target_path, 0755, true);
1 efrain 79
            }
80
 
345 www 81
            $full_video_filename = $target_path . DIRECTORY_SEPARATOR . $feed->file_name;
82
 
1 efrain 83
            $full_filename_preview = substr($feed->file_name, 0, strrpos($feed->file_name, '.'));
345 www 84
            $full_filename_preview = $target_path . DIRECTORY_SEPARATOR . $full_filename_preview . '.png';
85
 
86
            if (! file_exists($full_filename_preview)) {
1 efrain 87
                echo 'Procesando el Video ' . PHP_EOL;
88
                echo 'UUID : ' . $feed->uuid . PHP_EOL;
89
                echo 'Image : ' . $feed->file_image_preview . PHP_EOL;
90
                echo 'Video : ' . $feed->file_name . PHP_EOL;
345 www 91
                echo 'Video Filename : ' . $full_video_filename . PHP_EOL;
92
                echo 'Cover Filename : ' . $full_filename_preview . PHP_EOL;
93
 
1 efrain 94
                @unlink($full_filename_preview);
345 www 95
                $cmd = "/usr/bin/ffmpeg -i $full_video_filename -frames:v 1  -s $size $full_filename_preview";
96
                echo 'CMD = ' . $cmd . PHP_EOL . PHP_EOL;
1 efrain 97
                exec($cmd);
98
            }
99
 
100
            $feed->file_image_preview = basename($full_filename_preview);
101
            $feedMapper->update($feed);
102
        }
103
 
345 www 104
        $output->writeln('Fin del proceso');
1 efrain 105
 
106
        return 0;
107
    }
108
}