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

com.aspectran.core.activity.request.ParameterMap Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2008-2025 The Aspectran Project
 *
 * 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.aspectran.core.activity.request;

import com.aspectran.utils.Assert;

import java.io.Serial;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Set;

/**
 * The Class ParameterMap.
 *
 * 

Created: 2008. 06. 11 PM 8:55:13

*/ public class ParameterMap extends LinkedHashMap { @Serial private static final long serialVersionUID = 1709146569240133920L; /** * Instantiates a new ParameterMap. */ public ParameterMap() { super(); } /** * Instantiates a new ParameterMap. * @param initialCapacity the initial capacity */ public ParameterMap(int initialCapacity) { super(initialCapacity); } /** * Instantiates a new ParameterMap. * @param params the other parameter map */ public ParameterMap(Map params) { super(params); } /** * Returns the string value to which the specified name is mapped, * or {@code null} if this map contains no mapping for the name. * @param name the parameter name * @return a {@code String} representing the * single value of the parameter */ public String getParameter(String name) { String[] values = get(name); return (values != null && values.length > 0 ? values[0] : null); } /** * Returns the string values to which the specified name is mapped, * or {@code null} if this map contains no mapping for the name. * @param name the parameter name * @return an array of {@code String} objects * containing the parameter's values */ public String[] getParameterValues(String name) { return get(name); } /** * Sets the value to the parameter with the given name. * @param name a {@code String} specifying the name of the parameter * @param value a {@code String} representing the * single value of the parameter * @see #setParameterValues(String, String[]) */ public void setParameter(String name, String value) { put(name, new String[] { value }); } /** * Sets the values to the parameter with the given name. * @param name a {@code String} specifying the name of the parameter * @param values an array of {@code String} objects * containing the parameter's values * @see #setParameter */ public void setParameterValues(String name, String[] values) { put(name, values); } /** * Returns a {@code Collection} of {@code String} objects containing * the names of the parameters. * If no parameters, the method returns an empty {@code Collection}. * @return a {@code Collection} of {@code String} objects, each {@code String} * containing the name of a parameter; * or an empty {@code Collection} if no parameters */ public Set getParameterNames() { return keySet(); } /** * Set the given parameters under. * @param params the other parameter map */ public void setAll(Map params) { Assert.notNull(params, "params must not be null"); for (Map.Entry entry : params.entrySet()) { setParameter(entry.getKey(), entry.getValue()); } } public Map extractAsMap() { Map map = new HashMap<>(); return extractAsMap(map); } public Map extractAsMap(Map targetMap) { Assert.notNull(targetMap, "targetMap must not be null"); for (Map.Entry entry : this.entrySet()) { String name = entry.getKey(); String[] values = entry.getValue(); if (values.length == 1) { targetMap.put(name, values[0]); } else { targetMap.put(name, values); } } return targetMap; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy