DirectorView.php 39.1 KB
Newer Older
Open Source Developer's avatar
Open Source Developer committed
1 2 3 4 5 6 7 8 9 10
<?php

namespace Drupal\epal\Controller;

use Drupal\Core\Entity\EntityTypeManagerInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Symfony\Component\HttpFoundation\JsonResponse;
use Drupal\Core\Controller\ControllerBase;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
Open Source Developer's avatar
Open Source Developer committed
11 12
use Drupal\Core\Database\Connection;
use Drupal\Core\Logger\LoggerChannelFactoryInterface;
Open Source Developer's avatar
Open Source Developer committed
13 14 15 16

class DirectorView extends ControllerBase
{
    protected $entityTypeManager;
17
    protected $logger;
Open Source Developer's avatar
Open Source Developer committed
18
  //  protected $testSchoolId='0640050';
Open Source Developer's avatar
Open Source Developer committed
19

20 21
    public function __construct(EntityTypeManagerInterface $entityTypeManager,
        LoggerChannelFactoryInterface $loggerChannel)
Open Source Developer's avatar
Open Source Developer committed
22 23
    {
        $this->entityTypeManager = $entityTypeManager;
24
        $this->logger = $loggerChannel->get('epal-school');
Open Source Developer's avatar
Open Source Developer committed
25 26 27 28 29
    }

    public static function create(ContainerInterface $container)
    {
        return new static(
30 31
            $container->get('entity_type.manager'),
            $container->get('logger.factory')
Open Source Developer's avatar
Open Source Developer committed
32
        );
33
    }
Open Source Developer's avatar
Open Source Developer committed
34 35 36



Open Source Developer's avatar
Open Source Developer committed
37
public function getSectorsPerSchool(Request $request)
Open Source Developer's avatar
Open Source Developer committed
38
    {
39

Open Source Developer's avatar
Open Source Developer committed
40
        $authToken = $request->headers->get('PHP_AUTH_USER');
41 42 43 44

        $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
         $user = reset($users);
         if ($user) {
Open Source Developer's avatar
Open Source Developer committed
45 46 47 48
                $epalId = $user ->  init -> value;

             $schools = $this->entityTypeManager->getStorage('eepal_school')->
             loadByProperties(array('id' => $epalId));
49 50 51 52 53 54 55 56 57 58 59 60
             $school = reset($schools);
             if (!$school) {
                 $this->logger->warning("no access to this school=" . $user->id());
                 $response = new Response();
                 $response->setContent('No access to this school');
                 $response->setStatusCode(Response::HTTP_FORBIDDEN);
                 $response->headers->set('Content-Type', 'application/json');
                 return $response;
             }


                $userid = $user -> id();
Open Source Developer's avatar
Open Source Developer committed
61 62
                //$epalIdNew = intval($epalId);
                $sectorPerSchool = $this->entityTypeManager->getStorage('eepal_sectors_in_epal')->loadByProperties(array('epal_id'=> $epalId));
Open Source Developer's avatar
Open Source Developer committed
63 64 65 66 67 68 69 70 71 72 73 74
                $i = 0;

            if ($sectorPerSchool) {
                 $list = array();
                foreach ($sectorPerSchool as $object) {
                    $list[] = array(
                            'sector_id' => $object -> sector_id ->entity->get('name')->value ,
                            'id' => $object -> sector_id -> entity -> id()
);

                   	 $i++;
                }
75

Open Source Developer's avatar
Open Source Developer committed
76 77 78 79 80 81 82
                return $this->respondWithStatus(
                        $list
                    , Response::HTTP_OK);
                }
             else {
                       return $this->respondWithStatus([
                    'message' => t("School not found!!!"),
83
                ], Response::HTTP_OK);
Open Source Developer's avatar
Open Source Developer committed
84
                }
85

Open Source Developer's avatar
Open Source Developer committed
86 87 88 89 90 91 92 93


        } else {

            return $this->respondWithStatus([
                    'message' => t("User not found!"),
                ], Response::HTTP_FORBIDDEN);
        }
94

Open Source Developer's avatar
Open Source Developer committed
95 96
    }

Open Source Developer's avatar
Open Source Developer committed
97
public function getSpecialPerSchool(Request $request , $sectorId)
Open Source Developer's avatar
Open Source Developer committed
98
    {
99

Open Source Developer's avatar
Open Source Developer committed
100
        $authToken = $request->headers->get('PHP_AUTH_USER');
101 102 103 104

        $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
         $user = reset($users);
         if ($user) {
Open Source Developer's avatar
Open Source Developer committed
105 106 107
            $epalId = $user ->  init -> value;

            $schools = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array( 'id' => $epalId));
108 109 110 111 112 113 114 115 116 117
             $school = reset($schools);
             if (!$school) {
                 $this->logger->warning("no access to this school=" . $user->id());
                 $response = new Response();
                 $response->setContent('No access to this school');
                 $response->setStatusCode(Response::HTTP_FORBIDDEN);
                 $response->headers->set('Content-Type', 'application/json');
                 return $response;
             }
                $userid = $user -> id();
Open Source Developer's avatar
Open Source Developer committed
118 119
                //$epalIdNew = intval($epalId);
                $specialityPerSchool = $this->entityTypeManager->getStorage('eepal_specialties_in_epal')->loadByProperties(array('epal_id'=> $epalId));
Open Source Developer's avatar
Open Source Developer committed
120 121 122 123 124 125 126 127 128 129
                $i = 0;

            if ($specialityPerSchool) {
                 $list = array();
                 $SectorIdNew = intval($sectorId);
                foreach ($specialityPerSchool as $object) {
                       $idSpecial =  $object -> specialty_id -> entity -> id() ;

                       $specialityPerSector = $this->entityTypeManager->getStorage('eepal_specialty')->loadByProperties(array('id'=> $idSpecial,'sector_id' => $SectorIdNew ));
                       $specialPerSec = reset($specialityPerSector);
130
                       if ($specialPerSec)
Open Source Developer's avatar
Open Source Developer committed
131 132 133 134 135
                        {       $list[] = array(
                                'specialty_id' => $object -> specialty_id ->entity->get('name')->value ,
                                'id' => $object -> specialty_id -> entity -> id()     );
                                $i++;
                        }
136

Open Source Developer's avatar
Open Source Developer committed
137
                }
138

Open Source Developer's avatar
Open Source Developer committed
139 140 141 142 143 144 145
                return $this->respondWithStatus(
                        $list
                    , Response::HTTP_OK);
                }
             else {
                       return $this->respondWithStatus([
                    'message' => t("School not found!!!"),
146
                ], Response::HTTP_OK);
Open Source Developer's avatar
Open Source Developer committed
147
                }
148

Open Source Developer's avatar
Open Source Developer committed
149

Open Source Developer's avatar
Open Source Developer committed
150

Open Source Developer's avatar
Open Source Developer committed
151 152 153 154 155 156
        } else {

            return $this->respondWithStatus([
                    'message' => t("User not found!"),
                ], Response::HTTP_FORBIDDEN);
        }
157

Open Source Developer's avatar
Open Source Developer committed
158 159 160
    }


