# 问卷发布 消息通知 class PollPublishNotifyJob < ApplicationJob queue_as :notify def perform(poll_id, group_ids) poll = Poll.find_by(id: poll_id) return if poll.blank? user = poll.user course = poll.course if group_ids.present? students = course.students.where(course_group_id: group_ids) subquery = course.teacher_course_groups.where(course_group_id: group_ids).select(:course_member_id) teachers = course.teachers.where(id: subquery) else students = course.students teachers = course.teachers end attrs = %i[ user_id trigger_user_id container_id container_type parent_container_id parent_container_type belong_container_id belong_container_type viewed tiding_type created_at updated_at ] same_attrs = { trigger_user_id: user.id, container_id: poll.id, container_type: 'Poll', parent_container_id: poll.id, parent_container_type: 'PollPublish', belong_container_id: poll.course_id, belong_container_type: 'Course', viewed: 0, tiding_type: 'Poll' } Tiding.bulk_insert(*attrs) do |worker| teacher_ids = teachers.pluck(:user_id) unless poll.tidings.exists?(parent_container_type: 'PollPublish', user_id: teacher_ids) teacher_ids.find_each do |user_id| worker.add same_attrs.merge(user_id: user_id) end end students.pluck(:user_id).each do |user_id| worker.add same_attrs.merge(user_id: user_id) end end end end