Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 16797 | Ir a la última revisión | | 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
 
16797 efrain 269
                $jobs_description = [];
15831 efrain 270
 
16797 efrain 271
 
272
                $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
273
                $myCoachCategoryJobDescriptionMapper = MyCoachCategoryJobDescriptionMapper::getInstance($this->adapter);
274
                $records = $myCoachCategoryJobDescriptionMapper->fetchAllByCategoryId($myCoachCategory->id);
275
                foreach($records as $record)
276
                {
277
                    $jobDescription = $jobDescriptionMapper->fetchOne($record->job_description_id);
278
                    array_push($jobs_description, $jobDescription->uuid);
279
                }
280
 
281
 
282
 
283
 
15831 efrain 284
 
285
                return new JsonModel([
286
                    'success' => true,
287
                    'data' => [
288
                        'total' => $paginator->getTotalItemCount(),
289
                        'items' => $items,
290
                        'link_add' => $allowAdd ? $this->url()->fromRoute('my-coach/categories/users/add', ['id' => $myCoachCategory->uuid ] ) : '',
291
                        'link_upload' => $allowUpload ? $this->url()->fromRoute('my-coach/categories/users/upload', ['id' => $myCoachCategory->uuid ] ) : '',
292
                        'roles' => $roles,
16797 efrain 293
                        'link_jobs_description' => $allowJobsDescription ? $this->url()->fromRoute('my-coach/categories/users/jobs-description', ['id' => $myCoachCategory->uuid ] ) : '',
294
                        'roles' => $roles,
295
                        'jobs_description' =>  $jobs_description,
15831 efrain 296
                    ]
297
                ]);
298
            } else {
16797 efrain 299
                $jobDescriptionIdBoss = 0;
300
                $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
301
                $jobsDescription = $this->recursiveLoad($currentUser, $currentCompany, $jobDescriptionMapper, $jobDescriptionIdBoss);
15831 efrain 302
 
16797 efrain 303
 
15831 efrain 304
                $form = new  MyCoachCategoryUserForm($this->adapter, $currentCompany->id, MyCoachCategory::PRIVACY_COMPANY);
305
                $formFilter = new MyCoachCategoryUserDataForm($this->adapter, $currentCompany->id);
306
 
307
 
308
                $this->layout()->setTemplate('layout/layout-backend');
309
                $viewModel = new ViewModel();
310
                $viewModel->setTemplate('leaders-linked/my-coach-category-users/index.phtml');
311
                $viewModel->setVariables([
312
                    'form' =>  $form,
313
                    'formFilter' => $formFilter,
16797 efrain 314
                    'jobsDescription' => $jobsDescription,
315
                    'companyName' => $currentCompany->name,
15831 efrain 316
                ]);
317
                return $viewModel;
318
            }
319
        } else {
320
            return new JsonModel([
321
                'success' => false,
322
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
323
            ]);
324
        }
325
 
326
    }
16797 efrain 327
 
328
 
329
    /**
330
     *
331
     * @param User $currentUser
332
     * @param Company $currentCompany
333
     * @param JobDescriptionMapper $jobDescriptionMapper
334
     * @param int $jobDescriptionIdBoss
335
     * @return array
336
     */
337
    private function recursiveLoad($currentUser, $currentCompany, $jobDescriptionMapper, $jobDescriptionIdBoss)
338
    {
339
        $items = [];
340
        $records = $jobDescriptionMapper->fetchAllByCompanyIdAndJobDescriptionIdBoss($currentCompany->id, $jobDescriptionIdBoss);
341
 
342
 
343
        foreach($records as $record)
344
        {
345
 
346
 
347
 
348
            array_push($items, [
349
                'uuid' => $record->uuid,
350
                'name' => $record->name,
351
                'children' => $this->recursiveLoad($currentUser, $currentCompany, $jobDescriptionMapper, $record->id),
352
            ]);
353
        }
354
 
355
        return $items;
356
    }
357
 
15831 efrain 358
 
359
    public function addAction()
