Proyectos de Subversion LeadersLinked - Backend

Rev

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