com.hazelcast.jet.sql.impl.connector.infoschema.InfoSchemaConnector Maven / Gradle / Ivy
/*
* Copyright 2021 Hazelcast Inc.
*
* Licensed under the Hazelcast Community License (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://hazelcast.com/hazelcast-community-license
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.hazelcast.jet.sql.impl.connector.infoschema;
import com.hazelcast.jet.Traverser;
import com.hazelcast.jet.Traversers;
import com.hazelcast.jet.core.AbstractProcessor;
import com.hazelcast.jet.core.DAG;
import com.hazelcast.jet.core.ProcessorSupplier;
import com.hazelcast.jet.core.Vertex;
import com.hazelcast.jet.sql.impl.ExpressionUtil;
import com.hazelcast.jet.sql.impl.SimpleExpressionEvalContext;
import com.hazelcast.jet.sql.impl.connector.SqlConnector;
import com.hazelcast.sql.impl.schema.MappingField;
import com.hazelcast.spi.impl.NodeEngine;
import com.hazelcast.sql.impl.expression.Expression;
import com.hazelcast.sql.impl.expression.ExpressionEvalContext;
import com.hazelcast.sql.impl.schema.Table;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.util.List;
import java.util.Map;
import static com.hazelcast.jet.core.ProcessorMetaSupplier.forceTotalParallelismOne;
/**
* A connector for tables in the {@code information_schema}.
*/
final class InfoSchemaConnector implements SqlConnector {
public static final InfoSchemaConnector INSTANCE = new InfoSchemaConnector();
private static final String TYPE_NAME = "InformationSchema";
private InfoSchemaConnector() {
}
@Override
public String typeName() {
return TYPE_NAME;
}
@Override
public boolean isStream() {
return false;
}
@Nonnull @Override
public List resolveAndValidateFields(
@Nonnull NodeEngine nodeEngine,
@Nonnull Map options,
@Nonnull List userFields
) {
throw new UnsupportedOperationException();
}
@Nonnull @Override
public Table createTable(
@Nonnull NodeEngine nodeEngine,
@Nonnull String schemaName,
@Nonnull String mappingName,
@Nonnull String externalName,
@Nonnull Map options,
@Nonnull List resolvedFields
) {
throw new UnsupportedOperationException();
}
@Nonnull @Override
public Vertex fullScanReader(
@Nonnull DAG dag,
@Nonnull Table table0,
@Nullable Expression predicate,
@Nonnull List> projection
) {
InfoSchemaTable table = (InfoSchemaTable) table0;
List