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

net.krotscheck.kangaroo.util.ParamUtil Maven / Gradle / Ivy

/*
 * Copyright (c) 2016 Michael Krotscheck
 *
 * 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 net.krotscheck.kangaroo.util;

import javax.ws.rs.core.MultivaluedMap;
import java.util.List;

/**
 * A utility to assist in the manipulation, creation, and retrieval of query
 * parameters.
 *
 * @author Michael Krotscheck
 */
public final class ParamUtil {

    /**
     * Utility class, private constructor.
     */
    private ParamUtil() {

    }

    /**
     * This helper method assumes at least, but no more than, one single
     * value in a MultiValuedMap. If this value exists, it is returned.
     * Otherwise, it raises an InvalidRequestException.
     *
     * @param values The map of values.
     * @param key    The key to get.
     * @return The value retrieved, but only if only one exists for this key.
     */
    public static String getOne(final MultivaluedMap values,
                                final String key) {
        List listValues = values.get(key);
        if (listValues == null) {
            throw new InvalidFieldException(key);
        }
        if (listValues.size() != 1) {
            throw new InvalidFieldException(key);
        }
        return listValues.get(0);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy