class Api::V1::PartiesController < Api::V1::ApiController before_action :set_from_slug, except: ['create', 'update'] before_action :set, only: ['update', 'destroy'] def create @party = Party.new(shortcode: random_string) @party.extra = party_params['extra'] if current_user @party.user = current_user end render :show, status: :created if @party.save! end def show render_not_found_response if @party.nil? end def update if @party.user != current_user render_unauthorized_response else @party.attributes = party_params render :update, status: :ok if @party.save! end end def destroy if @party.user != current_user render_unauthorized_response else render :destroyed, status: :ok if @party.destroy end end def weapons render_not_found_response if @party.nil? render :weapons, status: :ok end def summons render_not_found_response if @party.nil? render :summons, status: :ok end def characters render_not_found_response if @party.nil? render :characters, status: :ok end def index element = request.params['element'] raid = request.params['raid'] recency = request.params['recency'] ? Time.at(request.params['recency']).to_datetime.beginning_of_day : nil now = DateTime.current @parties = Party.where(element: element, raid_id: raid, created_at: recency..now) render :all, status: :ok end private def random_string numChars = 6 o = [('a'..'z'), ('A'..'Z'), (0..9)].map(&:to_a).flatten return (0...numChars).map { o[rand(o.length)] }.join end def set_from_slug @party = Party.where("shortcode = ?", params[:id]).first end def set @party = Party.where("id = ?", params[:id]).first end def party_params params.require(:party).permit(:user_id, :extra, :name, :description, :raid_id) end end