Proyectos de Subversion LeadersLinked - Backend

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
13304 eleazar 1
<?php
2
 
3
declare(strict_types=1);
4
 
5
namespace LeadersLinked\Controller;
6
 
7
use Laminas\Db\Adapter\AdapterInterface;
8
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
9
use Laminas\Mvc\Controller\AbstractActionController;
10
use Laminas\Log\LoggerInterface;
11
use Laminas\View\Model\ViewModel;
12
use Laminas\View\Model\JsonModel;
13
use LeadersLinked\Library\Functions;
14
use LeadersLinked\Mapper\FeedMapper;
15
use LeadersLinked\Mapper\TopicMapper;
14748 kerby 16
use LeadersLinked\Mapper\FeedTopicMapper;
17
use LeadersLinked\Mapper\QueryMapper;
18
use Laminas\Paginator\Adapter\DbSelect;
19
use Laminas\Paginator\Paginator;
13304 eleazar 20
use LeadersLinked\Form\CreateFeedForm;
14748 kerby 21
use LeadersLinked\Form\TopicForm;
22
use Laminas\Hydrator\ArraySerializableHydrator;
23
use Laminas\Db\ResultSet\HydratingResultSet;
24
use LeadersLinked\Model\FeedTopic;
13304 eleazar 25
use LeadersLinked\Model\Feed;
14748 kerby 26
use LeadersLinked\Model\Topic;
27
use LeadersLinked\Mapper\CompanyMapper;
28
use LeadersLinked\Model\Company;
13304 eleazar 29
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
30
 
14748 kerby 31
 
14743 kerby 32
class DevelopmentContentController extends AbstractActionController
33
{
13304 eleazar 34
 
35
    /**
36
     *
37
     * @var AdapterInterface
38
     */
39
    private $adapter;
40
 
41
    /**
42
     *
43
     * @var AbstractAdapter
44
     */
45
    private $cache;
46
 
47
    /**
48
     *
49
     * @var  LoggerInterface
50
     */
51
    private $logger;
52
 
53
    /**
54
     *
55
     * @var array
56
     */
57
    private $config;
58
 
59
    /**
60
     *
61
     * @param AdapterInterface $adapter
62
     * @param AbstractAdapter $cache
63
     * @param LoggerInterface $logger
64
     * @param array $config
65
     */
14743 kerby 66
    public function __construct($adapter, $cache, $logger, $config)
67
    {
13304 eleazar 68
        $this->adapter = $adapter;
69
        $this->cache = $cache;
70
        $this->logger = $logger;
71
        $this->config = $config;
72
    }
73
 
14743 kerby 74
    public function indexAction()
75
    {
13304 eleazar 76
        $request = $this->getRequest();
77
        $currentUserPlugin = $this->plugin('currentUserPlugin');
78
        $currentCompany = $currentUserPlugin->getCompany();
79
        $currentUser = $currentUserPlugin->getUser();
80
 
81
        if ($request->isGet()) {
82
 
83
            $headers = $request->getHeaders();
84
 
85
            $isJson = false;
86
            if ($headers->has('Accept')) {
87
                $accept = $headers->get('Accept');
88
 
89
                $prioritized = $accept->getPrioritized();
90
 
91
                foreach ($prioritized as $key => $value) {
92
                    $raw = trim($value->getRaw());
93
 
94
                    if (!$isJson) {
95
                        $isJson = strpos($raw, 'json');
96
                    }
97
                }
98
            }
14743 kerby 99
            $topicMapper = TopicMapper::getInstance($this->adapter);
100
            $categories = $topicMapper->fetchAllDevelopment();
13304 eleazar 101
 
102
            if ($isJson) {
14749 kerby 103
 
14750 kerby 104
 
13304 eleazar 105
                $search = $this->params()->fromQuery('search', []);
106
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);
107
 
108
                $page = intval($this->params()->fromQuery('start', 1), 10);
109
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
110
 
14743 kerby 111
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
112
                $allowAdd = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/add');
113
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/edit');
114
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/delete');
115
                $allowAproved = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/aproved');
116
                $allowCategories = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/categories');
14751 kerby 117
 
13304 eleazar 118
                $items = [];
119
                $feedMapper = FeedMapper::getInstance($this->adapter);
14743 kerby 120
 
121
                $paginator = $feedMapper->fetchAllByDevelop($allowEdit);
14753 kerby 122
                // echo "despues del mapper";
123
                // exit;
13304 eleazar 124
                foreach ($paginator as $record) {
14743 kerby 125
                    $topicMapper = TopicMapper::getInstance($this->adapter);
126
                    $topic = $topicMapper->fetchOne($record->topic_id);
127
                    $topic_title =  ($topic) ? $topic->title : '';
128
                    $preview = ($record->file_image_preview != null && $record->file_image_preview != '') ? $this->url()->fromRoute('storage', ['code' => $record->uuid, 'type' => 'feed', 'filename' => $record->file_image_preview]) : '';
13304 eleazar 129
                    $item = [
130
                        'id' => $record->id,
14743 kerby 131
                        'uuid' => $record->uuid,
13304 eleazar 132
                        'title' => $record->title,
14743 kerby 133
                        'topic' => $topic_title,
14605 kerby 134
                        'added_on' => $record->added_on,
13304 eleazar 135
                        'description' => $record->description,
14604 kerby 136
                        'file' => $record->file_type ? $record->file_type : '',
137
                        'link_media' => $record->link_media ? $record->link_media : '',
138
                        'link_name' => $record->link_name,
139
                        'file_name' => $record->file_name ? $record->file_name : '',
140
                        'link_file' => $this->url()->fromRoute('storage', ['code' => $record->uuid, 'type' => 'feed', 'filename' => $record->file_name]),
14743 kerby 141
                        'status' => $record->status,
142
                        'preview' => $preview,
143
                        'actions' => [
14754 kerby 144
                            'link_edit' => ($allowEdit) ? $this->url()->fromRoute('development-and-content/edit', ['id' => $record->uuid]) : '',
145
                            'link_get' => $this->url()->fromRoute('development-and-content/getContent', ['id' => $record->uuid]),
146
                            'link_aproved' => ($allowAproved) ? $this->url()->fromRoute('development-and-content/aproved', ['id' => $record->uuid]) : '',
147
                            'link_delete' => ($allowDelete) ? $this->url()->fromRoute('development-and-content/delete', ['id' => $record->uuid]) : '',
14743 kerby 148
                        ]
13304 eleazar 149
                    ];
150
 
151
                    array_push($items, $item);
152
                }
14756 kerby 153
 
13304 eleazar 154
                return new JsonModel([
155
                    'success' => true,
156
                    'data' => [
157
                        'items' => $items,
158
                    ]
159
                ]);
160
            } else {
161
 
162
                $form = new CreateFeedForm($this->adapter, $currentCompany->id);
163
 
164
                $this->layout()->setTemplate('layout/layout-backend');
165
                $viewModel = new ViewModel();
14743 kerby 166
                // $viewModel->setTemplate('leaders-linked/development-content-waiting/index.phtml');
13309 eleazar 167
                $viewModel->setTemplate('leaders-linked/development-content/index.phtml');
14743 kerby 168
                $viewModel->setVariables([
169
                    'form' => $form,
170
                    'categories' => $categories,
171
                ]);
13304 eleazar 172
                return $viewModel;
173
            }
174
        } else {
175
            return new JsonModel([
176
                'success' => false,
177
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
178
            ]);
179
        }
14743 kerby 180
    }
