Prevent anon/banned/member users from voting (fix #2719).
There was a regression in 6d6d00b; `before_filter :voter_only` was a no-op in the post vote controller because it merely returned false, which does not halt the request. The fix is to arrange for a voter_only method to be defined that properly redirects to the access denied page.
This commit is contained in:
@@ -133,9 +133,9 @@ protected
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
%w(member banned builder gold platinum janitor moderator admin).each do |level|
|
User::Roles.each do |role|
|
||||||
define_method("#{level}_only") do
|
define_method("#{role}_only") do
|
||||||
if !CurrentUser.user.is_banned_or_ip_banned? && CurrentUser.user.__send__("is_#{level}?")
|
if !CurrentUser.user.is_banned_or_ip_banned? && CurrentUser.user.__send__("is_#{role}?")
|
||||||
true
|
true
|
||||||
else
|
else
|
||||||
access_denied()
|
access_denied()
|
||||||
|
|||||||
@@ -14,10 +14,4 @@ class PostVotesController < ApplicationController
|
|||||||
rescue PostVote::Error => x
|
rescue PostVote::Error => x
|
||||||
@error = x
|
@error = x
|
||||||
end
|
end
|
||||||
|
|
||||||
protected
|
|
||||||
|
|
||||||
def voter_only
|
|
||||||
CurrentUser.is_voter?
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -16,6 +16,16 @@ class User < ActiveRecord::Base
|
|||||||
ADMIN = 50
|
ADMIN = 50
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Used for `before_filter :<role>_only`. Must have a corresponding `is_<role>?` method.
|
||||||
|
Roles = Levels.constants.map(&:downcase) + [
|
||||||
|
:anonymous,
|
||||||
|
:banned,
|
||||||
|
:approver,
|
||||||
|
:voter,
|
||||||
|
:super_voter,
|
||||||
|
:verified,
|
||||||
|
]
|
||||||
|
|
||||||
BOOLEAN_ATTRIBUTES = %w(
|
BOOLEAN_ATTRIBUTES = %w(
|
||||||
is_banned
|
is_banned
|
||||||
has_mail
|
has_mail
|
||||||
@@ -384,6 +394,10 @@ class User < ActiveRecord::Base
|
|||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def is_blocked?
|
||||||
|
is_banned?
|
||||||
|
end
|
||||||
|
|
||||||
def is_builder?
|
def is_builder?
|
||||||
level >= Levels::BUILDER
|
level >= Levels::BUILDER
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user