/*
* Copyright (c) 2001-2007, Inversoft Inc., All Rights Reserved
*
* 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.primeframework.mvc.action.result.annotation;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import static java.lang.annotation.ElementType.*;
import static java.lang.annotation.RetentionPolicy.*;
/**
* This annotation marks a result from an action as a Streaming result using an InputStream from the action.
*
* @author Brian Pontarelli
*/
@ResultAnnotation
@Retention(RUNTIME)
@Target(TYPE)
public @interface Stream {
/**
* @return The result code from the action's execute method that this Result is associated with.
*/
String code() default "success";
/**
* @return The content type of the InputStream. This is used to set the HTTP header and disposition so that the
* browser can correctly handle the response. This defaults to <code>${type}</code>, which means that its
* value is set dynamically using the value from the <code>type</code> property of the action.
*/
String type() default "${type}";
/**
* @return The file name sent back to the client. This is used to set the content disposition header so that the
* browser displays the correct name when saving the response to a file. This defaults to
* <code>${name}</code>, which means that its value is set dynamically using the value from the
* <code>name</code> property of the action.
*/
String name() default "${name}";
/**
* @return The content length sent back to the client. This is used to set the content length header so that the
* browser displays a progress bar when downloading the file. This defaults to <code>${length}</code>, which
* means that its value is set dynamically using the value from the <code>length</code> property of the
* action.
*/
String length() default "${length}";
/**
* @return The name of the property of the action that returns an InputStream. The bytes from this InputStream are
* sent back to the browser via the ServletOutputStream. This defaults to <code>stream</code>, which means the
* getStream method of the action should return the InputStream.
*/
String property() default "stream";
/**
* A list of Stream annotations.
*/
@ResultContainerAnnotation
@Retention(RUNTIME)
@Target(TYPE)
public static @interface List {
Stream[] value();
}
}