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.");
}
}