Proyectos de Subversion LeadersLinked - Backend

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
9350 eleazar 1
<?php
2
 
3
declare(strict_types=1);
4
 
5
namespace LeadersLinked\Controller;
6
 
7
use Laminas\Db\Adapter\AdapterInterface;
8
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
9
use Laminas\Mvc\Controller\AbstractActionController;
10
use Laminas\Log\LoggerInterface;
11
use Laminas\View\Model\ViewModel;
12
use Laminas\View\Model\JsonModel;
13
use LeadersLinked\Library\Functions;
14
use LeadersLinked\Mapper\MyTrainerCategoriesMapper;
10117 eleazar 15
use LeadersLinked\Mapper\TopicMapper;
9356 eleazar 16
use LeadersLinked\Mapper\MyTrainerQuestionsMapper;
9350 eleazar 17
use LeadersLinked\Form\MyTrainerQuestionForm;
9369 eleazar 18
use LeadersLinked\Model\MyTrainerQuestions;
9350 eleazar 19
use LeadersLinked\Mapper\CompanyMapper;
20
use LeadersLinked\Model\Company;
21
use LeadersLinked\Hydrator\ObjectPropertyHydrator;
22
 
23
class MyTrainerQuestionController extends AbstractActionController {
24
 
25
    /**
26
     *
27
     * @var AdapterInterface
28
     */
29
    private $adapter;
30
 
31
    /**
32
     *
33
     * @var AbstractAdapter
34
     */
35
    private $cache;
36
 
37
    /**
38
     *
39
     * @var  LoggerInterface
40
     */
41
    private $logger;
42
 
43
    /**
44
     *
45
     * @var array
46
     */
47
    private $config;
48
 
49
    /**
50
     *
51
     * @param AdapterInterface $adapter
52
     * @param AbstractAdapter $cache
53
     * @param LoggerInterface $logger
54
     * @param array $config
55
     */
56
    public function __construct($adapter, $cache, $logger, $config) {
57
        $this->adapter = $adapter;
58
        $this->cache = $cache;
59
        $this->logger = $logger;
60
        $this->config = $config;
61
    }
62
 
63
    public function indexAction() {
64
        $request = $this->getRequest();
65
        $currentUserPlugin = $this->plugin('currentUserPlugin');
66
        $currentCompany = $currentUserPlugin->getCompany();
67
        $currentUser = $currentUserPlugin->getUser();
68
 
69
        try{
70
        $request = $this->getRequest();
71
        if ($request->isGet()) {
72
 
73
            $headers = $request->getHeaders();
74
 
75
            $isJson = false;
76
            if ($headers->has('Accept')) {
77
                $accept = $headers->get('Accept');
78
 
79
                $prioritized = $accept->getPrioritized();
80
 
81
                foreach ($prioritized as $key => $value) {
82
                    $raw = trim($value->getRaw());
83
 
84
                    if (!$isJson) {
85
                        $isJson = strpos($raw, 'json');
86
                    }
87
                }
88
            }
89
 
90
            if ($isJson) {
91
                $search = $this->params()->fromQuery('search', []);
92
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);
93
 
94
                $page = intval($this->params()->fromQuery('start', 1), 10);
95
                $records_x_page = intval($this->params()->fromQuery('length', 10), 10);
96
                $order = $this->params()->fromQuery('order', []);
97
                $order_field = empty($order[0]['column']) ? 99 : intval($order[0]['column'], 10);
98
                $order_direction = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var($order[0]['dir'], FILTER_SANITIZE_STRING));
99
 
100
                $fields = ['title'];
101
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'title';
102
 
103
                if (!in_array($order_direction, ['ASC', 'DESC'])) {
104
                    $order_direction = 'ASC';
105
                }
106
 
107
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
108
                $allowAdd = $acl->isAllowed($currentUser->usertype_id, 'my-trainer/question/add');
109
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'my-trainer/question/edit');
110
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'my-trainer/question/delete');
111
 
9356 eleazar 112
                $questionsMapper = MyTrainerQuestionsMapper::getInstance($this->adapter);
9350 eleazar 113
                $paginator = $questionsMapper->fetchAllDataTableByCompanyId($currentCompany->id, $search, $page, $records_x_page, $order_field, $order_direction);
114
 
115
                $items = [];
116
                $records = $paginator->getCurrentItems();
117
 
118
                foreach ($records as $record) {
10774 eleazar 119
                    $topicMapper = TopicMapper::getInstance($this->adapter);
10773 eleazar 120
                    $topic = $topicMapper->fetchOne($record->category_id);
9350 eleazar 121
                    $item = [
10557 eleazar 122
                        'id' => $record->uuid,
9350 eleazar 123
                        'title' => $record->title,
10773 eleazar 124
                        'category' => $topic->title,
9350 eleazar 125
                        'text' => $record->text,
126
                        'actions' => [
127
                            'link_edit' => $this->url()->fromRoute('my-trainer/question/edit', ['id' => $record->uuid]),
10759 eleazar 128
                            'link_delete' => $this->url()->fromRoute('my-trainer/question/delete', ['id' => $record->uuid]),
10818 eleazar 129
                            'link_answer' => $this->url()->fromRoute('my-trainer/answer', ['myt_id' => $record->uuid])
9350 eleazar 130
                        ]
131
                    ];
132
 
133
                    array_push($items, $item);
134
                }
135
 
136
                return new JsonModel([
137
                    'success' => true,
138
                    'data' => [
139
                        'items' => $items,
140
                        'total' => $paginator->getTotalItemCount(),
141
                    ]
142
                ]);
143
            } else {
144
 
10189 eleazar 145
                $form = new MyTrainerQuestionForm($this->adapter);
9350 eleazar 146
 
147
                $this->layout()->setTemplate('layout/layout-backend');
148
                $viewModel = new ViewModel();
149
                $viewModel->setTemplate('leaders-linked/my-trainer-question/index.phtml');
150
                $viewModel->setVariable('form', $form);
151
                return $viewModel;
152
            }
