Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 16768 | Ir a la última revisión | Autoría | Comparar con el anterior | Ultima modificación | Ver Log |

<?php
/**
 * 
 * Controlador: Mis Perfiles 
 * 
 */
declare(strict_types=1);

namespace LeadersLinked\Controller;

use Laminas\Db\Adapter\AdapterInterface;
use Laminas\Cache\Storage\Adapter\AbstractAdapter;
use Laminas\Mvc\Controller\AbstractActionController;
use Laminas\Log\LoggerInterface;
use Laminas\View\Model\ViewModel;
use Laminas\View\Model\JsonModel;

use LeadersLinked\Library\Functions;
use LeadersLinked\Mapper\QueryMapper;
use LeadersLinked\Model\CompanyMicrolearningQuiz;
use LeadersLinked\Mapper\CompanyMicrolearningQuizMapper;
use LeadersLinked\Form\QuizCreateOrEditForm;
use Laminas\Hydrator\ObjectPropertyHydrator;
use LeadersLinked\Mapper\CompanyMicrolearningQuestionMapper;
use LeadersLinked\Mapper\CompanyMicrolearningAnswerMapper;
use LeadersLinked\Model\CompanyMicrolearningQuestion;
use LeadersLinked\Model\CompanyMicrolearningAnswer;
use LeadersLinked\Mapper\CompanyMicrolearningSlideMapper;

class MicrolearningQuizController extends AbstractActionController
{
    /** 
     *
     * @var AdapterInterface
     */
    private $adapter;
    
    
    /**
     *
     * @var AbstractAdapter
     */
    private $cache;
    
    /**
     *
     * @var  LoggerInterface
     */
    private $logger;

    
    /**
     *
     * @var array
     */
    private $config;
    
    /**
     *
     * @param AdapterInterface $adapter
     * @param AbstractAdapter $cache
     * @param LoggerInterface $logger
     * @param array $config
     */
    public function __construct($adapter, $cache , $logger,  $config)
    {
        $this->adapter      = $adapter;
        $this->cache        = $cache;
        $this->logger       = $logger;
        $this->config       = $config;

    }

