Skip to content

Latest commit

 

History

History
60 lines (38 loc) · 1.99 KB

File metadata and controls

60 lines (38 loc) · 1.99 KB

Akka Streams for ReactiveMongo

This is an Akka Streams extension for the ReactiveMongo cursors.

Usage

In your project/Build.scala:

resolvers += "Sonatype Snapshots" at "https://oss.sonatype.org/content/repositories/snapshots/"

libraryDependencies ++= Seq(
  "org.reactivemongo" %% "rectivemongo" % VERSION,
  "org.reactivemongo" %% "reactivemongo-akkastream" % VERSION)

Maven Javadocs

Java 1.8+ is required.

Then in your code:

import scala.concurrent.Future

import reactivemongo.api.bson.{ BSONDocument, BSONDocumentReader }
import reactivemongo.api.bson.collection.BSONCollection

// Reactive streams imports
import org.reactivestreams.Publisher
import akka.stream.scaladsl.Source

// ReactiveMongo extensions
import reactivemongo.akkastream.{ AkkaStreamCursor, cursorProducer, State }

implicit def materializer: akka.stream.Materializer = ???

val ageReader = BSONDocumentReader.field[Int]("age")

def foo(collection: BSONCollection): (Source[Int, Future[State]], Publisher[Int]) = {
  implicit def reader: BSONDocumentReader[Int] = ageReader

  val cursor: AkkaStreamCursor[Int] =
    collection.find(BSONDocument.empty/* findAll */).
    sort(BSONDocument("id" -> 1)).cursor[Int]()

  val src: Source[Int, Future[State]] = cursor.documentSource()
  val pub: Publisher[Int] = cursor.documentPublisher()

  src -> pub
}

More examples

Documentation

The developer guide is available online.

The API documentation is available online.