кодировщики / декодеры scala circe для абстрактного класса с классами case

Я хочу сохранить коллекцию классов FieldMapping в виде строки json -

abstract class Field {
  def clazz: Class[_]

  def name: String
}

case class StringField(name: String) extends Field {
  override def clazz: Class[_] = classOf[String]
}

case class DateField(name: String) extends Field {
  override def clazz: Class[_] = classOf[Date]
}

... и т. д. - полный код здесь: https://github.com/alexeyOnGitHub/scala-typesafe/blob/master/src/main/scala/com/example/model/Field.scala

Код Цирцеи:

import com.example.model.{DateField, Field, FieldMapping, StringField}
import io.circe.generic.semiauto.{deriveDecoder, deriveEncoder}
import io.circe.{Decoder, Encoder}

object CirceBoilerplateForConfigs {
  implicit val fieldDecoder: Decoder[StringField] = deriveDecoder[StringField]
  implicit val fieldEncoder: Encoder[StringField] = deriveEncoder[StringField]

  implicit val dateDecoder: Decoder[DateField] = deriveDecoder[DateField]
  implicit val dateEncoder: Encoder[DateField] = deriveEncoder[DateField]

  implicit val fooDecoder: Decoder[FieldMapping] = deriveDecoder[FieldMapping]
  implicit val fooEncoder: Encoder[FieldMapping] = deriveEncoder[FieldMapping]
}

Ошибка: (14, 65) не удалось найти неявное значение типа io.circe.generic.decoding.DerivedDecoder [com.example.model.FieldMapping] неявное значение val fooDecoder: Decoder [FieldMapping] = deriveDecoder [FieldMapping] Ошибка: (14 , 65)

недостаточно аргументов для метода deriveDecoder: (неявное декодирование: shapeless.Lazy [io.circe.generic.decoding.DerivedDecoder [com.example.model.FieldMapping]]) io.circe.Decoder [com.example.model.FieldMapping]. Неопределенное значение параметра декодирования. неявный val fooDecoder: Decoder [FieldMapping] = deriveDecoder [FieldMapping] Ошибка: (15, 65)

не удалось найти Ленивое неявное значение типа io.circe.generic.encoding.DerivedObjectEncoder [com.example.model.FieldMapping] implicit val fooEncoder: Encoder [FieldMapping] = deriveEncoder [FieldMapping] Ошибка: (15, 65)

недостаточно аргументов для метода deriveEncoder: (неявное кодирование: shapeless.Lazy [io.circe.generic.encoding.DerivedObjectEncoder [com.example.model.FieldMapping]]) io.circe.ObjectEncoder [com.example.model.FieldMapping]. Кодирование параметра с неопределенным значением. неявный val fooEncoder: Encoder [FieldMapping] = deriveEncoder [FieldMapping]


person Alex    schedule 12.05.2018    source источник
comment
В своей сути вы не указали код для GUser.   -  person Dmytro Mitin    schedule 12.05.2018
comment
FieldMapping тоже не определен.   -  person Dmytro Mitin    schedule 12.05.2018
comment
Если я закомментирую case class GUserField, def user, import com.example.model..., implicit val fooDecoder, implicit val fooEncoder, все компилируется.   -  person Dmytro Mitin    schedule 12.05.2018
comment
вот остальная часть кода - github.com/alexeyOnGitHub/scala-typesafe/tree/master/src/main/ Мне нужны кодировщики / декодеры для коллекций FieldMapping, потому что это то, что я хочу преобразовать в строку json   -  person Alex    schedule 13.05.2018


Ответы (1)


Field должен быть запечатанным признаком (с абстрактным классом или незапечатанным признаком это не сработает).

Компилируется следующий код:

import java.util.Date

sealed trait Field {
  def clazz: Class[_]

  def name: String
}

case class StringField(name: String) extends Field {
  override def clazz: Class[_] = classOf[String]
}

case class DateField(name: String) extends Field {
  override def clazz: Class[_] = classOf[Date]
}

case class FieldMapping(fieldInConnector1: Option[Field],
                        fieldInConnector2: Option[Field],
                        selected: Boolean,
                        defaultValue: String)

import io.circe.generic.semiauto.{deriveDecoder, deriveEncoder}
import io.circe.{Decoder, Encoder}
object CirceBoilerplateForConfigs {
  implicit val stringDecoder: Decoder[StringField] = deriveDecoder[StringField]
  implicit val stringEncoder: Encoder[StringField] = deriveEncoder[StringField]

  implicit val dateDecoder: Decoder[DateField] = deriveDecoder[DateField]
  implicit val dateEncoder: Encoder[DateField] = deriveEncoder[DateField]

  implicit val fieldDecoder: Decoder[Field] = deriveDecoder[Field]
  implicit val fieldEncoder: Encoder[Field] = deriveEncoder[Field]

  implicit val fooDecoder: Decoder[FieldMapping] = deriveDecoder[FieldMapping]
  implicit val fooEncoder: Encoder[FieldMapping] = deriveEncoder[FieldMapping]
}
person Dmytro Mitin    schedule 13.05.2018