1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.Workers.Cron.HashtagsCleanupWorker do
7 The worker to clean up unused hashtags_objects and hashtags.
10 use Oban.Worker, queue: "hashtags_cleanup"
16 @hashtags_objects_query """
17 DELETE FROM hashtags_objects WHERE object_id IN
18 (SELECT DISTINCT objects.id FROM objects
19 JOIN hashtags_objects ON hashtags_objects.object_id = objects.id LEFT JOIN activities
20 ON COALESCE(activities.data->'object'->>'id', activities.data->>'object') =
22 AND activities.data->>'type' = 'Create'
23 WHERE activities.id IS NULL);
27 DELETE FROM hashtags WHERE id IN
28 (SELECT hashtags.id FROM hashtags
29 LEFT OUTER JOIN hashtags_objects
30 ON hashtags_objects.hashtag_id = hashtags.id
31 WHERE hashtags_objects.hashtag_id IS NULL AND hashtags.inserted_at < $1);
36 Logger.info("Cleaning up unused `hashtags_objects` records...")
38 {:ok, %{num_rows: hashtags_objects_count}} =
39 Repo.query(@hashtags_objects_query, [], timeout: :infinity)
41 Logger.info("Deleted #{hashtags_objects_count} unused `hashtags_objects` records.")
43 Logger.info("Cleaning up unused `hashtags` records...")
45 # Note: ignoring recently created hashtags since references are added after hashtag is created
46 {:ok, %{num_rows: hashtags_count}} =
47 Repo.query(@hashtags_query, [NaiveDateTime.add(NaiveDateTime.utc_now(), -3600 * 24)],
51 Logger.info("Deleted #{hashtags_count} unused `hashtags` records.")
53 Logger.info("HashtagsCleanupWorker complete.")