Chronobriq-API/app/controllers/api/v1/users_controller.rb

50 lines
987 B
Ruby

class Api::V1::UsersController < ApplicationController
before_action :set_user, only: %i[show update destroy]
before_action :check_owner, only: %i[update destroy]
def index
render json: User.all
end
def show
render json: User.find(params[:id])
end
def create
@user = User.new(user_params)
if @user.save
render json: @user, status: :created
else
render json: @user.errors, status: :unprocessable_entity
end
end
def update
if @user.update(user_params)
render json: @user, status: :ok
else
render json: @user.errors, status: :unprocessable_entity
end
end
def destroy
@user.destroy
head 204
end
private
# Only allow a trusted parameter "white list" through.
def user_params
params.require(:user).permit(:email, :username, :password)
end
def set_user
@user = User.find(params[:id])
end
def check_owner
head :forbidden unless @user.id == current_user&.id
end
end