[Castore-commits] Workflow.java NONE 1.1
Céline BENOIT
cbenoit at adullact1.hosting.cri74.org
Mer 22 Mar 14:37:24 CET 2006
Update of /cvsroot/castore/castore-core/src/java/fr/emn/castor/documents/metier/docGenerique/workflow
In directory adullact1:/tmp/cvs-serv25067/src/java/fr/emn/castor/documents/metier/docGenerique/workflow
Added Files:
Workflow.java
Log Message:
déplacement du fichier
--- NEW FILE: Workflow.java ---
/*
* $Id: Workflow.java,v 1.1 2006/03/22 13:37:22 cbenoit Exp $
*
* Plateforme CASTORE
* CeCILL Copyright (C) 2005-2006 by EMN
* Made by Stéphane Bouchet, Olivier Grouhan, Vanessa Bergere
* Web site = http://www.emn.fr/castore
* Contact = Cédric Dumas, e-mail = Cedric.Dumas at emn.fr
*
* Version 1.0 (1er mars 2005)
*
* Ce logiciel est un programme informatique servant à créer une plateforme
* open-source de bibliothèque numérique XML pour Conserver, Valoriser et
* Diffuser le patrimoine documentaire de votre institut.
*
* Ce logiciel est régi par la licence CeCILL soumise au droit français et
* respectant les principes de diffusion des logiciels libres. Vous pouvez
* utiliser, modifier et/ou redistribuer ce programme sous les conditions de la
* licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA sur le site
* "http://www.cecill.info". En contrepartie de l'accessibilité au code source
* et des droits de copie, de modification et de redistribution accordés par
* cette licence, il n'est offert aux utilisateurs qu'une garantie limitée. Pour
* les mêmes raisons, seule une responsabilité restreinte pèse sur l'auteur du
* programme, le titulaire des droits patrimoniaux et les concédants successifs.
* A cet égard l'attention de l'utilisateur est attirée sur les risques associés
* au chargement, à l'utilisation, à la modification et/ou au développement et à
* la reproduction du logiciel par l'utilisateur étant donné sa spécificité de
* logiciel libre, qui peut le rendre complexe à manipuler et qui le réserve
* donc à des développeurs et des professionnels avertis possédant des
* connaissances informatiques approfondies. Les utilisateurs sont donc invités
* à charger et tester l'adéquation du logiciel à leurs besoins dans des
* conditions permettant d'assurer la sécurité de leurs systèmes et ou de leurs
* données et, plus généralement, à l'utiliser et l'exploiter dans les mêmes
* conditions de sécurité. Le fait que vous puissiez accéder à cet en-tête
* signifie que vous avez pris connaissance de la licence CeCILL, et que vous en
* avez accepté les termes.
*
*/
package fr.emn.castor.documents.metier.docGenerique.workflow;
import java.util.ArrayList;
import java.util.Iterator;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* Classe representant un worflow.
*
* @author $Author: cbenoit $
* @version $Revision: 1.1 $
*/
public class Workflow {
/** Le logger. */
private static Log log = LogFactory.getLog(Workflow.class);
/** l'identifiant du workflow. */
private String id;
/** les etapes. */
protected ArrayList steps;
/** La cle pour l'identifiant de l'etape. */
public final static String STEP_NUMBER = "Stepnumber";
/**
* Constructeur.
*
* @param aId
* l'identifiant du workflow.
*/
public Workflow(final String aId) {
this.id = aId;
this.steps = new ArrayList();
}
/**
* Constructeur.
*/
private Workflow() {
//rien !
}
/**
* @return Renvoie id.
*/
public String getId() {
return this.id;
}
/**
* @param aId id à définir.
*/
public void setId(String aId) {
this.id = aId;
}
/**
* Methode ajoutant une etape au workflow.
*
* @param stepNumber
* le numero de l'etape.
*/
public void addStep(final int stepNumber) {
WorkflowStep step = new WorkflowStep();
// on verifie que l'etape n'est pas deja renseignée.
// ie qu'il n'existe pas 2 etapes "1"..
try {
if (this.steps.get(stepNumber - 1) != null) {
if (log.isErrorEnabled()) {
log.error("L'etape " + stepNumber
+ " est déja définie pour ce workflow.");
}
return;
}
} catch (IndexOutOfBoundsException ioobe) {
// on est dans le cas ou l'index demandé n'existe pas dans la liste
// donc ok, on peux rajouter une etape
}
this.steps.add(stepNumber - 1, step);
}
/**
* Renvoie l'etape correspondante au nombre passé en parametre.
*
* @param stepNumber
* @return l'etape correspondante
*/
public WorkflowStep getStep(final int stepNumber) {
try {
if (this.steps.get(stepNumber - 1) != null) {
return (WorkflowStep) this.steps.get(stepNumber - 1);
}
if (log.isErrorEnabled()) {
log.error("Pas d'étape correspondant au numero "
+ stepNumber);
}
} catch (IndexOutOfBoundsException ioobe) {
// sert lorsque l'on veux retrouver la prochaine etape alors
// que l'on est deja a la derniere.
}
return null;
}
// public void setStep(final int stepNumber){
//
// }
/**
* Renvoie le nombre total d'etape pour ce workflow.
*
* @return le nombre d'etapes de ce workflow.
*/
public int getNumberOfSteps() {
return this.steps.size();
}
/**
* Construit un worklow spécifique.
*
* @param workflowBase
* base pour le workflow
* @param docId
* id du document
*/
private Workflow(Workflow workflowBase) {
this(workflowBase.getId());
int numEtape = 1;
WorkflowStep etape = workflowBase.getStep(numEtape);
while (etape != null) {
this.addStep(etape);
etape = workflowBase.getStep(++numEtape);
}
}
/**
* Ajout et clonage d'une etape.
*
* @param step
* etape a ajouter
*/
private void addStep(WorkflowStep step) {
//copie de l'etape
WorkflowStep newStep = new WorkflowStep();
newStep.setValidationType(step.getValidationType());
Iterator validateurs = step.getValidateurs().iterator();
while (validateurs.hasNext()) {
newStep.addValidateur((String) validateurs.next());
}
Iterator validateursLink = step.getValidateursLink().iterator();
while (validateursLink.hasNext()) {
newStep.addValidateurLink((String) validateursLink.next());
}
this.steps.add(newStep);
}
/**
* Clonage du workflow.
* @return copie du workflow.
*/
public Workflow cloneWorkflow() {
return new Workflow(this);
}
}
Plus d'informations sur la liste de diffusion Castore-commits