Package de.willuhn.jameica.hbci.gui.action

Source Code of de.willuhn.jameica.hbci.gui.action.Synchronize$MyMessageConsumer

/**********************************************************************
* $Source: /cvsroot/hibiscus/hibiscus/src/de/willuhn/jameica/hbci/gui/action/Synchronize.java,v $
* $Revision: 1.18 $
* $Date: 2007/12/05 22:45:59 $
* $Author: willuhn $
* $Locker:  $
* $State: Exp $
*
* Copyright (c) by willuhn.webdesign
* All rights reserved
*
**********************************************************************/

package de.willuhn.jameica.hbci.gui.action;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import de.willuhn.jameica.gui.Action;
import de.willuhn.jameica.hbci.HBCI;
import de.willuhn.jameica.hbci.gui.dialogs.SynchronizeExecuteDialog;
import de.willuhn.jameica.hbci.synchronize.Synchronization;
import de.willuhn.jameica.hbci.synchronize.SynchronizeBackend;
import de.willuhn.jameica.hbci.synchronize.SynchronizeEngine;
import de.willuhn.jameica.hbci.synchronize.jobs.SynchronizeJob;
import de.willuhn.jameica.messaging.Message;
import de.willuhn.jameica.messaging.MessageBus;
import de.willuhn.jameica.messaging.MessageConsumer;
import de.willuhn.jameica.messaging.QueryMessage;
import de.willuhn.jameica.messaging.StatusBarMessage;
import de.willuhn.jameica.system.Application;
import de.willuhn.jameica.system.OperationCanceledException;
import de.willuhn.logging.Logger;
import de.willuhn.util.ApplicationException;
import de.willuhn.util.I18N;
import de.willuhn.util.ProgressMonitor;

/**
* Hilfsklasse zum Ausfuehren der Synchronisierung.
*/
public class Synchronize implements Action
{
  private final static I18N i18n = Application.getPluginLoader().getPlugin(HBCI.class).getResources().getI18N();
  private MessageConsumer mc = new MyMessageConsumer();
  private Iterator<Synchronization> list = null;

  /**
   * @see de.willuhn.jameica.gui.Action#handleAction(java.lang.Object)
   * Erwartet eine Liste mit Objekten des Typs {@link Synchronization}.
   */
  public void handleAction(Object context) throws ApplicationException
  {
    Logger.info("Start synchronization");

    if (!(context instanceof List))
      throw new ApplicationException(i18n.tr("Keine Synchronisierungsaufgaben ausgew�hlt"));

    List list = (List) context;
    if (list.size() == 0)
      throw new ApplicationException(i18n.tr("Keine Synchronisierungsaufgaben ausgew�hlt"));

    Logger.info("backends to synchronize: " + list.size());
    List<Synchronization> result = new ArrayList<Synchronization>();
    List<SynchronizeJob> nonRecurring = new ArrayList<SynchronizeJob>();
    for (Object o:list)
    {
      if (!(o instanceof Synchronization))
      {
        Logger.warn("type " + o.getClass() + " is no valid synchronization");
        continue;
      }

      Synchronization sync = (Synchronization) o;
      List<SynchronizeJob> jobs = sync.getJobs();
      for (SynchronizeJob job:jobs)
      {
        if (!job.isRecurring())
          nonRecurring.add(job);
      }
      result.add(sync);
    }
   
    this.checkNonRecurring(nonRecurring);
   
    Logger.info("synchronizing " + result.size() + " backends");
    this.list = result.iterator();
   
    MessageBus.send(SynchronizeEngine.STATUS,ProgressMonitor.STATUS_RUNNING);
    // Auf die Events registrieren, um die Folge-Backends zu starten
    Application.getMessagingFactory().getMessagingQueue(SynchronizeBackend.QUEUE_STATUS).registerMessageConsumer(this.mc);
    this.sync();
  }
 
