mirror of
https://github.com/mgerb/classic-wow-forums
synced 2026-01-11 17:42:48 +00:00
update thread reply
This commit is contained in:
@@ -1,6 +1,5 @@
|
|||||||
defmodule MyApp.Data.Reply do
|
defmodule MyApp.Data.Reply do
|
||||||
use Ecto.Schema
|
use Ecto.Schema
|
||||||
import Ecto.Query
|
|
||||||
import Ecto.Changeset
|
import Ecto.Changeset
|
||||||
alias MyApp.Repo
|
alias MyApp.Repo
|
||||||
alias MyApp.Data
|
alias MyApp.Data
|
||||||
@@ -15,18 +14,47 @@ defmodule MyApp.Data.Reply do
|
|||||||
timestamps()
|
timestamps()
|
||||||
end
|
end
|
||||||
|
|
||||||
def changeset(reply, params \\ %{}) do
|
defp insert_changeset(reply, params \\ %{}) do
|
||||||
reply
|
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])
|
|> validate_required([:user_id, :thread_id, :content])
|
||||||
|> foreign_key_constraint(:user_id)
|
|> foreign_key_constraint(:user_id)
|
||||||
|> foreign_key_constraint(:thread_id)
|
|> foreign_key_constraint(:thread_id)
|
||||||
end
|
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
|
def insert_reply(params) do
|
||||||
changeset(%Data.Reply{}, params)
|
insert_changeset(%Data.Reply{}, params)
|
||||||
|> Repo.insert
|
|> Repo.insert
|
||||||
|> Data.Util.process_insert_or_update
|
|> Data.Util.process_insert_or_update
|
||||||
end
|
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
|
end
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ defmodule MyApp.Data.Thread do
|
|||||||
timestamps()
|
timestamps()
|
||||||
end
|
end
|
||||||
|
|
||||||
def insert_changeset(thread, params \\ %{}) do
|
defp insert_changeset(thread, params \\ %{}) do
|
||||||
thread
|
thread
|
||||||
|> cast(params, [:title, :category_id, :content, :user_id])
|
|> cast(params, [:title, :category_id, :content, :user_id])
|
||||||
|> validate_required([: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)
|
|> foreign_key_constraint(:user_id)
|
||||||
end
|
end
|
||||||
|
|
||||||
def update_changeset(thread, params \\ %{}) do
|
# TODO: allow mods to set sticky/locked on threads
|
||||||
|
defp mod_update_changeset(thread, params \\ %{}) do
|
||||||
thread
|
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
|
|> force_change(:edited, true) # set edited flag on update
|
||||||
|> validate_required([:content, :user_id])
|
|> validate_required([:content])
|
||||||
|> foreign_key_constraint(:category_id)
|
|
||||||
|> foreign_key_constraint(:user_id)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def insert_thread(params) do
|
def insert_thread(params) do
|
||||||
@@ -41,22 +46,24 @@ defmodule MyApp.Data.Thread do
|
|||||||
|> Data.Util.process_insert_or_update
|
|> Data.Util.process_insert_or_update
|
||||||
end
|
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")
|
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"}
|
{:error, "Invalid thread"}
|
||||||
else
|
else
|
||||||
Repo.get(Data.Thread, id)
|
Repo.get_by(Data.Thread, %{id: id, user_id: user_id})
|
||||||
|> process_update(params)
|
|> process_user_update(params)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# TODO: delete thread
|
# TODO: delete thread
|
||||||
|
|
||||||
# TODO: check user permissions for sticky/locked
|
defp process_user_update(thread, _params) when is_nil(thread), do: {:error, "Invalid thread"}
|
||||||
defp process_update(thread, _params) when is_nil(thread), do: {:error, "Invalid thread"}
|
defp process_user_update(thread, params) when not is_nil(thread) do
|
||||||
defp process_update(thread, params) when not is_nil(thread) do
|
user_update_changeset(thread, params)
|
||||||
update_changeset(thread, params)
|
|
||||||
|> Repo.update
|
|> Repo.update
|
||||||
|> Data.Util.process_insert_or_update
|
|> Data.Util.process_insert_or_update
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -10,7 +10,6 @@ defmodule MyApp.Data.User do
|
|||||||
field :battle_net_id, :integer
|
field :battle_net_id, :integer
|
||||||
field :battletag, :string
|
field :battletag, :string
|
||||||
field :permissions, :string, default: "user" # admin, mod, user
|
field :permissions, :string, default: "user" # admin, mod, user
|
||||||
|
|
||||||
timestamps()
|
timestamps()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -1,11 +1,13 @@
|
|||||||
defmodule MyApp.Data.Util do
|
defmodule MyApp.Data.Util do
|
||||||
|
|
||||||
|
@spec map_changeset(map) :: map
|
||||||
def map_changeset(changeset) do
|
def map_changeset(changeset) do
|
||||||
Enum.map(changeset.errors, fn {key, val} ->
|
Enum.map(changeset.errors, fn {key, val} ->
|
||||||
%{key => elem(val, 0)}
|
%{key => elem(val, 0)}
|
||||||
end)
|
end)
|
||||||
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({:error, changeset}), do: {:error, map_changeset(changeset)}
|
||||||
def process_insert_or_update({:ok, data}), do: {:ok, data}
|
def process_insert_or_update({:ok, data}), do: {:ok, data}
|
||||||
|
|
||||||
|
|||||||
@@ -18,5 +18,21 @@ defmodule MyAppWeb.ReplyController do
|
|||||||
|> put_status(status)
|
|> put_status(status)
|
||||||
|> Response.json(output)
|
|> Response.json(output)
|
||||||
end
|
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
|
end
|
||||||
|
|||||||
@@ -27,7 +27,7 @@ defmodule MyAppWeb.ThreadController do
|
|||||||
|
|
||||||
{output, status} = params
|
{output, status} = params
|
||||||
|> Map.put("user_id", user_id)
|
|> Map.put("user_id", user_id)
|
||||||
|> Data.Thread.update_thread
|
|> Data.Thread.user_update_thread
|
||||||
|> Response.put_resp
|
|> Response.put_resp
|
||||||
|
|
||||||
conn
|
conn
|
||||||
|
|||||||
@@ -46,6 +46,7 @@ defmodule MyAppWeb.Router do
|
|||||||
# authenticated routes
|
# authenticated routes
|
||||||
pipe_through [:user_auth]
|
pipe_through [:user_auth]
|
||||||
post "/", ReplyController, :insert
|
post "/", ReplyController, :insert
|
||||||
|
put "/", ReplyController, :update
|
||||||
end
|
end
|
||||||
|
|
||||||
scope "/category" do
|
scope "/category" do
|
||||||
|
|||||||
Reference in New Issue
Block a user