Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 16766 | Rev 16769 | 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;
27
 
28
class MyCoachCategoryUserController extends AbstractActionController {
29
 
30
    /**
31
     *
32
     * @var AdapterInterface
33
     */
34
    private $adapter;
16768 efrain 35
 
15831 efrain 36
    /**
37
     *
38
     * @var  LoggerInterface
39
     */
40
    private $logger;
16768 efrain 41
 
15831 efrain 42
    /**
43
     *
44
     * @var array
45
     */
46
    private $config;
16768 efrain 47
 
15831 efrain 48
    /**
49
     *
50
     * @param AdapterInterface $adapter
51
     * @param LoggerInterface $logger
52
     * @param array $config
53
     */
16768 efrain 54
    public function __construct($adapter, $logger, $config)
55
    {
15831 efrain 56
        $this->adapter = $adapter;
57
        $this->logger = $logger;
58
        $this->config = $config;
59
    }
60
 
61
    public function indexAction() {
62
        $request = $this->getRequest();
63
        $currentUserPlugin = $this->plugin('currentUserPlugin');
64
        $currentCompany = $currentUserPlugin->getCompany();
65
        $currentUser = $currentUserPlugin->getUser();
66
 
67
 
68
        $request = $this->getRequest();
69
        if ($request->isGet()) {
70
 
71
            $headers = $request->getHeaders();
72
 
73
            $isJson = false;
74
            if ($headers->has('Accept')) {
75
                $accept = $headers->get('Accept');
76
 
77
                $prioritized = $accept->getPrioritized();
78
 
79
                foreach ($prioritized as $key => $value) {
80
                    $raw = trim($value->getRaw());
81
 
82
                    if (!$isJson) {
83
                        $isJson = strpos($raw, 'json');
84
                    }
85
                }
86
            }
87
 
88
            //$isJson = true;
89
            if ($isJson) {
90
 
16766 efrain 91
                $category_uuid = Functions::sanitizeFilterString($this->params()->fromQuery('category_id'));
92
 
15831 efrain 93
 
94
                if(!$category_uuid) {
95
                    return new JsonModel([
96
                        'success' => true,
97
                        'data' => [
98
                            'total' => 0,
99
                            'items' => [],
100
                            'link_add' => '',
101
                            'link_upload' => '',
102
                        ]
103
                    ]);
104
 
105
                }
106
 
107
 
108
                $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
109
                $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($category_uuid);
110
 
111
                if(!$myCoachCategory) {
112
                    return new JsonModel([
113
                        'success' => false,
114
                        'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
115
                    ]);
116
                }
117
 
118
                if($myCoachCategory->company_id != $currentCompany->id) {
119
                    return new JsonModel([
120
                        'success' => false,
121
                        'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
122
                    ]);
123
                }
124
 
125
 
126
 
127
 
128
                $search = $this->params()->fromQuery('search', []);
16766 efrain 129
                $search = empty($search['value']) ? '' :  Functions::sanitizeFilterString($search['value']);
15831 efrain 130
 
131
                $start = intval($this->params()->fromQuery('start', 0), 10);
132
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
133
                $page =  intval($start / $records_x_page);
134
                $page++;
135
 
136
                $order = $this->params()->fromQuery('order', []);
137
                $order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);
16766 efrain 138
                $order_direction = empty($order[0]['dir']) ? 'ASC' : Functions::sanitizeFilterString(filter_var($order[0]['dir']));
15831 efrain 139
 
140
                $fields = ['first_name', 'last_name', 'email'];
141
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'first_name';
142
 
143
                if (!in_array($order_direction, ['ASC', 'DESC'])) {
144
                    $order_direction = 'ASC';
145
                }
146
 
147
 
148
 
149
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
150
                $allowAdd = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/add');
151
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/edit');
152
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/delete');
153
                $allowUpload = $acl->isAllowed($currentUser->usertype_id, 'my-coach/categories/users/upload');
154
 
155
 
156
                $items = [];
157
 
158
                $queryMapper = QueryMapper::getInstance($this->adapter);
159
                $select = $queryMapper->getSql()->select();
160
                $select->columns(['role']);
161
                $select->from(['cu' => MyCoachCategoryUserMapper::_TABLE]);
162
                $select->join(['u' => UserMapper::_TABLE], 'cu.user_id = u.id',  ['uuid', 'first_name', 'last_name', 'email']);
163
                $select->where->equalTo('cu.category_id', $myCoachCategory->id);
164
 
165
 
166
                if($search) {
167
                    $select->where->nest()->like('first_name', '%' . $search . '%')
168
                    ->or->like('last_name', '%' . $search . '%')
169
                    ->or->like('email', '%' . $search . '%')->unnest();
170
                }
171
 
172
                $select->order($order_field . ' ' . $order_direction);
173
 
174
                //echo $select->getSqlString($this->adapter->platform); exit;
175
 
176
 
177
                $paginatorAdapter = new DbSelect($select, $this->adapter);
178
                $paginator = new Paginator($paginatorAdapter);
179
                $paginator->setItemCountPerPage($records_x_page);
180
                $paginator->setCurrentPageNumber($page);
181
 
182
                $records = $paginator->getCurrentItems();
183
 
184
                foreach ($records as $record) {
185
 
186
                    switch($record['role'])
187
                    {
188
 
189
                        case MyCoachCategoryUser::ROLE_ADMINISTRATOR :
190
                            $role = 'LABEL_ADMINISTRATOR';
191
                            break;
192
 
193
                        case MyCoachCategoryUser::ROLE_EDITOR :
194
                            $role = 'LABEL_EDITOR';
195
                            break;
196
 
197
                        case MyCoachCategoryUser::ROLE_USER :
198
                            $role = 'LABEL_USER';
199
                            break;
200
 
201
                        default :
202
                            $role = 'LABEL_UNKNOWN';
203
                            break;
204
                    }
205
 
206
 
207
 
208
 
209
 
210
 
211
                    $item = [
212
                        'first_name' => $record['first_name'],
213
                        'last_name' => $record['first_name'],
214
                        'email' => $record['email'],
215
                        'role' => $role,
216
                        'actions' => [
217
                            'link_edit' => $allowEdit ? $this->url()->fromRoute('my-coach/categories/users/edit', ['id' => $myCoachCategory->uuid, 'user_id' => $record['uuid'] ]) : '',
218
                            'link_delete' => $allowDelete ? $this->url()->fromRoute('my-coach/categories/users/delete', ['id' => $myCoachCategory->uuid, 'user_id' => $record['uuid'] ]) : '',
219
                        ]
220
                    ];
221
 
222
                    array_push($items, $item);
223
                }
224
 
225
 
226
                if($myCoachCategory->privacy == MyCoachCategory::PRIVACY_COMPANY) {
227
                    $roles = [
228
                        MyCoachCategoryUser::ROLE_USER => 'LABEL_USER',
229
                        MyCoachCategoryUser::ROLE_EDITOR => 'LABEL_EDITOR',
230
                        MyCoachCategoryUser::ROLE_ADMINISTRATOR => 'LABEL_ADMINISTRATOR',
231
                    ];
232
                } else {
233
                    $roles = [
234
                        MyCoachCategoryUser::ROLE_EDITOR => 'LABEL_EDITOR',
235
                        MyCoachCategoryUser::ROLE_ADMINISTRATOR => 'LABEL_ADMINISTRATOR',
236
                    ];
237
                }
238
 
239
 
240
 
241
                return new JsonModel([
242
                    'success' => true,
243
                    'data' => [
244
                        'total' => $paginator->getTotalItemCount(),
245
                        'items' => $items,
246
                        'link_add' => $allowAdd ? $this->url()->fromRoute('my-coach/categories/users/add', ['id' => $myCoachCategory->uuid ] ) : '',
247
                        'link_upload' => $allowUpload ? $this->url()->fromRoute('my-coach/categories/users/upload', ['id' => $myCoachCategory->uuid ] ) : '',
248
                        'roles' => $roles,
249
                    ]
250
                ]);
251
            } else {
252
 
253
                $form = new  MyCoachCategoryUserForm($this->adapter, $currentCompany->id, MyCoachCategory::PRIVACY_COMPANY);
254
                $formFilter = new MyCoachCategoryUserDataForm($this->adapter, $currentCompany->id);
255
 
256
 
257
                $this->layout()->setTemplate('layout/layout-backend');
258
                $viewModel = new ViewModel();
259
                $viewModel->setTemplate('leaders-linked/my-coach-category-users/index.phtml');
260
                $viewModel->setVariables([
261
                    'form' =>  $form,
262
                    'formFilter' => $formFilter,
263
                ]);
264
                return $viewModel;
265
            }
266
        } else {
267
            return new JsonModel([
268
                'success' => false,
269
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
270
            ]);
271
        }
272
 
273
    }
