forked from OpenNeo/impress
Matchu
abcf70a0c4
Due to a silly slip-up involving Javascript object literal syntax, we were sending {csrf_param: "token"} instead of {authenticity_token: "token"} with wardrobe AJAX requests. This would cause users to be auto-logged-out for failing to provide a proper token. Oops.
92 lines
2.6 KiB
Ruby
92 lines
2.6 KiB
Ruby
class OutfitsController < ApplicationController
|
|
before_filter :find_authorized_outfit, :only => [:update, :destroy]
|
|
|
|
def create
|
|
Rails.logger.debug "Signed in?: #{user_signed_in?}"
|
|
Rails.logger.debug "User 1: #{current_user.inspect}"
|
|
@outfit = Outfit.build_for_user(current_user, params[:outfit])
|
|
Rails.logger.debug "User 2: #{current_user.inspect}"
|
|
if @outfit.save
|
|
Rails.logger.debug "User 3: #{current_user.inspect}"
|
|
render :json => @outfit.id
|
|
Rails.logger.debug "User 4: #{current_user.inspect}"
|
|
else
|
|
Rails.logger.debug "User 5: #{current_user.inspect}"
|
|
render_outfit_errors
|
|
Rails.logger.debug "User 6: #{current_user.inspect}"
|
|
end
|
|
end
|
|
|
|
def index
|
|
if user_signed_in?
|
|
@outfits = current_user.outfits.wardrobe_order
|
|
respond_to do |format|
|
|
format.html { render }
|
|
format.json { render :json => @outfits }
|
|
end
|
|
else
|
|
respond_to do |format|
|
|
format.html { redirect_to login_path(:return_to => request.fullpath) }
|
|
format.json { render :json => [] }
|
|
end
|
|
end
|
|
end
|
|
|
|
def destroy
|
|
if @outfit.destroy
|
|
respond_to do |format|
|
|
format.html {
|
|
flash[:success] = "Outfit #{@outfit.name} successfully deleted"
|
|
redirect_to current_user_outfits_path
|
|
}
|
|
format.json { render :json => true }
|
|
end
|
|
else
|
|
respond_to do |format|
|
|
format.html {
|
|
flash[:alert] = "Error deleting outfit. Try again?"
|
|
redirect_to current_user_outfits_path, :status => :bad_request
|
|
}
|
|
format.json { render :json => false, :status => :bad_request }
|
|
end
|
|
end
|
|
end
|
|
|
|
def new
|
|
unless fragment_exist?(:action_suffix => 'start_from_scratch_form_content')
|
|
@colors = Color.all_ordered_by_name
|
|
@species = Species.all_ordered_by_name
|
|
end
|
|
unless fragment_exist?(:action_suffix => 'top_contributors')
|
|
@top_contributors = User.top_contributors.limit(User::PreviewTopContributorsCount)
|
|
end
|
|
end
|
|
|
|
def show
|
|
@outfit = Outfit.find(params[:id])
|
|
respond_to do |format|
|
|
format.html { render }
|
|
format.json { render :json => @outfit }
|
|
end
|
|
end
|
|
|
|
def update
|
|
if @outfit.update_attributes(params[:outfit])
|
|
render :json => true
|
|
else
|
|
render_outfit_errors
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def find_authorized_outfit
|
|
raise ActiveRecord::RecordNotFound unless user_signed_in?
|
|
@outfit = current_user.outfits.find(params[:id])
|
|
end
|
|
|
|
def render_outfit_errors
|
|
render :json => {:errors => @outfit.errors}, :status => :bad_request
|
|
end
|
|
end
|
|
|