Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 16798 | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
15831 efrain 1
<?php
2
 
3
declare(strict_types=1);
4
 
5
namespace LeadersLinked\Controller;
6
 
7
use Laminas\Db\Adapter\AdapterInterface;
16768 efrain 8
 
15831 efrain 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\Model\Company;
15
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
16
use LeadersLinked\Mapper\MyCoachCategoryMapper;
17
use LeadersLinked\Model\MyCoachCategory;
18
use LeadersLinked\Form\MyCoach\MyCoachCategoryForm;
19
use LeadersLinked\Mapper\UserMapper;
20
use LeadersLinked\Mapper\MyCoachCategoryUserMapper;
21
use LeadersLinked\Form\MyCoach\MyCoachCategoryUserDataForm;
22
use LeadersLinked\Form\MyCoach\MyCoachCategoryUserForm;
23
use LeadersLinked\Mapper\QueryMapper;
24
use Laminas\Paginator\Adapter\DbSelect;
25
use Laminas\Paginator\Paginator;
26
use LeadersLinked\Model\MyCoachCategoryUser;
16797 efrain 27
use LeadersLinked\Mapper\JobDescriptionMapper;
28
use LeadersLinked\Mapper\MyCoachCategoryJobDescriptionMapper;
29
use LeadersLinked\Model\User;
30
use LeadersLinked\Model\MyCoachCategoryJobDescription;
15831 efrain 31
 
