JaxbSerializer.java
/*
* GovWay - A customizable API Gateway
* https://govway.org
*
* Copyright (c) 2005-2025 Link.it srl (https://link.it).
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3, as published by
* the Free Software Foundation.
*
* 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, see <http://www.gnu.org/licenses/>.
*
*/
package org.openspcoop2.protocol.manifest.utils.serializer;
import java.io.File;
import java.io.OutputStream;
import org.openspcoop2.utils.beans.WriteToSerializerType;
import org.openspcoop2.generic_project.exception.SerializerException;
import javax.xml.bind.JAXBElement;
/**
* XML Serializer of beans with jaxb
*
* @author Poli Andrea (poli@link.it)
* @author $Author$
* @version $Rev$, $Date$
*/
public class JaxbSerializer extends AbstractSerializer {
@Override
protected WriteToSerializerType getType(){
return WriteToSerializerType.XML_JAXB;
}
/**
* Serialize to file system in <var>fileName</var> the object <var>jaxbElement</var> of type {@link javax.xml.bind.JAXBElement}
*
* @param fileName Xml file to serialize the object <var>jaxbElement</var>
* @param jaxbElement Object to be serialized in xml file <var>fileName</var>
* @throws SerializerException The exception that is thrown when an error occurs during serialization
*/
public <T> void write(String fileName,JAXBElement<T> jaxbElement) throws SerializerException {
this.objToXml(fileName, jaxbElement.getValue().getClass(), jaxbElement, false);
}
/**
* Serialize to file system in <var>fileName</var> the object <var>jaxbElement</var> of type {@link javax.xml.bind.JAXBElement}
*
* @param fileName Xml file to serialize the object <var>jaxbElement</var>
* @param jaxbElement Object to be serialized in xml file <var>fileName</var>
* @param prettyPrint if true output the XML with indenting
* @throws SerializerException The exception that is thrown when an error occurs during serialization
*/
public <T> void write(String fileName,JAXBElement<T> jaxbElement,boolean prettyPrint) throws SerializerException {
this.objToXml(fileName, jaxbElement.getValue().getClass(), jaxbElement, prettyPrint);
}
/**
* Serialize to file system in <var>file</var> the object <var>jaxbElement</var> of type {@link javax.xml.bind.JAXBElement}
*
* @param file Xml file to serialize the object <var>jaxbElement</var>
* @param jaxbElement Object to be serialized in xml file <var>fileName</var>
* @throws SerializerException The exception that is thrown when an error occurs during serialization
*/
public <T> void write(File file,JAXBElement<T> jaxbElement) throws SerializerException {
this.objToXml(file, jaxbElement.getValue().getClass(), jaxbElement, false);
}
/**
* Serialize to file system in <var>file</var> the object <var>jaxbElement</var> of type {@link javax.xml.bind.JAXBElement}
*
* @param file Xml file to serialize the object <var>jaxbElement</var>
* @param jaxbElement Object to be serialized in xml file <var>fileName</var>
* @param prettyPrint if true output the XML with indenting
* @throws SerializerException The exception that is thrown when an error occurs during serialization
*/
public <T> void write(File file,JAXBElement<T> jaxbElement,boolean prettyPrint) throws SerializerException {
this.objToXml(file, jaxbElement.getValue().getClass(), jaxbElement, prettyPrint);
}
/**
* Serialize to output stream <var>out</var> the object <var>jaxbElement</var> of type {@link javax.xml.bind.JAXBElement}
*
* @param out OutputStream to serialize the object <var>jaxbElement</var>
* @param jaxbElement Object to be serialized in xml file <var>fileName</var>
* @throws SerializerException The exception that is thrown when an error occurs during serialization
*/
public <T> void write(OutputStream out,JAXBElement<T> jaxbElement) throws SerializerException {
this.objToXml(out, jaxbElement.getValue().getClass(), jaxbElement, false);
}
/**
* Serialize to output stream <var>out</var> the object <var>jaxbElement</var> of type {@link javax.xml.bind.JAXBElement}
*
* @param out OutputStream to serialize the object <var>jaxbElement</var>
* @param jaxbElement Object to be serialized in xml file <var>fileName</var>
* @param prettyPrint if true output the XML with indenting
* @throws SerializerException The exception that is thrown when an error occurs during serialization
*/
public <T> void write(OutputStream out,JAXBElement<T> jaxbElement,boolean prettyPrint) throws SerializerException {
this.objToXml(out, jaxbElement.getValue().getClass(), jaxbElement, prettyPrint);
}
/**
* Serialize to byte array the object <var>jaxbElement</var> of type {@link javax.xml.bind.JAXBElement}
*
* @param jaxbElement Object to be serialized
* @return Object to be serialized in byte array
* @throws SerializerException The exception that is thrown when an error occurs during serialization
*/
public <T> byte[] toByteArray(JAXBElement<T> jaxbElement) throws SerializerException {
return this.objToXml(jaxbElement.getValue().getClass(), jaxbElement, false).toByteArray();
}
/**
* Serialize to byte array the object <var>jaxbElement</var> of type {@link javax.xml.bind.JAXBElement}
*
* @param jaxbElement Object to be serialized
* @param prettyPrint if true output the XML with indenting
* @return Object to be serialized in byte array
* @throws SerializerException The exception that is thrown when an error occurs during serialization
*/
public <T> byte[] toByteArray(JAXBElement<T> jaxbElement,boolean prettyPrint) throws SerializerException {
return this.objToXml(jaxbElement.getValue().getClass(), jaxbElement, prettyPrint).toByteArray();
}
/**
* Serialize to String the object <var>jaxbElement</var> of type {@link javax.xml.bind.JAXBElement}
*
* @param jaxbElement Object to be serialized
* @return Object to be serialized as String
* @throws SerializerException The exception that is thrown when an error occurs during serialization
*/
public <T> String toString(JAXBElement<T> jaxbElement) throws SerializerException {
return this.objToXml(jaxbElement.getValue().getClass(), jaxbElement, false).toString();
}
/**
* Serialize to String the object <var>jaxbElement</var> of type {@link javax.xml.bind.JAXBElement}
*
* @param jaxbElement Object to be serialized
* @param prettyPrint if true output the XML with indenting
* @return Object to be serialized as String
* @throws SerializerException The exception that is thrown when an error occurs during serialization
*/
public <T> String toString(JAXBElement<T> jaxbElement,boolean prettyPrint) throws SerializerException {
return this.objToXml(jaxbElement.getValue().getClass(), jaxbElement, prettyPrint).toString();
}
}