123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * Class UrlManager
- * This library provides functions for the access_url management.
- * Include/require it in your code to use its functionality.
- *
- * @package chamilo.library
- */
- class UrlManager
- {
- /**
- * Creates a new url access
- *
- * @author Julio Montoya <gugli100@gmail.com>,
- *
- * @param string $url The URL of the site
- * @param string $description The description of the site
- * @param int $active is active or not
- * @return boolean if success
- */
- public static function add($url, $description, $active)
- {
- $tms = time();
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "INSERT INTO $table
- SET url = '".Database::escape_string($url)."',
- description = '".Database::escape_string($description)."',
- active = '".intval($active)."',
- created_by = '".api_get_user_id()."',
- tms = FROM_UNIXTIME(".$tms.")";
- $result = Database::query($sql);
- return $result;
- }
- /**
- * Updates an URL access
- * @author Julio Montoya <gugli100@gmail.com>,
- *
- * @param int $url_id The url id
- * @param string $url
- * @param string $description The description of the site
- * @param int $active is active or not
- * @return boolean if success
- */
- public static function update($url_id, $url, $description, $active)
- {
- $url_id = intval($url_id);
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "UPDATE $table
- SET url = '".Database::escape_string($url)."',
- description = '".Database::escape_string($description)."',
- active = '".intval($active)."',
- created_by = '".api_get_user_id()."',
- tms = '".api_get_utc_datetime()."'
- WHERE id = '$url_id'";
- $result = Database::query($sql);
- return $result;
- }
- /**
- * Deletes an url
- * @author Julio Montoya
- * @param int $id url id
- *
- * @return boolean true if success
- * */
- public static function delete($id)
- {
- $id = intval($id);
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $tableUser = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $tableCourse = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $tableSession = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $tableCourseCategory = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $tableGroup = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USERGROUP);
- $sql = "DELETE FROM $tableCourse WHERE access_url_id = ".$id;
- Database::query($sql);
- /*
- $sql = "DELETE FROM $tableCourseCategory WHERE access_url_id = ".$id;
- Database::query($sql);
- */
- $sql = "DELETE FROM $tableSession WHERE access_url_id = ".$id;
- Database::query($sql);
- $sql = "DELETE FROM $tableGroup WHERE access_url_id = ".$id;
- Database::query($sql);
- $sql = "DELETE FROM $tableUser WHERE access_url_id = ".$id;
- Database::query($sql);
- $sql = "DELETE FROM $table WHERE id = ".$id;
- Database::query($sql);
- return true;
- }
- /**
- * @param string $url
- *
- * @return int
- */
- public static function url_exist($url)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "SELECT id FROM $table
- WHERE url = '".Database::escape_string($url)."' ";
- $res = Database::query($sql);
- $num = Database::num_rows($res);
- return $num;
- }
- /**
- * @param string $url
- *
- * @return int
- */
- public static function url_id_exist($url)
- {
- if (empty($url)) {
- return false;
- }
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "SELECT id FROM $table WHERE id = ".intval($url)."";
- $res = Database::query($sql);
- $num = Database::num_rows($res);
- return $num;
- }
- /**
- * This function get the quantity of URLs
- * @author Julio Montoya
- * @return int count of urls
- * */
- public static function url_count()
- {
- $table_access_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "SELECT count(id) as count_result FROM $table_access_url";
- $res = Database::query($sql);
- $url = Database::fetch_array($res, 'ASSOC');
- $result = $url['count_result'];
- return $result;
- }
- /**
- * Gets the id, url, description, and active status of ALL URLs
- * @author Julio Montoya
- * @return array
- * */
- public static function get_url_data()
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "SELECT id, url, description, active
- FROM $table
- ORDER BY id";
- $res = Database::query($sql);
- $urls = array();
- while ($url = Database::fetch_array($res)) {
- $urls[] = $url;
- }
- return $urls;
- }
- /**
- * Gets the id, url, description, and active status of ALL URLs
- * @author Julio Montoya
- * @param int $url_id
- * @return array
- * */
- public static function get_url_data_from_id($url_id)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "SELECT id, url, description, active
- FROM $table
- WHERE id = ".intval($url_id);
- $res = Database::query($sql);
- $row = Database::fetch_array($res);
- return $row;
- }
- /**
- * Gets the inner join of users and urls table
- * @author Julio Montoya
- * @param int access url id
- * @param string $order_by
- * @return array Database::store_result of the result
- **/
- public static function get_url_rel_user_data($access_url_id = null, $order_by = null)
- {
- $where = '';
- $table_url_rel_user = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- if (!empty($access_url_id)) {
- $where = "WHERE $table_url_rel_user.access_url_id = ".intval($access_url_id);
- }
- if (empty($order_by)) {
- $order_clause = api_sort_by_first_name(
- ) ? ' ORDER BY firstname, lastname, username' : ' ORDER BY lastname, firstname, username';
- } else {
- $order_clause = $order_by;
- }
- $sql = "SELECT u.user_id, lastname, firstname, username, official_code, access_url_id
- FROM $tbl_user u
- INNER JOIN $table_url_rel_user
- ON $table_url_rel_user.user_id = u.user_id
- $where $order_clause";
- $result = Database::query($sql);
- $users = Database::store_result($result);
- return $users;
- }
- /**
- * Gets the inner join of access_url and the course table
- *
- * @author Julio Montoya
- * @param int access url id
- * @return array Database::store_result of the result
- **/
- public static function get_url_rel_course_data($access_url_id = null)
- {
- $where = '';
- $table_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $tbl_course = Database::get_main_table(TABLE_MAIN_COURSE);
- if (!empty($access_url_id)) {
- $where = " WHERE uc.access_url_id = ".intval($access_url_id);
- }
- $sql = "SELECT u.id, c_id, title, uc.access_url_id
- FROM $tbl_course u
- INNER JOIN $table_url_rel_course uc
- ON uc.c_id = u.id
- $where
- ORDER BY title, code";
- $result = Database::query($sql);
- $courses = Database::store_result($result);
- return $courses;
- }
- /**
- * Gets the number of rows with a specific course_code in access_url_rel_course table
- * @author Yoselyn Castillo
- * @param int $courseId
- *
- * @return int Database::num_rows($res);
- **/
- public static function getCountUrlRelCourse($courseId)
- {
- $courseId = intval($courseId);
- $tableUrlRelCourse = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $sql = "SELECT *
- FROM $tableUrlRelCourse
- WHERE c_id = '$courseId'";
- $res = Database::query($sql);
- return Database::num_rows($res);
- }
- /**
- * Gets the inner join of access_url and the session table
- * @author Julio Montoya
- * @param int $access_url_id access url id
- *
- * @return array Database::store_result of the result
- *
- **/
- public static function get_url_rel_session_data($access_url_id = null)
- {
- $where = '';
- $table_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $tbl_session = Database::get_main_table(TABLE_MAIN_SESSION);
- if (!empty($access_url_id)) {
- $where = "WHERE $table_url_rel_session.access_url_id = ".intval($access_url_id);
- }
- $sql = "SELECT id, name, access_url_id
- FROM $tbl_session u
- INNER JOIN $table_url_rel_session
- ON $table_url_rel_session.session_id = id
- $where
- ORDER BY name, id";
- $result = Database::query($sql);
- $sessions = Database::store_result($result);
- return $sessions;
- }
- /**
- * Gets the inner join of access_url and the usergroup table
- *
- * @author Julio Montoya
- * @param int $access_url_id
- *
- * @return array Database::store_result of the result
- **/
- public static function get_url_rel_usergroup_data($access_url_id = null)
- {
- $where = '';
- $table_url_rel_usergroup = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USERGROUP);
- $table_user_group = Database::get_main_table(TABLE_USERGROUP);
- if (!empty($access_url_id)) {
- $where = " WHERE $table_url_rel_usergroup.access_url_id = ".intval($access_url_id);
- }
- $sql = "SELECT u.id, u.name, access_url_id
- FROM $table_user_group u
- INNER JOIN $table_url_rel_usergroup
- ON $table_url_rel_usergroup.usergroup_id = u.id
- $where
- ORDER BY name";
- $result = Database::query($sql);
- $courses = Database::store_result($result);
- return $courses;
- }
- /**
- * Gets the inner join of access_url and the usergroup table
- *
- * @author Julio Montoya
- * @param int $access_url_id
- * @return array Database::store_result of the result
- **/
- public static function getUrlRelCourseCategory($access_url_id = null)
- {
- $table_url_rel = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $table = Database::get_main_table(TABLE_MAIN_CATEGORY);
- $where = " WHERE 1=1 ";
- if (!empty($access_url_id)) {
- $where .= " AND $table_url_rel.access_url_id = ".intval($access_url_id);
- }
- $where .= " AND (parent_id IS NULL) ";
- $sql = "SELECT u.id, name, access_url_id
- FROM $table u
- INNER JOIN $table_url_rel
- ON $table_url_rel.course_category_id = u.id
- $where
- ORDER BY name";
- $result = Database::query($sql);
- $courses = Database::store_result($result, 'ASSOC');
- return $courses;
- }
- /**
- * Sets the status of an URL 1 or 0
- * @author Julio Montoya
- * @param string $status lock || unlock
- * @param int url id
- * */
- public static function set_url_status($status, $url_id)
- {
- $url_table = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- if ($status == 'lock') {
- $status_db = '0';
- }
- if ($status == 'unlock') {
- $status_db = '1';
- }
- if (($status_db == '1' || $status_db == '0') && is_numeric($url_id)) {
- $sql = "UPDATE $url_table SET active='".intval($status_db)."'
- WHERE id='".intval($url_id)."'";
- Database::query($sql);
- }
- }
- /**
- * Checks the relationship between an URL and a User (return the num_rows)
- * @author Julio Montoya
- * @param int user id
- * @param int url id
- * @return boolean true if success
- * */
- public static function relation_url_user_exist($user_id, $url_id)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $sql = "SELECT user_id FROM $table
- WHERE access_url_id = ".intval($url_id)." AND user_id = ".intval($user_id)." ";
- $result = Database::query($sql);
- $num = Database::num_rows($result);
- return $num;
- }
- /**
- * Checks the relationship between an URL and a Course (return the num_rows)
- * @author Julio Montoya
- * @param int $courseId
- * @param int $urlId
- * @return boolean true if success
- * */
- public static function relation_url_course_exist($courseId, $urlId)
- {
- $table_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $sql = "SELECT c_id FROM $table_url_rel_course
- WHERE
- access_url_id = ".intval($urlId)." AND
- c_id = '".intval($courseId)."'";
- $result = Database::query($sql);
- $num = Database::num_rows($result);
- return $num;
- }
- /**
- * Checks the relationship between an URL and a UserGr
- * oup (return the num_rows)
- * @author Julio Montoya
- * @param int $userGroupId
- * @param int $urlId
- * @return boolean true if success
- * */
- public static function relationUrlUsergroupExist($userGroupId, $urlId)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USERGROUP);
- $sql = "SELECT usergroup_id FROM $table
- WHERE
- access_url_id = ".intval($urlId)." AND
- usergroup_id = ".intval($userGroupId);
- $result = Database::query($sql);
- $num = Database::num_rows($result);
- return $num;
- }
- /**
- * Checks the relationship between an URL and a Session (return the num_rows)
- * @author Julio Montoya
- * @param int user id
- * @param int url id
- * @return boolean true if success
- * */
- public static function relation_url_session_exist($session_id, $url_id)
- {
- $table_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $session_id = intval($session_id);
- $url_id = intval($url_id);
- $sql = "SELECT session_id FROM $table_url_rel_session
- WHERE
- access_url_id = ".intval($url_id)." AND
- session_id = ".Database::escape_string($session_id);
- $result = Database::query($sql);
- $num = Database::num_rows($result);
- return $num;
- }
- /**
- * Add a group of users into a group of URLs
- * @author Julio Montoya
- * @param array of user_ids
- * @param array of url_ids
- * @return array
- * */
- public static function add_users_to_urls($user_list, $url_list)
- {
- $table_url_rel_user = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $result_array = array();
- if (is_array($user_list) && is_array($url_list)) {
- foreach ($url_list as $url_id) {
- foreach ($user_list as $user_id) {
- $count = self::relation_url_user_exist($user_id, $url_id);
- if ($count == 0) {
- $sql = "INSERT INTO $table_url_rel_user
- SET
- user_id = ".intval($user_id).",
- access_url_id = ".intval($url_id);
- $result = Database::query($sql);
- if ($result) {
- $result_array[$url_id][$user_id] = 1;
- } else {
- $result_array[$url_id][$user_id] = 0;
- }
- }
- }
- }
- }
- return $result_array;
- }
- /**
- * Add a group of courses into a group of URLs
- * @author Julio Montoya
- * @param array $course_list of course ids
- * @param array $url_list of url_ids
- * @return array
- **/
- public static function add_courses_to_urls($course_list, $url_list)
- {
- $table_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $result_array = array();
- if (is_array($course_list) && is_array($url_list)) {
- foreach ($url_list as $url_id) {
- foreach ($course_list as $course_code) {
- $courseInfo = api_get_course_info($course_code);
- $courseId = $courseInfo['real_id'];
- $count = self::relation_url_course_exist($courseId, $url_id);
- if ($count == 0) {
- $sql = "INSERT INTO $table_url_rel_course
- SET c_id = '".$courseId."', access_url_id = ".intval($url_id);
- $result = Database::query($sql);
- if ($result) {
- $result_array[$url_id][$course_code] = 1;
- } else {
- $result_array[$url_id][$course_code] = 0;
- }
- }
- }
- }
- }
- return $result_array;
- }
- /**
- * Add a group of user group into a group of URLs
- * @author Julio Montoya
- * @param array $userGroupList of course ids
- * @param array $urlList of url_ids
- * @return array
- **/
- public static function addUserGroupListToUrl($userGroupList, $urlList)
- {
- $resultArray = array();
- if (is_array($userGroupList) && is_array($urlList)) {
- foreach ($urlList as $urlId) {
- foreach ($userGroupList as $userGroupId) {
- $count = self::relationUrlUsergroupExist($userGroupId, $urlId);
- if ($count == 0) {
- $result = self::addUserGroupToUrl($userGroupId, $urlId);
- if ($result) {
- $resultArray[$urlId][$userGroupId] = 1;
- } else {
- $resultArray[$urlId][$userGroupId] = 0;
- }
- }
- }
- }
- }
- return $resultArray;
- }
- /**
- * Add a group of user group into a group of URLs
- * @author Julio Montoya
- * @param array of course ids
- * @param array of url_ids
- * @return array
- **/
- public static function addCourseCategoryListToUrl($courseCategoryList, $urlList)
- {
- $resultArray = array();
- if (is_array($courseCategoryList) && is_array($urlList)) {
- foreach ($urlList as $urlId) {
- foreach ($courseCategoryList as $categoryCourseId) {
- $count = self::relationUrlCourseCategoryExist($categoryCourseId, $urlId);
- if ($count == 0) {
- $result = self::addCourseCategoryToUrl($categoryCourseId, $urlId);
- if ($result) {
- $resultArray[$urlId][$categoryCourseId] = 1;
- } else {
- $resultArray[$urlId][$categoryCourseId] = 0;
- }
- }
- }
- }
- }
- return $resultArray;
- }
- /**
- * Checks the relationship between an URL and a UserGr
- * oup (return the num_rows)
- * @author Julio Montoya
- * @param int $categoryCourseId
- * @param int $urlId
- * @return boolean true if success
- * */
- public static function relationUrlCourseCategoryExist($categoryCourseId, $urlId)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $sql = "SELECT course_category_id FROM $table
- WHERE access_url_id = ".intval($urlId)." AND
- course_category_id = ".intval($categoryCourseId);
- $result = Database::query($sql);
- $num = Database::num_rows($result);
- return $num;
- }
- /**
- * @param int $userGroupId
- * @param int $urlId
- * @return int
- */
- public static function addUserGroupToUrl($userGroupId, $urlId)
- {
- $urlRelUserGroupTable = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USERGROUP);
- $sql = "INSERT INTO $urlRelUserGroupTable
- SET
- usergroup_id = '".intval($userGroupId)."',
- access_url_id = ".intval($urlId);
- Database::query($sql);
- return Database::insert_id();
- }
- /**
- * @param int $categoryId
- * @param int $urlId
- * @return int
- */
- public static function addCourseCategoryToUrl($categoryId, $urlId)
- {
- $exists = self::relationUrlCourseCategoryExist($categoryId, $urlId);
- if (empty($exists)) {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $sql = "INSERT INTO $table
- SET
- course_category_id = '".intval($categoryId)."',
- access_url_id = ".intval($urlId);
- Database::query($sql);
- return Database::insert_id();
- }
- return 0;
- }
- /**
- * Add a group of sessions into a group of URLs
- * @author Julio Montoya
- * @param array $session_list of session ids
- * @param array $url_list of url_ids
- * @return array
- * */
- public static function add_sessions_to_urls($session_list, $url_list)
- {
- $table_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $result_array = array();
- if (is_array($session_list) && is_array($url_list)) {
- foreach ($url_list as $url_id) {
- foreach ($session_list as $session_id) {
- $count = self::relation_url_session_exist($session_id, $url_id);
- if ($count == 0) {
- $sql = "INSERT INTO $table_url_rel_session
- SET
- session_id = ".intval($session_id).",
- access_url_id = ".intval($url_id);
- $result = Database::query($sql);
- if ($result) {
- $result_array[$url_id][$session_id] = 1;
- } else {
- $result_array[$url_id][$session_id] = 0;
- }
- }
- }
- }
- }
- return $result_array;
- }
- /**
- * Add a user into a url
- * @author Julio Montoya
- * @param int $user_id
- * @param int $url_id
- *
- * @return boolean true if success
- * */
- public static function add_user_to_url($user_id, $url_id = 1)
- {
- $table_url_rel_user = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- if (empty($url_id)) {
- $url_id = 1;
- }
- $count = self::relation_url_user_exist($user_id, $url_id);
- $result = true;
- if (empty($count)) {
- $sql = "INSERT INTO $table_url_rel_user (user_id, access_url_id)
- VALUES ('".intval($user_id)."', '".intval($url_id)."') ";
- $result = Database::query($sql);
- }
- return $result;
- }
- /**
- * @param int $courseId
- * @param int $url_id
- *
- * @return resource
- */
- public static function add_course_to_url($courseId, $url_id = 1)
- {
- $table_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- if (empty($url_id)) {
- $url_id = 1;
- }
- $count = self::relation_url_course_exist($courseId, $url_id);
- if (empty($count)) {
- $sql = "INSERT INTO $table_url_rel_course
- SET c_id = '".intval($courseId)."', access_url_id = ".intval($url_id);
- Database::query($sql);
- }
- return true;
- }
- /**
- * Inserts a session to a URL (access_url_rel_session table)
- * @param int $session_id Session ID
- * @param int URL ID
- *
- * @return bool True on success, false session already exists or insert failed
- */
- public static function add_session_to_url($session_id, $url_id = 1)
- {
- $table_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- if (empty($url_id)) {
- $url_id = 1;
- }
- $result = false;
- $count = self::relation_url_session_exist($session_id, $url_id);
- $session_id = intval($session_id);
- if (empty($count) && !empty($session_id)) {
- $url_id = intval($url_id);
- $sql = "INSERT INTO $table_url_rel_session
- SET session_id = ".intval($session_id).", access_url_id = ".intval($url_id);
- $result = Database::query($sql);
- }
- return $result;
- }
- /**
- * Deletes an url and user relationship
- * @author Julio Montoya
- * @param int user id
- * @param int url id
- *
- * @return boolean true if success
- * */
- public static function delete_url_rel_user($user_id, $url_id)
- {
- $table_url_rel_user = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $result = true;
- if (!empty($user_id) && !empty($url_id)) {
- $sql = "DELETE FROM $table_url_rel_user
- WHERE user_id = ".intval($user_id)." AND access_url_id = ".intval($url_id);
- $result = Database::query($sql);
- }
- return $result;
- }
- /**
- * Deletes user from all portals
- * @author Julio Montoya
- * @param int user id
- *
- * @return boolean true if success
- * */
- public static function deleteUserFromAllUrls($userId)
- {
- $table_url_rel_user = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $result = true;
- if (!empty($userId)) {
- $sql = "DELETE FROM $table_url_rel_user
- WHERE user_id = ".intval($userId);
- Database::query($sql);
- }
- return $result;
- }
- /**
- * Deletes an url and course relationship
- * @author Julio Montoya
- * @param int $courseId
- * @param int $urlId
- *
- * @return boolean true if success
- * */
- public static function delete_url_rel_course($courseId, $urlId)
- {
- $table_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $sql = "DELETE FROM $table_url_rel_course
- WHERE c_id = '".intval($courseId)."' AND access_url_id=".intval($urlId)." ";
- $result = Database::query($sql);
- return $result;
- }
- /**
- * Deletes an url and $userGroup relationship
- * @author Julio Montoya
- * @param int $userGroupId
- * @param int $urlId
- *
- * @return boolean true if success
- * */
- public static function delete_url_rel_usergroup($userGroupId, $urlId)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USERGROUP);
- $sql = "DELETE FROM $table
- WHERE usergroup_id = '".intval($userGroupId)."' AND
- access_url_id = ".intval($urlId);
- $result = Database::query($sql);
- return $result;
- }
- /**
- * Deletes an url and $userGroup relationship
- * @author Julio Montoya
- * @param int $userGroupId
- * @param int $urlId
- *
- * @return boolean true if success
- * */
- public static function deleteUrlRelCourseCategory($userGroupId, $urlId)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $sql = "DELETE FROM $table
- WHERE course_category_id = '".intval($userGroupId)."' AND
- access_url_id=".intval($urlId)." ";
- $result = Database::query($sql);
- return $result;
- }
- /**
- * Deletes an url and session relationship
- * @author Julio Montoya
- * @param char course code
- * @param int url id
- *
- * @return boolean true if success
- * */
- public static function delete_url_rel_session($session_id, $url_id)
- {
- $table_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $sql = "DELETE FROM $table_url_rel_session
- WHERE session_id = ".intval($session_id)." AND access_url_id=".intval($url_id)." ";
- $result = Database::query($sql, 'ASSOC');
- return $result;
- }
- /**
- * Updates the access_url_rel_user table with a given user list
- * @author Julio Montoya
- * @param array $user_list
- * @param int $access_url_id
- * */
- public static function update_urls_rel_user($user_list, $access_url_id)
- {
- $table_url_rel_user = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $sql = "SELECT user_id
- FROM $table_url_rel_user
- WHERE access_url_id = ".intval($access_url_id);
- $result = Database::query($sql);
- $existing_users = array();
- //Getting all users
- while ($row = Database::fetch_array($result)) {
- $existing_users[] = $row['user_id'];
- }
- // Adding users
- $users_added = array();
- foreach ($user_list as $user_id_to_add) {
- if (!in_array($user_id_to_add, $existing_users)) {
- $result = self::add_user_to_url($user_id_to_add, $access_url_id);
- if ($result) {
- $users_added[] = $user_id_to_add;
- }
- }
- }
- $users_deleted = array();
- // Deleting old users
- foreach ($existing_users as $user_id_to_delete) {
- if (!in_array($user_id_to_delete, $user_list)) {
- $result = self::delete_url_rel_user($user_id_to_delete, $access_url_id);
- if ($result) {
- $users_deleted[] = $user_id_to_delete;
- }
- }
- }
- if (empty($users_added) && empty($users_deleted)) {
- return false;
- }
- return array('users_added' => $users_added, 'users_deleted' => $users_deleted);
- }
- /**
- * Updates the access_url_rel_course table with a given user list
- * @author Julio Montoya
- * @param array $course_list
- * @param int $access_url_id
- * */
- public static function update_urls_rel_course($course_list, $access_url_id)
- {
- $table_url_rel_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $sql = "SELECT c_id FROM $table_url_rel_course
- WHERE access_url_id = ".intval($access_url_id);
- $result = Database::query($sql);
- $existing_courses = array();
- while ($row = Database::fetch_array($result)) {
- $existing_courses[] = $row['c_id'];
- }
- // Adding courses
- foreach ($course_list as $courseId) {
- self::add_course_to_url($courseId, $access_url_id);
- CourseManager::update_course_ranking($courseId, 0, $access_url_id);
- }
- // Deleting old courses
- foreach ($existing_courses as $courseId) {
- if (!in_array($courseId, $course_list)) {
- self::delete_url_rel_course($courseId, $access_url_id);
- CourseManager::update_course_ranking($courseId, 0, $access_url_id);
- }
- }
- }
- /**
- * Updates the access_url_rel_course table with a given user list
- * @author Julio Montoya
- * @param array $userGroupList user list
- * @param int $urlId
- * */
- public static function update_urls_rel_usergroup($userGroupList, $urlId)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USERGROUP);
- $sql = "SELECT usergroup_id FROM $table
- WHERE access_url_id = ".intval($urlId);
- $result = Database::query($sql);
- $existingItems = array();
- while ($row = Database::fetch_array($result)) {
- $existingItems[] = $row['usergroup_id'];
- }
- // Adding
- foreach ($userGroupList as $userGroupId) {
- if (!in_array($userGroupId, $existingItems)) {
- self::addUserGroupToUrl($userGroupId, $urlId);
- }
- }
- // Deleting old items
- foreach ($existingItems as $userGroupId) {
- if (!in_array($userGroupId, $userGroupList)) {
- self::delete_url_rel_usergroup($userGroupId, $urlId);
- }
- }
- }
- /**
- * Updates the access_url_rel_course_category table with a given list
- * @author Julio Montoya
- * @param array $list course category list
- * @param int $urlId access_url_id
- **/
- public static function updateUrlRelCourseCategory($list, $urlId)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE_CATEGORY);
- $sql = "SELECT course_category_id FROM $table WHERE access_url_id = ".intval($urlId);
- $result = Database::query($sql);
- $existingItems = array();
- while ($row = Database::fetch_array($result)) {
- $existingItems[] = $row['course_category_id'];
- }
- // Adding
- foreach ($list as $id) {
- self::addCourseCategoryToUrl($id, $urlId);
- $categoryInfo = CourseCategory::getCategoryById($id);
- $children = CourseCategory::getChildren($categoryInfo['code']);
- if (!empty($children)) {
- foreach ($children as $category) {
- self::addCourseCategoryToUrl($category['id'], $urlId);
- }
- }
- }
- // Deleting old items
- foreach ($existingItems as $id) {
- if (!in_array($id, $list)) {
- self::deleteUrlRelCourseCategory($id, $urlId);
- $categoryInfo = CourseCategory::getCategoryById($id);
- $children = CourseCategory::getChildren($categoryInfo['code']);
- if (!empty($children)) {
- foreach ($children as $category) {
- self::deleteUrlRelCourseCategory($category['id'], $urlId);
- }
- }
- }
- }
- }
- /**
- * Updates the access_url_rel_session table with a given user list
- * @author Julio Montoya
- * @param array $session_list
- * @param int $access_url_id
- * */
- public static function update_urls_rel_session($session_list, $access_url_id)
- {
- $table_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $sql = "SELECT session_id FROM $table_url_rel_session
- WHERE access_url_id=".intval($access_url_id);
- $result = Database::query($sql);
- $existing_sessions = array();
- while ($row = Database::fetch_array($result)) {
- $existing_sessions[] = $row['session_id'];
- }
- // Adding users
- foreach ($session_list as $session) {
- if (!in_array($session, $existing_sessions)) {
- if (!empty($session) && !empty($access_url_id)) {
- self::add_session_to_url($session, $access_url_id);
- }
- }
- }
- // Deleting old users
- foreach ($existing_sessions as $existing_session) {
- if (!in_array($existing_session, $session_list)) {
- if (!empty($existing_session) && !empty($access_url_id)) {
- self::delete_url_rel_session($existing_session, $access_url_id);
- }
- }
- }
- }
- /**
- * @param int $user_id
- *
- * @return array
- */
- public static function get_access_url_from_user($user_id)
- {
- $table_url_rel_user = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_USER);
- $table_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "SELECT url, access_url_id
- FROM $table_url_rel_user url_rel_user
- INNER JOIN $table_url u
- ON (url_rel_user.access_url_id = u.id)
- WHERE user_id = ".intval($user_id);
- $result = Database::query($sql);
- $url_list = Database::store_result($result, 'ASSOC');
- return $url_list;
- }
- /**
- * @param int $courseId
- * @return array
- */
- public static function get_access_url_from_course($courseId)
- {
- $table = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
- $table_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "SELECT url, access_url_id FROM $table c
- INNER JOIN $table_url u
- ON (c.access_url_id = u.id)
- WHERE c_id = ".intval($courseId);
- $result = Database::query($sql);
- $url_list = Database::store_result($result, 'ASSOC');
- return $url_list;
- }
- /**
- * @param $session_id
- * @return array
- */
- public static function get_access_url_from_session($session_id)
- {
- $table_url_rel_session = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_SESSION);
- $table_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "SELECT url, access_url_id FROM $table_url_rel_session url_rel_session
- INNER JOIN $table_url u
- ON (url_rel_session.access_url_id = u.id)
- WHERE session_id = ".intval($session_id);
- $result = Database::query($sql);
- $url_list = Database::store_result($result);
- return $url_list;
- }
- /**
- * @param string $url
- * @return bool|mixed|null
- */
- public static function get_url_id($url)
- {
- $table_access_url = Database::get_main_table(TABLE_MAIN_ACCESS_URL);
- $sql = "SELECT id FROM $table_access_url
- WHERE url = '".Database::escape_string($url)."'";
- $result = Database::query($sql);
- $access_url_id = Database::result($result, 0, 0);
- return $access_url_id;
- }
- /**
- *
- * @param string $needle
- * @return XajaxResponse
- */
- public static function searchCourseCategoryAjax($needle)
- {
- $response = new xajaxResponse();
- $return = '';
- if (!empty($needle)) {
- // xajax send utf8 datas... datas in db can be non-utf8 datas
- $charset = api_get_system_encoding();
- $needle = api_convert_encoding($needle, $charset, 'utf-8');
- $needle = Database::escape_string($needle);
- // search courses where username or firstname or lastname begins likes $needle
- $sql = 'SELECT id, name
- FROM '.Database::get_main_table(TABLE_MAIN_CATEGORY).' u
- WHERE
- name LIKE "'.$needle.'%" AND
- (parent_id IS NULL or parent_id = 0)
- ORDER BY name
- LIMIT 11';
- $result = Database::query($sql);
- $i = 0;
- while ($data = Database::fetch_array($result)) {
- $i++;
- if ($i <= 10) {
- $return .= '<a
- href="javascript: void(0);"
- onclick="javascript: add_user_to_url(\''.addslashes($data['id']).'\',\''.addslashes($data['name']).' \')">'.$data['name'].' </a><br />';
- } else {
- $return .= '...<br />';
- }
- }
- }
- $response->addAssign('ajax_list_courses', 'innerHTML', api_utf8_encode($return));
- return $response;
- }
- }
|