    public function indexAction()
    {
        $request            = $this->getRequest();
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
        $currentUser        = $currentUserPlugin->getUser();
        $currentCompany     = $currentUserPlugin->getCompany();
      
        $request = $this->getRequest();
        if($request->isGet()) {
            $headers  = $request->getHeaders();
            
            $isJson = false;
            if($headers->has('Accept')) {
                $accept = $headers->get('Accept');
                
                $prioritized = $accept->getPrioritized();
                
                foreach($prioritized as $key => $value) {
                    $raw = trim($value->getRaw());
                    
                    if(!$isJson) {
                        $isJson = strpos($raw, 'json');
                    }
                    
                }
            }
            
            if($isJson) {
                $acl = $this->getEvent()->getViewModel()->getVariable('acl');
                $allowQuestion = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/questions');
                $allowAdd = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/add');
                $allowEdit = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/edit');
                $allowDelete = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/delete');
                $allowCopy = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/copy');
                $allowCheck = $acl->isAllowed($currentUser->usertype_id, 'microlearning/content/quizzes/check');
                
                $search = $this->params()->fromQuery('search', []);
                $search = empty($search['value']) ? '' : filter_var($search['value'], FILTER_SANITIZE_STRING);
                
                $page               = intval($this->params()->fromQuery('start', 1), 10);
                $records_x_page     = intval($this->params()->fromQuery('length', 10), 10);
                $order =  $this->params()->fromQuery('order', []);
                $order_field        = empty($order[0]['column']) ? 99 :  intval($order[0]['column'], 10);
                $order_direction    = empty($order[0]['dir']) ? 'ASC' : strtoupper(filter_var( $order[0]['dir'], FILTER_SANITIZE_STRING));
                
                $fields =  ['name'];
                $order_field = isset($fields[$order_field]) ? $fields[$order_field] : 'name';
                
                if(!in_array($order_direction, ['ASC', 'DESC'])) {
                    $order_direction = 'ASC';
                }
                

                
                $companyMicrolearningSlideMapper = CompanyMicrolearningSlideMapper::getInstance($this->adapter);
                $companyMicrolearningQuizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
                $paginator = $companyMicrolearningQuizMapper->fetchAllDataTableByCompanyId($currentCompany->id,  $search, $page, $records_x_page, $order_field, $order_direction);
                $items = [];
                foreach($paginator as $record)
                {

                    
                    $slides = $companyMicrolearningSlideMapper->fetchTotalCountByCompanyIdQuizId($currentCompany->id, $record->id);
                    
                    $status_description = '';
                    switch ($record->status) 
                    {
                        case CompanyMicrolearningQuiz::STATUS_ACTIVE : 
                            $status_description = 'LABEL_ACTIVE';
                            break;
                            
                        case CompanyMicrolearningQuiz::STATUS_INACTIVE :
                            $status_description = 'LABEL_INACTIVE';
                            break;
                    }
                    
                    $check_description = '';
                    switch($record->check)
                    {
                        case CompanyMicrolearningQuiz::CHECK_OK :
                            $check_description = 'LABEL_WITHOUT_ERRORS';
                            break;
                            
                        case CompanyMicrolearningQuiz::CHECK_WRONG :
                            $check_description = 'LABEL_WITH_ERRORS';
                            break;
                            
                        case CompanyMicrolearningQuiz::CHECK_PENDING :
                            $check_description = 'LABEL_PENDING';
                            break;
                    }
                    
                    $params = [
                        'quiz_id' => $record->uuid
                    ];
                    
                    $item = [
                        'name' => $record->name,
                        'details' => [
                            'status' => $status_description,
                            'check' => $check_description,
                            'points' => $record->points,
                            'max_time' => $record->max_time,
                            'slides' => $slides,
                        ],
                        'actions' => [
                            'link_question' => $allowQuestion ? $this->url()->fromRoute('microlearning/content/quizzes/questions', $params) : '',
                            'link_edit'     => $allowEdit ? $this->url()->fromRoute('microlearning/content/quizzes/edit', $params) : '',
                            'link_delete'   => $allowDelete ? $this->url()->fromRoute('microlearning/content/quizzes/delete', $params) : '',
                            'link_copy'     => $allowCopy ? $this->url()->fromRoute('microlearning/content/quizzes/copy', $params) : '',
                            'link_check'    => $allowCheck ? $this->url()->fromRoute('microlearning/content/quizzes/check', $params) : '',
                        ],
                    ];
  
                    
                    array_push($items, $item);
                }
                
                $data = [];
                $data['items'] = $items;
                $data['total'] = $paginator->getTotalItemCount(); 
                
                if($allowAdd) {
                    $data['link_add'] = $this->url()->fromRoute('microlearning/content/quizzes/add');
                }  else {
                    $data['link_add'] = '';
                }
                
                $response = [
                    'success' => true,
                    'data' => $data
                ];
                
                return new JsonModel($response);
                
                
            } else {
                $form = new QuizCreateOrEditForm();
                
                $this->layout()->setTemplate('layout/layout-backend.phtml');
                $viewModel = new ViewModel();
                $viewModel->setTemplate('leaders-linked/microlearning-quizzes/index.phtml');
                $viewModel->setVariables([
                    'form' => $form,
                ]);
                return $viewModel ;
            }
            
        } else {
            return new JsonModel([
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ]);
        }
    }
    
