philomena/lib/philomena/adverts.ex
2019-08-28 12:34:37 -04:00

104 lines
1.7 KiB
Elixir

defmodule Philomena.Adverts do
@moduledoc """
The Adverts context.
"""
import Ecto.Query, warn: false
alias Philomena.Repo
alias Philomena.Adverts.Advert
@doc """
Returns the list of adverts.
## Examples
iex> list_adverts()
[%Advert{}, ...]
"""
def list_adverts do
Repo.all(Advert)
end
@doc """
Gets a single advert.
Raises `Ecto.NoResultsError` if the Advert does not exist.
## Examples
iex> get_advert!(123)
%Advert{}
iex> get_advert!(456)
** (Ecto.NoResultsError)
"""
def get_advert!(id), do: Repo.get!(Advert, id)
@doc """
Creates a advert.
## Examples
iex> create_advert(%{field: value})
{:ok, %Advert{}}
iex> create_advert(%{field: bad_value})
{:error, %Ecto.Changeset{}}
"""
def create_advert(attrs \\ %{}) do
%Advert{}
|> Advert.changeset(attrs)
|> Repo.insert()
end
@doc """
Updates a advert.
## Examples
iex> update_advert(advert, %{field: new_value})
{:ok, %Advert{}}
iex> update_advert(advert, %{field: bad_value})
{:error, %Ecto.Changeset{}}
"""
def update_advert(%Advert{} = advert, attrs) do
advert
|> Advert.changeset(attrs)
|> Repo.update()
end
@doc """
Deletes a Advert.
## Examples
iex> delete_advert(advert)
{:ok, %Advert{}}
iex> delete_advert(advert)
{:error, %Ecto.Changeset{}}
"""
def delete_advert(%Advert{} = advert) do
Repo.delete(advert)
end
@doc """
Returns an `%Ecto.Changeset{}` for tracking advert changes.
## Examples
iex> change_advert(advert)
%Ecto.Changeset{source: %Advert{}}
"""
def change_advert(%Advert{} = advert) do
Advert.changeset(advert, %{})
end
end