Proyectos de Subversion LeadersLinked - Backend

Rev

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