1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-22 11:52:21 +01:00
fab-manager/app/controllers/api/projects_controller.rb

98 lines
3.1 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
# API Controller for resources of type Project
2023-02-24 17:26:55 +01:00
class API::ProjectsController < API::APIController
2018-12-27 14:15:58 +01:00
before_action :authenticate_user!, except: %i[index show last_published search]
before_action :set_project, only: %i[update destroy]
2015-05-05 03:10:25 +02:00
respond_to :json
def index
2020-06-23 11:19:20 +02:00
@projects = policy_scope(Project).page(params[:page])
2015-05-05 03:10:25 +02:00
end
def last_published
@projects = Project.includes(:project_image).published.order('created_at desc').limit(5)
end
def show
2018-12-27 14:15:58 +01:00
@project = Project.friendly.find(params[:id])
2015-05-05 03:10:25 +02:00
end
2023-06-29 16:37:16 +02:00
def markdown
@project = Project.friendly.find(params[:id])
authorize @project
send_data ProjectToMarkdown.new(@project).call, filename: "#{@project.name.parameterize}-#{@project.id}.md", disposition: 'attachment', type: 'text/markdown'
end
2015-05-05 03:10:25 +02:00
def create
2019-06-06 16:34:53 +02:00
@project = Project.new(project_params.merge(author_statistic_profile_id: current_user.statistic_profile.id))
2015-05-05 03:10:25 +02:00
if @project.save
render :show, status: :created, location: @project
else
render json: @project.errors, status: :unprocessable_entity
end
end
def update
authorize @project
if @project.update(project_params)
render :show, status: :ok, location: @project
else
render json: @project.errors, status: :unprocessable_entity
end
end
def destroy
2016-03-23 18:39:41 +01:00
authorize @project
2015-05-05 03:10:25 +02:00
@project.destroy
head :no_content
end
def collaborator_valid
2016-11-23 16:30:19 +01:00
project_user = ProjectUser.find_by(valid_token: params[:valid_token])
2015-05-05 03:10:25 +02:00
if project_user
project_user.update(is_valid: true, valid_token: '')
redirect_to "/#!/projects/#{project_user.project.id}" and return
end
redirect_to root_url
end
2016-03-23 18:39:41 +01:00
def search
service = ProjectService.new
2023-06-30 11:15:37 +02:00
paginate = request.format.zip? ? false : true
res = service.search(params, current_user, paginate: paginate)
render json: res, status: :unprocessable_entity and return if res[:error]
2020-06-23 11:19:20 +02:00
2023-06-30 11:15:37 +02:00
respond_to do |format|
format.json do
@total = res[:total]
@projects = res[:projects]
render :index
end
format.zip do
head :forbidden unless current_user && (current_user.admin? || current_user.manager?)
2023-06-30 11:15:37 +02:00
send_data ProjectsArchive.new(res[:projects]).call, filename: "projets.zip", disposition: 'attachment', type: 'application/zip'
end
end
2016-03-23 18:39:41 +01:00
end
2015-05-05 03:10:25 +02:00
private
2018-12-27 14:15:58 +01:00
def set_project
@project = Project.find(params[:id])
end
def project_params
params.require(:project).permit(:name, :description, :tags, :machine_ids, :component_ids, :theme_ids, :licence_id, :status_id, :state,
2023-06-29 08:47:42 +02:00
user_ids: [], machine_ids: [], component_ids: [], theme_ids: [], project_category_ids: [],
2018-12-27 14:15:58 +01:00
project_image_attributes: [:attachment],
project_caos_attributes: %i[id attachment _destroy],
project_steps_attributes: [
:id, :description, :title, :_destroy, :step_nb,
{ project_step_images_attributes: %i[id attachment _destroy] }
2018-12-27 14:15:58 +01:00
])
end
2015-05-05 03:10:25 +02:00
end