181
 
182
    public function getContentAction()
183
    {
184
        $request = $this->getRequest();
185
        $currentUserPlugin = $this->plugin('currentUserPlugin');
186
        $currentCompany = $currentUserPlugin->getCompany();
187
        $currentUser = $currentUserPlugin->getUser();
188
 
189
 
190
        if ($request->isGet()) {
191
 
192
 
193
            $uuid = $this->params()->fromRoute('id');
194
            if (!$uuid) {
195
                $data = [
196
                    'success' => false,
197
                    'data' => 'ERROR_INVALID_PARAMETER'
198
                ];
199
 
200
                return new JsonModel($data);
201
            }
202
 
203
 
204
            $feedMapper = FeedMapper::getInstance($this->adapter);
205
            $record = $feedMapper->fetchOneByUuid($uuid);
206
 
207
            if ($record->company_id != $currentCompany->id) {
208
                $response = [
209
                    'success' => false,
210
                    'data' => 'ERROR_UNAUTHORIZED'
211
                ];
212
                return new JsonModel($response);
213
            }
214
 
215
            $topicMapper = TopicMapper::getInstance($this->adapter);
216
            $topic = $topicMapper->fetchOne($record->topic_id);
217
            $link_file = ($record->file_name != null && $record->file_name != '') ? $this->url()->fromRoute('storage', ['code' => $record->uuid, 'type' => 'feed', 'filename' => $record->file_name]) : null;
218
            $preview = ($record->file_image_preview != null && $record->file_image_preview != '') ? $this->url()->fromRoute('storage', ['code' => $record->uuid, 'type' => 'feed', 'filename' => $record->file_image_preview]) : null;
13304 eleazar 219
            return new JsonModel([
14743 kerby 220
                'success' => true,
221
                'data' => [
222
                    'feed' => $record,
223
                    'topic' => $topic,
224
                    'titulo' => $record->title,
225
                    'description' => $record->description,
226
                    'action' => $this->url()->fromRoute('development-and-content/edit', ['id' => $record->uuid]),
227
                    'link_file' => $link_file,
228
                    'preview' => $preview
229
                ]
230
            ]);
231
        } else {
232
            return new JsonModel([
13304 eleazar 233
                'success' => false,
14743 kerby 234
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
13304 eleazar 235
            ]);
236
        }
237
    }
