1
0
mirror of https://github.com/mgerb/classic-wow-forums synced 2026-01-09 16:42:49 +00:00

update thread reply

This commit is contained in:
2018-01-04 21:06:23 -06:00
parent 148bde8f99
commit f540e7351b
7 changed files with 73 additions and 20 deletions

View File

@@ -1,6 +1,5 @@
defmodule MyApp.Data.Reply do
use Ecto.Schema
import Ecto.Query
import Ecto.Changeset
alias MyApp.Repo
alias MyApp.Data
@@ -15,18 +14,47 @@ defmodule MyApp.Data.Reply do
timestamps()
end
def changeset(reply, params \\ %{}) do
defp insert_changeset(reply, params \\ %{}) do
reply
|> cast(params, [:user_id, :thread_id, :content, :edited, :quote])
|> cast(params, [:user_id, :thread_id, :content, :quote])
|> validate_required([:user_id, :thread_id, :content])
|> foreign_key_constraint(:user_id)
|> foreign_key_constraint(:thread_id)
end
# allow user to update reply
defp user_update_changeset(reply, params \\ %{}) do
reply
|> cast(params, [:content])
|> force_change(:edited, true) # set edited flag on update
|> validate_required([:content])
end
@spec insert_reply(map) :: {:ok, map} | {:error, map}
def insert_reply(params) do
changeset(%Data.Reply{}, params)
insert_changeset(%Data.Reply{}, params)
|> Repo.insert
|> Data.Util.process_insert_or_update
end
@spec user_update_reply(map) :: {:ok, map} | {:error, map}
def user_update_reply(params) do
id = Map.get(params, "id")
user_id = Map.get(params, "user_id")
if is_nil(id) || is_nil(user_id) do
{:error, "Invalid reply"}
else
Repo.get_by(Data.Reply, %{id: id, user_id: user_id})
|> process_user_update(params)
end
end
defp process_user_update(reply, _params) when is_nil(reply), do: {:error, "Invalid reply"}
defp process_user_update(reply, params) when not is_nil(reply) do
user_update_changeset(reply, params)
|> Repo.update
|> Data.Util.process_insert_or_update
end
end

View File

@@ -18,7 +18,7 @@ defmodule MyApp.Data.Thread do
timestamps()
end
def insert_changeset(thread, params \\ %{}) do
defp insert_changeset(thread, params \\ %{}) do
thread
|> cast(params, [:title, :category_id, :content, :user_id])
|> validate_required([:title, :category_id, :content, :user_id])
@@ -26,13 +26,18 @@ defmodule MyApp.Data.Thread do
|> foreign_key_constraint(:user_id)
end
def update_changeset(thread, params \\ %{}) do
# TODO: allow mods to set sticky/locked on threads
defp mod_update_changeset(thread, params \\ %{}) do
thread
|> cast(params, [:content, :user_id, :sticky, :locked])
|> cast(params, [:sticky, :locked])
end
# allow user to update content of their own thread
defp user_update_changeset(thread, params \\ %{}) do
thread
|> cast(params, [:content])
|> force_change(:edited, true) # set edited flag on update
|> validate_required([:content, :user_id])
|> foreign_key_constraint(:category_id)
|> foreign_key_constraint(:user_id)
|> validate_required([:content])
end
def insert_thread(params) do
@@ -41,22 +46,24 @@ defmodule MyApp.Data.Thread do
|> Data.Util.process_insert_or_update
end
def update_thread(params) do
@spec user_update_thread(map) :: {:ok, map} | {:error, map}
def user_update_thread(params) do
id = Map.get(params, "id")
if id == nil do
user_id = Map.get(params, "user_id")
if is_nil(id) || is_nil(user_id) do
{:error, "Invalid thread"}
else
Repo.get(Data.Thread, id)
|> process_update(params)
Repo.get_by(Data.Thread, %{id: id, user_id: user_id})
|> process_user_update(params)
end
end
# TODO: delete thread
# TODO: check user permissions for sticky/locked
defp process_update(thread, _params) when is_nil(thread), do: {:error, "Invalid thread"}
defp process_update(thread, params) when not is_nil(thread) do
update_changeset(thread, params)
defp process_user_update(thread, _params) when is_nil(thread), do: {:error, "Invalid thread"}
defp process_user_update(thread, params) when not is_nil(thread) do
user_update_changeset(thread, params)
|> Repo.update
|> Data.Util.process_insert_or_update
end

View File

@@ -10,7 +10,6 @@ defmodule MyApp.Data.User do
field :battle_net_id, :integer
field :battletag, :string
field :permissions, :string, default: "user" # admin, mod, user
timestamps()
end

View File

@@ -1,11 +1,13 @@
defmodule MyApp.Data.Util do
@spec map_changeset(map) :: map
def map_changeset(changeset) do
Enum.map(changeset.errors, fn {key, val} ->
%{key => elem(val, 0)}
end)
end
@spec process_insert_or_update({atom, map}) :: {:ok, map} | {:error, map}
def process_insert_or_update({:error, changeset}), do: {:error, map_changeset(changeset)}
def process_insert_or_update({:ok, data}), do: {:ok, data}

View File

@@ -18,5 +18,21 @@ defmodule MyAppWeb.ReplyController do
|> put_status(status)
|> Response.json(output)
end
@spec update(map, map) :: any
def update(conn, params) do
user_id = conn
|> MyApp.Guardian.Plug.current_claims
|> Map.get("id")
{output, status} = params
|> Map.put("user_id", user_id)
|> Data.Reply.user_update_reply
|> Response.put_resp
conn
|> put_status(status)
|> Response.json(output)
end
end

View File

@@ -27,7 +27,7 @@ defmodule MyAppWeb.ThreadController do
{output, status} = params
|> Map.put("user_id", user_id)
|> Data.Thread.update_thread
|> Data.Thread.user_update_thread
|> Response.put_resp
conn

View File

@@ -46,6 +46,7 @@ defmodule MyAppWeb.Router do
# authenticated routes
pipe_through [:user_auth]
post "/", ReplyController, :insert
put "/", ReplyController, :update
end
scope "/category" do