Defines Poll::Question#answerable_by?(user) and uses it in abilities

This commit is contained in:
kikito
2016-11-07 16:28:39 +01:00
parent fd3f00d61a
commit d39f19abb8
3 changed files with 61 additions and 1 deletions

View File

@@ -49,7 +49,9 @@ module Abilities
can :create, DirectMessage can :create, DirectMessage
can :show, DirectMessage, sender_id: user.id can :show, DirectMessage, sender_id: user.id
can(:answer, Poll, Poll.current){ |poll| poll.current? } can(:answer, Poll, Poll.current){ |poll| poll.current? }
can :answer, Poll::Question, geozones: {id: user.geozone_id} can(:answer, Poll::Question, Poll::Question.answerable_by(user)) do |question|
question.answerable_by?(user)
end
end end
can [:create, :show], ProposalNotification, proposal: { author_id: user.id } can [:create, :show], ProposalNotification, proposal: { author_id: user.id }

View File

@@ -46,6 +46,17 @@ class Poll::Question < ActiveRecord::Base
end end
end end
def answerable_by?(user)
user.present? && poll.current? && (self.all_geozones || self.geozone_ids.include?(user.geozone_id))
end
def self.answerable_by(user)
return where(false) unless user.present?
where(poll_id: Poll.current.pluck(:id))
.joins(:geozones)
.where('poll_questions.all_geozones = ? or geozones.id = ?',
true,
user.geozone_id || -1) # user.geozone_id can be nil, which would throw errors on sql
end
end end

View File

@@ -20,6 +20,13 @@ describe "Abilities::Common" do
let(:poll_question_from_own_geozone) { create(:poll_question, geozones: [geozone]) } let(:poll_question_from_own_geozone) { create(:poll_question, geozones: [geozone]) }
let(:poll_question_from_other_geozone) { create(:poll_question, geozones: [create(:geozone)]) } let(:poll_question_from_other_geozone) { create(:poll_question, geozones: [create(:geozone)]) }
let(:poll_question_from_all_geozones) { create(:poll_question, all_geozones: true) }
let(:expired_poll_question_from_own_geozone) { create(:poll_question, poll: expired_poll, geozones: [geozone]) }
let(:expired_poll_question_from_other_geozone) { create(:poll_question, poll: expired_poll, geozones: [create(:geozone)]) }
let(:expired_poll_question_from_all_geozones) { create(:poll_question, poll: expired_poll, all_geozones: true) }
let(:incoming_poll_question_from_own_geozone) { create(:poll_question, poll: incoming_poll, geozones: [geozone]) }
let(:incoming_poll_question_from_other_geozone) { create(:poll_question, poll: incoming_poll, geozones: [create(:geozone)]) }
let(:incoming_poll_question_from_all_geozones) { create(:poll_question, poll: incoming_poll, all_geozones: true) }
it { should be_able_to(:index, Debate) } it { should be_able_to(:index, Debate) }
it { should be_able_to(:show, debate) } it { should be_able_to(:show, debate) }
@@ -117,7 +124,27 @@ describe "Abilities::Common" do
it { should_not be_able_to(:answer, incoming_poll) } it { should_not be_able_to(:answer, incoming_poll) }
it { should be_able_to(:answer, poll_question_from_own_geozone ) } it { should be_able_to(:answer, poll_question_from_own_geozone ) }
it { should be_able_to(:answer, poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, poll_question_from_other_geozone ) } it { should_not be_able_to(:answer, poll_question_from_other_geozone ) }
it { should_not be_able_to(:answer, expired_poll_question_from_own_geozone ) }
it { should_not be_able_to(:answer, expired_poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, expired_poll_question_from_other_geozone ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_own_geozone ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_other_geozone ) }
context "without geozone" do
before(:each) { user.geozone = nil }
it { should_not be_able_to(:answer, poll_question_from_own_geozone ) }
it { should be_able_to(:answer, poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, poll_question_from_other_geozone ) }
it { should_not be_able_to(:answer, expired_poll_question_from_own_geozone ) }
it { should_not be_able_to(:answer, expired_poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, expired_poll_question_from_other_geozone ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_own_geozone ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_other_geozone ) }
end
end end
describe "when level 3 verified" do describe "when level 3 verified" do
@@ -142,6 +169,26 @@ describe "Abilities::Common" do
it { should_not be_able_to(:answer, incoming_poll) } it { should_not be_able_to(:answer, incoming_poll) }
it { should be_able_to(:answer, poll_question_from_own_geozone ) } it { should be_able_to(:answer, poll_question_from_own_geozone ) }
it { should be_able_to(:answer, poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, poll_question_from_other_geozone ) } it { should_not be_able_to(:answer, poll_question_from_other_geozone ) }
it { should_not be_able_to(:answer, expired_poll_question_from_own_geozone ) }
it { should_not be_able_to(:answer, expired_poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, expired_poll_question_from_other_geozone ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_own_geozone ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_other_geozone ) }
context "without geozone" do
before(:each) { user.geozone = nil }
it { should_not be_able_to(:answer, poll_question_from_own_geozone ) }
it { should be_able_to(:answer, poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, poll_question_from_other_geozone ) }
it { should_not be_able_to(:answer, expired_poll_question_from_own_geozone ) }
it { should_not be_able_to(:answer, expired_poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, expired_poll_question_from_other_geozone ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_own_geozone ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_all_geozones ) }
it { should_not be_able_to(:answer, incoming_poll_question_from_other_geozone ) }
end
end end
end end