nextapp.echo2.webcontainer.image.AbstractImageService Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ibis-echo2 Show documentation
Show all versions of ibis-echo2 Show documentation
Echo2 bundled with Echo2_Extras, Echo2_FileTransfer and echopointing and various improvements/bugfixes
/*
* This file is part of the Echo Web Application Framework (hereinafter "Echo").
* Copyright (C) 2002-2009 NextApp, Inc.
*
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (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.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*/
package nextapp.echo2.webcontainer.image;
import java.io.IOException;
import javax.servlet.http.HttpServletResponse;
import nextapp.echo2.app.ImageReference;
import nextapp.echo2.webcontainer.ContainerInstance;
import nextapp.echo2.webrender.Connection;
import nextapp.echo2.webrender.ContentType;
import nextapp.echo2.webrender.Service;
/**
* Abstract base service for rendering images sourced from the application
* container.
*/
public abstract class AbstractImageService
implements Service {
private static final String PARAMETER_IMAGE_UID = "imageuid";
private static final String[] URL_PARAMETERS = new String[]{PARAMETER_IMAGE_UID};
/**
* Creates a URI to retrieve a specific image for a specific component
* from the server.
*
* @param containerInstance the relevant application container instance.
* @param imageId the unique id to retrieve the image from the
* ContainerInstance
*/
public String createUri(ContainerInstance containerInstance, String imageId) {
return containerInstance.getServiceUri(this, URL_PARAMETERS, new String[]{imageId});
}
/**
* Renders the specified image to the given connection.
* Implementations should set the response content type, and write image
* data to the response OutputStream
.
*
* @param conn the Connection
on which to render the image
* @param imageReference the image to be rendered
* @throws IOException if the image cannot be rendered
*/
public abstract void renderImage(Connection conn, ImageReference imageReference)
throws IOException;
/**
* @see nextapp.echo2.webrender.Service#service(nextapp.echo2.webrender.Connection)
*/
public void service(Connection conn)
throws IOException {
ContainerInstance containerInstance = (ContainerInstance) conn.getUserInstance();
if (containerInstance == null) {
serviceBadRequest(conn, "No container available.");
return;
}
String imageId = conn.getRequest().getParameter(PARAMETER_IMAGE_UID);
if (imageId == null) {
serviceBadRequest(conn, "Image UID not specified.");
return;
}
ImageReference imageReference = (ImageReference) containerInstance.getIdTable().getObject(imageId);
if (imageReference == null) {
serviceBadRequest(conn, "Image UID is not valid.");
return;
}
renderImage(conn, imageReference);
}
/**
* Handles an invalid request for an image.
*
* @param conn the Connection
* @param message the error message
*/
public void serviceBadRequest(Connection conn, String message) {
conn.getResponse().setStatus(HttpServletResponse.SC_BAD_REQUEST);
conn.setContentType(ContentType.TEXT_PLAIN);
conn.getWriter().write(message);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy