props.load(istream);
istream.close();
HBCIUtils.init(props, new MyCallback(args));
// erzeugen des passport-objektes
HBCIPassport passport=AbstractHBCIPassport.getInstance();
try {
// initialisieren des hbci-handlers f�r das passport
String version=passport.getHBCIVersion();
HBCIHandler handler=new HBCIHandler(version.length()!=0?version:HBCIUtils.getParam("default.hbciversion"),passport);
try {
// batch-datei �ffnen
BufferedReader reader=new BufferedReader(new FileReader(args[2]));
String line;
try {
int state=STATE_NEED_JOBNAME;
boolean lljob=false; // low- oder high-level-job?
HBCIJob job=null; // job-objekt
String jobid=null; // job-bezeichner
String customerId=null; // customer-id f�r job
Hashtable<String, Object> jobs=new Hashtable<String, Object>(); // liste aller jobs
// batch-datei zeilenweise einlesen und auswerten
while ((line=reader.readLine())!=null) {
line=line.trim();
// kommentare ignorieren
if (line.startsWith("#")) {
continue;
}
if (state==STATE_NEED_JOBNAME && line.length()!=0) {
// es wird der beginn einer job-definition erwartet
StringTokenizer tok=new StringTokenizer(line,":");
// jobnamen extrahieren
String jobname=tok.nextToken().trim();
if (jobname.equals("--")) {
// wenn jobname="--", dann neue hbci-message erzeugen
customerId=(tok.hasMoreTokens()?tok.nextToken().trim():null);
handler.newMsg(customerId);
} else {
// ansonsten handelt es sich um einen "richtigen" job
String resultMode;
if (jobname.startsWith("_")) {
// wenn jobname mit "_" beginnt, handelt es
// sich um einen low-level-jobnamen
job=handler.newLowlevelJob(jobname.substring(1));
lljob=true;
// zu einem low-level-job m�ssen zus�tzlich noch
// eine ID (zum sp�teren wiederfinden des jobs)
// und optional eine kunden-id festgelegt werden
jobid=tok.nextToken().trim();
resultMode="toString";
customerId=(tok.hasMoreTokens()?tok.nextToken().trim():null);
} else {
// wenn jobname nicht mit "_" beginnt, ist es
// ein high-level-job
job=handler.newJob(jobname);
lljob=false;
// zu einem high-level-job m�ssen zus�tzlich noch
// eine ID (zum sp�teren wiederfinden des jobs),
// ein modus f�r die ausgabe der ergebisdaten
// und optional eine kunden-id festgelegt werden
jobid=tok.nextToken().trim();
resultMode=tok.nextToken().trim();
customerId=(tok.hasMoreTokens()?tok.nextToken().trim():null);
}
// job in menge der jobs speichern
jobs.put(jobid,job);
// ... und ausgabemodus f�r diesen job merken
jobs.put(jobid+"_resultMode",resultMode);
state=STATE_NEED_JOBPARAMS;
}
} else if (state==STATE_NEED_JOBPARAMS) {
// bis zur n�chsten leerzeile oder dem dateienende
// werden jetzt alle zeilen als job-parameter
// interpretiert
if (line.length()!=0) {
StringTokenizer tok=new StringTokenizer(line,"=");
// parameternamen und -wert holen
String paramName=tok.nextToken().trim();
if (!tok.hasMoreTokens()) {
continue;
}
String paramValue=tok.nextToken().trim();
// f�r low-level-jobs m�ssen die parameter mit
// einem "_" beginnen, bei high-level-jobs
// d�rfen sie *nicht* mit einem "_" beginnen
if (paramName.startsWith("_")!=lljob) {
if (lljob) {
throw new HBCI_Exception("*** "+jobid+" is a lowlevel job, so parameter names have to start with '_'");
}
throw new HBCI_Exception("*** "+jobid+" is a highlevel job, so parameter names must not start with '_'");
}
// wenn es sich um einen low-level-job, den
// f�hrenden "_" beim parameter-namen entfernen
if (lljob) {
paramName=paramName.substring(1);
}
// wenn der parameter-wert mit einem "<" beginnt,
// so soll der wert des parameter aus der datei
// gelesen werden, die nach dem "<" spezifiziert
// ist
if (paramValue.startsWith("<")) {
// �ffnen der datei
String filename=paramValue.substring(1);
FileInputStream fin=new FileInputStream(filename);
// puffer f�r einlesen der datei
byte[] buffer=new byte[2048];
int len;
StringBuffer content=new StringBuffer();
// datei in stringbuffer einlesen
while ((len=fin.read(buffer))>0) {
content.append(new String(buffer,0,len,"ISO-8859-1"));
}
// datei schlie�en
fin.close();
// parameterwert ist inhalt des stringbuffers
paramValue=content.toString();
}
// parameter f�r aktuellen job setzen
job.setParam(paramName,paramValue);
} else {
// leerzeile gefunden - damit ist die parameter-
// spez. f�r den aktuellen job beendet
// aktuellen job zur job-queue hinzuf�gen
job.addToQueue(customerId);
state=STATE_NEED_JOBNAME;
}
}
}
// wenn noch ein job "in bearbeitung" ist, der noch nicht
// zur job-queue hinzugef�gt wurde, dann das jetzt nachholen
if (state==STATE_NEED_JOBPARAMS) {
job.addToQueue(customerId);
}
// alle batch-jobs ausf�hren
handler.execute();
// ergebnis-writer f�r ok-jobs und f�r fehlerhafte jobs
// erzeugen
PrintWriter writer=new PrintWriter(new FileWriter(args[3]));
PrintWriter errWriter=new PrintWriter(new FileWriter(args[3]+".err"));
try {
// alle bekannten job-bezeichner (IDs) durchlaufen
for (Enumeration<String> jobIds=jobs.keys();jobIds.hasMoreElements();) {
jobid=jobIds.nextElement();
if (jobid.endsWith("_resultMode")) {
continue;
}
// den dazugeh�rigen job holen
job=(HBCIJob)jobs.get(jobid);
if (job.getJobResult().isOK()) {
// wenn der job erfolgreich gelaufen ist
// ausgabe von jobid
writer.println("jobid:"+jobid);
// ausgabe der hbci-status-meldungen zu diesem job
writer.println("job status:");
writer.println(job.getJobResult().getJobStatus());
// ausgabe der job-ergebnisse
writer.println("job result:");
String resultMode=(String)jobs.get(jobid+"_resultMode");
if (resultMode.equals("props")) {
// ausgabemodus="props": alle ergebnisdaten
// als lowlevel-properties ausgeben
Properties result=job.getJobResult().getResultData();
if (result!=null) {
// array mit result-properties holen und
// sortieren
String[] keys=(String[])new ArrayList(result.keySet()).toArray(new String[0]);
Arrays.sort(keys);
// ausgabe aller result-properties
for (int i=0;i<keys.length;i++) {
String name=keys[i];
String value=result.getProperty(name);
writer.println(name+"="+value);
}
}
} else {
// ausgabemodus="toString": job-spezifische
// toString()-methode f�r formatierung der
// ergebnisdaten aufrufen
writer.println(job.getJobResult());
}
// leerzeile einf�gen
writer.println();
} else {
// wenn ein job fehler erzeugt hatte, die fehlermeldungen
// an die err-datei anh�ngen
errWriter.println("jobid:"+jobid);
errWriter.println("global status:");
errWriter.println(job.getJobResult().getGlobStatus().getErrorString());
errWriter.println("job status:");
errWriter.println(job.getJobResult().getJobStatus().getErrorString());
errWriter.println();
}
}
} finally {
writer.close();
errWriter.close();
}
} finally {
reader.close();
}
} finally {
handler.close();
passport=null;
}
} finally {
if (passport!=null) {
passport.close();
}
}
}