Custom types do not use load/dump when embedded.
Then may use dump if they define embed_as to return :dump, but there is no way to use load or any other mechanism then cast when loading data.
- Is there a good reason for this design? The asymmetry in dumping / loading is a bit odd to me.
Moreover the fact that cast has to be called when loading from the DB can be quite inconvenient. While returning :error when casting user data (e.g. from a form) is very useful, if I have invalid data stored in my DB then returning :error result in a raised exception, which is blocking. Moreover, thereās no way to know within cast if Iām loading from the DB or casting user data.
- Documentation for
loadis very misleading, e.g.
There are two situations where this callback is called:
- When casting values by Ecto.Changeset
- When passing arguments to Ecto.Query
Clearly, this is incomplete and there is an extra situation ā3. When loading data in an embedded schemaā.
I can propose a PR but would appreciate to know if thereās every a plan to support custom loading for embedded types.
Thank you






















