Package de.sub.goobi.forms

Source Code of de.sub.goobi.forms.StatistikForm

package de.sub.goobi.forms;

/**
* This file is part of the Goobi Application - a Workflow tool for the support of mass digitization.
*
* Visit the websites for more information.
*         - http://www.goobi.org
*         - http://launchpad.net/goobi-production
*         - http://gdz.sub.uni-goettingen.de
*       - http://www.intranda.com
*       - http://digiverso.com
*
* This program 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.
*
* This program 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
*
* Linking this library statically or dynamically with other modules is making a combined work based on this library. Thus, the terms and conditions
* of the GNU General Public License cover the whole combination. As a special exception, the copyright holders of this library give you permission to
* link this library with independent modules to produce an executable, regardless of the license terms of these independent modules, and to copy and
* distribute the resulting executable under terms of your choice, provided that you also meet, for each linked independent module, the terms and
* conditions of the license of that module. An independent module is a module which is not derived from or based on this library. If you modify this
* library, you may extend this exception to your version of the library, but you are not obliged to do so. If you do not wish to do so, delete this
* exception statement from your version.
*/
import java.util.ArrayList;
import java.util.Calendar;
import java.util.GregorianCalendar;
import java.util.Iterator;
import java.util.List;
import java.util.Random;

import org.apache.log4j.Logger;
import org.hibernate.Criteria;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.criterion.Restrictions;

import de.sub.goobi.beans.Schritt;
import de.sub.goobi.config.ConfigMain;
import de.sub.goobi.helper.Helper;
import de.sub.goobi.helper.exceptions.DAOException;
import de.sub.goobi.persistence.BenutzerDAO;
import de.sub.goobi.persistence.ProzessDAO;
import de.sub.goobi.persistence.SchrittDAO;

public class StatistikForm {
  private static final Logger myLogger = Logger.getLogger(StatistikForm.class);
  Calendar cal = new GregorianCalendar();
  int n = 200;

  /**
   * @return Anzahl aller Literatureinträge
   * @throws DAOException
   */
  public Integer getAnzahlLiteraturGesamt() {
    return Integer.valueOf(0);
  }

  /**
   * The function getAnzahlBenutzer() counts the number of user accounts in the goobi.production environment. Since user accounts are not hard
   * deleted from the database when the delete button is pressed a where clause is used in the SQL statement to exclude the deleted accounts from
   * the sum.
   *
   * @return the count of valid user accounts
   * @throws DAOException
   *             if the current session can't be retrieved or an exception is thrown while performing the rollback.
   */

  public Long getAnzahlBenutzer() {
    try {
      return new BenutzerDAO().count("from Benutzer where isVisible is null");
    } catch (DAOException e) {
      Helper.setFehlerMeldung("fehlerBeimEinlesen", e.getMessage());
      return null;
    }
  }

  /**
   * @return Anzahl der Benutzer
   * @throws DAOException
   */
  public Long getAnzahlBenutzergruppen() {
    try {
      return new BenutzerDAO().count("from Benutzergruppe");
    } catch (DAOException e) {
      Helper.setMeldung(null, "fehlerBeimEinlesen", e.getMessage());
      return null;
    }
  }

  /**
   * @return Anzahl der Benutzer
   * @throws DAOException
   */
  public Long getAnzahlProzesse() {
    try {
      return new ProzessDAO().count("from Prozess");
    } catch (DAOException e) {
      Helper.setFehlerMeldung("fehlerBeimEinlesen", e.getMessage());
      return null;
    }
  }

  /**
   * @return Anzahl der Benutzer
   * @throws DAOException
   */
  public Long getAnzahlSchritte() {
    try {
      return new SchrittDAO().count("from Schritt");
    } catch (DAOException e) {
      myLogger.error("Hibernate error", e);
      Helper.setFehlerMeldung("fehlerBeimEinlesen", e);
      return Long.valueOf(-1);
    }
  }

  /**
   * @return Anzahl der Benutzer
   * @throws DAOException
   */
  public Long getAnzahlVorlagen() {
    Session session = Helper.getHibernateSession();
    return (Long) session.createQuery("select count(*) " + "from Vorlage").uniqueResult();
  }

  /**
   * @return Anzahl der Benutzer
   * @throws DAOException
   */
  public Long getAnzahlWerkstuecke() {
    Session session = Helper.getHibernateSession();
    return (Long) session.createQuery("select count(*) " + "from Werkstueck").uniqueResult();
  }

