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

io.smallrye.stork.api.Metadata Maven / Gradle / Ivy

package io.smallrye.stork.api;

import java.util.Collections;
import java.util.EnumMap;
import java.util.Map;

/**
 * Service Instance metadata.
 *
 * 

* This class stores service instance metadata that can be used by the load balancer to select the service instance to use. *

*

* Instances of this class are immutable. Modification operations return new instances. *

* You can create new instances using the {@link #of(Class)}, {@link #of(Class, Map)} and {@link #with(Enum, Object)}methods. */ public class Metadata & MetadataKey> { private final EnumMap metadata; private final Class clazz; private static final Metadata EMPTY = new Metadata<>(NoMetadataKey.class, Collections.emptyMap()); private Metadata(Class key, Map metadata) { if (metadata.isEmpty()) { this.metadata = new EnumMap<>(key); } else { this.metadata = new EnumMap<>(metadata); } this.clazz = key; } /** * Returns an immutable, empty set of metadata. * * @return the empty instance */ public static & MetadataKey> Metadata empty() { return (Metadata) EMPTY; } /** * Returns an instance of {@link Metadata} containing metadata values. * * @param key the class of the key, must not be {@code null} * @param metadata the metadata, must not be {@code null}, must not contain {@code null}, * must not contain multiple objects of the same class * @param the key type * @return the new metadata */ public static & MetadataKey> Metadata of(Class key, Map metadata) { if (metadata == null) { throw new IllegalArgumentException("`metadata` must not be `null`"); } return new Metadata<>(key, metadata); } /** * Returns an instance of {@link Metadata} containing an empty set of values. * * @param key the type of metadata, must not be {@code null} * @param the type key type * @return the new metadata */ public static & MetadataKey> Metadata of(Class key) { if (key == null) { throw new IllegalArgumentException("`key` must not be `null`"); } return new Metadata<>(key, Collections.emptyMap()); } /** * Creates a new instance of {@link Metadata} with the current entries, plus {@code item}. * If the current set of metadata contains already an instance of the class of {@code item}, the value is replaced * in the returned {@link Metadata}. * * @param key the key, must not be {@code null} * @param item the metadata to be added, must not be {@code null}. * @return the new instance of {@link Metadata} */ public Metadata with(T key, Object item) { if (key == null) { throw new IllegalArgumentException("`key` must not be `null`"); } if (item == null) { throw new IllegalArgumentException(key.name() + " should not be `null`"); } EnumMap copy = new EnumMap<>(metadata); copy.put(key, item); return new Metadata<>(this.clazz, copy); } /** * @return the metadata */ public EnumMap getMetadata() { return metadata; } /** * The default metadata key. */ public enum DefaultMetadataKey implements MetadataKey { /** * The key. */ GENERIC_METADATA_KEY("generic"); private final String name; DefaultMetadataKey(String name) { this.name = name; } @Override public String getName() { return name; } } public enum NoMetadataKey implements MetadataKey { ; @Override public String getName() { return null; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy