2022-03-23 13:30:55 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
# Send a reminder email to the user who has made a reservation
|
2016-08-17 17:39:12 +02:00
|
|
|
class ReservationReminderWorker
|
|
|
|
include Sidekiq::Worker
|
|
|
|
|
|
|
|
## In case the reminder is enabled but no delay were configured, we use this default value
|
|
|
|
DEFAULT_REMINDER_DELAY = 24.hours
|
|
|
|
|
|
|
|
def perform
|
2022-03-23 13:30:55 +01:00
|
|
|
return unless Setting.get('reminder_enable')
|
|
|
|
|
|
|
|
delay = Setting.find_by(name: 'reminder_delay').try(:value).try(:to_i).try(:hours) || DEFAULT_REMINDER_DELAY
|
|
|
|
|
2023-02-14 13:10:58 +01:00
|
|
|
starting = Time.current.beginning_of_hour + delay
|
2022-03-23 13:30:55 +01:00
|
|
|
ending = starting + 1.hour
|
2016-08-17 17:39:12 +02:00
|
|
|
|
2022-07-26 15:41:03 +02:00
|
|
|
Reservation.joins(slots_reservations: :slot)
|
|
|
|
.where('slots.start_at >= ? AND slots.start_at <= ? AND slots_reservations.canceled_at IS NULL', starting, ending)
|
|
|
|
.each do |r|
|
2022-03-23 13:30:55 +01:00
|
|
|
already_sent = Notification.where(
|
|
|
|
attached_object_type: Reservation.name,
|
|
|
|
attached_object_id: r.id,
|
|
|
|
notification_type_id: NotificationType.find_by_name('notify_member_reservation_reminder')
|
|
|
|
).count
|
|
|
|
next if already_sent.positive?
|
2016-08-17 17:39:12 +02:00
|
|
|
|
2022-03-23 13:30:55 +01:00
|
|
|
NotificationCenter.call type: 'notify_member_reservation_reminder',
|
|
|
|
receiver: r.user,
|
|
|
|
attached_object: r
|
2016-08-17 17:39:12 +02:00
|
|
|
end
|
|
|
|
end
|
2022-03-23 13:30:55 +01:00
|
|
|
end
|