ImageResource.java
package fr.sii.ogham.html.inliner;
import java.util.Arrays;
import fr.sii.ogham.core.resource.path.ResourcePath;
import fr.sii.ogham.html.translator.InlineImageTranslator;
/**
* A simple object that represents an image to be usable by the
* {@link InlineImageTranslator}. The aim is to decouple the translator
* implementation from the general system.
*
* @author Aurélien Baudet
*
*/
public class ImageResource {
private final String name;
private final String srcUrl;
private final ResourcePath path;
private final byte[] content;
private final String mimetype;
/**
* Initialize the resource with the name of the image, the path of the image
* found in the HTML, the content of the image as array of bytes and the
* mimetype of the image. The bytes for the content of the image are copied
* into a new array to prevent security leaks.
*
* @param name
* the name of the image
* @param srcUrl
* the URL of the image used in the html content
* @param path
* the path to the image
* @param content
* the content of the image
* @param mimetype
* the mimetype of the image
*/
public ImageResource(String name, String srcUrl, ResourcePath path, byte[] content, String mimetype) {
super();
this.name = name;
this.srcUrl = srcUrl;
this.path = path;
this.content = Arrays.copyOf(content, content.length);
this.mimetype = mimetype;
}
public String getSrcUrl() {
return srcUrl;
}
public ResourcePath getPath() {
return path;
}
public byte[] getContent() {
return content;
}
public String getMimetype() {
return mimetype;
}
public String getName() {
return name;
}
@Override
public String toString() {
StringBuilder builder = new StringBuilder();
builder.append("ImageResource(")
.append("src=").append(srcUrl).append(", ")
.append("path=").append(path).append(", ")
.append("name=").append(name).append(", ")
.append("mimetype=").append(mimetype).append(")");
return builder.toString();
}
}