Linux ip-172-26-7-228 5.4.0-1103-aws #111~18.04.1-Ubuntu SMP Tue May 23 20:04:10 UTC 2023 x86_64
Your IP : 3.137.219.221
<?php
error_reporting(E_ALL);
ini_set('display_errors','on');
class room_allotment
{
function __construct($aobj_context)
{
session_start();
$this->aobj_context=$aobj_context;
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$this->user_id = $_SESSION['user_id'];
$this->funivcode = $_SESSION['FUNIVCODE'];
$this->collcode = $_SESSION['collcode'];
$this->log_name = $_SESSION['usr'];
}
function DisplayIARoomAllotmentDetatilsDatewise()
{
session_start();
ini_set('max_execution_time', '400');
$this->collcode=$_SESSION['collcode'];
$frm_date = ($this->aobj_context->mobj_data["frm_date"]);
$session = ($this->aobj_context->mobj_data["session"]);
$ra_from = ($this->aobj_context->mobj_data["ra_from"]);
$ra_to = ($this->aobj_context->mobj_data["ra_to"]);
$canddet = "marks";
$subject = "subject";
$room_allotment = "room_allotment";
$query1 = "SELECT COUNT(DISTINCT cd.FREGNO) AS reg_cnt
FROM {$canddet} cd INNER JOIN {$subject} s ON s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FCSUBCODE = cd.FSUBCODE
inner join degree dd on cd.fdegree=dd.fdegree
and dd.fexamno=cd.fexamno
inner join iatimetable t on
cd.fcollcode = t.fcollcode and cd.fexamno = t.fexamno
and cd.fsubcode = t.fsubcode
and cd.fdegree = t.fdegree
WHERE t.fdoe = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
and t.fsession = '{$session}'
and cd.fcollcode = '{$this->collcode}'
GROUP BY t.fdoe";
$results1 = $this->aobj_context->mobj_db->GetRow($query1);
$reg_cnt = $results1['reg_cnt'];
//var_dump($reg_cnt);
$query1 = "select sum(fcapacity) as fcapacity from iamasroom where
froomno >= '0'
AND froomno <='z'
and fcollcode = '{$this->collcode}'
order by forder";
$results1 = $this->aobj_context->mobj_db->GetRow($query1);
$fcapacity = $results1['fcapacity'];
if($reg_cnt > $fcapacity)
{
$arr = "Insufficient Rooms for the allotment. Total Capacity : ".$fcapacity." Total Strength :".$reg_cnt;
echo $this->aobj_context->mobj_output->ToJSONEnvelope($arr,-1,"failure");
return;
}
$query = "update iamasroom set fbalroomcnt = fcapacity where froomno >= '0'
AND froomno <='z' AND fcollcode = '{$this->collcode}'";
$rst1 = $this->aobj_context->mobj_db->Execute($query);
$query = "SELECT COUNT(DISTINCT cd.FREGNO) AS reg_cnt,t.fdoe,cd.fsubcode
FROM {$canddet} cd INNER JOIN {$subject} s ON s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FCSUBCODE = cd.FSUBCODE
inner join timetable t on cd.fcollcode = t.fcollcode
and cd.fexamno = t.fexamno
and cd.fdegree = t.fdegree
and cd.fsubcode = t.fsubcode
WHERE t.fdoe = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
and t.fsession = '{$session}'
and cd.fcollcode = '{$this->collcode}'
GROUP BY cd.fsubcode,cd.FREGNO
ORDER BY reg_cnt DESC,cd.FREGNO,s.fsession";
//var_dump($query);
$results = $this->aobj_context->mobj_db->GetAll($query);
$k = 1;
foreach($results as $ak=>$value)
{
$reg_cnt = $value['reg_cnt'];
$fsubcode = $value['fsubcode'];
//var_dump($qpcode);
$query2 ="SELECT * FROM iamasroom
WHERE froomno >= '{$ra_from}'
AND froomno <='{$ra_to}'
AND fcollcode = '{$this->collcode}'
and fcapacity > 0
order by forder,froomno";
$restults = $this->aobj_context->mobj_db->GetAll($query2);
foreach($restults as $key => $value)
{
if($value['fbalroomcnt'] <= 0)
continue;
if($value['fmaxqpcnt'] == 0)
{
$value['fmaxqpcnt'] = 1;
}
$capacity = $value['fcapacity'];
$studperqp = round($value['fcapacity'] / $value['fmaxqpcnt']);
$balroomcnt = $value['fcapacity'] - $studperqp;
if($reg_cnt < $studperqp)
$studperqp = $reg_cnt;
if($value['fbalroomcnt'] <= $studperqp)
$studperqp = $value['fbalroomcnt'];
$query1 = "SET SESSION group_concat_max_len=100000";
$results1 = $this->aobj_context->mobj_db->Execute($query1);
$query = "select group_concat(distinct concat(\"'\",cd.FREGNO,\"'\") order by cd.fregno) as fregno
from {$canddet} cd
where cd.fsubcode = '{$qpcode}'
and ifnull(cd.FHALLNO,'') = ''
and cs.fcollcode = '{$this->collcode}'
order by cd.fregno
limit {$studperqp}";
$rst3 = $this->aobj_context->mobj_db->GetRow($query);
$regarr = explode(',',$rst3['fregno']);
$regnoin = array_slice($regarr,0,$studperqp);
$regnoin = implode(',',$regnoin);
$query = "update {$canddet} set FHALLNO = '{$value['froomno']}'
where fregno in ({$regnoin}) and fsubcode = '{$fsubcode}'";
//var_dump($query);
$rst1 = $this->aobj_context->mobj_db->Execute($query);
$rows_affected = $this->aobj_context->mobj_db->affected_rows();
// var_dump($rows_affected,$qpcode,$value['froomno']);
// var_dump($query);
if($rows_affected)
{
$query = "update iamasroom set fbalroomcnt = ({$value['fbalroomcnt']} - $rows_affected)
where froomno = '{$value['froomno']}'
and fcollcode = '{$this->collcode}'";
//var_dump($query);
$rst1 = $this->aobj_context->mobj_db->Execute($query);
$insert = " insert into {$room_allotment}(FCOLLCODE,FQPCODE,FHALLNO,FCAPACITY,FLOGNAME,FLOGDATE,FDOE,FSESSION,FORDER )
values ('{$this->collcode}','{$fsubcode}' ,'{$value['froomno']}','{$rows_affected}','{$this->log_name}',now(),{date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')},'{$session}','{$k}')";
//$lobj_insert = $this->aobj_context->mobj_db->Execute($insert);
$insert = " insert into {$room_allotment}(FCOLLCODE,FQPCODE,FHALLNO,FCAPACITY,FLOGNAME,FLOGDATE,FDOE,FSESSION,FORDER,FBATCH )
values ('{$this->collcode}','{$fsubcode}' ,'{$value['froomno']}','{$rows_affected}','{$this->log_name}',now(),date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d'),'{$session}','{$k}','{$fbatch}')
ON DUPLICATE KEY UPDATE
FCOLLCODE = '{$this->collcode}',
FQPCODE = '{$fsubcode}',
FHALLNO = '{$value['froomno']}',
FCAPACITY = '{$rows_affected}',
FLOGNAME = '{$this->log_name}',
FLOGDATE = now(),
FDOE = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d'),
FSESSION = '{$session}',
FORDER = '{$k}',
FBATCH = '{$fbatch}'";
$lobj_insert = $this->aobj_context->mobj_db->Execute($insert);
}
else
{
break;
}
}
$k++;
}
if($alternative == 'T')
{
}else
{
$query = "SELECT distinct cd.fhallno
FROM {$canddet} cd INNER JOIN {$subject} s ON s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FCSUBCODE = cd.FSUBCODE
inner join timetable t on cd.fcollcode = t.fcollcode
and cd.fexamno = t.fexamno
and cd.fdegree = t.fdegree
and cd.fsubcode = t.fsubcode
WHERE t.fdoe = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
and cs.fcollcode = '{$this->collcode}'
and t.fsession = '{$session}'
order by cd.fhallno";
//var_dump($query);
$results = $this->aobj_context->mobj_db->GetAll($query);
foreach($results as $value)
{
$query = "update {$canddet} x, (select right(concat('000',@a:=@a+1),3) as fslno, fregno, fsubcode, fhallno
from (select cd.fdegree, cd.fcollcode,
cd.fregno,cd.fsubcode, cd.fhallno from {$canddet} cd, {$subject} s, timetable t
where s.fdegree = cd.fdegree
AND s.fexamno = cd.fexamno AND s.FCSUBCODE = cd.FSUBCODE
and cd.fcollcode = t.fcollcode
and cd.fexamno = t.fexamno
and cd.fdegree = t.fdegree
and cd.fsubcode = t.fsubcode
and t.fdoe = date_format(STR_TO_DATE('{$frm_date}', '%d/%m/%Y'),'%Y-%m-%d')
and t.fsession = '{$session}'
AND cd.fhallno = '{$value['fhallno']}'
and cs.fcollcode = '{$this->collcode}'
order by cd.fsubcode,fregno) b, (SELECT @a:= '000') AS a) y
set x.fslno = y.fslno
where x.fsubcode = y.fsubcode
and x.fhallno = y.fhallno
and x.fregno = y.fregno";
$lobj_insert = $this->aobj_context->mobj_db->Execute($query);
//$query = "";
//var_dump($query); and cd.fregno in(select distinct fregno from student where fcollcode = '{$this->collcode}' order by fregno)
}
}
echo $this->aobj_context->mobj_output->ToJSONEnvelope($arr,0,"success");
return;
}
}
function DisplayIARoomAllotmentDetatilsDatewise($aobj_context)
{
$class_obj=new room_allotment($aobj_context);
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$class_obj->DisplayIARoomAllotmentDetatilsDatewise();
}
function getIARoomdetails($aobj_context)
{
session_start();
$aobj_context->mobj_db->SetFetchMode(ADODB_FETCH_ASSOC);
$collcode = $_SESSION['collcode'];
$query = "select froomno as id, froomname as value from iamasroom
where fcollcode = '{$collcode}'
and fcapacity > 0 order by froomno ";
$rst1 = $aobj_context->mobj_db->getAll($query);
$query = "select distinct fsession as id, fsession as value from iatimetable
where fcollcode = '{$collcode}'";
$rst2 = $aobj_context->mobj_db->getAll($query);
$rst['rooms'] = $rst1;
$rst['session'] = $rst2;
echo $aobj_context->mobj_output->ToJSONEnvelope($rst,0,"success");
return;
}
?>
|