Proyectos de Subversion LeadersLinked - Backend

Rev

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

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