public static function doAction($action, $id)
 {
     switch ($action) {
         case 'showList':
             $out = Mitarbeiter::getAll();
             $out = self::transform($out);
             break;
         case 'showUpdate':
             $out = Mitarbeiter::getById($id);
             $out = self::transformUpdate($out);
             break;
         case 'showInsert':
             $out = self::transformUpdate();
             break;
         case 'update':
             $vorgesetzter_idFiltered = filter_input(INPUT_POST, 'vorgesetzter_id', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $vornameFiltered = filter_input(INPUT_POST, 'vorname', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $nachnameFiltered = filter_input(INPUT_POST, 'nachname', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $geschlechtFiltered = filter_input(INPUT_POST, 'geschlecht', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $geburtsdatumFiltered = filter_input(INPUT_POST, 'geburtsdatum', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $abteilung_idFiltered = filter_input(INPUT_POST, 'abteilung_id', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $stundenlohnFiltered = filter_input(INPUT_POST, 'stundenlohn', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $updatemitarbeiterherstellerFiltered = filter_input(INPUT_POST, 'id', FILTER_SANITIZE_NUMBER_INT & FILTER_SANITIZE_SPECIAL_CHARS);
             $vorgesetzter = $vorgesetzter_idFiltered ? Mitarbeiter::getById($vorgesetzter_idFiltered) : NULL;
             $out = new Mitarbeiter($vornameFiltered, $nachnameFiltered, $geschlechtFiltered, HTML::germanToMysql($geburtsdatumFiltered), Abteilung::getById($abteilung_idFiltered), $stundenlohnFiltered, $vorgesetzter, $updatemitarbeiterherstellerFiltered);
             $out = Mitarbeiter::update($out);
             $out = Mitarbeiter::getAll();
             $out = self::transform($out);
             break;
         case 'insert':
             $vorgesetzter_idFiltered = filter_input(INPUT_POST, 'vorgesetzter_id', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $vornameFiltered = filter_input(INPUT_POST, 'vorname', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $nachnameFiltered = filter_input(INPUT_POST, 'nachname', FILTER_SANITIZE_MAGIC_QUOTES);
             $geschlechtFiltered = filter_input(INPUT_POST, 'geschlecht', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $geburtsdatumFiltered = filter_input(INPUT_POST, 'geburtsdatum', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $abteilung_idFiltered = filter_input(INPUT_POST, 'abteilung_id', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $stundenlohnFiltered = filter_input(INPUT_POST, 'stundenlohn', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS);
             $vorgesetzter = $vorgesetzter_idFiltered ? Mitarbeiter::getById($vorgesetzter_idFiltered) : NULL;
             $out = new Mitarbeiter($vornameFiltered, $nachnameFiltered, $geschlechtFiltered, HTML::germanToMysql($geburtsdatumFiltered), Abteilung::getById($abteilung_idFiltered), $stundenlohnFiltered, $vorgesetzter, NULL);
             $out = Mitarbeiter::insert($out);
             $out = Mitarbeiter::getAll();
             $out = self::transform($out);
             break;
         case 'delete':
             $deletemitarbeiteridFiltered = filter_input(INPUT_POST, 'id', FILTER_SANITIZE_NUMBER_INT & FILTER_SANITIZE_SPECIAL_CHARS);
             $out = $deletemitarbeiteridFiltered;
             $out = Mitarbeiter::delete($out);
             $out = Mitarbeiter::getAll();
             $out = self::transform($out);
             break;
         default:
             break;
     }
     return $out;
 }
 public static function doAction($action, &$view, $id)
 {
     switch ($action) {
         case 'showList':
             $out = Mitarbeiter::getAll();
             $out = self::transform($out);
             break;
         case 'showUpdate':
             $out = Mitarbeiter::getById($id);
             $out = self::transformUpdate($out);
             break;
         case 'showInsert':
             $out = self::transformUpdate();
             break;
         case 'update':
             $daten = $_POST['daten'];
             $daten = json_decode($daten, FALSE);
             $vorgesetzter = "";
             if (!$daten->vorgesetzter_id) {
                 $vorgesetzter = NULL;
             } else {
                 $vorgesetzter = $daten->vorgesetzter_id;
             }
             echo $vorgesetzter;
             Mitarbeiter::update(new Mitarbeiter($daten->vorname, $daten->nachname, $daten->geschlecht, $daten->geburtsdatum, Abteilung::getById($daten->abteilung_id), $daten->stundenlohn, Mitarbeiter::getVorgesetzterById($vorgesetzter), $daten->umaid));
             $out = Mitarbeiter::getAll();
             $out = self::transform($out);
             break;
         case 'insert':
             $daten = $_POST['daten'];
             $daten = json_decode($daten, FALSE);
             $vorgesetzter = "";
             if (!$daten->vorgesetzter_id) {
                 $vorgesetzter = NULL;
             } else {
                 $vorgesetzter = $daten->vorgesetzter_id;
             }
             Mitarbeiter::insert(new Mitarbeiter($daten->vorname, $daten->nachname, $daten->geschlecht, $daten->geburtsdatum, Abteilung::getById($daten->abteilung_id), $daten->stundenlohn, Mitarbeiter::getVorgesetzterById($vorgesetzter), ''));
             $out = Mitarbeiter::getAll();
             $out = self::transform($out);
             break;
         case 'delete':
             $out = $_POST['lmaid'];
             $out = Mitarbeiter::delete($out);
             $out = Mitarbeiter::getAll();
             $out = self::transform($out);
             break;
         default:
             break;
     }
     return $out;
 }
 public static function doAction($action, $id)
 {
     switch ($action) {
         case 'showList':
             $out = Abteilung::getAll();
             $out = self::transform($out);
             break;
         case 'showUpdate':
             $out = Abteilung::getById($id);
             $out = self::transformUpdate($out);
             break;
         case 'showInsert':
             $out = self::transformUpdate();
             break;
         case 'update':
             $abteilungFiltered = filter_input(INPUT_POST, 'Abteilung', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS & FILTER_SANITIZE_SPECIAL_CHARS & FILTER_SANITIZE_SPECIAL_CHARS);
             $updateabteilungidFiltered = filter_input(INPUT_POST, 'id', FILTER_SANITIZE_NUMBER_INT & FILTER_SANITIZE_SPECIAL_CHARS);
             $out = new Abteilung($abteilungFiltered, $updateabteilungidFiltered);
             $out = Abteilung::update($out);
             $out = Abteilung::getAll();
             $out = self::transform($out);
             break;
         case 'insert':
             $abteilungFiltered = filter_input(INPUT_POST, 'name', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS & FILTER_SANITIZE_SPECIAL_CHARS & FILTER_SANITIZE_SPECIAL_CHARS & FILTER_SANITIZE_SPECIAL_CHARS);
             $out = new Abteilung($abteilungFiltered, NULL);
             $out = Abteilung::insert($out);
             print_r($out);
             $out = Abteilung::getAll();
             $out = self::transform($out);
             break;
         case 'delete':
             $deleteabteilungidFiltered = filter_input(INPUT_POST, 'id', FILTER_SANITIZE_MAGIC_QUOTES & FILTER_SANITIZE_SPECIAL_CHARS & FILTER_SANITIZE_SPECIAL_CHARS & FILTER_SANITIZE_SPECIAL_CHARS);
             $out = $deleteabteilungidFiltered;
             $out = Abteilung::delete($out);
             $out = Abteilung::getAll();
             $out = self::transform($out);
             break;
         default:
             break;
     }
     return $out;
 }
 public static function doAction($action, &$view, $id)
 {
     switch ($action) {
         case 'showList':
             $out = Abteilung::getAll();
             $out = self::transform($out);
             break;
         case 'showUpdate':
             $out = Abteilung::getById($id);
             $out = self::transformUpdate($out);
             break;
         case 'showInsert':
             $out = self::transformUpdate();
             break;
         case 'update':
             $daten = $_POST['daten'];
             $daten = json_decode($daten, FALSE);
             $out = new Abteilung($daten->abteilung, $daten->uabid);
             $out = Abteilung::update($out);
             $out = Abteilung::getAll();
             $out = self::transform($out);
             break;
         case 'insert':
             $daten = $_POST['daten'];
             $daten = json_decode($daten, FALSE);
             $out = new Abteilung($daten->abteilung, NULL);
             $out = Abteilung::insert($out);
             $out = Abteilung::getAll();
             $out = self::transform($out);
             break;
         case 'delete':
             $out = $_POST['labid'];
             $out = Abteilung::delete($out);
             $out = Abteilung::getAll();
             $out = self::transform($out);
             break;
         default:
             break;
     }
     return $out;
 }
 public static function getVorgesetzterById($id)
 {
     if ($id !== NULL) {
         $pdo = DbConnect::connect();
         $sql = "SELECT * from mitarbeiter WHERE id=:id";
         $stmt = $pdo->prepare($sql);
         $stmt->execute([':id' => $id]);
         $rows = $stmt->fetchAll(PDO::FETCH_ASSOC);
         return new Mitarbeiter($rows[0]['vorname'], $rows[0]['nachname'], $rows[0]['geschlecht'], $rows[0]['geburtsdatum'], Abteilung::getById($rows[0]['abteilung_id']), $rows[0]['stundenlohn'], NULL, $rows[0]['id']);
     } else {
         return NULL;
     }
 }