Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 5053 | Rev 5056 | 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;
5027 efrain 13
use LeadersLinked\Library\Functions;
4579 eleazar 14
use LeadersLinked\Mapper\SurveyMapper;
4678 eleazar 15
use LeadersLinked\Mapper\SurveyFormMapper;
4883 eleazar 16
use LeadersLinked\Mapper\SurveyJobDescriptionMapper;
17
use LeadersLinked\Mapper\SurveyIndustryMapper;
18
use LeadersLinked\Mapper\SurveyJobCategoryMapper;
19
use LeadersLinked\Mapper\SurveyLocationMapper;
20
use LeadersLinked\Mapper\SurveyServiceMapper;
4855 eleazar 21
use LeadersLinked\Model\Location;
22
use LeadersLinked\Mapper\LocationMapper;
23
use LeadersLinked\Mapper\IndustryMapper;
24
use LeadersLinked\Mapper\JobDescriptionMapper;
25
use LeadersLinked\Mapper\BehaviorMapper;
26
use LeadersLinked\Mapper\JobDescriptionBehaviorCompetencyMapper;
27
use LeadersLinked\Mapper\CompanyMapper;
28
use LeadersLinked\Mapper\ServiceMapper;
29
use LeadersLinked\Model\Company;
30
use LeadersLinked\Mapper\JobCategoryMapper;
4865 eleazar 31
use LeadersLinked\Form\SurveySegmentedForm;
4579 eleazar 32
use LeadersLinked\Form\SurveyForm;
33
use LeadersLinked\Model\Survey;
34
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
5026 efrain 35
use LeadersLinked\Model\SurveyJobDescription;
5027 efrain 36
use LeadersLinked\Model\SurveyJobCategory;
37
use LeadersLinked\Model\SurveyIndustry;
38
use LeadersLinked\Model\SurveyService;
4384 eleazar 39
 
40
class SurveyController extends AbstractActionController {
41
 
42
    /**
43
     *
44
     * @var AdapterInterface
45
     */
46
    private $adapter;
47
 
48
    /**
49
     *
50
     * @var AbstractAdapter
51
     */
52
    private $cache;
53
 
54
    /**
55
     *
56
     * @var  LoggerInterface
57
     */
58
    private $logger;
59
 
60
    /**
61
     *
62
     * @var array
63
     */
64
    private $config;
65
 
66
    /**
67
     *
68
     * @param AdapterInterface $adapter
69
     * @param AbstractAdapter $cache
70
     * @param LoggerInterface $logger
71
     * @param array $config
72
     */
73
    public function __construct($adapter, $cache, $logger, $config) {
74
        $this->adapter = $adapter;
75
        $this->cache = $cache;
76
        $this->logger = $logger;
77
        $this->config = $config;
78
    }
79
 
80
    public function indexAction() {
4579 eleazar 81
        $request = $this->getRequest();
82
        $currentUserPlugin = $this->plugin('currentUserPlugin');
83
        $currentCompany = $currentUserPlugin->getCompany();
84
        $currentUser = $currentUserPlugin->getUser();
4384 eleazar 85
 
4579 eleazar 86
 
87
        $request = $this->getRequest();
88
        if ($request->isGet()) {
89
 
90
            $headers = $request->getHeaders();
91
 
92
            $isJson = false;
93
            if ($headers->has('Accept')) {
94
                $accept = $headers->get('Accept');
95
 
96
                $prioritized = $accept->getPrioritized();
97
 
98
                foreach ($prioritized as $key => $value) {
99
                    $raw = trim($value->getRaw());
100
 
101
                    if (!$isJson) {
102
                        $isJson = strpos($raw, 'json');
103
                    }
104
                }
105
            }
106
 
107
            if ($isJson) {
108
                $search = $this->params()->fromQuery('search', []);
109
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);
110
 
111
                $page = intval($this->params()->fromQuery('start', 1), 10);
112
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
113
                $order = $this->params()->fromQuery('order', []);
114
                $order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);
115
                $order_direction = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var($order[0]['dir'], FILTER_SANITIZE_STRING));
116
 
117
                $fields = ['name'];
118
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'name';
119
 
120
                if (!in_array($order_direction, ['ASC', 'DESC'])) {
121
                    $order_direction = 'ASC';
122
                }
123
 
4661 eleazar 124
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
125
                $allowAdd = $acl->isAllowed($currentUser->usertype_id, 'survey/add');
126
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'survey/edit');
127
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'survey/delete');
128
                $allowSegment = $acl->isAllowed($currentUser->usertype_id, 'survey/segment');
