diff options
author | lain <lain@soykaf.club> | 2018-02-21 18:34:19 +0100 |
---|---|---|
committer | lain <lain@soykaf.club> | 2018-02-21 18:34:19 +0100 |
commit | 94db9ac4dba6ba02fcae1b9055b532818cf787c7 (patch) | |
tree | 0b6189c60adbca5e0ea6b9aded01dccfbbc35755 /lib | |
parent | a06b9a3e0b5639dfc3a975c7a5f3ea11a05a286f (diff) | |
parent | e98aeabbdebee8f6c9a10d0c9e3f48c1031172cb (diff) | |
download | pleroma-94db9ac4dba6ba02fcae1b9055b532818cf787c7.tar.gz |
Merge branch 'develop' into feature/activitypub
Diffstat (limited to 'lib')
-rw-r--r-- | lib/mix/tasks/generate_password_reset.ex | 19 | ||||
-rw-r--r-- | lib/mix/tasks/make_moderator.ex | 27 | ||||
-rw-r--r-- | lib/pleroma/web/common_api/common_api.ex | 2 | ||||
-rw-r--r-- | lib/pleroma/web/twitter_api/views/user_view.ex | 4 |
4 files changed, 50 insertions, 2 deletions
diff --git a/lib/mix/tasks/generate_password_reset.ex b/lib/mix/tasks/generate_password_reset.ex new file mode 100644 index 000000000..b968b1f98 --- /dev/null +++ b/lib/mix/tasks/generate_password_reset.ex @@ -0,0 +1,19 @@ +defmodule Mix.Tasks.GeneratePasswordReset do + use Mix.Task + import Mix.Ecto + alias Pleroma.{Repo, User} + + @shortdoc "Generate password reset link for user" + def run([nickname]) do + Mix.Task.run("app.start") + + with %User{local: true} = user <- User.get_by_nickname(nickname), + {:ok, token} <- Pleroma.PasswordResetToken.create_token(user) do + IO.puts "Generated password reset token for #{user.nickname}" + IO.puts "Url: #{Pleroma.Web.Router.Helpers.util_url(Pleroma.Web.Endpoint, :show_password_reset, token.token)}" + else + _ -> + IO.puts "No local user #{nickname}" + end + end +end diff --git a/lib/mix/tasks/make_moderator.ex b/lib/mix/tasks/make_moderator.ex new file mode 100644 index 000000000..a76b54f40 --- /dev/null +++ b/lib/mix/tasks/make_moderator.ex @@ -0,0 +1,27 @@ +defmodule Mix.Tasks.SetModerator do + use Mix.Task + import Mix.Ecto + alias Pleroma.{Repo, User} + + @shortdoc "Set moderator status" + def run([nickname | rest]) do + ensure_started(Repo, []) + + moderator = case rest do + [moderator] -> moderator == "true" + _ -> true + end + + with %User{local: true} = user <- User.get_by_nickname(nickname) do + info = user.info + |> Map.put("is_moderator", !!moderator) + cng = User.info_changeset(user, %{info: info}) + user = Repo.update!(cng) + + IO.puts "Moderator status of #{nickname}: #{user.info["is_moderator"]}" + else + _ -> + IO.puts "No local user #{nickname}" + end + end +end diff --git a/lib/pleroma/web/common_api/common_api.ex b/lib/pleroma/web/common_api/common_api.ex index c6657b8e8..5bd6e136f 100644 --- a/lib/pleroma/web/common_api/common_api.ex +++ b/lib/pleroma/web/common_api/common_api.ex @@ -8,7 +8,7 @@ defmodule Pleroma.Web.CommonAPI do def delete(activity_id, user) do with %Activity{data: %{"object" => %{"id" => object_id}}} <- Repo.get(Activity, activity_id), %Object{} = object <- Object.get_by_ap_id(object_id), - true <- user.ap_id == object.data["actor"], + true <- user.info["is_moderator"] || (user.ap_id == object.data["actor"]), {:ok, delete} <- ActivityPub.delete(object) do {:ok, delete} end diff --git a/lib/pleroma/web/twitter_api/views/user_view.ex b/lib/pleroma/web/twitter_api/views/user_view.ex index f49bcc0fb..6fb07f052 100644 --- a/lib/pleroma/web/twitter_api/views/user_view.ex +++ b/lib/pleroma/web/twitter_api/views/user_view.ex @@ -41,7 +41,9 @@ defmodule Pleroma.Web.TwitterAPI.UserView do "profile_image_url_https" => image, "profile_image_url_profile_size" => image, "profile_image_url_original" => image, - "rights" => %{}, + "rights" => %{ + "delete_others_notice" => !!user.info["is_moderator"] + }, "screen_name" => user.nickname, "statuses_count" => user_info[:note_count], "statusnet_profile_url" => user.ap_id, |