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

io.helidon.config.spi.ConfigMapperProvider Maven / Gradle / Ivy

There is a newer version: 4.1.1
Show newest version
/*
 * Copyright (c) 2017, 2019 Oracle and/or its affiliates. All rights reserved.
 *
 * 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 io.helidon.config.spi;

import java.util.Map;
import java.util.Optional;
import java.util.function.BiFunction;
import java.util.function.Function;

import io.helidon.common.GenericType;
import io.helidon.config.Config;

/**
 * Provides mapping functions that convert a {@code Config}
 * subtree to specific Java types.
 * 

* The config system automatically loads {@code ConfigMapperProvider}s using the * Java {@link java.util.ServiceLoader} mechanism, and by default the config * system automatically registers all {@code ConfigMapper}s from all such * providers with every {@code Config.Builder}. The application can suppress * auto-registration of loaded mappers by invoking * {@link Config.Builder#disableMapperServices()}. *

* Each {@code ConfigMapperProvider} can specify a * {@link javax.annotation.Priority}. The default priority is {@value PRIORITY}. * * @see Config.Builder#addStringMapper(Class, Function) * @see Config.Builder#addMapper(ConfigMapperProvider) * @see Config.Builder#disableMapperServices() */ @FunctionalInterface public interface ConfigMapperProvider { /** * Default priority of the mapper provider if registered by {@link Config.Builder} automatically. */ int PRIORITY = 100; /** * Returns a map of mapper functions associated with appropriate target type ({@code Class}. *

* Mappers will by automatically registered by {@link Config.Builder} during * bootstrapping of {@link Config} unless * {@link Config.Builder#disableMapperServices() disableld}. * * @return a map of config mapper functions, never {@code null}, though this may return an empty map if * {@link #mapper(Class)} is used instead */ Map, Function> mappers(); /** * Returns a map of mapper functions associated with appropriate target type ({@code GenericType}. *

* Mappers will by automatically registered by {@link Config.Builder} during * bootstrapping of {@link Config} unless * {@link Config.Builder#disableMapperServices() disableld}. * * @return a map of config mapper functions, never {@code null}, though this may return an empty map if * {@link #mapper(Class)} is used instead */ default Map, BiFunction> genericTypeMappers() { return Map.of(); } /** * A simple mapping function from config node to a typed value based on the expected class. * If more complex type handling or conversion is needed, use {@link #mapper(GenericType)}. * * @param type type of the expected mapping result * @param type returned from conversion * @return function to convert config node to the expected type, or empty if the type is not supported by this provider */ default Optional> mapper(Class type) { return Optional.empty(); } /** * Mapper for a specific generic type. * If your mapper only supports simple classes, get it using {@link GenericType#rawType()}. * Otherwise you have access to the (possibly) generics type of the expected result using * {@link GenericType#type()}. *

* The mapping function has two parameters: *

    *
  • {@link Config} - config node to convert to the expected type *
  • {@link ConfigMapper} - mapper to help with conversion of sub-nodes if needed
  • *
* and returns a typed value. * * @param type type providing information what is the mapped type * @param type to map to * @return a function that would convert the provided Config instance into the expected type if * supported by this provider, empty otherwise. */ default Optional> mapper(GenericType type) { return Optional.empty(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy