1

I followed the example given in the docs but the following fails with Codec not found for requested operation: [varchar <-> java.util.UUID]. How is one supposed to provide a custom Cassandra codec with Quill?

import java.util.UUID
import javax.inject.Inject
import scala.concurrent.ExecutionContext.Implicits.global
import scala.concurrent.{Await, Future}
import io.getquill.{CassandraAsyncContext, LowerCase, MappedEncoding}
import scala.concurrent.duration._

object Main extends App {

  case class MyOrder(id: String, uuid: UUID)

  trait OrderRepository {
    implicit val encodeUUID: MappedEncoding[UUID, String] = MappedEncoding[UUID, String](_.toString)
    implicit val decodeUUID: MappedEncoding[String, UUID] = MappedEncoding[String, UUID](UUID.fromString)

    def list(): Future[Iterable[MyOrder]]
    def get(id: String): Future[Option[MyOrder]]
  }

  class OrderRepositoryImpl(db: CassandraAsyncContext[LowerCase]) extends OrderRepository {
    import db._

    override def list(): Future[Iterable[MyOrder]] = {
      run(quote(query[MyOrder]))
    }

    override def get(id: String): Future[Option[MyOrder]] = {
      val q = quote {
        (id: String) =>
          query[MyOrder].filter(_.id == id)
      }
      val res = run(q(lift(id.toString)))
      res.map(_.headOption)
    }
  }

  val db = new CassandraAsyncContext[LowerCase]("db")
  val repo = new OrderRepositoryImpl(db)
  val maybeOrder = Await.result(repo.get("id1"), 2 seconds)
  println(s"maybeOrder $maybeOrder")
}

and the Cassandra ddl:

CREATE TABLE myorder ( 
id text, 
uuid text, 
PRIMARY KEY (id)
);

INSERT INTO myorder (
id,
uuid
) values (
'id1',
'a8a8a416-2436-4e18-82b3-d5881c8fec1a'
);

Obviously I can just create a class whose uuid field is of type String but the goal here is to figure out how to use custom decoders.

Todor Kolev
  • 1,432
  • 1
  • 16
  • 33

0 Answers0