X-Git-Url: https://projects.mako.cc/source/selectricity-live/blobdiff_plain/75091532075247ae9c47164ea883f4fe803eddf4..538c52ea43285fc1ae40e3c3ff5ee78befa1c142:/app/controllers/voter_controller.rb diff --git a/app/controllers/voter_controller.rb b/app/controllers/voter_controller.rb index d2529f8..461be29 100644 --- a/app/controllers/voter_controller.rb +++ b/app/controllers/voter_controller.rb @@ -1,71 +1,72 @@ class VoterController < ApplicationController - layout 'vb' - model :voter - model :vote - model :election + layout 'main' + require_dependency "voter" + require_dependency "vote" + require_dependency "election" def index - password = params[:id] - password = params[:vote][:password] if params[:vote] - if @voter = FullVoter.find_all( [ "password = ?", password ] )[0] - render :action => 'fullvote' + if params[:urlpassword] + password = params[:urlpassword] + else + password = nil + end + + if @voter = FullVoter.find(:all, :conditions => + [ "password = ?", password ] )[0] + @voter.vote = Vote.new if @voter.vote.nil? + @voter.vote.set_defaults! if @voter.vote.rankings.empty? + + @election = @voter.election + @sidebar_content = render_to_string(:partial => 'sortable_vote') + render :action => 'full_vote' + elsif params[:urlpassword] + redirect_to :action => 'index' + end + end + + def login + if params[:vote] and params[:vote][:password] + redirect_to votepassword_url( :action => 'index', :urlpassword => params[:vote][:password]) + else + redirect_to :action => 'index' end end def review if authenticate - # remove any existing votes and reload - if @voter.vote - @voter.vote.destroy - @voter.reload - end - - @vote = Vote.new - @voter.vote = @vote - @vote.votestring = params[:vote][:votestring] - @vote.save + @voter.vote.time = Time.now + @voter.vote.save + @voter.reload else redirect_to :action => 'index' end end def confirm - if params[:votename] - if Voter.find_all( ["session_id = ?", session.session_id ])[0] - flash[:notice] = "You have already voted!" - redirect_to quickvote_url( :votename => params[:votename] ) - else - @voter = QuickVoter.new() - @voter.election = Election.find_all( [ "name = ?", - params[:votename] ] )[0] - @voter.session_id = session.session_id - @voter.save - @voter.reload - - @voter.vote = Vote.new - @voter.vote.votestring = params[:vote][:votestring] - @voter.vote.save - @voter.vote.confirm! - render :action => 'thanks' - end - - elsif authenticate + if authenticate @voter.vote.confirm! render :action => 'thanks' else redirect_to :action => 'index' end end - - def quickvote - @voter = QuickVoter.new - @voter.election = Election.find_all( [ "name = ?", params[:votename] ] )[0] + + def reminder + if params[:email] + voter_array= FullVoter.find(:all, :conditions => ["email = ?", params[:email]]) + voter_array.delete_if {|voter| voter.election.active == 0} + unless voter_array.empty? + VoterNotify.deliver_reminder(voter_array) + end + render :action => 'reminder_sent' + end end - + + private def authenticate password = params[:id] - @voter = FullVoter.find_all( [ "password = ?", password ] )[0] + @voter = FullVoter.find(:all, :conditions => [ "password = ?", password ] )[0] end end