129
 
4579 eleazar 130
                $surveyMapper = SurveyMapper::getInstance($this->adapter);
131
                $paginator = $surveyMapper->fetchAllDataTableByCompanyId($currentCompany->id, $search, $page, $records_x_page, $order_field, $order_direction);
132
 
133
                $items = [];
134
                $records = $paginator->getCurrentItems();
135
 
136
                foreach ($records as $record) {
4754 eleazar 137
                    $surveyFormMapper = SurveyFormMapper::getInstance($this->adapter);
138
                    $surveyForm = $surveyFormMapper->fetchOne($record->form_id);
139
 
4579 eleazar 140
                    $item = [
141
                        'id' => $record->id,
142
                        'name' => $record->name,
4754 eleazar 143
                        'form' => $surveyForm->name,
4579 eleazar 144
                        'status' => $record->status,
145
                        'actions' => [
146
                            'link_edit' => $this->url()->fromRoute('survey/edit', ['id' => $record->uuid]),
147
                            'link_delete' => $this->url()->fromRoute('survey/delete', ['id' => $record->uuid]),
148
                            'link_segment' => $this->url()->fromRoute('survey/segment', ['id' => $record->uuid])
149
                        ]
150
                    ];
151
 
152
                    array_push($items, $item);
153
                }
154
 
155
                return new JsonModel([
156
                    'success' => true,
157
                    'data' => [
158
                        'items' => $items,
159
                        'total' => $paginator->getTotalItemCount(),
160
                    ]
161
                ]);
162
            } else {
163
 
164
                $form = new SurveyForm($this->adapter, $currentCompany->id);
4873 eleazar 165
                $formSegmented = new SurveySegmentedForm($this->adapter, $currentCompany->id);
4579 eleazar 166
 
167
                $this->layout()->setTemplate('layout/layout-backend');
168
                $viewModel = new ViewModel();
169
                $viewModel->setTemplate('leaders-linked/survey/index.phtml');
170
                $viewModel->setVariable('form', $form);
4873 eleazar 171
                $viewModel->setVariable('formSegmented', $formSegmented);
4579 eleazar 172
                return $viewModel;
173
            }
174
        } else {
175
            return new JsonModel([
176
                'success' => false,
177
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
178
            ]);
179
        }
4384 eleazar 180
    }
181
 
4579 eleazar 182
    public function addAction() {
183
        $request = $this->getRequest();
184
        $currentUserPlugin = $this->plugin('currentUserPlugin');
185
        $currentCompany = $currentUserPlugin->getCompany();
186
        $currentUser = $currentUserPlugin->getUser();
187
 
188
        $request = $this->getRequest();
189
 
190
        if ($request->isPost()) {
191
 
192
            $form = new SurveyForm($this->adapter, $currentCompany->id);
4672 eleazar 193
 
4579 eleazar 194
            $dataPost = $request->getPost()->toArray();
4661 eleazar 195
            $dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : SurveyForm::STATUS_INACTIVE;
4579 eleazar 196
 
197
            $form->setData($dataPost);
198
 
199
            if ($form->isValid()) {
200
                $dataPost = (array) $form->getData();
201
 
202
                $hydrator = new ObjectPropertyHydrator();
203
                $survey = new Survey();
204
                $hydrator->hydrate($dataPost, $survey);
205
 
206
                if (!$survey->status) {
207
                    $survey->status = Survey::STATUS_INACTIVE;
208
                }
209
                $survey->company_id = $currentCompany->id;
210
 
4677 eleazar 211
                $surveyFormMapper = SurveyFormMapper::getInstance($this->adapter);
212
                $surveyForm = $surveyFormMapper->fetchOneByUuid($dataPost['form_id']);
213
                $survey->form_id = $surveyForm->id;
4579 eleazar 214
 
4724 eleazar 215
                $surveyMapper = SurveyMapper::getInstance($this->adapter);
216
                $result = $surveyMapper->insert($survey);
4730 eleazar 217
 
4579 eleazar 218
                if ($result) {
4734 eleazar 219
 
4728 eleazar 220
                    if ($result) {
4579 eleazar 221
 
222
                        $data = [
223
                            'success' => true,
224
                            'data' => 'LABEL_RECORD_ADDED'
225
                        ];
226
                    } else {
227
 
228
                        $data = [
229
                            'success' => false,
230
                            'data' => 'ERROR_RECORD_NOT_FOUND'
231
                        ];
232
                    }
233
                } else {
234
                    $data = [
235
                        'success' => false,
236
                        'data' => $surveyMapper->getError()
237
                    ];
238
                }
239
 
240
                return new JsonModel($data);
241
            } else {
242
                $messages = [];
243
                $form_messages = (array) $form->getMessages();
244
                foreach ($form_messages as $fieldname => $field_messages) {
245
 
246
                    $messages[$fieldname] = array_values($field_messages);
247
                }
248
 
249
                return new JsonModel([
250
                    'success' => false,
251
                    'data' => $messages
252
                ]);
253
            }
254
        } else {
255
            $data = [
256
                'success' => false,
257
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
258
            ];
259
 
260
            return new JsonModel($data);
261
        }
262
 
263
        return new JsonModel($data);
264
    }