274
 
275
    public function addAction()
276
    {
277
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
278
        $currentCompany     = $currentUserPlugin->getCompany();
279
        $currentUser        = $currentUserPlugin->getUser();
280
        $request            = $this->getRequest();
281
 
282
        if($request->isPost()) {
283
 
16766 efrain 284
            $category_uuid = Functions::sanitizeFilterString($this->params()->fromRoute('id'));
15831 efrain 285
 
286
            $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
287
            $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($category_uuid);
288
 
289
            if(!$myCoachCategory) {
290
                return new JsonModel([
291
                    'success' => false,
292
                    'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
293
                ]);
294
            }
295
 
296
            if($myCoachCategory->company_id != $currentCompany->id) {
297
                return new JsonModel([
298
                    'success' => false,
299
                    'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
300
                ]);
301
            }
302
 
303
            $dataPost = $request->getPost()->toArray();
304
 
305
            $form = new  MyCoachCategoryUserForm($this->adapter, $currentCompany->id, $myCoachCategory->privacy);
306
            $form->setData($dataPost);
307
 
308
            if($form->isValid()) {
309
 
310
                $dataPost = (array) $form->getData();
311
 
312
 
313
                $userMapper = UserMapper::getInstance($this->adapter);
314
                $user = $userMapper->fetchOneByUuid($dataPost['user_id']);
315
 
316
                $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
317
                $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);
318
 
319
                if($myCoachCategoryUser) {
320
                    return new JsonModel([
321
                        'success' => false,
322
                        'data' => 'ERROR_MY_COACH_CATEGORY_USER_ALREADY_FOUND'
323
                    ]);
324
                }
325
 
326
 
327
                $myCoachCategoryUser =  new MyCoachCategoryUser();
328
                $myCoachCategoryUser->category_id = $myCoachCategory->id;
329
                $myCoachCategoryUser->user_id = $user->id;
330
                $myCoachCategoryUser->role = $dataPost['role'];
331
                $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
332
 
333
 
334
                if($myCoachCategoryUserMapper->insert($myCoachCategoryUser)) {
335
 
336
 
337
                    $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()]);
338
 
339
                    $data = [
340
                        'success'   => true,
341
                        'data'   => 'LABEL_RECORD_ADDED'
342
                    ];
343
                } else {
344
                    $data = [
345
                        'success'   => false,
346
                        'data'      => $myCoachCategoryUserMapper->getError()
347
                    ];
348
 
349
                }