238
 
14743 kerby 239
    public function addAction()
240
    {
13304 eleazar 241
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
14743 kerby 242
        $currentCompany     = $currentUserPlugin->getCompany();
13304 eleazar 243
        $currentUser        = $currentUserPlugin->getUser();
244
 
14743 kerby 245
        $request    = $this->getRequest();
246
        try {
247
            if ($request->isPost()) {
248
                $form = new  CreateFeedForm($this->adapter);
249
 
250
                $dataPost = array_merge($request->getPost()->toArray(), $request->getFiles()->toArray());
251
                $form->setData($dataPost);
252
 
253
                if ($form->isValid()) {
254
                    $dataPost = (array) $form->getData();
255
                    $hydrator = new ObjectPropertyHydrator();
256
                    $feed = new Feed();
257
                    $hydrator->hydrate($dataPost, $feed);
258
 
259
                    $topicMapper = TopicMapper::getInstance($this->adapter);
260
                    $topic = $topicMapper->fetchOneByUuid($dataPost['category_dc']);
261
 
262
                    $feed->user_id = $currentUser->id;
263
                    $feed->company_id = $currentCompany->id;
264
                    $feed->user_id          = $currentUser->id;
265
                    $feed->status           = Feed::STATUS_SAVED;
266
                    $feed->topic_id         = $topic->id;
267
                    $feed->type             = Feed::TYPE_DC;
268
                    $feed->posted_or_shared = Feed::POSTED;
269
                    $feed->shared_with      = Feed::SHARE_WITH_PUBLIC;
270
 
271
                    $feed->total_comments   = 0;
272
                    $feed->total_shared     = 0;
273
 
274
 
275
                    $files = $this->getRequest()->getFiles()->toArray();
276
                    $file_type = '';
277
                    if (isset($files['file']) && empty($files['file']['error'])) {
278
                        $feed_tmp_filename  = $files['file']['tmp_name'];
279
                        $feed_filename      = $this->normalizeString($files['file']['name']);
280
 
281
                        $mime_type = mime_content_type($feed_tmp_filename);
282
                        if ($mime_type == 'image/jpg' || $mime_type == 'image/jpeg' || $mime_type == 'image/png') {
283
                            $file_type = Feed::FILE_TYPE_IMAGE;
284
                        } else if ($mime_type == 'video/webm' || $mime_type == 'video/mpeg' || $mime_type == 'video/mpg' || $mime_type == 'video/mp4') {
285
                            $file_type = Feed::FILE_TYPE_VIDEO;
286
                        } else if ($mime_type == 'application/pdf') {
287
                            $file_type = Feed::FILE_TYPE_DOCUMENT;
288
                        }
13304 eleazar 289
                    }
14743 kerby 290
                    //preview
291
                    $fileImg = $this->params()->fromFiles('img_add');
292
                    if (isset($fileImg) && empty($fileImg['error'])) {
13304 eleazar 293
 
14743 kerby 294
                        $img_tmp_filename  = $fileImg['tmp_name'];
295
                        $img_filename  = $this->normalizeString($fileImg['name']);
296
                    } else {
297
                        $img_tmp_filename = null;
298
                        $img_filename = null;
299
                    }
13304 eleazar 300
 
14743 kerby 301
                    $feedMapper = FeedMapper::getInstance($this->adapter);
13304 eleazar 302
 
14743 kerby 303
                    if ($feedMapper->insert($feed)) {
13304 eleazar 304
                        $feed = $feedMapper->fetchOne($feed->id);
14743 kerby 305
                        $feedMapper->update($feed);
306
                        if ($file_type == Feed::FILE_TYPE_DOCUMENT) {
13304 eleazar 307
                            try {
308
                                $target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;
14743 kerby 309
                                if (!file_exists($target_path)) {
13304 eleazar 310
                                    mkdir($target_path, 0755);
311
                                }
14743 kerby 312
 
313
                                $full_filename = $target_path  . DIRECTORY_SEPARATOR . $feed_filename;
314
                                $result = move_uploaded_file($feed_tmp_filename, $full_filename);
315
                                if ($result) {
316
 
13304 eleazar 317
                                    $feed->file_type = $file_type;
318
                                    $feed->file_name = basename($feed_filename);
319
                                    $feedMapper->update($feed);
320
                                } else {
14743 kerby 321
                                    error_log('no se pudo mover o renombrar el documento : ' . $feed_tmp_filename . ' al directorio : ' . $full_filename);
13304 eleazar 322
                                }
14743 kerby 323
                            } catch (\Throwable $e) {
13304 eleazar 324
                                error_log($e->getTraceAsString());
325
                            }
326
                        }
14743 kerby 327
                        if ($file_type == Feed::FILE_TYPE_IMAGE) {
13304 eleazar 328
                            try {
329
                                $target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;
14743 kerby 330
                                if (!file_exists($target_path)) {
13304 eleazar 331
                                    mkdir($target_path, 0755);
332
                                }
14743 kerby 333
 
13304 eleazar 334
                                list($target_width, $target_height) = explode('x', $this->config['leaderslinked.image_sizes.feed_image_size']);
14743 kerby 335
 
13304 eleazar 336
                                $feed_filename = substr($feed_filename, 0, strrpos($feed_filename, '.'))  . '.png';
337
                                $crop_to_dimensions = false;
14743 kerby 338
                                if (Image::uploadImage($feed_tmp_filename, $target_path, $feed_filename, $target_width, $target_height, $crop_to_dimensions)) {
13304 eleazar 339
                                    $feed->file_type = $file_type;
340
                                    $feed->file_name = basename($feed_filename);
341
                                    $feedMapper->update($feed);
342
                                }
14743 kerby 343
                            } catch (\Throwable $e) {
13304 eleazar 344
                                error_log($e->getTraceAsString());
345
                            }
346
                        }
14743 kerby 347
                        if ($file_type == Feed::FILE_TYPE_VIDEO) {
13304 eleazar 348
                            try {
349
                                $target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;
14743 kerby 350
                                if (!file_exists($target_path)) {
13304 eleazar 351
                                    mkdir($target_path, 0755);
352
                                }
14743 kerby 353
 
13304 eleazar 354
                                $full_filename = $target_path  . DIRECTORY_SEPARATOR . $feed_filename;
14743 kerby 355
 
356
                                $result = move_uploaded_file($feed_tmp_filename, $full_filename);
357
                                if ($result) {
358
 
13304 eleazar 359
                                    $size = $this->config['leaderslinked.image_sizes.feed_image_size'];
360
                                    $getFromSecound = 2;
14743 kerby 361
 
13304 eleazar 362
                                    //extracción del cover
363
                                    $generateFileName = substr($feed_filename, 0, strrpos($feed_filename, '.'));
364
                                    $generateFile =  $target_path  . DIRECTORY_SEPARATOR . $generateFileName .  '.png';
365
                                    $cmd            = "/usr/bin/ffmpeg -i $full_filename -an -ss $getFromSecound -s $size $generateFile";
366
                                    exec($cmd);
14743 kerby 367
 
368
 
13304 eleazar 369
                                    $feed->file_type = $file_type;
370
                                    $feed->file_name = basename($feed_filename);
371
                                    $feed->file_image_preview = basename($generateFile);
372
                                    $feedMapper->update($feed);
14743 kerby 373
 
13304 eleazar 374
                                    $videoConvert = new VideoConvert();
375
                                    $videoConvert->filename = $full_filename;
376
                                    $videoConvert->type = VideoConvert::TYPE_FEED;
14743 kerby 377
 
13304 eleazar 378
                                    $videoConvertMapper = VideoConvertMapper::getInstance($this->adapter);
379
                                    $videoConvertMapper->insert($videoConvert);
380
                                } else {
14743 kerby 381
                                    error_log('no se pudo mover o renombrar el documento : ' . $feed_tmp_filename . ' al directorio : ' . $full_filename);
13304 eleazar 382
                                }
14743 kerby 383
                            } catch (\Throwable $e) {
13304 eleazar 384
                                error_log($e->getTraceAsString());
385
                            }
386
                        }
14743 kerby 387
 
388
                        if ($file_type != Feed::FILE_TYPE_VIDEO && !empty($img_tmp_filename) && !empty($img_filename)) {
389
 
390
                            try {
391
                                $target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;
392
                                if (!file_exists($target_path)) {
393
                                    mkdir($target_path, 0755);
394
                                }
395
 
396
                                Functions::deleteFilename($target_path, $feed->file_image_preview);
397
 
398
                                list($target_width, $target_height) = explode('x', $this->config['leaderslinked.image_sizes.feed_image_size']);
399
 
400
                                $img_filename = substr($img_filename, 0, strrpos($img_filename, '.'))  . '.png';
401
 
402
 
403
                                if (Functions::uploadImage($img_tmp_filename, $target_path, $img_filename, $target_width, $target_height)) {
404
                                    $feed->file_image_preview = basename($img_filename);
405
                                    $feedMapper->update($feed);
406
                                }
407
                            } catch (\Throwable $e) {
408
                                error_log($e->getTraceAsString());
409
                            }
410
                        }
411
 
412
 
13304 eleazar 413
                        $response = [
414
                            'success'   => true,
415
                            'data'   => 'success'
416
                        ];
14743 kerby 417
                    } else {
418
                        $messages = [];
419
                        $form_messages = (array) $form->getMessages();
420
                        foreach ($form_messages  as $fieldname => $field_messages) {
421
                            $messages[$fieldname] = array_values($field_messages);
422
                        }
423
                    }
13304 eleazar 424
                } else {
14743 kerby 425
                    $response = [
426
                        'success' => false,
427
                        'data' => 'ERROR_METHOD_NOT_ALLOWED'
428
                    ];
13304 eleazar 429
                }
14743 kerby 430
 
431
                return new JsonModel($response);
432
            }
433
        } catch (\Throwable $e) {
434
            $e->getMessage();
435
            return new JsonModel([
436
                'success' => false,
437
                'data' => $e
438
            ]);
439
        }
440
    }
