com.facebook.presto.atop.AtopPageSourceProvider Maven / Gradle / Ivy
/*
* 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 com.facebook.presto.atop;
import com.facebook.presto.atop.AtopTable.AtopColumn;
import com.facebook.presto.common.type.Type;
import com.facebook.presto.common.type.TypeManager;
import com.facebook.presto.spi.ColumnHandle;
import com.facebook.presto.spi.ConnectorPageSource;
import com.facebook.presto.spi.ConnectorSession;
import com.facebook.presto.spi.ConnectorSplit;
import com.facebook.presto.spi.SplitContext;
import com.facebook.presto.spi.connector.ConnectorPageSourceProvider;
import com.facebook.presto.spi.connector.ConnectorTransactionHandle;
import com.google.common.collect.ImmutableList;
import javax.inject.Inject;
import java.time.ZonedDateTime;
import java.util.List;
import java.util.concurrent.Semaphore;
import static com.google.common.base.Preconditions.checkArgument;
import static io.airlift.slice.Slices.utf8Slice;
import static java.util.Objects.requireNonNull;
public final class AtopPageSourceProvider
implements ConnectorPageSourceProvider
{
private final Semaphore readerPermits;
private final AtopFactory atopFactory;
private final TypeManager typeManager;
@Inject
public AtopPageSourceProvider(AtopConnectorConfig config, AtopFactory atopFactory, TypeManager typeManager)
{
readerPermits = new Semaphore(requireNonNull(config, "config is null").getConcurrentReadersPerNode());
this.atopFactory = requireNonNull(atopFactory, "atopFactory is null");
this.typeManager = requireNonNull(typeManager, "typeManager is null");
}
@Override
public ConnectorPageSource createPageSource(
ConnectorTransactionHandle transactionHandle,
ConnectorSession session,
ConnectorSplit split,
List columns,
SplitContext splitContext)
{
AtopSplit atopSplit = (AtopSplit) split;
ImmutableList.Builder types = ImmutableList.builder();
ImmutableList.Builder atopColumns = ImmutableList.builder();
for (ColumnHandle column : columns) {
AtopColumnHandle atopColumnHandle = (AtopColumnHandle) column;
AtopColumn atopColumn = atopSplit.getTable().getColumn(atopColumnHandle.getName());
atopColumns.add(atopColumn);
types.add(typeManager.getType(atopColumn.getType()));
}
ZonedDateTime date = atopSplit.getDate();
checkArgument(date.equals(date.withHour(0).withMinute(0).withSecond(0).withNano(0)), "Expected date to be at beginning of day");
return new AtopPageSource(readerPermits, atopFactory, session, utf8Slice(atopSplit.getHost().getHostText()), atopSplit.getTable(), date, atopColumns.build(), types.build());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy