338 lines
10 KiB
PHP
338 lines
10 KiB
PHP
<?php
|
|
# Hier werden die Anfragen vom Javascript verarbeitet und die
|
|
# Datenbank bedient
|
|
|
|
include '../../../config_stern.php';
|
|
include '../../../phpmailer/dosendmail.php';
|
|
|
|
|
|
// Holen der Einträge in der anmelde-Datenbank für den selektierten Tag
|
|
// Parameter
|
|
// $special -> was muss geholt werden
|
|
// $date -> Datum, für das geholt wird
|
|
//
|
|
// Return:
|
|
// Array mit den Einträgen
|
|
function getAnmeldungenNew($special, $date)
|
|
{
|
|
global $db, $table;
|
|
$retur = [];
|
|
$retur['error'] = false;
|
|
$retur['errortext'] = '';
|
|
$erg = array();
|
|
if ($special == 'total') {
|
|
$sql_stmt = "SELECT * FROM $table";
|
|
} else if ($special == 'all') {
|
|
$sql_stmt = "SELECT * FROM $table WHERE name != '-'";
|
|
} else if ($special == 'abgesagt') {
|
|
$sql_stmt = "SELECT * FROM $table WHERE abgesagt=1 AND name != '-'";
|
|
} else if ($special == 'nichtda') {
|
|
$sql_stmt = "SELECT * FROM $table WHERE DATE_ADD(DATE(fdatum),INTERVAL 1 DAY)<=DATE(NOW()) AND teilgenommen = 0 AND name != '-'";
|
|
} else if ($special == 'zualt') {
|
|
$sql_stmt = "SELECT * FROM $table WHERE DATE_ADD(DATE(fdatum),INTERVAL $date DAY)<=DATE(NOW()) AND name != '-'";
|
|
} else if ($special == 'alllater'){
|
|
$sql_stmt = "SELECT * FROM $table WHERE fdatum > '$date' AND name != '-' ORDER BY fdatum";
|
|
} else if ($special == 'normal'){
|
|
$sql_stmt = "SELECT * FROM $table WHERE fdatum = '$date'";
|
|
} else {
|
|
$retur['error'] = 'false';
|
|
$retur['errortext'] = 'Falsches SELECT Statement!';
|
|
$retur['data'] = [];
|
|
return $retur;
|
|
}
|
|
$result = mysqli_query($db, $sql_stmt) or die(mysqli_error($db));
|
|
while ($row = mysqli_fetch_assoc($result)) {
|
|
foreach($row as $key => $value) {
|
|
$entry[$key] = $value;
|
|
}
|
|
$erg[] = $entry;
|
|
}
|
|
$retur['data'] = $erg;
|
|
return $retur;
|
|
}
|
|
|
|
// Holen der Einträge in der anmelde-Datenbank für den selektierten Tag
|
|
// Parameter
|
|
// $special -> was muss geholt werden
|
|
// $date -> Datum, für das geholt wird
|
|
//
|
|
// Return:
|
|
// Array mit den Einträgen
|
|
function getSonderNew($special, $date)
|
|
{
|
|
global $db, $table;
|
|
$retur = [];
|
|
$retur['error'] = false;
|
|
$retur['errortext'] = '';
|
|
$erg = array();
|
|
/* if ($special == 'total') {
|
|
$sql_stmt = "SELECT * FROM anmeldungen";
|
|
} else if ($special == 'all') {
|
|
$sql_stmt = "SELECT * FROM anmeldungen WHERE name != '-'";
|
|
} else if ($special == 'abgesagt') {
|
|
$sql_stmt = "SELECT * FROM anmeldungen WHERE abgesagt=1 AND name != '-'";
|
|
} else if ($special == 'nichtda') {
|
|
$sql_stmt = "SELECT * FROM anmeldungen WHERE DATE_ADD(DATE(fdatum),INTERVAL 1 DAY)<=DATE(NOW()) AND teilgenommen = 0 AND name != '-'";
|
|
} else if ($special == 'zualt') {
|
|
$sql_stmt = "SELECT * FROM anmeldungen WHERE DATE_ADD(DATE(fdatum),INTERVAL $date DAY)<=DATE(NOW()) AND name != '-'";
|
|
} else
|
|
*/ if ($special == 'alllater'){
|
|
$sql_stmt = "SELECT * FROM SoFue2 WHERE wtermin > '$date' ORDER BY wtermin";
|
|
// } else if ($special == 'normal'){
|
|
// $sql_stmt = "SELECT * FROM anmeldungen WHERE fdatum = '$date'";
|
|
} else {
|
|
$retur['error'] = 'false';
|
|
$retur['errortext'] = 'Falsches SELECT Statement!';
|
|
$retur['data'] = [];
|
|
return $retur;
|
|
}
|
|
$result = mysqli_query($db, $sql_stmt) or die(mysqli_error($db));
|
|
while ($row = mysqli_fetch_assoc($result)) {
|
|
foreach($row as $key => $value) {
|
|
$entry[$key] = $value;
|
|
}
|
|
$erg[] = $entry;
|
|
}
|
|
$retur['data'] = $erg;
|
|
return $retur;
|
|
}
|
|
|
|
// Holen der Einträge in der anmelde-Datenbank für den selektierten Tag
|
|
// Parameter
|
|
// $date -> so für dieses Datum die Einträge holen
|
|
// Retunrn:
|
|
// Array mit den Einträgen
|
|
function getAnmeldungen($date)
|
|
{
|
|
global $db, $table;
|
|
$erg = array();
|
|
$sql_stmt = "SELECT * FROM $table WHERE fdatum = '$date'";
|
|
$result = mysqli_query($db, $sql_stmt) or die(mysqli_error($db));
|
|
while ($row = mysqli_fetch_assoc($result)) {
|
|
foreach($row as $key => $value) {
|
|
$entry[$key] = $value;
|
|
}
|
|
$erg[] = $entry;
|
|
}
|
|
return $erg;
|
|
}
|
|
|
|
// Daten eines Teilnehmers abholen
|
|
// Parameter:
|
|
// $id: Teilnehmer - ID
|
|
// Return:
|
|
// Dict mit allen Daten des Teilnehmers
|
|
function getTeilnehmer($id)
|
|
{
|
|
global $db, $table;
|
|
$erg = array();
|
|
$sql_stmt = "SELECT * FROM $table WHERE id='$id'";
|
|
$result = mysqli_query($db, $sql_stmt) or die(mysqli_error($db));
|
|
while ($row = mysqli_fetch_assoc($result)) {
|
|
foreach ($row as $key => $value) {
|
|
$entry[$key] = $value;
|
|
}
|
|
$erg[] = $entry;
|
|
}
|
|
return $erg;
|
|
}
|
|
|
|
// Daten eines Teilnehmers abholen
|
|
// Parameter:
|
|
// $name: Name oder Vorname des Teilnehmers
|
|
// Return:
|
|
// Dict mit allen Daten des Teilnehmers
|
|
function getTeilnehmerByName($name)
|
|
{
|
|
global $db, $table;
|
|
$erg = array();
|
|
$sql_stmt = "SELECT * FROM $table WHERE name ='$name' || vorname = '$name'";
|
|
$result = mysqli_query($db, $sql_stmt) or die(mysqli_error($db));
|
|
while ($row = mysqli_fetch_assoc($result)) {
|
|
foreach ($row as $key => $value) {
|
|
$entry[$key] = $value;
|
|
}
|
|
$erg[] = $entry;
|
|
}
|
|
return $erg;
|
|
}
|
|
|
|
// Die Daten der nächsten $soviel Führungen ab dem Datum $ab in ein Array holen
|
|
// Parameter
|
|
// $soviel -> so viele Einträge ab jetzt holen
|
|
// $ab -> Startdatum
|
|
// Retunrn:
|
|
// Array mit allen Werte aus der Table
|
|
function getNextFuehrungen($soviel, $ab) {
|
|
global $db, $table;
|
|
$tab = $table;
|
|
$erg = [];
|
|
// $datum_heute = date("Ymd",strtotime("-1 days"));
|
|
if ($table == 'anmeldungen') {
|
|
$tab = 'fdatum1';
|
|
} else if ($table == 'sonneanmeld') {
|
|
$tab = 'sonnedatum';
|
|
}
|
|
$sql_sel = "SELECT * FROM $tab where datum >='$ab' order by datum ASC LIMIT $soviel";
|
|
$result = mysqli_query($db, $sql_sel) or die(mysqli_error($db));
|
|
while ($row = mysqli_fetch_assoc($result)) {
|
|
foreach ($row as $key => $value) {
|
|
$entry[$key] = $value;
|
|
}
|
|
$erg[] = $entry;
|
|
}
|
|
return $erg;
|
|
}
|
|
|
|
// Das Datum der letzen Anmeldung suchen und übergeben
|
|
// Parameter
|
|
// $date -> Startdatum
|
|
// Retunrn:
|
|
// Datum der letzten Anmeldung
|
|
function getLastAnmeldung($date) {
|
|
global $db, $table;
|
|
$erg = array();
|
|
// $datum_heute = date("Ymd",strtotime("-1 days"));
|
|
$sql_sel = "SELECT MAX(fdatum) AS lastdate FROM $table WHERE fdatum >= '$date' and anzahl != 0";
|
|
$result = mysqli_query($db, $sql_sel) or die(mysqli_error($db));
|
|
$row = mysqli_fetch_row($result);
|
|
return $row[0];
|
|
}
|
|
|
|
// Bezeichnung der Gruppe für das übergeben Datum holen
|
|
// Parameter:
|
|
// $date -> Datum/Zeit (YYY-MM-DD HH:mm:ss), für das die Gruppe geholt werden soll
|
|
// Return: Bezeichnung der Gruppe
|
|
function getGroup($date) {
|
|
global $db;
|
|
global $db;
|
|
$sql_stmt = "SELECT grp FROM fdates WHERE dateTime = '$date'";
|
|
$result = mysqli_query($db, $sql_stmt) or die(mysqli_error($db));
|
|
$data = mysqli_fetch_assoc($result);
|
|
return $data['grp'] ;
|
|
}
|
|
|
|
// Zählen, wieviele Personen zu einem Führungstermin angemeldet sind
|
|
// Parameter:
|
|
// $fid -> id des Führungsdatum
|
|
// Return: Anzahl der Personen
|
|
function getCountsPerDate($fdate) {
|
|
global $db, $table;
|
|
$sql_stmt = "SELECT SUM(anzahl) AS count FROM $table WHERE fdatum='$fdate'";
|
|
$result = mysqli_query($db, $sql_stmt) or die(mysqli_error($db));
|
|
$data = mysqli_fetch_assoc($result);
|
|
return $data['count'] ;
|
|
}
|
|
|
|
function updateentries($nr,$val,$field)
|
|
{
|
|
global $db, $table;
|
|
$result = false;
|
|
for ($i = 0; $i < count($nr); $i++) {
|
|
$sql_stmt = "UPDATE $table SET $field=$val[0] where id=$nr[$i]";
|
|
$result = mysqli_query($db, $sql_stmt) or die(mysqli_error($db));
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
function updateCount($date, $anzahl) {
|
|
global $db;
|
|
$sql_stmt = "UPDATE fdatum1 SET count=count-$anzahl WHERE datum=$date AND count >0";
|
|
$result = mysqli_query($db, $sql_stmt) or die(mysqli_error($db));
|
|
return $result;
|
|
}
|
|
|
|
function deleteOne($id) {
|
|
global $db, $table;
|
|
$sql_stmt = "DELETE FROM $table WHERE id=$id";
|
|
$result = mysqli_query($db, $sql_stmt) or die(mysqli_error($db));
|
|
return $result;
|
|
}
|
|
|
|
|
|
$_POST = json_decode(file_get_contents('php://input'), true);
|
|
|
|
$erg = "";
|
|
$cmd = $_POST["cmd"];
|
|
$typ = $_POST["typ"];
|
|
$table = 'anmeldungen';
|
|
if ($typ == 'sonnen') {
|
|
$table = 'sonneanmeld';
|
|
}
|
|
|
|
/*
|
|
$x = "#-->";
|
|
foreach ($_POST as $key => $value) {
|
|
$x = $x . $key . " <> " . $value . "\n";
|
|
}
|
|
$x = $x . '# ';
|
|
echo $x;
|
|
var_dump($_POST);
|
|
*/
|
|
|
|
switch ($cmd) {
|
|
case 'GET_ANMELD':
|
|
$erg = getAnmeldungen($_POST['id']);
|
|
break;
|
|
|
|
case 'GET_ANMELDNEW':
|
|
$erg = getAnmeldungenNew($_POST['special'], $_POST['date']);
|
|
break;
|
|
|
|
case 'GET_SONDERNEW':
|
|
$erg = getSonderNew($_POST['special'], $_POST['date']);
|
|
break;
|
|
|
|
case 'GET_TEILN_ID':
|
|
$erg = getTeilnehmer($_POST['id']);
|
|
break;
|
|
|
|
case 'GET_TEILN_NAME':
|
|
$erg = getTeilnehmerByName($_POST['name']);
|
|
break;
|
|
|
|
case 'GET_GROUP':
|
|
$erg = getGroup($_POST['date']);
|
|
break;
|
|
|
|
case 'GET_DATES':
|
|
$erg = getNextFuehrungen($_POST['anzahl'], $_POST['date']);
|
|
break;
|
|
|
|
case 'GET_COUNTS':
|
|
$erg = getCountsPerDate($_POST['fdate']);
|
|
break;
|
|
|
|
case 'GET_LASTANMELDUNG':
|
|
$erg = getLastAnmeldung($_POST['date']);
|
|
break;
|
|
|
|
case 'UPDATE':
|
|
$erg = "Nix gut";
|
|
if ((count($_POST['ids']) != 0) and (count($_POST['values']) != 0)) {
|
|
$rows = $_POST['ids'];
|
|
$values = $_POST['values'];
|
|
$erg = updateEntries($rows, $values, $_POST['field']);
|
|
}
|
|
break;
|
|
case 'UPDATECOUNT':
|
|
$erg = updateCount($_POST['date'], $_POST['anzahl']);
|
|
break;
|
|
|
|
case 'DELETEONE':
|
|
$erg = deleteOne($_POST['id']);
|
|
break;
|
|
|
|
case 'SENDMYMAIL':
|
|
$erg = sendmail($_POST['betreff'], $defaultabsender, $_POST['body'], [], $_POST['bcc'], $_POST['to']);
|
|
break;
|
|
}
|
|
|
|
|
|
header("Content-type: text/json;charset=utf-8");
|
|
|
|
echo json_encode($erg);
|
|
|
|
|
|
|