/*
* BufferBody.java February 2012
*
* Copyright (C) 2001, Niall Gallagher <niallg@users.sf.net>
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
* implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package org.simpleframework.http.message;
import java.io.IOException;
import java.io.InputStream;
import java.util.Collections;
import java.util.List;
import org.simpleframework.http.Part;
import org.simpleframework.util.buffer.Buffer;
/**
* The <code>Body</code> interface is used to represent the body of a HTTP
* entity. It contains the information that is delivered with the request. The
* body is represented by a stream of bytes. In order to access the entity body
* this interface provides a stream which can be used to read it. Also, should
* the message be encoded as a multipart message the individual parts can be
* read using the <code>Attachment</code> instance for it.
*
* @author Niall Gallagher
*/
class BufferBody implements Body {
/**
* This is used to hold the attachments for the HTTP body.
*/
private final PartSeries series;
/**
* This is usd to hold the bytes representing the HTTP body.
*/
private final Buffer buffer;
/**
* Constructor for the <code>BufferBody</code> object. This is used to
* create a body that represents a HTTP payload. The body enables the
* payload to be either read in a stream or as an encoded string. Also the
* attachments are available.
*/
public BufferBody() {
this(null);
}
/**
* Constructor for the <code>BufferBody</code> object. This is used to
* create a body that represents a HTTP payload. The body enables the
* payload to be either read in a stream or as an encoded string. Also the
* attachments are available.
*
* @param buffer
* this is the buffer representing the body
*/
public BufferBody(Buffer buffer) {
this(buffer, null);
}
/**
* Constructor for the <code>BufferBody</code> object. This is used to
* create a body that represents a HTTP payload. The body enables the
* payload to be either read in a stream or as an encoded string. Also the
* attachments are available.
*
* @param buffer
* this is the buffer representing the body
* @param series
* this is the list of parts for this body
*/
public BufferBody(Buffer buffer, PartSeries series) {
this.buffer = buffer;
this.series = series;
}
/**
* This method is used to acquire a <code>Part</code> from the HTTP request
* using a known name for the part. This is typically used when there is a
* file upload with a multipart POST request. All parts that are not files
* can be acquired as string values from the attachment object.
*
* @param name
* this is the name of the part object to acquire
*
* @return the named part or null if the part does not exist
*/
@Override
public Part getPart(String name) {
if (this.series != null) return this.series.getPart(name);
return null;
}
/**
* This method is used to get all <code>Part</code> objects that are
* associated with the request. Each attachment contains the body and
* headers associated with it. If the request is not a multipart POST
* request then this will return an empty list.
*
* @return the list of parts associated with this request
*/
@Override
public List<Part> getParts() {
if (this.series != null) return this.series.getParts();
return Collections.emptyList();
}
/**
* This will acquire the contents of the body in UTF-8. If there is no
* content encoding and the user of the request wants to deal with the body
* as a string then this method can be used. It will simply create a UTF-8
* string using the body bytes.
*
* @return returns a UTF-8 string representation of the body
*/
@Override
public String getContent() throws IOException {
if (this.buffer == null) return new String();
return this.buffer.encode();
}
/**
* This will acquire the contents of the body in the specified charset.
* Typically this will be given the charset as taken from the HTTP
* Content-Type header. Although any encoding can be specified to convert
* the body to a string representation.
*
* @return returns an encoded string representation of the body
*/
@Override
public String getContent(String charset) throws IOException {
if (this.buffer == null) return new String();
return this.buffer.encode(charset);
}
/**
* This is used to acquire the contents of the body as a stream. Each time
* this method is invoked a new stream is created that will read the
* contents of the body from the first byte. This ensures that the stream
* can be acquired several times without any issues arising from previous
* reads.
*
* @return this returns a new string used to read the body
*/
@Override
public InputStream getInputStream() throws IOException {
if (this.buffer == null) return new EmptyInputStream();
return this.buffer.getInputStream();
}
}