Compare commits

..

5 Commits

15 changed files with 733 additions and 193 deletions

View File

@ -18,12 +18,10 @@ public class AccountMgr {
/** /**
* creates a user with createUser(...) and adds its id to the 'worker' table * creates a user with createUser(...) and adds its id to the 'worker' table
* @param userData String[] name, firstname, password, email
* @param addressData String[] street, number, plz, city
* @return userid or -1 * @return userid or -1
*/ */
protected static long createWorker(String[] userData, String[] addressData){ protected static long createWorker(Worker worker){
long id = createUser(userData, addressData); long id = createUser(worker);
String sId = String.valueOf(id); String sId = String.valueOf(id);
Database.insert("worker", new String[]{"userid"}, new String[]{sId}); Database.insert("worker", new String[]{"userid"}, new String[]{sId});
return id; return id;
@ -31,12 +29,10 @@ public class AccountMgr {
/** /**
* creates a user with createUser(...) and adds its id to the 'parent' table * creates a user with createUser(...) and adds its id to the 'parent' table
* @param userData String[] name, firstname, password, email
* @param addressData String[] street, number, plz, city
* @return userid or -1 * @return userid or -1
*/ */
protected static long createParent(String[] userData, String[] addressData){ protected static long createParent(Parent parent){
long id = createUser(userData, addressData); long id = createUser(parent);
String sId = String.valueOf(id); String sId = String.valueOf(id);
Database.insert("parent", new String[]{"userid"}, new String[]{sId}); Database.insert("parent", new String[]{"userid"}, new String[]{sId});
return id; return id;
@ -44,46 +40,89 @@ public class AccountMgr {
/** /**
* adds a user to the database * adds a user to the database
* @param userData String[] name, firstname, password, email
* @param addressData String[] street, number, plz, city
* @return userid or -1 * @return userid or -1
*/ */
protected static long createUser(String[] userData, String[] addressData) { protected static long createUser(User user) {
String[] addressH = {"street", "number", "plz", "city"};
String[] userH = {"name", "firstname", "addressid", "password", "email"}; String[] userH = {"name", "firstname", "addressid", "password", "email"};
String name = userData[0]; String name = user.getName();
String firstname = userData[1]; String firstname = user.getFirstname();
String pw = hashAndSalt(userData[2], getSalt()); String pw = hashAndSalt(user.getPassword(), getSalt());
String email = userData[3]; String email = user.getEmail();
long addressId = user.getAddress().getId();
if(addressId < 1){
addressId = createAddress(user.getAddress());
}
String[] userD = {name, firstname, String.valueOf(addressId), pw, email};
return Database.insert("user", userH, userD);
}
long id = Database.insert("address", addressH, addressData); protected static long createAddress(Address address){
String sId = String.valueOf(id); String[] addressH = {"street", "number", "plz", "city"};
String[] userD = {name, firstname, sId, pw, email}; String[] addressD = {address.getStreet(),address.getNumber(),address.getPlz(),address.getCity()};
id = Database.insert("user", userH, userD); return Database.insert("address",addressH,addressD);
return id;
} }
/** /**
* adds a child and allergies to the database * adds a child and allergies to the database
* @param childData name, firstname, addressid
* @param allergyData id of allergies order matching with severityData
* @param severityData id of severity order matching with allergyData
* @return id of child or -1 * @return id of child or -1
*/ */
protected static long createChild(String[] childData,String[] allergyData, String[] severityData){ protected static long createChild(Child child){
String[] childH = {"name","firstname","addressid"}; String[] childH = {"name","firstname","addressid"};
String[] childD = {child.getName(), child.getFirstname(), String.valueOf(child.getAddress().getId())};
long id = Database.insert("child", childH, childD);
String[] child_allergyH = {"childid","allergyid","severityid"}; String[] child_allergyH = {"childid","allergyid","severityid"};
long id = Database.insert("child", childH, childData); for (AllergySeverity allergy: child.getAllergies()) {
if(allergyData.length > 0){ String sId = String.valueOf(id);
for(int i = 0; i < allergyData.length; i++){ String sAllergyId = String.valueOf(allergy.getAllergy().getId());
String sId = String.valueOf(id); String sSeverityId = String.valueOf(allergy.getSeverityId());
String[] child_allergyD = {sId,allergyData[i],severityData[i]}; String[] child_allergyD = {sId,sAllergyId,sSeverityId};
Database.insert("child_allergy",child_allergyH,child_allergyD); Database.insert("child_allergy",child_allergyH,child_allergyD);
}
} }
return id; return id;
} }
protected static User getUserById(long id){
List<String> entry = Database.getEntryById("user",id);
String[] parts = entry.get(0).split(":");
Address address = getAddressById(id);
if(isWorker(String.valueOf(id))){
return new Worker(id,parts[1],parts[2],parts[4],parts[5],address);
}else{
String[] parent_childH = {"parentuserid"};
String[] parent_childD = {String.valueOf(id)};
List<Child> children = new ArrayList<>();
List<String> parent_childEntries = Database.select("parent_child",parent_childH,parent_childD);
for (String parent_childEntry: parent_childEntries) {
String[] parent_childParts = parent_childEntry.split(":");
children.add(getChildById(Long.parseLong(parent_childParts[2])));
}
return new Parent(id,parts[1],parts[2],parts[4],parts[5],address,children);
}
}
protected static Child getChildById(long id){
List<String> entry = Database.getEntryById("child",id);
String[] parts = entry.get(0).split(":");
String[] child_allergyH = {"childid"};
String[] child_allergyD = {String.valueOf(id)};
List<String> entriesAllergy = Database.select("child_allergy",child_allergyH,child_allergyD);
List<AllergySeverity> allergySeverities = new ArrayList<>();
for (String entryAllergy : entriesAllergy) {
String[] allergyParts = entryAllergy.split(":");
List<String> severity = Database.getEntryById("severity", Long.parseLong(allergyParts[3]));
String sSeverity = severity.get(0).split(":")[1];
long lSeverity = Long.parseLong(severity.get(0).split(":")[0]);
allergySeverities.add(new AllergySeverity(FoodMgr.getAllergyById(Long.parseLong(allergyParts[2])),lSeverity,sSeverity));
}
return new Child(id,parts[1],parts[2],getAddressById(Long.parseLong(parts[3])),allergySeverities);
}
protected static Address getAddressById(long id){
List<String> entry = Database.getEntryById("address",id);
String[] parts = entry.get(0).split(":");
return new Address(Long.parseLong(parts[0]),parts[1],parts[2],parts[3],parts[4]);
}
/** /**
* creates entries in the database to match parent to child * creates entries in the database to match parent to child
* @param parentId id of parent * @param parentId id of parent
@ -149,7 +188,7 @@ public class AccountMgr {
* @param pw the password to hash * @param pw the password to hash
* @return hashed and salted password * @return hashed and salted password
*/ */
protected static String hashAndSalt(String pw, String salt){ private static String hashAndSalt(String pw, String salt){
Base64.Decoder dec = Base64.getDecoder(); Base64.Decoder dec = Base64.getDecoder();
byte[] bySalt = dec.decode(salt); byte[] bySalt = dec.decode(salt);
KeySpec spec = new PBEKeySpec(pw.toCharArray(), bySalt,310001,256); KeySpec spec = new PBEKeySpec(pw.toCharArray(), bySalt,310001,256);
@ -205,4 +244,15 @@ public class AccountMgr {
invoice.add("Total: " + (invoice.size()-2) + " X " + price + "€ = " + ((invoice.size()-2)*price) + ""); invoice.add("Total: " + (invoice.size()-2) + " X " + price + "€ = " + ((invoice.size()-2)*price) + "");
return invoice; return invoice;
} }
protected static void getPriceFromDb(){
List<String> priceEntry = Database.getEntryById("price",1);
price = Double.parseDouble(priceEntry.get(0).split(":")[1])/100.0;
}
protected static void setPriceInDb(){
String[] priceH = {"id","price"};
String[] priceD = {"1", String.valueOf(price*100)};
Database.update("price",priceH,priceD);
}
} }

View File

@ -0,0 +1,47 @@
package com.bib.essensbestellungsverwaltung;
/*
@author Malte Schulze Hobeling
*/
public class Address {
private long id;
private String street;
private String number;
private String plz;
private String city;
public long getId() {
return id;
}
public String getStreet() {
return street;
}
public String getNumber() {
return number;
}
public String getPlz() {
return plz;
}
public String getCity() {
return city;
}
public Address(long id, String street, String number, String plz, String city) {
this.id = id;
this.street = street;
this.number = number;
this.plz = plz;
this.city = city;
}
public Address(String street, String number, String plz, String city) {
this.id = -1;
this.street = street;
this.number = number;
this.plz = plz;
this.city = city;
}
}

View File

@ -0,0 +1,28 @@
package com.bib.essensbestellungsverwaltung;
/*
@author Malte Schulze Hobeling
*/
public class Allergy {
private final long id;
private final String name;
private final String handle;
public Allergy(long id, String name, String handle) {
this.id = id;
this.name = name;
this.handle = handle;
}
public long getId() {
return id;
}
public String getName() {
return name;
}
public String getHandle() {
return handle;
}
}

View File

@ -0,0 +1,28 @@
package com.bib.essensbestellungsverwaltung;
/*
@author Malte Schulze Hobeling
*/
public class AllergySeverity {
private Allergy allergy;
private long severityId;
private String severity;
public AllergySeverity(Allergy allergy, long severityId, String severity) {
this.allergy = allergy;
this.severityId = severityId;
this.severity = severity;
}
public Allergy getAllergy() {
return allergy;
}
public long getSeverityId() {
return severityId;
}
public String getSeverity() {
return severity;
}
}

View File

@ -0,0 +1,49 @@
package com.bib.essensbestellungsverwaltung;
/*
@author Malte Schulze Hobeling
*/
import java.util.List;
public class Child {
private long id;
private String name;
private String firstname;
private Address address;
private List<AllergySeverity> allergies;
public Child(long id, String name, String firstname, Address address, List<AllergySeverity> allergies) {
this.id = id;
this.name = name;
this.firstname = firstname;
this.address = address;
this.allergies = allergies;
}
public Child(String name, String firstname, Address address, List<AllergySeverity> allergies) {
this.id = -1;
this.name = name;
this.firstname = firstname;
this.address = address;
this.allergies = allergies;
}
public String getName() {
return name;
}
public String getFirstname() {
return firstname;
}
public Address getAddress() {
return address;
}
public long getId() {
return id;
}
public List<AllergySeverity> getAllergies() {
return allergies;
}
}

View File

@ -29,7 +29,9 @@ public class ConsoleLib {
userData[3] = sc.nextLine(); userData[3] = sc.nextLine();
System.out.print("Passwort: "); System.out.print("Passwort: ");
userData[2] = sc.nextLine(); userData[2] = sc.nextLine();
long id = AccountMgr.createWorker(userData,addressData); Address address = new Address(addressData[0],addressData[1],addressData[2],addressData[3]);
Worker worker = new Worker(userData[0],userData[1],userData[2],userData[3],address);
long id = AccountMgr.createWorker(worker);
if(id < 1){ if(id < 1){
System.out.println("Fehler beim erstellen"); System.out.println("Fehler beim erstellen");
} }
@ -56,7 +58,9 @@ public class ConsoleLib {
userData[3] = sc.nextLine(); userData[3] = sc.nextLine();
System.out.print("Passwort: "); System.out.print("Passwort: ");
userData[2] = sc.nextLine(); userData[2] = sc.nextLine();
long id = AccountMgr.createParent(userData,addressData); Address address = new Address(addressData[0],addressData[1],addressData[2],addressData[3]);
Parent parent = new Parent(userData[0],userData[1],userData[2],userData[3],address);
long id = AccountMgr.createParent(parent);
if(id < 1){ if(id < 1){
System.out.println("Fehler beim erstellen"); System.out.println("Fehler beim erstellen");
} }
@ -88,7 +92,15 @@ public class ConsoleLib {
System.out.print("Schweren (1 Harmlos - 3 Kritisch[2,3,1,3]): "); System.out.print("Schweren (1 Harmlos - 3 Kritisch[2,3,1,3]): ");
String severities = sc.nextLine(); String severities = sc.nextLine();
String[] severityData = severities.split(","); String[] severityData = severities.split(",");
long id = AccountMgr.createChild(childData,allergyData,severityData); Address address = AccountMgr.getAddressById(Long.parseLong(childData[2]));
List<AllergySeverity> allergySeverities = new ArrayList<>();
for(int i = 0; i < allergyData.length; i++){
List<String> allergySeverity = Database.getEntryById("severity", Long.parseLong(severityData[i]));
String[] asParts = allergySeverity.get(0).split(":");
allergySeverities.add(new AllergySeverity(FoodMgr.getAllergyById(Long.parseLong(allergyData[0])),Long.parseLong(asParts[0]),asParts[1]));
}
Child child = new Child(childData[0],childData[1],address,allergySeverities);
long id = AccountMgr.createChild(child);
if(id < 1){ if(id < 1){
System.out.println("Fehler beim erstellen"); System.out.println("Fehler beim erstellen");
return; return;
@ -119,27 +131,39 @@ public class ConsoleLib {
System.out.print("Allergienummer: "); System.out.print("Allergienummer: ");
String allergies = sc.nextLine(); String allergies = sc.nextLine();
String[] allergyData = allergies.split(","); String[] allergyData = allergies.split(",");
if(FoodMgr.createFood(foodData,allergyData) < 1){ FoodType foodType = FoodMgr.getFoodTypeById(Long.parseLong(foodData[3]));
List<Allergy> allergyList = new ArrayList<>();
for (String data : allergyData) {
allergyList.add(FoodMgr.getAllergyById(Long.parseLong(data)));
}
boolean isDessert = !foodData[2].equals("0");
Food food = new Food(foodData[0],foodData[1],isDessert,foodType,allergyList);
if(FoodMgr.createFood(food) < 1){
System.out.println("Fehler"); System.out.println("Fehler");
} }
} }
public static long loginPrompt(){ public static User loginPrompt(){
System.out.println("Login"); System.out.println("Login");
Scanner sc = new Scanner(System.in); Scanner sc = new Scanner(System.in);
long id = -1; User user = null;
while (id == -1){ while (user == null){
System.out.print("Email: "); System.out.print("Email: ");
String email = sc.nextLine(); String email = sc.nextLine();
if(email.isEmpty()){
return null;
}
System.out.print("Passwort: "); System.out.print("Passwort: ");
String pw = sc.nextLine(); String pw = sc.nextLine();
id = AccountMgr.login(email,pw); long id = AccountMgr.login(email,pw);
if(id == -1){ if(id == -1){
System.out.println("Login fehlgeschlagen"); System.out.println("Login fehlgeschlagen");
}else {
user = AccountMgr.getUserById(id);
} }
} }
System.out.println("Login erfolgreich"); System.out.println("Login erfolgreich");
return id; return user;
} }
public static void matchParentChildPrompt(String parentId){ public static void matchParentChildPrompt(String parentId){
@ -183,19 +207,36 @@ public class ConsoleLib {
Scanner sc = new Scanner(System.in); Scanner sc = new Scanner(System.in);
System.out.print("Bitte geben Sie das Datum im Format YYYY-MM-DD an: "); System.out.print("Bitte geben Sie das Datum im Format YYYY-MM-DD an: ");
food_planData[0] = sc.nextLine(); food_planData[0] = sc.nextLine();
printConsole(FoodMgr.getVeganFood(false)); List<Food> veganMain = FoodMgr.getVeganFood(false);
for (Food food : veganMain) {
System.out.println(food.getId() + " : " + food.getName());
}
System.out.print("Veganes Hauptgericht Nr: "); System.out.print("Veganes Hauptgericht Nr: ");
food_planData[1] = sc.nextLine(); food_planData[1] = sc.nextLine();
printConsole(FoodMgr.getFood(false)); List<Food> foodMain = FoodMgr.getFood(false);
for (Food food : foodMain) {
System.out.println(food.getId() + " : " + food.getName());
}
System.out.print("Zweites Hauptgericht Nr: "); System.out.print("Zweites Hauptgericht Nr: ");
food_planData[2] = sc.nextLine(); food_planData[2] = sc.nextLine();
printConsole(FoodMgr.getVeganFood(true)); List<Food> veganDessert = FoodMgr.getVeganFood(true);
for (Food food : veganDessert) {
System.out.println(food.getId() + " : " + food.getName());
}
System.out.print("Veganes Dessert Nr: "); System.out.print("Veganes Dessert Nr: ");
food_planData[3] = sc.nextLine(); food_planData[3] = sc.nextLine();
printConsole(FoodMgr.getFood(true)); List<Food> foodDessert = FoodMgr.getFood(true);
for (Food food : foodDessert) {
System.out.println(food.getId() + " : " + food.getName());
}
System.out.print("Zweites Dessert Nr: "); System.out.print("Zweites Dessert Nr: ");
food_planData[4] = sc.nextLine(); food_planData[4] = sc.nextLine();
long id = FoodMgr.createFood_plan(food_planData); FoodPlan foodPlan = new FoodPlan(food_planData[0],
FoodMgr.getFoodById(Long.parseLong(food_planData[1])),
FoodMgr.getFoodById(Long.parseLong(food_planData[2])),
FoodMgr.getFoodById(Long.parseLong(food_planData[3])),
FoodMgr.getFoodById(Long.parseLong(food_planData[4])));
long id = FoodMgr.createFood_plan(foodPlan);
if(id < 0){ if(id < 0){
System.out.println("Fehler"); System.out.println("Fehler");
} }
@ -206,33 +247,22 @@ public class ConsoleLib {
Scanner sc = new Scanner(System.in); Scanner sc = new Scanner(System.in);
System.out.print("Bitte geben Sie das Datum im Format YYYY-MM-DD an: "); System.out.print("Bitte geben Sie das Datum im Format YYYY-MM-DD an: ");
String date = sc.nextLine(); String date = sc.nextLine();
List<String> plan = FoodMgr.getFood_plan(date); FoodPlan plan = FoodMgr.getFoodPlan(date);
List<String> food = new ArrayList<>(); List<String> foodList = new ArrayList<>();
StringBuilder sb; StringBuilder sb;
for (String day : plan) { sb = new StringBuilder();
sb = new StringBuilder(); sb.append("Tag: ");
String[] parts = day.split(":"); sb.append(plan.getDate());
sb.append("Tag: "); sb.append(" Veganesgericht: ");
sb.append(parts[1]); sb.append(plan.getFoodVegan().getName());
sb.append(" Veganesgericht: "); sb.append(" Zweites Hauptgericht: ");
food = FoodMgr.getFoodById(Long.parseLong(parts[2])); sb.append(plan.getFoodSecond().getName());
String[] foodParts = food.get(0).split(":"); sb.append(" Veganesdessert: ");
sb.append(foodParts[1]); sb.append(plan.getDessertVegan().getName());
sb.append(" Zweites Hauptgericht: "); sb.append(" Zweites Dessert: ");
food = FoodMgr.getFoodById(Long.parseLong(parts[3])); sb.append(plan.getDessertSecond().getName());
foodParts = food.get(0).split(":"); foodList.add(sb.toString());
sb.append(foodParts[1]); printConsole(foodList);
sb.append(" Veganesdessert: ");
food = FoodMgr.getFoodById(Long.parseLong(parts[4]));
foodParts = food.get(0).split(":");
sb.append(foodParts[1]);
sb.append(" Zweites Dessert: ");
food = FoodMgr.getFoodById(Long.parseLong(parts[5]));
foodParts = food.get(0).split(":");
sb.append(foodParts[1]);
food.add(sb.toString());
}
printConsole(food);
} }
public static void createFood_selectionPrompt(){ public static void createFood_selectionPrompt(){
@ -291,5 +321,6 @@ public class ConsoleLib {
double price = sc.nextDouble(); double price = sc.nextDouble();
sc.nextLine(); sc.nextLine();
AccountMgr.price = price; AccountMgr.price = price;
AccountMgr.setPriceInDb();
} }
} }

View File

@ -6,9 +6,8 @@ package com.bib.essensbestellungsverwaltung;
import java.util.Scanner; import java.util.Scanner;
public class ConsoleMain { public class ConsoleMain {
static long currentUserId = -1; static User currentUser = null;
static boolean isWorker = false; static boolean running = true;
static boolean isParent = false;
public static void main(String[] args) { public static void main(String[] args) {
boolean firstRun = Database.init(); boolean firstRun = Database.init();
if(firstRun){ if(firstRun){
@ -16,15 +15,14 @@ public class ConsoleMain {
Database.fillDb(); Database.fillDb();
ConsoleLib.createWorkerPrompt(); ConsoleLib.createWorkerPrompt();
} }
while (true){ AccountMgr.getPriceFromDb();
if(currentUserId == -2){ while (running){
break; if(currentUser == null){
}else if(currentUserId < 0){
defaultMenu(); defaultMenu();
}else{ }else{
if(isWorker){ if(currentUser.getClass().getSimpleName().equals("Worker")){
adminMenu(); adminMenu();
}else if(isParent){ }else if(currentUser.getClass().getSimpleName().equals("Parent")){
parentMenu(); parentMenu();
} }
} }
@ -32,21 +30,21 @@ public class ConsoleMain {
} }
public static void defaultMenu(){ public static void defaultMenu(){
System.out.println("0: Programm beenden");
System.out.println("1: Login"); System.out.println("1: Login");
System.out.println("2: Essensplan anzeigen"); System.out.println("2: Essensplan anzeigen");
System.out.println("3: Programm beenden"); System.out.println("3: Registrieren");
System.out.print("Auswahl: "); System.out.print("Auswahl: ");
Scanner sc = new Scanner(System.in); Scanner sc = new Scanner(System.in);
String selection = sc.nextLine(); String selection = sc.nextLine();
switch (selection) { switch (selection) {
case "0" -> running = false;
case "1" -> { case "1" -> {
currentUserId = ConsoleLib.loginPrompt(); currentUser = ConsoleLib.loginPrompt();
isWorker = AccountMgr.isWorker(String.valueOf(currentUserId));
isParent = AccountMgr.isParent(String.valueOf(currentUserId));
} }
case "2" -> ConsoleLib.showFood_planPrompt(); case "2" -> ConsoleLib.showFood_planPrompt();
case "3" -> currentUserId = -2; case "3" -> ConsoleLib.createParentPrompt();
} }
} }
@ -57,14 +55,14 @@ public class ConsoleMain {
System.out.println("3: Ein neues Kind anlegen"); System.out.println("3: Ein neues Kind anlegen");
System.out.println("4: Kind einem Elternteil zuordnen"); System.out.println("4: Kind einem Elternteil zuordnen");
System.out.println("5: Ein neues Essen anlegen"); System.out.println("5: Ein neues Essen anlegen");
System.out.println("6: Table"); System.out.println("6: Einen Essensplan erstellen");
System.out.println("7: Einen Essensplan erstellen"); System.out.println("7: Essensplan anzeigen");
System.out.println("8: Essensplan anzeigen"); System.out.println("8: Essen auswählen");
System.out.println("9: Löschen"); System.out.println("9: Bestellungen des Tages sammeln");
System.out.println("10: Essen auswählen"); System.out.println("10: Monatsabrechnung");
System.out.println("11: Bestellungen des Tages sammeln"); System.out.println("11: Preis ändern");
System.out.println("12: Monatsabrechnung"); System.out.println("x1: Table");
System.out.println("13: Preis ändern"); System.out.println("x2: Löschen");
System.out.print("Auswahl: "); System.out.print("Auswahl: ");
@ -72,23 +70,21 @@ public class ConsoleMain {
String selection = sc.nextLine(); String selection = sc.nextLine();
switch (selection) { switch (selection) {
case "0" -> { case "0" -> {
currentUserId = -1; currentUser = null;
isWorker = false;
isParent = false;
} }
case "1" -> ConsoleLib.createWorkerPrompt(); case "1" -> ConsoleLib.createWorkerPrompt();
case "2" -> ConsoleLib.createParentPrompt(); case "2" -> ConsoleLib.createParentPrompt();
case "3" -> ConsoleLib.createChildPrompt(String.valueOf(currentUserId)); case "3" -> ConsoleLib.createChildPrompt(String.valueOf(currentUser.getId()));
case "4" -> ConsoleLib.matchParentChildPrompt(String.valueOf(currentUserId)); case "4" -> ConsoleLib.matchParentChildPrompt(String.valueOf(currentUser.getId()));
case "5" -> ConsoleLib.createFoodPrompt(); case "5" -> ConsoleLib.createFoodPrompt();
case "6" -> ConsoleLib.tablePrompt(); case "6" -> ConsoleLib.createFood_planPrompt();
case "7" -> ConsoleLib.createFood_planPrompt(); case "7" -> ConsoleLib.showFood_planPrompt();
case "8" -> ConsoleLib.showFood_planPrompt(); case "8" -> ConsoleLib.createFood_selectionPrompt();
case "9" -> ConsoleLib.deletePrompt(); case "9" -> ConsoleLib.dayOrderPrompt();
case "10" -> ConsoleLib.createFood_selectionPrompt(); case "10" -> ConsoleLib.invoicePrompt();
case "11" -> ConsoleLib.dayOrderPrompt(); case "11" -> ConsoleLib.changePricePrompt();
case "12" -> ConsoleLib.invoicePrompt(); case "x1" -> ConsoleLib.tablePrompt();
case "13" -> ConsoleLib.changePricePrompt(); case "x2" -> ConsoleLib.deletePrompt();
} }
} }
@ -96,7 +92,8 @@ public class ConsoleMain {
public static void parentMenu(){ public static void parentMenu(){
System.out.println("0: Ausloggen"); System.out.println("0: Ausloggen");
System.out.println("3: Ein neues Kind anlegen"); System.out.println("3: Ein neues Kind anlegen");
System.out.println("4: Kind einem Elternteil zuordnen"); System.out.println("7: Essensplan anzeigen");
System.out.println("8: Essen auswählen");
System.out.print("Auswahl: "); System.out.print("Auswahl: ");
@ -104,15 +101,12 @@ public class ConsoleMain {
String selection = sc.nextLine(); String selection = sc.nextLine();
switch (selection) { switch (selection) {
case "0" -> { case "0" -> {
currentUserId = -1; currentUser = null;
isWorker = false;
isParent = false;
} }
case "3" -> ConsoleLib.createChildPrompt(String.valueOf(currentUserId)); case "3" -> ConsoleLib.createChildPrompt(String.valueOf(currentUser.getId()));
case "4" -> ConsoleLib.matchParentChildPrompt(String.valueOf(currentUserId));
case "6" -> ConsoleLib.tablePrompt(); case "6" -> ConsoleLib.tablePrompt();
default -> { case "7" -> ConsoleLib.showFood_planPrompt();
} case "8" -> ConsoleLib.createFood_selectionPrompt();
} }
} }

View File

@ -45,7 +45,7 @@ public class Database {
* creates the initial structure of the db * creates the initial structure of the db
*/ */
protected static void createDb(){ protected static void createDb(){
String[] sql = new String[14]; String[] sql = new String[15];
sql[0] = """ sql[0] = """
CREATE TABLE IF NOT EXISTS address ( CREATE TABLE IF NOT EXISTS address (
id integer PRIMARY KEY, id integer PRIMARY KEY,
@ -62,7 +62,8 @@ public class Database {
sql[2] = """ sql[2] = """
CREATE TABLE IF NOT EXISTS allergy ( CREATE TABLE IF NOT EXISTS allergy (
id integer PRIMARY KEY, id integer PRIMARY KEY,
name text UNIQUE name text UNIQUE,
handle text UNIQUE
);"""; );""";
sql[3] = """ sql[3] = """
CREATE TABLE IF NOT EXISTS severity ( CREATE TABLE IF NOT EXISTS severity (
@ -156,6 +157,11 @@ public class Database {
FOREIGN KEY(food_planid) REFERENCES food_plan(id), FOREIGN KEY(food_planid) REFERENCES food_plan(id),
FOREIGN KEY(foodid) REFERENCES food(id) FOREIGN KEY(foodid) REFERENCES food(id)
);"""; );""";
sql[14] = """
CREATE TABLE IF NOT EXISTS price (
id integer PRIMARY KEY,
price integer
);""";
try(Connection conn = connect(); Statement stmt = conn.createStatement()){ try(Connection conn = connect(); Statement stmt = conn.createStatement()){
for(int i = 0; i < sql.length; i++){ for(int i = 0; i < sql.length; i++){
stmt.execute(sql[i]); stmt.execute(sql[i]);
@ -180,71 +186,71 @@ public class Database {
INSERT OR IGNORE INTO food_type (id,name) INSERT OR IGNORE INTO food_type (id,name)
VALUES ('3','Fleischhaltig');"""); VALUES ('3','Fleischhaltig');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('1','Eier');"""); VALUES('1','Eier','a');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('2','Soja');"""); VALUES('2','Soja','b');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('3','Milch');"""); VALUES('3','Milch','c');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('4','Erdnüsse');"""); VALUES('4','Erdnüsse','d');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('5','Weichtiere');"""); VALUES('5','Weichtiere','e');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('6','Krebstiere');"""); VALUES('6','Krebstiere','f');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('7','Getreide');"""); VALUES('7','Getreide','g');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('8','Senf');"""); VALUES('8','Senf','h');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('9','Sesam');"""); VALUES('9','Sesam','i');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('10','Schwefeldioxid und Sulfit');"""); VALUES('10','Schwefeldioxid und Sulfit','j');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('11','Nüsse');"""); VALUES('11','Nüsse','k');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('12','Sellerie');"""); VALUES('12','Sellerie','l');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('13','Fische');"""); VALUES('13','Fische','m');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('14','Lupinen');"""); VALUES('14','Lupinen','n');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('15','Nitrit-Pökelsalz');"""); VALUES('15','Nitrit-Pökelsalz','1');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('16','Phosphat');"""); VALUES('16','Phosphat','2');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('17','Nitrat');"""); VALUES('17','Nitrat','3');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('18','Antioxidationsmittel');"""); VALUES('18','Antioxidationsmittel','4');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('19','Farbstoff');"""); VALUES('19','Farbstoff','5');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('20','Geschmacksverstärker');"""); VALUES('20','Geschmacksverstärker','6');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('21','Süßungsmittel');"""); VALUES('21','Süßungsmittel','7');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO allergy (id,name) INSERT OR IGNORE INTO allergy (id,name,handle)
VALUES('22','Konservierungsstoff');"""); VALUES('22','Konservierungsstoff','8');""");
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO severity (id,name) INSERT OR IGNORE INTO severity (id,name)
VALUES('1','Harmlos');"""); VALUES('1','Harmlos');""");
@ -254,6 +260,9 @@ public class Database {
sqls.add(""" sqls.add("""
INSERT OR IGNORE INTO severity (id,name) INSERT OR IGNORE INTO severity (id,name)
VALUES('3','Kritisch');"""); VALUES('3','Kritisch');""");
sqls.add("""
INSERT OR IGNORE INTO price (id,price)
VALUES('1','500');""");
try(Connection conn = connect(); Statement stmt = conn.createStatement()){ try(Connection conn = connect(); Statement stmt = conn.createStatement()){
for (String sql : sqls) { for (String sql : sqls) {
stmt.execute(sql); stmt.execute(sql);

View File

@ -0,0 +1,62 @@
package com.bib.essensbestellungsverwaltung;
/*
@author Malte Schulze Hobeling
*/
import java.util.List;
public class Food {
private long id;
private String name;
private String description;
private boolean isDessert;
private FoodType foodType;
private List<Allergy> allergies;
public Food(long id, String name, String description, boolean isDessert, FoodType foodType, List<Allergy> allergies) {
this.id = id;
this.name = name;
this.description = description;
this.isDessert = isDessert;
this.foodType = foodType;
this.allergies = allergies;
}
public Food(String name, String description, boolean isDessert, FoodType foodType, List<Allergy> allergies) {
this.id = -1;
this.name = name;
this.description = description;
this.isDessert = isDessert;
this.foodType = foodType;
this.allergies = allergies;
}
public long getId() {
return id;
}
public String getName() {
return name;
}
public String getDescription() {
return description;
}
public boolean isDessert() {
return isDessert;
}
public FoodType getFoodType() {
return foodType;
}
public List<Allergy> getAllergies() {
return allergies;
}
@Override
public String toString() {
return getName();
}
}

View File

@ -6,21 +6,21 @@ package com.bib.essensbestellungsverwaltung;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
public class FoodMgr { public class FoodMgr {
/** /**
* inserts a food int to the database and creates the food_restriction entries * inserts a food int to the database and creates the food_restriction entries
* @param foodData name, description, isdessert, food_typeid
* @param allergyData allergyids
* @return id of food or -1 * @return id of food or -1
*/ */
public static long createFood(String[] foodData, String[] allergyData){ public static long createFood(Food food){
String[] foodH = {"name","description","isDessert","food_typeid"}; String[] foodH = {"name","description","isDessert","food_typeid"};
String[] food_restrictionH = {"foodid","allergyid"}; String[] food_restrictionH = {"foodid","allergyid"};
long id = Database.insert("food",foodH,foodData); String[] foodD = {food.getName(),food.getDescription(),(food.isDessert() ? "1" : "0"), String.valueOf(food.getFoodType().getId())};
if(allergyData.length > 0){ long id = Database.insert("food",foodH,foodD);
if(food.getAllergies().size() > 0){
String sId = String.valueOf(id); String sId = String.valueOf(id);
for (String allergyId : allergyData) { for (Allergy allergy : food.getAllergies()) {
String[] food_restrictionD = {sId,allergyId}; String[] food_restrictionD = {sId, String.valueOf(allergy.getId())};
Database.insert("food_restriction",food_restrictionH, food_restrictionD); Database.insert("food_restriction",food_restrictionH, food_restrictionD);
} }
} }
@ -29,12 +29,16 @@ public class FoodMgr {
/** /**
* inserts a food_plan into the database * inserts a food_plan into the database
* @param food_planData date[YYYY-MM-DD], foodid[vegan], foodid, foodid[dessert,vegan], foodid[dessert]
* @return id of food_plan or -1 * @return id of food_plan or -1
*/ */
public static long createFood_plan(String[] food_planData){ public static long createFood_plan(FoodPlan foodPlan){
String[] food_planH = {"date","food1","food2","dessert1","dessert2"}; String[] food_planH = {"date","food1","food2","dessert1","dessert2"};
return Database.insert("food_plan",food_planH,food_planData); String[] food_planD = {foodPlan.getDate(),
String.valueOf(foodPlan.getFoodVegan().getId()),
String.valueOf(foodPlan.getFoodSecond().getId()),
String.valueOf(foodPlan.getDessertVegan().getId()),
String.valueOf(foodPlan.getDessertSecond().getId())};
return Database.insert("food_plan",food_planH,food_planD);
} }
/** /**
@ -42,10 +46,16 @@ public class FoodMgr {
* @param isDessert true for only desserts false for non desserts * @param isDessert true for only desserts false for non desserts
* @return a list of all non desserts or all desserts * @return a list of all non desserts or all desserts
*/ */
public static List<String> getFood(boolean isDessert){ public static List<Food> getFood(boolean isDessert){
String[] foodH = {"isDessert"}; String[] foodH = {"isDessert"};
String[] foodD = {(isDessert ? "1" : "0")}; String[] foodD = {(isDessert ? "1" : "0")};
return Database.select("food",foodH,foodD); List<String> entries = Database.select("food",foodH,foodD);
List<Food> foods = new ArrayList<>();
for (String entry : entries) {
String[] parts = entry.split(":");
foods.add(getFoodById(Long.parseLong(parts[0])));
}
return foods;
} }
/** /**
@ -53,10 +63,16 @@ public class FoodMgr {
* @param isDessert true for only desserts false for non desserts * @param isDessert true for only desserts false for non desserts
* @return a list of all vegan non desserts or all vegan desserts * @return a list of all vegan non desserts or all vegan desserts
*/ */
public static List<String> getVeganFood(boolean isDessert){ public static List<Food> getVeganFood(boolean isDessert){
String[] foodH = {"isDessert","food_typeid"}; String[] foodH = {"isDessert","food_typeid"};
String[] foodD = {(isDessert ? "1" : "0"),"1"}; String[] foodD = {(isDessert ? "1" : "0"),"1"};
return Database.select("food",foodH,foodD); List<String> entries = Database.select("food",foodH,foodD);
List<Food> foods = new ArrayList<>();
for (String entry : entries) {
String[] parts = entry.split(":");
foods.add(getFoodById(Long.parseLong(parts[0])));
}
return foods;
} }
/** /**
@ -64,14 +80,66 @@ public class FoodMgr {
* @param date YYYY-MM-DD one day * @param date YYYY-MM-DD one day
* @return food_plan for date * @return food_plan for date
*/ */
public static List<String> getFood_plan(String date){ public static FoodPlan getFoodPlan(String date){
String[] food_planH = {"date"}; String[] food_planH = {"date"};
String[] food_planD = {date}; String[] food_planD = {date};
return Database.select("food_plan",food_planH,food_planD); List<String> entry = Database.select("food_plan",food_planH,food_planD);
String[] parts = entry.get(0).split(":");
Food foodVegan = getFoodById(Long.parseLong(parts[2]));
Food foodSecond = getFoodById(Long.parseLong(parts[3]));
Food dessertVegan = getFoodById(Long.parseLong(parts[4]));
Food dessertSecond = getFoodById(Long.parseLong(parts[5]));
boolean isSent = !parts[6].equals("0");
return new FoodPlan(Long.parseLong(parts[0]),date,foodVegan,foodSecond,dessertVegan,dessertSecond,isSent);
} }
public static List<String> getFoodById(long id){ public static FoodPlan getFoodPlanById(long id){
return Database.getEntryById("food",id); List<String> entry = Database.getEntryById("food_plan",id);
String[] parts = entry.get(0).split(":");
Food foodVegan = getFoodById(Long.parseLong(parts[2]));
Food foodSecond = getFoodById(Long.parseLong(parts[3]));
Food dessertVegan = getFoodById(Long.parseLong(parts[4]));
Food dessertSecond = getFoodById(Long.parseLong(parts[5]));
boolean isSent = !parts[6].equals("0");
return new FoodPlan(id,parts[1], foodVegan,foodSecond,dessertVegan,dessertSecond,isSent);
}
public static Food getFoodById(long id){
List<String> entry = Database.getEntryById("food",id);
String[] parts = entry.get(0).split(":");
String name = parts[1];
String description = parts[2];
boolean isDessert;
isDessert = parts[3].equals("0");
FoodType foodType = getFoodTypeById(Long.parseLong(parts[4]));
List<Allergy> allergies = getAllergies(id);
return new Food(id,name,description,isDessert,foodType,allergies);
}
public static FoodType getFoodTypeById(long id){
List<String> entry = Database.getEntryById("food_type",id);
String[] typeParts = entry.get(0).split(":");
return new FoodType(Long.parseLong(typeParts[0]),typeParts[1]);
}
public static Allergy getAllergyById(long id){
String[] allergyH = {"id"};
String[] allergyD = {String.valueOf(id)};
List<String> allergies = Database.select("allergy",allergyH,allergyD);
String[] allergyParts = allergies.get(0).split(":");
return new Allergy(id,allergyParts[1],allergyParts[2]);
}
public static List<Allergy> getAllergies(long foodId){
List<Allergy> allergies = new ArrayList<>();
String[] restrictionsH = {"foodid"};
String[] restrictionsD = {String.valueOf(foodId)};
List<String> restrictions = Database.select("food_restriction",restrictionsH,restrictionsD);
for (String restriction : restrictions) {
String[] partsRestrictions = restriction.split(":");
allergies.add(getAllergyById(Long.parseLong(partsRestrictions[2])));
}
return allergies;
} }
/** /**
@ -81,9 +149,8 @@ public class FoodMgr {
*/ */
public static long createFood_selection(String[] food_selectionData){ public static long createFood_selection(String[] food_selectionData){
String[] food_selectionH = {"childid","food_planid","foodid"}; String[] food_selectionH = {"childid","food_planid","foodid"};
List<String> food_plan = Database.getEntryById("food_plan",Long.parseLong(food_selectionData[1])); FoodPlan food_plan = getFoodPlanById(Long.parseLong(food_selectionData[1]));
String[] food_planParts = food_plan.get(0).split(":"); if(!food_plan.isSent()){
if(Long.parseLong(food_planParts[6]) == 0){
return Database.insert("food_selection",food_selectionH,food_selectionData); return Database.insert("food_selection",food_selectionH,food_selectionData);
}else { }else {
return -1; return -1;
@ -97,19 +164,23 @@ public class FoodMgr {
*/ */
public static List<String> getDayOrder(String date){ public static List<String> getDayOrder(String date){
List<String> orders = new ArrayList<>(); List<String> orders = new ArrayList<>();
List<String> food_plan = getFood_plan(date); FoodPlan food_plan = getFoodPlan(date);
String[] food_planParts = food_plan.get(0).split(":"); String sId = String.valueOf(food_plan.getId());
for(int i = 2; i < 2+4; i++){ String[] food_selectionH = {"food_planid","foodid"};
List<String> food = getFoodById(Long.parseLong(food_planParts[i])); Food[] foodArray = {
String[] foodParts = food.get(0).split(":"); food_plan.getFoodVegan(),
String foodName = foodParts[1]; food_plan.getFoodSecond(),
String[] food_selectionH = {"food_planid","foodid"}; food_plan.getDessertVegan(),
String[] food_selectionD = {food_planParts[0],foodParts[0]}; food_plan.getDessertSecond()
};
for(int i = 0; i < 4; i++){
String foodName = foodArray[i].getName();
String[] food_selectionD = {sId, String.valueOf(foodArray[i].getId())};
int count = Database.count("food_selection",food_selectionH,food_selectionD); int count = Database.count("food_selection",food_selectionH,food_selectionD);
orders.add(foodName+":"+count); orders.add(count+" X "+foodName);
} }
String[] updateH = {"id","issent"}; String[] updateH = {"id","issent"};
String[] updateD = {food_planParts[0],"1"}; String[] updateD = {sId,"1"};
if(Database.update("food_plan",updateH,updateD) < 0){ if(Database.update("food_plan",updateH,updateD) < 0){
System.out.println("Fehler"); System.out.println("Fehler");
} }

View File

@ -0,0 +1,58 @@
package com.bib.essensbestellungsverwaltung;
public class FoodPlan {
private long id;
private String date;
private Food foodVegan;
private Food foodSecond;
private Food dessertVegan;
private Food dessertSecond;
private boolean isSent;
public FoodPlan(long id, String date, Food foodVegan, Food foodSecond, Food dessertVegan, Food dessertSecond, boolean isSent) {
this.id = id;
this.date = date;
this.foodVegan = foodVegan;
this.foodSecond = foodSecond;
this.dessertVegan = dessertVegan;
this.dessertSecond = dessertSecond;
this.isSent = isSent;
}
public FoodPlan(String date, Food foodVegan, Food foodSecond, Food dessertVegan, Food dessertSecond) {
this.id = -1;
this.date = date;
this.foodVegan = foodVegan;
this.foodSecond = foodSecond;
this.dessertVegan = dessertVegan;
this.dessertSecond = dessertSecond;
this.isSent = false;
}
public long getId() {
return id;
}
public String getDate() {
return date;
}
public Food getFoodVegan() {
return foodVegan;
}
public Food getFoodSecond() {
return foodSecond;
}
public Food getDessertVegan() {
return dessertVegan;
}
public Food getDessertSecond() {
return dessertSecond;
}
public boolean isSent() {
return isSent;
}
}

View File

@ -0,0 +1,22 @@
package com.bib.essensbestellungsverwaltung;
/*
@author Malte Schulze Hobeling
*/
public class FoodType {
private long id;
private String name;
public FoodType(long id, String name) {
this.id = id;
this.name = name;
}
public long getId() {
return id;
}
public String getName() {
return name;
}
}

View File

@ -0,0 +1,24 @@
package com.bib.essensbestellungsverwaltung;
/*
@author Malte Schulze Hobeling
*/
import java.util.ArrayList;
import java.util.List;
public class Parent extends User{
List<Child> children;
public Parent(long id, String name, String firstname, String password, String email, Address address, List<Child> children) {
super(id, name, firstname, password, email, address);
this.children = children;
}
public Parent(String name, String firstname, String password, String email, Address address) {
super(name, firstname, password, email, address);
this.children = new ArrayList<>();
}
public List<Child> getChildren() {
return children;
}
}

View File

@ -0,0 +1,54 @@
package com.bib.essensbestellungsverwaltung;
/*
@author Malte Schulze Hobeling
*/
public class User {
private long id;
private String name;
private String firstname;
private String password;
private String email;
private Address address;
public User(long id, String name, String firstname, String password, String email, Address address) {
this.id = id;
this.name = name;
this.firstname = firstname;
this.password = password;
this.email = email;
this.address = address;
}
public User(String name, String firstname, String password, String email, Address address) {
this.id = -1;
this.name = name;
this.firstname = firstname;
this.password = password;
this.email = email;
this.address = address;
}
public long getId() {
return id;
}
public String getName() {
return name;
}
public String getFirstname() {
return firstname;
}
public String getPassword() {
return password;
}
public String getEmail() {
return email;
}
public Address getAddress() {
return address;
}
}

View File

@ -0,0 +1,13 @@
package com.bib.essensbestellungsverwaltung;
/*
@author Malte Schulze Hobeling
*/
public class Worker extends User{
public Worker(long id, String name, String firstname, String password, String email, Address address) {
super(id, name, firstname, password, email, address);
}
public Worker(String name, String firstname, String password, String email, Address address) {
super(name, firstname, password, email, address);
}
}