Open Source Developer's avatar
Open Source Developer committed
161
public function getStudentPerSchool(Request $request , $selectId, $classId, $limitdown, $limitup)
Open Source Developer's avatar
Open Source Developer committed
162
    {
163

Open Source Developer's avatar
Open Source Developer committed
164
        $authToken = $request->headers->get('PHP_AUTH_USER');
165 166 167 168

       $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
        $user = reset($users);
        if ($user) {
Open Source Developer's avatar
Open Source Developer committed
169 170
            $epalId = $user ->  init -> value;
            $schools = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array( 'id' => $epalId));
171 172 173 174 175 176 177 178 179 180 181
            $school = reset($schools);
            if (!$school) {
                $this->logger->warning("no access to this school=" . $user->id());
                $response = new Response();
                $response->setContent('No access to this school');
                $response->setStatusCode(Response::HTTP_FORBIDDEN);
                $response->headers->set('Content-Type', 'application/json');
                return $response;
            }

                $userid = $user -> id();
Open Source Developer's avatar
Open Source Developer committed
182
                //$epalIdNew = intval($epalId);
Open Source Developer's avatar
Open Source Developer committed
183
                $selectIdNew = intval($selectId);
Open Source Developer's avatar
Open Source Developer committed
184 185 186
                if ($classId == 1)
                {
                 $selectIdNew = -1;
Open Source Developer's avatar
Open Source Developer committed
187
                 $studentPerSchool = $this->entityTypeManager->getStorage('epal_student_class')->loadByProperties(array('epal_id'=> $epalId, 'specialization_id' => $selectIdNew, 'currentclass' => $classId ));
188

Open Source Developer's avatar
Open Source Developer committed
189 190
                }
                else
191
                {
Open Source Developer's avatar
Open Source Developer committed
192
                $studentPerSchool = $this->entityTypeManager->getStorage('epal_student_class')->loadByProperties(array('epal_id'=> $epalId, 'specialization_id' => $selectIdNew, 'currentclass' => $classId ));
193
                }
Open Source Developer's avatar
Open Source Developer committed
194 195 196 197
                $i = 0;

            if ($studentPerSchool) {
                 $list = array();
Open Source Developer's avatar
Open Source Developer committed
198 199 200 201
                 $i = 0;
                 if  ($limitdown==$limitup && $limitup == 0)
                     {
                            $list=array(
Open Source Developer's avatar
Open Source Developer committed
202 203 204
                                   'id' => sizeof($studentPerSchool),
                                   'up' => $limitup,  
                                   'down' => $limitdown
Open Source Developer's avatar
Open Source Developer committed
205 206 207 208 209 210 211 212 213 214 215 216
                                ); 
                     }

                  else   
                  {
                         foreach ($studentPerSchool as $object)
                                {
                                $studentId = $object -> id() ;
                                $epalStudents = $this->entityTypeManager->getStorage('epal_student')->loadByProperties(array('id'=> $studentId));
                                $epalStudent = reset($epalStudents);
                               
                                if ($epalStudents) {
Open Source Developer's avatar
Open Source Developer committed
217 218 219
                                    $studentIdNew = $epalStudent -> id();
                                    $checkstatus = $this->entityTypeManager->getStorage('epal_student_class')->loadByProperties(array( 'student_id'=> $studentIdNew));
                                    $checkstudentstatus = reset($checkstatus);
Open Source Developer's avatar
Open Source Developer committed
220 221
                                   if ($i >= $limitdown && $i < $limitup)
                                   { 
Open Source Developer's avatar
Open Source Developer committed
222 223
                                    $newstatus = $checkstudentstatus -> directorconfirm-> getValue();
                                                                    
Open Source Developer's avatar
Open Source Developer committed
224 225 226 227 228 229 230 231 232
                                   $list[] = array(
                                    'i' => $i,
                                    'id' => $epalStudent -> id(),
                                    'name' => $epalStudent -> name ->value,
                                    'studentsurname' => $epalStudent -> studentsurname ->value,
                                    'fatherfirstname' => $epalStudent -> fatherfirstname ->value,
                                    'fathersurname' =>$epalStudent -> fathersurname ->value,
                                    'motherfirstname' => $epalStudent -> motherfirstname ->value,
                                    'mothersurname' =>$epalStudent -> mothersurname ->value,
Open Source Developer's avatar
Open Source Developer committed
233
                                    'guardianfirstname' =>$epalUser -> name ->value,
Open Source Developer's avatar
Open Source Developer committed
234
                                    'guardiansurname' =>$epalUser -> surname ->value,
Open Source Developer's avatar
Open Source Developer committed
235 236 237 238 239 240
                                    'regionaddress' =>$epalStudent -> regionaddress ->value,
                                    'regiontk' =>$epalStudent -> regiontk ->value,
                                    'regionarea' =>$epalStudent -> regionarea ->value,
                                    'certificatetype' =>$epalStudent -> certificatetype ->value,
                                    'telnum' =>$epalStudent -> telnum ->value,
                                    'relationtostudent' =>$epalStudent -> relationtostudent ->value,
Open Source Developer's avatar
Open Source Developer committed
241
                                    'birthdate' =>$epalStudent -> birthdate ->value,
Open Source Developer's avatar
Open Source Developer committed
242 243
                                    'checkstatus' =>$newstatus[0][value],

Open Source Developer's avatar
Open Source Developer committed
244 245 246 247 248 249 250 251 252
                                    );
                                   }
                                   $i++;
                                }
                            }
                        }
                        return $this->respondWithStatus(
                                $list
                            , Response::HTTP_OK);
Open Source Developer's avatar
Open Source Developer committed
253 254
                        }
             else {
255 256
                 $list = array();
                       return $this->respondWithStatus($list, Response::HTTP_OK);
Open Source Developer's avatar
Open Source Developer committed
257 258 259
                }


260 261

        }