  /**
   * Zeigt nochmal einen Warndialog an, wenn in der Synchronisation Auftraege
   * enthalten, die Geld bewegen. Dann hat der User die Chance, den Vorgang
   * noch abzubrechen, falls er sie auf der Startseite in der Liste der Synchronisierungsaufgaben
   * uebersehen hat - z.Bsp. weil er viele Konten hat und die Ueberweisungen ausserhalb
   * des sichtbaren Bereichs waren.
   * @param jobs die Liste der Auftraege.
   * @throws ApplicationException
   * @throws OperationCanceledException
   */
  private void checkNonRecurring(List<SynchronizeJob> jobs) throws ApplicationException, OperationCanceledException
  {
    if (jobs == null || jobs.size() == 0)
      return;
   
    if (Application.inServerMode())
      return;

    try
    {
      SynchronizeExecuteDialog d = new SynchronizeExecuteDialog(jobs,SynchronizeExecuteDialog.POSITION_CENTER);
      d.open();
    }
    catch (ApplicationException ae)
    {
      throw ae;
    }
    catch (OperationCanceledException oce)
    {
      throw oce;
    }
    catch (Exception e)
    {
      Logger.error("error while checking jobs",e);
      throw new ApplicationException(i18n.tr("Fehler beim Ausf�hren der Auftr�ge: {0}",e.getMessage()));
    }
  }
 
  /**
   * Startet den naechsten Durchlauf.
   * @throws ApplicationException
   */
  private void sync()
  {
    if (!this.list.hasNext())
    {
      Logger.info("no more backends. synchronization done");
      finish(ProgressMonitor.STATUS_DONE);
      return;
    }
   
    try
    {
      // Sonst naechste Iteration starten
      Synchronization s = this.list.next();
      SynchronizeBackend backend = s.getBackend();
      List<SynchronizeJob> jobs = s.getJobs();
      Logger.info("synchronizing backend " + backend.getName() + " with " + jobs.size() + " jobs");
      backend.execute(jobs);
    }
    catch (ApplicationException ae)
    {
      Application.getMessagingFactory().getMessagingQueue(SynchronizeBackend.QUEUE_STATUS).unRegisterMessageConsumer(this.mc);
      Application.getMessagingFactory().sendMessage(new StatusBarMessage(ae.getMessage(),StatusBarMessage.TYPE_ERROR));
      MessageBus.send(SynchronizeEngine.STATUS,ProgressMonitor.STATUS_ERROR);
    }
    catch (OperationCanceledException oce)
    {
      Application.getMessagingFactory().getMessagingQueue(SynchronizeBackend.QUEUE_STATUS).unRegisterMessageConsumer(this.mc);
      Application.getMessagingFactory().sendMessage(new StatusBarMessage(i18n.tr("Synchronisierung abgebrochen"),StatusBarMessage.TYPE_ERROR));
      MessageBus.send(SynchronizeEngine.STATUS,ProgressMonitor.STATUS_CANCEL);
    }
  }
 
  /**
   * Beendet die Synchronisierung mit dem angegebenen Status.
   * @param status der Status.
   */
  private void finish(int status)
  {
    MessageBus.send(SynchronizeEngine.STATUS,status);
    Application.getMessagingFactory().getMessagingQueue(SynchronizeBackend.QUEUE_STATUS).unRegisterMessageConsumer(this.mc);
  }
 
  /**
   * Wird ueber die Status-Events der Backends benachrichtigt und startet dann das naechste
   */
  private class MyMessageConsumer implements MessageConsumer
  {
    /**
     * @see de.willuhn.jameica.messaging.MessageConsumer#getExpectedMessageTypes()
     */
    public Class[] getExpectedMessageTypes()
    {
      return new Class[]{QueryMessage.class};
    }

    /**
     * @see de.willuhn.jameica.messaging.MessageConsumer#handleMessage(de.willuhn.jameica.messaging.Message)
     */
    public void handleMessage(Message message) throws Exception
    {
      QueryMessage msg = (QueryMessage) message;
      Object data = msg.getData();
      if (!(data instanceof Integer))
      {
        Logger.warn("got unknown data: " + data);
        return;
      }
     
      int status = ((Integer) data).intValue();
      if (status == ProgressMonitor.STATUS_DONE)
      {
        sync();
      }
      else if (status == ProgressMonitor.STATUS_ERROR || status == ProgressMonitor.STATUS_CANCEL)
      {
        finish(status);
      }
    }

    /**
     * @see de.willuhn.jameica.messaging.MessageConsumer#autoRegister()
     */
    public boolean autoRegister()
    {
      return false;
    }
  }
}
TOP

Related Classes of de.willuhn.jameica.hbci.gui.action.Synchronize$MyMessageConsumer

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.