  /**
   * @return Dummy-Rückgabe
   * @throws DAOException
   */
  public int getDummy() {
    this.n++;
    return new Random().nextInt(this.n);
  }

  public int getAnzahlAktuelleSchritte() {
    return getAnzahlAktuelleSchritte(false, false);
  }

  public int getAnzahlAktuelleSchritteOffen() {
    return getAnzahlAktuelleSchritte(true, false);
  }

  public int getAnzahlAktuelleSchritteBearbeitung() {
    return getAnzahlAktuelleSchritte(false, true);
  }

  @SuppressWarnings("unchecked")
  private int getAnzahlAktuelleSchritte(boolean inOffen, boolean inBearbeitet) {
    /* aktuellen Benutzer ermitteln */
    LoginForm login = (LoginForm) Helper.getManagedBeanValue("#{LoginForm}");
    if (login.getMyBenutzer() == null) {
      return 0;
    }

    try {
      Session session = Helper.getHibernateSession();
      Criteria crit = session.createCriteria(Schritt.class);

      /* Liste der IDs */
      List<Integer> trefferListe = new ArrayList<Integer>();

      /*
       * -------------------------------- die Treffer der Benutzergruppen --------------------------------
       */
      Criteria critGruppen = session.createCriteria(Schritt.class);
      if (!inOffen && !inBearbeitet) {
        critGruppen.add(Restrictions.or(Restrictions.eq("bearbeitungsstatus", Integer.valueOf(1)),
            Restrictions.like("bearbeitungsstatus", Integer.valueOf(2))));
      }
      if (inOffen) {
        critGruppen.add(Restrictions.eq("bearbeitungsstatus", Integer.valueOf(1)));
      }
      if (inBearbeitet) {
        critGruppen.add(Restrictions.eq("bearbeitungsstatus", Integer.valueOf(2)));
      }

      /* nur Prozesse, die keine Vorlagen sind */
      critGruppen.createCriteria("prozess", "proz");
      critGruppen.add(Restrictions.eq("proz.istTemplate", Boolean.valueOf(false)));

      /* nur Schritte, wo Benutzergruppen des aktuellen Benutzers eingetragen sind */
      critGruppen.createCriteria("benutzergruppen", "gruppen").createCriteria("benutzer", "gruppennutzer");
      critGruppen.add(Restrictions.eq("gruppennutzer.id", login.getMyBenutzer().getId()));

      /* die Treffer sammeln */
      for (Iterator<Schritt> iter = critGruppen.list().iterator(); iter.hasNext();) {
        Schritt step = iter.next();
        trefferListe.add(step.getId());
      }

      /*
       * -------------------------------- Treffer der Benutzer --------------------------------
       */
      Criteria critBenutzer = session.createCriteria(Schritt.class);
      if (!inOffen && !inBearbeitet) {
        critBenutzer.add(Restrictions.or(Restrictions.eq("bearbeitungsstatus", Integer.valueOf(1)),
            Restrictions.like("bearbeitungsstatus", Integer.valueOf(2))));
      }
      if (inOffen) {
        critBenutzer.add(Restrictions.eq("bearbeitungsstatus", Integer.valueOf(1)));
      }
      if (inBearbeitet) {
        critBenutzer.add(Restrictions.eq("bearbeitungsstatus", Integer.valueOf(2)));
      }

      /* nur Prozesse, die keine Vorlagen sind */
      critBenutzer.createCriteria("prozess", "proz");
      critBenutzer.add(Restrictions.eq("proz.istTemplate", Boolean.valueOf(false)));

      /* nur Schritte, wo der aktuelle Benutzer eingetragen ist */
      critBenutzer.createCriteria("benutzer", "nutzer");
      critBenutzer.add(Restrictions.eq("nutzer.id", login.getMyBenutzer().getId()));

      /* die Treffer sammeln */
      for (Iterator<Schritt> iter = critBenutzer.list().iterator(); iter.hasNext();) {
        Schritt step = iter.next();
        trefferListe.add(step.getId());
      }

      /*
       * -------------------------------- nun nur die Treffer übernehmen, die in der Liste sind --------------------------------
       */
      crit.add(Restrictions.in("id", trefferListe));
      return crit.list().size();

    } catch (HibernateException he) {
      Helper.setFehlerMeldung("fehlerBeimEinlesen", he.getMessage());
      return 0;
    }
  }

  public boolean getShowStatistics() {
    return ConfigMain.getBooleanParameter("showStatisticsOnStartPage", true);
  }
}
TOP

Related Classes of de.sub.goobi.forms.StatistikForm

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.