Proyectos de Subversion LeadersLinked - Backend

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
7811 nelberth 1
<?php
2
declare(strict_types=1);
3
 
4
namespace LeadersLinked\Controller;
5
 
6
use Laminas\Authentication\AuthenticationService;
7
use Laminas\Authentication\Result as AuthResult;
8
use Laminas\Db\Adapter\AdapterInterface;
9
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
10
use Laminas\Mvc\Controller\AbstractActionController;
11
use Laminas\Mvc\I18n\Translator;
12
use Laminas\Log\LoggerInterface;
13
use Laminas\View\Model\ViewModel;
14
use Laminas\View\Model\JsonModel;
15
use LeadersLinked\Model\HighPerformanceTeamsGroups;
16
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
17
use LeadersLinked\Form\HighPerformanceTeamsGroupsForm;
18
use LeadersLinked\Library\Functions;
19
use LeadersLinked\Mapper\UserMapper;
20
use LeadersLinked\Mapper\HighPerformanceTeamsGroupsMapper;
21
use LeadersLinked\Mapper\CompanyMapper;
22
use LeadersLinked\Mapper\CompanyUserMapper;
23
 
24
 
25
use LeadersLinked\Model\HighPerformanceTeamsGroupsMembers;
26
use LeadersLinked\Form\HighPerformanceTeamsGroupsMembersForm;
27
use LeadersLinked\Mapper\HighPerformanceTeamsGroupsMembersMapper;
28
 
29
class HighPerformanceTeamsGroupsMembersController extends AbstractActionController
30
{
31
    /**
32
     *
33
     * @var AdapterInterface
34
     */
35
    private $adapter;
36
 
37
 
38
    /**
39
     *
40
     * @var AbstractAdapter
41
     */
42
    private $cache;
43
 
44
    /**
45
     *
46
     * @var  LoggerInterface
47
     */
48
    private $logger;
49
 
50
    /**
51
     *
52
     * @var array
53
     */
54
    private $config;
55
 
56
 
57
 
58
    /**
59
     *
60
     * @param AdapterInterface $adapter
61
     * @param AbstractAdapter $cache
62
     * @param LoggerInterface $logger
63
     * @param array $config
64
     */
65
    public function __construct($adapter, $cache , $logger, $config)
66
    {
67
        $this->adapter      = $adapter;
68
        $this->cache        = $cache;
69
        $this->logger       = $logger;
70
        $this->config       = $config;
71
 
72
 
73
    }
74
 
75
 
76
 
77
 
78
    public function indexAction()
79
    {
80
 
81
 
82
        $currentUserPlugin = $this->plugin('currentUserPlugin');
83
        $currentUser = $currentUserPlugin->getUser();
84
        $currentCompany = $currentUserPlugin->getCompany();
85
 
86
 
87
        $request = $this->getRequest();
88
        if($request->isGet()) {
89
 
90
 
91
            $headers  = $request->getHeaders();
92
 
93
            $isJson = false;
94
            if($headers->has('Accept')) {
95
                $accept = $headers->get('Accept');
96
 
97
                $prioritized = $accept->getPrioritized();
98
 
99
                foreach($prioritized as $key => $value) {
100
                    $raw = trim($value->getRaw());
101
 
102
                    if(!$isJson) {
103
                        $isJson = strpos($raw, 'json');
104
                    }
105
 
106
                }
107
            }
108
 
109
            if($isJson) {
110
 
111
 
112
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
113
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'high-performance-teams/groups/edit');
114
                $allowDelete = $acl->isAllowed($currentUser->usertype_id,'high-performance-teams/groups/delete');
115
                $allowView = $acl->isAllowed($currentUser->usertype_id,'high-performance-teams/groups/view');
116
 
117
 
118
                $search = $this->params()->fromQuery('search', []);
119
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);
120
 
121
 
122
                $records_x_page     = intval($this->params()->fromQuery('length', 10), 10);
123
                $page               = (intval($this->params()->fromQuery('start', 1), 10)/$records_x_page)+1;
124
                $order =  $this->params()->fromQuery('order', []);
125
                $order_field        = empty($order[0]['column']) ? 99 :  intval($order[0]['column'], 10);
126
                $order_direction    = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var( $order[0]['dir'], FILTER_SANITIZE_STRING));
127
 
128
                $fields =  ['title', 'date'];
129
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'title';
130
 
131
                if(!in_array($order_direction, ['ASC', 'DESC'])) {
132
                    $order_direction = 'ASC';
133
                }
134
 
135
                $highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);
