Improve member adding and excluding flow
Allow to exclude a member Send emails to the member when it's excluded Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
@@ -4,14 +4,15 @@ defmodule Mobilizon.Storage.Ecto do
|
||||
"""
|
||||
|
||||
import Ecto.Query, warn: false
|
||||
import Ecto.Changeset, only: [fetch_change: 2, put_change: 3]
|
||||
import Ecto.Changeset, only: [fetch_change: 2, put_change: 3, get_field: 2]
|
||||
alias Ecto.{Changeset, Query}
|
||||
alias Mobilizon.Web.Endpoint
|
||||
alias Mobilizon.Web.Router.Helpers, as: Routes
|
||||
|
||||
@doc """
|
||||
Adds sort to the query.
|
||||
"""
|
||||
@spec sort(Ecto.Query.t(), atom, atom) :: Ecto.Query.t()
|
||||
@spec sort(Query.t(), atom, atom) :: Query.t()
|
||||
def sort(query, sort, direction) do
|
||||
from(query, order_by: [{^direction, ^sort}])
|
||||
end
|
||||
@@ -22,8 +23,8 @@ defmodule Mobilizon.Storage.Ecto do
|
||||
If there's a blank URL that's because we're doing the first insert.
|
||||
Most of the time just go with the given URL.
|
||||
"""
|
||||
@spec ensure_url(Ecto.Changeset.t(), atom()) :: Ecto.Changeset.t()
|
||||
def ensure_url(%Ecto.Changeset{data: %{url: nil}} = changeset, route) do
|
||||
@spec ensure_url(Changeset.t(), atom()) :: Changeset.t()
|
||||
def ensure_url(%Changeset{data: %{url: nil}} = changeset, route) do
|
||||
case fetch_change(changeset, :url) do
|
||||
{:ok, _url} ->
|
||||
changeset
|
||||
@@ -33,10 +34,10 @@ defmodule Mobilizon.Storage.Ecto do
|
||||
end
|
||||
end
|
||||
|
||||
def ensure_url(%Ecto.Changeset{} = changeset, _route), do: changeset
|
||||
def ensure_url(%Changeset{} = changeset, _route), do: changeset
|
||||
|
||||
@spec generate_url(Ecto.Changeset.t(), atom()) :: Ecto.Changeset.t()
|
||||
defp generate_url(%Ecto.Changeset{} = changeset, route) do
|
||||
@spec generate_url(Changeset.t(), atom()) :: Changeset.t()
|
||||
defp generate_url(%Changeset{} = changeset, route) do
|
||||
uuid = Ecto.UUID.generate()
|
||||
|
||||
changeset
|
||||
@@ -46,4 +47,13 @@ defmodule Mobilizon.Storage.Ecto do
|
||||
apply(Routes, String.to_existing_atom("page_url"), [Endpoint, route, uuid])
|
||||
)
|
||||
end
|
||||
|
||||
@spec maybe_add_published_at(Changeset.t()) :: Changeset.t()
|
||||
def maybe_add_published_at(%Changeset{} = changeset) do
|
||||
if is_nil(get_field(changeset, :published_at)) do
|
||||
put_change(changeset, :published_at, DateTime.utc_now() |> DateTime.truncate(:second))
|
||||
else
|
||||
changeset
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user