org.kapott.hbci.tools.INILetter Maven / Gradle / Ivy
Show all versions of hbci4j-adorsys Show documentation
/* $Id: INILetter.java,v 1.1 2011/05/04 22:37:45 willuhn Exp $
This file is part of HBCI4Java
Copyright (C) 2001-2008 Stefan Palme
HBCI4Java is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
HBCI4Java is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.kapott.hbci.tools;
import org.kapott.hbci.passport.HBCIPassport;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
/**
* Tool zum Erzeugen eines INI-Briefes. Diese Klasse enthält kein Programmier-API,
* sondern ist direkt mit
* java org.kapott.hbci.tools.INILetter [passporttype [passport-file [textfile]]]
* ausführbar.
* Mit diesem Tool kann zu einem bereits existierenden RDH-Passport ein
* INI-Brief erzeugt werden. Das Passport muss dabei schon initialisiert
* sein, und es müssen bereits Schlüssel erzeugt worden sein. Dieses Tool
* wird also i.d.R. dann benötigt, wenn ein Passport erstmalig erzeugt wird
* und die Programmausführung mit der Meldung "Es muss ein INI-Brief erzeugt
* werden..." abbricht.
* Das erste Kommandozeilenargument passporttype
gibt an, ob es sich um ein RDH
-,
* ein RDHNew
-, ein SIZRDHFile
- oder ein RDHXFile
-Passport-Format handelt.
* RDH
-Passports sollten nicht mehr verwendet werden (siehe dazu auch Datei
* README.RDHNew
). Für SIZRDHFile
-Passports wird eine separate
* Bibliothek benötigt (siehe {@link org.kapott.hbci.passport.HBCIPassportSIZRDHFile}).
* Das zweite Kommandozeilenargument passport-file
ist dabei die
* Schlüsseldatei, in der die Passport-Daten gespeichert sind (entspricht
* also dem Inhalt von client.passport.*.filename
).
* Das Argument textfile
gibt den Dateinamen einer Datei an,
* in die der INI-Brief geschrieben werden soll. Der INI-Brief wird als
* reine ASCII-Ausgabe erzeugt, welche ausgedruckt, unterschrieben und an die
* Bank versandt werden kann.
* Falls ein oder beide Parameter nicht angegeben sind, so fragt das Tool
* interaktiv nach den entsprechenden Daten.
*/
public final class INILetter {
private static HBCIPassport passport;
private static String getArg(String[] args, int idx, String st)
throws IOException {
String ret = null;
System.out.print(st + ": ");
System.out.flush();
if (args != null && idx < args.length) {
ret = args[idx];
System.out.println(ret);
} else {
ret = new BufferedReader(new InputStreamReader(System.in)).readLine();
}
return ret;
}
}