Skip to content
Snippets Groups Projects
AutoCompleteController.php 5.22 KiB
Newer Older
  • Learn to ignore specific revisions
  • <?php
    
    /**
    * Copyright Maarch since 2008 under licence GPLv3.
    * See LICENCE.txt file at the root folder for more details.
    * This file is part of Maarch software.
    *
    */
    
    /**
    * @brief Auto Complete Controller
    * @author dev@maarch.org
    */
    
    namespace SrcCore\controllers;
    
    
    use Group\models\ServiceModel;
    
    Damien's avatar
    Damien committed
    use Respect\Validation\Validator;
    
    use Slim\Http\Request;
    use Slim\Http\Response;
    use Entity\models\EntityModel;
    use Status\models\StatusModel;
    use User\models\UserModel;
    
    class AutoCompleteController
    {
        public static function getUsers(Request $request, Response $response)
        {
            $excludedUsers = ['superadmin'];
    
            $users = UserModel::get([
                'select'    => ['user_id', 'firstname', 'lastname'],
                'where'     => ['enabled = ?', 'status != ?', 'user_id not in (?)'],
                'data'      => ['Y', 'DEL', $excludedUsers],
                'orderBy'   => ['lastname']
            ]);
    
            $data = [];
            foreach ($users as $key => $value) {
                $primaryEntity = UserModel::getPrimaryEntityByUserId(['userId' => $value['user_id']]);
                $data[] = [
                    'type'          => 'user',
                    'id'            => $value['user_id'],
                    'idToDisplay'   => "{$value['firstname']} {$value['lastname']}",
                    'otherInfo'     => $primaryEntity['entity_label']
                ];
            }
    
            return $response->withJson($data);
        }
    
        public static function getUsersForVisa(Request $request, Response $response)
        {
            $excludedUsers = ['superadmin'];
    
            $users = UserModel::get([
                'select'    => ['user_id', 'firstname', 'lastname'],
                'where'     => ['enabled = ?', 'status != ?', 'user_id not in (?)'],
                'data'      => ['Y', 'DEL', $excludedUsers],
                'orderBy'   => ['lastname']
            ]);
    
            $data = [];
            foreach ($users as $key => $value) {
    
                if (ServiceModel::hasService(['id' => 'visa_documents', 'userId' => $value['user_id'], 'location' => 'visa', 'type' => 'use'])
                    || ServiceModel::hasService(['id' => 'sign_document', 'userId' => $value['user_id'], 'location' => 'visa', 'type' => 'use'])) {
    
                    $primaryEntity = UserModel::getPrimaryEntityByUserId(['userId' => $value['user_id']]);
                    $data[] = [
                        'type'          => 'user',
                        'id'            => $value['user_id'],
                        'idToDisplay'   => "{$value['firstname']} {$value['lastname']}",
                        'otherInfo'     => $primaryEntity['entity_label']
                    ];
                }
            }
    
            return $response->withJson($data);
        }
    
        public static function getEntities(Request $request, Response $response)
        {
            $entities = EntityModel::get([
                'select'    => ['entity_id', 'entity_label', 'short_label'],
                'where'     => ['enabled = ?'],
                'data'      => ['Y'],
                'orderBy'   => ['entity_label']
            ]);
    
            $data = [];
            foreach ($entities as $key => $value) {
                $data[] = [
                    'type'          => 'entity',
                    'id'            => $value['entity_id'],
                    'idToDisplay'   => $value['entity_label'],
                    'otherInfo'     => $value['short_label']
                ];
            }
    
            return $response->withJson($data);
        }
    
        public static function getStatuses(Request $request, Response $response)
        {
            $statuses = StatusModel::get([
    
                'select'    => ['id', 'label_status', 'img_filename']
    
            ]);
    
            $data = [];
            foreach ($statuses as $key => $value) {
                $data[] = [
                    'type'          => 'status',
                    'id'            => $value['id'],
                    'idToDisplay'   => $value['label_status'],
    
                    'otherInfo'     => $value['img_filename']
    
                ];
            }
    
            return $response->withJson($data);
        }
    
    Damien's avatar
    Damien committed
    
        public static function getBanAddresses(Request $request, Response $response)
        {
            $data = $request->getQueryParams();
    
            $check = Validator::stringType()->notEmpty()->validate($data['address']);
            if (!$check) {
                return $response->withStatus(400)->withJson(['errors' => 'Bad Request']);
            }
    
            \Zend_Search_Lucene_Analysis_Analyzer::setDefault(new \Zend_Search_Lucene_Analysis_Analyzer_Common_Utf8Num_CaseInsensitive());
            \Zend_Search_Lucene_Search_QueryParser::setDefaultOperator(\Zend_Search_Lucene_Search_QueryParser::B_AND);
            \Zend_Search_Lucene_Search_QueryParser::setDefaultEncoding('utf-8');
    
    
    Damien's avatar
    Damien committed
            $index = \Zend_Search_Lucene::open('referential/ban/indexes');
    
    Damien's avatar
    Damien committed
            \Zend_Search_Lucene::setResultSetLimit(10);
    
    Damien's avatar
    Damien committed
            $hits = $index->find($data['address']);
    
    Damien's avatar
    Damien committed
    
    
    Damien's avatar
    Damien committed
            $addresses = [];
            foreach($hits as $key => $hit){
                $addresses[] = [
    
    Damien's avatar
    Damien committed
                    'banId'         => $hit->banId,
                    'number'        => $hit->streetNumber,
                    'afnorName'     => $hit->afnorName,
                    'postalCode'    => $hit->postalCode,
    
    Damien's avatar
    Damien committed
                    'city'          => $hit->city,
                    'address'       => "{$hit->streetNumber} {$hit->afnorName}, {$hit->city} ({$hit->postalCode})"
    
    Damien's avatar
    Damien committed
            return $response->withJson($addresses);
    
    Damien's avatar
    Damien committed
        }