Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jclem/base62_uuid_field
An Ecto type for Base62-encoded binary UUIDs
https://github.com/jclem/base62_uuid_field
Last synced: about 1 month ago
JSON representation
An Ecto type for Base62-encoded binary UUIDs
- Host: GitHub
- URL: https://github.com/jclem/base62_uuid_field
- Owner: jclem
- License: mit
- Created: 2018-12-13T16:36:36.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2022-02-16T19:07:25.000Z (over 2 years ago)
- Last Synced: 2024-10-11T22:19:06.522Z (about 1 month ago)
- Language: Elixir
- Homepage: https://hex.pm/packages/base62_uuid_field
- Size: 25.4 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Base62UUIDField [![Coverage Status](https://coveralls.io/repos/github/jclem/base62_uuid_field/badge.svg?branch=master&bump=1)](https://coveralls.io/github/jclem/base62_uuid_field?branch=master)
An [Ecto.Type](https://hexdocs.pm/ecto/Ecto.Type.html) for Base62-encoded UUIDs.
## Installation
If [available in Hex](https://hex.pm/docs/publish), the package can be installed
by adding `base62_uuid_field` to your list of dependencies in `mix.exs`:```elixir
def deps do
[
{:base62_uuid_field, "~> 1.0.0"}
]
end
```## Usage
This Ecto type builds on top of the existing `Ecto.UUID` type, except that it ensures that the types at runtime are represented as [Base62-encoded UUIDs](https://github.com/jclem/base62_uuid).
For example, given an `identity_users` table with a `:binary_id` primary key:
```elixir
create table(:identity_users, primary_key: false) do
add :id, :binary_id, primary_key: true
end
```We can have Base62-encoded primary keys at runtime instead of much longer and less URL-friendly hexadecimal-encoded UUIDs.
```elixir
defmodule App.Identity.User do
use Ecto.Schema@primary_key {:id, Base62UUIDField, autogenerate: true}
# ...etc.
end
``````elixir
iex> %App.Identity.User{} |> App.Identity.User.changeset(%{}) |> App.Repo.insert!()
%App.Identity.User{
__meta__: #Ecto.Schema.Metadata<:loaded, "identity_users">,
id: "6UupZ56JriyqxwjYXR9Aiz",
inserted_at: ~N[2018-12-13 18:22:57],
updated_at: ~N[2018-12-13 18:22:57]
}
```