|
|
|
@ -9,8 +9,28 @@ defmodule LinkShortener.Links do
|
|
|
|
|
|
|
|
|
|
def new_one(), do: Link.changeset(%Link{}, %{})
|
|
|
|
|
|
|
|
|
|
def create_one(attrs, length \\ 10, generator \\ &LinkGenerator.generate_one/2) do
|
|
|
|
|
generator.(attrs, length)
|
|
|
|
|
@doc """
|
|
|
|
|
Create a Link with random shorten with the length.
|
|
|
|
|
|
|
|
|
|
## Options
|
|
|
|
|
• :is_atom_based (boolean, true by default) - if a map is
|
|
|
|
|
atom-based, then a key for shorten will be :shorten, else
|
|
|
|
|
"shorten".
|
|
|
|
|
• :length (integer, 10 by default) - the length for
|
|
|
|
|
the shorten.
|
|
|
|
|
• :generator (function) - the shorten is generated by the
|
|
|
|
|
generator function.
|
|
|
|
|
LinkShortener.Generators.LinkWithRandomShorten.generate_one/2 by
|
|
|
|
|
default.
|
|
|
|
|
"""
|
|
|
|
|
@spec create_one(map(), [is_atom_based: boolean(), length: integer(), generator: function()]) ::
|
|
|
|
|
[map()]
|
|
|
|
|
def create_one(attrs, opts \\ []) do
|
|
|
|
|
is_atom_based = Keyword.get(opts, :is_atom_based, true)
|
|
|
|
|
length = Keyword.get(opts, :length, 10)
|
|
|
|
|
generator = Keyword.get(opts, :generator, &LinkGenerator.generate_one/2)
|
|
|
|
|
|
|
|
|
|
generator.(attrs, is_atom_based: is_atom_based, length: length)
|
|
|
|
|
|> insert_one()
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|