ShortUUID is a lightweight Elixir library for generating short, unique IDs in URLs. It turns standard UUIDs into smaller strings ideal for use in URLs. You can choose from a set of predefined alphabets or define your own. The default alphabet includes lowercase letters, uppercase letters, and digits, omitting characters like 'l', '1', 'I', 'O', and '0' to keep them readable.
Note: Different ShortUUID implementations be compatible as long as they use the same alphabet. However, there is no official standard, so if you plan to use ShortUUID with other libraries, it's a good idea to research and test for compatibility.
Unlike some other solutions, ShortUUID does not produce UUIDs on its own as there are already plenty of libraries to do so. To generate UUIDs, use libraries such as Elixir UUID, Erlang UUID and also Ecto as it can generate version 4 UUIDs.
ShortUUID supports common UUID formats and is case-insensitive.
Raw binary UUID input (as <<...>>
) is no longer supported. UUIDs must be provided as strings in standard UUID format ("xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
) or as 32-character hex strings without hyphens.
Examples of supported formats:
# Supported
"550e8400-e29b-41d4-a716-446655440000" # With hyphens
"550e8400e29b41d4a716446655440000" # Without hyphens
# No longer supported in v4.0.0
<<85, 14, 132, 0, 226, 155, 65, 212, 167, 22, 68, 102, 85, 68, 0, 0>>
Changed bit order and padding behavior to align with other language implementations:
- Most significant bits are now encoded first
- Padding characters appear at the end of the string
- Compatible with Python's shortuuid v1.0.0+ and Node.js short-uuid
Before v3.0.0
iex> "00000001-0001-0001-0001-000000000001" |> ShortUUID.encode
{:ok, "UD6ibhr3V4YXvriP822222"}
After v3.0.0
iex> "00000001-0001-0001-0001-000000000001" |> ShortUUID.encode
{:ok, "222228PirvXY4V3rhbi6DU"}
To migrate ShortUUIDs created using < v3.0.0
reverse them before passing to decode
.
# UUID "00000001-0001-0001-0001-000000000001" encoded using v2.1.2 to "UD6ibhr3V4YXvriP822222"
# reversing the encoded string before decode with v3.0.0 will produce the correct result
iex> "UD6ibhr3V4YXvriP822222" |> String.reverse() |> ShortUUID.decode!()
"00000001-0001-0001-0001-000000000001"
Warning: Decoding ShortUUIDs created using a version < v3.0.0
without reversing the string first will not fail but produce an incorrect result
iex> "UD6ibhr3V4YXvriP822222" |> ShortUUID.decode!() === "00000001-0001-0001-0001-000000000001"
false
iex> "UD6ibhr3V4YXvriP822222" |> ShortUUID.decode()
{:ok, "933997ef-eb92-293f-b202-2a879fc84be9"}
Add :shortuuid
to your list of dependencies in mix.exs
:
def deps do
[
{:shortuuid, "~> 4.0"}
]
end
iex> "f98e80e7-9923-4173-8408-98f8254912ad" |> ShortUUID.encode
{:ok, "nQtAWSRQ6ByybDtRs7dQwE"}
iex> "f98e80e7-9923-4173-8408-98f8254912ad" |> ShortUUID.encode!
"nQtAWSRQ6ByybDtRs7dQwE"
iex> "nQtAWSRQ6ByybDtRs7dQwE" |> ShortUUID.decode
{:ok, "f98e80e7-9923-4173-8408-98f8254912ad"}
iex> "nQtAWSRQ6ByybDtRs7dQwE" |> ShortUUID.decode!
"f98e80e7-9923-4173-8408-98f8254912ad"
If you would like to use ShortUUID with Ecto schemas try Ecto.ShortUUID.
It provides a custom Ecto type which allows for ShortUUID primary and foreign keys while staying compatible with :binary_key
(EctoUUID
).
Starting with version v4.0.0
, ShortUUID allows you to define custom alphabets for encoding and decoding UUIDs. You can use predefined alphabets or define your own.
- The alphabet must contain at least 16 unique characters.
- The alphabet must not contain duplicate characters.
Starting with version v4.0.0
, the following predefined alphabets are available:
:base57_shortuuid
- "23456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz":base32
- "ABCDEFGHIJKLMNOPQRSTUVWXYZ234567":base32_crockford
- "0123456789ABCDEFGHJKMNPQRSTVWXYZ":base32_hex
- "0123456789ABCDEFGHIJKLMNOPQRSTUV":base32_z
- "ybndrfg8ejkmcpqxot1uwisza345h769":base58
- "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz":base62
- "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz":base64
- "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/":base64_url
- "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_"
defmodule MyBase58UUID do
use ShortUUID.Builder, alphabet: :base58
end
defmodule MyCustomUUID do
use ShortUUID.Builder, alphabet: "0123456789ABCDEF"
end
iex> MyBase58UUID.encode("550e8400-e29b-41d4-a716-446655440000")
{:ok, "BWBeN28Vb7cMEx7Ym8AUzs"}
iex> MyBase58UUID.decode("BWBeN28Vb7cMEx7Ym8AUzs")
{:ok, "550e8400-e29b-41d4-a716-446655440000"}
Since v4.0.0 alphabets are not limited to alphanumeric characters either
defmodule UnicodeUUID do
use ShortUUID.Builder, alphabet: "๐๐ซโจโญ๏ธ๐๐๐๐๐๐๐๐๐๐๐๐"
end
iex> UnicodeUUID.encode("550e8400-e29b-41d4-a716-446655440000")
{:ok, "๐๐๐๐๐๐๐๐๐โจ๐๐๐๐ซ๐๐๐๐๐ซ๐๐๐๐๐๐๐๐๐๐๐๐๐"}
defmodule SmileyUUID do
use ShortUUID.Builder, alphabet: "๐๐๐๐๐ฅฐ๐๐๐คช๐๐ค๐๐ง๐๐๐ถ๐ฎ๐ฒ๐ฑ๐ด๐ฅฑ๐ช๐ข๐ญ๐ค๐๐ค๐๐๐ป๐ฝ๐ค๐คก๐"
end
iex> SmileyUUID.encode("550e8400-e29b-41d4-a716-446655440000")
{:ok, "๐๐คช๐ข๐๐๐ฅฐ๐ฒ๐๐คก๐ค๐ค๐๐๐ค๐ฝ๐ค๐ป๐๐ฝ๐ฒ๐๐๐ญ๐๐ฒ๐ค"}
Look up the full documentation at https://hexdocs.pm/shortuuid.
Inspired by shortuuid.
Copyright (c) 2024 Goran Pediฤ
This work is free. You can redistribute it and/or modify it under the terms of the MIT License.
See the LICENSE.md file for more details.