136
                $paginator = $highPerformanceTeamsGroupsMapper->fetchAllDataTable($search, $page, $records_x_page, $order_field, $order_direction, $currentCompany->id);
137
 
138
                $items = [];
139
 
140
                $records = $paginator->getCurrentItems();
141
 
142
 
143
                foreach($records as $record)
144
                {
145
 
146
 
147
 
148
                    $item = [
149
                        'title' => $record->title,
150
                        'description' => $record->description,
151
                        'status'=> $record->status,
152
                        'actions' => [
153
                            'link_edit' => $allowEdit ? $this->url()->fromRoute('high-performance-teams/groups/edit', ['id' => $record->uuid]) : '',
154
                            'link_delete' => $allowDelete ? $this->url()->fromRoute('high-performance-teams/groups/delete', ['id' => $record->uuid]) : '',
155
                            'link_view' => $allowView ? $this->url()->fromRoute('high-performance-teams/groups/view', ['id' => $record->uuid]) : '',
156
                        ]
157
 
158
                    ];
159
 
160
                    array_push($items, $item);
161
 
162
                }
163
 
164
                return new JsonModel([
165
                    'success' => true,
166
                    'data' => [
167
                        'items' => $items,
168
                        'total' => $paginator->getTotalItemCount(),
169
                    ]
170
                ]);
171
 
172
            } else  {
173
                $formAdd = new HighPerformanceTeamsGroupsForm($this->adapter, $currentCompany->id);
174
                $this->layout()->setTemplate('layout/layout-backend');
175
                $viewModel = new ViewModel();
176
                $viewModel->setTemplate('leaders-linked/high-performance-teams-groups/index.phtml');
177
                $viewModel->setVariables([
178
                    'formAdd' => $formAdd,
179
                ]);
180
                return $viewModel ;
181
            }
182
        } else {
183
            return new JsonModel([
184
                'success' => false,
185
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
186
            ]);
187
        }
188
    }
189
 
190
    public function addAction()
