blob: 9af61f55f7704ac5d3265daf976357ff312e5f8a [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF 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.
*/
package org.apache.calcite.config;
import org.apache.calcite.avatica.ConnectionConfigImpl;
import org.apache.calcite.avatica.util.Casing;
import org.apache.calcite.avatica.util.Quoting;
import org.apache.calcite.model.JsonSchema;
import org.apache.calcite.sql.SqlOperatorTable;
import org.apache.calcite.sql.fun.OracleSqlOperatorTable;
import org.apache.calcite.sql.fun.SqlStdOperatorTable;
import org.apache.calcite.sql.util.ChainedSqlOperatorTable;
import org.apache.calcite.sql.validate.SqlConformance;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;
/** Implementation of {@link CalciteConnectionConfig}. */
public class CalciteConnectionConfigImpl extends ConnectionConfigImpl
implements CalciteConnectionConfig {
public CalciteConnectionConfigImpl(Properties properties) {
super(properties);
}
/** Returns a copy of this configuration with one property changed. */
public CalciteConnectionConfigImpl set(CalciteConnectionProperty property,
String value) {
final Properties properties1 = new Properties(properties);
properties1.setProperty(property.camelName(), value);
return new CalciteConnectionConfigImpl(properties1);
}
public boolean autoTemp() {
return CalciteConnectionProperty.AUTO_TEMP.wrap(properties).getBoolean();
}
public boolean materializationsEnabled() {
return CalciteConnectionProperty.MATERIALIZATIONS_ENABLED.wrap(properties)
.getBoolean();
}
public boolean createMaterializations() {
return CalciteConnectionProperty.CREATE_MATERIALIZATIONS.wrap(properties)
.getBoolean();
}
public NullCollation defaultNullCollation() {
return CalciteConnectionProperty.DEFAULT_NULL_COLLATION.wrap(properties)
.getEnum(NullCollation.class, NullCollation.HIGH);
}
public <T> T fun(Class<T> operatorTableClass, T defaultOperatorTable) {
final String fun =
CalciteConnectionProperty.FUN.wrap(properties).getString();
if (fun == null || fun.equals("") || fun.equals("standard")) {
return defaultOperatorTable;
}
final List<SqlOperatorTable> tables = new ArrayList<>();
for (String s : fun.split(",")) {
tables.add(operatorTable(s));
}
return operatorTableClass.cast(
ChainedSqlOperatorTable.of(
tables.toArray(new SqlOperatorTable[tables.size()])));
}
private static SqlOperatorTable operatorTable(String s) {
switch (s) {
case "standard":
return SqlStdOperatorTable.instance();
case "oracle":
return ChainedSqlOperatorTable.of(OracleSqlOperatorTable.instance(),
SqlStdOperatorTable.instance());
default:
throw new IllegalArgumentException("Unknown operator table: " + s);
}
}
public String model() {
return CalciteConnectionProperty.MODEL.wrap(properties).getString();
}
public Lex lex() {
return CalciteConnectionProperty.LEX.wrap(properties).getEnum(Lex.class);
}
public Quoting quoting() {
return CalciteConnectionProperty.QUOTING.wrap(properties)
.getEnum(Quoting.class, lex().quoting);
}
public Casing unquotedCasing() {
return CalciteConnectionProperty.UNQUOTED_CASING.wrap(properties)
.getEnum(Casing.class, lex().unquotedCasing);
}
public Casing quotedCasing() {
return CalciteConnectionProperty.QUOTED_CASING.wrap(properties)
.getEnum(Casing.class, lex().quotedCasing);
}
public boolean caseSensitive() {
return CalciteConnectionProperty.CASE_SENSITIVE.wrap(properties)
.getBoolean(lex().caseSensitive);
}
public <T> T schemaFactory(Class<T> schemaFactoryClass,
T defaultSchemaFactory) {
return CalciteConnectionProperty.SCHEMA_FACTORY.wrap(properties)
.getPlugin(schemaFactoryClass, defaultSchemaFactory);
}
public JsonSchema.Type schemaType() {
// Avatica won't allow enum properties whose default is null, so we use
// NONE, which is equivalent to null.
final JsonSchema.Type type =
CalciteConnectionProperty.SCHEMA_TYPE.wrap(properties)
.getEnum(JsonSchema.Type.class);
return type == null || type == JsonSchema.Type.NONE ? null : type;
}
public boolean spark() {
return CalciteConnectionProperty.SPARK.wrap(properties).getBoolean();
}
public boolean forceDecorrelate() {
return CalciteConnectionProperty.FORCE_DECORRELATE.wrap(properties)
.getBoolean();
}
public <T> T typeSystem(Class<T> typeSystemClass, T defaultTypeSystem) {
return CalciteConnectionProperty.TYPE_SYSTEM.wrap(properties)
.getPlugin(typeSystemClass, defaultTypeSystem);
}
public SqlConformance conformance() {
return CalciteConnectionProperty.CONFORMANCE.wrap(properties)
.getEnum(SqlConformance.class);
}
}
// End CalciteConnectionConfigImpl.java