All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.esigate.renderers.ResourceFixupRenderer Maven / Gradle / Ivy

There is a newer version: 5.3
Show newest version
/* 
 * 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.esigate.renderers;

import static org.apache.commons.lang3.StringUtils.stripEnd;

import java.io.IOException;
import java.io.Writer;

import org.esigate.Renderer;
import org.esigate.impl.DriverRequest;
import org.esigate.impl.UrlRewriter;

/**
 * This renderer "fixes" links to resources, images and pages in pages retrieved by esigate :
 * 
    *
  • Current-path-relative urls are converted to full path relative urls ( img/test.img -> * /myapp/curentpath/img/test.img)
  • *
  • All relative urls can be converted to absolute urls (including server name)
  • *
* * This enables use of esigate without any special modifications of the generated urls on the provider side. * * All href and src attributes are processed, except javascript links. * * @author Nicolas Richeton * */ public class ResourceFixupRenderer implements Renderer { private final String baseUrl; private final String requestUrl; private final UrlRewriter urlRewriter; private final String visibleBaseUrl; private final boolean absolute; /** * Creates a renderer which fixes urls. The domain name and the url path are computed from the full url made of * baseUrl + pageFullPath. * * If mode is ABSOLUTE, all relative urls will be replaced by the full urls : *
    *
  • images/image.png is replaced by http://server/context/images/image.png
  • *
  • /context/images/image.png is replaced by http://server/context/images/image.png
  • *
* * If mode is RELATIVE, context will be added to relative urls : *
    *
  • images/image.png is replaced by /context/images/image.png
  • *
* * @param baseUrl * Base url (same as configured in provider). * @param requestUrl * Page as used in tag lib or using API * @param urlRewriter * The url rewriter for this provider * @param visibleBaseUrl * The base url as seen from the client * @param absolute * Should the rewritten urls contain the scheme host and port */ public ResourceFixupRenderer(String baseUrl, String requestUrl, UrlRewriter urlRewriter, String visibleBaseUrl, boolean absolute) { this.baseUrl = stripEnd(baseUrl, "/"); this.requestUrl = requestUrl; this.urlRewriter = urlRewriter; this.visibleBaseUrl = visibleBaseUrl; this.absolute = absolute; } @Override public void render(DriverRequest httpRequest, String src, Writer out) throws IOException { out.write(urlRewriter.rewriteHtml(src, requestUrl, baseUrl, visibleBaseUrl, absolute).toString()); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy