mirror of
https://github.com/philomena-dev/philomena.git
synced 2025-01-19 22:27:59 +01:00
unsubscribe users from privileged topics when their role is updated, fixes #30
This commit is contained in:
parent
1ef368c286
commit
be520b1d7c
3 changed files with 36 additions and 5 deletions
|
@ -9,6 +9,8 @@ defmodule Philomena.Users do
|
|||
|
||||
alias Philomena.Users.Uploader
|
||||
alias Philomena.Users.User
|
||||
alias Philomena.{Forums, Forums.Forum}
|
||||
alias Philomena.Topics
|
||||
alias Philomena.Roles.Role
|
||||
|
||||
use Pow.Ecto.Context,
|
||||
|
@ -80,9 +82,16 @@ defmodule Philomena.Users do
|
|||
|> where([r], r.id in ^clean_roles(attrs["roles"]))
|
||||
|> Repo.all()
|
||||
|
||||
user
|
||||
|> User.update_changeset(attrs, roles)
|
||||
|> Repo.update()
|
||||
changeset =
|
||||
user
|
||||
|> User.update_changeset(attrs, roles)
|
||||
|
||||
Multi.new()
|
||||
|> Multi.update(:user, changeset)
|
||||
|> Multi.run(:unsubscribe, fn _repo, %{user: user} ->
|
||||
unsubscribe_restricted_actors(user)
|
||||
end)
|
||||
|> Repo.isolated_transaction(:serializable)
|
||||
end
|
||||
|
||||
defp clean_roles(nil), do: []
|
||||
|
@ -215,4 +224,26 @@ defmodule Philomena.Users do
|
|||
|
||||
%{user | role_map: role_map}
|
||||
end
|
||||
|
||||
defp unsubscribe_restricted_actors(%User{} = user) do
|
||||
forum_ids =
|
||||
Forum
|
||||
|> order_by(asc: :name)
|
||||
|> Repo.all()
|
||||
|> Enum.reject(&Canada.Can.can?(user, :show, &1))
|
||||
|> Enum.map(& &1.id)
|
||||
|
||||
{_count, nil} =
|
||||
Forums.Subscription
|
||||
|> where([s], s.user_id == ^user.id and s.forum_id in ^forum_ids)
|
||||
|> Repo.delete_all()
|
||||
|
||||
{_count, nil} =
|
||||
Topics.Subscription
|
||||
|> join(:inner, [s], _ in assoc(s, :topic))
|
||||
|> where([s, t], s.user_id == ^user.id and t.forum_id in ^forum_ids)
|
||||
|> Repo.delete_all()
|
||||
|
||||
{:ok, nil}
|
||||
end
|
||||
end
|
||||
|
|
|
@ -64,7 +64,7 @@ defmodule PhilomenaWeb.Admin.UserController do
|
|||
|> put_flash(:info, "User successfully updated.")
|
||||
|> redirect(to: Routes.admin_user_path(conn, :index))
|
||||
|
||||
{:error, changeset} ->
|
||||
{:error, %{user: changeset}} ->
|
||||
render(conn, "edit.html", changeset: changeset)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -64,7 +64,7 @@ defmodule Search.Evaluator do
|
|||
|> Enum.any?(&String.contains?(&1, query_val))
|
||||
end
|
||||
|
||||
def hits?(doc, %{nested: _}) do
|
||||
def hits?(_doc, %{nested: _}) do
|
||||
# No way to tell without a wildly expensive database query
|
||||
false
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue