/* * Copyright 2015 MongoDB, Inc. * * 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.mongodb.async.client; import com.mongodb.Block; import com.mongodb.Function; import com.mongodb.ReadPreference; import com.mongodb.async.AsyncBatchCursor; import com.mongodb.async.SingleResultCallback; import com.mongodb.operation.AsyncOperationExecutor; import com.mongodb.operation.ListCollectionsOperation; import org.bson.BsonDocument; import org.bson.codecs.configuration.CodecRegistry; import org.bson.conversions.Bson; import java.util.Collection; import java.util.concurrent.TimeUnit; import static com.mongodb.assertions.Assertions.notNull; import static java.util.concurrent.TimeUnit.MILLISECONDS; final class ListCollectionsIterableImpl<TResult> implements ListCollectionsIterable<TResult> { private final String databaseName; private final Class<TResult> resultClass; private final ReadPreference readPreference; private final CodecRegistry codecRegistry; private final AsyncOperationExecutor executor; private Bson filter; private int batchSize; private long maxTimeMS; ListCollectionsIterableImpl(final String databaseName, final Class<TResult> resultClass, final CodecRegistry codecRegistry, final ReadPreference readPreference, final AsyncOperationExecutor executor) { this.databaseName = notNull("databaseName", databaseName); this.resultClass = notNull("resultClass", resultClass); this.codecRegistry = notNull("codecRegistry", codecRegistry); this.readPreference = notNull("readPreference", readPreference); this.executor = notNull("executor", executor); } @Override public ListCollectionsIterable<TResult> filter(final Bson filter) { notNull("filter", filter); this.filter = filter; return this; } @Override public ListCollectionsIterable<TResult> maxTime(final long maxTime, final TimeUnit timeUnit) { notNull("timeUnit", timeUnit); this.maxTimeMS = MILLISECONDS.convert(maxTime, timeUnit); return this; } @Override public ListCollectionsIterable<TResult> batchSize(final int batchSize) { this.batchSize = batchSize; return this; } @Override public void first(final SingleResultCallback<TResult> callback) { notNull("callback", callback); execute(createListCollectionsOperation().batchSize(-1)).first(callback); } @Override public void forEach(final Block<? super TResult> block, final SingleResultCallback<Void> callback) { notNull("block", block); notNull("callback", callback); execute().forEach(block, callback); } @Override public <A extends Collection<? super TResult>> void into(final A target, final SingleResultCallback<A> callback) { notNull("target", target); notNull("callback", callback); execute().into(target, callback); } @Override public <U> MongoIterable<U> map(final Function<TResult, U> mapper) { return new MappingIterable<TResult, U>(this, mapper); } @Override public void batchCursor(final SingleResultCallback<AsyncBatchCursor<TResult>> callback) { notNull("callback", callback); execute().batchCursor(callback); } private MongoIterable<TResult> execute() { return execute(createListCollectionsOperation()); } private MongoIterable<TResult> execute(final ListCollectionsOperation<TResult> operation) { return new OperationIterable<TResult>(operation, readPreference, executor); } private ListCollectionsOperation<TResult> createListCollectionsOperation() { return new ListCollectionsOperation<TResult>(databaseName, codecRegistry.get(resultClass)) .filter(toBsonDocument(filter)) .batchSize(batchSize) .maxTime(maxTimeMS, MILLISECONDS); } private BsonDocument toBsonDocument(final Bson document) { return document == null ? null : document.toBsonDocument(BsonDocument.class, codecRegistry); } }