360
    {
361
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
362
        $currentCompany     = $currentUserPlugin->getCompany();
363
        $currentUser        = $currentUserPlugin->getUser();
364
        $request            = $this->getRequest();
365
 
366
        if($request->isPost()) {
367
 
16766 efrain 368
            $category_uuid = Functions::sanitizeFilterString($this->params()->fromRoute('id'));
15831 efrain 369
 
370
            $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
371
            $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($category_uuid);
372
 
373
            if(!$myCoachCategory) {
374
                return new JsonModel([
375
                    'success' => false,
376
                    'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
377
                ]);
378
            }
379
 
380
            if($myCoachCategory->company_id != $currentCompany->id) {
381
                return new JsonModel([
382
                    'success' => false,
383
                    'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
384
                ]);
385
            }
386
 
387
            $dataPost = $request->getPost()->toArray();
388
 
389
            $form = new  MyCoachCategoryUserForm($this->adapter, $currentCompany->id, $myCoachCategory->privacy);
390
            $form->setData($dataPost);
391
 
392
            if($form->isValid()) {
393
 
394
                $dataPost = (array) $form->getData();
395
 
396
 
397
                $userMapper = UserMapper::getInstance($this->adapter);
398
                $user = $userMapper->fetchOneByUuid($dataPost['user_id']);
399
 
400
                $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
401
                $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);
402
 
403
                if($myCoachCategoryUser) {
404
                    return new JsonModel([
405
                        'success' => false,
406
                        'data' => 'ERROR_MY_COACH_CATEGORY_USER_ALREADY_FOUND'
407
                    ]);
408
                }
409
 
410
 
411
                $myCoachCategoryUser =  new MyCoachCategoryUser();
412
                $myCoachCategoryUser->category_id = $myCoachCategory->id;
413
                $myCoachCategoryUser->user_id = $user->id;
414
                $myCoachCategoryUser->role = $dataPost['role'];
415
                $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
416
 
417
 
418
                if($myCoachCategoryUserMapper->insert($myCoachCategoryUser)) {
419
 
420
 
421
                    $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()]);
422
 
423
                    $data = [
424
                        'success'   => true,
425
                        'data'   => 'LABEL_RECORD_ADDED'
426
                    ];
427
                } else {
428
                    $data = [
429
                        'success'   => false,
430
                        'data'      => $myCoachCategoryUserMapper->getError()
431
                    ];
432
 
433
                }
434
 
435
                return new JsonModel($data);
436
 
437
            } else {
438
                $messages = [];
439
                $form_messages = (array) $form->getMessages();
440
                foreach ($form_messages as $fieldname => $field_messages) {
441
 
442
                    $messages[$fieldname] = array_values($field_messages);
443
                }
444
 
445
                return new JsonModel([
446
                    'success' => false,
447
                    'data' => $messages
448
                ]);
449
 
450
            }
451
 
452
        } else {
453
            $data = [
454
                'success' => false,
455
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
456
            ];
457
 
458
            return new JsonModel($data);
459
        }
460
 
461
        return new JsonModel($data);
462
 
463
 
464
    }
465
 
466
    public function editAction()
467
    {
468
        $request = $this->getRequest();
469
        $currentUserPlugin = $this->plugin('currentUserPlugin');
470
        $currentCompany = $currentUserPlugin->getCompany();
471
        $currentUser = $currentUserPlugin->getUser();
472
 
473
        $request = $this->getRequest();
474
        $uuid = $this->params()->fromRoute('id');
475
        $user_uuid = $this->params()->fromRoute('user_id');
476
 
477
        $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
478
        $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);
479
 
480
        if(!$myCoachCategory) {
481
            return new JsonModel([
482
                'success' => false,
483
                'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
484
            ]);
485
        }
486
 
487
        if($myCoachCategory->company_id != $currentCompany->id) {
488
            return new JsonModel([
489
                'success' => false,
490
                'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
491
            ]);
492
        }
493
 
494
        $userMapper = UserMapper::getInstance($this->adapter);
495
        $user = $userMapper->fetchOneByUuid($user_uuid);
496
 
497
        if(!$user) {
498
            return new JsonModel([
499
                'success' => false,
500
                'data' => 'ERROR_USER_NOT_FOUND'
501
            ]);
502
 
503
        }
504
 
505
        $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
506
        $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);
507
 
508
        if(!$myCoachCategoryUser) {
509
            return new JsonModel([
510
                'success' => false,
511
                'data' => 'ERROR_MY_COACH_CATEGORY_USER_NOT_FOUND'
512
            ]);
513
        }
514
 
515
 
516
 
517
        if ($request->isPost()) {
518
            $dataPost = $request->getPost()->toArray();
519
 
520
            $form = new  MyCoachCategoryUserForm($this->adapter, $currentCompany->id, $myCoachCategory->privacy);
521
            $form->setData($dataPost);
522
 
523
 
524
 
525
            if ($form->isValid()) {
526
                $dataPost = (array) $form->getData();
527
 
528
                $myCoachCategoryUser->role = $dataPost['role'];
529
 
530
 
531
                if($myCoachCategoryUserMapper->update($myCoachCategoryUser)) {
532
 
533
                  $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()]);
534
 
535
                   $data = [
536
                       'success'   => true,
537
                       'data'   => 'LABEL_RECORD_UPDATED'
538
                   ];
539
               } else {
540
                   $data = [
541
                       'success'   => false,
542
                       'data'      => $myCoachCategoryUserMapper->getError()
543
                   ];
544
 
545
               }
546
 
547
                return new JsonModel($data);
548
            } else {
549
                $messages = [];
550
                $form_messages = (array) $form->getMessages();
551
                foreach ($form_messages as $fieldname => $field_messages) {
552
                    $messages[$fieldname] = array_values($field_messages);
553
                }
554
 
555
                return new JsonModel([
556
                    'success' => false,
557
                    'data' => $messages
558
                ]);
559
            }
560
        } else if ($request->isGet()) {
561
 
562
 
563
            $data = [
564
                'success' => true,
565
                'data' => [
566
                    'user_id' => $user->uuid,
567
                    'role' => $myCoachCategoryUser->role,
568
                ]
569
            ];
570
 
571
            return new JsonModel($data);
572
        }
