/* * SPDX-License-Identifier: Apache-2.0 * * The OpenSearch Contributors require contributions made to * this file be licensed under the Apache-2.0 license or a * compatible open source license. */ /* * Licensed to Elasticsearch under one or more contributor * license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright * ownership. Elasticsearch licenses this file to you 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. */ /* * Modifications Copyright OpenSearch Contributors. See * GitHub history for details. */ package org.opensearch.indices.mapper; import org.opensearch.index.mapper.Mapper; import org.opensearch.index.mapper.MetadataFieldMapper; import org.opensearch.plugins.MapperPlugin; import java.util.Collections; import java.util.LinkedHashMap; import java.util.Map; import java.util.function.Function; import java.util.function.Predicate; /** * A registry for all field mappers. * * @opensearch.internal */ public final class MapperRegistry { private final Map mapperParsers; private final Map metadataMapperParsers; private final Function> fieldFilter; public MapperRegistry( Map mapperParsers, Map metadataMapperParsers, Function> fieldFilter ) { this.mapperParsers = Collections.unmodifiableMap(new LinkedHashMap<>(mapperParsers)); this.metadataMapperParsers = Collections.unmodifiableMap(new LinkedHashMap<>(metadataMapperParsers)); this.fieldFilter = fieldFilter; } /** * Return a map of the mappers that have been registered. The * returned map uses the type of the field as a key. */ public Map getMapperParsers() { return mapperParsers; } /** * Return a map of the meta mappers that have been registered. The * returned map uses the name of the field as a key. */ public Map getMetadataMapperParsers() { return metadataMapperParsers; } /** * Returns true if the provided field is a registered metadata field, false otherwise */ public boolean isMetadataField(String field) { return getMetadataMapperParsers().containsKey(field); } /** * Returns a function that given an index name, returns a predicate that fields must match in order to be returned by get mappings, * get index, get field mappings and field capabilities API. Useful to filter the fields that such API return. * The predicate receives the field name as input arguments. In case multiple plugins register a field filter through * {@link MapperPlugin#getFieldFilter()}, only fields that match all the registered filters will be returned by get mappings, * get index, get field mappings and field capabilities API. */ public Function> getFieldFilter() { return fieldFilter; } }