X-Git-Url: https://projects.mako.cc/source/selectricity-live/blobdiff_plain/4ff0c6cd9e37482d16d1713fd6d265c0604f60d1..133c94ce531e1c623dbe9c5f2eb05307357b35f2:/app/models/selectricity_service.rb diff --git a/app/models/selectricity_service.rb b/app/models/selectricity_service.rb index 3f0a3bf..7da46e1 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" @@ -15,6 +21,8 @@ class SelectricityService < ActionWebService::Base voter.save! voter.vote.confirm! voter.save! + else + raise ArgumentError.new "Cannot find election #{election_name}" end end def quickvote_candidate_ids_to_names(shortname, id_list)