]> git.openstreetmap.org Git - rails.git/blobdiff - app/controllers/api_controller.rb
Move the authorize method to api_controller
[rails.git] / app / controllers / api_controller.rb
index fb3717b2a981d99718e4a48b284ac2ac49175e25..cb3d71d490587f5641c27c0ca70ff528c42f0847 100644 (file)
@@ -1,3 +1,30 @@
 class ApiController < ApplicationController
   skip_before_action :verify_authenticity_token
+
+  def authorize(realm = "Web Password", errormessage = "Couldn't authenticate you")
+    # make the current_user object from any auth sources we have
+    setup_user_auth
+
+    # handle authenticate pass/fail
+    unless current_user
+      # no auth, the user does not exist or the password was wrong
+      response.headers["WWW-Authenticate"] = "Basic realm=\"#{realm}\""
+      render :plain => errormessage, :status => :unauthorized
+      return false
+    end
+  end
+
+  def deny_access(_exception)
+    if current_token
+      set_locale
+      report_error t("oauth.permissions.missing"), :forbidden
+    elsif current_user
+      head :forbidden
+    else
+      realm = "Web Password"
+      errormessage = "Couldn't authenticate you"
+      response.headers["WWW-Authenticate"] = "Basic realm=\"#{realm}\""
+      render :plain => errormessage, :status => :unauthorized
+    end
+  end
 end