# frozen_string_literal: true
namespace :mastodon do
task make_admin : :environment do
include RoutingHelper
user = Account . find_local ( ENV . fetch ( 'USERNAME' ) ) . user
user . update ( admin : true )
puts " Congrats! #{ user . account . username } is now an admin. \\ o/ \n Navigate to #{ admin_settings_url } to get started "
end
namespace :media do
desc 'Removes media attachments that have not been assigned to any status for longer than a day'
task clear : :environment do
MediaAttachment . where ( status_id : nil ) . where ( 'created_at < ?' , 1 . day . ago ) . find_each ( & :destroy )
end
desc 'Remove media attachments attributed to silenced accounts'
task remove_silenced : :environment do
MediaAttachment . where ( account : Account . silenced ) . find_each ( & :destroy )
end
end
namespace :push do
desc 'Unsubscribes from PuSH updates of feeds nobody follows locally'
task clear : :environment do
Account . remote . without_followers . where . not ( subscription_expires_at : nil ) . find_each do | a |
Rails . logger . debug " PuSH unsubscribing from #{ a . acct } "
UnsubscribeService . new . call ( a )
end
end
desc 'Re-subscribes to soon expiring PuSH subscriptions'
task refresh : :environment do
Account . expiring ( 1 . day . from_now ) . find_each do | a |
Rails . logger . debug " PuSH re-subscribing to #{ a . acct } "
SubscribeService . new . call ( a )
end
end
end
namespace :feeds do
desc 'Clear timelines of inactive users'
task clear : :environment do
User . confirmed . where ( 'current_sign_in_at < ?' , 14 . days . ago ) . find_each do | user |
Redis . current . del ( FeedManager . instance . key ( :home , user . account_id ) )
end
end
desc 'Clears all timelines so that they would be regenerated on next hit'
task clear_all : :environment do
Redis . current . keys ( 'feed:*' ) . each { | key | Redis . current . del ( key ) }
end
end
namespace :emails do
desc 'Send out digest e-mails'
task digest : :environment do
User . confirmed . joins ( :account ) . where ( accounts : { silenced : false , suspended : false } ) . where ( 'current_sign_in_at < ?' , 20 . days . ago ) . find_each do | user |
DigestMailerWorker . perform_async ( user . id )
end
end
end
namespace :maintenance do
desc 'Update counter caches'
task update_counter_caches : :environment do
Rails . logger . debug 'Updating counter caches for accounts...'
Account . unscoped . select ( 'id' ) . find_in_batches do | batch |
Account . where ( id : batch . map ( & :id ) ) . update_all ( 'statuses_count = (select count(*) from statuses where account_id = accounts.id), followers_count = (select count(*) from follows where target_account_id = accounts.id), following_count = (select count(*) from follows where account_id = accounts.id)' )
end
Rails . logger . debug 'Updating counter caches for statuses...'
Status . unscoped . select ( 'id' ) . find_in_batches do | batch |
Status . where ( id : batch . map ( & :id ) ) . update_all ( 'favourites_count = (select count(*) from favourites where favourites.status_id = statuses.id), reblogs_count = (select count(*) from statuses as reblogs where reblogs.reblog_of_id = statuses.id)' )
end
Rails . logger . debug 'Done!'
end
end
end