]> git.openstreetmap.org Git - rails.git/blobdiff - app/controllers/api_controller.rb
Mark all methods in api_controller and application_controller as private
[rails.git] / app / controllers / api_controller.rb
index 8ddb7242fe5ee3a78d5188dfec62b6204eb5a653..ebc75ac3919fbacc98fe1ff29960bbc56601566e 100644 (file)
@@ -1,6 +1,21 @@
 class ApiController < ApplicationController
   skip_before_action :verify_authenticity_token
 
+  private
+
+  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