class ApiController < ApplicationController
+ skip_before_action :verify_authenticity_token
- def map
+ def authorize(realm = "Web Password", errormessage = "Couldn't authenticate you")
+ # make the current_user object from any auth sources we have
+ setup_user_auth
-
- doc = XML::Document.new
- doc.encoding = 'UTF-8'
- root = XML::Node.new 'osm'
- root['version'] = '0.4'
- root['generator'] = 'OpenStreetMap server'
- doc.root = root
-
- render :text => doc.to_s
-
- #el1 = XML::Node.new 'node'
- #el1['id'] = self.id.to_s
- #el1['lat'] = self.latitude.to_s
- #el1['lon'] = self.longitude.to_s
- #Node.split_tags(el1, self.tags)
- #el1['visible'] = self.visible.to_s
- #el1['timestamp'] = self.timestamp.xmlschema
- #root << el1
+ # 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