441
 
442
    public function deleteAction()
443
    {
444
        $currentUserPlugin = $this->plugin('currentUserPlugin');
445
        $currentUser = $currentUserPlugin->getUser();
446
        $currentCompany = $currentUserPlugin->getCompany();
447
 
448
        $request = $this->getRequest();
449
        if ($request->isPost()) {
450
 
451
 
452
            $id =  $this->params()->fromRoute('id');
453
 
454
            $feedMapper = FeedMapper::getInstance($this->adapter);
455
            $feed = $feedMapper->fetchOneByUuid($id);
456
            if (!$feed) {
457
                $response = [
458
                    'success' => false,
459
                    'data' => 'ERROR_POST_NOT_FOUND'
460
                ];
461
                return new JsonModel($response);
462
            }
463
 
464
            if ($feed->company_id != $currentCompany->id) {
465
                $response = [
466
                    'success' => false,
467
                    'data' => 'ERROR_UNAUTHORIZED'
468
                ];
469
                return new JsonModel($response);
470
            }
471
 
472
            $feedMapper = FeedMapper::getInstance($this->adapter);
473
            $feed->status = Feed::STATUS_DELETED;
474
            if ($feedMapper->update($feed)) {
475
 
476
                $target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;
477
 
478
                Functions::deleteFilename($target_path, $feed->file_image_preview);
479
                Functions::deleteFilename($target_path, $feed->file_name);
480
 
481
                $response = [
482
                    'success' => true,
483
                    'data' => 'LABEL_FEED_WAS_DELETED'
484
                ];
13304 eleazar 485
            } else {
486
                $response = [
487
                    'success' => false,
14743 kerby 488
                    'data' => $feedMapper->getError()
13304 eleazar 489
                ];
490
            }
14743 kerby 491
 
492
 
13304 eleazar 493
            return new JsonModel($response);
14743 kerby 494
        } else {
495
            $response = [
496
                'success' => false,
497
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
498
            ];
13304 eleazar 499
        }
14743 kerby 500
 
501
        return new JsonModel($response);
13304 eleazar 502
    }
503
 
14743 kerby 504
    private function normalizeString($str = '')
505
    {
506
        $basename  = substr($str, 0, strrpos($str, '.'));
507
        $basename  = str_replace('.', '-', $basename);
508
 
509
        $extension  = substr($str, strrpos($str, '.'));
510
 
511
        $str = $basename . $extension;
512
 
513
        $str = strip_tags($str);
514
        $str = preg_replace('/[\r\n\t ]+/', ' ', $str);
515
        $str = preg_replace('/[\"\*\/\:\<\>\?\'\|\,]+/', ' ', $str);
516
        $str = strtolower($str);
517
        $str = html_entity_decode($str, ENT_QUOTES, "utf-8");
518
        $str = htmlentities($str, ENT_QUOTES, "utf-8");
519
        $str = preg_replace("/(&)([a-z])([a-z]+;)/i", '$2', $str);
520
        $str = str_replace(' ', '-', $str);
521
        $str = rawurlencode($str);
522
        $str = str_replace('%', '-', $str);
523
        return trim(strtolower($str));
524
    }
525
 
526
    public function aprovedAction()
527
    {
13304 eleazar 528
        $currentUserPlugin = $this->plugin('currentUserPlugin');
529
        $currentUser = $currentUserPlugin->getUser();
530
        $currentCompany = $currentUserPlugin->getCompany();
14743 kerby 531
 
13304 eleazar 532
        $request = $this->getRequest();
14743 kerby 533
        if ($request->isPost()) {
13304 eleazar 534
 
535
            $id =  $this->params()->fromRoute('id');
14743 kerby 536
 
13304 eleazar 537
            $feedMapper = FeedMapper::getInstance($this->adapter);
538
            $feed = $feedMapper->fetchOneByUuid($id);
14743 kerby 539
            if (!$feed) {
13304 eleazar 540
                $response = [
541
                    'success' => false,
542
                    'data' => 'ERROR_POST_NOT_FOUND'
543
                ];
544
                return new JsonModel($response);
545
            }
14743 kerby 546
 
547
            if ($feed->company_id != $currentCompany->id) {
13304 eleazar 548
                $response = [
549
                    'success' => false,
550
                    'data' => 'ERROR_UNAUTHORIZED'
551
                ];
552
                return new JsonModel($response);
553
            }
14743 kerby 554
 
13304 eleazar 555
            $feedMapper = FeedMapper::getInstance($this->adapter);
14743 kerby 556
            $feed->status = Feed::STATUS_PUBLISHED;
557
            if ($feedMapper->update($feed)) {
13304 eleazar 558
                $response = [
559
                    'success' => true,
14743 kerby 560
                    'data' => 'LABEL_FEED_WAS_ADDED'
13304 eleazar 561
                ];
562
            } else {
563
                $response = [
564
                    'success' => false,
565
                    'data' => $feedMapper->getError()
566
                ];
567
            }
568
 
14743 kerby 569
 
13304 eleazar 570
            return new JsonModel($response);
571
        } else {
572
            $response = [
573
                'success' => false,
574
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
575
            ];
576
        }
14743 kerby 577
 
13304 eleazar 578
        return new JsonModel($response);
579
    }
