class CreateSubjectCourseStudentJob < ApplicationJob
  queue_as :default

  def perform(course_id)
    course = Course.find_by(id: course_id)
    return if course.blank? || course.subject.blank?

    attrs = %i[course_id user_id role created_at updated_at]
    same_attrs = {course_id: course.id, role: 4}

    Rails.logger.info("1:course.students.count:##{course.students.count}")
    CourseMember.bulk_insert(*attrs) do |worker|
      course.subject.subject_appointments.each do |app|
        Rails.logger.info("##{course.students.where(user_id: app.user_id)}")
        next if course.students.where(user_id: app.user_id).any?
        worker.add same_attrs.merge(user_id: app.user_id)
      end
    end
    Rails.logger.info("2:course.students.count:##{course.students.count}")
    course.subject.subject_appointments.destroy_all
  end
end