philomena/lib/philomena_web/controllers/activity_controller.ex

139 lines
3.6 KiB
Elixir
Raw Normal View History

2019-10-04 18:48:00 +02:00
defmodule PhilomenaWeb.ActivityController do
use PhilomenaWeb, :controller
2019-11-17 03:20:33 +01:00
alias Philomena.{Images.Image, ImageFeatures.ImageFeature, Comments.Comment, Channels.Channel, Topics.Topic, Forums.Forum}
alias Philomena.Interactions
alias Philomena.Images
2019-10-04 18:48:00 +02:00
alias Philomena.Repo
import Ecto.Query
def index(conn, _params) do
user = conn.assigns.current_user
filter = conn.assigns.compiled_filter
{:ok, image_query} = Images.Query.compile(user, "created_at.lte:3 minutes ago")
images =
Image.search_records(
%{
query: %{
bool: %{
2019-11-17 03:20:33 +01:00
must: image_query,
must_not: [
filter,
%{term: %{hidden_from_users: true}}
],
2019-10-04 18:48:00 +02:00
}
},
sort: %{created_at: :desc}
},
2019-10-09 01:19:57 +02:00
%{page_number: 1, page_size: 25},
2019-10-04 18:48:00 +02:00
Image |> preload([:tags])
)
top_scoring =
Image.search_records(
%{
query: %{
bool: %{
2019-11-17 03:20:33 +01:00
must: %{range: %{first_seen_at: %{gt: "now-3d"}}},
must_not: [
filter,
%{term: %{hidden_from_users: true}}
]
2019-10-04 18:48:00 +02:00
}
},
sort: [%{score: :desc}, %{first_seen_at: :desc}]
},
2019-10-09 01:19:57 +02:00
%{page_number: :rand.uniform(6), page_size: 4},
2019-10-04 18:48:00 +02:00
Image |> preload([:tags])
)
comments =
Comment.search_records(
%{
query: %{
bool: %{
must: %{
range: %{posted_at: %{gt: "now-1w"}}
},
must_not: [
%{terms: %{image_tag_ids: conn.assigns.current_filter.hidden_tag_ids}},
%{term: %{hidden_from_users: true}}
]
}
},
sort: %{posted_at: :desc}
},
2019-10-09 01:19:57 +02:00
%{page_number: 1, page_size: 6},
2019-10-11 03:48:44 +02:00
Comment |> preload([:user, image: [:tags]])
)
2019-10-05 00:52:44 +02:00
watched = if !!user do
{:ok, watched_query} = Images.Query.compile(user, "my:watched")
2019-10-04 18:48:00 +02:00
Image.search_records(
%{
query: %{
bool: %{
2019-11-17 03:20:33 +01:00
must: watched_query,
must_not: [
filter,
%{term: %{hidden_from_users: true}}
]
2019-10-04 18:48:00 +02:00
}
},
sort: %{created_at: :desc}
},
2019-10-09 01:19:57 +02:00
%{page_number: 1, page_size: 25},
2019-10-04 18:48:00 +02:00
Image |> preload([:tags])
)
end
featured_image =
Image
2019-11-17 03:20:33 +01:00
|> join(:inner, [i], f in ImageFeature, on: [image_id: i.id])
2019-10-04 18:48:00 +02:00
|> order_by([i, f], desc: f.created_at)
|> limit(1)
2019-10-11 03:47:13 +02:00
|> preload([:tags])
2019-10-04 18:48:00 +02:00
|> Repo.one()
2019-10-05 00:52:44 +02:00
streams =
Channel
|> where([c], c.nsfw == false)
|> where([c], not is_nil(c.last_fetched_at))
|> order_by(desc: :is_live, asc: :title)
|> limit(6)
|> Repo.all()
2019-10-04 18:48:00 +02:00
topics =
Topic
2019-10-05 00:52:44 +02:00
|> join(:inner, [t], f in Forum, on: [id: t.forum_id])
2019-10-04 18:48:00 +02:00
|> where([t, _f], t.hidden_from_users == false)
2019-10-05 00:56:51 +02:00
|> where([t, _f], fragment("? !~ ?", t.title, "NSFW"))
2019-10-04 18:48:00 +02:00
|> where([_t, f], f.access_level == "normal")
|> order_by(desc: :last_replied_to_at)
|> preload([:forum, last_post: :user])
|> limit(6)
2019-10-05 00:52:44 +02:00
|> Repo.all()
2019-10-04 18:48:00 +02:00
2019-11-17 03:20:33 +01:00
interactions =
Interactions.user_interactions(
[images, top_scoring, watched, featured_image],
user
)
2019-10-04 18:48:00 +02:00
render(
conn,
"index.html",
images: images,
comments: comments,
2019-10-04 18:48:00 +02:00
top_scoring: top_scoring,
watched: watched,
featured_image: featured_image,
2019-10-05 00:52:44 +02:00
streams: streams,
2019-11-17 03:20:33 +01:00
topics: topics,
interactions: interactions
2019-10-04 18:48:00 +02:00
)
end
end