Flint - Drop-In Utilities / Enhancement for Ecto Schemas

New v0.3.0 pushed to Hex. Main addition is the new Flint.Type module that makes writing custom Ecto types a breeze!

Video Demo: x.com

Flint.Type

Flint.Type is meant to make writing new Ecto types require much less boilerplate, because you can base your
type off of an existing type and only modify the callbacks that have different behavior.

Simply use Flint.Type and pass the :extends option which says which type module to inherit callbacks
from. This will delegate all required callbacks and any implemented optional callbacks and make them
overridable.

It also lets you make a type from an Ecto.ParameterizedType with default parameter values.
You may supply any number of default parameters. This essentially provides a new
init/1 implementation for the type, supplying the default values, while not affecting any of the
other Ecto.ParameterizedType callbacks. You may still override the newly set defaults at the local level.

Just supply all options that you wish to be defaults as extra options when using Flint.Type.

You may override any of the inherited callbacks inherity from the extended module
in the case that you wish to customize the module further.

Examples

defmodule Category do
  use Flint.Type, extends: Ecto.Enum, values: [:folder, :file]
end

This will apply default values to Ecto.Enum when you supply a Category type
to an Ecto schema. You may still override the values if you supply the :values
option for the field.

import Flint.Type
deftype NewUID, extends: Ecto.UUID, dump: &String.length/1

This will create a new NewUID type that behaves exactly like an Ecto.UUID except it dumps
its string length.

3 Likes

v0.4 available now on Hex.

Big refactor adding Flint.Extension module. Now most of the features are packaged as extensions, making it easier to enable or disable features per schema.

Extensions also allows you to register new options to the field macro in Flint.Schema.

Extension Docs: Flint.Extension — Flint v0.4.2

Demos:
x.com - v0.4 release demo
x.com - Demo with Instructor pt. 1
x.com - Demo with Instructor pt. 2

1 Like