32
class MyCoachCategoryUserController extends AbstractActionController {
33
 
34
    /**
35
     *
16769 efrain 36
     * @var \Laminas\Db\Adapter\AdapterInterface
15831 efrain 37
     */
38
    private $adapter;
16768 efrain 39
 
15831 efrain 40
    /**
41
     *
16769 efrain 42
     * @var \LeadersLinked\Cache\CacheInterface
15831 efrain 43
     */
16769 efrain 44
    private $cache;
45
 
46
 
47
    /**
48
     *
49
     * @var \Laminas\Log\LoggerInterface
50
     */
15831 efrain 51
    private $logger;
16768 efrain 52
 
15831 efrain 53
    /**
54
     *
55
     * @var array
56
     */
57
    private $config;
16768 efrain 58
 
16769 efrain 59
 
15831 efrain 60
    /**
61
     *
16769 efrain 62
     * @var \Laminas\Mvc\I18n\Translator
63
     */
64
    private $translator;
65
 
66
 
67
    /**
68
     *
69
     * @param \Laminas\Db\Adapter\AdapterInterface $adapter
70
     * @param \LeadersLinked\Cache\CacheInterface $cache
71
     * @param \Laminas\Log\LoggerInterface LoggerInterface $logger
15831 efrain 72
     * @param array $config
16769 efrain 73
     * @param \Laminas\Mvc\I18n\Translator $translator
15831 efrain 74
     */
16769 efrain 75
    public function __construct($adapter, $cache, $logger, $config, $translator)
16768 efrain 76
    {
16769 efrain 77
        $this->adapter      = $adapter;
78
        $this->cache        = $cache;
79
        $this->logger       = $logger;
80
        $this->config       = $config;
81
        $this->translator   = $translator;
15831 efrain 82
    }
83
 
16798 efrain 84
    public function indexAction()
85
    {
15831 efrain 86
        $request = $this->getRequest();
87
        $currentUserPlugin = $this->plugin('currentUserPlugin');
88
        $currentCompany = $currentUserPlugin->getCompany();
89
        $currentUser = $currentUserPlugin->getUser();
90
 
91
 
92
        $request = $this->getRequest();
93
        if ($request->isGet()) {
94
 
95
            $headers = $request->getHeaders();
96
 
97
            $isJson = false;
98
            if ($headers->has('Accept')) {
99
                $accept = $headers->get('Accept');
100
 
101
                $prioritized = $accept->getPrioritized();
102
 
103
                foreach ($prioritized as $key => $value) {
104
                    $raw = trim($value->getRaw());
105
 
106
                    if (!$isJson) {
107
                        $isJson = strpos($raw, 'json');
108
                    }
109
                }
110
            }
111
 
112
            //$isJson = true;
113
            if ($isJson) {
114
 
16766 efrain 115
                $category_uuid = Functions::sanitizeFilterString($this->params()->fromQuery('category_id'));
116
 
15831 efrain 117
 
118
                if(!$category_uuid) {
119
                    return new JsonModel([
120
                        'success' => true,
121
                        'data' => [
122
                            'total' => 0,
123
                            'items' => [],
124
                            'link_add' => '',
125
                            'link_upload' => '',
16797 efrain 126
                            'link_jobs_description' => '',
127
                            'roles' => [],
128
                            'jobs_description' =>  [],
15831 efrain 129
                        ]
130
                    ]);
131
 
132
                }
133
 
134
 
135
                $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
136
                $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($category_uuid);
137
 
138
                if(!$myCoachCategory) {
139
                    return new JsonModel([
140
                        'success' => false,
141
                        'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
142
                    ]);
143
                }
144
 
145
                if($myCoachCategory->company_id != $currentCompany->id) {
146
                    return new JsonModel([
147
                        'success' => false,
148
                        'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
149
                    ]);
150
                }
151
 
152
 
153
 
154
 
155
                $search = $this->params()->fromQuery('search', []);
16766 efrain 156
                $search = empty($search['value']) ? '' :  Functions::sanitizeFilterString($search['value']);
15831 efrain 157
 
158
                $start = intval($this->params()->fromQuery('start', 0), 10);
159
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
160
                $page =  intval($start / $records_x_page);
161
                $page++;
162
 
163
                $order = $this->params()->fromQuery('order', []);
164
                $order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);
16766 efrain 165
                $order_direction = empty($order[0]['dir']) ? 'ASC' : Functions::sanitizeFilterString(filter_var($order[0]['dir']));
15831 efrain 166
 
167
                $fields = ['first_name', 'last_name', 'email'];
168
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'first_name';
169
 
170
                if (!in_array($order_direction, ['ASC', 'DESC'])) {
171
                    $order_direction = 'ASC';
172
                }
173
 
174
 
175
 
176
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
177
                $allowAdd = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/add');
178
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/edit');
179
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/delete');
180
                $allowUpload = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/upload');
16797 efrain 181
                $allowJobsDescription = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/jobs-description');
15831 efrain 182
 
16797 efrain 183
 
184
 
15831 efrain 185
 
186
                $items = [];
187
 
188
                $queryMapper = QueryMapper::getInstance($this->adapter);
189
                $select = $queryMapper->getSql()->select();
190
                $select->columns(['role']);
191
                $select->from(['cu' => MyCoachCategoryUserMapper::_TABLE]);
192
                $select->join(['u' => UserMapper::_TABLE], 'cu.user_id = u.id',  ['uuid', 'first_name', 'last_name', 'email']);
193
                $select->where->equalTo('cu.category_id', $myCoachCategory->id);
194
 
195
 
196
                if($search) {
197
                    $select->where->nest()->like('first_name', '%' . $search . '%')
198
                    ->or->like('last_name', '%' . $search . '%')
199
                    ->or->like('email', '%' . $search . '%')->unnest();
200
                }
201
 
202
                $select->order($order_field . ' ' . $order_direction);
203
 
204
                //echo $select->getSqlString($this->adapter->platform); exit;
205
 
206
 
207
                $paginatorAdapter = new DbSelect($select, $this->adapter);
208
                $paginator = new Paginator($paginatorAdapter);
209
                $paginator->setItemCountPerPage($records_x_page);
210
                $paginator->setCurrentPageNumber($page);
211
 
212
                $records = $paginator->getCurrentItems();
213
 
214
                foreach ($records as $record) {
215
 
216
                    switch($record['role'])
217
                    {
218
 
219
                        case MyCoachCategoryUser::ROLE_ADMINISTRATOR :
220
                            $role = 'LABEL_ADMINISTRATOR';
221
                            break;
222
 
223
                        case MyCoachCategoryUser::ROLE_EDITOR :
224
                            $role = 'LABEL_EDITOR';
225
                            break;
226
 
227
                        case MyCoachCategoryUser::ROLE_USER :
228
                            $role = 'LABEL_USER';
229
                            break;
230
 
231
                        default :
232
                            $role = 'LABEL_UNKNOWN';
233
                            break;
234
                    }
235
 
236
 
237
 
238
 
239
 
240
 
241
                    $item = [
242
                        'first_name' => $record['first_name'],
243
                        'last_name' => $record['first_name'],
244
                        'email' => $record['email'],
245
                        'role' => $role,
246
                        'actions' => [
247
                            'link_edit' => $allowEdit ? $this->url()->fromRoute('my-coach/categories/users/edit', ['id' => $myCoachCategory->uuid, 'user_id' => $record['uuid'] ]) : '',
248
                            'link_delete' => $allowDelete ? $this->url()->fromRoute('my-coach/categories/users/delete', ['id' => $myCoachCategory->uuid, 'user_id' => $record['uuid'] ]) : '',
249
                        ]
250
                    ];
251
 
252
                    array_push($items, $item);
253
                }
254
 
255
 
256
                if($myCoachCategory->privacy == MyCoachCategory::PRIVACY_COMPANY) {
257
                    $roles = [
258
                        MyCoachCategoryUser::ROLE_USER => 'LABEL_USER',
259
                        MyCoachCategoryUser::ROLE_EDITOR => 'LABEL_EDITOR',
260
                        MyCoachCategoryUser::ROLE_ADMINISTRATOR => 'LABEL_ADMINISTRATOR',
261
                    ];
262
                } else {
263
                    $roles = [
264
                        MyCoachCategoryUser::ROLE_EDITOR => 'LABEL_EDITOR',
265
                        MyCoachCategoryUser::ROLE_ADMINISTRATOR => 'LABEL_ADMINISTRATOR',
266
                    ];
267
                }
268
 
16940 efrain 269
 
270
 
16797 efrain 271
                $jobs_description = [];
15831 efrain 272
 
16797 efrain 273
 
274
                $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
275
                $myCoachCategoryJobDescriptionMapper = MyCoachCategoryJobDescriptionMapper::getInstance($this->adapter);
276
                $records = $myCoachCategoryJobDescriptionMapper->fetchAllByCategoryId($myCoachCategory->id);
277
                foreach($records as $record)
278
                {
279
                    $jobDescription = $jobDescriptionMapper->fetchOne($record->job_description_id);
280
                    array_push($jobs_description, $jobDescription->uuid);
281
                }
282
 
283
 
284
 
285
 
15831 efrain 286
 
287
                return new JsonModel([
288
                    'success' => true,
289
                    'data' => [
290
                        'total' => $paginator->getTotalItemCount(),
291
                        'items' => $items,
292
                        'link_add' => $allowAdd ? $this->url()->fromRoute('my-coach/categories/users/add', ['id' => $myCoachCategory->uuid ] ) : '',
293
                        'link_upload' => $allowUpload ? $this->url()->fromRoute('my-coach/categories/users/upload', ['id' => $myCoachCategory->uuid ] ) : '',
294
                        'roles' => $roles,
16797 efrain 295
                        'link_jobs_description' => $allowJobsDescription ? $this->url()->fromRoute('my-coach/categories/users/jobs-description', ['id' => $myCoachCategory->uuid ] ) : '',
296
                        'jobs_description' =>  $jobs_description,
15831 efrain 297
                    ]
298
                ]);
299
            } else {
16797 efrain 300
                $jobDescriptionIdBoss = 0;
301
                $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
302
                $jobsDescription = $this->recursiveLoad($currentUser, $currentCompany, $jobDescriptionMapper, $jobDescriptionIdBoss);
15831 efrain 303
 
16797 efrain 304
 
15831 efrain 305
                $form = new  MyCoachCategoryUserForm($this->adapter, $currentCompany->id, MyCoachCategory::PRIVACY_COMPANY);
306
                $formFilter = new MyCoachCategoryUserDataForm($this->adapter, $currentCompany->id);
307
 
308
 
309
                $this->layout()->setTemplate('layout/layout-backend');
310
                $viewModel = new ViewModel();
311
                $viewModel->setTemplate('leaders-linked/my-coach-category-users/index.phtml');
312
                $viewModel->setVariables([
313
                    'form' =>  $form,
314
                    'formFilter' => $formFilter,
16797 efrain 315
                    'jobsDescription' => $jobsDescription,
316
                    'companyName' => $currentCompany->name,
15831 efrain 317
                ]);
318
                return $viewModel;
319
            }
320
        } else {
321
            return new JsonModel([
322
                'success' => false,
323
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
324
            ]);
325
        }
326
 
327
    }
