longevity

A Persistence Framework for Scala and NoSQL

View project on GitHub

limitations on persistents, components, and key values

Longevity currently places the following limitations on the kinds of classes you can use for your persistents, components, and key values:

  • They must be a case class or a case object.
  • They must not be an inner class.
  • Case class primary constructors must have a single parameter list.

We would like to relax these limitations in the future. If you find these limitations to be too cumbersome for you, please let us know what you are trying to do, and we will see what we can to do help. Just keep in mind that, whatever possibilities we allow for, longevity has the following requirements:

  • The list of properties that a persistent, components, or key value contains must be clearly defined.
  • We must be able to retrieve a property value from a persistent, component, or key value.
  • We must be able to construct a new persistent, component, or key value from a complete set of property values.

Case classes are quite convenient things for fulfilling the requirements we have. They also seem a natural choice for modeling out a domain. We chose to start with them for these reasons.

Update: It seems like we can achieve these requirements by asking users to provide apply and unapply methods for anything that is not a case class. This would also allow for bringing external classes (i.e., classes the user is not able to extend with an empty trait) into the domain model. You can track this on the story board.

prev: key values
up: the domain model
next: constructing a domain model