@@ -26,14 +26,14 @@ |
||
26 | 26 | * Redirect to the correct script to handle this type of upload |
27 | 27 | */ |
28 | 28 | switch ($_SESSION['my_tool']) { |
29 | - case TOOL_LEARNPATH: |
|
30 | - require 'upload.scorm.php'; |
|
31 | - break; |
|
32 | - //the following cases need to be distinguished later on |
|
33 | - case TOOL_DROPBOX: |
|
34 | - case TOOL_STUDENTPUBLICATION: |
|
35 | - case TOOL_DOCUMENT: |
|
36 | - default: |
|
37 | - require 'upload.document.php'; |
|
38 | - break; |
|
29 | + case TOOL_LEARNPATH: |
|
30 | + require 'upload.scorm.php'; |
|
31 | + break; |
|
32 | + //the following cases need to be distinguished later on |
|
33 | + case TOOL_DROPBOX: |
|
34 | + case TOOL_STUDENTPUBLICATION: |
|
35 | + case TOOL_DOCUMENT: |
|
36 | + default: |
|
37 | + require 'upload.document.php'; |
|
38 | + break; |
|
39 | 39 | } |
@@ -55,56 +55,56 @@ |
||
55 | 55 | } |
56 | 56 | |
57 | 57 | switch ($action) { |
58 | - case 'chatheartbeat': |
|
59 | - $chat->heartbeat(); |
|
60 | - break; |
|
61 | - case 'closechat': |
|
62 | - $chat->close(); |
|
63 | - break; |
|
64 | - case 'sendchat': |
|
65 | - $chat->send(api_get_user_id(), $to_user_id, $message); |
|
66 | - break; |
|
67 | - case 'startchatsession': |
|
68 | - $chat->startSession(); |
|
69 | - break; |
|
70 | - case 'set_status': |
|
71 | - $status = isset($_REQUEST['status']) ? intval($_REQUEST['status']) : 0; |
|
72 | - $chat->setUserStatus($status); |
|
73 | - break; |
|
74 | - case 'create_room': |
|
75 | - $room = VideoChat::getChatRoomByUsers(api_get_user_id(), $to_user_id); |
|
76 | - |
|
77 | - if ($room === false) { |
|
78 | - $createdRoom = VideoChat::createRoom(api_get_user_id(), $to_user_id); |
|
79 | - |
|
80 | - if ($createdRoom === false) { |
|
81 | - echo Display::return_message(get_lang('ChatRoomNotCreated'), 'error'); |
|
82 | - break; |
|
58 | + case 'chatheartbeat': |
|
59 | + $chat->heartbeat(); |
|
60 | + break; |
|
61 | + case 'closechat': |
|
62 | + $chat->close(); |
|
63 | + break; |
|
64 | + case 'sendchat': |
|
65 | + $chat->send(api_get_user_id(), $to_user_id, $message); |
|
66 | + break; |
|
67 | + case 'startchatsession': |
|
68 | + $chat->startSession(); |
|
69 | + break; |
|
70 | + case 'set_status': |
|
71 | + $status = isset($_REQUEST['status']) ? intval($_REQUEST['status']) : 0; |
|
72 | + $chat->setUserStatus($status); |
|
73 | + break; |
|
74 | + case 'create_room': |
|
75 | + $room = VideoChat::getChatRoomByUsers(api_get_user_id(), $to_user_id); |
|
76 | + |
|
77 | + if ($room === false) { |
|
78 | + $createdRoom = VideoChat::createRoom(api_get_user_id(), $to_user_id); |
|
79 | + |
|
80 | + if ($createdRoom === false) { |
|
81 | + echo Display::return_message(get_lang('ChatRoomNotCreated'), 'error'); |
|
82 | + break; |
|
83 | + } |
|
84 | + |
|
85 | + $room = VideoChat::getChatRoomByUsers(api_get_user_id(), $to_user_id); |
|
83 | 86 | } |
84 | 87 | |
85 | - $room = VideoChat::getChatRoomByUsers(api_get_user_id(), $to_user_id); |
|
86 | - } |
|
87 | - |
|
88 | - $videoChatUrl = api_get_path(WEB_LIBRARY_JS_PATH) . "chat/video.php?room={$room['id']}"; |
|
89 | - $videoChatLink = Display::url( |
|
90 | - Display::returnFontAwesomeIcon('video-camera') . get_lang('StartVideoChat'), |
|
91 | - $videoChatUrl |
|
92 | - ); |
|
93 | - |
|
94 | - $chat->send( |
|
95 | - api_get_user_id(), |
|
96 | - $to_user_id, |
|
97 | - $videoChatLink, |
|
98 | - false, |
|
99 | - false |
|
100 | - ); |
|
101 | - |
|
102 | - echo Display::tag('p', $videoChatLink, ['class' => 'lead']); |
|
103 | - break; |
|
104 | - case 'notify_not_support': |
|
105 | - $chat->send(api_get_user_id(), $to_user_id, get_lang('TheXUserBrowserDoesNotSupportWebRTC')); |
|
106 | - break; |
|
107 | - default: |
|
108 | - echo ''; |
|
88 | + $videoChatUrl = api_get_path(WEB_LIBRARY_JS_PATH) . "chat/video.php?room={$room['id']}"; |
|
89 | + $videoChatLink = Display::url( |
|
90 | + Display::returnFontAwesomeIcon('video-camera') . get_lang('StartVideoChat'), |
|
91 | + $videoChatUrl |
|
92 | + ); |
|
93 | + |
|
94 | + $chat->send( |
|
95 | + api_get_user_id(), |
|
96 | + $to_user_id, |
|
97 | + $videoChatLink, |
|
98 | + false, |
|
99 | + false |
|
100 | + ); |
|
101 | + |
|
102 | + echo Display::tag('p', $videoChatLink, ['class' => 'lead']); |
|
103 | + break; |
|
104 | + case 'notify_not_support': |
|
105 | + $chat->send(api_get_user_id(), $to_user_id, get_lang('TheXUserBrowserDoesNotSupportWebRTC')); |
|
106 | + break; |
|
107 | + default: |
|
108 | + echo ''; |
|
109 | 109 | } |
110 | 110 | exit; |
@@ -15,52 +15,52 @@ |
||
15 | 15 | } |
16 | 16 | |
17 | 17 | switch ($_REQUEST['action']) { |
18 | - case "get": |
|
19 | - print storage_get($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey']); |
|
20 | - break; |
|
21 | - case "set": |
|
22 | - if (storage_can_set($_REQUEST['svuser'])) { |
|
23 | - print storage_set($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey'], $_REQUEST['svvalue']); |
|
24 | - } |
|
25 | - break; |
|
26 | - case "getall": |
|
27 | - print storage_getall($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco']); |
|
28 | - break; |
|
29 | - case "stackpush": |
|
30 | - if (storage_can_set($_REQUEST['svuser'])) { |
|
31 | - print storage_stack_push($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey'], $_REQUEST['svvalue']); |
|
32 | - } |
|
33 | - break; |
|
34 | - case "stackpop": |
|
35 | - if (storage_can_set($_REQUEST['svuser'])) { |
|
36 | - print storage_stack_pop($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey']); |
|
37 | - } |
|
38 | - break; |
|
39 | - case "stacklength": |
|
40 | - print storage_stack_length($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey']); |
|
41 | - break; |
|
42 | - case "stackclear": |
|
43 | - if (storage_can_set($_REQUEST['svuser'])) { |
|
44 | - print storage_stack_clear($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey']); |
|
45 | - } |
|
46 | - break; |
|
47 | - case "stackgetall": |
|
48 | - if (storage_can_set($_REQUEST['svuser'])) |
|
49 | - print storage_stack_getall($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey']); |
|
50 | - break; |
|
51 | - case "getposition": |
|
52 | - print storage_get_position($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey'], $_REQUEST['svasc']); |
|
53 | - break; |
|
54 | - case "getleaders": |
|
55 | - print storage_get_leaders($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey'], $_REQUEST['svasc'], $_REQUEST['svlength']); |
|
56 | - break; |
|
57 | - case "usersgetall": |
|
58 | -// security issue |
|
59 | - print "NOT allowed, security issue, see sources"; |
|
60 | -// print storage_get_all_users(); |
|
61 | - break; |
|
62 | - default: |
|
63 | - // Do nothing |
|
18 | + case "get": |
|
19 | + print storage_get($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey']); |
|
20 | + break; |
|
21 | + case "set": |
|
22 | + if (storage_can_set($_REQUEST['svuser'])) { |
|
23 | + print storage_set($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey'], $_REQUEST['svvalue']); |
|
24 | + } |
|
25 | + break; |
|
26 | + case "getall": |
|
27 | + print storage_getall($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco']); |
|
28 | + break; |
|
29 | + case "stackpush": |
|
30 | + if (storage_can_set($_REQUEST['svuser'])) { |
|
31 | + print storage_stack_push($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey'], $_REQUEST['svvalue']); |
|
32 | + } |
|
33 | + break; |
|
34 | + case "stackpop": |
|
35 | + if (storage_can_set($_REQUEST['svuser'])) { |
|
36 | + print storage_stack_pop($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey']); |
|
37 | + } |
|
38 | + break; |
|
39 | + case "stacklength": |
|
40 | + print storage_stack_length($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey']); |
|
41 | + break; |
|
42 | + case "stackclear": |
|
43 | + if (storage_can_set($_REQUEST['svuser'])) { |
|
44 | + print storage_stack_clear($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey']); |
|
45 | + } |
|
46 | + break; |
|
47 | + case "stackgetall": |
|
48 | + if (storage_can_set($_REQUEST['svuser'])) |
|
49 | + print storage_stack_getall($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey']); |
|
50 | + break; |
|
51 | + case "getposition": |
|
52 | + print storage_get_position($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey'], $_REQUEST['svasc']); |
|
53 | + break; |
|
54 | + case "getleaders": |
|
55 | + print storage_get_leaders($_REQUEST['svuser'], $_REQUEST['svcourse'], $_REQUEST['svsco'], $_REQUEST['svkey'], $_REQUEST['svasc'], $_REQUEST['svlength']); |
|
56 | + break; |
|
57 | + case "usersgetall": |
|
58 | + // security issue |
|
59 | + print "NOT allowed, security issue, see sources"; |
|
60 | + // print storage_get_all_users(); |
|
61 | + break; |
|
62 | + default: |
|
63 | + // Do nothing |
|
64 | 64 | } |
65 | 65 | |
66 | 66 | function storage_can_set($sv_user) { |
@@ -171,28 +171,53 @@ discard block |
||
171 | 171 | } |
172 | 172 | |
173 | 173 | switch ($action) { |
174 | - case 'subscribe_user_with_password': |
|
175 | - $courses_controller->subscribe_user( |
|
176 | - isset($_POST['subscribe_user_with_password']) ? $_POST['subscribe_user_with_password'] : '', |
|
177 | - isset($_POST['search_term']) ? $_POST['search_term'] : '', |
|
178 | - isset($_POST['category_code']) ? $_POST['category_code'] : '' |
|
179 | - ); |
|
180 | - break; |
|
181 | - case 'createcoursecategory': |
|
182 | - $courses_controller->categories_list($action); |
|
183 | - break; |
|
184 | - case 'deletecoursecategory': |
|
185 | - $courses_controller->courses_list($action); |
|
186 | - break; |
|
187 | - case 'sortmycourses': |
|
188 | - $courses_controller->courses_list($action); |
|
189 | - break; |
|
190 | - case 'subscribe': |
|
191 | - if (!$user_can_view_page) { |
|
192 | - api_not_allowed(true); |
|
193 | - } |
|
194 | - |
|
195 | - if (!CoursesAndSessionsCatalog::is(CATALOG_SESSIONS)) { |
|
174 | + case 'subscribe_user_with_password': |
|
175 | + $courses_controller->subscribe_user( |
|
176 | + isset($_POST['subscribe_user_with_password']) ? $_POST['subscribe_user_with_password'] : '', |
|
177 | + isset($_POST['search_term']) ? $_POST['search_term'] : '', |
|
178 | + isset($_POST['category_code']) ? $_POST['category_code'] : '' |
|
179 | + ); |
|
180 | + break; |
|
181 | + case 'createcoursecategory': |
|
182 | + $courses_controller->categories_list($action); |
|
183 | + break; |
|
184 | + case 'deletecoursecategory': |
|
185 | + $courses_controller->courses_list($action); |
|
186 | + break; |
|
187 | + case 'sortmycourses': |
|
188 | + $courses_controller->courses_list($action); |
|
189 | + break; |
|
190 | + case 'subscribe': |
|
191 | + if (!$user_can_view_page) { |
|
192 | + api_not_allowed(true); |
|
193 | + } |
|
194 | + |
|
195 | + if (!CoursesAndSessionsCatalog::is(CATALOG_SESSIONS)) { |
|
196 | + $courses_controller->courses_categories( |
|
197 | + $action, |
|
198 | + $categoryCode, |
|
199 | + null, |
|
200 | + null, |
|
201 | + null, |
|
202 | + $limit |
|
203 | + ); |
|
204 | + } else { |
|
205 | + header('Location: ' . api_get_self()); |
|
206 | + exit; |
|
207 | + } |
|
208 | + break; |
|
209 | + case 'display_random_courses': |
|
210 | + if (!$user_can_view_page) { |
|
211 | + api_not_allowed(true); |
|
212 | + } |
|
213 | + |
|
214 | + $courses_controller->courses_categories($action); |
|
215 | + break; |
|
216 | + case 'display_courses': |
|
217 | + if (!$user_can_view_page) { |
|
218 | + api_not_allowed(true); |
|
219 | + } |
|
220 | + |
|
196 | 221 | $courses_controller->courses_categories( |
197 | 222 | $action, |
198 | 223 | $categoryCode, |
@@ -201,127 +226,102 @@ discard block |
||
201 | 226 | null, |
202 | 227 | $limit |
203 | 228 | ); |
204 | - } else { |
|
205 | - header('Location: ' . api_get_self()); |
|
206 | - exit; |
|
207 | - } |
|
208 | - break; |
|
209 | - case 'display_random_courses': |
|
210 | - if (!$user_can_view_page) { |
|
211 | - api_not_allowed(true); |
|
212 | - } |
|
213 | - |
|
214 | - $courses_controller->courses_categories($action); |
|
215 | - break; |
|
216 | - case 'display_courses': |
|
217 | - if (!$user_can_view_page) { |
|
218 | - api_not_allowed(true); |
|
219 | - } |
|
220 | - |
|
221 | - $courses_controller->courses_categories( |
|
222 | - $action, |
|
223 | - $categoryCode, |
|
224 | - null, |
|
225 | - null, |
|
226 | - null, |
|
227 | - $limit |
|
228 | - ); |
|
229 | - break; |
|
230 | - case 'display_sessions': |
|
231 | - if (!$user_can_view_page) { |
|
232 | - api_not_allowed(true); |
|
233 | - } |
|
234 | - |
|
235 | - $courses_controller->sessionsList($action, $nameTools, $limit); |
|
236 | - break; |
|
237 | - case 'subscribe_to_session': |
|
238 | - if (!$user_can_view_page) { |
|
239 | - api_not_allowed(true); |
|
240 | - } |
|
241 | - |
|
242 | - $userId = api_get_user_id(); |
|
243 | - $confirmed = isset($_GET['confirm']); |
|
244 | - $sessionId = intval($_GET['session_id']); |
|
245 | - |
|
246 | - if (empty($userId)) { |
|
247 | - api_not_allowed(); |
|
248 | - exit; |
|
249 | - } |
|
250 | - |
|
251 | - if (!$confirmed) { |
|
252 | - $template = new Template(null, false, false, false, false, false); |
|
253 | - $template->assign('session_id', $sessionId); |
|
254 | - |
|
255 | - $layout = $template->get_template('auth/confirm_session_subscription.tpl'); |
|
256 | - |
|
257 | - echo $template->fetch($layout); |
|
258 | - exit; |
|
259 | - } |
|
260 | - |
|
261 | - $registrationAllowed = api_get_setting('catalog_allow_session_auto_subscription'); |
|
262 | - if ($registrationAllowed === 'true') { |
|
263 | - $entityManager = Database::getManager(); |
|
264 | - $repository = $entityManager->getRepository('ChamiloCoreBundle:SequenceResource'); |
|
265 | - |
|
266 | - $sequences = $repository->getRequirements( |
|
267 | - $sessionId, |
|
268 | - SequenceResource::SESSION_TYPE |
|
269 | - ); |
|
229 | + break; |
|
230 | + case 'display_sessions': |
|
231 | + if (!$user_can_view_page) { |
|
232 | + api_not_allowed(true); |
|
233 | + } |
|
234 | + |
|
235 | + $courses_controller->sessionsList($action, $nameTools, $limit); |
|
236 | + break; |
|
237 | + case 'subscribe_to_session': |
|
238 | + if (!$user_can_view_page) { |
|
239 | + api_not_allowed(true); |
|
240 | + } |
|
241 | + |
|
242 | + $userId = api_get_user_id(); |
|
243 | + $confirmed = isset($_GET['confirm']); |
|
244 | + $sessionId = intval($_GET['session_id']); |
|
270 | 245 | |
271 | - if (count($sequences) > 0) { |
|
272 | - $requirementsData = SequenceResourceManager::checkRequirementsForUser( |
|
273 | - $sequences, |
|
274 | - SequenceResource::SESSION_TYPE, |
|
275 | - $userId |
|
246 | + if (empty($userId)) { |
|
247 | + api_not_allowed(); |
|
248 | + exit; |
|
249 | + } |
|
250 | + |
|
251 | + if (!$confirmed) { |
|
252 | + $template = new Template(null, false, false, false, false, false); |
|
253 | + $template->assign('session_id', $sessionId); |
|
254 | + |
|
255 | + $layout = $template->get_template('auth/confirm_session_subscription.tpl'); |
|
256 | + |
|
257 | + echo $template->fetch($layout); |
|
258 | + exit; |
|
259 | + } |
|
260 | + |
|
261 | + $registrationAllowed = api_get_setting('catalog_allow_session_auto_subscription'); |
|
262 | + if ($registrationAllowed === 'true') { |
|
263 | + $entityManager = Database::getManager(); |
|
264 | + $repository = $entityManager->getRepository('ChamiloCoreBundle:SequenceResource'); |
|
265 | + |
|
266 | + $sequences = $repository->getRequirements( |
|
267 | + $sessionId, |
|
268 | + SequenceResource::SESSION_TYPE |
|
276 | 269 | ); |
277 | 270 | |
278 | - $continueWithSubscription = SequenceResourceManager::checkSequenceAreCompleted($requirementsData); |
|
271 | + if (count($sequences) > 0) { |
|
272 | + $requirementsData = SequenceResourceManager::checkRequirementsForUser( |
|
273 | + $sequences, |
|
274 | + SequenceResource::SESSION_TYPE, |
|
275 | + $userId |
|
276 | + ); |
|
277 | + |
|
278 | + $continueWithSubscription = SequenceResourceManager::checkSequenceAreCompleted($requirementsData); |
|
279 | 279 | |
280 | - if (!$continueWithSubscription) { |
|
281 | - header('Location: ' . api_get_path(WEB_CODE_PATH) . 'auth/courses.php'); |
|
282 | - exit; |
|
280 | + if (!$continueWithSubscription) { |
|
281 | + header('Location: ' . api_get_path(WEB_CODE_PATH) . 'auth/courses.php'); |
|
282 | + exit; |
|
283 | + } |
|
283 | 284 | } |
284 | - } |
|
285 | 285 | |
286 | - SessionManager::subscribe_users_to_session( |
|
287 | - $_GET['session_id'], |
|
288 | - array($userId), |
|
289 | - SESSION_VISIBLE_READ_ONLY, |
|
290 | - false |
|
291 | - ); |
|
286 | + SessionManager::subscribe_users_to_session( |
|
287 | + $_GET['session_id'], |
|
288 | + array($userId), |
|
289 | + SESSION_VISIBLE_READ_ONLY, |
|
290 | + false |
|
291 | + ); |
|
292 | 292 | |
293 | - $coursesList = SessionManager::get_course_list_by_session_id($_GET['session_id']); |
|
294 | - $count = count($coursesList); |
|
295 | - $url = ''; |
|
296 | - |
|
297 | - if ($count <= 0) { |
|
298 | - // no course in session -> return to catalog |
|
299 | - $url = api_get_path(WEB_CODE_PATH) . 'auth/courses.php'; |
|
300 | - } elseif ($count == 1) { |
|
301 | - // only one course, so redirect directly to this course |
|
302 | - foreach ($coursesList as $course) { |
|
303 | - $url = api_get_path(WEB_COURSE_PATH) . $course['directory'] . '/index.php?id_session=' . intval($_GET['session_id']); |
|
293 | + $coursesList = SessionManager::get_course_list_by_session_id($_GET['session_id']); |
|
294 | + $count = count($coursesList); |
|
295 | + $url = ''; |
|
296 | + |
|
297 | + if ($count <= 0) { |
|
298 | + // no course in session -> return to catalog |
|
299 | + $url = api_get_path(WEB_CODE_PATH) . 'auth/courses.php'; |
|
300 | + } elseif ($count == 1) { |
|
301 | + // only one course, so redirect directly to this course |
|
302 | + foreach ($coursesList as $course) { |
|
303 | + $url = api_get_path(WEB_COURSE_PATH) . $course['directory'] . '/index.php?id_session=' . intval($_GET['session_id']); |
|
304 | + } |
|
305 | + } else { |
|
306 | + $url = api_get_path(WEB_CODE_PATH) . 'session/index.php?session_id=' . intval($_GET['session_id']); |
|
304 | 307 | } |
305 | - } else { |
|
306 | - $url = api_get_path(WEB_CODE_PATH) . 'session/index.php?session_id=' . intval($_GET['session_id']); |
|
308 | + header('Location: ' . $url); |
|
309 | + exit; |
|
307 | 310 | } |
308 | - header('Location: ' . $url); |
|
309 | - exit; |
|
310 | - } |
|
311 | - //else show error message? |
|
312 | - break; |
|
313 | - case 'search_tag': |
|
314 | - if (!$user_can_view_page) { |
|
315 | - api_not_allowed(true); |
|
316 | - } |
|
317 | - |
|
318 | - $courses_controller->sessionsListByCoursesTag($limit); |
|
319 | - break; |
|
320 | - case 'search_session': |
|
321 | - if (!$user_can_view_page) { |
|
322 | - api_not_allowed(true); |
|
323 | - } |
|
324 | - |
|
325 | - $courses_controller->sessionListBySearch($limit); |
|
326 | - break; |
|
311 | + //else show error message? |
|
312 | + break; |
|
313 | + case 'search_tag': |
|
314 | + if (!$user_can_view_page) { |
|
315 | + api_not_allowed(true); |
|
316 | + } |
|
317 | + |
|
318 | + $courses_controller->sessionsListByCoursesTag($limit); |
|
319 | + break; |
|
320 | + case 'search_session': |
|
321 | + if (!$user_can_view_page) { |
|
322 | + api_not_allowed(true); |
|
323 | + } |
|
324 | + |
|
325 | + $courses_controller->sessionListBySearch($limit); |
|
326 | + break; |
|
327 | 327 | } |