Open Source Developer's avatar
Open Source Developer committed
262 263 264 265 266 267
        else {

            return $this->respondWithStatus([
                    'message' => t("User not found!"),
                ], Response::HTTP_FORBIDDEN);
        }
268

Open Source Developer's avatar
Open Source Developer committed
269
    }
Open Source Developer's avatar
Open Source Developer committed
270 271 272



Open Source Developer's avatar
Open Source Developer committed
273 274 275 276
    public function ConfirmStudents(Request $request)
    {

        if (!$request->isMethod('POST')) {
277
            return $this->respondWithStatus([
Open Source Developer's avatar
Open Source Developer committed
278 279 280 281 282
                    "message" => t("Method Not Allowed")
                ], Response::HTTP_METHOD_NOT_ALLOWED);
        }
        $authToken = $request->headers->get('PHP_AUTH_USER');

283 284 285
        $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
         $user = reset($users);
         if ($user) {
Open Source Developer's avatar
Open Source Developer committed
286
//             
287

Open Source Developer's avatar
Open Source Developer committed
288
            $postData = null;
Open Source Developer's avatar
Open Source Developer committed
289

Open Source Developer's avatar
Open Source Developer committed
290
            if ($content = $request->getContent())
Open Source Developer's avatar
Open Source Developer committed
291 292 293
            {
                 $postData = json_decode($content);
                 $arr = $postData->students;
Open Source Developer's avatar
Open Source Developer committed
294
                 $type = $postData ->type;
Open Source Developer's avatar
Open Source Developer committed
295 296

                foreach ($arr as $value) {
297
                    $valnew = intval($value);
Open Source Developer's avatar
Open Source Developer committed
298 299 300
                 $studentForConfirm = $this->entityTypeManager->getStorage('epal_student_class')->loadByProperties(array('id' => $valnew ));
                    $studentConfirm = reset($studentForConfirm);
                  if ($studentConfirm) {
Open Source Developer's avatar
Open Source Developer committed
301
                    if ($type == 1)
Open Source Developer's avatar
Open Source Developer committed
302
                         $studentConfirm->set('directorconfirm', true);
Open Source Developer's avatar
Open Source Developer committed
303
                     if ($type == 2)
Open Source Developer's avatar
Open Source Developer committed
304
                        $studentConfirm->set('directorconfirm', false);
Open Source Developer's avatar
Open Source Developer committed
305 306
                    if ($type == 3)
                        unset($studentConfirm->{directorconfirm});
Open Source Developer's avatar
Open Source Developer committed
307
                         $studentConfirm->save();
308 309
                    }
                }
Open Source Developer's avatar
Open Source Developer committed
310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330
                return $this->respondWithStatus([
                    'message' => t("saved"),
                ], Response::HTTP_OK);
            }
             else
              {
                  return $this->respondWithStatus([
                    'message' => t("post with no data"),
                ], Response::HTTP_BAD_REQUEST);
                }

            } else {
            return $this->respondWithStatus([
                    'message' => t("EPAL user not found"),
                ], Response::HTTP_FORBIDDEN);
        }
    }




Open Source Developer's avatar
Open Source Developer committed
331 332