265
 
4856 eleazar 266
    public function segmentAction() {
4855 eleazar 267
        $request = $this->getRequest();
268
        $currentUserPlugin = $this->plugin('currentUserPlugin');
269
        $currentCompany = $currentUserPlugin->getCompany();
270
        $currentUser = $currentUserPlugin->getUser();
271
 
272
        $request = $this->getRequest();
273
        $uuid = $this->params()->fromRoute('id');
274
 
275
 
276
        if (!$uuid) {
277
            $data = [
278
                'success' => false,
279
                'data' => 'ERROR_INVALID_PARAMETER'
280
            ];
281
 
282
            return new JsonModel($data);
283
        }
284
 
285
        $surveyMapper = SurveyMapper::getInstance($this->adapter);
286
        $survey = $surveyMapper->fetchOneByUuid($uuid);
287
        if (!$survey) {
288
            $data = [
289
                'success' => false,
290
                'data' => 'ERROR_RECORD_NOT_FOUND'
291
            ];
292
 
293
            return new JsonModel($data);
294
        }
295
 
296
        if ($survey->company_id != $currentCompany->id) {
297
            return new JsonModel([
298
                'success' => false,
299
                'data' => 'ERROR_UNAUTHORIZED'
300
            ]);
301
        }
302
 
4863 eleazar 303
        if($request->isPost()){
4865 eleazar 304
            $form = new SurveySegmentedForm($this->adapter, $currentCompany->id);
5039 efrain 305
 
306
 
4855 eleazar 307
            $dataPost = $request->getPost()->toArray();
5006 eleazar 308
            $form->setData($dataPost);
5019 efrain 309
 
4855 eleazar 310
 
5020 efrain 311
 
4855 eleazar 312
            if ($form->isValid()) {
313
                $dataPost = (array) $form->getData();
5029 efrain 314
 
315
                /*
4855 eleazar 316
 
317
                $location = new Location();
318
                $hydrator->hydrate($dataPost, $location);
319
 
320
                $locationMapper= LocationMapper::getInstance($this->adapter);
321
                $resultLocation = $locationMapper->insert($location);
322
 
323
                if (!$resultLocation) {
324
                    return new JsonModel([
325
                        'success'   => false,
326
                        'data' => 'ERROR_THERE_WAS_AN_ERROR'
327
                    ]);
328
                }
5029 efrain 329
                */
4991 eleazar 330
 
4855 eleazar 331
                $jobDescription = new SurveyJobDescription();
332
                $jobCategory = new SurveyJobCategory();
333
                $industry = new SurveyIndustry();
334
                $service = new SurveyService();
4963 eleazar 335
 
5031 efrain 336
                if(!empty($dataPost['job_description_id'])){
337
 
5032 efrain 338
                   // print_r($dataPost['job_description_id']);
5031 efrain 339
 
5026 efrain 340
                    $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
341
                    $surveyJobDescriptionMapper = SurveyJobDescriptionMapper::getInstance($this->adapter);
342
 
343
                    $ok = true;
344
 
345
                    foreach($dataPost['job_description_id'] as $jobDescriptionUuid) {
346
 
5032 efrain 347
                       // echo '$jobDescriptionUuid = ' . $jobDescriptionUuid ;
5026 efrain 348
 
349
 
350
                        $jobDescription = $jobDescriptionMapper->fetchOneByUuid($jobDescriptionUuid);
5032 efrain 351
 
5033 efrain 352
                       // print_r($jobDescription);
353
                        //print_r($currentCompany);
5032 efrain 354
 
5034 efrain 355
                        if($jobDescription && $jobDescription->company_id == $currentCompany->id) {
5026 efrain 356
                            $record = new SurveyJobDescription();
357
                            $record->job_description_id = $jobDescription->id;
358
                            $record->survey_id = $survey->id;
359
 
5034 efrain 360
 
5033 efrain 361
 
5026 efrain 362
                            $result = $surveyJobDescriptionMapper->insert($record);
363
                            $ok = $ok && $result;
4985 eleazar 364
                        }
4916 eleazar 365
                    }
5026 efrain 366
 
367
                    if($ok){
5028 efrain 368
 
5026 efrain 369
                    }
4883 eleazar 370
                }
5028 efrain 371
 
372
                $data = [
373
                    'success' => true,
374
                    'data' => 'LABEL_RECORD_ADDED'
375
                ];
5046 eleazar 376
                return new JsonModel($data); exit;
4855 eleazar 377
 
5042 eleazar 378
                if(!empty($dataPost['job_category_id'])){
379
 
5048 eleazar 380
                    // print_r($dataPost['job_category_id']);
5042 eleazar 381
 
5048 eleazar 382
                     $jobCategoryMapper = JobCategoryMapper::getInstance($this->adapter);
5042 eleazar 383
                     $surveyJobCategoryMapper = SurveyJobCategoryMapper::getInstance($this->adapter);
384
 
385
                     $ok = true;
386
 
387
                     foreach($dataPost['job_category_id'] as $jobCategoryUuid) {
388
 
389
                        // echo '$jobCategoryUuid = ' . $jobCategoryUuid ;
390
 
391
 
392
                         $jobCategory = $jobCategoryMapper->fetchOneByUuid($jobCategoryUuid);
393
 
394
                        // print_r($jobCategory);
395
                         //print_r($currentCompany);
396
 
5052 eleazar 397
                         //if($jobCategory && $jobCategory->company_id == $currentCompany->id) {
5053 eleazar 398
                            $record = new SurveyJobCategory();
399
                            $record->job_category_id = $jobCategory->id;
400
                            $record->survey_id = $survey->id;
401
 
402
 
403
                            $result = $surveyJobCategoryMapper->insert($record);
404
                            $ok = $ok && $result;
5052 eleazar 405
                        // }
5042 eleazar 406
                     }
407
 
408
                     if($ok){
409
 
410
                     }
411
                 }
412
 
413
                $data = [
414
                    'success' => true,
415
                    'data' => 'LABEL_RECORD_ADDED'
416
                ];
417
                return new JsonModel($data); exit;
5049 eleazar 418
 
5042 eleazar 419
                if(!empty($dataPost['industry_id'])){
420
 
421
                    // print_r($dataPost['industry_id']);
422
 
423
                     $industryMapper = IndustryMapper::getInstance($this->adapter);
424
                     $surveyIndustryMapper = SurveyIndustryMapper::getInstance($this->adapter);
425
 
426
                     $ok = true;
427
 
428
                     foreach($dataPost['industry_id'] as $industryUuid) {
429
 
430
                        // echo '$industryUuid = ' . $industryUuid ;
431
 
432
 
433
                         $industry = $industryMapper->fetchOneByUuid($industryUuid);
434
 
435
                        // print_r($industry);
436
                         //print_r($currentCompany);
437
 
5050 eleazar 438
                         //if($industry && $industry->company_id == $currentCompany->id) {
5042 eleazar 439
                             $record = new SurveyIndustry();
440
                             $record->industry_id = $industry->id;
441
                             $record->survey_id = $survey->id;
442
 
443
 
444
 
445
                             $result = $surveyIndustryMapper->insert($record);
446
                             $ok = $ok && $result;
5050 eleazar 447
                         //}
5042 eleazar 448
                     }
449
 
450
                     if($ok){
451
 
452
                     }
453
                 }
454
 
455
                $data = [
456
                    'success' => true,
457
                    'data' => 'LABEL_RECORD_ADDED'
458
                ];
459
                return new JsonModel($data); exit;
4855 eleazar 460
 
5042 eleazar 461
                if(!empty($dataPost['service_id'])){
462
 
463
                    // print_r($dataPost['service_id']);
464
 
465
                     $serviceMapper = ServiceMapper::getInstance($this->adapter);
466
                     $surveyServiceMapper = SurveyServiceMapper::getInstance($this->adapter);
467
 
468
                     $ok = true;
469
 
470
                     foreach($dataPost['service_id'] as $serviceId) {
471
 
472
                        // echo '$serviceUuid = ' . $serviceUuid ;
473
 
474
 
475
                         $service = $serviceMapper->fetchOne($serviceId);
476
 
477
                        // print_r($service);
478
                         //print_r($currentCompany);
479
 
5055 eleazar 480
                         //if($service && $service->company_id == $currentCompany->id) {
5042 eleazar 481
                             $record = new SurveyService();
482
                             $record->service_id = $service->id;
483
                             $record->survey_id = $survey->id;
484
 
485
 
486
 
487
                             $result = $surveyServiceMapper->insert($record);
488
                             $ok = $ok && $result;
5055 eleazar 489
                        //}
5042 eleazar 490
                     }
491
 
492
                     if($ok){
493
 
494
                     }
495
                 }
496
 
497
                $data = [
498
                    'success' => true,
499
                    'data' => 'LABEL_RECORD_ADDED'
500
                ];
501
                return new JsonModel($data); exit;
5055 eleazar 502
 
4855 eleazar 503
                return new JsonModel($data);
504
            } else {
5013 eleazar 505
                $messages = [];
4855 eleazar 506
                $form_messages = (array) $form->getMessages();
507
                foreach ($form_messages as $fieldname => $field_messages) {
508
 
509
                    $messages[$fieldname] = array_values($field_messages);
510
                }
511
 
512
                return new JsonModel([
513
                    'success' => false,
5011 eleazar 514
                    'data' => $messages
5013 eleazar 515
                ]);
4855 eleazar 516
            }
517
        } else {
518
            $data = [
519
                'success' => false,
520
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
521
            ];
522
 
523
            return new JsonModel($data);
524
        }
525
 
526
        return new JsonModel($data);
527
 
528
    }