350
 
351
                return new JsonModel($data);
352
 
353
            } else {
354
                $messages = [];
355
                $form_messages = (array) $form->getMessages();
356
                foreach ($form_messages as $fieldname => $field_messages) {
357
 
358
                    $messages[$fieldname] = array_values($field_messages);
359
                }
360
 
361
                return new JsonModel([
362
                    'success' => false,
363
                    'data' => $messages
364
                ]);
365
 
366
            }
367
 
368
        } else {
369
            $data = [
370
                'success' => false,
371
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
372
            ];
373
 
374
            return new JsonModel($data);
375
        }
376
 
377
        return new JsonModel($data);
378
 
379
 
380
    }
381
 
382
    public function editAction()
383
    {
384
        $request = $this->getRequest();
385
        $currentUserPlugin = $this->plugin('currentUserPlugin');
386
        $currentCompany = $currentUserPlugin->getCompany();
387
        $currentUser = $currentUserPlugin->getUser();
388
 
389
        $request = $this->getRequest();
390
        $uuid = $this->params()->fromRoute('id');
391
        $user_uuid = $this->params()->fromRoute('user_id');
392
 
393
        $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
394
        $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);
395
 
396
        if(!$myCoachCategory) {
397
            return new JsonModel([
398
                'success' => false,
399
                'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
400
            ]);
401
        }
402
 
403
        if($myCoachCategory->company_id != $currentCompany->id) {
404
            return new JsonModel([
405
                'success' => false,
406
                'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
407
            ]);
408
        }
409
 
410
        $userMapper = UserMapper::getInstance($this->adapter);
411
        $user = $userMapper->fetchOneByUuid($user_uuid);
412
 
413
        if(!$user) {
414
            return new JsonModel([
415
                'success' => false,
416
                'data' => 'ERROR_USER_NOT_FOUND'
417
            ]);
418
 
419
        }
420
 
421
        $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
422
        $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);
423
 
424
        if(!$myCoachCategoryUser) {
425
            return new JsonModel([
426
                'success' => false,
427
                'data' => 'ERROR_MY_COACH_CATEGORY_USER_NOT_FOUND'
428
            ]);
429
        }
430
 
431
 
432
 