Open Source Developer's avatar
Open Source Developer committed
333
public function SaveCapacity(Request $request,$taxi,$tomeas,$specialit)
Open Source Developer's avatar
Open Source Developer committed
334 335
    {

Open Source Developer's avatar
Open Source Developer committed
336 337


Open Source Developer's avatar
Open Source Developer committed
338
        if (!$request->isMethod('POST')) {
339
            return $this->respondWithStatus([
Open Source Developer's avatar
Open Source Developer committed
340 341 342 343 344
                    "message" => t("Method Not Allowed")
                ], Response::HTTP_METHOD_NOT_ALLOWED);
        }
        $authToken = $request->headers->get('PHP_AUTH_USER');

345 346 347
        $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
         $user = reset($users);
         if ($user) {
Open Source Developer's avatar
Open Source Developer committed
348
             $schoolid = $user ->  init -> value;
Open Source Developer's avatar
Open Source Developer committed
349
             $schools = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array('id'=> $schoolid));
350 351 352 353 354 355 356 357 358
             $school = reset($schools);
             if (!$school) {
                 $this->logger->warning("no access to this school=" . $user->id());
                 $response = new Response();
                 $response->setContent('No access to this school');
                 $response->setStatusCode(Response::HTTP_FORBIDDEN);
                 $response->headers->set('Content-Type', 'application/json');
                 return $response;
             }
Open Source Developer's avatar
Open Source Developer committed
359 360 361 362 363 364
            $postData = null;

            if ($content = $request->getContent())
            {
                 $postData = json_decode($content);
                 $cap = $postData->capacity;
365 366 367 368 369 370 371
                 if ($cap<= 0 || $cap > 99)
                 {
                    return $this->respondWithStatus([
                    'message' => t("Number out of limits!"),
                ], Response::HTTP_BAD_REQUEST);
                 }

Open Source Developer's avatar
Open Source Developer committed
372
                if (($tomeas == 0) && ($specialit == 0))
Open Source Developer's avatar
Open Source Developer committed
373 374 375 376 377 378
                {
                 $CapacityPerClass = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array('id' => $schoolid ));
                 $classcapacity = reset($CapacityPerClass);
                  if ($classcapacity) {
                         $classcapacity->set('capacity_class_a', $cap);
                         $classcapacity->save();
379
                    }
Open Source Developer's avatar
Open Source Developer committed
380 381 382
                }


Open Source Developer's avatar
Open Source Developer committed
383
                if (($tomeas != 0) && ($specialit == 0))
Open Source Developer's avatar
Open Source Developer committed
384 385 386 387 388 389
                {
                 $CapacityPerClass = $this->entityTypeManager->getStorage('eepal_sectors_in_epal')->loadByProperties(array('epal_id' => $schoolid, 'sector_id' => $tomeas ));
                 $classcapacity = reset($CapacityPerClass);
                  if ($classcapacity) {
                         $classcapacity->set('capacity_class_sector', $cap);
                         $classcapacity->save();
390
                    }
Open Source Developer's avatar
Open Source Developer committed
391 392 393
                }


Open Source Developer's avatar
Open Source Developer committed
394
                if (($tomeas != 0) && ($specialit != 0) && ($taxi == 3))
Open Source Developer's avatar
Open Source Developer committed
395 396 397 398 399 400
                {
                 $CapacityPerClass = $this->entityTypeManager->getStorage('eepal_specialties_in_epal')->loadByProperties(array('epal_id' => $schoolid, 'specialty_id' => $specialit));
                 $classcapacity = reset($CapacityPerClass);
                  if ($classcapacity) {
                         $classcapacity->set('capacity_class_specialty', $cap);
                         $classcapacity->save();
401
                    }
Open Source Developer's avatar
Open Source Developer committed
402 403 404
                }


Open Source Developer's avatar
Open Source Developer committed
405 406 407 408 409 410 411 412 413
                if (($tomeas != 0) && ($specialit != 0) && ($taxi == 4))
                {
                 $CapacityPerClass = $this->entityTypeManager->getStorage('eepal_specialties_in_epal')->loadByProperties(array('epal_id' => $schoolid, 'specialty_id' => $specialit));
                 $classcapacity = reset($CapacityPerClass);
                  if ($classcapacity) {
                         $classcapacity->set('capacity_class_specialty_d', $cap);
                         $classcapacity->save();
                    }
                }
Open Source Developer's avatar
Open Source Developer committed
414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436



                return $this->respondWithStatus([
                    'message' => t("saved"),
                ], Response::HTTP_OK);
            }
             else
              {
                  return $this->respondWithStatus([
                    'message' => t("post with no data"),
                ], Response::HTTP_BAD_REQUEST);
                }

            } else {
            return $this->respondWithStatus([
                    'message' => t("EPAL user not found"),
                ], Response::HTTP_FORBIDDEN);
        }
    }



Open Source Developer's avatar
Open Source Developer committed
437
    public function getSchoolsPerPerfetcure(Request $request, $check_status)
Open Source Developer's avatar
Open Source Developer committed
438 439 440 441 442 443 444 445
    {

        $authToken = $request->headers->get('PHP_AUTH_USER');

        $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
        $user = reset($users);
        if ($user)
            {
Open Source Developer's avatar
Open Source Developer committed
446 447 448 449 450 451 452 453
                $selectionId = $user ->  init -> value;
                if ($check_status == 1){
                $schools = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array('region_edu_admin_id'=> $selectionId ));
                } 
                else
                {
                    $schools = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array('edu_admin_id'=> $selectionId ));
                }  
