官术网_书友最值得收藏!

Custom converters

If your application defines Java types that do not provide any of these three cases covered by the automatic converters, MicroProfile Config can still provide conversion using custom converters that extend the org.eclipse.microprofile.config.spi.Converter interface defined in the following:

public interface Converter<T> {
    /**
     * Configure the string value to a specified type
     * @param value the string representation of a property value.
     * @return the converted value or null
     *
     * @throws IllegalArgumentException if the value cannot be converted to 
the specified type. */ T convert(String value);

You have to write an implementation of org.eclipse.microprofile.config.spi.Converter, then add its name to the /META-INF/services/org.eclipse.microprofile.config.spi.Converter file and put that file in your application archive. For your reference, here is an example of the implementation of a custom converter that supports a named number concept:

package io.packt.sample.config;

import org.eclipse.microprofile.config.spi.Converter;

public class NamedNumberConverter implements Converter<NamedNumber> {
/**
* Parses an assignment type of expression into a name and number value
* @param value name=Number expression
* @return NamedNumber instance
*/
@Override
public NamedNumber convert(String value) {
String[] parts = value.split("="); // 1
return new NamedNumber(parts[0], parts[1]);
}
}

package io.packt.sample.config;

public class NamedNumber {
private String name;
private Number number;

public NamedNumber(String name, Number number) {
this.name = name;
this.number = number;
}

...
}

The converter takes a string and splits it based on a comma separator to extract the name and corresponding value to build the NamedNumber instance.

You would then specify a named number in your configuration, as shown here:

# microprofile-config.properties NamedNumber example
injected.namedNumber
=jdoe,2.0

The addition of NamedNumberConverter allows us to use the NamedNumber type as a configuration type that can be injected. Here is an example that would match the configuration setting shown previously:

@Inject
@ConfigProperty(name="injected.namedNumber")
NamedNumber configuredNumber;

With the base MicroProfile Config feature covered, let's move onto another feature, MicroProfile Fault Tolerance.

主站蜘蛛池模板: 嫩江县| 郓城县| 闽清县| 南昌县| 河津市| 安徽省| 景泰县| 且末县| 巴里| 安平县| 禹城市| 古丈县| 景谷| 保康县| 天镇县| 海阳市| 靖州| 南平市| 昭觉县| 杂多县| 阿鲁科尔沁旗| 康马县| 驻马店市| 县级市| 长顺县| 富蕴县| 平定县| 延安市| 高要市| 武冈市| 花垣县| 锡林浩特市| 英山县| 平原县| 连南| 兴业县| 景德镇市| 嘉黎县| 龙口市| 雅安市| 铅山县|