153
        } else {
154
            return new JsonModel([
155
                'success' => false,
156
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
157
            ]);
158
        }
159
    } catch (\Throwable $e) {
160
            $e->getMessage();
161
            return new JsonModel([
162
                'success' => false,
163
                'data' => $e
164
            ]);
165
        }
166
    }
167
 
168
    public function addAction() {
169
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
170
        $currentCompany     = $currentUserPlugin->getCompany();
171
        $currentUser        = $currentUserPlugin->getUser();
172
 
10180 eleazar 173
        $request    = $this->getRequest();
10238 eleazar 174
        try{
9350 eleazar 175
        if($request->isPost()) {
10189 eleazar 176
            $form = new  MyTrainerQuestionForm($this->adapter);
9365 eleazar 177
            $dataPost = $request->getPost()->toArray();
9373 eleazar 178
            $form->setData($dataPost);
10212 eleazar 179
 
9350 eleazar 180
            if($form->isValid()) {
10198 eleazar 181
 
10196 eleazar 182
                $dataPost = (array) $form->getData();
9385 eleazar 183
                $hydrator = new ObjectPropertyHydrator();
9384 eleazar 184
                $questions = new MyTrainerQuestions();
9383 eleazar 185
                $hydrator->hydrate($dataPost, $questions);
186
 
9382 eleazar 187
                $questions->first_name = $currentUser->first_name;
9381 eleazar 188
                $questions->last_name = $currentUser->last_name;
189
                $questions->company_id = $currentCompany->id;
9377 eleazar 190
 
10117 eleazar 191
                $categoriesMapper = TopicMapper::getInstance($this->adapter);
9363 eleazar 192
                $category = $categoriesMapper->fetchOneByUuid($dataPost['category_id']);
10249 eleazar 193
                $questions->category_id = $category->id;
9363 eleazar 194
 
9356 eleazar 195
                $questionsMapper = MyTrainerQuestionsMapper::getInstance($this->adapter);
9350 eleazar 196
 
197
                if($questionsMapper->insert($questions)) {
198
                     $questions = $questionsMapper->fetchOne($questions->id);
199
 
200
                    $this->logger->info('Se agrego la pregunta ' . $questions->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
201
 
202
                    $data = [
203
                        'success'   => true,
204
                        'data'   => 'LABEL_RECORD_ADDED'
205
                    ];
206
                } else {
207
                    $data = [
208
                        'success'   => false,
209
                        'data'      => $questionsMapper->getError()
210
                    ];
211
 
212
                }
213
 
214
                return new JsonModel($data);
215
 
216
            } else {
217
                $messages = [];
218
                $form_messages = (array) $form->getMessages();
219
                foreach($form_messages  as $fieldname => $field_messages)
220
                {
221
 
222
                    $messages[$fieldname] = array_values($field_messages);
223
                }
224
 
225
            }
226
 
227
        } else {
228
            $data = [
229
                'success' => false,
230
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
231
            ];
232
 
233
            return new JsonModel($data);
234
        }
235
 
236
        return new JsonModel($data);
10238 eleazar 237
    } catch (\Throwable $e) {
10247 eleazar 238
        return $e;
9350 eleazar 239
    }
10238 eleazar 240
    }
9350 eleazar 241
 
242
    public function editAction() {
243
        $request = $this->getRequest();
244
        $currentUserPlugin = $this->plugin('currentUserPlugin');
245
        $currentCompany = $currentUserPlugin->getCompany();
246
        $currentUser = $currentUserPlugin->getUser();
247
 
248
        $request = $this->getRequest();
249
        $uuid = $this->params()->fromRoute('id');
250
        try{
251
        if (!$uuid) {
252
            $data = [
253
                'success' => false,
254
                'data' => 'ERROR_INVALID_PARAMETER'
255
            ];
256
 
257
            return new JsonModel($data);
258
        }
259
 
9356 eleazar 260
        $questionsMapper = MyTrainerQuestionsMapper::getInstance($this->adapter);
9350 eleazar 261
        $questions = $questionsMapper->fetchOneByUuid($uuid);
262
 
263
        if (!$questions) {
264
            $data = [
265
                'success' => false,
266
                'data' => 'ERROR_RECORD_NOT_FOUND'
267
            ];
268
 
269
            return new JsonModel($data);
270
        }
271
 
272
        if ($questions->company_id != $currentCompany->id) {
273
            return new JsonModel([
274
                'success' => false,
275
                'data' => 'ERROR_UNAUTHORIZED'
276
            ]);
277
        }
278
 
279
 
280
        if ($request->isPost()) {
10189 eleazar 281
            $form = new MyTrainerQuestionForm($this->adapter);
9350 eleazar 282
            $dataPost = $request->getPost()->toArray();
283
 
284
            $form->setData($dataPost);
285
 
286
            if ($form->isValid()) {
287
                $dataPost = (array) $form->getData();
288
 
289
                $hydrator = new ObjectPropertyHydrator();
290
                $hydrator->hydrate($dataPost, $questions);
10250 eleazar 291
                $categoriesMapper = TopicMapper::getInstance($this->adapter);
292
                $category = $categoriesMapper->fetchOneByUuid($dataPost['category_id']);
293
                $questions->category_id = $category->id;
9350 eleazar 294
 
295
                if($questionsMapper->update($questions)) {
296
                    $questions = $questionsMapper->fetchOne($questions->id);
297
 
298
                   $this->logger->info('Se modifico la pregunta ' . $questions->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
299
 
300
                   $data = [
301
                       'success'   => true,
302
                       'data'   => 'LABEL_RECORD_UPDATED'
303
                   ];
304
               } else {
305
                   $data = [
306
                       'success'   => false,
307
                       'data'      => $questionsMapper->getError()
308
                   ];
309
 
310
               }
311
 
312
                return new JsonModel($data);
313
            } else {
314
                $messages = [];
315
                $form_messages = (array) $form->getMessages();
316
                foreach ($form_messages as $fieldname => $field_messages) {
317
                    $messages[$fieldname] = array_values($field_messages);
318
                }
319
 
320
                return new JsonModel([
321
                    'success' => false,
322
                    'data' => $messages
323
                ]);
324
            }
325
        } else if ($request->isGet()) {
326
 
327
            $hydrator = new ObjectPropertyHydrator();
10252 eleazar 328
            $categoriesMapper = TopicMapper::getInstance($this->adapter);
329
            $category = $categoriesMapper->fetchOne($questions->category_id);
9350 eleazar 330
 
331
            $data = [
332
                'success' => true,
333
                'data' => [
334
                    'id' => $questions->uuid,
10252 eleazar 335
                    'category_id' => $category->uuid,
9350 eleazar 336
                    'title' => $questions->title,
337
                    'text' => $questions->text,
338
                ]
339
            ];
340
 
341
            return new JsonModel($data);
342
        } else {
343
            $data = [
344
                'success' => false,
345
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
346
            ];
347
 
348
            return new JsonModel($data);
349
        }
350
 
351
        return new JsonModel($data);
352
    } catch (\Throwable $e) {
353
        $e->getMessage();
354
        return new JsonModel([
355
            'success' => false,
356
            'data' => $e
357
        ]);
358
    }
359
    }
360
 
361
    public function deleteAction() {
362
        $request = $this->getRequest();
363
        $currentUserPlugin = $this->plugin('currentUserPlugin');
364
        $currentCompany = $currentUserPlugin->getCompany();
365
        $currentUser = $currentUserPlugin->getUser();
366
 
367
        $request = $this->getRequest();
368
        $uuid = $this->params()->fromRoute('id');
369
 
370
        if (!$uuid) {
371
            $data = [
372
                'success' => false,
373
                'data' => 'ERROR_INVALID_PARAMETER'
374
            ];
375
 
376
            return new JsonModel($data);
377
        }
378
 
9356 eleazar 379
        $questionsMapper = MyTrainerQuestionsMapper::getInstance($this->adapter);
9350 eleazar 380
        $questions = $questionsMapper->fetchOneByUuid($uuid);
381
        if (!$questions) {
382
            $data = [
383
                'success' => false,
384
                'data' => 'ERROR_RECORD_NOT_FOUND'
385
            ];
386
 
387
            return new JsonModel($data);
388
        }
389
 
390
        if ($questions->company_id != $currentCompany->id) {
391
            return new JsonModel([
392
                'success' => false,
393
                'data' => 'ERROR_UNAUTHORIZED'
394
            ]);
395
        }
396
 
397
        if ($request->isPost()) {
398
 
399
 
400
            $result = $questionsMapper->delete($questions->id);
401
            if ($result) {
402
                $this->logger->info('Se borro la pregunta ' . $questions->title, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
403
 
404
                $data = [
405
                    'success' => true,
406
                    'data' => 'LABEL_RECORD_DELETED'
407
                ];
408
            } else {
409
 
410
                $data = [
411
                    'success' => false,
412
                    'data' => $questionsMapper->getError()
413
                ];
414
 
415
                return new JsonModel($data);
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
}