    public function addAction()
    {
        $request            = $this->getRequest();
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
        $currentUser        = $currentUserPlugin->getUser();
        $currentCompany     = $currentUserPlugin->getCompany();

        if($request->isPost()) {
            $formCreateOrEdit = new  QuizCreateOrEditForm();
            $formCreateOrEdit->setData($request->getPost()->toArray());
            
            if($formCreateOrEdit->isValid()) {
                $dataPost = (array) $formCreateOrEdit->getData();
                
                $hydrator = new ObjectPropertyHydrator();
                $quiz = new CompanyMicrolearningQuiz();
                $hydrator->hydrate($dataPost, $quiz);
                
                $quiz->company_id = $currentCompany->id;
                
                $quizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
                if($quizMapper->insert($quiz)) {
                    
                   
                    $this->logger->info('Se agrego el quiz ' . $quiz->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
                    
                    $data = [
                        'success'   => true,
                        'data'   => 'LABEL_RECORD_ADDED'
                    ];
                } else {
                    $data = [
                        'success'   => false,
                        'data'      => $quizMapper->getError()
                    ];
                    
                }
                
                return new JsonModel($data);
                
            } else {
                $messages = [];
                $form_messages = (array) $formCreateOrEdit->getMessages();
                foreach($form_messages  as $fieldname => $field_messages)
                {
                    
                    $messages[$fieldname] = array_values($field_messages);
                }
                
                return new JsonModel([
                    'success'   => false,
                    'data'   => $messages
                ]);
            }
            
        } else {
            $data = [
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ];
            
            return new JsonModel($data);
        }
        
        return new JsonModel($data);
    }
    
    /**
     *
     * Borrar un perfil excepto el público
     * @return \Laminas\View\Model\JsonModel
     */
    public function deleteAction()
    {
        $request            = $this->getRequest();
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
        $currentUser        = $currentUserPlugin->getUser();
        $currentCompany     = $currentUserPlugin->getCompany();
        $quiz_id            = $this->params()->fromRoute('quiz_id');
        
        $quizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
        $quiz = $quizMapper->fetchOneByUuid($quiz_id);
        if(!$quiz) {
            return new JsonModel([
                'success'   => false,
                'data'   => 'ERROR_FORM_NOT_FOUND'
            ]);
        }
        
        if($quiz->company_id != $currentCompany->id) {
            return new JsonModel([
                'success'   => false,
                'data'   => 'ERROR_UNAUTHORIZED'
            ]);
        }
        
        if($request->isPost()) {
            $result = $quizMapper->delete($quiz);
            if($result) {
                $this->logger->info('Se borro el cuestionario : ' .  $quiz->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);

                $data = [
                    'success' => true,
                    'data' => 'LABEL_RECORD_DELETED'
                ];
            } else {
                
                $data = [
                    'success'   => false,
                    'data'      => $quizMapper->getError()
                ];
                
                return new JsonModel($data);
            }
            
        } else {
            $data = [
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ];
            
            return new JsonModel($data);
        }
        
        return new JsonModel($data);
    }
    
    
    public function editAction()
    {
        $request            = $this->getRequest();
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
        $currentUser        = $currentUserPlugin->getUser();
        $currentCompany     = $currentUserPlugin->getCompany();
        $quiz_id            = $this->params()->fromRoute('quiz_id');
        
        $quizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
        $quiz = $quizMapper->fetchOneByUuid($quiz_id);
        if(!$quiz) {
            return new JsonModel([
                'success'   => false,
                'data'   => 'ERROR_FORM_NOT_FOUND'
            ]);
        }
        
        if($quiz->company_id != $currentCompany->id) {
            return new JsonModel([
                'success'   => false,
                'data'   => 'ERROR_UNAUTHORIZED'
            ]);
        }
        
        
        if($request->isGet()) {
            $data = [
                'success' => true,
                'data' => [
                    'name' => $quiz->name,
                    'text' => $quiz->text,
                    'status' => $quiz->status,
                    'points' => $quiz->points,
                    'minimum_points_required' => $quiz->minimum_points_required,
                    'max_time' => $quiz->max_time,
                    'failed' => $quiz->failed,
                    
                ]
            ];
            
            return new JsonModel($data);
        }
        else if($request->isPost()) {
            $formCreateOrEdit = new  QuizCreateOrEditForm();
            $formCreateOrEdit->setData($request->getPost()->toArray());
            
            if($formCreateOrEdit->isValid()) {
                $dataPost = (array) $formCreateOrEdit->getData();
                
                $hydrator = new ObjectPropertyHydrator();
                $hydrator->hydrate($dataPost, $quiz);
                
                $quiz->check = CompanyMicrolearningQuiz::CHECK_PENDING;
                if($quizMapper->update($quiz)) {
                    
                    $this->logger->info('Se edito el cuestionario ' . $quiz->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
                    
                    $data = [
                        'success'   => true,
                        'data'   => 'LABEL_RECORD_UPDATED'
                    ];
                } else {
                    $data = [
                        'success'   => false,
                        'data'      => $quizMapper->getError()
                    ];
                    
                }
                
                return new JsonModel($data);
                
            } else {
                $messages = [];
                $form_messages = (array) $formCreateOrEdit->getMessages();
                foreach($form_messages  as $fieldname => $field_messages)
                {
                    
                    $messages[$fieldname] = array_values($field_messages);
                }
                
                return new JsonModel([
                    'success'   => false,
                    'data'   => $messages
                ]);
            }
        } else {
            $data = [
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ];
            
            return new JsonModel($data);
        }
        
        return new JsonModel($data);
    }
    
    
    public function checkAction()
    {
        $request            = $this->getRequest();
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
        $currentUser        = $currentUserPlugin->getUser();
        $currentCompany     = $currentUserPlugin->getCompany();
        $quiz_id            = $this->params()->fromRoute('quiz_id');
        
        $quizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
        $quiz = $quizMapper->fetchOneByUuid($quiz_id);
        if(!$quiz) {
            return new JsonModel([
                'success'   => false,
                'data'   => 'ERROR_QUIZ_NOT_FOUND'
            ]);
        }
        
        if($quiz->company_id != $currentCompany->id) {
            return new JsonModel([
                'success'   => false,
                'data'   => 'ERROR_UNAUTHORIZED'
            ]);
        }
        
         if($request->isPost()) {
            $questionMapper = CompanyMicrolearningQuestionMapper::getInstance($this->adapter);
            $answerMapper = CompanyMicrolearningAnswerMapper::getInstance($this->adapter);
            
            $total_wrong_questions = 0;
            $total_point_questions = 0;
            

            $questions = $questionMapper->fetchAllByQuizId($quiz->id);

            foreach($questions as $question)
            {
                $total_point_questions += $question->points;
                $answers = $answerMapper->fetchAllByQuizIdAndQuestionId($question->quiz_id, $question->id);
                            
                if($question->type == CompanyMicrolearningQuestion::TYPE_SINGLE_SELECTION ) {
                    $number_correct     = 0;
                    $number_incorrect   = 0;
                    foreach($answers as $answer)
                    {
                        if($answer->correct == CompanyMicrolearningAnswer::CORRECT_YES) {
                            $number_correct++;
                        } else {
                            $number_incorrect++;
                        }
                    }

                    if($number_correct == 1 && $number_incorrect >= 1 ) {
                        $check_question = CompanyMicrolearningQuestion::CHECK_OK;
                    } else {
                        $check_question = CompanyMicrolearningQuestion::CHECK_WRONG;
                    }
                } else if($question->type == CompanyMicrolearningQuestion::TYPE_MULTIPLE_SELECTION ) {
                    $number_correct     = 0;
                    $number_incorrect   = 0;
                    $points = 0;

                    foreach($answers as $answer)
                    {
                        $points += $answer->points;
                        if($answer->correct == CompanyMicrolearningAnswer::CORRECT_YES) {
                            $number_correct++;
                        } else {
                            $number_incorrect++;
                        }
                    }
                        
                    if($number_correct < 2 || $number_incorrect < 1) {
                        $check_question = CompanyMicrolearningQuestion::CHECK_WRONG;
                    } else {
                        if($points == $question->points) {
                            $check_question = CompanyMicrolearningQuestion::CHECK_OK;
                        } else {
                            $check_question = CompanyMicrolearningQuestion::CHECK_WRONG;
                        }
                           
                    }
                } else {
                    $check_question = CompanyMicrolearningQuestion::CHECK_OK;
                }
                    
                
                if($check_question == CompanyMicrolearningQuestion::CHECK_WRONG) {
                    $quiz->check = CompanyMicrolearningQuiz::CHECK_WRONG;
                }

                $question->check = $check_question;
                $questionMapper->update($question);
            }
            
            if($quiz->check == CompanyMicrolearningQuiz::CHECK_PENDING) {
                $quiz->check = $quiz->points == $total_point_questions ? CompanyMicrolearningQuiz::CHECK_OK : CompanyMicrolearningQuiz::CHECK_WRONG;
            }
            

            $quizMapper->update($quiz);
            
            if($quiz->check ==  CompanyMicrolearningQuiz::CHECK_OK) {
                $this->logger->info('Se comprobo el cuestionario ' . $quiz->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
                
                $data = [
                    'success'   => true,
                    'data'   => 'LABEL_QUIZ_CHECK_OK'
                ];
            } else {
                $messages = [];
                if($total_wrong_questions == 1) {
                    array_push($messages, '1 LABEL_QUESTION_CHECK_WRONG '); 
                } else if($total_wrong_questions > 1) {
                    array_push($messages,  $total_wrong_questions . 'LABEL_QUESTIONS_CHECK_WRONG '); 
                }
                
                if(!$messages) {
                    $messages = 'LABEL_QUIZ_CHECK_WRONG'; 
                } else {
                    $messages = implode(', ', $messages);
                }
                
                $data = [
                    'success'   => false,
                    'data'   => $messages
                ];
            }
            
           
        } else {
            $data = [
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ];
            
            return new JsonModel($data);
        }
        
        return new JsonModel($data);
    }
    
    
    
    public function copyAction()
    {
        $request            = $this->getRequest();
        $currentUserPlugin  = $this->plugin('currentUserPlugin');
        $currentUser        = $currentUserPlugin->getUser();
        $currentCompany     = $currentUserPlugin->getCompany();
        $quiz_id            = $this->params()->fromRoute('quiz_id');
        
        $quizMapper = CompanyMicrolearningQuizMapper::getInstance($this->adapter);
        $quiz = $quizMapper->fetchOneByUuid($quiz_id);
        if(!$quiz) {
            return new JsonModel([
                'success'   => false,
                'data'   => 'ERROR_QUIZ_NOT_FOUND'
            ]);
        }
        
        if($quiz->company_id != $currentCompany->id) {
            return new JsonModel([
                'success'   => false,
                'data'   => 'ERROR_UNAUTHORIZED'
            ]);
        }
        
        if($request->isPost()) {
            
            $quizClone = new CompanyMicrolearningQuiz();
            
            $quizClone->check = CompanyMicrolearningQuiz::CHECK_PENDING;
            $quizClone->status = CompanyMicrolearningQuiz::STATUS_INACTIVE;
            $quizClone->company_id = $quiz->company_id;
            $quizClone->failed = $quiz->failed;
            $quizClone->name = 'COPIA - ' . $quiz->name;
            $quizClone->max_time = $quiz->max_time;
            $quizClone->minimum_points_required = $quiz->minimum_points_required;
            $quizClone->points = $quiz->points;
            $quizClone->text = $quiz->text;

            if($quizMapper->insert($quizClone)) {
                $this->logger->info('Se copio el quiz ' . $quizClone->name, ['user_id' => $currentUser->id, 'ip' => Functions::getUserIP()]);
                
                $questionMapper = CompanyMicrolearningQuestionMapper::getInstance($this->adapter);
                $answerMapper = CompanyMicrolearningAnswerMapper::getInstance($this->adapter);
                
                $questions = $questionMapper->fetchAllByQuizId($quiz->id);
                foreach($questions as $question)
                {
                    $questionClone = new CompanyMicrolearningQuestion();
                    $questionClone->check = CompanyMicrolearningQuestion::CHECK_PENDING;
                    $questionClone->company_id = $question->company_id;
                    $questionClone->maxlength = $question->maxlength;
                    $questionClone->points = $question->points;
                    $questionClone->quiz_id = $quizClone->id;
                    $questionClone->text = $question->text;
                    $questionClone->type = $question->type;
                    
                    if($questionMapper->insert($questionClone)) {
                        $answers = $answerMapper->fetchAllByQuizIdAndQuestionId($question->quiz_id, $question->id);
                        foreach($answers as $answer)
                        {
                            $answerClone = new CompanyMicrolearningAnswer();
                            $answerClone->company_id = $answer->company_id;
                            $answerClone->correct = $answer->correct;
                            $answerClone->points = $answer->points;
                            $answerClone->question_id = $questionClone->id;
                            $answerClone->quiz_id = $quizClone->id;
                            $answerClone->text = $answer->text;
                            
                            if(!$answerMapper->insert($answerClone)) {
                                $response = [
                                    'success'   => false,
                                    'data'   => $answerMapper->getError()
                                ];
                            }
                        }
                    } else {
                        $response = [
                            'success'   => false,
                            'data'   => $questionMapper->getError()
                        ];
                    }
                }

                $response = [
                    'success'   => true,
                    'data'   => 'LABEL_RECORD_ADDED'
                ];
            } else {
                $response = [
                    'success'   => false,
                    'data'   => $quizMapper->getError()
                ];
                
            }

        } else {
            $response = [
                'success' => false,
                'data' => 'ERROR_METHOD_NOT_ALLOWED'
            ];
        }
        
        return new JsonModel($response);
    }
}