akka-stream - Como tratar o último elemento de um fluxo de maneira diferente em um Flow / Graph
Estou tentando implementar um Akka StreamsFlow
que converterá um fluxo de objetos JSON em um fluxo de uma única matriz de objetos JSON. Eu posso usarConcat
para adicionar um "[" antes e "]" depois, bem comoZip
para inserir vírgulas entre os elementos, mas não consigo descobrir como não inserir a vírgula final.
O código que tenho até agora é:
trait JsonStreamSupport {
protected def toJsonArrayString[T : Writes] = Flow[T].map(Json.toJson(_)).map(_.toString()).via(jsonArrayWrapper)
private[this] val jsonArrayWrapper: Flow[String, String, NotUsed] = Flow.fromGraph(GraphDSL.create() { implicit b =>
import GraphDSL.Implicits._
val start = Source.single("[")
val comma = Source.repeat(",")
val end = Source.single("]")
val concat = b.add(Concat[String](3))
val zip = b.add(Zip[String,String])
comma ~> zip.in1
start ~> concat.in(0)
zip.out.map({case (msg,delim) => msg + delim}) ~> concat.in(1)
end ~> concat.in(2)
FlowShape(zip.in0, concat.out)
})
}
Atualmente, a saída é:[{"key":"value},{"key","value"},]
mas eu preciso que seja[{"key":"value},{"key","value"}]
(sem vírgula final),
onde cada elemento da matriz ainda é um elemento distinto do fluxo, portanto, pode ser, por exemplo, enviado por HTTP em pedaços separadamente.