123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * @package chamilo.webservices
- */
- require_once(dirname(__FILE__).'/../inc/global.inc.php');
- $libpath = api_get_path(LIBRARY_PATH);
- require_once($libpath.'sessionmanager.lib.php');
- require_once($libpath.'course.lib.php');
- require_once(dirname(__FILE__).'/webservice.php');
- /**
- * Web services available for the Session module. This class extends the WS class
- */
- class WSSession extends WS {
- /**
- * Creates a session (helper method)
- *
- * @param string Name of the session
- * @param string Start date, use the 'YYYY-MM-DD' format
- * @param string End date, use the 'YYYY-MM-DD' format
- * @param int Access delays of the coach (days before)
- * @param int Access delays of the coach (days after)
- * @param int Nolimit (0 = no limit of time, 1 = limit of time)
- * @param int Visibility
- * @param string User id field name for the coach
- * @param string User id value for the coach
- * @param string Original session id field name (use "chamilo_session_id" to use internal id)
- * @param string Original session id value
- * @param array Array of extra fields
- * @return mixed Generated id in case of success, WSError otherwise
- */
- protected function createSessionHelper($name, $start_date, $end_date, $nb_days_access_before, $nb_days_access_after, $nolimit, $visibility, $user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value, $extras) {
- // Verify that coach exists and get its id
- $user_id = $this->getUserId($user_id_field_name, $user_id_value);
- if($user_id instanceof WSError) {
- return $user_id;
- }
- // Build the date
- $start_date_array = explode('-', $start_date);
- foreach($start_date_array as &$sd_element) {
- $sd_element = intval($sd_element);
- }
- $end_date_array = explode('-', $end_date);
- foreach($end_date_array as &$ed_element) {
- $ed_element = intval($ed_element);
- }
- // Try to create the session
- $session_id = SessionManager::create_session($name, $start_date_array[0], $start_date_array[1], $start_date_array[2], $end_date_array[0], $end_date_array[1], $end_date_array[2], (int)$nb_days_access_before, (int)$nb_days_access_after, (int)$nolimit, $user_id, 0, (int)$visibility);
- if(!is_int($session_id)) {
- return new WSError(301, 'Could not create the session');
- } else {
- // Add the Original session id to the extra fields
- $extras_associative = array();
- if($session_id_field_name != "chamilo_session_id") {
- $extras_associative[$session_id_field_name] = $session_id_value;
- }
- foreach($extras as $extra) {
- $extras_associative[$extra['field_name']] = $extra['field_value'];
- }
- // Create the extra fields
- foreach($extras_associative as $fname => $fvalue) {
- SessionManager::create_session_extra_field($fname, 1, $fname);
- SessionManager::update_session_extra_field_value($session_id, $fname, $fvalue);
- }
- return $session_id;
- }
- }
- /**
- * Creates a session
- *
- * @param string API secret key
- * @param string Name of the session
- * @param string Start date, use the 'YYYY-MM-DD' format
- * @param string End date, use the 'YYYY-MM-DD' format
- * @param int Access delays of the coach (days before)
- * @param int Access delays of the coach (days after)
- * @param int Nolimit (0 = no limit of time, 1 = limit of time)
- * @param int Visibility
- * @param string User id field name for the coach
- * @param string User id value for the coach
- * @param string Original session id field name (use "chamilo_session_id" to use internal id)
- * @param string Original session id value
- * @param array Array of extra fields
- * @return int Session id generated
- */
- public function CreateSession($secret_key, $name, $start_date, $end_date, $nb_days_access_before, $nb_days_access_after, $nolimit, $visibility, $user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value, $extras) {
- $verifKey = $this->verifyKey($secret_key);
- if($verifKey instanceof WSError) {
- $this->handleError($verifKey);
- } else {
- $session_id = $this->createSessionHelper($name, $start_date, $end_date, $nb_days_access_before, $nb_days_access_after, $nolimit, $visibility, $user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value, $extras);
- if($session_id instanceof WSError) {
- $this->handleError($session_id);
- } else {
- return $session_id;
- }
- }
- }
- /**
- * Deletes a session (helper method)
- *
- * @param string Session id field name
- * @param string Session id value
- * @return mixed True in case of success, WSError otherwise
- */
- protected function deleteSessionHelper($session_id_field_name, $session_id_value) {
- $session_id = $this->getSessionId($session_id_field_name, $session_id_value);
- if($session_id instanceof WSError) {
- return $session_id;
- } else {
- SessionManager::delete_session($session_id, true);
- return true;
- }
- }
- /**
- * Deletes a session
- *
- * @param string API secret key
- * @param string Session id field name
- * @param string Session id value
- */
- public function DeleteSession($secret_key, $session_id_field_name, $session_id_value) {
- $verifKey = $this->verifyKey($secret_key);
- if($verifKey instanceof WSError) {
- $this->handleError($verifKey);
- } else {
- $result = $this->deleteSessionHelper($session_id_field_name, $session_id_value);
- if($result instanceof WSError) {
- $this->handleError($result);
- }
- }
- }
- /**
- * Edits a session (helper method)
- *
- * @param string Name of the session
- * @param string Start date, use the 'YYYY-MM-DD' format
- * @param string End date, use the 'YYYY-MM-DD' format
- * @param int Access delays of the coach (days before)
- * @param int Access delays of the coach (days after)
- * @param int Nolimit (0 = no limit of time, 1 = limit of time)
- * @param int Visibility
- * @param string User id field name for the coach
- * @param string User id value for the coach
- * @param string Original session id field name (use "chamilo_session_id" to use internal id)
- * @param string Original session id value
- * @param array Array of extra fields
- * @return mixed True on success, WSError otherwise
- */
- protected function editSessionHelper($name, $start_date, $end_date, $nb_days_access_before, $nb_days_access_after, $nolimit, $visibility, $user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value, $extras) {
- $session_id = $this->getSessionId($session_id_field_name, $session_id_value);
- if($session_id instanceof WSError) {
- return $session_id;
- } else {
- // Verify that coach exists and get its id
- $user_id = $this->getUserId($user_id_field_name, $user_id_value);
- if($user_id instanceof WSError) {
- return $user_id;
- }
- // Build the date
- $start_date_array = explode('-', $start_date);
- foreach($start_date_array as &$sd_element) {
- $sd_element = intval($sd_element);
- }
- $end_date_array = explode('-', $end_date);
- foreach($end_date_array as &$ed_element) {
- $ed_element = intval($ed_element);
- }
- $result_id = SessionManager::edit_session($session_id, $name, $start_date_array[0], $start_date_array[1], $start_date_array[2], $end_date_array[0], $end_date_array[1], $end_date_array[2], (int)$nb_days_access_before, (int)$nb_days_access_after, (int)$nolimit, $user_id, 0, (int)$visibility);
- if(!is_int($result_id)) {
- return new WSError(302, 'Could not edit the session');
- } else {
- if(!empty($extras)) {
- $extras_associative = array();
- foreach($extras as $extra) {
- $extras_associative[$extra['field_name']] = $extra['field_value'];
- }
- // Create the extra fields
- foreach($extras_associative as $fname => $fvalue) {
- SessionManager::create_session_extra_field($fname, 1, $fname);
- SessionManager::update_session_extra_field_value($session_id, $fname, $fvalue);
- }
- }
- return true;
- }
- }
- }
- /**
- * Edits a session
- *
- * @param string API secret key
- * @param string Name of the session
- * @param string Start date, use the 'YYYY-MM-DD' format
- * @param string End date, use the 'YYYY-MM-DD' format
- * @param int Access delays of the coach (days before)
- * @param int Access delays of the coach (days after)
- * @param int Nolimit (0 = no limit of time, 1 = limit of time)
- * @param int Visibility
- * @param string User id field name for the coach
- * @param string User id value for the coach
- * @param string Original session id field name (use "chamilo_session_id" to use internal id)
- * @param string Original session id value
- * @param array Array of extra fields
- */
- public function EditSession($secret_key, $name, $start_date, $end_date, $nb_days_access_before, $nb_days_access_after, $nolimit, $visibility, $user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value, $extras) {
- $verifKey = $this->verifyKey($secret_key);
- if($verifKey instanceof WSError) {
- $this->handleError($verifKey);
- } else {
- $result = $this->editSessionHelper($name, $start_date, $end_date, $nb_days_access_before, $nb_days_access_after, $nolimit, $visibility, $user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value, $extras);
- if($session_id_value instanceof WSError) {
- $this->handleError($result);
- }
- }
- }
- /**
- * Change user subscription (helper method)
- *
- * @param string User id field name
- * @param string User id value
- * @param string Session id field name
- * @param string Session id value
- * @param int State (1 to subscribe, 0 to unsubscribe)
- * @return mixed True on success, WSError otherwise
- */
- protected function changeUserSubscription($user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value, $state) {
- $session_id = $this->getSessionId($session_id_field_name, $session_id_value);
- if($session_id instanceof WSError) {
- return $session_id;
- } else {
- $user_id = $this->getUserId($user_id_field_name, $user_id_value);
- if($user_id instanceof WSError) {
- return $user_id;
- } else {
- if($state == 1) {
- SessionManager::suscribe_users_to_session($session_id, array($user_id));
- } else {
- $result = SessionManager::unsubscribe_user_from_session($session_id, $user_id);
- if (!$result) {
- return new WSError(303, 'There was an error unsubscribing this user from the session');
- }
- }
- return true;
- }
- }
- }
- /**
- * Subscribe user to a session
- *
- * @param string API secret key
- * @param string User id field name
- * @param string User id value
- * @param string Session id field name
- * @param string Session id value
- */
- public function SubscribeUserToSession($secret_key, $user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value) {
- $verifKey = $this->verifyKey($secret_key);
- if($verifKey instanceof WSError) {
- $this->handleError($verifKey);
- } else {
- $result = $this->changeUserSubscription($user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value, 1);
- if($result instanceof WSError) {
- $this->handleError($result);
- }
- }
- }
- /**
- * Subscribe user to a session
- *
- * @param string API secret key
- * @param string User id field name
- * @param string User id value
- * @param string Session id field name
- * @param string Session id value
- */
- public function UnsubscribeUserFromSession($secret_key, $user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value) {
- $verifKey = $this->verifyKey($secret_key);
- if($verifKey instanceof WSError) {
- $this->handleError($verifKey);
- } else {
- $result = $this->changeUserSubscription($user_id_field_name, $user_id_value, $session_id_field_name, $session_id_value, 0);
- if($result instanceof WSError) {
- $this->handleError($result);
- }
- }
- }
- /**
- * Change course subscription
- *
- * @param string Course id field name
- * @param string Course id value
- * @param string Session id field name
- * @param string Session id value
- * @param int State (1 to subscribe, 0 to unsubscribe)
- * @return mixed True on success, WSError otherwise
- */
- protected function changeCourseSubscription($course_id_field_name, $course_id_value, $session_id_field_name, $session_id_value, $state) {
- $session_id = $this->getSessionId($session_id_field_name, $session_id_value);
- if($session_id instanceof WSError) {
- return $session_id;
- } else {
- $course_id = $this->getCourseId($course_id_field_name, $course_id_value);
- if($course_id instanceof WSError) {
- return $course_id;
- } else {
- if($state == 1) {
- $course_code = CourseManager::get_course_code_from_course_id($course_id);
- SessionManager::add_courses_to_session($session_id, array($course_code));
- return true;
- } else {
- $result = SessionManager::unsubscribe_course_from_session($session_id, $course_id);
- if ($result) {
- return true;
- } else {
- return new WSError(304, 'Error unsubscribing course from session');
- }
- }
- }
- }
- }
- /**
- * Subscribe course to session
- *
- * @param string API secret key
- * @param string Course id field name
- * @param string Course id value
- * @param string Session id field name
- * @param string Session id value
- */
- public function SubscribeCourseToSession($secret_key, $course_id_field_name, $course_id_value, $session_id_field_name, $session_id_value) {
- $verifKey = $this->verifyKey($secret_key);
- if($verifKey instanceof WSError) {
- $this->handleError($verifKey);
- } else {
- $result = $this->changeCourseSubscription($course_id_field_name, $course_id_value, $session_id_field_name, $session_id_value, 1);
- if($result instanceof WSError) {
- $this->handleError($result);
- }
- }
- }
- /**
- * Unsubscribe course from session
- *
- * @param string API secret key
- * @param string Course id field name
- * @param string Course id value
- * @param string Session id field name
- * @param string Session id value
- */
- public function UnsubscribeCourseFromSession($secret_key, $course_id_field_name, $course_id_value, $session_id_field_name, $session_id_value) {
- $verifKey = $this->verifyKey($secret_key);
- if($verifKey instanceof WSError) {
- $this->handleError($verifKey);
- } else {
- $result = $this->changeCourseSubscription($course_id_field_name, $course_id_value, $session_id_field_name, $session_id_value, 0);
- if($result instanceof WSError) {
- $this->handleError($result);
- }
- }
- }
- }
|