class API::TrainingsController < API::ApiController include ApplicationHelper before_action :authenticate_user!, except: [:index, :show] before_action :set_training, only: [:update, :destroy] def index @requested_attributes = params[:requested_attributes] @trainings = policy_scope(Training) if params[:public_page] @trainings = @trainings.where(public_page: true) end if attribute_requested?(@requested_attributes, 'availabilities') @trainings = @trainings.includes(:availabilities => [:slots => [:reservation => [:user => [:profile, :trainings]]]]).order('availabilities.start_at DESC') end end def show @training = Training.friendly.find(params[:id]) end def create authorize Training @training = Training.new(training_params) if @training.save render :show, status: :created, location: @training else render json: @training.errors, status: :unprocessable_entity end end def update authorize Training if params[:training][:users].present? members = User.where(id: valid_training_params[:users]) members.each do |m| m.trainings << @training end head :no_content else if @training.update(training_params) render :show, status: :ok, location: @training else render json: @training.errors, status: :unprocessable_entity end end end def destroy authorize @training @training.destroy head :no_content end def availabilities authorize Training @training = Training.find(params[:id]) @availabilities = @training.availabilities.includes(slots: {reservations: {user: [:profile, :trainings] }}).order('start_at DESC') end private def set_training @training = Training.find(params[:id]) end def valid_training_params params.require(:training).permit(:id, users: []) end def training_params params.require(:training).permit(:id, :name, :description, :machine_ids, :plan_ids, :nb_total_places, :public_page, training_image_attributes: [:attachment], machine_ids: [], plan_ids: []) end end