package de.sub.goobi.helper;
/**
* 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.List;
import org.apache.log4j.Logger;
import org.goobi.production.enums.PluginType;
import org.goobi.production.plugin.PluginLoader;
import org.goobi.production.plugin.interfaces.IStepPlugin;
import de.sub.goobi.persistence.apache.StepManager;
import de.sub.goobi.persistence.apache.StepObject;
public class ScriptThreadWithoutHibernate extends Thread {
HelperSchritteWithoutHibernate hs = new HelperSchritteWithoutHibernate();
private StepObject step;
public String rueckgabe = "";
public boolean stop = false;
private static final Logger logger = Logger.getLogger(ScriptThreadWithoutHibernate.class);
public ScriptThreadWithoutHibernate(StepObject step) {
this.step = step;
setDaemon(true);
}
@Override
public void run() {
boolean automatic = this.step.isTypAutomatisch();
logger.debug("step is automatic: " + automatic);
List<String> scriptPaths = StepManager.loadScripts(this.step.getId());
logger.debug("found " + scriptPaths.size() + " scripts");
if (scriptPaths.size() > 0) {
this.hs.executeAllScriptsForStep(this.step, automatic);
} else if (this.step.isTypExport()) {
this.hs.executeDmsExport(this.step, automatic);
} else if (this.step.getStepPlugin() != null && this.step.getStepPlugin().length() > 0) {
IStepPlugin isp = (IStepPlugin) PluginLoader.getPluginByTitle(PluginType.Step, step.getStepPlugin());
isp.initialize(step, "");
if (isp.execute()) {
hs.CloseStepObjectAutomatic(step);
}
}
}
public void stopThread() {
this.rueckgabe = "Import wurde wegen Zeitüberschreitung abgebrochen";
this.stop = true;
}
}