433
        if ($request->isPost()) {
434
            $dataPost = $request->getPost()->toArray();
435
 
436
            $form = new  MyCoachCategoryUserForm($this->adapter, $currentCompany->id, $myCoachCategory->privacy);
437
            $form->setData($dataPost);
438
 
439
 
440
 
441
            if ($form->isValid()) {
442
                $dataPost = (array) $form->getData();
443
 
444
                $myCoachCategoryUser->role = $dataPost['role'];
445
 
446
 
447
                if($myCoachCategoryUserMapper->update($myCoachCategoryUser)) {
448
 
449
                  $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()]);
450
 
451
                   $data = [
452
                       'success'   => true,
453
                       'data'   => 'LABEL_RECORD_UPDATED'
454
                   ];
455
               } else {
456
                   $data = [
457
                       'success'   => false,
458
                       'data'      => $myCoachCategoryUserMapper->getError()
459
                   ];
460
 
461
               }
462
 
463
                return new JsonModel($data);
464
            } else {
465
                $messages = [];
466
                $form_messages = (array) $form->getMessages();
467
                foreach ($form_messages as $fieldname => $field_messages) {
468
                    $messages[$fieldname] = array_values($field_messages);
469
                }
470
 
471
                return new JsonModel([
472
                    'success' => false,
473
                    'data' => $messages
474
                ]);
475
            }
476
        } else if ($request->isGet()) {
477
 
478
 
479
            $data = [
480
                'success' => true,
481
                'data' => [
482
                    'user_id' => $user->uuid,
483
                    'role' => $myCoachCategoryUser->role,
484
                ]
485
            ];
486
 
487
            return new JsonModel($data);
488
        }
489
 
490
 
491
        $data = [
492
            'success' => false,
493
            'data' => 'ERROR_METHOD_NOT_ALLOWED'
494
        ];
495
 
496
        return new JsonModel($data);
497
 
498
    }
499
 
500
    public function deleteAction()
501
    {
502
        $request = $this->getRequest();
503
        $currentUserPlugin = $this->plugin('currentUserPlugin');
504
        $currentCompany = $currentUserPlugin->getCompany();
505
        $currentUser = $currentUserPlugin->getUser();
506
 
507
        $request = $this->getRequest();
508
        $uuid = $this->params()->fromRoute('id');
509
        $user_id = $this->params()->fromRoute('user_id');
510
 
511
 
512
        $myCoachCategoryMapper = MyCoachCategoryMapper::getInstance($this->adapter);
513
        $myCoachCategory = $myCoachCategoryMapper->fetchOneByUuid($uuid);
514
 
515
        if(!$myCoachCategory) {
516
            return new JsonModel([
517
                'success' => false,
518
                'data' => 'ERROR_MY_COACH_CATEGORY_NOT_FOUND'
519
            ]);
520
        }
521
 
522
        if($myCoachCategory->company_id != $currentCompany->id) {
523
            return new JsonModel([
524
                'success' => false,
525
                'data' => 'ERROR_MY_COACH_CATEGORY_IS_OTHER_COMPANY'
526
            ]);
527
        }
528
 
529
        $userMapper = UserMapper::getInstance($this->adapter);
530
        $user = $userMapper->fetchOneByUuid($user_id);
531
 
532
        if(!$user) {
533
            return new JsonModel([
534
                'success' => false,
535
                'data' => 'ERROR_USER_NOT_FOUND'
536
            ]);
537
 
538
        }
539
 
540
        $myCoachCategoryUserMapper = MyCoachCategoryUserMapper::getInstance($this->adapter);
541
        $myCoachCategoryUser = $myCoachCategoryUserMapper->fetchOneByCategoryIdAndUserId($myCoachCategory->id, $user->id);
542
 
543
        if(!$myCoachCategoryUser) {
544
            return new JsonModel([
545
                'success' => false,
546
                'data' => 'ERROR_MY_COACH_CATEGORY_USER_NOT_FOUND'
547
            ]);
548
        }
549
 
550
 
551
 
552
        if ($request->isPost()) {
553
 
554
            if ($myCoachCategoryUserMapper->deleteOneByCategoryIdAndUserId($myCoachCategory->id, $user->id)) {
555
            $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()]);
556
 
557
                $data = [
558
                    'success' => true,
559
                    'data' => 'LABEL_RECORD_DELETED'
560
                ];
561
            } else {
562
 
563
                $data = [
564
                    'success' => false,
565
                    'data' => $myCoachCategoryUserMapper->getError()
566
                ];
567
 
568
 
569
            }
570
        } else {
571
            $data = [
572
                'success' => false,
573
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
574
            ];
575
 
576
 
577
        }
578
 
579
 
580
        return new JsonModel($data);
581
 
582
    }
583
}