Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 4681 | Rev 4723 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

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