Explorar el Código

authorize-follow-requests-after-unlocking (#4658)

master
masarakki hace 6 años
committed by Eugen Rochko
padre
commit
649a20ab46
Se han modificado 4 ficheros con 37 adiciones y 2 borrados
  1. +1
    -1
      app/controllers/api/v1/accounts/credentials_controller.rb
  2. +1
    -1
      app/controllers/settings/profiles_controller.rb
  3. +21
    -0
      app/services/update_account_service.rb
  4. +14
    -0
      app/workers/authorize_follow_worker.rb

+ 1
- 1
app/controllers/api/v1/accounts/credentials_controller.rb Ver fichero

@@ -12,7 +12,7 @@ class Api::V1::Accounts::CredentialsController < Api::BaseController

def update
@account = current_account
@account.update!(account_params)
UpdateAccountService.new.call(@account, account_params, raise_error: true)
ActivityPub::UpdateDistributionWorker.perform_async(@account.id)
render json: @account, serializer: REST::CredentialAccountSerializer
end


+ 1
- 1
app/controllers/settings/profiles_controller.rb Ver fichero

@@ -14,7 +14,7 @@ class Settings::ProfilesController < ApplicationController
def show; end

def update
if @account.update(account_params)
if UpdateAccountService.new.call(@account, account_params)
ActivityPub::UpdateDistributionWorker.perform_async(@account.id)
redirect_to settings_profile_path, notice: I18n.t('generic.changes_saved_msg')
else


+ 21
- 0
app/services/update_account_service.rb Ver fichero

@@ -0,0 +1,21 @@
# frozen_string_literal: true

class UpdateAccountService < BaseService
def call(account, params, raise_error: false)
was_locked = account.locked
update_method = raise_error ? :update! : :update
account.send(update_method, params).tap do |ret|
next unless ret
authorize_all_follow_requests(account) if was_locked && !account.locked
end
end

private

def authorize_all_follow_requests(account)
follow_requests = FollowRequest.where(target_account: account)
AuthorizeFollowWorker.push_bulk(follow_requests) do |req|
[req.account_id, req.target_account_id]
end
end
end

+ 14
- 0
app/workers/authorize_follow_worker.rb Ver fichero

@@ -0,0 +1,14 @@
# frozen_string_literal: true

class AuthorizeFollowWorker
include Sidekiq::Worker

def perform(source_account_id, target_account_id)
source_account = Account.find(source_account_id)
target_account = Account.find(target_account_id)

AuthorizeFollowService.new.call(source_account, target_account)
rescue ActiveRecord::RecordNotFound
true
end
end

Cargando…
Cancelar
Guardar