public function showSimpleCodes($date)
 {
     $date = date_create($date);
     $sc = new Settings_controller();
     $codes = $sc->getSimpleVksCodeParams();
     $codeRange = range(floatval($codes->code['start']), floatval($codes->code['end']));
     $rangeStringed = [];
     foreach ($codeRange as $code) {
         $rangeStringed[] = (string) $code;
     }
     if (count($rangeStringed)) {
         $vkses = Vks::simple()->where('date', $date)->with(['connection_codes' => function ($query) use($rangeStringed) {
             $query->whereIn('value', $rangeStringed);
         }])->get();
         $collected = [];
         foreach ($rangeStringed as $code) {
             $collected[$code] = [];
             foreach ($vkses as $vks) {
                 foreach ($vks->connection_codes as $code_vk) {
                     $code_vk->value == $code ? $collected[$code][] = $vks : false;
                 }
             }
         }
         $date = $date->format('d.m.Y');
         $this->render('Dashboards/showSimpleCodes', compact('collected', 'date'));
     } else {
         die('range is corrupted');
     }
 }
 public function apiGetCodesInUse()
 {
     //post data get
     $start_date = $this->request->request->get("start_date");
     $end_date = $this->request->request->get("end_date");
     if (!$start_date || !$end_date) {
         return print new Response('params has wrong names', Response::HTTP_FAILED_DEPENDENCY);
     }
     try {
         $start = date_create($start_date)->format("Y-m-d H:i");
         $end = date_create($end_date)->format("Y-m-d H:i");
     } catch (Exception $e) {
         return print new Response('params can\'t be converted to dates', Response::HTTP_CONFLICT);
     }
     if (date_create($start_date) > date_create($end_date)) {
         return print new Response('start bigger than end', Response::HTTP_FAILED_DEPENDENCY);
     }
     $sc = new Settings_controller();
     $connCtrl = new ConnectionCode_controller();
     $codesLoadSet = [];
     foreach ($sc->getCodesPostfixSet() as $postfixCode) {
         $vksSearch = $connCtrl->isCodeInUse($postfixCode, $start, $end, true);
         $codesLoadSet[] = array('code' => $postfixCode, 'usage' => isset($vksSearch->id) ? ST::linkToVksPage($vksSearch->id, true) : false);
     }
     print json_encode($codesLoadSet, JSON_PRETTY_PRINT);
 }
 public function apiSearchFastTree($phrase, $except = [], $dateTimeforCheck = [])
 {
     if (!is_array($except) && strlen($except) > 0) {
         $except = explode(",", $except);
     }
     if (!is_array($except) && strlen($except) > 0) {
         $except = explode(",", $except);
     }
     $strict_option = intval(Settings_controller::getOther('attendance_strict'));
     $result = [];
     $points = Attendance::where("name", "like", "%" . $phrase . "%")->where('active', 1)->whereNotIn("id", $except)->take(500)->get();
     foreach ($points as $point) {
         $point->free = true;
         $point->selectable = true;
         $point->path = $this->makePathString($this->fullParentInfo($point->id));
         if ($point->container) {
             $result['containers'][] = $point;
         } else {
             if ($point->check) {
                 if (count($dateTimeforCheck)) {
                     foreach ($dateTimeforCheck as $dateTimeArr) {
                         $start = date_create($dateTimeArr['date'] . " " . $dateTimeArr['start_time']);
                         $end = date_create($dateTimeArr['date'] . " " . $dateTimeArr['end_time']);
                         //                            dump($point->id, $start, $end);
                         $check = $this->isFree($point->id, $start, $end);
                         //                            die;
                         if (!$check) {
                             $point->free = false;
                             if ($strict_option) {
                                 if (!Auth::isAdmin(App::$instance)) {
                                     $point->selectable = false;
                                 }
                             }
                             break;
                         }
                     }
                 }
             }
             $result['points'][] = $point;
         }
     }
     print json_encode($result);
 }
 private function getServerCapacity($serverNum)
 {
     $settings = new Settings_controller();
     return $settings->getServerParam($serverNum)['capacity'];
 }
 function showNaVks($id)
 {
     $versionCtrl = new VksVersion_controller();
     $load = new Load_controller();
     $sc = new Settings_controller();
     try {
         $vks = Vks::NotSimple()->full()->findOrFail($id);
     } catch (Exception $e) {
         $this->error('404', $e->getMessage());
     }
     $vks = $this->humanize($vks);
     $att = new AttendanceNew_controller();
     $check = boolval(intval(Settings_controller::getOther("attendance_check_enable")));
     foreach ($vks->participants as $parp) {
         if ($check) {
             $parp->free = $att->isFree($parp->id, $vks->start_date_time, $vks->end_date_time, [$vks->id]);
         } else {
             $parp->free = true;
         }
     }
     if (!self::isVksCanBeApproved($vks)) {
         $this->error('500', 'Открыть экран согласования по этой ВКС невозможно, переведите эту ВКС в статус "на согласовании" и попробуйте еще раз');
     }
     $vks->isPassebByCapacity = $load->isPassedByCapacity($vks->start_date_time, $vks->end_date_time, $this->countParticipants($vks->id), 0);
     $caVks = Null;
     if ($vks->link_ca_vks_id) {
         if ($vks->link_ca_vks_type == 0) {
             $caVks = Curl::get(ST::routeToCaApi('getVksWasById/' . $vks->link_ca_vks_id));
         } else {
             $caVks = Curl::get(ST::routeToCaApi('getVksNsById/' . $vks->link_ca_vks_id));
         }
         $caVks = json_decode($caVks);
         if ($caVks->status == 200) {
             $caVks = $caVks->data;
         } else {
             $caVks = Null;
         }
     }
     $codes = $sc->getCodeDelivery(true);
     $versions = $versionCtrl->getVersionsList($vks->id);
     $last_version = null;
     if (count($versions)) {
         $last_version = $versionCtrl->pullVersion($vks->id, $versionCtrl->findLastVersion($vks->id));
     }
     if ($vks->stack) {
         foreach ($vks->stack->vkses as $stVks) {
             $this->humanize($stVks);
             $stVks->connection_codes = $stVks->connection_codes()->get();
         }
     }
     if ($vks->other_tb_required) {
         $vks->CaInPlaceParticipantCount;
         $vks->CaIdParticipants;
     }
     $codesFiltrated = array();
     $ca_pool_codes = App::$instance->callService("vks_ca_negotiator")->askForPool();
     $currentVksStart = clone $vks->start_date_time;
     $currentVksEnd = clone $vks->end_date_time;
     if (count($ca_pool_codes)) {
         $ca_transport_vkses = App::$instance->callService("vks_ca_negotiator")->aksTransportVksInPeriod($currentVksStart, $currentVksEnd, $ca_pool_codes);
         foreach ($ca_pool_codes as $code) {
             $codesFiltrated[$code] = array();
             if (count($ca_transport_vkses)) {
                 foreach ($ca_transport_vkses as $ca_tr_vks) {
                     if ($code == $ca_tr_vks->v_room_num) {
                         $codesFiltrated[$code][] = $ca_tr_vks;
                     }
                 }
             }
         }
     }
     $graph = $load->pullLoadDataForJs($vks->humanized->date);
     $this->render('vksSubmissions/approvePage', compact('vks', 'graphUrl', 'caVks', 'versions', 'codes', 'last_version', 'graph', 'codesFiltrated'));
 }