Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 16948 | Rev 16989 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
15338 efrain 1
<?php
2
 
3
declare(strict_types=1);
4
 
5
namespace LeadersLinked\Controller;
6
 
7
use Laminas\Db\Adapter\AdapterInterface;
16768 efrain 8
 
15338 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\Mapper\NetworkMapper;
15
use LeadersLinked\Model\Network;
15459 efrain 16
 
15338 efrain 17
use LeadersLinked\Model\User;
18
use LeadersLinked\Model\UserType;
15348 efrain 19
use LeadersLinked\Mapper\PageMapper;
15338 efrain 20
use LeadersLinked\Mapper\UserMapper;
21
use LeadersLinked\Mapper\UserPasswordMapper;
22
use LeadersLinked\Model\UserPassword;
23
use LeadersLinked\Mapper\CompanySizeMapper;
24
use LeadersLinked\Mapper\IndustryMapper;
25
use LeadersLinked\Model\Company;
26
use LeadersLinked\Mapper\CompanyMapper;
27
use LeadersLinked\Model\CompanyUser;
28
use LeadersLinked\Mapper\CompanyUserMapper;
15459 efrain 29
use LeadersLinked\Form\Network\NetworkCreateForm;
30
use LeadersLinked\Form\Network\NetworkEditForm;
15338 efrain 31
use LeadersLinked\Mapper\EmailTemplateMapper;
15348 efrain 32
use LeadersLinked\Model\Page;
15441 efrain 33
use LeadersLinked\Mapper\ThemeMapper;
15459 efrain 34
use LeadersLinked\Model\EmailTemplate;
15338 efrain 35
 
