[Castore-commits] ListUpdaterManager.java NONE 1.1
Céline BENOIT
cbenoit at adullact1.hosting.cri74.org
Mer 22 Mar 15:30:57 CET 2006
Update of /cvsroot/castore/castore-core/src/java/fr/emn/castor/documents/metier/docGenerique/soumission/resources/liste
In directory adullact1:/tmp/cvs-serv11170/src/java/fr/emn/castor/documents/metier/docGenerique/soumission/resources/liste
Added Files:
ListUpdaterManager.java
Log Message:
déplacement du fichier
--- NEW FILE: ListUpdaterManager.java ---
/*
* $Id: ListUpdaterManager.java,v 1.1 2006/03/22 14:30:55 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.soumission.resources.liste;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import fr.emn.castor.common.Constants;
import fr.emn.castor.documents.Facade;
/**
* Classe permettant de gérer la mise a jour des fichiers xml de listes.
* La classe offre également une gestionnaire de mutex (exclusion mutuelle)
* sur les acces aux fichiers.
* @author $Author: cbenoit $
* @version $Revision: 1.1 $
*/
public class ListUpdaterManager {
/**
* le document.
*/
private String docId;
/**
* Constructeur.
* @param idDoc id du document qui vient d'être validé
*/
public ListUpdaterManager(final String idDoc) {
this.docId = idDoc;
}
/**
* Lance la mise a jour des listes a partir
* des metadonnees validees.
*
*/
public final void update() {
//Recuperation des MD validees
Map mdMap = Facade.getInstance().getAllValidationMap(this.docId);
Set keySet = mdMap.keySet();
Iterator mdIter = keySet.iterator();
//pour chaque MD, si elle de type liste controlee editable
//on va lancer un processus de mis a jour
while (mdIter.hasNext()) {
String key = (String) mdIter.next();
Map md = (Map) mdMap.get(key);
String controlledList = (String) md.get("controlled_list");
if (controlledList.equals(Constants.TRUE)) {
String editableList = (String) md.get("editableList");
if (editableList.equals(Constants.TRUE)) {
String xmlFile = (String) md.get("xmlFile");
String[] tabValues = null;
if (((String) md.get("multi")).equals(Constants.TRUE)) {
Map newValues = (Map) md.get("value");
Set valueKeys = newValues.keySet();
Iterator valuesIter = valueKeys.iterator();
tabValues = new String[valueKeys.size()];
int i = 0;
while (valuesIter.hasNext()) {
tabValues[i++] = (String) valuesIter.next();
}
} else {
String value = (String) md.get("value");
if (!value.equals("")) {
tabValues = new String[1];
tabValues[0] = value;
}
}
//lancement d'une thread de mise a jour
ListUpdaterThread thread = new ListUpdaterThread(
xmlFile, tabValues);
thread.start();
}
}
}
}
}
Plus d'informations sur la liste de diffusion Castore-commits