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

net.pincette.mongo.streams.Delete Maven / Gradle / Ivy

package net.pincette.mongo.streams;

import static net.pincette.json.JsonUtil.isObject;
import static net.pincette.json.JsonUtil.string;
import static net.pincette.mongo.BsonUtil.fromJson;
import static net.pincette.mongo.Collection.deleteMany;
import static net.pincette.mongo.streams.Pipeline.DELETE;
import static net.pincette.mongo.streams.Util.matchFields;
import static net.pincette.mongo.streams.Util.matchQuery;
import static net.pincette.mongo.streams.Util.tryForever;
import static net.pincette.rs.Box.box;
import static net.pincette.rs.Filter.filter;
import static net.pincette.rs.Mapper.map;
import static net.pincette.util.Util.must;

import com.mongodb.client.result.DeleteResult;
import com.mongodb.reactivestreams.client.MongoCollection;
import java.util.Set;
import java.util.concurrent.Flow.Processor;
import javax.json.JsonObject;
import javax.json.JsonValue;
import net.pincette.rs.streams.Message;
import org.bson.Document;

/**
 * The $delete operator.
 *
 * @author Werner Donné
 */
class Delete {
  private static final String FROM = "from";

  private Delete() {}

  static Processor, Message> stage(
      final JsonValue expression, final Context context) {
    must(isObject(expression));

    final JsonObject expr = expression.asJsonObject();
    final MongoCollection collection =
        context.database.getCollection(expr.getString(FROM));
    final Set fields = matchFields(expr, null);

    assert !fields.isEmpty();

    return box(
        map(
            m ->
                m.withValue(
                    matchQuery(m.value, fields)
                        .map(
                            query ->
                                tryForever(
                                    () ->
                                        deleteMany(collection, fromJson(query))
                                            .thenApply(
                                                result ->
                                                    must(result, DeleteResult::wasAcknowledged)),
                                    DELETE,
                                    () -> "Collection " + collection + ", delete: " + string(query),
                                    context))
                        .map(result -> m.value)
                        .orElse(null))),
        filter(m -> m.value != null));
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy