diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..d8fe4fa --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +/.project diff --git a/Bank-Beispiel/.classpath b/Bank-Beispiel/.classpath index 57bca72..9e73c62 100644 --- a/Bank-Beispiel/.classpath +++ b/Bank-Beispiel/.classpath @@ -1,10 +1,11 @@ - - - - - - - - - - + + + + + + + + + + + diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java index b075558..16a794f 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/Main.java @@ -5,7 +5,7 @@ import de.hs_mannheim.informatik.bank.ui.UI; public class Main { - public static void main(String[] args) { + public static void main(String[] args) throws Exception { Banksystem bs = new Banksystem("Spaßkasse Mannheim"); UI ui = new UI(bs); } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java index 0b66d3d..27aeb58 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Bank.java @@ -1,18 +1,30 @@ package de.hs_mannheim.informatik.bank.domain; +import java.io.Serializable; import java.util.Collection; import java.util.HashMap; -public class Bank { +public class Bank implements Serializable { private String name; private HashMap konten = new HashMap<>(); + private int kontozähler; public Bank(String name) { this.name = name; + this.kontozähler = -1; } - public void addKonto(Konto k) { + public int addKonto(String name, int auswahl) { + Konto k; + + if (auswahl == 1) + k = new Konto(name, ++kontozähler); + else + k = new Girokonto(name, ++kontozähler); + konten.put(k.getKontonummer(), k); + + return k.getKontonummer(); } public String getName() { @@ -22,5 +34,9 @@ public class Bank { public Collection getKontenliste() { return konten.values(); } + + public Konto findeKonto(int kontonummer) { + return konten.get(kontonummer); + } } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java new file mode 100644 index 0000000..cefc02c --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Girokonto.java @@ -0,0 +1,27 @@ +package de.hs_mannheim.informatik.bank.domain; + +import java.io.Serializable; + +public class Girokonto extends Konto implements Serializable { + + public Girokonto(String inhaber, int kontozähler) { + super(inhaber, kontozähler); + } + + public boolean Überweise(Girokonto ziel, long betrag, String zweck) { + if (super.getKontostand() - betrag >= 0) { + this.auszahlen(betrag, zweck, "Ãœberweisungsausgang", super.getInhaber()); + ziel.einzahlen(betrag, zweck, "Ãœberweisungseingang", super.getInhaber()); + + return true; + } + + return false; + } + + @Override + public String toString() { + return "Giro-" + super.toString(); + } + +} diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java index 8a5ad27..d1560bb 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Konto.java @@ -1,17 +1,22 @@ package de.hs_mannheim.informatik.bank.domain; -public class Konto { - private static int kontozähler = 0; - +import java.io.Serializable; +import java.util.ArrayList; + +public class Konto implements Serializable { private int nummer; private long stand = 0; private String inhaber; - public Konto(String inhaber) { - nummer = 1000 + kontozähler++; + private ArrayList kontobewegungen; + + public Konto(String inhaber, int kontozähler) { + nummer = 1000 + kontozähler; this.inhaber = inhaber; + + this.kontobewegungen = new ArrayList<>(); } - + public int getKontonummer() { return nummer; } @@ -21,17 +26,41 @@ public class Konto { return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + "]"; } - public void geldEinzahlen(long betrag) { - if (betrag < 0) { - - } - stand += betrag; - + public String getInhaber() { + return inhaber; } - public long getStand() { - // TODO Auto-generated method stub + public long getKontostand() { return stand; } - + + public void einzahlen(long betrag, String zweck, String art, String auftraggeber) { + stand += betrag; + + kontobewegungen.add(new Kontobewegungen(betrag, zweck, art, auftraggeber)); + } + + public boolean auszahlen(long betrag, String zweck, String art, String auftraggeber) { + if (stand - betrag >= 0) { + stand -= betrag; + + kontobewegungen.add(new Kontobewegungen(betrag * -1, zweck, art, auftraggeber)); + + return true; + } + + return false; + } + + public String[] getKontobewegungen() { + String[] auflistung = new String[kontobewegungen.size()]; + + int i = 0; + for (Kontobewegungen kb : kontobewegungen) { + auflistung[i++] = kb.toString(); + } + + return auflistung; + } + } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java new file mode 100644 index 0000000..8fb80de --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/KontoTest.java @@ -0,0 +1,38 @@ +package de.hs_mannheim.informatik.bank.domain; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertFalse; +import static org.junit.Assert.assertNotEquals; +import static org.junit.Assert.assertTrue; + +import org.junit.jupiter.api.Test; + +class KontoTest { + + @Test + void testKontoBasics() { + Konto k = new Konto("Müller", 0); + assertEquals("Müller", k.getInhaber()); + assertEquals(1000, k.getKontonummer()); + assertEquals(0, k.getKontostand()); + } + + @Test + void testKontoEinUndAuszahlung() { + Konto k = new Konto("Müller", 0); + Konto k2 = new Konto("Mayer", 1); + + assertEquals("Mayer", k2.getInhaber()); + assertNotEquals(k.getKontonummer(), k2.getKontonummer()); + + k2.einzahlen(100, "Test", "Einzahlung", "JUnit"); + assertEquals(100, k2.getKontostand()); + + assertTrue(k2.auszahlen(50, "Test", "Auszahlung", "JUnit")); + assertEquals(50, k2.getKontostand()); + + assertFalse(k2.auszahlen(500, "Test", "Auszahlung", "JUnit")); + assertEquals(50, k2.getKontostand()); + } + +} diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Kontobewegungen.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Kontobewegungen.java new file mode 100644 index 0000000..9564e4d --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Kontobewegungen.java @@ -0,0 +1,28 @@ +package de.hs_mannheim.informatik.bank.domain; + +import java.io.Serializable; +import java.util.Date; + +public class Kontobewegungen implements Serializable { + private long betrag; + private Date datum; + private String betreff; + private String art; + private String auftraggeber; + + public Kontobewegungen (long betrag, String betreff, String art, String auftraggeber) { + this.betrag = betrag; + this.betreff = betreff; + this.art = art; + this.auftraggeber = auftraggeber; + + this.datum = new Date(); + } + + @Override + public String toString() { + return "Kontobewegung [betrag=" + betrag + ", datum=" + datum + ", betreff=" + betreff + ", art=" + art + + ", auftraggeber=" + auftraggeber + "]"; + } + +} diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java index a737d38..cc25881 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/Banksystem.java @@ -3,56 +3,82 @@ package de.hs_mannheim.informatik.bank.facade; import java.util.Collection; import de.hs_mannheim.informatik.bank.domain.Bank; +import de.hs_mannheim.informatik.bank.domain.Girokonto; import de.hs_mannheim.informatik.bank.domain.Konto; +import de.hs_mannheim.informatik.bank.infrastructure.Persistenz; public class Banksystem { private Bank bank; - - public Banksystem(String bankname) { - this.bank = new Bank(bankname); + + public Banksystem(String bankname) throws Exception { + if (Persistenz.sindDatenGespeichert(bankname)) + this.bank = (Bank) Persistenz.ladeBankDaten(bankname); + else + this.bank = new Bank(bankname); } - - public int kontoAnlegen(String name) { - Konto k = new Konto(name); - bank.addKonto(k); + + public int kontoAnlegen(String name, int auswahl) throws Exception { + int kontonummer = bank.addKonto(name, auswahl); - return k.getKontonummer(); - } - - + Persistenz.speichereBankDaten(this.bank, bank.getName()); - public boolean geldEinzahlen(long betrag, int kontonummer) { - - for (Konto k : bank.getKontenliste()) - if (k.getKontonummer() == kontonummer) { - k.geldEinzahlen(betrag); - return true; - } - - return false; - } - - public long kontstandAnzeigen(int kontonummer) { - for (Konto k : bank.getKontenliste()) - if (k.getKontonummer() == kontonummer) - return k.getStand(); return kontonummer; } - public String[] getKontenliste() { Collection konten = bank.getKontenliste(); String[] liste = new String[konten.size()]; - + int i = 0; for (Konto k : konten) { liste[i++] = k.toString(); } - + return liste; } - + public String getBankname() { return bank.getName(); } + + public long geldEinzahlen(int kontonummer, long betrag) throws Exception { + Konto konto = bank.findeKonto(kontonummer); + konto.einzahlen(betrag, "Einzahlung am Schalter", "Einzahlung", konto.getInhaber()); + + Persistenz.speichereBankDaten(this.bank, bank.getName()); + + return konto.getKontostand(); + } + + public boolean geldAuszahlen(int kontonummer, long betrag) throws Exception { + Konto konto = bank.findeKonto(kontonummer); + + Persistenz.speichereBankDaten(this.bank, bank.getName()); + + return konto.auszahlen(betrag, "Auszahlung am Schalter", "Auszahlung", konto.getInhaber()); + } + + public String[] erstelleKontoauszug(int kontonummer) { + Konto konto = bank.findeKonto(kontonummer); + + return konto.getKontobewegungen(); + } + + public boolean ÜberweisungBeauftragen(int startkonto, int zielkonto, long betrag, String verwendungszweck) { + Konto start = bank.findeKonto(startkonto); + Konto ziel = bank.findeKonto(zielkonto); + + if (start instanceof Girokonto && ziel instanceof Girokonto) { + return ((Girokonto)start).Überweise((Girokonto)ziel, betrag, verwendungszweck); + } + + return false; + } + + public long getKontostand(int kontonummer) { + Konto konto = bank.findeKonto(kontonummer); + + return konto.getKontostand(); + } + } diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java new file mode 100644 index 0000000..c2ce11c --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/facade/BanksystemTest.java @@ -0,0 +1,35 @@ +package de.hs_mannheim.informatik.bank.facade; + +import static org.junit.Assert.*; + +import org.junit.Before; +import org.junit.Test; + +public class BanksystemTest { + + private Banksystem bs; + + + @Before + public void vorDemTest() throws Exception { + bs = new Banksystem("Meine Bank"); + bs.kontoAnlegen("Hans Peter", 1000); + + + } + + + @Test + public void testEinzahlen() throws Exception { + bs.geldEinzahlen(50 , 1000); + assertTrue(bs.getKontostand(1000)== 50); + } + + @Test + public void testAuszahlen() throws Exception { + bs.kontoAnlegen("fs", 1001); + bs.geldEinzahlen(100, 1001); + bs.geldAuszahlen(10, 1001); + assertTrue(bs.getKontostand(1001) == 90); + } +} diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/infrastructure/Persistenz.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/infrastructure/Persistenz.java new file mode 100644 index 0000000..2a968f0 --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/infrastructure/Persistenz.java @@ -0,0 +1,30 @@ +package de.hs_mannheim.informatik.bank.infrastructure; + +import java.io.File; +import java.io.FileInputStream; +import java.io.FileOutputStream; +import java.io.ObjectInputStream; +import java.io.ObjectOutputStream; + +public class Persistenz { + private static final String BANK_DATEI = "-bank-data.ser"; + + public static boolean sindDatenGespeichert(String name) { + return new File(name + BANK_DATEI).exists(); + } + + public static void speichereBankDaten(Object bank, String name) throws Exception { + ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(name + BANK_DATEI)); + oos.writeObject(bank); + oos.close(); + } + + public static Object ladeBankDaten(String name) throws Exception { + ObjectInputStream ois = new ObjectInputStream(new FileInputStream(name + BANK_DATEI)); + Object bank = ois.readObject(); + ois.close(); + + return bank; + } + +} diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java index 4a1dbc0..4393b7a 100644 --- a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/ui/UI.java @@ -4,60 +4,64 @@ import java.util.Scanner; import de.hs_mannheim.informatik.bank.facade.Banksystem; - public class UI { private Banksystem bs; Scanner sc = new Scanner(System.in); public UI(Banksystem bs) { this.bs = bs; - hauptmenue(); + hauptmenü(); } - private void hauptmenue() { + private void hauptmenü() { System.out.println("Willkommen bei der " + bs.getBankname() + "!"); - mainloop: while (true) { - System.out.println(); - System.out.println("--------"); - System.out.println("Hauptmenü"); - System.out.println("1 -> Konten anzeigen"); - System.out.println("2 -> Konto anlegen"); - System.out.println("3 -> Konto einzahlen"); - System.out.println("4 -> Kontostand anzeigen"); - System.out.println("9 -> Beenden"); - System.out.println(); + mainloop: + while (true) { + System.out.println(); + System.out.println("--------"); + System.out.println("Hauptmenü"); + System.out.println("1 -> Konten anzeigen"); + System.out.println("2 -> Konto anlegen"); + System.out.println("3 -> Geld einzahlen"); + System.out.println("4 -> Geld auszahlen"); + System.out.println("5 -> Kontoauszug drucken"); + System.out.println("6 -> Überweisung beauftragen"); - System.out.print("> "); - int input = Integer.parseInt(sc.nextLine()); - System.out.println(); + System.out.println("9 -> Beenden"); + System.out.println(); - switch (input) { - case 1: - kontenAnzeigen(); - break; - case 2: - kontoAnlegen(); - break; - case 3: - kontoAuswaehlen(); - break; - case 4: - kontostandAnzeigen(); - break; - case 9: - break mainloop; + System.out.print("> "); + int input = Integer.parseInt(sc.nextLine()); + System.out.println(); + + try { + switch(input) { + case 1: kontenAnzeigen(); break; + case 2: + kontoAnlegen(); + break; + case 3: geldEinzahlen(); break; + case 4: geldAuszahlen(); break; + case 5: kontoauszugDrucken(); break; + case 6: überweisungBeauftragen(); break; + case 9: break mainloop; + } + + } catch (Exception e) { + System.err.println(e.getLocalizedMessage()); + } + System.out.println(); } - } System.out.println("Auf Wiedersehen!"); - } // hauptmenü + } // hauptmenü - private void kontenAnzeigen() { + private void kontenAnzeigen() { String[] konten = bs.getKontenliste(); if (konten.length > 0) { - System.out.println("Folgende Konten sind aktuell verfügbar:"); + System.out.println("Folgende Konten sind aktuell verfügbar:"); for (String s : konten) { System.out.println(s); } @@ -66,35 +70,80 @@ public class UI { } } - private void kontoAnlegen() { + private void kontoAnlegen() throws Exception { System.out.println("Bitte den Namen des Kontoinhabers angeben: "); String name = sc.nextLine(); - int kontonummer = bs.kontoAnlegen(name); + System.out.println("Möchten Sie ein Sparkonto (1) oder ein Girokonto (2) anlegen?"); + int auswahl = Integer.parseInt(sc.nextLine()); + + int kontonummer = bs.kontoAnlegen(name, auswahl); System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt."); } - private void kontoAuswaehlen() { - - kontenAnzeigen(); - System.out.println("Geben Sie die Kontonummer des Kontos an auf dem Sie einzahlen möchten"); - int nr = Integer.parseInt(sc.nextLine()); - System.out.println("Geben Sie den Betrag ein"); - long betrag = Long.parseLong(sc.nextLine()); - if (bs.geldEinzahlen(betrag, nr)) { - - } else { - System.out.println("Bitte geben Sie eine vorhandene Kontonummer ein"); - } + private void geldEinzahlen() throws Exception { + System.out.println("Geld einzahlen"); + System.out.print("Bitte die gewünschte Kontonummer eingeben: "); + int kontonummer = Integer.parseInt(sc.nextLine()); + + // optional prüfen, ob Konto existiert + + System.out.print("Bitte den gewünschten Betrag eingeben: "); + double betrag = Double.parseDouble(sc.nextLine()); + + long neuerKontostand = bs.geldEinzahlen(kontonummer, (long)betrag * 100); + + System.out.printf("Einzahlung erfolgreich, neuer Kontostand = %.2f Euro", (neuerKontostand / 100.0)); } + private void geldAuszahlen() throws Exception { + System.out.println("Geld auszahlen"); + System.out.print("Bitte die gewünschte Kontonummer eingeben: "); + int kontonummer = Integer.parseInt(sc.nextLine()); + System.out.print("Bitte den gewünschten Betrag eingeben: "); + double betrag = Double.parseDouble(sc.nextLine()); - private void kontostandAnzeigen() { - System.out.println("Kontonr."); - int nr = Integer.parseInt(sc.nextLine()); - System.out.println(bs.kontstandAnzeigen(nr)); - + boolean erfolgreich = bs.geldAuszahlen(kontonummer, (long)betrag * 100); + + System.out.printf("Auszahlung" + ((!erfolgreich)? " nicht" : "" )+ " erfolgreich. "); + System.out.printf("Neuer Kontostand = %.2f Euro.", (bs.getKontostand(kontonummer) / 100.0)); + } + + private void kontoauszugDrucken() { + System.out.print("Bitte die gewünschte Kontonummer für den Auszug eingeben: "); + int kontonummer = Integer.parseInt(sc.nextLine()); + + System.out.println(); + + // in echt auf einem Drucker + System.out.println("Auszug für Konto " + kontonummer); + String[] kontobewegungen = bs.erstelleKontoauszug(kontonummer); + + if (kontobewegungen.length > 0) + for (String kb : kontobewegungen) { + System.out.println(kb); + } + else + System.out.println("Noch keine Kontobewegungen."); + } + + private void überweisungBeauftragen() { + System.out.print("Bitte die Kontonummer des Ausgangskontos der Überweisung eingeben: "); + int startkonto = Integer.parseInt(sc.nextLine()); + + System.out.print("Bitte die Kontonummmer für das Zielkonto der Überweisung eingeben: "); + int zielkonto = Integer.parseInt(sc.nextLine()); + + System.out.print("Bitte den gewünschten Überweisungsbetrag eingeben: "); + double betrag = Double.parseDouble(sc.nextLine()); + + System.out.print("Bitte den Verwendungszweck eingeben: "); + String verwendungszweck = sc.nextLine(); + + boolean erfolgreich = bs.ÜberweisungBeauftragen(startkonto, zielkonto, (long)(betrag * 100), verwendungszweck); + + System.out.println("Überweisung" + ( (!erfolgreich) ? " nicht" : "") + " erfolgreich ausgeführt."); } }