Skip to content

Commit

Permalink
Mongo Client should not require Jackson Databind (#312)
Browse files Browse the repository at this point in the history
See #293

Signed-off-by: Thomas Segismont <[email protected]>
  • Loading branch information
tsegismont committed Nov 8, 2023
1 parent c65c858 commit 1546a0f
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 23 deletions.
5 changes: 0 additions & 5 deletions pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -76,11 +76,6 @@
<artifactId>reactive-streams</artifactId>
<version>1.0.3</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.testcontainers</groupId>
<artifactId>mongodb</artifactId>
Expand Down
44 changes: 26 additions & 18 deletions src/main/java/io/vertx/ext/mongo/impl/MongoClientImpl.java
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,8 @@
import io.vertx.codegen.annotations.Nullable;
import io.vertx.core.*;
import io.vertx.core.impl.ContextInternal;
import io.vertx.core.impl.future.PromiseInternal;
import io.vertx.core.impl.VertxInternal;
import io.vertx.core.impl.future.PromiseInternal;
import io.vertx.core.json.JsonArray;
import io.vertx.core.json.JsonObject;
import io.vertx.core.shareddata.LocalMap;
Expand All @@ -41,7 +41,6 @@
import io.vertx.ext.mongo.BulkWriteOptions;
import io.vertx.ext.mongo.CountOptions;
import io.vertx.ext.mongo.CreateCollectionOptions;
import io.vertx.ext.mongo.FindOptions;
import io.vertx.ext.mongo.IndexModel;
import io.vertx.ext.mongo.IndexOptions;
import io.vertx.ext.mongo.MongoClient;
Expand All @@ -55,11 +54,7 @@
import org.reactivestreams.Publisher;

import java.io.IOException;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.*;
import java.util.concurrent.TimeUnit;
import java.util.stream.Collectors;

Expand Down Expand Up @@ -264,9 +259,12 @@ public MongoClient updateCollectionWithOptions(String collection, JsonObject que
Bson bupdate = wrap(encodeKeyWhenUseObjectId(generateIdIfNeeded(query, update, options)));

com.mongodb.client.model.UpdateOptions updateOptions = new com.mongodb.client.model.UpdateOptions().upsert(options.isUpsert());
if (options.getArrayFilters() != null && !options.getArrayFilters().isEmpty()) {
final List<Bson> bArrayFilters = new ArrayList<>(options.getArrayFilters().size());
options.getArrayFilters().getList().forEach(entry -> bArrayFilters.add(wrap(JsonObject.mapFrom(entry))));
JsonArray arrayFilters = options.getArrayFilters();
if (arrayFilters != null && !arrayFilters.isEmpty()) {
List<Bson> bArrayFilters = new ArrayList<>(arrayFilters.size());
for (int i = 0; i < arrayFilters.size(); i++) {
bArrayFilters.add(wrap(arrayFilters.getJsonObject(i)));
}
updateOptions.arrayFilters(bArrayFilters);
}
if (options.getHint() != null) {
Expand Down Expand Up @@ -313,9 +311,12 @@ public MongoClient updateCollectionWithOptions(String collection, JsonObject que
}

com.mongodb.client.model.UpdateOptions updateOptions = new com.mongodb.client.model.UpdateOptions().upsert(options.isUpsert());
if (options.getArrayFilters() != null && !options.getArrayFilters().isEmpty()) {
final List<Bson> bArrayFilters = new ArrayList<>(options.getArrayFilters().size());
options.getArrayFilters().getList().forEach(entry -> bArrayFilters.add(wrap(JsonObject.mapFrom(entry))));
JsonArray arrayFilters = options.getArrayFilters();
if (arrayFilters != null && !arrayFilters.isEmpty()) {
List<Bson> bArrayFilters = new ArrayList<>(arrayFilters.size());
for (int i = 0; i < arrayFilters.size(); i++) {
bArrayFilters.add(wrap(arrayFilters.getJsonObject(i)));
}
updateOptions.arrayFilters(bArrayFilters);
}
if (options.getHint() != null) {
Expand Down Expand Up @@ -495,9 +496,12 @@ public MongoClient findOneAndUpdateWithOptions(String collection, JsonObject que
foauOptions.projection(wrap(findOptions.getFields()));
foauOptions.upsert(updateOptions.isUpsert());
foauOptions.returnDocument(updateOptions.isReturningNewDocument() ? ReturnDocument.AFTER : ReturnDocument.BEFORE);
if (updateOptions.getArrayFilters() != null && !updateOptions.getArrayFilters().isEmpty()) {
final List<Bson> bArrayFilters = new ArrayList<>(updateOptions.getArrayFilters().size());
updateOptions.getArrayFilters().getList().forEach(entry -> bArrayFilters.add(wrap(JsonObject.mapFrom(entry))));
JsonArray arrayFilters = updateOptions.getArrayFilters();
if (arrayFilters != null && !arrayFilters.isEmpty()) {
List<Bson> bArrayFilters = new ArrayList<>(arrayFilters.size());
for (int i = 0; i < arrayFilters.size(); i++) {
bArrayFilters.add(wrap(arrayFilters.getJsonObject(i)));
}
foauOptions.arrayFilters(bArrayFilters);
}
if (findOptions.getHint() != null) {
Expand Down Expand Up @@ -1142,7 +1146,9 @@ public ReadStream<ChangeStreamDocument<JsonObject>> watch(final String collectio
requireNonNull(pipeline, PIPELINE_CANNOT_BE_NULL);
MongoCollection<JsonObject> coll = getCollection(collection);
final List<Bson> bpipeline = new ArrayList<>(pipeline.size());
pipeline.getList().forEach(entry -> bpipeline.add(wrap(JsonObject.mapFrom(entry))));
for (int i = 0; i < pipeline.size(); i++) {
bpipeline.add(wrap(pipeline.getJsonObject(i)));
}
ChangeStreamPublisher<JsonObject> changeStreamPublisher = coll.watch(bpipeline, JsonObject.class);
if (withUpdatedDoc) {
// By default, only "insert" and "replace" operations return fullDocument
Expand Down Expand Up @@ -1175,7 +1181,9 @@ private AggregatePublisher<JsonObject> doAggregate(final String collection, fina
requireNonNull(aggregateOptions, "aggregateOptions cannot be null");
final MongoCollection<JsonObject> coll = getCollection(collection);
final List<Bson> bpipeline = new ArrayList<>(pipeline.size());
pipeline.getList().forEach(entry -> bpipeline.add(wrap(JsonObject.mapFrom(entry))));
for (int i = 0; i < pipeline.size(); i++) {
bpipeline.add(wrap(pipeline.getJsonObject(i)));
}
AggregatePublisher<JsonObject> aggregate = coll.aggregate(bpipeline, JsonObject.class);

if(aggregateOptions.getCollation() != null) {
Expand Down

0 comments on commit 1546a0f

Please sign in to comment.