This is an Akka Streams extension for the ReactiveMongo cursors.
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)
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
The developer guide is available online.
The API documentation is available online.