191
    {
192
      $currentUserPlugin = $this->plugin('currentUserPlugin');
193
        $currentUser = $currentUserPlugin->getUser();
194
        $currentCompany = $currentUserPlugin->getCompany();
195
 
196
        $request = $this->getRequest();
197
        if($request->isPost()) {
198
            $form = new  HighPerformanceTeamsGroupsForm($this->adapter, $currentCompany->id);
199
            $dataPost = $request->getPost()->toArray();
200
 
201
            $form->setData($dataPost);
202
 
203
            if($form->isValid()) {
204
                $dataPost = (array) $form->getData();
205
                $dataPost['status'] =  isset($dataPost['status']) ? $dataPost['status'] : HighPerformanceTeamsGroups::STATUS_INACTIVE;
206
                $dataPost['company_id']=$currentCompany->id;
207
 
208
                $hydrator = new ObjectPropertyHydrator();
209
                $highPerformanceTeamsGroups = new HighPerformanceTeamsGroups();
210
                $hydrator->hydrate($dataPost, $highPerformanceTeamsGroups);
211
 
212
                $highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);
213
 
214
                $result = $highPerformanceTeamsGroupsMapper->insert($highPerformanceTeamsGroups);
215
 
216
                if($result) {
217
 
218
                        $highPerformanceTeamsGroupsMember = new HighPerformanceTeamsGroupsMembers();
219
                        $highPerformanceTeamsGroupsMember->group_id  = $highPerformanceTeamsGroups->id;
220
 
221
                        $highPerformanceTeamsGroupsMember->user_id = $currentUser->id;
222
                        $highPerformanceTeamsGroupsMember->status = HighPerformanceTeamsGroupsMembers::STATUS_ADDED_BY_ADMIN;
223
                        $highPerformanceTeamsGroupsMember->type = HighPerformanceTeamsGroupsMembers::TYPE_CREATOR;
224
                        $highPerformanceTeamsGroupsMemberMapper = HighPerformanceTeamsGroupsMembersMapper::getInstance($this->adapter);
225
 
226
                        $highPerformanceTeamsGroupsMemberMapper->insert($highPerformanceTeamsGroupsMember);
227
 
228
 
229
                    $this->logger->info('Se agrego el grupo de alto rendimiento ' . $highPerformanceTeamsGroups->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
230
 
231
                    $data = [
232
                        'success'   => true,
233
                        'data'   => 'LABEL_RECORD_ADDED'
234
                    ];
235
                } else {
236
                    $data = [
237
                        'success'   => false,
238
                        'data'      => $highPerformanceTeamsGroupsMapper->getError()
239
                    ];
240
 
241
                }
242
 
243
                return new JsonModel($data);
244
 
245
            } else {
246
                $messages = [];
247
                $form_messages = (array) $form->getMessages();
248
                foreach($form_messages  as $fieldname => $field_messages)
249
                {
250
 
251
                    $messages[$fieldname] = array_values($field_messages);
252
                }
253
 
254
                return new JsonModel([
255
                    'success'   => false,
256
                    'data'   => $messages
257
                ]);
258
            }
259
 
260
        }else if ($request->isGet()) {
261
            $companyUserMapper = CompanyUserMapper::getInstance($this->adapter);
262
            $userMapper = UserMapper::getInstance($this->adapter);
263
            $datosCompanyUser = $companyUserMapper->fetchAllByCompanyId($currentCompany->id);
264
 
265
            $users=[];
266
 
267
            foreach($datosCompanyUser as $record){
268
                $datosUser = $userMapper->fetchOne($record->user_id);
269
 
270
                    $user=[
271
                        'uuid'=>$datosUser->uuid,
272
                        'email'=>$datosUser->email,
273
                        'first_name'=>$datosUser->first_name,
274
                        'last_name'=>$datosUser->last_name,
275
 
276
                    ];
277
                    array_push($users, $user);
278
 
279
            }
280
 
281
            return new JsonModel([
282
                'success' => true,
283
                'data' => $users
284
 
285
            ]);
286
        } else {
287
            $data = [
288
                'success' => false,
289
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
290
            ];
291
 
292
            return new JsonModel($data);
293
        }
294
 
295
        return new JsonModel($data);
296
 
297
 
298
    }
299
 
300
 
301
 
302
     public function editAction(){
303
 
304
        $currentUserPlugin = $this->plugin('currentUserPlugin');
305
        $currentUser = $currentUserPlugin->getUser();
306
        $currentCompany = $currentUserPlugin->getCompany();
307
        $request = $this->getRequest();
308
        $uuid = $this->params()->fromRoute('id');
309
 
310
 
311
        if(!$uuid) {
312
            $data = [
313
                'success'   => false,
314
                'data'   => 'ERROR_INVALID_PARAMETER'
315
            ];
316
 
317
            return new JsonModel($data);
318
        }
319
 
320
        $highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);
321
        $group = $highPerformanceTeamsGroupsMapper->fetchOneByUuid($uuid);
322
 
323
        if (!$group) {
324
            $data = [
325
                'success' => false,
326
                'data' => 'ERROR_RECORD_NOT_FOUND'
327
            ];
328
 
329
            return new JsonModel($data);
330
        }
331
 
332
        if ($group->company_id != $currentCompany->id) {
333
            return new JsonModel([
334
                'success' => false,
335
                'data' => 'ERROR_UNAUTHORIZED'
336
            ]);
337
        }
338
 
