Proyectos de Subversion LeadersLinked - Backend

Rev

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

Rev Autor Línea Nro. Línea
15392 efrain 1
<?php
2
declare(strict_types=1);
3
 
4
namespace LeadersLinked\Controller;
5
 
6
use Laminas\Db\Adapter\AdapterInterface;
7
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
8
 
9
use Laminas\Mvc\Controller\AbstractActionController;
10
use Laminas\Log\LoggerInterface;
11
 
12
use Laminas\View\Model\ViewModel;
13
use Laminas\View\Model\JsonModel;
14
use LeadersLinked\Library\Functions;
15
use LeadersLinked\Mapper\AptitudeMapper;
16
use LeadersLinked\Form\AptitudeForm;
17
use LeadersLinked\Model\Aptitude;
18
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
19
 
20
 
21
class AptitudeController extends AbstractActionController
22
{
23
    /**
24
     *
25
     * @var AdapterInterface
26
     */
27
    private $adapter;
28
 
29
 
30
    /**
31
     *
32
     * @var AbstractAdapter
33
     */
34
    private $cache;
35
 
36
    /**
37
     *
38
     * @var  LoggerInterface
39
     */
40
    private $logger;
41
 
42
    /**
43
     *
44
     * @var array
45
     */
46
    private $config;
47
 
48
    /**
49
     *
50
     * @param AdapterInterface $adapter
51
     * @param AbstractAdapter $cache
52
     * @param LoggerInterface $logger
53
     * @param array $config
54
     */
55
    public function __construct($adapter, $cache , $logger, $config)
56
    {
57
        $this->adapter      = $adapter;
58
        $this->cache        = $cache;
59
        $this->logger       = $logger;
60
        $this->config       = $config;
61
 
62
    }
63
 
64
    public function indexAction()
65
    {
66
        $request = $this->getRequest();
67
 
68
        $request = $this->getRequest();
69
        if($request->isGet()) {
70
 
71
 
72
            $headers  = $request->getHeaders();
73
 
74
            $isJson = false;
75
            if($headers->has('Accept')) {
76
                $accept = $headers->get('Accept');
77
 
78
                $prioritized = $accept->getPrioritized();
79
 
80
                foreach($prioritized as $key => $value) {
81
                    $raw = trim($value->getRaw());
82
 
83
                    if(!$isJson) {
84
                        $isJson = strpos($raw, 'json');
85
                    }
86
 
87
                }
88
            }
89
 
90
            if($isJson) {
91
                $search = $this->params()->fromQuery('search');
92
                $search = empty($search) ? '' : filter_var($search, FILTER_SANITIZE_STRING);
93
 
94
                $page               = intval($this->params()->fromQuery('start', 1), 10);
95
                $records_x_page     = intval($this->params()->fromQuery('length', 10), 10);
96
                $order =  $this->params()->fromQuery('order', []);
97
                $order_field        = empty($order[0]['column']) ? 99 :  intval($order[0]['column'], 10);
98
                $order_direction    = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var( $order[0]['dir'], FILTER_SANITIZE_STRING));
99
 
100
                $fields =  ['name'];
101
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'name';
102
 
103
                if(!in_array($order_direction, ['ASC', 'DESC'])) {
104
                    $order_direction = 'ASC';
105
                }
106
 
107
                $aptitudeMapper = AptitudeMapper::getInstance($this->adapter);
108
                $paginator = $aptitudeMapper->fetchAllDataTable($search, $page, $records_x_page, $order_field, $order_direction);
109
 
110
                $items = [];
111
                $records = $paginator->getCurrentItems();
112
                foreach($records as $record)
113
                {
114
                    $item = [
115
                        'name' => $record->name,
116
                        'status' => $record->status,
117
                        'actions' => [
118
                            'link_edit' => $this->url()->fromRoute('settings/aptitudes/edit', ['id' => $record->uuid ]),
119
                            'link_delete' => $this->url()->fromRoute('settings/aptitudes/delete', ['id' => $record->uuid ])
120
                        ],
121
                    ];
122
 
123
                    array_push($items, $item);
124
                }
125
 
126
                return new JsonModel([
127
                    'success' => true,
128
                    'data' => [
129
                        'items' => $items,
130
                        'total' => $paginator->getTotalItemCount(),
131
                    ]
132
                ]);
133
 
134
 
135
            } else {
136
                $form = new AptitudeForm();
137
 
138
                $this->layout()->setTemplate('layout/layout-backend');
139
                $viewModel = new ViewModel();
140
                $viewModel->setTemplate('leaders-linked/aptitudes/index.phtml');
141
                $viewModel->setVariable('form', $form);
142
                return $viewModel ;
143
            }
144
        } else {
145
            return new JsonModel([
146
                'success' => false,
147
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
148
            ]);;
149
        }
150
    }
151
 
152
    public function addAction()