Open Source Developer's avatar
Open Source Developer committed
454 455 456
                if ($schools)        
                {
                    $list = array();
Open Source Developer's avatar
Open Source Developer committed
457

Open Source Developer's avatar
Open Source Developer committed
458
                    foreach ($schools as $object) {
Open Source Developer's avatar
Open Source Developer committed
459
                             $status = $this->returnstatus($object -> id());  
Open Source Developer's avatar
Open Source Developer committed
460
                             $list[] = array(
Open Source Developer's avatar
Open Source Developer committed
461 462
                                    'id' =>$object -> id(),
                                    'name' => $object -> name ->value,
Open Source Developer's avatar
Open Source Developer committed
463
                                    'status' => $status
Open Source Developer's avatar
Open Source Developer committed
464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490
                                    );

                                 $i++;
                            }
                            return $this->respondWithStatus(
                                     $list
                                   , Response::HTTP_OK);
                }
                else
                {
                       return $this->respondWithStatus([
                            'message' => t("Perfecture not found!"),
                        ], Response::HTTP_FORBIDDEN);

                }
            }    
            else
            {

                   return $this->respondWithStatus([
                            'message' => t("User not found!"),
                        ], Response::HTTP_FORBIDDEN);
            }

    }


Open Source Developer's avatar
Open Source Developer committed
491 492 493



Open Source Developer's avatar
Open Source Developer committed
494 495 496 497 498 499 500 501
    public function getCoursesPerSchool(Request $request, $schoolid)
    {
      $authToken = $request->headers->get('PHP_AUTH_USER');

        $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
        $user = reset($users);
        if ($user)
            {
Open Source Developer's avatar
Open Source Developer committed
502

Open Source Developer's avatar
Open Source Developer committed
503 504
               $list= array();

Open Source Developer's avatar
Open Source Developer committed
505 506 507 508 509 510 511
                $SchoolCats = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array('id'=> $schoolid ));               
                $SchoolCat = reset($SchoolCats);
                if ($SchoolCat){
                $categ = $SchoolCat-> metathesis_region -> value;
                }
                $CourseA = $this->entityTypeManager->getStorage('epal_student')->loadByProperties(array('id'=> $schoolid ));
               
Open Source Developer's avatar
Open Source Developer committed
512 513
                if ($CourseA)        
                {
Open Source Developer's avatar
Open Source Developer committed
514 515 516 517 518 519
                    $limit_down = $this->entityTypeManager->getStorage('epal_class_limits')->loadByProperties(array('name'=> 1, 'category' => $categ ));
                    $limitdown = reset($limit_down);
                    if ($limitdown)
                    {
                        $limit = $limitdown -> limit_down -> value;
                    }
Open Source Developer's avatar
Open Source Developer committed
520
                    $studentPerSchool = $this->entityTypeManager->getStorage('epal_student_class')->loadByProperties(array('currentepal'=> $schoolid, 'specialization_id' => -1, 'currentclass' => 1 ));
Open Source Developer's avatar
Open Source Developer committed
521 522 523
                    $list = array();
                    foreach ($CourseA as $object) {
                             $list[] = array(
Open Source Developer's avatar
Open Source Developer committed
524
                                    'id' => '1',
Open Source Developer's avatar
Open Source Developer committed
525
                                    'name' => 'Α Λυκείου',
Open Source Developer's avatar
Open Source Developer committed
526 527
                                    'size' => sizeof($studentPerSchool),
                                    'categ' => $categ,
Open Source Developer's avatar
Open Source Developer committed
528 529
                                    'classes' => 1,
                                    'limitdown' => $limit,
Open Source Developer's avatar
Open Source Developer committed
530 531 532 533 534 535 536 537
                                    );
                                
                }            }

            
                $CourseB = $this->entityTypeManager->getStorage('eepal_sectors_in_epal')->loadByProperties(array('epal_id' => $schoolid ));
                if ($CourseB)
                {
Open Source Developer's avatar
Open Source Developer committed
538 539 540 541 542 543 544
                    $limit_down = $this->entityTypeManager->getStorage('epal_class_limits')->loadByProperties(array('name'=> 2, 'category' => $categ ));
                    $limitdown = reset($limit_down);
                    if ($limitdown)
                    {
                        $limit = $limitdown -> limit_down -> value;
                    }

Open Source Developer's avatar
Open Source Developer committed
545
                    foreach ($CourseB as $object) {
Open Source Developer's avatar
Open Source Developer committed
546 547
                    $sectorid = $object -> sector_id -> entity -> id();
                    $studentPerSchool = $this->entityTypeManager->getStorage('epal_student_class')->loadByProperties(array('currentepal'=> $schoolid, 'specialization_id' => $sectorid, 'currentclass' => 2 ));
Open Source Developer's avatar
Open Source Developer committed
548
                         $list[] = array(
Open Source Developer's avatar
Open Source Developer committed
549
                            'id' => $object -> sector_id -> entity -> id(),
Open Source Developer's avatar
Open Source Developer committed
550
                            'name' => 'Β Λυκείου  '.$object -> sector_id -> entity-> get('name')->value,
Open Source Developer's avatar
Open Source Developer committed
551 552
                            'size' => sizeof($studentPerSchool),
                            'categ' => $categ,
Open Source Developer's avatar
Open Source Developer committed
553 554
                            'classes' => 2,
                            'limitdown' => $limit,
Open Source Developer's avatar
Open Source Developer committed
555 556 557 558 559 560 561

                          );
                    }
                }
              $CourseC = $this->entityTypeManager->getStorage('eepal_specialties_in_epal')->loadByProperties(array('epal_id' => $schoolid ));
                if ($CourseC)
                {
Open Source Developer's avatar
Open Source Developer committed
562 563 564 565 566 567 568
                    $limit_down = $this->entityTypeManager->getStorage('epal_class_limits')->loadByProperties(array('name'=> 3, 'category' => $categ ));
                    $limitdown = reset($limit_down);
                    if ($limitdown)
                    {
                        $limit = $limitdown -> limit_down -> value;
                    }

Open Source Developer's avatar
Open Source Developer committed
569
                    foreach ($CourseC as $object) {
Open Source Developer's avatar
Open Source Developer committed
570 571 572
                    $specialityid = $object -> specialty_id -> entity -> id() ;
                    $studentPerSchool = $this->entityTypeManager->getStorage('epal_student_class')->loadByProperties(array('currentepal'=> $schoolid, 'specialization_id' => $specialityid, 'currentclass' => 3 ));

Open Source Developer's avatar
Open Source Developer committed
573
                         $list[] = array(
Open Source Developer's avatar
Open Source Developer committed
574
                            'id'=> $object -> specialty_id -> entity -> id(),
Open Source Developer's avatar
Open Source Developer committed
575
                            'name' => 'Γ Λυκείου  '.$object -> specialty_id -> entity-> get('name')->value,
Open Source Developer's avatar
Open Source Developer committed
576 577
                            'size' => sizeof($studentPerSchool),
                            'categ' => $categ,
Open Source Developer's avatar
Open Source Developer committed
578 579
                            'classes' => 3,
                            'limitdown' => $limit,
Open Source Developer's avatar
Open Source Developer committed
580
                            
Open Source Developer's avatar
Open Source Developer committed
581 582 583
                          );
                    }
                }
Open Source Developer's avatar
Open Source Developer committed
584 585
                if ($CourseA || $CourseB || $CourseC)
                {
Open Source Developer's avatar
Open Source Developer committed
586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606
              
                            return $this->respondWithStatus(
                                     $list
                                   , Response::HTTP_OK);
                }
                else
                {
                       return $this->respondWithStatus([
                            'message' => t("Perfecture not found!"),
                        ], Response::HTTP_FORBIDDEN);

                }
            }    
            else
            {

                   return $this->respondWithStatus([
                            'message' => t("User not found!"),
                        ], Response::HTTP_FORBIDDEN);
            }
    }