16797 efrain 328
 
329
 
330
    /**
331
     *
332
     * @param User $currentUser
333
     * @param Company $currentCompany
334
     * @param JobDescriptionMapper $jobDescriptionMapper
335
     * @param int $jobDescriptionIdBoss
336
     * @return array
337
     */
338
    private function recursiveLoad($currentUser, $currentCompany, $jobDescriptionMapper, $jobDescriptionIdBoss)
339
    {
340
        $items = [];
341
        $records = $jobDescriptionMapper->fetchAllByCompanyIdAndJobDescriptionIdBoss($currentCompany->id, $jobDescriptionIdBoss);
342
 
343
 
344
        foreach($records as $record)
345
        {
346
 
347
 
348
 
349
            array_push($items, [
350
                'uuid' => $record->uuid,
351
                'name' => $record->name,
352
                'children' => $this->recursiveLoad($currentUser, $currentCompany, $jobDescriptionMapper, $record->id),
353
            ]);
354
        }
355
 
356
        return $items;
357
    }
358
 
15831 efrain 359
 
360
    public function addAction()
361
    {
362
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
363
        $currentCompany     = $currentUserPlugin->getCompany();
364
        $currentUser        = $currentUserPlugin->getUser();
365
        $request            = $this->getRequest();
366
 
367
        if($request->isPost()) {
368
 
16766 efrain 369
            $category_uuid = Functions::sanitizeFilterString($this->params()->fromRoute('id'));
15831 efrain 370
 
371
            $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
372
            $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($category_uuid);
373
 
374
            if(!$myCoachCategory) {
375
                return new JsonModel([
376
                    'success' => false,
377
                    'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
378
                ]);
379
            }
380
 
381
            if($myCoachCategory->company_id != $currentCompany->id) {
382
                return new JsonModel([
383
                    'success' => false,
384
                    'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
385
                ]);
386
            }
387
 
388
            $dataPost = $request->getPost()->toArray();
389
 
390
            $form = new  MyCoachCategoryUserForm($this->adapter, $currentCompany->id, $myCoachCategory->privacy);
391
            $form->setData($dataPost);
392
 
393
            if($form->isValid()) {
394
 
395
                $dataPost = (array) $form->getData();
396
 
397
 
398
                $userMapper = UserMapper::getInstance($this->adapter);
399
                $user = $userMapper->fetchOneByUuid($dataPost['user_id']);
400
 
401
                $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
402
                $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);
403
 
404
                if($myCoachCategoryUser) {
405
                    return new JsonModel([
406
                        'success' => false,
407
                        'data' => 'ERROR_MY_COACH_CATEGORY_USER_ALREADY_FOUND'
408
                    ]);
409
                }
410
 
411
 
412
                $myCoachCategoryUser =  new MyCoachCategoryUser();
413
                $myCoachCategoryUser->category_id = $myCoachCategory->id;
414
                $myCoachCategoryUser->user_id = $user->id;
415
                $myCoachCategoryUser->role = $dataPost['role'];
416
                $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
417
 
418
 
419
                if($myCoachCategoryUserMapper->insert($myCoachCategoryUser)) {
420
 
421
 
422
                    $this->logger->info('Se agrego el usuario ' . $user->first_name . ' ' . $user->last_name . ' (' . $user->email . ') la categoria ' . $myCoachCategory->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
423
 
424
                    $data = [
425
                        'success'   => true,
426
                        'data'   => 'LABEL_RECORD_ADDED'
427
                    ];
428
                } else {
429
                    $data = [
430
                        'success'   => false,
431
                        'data'      => $myCoachCategoryUserMapper->getError()
432
                    ];
433
 
434
                }
435
 
436
                return new JsonModel($data);
437
 
438
            } else {
439
                $messages = [];
440
                $form_messages = (array) $form->getMessages();
441
                foreach ($form_messages as $fieldname => $field_messages) {
442
 
443
                    $messages[$fieldname] = array_values($field_messages);
444
                }
445
 
446
                return new JsonModel([
447
                    'success' => false,
448
                    'data' => $messages
449
                ]);
450
 
451
            }
452
 
453
        } else {
454
            $data = [
455
                'success' => false,
456
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
457
            ];
458
 
459
            return new JsonModel($data);
460
        }
461
 
462
        return new JsonModel($data);
463
 
464
 
465
    }
