public function deleteRent() { global $config; // lettura valori $view = new VAdmin(); $row = intval($view->getRow()); // fila $number = intval($view->getNumber()); // numero $sdate = $view->getStartDate(); // data di inizio $edate = $view->getEndDate(); // data di fine $periodsdate = $view->getPeriodSdate(); $periodedate = $view->getPeriodEdate(); $flag = true; $FRate = new FRate(); $FRent = new FRent(); $season = false; if ($periodsdate == 'STAGIONE' && $periodedate == 'STAGIONE') { //$seasonRates = $FRate->getSeasonRates(); // tariffa stagionale $periodsdate = new DateTime($config['season_start']); $periodedate = new DateTime($config['season_end']); $season = true; } else { try { $periodsdate = new DateTime($periodsdate); $periodedate = new DateTime($periodedate); } catch (Exception $e) { $flag = false; } } if ($flag) { try { $sdate = new DateTime($sdate); $edate = new DateTime($edate); } catch (Exception $e) { $flag = false; } } if ($flag) { $Fumb = new FUmbrella(); $umb = $Fumb->loadUmbrella($row, $number); if (!$umb) { $flag = false; } } if ($flag) { if ($FRent->is_Rent($umb, $sdate) == 0) { $flag = false; } } if ($flag) { $bool = $FRent->deleteRent($umb, $sdate); // cancello if (!$bool) { echo 'error'; } else { $numRent = count($FRent->getRentByPeriod($periodsdate, $periodedate, $umb)); if ($numRent > 0) { echo '0'; } else { /*$season = false; if($sdate == $seasonStart && $edate== $seasonEnd) // se la tariffa è stagionale $season = true;*/ $price = $this->getPrice($umb, $periodsdate, $periodedate, $season); // calcolo il prezzo dell'ombrellone $lenght = strlen("{$price}"); echo "1{$lenght}" . "{$price}"; } } } else { echo 'error'; } // da modificare la risposta }
public function rent() { global $config; $maxUmb = $config['max']; $FUmbrella = new FUmbrella(); $USession = new USession(); $view = new VRent(); $row = intval($view->getRow()); $number = intval($view->getNumber()); $start = $view->getStartDate(); $end = $view->getEndDate(); $owner = new DPerson($USession->getValue('name'), $USession->getValue('surname'), $USession->getValue('ssn'), $USession->getValue('phone')); $flag = true; $FRate = new FRate(); $FRent = new FRent(); $today = new DateTime('now'); $numUmb = $FRent->getNumRent($USession->getValue('ssn'), $today->format('y-m-d')); $season = false; //$seasonRate = $FRate->getSeasonRates(); // tariffa stagionale $startSeason = new DateTime($config['season_start']); $endSeason = new DateTime($config['season_end']); try { if ($start == 'STAGIONE' && $end == 'STAGIONE') { $t = clone $startSeason; $end = $endSeason; $t->add(new DateInterval('P20D')); // data massima per stagionale if ($today > $t) { $start = $today; } else { $start = $startSeason; $season = true; } } else { $start = new DateTime($start); $end = new DateTime($end); if ($start < new DateTime('yesterday') || $end < new DateTime('yesterday')) { $flag = false; } } $FUmbrella = new FUmbrella(); $umbrella = $FUmbrella->loadUmbrella($row, $number); if (!$umbrella) { $flag = false; } if (!$FUmbrella->isFree($start->format('y-m-d'), $end->format('y-m-d'), $umbrella)) { $flag = false; } if (!($FRate->isInSeason($start->format('y-m-d')) && $FRate->isInSeason($end->format('y-m-d')))) { $flag = false; } if ($end < $start) { $flag = false; } if ($numUmb >= $maxUmb) { $flag = false; } } catch (Exception $e) { $flag = false; } if ($flag) { $t = clone $startSeason; $t->add(new DateInterval('P20D')); // data entro la quale è stagionale $t1 = clone $end; $t1->add(new DateInterval('P10D')); if ($start <= $t && $t1 >= $endSeason) { $season = true; } if (!$season) { $rates = $FRate->getRateByLine($start->format('y-m-d'), $end->format('y-m-d'), $umbrella->getRow()); // array di tariffe da considerare $period = date_diff($start, $end); $period = $period->format('%a') + 1; // periodo in giorni richiesto dal cliente $tar = count($rates); if ($tar > 0) { // il peirodo scelto appartiene ad una sola tariffa(periodo) $this->getRateArray($rates, $period, $start, $owner, $umbrella); } else { $rates = $FRate->getOtherRateByLine($start->format('y-m-d'), $end->format('y-m-d'), $umbrella->getRow()); foreach ($rates as $r) { $f = true; if ($r[0]->getStartPeriod() <= $start) { $period = date_diff($start, $r[0]->getEndPeriod()); $period = $period->format('%a') + 1; $this->getRateArray($r, $period, $start, $owner, $umbrella); $f = false; } if ($end <= $r[0]->getEndPeriod()) { $period = date_diff($r[0]->getStartPeriod(), $end); $period = $period->format('%a') + 1; $this->getRateArray($r, $period, $r[0]->getStartPeriod(), $owner, $umbrella); $f = false; } if ($f) { $period = date_diff($r[0]->getStartPeriod(), $r[0]->getEndPeriod()); $period = $period->format('%a') + 1; $this->getRateArray($r, $period, $r[0]->getStartPeriod(), $owner, $umbrella); } } // fine foreach } // fine else echo '0'; } else { $price = $seasonRate[$umbrella->getRow()]->getPrice(); $Rent = new DRent($owner, $umbrella, false, $price, new DateTime($config['season_start']), new DateTime($config['season_end'])); $FRent->saveRent($Rent); echo '0'; } } else { echo 'error'; } // codice se nel caso i dati arrivati sono sbagliati }
public function getRentBySSN($ssn) { global $config; $start = $config['season_start']; $end = $config['season_end']; if ($start != "closed" && $end != "closed") { $Fu = new FUmbrella(); $Fp = new FPerson(); $query = "SELECT * FROM rent WHERE \n\t\t\t(startDate>='{$start}' AND endDate<='{$end}') AND SSNOwner = '{$ssn}'"; $temp = $this->query($query); if ($temp) { $results = array(); foreach ($temp as $t) { $umb = $Fu->loadUmbrella($t['linUmb'], $t['numUmb']); $person = $Fp->getOwnerBySSN($t['SSNOwner']); $startD = new DateTime($t['startDate']); $endD = new DateTime($t['endDate']); if ($t['state'] == 1) { $state = true; } else { $state = false; } $results[] = new DRent($person, $umb, $state, intval($t['price']), $startD, $endD); } } else { throw new Exception("Query Failed getRentBySSN FRent"); } return $results; } else { return false; } }