lib/faker/uuid.ex

defmodule Faker.UUID do
  @moduledoc """
  Functions for generating UUID's.
  """

  @uuid_v4 4

  @variant10 2

  @doc """
  Generate a random v4 UUID.

  ## Examples

      iex> Faker.UUID.v4()
      "d6d98b88-c866-4496-9bd4-de7ba48d0f52"
      iex> Faker.UUID.v4()
      "29fa7bf9-0728-4272-a7bc-5b7c964f332d"
      iex> Faker.UUID.v4()
      "c9edd02c-c9f3-41de-b9d9-22a146bf8550"
      iex> Faker.UUID.v4()
      "8a5f03ff-1875-4bf3-a3f4-aef1264e3bcc"
  """
  @spec v4() :: String.t()
  def v4 do
    <<u0::48, _::4, u1::12, _::2, u2::62>> = Faker.random_bytes(16)

    <<u0::48, @uuid_v4::4, u1::12, @variant10::2, u2::62>>
    |> uuid_to_string()
  end

  defp uuid_to_string(<<u0::32, u1::16, u2::16, u3::16, u4::48>>) do
    [
      Base.encode16(<<u0::32>>, case: :lower),
      ?-,
      Base.encode16(<<u1::16>>, case: :lower),
      ?-,
      Base.encode16(<<u2::16>>, case: :lower),
      ?-,
      Base.encode16(<<u3::16>>, case: :lower),
      ?-,
      Base.encode16(<<u4::48>>, case: :lower)
    ]
    |> IO.iodata_to_binary()
  end
end