philomena/lib/philomena/static_pages.ex
byte[] 4dcb2958d3 Squashed commit of the following:
commit 8ea9cff4af46e24c38020652cedeff72957354fb
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 01:29:24 2020 -0400

    remove remaining serializable aside hiding related

commit 99ccf06264db6319ece2a896a104031447447a5f
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 01:20:40 2020 -0400

    interactions: remove serializable

commit a63bef06a6962368f69cf83afbc3c44f2467618c
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 01:16:27 2020 -0400

    users: remove serializable

commit 8053229f6fab507c29a40f0e22dd9cab7971e34f
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 01:11:14 2020 -0400

    user_links: remove serializable

commit 9b058add825b0a876a91a1cf2b1b22dc34066e42
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 01:09:33 2020 -0400

    topics: remove serializable

commit cd9ea908c34f72c0120fca1c4d581540db60db98
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 01:05:23 2020 -0400

    tags: remove serializable

commit c7563fef8fc905c32a0727a4b104222227a6bafa
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 01:02:22 2020 -0400

    static_pages: remove serializable

commit 3da661bdd1aec74e4ac5b69ec21124bc1ebc6fb4
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 01:00:15 2020 -0400

    posts: remove serializable

commit 18a50a4e5bed1ab6e4e6c13c3051a21ae7e8fbb0
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 00:55:55 2020 -0400

    poll_votes: remove serializable

commit 7d946ef23d7b27877d4bf0fb6a4db4ae64a9ffab
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 00:51:49 2020 -0400

    galleries: remove serializable

commit d8c35a0934e5394b092b050e071abdada4bdb640
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 00:42:43 2020 -0400

    conversations: remove serializable

commit 079e6dca6c8064867f2c0f90f351ea83c0f12b75
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 00:38:28 2020 -0400

    comments: remove serializable

commit 00ae38bad566fb6badeccceac2e394e65ec9428e
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 00:37:15 2020 -0400

    commissions: remove serializable

commit b3c4a4b13671ca73c58080b090dd6165552c87d6
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 00:17:12 2020 -0400

    bans: remove serializable

commit 8be9fe913ff1f6264b899e96ee38fa52032b8bda
Author: byte[] <byteslice@airmail.cc>
Date:   Sun Sep 6 00:02:44 2020 -0400

    badges: remove serializable

commit 162adda185f705b9749774c4af8c7d8db0d89790
Author: byte[] <byteslice@airmail.cc>
Date:   Sat Sep 5 23:56:51 2020 -0400

    adverts: remove serializable
2020-09-06 01:30:53 -04:00

122 lines
2.5 KiB
Elixir

defmodule Philomena.StaticPages do
@moduledoc """
The StaticPages context.
"""
import Ecto.Query, warn: false
alias Ecto.Multi
alias Philomena.Repo
alias Philomena.StaticPages.StaticPage
alias Philomena.StaticPages.Version
@doc """
Returns the list of static_pages.
## Examples
iex> list_static_pages()
[%StaticPage{}, ...]
"""
def list_static_pages do
Repo.all(StaticPage)
end
@doc """
Gets a single static_page.
Raises `Ecto.NoResultsError` if the Static page does not exist.
## Examples
iex> get_static_page!(123)
%StaticPage{}
iex> get_static_page!(456)
** (Ecto.NoResultsError)
"""
def get_static_page!(id), do: Repo.get!(StaticPage, id)
@doc """
Creates a static_page.
## Examples
iex> create_static_page(%{field: value})
{:ok, %StaticPage{}}
iex> create_static_page(%{field: bad_value})
{:error, %Ecto.Changeset{}}
"""
def create_static_page(user, attrs \\ %{}) do
static_page = StaticPage.changeset(%StaticPage{}, attrs)
Multi.new()
|> Multi.insert(:static_page, static_page)
|> Multi.run(:version, fn repo, %{static_page: static_page} ->
%Version{static_page_id: static_page.id, user_id: user.id}
|> Version.changeset(attrs)
|> repo.insert()
end)
|> Repo.transaction()
end
@doc """
Updates a static_page.
## Examples
iex> update_static_page(static_page, %{field: new_value})
{:ok, %StaticPage{}}
iex> update_static_page(static_page, %{field: bad_value})
{:error, %Ecto.Changeset{}}
"""
def update_static_page(%StaticPage{} = static_page, user, attrs) do
version =
%Version{static_page_id: static_page.id, user_id: user.id}
|> Version.changeset(attrs)
static_page =
static_page
|> StaticPage.changeset(attrs)
Multi.new()
|> Multi.update(:static_page, static_page)
|> Multi.insert(:version, version)
|> Repo.transaction()
end
@doc """
Deletes a StaticPage.
## Examples
iex> delete_static_page(static_page)
{:ok, %StaticPage{}}
iex> delete_static_page(static_page)
{:error, %Ecto.Changeset{}}
"""
def delete_static_page(%StaticPage{} = static_page) do
Repo.delete(static_page)
end
@doc """
Returns an `%Ecto.Changeset{}` for tracking static_page changes.
## Examples
iex> change_static_page(static_page)
%Ecto.Changeset{source: %StaticPage{}}
"""
def change_static_page(%StaticPage{} = static_page) do
StaticPage.changeset(static_page, %{})
end
end