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..b6c7d95 --- /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 exception.BankException; + +public class Girokonto extends Konto { + + public Girokonto(String inhaber) { + super(inhaber); + } + + public boolean überweise(Girokonto ziel, long betrag, String zweck) throws BankException { + if (super.getStand() - betrag >= 0) { + this.auszahlenKonto(betrag, zweck, "Überweisungsausgang", super.getInhaber()); + ziel.einzahlenKonto(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 2b45836..223d199 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 @@ -15,10 +15,13 @@ public class Konto implements Serializable{ private long stand = 0; private String inhaber; private ArrayList liste = new ArrayList<>(); + private ArrayList kontobewegungen; public Konto(String inhaber) { nummer = 1000 + kontozähler++; this.inhaber = inhaber; + + this.kontobewegungen = new ArrayList<>(); } public int getKontonummer() { @@ -33,15 +36,23 @@ public class Konto implements Serializable{ return inhaber; } - public void einzahlenKonto(long betrag) throws BankException { + public void einzahlenKonto(long betrag, String zweck, String art, String auftraggeber) throws BankException { if (betrag < 0) { throw new BankException("Betrag darf nicht negativ sein"); } this.stand = stand + betrag; + + kontobewegungen.add(new Kontobewegung(betrag, zweck, art, auftraggeber)); } - public void auszahlenKonto(long betrag) { - this.stand = stand - betrag; + public void auszahlenKonto(long betrag, String zweck, String art, String auftraggeber) throws BankException { + if (this.stand - betrag >= 0) { + this.stand = stand - betrag; + } else { + throw new BankException("Kontostand darf nicht unter 0 sein"); + } + + kontobewegungen.add(new Kontobewegung(betrag, zweck, art, auftraggeber)); } public void kontoauszugErzeugenKonto(long betrag) { @@ -66,6 +77,18 @@ public class Konto implements Serializable{ Konto.kontozähler = kontozähler; } + public String[] getKontobewgungen() { + String[] auflistung = new String[kontobewegungen.size()]; + + int i = 0; + for (Kontobewegung kb : kontobewegungen) { + auflistung[i++] = kb.toString(); + } + + return auflistung; + + } + @Override public String toString() { return "Konto [nummer=" + nummer + ", inhaber=" + inhaber + ", stand=" + stand + "]"; diff --git a/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java new file mode 100644 index 0000000..77451c5 --- /dev/null +++ b/Bank-Beispiel/src/de/hs_mannheim/informatik/bank/domain/Kontobewegung.java @@ -0,0 +1,28 @@ +package de.hs_mannheim.informatik.bank.domain; + +import java.util.Date; + +public class Kontobewegung { + private long betrag; + private Date date; + private String betreff; + private String art; + private String auftraggeber; + + public Kontobewegung(long betrag, String betreff, String art, String auftraggeber) { + super(); + this.betrag = betrag; + this.betreff = betreff; + this.art = art; + this.auftraggeber = auftraggeber; + + this.date = new Date(); + } + + @Override + public String toString() { + return "Kontobewegung [betrag=" + betrag + ", date=" + date + ", 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 2ea6819..40d8ade 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 @@ -5,6 +5,7 @@ import java.util.ArrayList; 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 exception.BankException; import persistence.PersistenzSerialisiert; @@ -16,10 +17,19 @@ public class Banksystem { this.bank = new Bank(bankname); } - public int kontoAnlegen(String name) { - Konto k = new Konto(name); + public int kontoAnlegen(String name, int auswahl) { + Konto k; + + if (auswahl == 1) { + k = new Konto(name); + } else { + k = new Girokonto(name); + } + bank.addKonto(k); + System.out.println(k instanceof Girokonto); + return k.getKontonummer(); } @@ -44,11 +54,11 @@ public class Banksystem { } public void einzahlenBanksystem(int kNummer, long betrag) throws BankException { - bank.getKonten().get(kNummer).einzahlenKonto(betrag); + bank.getKonten().get(kNummer).einzahlenKonto(betrag, "Einzahlung am Schalter", "Einzahlung", bank.getKonten().get(kNummer).getInhaber()); } - public void auszahlenBanksystem(int kNummer, long betrag) { - bank.getKonten().get(kNummer).auszahlenKonto(betrag); + public void auszahlenBanksystem(int kNummer, long betrag) throws BankException { + bank.getKonten().get(kNummer).auszahlenKonto(betrag, "Auszahlung am Schalter", "Auszahlung", bank.getKonten().get(kNummer).getInhaber()); } public void kontoauszugErzeugenBanksystem(int kNummer, long betrag) { @@ -82,4 +92,10 @@ public class Banksystem { Konto.setKontozähler(bank.getKontenliste().size()); } + + public String[] erstelleKontoauszug(int kNummer) { + Konto konto = bank.getKonto(kNummer); + + return konto.getKontobewgungen(); + } } 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 997c17b..c92ec88 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 @@ -32,7 +32,8 @@ public class UI { System.out.println("6 -> Kontoauszug anzeigen"); System.out.println("7 -> Konten speichern?"); System.out.println("8 -> Konten laden?"); - System.out.println("9 -> Beenden"); + System.out.println("9 -> Kontoauszug drucken?"); + System.out.println("99 -> Beenden"); System.out.println(); System.out.print("> "); @@ -48,7 +49,8 @@ public class UI { case 6: kontoauszugAnzeigen(); break; case 7: bs.kontenSpeichern(); break; case 8: bs.kontenLaden(); break; - case 9: break mainloop; + case 9: kontoauszugDrucken(); break; + case 99: break mainloop; } } @@ -86,8 +88,13 @@ public class UI { private void kontoAnlegen() throws IOException { System.out.println("Bitte den Namen des Kontoinhabers angeben: "); String name = sc.nextLine(); + + System.out.println("Möchten Sie ein normales Konto oder ein Girokonto anlegen?"); + System.out.println("Normales Konto 1"); + System.out.println("Girokonto 2"); + int kontoArt = Integer.parseInt(sc.nextLine()); - int kontonummer = bs.kontoAnlegen(name); + int kontonummer = bs.kontoAnlegen(name, kontoArt); System.out.println("Konto mit der Nummer " + kontonummer + " neu angelegt."); // PersistenzSerialisiert.objectSpeichern(bs.getKontoBanksystem(kontonummer)); } @@ -119,7 +126,7 @@ public class UI { } - private void auszahlen() { + private void auszahlen() throws BankException { System.out.println("Bitte den Namen des Kontoinhabers angeben: "); String kName = sc.nextLine(); String [] konten = bs.getKontenliste(); @@ -152,5 +159,22 @@ public class UI { System.out.println("Auftraggeber: " + bs.getKontoBanksystem(temp).getInhaber()); bs.kontoauszugAnzeigenBanksystem(temp); } + + private void kontoauszugDrucken() { + System.out.println("Bitte die gewünschte Kontonummer für den Auszug eingeben: "); + int kNummer = Integer.parseInt(sc.nextLine()); + + System.out.println(); + + System.out.println("Auszug für Konto " + kNummer); + String[] kontobewegungen = bs.erstelleKontoauszug(kNummer); + + if (kontobewegungen.length > 0) + for (String kb : kontobewegungen) { + System.out.println(kb); + } + else + System.out.println("Noch keine Kontobewegungen."); + } }