466
 
467
    public function editAction()
468
    {
469
        $request = $this->getRequest();
470
        $currentUserPlugin = $this->plugin('currentUserPlugin');
471
        $currentCompany = $currentUserPlugin->getCompany();
472
        $currentUser = $currentUserPlugin->getUser();
473
 
474
        $request = $this->getRequest();
475
        $uuid = $this->params()->fromRoute('id');
476
        $user_uuid = $this->params()->fromRoute('user_id');
477
 
478
        $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
479
        $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);
480
 
481
        if(!$myCoachCategory) {
482
            return new JsonModel([
483
                'success' => false,
484
                'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
485
            ]);
486
        }
487
 
488
        if($myCoachCategory->company_id != $currentCompany->id) {
489
            return new JsonModel([
490
                'success' => false,
491
                'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
492
            ]);
493
        }
494
 
495
        $userMapper = UserMapper::getInstance($this->adapter);
496
        $user = $userMapper->fetchOneByUuid($user_uuid);
497
 
498
        if(!$user) {
499
            return new JsonModel([
500
                'success' => false,
501
                'data' => 'ERROR_USER_NOT_FOUND'
502
            ]);
503
 
504
        }
505
 
506
        $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
507
        $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);
508
 
509
        if(!$myCoachCategoryUser) {
510
            return new JsonModel([
511
                'success' => false,
512
                'data' => 'ERROR_MY_COACH_CATEGORY_USER_NOT_FOUND'
513
            ]);
514
        }
