Browse Source

Fix #2, add rake task for PuSH-unsubscribing from remote users who have no

local followers. Remote users' usernames SHOULD be case-sensitive
closed-social-glitch-2
Eugen Rochko 8 years ago
parent
commit
323474c97e
3 changed files with 22 additions and 3 deletions
  1. +7
    -2
      app/controllers/api/accounts_controller.rb
  2. +2
    -1
      app/models/account.rb
  3. +13
    -0
      lib/tasks/subscriptions.rake

+ 7
- 2
app/controllers/api/accounts_controller.rb View File

@ -19,12 +19,17 @@ class Api::AccountsController < ApiController
end
def follow
@follow = current_user.account.follow!(@account)
if @account.local?
@follow = current_user.account.follow!(@account)
else
@follow = FollowService.new.(current_user.account, @account.acct)
end
render action: :show
end
def unfollow
@unfollow = current_user.account.unfollow!(@account)
@unfollow = UnfollowService.new.(current_user.account, @account)
render action: :show
end

+ 2
- 1
app/models/account.rb View File

@ -1,7 +1,8 @@
class Account < ActiveRecord::Base
# Local users
has_one :user, inverse_of: :account
validates :username, uniqueness: { scope: :domain, case_sensitive: false }
validates :username, uniqueness: { scope: :domain, case_sensitive: false }, if: 'local?'
validates :username, uniqueness: { scope: :domain, case_sensitive: true }, unless: 'local?'
# Avatar upload
attr_reader :avatar_remote_url

+ 13
- 0
lib/tasks/subscriptions.rake View File

@ -0,0 +1,13 @@
namespace :subscriptions do
desc "For all remote accounts that have no local followers, unsubscribe from PuSH"
task clear: :environment do
accounts = Account.where('(select count(f.id) from follows as f where f.target_account_id = accounts.id) = 0').where.not(domain: nil)
accounts.each do |a|
a.subscription(api_subscription_url(a.id)).unsubscribe
a.update!(verify_token: '', secret: '')
end
end
end

Loading…
Cancel
Save