blob: 96d3bd0a5ad7b11e750bf4bbd2616dc2faca515f [file] [log] [blame]
/*
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you 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.apache.wiki.plugin;
import org.apache.wiki.WikiContext;
import org.apache.wiki.api.core.Context;
import org.apache.wiki.api.core.Engine;
import org.apache.wiki.api.exceptions.PluginException;
import org.apache.wiki.api.exceptions.ProviderException;
import org.apache.wiki.api.plugin.Plugin;
import org.apache.wiki.attachment.Attachment;
import org.apache.wiki.attachment.AttachmentManager;
import org.apache.wiki.util.TextUtil;
import java.util.Map;
/**
* Provides an image plugin for better control than is possible with a simple image inclusion.
* <br> Most parameters are equivalents of the html image attributes.
*
* <p>Parameters : </p>
* <ul>
* <li><b>src</b> - the source (a URL) of the image (required parameter)</li>
* <li><b>align</b> - the alignment of the image</li>
* <li><b>height</b> - the height of the image</li>
* <li><b>width</b> - the width of the image</li>
* <li><b>alt</b> - alternate text</li>
* <li><b>caption</b> - the caption for the image</li>
* <li><b>link</b> - the hyperlink for the image</li>
* <li><b>target</b> - the target (frame) to be used for opening the image</li>
* <li><b>style</b> - the style attribute of the image</li>
* <li><b>class</b> - the associated class for the image</li>
* <li><b>border</b> - the border for the image</li>
* <li><b>title</b> - the title for the image, can be presented as a tooltip to the user</li>
* </ul>
*
* @since 2.1.4.
*/
// FIXME: It is not yet possible to do wiki internal links. In order to do this cleanly, a TranslatorReader revamp is needed.
public class Image implements Plugin {
/** The parameter name for setting the src. Value is <tt>{@value}</tt>. */
public static final String PARAM_SRC = "src";
/** The parameter name for setting the align. Value is <tt>{@value}</tt>. */
public static final String PARAM_ALIGN = "align";
/** The parameter name for setting the height. Value is <tt>{@value}</tt>. */
public static final String PARAM_HEIGHT = "height";
/** The parameter name for setting the width. Value is <tt>{@value}</tt>. */
public static final String PARAM_WIDTH = "width";
/** The parameter name for setting the alt. Value is <tt>{@value}</tt>. */
public static final String PARAM_ALT = "alt";
/** The parameter name for setting the caption. Value is <tt>{@value}</tt>. */
public static final String PARAM_CAPTION = "caption";
/** The parameter name for setting the link. Value is <tt>{@value}</tt>. */
public static final String PARAM_LINK = "link";
/** The parameter name for setting the target. Value is <tt>{@value}</tt>. */
public static final String PARAM_TARGET = "target";
/** The parameter name for setting the style. Value is <tt>{@value}</tt>. */
public static final String PARAM_STYLE = "style";
/** The parameter name for setting the class. Value is <tt>{@value}</tt>. */
public static final String PARAM_CLASS = "class";
// public static final String PARAM_MAP = "map";
/** The parameter name for setting the border. Value is <tt>{@value}</tt>. */
public static final String PARAM_BORDER = "border";
/** The parameter name for setting the title. Value is <tt>{@value}</tt>. */
public static final String PARAM_TITLE = "title";
/**
* This method is used to clean away things like quotation marks which
* a malicious user could use to stop processing and insert javascript.
*/
private static String getCleanParameter( final Map< String, String > params, final String paramId ) {
return TextUtil.replaceEntities( params.get( paramId ) );
}
/**
* {@inheritDoc}
*/
@Override
public String execute( final Context context, final Map<String, String> params ) throws PluginException {
final Engine engine = context.getEngine();
String src = getCleanParameter( params, PARAM_SRC );
final String align = getCleanParameter( params, PARAM_ALIGN );
final String ht = getCleanParameter( params, PARAM_HEIGHT );
final String wt = getCleanParameter( params, PARAM_WIDTH );
final String alt = getCleanParameter( params, PARAM_ALT );
final String caption = getCleanParameter( params, PARAM_CAPTION );
final String link = getCleanParameter( params, PARAM_LINK );
String target = getCleanParameter( params, PARAM_TARGET );
final String style = getCleanParameter( params, PARAM_STYLE );
final String cssclass= getCleanParameter( params, PARAM_CLASS );
// String map = getCleanParameter( params, PARAM_MAP );
final String border = getCleanParameter( params, PARAM_BORDER );
final String title = getCleanParameter( params, PARAM_TITLE );
if( src == null ) {
throw new PluginException("Parameter 'src' is required for Image plugin");
}
//if( cssclass == null ) cssclass = "imageplugin";
if( target != null && !validTargetValue(target) ) {
target = null; // not a valid value so ignore
}
try {
final AttachmentManager mgr = engine.getManager( AttachmentManager.class );
final Attachment att = mgr.getAttachmentInfo( context, src );
if( att != null ) {
src = context.getURL( WikiContext.ATTACH, att.getName() );
}
} catch( final ProviderException e ) {
throw new PluginException( "Attachment info failed: " + e.getMessage() );
}
final StringBuilder result = new StringBuilder();
result.append( "<table border=\"0\" class=\"imageplugin\"" );
if( title != null ) {
result.append( " title=\"" + title + "\"" );
}
if( align != null ) {
if( align.equals( "center" ) ) {
result.append( " style=\"margin-left: auto; margin-right: auto; text-align:center; vertical-align:middle;\"" );
} else {
result.append( " style=\"float:" + align + ";\"" );
}
}
result.append( ">\n" );
if( caption != null ) {
result.append( "<caption>" + caption + "</caption>\n" );
}
// move css class and style to the container of the image, so it doesn't affect the caption
result.append( "<tr><td" );
if( cssclass != null ) {
result.append(" class=\""+cssclass+"\"");
}
if( style != null ) {
result.append(" style=\""+style);
// Make sure that we add a ";" to the end of the style string
if( result.charAt( result.length()-1 ) != ';' ) result.append(";");
result.append("\"");
}
result.append( ">" );
if( link != null ) {
result.append("<a href=\""+link+"\"");
if( target != null ) {
result.append(" target=\""+target+"\"");
}
result.append(">");
}
result.append( "<img src=\""+src+"\"" );
if( ht != null ) {
result.append(" height=\""+ht+"\"");
}
if( wt != null ) {
result.append(" width=\""+wt+"\"");
}
if( alt != null ) {
result.append(" alt=\""+alt+"\"");
}
if( border != null ) {
result.append(" border=\""+border+"\"");
}
// if( map != null ) result.append(" map=\""+map+"\"");
result.append(" />");
if( link != null ) {
result.append("</a>");
}
result.append("</td></tr>\n");
result.append("</table>\n");
return result.toString();
}
private boolean validTargetValue( final String s )
{
if( s.equals("_blank")
|| s.equals("_self")
|| s.equals("_parent")
|| s.equals("_top") )
{
return true;
}
else if( s.length() > 0 ) // check [a-zA-z]
{
final char c = s.charAt(0);
return Character.isLowerCase(c) || Character.isUpperCase(c);
}
return false;
}
}