class DebatesController < ApplicationController before_action :authenticate_user!, except: [:index, :show] load_and_authorize_resource def index @debates = Debate.search(params) set_debate_votes(@debates) end def show set_debate_votes(@debate) end def new @debate = Debate.new end def edit end def create @debate = Debate.new(debate_params) @debate.author = current_user if @debate.save_with_captcha redirect_to @debate, notice: t('flash.actions.create.notice', resource_name: 'Debate') else render :new end end def update @debate.update(debate_params) respond_with @debate end def vote @debate.vote_by(voter: current_user, vote: params[:value]) set_debate_votes(@debate) end private def set_debate @debate = Debate.find(params[:id]) end def debate_params params.require(:debate).permit(:title, :description, :tag_list, :terms_of_service, :captcha, :captcha_key) end end