Proyectos de Subversion LeadersLinked - Backend

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1468 eleazar 1
<?php
2
 
3
declare(strict_types=1);
4
 
5
namespace LeadersLinked\Controller;
6
 
7
use Laminas\Db\Adapter\AdapterInterface;
8
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
9
use Laminas\Mvc\Controller\AbstractActionController;
10
use Laminas\Log\LoggerInterface;
11
use Laminas\View\Model\ViewModel;
12
use Laminas\View\Model\JsonModel;
1471 eleazar 13
use LeadersLinked\Form\RecruitmentSelectionCandidateFormForm;
1468 eleazar 14
use LeadersLinked\Library\Functions;
1479 eleazar 15
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
1468 eleazar 16
use LeadersLinked\Mapper\RecruitmentSelectionCandidateMapper;
17
use LeadersLinked\Model\RecruitmentSelectionCandidate;
18
use LeadersLinked\Mapper\RecruitmentSelectionVacancyMapper;
19
use LeadersLinked\Model\RecruitmentSelectionVacancy;
20
use LeadersLinked\Mapper\BehaviorMapper;
1473 eleazar 21
use LeadersLinked\Mapper\UserMapper;
1468 eleazar 22
use LeadersLinked\Mapper\CompanyMapper;
23
use LeadersLinked\Model\Company;
1601 eleazar 24
use Laminas\Hydrator\ArraySerializableHydrator;
25
use Laminas\Db\ResultSet\HydratingResultSet;
26
use LeadersLinked\Mapper\QueryMapper;
27
use Laminas\Paginator\Adapter\DbSelect;
28
use Laminas\Paginator\Paginator;
1468 eleazar 29
 
1470 eleazar 30
class RecruitmentSelectionCandidateController extends AbstractActionController{
31
 
32
    /**
1468 eleazar 33
     *
34
     * @var AdapterInterface
35
     */
36
    private $adapter;
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
     * @param AdapterInterface $adapter
59
     * @param AbstractAdapter $cache
60
     * @param LoggerInterface $logger
61
     * @param array $config
62
     */
63
    public function __construct($adapter, $cache, $logger, $config) {
64
        $this->adapter = $adapter;
65
        $this->cache = $cache;
66
        $this->logger = $logger;
67
        $this->config = $config;
68
    }
69
 
70
    public function indexAction() {
71
        $currentUserPlugin = $this->plugin('currentUserPlugin');
72
        $currentUser = $currentUserPlugin->getUser();
73
        $currentCompany = $currentUserPlugin->getCompany();
74
 
75
        $request = $this->getRequest();
76
 
77
        if ($request->isGet()) {
78
 
79
            $headers = $request->getHeaders();
80
 
81
            $isJson = false;
82
            if ($headers->has('Accept')) {
83
                $accept = $headers->get('Accept');
84
 
85
                $prioritized = $accept->getPrioritized();
86
 
87
                foreach ($prioritized as $key => $value) {
88
                    $raw = trim($value->getRaw());
89
 
90
                    if (!$isJson) {
91
                        $isJson = strpos($raw, 'json');
92
                    }
93
                }
94
            }
95
 
96
            if ($isJson) {
1477 efrain 97
                //$form_uuid = filter_var($this->params()->fromQuery('form_uuid'), FILTER_SANITIZE_STRING);
1468 eleazar 98
 
1502 eleazar 99
                $vacancy_uuid = $this->params()->fromRoute('vacancy_uuid');
1501 eleazar 100
 
1468 eleazar 101
                $data = [
102
                    'items' => [],
103
                    'total' => 0,
104
                ];
105
 
106
 
1477 efrain 107
                if (!$vacancy_uuid) {
1468 eleazar 108
                    return new JsonModel([
109
                        'success' => true,
110
                        'data' => $data
111
                    ]);
112
                }
113
 
114
 
1477 efrain 115
                $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
116
                $vacancy = $vacancyMapper->fetchOneByUuid($vacancy_uuid);
117
                if (! $vacancy) {
1468 eleazar 118
                    return new JsonModel([
119
                        'success' => true,
120
                        'data' => 'ERROR_FORM_NOT_FOUND'
121
                    ]);
122
                }
123
 
1477 efrain 124
                if ( $vacancy->company_id != $currentCompany->id) {
1468 eleazar 125
                    return new JsonModel([
126
                        'success' => true,
127
                        'data' => 'ERROR_UNAUTHORIZED'
128
                    ]);
129
                }
130
 
131
 
132
                $search = $this->params()->fromQuery('search', []);
133
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);
134
 
135
                $page = intval($this->params()->fromQuery('start', 1), 10);
136
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
137
                $order = $this->params()->fromQuery('order', []);
138
                $order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);
139
                $order_direction = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var($order[0]['dir'], FILTER_SANITIZE_STRING));
140
 
141
                $fields = ['uuid', 'first_name', 'last_name', 'email'];
142
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'first_name';
143
 
144
                if (!in_array($order_direction, ['ASC', 'DESC'])) {
145
                    $order_direction = 'ASC';
146
                }
147
 
148
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
149
                $allowAdd = $acl->isAllowed($currentUser->usertype_id, 'recruitment-and-selection/candidates/add');
1614 eleazar 150
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'recruitment-and-selection/candidates/edit');
1468 eleazar 151
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'recruitment-and-selection/candidates/delete');
1636 eleazar 152
                $allowEmail = $acl->isAllowed($currentUser->usertype_id, 'recruitment-and-selection/user-by-email');
