diff options
Diffstat (limited to 'lib/mix')
| -rw-r--r-- | lib/mix/tasks/pleroma/database.ex | 28 | ||||
| -rw-r--r-- | lib/mix/tasks/pleroma/user.ex | 19 | 
2 files changed, 45 insertions, 2 deletions
| diff --git a/lib/mix/tasks/pleroma/database.ex b/lib/mix/tasks/pleroma/database.ex index ab9a3a7ff..f650b447d 100644 --- a/lib/mix/tasks/pleroma/database.ex +++ b/lib/mix/tasks/pleroma/database.ex @@ -4,6 +4,9 @@  defmodule Mix.Tasks.Pleroma.Database do    alias Mix.Tasks.Pleroma.Common +  alias Pleroma.Conversation +  alias Pleroma.Repo +  alias Pleroma.User    require Logger    use Mix.Task @@ -19,6 +22,14 @@ defmodule Mix.Tasks.Pleroma.Database do      Options:      - `--vacuum` - run `VACUUM FULL` after the embedded objects are replaced with their references + +  ## Create a conversation for all existing DMs. Can be safely re-run. + +      mix pleroma.database bump_all_conversations + +  ## Remove duplicated items from following and update followers count for all users + +      mix pleroma.database update_users_following_followers_counts    """    def run(["remove_embedded_objects" | args]) do      {options, [], []} = @@ -32,7 +43,7 @@ defmodule Mix.Tasks.Pleroma.Database do      Common.start_pleroma()      Logger.info("Removing embedded objects") -    Pleroma.Repo.query!( +    Repo.query!(        "update activities set data = jsonb_set(data, '{object}'::text[], data->'object'->'id') where data->'object'->>'id' is not null;",        [],        timeout: :infinity @@ -41,11 +52,24 @@ defmodule Mix.Tasks.Pleroma.Database do      if Keyword.get(options, :vacuum) do        Logger.info("Runnning VACUUM FULL") -      Pleroma.Repo.query!( +      Repo.query!(          "vacuum full;",          [],          timeout: :infinity        )      end    end + +  def run(["bump_all_conversations"]) do +    Common.start_pleroma() +    Conversation.bump_for_all_activities() +  end + +  def run(["update_users_following_followers_counts"]) do +    Common.start_pleroma() + +    users = Repo.all(User) +    Enum.each(users, &User.remove_duplicated_following/1) +    Enum.each(users, &User.update_follower_count/1) +  end  end diff --git a/lib/mix/tasks/pleroma/user.ex b/lib/mix/tasks/pleroma/user.ex index d130ff8c9..25fc40ea7 100644 --- a/lib/mix/tasks/pleroma/user.ex +++ b/lib/mix/tasks/pleroma/user.ex @@ -77,6 +77,10 @@ defmodule Mix.Tasks.Pleroma.User do    ## Delete tags from a user.        mix pleroma.user untag NICKNAME TAGS + +  ## Toggle confirmation of the user's account. + +      mix pleroma.user toggle_confirmed NICKNAME    """    def run(["new", nickname, email | rest]) do      {options, [], []} = @@ -388,6 +392,21 @@ defmodule Mix.Tasks.Pleroma.User do      end    end +  def run(["toggle_confirmed", nickname]) do +    Common.start_pleroma() + +    with %User{} = user <- User.get_cached_by_nickname(nickname) do +      {:ok, user} = User.toggle_confirmation(user) + +      message = if user.info.confirmation_pending, do: "needs", else: "doesn't need" + +      Mix.shell().info("#{nickname} #{message} confirmation.") +    else +      _ -> +        Mix.shell().error("No local user #{nickname}") +    end +  end +    defp set_moderator(user, value) do      info_cng = User.Info.admin_api_update(user.info, %{is_moderator: value}) | 