Open Source Developer's avatar
Open Source Developer committed
607

Open Source Developer's avatar
Open Source Developer committed
608

Open Source Developer's avatar
Open Source Developer committed
609 610
public function returnstatus($id)
{
Open Source Developer's avatar
Open Source Developer committed
611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678
                $schoolid = $id;
                $SchoolCats = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array('id'=> $schoolid ));               
                $SchoolCat = reset($SchoolCats);
                if ($SchoolCat){
                $categ = $SchoolCat-> metathesis_region -> value;
                }
                $CourseA = $this->entityTypeManager->getStorage('epal_student')->loadByProperties(array('id'=> $schoolid ));
               
                if ($CourseA)        
                {
                    $limit_down = $this->entityTypeManager->getStorage('epal_class_limits')->loadByProperties(array('name'=> 1, 'category' => $categ ));
                    $limitdown = reset($limit_down);
                    if ($limitdown)
                    {
                        $limit = $limitdown -> limit_down -> value;
                    }
                    $studentPerSchool = $this->entityTypeManager->getStorage('epal_student_class')->loadByProperties(array('currentepal'=> $schoolid, 'specialization_id' => -1, 'currentclass' => 1 ));
                    
                    //foreach ($CourseA as $object) {
                            if (sizeof($studentPerSchool) < $limit){
                                return false; 
                                exit;
                            }
                                                         
                }          //  }

            
                $CourseB = $this->entityTypeManager->getStorage('eepal_sectors_in_epal')->loadByProperties(array('epal_id' => $schoolid ));
                if ($CourseB)
                {
                    $limit_down = $this->entityTypeManager->getStorage('epal_class_limits')->loadByProperties(array('name'=> 2, 'category' => $categ ));
                    $limitdown = reset($limit_down);
                    if ($limitdown)
                    {
                        $limit = $limitdown -> limit_down -> value;
                    }

                    foreach ($CourseB as $object) {
                    $sectorid = $object -> sector_id -> entity -> id();
                    $studentPerSchool = $this->entityTypeManager->getStorage('epal_student_class')->loadByProperties(array('currentepal'=> $schoolid, 'specialization_id' => $sectorid, 'currentclass' => 2 ));
                         if (sizeof($studentPerSchool) < $limit){
                                return false; 
                                exit;   
                            }
                    }
                }
                $CourseC = $this->entityTypeManager->getStorage('eepal_specialties_in_epal')->loadByProperties(array('epal_id' => $schoolid ));
                if ($CourseC)
                {
                    $limit_down = $this->entityTypeManager->getStorage('epal_class_limits')->loadByProperties(array('name'=> 3, 'category' => $categ ));
                    $limitdown = reset($limit_down);
                    if ($limitdown)
                    {
                        $limit = $limitdown -> limit_down -> value;
                    }

                    foreach ($CourseC as $object) {
                    $specialityid = $object -> specialty_id -> entity -> id() ;
                    $studentPerSchool = $this->entityTypeManager->getStorage('epal_student_class')->loadByProperties(array('currentepal'=> $schoolid, 'specialization_id' => $specialityid, 'currentclass' => 3 ));

                         if (sizeof($studentPerSchool) < $limit){
                                return false;
                                exit; 
                                }   
                    }
                }
                return true;
                exit; 
