2023-04-03 18:23:49 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
# API Controller for resources of type Child
|
|
|
|
# Children are used to provide a way to manage multiple users in the family account
|
2023-04-04 18:09:17 +02:00
|
|
|
class API::ChildrenController < API::APIController
|
2023-04-03 18:23:49 +02:00
|
|
|
before_action :authenticate_user!
|
2023-05-25 20:17:37 +02:00
|
|
|
before_action :set_child, only: %i[show update destroy validate]
|
2023-04-03 18:23:49 +02:00
|
|
|
|
|
|
|
def index
|
2023-05-15 16:42:01 +02:00
|
|
|
authorize Child
|
|
|
|
user_id = current_user.id
|
|
|
|
user_id = params[:user_id] if current_user.privileged? && params[:user_id]
|
2023-05-31 18:20:14 +02:00
|
|
|
@children = Child.where(user_id: user_id).includes(:supporting_document_files).order(:created_at)
|
2023-04-03 18:23:49 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def show
|
|
|
|
authorize @child
|
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
@child = Child.new(child_params)
|
|
|
|
authorize @child
|
2023-05-26 15:55:38 +02:00
|
|
|
if ChildService.create(@child)
|
2023-04-03 18:23:49 +02:00
|
|
|
render status: :created
|
|
|
|
else
|
|
|
|
render json: @child.errors.full_messages, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
authorize @child
|
|
|
|
|
|
|
|
if @child.update(child_params)
|
|
|
|
render status: :ok
|
|
|
|
else
|
|
|
|
render json: @child.errors.full_messages, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
|
|
|
authorize @child
|
|
|
|
@child.destroy
|
|
|
|
head :no_content
|
|
|
|
end
|
|
|
|
|
2023-05-25 20:17:37 +02:00
|
|
|
def validate
|
|
|
|
authorize @child
|
|
|
|
|
|
|
|
cparams = params.require(:child).permit(:validated_at)
|
2023-05-26 16:44:18 +02:00
|
|
|
if ChildService.validate(@child, cparams[:validated_at].present?)
|
2023-05-25 20:17:37 +02:00
|
|
|
render :show, status: :ok, location: child_path(@child)
|
|
|
|
else
|
|
|
|
render json: @child.errors, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-04-03 18:23:49 +02:00
|
|
|
private
|
|
|
|
|
|
|
|
def set_child
|
|
|
|
@child = Child.find(params[:id])
|
|
|
|
end
|
|
|
|
|
|
|
|
def child_params
|
2023-05-24 19:56:48 +02:00
|
|
|
params.require(:child).permit(:first_name, :last_name, :email, :phone, :birthday, :user_id,
|
|
|
|
supporting_document_files_attributes: %i[id supportable_id supportable_type
|
|
|
|
supporting_document_type_id
|
|
|
|
attachment _destroy])
|
2023-04-03 18:23:49 +02:00
|
|
|
end
|
|
|
|
end
|