Package jodd.lagarto.filter

Source Code of jodd.lagarto.filter.LagartoServletFilter

// Copyright (c) 2003-2014, Jodd Team (jodd.org). All Rights Reserved.

package jodd.lagarto.filter;

import jodd.io.FileNameUtil;
import jodd.servlet.DispatcherUtil;
import jodd.servlet.wrapper.BufferResponseWrapper;
import jodd.log.Logger;
import jodd.log.LoggerFactory;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

/**
* Lagarto servlet filter takes HTML content and invokes user defined parser on it.
* This filter is a generic one and does not use Lagarto parser explicitly.
* It just gives a placeholder where user can add it's own parsing mechanism.
*/
public abstract class LagartoServletFilter implements Filter {

  private static final Logger log = LoggerFactory.getLogger(LagartoServletFilter.class);

  public void init(FilterConfig filterConfig) throws ServletException {
  }

  public void destroy() {
  }

  /**
   * Wraps the response and parse it using Lagarto parser.
   * It first calls {@link #processActionPath(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse, String)}
   * to optionally consumes path, then {@link #acceptActionPath(javax.servlet.http.HttpServletRequest, String)} to
   * check if path is accepted for processing.
   */
  public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
    HttpServletRequest request = (HttpServletRequest) servletRequest;
    HttpServletResponse response = (HttpServletResponse) servletResponse;
    String actionPath = DispatcherUtil.getServletPath(request);

    if (processActionPath(request, response, actionPath) == true) {
      return;
    }

    if (acceptActionPath(request, actionPath) == false) {
      filterChain.doFilter(servletRequest, servletResponse);
      return;
    }

    BufferResponseWrapper wrapper = new BufferResponseWrapper(response);
    filterChain.doFilter(servletRequest, wrapper);

    char[] content = wrapper.getBufferContentAsChars();

    if ((content != null) && (content.length != 0)) {
      if (log.isDebugEnabled()) {
        log.debug("Lagarto is about to parse: " + actionPath);
      }
      try {
        content = parse(content, request);
      } catch (Exception ex) {
        log.error("Error parsing", ex);
        throw new ServletException(ex);
      }

      wrapper.writeContentToResponse(content);
    }
  }

  /**
   * Manually process the action path and returns <code>true</code> if path is consumed.
   * When path is consumed, filter chain is not continued.
   * By default, it returns <code>false</code>.
   */
  protected boolean processActionPath(
      HttpServletRequest servletRequest,
      HttpServletResponse servletResponse,
      String actionPath) throws IOException {

    return false;
  }

  /**
   * Accepts action path for further parsing. By default, only <code>*.htm(l)</code>
   * requests are passed through and those without any extension.
   */
  protected boolean acceptActionPath(HttpServletRequest request, String actionPath) {
    String extension = FileNameUtil.getExtension(actionPath);
    if (extension.length() == 0) {
      return true;
    }
    if (extension.equals("html") || extension.equals("htm")) {
      return true;
    }
    return false;
  }

  /**
   * Main method that parses content. It can use Lagarto parser
   * or any other custom parsing technology.
   */
  protected abstract char[] parse(char[] content, HttpServletRequest request);

}
TOP

Related Classes of jodd.lagarto.filter.LagartoServletFilter

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.