14743 kerby 580
 
581
    public function editAction()
582
    {
583
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
584
        $currentCompany     = $currentUserPlugin->getCompany();
585
        $currentUser        = $currentUserPlugin->getUser();
586
        $request    = $this->getRequest();
587
        try {
588
 
589
            $uuid = $this->params()->fromRoute('id');
590
            if (!$uuid) {
591
                $data = [
592
                    'success' => false,
593
                    'data' => 'ERROR_INVALID_PARAMETER'
594
                ];
595
 
596
                return new JsonModel($data);
597
            }
598
 
599
            $feedMapper = FeedMapper::getInstance($this->adapter);
600
 
601
            $feed = $feedMapper->fetchOneByUuid($uuid);
602
 
603
 
604
            if (!$feed) {
605
                $data = [
606
                    'success' => false,
607
                    'data' => 'ERROR_RECORD_NOT_FOUND'
608
                ];
609
 
610
                return new JsonModel($data);
611
            }
612
 
613
            if ($currentCompany) {
614
                if ($feed->company_id != $currentCompany->id) {
615
                    $data = [
616
                        'success' => false,
617
                        'data' => 'ERROR_UNAUTHORIZED'
618
                    ];
619
 
620
                    return new JsonModel($data);
621
                }
622
            } else {
623
                if ($feed->company_id) {
624
                    $data = [
625
                        'success' => false,
626
                        'data' => 'ERROR_UNAUTHORIZED'
627
                    ];
628
 
629
                    return new JsonModel($data);
630
                }
631
            }
632
 
633
            if ($request->isPost()) {
634
 
635
 
636
                $form = new CreateFeedForm($this->adapter);
637
                $dataPost = array_merge($request->getPost()->toArray(), $request->getFiles()->toArray());
638
                // $categoriesId = $dataPost['category_id'] ?? [];
639
                $categoryUuid = $dataPost['category_dc'];
640
                $dataPost['category_id'] = null;
641
                // print_r($dataPost);
642
                $form->setData($dataPost);
643
 
644
                if ($form->isValid()) {
645
                    $dataPost = (array) $form->getData();
646
                    $hydrator = new ObjectPropertyHydrator();
647
                    $hydrator->hydrate($dataPost, $feed);
648
 
649
                    $files = null;
650
 
651
                    if (isset($dataPost['doc_edit']) && empty($dataPost['doc_edit']['error'])) {
652
                        $files = $dataPost['doc_edit'];
653
                    }
654
                    if (isset($dataPost['video_edit']) && empty($dataPost['video_edit']['error'])) {
655
                        $files = $dataPost['video_edit'];
656
                    }
657
 
658
                    $file_type = '';
659
                    if (isset($files) && empty($files['error'])) {
660
                        $feed_tmp_filename  = $files['tmp_name'];
661
                        $feed_filename      = $this->normalizeString($files['name']);
662
 
663
                        $mime_type = mime_content_type($feed_tmp_filename);
664
                        if ($mime_type == 'image/jpg' || $mime_type == 'image/jpeg' || $mime_type == 'image/png') {
665
                            $file_type = Feed::FILE_TYPE_IMAGE;
666
                        } else if ($mime_type == 'video/webm' || $mime_type == 'video/mpeg' || $mime_type == 'video/mpg' || $mime_type == 'video/mp4') {
667
                            $file_type = Feed::FILE_TYPE_VIDEO;
668
                        } else if ($mime_type == 'application/pdf') {
669
                            $file_type = Feed::FILE_TYPE_DOCUMENT;
670
                        }
671
                    }
672
                    //preview
673
                    $fileImg = $this->params()->fromFiles('img_edit');
674
                    if (isset($fileImg) && empty($fileImg['error'])) {
675
 
676
                        $img_tmp_filename  = $fileImg['tmp_name'];
677
                        $img_filename  = $this->normalizeString($fileImg['name']);
678
                    } else {
679
                        $img_tmp_filename = null;
680
                        $img_filename = null;
681
                    }
682
 
683
                    $feedMapper = FeedMapper::getInstance($this->adapter);
684
                    $feed = $feedMapper->fetchOne($feed->id);
685
 
686
                    $categoriesMapper = TopicMapper::getInstance($this->adapter);
687
                    $category = $categoriesMapper->fetchOneByUuidOrTitle($categoryUuid);
688
 
689
                    $feed->topic_id = $category->id;
690
                    $feed->status = Feed::STATUS_SAVED;
691
                    if ($feedMapper->update($feed)) {
692
 
693
                        if ($file_type == Feed::FILE_TYPE_DOCUMENT) {
694
                            try {
695
 
696
                                $target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;
697
 
698
 
699
                                if (!file_exists($target_path)) {
700
                                    mkdir($target_path, 0755);
701
                                }
702
 
703
                                Functions::deleteFilename($target_path, $feed->file_name);
704
 
705
                                $full_filename = $target_path  . DIRECTORY_SEPARATOR . $feed_filename;
706
                                $result = move_uploaded_file($feed_tmp_filename, $full_filename);
707
                                if ($result) {
708
 
709
                                    $feed->file_type = $file_type;
710
                                    $feed->file_name = basename($feed_filename);
711
                                    $feedMapper->update($feed);
712
                                } else {
713
                                    error_log('no se pudo mover o renombrar el documento : ' . $feed_tmp_filename . ' al directorio : ' . $full_filename);
714
                                }
715
                            } catch (\Throwable $e) {
716
                                error_log($e->getTraceAsString());
717
                            }
718
                        }
719
                        if ($file_type == Feed::FILE_TYPE_IMAGE) {
720
                            try {
721
                                $target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;
722
                                if (!file_exists($target_path)) {
723
                                    mkdir($target_path, 0755);
724
                                }
725
 
726
                                Functions::deleteFilename($target_path, $feed->file_name);
727
 
728
                                list($target_width, $target_height) = explode('x', $this->config['leaderslinked.image_sizes.feed_image_size']);
729
 
730
                                $feed_filename = substr($feed_filename, 0, strrpos($feed_filename, '.'))  . '.png';
731
                                $crop_to_dimensions = false;
732
                                if (Image::uploadImage($feed_tmp_filename, $target_path, $feed_filename, $target_width, $target_height, $crop_to_dimensions)) {
733
                                    $feed->file_type = $file_type;
734
                                    $feed->file_name = basename($feed_filename);
735
                                    $feedMapper->update($feed);
736
                                }
737
                            } catch (\Throwable $e) {
738
                                error_log($e->getTraceAsString());
739
                            }
740
                        }
741
                        if ($file_type == Feed::FILE_TYPE_VIDEO) {
742
                            try {
743
                                $target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;
744
                                if (!file_exists($target_path)) {
745
                                    mkdir($target_path, 0755);
746
                                }
747
 
748
 
749
                                Functions::deleteFilename($target_path, $feed->file_name);
750
 
751
                                Functions::deleteFilename($target_path, $feed->file_image_preview);
752
 
753
                                $full_filename = $target_path  . DIRECTORY_SEPARATOR . $feed_filename;
754
 
755
                                $result = move_uploaded_file($feed_tmp_filename, $full_filename);
756
                                if ($result) {
757
 
758
                                    $size = $this->config['leaderslinked.image_sizes.feed_image_size'];
759
                                    $getFromSecound = 2;
760
 
761
                                    //extracción del cover
762
                                    $generateFileName = substr($feed_filename, 0, strrpos($feed_filename, '.'));
763
                                    $generateFile =  $target_path  . DIRECTORY_SEPARATOR . $generateFileName .  '.png';
764
                                    $cmd            = "/usr/bin/ffmpeg -i $full_filename -an -ss $getFromSecound -s $size $generateFile";
765
                                    exec($cmd);
766
 
767
 
768
                                    $feed->file_type = $file_type;
769
                                    $feed->file_name = basename($feed_filename);
770
                                    $feed->file_image_preview = basename($generateFile);
771
                                    $feedMapper->update($feed);
772
 
773
                                    $videoConvert = new VideoConvert();
774
                                    $videoConvert->filename = $full_filename;
775
                                    $videoConvert->type = VideoConvert::TYPE_FEED;
776
 
777
                                    $videoConvertMapper = VideoConvertMapper::getInstance($this->adapter);
778
                                    $videoConvertMapper->insert($videoConvert);
779
                                } else {
780
                                    error_log('no se pudo mover o renombrar el documento : ' . $feed_tmp_filename . ' al directorio : ' . $full_filename);
781
                                }
782
                            } catch (\Throwable $e) {
783
                                error_log($e->getTraceAsString());
784
                            }
785
                        }
786
                        if ($file_type != Feed::FILE_TYPE_VIDEO && !empty($img_tmp_filename) && !empty($img_filename)) {
787
 
788
                            try {
789
                                $target_path = $this->config['leaderslinked.fullpath.feed'] . $feed->uuid;
790
                                if (!file_exists($target_path)) {
791
                                    mkdir($target_path, 0755);
792
                                }
793
 
794
                                Functions::deleteFilename($target_path, $feed->file_image_preview);
795
 
796
                                list($target_width, $target_height) = explode('x', $this->config['leaderslinked.image_sizes.feed_image_size']);
797
 
798
                                $img_filename = substr($img_filename, 0, strrpos($img_filename, '.'))  . '.png';
799
 
800
 
801
                                if (Functions::uploadImage($img_tmp_filename, $target_path, $img_filename, $target_width, $target_height)) {
802
                                    $feed->file_image_preview = basename($img_filename);
803
                                    $feedMapper->update($feed);
804
                                }
805
                            } catch (\Throwable $e) {
806
                                error_log($e->getTraceAsString());
807
                            }
808
                        }
809
 
810
                        $response = [
811
                            'success'   => true,
812
                            'data'   => 'success'
813
                        ];
814
                    } else {
815
                        $messages = [];
816
                        $form_messages = (array) $form->getMessages();
817
                        foreach ($form_messages  as $fieldname => $field_messages) {
818
                            $messages[$fieldname] = array_values($field_messages);
819
                        }
820
                        $response = [
821
                            'success' => false,
822
                            'data' => $messages
823
                        ];
824
                    }
825
                } else {
826
                    $response = [
827
                        'success' => false,
828
                        'data' => 'ERROR_METHOD_NOT_ALLOWED'
829
                    ];
830
                }
831
 
832
                return new JsonModel($response);
833
            }
834
        } catch (\Throwable $e) {
835
            $e->getMessage();
836
            return new JsonModel([
837
                'success' => false,
838
                'data' => $e
839
            ]);
840
        }
841
    }
