diff options
author | ThibG <thib@sitedethib.com> | 2018-06-24 15:27:51 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-06-24 15:27:51 +0200 |
commit | c18d55e8c25d47a81f99f5ea018d58eecb206a79 (patch) | |
tree | fe8d33304593499d6c9f87e59a23a51d4d45f9b0 /app/controllers/remote_unfollows_controller.rb | |
parent | f364a27922b19efb312959a562a7541cf9d89e97 (diff) | |
parent | 4b0f27ba7822befed76f8368b472c6ade6977cb2 (diff) |
Merge pull request #553 from ThibG/glitch-soc/merge-upstream
Merge upstream changes
Diffstat (limited to 'app/controllers/remote_unfollows_controller.rb')
-rw-r--r-- | app/controllers/remote_unfollows_controller.rb | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/app/controllers/remote_unfollows_controller.rb b/app/controllers/remote_unfollows_controller.rb new file mode 100644 index 000000000..af5943363 --- /dev/null +++ b/app/controllers/remote_unfollows_controller.rb @@ -0,0 +1,39 @@ +# frozen_string_literal: true + +class RemoteUnfollowsController < ApplicationController + layout 'modal' + + before_action :authenticate_user! + before_action :set_body_classes + + def create + @account = unfollow_attempt.try(:target_account) + + if @account.nil? + render :error + else + render :success + end + rescue ActiveRecord::RecordNotFound, Mastodon::NotPermittedError + render :error + end + + private + + def unfollow_attempt + username, domain = acct_without_prefix.split('@') + UnfollowService.new.call(current_account, Account.find_remote!(username, domain)) + end + + def acct_without_prefix + acct_params.gsub(/\Aacct:/, '') + end + + def acct_params + params.fetch(:acct, '') + end + + def set_body_classes + @body_classes = 'modal-layout' + end +end |