Open Source Developer's avatar
Open Source Developer committed
679
}
Open Source Developer's avatar
Open Source Developer committed
680 681


Open Source Developer's avatar
Open Source Developer committed
682

Open Source Developer's avatar
Open Source Developer committed
683
public function findCapacity(Request $request,$taxi,$tomeas,$specialit)
Open Source Developer's avatar
Open Source Developer committed
684 685 686
    {

    $tomeasnew = intval($tomeas);
Open Source Developer's avatar
Open Source Developer committed
687
    $specialitnew = intval($specialit) ;
Open Source Developer's avatar
Open Source Developer committed
688 689 690 691 692
       $authToken = $request->headers->get('PHP_AUTH_USER');

        $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
         $user = reset($users);
         if ($user) {
Open Source Developer's avatar
Open Source Developer committed
693
            $schoolid = $user ->  init -> value;
Open Source Developer's avatar
Open Source Developer committed
694
           $schools = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array('id'=> $schoolid));
Open Source Developer's avatar
Open Source Developer committed
695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718
             $school = reset($schools);
             if (!$school) {
                 $this->logger->warning("no access to this school=" . $user->id());
                 $response = new Response();
                 $response->setContent('No access to this school');
                 $response->setStatusCode(Response::HTTP_FORBIDDEN);
                 $response->headers->set('Content-Type', 'application/json');
                 return $response;
             }
                     
              $list = array();

                if (($tomeasnew == 0) && ($specialitnew == 0))
                {
                 $CapacityPerClass = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array('id' => $schoolid ));
                 $classcapacity = reset($CapacityPerClass);
                 
                
                  if ($classcapacity) {
                        
                       
                    $list[] = array(
                        'taxi' => $taxi,
                       'capacity' => $classcapacity -> capacity_class_a -> value ,
Open Source Developer's avatar
Open Source Developer committed
719
                       ); 
Open Source Developer's avatar
Open Source Developer committed
720 721 722 723 724 725 726 727 728 729 730 731 732 733
                    }
                }


                if (($tomeasnew != 0) && ($specialitnew == 0))
                {
                 $CapacityPerClass = $this->entityTypeManager->getStorage('eepal_sectors_in_epal')->loadByProperties(array('epal_id' => $schoolid, 'sector_id' => $tomeasnew ));
                 $classcapacity = reset($CapacityPerClass);
                  if ($classcapacity) {
                    $list[] = array(
                        'taxi' => $taxi,
                        'tomeas' => $tomeasnew,
                        'special' =>$specialitnew,
                        'capacity' => $classcapacity -> capacity_class_sector -> value ,
Open Source Developer's avatar
Open Source Developer committed
734
                        'sector' =>$tomeasnew."lala".$specialitnew
Open Source Developer's avatar
Open Source Developer committed
735 736 737 738 739
                        );
                    }
                }


Open Source Developer's avatar
Open Source Developer committed
740
                if (($tomeasnew != 0) && ($specialitnew != 0) && ($taxi == 3))
Open Source Developer's avatar
Open Source Developer committed
741 742 743 744 745 746 747 748 749 750
                {
                 $CapacityPerClass = $this->entityTypeManager->getStorage('eepal_specialties_in_epal')->loadByProperties(array('epal_id' => $schoolid, 'specialty_id' => $specialitnew));
                 $classcapacity = reset($CapacityPerClass);
                  if ($classcapacity) {
                    $list[] = array(
                        'taxi' =>$taxi,
                        'tomeas' => $tomeasnew,
                        'special' =>$specialitnew,
                        'tomeas' =>  $classcapacity ->  specialty_id -> value,
                        'capacity' => $classcapacity -> capacity_class_specialty -> value ,
Open Source Developer's avatar
Open Source Developer committed
751
                        'specialty' =>"fromspeciality"
Open Source Developer's avatar
Open Source Developer committed
752 753 754 755
                        );
                    }
                }

Open Source Developer's avatar
Open Source Developer committed
756 757 758 759 760 761 762 763 764 765 766 767 768 769 770
                if (($tomeasnew != 0) && ($specialitnew != 0) && ($taxi == 4))
                {
                 $CapacityPerClass = $this->entityTypeManager->getStorage('eepal_specialties_in_epal')->loadByProperties(array('epal_id' => $schoolid, 'specialty_id' => $specialitnew));
                 $classcapacity = reset($CapacityPerClass);
                  if ($classcapacity) {
                    $list[] = array(
                        'taxi' =>$taxi,
                        'tomeas' => $tomeasnew,
                        'special' =>$specialitnew,
                        'tomeas' =>  $classcapacity ->  specialty_id -> value,
                        'capacity' => $classcapacity -> capacity_class_specialty_d -> value ,
                        'specialty' =>"fromspecialityd"
                        );
                    }
                }
Open Source Developer's avatar
Open Source Developer committed
771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788





                      return $this->respondWithStatus(
                                     $list
                                   , Response::HTTP_OK);
            

            } else {
            return $this->respondWithStatus([
                    'message' => t("EPAL user not found"),
                ], Response::HTTP_FORBIDDEN);
        }
    }


