Proyectos de Subversion LeadersLinked - Backend

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
13287 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\TopicMapper;
14958 kerby 15
use LeadersLinked\Mapper\FeedMapper;
13287 eleazar 16
use LeadersLinked\Mapper\QueryMapper;
17
use Laminas\Paginator\Adapter\DbSelect;
18
use Laminas\Paginator\Paginator;
19
use LeadersLinked\Form\TopicForm;
20
use Laminas\Hydrator\ArraySerializableHydrator;
21
use Laminas\Db\ResultSet\HydratingResultSet;
22
use LeadersLinked\Model\Topic;
23
use LeadersLinked\Mapper\CompanyMapper;
24
use LeadersLinked\Model\Company;
25
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
26
 
27
class DevelopmentContentCategoryController extends AbstractActionController {
28
 
29
    /**
30
     *
31
     * @var AdapterInterface
32
     */
33
    private $adapter;
34
 
35
    /**
36
     *
37
     * @var AbstractAdapter
38
     */
39
    private $cache;
40
 
41
    /**
42
     *
43
     * @var  LoggerInterface
44
     */
45
    private $logger;
46
 
47
    /**
48
     *
49
     * @var array
50
     */
51
    private $config;
52
 
53
    /**
54
     *
55
     * @param AdapterInterface $adapter
56
     * @param AbstractAdapter $cache
57
     * @param LoggerInterface $logger
58
     * @param array $config
59
     */
60
    public function __construct($adapter, $cache, $logger, $config) {
61
        $this->adapter = $adapter;
62
        $this->cache = $cache;
63
        $this->logger = $logger;
64
        $this->config = $config;
65
    }
66
 
67
    public function indexAction() {
68
        $request = $this->getRequest();
69
        $currentUserPlugin = $this->plugin('currentUserPlugin');
70
        $currentCompany = $currentUserPlugin->getCompany();
71
        $currentUser = $currentUserPlugin->getUser();
72
 
73
        try{
74
        $request = $this->getRequest();
75
        if ($request->isGet()) {
76
 
77
            $headers = $request->getHeaders();
78
 
79
            $isJson = false;
80
            if ($headers->has('Accept')) {
81
                $accept = $headers->get('Accept');
82
 
83
                $prioritized = $accept->getPrioritized();
84
 
85
                foreach ($prioritized as $key => $value) {
86
                    $raw = trim($value->getRaw());
87
 
88
                    if (!$isJson) {
89
                        $isJson = strpos($raw, 'json');
90
                    }
91
                }
92
            }
93
 
94
            if ($isJson) {
95
                $search = $this->params()->fromQuery('search', []);
96
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);
97
 
98
                $page = intval($this->params()->fromQuery('start', 1), 10);
99
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
100
                $order = $this->params()->fromQuery('order', []);
101
                $order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);
102
                $order_direction = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var($order[0]['dir'], FILTER_SANITIZE_STRING));
103
 
104
                $fields = ['title'];
105
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'title';
106
 
107
                if (!in_array($order_direction, ['ASC', 'DESC'])) {
108
                    $order_direction = 'ASC';
109
                }
110
 
111
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
112
                $allowAdd = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/category/add');
113
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/category/edit');
114
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'development-and-content/category/delete');
115
 
116
                $items = [];
117
                $topicMapper = TopicMapper::getInstance($this->adapter);
118
 
13303 eleazar 119
                $paginator = $topicMapper->fetchAllDevelopment();
13287 eleazar 120
 
121
 
122
                foreach ($paginator as $record) {
123
 
124
                    $item = [
125
                        'id' => $record->id,
126
                        'title' => $record->title,
127
                        'description' => $record->description,
128
                        'status' => $record->status,
129
                        'actions' => [
130
                            'link_edit' => $this->url()->fromRoute('development-and-content/category/edit', ['id' => $record->uuid]),
131
                            'link_delete' => $this->url()->fromRoute('development-and-content/category/delete', ['id' => $record->uuid]),
132
                        ]
133
                    ];
134
 
135
                    array_push($items, $item);
136
                }
137
 
138
                return new JsonModel([
139
                    'success' => true,
140
                    'data' => [
141
                        'items' => $items,
142
                    ]
143
                ]);
144
            } else {
145
 
146
                $form = new TopicForm($this->adapter, $currentCompany->id);
147
 
148
                $this->layout()->setTemplate('layout/layout-backend');
149
                $viewModel = new ViewModel();
13304 eleazar 150
                $viewModel->setTemplate('leaders-linked/development-content-category/index.phtml');
13287 eleazar 151
                $viewModel->setVariable('form', $form);
152
                return $viewModel;
153
            }