529
 
4579 eleazar 530
    public function editAction() {
531
        $request = $this->getRequest();
532
        $currentUserPlugin = $this->plugin('currentUserPlugin');
533
        $currentCompany = $currentUserPlugin->getCompany();
534
        $currentUser = $currentUserPlugin->getUser();
535
 
536
        $request = $this->getRequest();
537
        $uuid = $this->params()->fromRoute('id');
538
 
539
 
540
        if (!$uuid) {
541
            $data = [
542
                'success' => false,
543
                'data' => 'ERROR_INVALID_PARAMETER'
544
            ];
545
 
546
            return new JsonModel($data);
547
        }
548
 
549
        $surveyMapper = SurveyMapper::getInstance($this->adapter);
550
        $survey = $surveyMapper->fetchOneByUuid($uuid);
551
 
552
        if (!$survey) {
553
            $data = [
554
                'success' => false,
555
                'data' => 'ERROR_RECORD_NOT_FOUND'
556
            ];
557
 
558
            return new JsonModel($data);
559
        }
560
 
561
        if ($survey->company_id != $currentCompany->id) {
562
            return new JsonModel([
563
                'success' => false,
564
                'data' => 'ERROR_UNAUTHORIZED'
565
            ]);
566
        }
567
 
568
 
569
        if ($request->isPost()) {
570
            $form = new SurveyForm();
571
            $dataPost = $request->getPost()->toArray();
572
            $dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : SurveyForm::STATUS_INACTIVE;
573
 
574
            $form->setData($dataPost);
575
 
576
            if ($form->isValid()) {
577
                $dataPost = (array) $form->getData();
578
 
579
                $hydrator = new ObjectPropertyHydrator();
580
                $hydrator->hydrate($dataPost, $survey);
581
 
582
                if (!$survey->status) {
583
                    $survey->status = Survey::STATUS_INACTIVE;
584
                }
4749 eleazar 585
 
586
                $surveyFormMapper = SurveyFormMapper::getInstance($this->adapter);
587
                $surveyForm = $surveyFormMapper->fetchOneByUuid($dataPost['form_id']);
588
                $survey->form_id = $surveyForm->id;
589
 
4579 eleazar 590
                $result = $surveyMapper->update($survey);
591
 
592
                if ($result) {
593
                    $this->logger->info('Se edito la encuesta ' . $survey->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
594
                    $data = [
595
                        'success' => true,
596
                        'id' => $survey->id,
597
                        'action_edit' => $this->url()->fromRoute('survey/edit', ['id' => $survey->uuid]),
598
                        'data' => 'LABEL_RECORD_UPDATED'
599
                    ];
600
                } else {
601
                    $data = [
602
                        'success' => false,
603
                        'data' => $surveyMapper->getError()
604
                    ];
605
                }
606
 
607
                return new JsonModel($data);
608
            } else {
609
                $messages = [];
610
                $form_messages = (array) $form->getMessages();
611
                foreach ($form_messages as $fieldname => $field_messages) {
612
                    $messages[$fieldname] = array_values($field_messages);
613
                }
614
 
615
                return new JsonModel([
616
                    'success' => false,
617
                    'data' => $messages
618
                ]);
619
            }
620
        } else if ($request->isGet()) {
621
            $hydrator = new ObjectPropertyHydrator();
622
 
4749 eleazar 623
            $surveyFormMapper = SurveyFormMapper::getInstance($this->adapter);
624
            $surveyForm = $surveyFormMapper->fetchOne($survey->form_id);
625
 
4579 eleazar 626
            $data = [
627
                'success' => true,
628
                'data' => [
4653 eleazar 629
                    'name' => $survey->name,
4749 eleazar 630
                    'form_id' => $surveyForm->uuid,
4653 eleazar 631
                    'target' => $survey->target,
632
                    'identity' => $survey->identity,
633
                    'since_date' => $survey->since_date,
634
                    'last_date' => $survey->last_date,
635
                    'status' => $survey->status,
4579 eleazar 636
                ]
637
            ];
638
 
639
            return new JsonModel($data);
640
        } else {
641
            $data = [
642
                'success' => false,
643
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
644
            ];
645
 
646
            return new JsonModel($data);
647
        }
648
 
649
        return new JsonModel($data);
650
    }
651
 
652
    public function deleteAction() {
653
        $request = $this->getRequest();
654
        $currentUserPlugin = $this->plugin('currentUserPlugin');
655
        $currentCompany = $currentUserPlugin->getCompany();
656
        $currentUser = $currentUserPlugin->getUser();
657
 
658
        $request = $this->getRequest();
659
        $uuid = $this->params()->fromRoute('id');
660
 
661
        if (!$uuid) {
662
            $data = [
663
                'success' => false,
664
                'data' => 'ERROR_INVALID_PARAMETER'
665
            ];
666
 
667
            return new JsonModel($data);
668
        }
669
 
670
        $surveyMapper = SurveyMapper::getInstance($this->adapter);
671
        $survey = $surveyMapper->fetchOneByUuid($uuid);
672
        if (!$survey) {
673
            $data = [
674
                'success' => false,
675
                'data' => 'ERROR_RECORD_NOT_FOUND'
676
            ];
677
 
678
            return new JsonModel($data);
679
        }
680
 
681
        if ($survey->company_id != $currentCompany->id) {
682
            return new JsonModel([
683
                'success' => false,
684
                'data' => 'ERROR_UNAUTHORIZED'
685
            ]);
686
        }
687
 
688
        if ($request->isPost()) {
689
 
690
            $result = $surveyMapper->delete($survey->id);
691
            if ($result) {
4735 eleazar 692
                //$this->logger->info('Se borro la encuesta ' . $survey->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
4579 eleazar 693
 
694
                $data = [
695
                    'success' => true,
696
                    'data' => 'LABEL_RECORD_DELETED'
697
                ];
698
            } else {
699
 
700
                $data = [
701
                    'success' => false,
702
                    'data' => $surveyMapper->getError()
703
                ];
704
 
705
                return new JsonModel($data);
706
            }
707
        } else {
708
            $data = [
709
                'success' => false,
710
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
711
            ];
712
 
713
            return new JsonModel($data);
714
        }
715
 
716
        return new JsonModel($data);
717
    }
718
 
4384 eleazar 719
}