153
    {
154
        $currentUserPlugin = $this->plugin('currentUserPlugin');
155
        $currentUser = $currentUserPlugin->getUser();
156
 
157
        $request = $this->getRequest();
158
        if($request->isPost()) {
159
            $form = new  AptitudeForm();
160
            $dataPost = $request->getPost()->toArray();
161
 
162
            $form->setData($dataPost);
163
 
164
            if($form->isValid()) {
165
                $dataPost = (array) $form->getData();
166
                $dataPost['status'] =  isset($dataPost['status']) ? $dataPost['status'] : Aptitude::STATUS_INACTIVE;
167
 
168
                $hydrator = new ObjectPropertyHydrator();
169
                $aptitude = new Aptitude();
170
                $hydrator->hydrate($dataPost, $aptitude);
171
 
172
 
173
 
174
                $aptitudeMapper = AptitudeMapper::getInstance($this->adapter);
175
                $result = $aptitudeMapper->insert($aptitude);
176
 
177
                if($result) {
178
                    $this->logger->info('Se agrego la aptitud ' . $aptitude->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
179
 
180
                    $data = [
181
                        'success'   => true,
182
                        'data'   => 'LABEL_RECORD_ADDED'
183
                    ];
184
                } else {
185
                    $data = [
186
                        'success'   => false,
187
                        'data'      => $aptitudeMapper->getError()
188
                    ];
189
 
190
                }
191
 
192
                return new JsonModel($data);
193
 
194
            } else {
195
                $messages = [];
196
                $form_messages = (array) $form->getMessages();
197
                foreach($form_messages  as $fieldname => $field_messages)
198
                {
199
 
200
                    $messages[$fieldname] = array_values($field_messages);
201
                }
202
 
203
                return new JsonModel([
204
                    'success'   => false,
205
                    'data'   => $messages
206
                ]);
207
            }
208
 
209
        } else {
210
            $data = [
211
                'success' => false,
212
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
213
            ];
214
 
215
            return new JsonModel($data);
216
        }
217
 
218
        return new JsonModel($data);
219
    }
220
 
221
    public function editAction()
222
    {
223
        $currentUserPlugin = $this->plugin('currentUserPlugin');
224
        $currentUser = $currentUserPlugin->getUser();
225
 
226
        $request = $this->getRequest();
227
        $uuid = $this->params()->fromRoute('id');
228
 
229
 
230
        if(!$uuid) {
231
            $data = [
232
                'success'   => false,
233
                'data'   => 'ERROR_INVALID_PARAMETER'
234
            ];
235
 
236
            return new JsonModel($data);
237
        }
238
 
239
        $aptitudeMapper = AptitudeMapper::getInstance($this->adapter);
240
        $aptitude = $aptitudeMapper->fetchOneByUuid($uuid);
241
        if(!$aptitude) {
242
            $data = [
243
                'success'   => false,
244
                'data'   => 'ERROR_RECORD_NOT_FOUND'
245
            ];
246
 
247
            return new JsonModel($data);
248
        }
249
 
250
        if($request->isPost()) {
251
            $form = new  AptitudeForm();
252
            $dataPost = $request->getPost()->toArray();
253
            $dataPost['status'] =  isset($dataPost['status']) ? $dataPost['status'] : Aptitude::STATUS_INACTIVE;
254
 
255
            $form->setData($dataPost);
256
 
257
            if($form->isValid()) {
258
                $dataPost = (array) $form->getData();
259
 
260
                $hydrator = new ObjectPropertyHydrator();
261
                $hydrator->hydrate($dataPost, $aptitude);
262
                $result = $aptitudeMapper->update($aptitude);
263
 
264
                if($result) {
265
                    $this->logger->info('Se actualizo la aptitud ' . $aptitude->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
266
 
267
                    $data = [
268
                        'success' => true,
269
                        'data' => 'LABEL_RECORD_UPDATED'
270
                    ];
271
                } else {
272
                    $data = [
273
                        'success'   => false,
274
                        'data'      => $aptitudeMapper->getError()
275
                    ];
276
                }
277
 
278
                return new JsonModel($data);
279
 
280
            } else {
281
                $messages = [];
282
                $form_messages = (array) $form->getMessages();
283
                foreach($form_messages  as $fieldname => $field_messages)
284
                {
285
                    $messages[$fieldname] = array_values($field_messages);
286
                }
287
 
288
                return new JsonModel([
289
                    'success'   => false,
290
                    'data'   => $messages
291
                ]);
292
            }
293
        } else if ($request->isGet()) {
294
            $hydrator = new ObjectPropertyHydrator();
295
 
296
            $data = [
297
                'success' => true,
298
                'data' => $hydrator->extract($aptitude)
299
            ];
300
 
301
            return new JsonModel($data);
302
        } else {
303
            $data = [
304
                'success' => false,
305
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
306
            ];
307
 
308
            return new JsonModel($data);
309
        }
310
 
311
        return new JsonModel($data);
312
    }
313
 
314
    public function deleteAction()
315
    {
316
        $currentUserPlugin = $this->plugin('currentUserPlugin');
317
        $currentUser = $currentUserPlugin->getUser();
318
 
319
        $request = $this->getRequest();
320
        $uuid = $this->params()->fromRoute('id');
321
 
322
        if(!$uuid) {
323
            $data = [
324
                'success'   => false,
325
                'data'   => 'ERROR_INVALID_PARAMETER'
326
            ];
327
 
328
            return new JsonModel($data);
329
        }
330
 
331
        $aptitudeMapper = AptitudeMapper::getInstance($this->adapter);
332
        $aptitude = $aptitudeMapper->fetchOneByUuid($uuid);
333
        if(!$aptitude) {
334
            $data = [
335
                'success'   => false,
336
                'data'   => 'ERROR_RECORD_NOT_FOUND'
337
            ];
338
 
339
            return new JsonModel($data);
340
        }
341
 
342
        if($request->isPost()) {
343
            $result = $aptitudeMapper->delete($aptitude);
344
            if($result) {
345
                $this->logger->info('Se borro la aptitud ' . $aptitude->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
346
 
347
                $data = [
348
                    'success' => true,
349
                    'data' => 'LABEL_RECORD_DELETED'
350
                ];
351
            } else {
352
 
353
                $data = [
354
                    'success'   => false,
355
                    'data'      => $aptitudeMapper->getError()
356
                ];
357
 
358
                return new JsonModel($data);
359
            }
360
 
361
        } else {
362
            $data = [
363
                'success' => false,
364
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
365
            ];
366
 
367
            return new JsonModel($data);
368
        }
369
 
370
        return new JsonModel($data);
371
    }
372
}