From bbd877082e64db53c96467431cb766c75f14c96c Mon Sep 17 00:00:00 2001 From: John Dong Date: Thu, 16 Aug 2007 20:20:16 -0400 Subject: [PATCH] XMLRPC Vote Casting Validation: * Can only vote for candidate_id's within the current election * Can only rank each candidate once * Must rank all candidates --- TODO | 1 - app/models/selectricity_service.rb | 6 ++++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/TODO b/TODO index dbac0f6..be982ee 100644 --- a/TODO +++ b/TODO @@ -1,3 +1,2 @@ Known bugs or issues: -* Validate XMLRPC data, particularly creating quickvotes diff --git a/app/models/selectricity_service.rb b/app/models/selectricity_service.rb index 3f0a3bf..4075f64 100644 --- a/app/models/selectricity_service.rb +++ b/app/models/selectricity_service.rb @@ -5,6 +5,12 @@ class SelectricityService < ActionWebService::Base def cast_quickvote(election_name, voter_id, vote_list) election = QuickVote.ident_to_quickvote election_name if election + candidates=election.candidates.collect { |c| c.id } + vote_list[0].each do |vote| + raise ArgumentError.new "Invalid Candidate ID #{vote}" unless candidates.index(vote) + end + raise ArgumentError.new "You must rank all candidates" unless candidates.length <= vote_list[0].length + raise ArgumentError.new "Please rank each candidate only once" if vote_list[0].uniq! voter = QuickVoter.new voter.election = election voter.ipaddress = "XMLRPC Request" -- 2.30.2