36
class PrivateNetworksController extends AbstractActionController {
37
 
38
    /**
39
     *
16769 efrain 40
     * @var \Laminas\Db\Adapter\AdapterInterface
15338 efrain 41
     */
42
    private $adapter;
16768 efrain 43
 
15338 efrain 44
    /**
45
     *
16769 efrain 46
     * @var \LeadersLinked\Cache\CacheInterface
15338 efrain 47
     */
16769 efrain 48
    private $cache;
49
 
50
 
51
    /**
52
     *
53
     * @var \Laminas\Log\LoggerInterface
54
     */
15338 efrain 55
    private $logger;
16768 efrain 56
 
15338 efrain 57
    /**
58
     *
59
     * @var array
60
     */
61
    private $config;
16768 efrain 62
 
16769 efrain 63
 
15338 efrain 64
    /**
65
     *
16769 efrain 66
     * @var \Laminas\Mvc\I18n\Translator
67
     */
68
    private $translator;
69
 
70
 
71
    /**
72
     *
73
     * @param \Laminas\Db\Adapter\AdapterInterface $adapter
74
     * @param \LeadersLinked\Cache\CacheInterface $cache
75
     * @param \Laminas\Log\LoggerInterface LoggerInterface $logger
15338 efrain 76
     * @param array $config
16769 efrain 77
     * @param \Laminas\Mvc\I18n\Translator $translator
15338 efrain 78
     */
16769 efrain 79
    public function __construct($adapter, $cache, $logger, $config, $translator)
16768 efrain 80
    {
16769 efrain 81
        $this->adapter      = $adapter;
82
        $this->cache        = $cache;
83
        $this->logger       = $logger;
84
        $this->config       = $config;
85
        $this->translator   = $translator;
15338 efrain 86
    }
87
 
88
    public function indexAction()
89
    {
90
        $currentUserPlugin = $this->plugin('currentUserPlugin');
91
        $currentUser = $currentUserPlugin->getUser();
92
 
93
        $request = $this->getRequest();
94
 
95
        $request = $this->getRequest();
96
        if($request->isGet()) {
97
 
98
 
99
            $headers  = $request->getHeaders();
100
 
101
            $isJson = false;
102
            if($headers->has('Accept')) {
103
                $accept = $headers->get('Accept');
104
 
105
                $prioritized = $accept->getPrioritized();
106
 
107
                foreach($prioritized as $key => $value) {
108
                    $raw = trim($value->getRaw());
109
 
110
                    if(!$isJson) {
111
                        $isJson = strpos($raw, 'json');
112
                    }
113
 
114
                }
115
            }
116
 
117
 
118
            if($isJson) {
119
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
120
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'settings/private-networks/edit');
121
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'settings/private-networks/delete');
122
 
123
 
124
                $search = $this->params()->fromQuery('search');
16766 efrain 125
                $search = empty($search['value']) ? '' :  Functions::sanitizeFilterString($search['value']);
15338 efrain 126
 
127
                $page               = intval($this->params()->fromQuery('start', 1), 10);
128
                $records_x_page     = intval($this->params()->fromQuery('length', 10), 10);
129
                $order =  $this->params()->fromQuery('order', []);
130
                $order_field        = empty($order[0]['column']) ? 99 :  intval($order[0]['column'], 10);
16766 efrain 131
                $order_direction    = empty($order[0]['dir']) ? 'ASC' : strtoupper(Functions::sanitizeFilterString($order[0]['dir']));
15338 efrain 132
 
133
                $fields =  ['name','main_hostname', 'admin_hostname'];
134
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'name';
135
 
136
                if(!in_array($order_direction, ['ASC', 'DESC'])) {
137
                    $order_direction = 'ASC';
138
                }
139
 
140
                $networkMapper = NetworkMapper::getInstance($this->adapter);
141
                $paginator = $networkMapper->fetchAllDataTable($search, $page, $records_x_page, $order_field, $order_direction);
142
 
143
                $items = [];
144
                $records = $paginator->getCurrentItems();
145
                foreach($records as $record)
146
                {
147
                    $item = [
148
                        'name' => $record->name,
149
                        'main_hostname' => $record->main_hostname,
150
                        'admin_hostname' => $record->admin_hostname,
151
                        'status' => $record->status,
152
                        'actions' => [
153
                            'link_edit' => $allowEdit ?  $this->url()->fromRoute('settings/private-networks/edit', ['id' => $record->uuid ]) : '',
154
                            'link_delete' => $allowDelete && $record->default == Network::DEFAULT_NO ? $this->url()->fromRoute('settings/private-networks/delete', ['id' => $record->uuid ]) : '',
155
                        ],
156
 
157
                    ];
158
 
159
                    array_push($items, $item);
160
                }
161
 
162
                return new JsonModel([
163
                    'success' => true,
164
                    'data' => [
165
                        'items' => $items,
166
                        'total' => $paginator->getTotalItemCount(),
167
                    ]
168
                ]);
169
            } else  {
170
                $formAdd = new NetworkCreateForm($this->adapter);
15441 efrain 171
                $formEdit = new NetworkEditForm($this->adapter);
15338 efrain 172
 
173
                $this->layout()->setTemplate('layout/layout-backend');
174
                $viewModel = new ViewModel();
175
                $viewModel->setTemplate('leaders-linked/private-networks/index.phtml');
176
                $viewModel->setVariables([
177
                    'formAdd' =>  $formAdd,
178
                    'formEdit' => $formEdit
179
 
180
                ]);
181
                return $viewModel ;
182
            }
183
 
184
        } else {
185
            return new JsonModel([
186
                'success' => false,
187
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
188
            ]);;
189
        }
190
    }
191
 
192
 
