All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jnosql.diana.mongodb.document.MongoDBDocumentCollectionManagerAsync Maven / Gradle / Ivy

The newest version!
/*
 *  Copyright (c) 2017 Otávio Santana and others
 *   All rights reserved. This program and the accompanying materials
 *   are made available under the terms of the Eclipse Public License v1.0
 *   and Apache License v2.0 which accompanies this distribution.
 *   The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
 *   and the Apache License v2.0 is available at http://www.opensource.org/licenses/apache2.0.php.
 *
 *   You may elect to redistribute this code under either of these licenses.
 *
 *   Contributors:
 *
 *   Otavio Santana
 */
package org.jnosql.diana.mongodb.document;


import com.mongodb.Block;
import com.mongodb.async.SingleResultCallback;
import com.mongodb.async.client.FindIterable;
import com.mongodb.async.client.MongoCollection;
import com.mongodb.async.client.MongoDatabase;
import com.mongodb.client.model.Sorts;
import com.mongodb.client.result.DeleteResult;
import org.bson.BsonDocument;
import org.bson.Document;
import org.bson.conversions.Bson;
import org.jnosql.diana.api.ExecuteAsyncQueryException;
import org.jnosql.diana.api.Sort;
import org.jnosql.diana.api.document.DocumentCollectionManagerAsync;
import org.jnosql.diana.api.document.DocumentDeleteQuery;
import org.jnosql.diana.api.document.DocumentEntity;
import org.jnosql.diana.api.document.DocumentQuery;
import org.jnosql.diana.api.document.Documents;

import java.time.Duration;
import java.util.List;
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.function.Consumer;

import static java.util.Objects.requireNonNull;
import static org.jnosql.diana.mongodb.document.MongoDBUtils.ID_FIELD;
import static org.jnosql.diana.mongodb.document.MongoDBUtils.getDocument;

/**
 * The mongodb implementation of {@link DocumentCollectionManagerAsync} whose does not support the TTL methods:
 * 

{@link MongoDBDocumentCollectionManagerAsync#insert(DocumentEntity, Duration)}

*

{@link MongoDBDocumentCollectionManagerAsync#insert(DocumentEntity, Duration, Consumer)}

*/ public class MongoDBDocumentCollectionManagerAsync implements DocumentCollectionManagerAsync { private static final BsonDocument EMPTY = new BsonDocument(); private final MongoDatabase asyncMongoDatabase; MongoDBDocumentCollectionManagerAsync(MongoDatabase asyncMongoDatabase) { this.asyncMongoDatabase = asyncMongoDatabase; } @Override public void insert(DocumentEntity entity) throws ExecuteAsyncQueryException, UnsupportedOperationException { requireNonNull(entity, "entity is required"); insert(entity, v -> { }); } @Override public void insert(DocumentEntity entity, Duration ttl) { throw new UnsupportedOperationException("MongoDB does not support saveAsync with TTL"); } @Override public void insert(DocumentEntity entity, Consumer callBack) throws ExecuteAsyncQueryException, UnsupportedOperationException { requireNonNull(entity, "entity is required"); requireNonNull(callBack, "callBack is required"); insert(entity, (aVoid, throwable) -> callBack.accept(entity)); } @Override public void insert(DocumentEntity entity, Duration ttl, Consumer callBack) { throw new UnsupportedOperationException("MongoDB does not support saveAsync with TTL"); } @Override public void update(DocumentEntity entity) throws ExecuteAsyncQueryException, UnsupportedOperationException { requireNonNull(entity, "entity is required"); update(entity, (d, throwable) -> { }); } @Override public void update(DocumentEntity entity, Consumer callBack) throws ExecuteAsyncQueryException, UnsupportedOperationException { requireNonNull(entity, "entity is required"); requireNonNull(callBack, "callBack is required"); update(entity, (d, throwable) -> callBack.accept(DocumentEntity.of(entity.getName(), Documents.of(d)))); } @Override public void delete(DocumentDeleteQuery query) { requireNonNull(query, "query is required"); delete(query, (deleteResult, throwable) -> { }); } @Override public void delete(DocumentDeleteQuery query, Consumer callBack) throws ExecuteAsyncQueryException, UnsupportedOperationException { requireNonNull(query, "query is required"); requireNonNull(callBack, "callBack is required"); delete(query, (deleteResult, throwable) -> callBack.accept(null)); } @Override public void select(DocumentQuery query, Consumer> callBack) throws ExecuteAsyncQueryException, UnsupportedOperationException { requireNonNull(query, "query is required"); requireNonNull(callBack, "callBack is required"); String collectionName = query.getDocumentCollection(); MongoCollection collection = asyncMongoDatabase.getCollection(collectionName); Bson mongoDBQuery = query.getCondition().map(DocumentQueryConversor::convert).orElse(EMPTY); List entities = new CopyOnWriteArrayList<>(); FindIterable result = collection.find(mongoDBQuery); if (query.getSkip() > 0) { result.skip((int) query.getSkip()); } if (query.getLimit() > 0) { result.limit((int) query.getLimit()); } query.getSorts().stream().map(this::getSort).forEach(result::sort); Block documentBlock = d -> entities.add(createEntity(collectionName, d)); SingleResultCallback voidSingleResultCallback = (v, e) -> callBack.accept(entities); result.forEach(documentBlock, voidSingleResultCallback); } @Override public void count(String documentCollection, Consumer callback) { requireNonNull(documentCollection, "documentCollection is required"); requireNonNull(callback, "callback is required"); MongoCollection collection = asyncMongoDatabase.getCollection(documentCollection); collection.count((l, e) -> callback.accept(l)); } private DocumentEntity createEntity(String collectionName, Document document) { return DocumentEntity.of(collectionName, MongoDBUtils.of(document)); } private void insert(DocumentEntity entity, SingleResultCallback callBack) { String collectionName = entity.getName(); com.mongodb.async.client.MongoCollection collectionAsync = asyncMongoDatabase.getCollection(collectionName); Document document = getDocument(entity); collectionAsync.insertOne(document, callBack); } private void update(DocumentEntity entity, SingleResultCallback callBack) { String collectionName = entity.getName(); com.mongodb.async.client.MongoCollection asyncCollection = asyncMongoDatabase.getCollection(collectionName); Document id = entity.find(ID_FIELD).map(d -> new Document(d.getName(), d.getValue().get())) .orElseThrow(() -> new UnsupportedOperationException("To update this DocumentEntity " + "the field `_id` is required")); asyncCollection.findOneAndReplace(id, getDocument(entity), callBack); } private void delete(DocumentDeleteQuery query, SingleResultCallback callBack) { String collectionName = query.getDocumentCollection(); com.mongodb.async.client.MongoCollection asyncCollection = asyncMongoDatabase.getCollection(collectionName); Bson mongoDBQuery = DocumentQueryConversor.convert(query.getCondition() .orElseThrow(() -> new IllegalArgumentException("condition is required"))); asyncCollection.deleteMany(mongoDBQuery, callBack); } @Override public void close() { } private Bson getSort(Sort sort) { boolean isAscending = Sort.SortType.ASC.equals(sort.getType()); return isAscending?Sorts.ascending(sort.getName()): Sorts.descending(sort.getName()); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy