Proyectos de Subversion LeadersLinked - Services

Rev

Rev 179 | Ir a la última revisión | | Ultima modificación | Ver Log |

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