193
    public function addAction() {
194
        $currentUserPlugin = $this->plugin('currentUserPlugin');
195
        $currentUser = $currentUserPlugin->getUser();
196
 
197
 
198
        $request = $this->getRequest();
199
 
200
 
201
        if ($request->isPost()) {
202
 
203
 
204
 
205
            $form = new NetworkCreateForm($this->adapter);
206
            $dataPost = $request->getPost()->toArray();
207
 
208
 
209
 
210
            $form->setData($dataPost);
211
            if ($form->isValid()) {
212
 
213
                $dataPost = (array) $form->getData();
214
 
215
                $networkMapper = NetworkMapper::getInstance($this->adapter);
216
                $networkDefault = $networkMapper->fetchOneByDefault();
217
 
15441 efrain 218
                $themeMapper = ThemeMapper::getInstance($this->adapter);
219
                $theme = $themeMapper->fetchOneByUuid($dataPost['theme_id']);
15338 efrain 220
 
15454 efrain 221
 
15338 efrain 222
 
223
 
224
                $network = new Network();
225
                $network->status = Network::STATUS_ACTIVE;
226
                $network->default = Network::DEFAULT_NO;
227
                $network->name = $dataPost['company'];
228
                $network->admin_hostname = $dataPost['admin_hostname'];
15452 efrain 229
                $network->alternative_hostname = $dataPost['alternative_hostname'];
15338 efrain 230
                $network->main_hostname = $dataPost['main_hostname'];
16948 efrain 231
                $network->service_hostname = $dataPost['service_hostname'];
15831 efrain 232
                $network->moodle_name = $dataPost['moodle_name'];
233
                $network->moodle_url = $dataPost['moodle_url'];
234
                $network->microlearning_appstore = $dataPost['microlearning_appstore'];
235
                $network->microlearning_playstore = $dataPost['microlearning_playstore'];
15454 efrain 236
                $network->theme_id = $theme->id;
15338 efrain 237
 
15454 efrain 238
 
239
 
15459 efrain 240
 
241
 
242
 
15338 efrain 243
                foreach($networkDefault as $key => $value)
244
                {
245
                    if(strpos($key, 'css') !== false) {
246
 
247
                        $network->{$key} = $networkDefault->{$key};
248
 
249
                    }
250
                }
251
 
252
 
253
                if(!$networkMapper->insert($network)) {
254
 
255
                    $response = [
256
                        'success' => false,
257
                        'data' => $networkMapper->getError()
258
                    ];
259
 
260
                    return new JsonModel($response);
261
 
262
                }
263
 
264
                $this->logger->info('Se agrego la red privada : ' . $network->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
265
 
266
                $timestamp = time();
267
                $activation_key = sha1($dataPost['email'] . uniqid() . $timestamp);
268
 
269
                $password_hash = password_hash($dataPost['password'], PASSWORD_DEFAULT);
270
 
271
 
272
                $user = new User();
273
                $user->blocked = User::BLOCKED_NO;
274
                $user->email = $dataPost['email'];
275
                $user->email_verified = User::EMAIL_VERIFIED_YES;
276
                $user->first_name = $dataPost['first_name'];
277
                $user->last_name = $dataPost['last_name'];
278
                $user->usertype_id          = UserType::ADMIN;
279
                $user->password             = $password_hash;
280
                $user->password_updated_on  = date('Y-m-d H:i:s');
281
                $user->activation_key       = $activation_key;
282
                $user->status               = User::STATUS_ACTIVE;
283
                $user->login_attempt        = 0;
284
                $user->network_id           = $network->id;
285
 
286
                $userMapper = UserMapper::getInstance($this->adapter);
287
                if(!$userMapper->insert($user)) {
288
                    $response = [
289
                        'success' => false,
290
                        'data' => $networkMapper->getError()
291
                    ];
292
 
293
                    return new JsonModel($response);
294
 
295
                }
296
 
297
                $userPassword = new UserPassword();
298
                $userPassword->user_id = $user->id;
299
                $userPassword->password = $password_hash;
300
 
301
                $userPasswordMapper = UserPasswordMapper::getInstance($this->adapter);
302
                $userPasswordMapper->insert($userPassword);
303
 
304
                $this->logger->info('Se agrego el usuario administrador : ' . $user->first_name . ' ' . $user->last_name . ' de la red privada : ' . $network->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
305
 
306
                $companySizeMapper = CompanySizeMapper::getInstance($this->adapter);
307
                $companySize = $companySizeMapper->fetchOneByUuid($dataPost['company_size_id']);
308
 
309
                $industryMapper = IndustryMapper::getInstance($this->adapter);
310
                $industry = $industryMapper->fetchOneByUuid($dataPost['industry_id']);
311
 
312
                $company = new Company();
313
                $company->name = $network->name;
314
                $company->default_for_network = Company::DEFAULT_FOR_NETWORK_YES;
315
                $company->network_id = $network->id;
316
                $company->company_size_id =  $companySize->id;
317
                $company->industry_id = $industry->id;
318
                $company->foundation_year = date('Y');
319
                $company->status = Company::STATUS_ACTIVE;
320
                $company->description = '';
321
 
322
 
323
                $companyMapper = CompanyMapper::getInstance($this->adapter);
324
                $result = $companyMapper->insert($company);
325
 
326
                if($result) {
327
 
328
 
329
 
330
                    /** Creación del fake user propietario de la empresa */
331
                    $owner = new User();
15344 efrain 332
                    $owner->network_id = $network->id;
15338 efrain 333
                    $owner->email = 'fake-email'.$company->id;
334
                    $owner->first_name = substr($company->name, 0, 64);
335
                    $owner->last_name = substr($company->name, 64);
336
                    $owner->status = User::STATUS_INACTIVE;
337
                    $owner->blocked = User::BLOCKED_YES;
338
                    $owner->login_attempt = 0;
339
                    $owner->email_verified = User::EMAIL_VERIFIED_YES;
340
                    $owner->show_in_search = User::SHOW_IN_SEARCH_NO;
341
                    $owner->password = 'NO-PASSWORD';
16981 efrain 342
                    $owner->network_id = $network->id;
15338 efrain 343
                    $owner->usertype_id = UserType::COMPANY;
344
 
345
                    $userMapper = UserMapper::getInstance($this->adapter);
346
                    $userMapper->insert($owner);
347
 
348
                    $companyUser = new CompanyUser();
349
                    $companyUser->company_id = $company->id;
350
                    $companyUser->user_id = $owner->id;
351
                    $companyUser->owner = CompanyUser::OWNER_YES;
352
                    $companyUser->creator = CompanyUser::CREATOR_NO;
353
                    $companyUser->status = CompanyUser::STATUS_ACCEPTED;
354
 
355
                    $companyUserMapper = CompanyUserMapper::getInstance($this->adapter);
356
                    $companyUserMapper->insert($companyUser);
357
 
358
                    /** agregamos el usuario que lo crea como full administrador */
359
                    $companyUser = new CompanyUser();
360
                    $companyUser->company_id = $company->id;
361
                    $companyUser->user_id = $user->id;
362
                    $companyUser->owner = CompanyUser::OWNER_NO;
363
                    $companyUser->creator = CompanyUser::CREATOR_YES;
364
                    $companyUser->status = CompanyUser::STATUS_ACCEPTED;
365
                    $companyUser->backend = CompanyUser::BACKEND_YES;
366
                    $companyUserMapper->insert($companyUser);
367
 
368
 
369
                    $emailTemplateMapper = EmailTemplateMapper::getInstance($this->adapter);
370
                    $records = $emailTemplateMapper->fetchAllDefault();
371
 
372
                    foreach($records as $record)
373
                    {
374
                        $emailTemplate = new EmailTemplate();
15345 efrain 375
                        $emailTemplate->network_id = $network->id;
15338 efrain 376
                        $emailTemplate->email_template_default_id = $record->id;
377
                        $emailTemplate->code = $record->code;
378
                        $emailTemplate->subject = $record->subject;
379
                        $emailTemplate->content = $record->content;
380
                        $emailTemplate->status = $record->status;
381
 
15344 efrain 382
                        $emailTemplateMapper->insert($emailTemplate);
15338 efrain 383
 
384
                    }
15348 efrain 385
 
386
                    $pageMapper = PageMapper::getInstance($this->adapter);
387
                    $records = $pageMapper->fetchAllDefault();
388
 
389
                    foreach($records as $record)
390
                    {
391
                        $page = new Page();
392
                        $page->network_id = $network->id;
393
                        $page->code = $record->code;
394
                        $page->content = $record->content;
395
                        $page->fixed = $record->fixed;
396
                        $page->page_default_id = $record->id;
397
                        $page->title = $record->title;
398
                        $page->status = $record->status;
399
                        $page->type = $record->type;
400
                        $page->url = $record->url;
401
 
402
                        $pageMapper->insert($page);
403
 
404
                    }
15338 efrain 405
 
406
 
407
                    $this->logger->info('Se agrego la empresa por defecto : ' . $company->name . ' de la red : ' . $network->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
408
 
409
                    $data = [
410
                        'success'   => true,
411
                        'data'   => 'LABEL_RECORD_ADDED'
412
                    ];
413
                } else {
414
                    $data = [
415
                        'success'   => false,
416
                        'data'      => $companyMapper->getError()
417
                    ];
418
 
419
                }
420
 
421
                return new JsonModel($data);
422
 
423
 
424
            } else {
425
                $messages = [];
426
                $form_messages = (array) $form->getMessages();
427
                foreach ($form_messages as $fieldname => $field_messages) {
428
 
429
                    $messages[$fieldname] = array_values($field_messages);
430
                }
431
 
432
                return new JsonModel([
433
                    'success' => false,
434
                    'data' => $messages
435
                ]);
436
            }
437
        } else {
438
            $data = [
439
                'success' => false,
440
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
441
            ];
442
 
443
            return new JsonModel($data);
444
        }
445
 
446
        return new JsonModel($data);
447
    }
448
 
449
 
450
    public function editAction()
451
    {
452
        $currentUserPlugin = $this->plugin('currentUserPlugin');
453
        $currentUser = $currentUserPlugin->getUser();
454
 
455
        $request = $this->getRequest();
456
        $id = $this->params()->fromRoute('id');
457
 
458
 
459
        if (!$id) {
460
            $data = [
461
                'success' => false,
462
                'data' => 'ERROR_INVALID_PARAMETER'
463
            ];
464
 
465
            return new JsonModel($data);
466
        }
467
 
468
        $networkMapper = NetworkMapper::getInstance($this->adapter);
469
        $network = $networkMapper->fetchOneByUuid($id);
470
        if (!$network) {
471
            $data = [
472
                'success' => false,
473
                'data' => 'ERROR_RECORD_NOT_FOUND'
474
            ];
475
 
476
            return new JsonModel($data);
477
        }
478
 
479
 
480
        if ($request->isPost()) {
15441 efrain 481
            $form = new NetworkEditForm($this->adapter);
15338 efrain 482
            $dataPost = $request->getPost()->toArray();
483
 
484
            $form->setData($dataPost);
485
 
486
            if ($form->isValid()) {
487
                $dataPost = (array) $form->getData();
488
 
489
 
490
                if(empty($dataPost['status'])) {
491
                    $network->status = Network::STATUS_INACTIVE;
492
                }
15441 efrain 493
 
494
                $themeMapper = ThemeMapper::getInstance($this->adapter);
495
                $theme = $themeMapper->fetchOneByUuid($dataPost['theme_id']);
496
 
497
 
15338 efrain 498
                $network->name = $dataPost['name'];
499
                $network->main_hostname = $dataPost['main_hostname'];
15452 efrain 500
                $network->alternative_hostname = $dataPost['alternative_hostname'];
15338 efrain 501
                $network->admin_hostname = $dataPost['admin_hostname'];
16948 efrain 502
                $network->service_hostname = $dataPost['service_hostname'];
15441 efrain 503
                $network->theme_id = $theme->id;
15831 efrain 504
                $network->moodle_name = $dataPost['moodle_name'];
15459 efrain 505
                $network->moodle_url = $dataPost['moodle_url'];
15831 efrain 506
                $network->microlearning_appstore = $dataPost['microlearning_appstore'];
507
                $network->microlearning_playstore = $dataPost['microlearning_playstore'];
15459 efrain 508
                $network->relationship_user_mode = $dataPost['relationship_user_mode'];
15338 efrain 509
 
510
                $result = $networkMapper->update($network);
511
                if ($result) {
512
                    $this->logger->info('Se actualizo la red privada : ' . $network->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
513
 
514
                    $data = [
515
                        'success' => true,
516
                        'data' => 'LABEL_RECORD_UPDATED'
517
                    ];
518
                } else {
519
                    $data = [
520
                        'success' => false,
521
                        'data' => $networkMapper->getError()
522
                    ];
523
                }
524
 
525
                return new JsonModel($data);
526
            } else {
527
                $messages = [];
528
                $form_messages = (array) $form->getMessages();
529
                foreach ($form_messages as $fieldname => $field_messages) {
530
                    $messages[$fieldname] = array_values($field_messages);
531
                }
532
 
533
                return new JsonModel([
534
                    'success' => false,
535
                    'data' => $messages
536
                ]);
537
            }
538
        } else if ($request->isGet()) {
539
 
15441 efrain 540
            $themeMapper = ThemeMapper::getInstance($this->adapter);
541
            $theme = $themeMapper->fetchOne($network->theme_id);
542
 
15338 efrain 543
 
544
            $data = [
545
                'success' => true,
546
                'data' => [
547
                    'name' => $network->name,
548
                    'status' => $network->status,
549
                    'main_hostname' => $network->main_hostname,
550
                    'admin_hostname' => $network->admin_hostname,
15452 efrain 551
                    'alternative_hostname' => $network->alternative_hostname,
16948 efrain 552
                    'service_hostname' => $network->service_hostname,
15441 efrain 553
                    'status' => $network->status,
15459 efrain 554
                    'theme_id' => $theme->uuid,
15831 efrain 555
                    'moodle_name' => $network->moodle_name,
15459 efrain 556
                    'moodle_url' => $network->moodle_url,
15831 efrain 557
                    'microlearning_appstore' => $network->microlearning_appstore,
558
                    'microlearning_playstore' => $network->microlearning_playstore,
15459 efrain 559
                    'relationship_user_mode' => $network->relationship_user_mode,
560
 
15338 efrain 561
                ]
562
            ];
563
 
564
            return new JsonModel($data);
565
        } else {
566
            $data = [
567
                'success' => false,
568
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
569
            ];
570
 
571
            return new JsonModel($data);
572
        }
573
 
574
        return new JsonModel($data);
575
    }
576
 
577
    public function deleteAction()
578
    {
579
        $currentUserPlugin = $this->plugin('currentUserPlugin');
580
        $currentUser = $currentUserPlugin->getUser();
581
 
582
 
583
        $request = $this->getRequest();
584
        if ($request->isPost()) {
585
 
586
            $id = $this->params()->fromRoute('id');
587
            if (!$id) {
588
                $response = [
589
                    'success' => false,
590
                    'data' => 'ERROR_INVALID_PARAMETER'
591
                ];
592
 
593
                return new JsonModel($response);
594
            }
595
 
596
 
597
            $networkMapper = NetworkMapper::getInstance($this->adapter);
598
            $network = $networkMapper->fetchOneByUuid($id);
599
            if (!$network) {
600
                $response = [
601
                    'success' => false,
602
                    'data' => 'ERROR_RECORD_NOT_FOUND'
603
                ];
604
 
605
                return new JsonModel($response);
606
            }
607
 
608
            if($network->default == Network::DEFAULT_YES) {
609
                $response = [
610
                    'success' => false,
611
                    'data' =>  'ERROR_PRIVATE_NETWORK_CANNOT_DELETED'
612
                ];
613
 
614
                return new JsonModel($response);
615
 
616
            }
617
 
618
 
619
 
620
            $result = $networkMapper->delete($network->id);
621
            if ($result) {
622
                $this->logger->info('Se borro la red privada : ' . $network->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
623
 
624
                $response = [
625
                    'success' => true,
626
                    'data' => 'LABEL_RECORD_DELETED'
627
                ];
628
            } else {
629
 
630
                $response = [
631
                    'success' => false,
632
                    'data' => $networkMapper->getError()
633
                ];
634
 
635
            }
636
        } else {
637
            $response = [
638
                'success' => false,
639
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
640
            ];
641
 
642
        }
643
 
644
        return new JsonModel($response);
645
    }
646
 
647
 
648
 
649
}