com.authlete.common.util.MapUtils Maven / Gradle / Ivy
/*
* Copyright (C) 2022-2024 Authlete, Inc.
*
* 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.authlete.common.util;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
import com.authlete.common.dto.TaggedValue;
/**
* Utility for {@link Map}.
*
* @since 3.45
*/
public class MapUtils
{
/**
* Put the given key-value pair into the {@code target} map when the
* {@code value} is {@code true} or {@code falseIncluded} is {@code true}.
*/
public static void put(
Map target, String key,
boolean value, boolean falseIncluded)
{
if (value != false || falseIncluded)
{
target.put(key, value);
}
}
/**
* Put the given key-value pair into the {@code target} map when the
* {@code value} is not 0 or {@code zeroIncluded} is {@code true}.
*/
public static void put(
Map target, String key,
int value, boolean zeroIncluded)
{
if (value != 0 || zeroIncluded)
{
target.put(key, value);
}
}
/**
* Put the given key-value pair into the {@code target} map when the
* {@code value} is not 0 or {@code zeroIncluded} is {@code true}.
*/
public static void put(
Map target, String key,
long value, boolean zeroIncluded)
{
if (value != 0 || zeroIncluded)
{
target.put(key, value);
}
}
/**
* Put the given key-value pair into the {@code target} map when the
* {@code value} is not null or {@code nullIncluded} is {@code true}.
*
* @since 3.95
*/
public static void put(
Map target, String key,
Map value, boolean nullIncluded)
{
if (value != null)
{
target.put(key, value);
}
else if (nullIncluded)
{
target.put(key, null);
}
}
/**
* Put the given key-value pair into the {@code target} map when the
* {@code value} is not {@code null} or {@code nullIncluded} is
* {@code true}.
*
*
* Note that the value of {@code value.toString()} is put into the
* {@code target} map, not the {@code value} itself.
*
*/
public static void put(
Map target, String key,
T value, boolean nullIncluded)
{
if (value != null)
{
target.put(key, value.toString());
}
else if (nullIncluded)
{
target.put(key, null);
}
}
/**
* Put the given key-array pair into the {@code target} map when the
* {@code array} is not {@code null} or {@code nullIncluded} is
* {@code true}.
*
*
* Note that elements in the array are converted to {@code String}
* instances by the {@code toString()} method and added to a new
* {@code List} instance, and the {@code List} instance is put into
* the {@code target} map.
*
*/
public static void put(
Map target, String key,
T[] array, boolean nullIncluded)
{
List list = asList(array);
if (list != null || nullIncluded)
{
target.put(key, list);
}
}
/**
* Put "{baseKey}#{tag}"
properties into the {@code target}
* map.
*/
public static void put(
Map target, String baseKey,
TaggedValue[] array, boolean nullIncluded)
{
if (array == null)
{
return;
}
for (TaggedValue taggedValue : array)
{
putTaggedValue(target, baseKey, taggedValue, nullIncluded);
}
}
private static void putTaggedValue(
Map target, String baseKey,
TaggedValue taggedValue, boolean nullIncluded)
{
if (taggedValue == null)
{
return;
}
String tag = taggedValue.getTag();
if (tag == null || tag.isEmpty())
{
return;
}
String value = taggedValue.getValue();
if (value == null && !nullIncluded)
{
return;
}
target.put(String.format("%s#%s", baseKey, tag), value);
}
/**
* Convert the given {@code json} into a {@code Map} instance and put
* the instance into the {@code target} map with the {@code key}.
*
*
* If {@code nullIncluded} is {@code true}, the {@code key} is put into
* the {@code target} map even when the given {@code json} is {@code null}.
*
*/
@SuppressWarnings("unchecked")
public static void putJsonObject(
Map target, String key,
String json, boolean nullIncluded)
{
Map value = (json == null) ? null :
(Map)Utils.fromJson(json, Map.class);
if (value != null || nullIncluded)
{
target.put(key, value);
}
}
/**
* Convert the given {@code json} into a {@code List} instance and put
* the instance into the {@code target} map with the {@code key}.
*
*
* If {@code nullIncluded} is {@code true}, the {@code key} is put into
* the {@code target} map even when the given {@code json} is {@code null}.
*
*
* @since 3.55
*/
public static void putJsonArray(
Map target, String key,
String json, boolean nullIncluded)
{
List> value = (json == null) ? null :
(List>)Utils.fromJson(json, List.class);
if (value != null || nullIncluded)
{
target.put(key, value);
}
}
private static List asList(T[] array)
{
if (array == null)
{
return null;
}
return Arrays.stream(array)
.map(element -> element.toString())
.collect(Collectors.toList());
}
/**
* Put the entries in the {@code map} into the {@code target} map.
* When {@code control} is {@code null}, an instance is internally
* created by {@code new MapControl()} and used.
*/
public static void put(
Map target,
Map map, MapControl control)
{
if (control == null)
{
control = new MapControl();
}
for (Map.Entry entry : map.entrySet())
{
putEntry(target, entry, control);
}
}
private static void putEntry(
Map target,
Map.Entry entry, MapControl control)
{
String key = entry.getKey();
Object value = entry.getValue();
if (value instanceof Boolean)
{
putEntryBoolean(target, key, (Boolean)value, control);
}
else if (value instanceof Integer)
{
putEntryInteger(target, key, (Integer)value, control);
}
else if (value instanceof Number)
{
putEntryNumber(target, key, (Number)value, control);
}
else
{
putEntryDefault(target, key, value, control);
}
}
private static void putEntryBoolean(
Map target,
String key, Boolean value, MapControl control)
{
boolean value_ = value.booleanValue();
if (value_ || control.isFalseIncluded())
{
target.put(key, value_);
}
}
private static void putEntryInteger(
Map target,
String key, Integer value, MapControl control)
{
int value_ = ((Integer)value).intValue();
if (value_ != 0 || control.isZeroIncluded())
{
target.put(key, value_);
}
}
private static void putEntryNumber(
Map target,
String key, Number value, MapControl control)
{
long value_ = ((Number)value).longValue();
if (value_ != 0 || control.isZeroIncluded())
{
target.put(key, value_);
}
}
private static void putEntryDefault(
Map target,
String key, Object value, MapControl control)
{
if (value != null || control.isNullIncluded())
{
target.put(key, value);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy