Package org.hdiv.urlProcessor

Source Code of org.hdiv.urlProcessor.FormUrlProcessor

/**
* Copyright 2005-2013 hdiv.org
*
* 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.hdiv.urlProcessor;

import javax.servlet.http.HttpServletRequest;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.hdiv.dataComposer.IDataComposer;
import org.hdiv.util.Constants;
import org.hdiv.util.HDIVUtil;

/**
* UrlProcessor for form action urls.
*
* @author Gotzon Illarramendi
*/
public class FormUrlProcessor extends AbstractUrlProcessor {

  public static final String FORM_STATE_ID = "hdivFormStateId";

  /**
   * Commons Logging instance.
   */
  private static Log log = LogFactory.getLog(FormUrlProcessor.class);

  /*
   * (non-Javadoc)
   *
   * @see org.hdiv.urlProcessor.AbstractUrlProcessor#createUrlData(java.lang.String, java.lang.String,
   * javax.servlet.http.HttpServletRequest)
   */
  @Override
  public UrlData createUrlData(String url, String method, HttpServletRequest request) {

    // Execute common url parser
    UrlData urlData = super.createUrlData(url, method, request);

    // Specific url parsing for form action

    String params = this.removeStateParameter(request, urlData.getUrlParams());
    urlData.setUrlParams(params);

    return urlData;
  }

  /**
   * Remove _HDIV_STATE_ parameter if it exist.
   *
   * @param request
   *            {@link HttpServletRequest} object
   * @param params
   *            parameters string
   * @return parameters string without state id
   */
  protected String removeStateParameter(HttpServletRequest request, String params) {

    String hdivParameter = (String) request.getSession().getAttribute(Constants.HDIV_PARAMETER);

    if (params == null || !params.contains(hdivParameter)) {
      return params;
    }

    int start = params.indexOf(hdivParameter);

    int end = params.indexOf("&", start);
    if (end < 0) {
      end = params.indexOf("#", start);
    }
    if (end < 0) {
      end = params.length();
    }

    String result = params.substring(0, start);
    result = result + params.substring(end, params.length());

    if (result.endsWith("&")) {
      result = result.substring(0, result.length() - 1);
    }

    return result;
  }

  /**
   * Process form action url to add hdiv state if it is necessary.
   *
   * @param request
   *            {@link HttpServletRequest} object
   * @param url
   *            url to process
   * @return processed url
   */
  public String processUrl(HttpServletRequest request, String url) {

    return this.processUrl(request, url, "POST");
  }

  /**
   * Process form action url to add hdiv state if it is necessary.
   *
   * @param request
   *            {@link HttpServletRequest} object
   * @param url
   *            url to process
   * @param method
   *            form submit method
   * @return processed url
   */
  public String processUrl(HttpServletRequest request, String url, String method) {

    if (method == null) {
      method = "POST";
    }

    IDataComposer dataComposer = HDIVUtil.getDataComposer(request);
    if (dataComposer == null) {
      // IDataComposer not initialized on request, request is out of filter
      if (log.isDebugEnabled()) {
        log.debug("IDataComposer not initialized on request, request is out of filter");
      }
      return url;
    }

    UrlData urlData = this.createUrlData(url, method, request);
    if (this.isHdivStateNecessary(urlData)) {
      // the url needs protection
      String stateId = dataComposer.beginRequest(method, urlData.getUrlWithoutContextPath());

      // Publish the state in request to make it accessible on jsp
      request.setAttribute(FORM_STATE_ID, stateId);

      // Process url params
      String processedParams = dataComposer.composeParams(urlData.getUrlParams(), method,
          Constants.ENCODING_UTF_8);
      urlData.setUrlParams(processedParams);

      // Action url with confidential values
      url = this.getProcessedUrl(urlData);
    }

    return url;

  }
}
TOP

Related Classes of org.hdiv.urlProcessor.FormUrlProcessor

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.