339
        if($request->isPost()) {
340
            $form = new  HighPerformanceTeamsGroupsForm($this->adapter, $currentCompany->id);
341
            $dataPost = $request->getPost()->toArray();
342
            $dataPost['status'] =  isset($dataPost['status']) ? $dataPost['status'] : HighPerformanceTeamsGroups::STATUS_INACTIVE;
343
            $form->setData($dataPost);
344
 
345
            if($form->isValid()) {
346
                $dataPost = (array) $form->getData();
347
 
348
                $hydrator = new ObjectPropertyHydrator();
349
                $hydrator->hydrate($dataPost, $group);
350
                $result = $highPerformanceTeamsGroupsMapper->update($group);
351
 
352
                if($result) {
353
                    $this->logger->info('Se actualizo el grupo de alto rendimiento ' . $group->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
354
 
355
                    $data = [
356
                        'success' => true,
357
                        'data' => 'LABEL_RECORD_UPDATED'
358
                    ];
359
                } else {
360
                    $data = [
361
                        'success'   => false,
362
                        'data'      => $highPerformanceTeamsGroupsMapper->getError()
363
                    ];
364
                }
365
 
366
                return new JsonModel($data);
367
 
368
            } else {
369
                $messages = [];
370
                $form_messages = (array) $form->getMessages();
371
                foreach($form_messages  as $fieldname => $field_messages)
372
                {
373
                    $messages[$fieldname] = array_values($field_messages);
374
                }
375
 
376
                return new JsonModel([
377
                    'success'   => false,
378
                    'data'   => $messages
379
                ]);
380
            }
381
        }else if ($request->isGet()) {
382
            $hydrator = new ObjectPropertyHydrator();
383
 
384
            $data = [
385
                'success' => true,
386
                'data' => $hydrator->extract($group)
387
            ];
388
 
389
            return new JsonModel($data);
390
        } else {
391
            $data = [
392
                'success' => false,
393
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
394
            ];
395
 
396
            return new JsonModel($data);
397
        }
398
 
399
        return new JsonModel($data);
400
 
401
    }
402
 
403
 
404
 
405
 
406
    public function deleteAction(){
407
        $currentUserPlugin = $this->plugin('currentUserPlugin');
408
        $currentCompany = $currentUserPlugin->getCompany();
409
        $currentUser = $currentUserPlugin->getUser();
410
 
411
        $request = $this->getRequest();
412
        $uuid = $this->params()->fromRoute('id');
413
 
414
 
415
        if (!$uuid) {
416
            $data = [
417
                'success' => false,
418
                'data' => 'ERROR_INVALID_PARAMETER'
419
            ];
420
 
421
            return new JsonModel($data);
422
        }
423
 
424
 
425
 
426
        $highPerformanceTeamsGroupsMapper = HighPerformanceTeamsGroupsMapper::getInstance($this->adapter);
427
        $group = $highPerformanceTeamsGroupsMapper->fetchOneByUuid($uuid);
428
 
429
        if (!$group) {
430
            $data = [
431
                'success' => false,
432
                'data' => 'ERROR_RECORD_NOT_FOUND'
433
            ];
434
 
435
            return new JsonModel($data);
436
        }
437
 
438
        if ($group->company_id != $currentCompany->id) {
439
            return new JsonModel([
440
                'success' => false,
441
                'data' => 'ERROR_UNAUTHORIZED'
442
            ]);
443
        }
444
 
445
        if ($request->isPost()) {
446
 
447
 
448
            $result = $highPerformanceTeamsGroupsMapper->delete($group->id);
449
            if ($result) {
450
                $this->logger->info('Se borro el grupo de alto rendimiento  ' . $group->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
451
 
452
                $data = [
453
                    'success' => true,
454
                    'data' => 'LABEL_RECORD_DELETED'
455
                ];
456
            } else {
457
 
458
                $data = [
459
                    'success' => false,
460
                    'data' => $highPerformanceTeamsGroupsMapper->getError()
461
                ];
462
 
463
                return new JsonModel($data);
464
            }
465
        } else {
466
            $data = [
467
                'success' => false,
468
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
469
            ];
470
 
471
            return new JsonModel($data);
472
        }
473
 
474
        return new JsonModel($data);
475
    }
476
 
477
 
478
 
479
 
480
}