1468 eleazar 153
 
1600 eleazar 154
                $queryMapper = QueryMapper::getInstance($this->adapter);
155
                $sql = $queryMapper->getSql();
156
                $select = $sql->select();
157
                $select->columns(['id', 'uuid', 'first_name', 'last_name', 'email']);
158
                $select->from(['tb1' => RecruitmentSelectionCandidateMapper::_TABLE]);
2681 eleazar 159
                $select->where->equalTo('tb1.vacancy_id', $vacancy->id);
1468 eleazar 160
 
1600 eleazar 161
                if($search) {
162
                    $select->where->nest()
163
                    ->like('first_name', '%' . $search . '%')
164
                    ->or->like('last_name', '%' . $search . '%')
165
                    ->or->like('email', '%' . $search . '%')
166
                    ->unnest();
167
                }
168
 
169
                $select->order($order_field . ' ' . $order_direction);
170
 
1468 eleazar 171
                $hydrator = new ArraySerializableHydrator();
172
                $resultset = new HydratingResultSet($hydrator);
173
 
174
                $adapter = new DbSelect($select, $sql, $resultset);
175
                $paginator = new Paginator($adapter);
176
                $paginator->setItemCountPerPage($records_x_page);
177
                $paginator->setCurrentPageNumber($page);
178
 
179
 
180
                $items = [];
181
                $records = $paginator->getCurrentItems();
4503 eleazar 182
 
1468 eleazar 183
                foreach ($records as $record) {
184
                    $params = [
1608 eleazar 185
                        'vacancy_uuid' => $vacancy->uuid,
186
                        'id' => $record['uuid'],
1468 eleazar 187
                    ];
188
 
1624 eleazar 189
                    $link_delete = $this->url()->fromRoute('recruitment-and-selection/candidates/delete', $params);
190
 
191
                    $link_edit = $this->url()->fromRoute('recruitment-and-selection/candidates/edit', $params);
192
 
1468 eleazar 193
                    $item = [
194
                        'uuid' => $record['uuid'],
195
                        'first_name' => $record['first_name'],
196
                        'last_name' => $record['last_name'],
197
                        'email' => $record['email'],
1611 eleazar 198
                        // 'file' => $this->url()->fromRoute('storage', ['type' => 'recruitment_selection', 'code' => $record['uuid'], 'filename' => $record['file']]),
1468 eleazar 199
                        'actions' => [
1614 eleazar 200
                            'link_edit' => $allowEdit ? $link_edit : '',
1468 eleazar 201
                            'link_delete' => $allowDelete ? $link_delete : '',
202
                        ]
203
                    ];
204
 
205
                    array_push($items, $item);
206
                }
207
 
208
                $data['items'] = $items;
209
                $data['total'] = $paginator->getTotalItemCount();
210
 
211
 
212
                return new JsonModel([
213
                    'success' => true,
214
                    'data' => $data
215
                ]);
216
            } else {
217
                $form = new RecruitmentSelectionCandidateFormForm($this->adapter, $currentCompany->id);
218
 
219
                $this->layout()->setTemplate('layout/layout-backend');
220
                $viewModel = new ViewModel();
1475 eleazar 221
                $viewModel->setTemplate('leaders-linked/recruitment-and-selection-candidates/index.phtml');
1598 eleazar 222
                $viewModel->setVariables(['form' => $form]);
1468 eleazar 223
 
224
                return $viewModel;
225
            }
226
        } else {
227
            return new JsonModel([
228
                'success' => false,
229
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
230
            ]);
231
            ;
232
        }
233
    }
234
 
1485 eleazar 235
    public function addAction()
