class V1::CollectionsController < ApplicationController include ::SociableController include ::FollowableController include ::TaggableController before_action :set_collection, only: [:show, :update, :destroy] before_action :authenticate_user!, only: [:create, :update, :destroy] # GET /v1/collections # GET /v1/collections.json def index render json: Collection.all end # GET /v1/collections/1 # GET /v1/collections/1.json def show render json: @collection end # POST /v1/collection # POST /v1/collection.json def create collection = Collection.new(collection_params) if collection.save render json: collection, status: :created else render json: collection.errors, status: :unprocessable_entity end end # PUT/PATCH /v1/users/1 # PUT/PATCH /v1/users/1.json def update if @collection.update(collection_params) render json: @collection, status: :ok else render json: @collection.errors, status: :unprocessable_entity end end # DELETE /v1/collections/1 # DELETE /v1/collections/1.json def destroy @collection.destroy render nothing: true, status: :ok end private # social concerns methods def followable set_collection end def taggable set_collection end def sociable set_collection end def set_collection @collection ||= Collection.find(params[:id]) end # Never trust parameters from the scary internet, only allow the white list through. def collection_params params.require(:collection).permit(:name, :description, :owner_id, :owner_type, :privacy, tags: [], learning_objects: []) end end