Proyectos de Subversion LeadersLinked - Services

Rev

Rev 179 | Mostrar el archivo completo | | | Autoría | Ultima modificación | Ver Log |

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