515
 
516
 
517
 
518
        if ($request->isPost()) {
519
            $dataPost = $request->getPost()->toArray();
520
 
521
            $form = new  MyCoachCategoryUserForm($this->adapter, $currentCompany->id, $myCoachCategory->privacy);
522
            $form->setData($dataPost);
523
 
524
 
525
 
526
            if ($form->isValid()) {
527
                $dataPost = (array) $form->getData();
528
 
529
                $myCoachCategoryUser->role = $dataPost['role'];
530
 
531
 
532
                if($myCoachCategoryUserMapper->update($myCoachCategoryUser)) {
533
 
534
                  $this->logger->info('Se actualizo el usuario ' . $user->first_name . ' ' . $user->last_name . ' (' . $user->email . ') la categoria ' . $myCoachCategory->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
535
 
536
                   $data = [
537
                       'success'   => true,
538
                       'data'   => 'LABEL_RECORD_UPDATED'
539
                   ];
540
               } else {
541
                   $data = [
542
                       'success'   => false,
543
                       'data'      => $myCoachCategoryUserMapper->getError()
544
                   ];
545
 
546
               }
547
 
548
                return new JsonModel($data);
549
            } else {
550
                $messages = [];
551
                $form_messages = (array) $form->getMessages();
552
                foreach ($form_messages as $fieldname => $field_messages) {
553
                    $messages[$fieldname] = array_values($field_messages);
554
                }
555
 
556
                return new JsonModel([
557
                    'success' => false,
558
                    'data' => $messages
559
                ]);
560
            }
561
        } else if ($request->isGet()) {
562
 
563
 
564
            $data = [
565
                'success' => true,
566
                'data' => [
567
                    'user_id' => $user->uuid,
568
                    'role' => $myCoachCategoryUser->role,
569
                ]
570
            ];
571
 
572
            return new JsonModel($data);
573
        }
574
 
575
 
576
        $data = [
577
            'success' => false,
578
            'data' => 'ERROR_METHOD_NOT_ALLOWED'
579
        ];
580
 
581
        return new JsonModel($data);
582
 
583
    }
584
 
585
    public function deleteAction()
586
    {
587
        $request = $this->getRequest();
588
        $currentUserPlugin = $this->plugin('currentUserPlugin');
589
        $currentCompany = $currentUserPlugin->getCompany();
590
        $currentUser = $currentUserPlugin->getUser();
591
 
592
        $request = $this->getRequest();
593
        $uuid = $this->params()->fromRoute('id');
594
        $user_id = $this->params()->fromRoute('user_id');
595
 
596
 
597
        $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
598
        $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);
599
 
600
        if(!$myCoachCategory) {
601
            return new JsonModel([
602
                'success' => false,
603
                'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
604
            ]);
605
        }