Open Source Developer's avatar
Open Source Developer committed
789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823

public function getSchoolID(Request $request)
    {

        $authToken = $request->headers->get('PHP_AUTH_USER');

        $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
         $user = reset($users);
         if ($user) {
                    $schid = intval($user ->  init -> value );
                    $list = array();
                    $list[] = array(
                             'id' =>  $schid
                        );

                     $i++;
       

                return $this->respondWithStatus(
                        $list
                    , Response::HTTP_OK);
 


            } else {

            return $this->respondWithStatus([
                    'message' => t("User not found!"),
                ], Response::HTTP_FORBIDDEN);
        }

    }



Open Source Developer's avatar
Open Source Developer committed
824 825
public function gettypeofschool(Request $request)
    {
Open Source Developer's avatar
Open Source Developer committed
826

Open Source Developer's avatar
Open Source Developer committed
827
        $authToken = $request->headers->get('PHP_AUTH_USER');
Open Source Developer's avatar
Open Source Developer committed
828

Open Source Developer's avatar
Open Source Developer committed
829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854
        $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
         $user = reset($users);
         if ($user) {
                $schid = intval($user ->  init -> value );
                $schools = $this->entityTypeManager->getStorage('eepal_school')->
                 loadByProperties(array('id' => $schid));
                 $school = reset($schools);
                if (!$school) {
                     $this->logger->warning("no access to this school=" . $user->id());
                     $response = new Response();
                     $response->setContent('No access to this school');
                     $response->setStatusCode(Response::HTTP_FORBIDDEN);
                     $response->headers->set('Content-Type', 'application/json');
                     return $response;
                 }
                 else
                 {
                        $list = array();
                        $list[] = array(
                            'type' =>  $school ->  operation_shift  -> value,    
                            );
                        return $this->respondWithStatus(
                            $list
                        , Response::HTTP_OK);
     
                }
Open Source Developer's avatar
Open Source Developer committed
855

Open Source Developer's avatar
Open Source Developer committed
856
            } else {
Open Source Developer's avatar
Open Source Developer committed
857

Open Source Developer's avatar
Open Source Developer committed
858 859 860 861
            return $this->respondWithStatus([
                    'message' => t("User not found!"),
                ], Response::HTTP_FORBIDDEN);
        }
Open Source Developer's avatar
Open Source Developer committed
862

Open Source Developer's avatar
Open Source Developer committed
863
    }
Open Source Developer's avatar
Open Source Developer committed
864 865


866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974


    public function getlimitsperCourse(Request $request, $classid)
    {
      $authToken = $request->headers->get('PHP_AUTH_USER');

        $users = $this->entityTypeManager->getStorage('user')->loadByProperties(array('name' => $authToken));
        $user = reset($users);
        if ($user)
            {
              $schoolid = $user ->  init -> value;
               $list= array();

                $SchoolCats = $this->entityTypeManager->getStorage('eepal_school')->loadByProperties(array('id'=> $schoolid ));               
                $SchoolCat = reset($SchoolCats);
                if ($SchoolCat){
                $categ = $SchoolCat-> metathesis_region -> value;
                
                 $list = array();
               if ($classid == 1)
               {
               
                    $limit_down = $this->entityTypeManager->getStorage('epal_class_limits')->loadByProperties(array('name'=> 1, 'category' => $categ ));
                    $limitdown = reset($limit_down);
                    if ($limitdown)
                    {
                        $limit = $limitdown -> limit_down -> value;
                    }
                    
                   
                    
                             $list[] = array(
                                    'id' => '1',
                                    'name' => 'Α Λυκείου',
                                    'categ' => $categ,
                                    'classes' => 1,
                                    'limitdown' => $limit,
                                    );
                                
                }            

            
                if ($classid == 2){
                    $limit_down = $this->entityTypeManager->getStorage('epal_class_limits')->loadByProperties(array('name'=> 2, 'category' => $categ ));
                    $limitdown = reset($limit_down);
                    if ($limitdown)
                    {
                        $limit = $limitdown -> limit_down -> value;
                    }

                    
                    
                         $list[] = array(
                            
                            'name' => 'Β Λυκείου ',
                            
                            'categ' => $categ,
                            'classes' => 2,
                            'limitdown' => $limit,

                          );
                    }
                
                
                if ($classid == 3){
                    $limit_down = $this->entityTypeManager->getStorage('epal_class_limits')->loadByProperties(array('name'=> 3, 'category' => $categ ));
                    $limitdown = reset($limit_down);
                    if ($limitdown)
                    {
                        $limit = $limitdown -> limit_down -> value;
                    }

                    
                    
                         $list[] = array(
                            
                            
                            'categ' => $categ,
                            'classes' => 3,
                            'limitdown' => $limit,
                            
                          );
                    }
                
               
              
                            return $this->respondWithStatus(
                                     $list
                                   , Response::HTTP_OK);
                }
                else
                {
                       return $this->respondWithStatus([
                            'message' => t("Perfecture not found!"),
                        ], Response::HTTP_FORBIDDEN);

                }
            }    
            else
            {

                   return $this->respondWithStatus([
                            'message' => t("User not found!"),
                        ], Response::HTTP_FORBIDDEN);
            }
    }



Open Source Developer's avatar
Open Source Developer committed
975 976 977 978 979 980 981 982 983 984 985
   private function respondWithStatus($arr, $s) {
        $res = new JsonResponse($arr);
        $res->setStatusCode($s);
        return $res;
    }





}