-
Notifications
You must be signed in to change notification settings - Fork 40
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Kavindu Dodanduwa <[email protected]>
- Loading branch information
1 parent
5f173ff
commit 3ed40a3
Showing
6 changed files
with
275 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,188 @@ | ||
package dev.openfeature.sdk; | ||
|
||
import lombok.extern.slf4j.Slf4j; | ||
|
||
import java.util.HashMap; | ||
import java.util.Map; | ||
|
||
/** | ||
* Immutable Flag Metadata representation. Implementation is backed by a {@link Map} and immutability is provided | ||
* through builder and accessors. | ||
*/ | ||
@Slf4j | ||
public class FlagMetadata { | ||
private final Map<String, Object> metadata; | ||
|
||
private FlagMetadata(Map<String, Object> metadata) { | ||
this.metadata = metadata; | ||
} | ||
|
||
/** | ||
* Retrieve a {@link String} value for the given key. A {@code null} value is returned if the key does not exist | ||
* or if the value is of a different type. | ||
* | ||
* @param key flag metadata key to retrieve | ||
*/ | ||
public String getString(final String key) { | ||
return getValue(key, String.class); | ||
} | ||
|
||
/** | ||
* Retrieve a {@link Integer} value for the given key. A {@code null} value is returned if the key does not exist | ||
* or if the value is of a different type. | ||
* | ||
* @param key flag metadata key to retrieve | ||
*/ | ||
public Integer getInteger(final String key) { | ||
return getValue(key, Integer.class); | ||
} | ||
|
||
/** | ||
* Retrieve a {@link Long} value for the given key. A {@code null} value is returned if the key does not exist | ||
* or if the value is of a different type. | ||
* | ||
* @param key flag metadata key to retrieve | ||
*/ | ||
public Long getLong(final String key) { | ||
return getValue(key, Long.class); | ||
} | ||
|
||
/** | ||
* Retrieve a {@link Float} value for the given key. A {@code null} value is returned if the key does not exist | ||
* or if the value is of a different type. | ||
* | ||
* @param key flag metadata key to retrieve | ||
*/ | ||
public Float getFloat(final String key) { | ||
return getValue(key, Float.class); | ||
} | ||
|
||
/** | ||
* Retrieve a {@link Double} value for the given key. A {@code null} value is returned if the key does not exist | ||
* or if the value is of a different type. | ||
* | ||
* @param key flag metadata key to retrieve | ||
*/ | ||
public Double getDouble(final String key) { | ||
return getValue(key, Double.class); | ||
} | ||
|
||
/** | ||
* Retrieve a {@link Boolean} value for the given key. A {@code null} value is returned if the key does not exist | ||
* or if the value is of a different type. | ||
* | ||
* @param key flag metadata key to retrieve | ||
*/ | ||
public Boolean getBoolean(final String key) { | ||
return getValue(key, Boolean.class); | ||
} | ||
|
||
private <T> T getValue(final String key, final Class<T> type) { | ||
final Object o = metadata.get(key); | ||
|
||
if (o == null) { | ||
log.debug("Metadata key " + key + "does not exist"); | ||
return null; | ||
} | ||
|
||
try { | ||
return type.cast(o); | ||
} catch (ClassCastException e) { | ||
log.debug("Error retrieving value for key " + key, e); | ||
return null; | ||
} | ||
} | ||
|
||
|
||
/** | ||
* Obtain a builder for {@link FlagMetadata}. | ||
*/ | ||
public static FlagMetadataBuilder builder() { | ||
return new FlagMetadataBuilder(); | ||
} | ||
|
||
/** | ||
* Immutable builder for {@link FlagMetadata}. | ||
*/ | ||
public static class FlagMetadataBuilder { | ||
private final Map<String, Object> metadata; | ||
|
||
private FlagMetadataBuilder() { | ||
metadata = new HashMap<>(); | ||
} | ||
|
||
/** | ||
* Add String value to the metadata. | ||
* | ||
* @param key flag metadata key to add | ||
* @param value flag metadata value to add | ||
*/ | ||
public FlagMetadataBuilder addString(final String key, final String value) { | ||
metadata.put(key, value); | ||
return this; | ||
} | ||
|
||
/** | ||
* Add Integer value to the metadata. | ||
* | ||
* @param key flag metadata key to add | ||
* @param value flag metadata value to add | ||
*/ | ||
public FlagMetadataBuilder addInteger(final String key, final Integer value) { | ||
metadata.put(key, value); | ||
return this; | ||
} | ||
|
||
/** | ||
* Add Long value to the metadata. | ||
* | ||
* @param key flag metadata key to add | ||
* @param value flag metadata value to add | ||
*/ | ||
public FlagMetadataBuilder addLong(final String key, final Long value) { | ||
metadata.put(key, value); | ||
return this; | ||
} | ||
|
||
/** | ||
* Add Float value to the metadata. | ||
* | ||
* @param key flag metadata key to add | ||
* @param value flag metadata value to add | ||
*/ | ||
public FlagMetadataBuilder addFloat(final String key, final Float value) { | ||
metadata.put(key, value); | ||
return this; | ||
} | ||
|
||
/** | ||
* Add Double value to the metadata. | ||
* | ||
* @param key flag metadata key to add | ||
* @param value flag metadata value to add | ||
*/ | ||
public FlagMetadataBuilder addDouble(final String key, final Double value) { | ||
metadata.put(key, value); | ||
return this; | ||
} | ||
|
||
/** | ||
* Add Boolean value to the metadata. | ||
* | ||
* @param key flag metadata key to add | ||
* @param value flag metadata value to add | ||
*/ | ||
public FlagMetadataBuilder addBoolean(final String key, final Boolean value) { | ||
metadata.put(key, value); | ||
return this; | ||
} | ||
|
||
/** | ||
* Retrieve {@link FlagMetadata} with provided key,value pairs. | ||
*/ | ||
public FlagMetadata build() { | ||
return new FlagMetadata(this.metadata); | ||
} | ||
|
||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.