/*
* Copyright (C) 2009 eXo Platform SAS.
*
* This 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 2.1 of
* the License, or (at your option) any later version.
*
* This software 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.exoplatform.services.jcr.impl.xml;
import org.apache.ws.commons.util.Base64.Decoder;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
/**
* Created by The eXo Platform SAS.
*
* @author <a href="mailto:Sergey.Kabashnyuk@gmail.com">Sergey Kabashnyuk</a>
* @version $Id: DecodedValue.java 11987 2008-03-17 09:06:06Z ksm $
*/
/**
* Temporary class for swapping values and decode binary values during import.
*
* @author ksm
*/
public class DecodedValue
{
/**
* Decoder buffer.
*/
private BufferedDecoder decoder;
/**
* String buffer.
*/
private StringBuilder StringBuilder;
/**
* true if DecodedValue is completed
*/
private boolean complete;
/**
* Indicates whether the value has been explicitly declared as encoded in Base64
*/
private boolean binary;
/**
* Dafault constructor.
*/
public DecodedValue()
{
super();
StringBuilder = new StringBuilder();
}
/**
* @return Base64 decoder. It is write decoded incoming data into the temporary file.
* @exception IOException
* if an I/O error occurs.
*/
public Decoder getBinaryDecoder() throws IOException
{
if (decoder == null)
{
decoder = new BufferedDecoder();
StringBuilder = null;
}
return decoder;
}
/**
* @return InputStream from decoded file.
* @exception IOException
* if an I/O error occurs.
*/
public InputStream getInputStream() throws IOException
{
if (decoder == null)
{
return new ByteArrayInputStream(new byte[0]);
}
return decoder.getInputStream();
}
/**
* @return String buffer.
*/
public StringBuilder getStringBuffer()
{
return StringBuilder;
}
/**
* Removes all temporary variables and files.
*
* @throws IOException
* if file can't be removed.
*/
public void remove() throws IOException
{
if (decoder != null)
{
decoder.remove();
decoder = null;
}
}
/**
* Used to determine the end of value tag in system view import.
*
* @param complete
*/
public void setComplete(boolean complete)
{
this.complete = complete;
}
/**
* Used to determine the end of value tag in system view import.
*
* @return
*/
public boolean isComplete()
{
return complete;
}
/**
* Indicates whether the value has been explicitly declared as encoded in Base64
*/
public boolean isBinary()
{
return binary;
}
/**
* Used to indicate if the value has been explicitly declared as encoded in Base64
*/
public void setBinary(boolean binary)
{
this.binary = binary;
}
/**
* @return string representation for value.
*/
public String toString()
{
if (decoder != null)
{
return decoder.toString();
}
return StringBuilder.toString();
}
}