573
 
574
 
575
        $data = [
576
            'success' => false,
577
            'data' => 'ERROR_METHOD_NOT_ALLOWED'
578
        ];
579
 
580
        return new JsonModel($data);
581
 
582
    }
583
 
584
    public function deleteAction()
585
    {
586
        $request = $this->getRequest();
587
        $currentUserPlugin = $this->plugin('currentUserPlugin');
588
        $currentCompany = $currentUserPlugin->getCompany();
589
        $currentUser = $currentUserPlugin->getUser();
590
 
591
        $request = $this->getRequest();
592
        $uuid = $this->params()->fromRoute('id');
593
        $user_id = $this->params()->fromRoute('user_id');
594
 
595
 
596
        $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
597
        $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);
598
 
599
        if(!$myCoachCategory) {
600
            return new JsonModel([
601
                'success' => false,
602
                'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
603
            ]);
604
        }
605
 
606
        if($myCoachCategory->company_id != $currentCompany->id) {
607
            return new JsonModel([
608
                'success' => false,
609
                'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
610
            ]);
611
        }
612
 
613
        $userMapper = UserMapper::getInstance($this->adapter);
614
        $user = $userMapper->fetchOneByUuid($user_id);
615
 
616
        if(!$user) {
617
            return new JsonModel([
618
                'success' => false,
619
                'data' => 'ERROR_USER_NOT_FOUND'
620
            ]);
621
 
622
        }
623
 
624
        $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
625
        $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);
626
 
627
        if(!$myCoachCategoryUser) {
628
            return new JsonModel([
629
                'success' => false,
630
                'data' => 'ERROR_MY_COACH_CATEGORY_USER_NOT_FOUND'
631
            ]);
632
        }
633
 
634
 
635
 
636
        if ($request->isPost()) {
637
 
638
            if ($myCoachCategoryUserMapper->deleteOneByCategoryIdAndUserId($myCoachCategory->id, $user->id)) {
639
            $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()]);
640
 
641
                $data = [
642
                    'success' => true,
643
                    'data' => 'LABEL_RECORD_DELETED'
644
                ];
645
            } else {
646
 
647
                $data = [
648
                    'success' => false,
649
                    'data' => $myCoachCategoryUserMapper->getError()
650
                ];
651
 
652
 
653
            }
654
        } else {
655
            $data = [
656
                'success' => false,
657
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
658
            ];
659
 
660
 
661
        }
662
 
663
 
664
        return new JsonModel($data);
665
 
666
    }
16797 efrain 667
 
668
 
669
 
670
    public function jobsDescriptionAction()
671
    {
672
        $request = $this->getRequest();
673
        $currentUserPlugin = $this->plugin('currentUserPlugin');
674
        $currentCompany = $currentUserPlugin->getCompany();
675
        $currentUser = $currentUserPlugin->getUser();
676
 
677
        $request = $this->getRequest();
678
        $uuid = $this->params()->fromRoute('id');
679
 
680
 
681
 
682
        $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
683
        $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);
684
 
685
        if(!$myCoachCategory) {
686
            return new JsonModel([
687
                'success' => false,
688
                'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
689
            ]);
690
        }
691
 
692
        if($myCoachCategory->company_id != $currentCompany->id) {
693
            return new JsonModel([
694
                'success' => false,
695
                'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
696
            ]);
697
        }
698
 
699
        if ($request->isPost()) {
700
 
701
            $myCoachCategoryJobDescriptionMapper = MyCoachCategoryJobDescriptionMapper::getInstance($this->adapter);
702
            $myCoachCategoryJobDescriptionMapper->deleteAllByCategoryId($myCoachCategory->id);
703
 
704
            $jobDescriptionMapper = JobDescriptionMapper::getInstance($this->adapter);
705
            $jobs_description_uuid = $this->params()->fromPost('job_description_id');
706
 
707
            if(!empty($jobs_description_uuid)) {
708
 
709
                foreach($jobs_description_uuid as $job_description_uuid)
710
                {
711
                    $jobDescription = $jobDescriptionMapper->fetchOneByUuid($job_description_uuid);
712
 
713
 
714
                    if($jobDescription && $jobDescription->company_id == $currentCompany->id) {
715
 
716
 
717
                        $myCoachCategoryJobDescription = new  MyCoachCategoryJobDescription();
718
                        $myCoachCategoryJobDescription->category_id = $myCoachCategory->id;
719
                        $myCoachCategoryJobDescription->job_description_id = $jobDescription->id;
720
 
721
 
722
                        $myCoachCategoryJobDescriptionMapper->insert($myCoachCategoryJobDescription);
723
                    }
724
 
725
                }
726
            }
727
 
728
 
729
            $data = [
730
                'success' => true,
731
                'data' => 'LABEL_RECORD_UPDATED'
732
            ];
733
 
734
        } else {
735
            $data = [
736
                'success' => false,
737
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
738
            ];
739
 
740
 
741
        }
742
 
743
 
744
        return new JsonModel($data);
745
 
746
    }
747
 
15831 efrain 748
}