123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716 |
- <?php
- class CourseRequestManager
- {
-
- public static function course_code_exists($wanted_course_code)
- {
- if ($code_exists = CourseManager::course_code_exists($wanted_course_code)) {
- return $code_exists;
- }
- $table_course_request = Database::get_main_table(TABLE_MAIN_COURSE_REQUEST);
- $wanted_course_code = Database::escape_string($wanted_course_code);
- $sql = sprintf(
- 'SELECT COUNT(id) AS number FROM %s WHERE visual_code = "%s"',
- $table_course_request,
- $wanted_course_code
- );
- $result = Database::fetch_array(Database::query($sql));
- return $result['number'] > 0;
- }
-
- public static function create_course_request(
- $wanted_code,
- $title,
- $description,
- $category_code,
- $course_language,
- $objectives,
- $target_audience,
- $user_id,
- $exemplary_content
- ) {
- $wanted_code = trim($wanted_code);
- $user_id = (int) $user_id;
- $exemplary_content = (bool) $exemplary_content ? 1 : 0;
- if ($wanted_code == '') {
- return false;
- }
- if (self::course_code_exists($wanted_code)) {
- return false;
- }
- if ($user_id <= 0) {
- return false;
- }
- $user_info = api_get_user_info($user_id);
- if (!is_array($user_info)) {
- return false;
- }
- $tutor_name = api_get_person_name($user_info['firstname'], $user_info['lastname'], null, null, $course_language);
- $request_date = api_get_utc_datetime();
- $status = COURSE_REQUEST_PENDING;
- $info = 0;
- $keys = AddCourse::define_course_keys($wanted_code, '');
- if (!count($keys)) {
- return false;
- }
- $visual_code = $keys['currentCourseCode'];
- $code = $keys['currentCourseId'];
- $db_name = isset($keys['currentCourseDbName']) ? $keys['currentCourseDbName'] : null;
- $directory = $keys['currentCourseRepository'];
-
- $sql = sprintf(
- 'INSERT INTO %s (
- code, user_id, directory, db_name,
- course_language, title, description, category_code,
- tutor_name, visual_code, request_date,
- objetives, target_audience, status, info, exemplary_content)
- VALUES (
- "%s", "%s", "%s", "%s",
- "%s", "%s", "%s", "%s",
- "%s", "%s", "%s",
- "%s", "%s", "%s", "%s", "%s");',
- Database::get_main_table(TABLE_MAIN_COURSE_REQUEST),
- Database::escape_string($code),
- Database::escape_string($user_id),
- Database::escape_string($directory),
- Database::escape_string($db_name),
- Database::escape_string($course_language),
- Database::escape_string($title),
- Database::escape_string($description),
- Database::escape_string($category_code),
- Database::escape_string($tutor_name),
- Database::escape_string($visual_code),
- Database::escape_string($request_date),
- Database::escape_string($objectives),
- Database::escape_string($target_audience),
- Database::escape_string($status),
- Database::escape_string($info),
- Database::escape_string($exemplary_content)
- );
- $result_sql = Database::query($sql);
- if (!$result_sql) {
- return false;
- }
- $last_insert_id = Database::insert_id();
-
-
- $email_language = api_get_setting('platformLanguage');
- $email_subject = sprintf(get_lang('CourseRequestEmailSubject', null, $email_language), '['.api_get_setting('siteName').']', $code);
- $email_body = get_lang('CourseRequestMailOpening', null, $email_language)."\n\n";
- $email_body .= get_lang('CourseName', null, $email_language).': '.$title."\n";
- $email_body .= get_lang('Fac', null, $email_language).': '.$category_code."\n";
- $email_body .= get_lang('CourseCode', null, $email_language).': '.$code."\n";
- $email_body .= get_lang('Professor', null, $email_language).': '.api_get_person_name($user_info['firstname'], $user_info['lastname'], null, null, $email_language)."\n";
- $email_body .= get_lang('Email', null, $email_language).': '.$user_info['mail']."\n";
- $email_body .= get_lang('Description', null, $email_language).': '.$description."\n";
- $email_body .= get_lang('Objectives', null, $email_language).': '.$objectives."\n";
- $email_body .= get_lang('TargetAudience', null, $email_language).': '.$target_audience."\n";
- $email_body .= get_lang('Ln', null, $email_language).': '.$course_language."\n";
- $email_body .= get_lang('FillWithExemplaryContent', null, $email_language).': '.($exemplary_content ? get_lang('Yes', null, $email_language) : get_lang('No', null, $email_language))."\n";
-
- $email_body_admin = $email_body;
- $email_body_admin .= "\n".get_lang('CourseRequestPageForApproval', null, $email_language).' '.api_get_path(WEB_CODE_PATH).'admin/course_request_edit.php?id='.$last_insert_id."\n";
- $email_body_admin .= "\n".get_lang('CourseRequestLegalNote', null, $email_language)."\n";
- $sender_name_teacher = api_get_person_name($user_info['firstname'], $user_info['lastname'], null, PERSON_NAME_EMAIL_ADDRESS);
- $sender_email_teacher = $user_info['mail'];
- $recipient_name_admin = api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'), null, PERSON_NAME_EMAIL_ADDRESS);
- $recipient_email_admin = api_get_setting('emailAdministrator');
- $userInfo = api_get_user_info($user_id);
- $additionalParameters = array(
- 'smsType' => SmsPlugin::NEW_COURSE_SUGGESTED_TEACHER,
- 'userId' => $user_id,
- 'userUsername' => $userInfo['username']
- );
- api_mail_html(
- $recipient_name_admin,
- $recipient_email_admin,
- $email_subject,
- $email_body_admin,
- $sender_name_teacher,
- $sender_email_teacher,
- null,
- null,
- null,
- $additionalParameters
- );
-
- $email_body_teacher = get_lang('Dear', null, $email_language).' ';
- $email_body_teacher .= api_get_person_name($user_info['firstname'], $user_info['lastname'], null, null, $email_language).",\n\n";
- $email_body_teacher .= $email_body;
- $email_body_teacher .= "\n".get_lang('Formula', null, $email_language)."\n";
- $email_body_teacher .= api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'), null, null, $email_language)."\n";
- $email_body_teacher .= get_lang('Manager', null, $email_language).' '.api_get_setting('siteName')."\n";
- $email_body_teacher .= get_lang('Phone', null, $email_language).': '.api_get_setting('administratorTelephone')."\n";
- $email_body_teacher .= get_lang('Email', null, $email_language).': '.api_get_setting('emailAdministrator', null, $email_language)."\n";
- $email_body_teacher .= "\n".get_lang('CourseRequestLegalNote', null, $email_language)."\n";
-
- $sender_name_admin = $recipient_name_admin;
- $sender_email_admin = $recipient_email_admin;
- $recipient_name_teacher = $sender_name_teacher;
- $recipient_email_teacher = $sender_email_teacher;
- $additionalParameters = array(
- 'smsType' => SmsPlugin::COURSE_OPENING_REQUEST_CODE_REGISTERED,
- 'userId' => $user_info['user_id'],
- 'courseCode' => $wanted_code
- );
- api_mail_html(
- $recipient_name_teacher,
- $recipient_email_teacher,
- $email_subject,
- $email_body_teacher,
- $sender_name_admin,
- $sender_email_admin,
- null,
- null,
- null,
- $additionalParameters
- );
- return $last_insert_id;
- }
-
- public static function update_course_request(
- $id,
- $wanted_code,
- $title,
- $description,
- $category_code,
- $course_language,
- $objectives,
- $target_audience,
- $user_id,
- $exemplary_content
- ) {
- $id = (int) $id;
- $wanted_code = trim($wanted_code);
- $user_id = (int) $user_id;
- $exemplary_content = (bool) $exemplary_content ? 1 : 0;
- if ($wanted_code == '') {
- return false;
- }
- if ($user_id <= 0) {
- return false;
- }
-
- $course_request_info = self::get_course_request_info($id);
- if (!is_array($course_request_info)) {
- return false;
- }
- $code = $wanted_code;
- $tutor_name = $course_request_info['tutor_name'];
- $directory = $course_request_info['directory'];
- $visual_code = $course_request_info['visual_code'];
- $request_date = $course_request_info['request_date'];
- $status = $course_request_info['status'];
- $info = $course_request_info['info'];
- if ($wanted_code != $course_request_info['code']) {
- if (self::course_code_exists($wanted_code)) {
- return false;
- }
- $keys = AddCourse::define_course_keys($wanted_code, '');
- if (count($keys)) {
- $visual_code = $keys['currentCourseCode'];
- $code = $keys['currentCourseId'];
- $db_name = $keys['currentCourseDbName'];
- $directory = $keys['currentCourseRepository'];
- } else {
- return false;
- }
- }
- if ($user_id != $course_request_info['code']) {
- $user_info = api_get_user_info($user_id);
- if (is_array($user_info)) {
- $tutor_name = api_get_person_name(
- $user_info['firstname'],
- $user_info['lastname'],
- null,
- null,
- $course_language
- );
- } else {
- $user_id = $course_request_info['code'];
- }
- }
- if ($course_language != $course_request_info['course_language']) {
- $user_info = api_get_user_info($user_id);
- if (is_array($user_info)) {
- $tutor_name = api_get_person_name(
- $user_info['firstname'],
- $user_info['lastname'],
- null,
- null,
- $course_language
- );
- }
- }
-
- $sql = sprintf('UPDATE %s SET
- code = "%s", user_id = "%s", directory = "%s", db_name = "%s",
- course_language = "%s", title = "%s", description = "%s", category_code = "%s",
- tutor_name = "%s", visual_code = "%s", request_date = "%s",
- objetives = "%s", target_audience = "%s", status = "%s", info = "%s", exemplary_content = "%s"
- WHERE id = '.$id, Database::get_main_table(TABLE_MAIN_COURSE_REQUEST),
- Database::escape_string($code),
- intval($user_id),
- Database::escape_string($directory),
- Database::escape_string($db_name),
- Database::escape_string($course_language),
- Database::escape_string($title),
- Database::escape_string($description),
- Database::escape_string($category_code),
- Database::escape_string($tutor_name),
- Database::escape_string($visual_code),
- Database::escape_string($request_date),
- Database::escape_string($objectives),
- Database::escape_string($target_audience),
- Database::escape_string($status),
- Database::escape_string($info),
- Database::escape_string($exemplary_content)
- );
- $result_sql = Database::query($sql);
- return $result_sql !== false;
- }
-
- public static function delete_course_request($id)
- {
- $id = (int) $id;
- $sql = "DELETE FROM ".Database::get_main_table(TABLE_MAIN_COURSE_REQUEST)."
- WHERE id = ".$id;
- $result = Database::query($sql);
- return $result !== false;
- }
-
- public static function count_course_requests($status = null)
- {
- $course_table = Database::get_main_table(TABLE_MAIN_COURSE_REQUEST);
- if (is_null($status)) {
- $sql = "SELECT COUNT(id) AS number FROM ".$course_table;
- } else {
- $status = (int) $status;
- $sql = "SELECT COUNT(id) AS number FROM ".$course_table."
- WHERE status = ".$status;
- }
- $result = Database::fetch_array(Database::query($sql));
- if (is_array($result)) {
- return $result['number'];
- }
- return false;
- }
-
- public static function get_course_request_info($id)
- {
- $id = (int) $id;
- $sql = "SELECT *
- FROM ".Database::get_main_table(TABLE_MAIN_COURSE_REQUEST)."
- WHERE id = ".$id;
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0) {
- return Database::fetch_array($result);
- }
- return false;
- }
-
- public static function get_course_request_code($id)
- {
- $id = (int) $id;
- $sql = "SELECT code
- FROM ".Database::get_main_table(TABLE_MAIN_COURSE_REQUEST)."
- WHERE id = ".$id;
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0) {
- $result_array = Database::fetch_array($result, 'NUM');
- if (is_array($result_array)) {
- return $result_array[0];
- }
- }
- return false;
- }
-
- public static function accept_course_request($id)
- {
- $id = (int) $id;
-
- $course_request_info = self::get_course_request_info($id);
- if (!is_array($course_request_info)) {
- return false;
- }
-
-
- $user_id = (int) $course_request_info['user_id'];
- if ($user_id <= 0) {
- return false;
- }
- $user_info = api_get_user_info($user_id);
- if (!is_array($user_info)) {
- return false;
- }
-
- $params = array();
- $params['title'] = $course_request_info['title'];
- $params['course_category'] = $course_request_info['category_code'];
- $params['course_language'] = $course_request_info['course_language'];
- $params['exemplary_content'] = intval($course_request_info['exemplary_content']) > 0;
- $params['wanted_code'] = $course_request_info['code'];
- $params['user_id'] = $course_request_info['user_id'];
- $params['tutor_name'] = api_get_person_name($user_info['firstname'], $user_info['lastname']);
- $course_info = CourseManager::create_course($params);
- if (!empty($course_info)) {
-
- $sql = "UPDATE ".Database::get_main_table(TABLE_MAIN_COURSE_REQUEST)."
- SET status = ".COURSE_REQUEST_ACCEPTED."
- WHERE id = ".$id;
- Database::query($sql);
-
-
- $email_language = api_get_setting('platformLanguage');
- $email_subject = sprintf(get_lang('CourseRequestAcceptedEmailSubject', null, $email_language), '['.api_get_setting('siteName').']', $course_info['code']);
- $email_body = get_lang('Dear', null, $email_language).' ';
- $email_body .= api_get_person_name($user_info['firstname'], $user_info['lastname'], null, null, $email_language).",\n\n";
- $email_body .= sprintf(
- get_lang(
- 'CourseRequestAcceptedEmailText',
- null,
- $email_language
- ),
- $course_info['code'],
- $course_info['code'],
- api_get_path(WEB_COURSE_PATH).$course_info['directory'].'/'
- )."\n";
- $email_body .= "\n".get_lang('Formula', null, $email_language)."\n";
- $email_body .= api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'), null, null, $email_language)."\n";
- $email_body .= get_lang('Manager', null, $email_language).' '.api_get_setting('siteName')."\n";
- $email_body .= get_lang('Phone', null, $email_language).': '.api_get_setting('administratorTelephone')."\n";
- $email_body .= get_lang('Email', null, $email_language).': '.api_get_setting('emailAdministrator', null, $email_language)."\n";
- $email_body .= "\n".get_lang('CourseRequestLegalNote', null, $email_language)."\n";
- $sender_name = api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'), null, PERSON_NAME_EMAIL_ADDRESS);
- $sender_email = api_get_setting('emailAdministrator');
- $recipient_name = api_get_person_name($user_info['firstname'], $user_info['lastname'], null, PERSON_NAME_EMAIL_ADDRESS);
- $recipient_email = $user_info['mail'];
- $additionalParameters = array(
- 'smsType' => SmsPlugin::COURSE_OPENING_REQUEST_CODE_APPROVED,
- 'userId' => $user_id,
- 'courseCode' => $course_info['code']
- );
- api_mail_html(
- $recipient_name,
- $recipient_email,
- $email_subject,
- $email_body,
- $sender_name,
- $sender_email,
- null,
- null,
- null,
- $additionalParameters
- );
- return $course_info['code'];
- }
- return false;
- }
-
- public static function reject_course_request($id)
- {
- $id = (int) $id;
-
- $course_request_info = self::get_course_request_info($id);
- if (!is_array($course_request_info)) {
- return false;
- }
- $user_id = intval($course_request_info['user_id']);
- if ($user_id <= 0) {
- return false;
- }
- $user_info = api_get_user_info($user_id);
- if (!is_array($user_info)) {
- return false;
- }
- $code = $course_request_info['code'];
- $sql = "UPDATE ".Database::get_main_table(TABLE_MAIN_COURSE_REQUEST)."
- SET status = ".COURSE_REQUEST_REJECTED."
- WHERE id = ".$id;
- if (Database::query($sql) === false) {
- return false;
- }
-
-
- $email_language = api_get_setting('platformLanguage');
- $email_subject = sprintf(get_lang('CourseRequestRejectedEmailSubject', null, $email_language), '['.api_get_setting('siteName').']', $code);
- $email_body = get_lang('Dear', null, $email_language).' ';
- $email_body .= api_get_person_name($user_info['firstname'], $user_info['lastname'], null, null, $email_language).",\n\n";
- $email_body .= sprintf(get_lang('CourseRequestRejectedEmailText', null, $email_language), $code)."\n";
- $email_body .= "\n".get_lang('Formula', null, $email_language)."\n";
- $email_body .= api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'), null, null, $email_language)."\n";
- $email_body .= get_lang('Manager', null, $email_language).' '.api_get_setting('siteName')."\n";
- $email_body .= get_lang('Phone', null, $email_language).': '.api_get_setting('administratorTelephone')."\n";
- $email_body .= get_lang('Email', null, $email_language).': '.api_get_setting('emailAdministrator', null, $email_language)."\n";
- $email_body .= "\n".get_lang('CourseRequestLegalNote', null, $email_language)."\n";
- $sender_name = api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'), null, PERSON_NAME_EMAIL_ADDRESS);
- $sender_email = api_get_setting('emailAdministrator');
- $recipient_name = api_get_person_name($user_info['firstname'], $user_info['lastname'], null, PERSON_NAME_EMAIL_ADDRESS);
- $recipient_email = $user_info['mail'];
- $extra_headers = 'Bcc: '.$sender_email;
- $additionalParameters = array(
- 'smsType' => SmsPlugin::COURSE_OPENING_REQUEST_CODE_REJECTED,
- 'userId' => $user_id,
- 'courseCode' => $code
- );
- api_mail_html(
- $recipient_name,
- $recipient_email,
- $email_subject,
- $email_body,
- $sender_name,
- $sender_email,
- null,
- null,
- null,
- $additionalParameters
- );
- return true;
- }
-
- public static function ask_for_additional_info($id)
- {
- $id = (int) $id;
-
- $course_request_info = self::get_course_request_info($id);
- if (!is_array($course_request_info)) {
- return false;
- }
- $user_id = intval($course_request_info['user_id']);
- if ($user_id <= 0) {
- return false;
- }
- $user_info = api_get_user_info($user_id);
- if (!is_array($user_info)) {
- return false;
- }
- $code = $course_request_info['code'];
- $info = intval($course_request_info['info']);
-
- if (!empty($info)) {
- return false;
- }
-
-
- $email_language = api_get_setting('platformLanguage');
- $email_subject = sprintf(get_lang('CourseRequestAskInfoEmailSubject', null, $email_language), '['.api_get_setting('siteName').']', $code);
- $email_body = get_lang('Dear', null, $email_language).' ';
- $email_body .= api_get_person_name($user_info['firstname'], $user_info['lastname'], null, null, $email_language).",\n\n";
- $email_body .= sprintf(get_lang('CourseRequestAskInfoEmailText', null, $email_language), $code)."\n";
- $email_body .= "\n".get_lang('Formula', null, $email_language)."\n";
- $email_body .= api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'))."\n";
- $email_body .= get_lang('Manager', null, $email_language).' '.api_get_setting('siteName')."\n";
- $email_body .= get_lang('Phone', null, $email_language).': '.api_get_setting('administratorTelephone')."\n";
- $email_body .= get_lang('Email', null, $email_language).': '.api_get_setting('emailAdministrator')."\n";
- $email_body .= "\n".get_lang('CourseRequestLegalNote', null, $email_language)."\n";
- $sender_name = api_get_person_name(
- api_get_setting('administratorName'),
- api_get_setting('administratorSurname'),
- null,
- PERSON_NAME_EMAIL_ADDRESS
- );
- $sender_email = api_get_setting('emailAdministrator');
- $recipient_name = api_get_person_name($user_info['firstname'], $user_info['lastname'], null, PERSON_NAME_EMAIL_ADDRESS);
- $recipient_email = $user_info['mail'];
- $extra_headers = 'Bcc: '.$sender_email;
- $additionalParameters = array(
- 'smsType' => SmsPlugin::COURSE_OPENING_REQUEST_CODE,
- 'userId' => $user_id,
- 'courseCode' => $code
- );
- $result = api_mail_html(
- $recipient_name,
- $recipient_email,
- $email_subject,
- $email_body,
- $sender_name,
- $sender_email,
- null,
- null,
- null,
- $additionalParameters
- );
- if (!$result) {
- return false;
- }
-
- $sql = "UPDATE ".Database::get_main_table(TABLE_MAIN_COURSE_REQUEST)."
- SET info = 1 WHERE id = ".$id;
- $result = Database::query($sql) !== false;
- return $result;
- }
-
- public static function additional_info_asked($id)
- {
- $id = (int) $id;
- $sql = "SELECT id FROM ".Database::get_main_table(TABLE_MAIN_COURSE_REQUEST)."
- WHERE (id = ".$id." AND info > 0)";
- $result = Database::num_rows(Database::query($sql));
- return !empty($result);
- }
- }
|