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

com.ibm.commons.runtime.util.ParameterProcessor Maven / Gradle / Ivy

There is a newer version: 1.1.12.20161007-1200
Show newest version
/*
 * © Copyright IBM Corp. 2013
 * 
 * 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 com.ibm.commons.runtime.util;

import java.text.MessageFormat;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import com.ibm.commons.runtime.Application;
import com.ibm.commons.runtime.Context;
import com.ibm.commons.util.StringUtil;

/**
 * @author mwallace
 */
public class ParameterProcessor {
    
    static final String DELIM_START = "%{"; //$NON-NLS-1$
    static final String DELIM_END   = "}"; //$NON-NLS-1$
    static final Pattern PARAMETER_PATTERN = Pattern.compile("%\\{(.*?)\\}");
    
    static ParameterProvider defaultProvider;

    /**
     * 
     * @param input
     * @return
     */
    public static String process(String input) {
        if(StringUtil.isNotEmpty(input)) {
            // default behaviour is to use context or if not available use application properties
            final Context context = Context.getUnchecked();
            final Application application = Application.getUnchecked();
            ParameterProvider provider = new ParameterProvider() {
                @Override
                public String getParameter(String name) {
                    if (context != null) {
                        return context.getProperty(name);
                    }
                    return (application == null) ? null : application.getProperty(name);
                }
            };
            
            return process(input, DELIM_START, DELIM_END, provider);
        }
        return input;
    }
    
    public static List getParameters(String input){
        Matcher paramsMatcher = PARAMETER_PATTERN.matcher(input);
        ArrayList result = new ArrayList();
        while(paramsMatcher.find()){
            result.add(paramsMatcher.group(1));
        }
        return result;
    }
    /*
     * The default provider. Checks the Context and Application for parameter values.
     * @return
     */
    public static ParameterProvider getDefaultProvider(){
        if(defaultProvider != null)
            return defaultProvider;
        final Context context = Context.getUnchecked();
        final Application application = Application.getUnchecked();
        defaultProvider = new ParameterProvider() {
            @Override
            public String getParameter(String name) {
                if (context != null) {
                    return context.getProperty(name);
                }
                return (application == null) ? null : application.getProperty(name);
            }
        };
        return defaultProvider;
    }
    /*
     * A provider which will get values from the HttpRequest, and store values in the HttpSession.
     * @param finalRequest
     * @param finalSession
     * @param finalSnippetName
     * @return
     */
    public static ParameterProvider getWebProvider(final HttpServletRequest finalRequest, final HttpSession finalSession, final String finalSnippetName){
        return ParameterProcessor.getDefaultProvider(new ParameterProvider() {
              @Override
            public String getParameter(String name) {
                  String value = finalRequest.getParameter(name);
                  
                  String storeKey = finalSnippetName + "_" + name; // store per snippet
                  
                  if(value == null){
                      value = (String) finalSession.getAttribute(storeKey); //check if there is a stored param
                  }
                  
                  if (value != null){
                      finalSession.setAttribute(storeKey, value); //store the param
                  }
                  
                  return value;
              }
        });
        
    }

    /*
     * Use this to use the defaultProvider as backup to your own. If the provider given as argument fails to find a parameter value, the defaultProvider will try.
     * @param provider
     * @return
     */
    public static ParameterProvider getDefaultProvider(final ParameterProvider provider){
        final ParameterProvider defaultProvider = getDefaultProvider();
        ParameterProvider result = new ParameterProvider() {
            @Override
            public String getParameter(String name) {
                if (provider != null) {
                    String value = provider.getParameter(name);
                    if (value != null) {
                        return value;
                    }
                }
                return defaultProvider.getParameter(name);
            }
        };
        return result;
    }
    
    /**
     * 
     * @param input
     * @return
     */
    public static String process(String input, final ParameterProvider provider, boolean includeDefault) {
        if (!includeDefault) {
            return process(input, provider);
        }
        if(StringUtil.isNotEmpty(input)) {
            // default behaviour is to use context or if not available use application properties
            final Context context = Context.getUnchecked();
            final Application application = Application.getUnchecked();
            ParameterProvider defaultProvider = new ParameterProvider() {
                @Override
                public String getParameter(String name) {
                    if (provider != null) {
                        String value = provider.getParameter(name);
                        if (value != null) {
                            return value;
                        }
                    }
                    if (context != null) {
                        return context.getProperty(name);
                    }
                    return (application == null) ? null : application.getProperty(name);
                }
            };
            
            return process(input, DELIM_START, DELIM_END, defaultProvider);
        }
        return input;
    }

    /**
     * 
     * @param input
     * @param properties
     * @return
     */
    public static String process(String input, final Properties properties) {
        if(StringUtil.isNotEmpty(input)) {
            ParameterProvider provider = new ParameterProvider() {
                @Override
                public String getParameter(String name) {
                    return (properties == null) ? null : properties.getProperty(name);
                }
            };
            
            return process(input, DELIM_START, DELIM_END, provider);
        }
        return input;
    }

    /**
     * 
     * @param input
     * @param map
     * @return
     */
    @SuppressWarnings("rawtypes")
    public static String process(String input, final Map map) {
        if(StringUtil.isNotEmpty(input)) {
            ParameterProvider provider = new ParameterProvider() {
                @Override
                public String getParameter(String name) {
                    return (map == null) ? null : (String)map.get(name);
                }
            };
            
            return process(input, DELIM_START, DELIM_END, provider);
        }
        return input;
    }

    /**
     * 
     * @param input
     * @param provider
     * @return
     */
    public static String process(String input, ParameterProvider provider) {
        return process(input, DELIM_START, DELIM_END, provider);
    }

