/driver/src/main/com/mongodb/DistinctIterableImpl.java
https://github.com/foursquare/mongo-java-driver · Java · 121 lines · 87 code · 18 blank · 16 comment · 1 complexity · 6c3a11bc897203e866c3f8801399afaf MD5 · raw file
- /*
- * 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;
- import com.mongodb.client.DistinctIterable;
- import com.mongodb.client.MongoCursor;
- import com.mongodb.client.MongoIterable;
- import com.mongodb.client.model.Collation;
- import com.mongodb.operation.DistinctOperation;
- import com.mongodb.operation.OperationExecutor;
- 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;
- class DistinctIterableImpl<TDocument, TResult> implements DistinctIterable<TResult> {
- private final MongoNamespace namespace;
- private final Class<TDocument> documentClass;
- private final Class<TResult> resultClass;
- private final ReadPreference readPreference;
- private final ReadConcern readConcern;
- private final CodecRegistry codecRegistry;
- private final OperationExecutor executor;
- private final String fieldName;
- private Bson filter;
- private long maxTimeMS;
- private Collation collation;
- DistinctIterableImpl(final MongoNamespace namespace, final Class<TDocument> documentClass, final Class<TResult> resultClass,
- final CodecRegistry codecRegistry, final ReadPreference readPreference, final ReadConcern readConcern,
- final OperationExecutor executor, final String fieldName, final Bson filter) {
- this.namespace = notNull("namespace", namespace);
- this.documentClass = notNull("documentClass", documentClass);
- this.resultClass = notNull("resultClass", resultClass);
- this.codecRegistry = notNull("codecRegistry", codecRegistry);
- this.readPreference = notNull("readPreference", readPreference);
- this.readConcern = notNull("readConcern", readConcern);
- this.executor = notNull("executor", executor);
- this.fieldName = notNull("mapFunction", fieldName);
- this.filter = filter;
- }
- @Override
- public DistinctIterable<TResult> filter(final Bson filter) {
- this.filter = filter;
- return this;
- }
- @Override
- public DistinctIterable<TResult> maxTime(final long maxTime, final TimeUnit timeUnit) {
- notNull("timeUnit", timeUnit);
- this.maxTimeMS = TimeUnit.MILLISECONDS.convert(maxTime, timeUnit);
- return this;
- }
- @Override
- public DistinctIterable<TResult> batchSize(final int batchSize) {
- // Noop - not supported by DistinctIterable
- return this;
- }
- @Override
- public DistinctIterable<TResult> collation(final Collation collation) {
- this.collation = collation;
- return this;
- }
- @Override
- public MongoCursor<TResult> iterator() {
- return execute().iterator();
- }
- @Override
- public TResult first() {
- return execute().first();
- }
- @Override
- public <U> MongoIterable<U> map(final Function<TResult, U> mapper) {
- return new MappingIterable<TResult, U>(this, mapper);
- }
- @Override
- public void forEach(final Block<? super TResult> block) {
- execute().forEach(block);
- }
- @Override
- public <A extends Collection<? super TResult>> A into(final A target) {
- return execute().into(target);
- }
- private MongoIterable<TResult> execute() {
- DistinctOperation<TResult> operation = new DistinctOperation<TResult>(namespace, fieldName, codecRegistry.get(resultClass))
- .filter(filter == null ? null : filter.toBsonDocument(documentClass, codecRegistry))
- .maxTime(maxTimeMS, MILLISECONDS)
- .readConcern(readConcern)
- .collation(collation);
- return new OperationIterable<TResult>(operation, readPreference, executor);
- }
- }