array( 's.access_start_date >= ? AND uu.relation_type = ? AND asq.updated_at <= ?' => array( $now, USER_RELATION_TYPE_BOSS, $weekAgo, ) ), 'order' => 's.id', ); $queueList = Database::select($columns, $joinTables, $conditions); /** * Remind students */ $sessionInfoList = array(); foreach ($queueList as $queueItem) { if (!isset($sessionInfoList[$queueItem['session_id']])) { $sessionInfoList[$queueItem['session_id']] = api_get_session_info($queueItem['session_id']); } } foreach ($queueList as $queueItem) { switch ($queueItem['status']) { case ADVANCED_SUBSCRIPTION_QUEUE_STATUS_START: // No break case ADVANCED_SUBSCRIPTION_QUEUE_STATUS_BOSS_APPROVED: $data = array('sessionId' => $queueItem['session_id']); $data['session'] = api_get_session_info($queueItem['session_id']); $data['student'] = api_get_user_info($queueItem['student_id']); $plugin->sendMail($data, ADVANCED_SUBSCRIPTION_ACTION_REMINDER_STUDENT); break; default: break; } } /** * Remind superiors */ // Get recommended number of participants $sessionRecommendedNumber = array(); foreach ($queueList as $queueItem) { $row = $sessionExtraFieldValue->get_values_by_handler_and_field_variable( $queueItem['session_id'], 'recommended_number_of_participants' ); $sessionRecommendedNumber[$queueItem['session_id']] = $row['value']; } // Group student by superior and session $queueBySuperior = array(); foreach ($queueList as $queueItem) { $queueBySuperior[$queueItem['session_id']][$queueItem['superior_id']][$queueItem['student_id']]['status'] = $queueItem['status']; } foreach ($queueBySuperior as $sessionId => $superiorStudents) { $data = array( 'sessionId' => $sessionId, 'session' => $sessionInfoList[$sessionId], 'students' => array(), ); $dataUrl = array( 'action' => 'confirm', 'sessionId' => $sessionId, 'currentUserId' => 0, 'newStatus' => ADVANCED_SUBSCRIPTION_QUEUE_STATUS_BOSS_APPROVED, 'studentUserId' => 0, 'is_connected' => true, 'profile_completed' => 0, ); foreach ($superiorStudents as $superiorId => $students) { $data['superior'] = api_get_user_info($superiorId); // Check if superior has at least one student if (count($students) > 0) { foreach ($students as $studentId => $studentInfo) { if ($studentInfo['status'] == ADVANCED_SUBSCRIPTION_QUEUE_STATUS_START) { $data['students'][$studentId] = api_get_user_info($studentId); $dataUrl['studentUserId'] = $studentId; $dataUrl['newStatus'] = ADVANCED_SUBSCRIPTION_QUEUE_STATUS_BOSS_APPROVED; $data['students'][$studentId]['acceptUrl'] = $plugin->getQueueUrl($dataUrl); $dataUrl['newStatus'] = ADVANCED_SUBSCRIPTION_QUEUE_STATUS_BOSS_DISAPPROVED; $data['students'][$studentId]['rejectUrl'] = $plugin->getQueueUrl($dataUrl); } } if (is_array($data['students']) && count($data['students']) > 0) { // Check if superior have more than recommended if ($sessionRecommendedNumber[$sessionId] >= count($students)) { // Is greater or equal than recommended $plugin->sendMail($data, ADVANCED_SUBSCRIPTION_ACTION_REMINDER_SUPERIOR); } else { // Is less than recommended $plugin->sendMail($data, ADVANCED_SUBSCRIPTION_ACTION_REMINDER_SUPERIOR_MAX); } } } } } /** * Remind admins */ $admins = UserManager::get_all_administrators(); $isWesternNameOrder = api_is_western_name_order(); foreach ($admins as &$admin) { $admin['complete_name'] = $isWesternNameOrder ? $admin['firstname'].', '.$admin['lastname'] : $admin['lastname'].', '.$admin['firstname'] ; } unset($admin); $queueByAdmin = array(); foreach ($queueList as $queueItem) { if ($queueItem['status'] == ADVANCED_SUBSCRIPTION_QUEUE_STATUS_BOSS_APPROVED) { $queueByAdmin[$queueItem['session_id']]['students'][$queueItem['student_id']]['user_id'] = $queueItem['student_id']; } } $data = array( 'admins' => $admins, ); foreach ($queueByAdmin as $sessionId => $studentInfo) { $data['sessionId'] = $sessionId; $data['admin_view_url'] = api_get_path(WEB_PLUGIN_PATH). 'advanced_subscription/src/admin_view.php?s='.$data['sessionId']; $data['session'] = $sessionInfoList[$sessionId]; $data['students'] = $studentInfo['students']; $plugin->sendMail($data, ADVANCED_SUBSCRIPTION_ACTION_REMINDER_ADMIN); }