236
    {
237
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
238
        $currentCompany     = $currentUserPlugin->getCompany();
239
        $currentUser        = $currentUserPlugin->getUser();
240
 
241
        $request    = $this->getRequest();
242
 
1515 eleazar 243
        $vacancy_uuid = $this->params()->fromRoute('vacancy_uuid');
244
 
1485 eleazar 245
        if($request->isPost()) {
1513 eleazar 246
            $form = new  RecruitmentSelectionCandidateFormForm($this->adapter, $currentCompany->id);
1516 eleazar 247
            $dataPost = array_merge(
248
                $request->getPost()->toArray(),
249
                $request->getFiles()->toArray(),
250
                ['form_uuid' => $vacancy_uuid],
251
            );
1485 eleazar 252
 
253
            $form->setData($dataPost);
254
 
255
            if($form->isValid()) {
256
                $dataPost = (array) $form->getData();
257
 
1592 eleazar 258
                $files = $this->getRequest()->getFiles()->toArray();
259
 
1485 eleazar 260
                $hydrator = new ObjectPropertyHydrator();
261
                $candidate = new RecruitmentSelectionCandidate();
262
                $hydrator->hydrate($dataPost, $candidate);
263
 
264
                $candidate->company_id = $currentCompany->id;
1586 eleazar 265
                $candidate->file = null;
1520 eleazar 266
 
267
                $vacancyMapper = RecruitmentSelectionVacancyMapper::getInstance($this->adapter);
268
                $vacancy = $vacancyMapper->fetchOneByUuid($vacancy_uuid);
269
 
2680 eleazar 270
                $candidate->vacancy_id = $vacancy->id;
1494 eleazar 271
                $candidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
1518 eleazar 272
 
1534 eleazar 273
                if($candidateMapper->insert($candidate)) {
1593 eleazar 274
                     $candidate = $candidateMapper->fetchOne($candidate->id);
1485 eleazar 275
 
276
                    //leaderslinked.fullpath.recruitment_selection/uuid vacante/uuid candidato
277
 
1591 eleazar 278
                     $target_path = $this->config['leaderslinked.fullpath.recruitment_selection'] . $vacancy->uuid;
1582 eleazar 279
                     if(!file_exists($target_path)) {
280
                         mkdir($target_path, 0755, true);
281
                     }
282
                    $files = $this->getRequest()->getFiles()->toArray();
283
                     if(isset($files['file']) && empty($files['file']['error'])) {
284
                         $tmp_filename  = $files['file']['tmp_name'];
1592 eleazar 285
                         $original_filename  = trim(strtolower($files['file']['name']));
1582 eleazar 286
                        try {
1592 eleazar 287
                            $parts = explode('.', $original_filename);
288
                            $filename = 'document-' . uniqid() . '.' . $parts[ count($parts) - 1 ];
289
 
290
                            $full_filename = $target_path  . DIRECTORY_SEPARATOR .$filename;
291
                            if(move_uploaded_file($tmp_filename, $full_filename)) {
1582 eleazar 292
                                 $candidate->file = $filename;
293
                                 $candidateMapper->update($candidate);
294
                             }
295
                         } catch(\Throwable $e) {
296
                             error_log($e->getTraceAsString());
297
                         }
298
                     }
1518 eleazar 299
 
1588 eleazar 300
                    $this->logger->info('Se agrego el candidato ' . $candidate->first_name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
1485 eleazar 301
 
302
                    $data = [
303
                        'success'   => true,
304
                        'data'   => 'LABEL_RECORD_ADDED'
305
                    ];
306
                } else {
307
                    $data = [
308
                        'success'   => false,
1494 eleazar 309
                        'data'      => $candidateMapper->getError()
1485 eleazar 310
                    ];
311
 
312
                }
313
 
314
                return new JsonModel($data);
315
 
316
            } else {
317
                $messages = [];
318
                $form_messages = (array) $form->getMessages();
319
                foreach($form_messages  as $fieldname => $field_messages)
320
                {
321
 
322
                    $messages[$fieldname] = array_values($field_messages);
323
                }
324
 
325
            }
326
 
327
        } else {
328
            $data = [
329
                'success' => false,
330
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
331
            ];
332
 
333
            return new JsonModel($data);
334
        }
335
 
336
        return new JsonModel($data);
337
    }
1614 eleazar 338
 
339
    public function editAction() {
340
        $request = $this->getRequest();
341
        $currentUserPlugin = $this->plugin('currentUserPlugin');
342
        $currentCompany = $currentUserPlugin->getCompany();
343
        $currentUser = $currentUserPlugin->getUser();
344
 
345
        $request = $this->getRequest();
1623 eleazar 346
        $id = $this->params()->fromRoute('id');
1614 eleazar 347
 
1625 eleazar 348
        if (!$id) {
1614 eleazar 349
            $data = [
350
                'success' => false,
351
                'data' => 'ERROR_INVALID_PARAMETER'
352
            ];
353
 
354
            return new JsonModel($data);
355
        }
356
 
357
        $recruitmentSelectionCandidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
1625 eleazar 358
        $candidate = $recruitmentSelectionCandidateMapper->fetchOneByUuid($id);
359
 
360
        if (!$candidate) {
1614 eleazar 361
            $data = [
362
                'success' => false,
363
                'data' => 'ERROR_RECORD_NOT_FOUND'
364
            ];
365
 
366
            return new JsonModel($data);
367
        }
368
 
1625 eleazar 369
        if ($candidate->company_id != $currentCompany->id) {
1614 eleazar 370
            return new JsonModel([
371
                'success' => false,
372
                'data' => 'ERROR_UNAUTHORIZED'
373
            ]);
374
        }
375
 
376
        if ($request->isPost()) {
1626 eleazar 377
            $vacancy_uuid = $this->params()->fromRoute('vacancy_uuid');
1614 eleazar 378
            $form = new RecruitmentSelectionCandidateFormForm($this->adapter, $currentCompany->id);
379
            $dataPost = $request->getPost()->toArray();
3879 eleazar 380
            $dataPost['status'] = isset($dataPost['status']) ? $dataPost['status'] : RecruitmentSelectionCandidate::STATUS_REJECTED;
1626 eleazar 381
            $dataPost['form_uuid'] = $vacancy_uuid;
1614 eleazar 382
 
383
            $form->setData($dataPost);
384
 
385
            if ($form->isValid()) {
386
                $dataPost = (array) $form->getData();
387
 
388
                $hydrator = new ObjectPropertyHydrator();
389
                $hydrator->hydrate($dataPost, $candidate);
390
 
1625 eleazar 391
                if($recruitmentSelectionCandidateMapper->update($candidate)) {
392
                    $candidate = $recruitmentSelectionCandidateMapper->fetchOne($candidate->id);
1623 eleazar 393
 
394
                   //leaderslinked.fullpath.recruitment_selection/uuid vacante/uuid candidato
395
 
1627 eleazar 396
                    $target_path = $this->config['leaderslinked.fullpath.recruitment_selection'] . $vacancy_uuid;
1623 eleazar 397
                    if(!file_exists($target_path)) {
398
                        mkdir($target_path, 0755, true);
399
                    }
1625 eleazar 400
 
401
                    $files = $this->getRequest()->getFiles()->toArray();
402
 
1623 eleazar 403
                    if(isset($files['file']) && empty($files['file']['error'])) {
404
                        $tmp_filename  = $files['file']['tmp_name'];
405
                        $original_filename  = trim(strtolower($files['file']['name']));
1625 eleazar 406
 
407
                        try {
408
                            $parts = explode('.', $original_filename);
409
                            $filename = 'document-' . uniqid() . '.' . $parts[ count($parts) - 1 ];
410
 
411
                            $full_filename = $target_path  . DIRECTORY_SEPARATOR .$filename;
412
                            if(move_uploaded_file($tmp_filename, $full_filename)) {
1623 eleazar 413
                                $candidate->file = $filename;
1625 eleazar 414
                                $recruitmentSelectionCandidateMapper->update($candidate);
1623 eleazar 415
                            }
416
                        } catch(\Throwable $e) {
417
                            error_log($e->getTraceAsString());
418
                        }
419
                    }
420
 
421
                   $this->logger->info('Se agrego el candidato ' . $candidate->first_name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
422
 
423
                   $data = [
424
                       'success'   => true,
1628 eleazar 425
                       'data'   => 'LABEL_RECORD_UPDATED'
1623 eleazar 426
                   ];
427
               } else {
428
                   $data = [
429
                       'success'   => false,
1625 eleazar 430
                       'data'      => $recruitmentSelectionCandidateMapper->getError()
1623 eleazar 431
                   ];
432
 
433
               }
434
 
1614 eleazar 435
                return new JsonModel($data);
436
            } else {
437
                $messages = [];
438
                $form_messages = (array) $form->getMessages();
439
                foreach ($form_messages as $fieldname => $field_messages) {
440
                    $messages[$fieldname] = array_values($field_messages);
441
                }
442
 
443
                return new JsonModel([
444
                    'success' => false,
445
                    'data' => $messages
446
                ]);
447
            }
448
        } else if ($request->isGet()) {
449
            $hydrator = new ObjectPropertyHydrator();
450
 
451
            $data = [
452
                'success' => true,
453
                'data' => [
454
                    'id' => $candidate->uuid,
1660 eleazar 455
                    'user_id' => $candidate->user_id,
1614 eleazar 456
                    'first_name' => $candidate->first_name,
457
                    'last_name' => $candidate->last_name,
458
                    'email' => $candidate->email,
1658 eleazar 459
                    'evaluation' => $candidate->evaluation,
1655 eleazar 460
                    'coment' => $candidate->coment,
1614 eleazar 461
                    'status' => $candidate->status,
462
                ]
463
            ];
464
 
465
            return new JsonModel($data);
466
        } else {
467
            $data = [
468
                'success' => false,
1619 eleazar 469
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
1614 eleazar 470
            ];
471
 
472
            return new JsonModel($data);
473
        }
474
 
475
        return new JsonModel($data);
476
    }
477
 
478
    public function deleteAction() {
479
        $request = $this->getRequest();
480
        $currentUserPlugin = $this->plugin('currentUserPlugin');
481
        $currentCompany = $currentUserPlugin->getCompany();
482
        $currentUser = $currentUserPlugin->getUser();
483
 
484
        $request = $this->getRequest();
485
        $uuid = $this->params()->fromRoute('id');
486
 
487
        if (!$uuid) {
488
            $data = [
489
                'success' => false,
490
                'data' => 'ERROR_INVALID_PARAMETER'
491
            ];
492
 
493
            return new JsonModel($data);
494
        }
495
 
496
        $recruitmentSelectionCandidateMapper = RecruitmentSelectionCandidateMapper::getInstance($this->adapter);
497
        $candidateMapper = $recruitmentSelectionCandidateMapper->fetchOneByUuid($uuid);
498
        if (!$candidateMapper) {
499
            $data = [
500
                'success' => false,
501
                'data' => 'ERROR_RECORD_NOT_FOUND'
502
            ];
503
 
504
            return new JsonModel($data);
505
        }
506
 
507
        if ($candidateMapper->company_id != $currentCompany->id) {
508
            return new JsonModel([
509
                'success' => false,
510
                'data' => 'ERROR_UNAUTHORIZED'
511
            ]);
512
        }
513
 
514
        if ($request->isPost()) {
515
 
516
 
517
            $result = $recruitmentSelectionCandidateMapper->delete($candidateMapper->id);
518
            if ($result) {
1615 eleazar 519
                $this->logger->info('Se borro el candidato ' . $candidateMapper->first_name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
1614 eleazar 520
 
521
                $data = [
522
                    'success' => true,
523
                    'data' => 'LABEL_RECORD_DELETED'
524
                ];
525
            } else {
526
 
527
                $data = [
528
                    'success' => false,
529
                    'data' => $recruitmentSelectionCandidateMapper->getError()
530
                ];
531
 
532
                return new JsonModel($data);
533
            }
534
        } else {
535
            $data = [
536
                'success' => false,
537
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
538
            ];
539
 
540
            return new JsonModel($data);
541
        }
542
 
543
        return new JsonModel($data);
544
    }
545
 
1632 eleazar 546
    public function emailAction() {
1630 eleazar 547
        $request = $this->getRequest();
548
        $currentUserPlugin = $this->plugin('currentUserPlugin');
549
        $currentCompany = $currentUserPlugin->getCompany();
550
        $currentUser = $currentUserPlugin->getUser();
1640 eleazar 551
 
552
        $email = $request->getQuery('email');
1643 eleazar 553
 
554
        if(!$email){
555
            $data = [
556
                'success' => false,
557
                'data' => 'ERROR_INVALID_PARAMETER'
558
            ];
559
 
560
            return new JsonModel($data);
561
        }
562
 
563
        $userMapper = UserMapper::getInstance($this->adapter);
564
        $user = $userMapper->fetchOneByEmail($email);
565
 
566
        if (!$user) {
567
            return new JsonModel([
568
                'success' => false,
569
                'data' => 'ERROR_USER_NOT_FOUND',
570
            ]);
1644 eleazar 571
        } else if($request->isGet()){
572
            $data = [
573
                'success' => true,
574
                'data' => [
1663 eleazar 575
                    'user_id' => $user->id,
1644 eleazar 576
                    'first_name' => $user->first_name,
577
                    'last_name' => $user->last_name,
578
 
579
                ]
580
            ];
581
            return new JsonModel($data);
582
 
583
        }else {
584
            $data = [
1643 eleazar 585
                'success' => false,
1644 eleazar 586
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
587
            ];
588
 
589
            return new JsonModel($data);
1643 eleazar 590
        }
1630 eleazar 591
    }
1468 eleazar 592
}