+ unless current_user
+ if request.get?
+ redirect_to :controller => "user", :action => "login", :referer => request.fullpath
+ else
+ head :forbidden
+ end
+ end
+ end
+
+ def require_oauth
+ @oauth = current_user.access_token(OAUTH_KEY) if current_user && defined? OAUTH_KEY
+ end
+
+ ##
+ # requires the user to be logged in by the token or HTTP methods, or have an
+ # OAuth token with the right capability. this method is a bit of a pain to call
+ # directly, since it's cumbersome to call filters with arguments in rails. to
+ # make it easier to read and write the code, there are some utility methods
+ # below.
+ def require_capability(cap)
+ # when the current token is nil, it means the user logged in with a different
+ # method, otherwise an OAuth token was used, which has to be checked.
+ unless current_token.nil?
+ unless current_token.read_attribute(cap)
+ set_locale
+ report_error t("oauth.permissions.missing"), :forbidden
+ false
+ end
+ end
+ end
+
+ ##
+ # require the user to have cookies enabled in their browser
+ def require_cookies
+ if request.cookies["_osm_session"].to_s == ""
+ if params[:cookie_test].nil?
+ session[:cookie_test] = true
+ redirect_to params.to_unsafe_h.merge(:cookie_test => "true")
+ false
+ else
+ flash.now[:warning] = t "application.require_cookies.cookies_needed"
+ end
+ else
+ session.delete(:cookie_test)
+ end
+ end
+
+ # Utility methods to make the controller filter methods easier to read and write.
+ def require_allow_read_prefs
+ require_capability(:allow_read_prefs)
+ end
+
+ def require_allow_write_prefs
+ require_capability(:allow_write_prefs)
+ end
+
+ def require_allow_write_diary
+ require_capability(:allow_write_diary)
+ end
+
+ def require_allow_write_api
+ require_capability(:allow_write_api)
+
+ if REQUIRE_TERMS_AGREED && current_user.terms_agreed.nil?
+ report_error "You must accept the contributor terms before you can edit.", :forbidden
+ return false
+ end
+ end
+
+ def require_allow_read_gpx
+ require_capability(:allow_read_gpx)
+ end
+
+ def require_allow_write_gpx
+ require_capability(:allow_write_gpx)
+ end
+
+ def require_allow_write_notes
+ require_capability(:allow_write_notes)
+ end
+
+ ##
+ # require that the user is a moderator, or fill out a helpful error message
+ # and return them to the index for the controller this is wrapped from.
+ def require_moderator
+ unless current_user.moderator?
+ if request.get?
+ flash[:error] = t("application.require_moderator.not_a_moderator")
+ redirect_to :action => "index"
+ else
+ head :forbidden
+ end
+ end