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