mirror of
https://github.com/philomena-dev/philomena.git
synced 2025-01-06 00:08:00 +01:00
49 lines
1.6 KiB
Elixir
49 lines
1.6 KiB
Elixir
defmodule PhilomenaWeb.Api.Json.PostController do
|
|
use PhilomenaWeb, :controller
|
|
|
|
alias PhilomenaWeb.PostJson
|
|
alias Philomena.Posts.Post
|
|
alias Philomena.Repo
|
|
import Ecto.Query
|
|
|
|
def show(conn, %{"forum_id" => forum_id, "topic_id" => topic_id, "id" => post_id}) do
|
|
post =
|
|
Post
|
|
|> join(:inner, [p], _ in assoc(p, :topic))
|
|
|> join(:inner, [_p, t], _ in assoc(t, :forum))
|
|
|> where(id: ^post_id)
|
|
|> where(destroyed_content: false)
|
|
|> where([_p, t], t.hidden_from_users == false and t.slug == ^topic_id)
|
|
|> where([_p, _t, f], f.access_level == "normal" and f.short_name == ^forum_id)
|
|
|> preload([:user, :topic])
|
|
|> Repo.one()
|
|
|
|
cond do
|
|
is_nil(post) ->
|
|
conn
|
|
|> put_status(:not_found)
|
|
|> text("")
|
|
|
|
true ->
|
|
json(conn, %{post: PostJson.as_json(post)})
|
|
end
|
|
end
|
|
|
|
def index(conn, %{"forum_id" => forum_id, "topic_id" => topic_id}) do
|
|
page = conn.assigns.pagination.page_number
|
|
posts =
|
|
Post
|
|
|> join(:inner, [p], _ in assoc(p, :topic))
|
|
|> join(:inner, [_p, t], _ in assoc(t, :forum))
|
|
|> where(destroyed_content: false)
|
|
|> where([_p, t], t.hidden_from_users == false and t.slug == ^topic_id)
|
|
|> where([_p, _t, f], f.access_level == "normal" and f.short_name == ^forum_id)
|
|
|> where([p], p.topic_position >= ^(25 * (page - 1)) and p.topic_position < ^(25 * page))
|
|
|> order_by(asc: :topic_position)
|
|
|> preload([:user, :topic])
|
|
|> preload([_p, t, _f], topic: t)
|
|
|> Repo.all()
|
|
|
|
json(conn, %{posts: Enum.map(posts, &PostJson.as_json/1), page: page, total: hd(posts).topic.post_count})
|
|
end
|
|
end
|