154
        } else {
155
            return new JsonModel([
156
                'success' => false,
157
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
158
            ]);
159
        }
160
    } catch (\Throwable $e) {
161
            $e->getMessage();
162
            return new JsonModel([
163
                'success' => false,
164
                'data' => $e
165
            ]);
166
        }
167
    }
168
 
169
    public function addAction() {
170
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
171
        $currentCompany     = $currentUserPlugin->getCompany();
172
        $currentUser        = $currentUserPlugin->getUser();
173
 
174
        $request    = $this->getRequest();
175
 
176
        try{
177
        if($request->isPost()) {
178
            $form = new  TopicForm($this->adapter, $currentCompany->id);
179
 
180
            $dataPost = $request->getPost()->toArray();
181
 
182
            $form->setData($dataPost);
183
 
184
            if($form->isValid()) {
185
 
186
                $dataPost = (array) $form->getData();
187
 
188
                $hydrator = new ObjectPropertyHydrator();
189
                $categories = new Topic();
190
                $hydrator->hydrate($dataPost, $categories);
191
 
192
                $categories->type='dc';
193
               // echo $select->getSqlString($this->adapter->platform);
194
                $categoriesMapper = TopicMapper::getInstance($this->adapter);
195
 
196
                if($categoriesMapper->insert($categories)) {
197
                     $categories = $categoriesMapper->fetchOne($categories->id);
198
 
199
                    $this->logger->info('Se agrego la categoria ' . $categories->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
200
 
201
                    $data = [
202
                        'success'   => true,
203
                        'data'   => 'LABEL_RECORD_ADDED'
204
                    ];
205
                } else {
206
                    $data = [
207
                        'success'   => false,
208
                        'data'      => $categoriesMapper->getError()
209
                    ];
210
 
211
                }
212
 
213
                return new JsonModel($data);
214
 
215
            } else {
216
                $messages = [];
217
                $form_messages = (array) $form->getMessages();
218
                foreach($form_messages  as $fieldname => $field_messages)
219
                {
220
 
221
                    $messages[$fieldname] = array_values($field_messages);
222
                }
223
 
224
            }
225
 
226
        } else {
227
            $data = [
228
                'success' => false,
229
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
230
            ];
231
 
232
            return new JsonModel($data);
233
        }
234
 
235
        return new JsonModel($data);
236
    } catch (\Throwable $e) {
237
        $e->getMessage();
238
        return new JsonModel([
239
            'success' => false,
240
            'data' => $e
241
        ]);
242
    }
243
 
244
    }
245
 
246
    public function editAction() {
247
        $request = $this->getRequest();
248
        $currentUserPlugin = $this->plugin('currentUserPlugin');
249
        $currentCompany = $currentUserPlugin->getCompany();
250
        $currentUser = $currentUserPlugin->getUser();
251
 
252
        $request = $this->getRequest();
253
        $uuid = $this->params()->fromRoute('id');
254
        try{
255
        if (!$uuid) {
256
            $data = [
257
                'success' => false,
258
                'data' => 'ERROR_INVALID_PARAMETER'
259
            ];
260
 
261
            return new JsonModel($data);
262
        }
263
 
264
        $categoriesMapper = TopicMapper::getInstance($this->adapter);
265
        $categories = $categoriesMapper->fetchOneByUuid($uuid);
266
 
267
        if (!$categories) {
268
            $data = [
269
                'success' => false,
270
                'data' => 'ERROR_RECORD_NOT_FOUND'
271
            ];
272
 
273
            return new JsonModel($data);
274
        }
275
 
276
 
277
        if ($request->isPost()) {
278
            $form = new TopicForm();
279
            $dataPost = $request->getPost()->toArray();
280
 
281
            $form->setData($dataPost);
282
 
283
            if ($form->isValid()) {
284
                $dataPost = (array) $form->getData();
285
 
286
                $hydrator = new ObjectPropertyHydrator();
287
                $hydrator->hydrate($dataPost, $categories);
288
 
289
                if($categoriesMapper->update($categories)) {
290
                    $categories = $categoriesMapper->fetchOne($categories->id);
291
 
292
                   $this->logger->info('Se modifico la categoria ' . $categories->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
293
 
294
                   $data = [
295
                       'success'   => true,
296
                       'data'   => 'LABEL_RECORD_UPDATED'
297
                   ];
298
               } else {
299
                   $data = [
300
                       'success'   => false,
301
                       'data'      => $categoriesMapper->getError()
302
                   ];
303
 
304
               }
305
 
306
                return new JsonModel($data);
307
            } else {
308
                $messages = [];
309
                $form_messages = (array) $form->getMessages();
310
                foreach ($form_messages as $fieldname => $field_messages) {
311
                    $messages[$fieldname] = array_values($field_messages);
312
                }
313
 
314
                return new JsonModel([
315
                    'success' => false,
316
                    'data' => $messages
317
                ]);
318
            }
319
        } else if ($request->isGet()) {
320
 
321
            $hydrator = new ObjectPropertyHydrator();
322
 
323
            $data = [
324
                'success' => true,
325
                'data' => [
326
                    'id' => $categories->uuid,
327
                    'title' => $categories->title,
328
                    'description' => $categories->description,
14554 kerby 329
                    'status' => $categories->status
13287 eleazar 330
                ]
331
            ];
332
 
333
            return new JsonModel($data);
334
        } else {
335
            $data = [
336
                'success' => false,
337
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
338
            ];
339
 
340
            return new JsonModel($data);
341
        }
342
 
14564 kerby 343
            return new JsonModel($data);
344
        } catch (\Throwable $e) {
345
            $e->getMessage();
346
            return new JsonModel([
347
                'success' => false,
348
                'data' => $e
349
            ]);
350
        }
13287 eleazar 351
    }
352
 
353
    public function deleteAction() {
354
        $request = $this->getRequest();
355
        $currentUserPlugin = $this->plugin('currentUserPlugin');
356
        $currentCompany = $currentUserPlugin->getCompany();
357
        $currentUser = $currentUserPlugin->getUser();
358
 
359
        $request = $this->getRequest();
360
        $uuid = $this->params()->fromRoute('id');
361
 
362
        if (!$uuid) {
363
            $data = [
364
                'success' => false,
365
                'data' => 'ERROR_INVALID_PARAMETER'
366
            ];
367
 
368
            return new JsonModel($data);
369
        }
370
 
371
        $categoriesMapper = TopicMapper::getInstance($this->adapter);
372
        $categories = $categoriesMapper->fetchOneByUuid($uuid);
373
        if (!$categories) {
374
            $data = [
375
                'success' => false,
376
                'data' => 'ERROR_RECORD_NOT_FOUND'
377
            ];
378
 
379
            return new JsonModel($data);
380
        }
381
 
382
        if ($request->isPost()) {
383
 
14958 kerby 384
            $feedMapper = FeedMapper::getInstance($this->adapter);
14960 kerby 385
            $feeds = $feedMapper->fetchAllByDevelopAndCategoryIdCount($categories->id);
386
            if($feeds > 0){
14962 kerby 387
 
388
                $data = [
389
                    'success' => false,
390
                    'data' => 'Esta categoria posee contenidos asociados no puede ser eliminada'
391
                ];
392
                return new JsonModel($data);
393
            }else{
14958 kerby 394
                $result = $categoriesMapper->delete($categories->id);
395
                if ($result) {
396
                    $this->logger->info('Se borro la categoria ' . $categories->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
13287 eleazar 397
 
14958 kerby 398
                    $data = [
399
                        'success' => true,
400
                        'data' => 'LABEL_RECORD_DELETED'
401
                    ];
402
                } else {
13287 eleazar 403
 
14958 kerby 404
                    $data = [
405
                        'success' => false,
406
                        'data' => $categoriesMapper->getError()
407
                    ];
408
 
409
                    return new JsonModel($data);
410
                }
411
            }
13287 eleazar 412
 
14958 kerby 413
 
13287 eleazar 414
        } else {
415
            $data = [
416
                'success' => false,
417
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
418
            ];
419
 
420
            return new JsonModel($data);
421
        }
422
 
423
        return new JsonModel($data);
424
    }
425
}