842
 
843
    public function filterAction()
844
    {
845
        $request = $this->getRequest();
846
        $currentUserPlugin = $this->plugin('currentUserPlugin');
847
        $currentUser = $currentUserPlugin->getUser();
848
        if ($request->isPost()) {
849
 
850
            $acl = $this->getEvent()->getViewModel()->getVariable('acl');
851
            $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/edit');
852
            $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/delete');
853
            $allowAproved = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/aproved');
854
 
855
            $dataPost = $request->getPost()->toArray();
856
            $items = [];
857
            $feedMapper = FeedMapper::getInstance($this->adapter);
858
            $paginator = $feedMapper->fetchAllByDevelopAndCategoryId($dataPost['category_id'], $allowEdit);
859
 
860
            foreach ($paginator as $record) {
861
                $topicMapper = TopicMapper::getInstance($this->adapter);
862
                $topic = $topicMapper->fetchOne($record->topic_id);
863
                $topic_title =  ($topic) ? $topic->title : '';
864
                $preview = ($record->file_image_preview != null && $record->file_image_preview != '') ? $this->url()->fromRoute('storage', ['code' => $record->uuid, 'type' => 'feed', 'filename' => $record->file_image_preview]) : null;
865
                $item = [
866
                    'id' => $record->id,
867
                    'uuid' => $record->uuid,
868
                    'title' => $record->title,
869
                    'topic' => $topic_title,
870
                    'added_on' => $record->added_on,
871
                    'description' => $record->description,
872
                    'file' => $record->file_type ? $record->file_type : '',
873
                    'link_media' => $record->link_media ? $record->link_media : '',
874
                    'link_name' => $record->link_name,
875
                    'file_name' => $record->file_name ? $record->file_name : '',
876
                    'link_file' => $this->url()->fromRoute('storage', ['code' => $record->uuid, 'type' => 'feed', 'filename' => $record->file_name]),
877
                    'status' => $record->status,
878
                    'preview' => $preview,
879
                    'actions' => [
880
                        'link_edit' => ($allowEdit) ? $this->url()->fromRoute('development-and-content/edit', ['id' => $record->uuid]) : '',
881
                        'link_get' => $this->url()->fromRoute('development-and-content/getContent', ['id' => $record->uuid]),
882
                        'link_aproved' => ($allowAproved) ? $this->url()->fromRoute('development-and-content/aproved', ['id' => $record->uuid]) : '',
883
                        'link_delete' => ($allowDelete) ? $this->url()->fromRoute('development-and-content/delete', ['id' => $record->uuid]) : ''
884
                    ]
885
                ];
886
 
887
                array_push($items, $item);
888
            }
889
 
890
            return new JsonModel([
891
                'success' => true,
892
                'data' => [
893
                    'items' => $items,
894
                ]
895
            ]);
896
        } else {
897
            return new JsonModel([
898
                'success' => false,
899
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
900
            ]);
901
        }
902
    }
903
}