1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-05 20:46:14 +01:00
fab-manager/app/controllers/api/availabilities_controller.rb

200 lines
7.0 KiB
Ruby
Raw Normal View History

2019-01-17 16:26:03 +01:00
# frozen_string_literal: true
# API Controller for resources of type Availability
2016-03-23 18:39:41 +01:00
class API::AvailabilitiesController < API::ApiController
include FablabConfiguration
before_action :authenticate_user!, except: [:public]
2019-11-18 17:29:51 +01:00
before_action :set_availability, only: %i[show update reservations lock]
2018-12-17 16:02:02 +01:00
before_action :define_max_visibility, only: %i[machine trainings spaces]
2016-03-23 18:39:41 +01:00
respond_to :json
def index
authorize Availability
start_date = ActiveSupport::TimeZone[params[:timezone]].parse(params[:start])
end_date = ActiveSupport::TimeZone[params[:timezone]].parse(params[:end]).end_of_day
2019-01-17 16:26:03 +01:00
@availabilities = Availability.includes(:machines, :tags, :trainings, :spaces)
.where('start_at >= ? AND end_at <= ?', start_date, end_date)
@availabilities = @availabilities.where.not(available_type: 'event') unless Rails.application.secrets.events_in_calendar
2019-01-17 16:26:03 +01:00
@availabilities = @availabilities.where.not(available_type: 'space') if fablab_spaces_deactivated?
2016-03-23 18:39:41 +01:00
end
def public
start_date = ActiveSupport::TimeZone[params[:timezone]].parse(params[:start])
end_date = ActiveSupport::TimeZone[params[:timezone]].parse(params[:end]).end_of_day
@reservations = Reservation.includes(:slots, :statistic_profile)
.references(:slots)
2019-01-17 16:26:03 +01:00
.where('slots.start_at >= ? AND slots.end_at <= ?', start_date, end_date)
machine_ids = params[:m] || []
2019-01-17 16:55:25 +01:00
service = Availabilities::PublicAvailabilitiesService.new(current_user)
2019-01-17 16:26:03 +01:00
@availabilities = service.public_availabilities(
start_date,
end_date,
@reservations,
machines: machine_ids, spaces: params[:s]
)
@title_filter = { machine_ids: machine_ids.map(&:to_i) }
@availabilities = filter_availabilites(@availabilities)
end
2016-03-23 18:39:41 +01:00
def show
authorize Availability
end
def create
authorize Availability
@availability = Availability.new(availability_params)
if @availability.save
2019-11-18 11:50:20 +01:00
if params[:availability][:occurrences]
service = Availabilities::CreateAvailabilitiesService.new
service.create(@availability, params[:availability][:occurrences])
end
2016-03-23 18:39:41 +01:00
render :show, status: :created, location: @availability
else
render json: @availability.errors, status: :unprocessable_entity
end
end
def update
authorize Availability
if @availability.update(availability_params)
render :show, status: :ok, location: @availability
else
render json: @availability.errors, status: :unprocessable_entity
end
end
def destroy
authorize Availability
2019-11-18 17:29:51 +01:00
service = Availabilities::DeleteAvailabilitiesService.new
res = service.delete(params[:id], params[:mode])
if res.all? { |r| r[:status] }
render json: { deleted: res.length, details: res }, status: :ok
2016-03-23 18:39:41 +01:00
else
2019-11-18 17:29:51 +01:00
render json: { total: res.length, deleted: res.select { |r| r[:status] }.length, details: res }, status: :unprocessable_entity
2016-03-23 18:39:41 +01:00
end
end
def machine
@current_user_role = current_user.role
2019-01-17 16:26:03 +01:00
2019-01-17 16:55:25 +01:00
service = Availabilities::AvailabilitiesService.new(current_user, other: @visi_max_other, year: @visi_max_year)
2019-01-17 16:26:03 +01:00
@slots = service.machines(params[:machine_id], user)
2016-03-23 18:39:41 +01:00
end
def trainings
2019-01-17 16:55:25 +01:00
service = Availabilities::AvailabilitiesService.new(current_user, other: @visi_max_other, year: @visi_max_year)
@availabilities = service.trainings(params[:training_id], user)
2016-03-23 18:39:41 +01:00
end
2017-02-23 17:45:55 +01:00
def spaces
@current_user_role = current_user.role
2019-01-17 16:26:03 +01:00
2019-01-17 16:55:25 +01:00
service = Availabilities::AvailabilitiesService.new(current_user, other: @visi_max_other, year: @visi_max_year)
2019-01-17 16:26:03 +01:00
@slots = service.spaces(params[:space_id], user)
2017-02-23 17:45:55 +01:00
end
2016-03-23 18:39:41 +01:00
def reservations
authorize Availability
@reservation_slots = @availability.slots.includes(reservations: [statistic_profile: [user: [:profile]]]).order('slots.start_at ASC')
2016-03-23 18:39:41 +01:00
end
2017-03-02 12:34:28 +01:00
def export_availabilities
authorize :export
2018-12-17 16:02:02 +01:00
export = Export.where(category: 'availabilities', export_type: 'index')
.where('created_at > ?', Availability.maximum('updated_at')).last
2017-03-02 12:34:28 +01:00
if export.nil? || !FileTest.exist?(export.file)
2018-12-17 16:02:02 +01:00
@export = Export.new(category: 'availabilities', export_type: 'index', user: current_user)
2017-03-02 12:34:28 +01:00
if @export.save
2019-01-17 16:26:03 +01:00
render json: { export_id: @export.id }, status: :ok
2017-03-02 12:34:28 +01:00
else
render json: @export.errors, status: :unprocessable_entity
end
else
2018-12-17 16:02:02 +01:00
send_file File.join(Rails.root, export.file),
type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
disposition: 'attachment'
2017-03-02 12:34:28 +01:00
end
end
def lock
authorize @availability
if @availability.update_attributes(lock: lock_params)
render :show, status: :ok, location: @availability
else
render json: @availability.errors, status: :unprocessable_entity
end
end
2016-03-23 18:39:41 +01:00
private
2019-01-17 16:26:03 +01:00
def user
if params[:member_id]
User.find(params[:member_id])
else
current_user
end
end
2018-12-17 16:02:02 +01:00
def set_availability
@availability = Availability.find(params[:id])
end
2016-03-23 18:39:41 +01:00
2018-12-17 16:02:02 +01:00
def availability_params
params.require(:availability).permit(:start_at, :end_at, :available_type, :machine_ids, :training_ids, :nb_total_places,
:is_recurrent, :period, :nb_periods, :end_date, :slot_duration,
machine_ids: [], training_ids: [], space_ids: [], tag_ids: [], plan_ids: [],
machines_attributes: %i[id _destroy], plans_attributes: %i[id _destroy])
2018-12-17 16:02:02 +01:00
end
2018-12-17 16:02:02 +01:00
def lock_params
params.require(:lock)
end
2019-01-17 16:26:03 +01:00
def filter_availabilites(availabilities)
availabilities_filtered = []
availabilities.to_ary.each do |a|
# machine slot
if !a.try(:available_type)
availabilities_filtered << a
else
availabilities_filtered << a if filter_training?(a)
availabilities_filtered << a if filter_space?(a)
availabilities_filtered << a if filter_machine?(a)
availabilities_filtered << a if filter_event?(a)
2017-02-23 17:45:55 +01:00
end
end
2019-01-17 16:26:03 +01:00
availabilities_filtered.delete_if(&method(:remove_completed?))
2018-12-17 16:02:02 +01:00
end
2017-02-23 17:45:55 +01:00
2019-01-17 16:26:03 +01:00
def filter_training?(availability)
params[:t] && availability.available_type == 'training' && params[:t].include?(availability.trainings.first.id.to_s)
2018-12-17 16:02:02 +01:00
end
2016-03-23 18:39:41 +01:00
2019-01-17 16:26:03 +01:00
def filter_space?(availability)
params[:s] && availability.available_type == 'space' && params[:s].include?(availability.spaces.first.id.to_s)
2018-12-17 16:02:02 +01:00
end
2016-03-23 18:39:41 +01:00
2019-01-17 16:26:03 +01:00
def filter_machine?(availability)
params[:m] && availability.available_type == 'machines' && (params[:m].map(&:to_i) & availability.machine_ids).any?
2018-12-17 16:02:02 +01:00
end
2016-06-28 18:58:44 +02:00
2019-01-17 16:26:03 +01:00
def filter_event?(availability)
params[:evt] && params[:evt] == 'true' && availability.available_type == 'event'
2018-12-17 16:02:02 +01:00
end
2019-01-17 16:26:03 +01:00
def remove_completed?(availability)
2019-01-17 16:55:25 +01:00
params[:dispo] == 'false' && (availability.is_reserved || (availability.try(:completed?) && availability.completed?))
2018-12-17 16:02:02 +01:00
end
def define_max_visibility
@visi_max_year = Setting.find_by(name: 'visibility_yearly').value.to_i.months.since
@visi_max_other = Setting.find_by(name: 'visibility_others').value.to_i.months.since
end
2016-03-23 18:39:41 +01:00
end