/**
* Copyright (C) 2008-2010, Squale Project - http://www.squale.org
*
* This file is part of Squale.
*
* Squale is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or any later version.
*
* Squale 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 Lesser General Public License
* along with Squale. If not, see <http://www.gnu.org/licenses/>.
*/
package org.squale.squalecommon.enterpriselayer.facade.message;
import java.io.InputStream;
import java.util.Collection;
import java.util.TreeSet;
import org.apache.commons.digester.Digester;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.squale.squalecommon.enterpriselayer.businessobject.message.MessageBO;
import org.squale.squalecommon.util.xml.XmlImport;
/**
* Importation des messages
*/
public class MessageImport
extends XmlImport
{
/** Log */
private static Log LOG = LogFactory.getLog( MessageImport.class );
/** Nom publique de la DTD */
final static String PUBLIC_DTD = "-//Squale//DTD Message Configuration 1.0//EN";
/** Localisation de la DTD */
final static String DTD_LOCATION = "/org/squale/squalecommon/dtd/message-1.0.dtd";
/**
* Constructeur
*/
public MessageImport()
{
super( LOG );
}
/**
* Importation de messages
*
* @param pStream flux de messages
* @param pErrors erreurs de traitement ou vide si aucune erreur n'est rencontr�e
* @return collection de messages import�s sous la forme de MessageBO
*/
public Collection importMessages( InputStream pStream, StringBuffer pErrors )
{
Digester configDigester = setupDigester( pErrors );
TreeSet messages = new TreeSet();
configDigester.push( messages );
parse( configDigester, pStream, pErrors );
return messages;
}
/**
* Configuration du digester Le digester est utilis� pour le chargement du fichier XML de r�gles
*
* @param pErrors erreurs de traitement
* @return digester
*/
private Digester setupDigester( StringBuffer pErrors )
{
Digester configDigester = preSetupDigester( PUBLIC_DTD, DTD_LOCATION, pErrors );
// Traitement des messages
configDigester.addObjectCreate( "messages/message", MessageBO.class );
configDigester.addSetProperties( "messages/message" );
configDigester.addCallMethod( "messages/message", "setText", 1 );
configDigester.addCallParam( "messages/message", 0 );
configDigester.addSetNext( "messages/message", "add" );
return configDigester;
}
}