63 lines
1.4 KiB
Ruby
63 lines
1.4 KiB
Ruby
class OutfitsController < ApplicationController
|
|
before_filter :find_authorized_outfit, :only => [:update, :destroy]
|
|
|
|
def create
|
|
if user_signed_in?
|
|
@outfit = Outfit.new params[:outfit]
|
|
@outfit.user = current_user
|
|
if @outfit.save
|
|
render :json => @outfit.id
|
|
else
|
|
render_outfit_errors
|
|
end
|
|
else
|
|
render :json => {:errors => {:user => ['not logged in']}}, :status => :forbidden
|
|
end
|
|
end
|
|
|
|
def for_current_user
|
|
@outfits = user_signed_in? ? current_user.outfits : []
|
|
render :json => @outfits
|
|
end
|
|
|
|
def destroy
|
|
if @outfit.destroy
|
|
render :json => true
|
|
else
|
|
render :json => false, :status => :bad_request
|
|
end
|
|
end
|
|
|
|
def new
|
|
@colors = Color.all
|
|
@species = Species.all
|
|
@top_contributors = User.top_contributors.limit(3)
|
|
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
|