    /**
     * 
     * @param input
     * @param delimStart
     * @param delimEnd
     * @param provider
     * @return
     */
    public static String process(String input, String delimStart, String delimEnd, ParameterProvider provider) {
        if(StringUtil.isNotEmpty(input)) {
            StringBuilder output = new StringBuilder(2048);
            int length = input.length();
            for(int index=0; index= 0) ? start : length;
                if(end > index) {
                    output.append(input.substring(index, end));
                    index = end;
                }
                if(start >= 0) {
                    int paramEnd = input.indexOf(delimEnd, start+delimStart.length()); 
                    if(paramEnd < 0) {
                        // assume malformed delim pair is an error 
                        String msg = MessageFormat.format("Unable to find parameter end delimiter {0}", delimEnd);
                        throw new IllegalArgumentException(msg);
                    }
                    
                    // process the parameter
                    String parameter = input.substring(start+delimStart.length(), paramEnd);
                    String replace = processParameter(parameter, provider);
                    replace = StringUtil.trim(replace);
                    output.append(replace!=null?replace:""); // avoid 'null' string
    
                    index = paramEnd + delimEnd.length();
                }
            }
    
            return output.toString();
        }
        return input;
    }

    /*
     * Process a parameter with one of the following formats:
     *      name
     *      name=xxx[|value=xxx][|label=xxx][|idHelpSnippet=snippet_id][|required=boolean]
     */
    private static String processParameter(String parameter, ParameterProvider provider) {
        if(parameter.contains("|") || parameter.contains("=")){
            String name = ParameterProcessor.getParameterPart(parameter, "label"); 
            if(name == null){
                name = ParameterProcessor.getParameterPart(parameter, "name");
            }
            String defaultValue = ParameterProcessor.getParameterPart(parameter, "value"); // the parameter may have a default value
            String providerValue = provider.getParameter(name);
            
            return providerValue != null ? providerValue : defaultValue;
        }
        else{
            return provider.getParameter(parameter); // just pass whole parameter, should look like %{name}
        }
    }
    
    /**
     * Gets the specified part out of a parameter of format
     *    name=xxx[|value=xxx][|label=xxx][|idHelpSnippet=snippet_id][|required]
     *    
     *    If a part is followed by '=' then the part after '=' is returned, else it just returns the part.
     *    Here the parameter is already split into name=value sections.
     * @param parts The parameter split into name=value pieces.
     * @param part The part to be retrieved.
     * @return
     */
    public static String getParameterPart(String[] parts, String part){
        for(int i = 0; i < parts.length; i++){
            String[] splitParts = StringUtil.splitString(parts[i], '=');
            if(splitParts[0].equals(part)){
                if(splitParts.length == 1){
                    return splitParts[0];
                }
                else{
                    return splitParts[1];
                }
            }
        }
        return null;
    }
    
    /**
     * Splits the parameter into sections and returns the value of part.
     * @param parameter
     * @param part
     * @return
     */
    public static String getParameterPart(String parameter, String part){
        if(!parameter.contains("|") && !parameter.contains("=")){
            return parameter;
        }
        String[] parts = StringUtil.splitString(parameter, '|');
        
        return getParameterPart(parts, part);
    }

    /**
     * Interface to provide parameter values for the processing
     */
    public interface ParameterProvider {
        
        /**
         * Returned the parameter for the specified name.
         * 
         * @param name
         * 
         * @return
         */
        public String getParameter(String name);
        
    }
    
    /*
     * Unit tests
     */
    @SuppressWarnings("unused")
    public static void main(String[] args) {
        final Map params = new HashMap();
        params.put("name1", "value1");
        params.put("name2", "value2");
        params.put("sample.email1", "[email protected]");
        
        ParameterProvider provider = new ParameterProvider() {
            @Override
            public String getParameter(String name) {
                return params.get(name);
            }
        };
        
        String input1 = "Example 1: %{name1} %{name2=defaultValue2} %{name3=defaultValue3}";
        String result1 = "Example 1: value1 value2 defaultValue3";
        String output1 = process(input1, provider);
        if (!result1.equals(output1)) {
            System.err.println("Example 1 failed: "+output1);
        } else {
            System.out.println("Example 1 passed");
        }
        
        String input2 = "Example 2: %{name1} %{name2=defaultValue2} %{name3=defaultValue3}";
        String result2 = "Example 2: value1 value2 defaultValue3";
        String output2 = process(input2, provider);
        if (!result2.equals(output2)) {
            System.err.println("Example 2 failed: "+output2);
        } else {
            System.out.println("Example 2 passed");
        }

        String input3 = "Example 3: value1 value2 defaultValue3";
        String result3 = "Example 3: value1 value2 defaultValue3";
        String output3 = process(input3, provider);
        if (!result3.equals(output3)) {
            System.err.println("Example 3 failed");
        } else {
            System.out.println("Example 3 passed");
        }

        try {
            String input4 = "Example 4: %{name1";
            process(input4, provider);
            System.err.println("Example 4 failed");
        } catch (IllegalArgumentException iae) {    
            System.out.println("Example 4 passed");
        }
        
        String input5 = "require(['sbt/connections/ProfileService','sbt/dom'], function(ProfileService,dom) {\nvar email = '%{sample.email1}';\nvar svc = new ProfileService();";
        String result5 = "require(['sbt/connections/ProfileService','sbt/dom'], function(ProfileService,dom) {\nvar email = '[email protected]';\nvar svc = new ProfileService();";;
        String output5 = process(input5, provider);
        if (!result5.equals(output5)) {
            System.err.println("Example 5 failed: "+output5);
        } else {
            System.out.println("Example 5 passed");
        }
        
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy