get_lang($name); } /** * * @return bool */ function is_homepage() { $url = self::server('REQUEST_URI'); $url = explode('?', $url); $url = reset($url); $url = self::server('SERVER_NAME') . $url; $root = api_get_path('WEB_PATH'); $root = str_replace('https://', '', $root); $root = str_replace('http://', '', $root); $index_url = $root . 'index.php'; return $url == $index_url || $url == $root; } /** * * @return bool */ function is_user_portal() { $url = self::server('REQUEST_URI'); $url = explode('?', $url); $url = reset($url); $url = self::server('SERVER_NAME') . $url; $root = api_get_path('WEB_PATH'); $root = str_replace('https://', '', $root); $root = str_replace('http://', '', $root); $index_url = $root . 'user_portal.php'; return $url == $index_url || $url == $root; } /** * */ function accept() { return $this->is_homepage() || $this->is_user_portal(); } /** * Display the search course widget: * * Title * Search form * * Search results */ function run() { if (!$this->accept()) { return; } $this->display_header(); $this->display_form(); $search_term = self::post('search_term'); $action = self::get('action'); $has_content = !empty($search_term) || !empty($action); if ($has_content) { echo '
'; } else { echo '
'; } if (RegisterCourseWidget::factory()->run()) { $result = true; } else { $result = $this->action_display(); } echo '
'; $this->display_footer(); return $result; } function get_url($action = '') { $self = $_SERVER['PHP_SELF']; $parameters = array(); if ($action) { $parameters[self::PARAM_ACTION] = $action; } $parameters = implode('&', $parameters); $parameters = $parameters ? '?' . $parameters : ''; return $self . $parameters; } /** * Handle the display action */ function action_display() { global $charset; $search_term = self::post('search_term'); if ($search_term) { $search_result_for_label = self::get_lang('SearchResultsFor'); $search_term_html = htmlentities($search_term, ENT_QUOTES, $charset); echo "
$search_result_for_label $search_term_html
"; $courses = $this->retrieve_courses($search_term); $this->display_list($courses); } return true; } function display_header() { $search_course_label = self::get_lang('SearchCourse'); echo <<
'; } /** * Display the search course form. */ function display_form() { global $stok; $search_label = self::get_lang('_search'); $self = api_get_self(); $search_term = self::post('search_term'); $form = <<   EOT; echo $form; } /** * * @param array $courses * @return bool */ function display_list($courses) { if (empty($courses)) { return false; } $user_courses = $this->retrieve_user_courses(); $display_coursecode = (api_get_setting('display_coursecode_in_courselist') == 'true'); $display_teacher = (api_get_setting('display_teacher_in_courselist') == 'true'); echo ''; foreach ($courses as $key => $course) { $details = array(); if ($display_coursecode) { $details[] = $course['visual_code']; } if ($display_teacher) { $details[] = $course['tutor']; } $details = implode(' - ', $details); $title = $course['title']; $href = api_get_path(WEB_PATH) . 'courses/' . $course['code'] .'/index.php'; echo ''; } echo '
' . "$title
$details
"; if (!api_is_anonymous()) { if ($course['registration_code']) { Display::display_icon('passwordprotected.png', '', array('style' => 'float:left;')); } $this->display_subscribe_icon($course, $user_courses); } echo '
'; return true; } /** * Displays the subscribe icon if subscribing is allowed and * if the user is not yet subscribed to this course * * @global type $stok * @param array $current_course * @param array $user_courses * @return bool */ function display_subscribe_icon($current_course, $user_courses) { global $stok; //Already subscribed $code = $current_course['code']; if (isset($user_courses[$code])) { echo self::get_lang('AlreadySubscribed'); return false; } //Not authorized to subscribe if ($current_course['subscribe'] != SUBSCRIBE_ALLOWED) { echo self::get_lang('SubscribingNotAllowed'); return false; } //Subscribe form $self = $_SERVER['PHP_SELF']; echo << EOT; $search_term = $this->post('search_term'); if ($search_term) { $search_term = Security::remove_XSS($search_term); echo << EOT; } $web_path = api_get_path(WEB_PATH); $subscribe_label = get_lang('Subscribe'); echo <<$subscribe_label EOT; return true; } /** * DB functions - DB functions - DB functions */ /** * Search courses that match the search term. * Search is done on the code, title and tutor fields. * * @param string $search_term * @return array */ function retrieve_courses($search_term) { if (empty($search_term)) { return array(); } $search_term = Database::escape_string($search_term); $course_table = Database::get_main_table(TABLE_MAIN_COURSE); if (api_is_anonymous()) { $course_fiter = 'visibility = ' . COURSE_VISIBILITY_OPEN_WORLD; } else { $course_fiter = 'visibility = ' . COURSE_VISIBILITY_OPEN_WORLD . ' OR '; $course_fiter .= 'visibility = ' . COURSE_VISIBILITY_OPEN_PLATFORM . ' OR '; $course_fiter .= '(visibility = ' . COURSE_VISIBILITY_REGISTERED . ' AND subscribe = 1)'; } $sql = << $code, 'directory' => $row['directory'], 'db' => $row['db_name'], 'visual_code' => $row['visual_code'], 'title' => $row['title'], 'tutor' => $row['tutor_name'], 'subscribe' => $row['subscribe'], 'unsubscribe' => $row['unsubscribe'] ); } return $result; } /** * Retrieves courses that the user is subscribed to * * @param int $user_id * @return array */ function retrieve_user_courses($user_id = null) { if (is_null($user_id)) { global $_user; $user_id = $_user['user_id']; } $course_table = Database::get_main_table(TABLE_MAIN_COURSE); $user_course_table = Database::get_main_table(TABLE_MAIN_COURSE_USER); $user_id = intval($user_id); $sql_select_courses = "SELECT course.code k, course.visual_code vc, course.subscribe subscr, course.unsubscribe unsubscr, course.title i, course.tutor_name t, course.db_name db, course.directory dir, course_rel_user.status status, course_rel_user.sort sort, course_rel_user.user_course_cat user_course_cat FROM $course_table course, $user_course_table course_rel_user WHERE course.id = course_rel_user.c_id AND course_rel_user.user_id = $user_id ORDER BY course_rel_user.sort ASC"; $result = array(); $resultset = api_sql_query($sql_select_courses, __FILE__, __LINE__); while ($row = Database::fetch_array($resultset)) { $code = $row['k']; $result[$code] = array( 'db' => $row['db'], 'code' => $code, 'visual_code' => $row['vc'], 'title' => $row['i'], 'directory' => $row['dir'], 'status' => $row['status'], 'tutor' => $row['t'], 'subscribe' => $row['subscr'], 'unsubscribe' => $row['unsubscr'], 'sort' => $row['sort'], 'user_course_category' => $row['user_course_cat']); } return $result; } /* * Utility functions - Utility functions - Utility functions */ /** * Removes from $courses all courses the user is subscribed to. * * @global array $_user * @param array $courses * @return array */ function filter_out_user_courses($courses) { if (empty($courses)) { return $courses; } global $_user; $user_id = $_user['user_id']; $user_courses = $this->retrieve_user_courses($user_id); foreach ($user_courses as $key => $value) { unset($courses[$key]); } return $courses; } }