/* * Licensed to CRATE Technology GmbH ("Crate") under one or more contributor * license agreements. See the NOTICE file distributed with this work for * additional information regarding copyright ownership. Crate 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. * * However, if you have executed another commercial license agreement * with Crate these terms will supersede the license and you may use the * software solely pursuant to the terms of the relevant commercial agreement. */ package io.crate.operation.scalar; import io.crate.metadata.FunctionResolver; import io.crate.metadata.FunctionIdent; import io.crate.metadata.FunctionImplementation; import io.crate.operation.scalar.arithmetic.*; import io.crate.operation.scalar.cast.CastFunction; import io.crate.operation.scalar.cast.TryCastScalarFunction; import io.crate.operation.scalar.conditional.*; import io.crate.operation.scalar.geo.*; import io.crate.operation.scalar.regex.MatchesFunction; import io.crate.operation.scalar.regex.ReplaceFunction; import io.crate.operation.scalar.string.HashFunctions; import io.crate.operation.scalar.string.LengthFunction; import io.crate.operation.scalar.string.StringCaseFunction; import io.crate.operation.scalar.systeminformation.CurrentSchemaFunction; import io.crate.operation.scalar.timestamp.CurrentTimestampFunction; import org.elasticsearch.common.inject.AbstractModule; import org.elasticsearch.common.inject.multibindings.MapBinder; import java.util.HashMap; import java.util.Map; public class ScalarFunctionModule extends AbstractModule { private Map<FunctionIdent, FunctionImplementation> functions = new HashMap<>(); private Map<String, FunctionResolver> resolver = new HashMap<>(); private MapBinder<FunctionIdent, FunctionImplementation> functionBinder; private MapBinder<String, FunctionResolver> resolverBinder; public void register(FunctionImplementation impl) { functions.put(impl.info().ident(), impl); } public void register(String name, FunctionResolver functionResolver) { resolver.put(name, functionResolver); } @Override protected void configure() { NegateFunction.register(this); CollectionCountFunction.register(this); CollectionAverageFunction.register(this); FormatFunction.register(this); SubstrFunction.register(this); MatchesFunction.register(this); ReplaceFunction.register(this); ArithmeticFunctions.register(this); DistanceFunction.register(this); WithinFunction.register(this); IntersectsFunction.register(this); CoordinateFunction.register(this); GeoHashFunction.register(this); SubscriptFunction.register(this); SubscriptObjectFunction.register(this); RoundFunction.register(this); CeilFunction.register(this); RandomFunction.register(this); AbsFunction.register(this); FloorFunction.register(this); SquareRootFunction.register(this); LogFunction.register(this); TrigonometricFunctions.register(this); DateTruncFunction.register(this); ExtractFunctions.register(this); CurrentTimestampFunction.register(this); DateFormatFunction.register(this); CastFunction.register(this); TryCastScalarFunction.register(this); StringCaseFunction.register(this); ConcatFunction.register(this); LengthFunction.register(this); HashFunctions.register(this); MapFunction.register(this); ArrayFunction.register(this); ArrayCatFunction.register(this); ArrayDifferenceFunction.register(this); ArrayUniqueFunction.register(this); CoalesceFunction.register(this); GreatestFunction.register(this); LeastFunction.register(this); NullIfFunction.register(this); IfFunction.register(this); CurrentSchemaFunction.register(this); // bind all registered functions and resolver // by doing it here instead of the register functions, plugins can also use the // register functions in their onModule(...) hooks functionBinder = MapBinder.newMapBinder(binder(), FunctionIdent.class, FunctionImplementation.class); resolverBinder = MapBinder.newMapBinder(binder(), String.class, FunctionResolver.class); for (Map.Entry<FunctionIdent, FunctionImplementation> entry : functions.entrySet()) { functionBinder.addBinding(entry.getKey()).toInstance(entry.getValue()); } for (Map.Entry<String, FunctionResolver> entry : resolver.entrySet()) { resolverBinder.addBinding(entry.getKey()).toInstance(entry.getValue()); } // clear registration maps functions = null; resolver = null; } }