about summary refs log tree commit diff
path: root/app/controllers/remote_unfollows_controller.rb
diff options
context:
space:
mode:
authorThibG <thib@sitedethib.com>2018-06-24 15:27:51 +0200
committerGitHub <noreply@github.com>2018-06-24 15:27:51 +0200
commitc18d55e8c25d47a81f99f5ea018d58eecb206a79 (patch)
treefe8d33304593499d6c9f87e59a23a51d4d45f9b0 /app/controllers/remote_unfollows_controller.rb
parentf364a27922b19efb312959a562a7541cf9d89e97 (diff)
parent4b0f27ba7822befed76f8368b472c6ade6977cb2 (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.rb39
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