606
 
607
        if($myCoachCategory->company_id != $currentCompany->id) {
608
            return new JsonModel([
609
                'success' => false,
610
                'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
611
            ]);
612
        }
613
 
614
        $userMapper = UserMapper::getInstance($this->adapter);
615
        $user = $userMapper->fetchOneByUuid($user_id);
616
 
617
        if(!$user) {
618
            return new JsonModel([
619
                'success' => false,
620
                'data' => 'ERROR_USER_NOT_FOUND'
621
            ]);
622
 
623
        }
624
 
625
        $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
626
        $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);
627
 
628
        if(!$myCoachCategoryUser) {
629
            return new JsonModel([
630
                'success' => false,
631
                'data' => 'ERROR_MY_COACH_CATEGORY_USER_NOT_FOUND'
632
            ]);
633
        }
634
 
635
 
636
 
637
        if ($request->isPost()) {
638
 
639
            if ($myCoachCategoryUserMapper->deleteOneByCategoryIdAndUserId($myCoachCategory->id, $user->id)) {
640
            $this->logger->info('Se borro el usuario ' . $user->first_name . ' ' . $user->last_name . ' (' . $user->email . ') la categoria ' . $myCoachCategory->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
641
 
642
                $data = [
643
                    'success' => true,
644
                    'data' => 'LABEL_RECORD_DELETED'
645
                ];
646
            } else {
647
 
648
                $data = [
649
                    'success' => false,
650
                    'data' => $myCoachCategoryUserMapper->getError()
651
                ];
652
 
653
 
654
            }
655
        } else {
656
            $data = [
657
                'success' => false,
658
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
659
            ];
660
 
661
 
662
        }
663
 
664
 
665
        return new JsonModel($data);
666
 
667
    }
16797 efrain 668
 
669
 
670
 
671
    public function jobsDescriptionAction()
672
    {
673
        $request = $this->getRequest();
674
        $currentUserPlugin = $this->plugin('currentUserPlugin');
675
        $currentCompany = $currentUserPlugin->getCompany();
676
        $currentUser = $currentUserPlugin->getUser();
677
 
678
        $request = $this->getRequest();
679
        $uuid = $this->params()->fromRoute('id');
680
 
681
 
682
 
683
        $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
684
        $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);
685
 
686
        if(!$myCoachCategory) {
687
            return new JsonModel([
688
                'success' => false,
689
                'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
690
            ]);
691
        }
692
 
693
        if($myCoachCategory->company_id != $currentCompany->id) {
694
            return new JsonModel([
695
                'success' => false,
696
                'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
697
            ]);
698
        }
699
 
700
        if ($request->isPost()) {
701
 
702
            $myCoachCategoryJobDescriptionMapper = MyCoachCategoryJobDescriptionMapper::getInstance($this->adapter);
703
            $myCoachCategoryJobDescriptionMapper->deleteAllByCategoryId($myCoachCategory->id);
704
 
705
            $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
706
            $jobs_description_uuid = $this->params()->fromPost('job_description_id');
707
 
708
            if(!empty($jobs_description_uuid)) {
709
 
710
                foreach($jobs_description_uuid as $job_description_uuid)
711
                {
712
                    $jobDescription = $jobDescriptionMapper->fetchOneByUuid($job_description_uuid);
713
 
714
 
715
                    if($jobDescription && $jobDescription->company_id == $currentCompany->id) {
716
 
717
 
718
                        $myCoachCategoryJobDescription = new  MyCoachCategoryJobDescription();
719
                        $myCoachCategoryJobDescription->category_id = $myCoachCategory->id;
720
                        $myCoachCategoryJobDescription->job_description_id = $jobDescription->id;
721
 
722
 
723
                        $myCoachCategoryJobDescriptionMapper->insert($myCoachCategoryJobDescription);
724
                    }
725
 
726
                }
727
            }
728
 
729
 
730
            $data = [
731
                'success' => true,
732
                'data' => 'LABEL_RECORD_UPDATED'
733
            ];
734
 
735
        } else {
736
            $data = [
737
                'success' => false,
738
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
739
            ];
740
 
741
 
742
        }
743
 
744
 
745
        return new JsonModel($data);
746
 
747
    }
748
 
15831 efrain 749
}