123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586 |
- <?php
- /* For licensing terms, see /license.txt*/
- /**
- * @package chamilo.user
- */
- /* CATEGORIES DEFINITION TREATMENT */
- /**
- * create a new category definition for the user information
- *
- * @author - Hugues peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesch� <gesche@ipm.ucl.ac.be>
- * @param - string $title - category title
- * @param - string $comment - title comment
- * @param - int$nbline - lines number for the field the user will fill.
- * @return - bollean true if succeed, else bolean false
- */
- function create_cat_def($title="", $comment="", $nbline="5")
- {
- global $TBL_USERINFO_DEF; //taken from userInfo.php
- $title = Database::escape_string(trim($title));
- $comment = Database::escape_string(trim($comment));
- $nbline = strval(intval($nbline));
- if ( 0 == (int) $nbline || empty($title))
- {
- return false;
- }
- $sql = "SELECT MAX(rank) as maxRank FROM ".$TBL_USERINFO_DEF;
- $result = Database::query($sql);
- if ($result) $maxRank = Database::fetch_array($result);
- $maxRank = $maxRank['maxRank'];
- $thisRank = $maxRank + 1;
- $sql = "INSERT INTO $TBL_USERINFO_DEF SET
- title = '$title',
- comment = '$comment',
- line_count = '$nbline',
- rank = '$thisRank'";
- Database::query($sql);
- return true;
- }
- /**
- * modify the definition of a user information category
- *
- * @author - Hugues peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesch� <gesche@ipm.ucl.ac.be>
- * @param - int $id - id of the category
- * @param - string $title - category title
- * @param - string $comment - title comment
- * @param - int$nbline - lines number for the field the user will fill.
- * @return - boolean true if succeed, else otherwise
- */
- function edit_cat_def($id, $title, $comment, $nbline)
- {
- global $TBL_USERINFO_DEF;
- if ( 0 == $nbline || 0 == $id )
- {
- return false;
- }
- $id = strval(intval($id)); //make sure id is integer
- $title = Database::escape_string(trim($title));
- $comment = Database::escape_string(trim($comment));
- $nbline = strval(intval($nbline));
- $sql = "UPDATE ".$TBL_USERINFO_DEF." SET
- title = '$title',
- comment = '$comment',
- line_count = '$nbline'
- WHERE id = '$id'";
- Database::query($sql);
- return true;
- }
- /**
- * remove a category from the category list
- *
- * @author - Hugues peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesche <gesche@ipm.ucl.ac.be>
- *
- * @param - int $id - id of the category
- * or "ALL" for all category
- * @param - boolean $force - FALSE (default) : prevents removal if users have
- * already fill this category
- * TRUE : bypass user content existence check
- * @param - int $nbline - lines number for the field the user will fill.
- * @return - bollean - TRUE if succeed, ELSE otherwise
- */
- function remove_cat_def($id, $force = false)
- {
- $TBL_USERINFO_DEF = Database :: get_course_table(TABLE_USER_INFO);
- $TBL_USERINFO_CONTENT = Database :: get_course_table(TABLE_USER_INFO_CONTENT);
- $id = strval(intval($id));
- if ( (0 == (int) $id || $id == "ALL") || ! is_bool($force))
- {
- return false;
- }
- $sqlCondition = " WHERE id = '$id'";
- if (!$force)
- {
- $sql = "SELECT * FROM $TBL_USERINFO_CONTENT $sqlCondition";
- $result = Database::query($sql);
- if ( Database::num_rows($result) > 0)
- {
- return false;
- }
- }
- $sql = "DELETE FROM $TBL_USERINFO_DEF $sqlCondition";
- Database::query($sql);
- }
- /**
- * move a category in the category list
- *
- * @author - Hugues peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesch� <gesche@ipm.ucl.ac.be>
- *
- * @param - int $id - id of the category
- * @param - direction "up" or "down" :
- * "up" decrease the rank of gived $id by switching rank with the just lower
- * "down" increase the rank of gived $id by switching rank with the just upper
- *
- * @return - boolean true if succeed, else bolean false
- */
- function move_cat_rank($id, $direction) // up & down.
- {
- $TBL_USERINFO_DEF = Database :: get_course_table(TABLE_USER_INFO);
- $id = strval(intval($id));
- if ( 0 == (int) $id || ! ($direction == "up" || $direction == "down") )
- {
- return false;
- }
- $sql = "SELECT rank FROM $TBL_USERINFO_DEF WHERE id = '$id'";
- $result = Database::query($sql);
- if (Database::num_rows($result) < 1)
- {
- return false;
- }
- $cat = Database::fetch_array($result);
- $rank = (int) $cat['rank'];
- return move_cat_rank_by_rank($rank, $direction);
- }
- /**
- * move a category in the category list
- *
- * @author - Hugues peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesche <gesche@ipm.ucl.ac.be>
- *
- * @param - int $rank - actual rank of the category
- * @param - direction "up" or "down" :
- * "up" decrease the rank of gived $rank by switching rank with the just lower
- * "down" increase the rank of gived $rank by switching rank with the just upper
- *
- * @return - boolean true if succeed, else bolean false
- */
- function move_cat_rank_by_rank($rank, $direction) // up & down.
- {
- $TBL_USERINFO_DEF = Database :: get_course_table(TABLE_USER_INFO);
- if ( 0 == (int) $rank || ! ($direction == "up" || $direction == "down") )
- {
- return false;
- }
- if ($direction == "down") // thus increase rank ...
- {
- $sort = "ASC";
- $compOp = ">=";
- }
- else // thus decrease rank ...
- {
- $sort = "DESC";
- $compOp = "<=";
- }
- // this request find the 2 line to be switched (on rank value)
- $sql = "SELECT id, rank FROM ".$TBL_USERINFO_DEF." WHERE rank $compOp $rank
- ORDER BY rank $sort LIMIT 2";
- $result = Database::query($sql);
- if (Database::num_rows($result) < 2)
- {
- return false;
- }
- $thisCat = Database::fetch_array($result);
- $nextCat = Database::fetch_array($result);
- $sql1 = "UPDATE ".$TBL_USERINFO_DEF." SET rank ='".$nextCat['rank'].
- "' WHERE id = '".$thisCat['id']."'";
- $sql2 = "UPDATE ".$TBL_USERINFO_DEF." SET rank ='".$thisCat['rank'].
- "' WHERE id = '".$nextCat['id']."'";
- Database::query($sql1);
- Database::query($sql2);
- return true;
- }
- /**
- * @author Hugues Peeters - peeters@ipm.ucl.ac.be
- * @param int $user_id
- * @param string $course_code
- * @param array $properties - should contain 'role', 'status', 'tutor_id'
- * @return boolean true if succeed false otherwise
- */
- function update_user_course_properties($user_id, $course_code, $properties)
- {
- global $tbl_coursUser,$_user;
- $sqlChangeStatus = "";
- $user_id = strval(intval($user_id));//filter integer
- $course_code = Database::escape_string($course_code);
- if ($user_id != $_user['user_id'])
- {
- $sqlChangeStatus = "status = '".Database::escape_string($properties['status'])."',";
- }
- //feature deprecated tutor_id = '".Database::escape_string($properties['tutor'])."'
- $sql = "UPDATE $tbl_coursUser
- SET ".$sqlChangeStatus."
- role = '".Database::escape_string($properties['role'])."',
- tutor_id = '".Database::escape_string($properties['tutor'])."'
- WHERE user_id = '".$user_id."'
- AND course_code = '".$course_code."'";
- $result = Database::query($sql);
- if (Database::affected_rows($result) > 0) {
- return true;
- } else {
- return false;
- }
- }
- /**
- * fill a bloc for information category
- *
- * @author - Hugues peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesche <gesche@ipm.ucl.ac.be>
- * @param - $definition_id,
- * @param - $user_id,
- * @param - $user_ip,
- * @param - $content
- * @return - boolean true if succeed, else bolean false
- */
- function fill_new_cat_content($definition_id, $user_id, $content="", $user_ip="")
- {
- global $TBL_USERINFO_CONTENT;
- if (empty($user_ip))
- {
- $user_ip = $_SERVER['REMOTE_ADDR'];
- }
- $definition_id = strval(intval($definition_id));
- $user_id = strval(intval($user_id));
- $content = Database::escape_string(trim($content));
- $user_ip = Database::escape_string(trim($user_ip));
- if ( 0 == $definition_id || 0 == $user_id || $content == "")
- {
- // Here we should introduce an error handling system...
- return false;
- }
- // Do not create if already exist
- $sql = "SELECT id FROM ".$TBL_USERINFO_CONTENT."
- WHERE definition_id = '$definition_id'
- AND user_id = '$user_id'";
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0)
- {
- return false;
- }
- $sql = "INSERT INTO ".$TBL_USERINFO_CONTENT." SET
- content = '$content',
- definition_id = '$definition_id',
- user_id = '$user_id',
- editor_ip = '$user_ip',
- edition_time = now()";
- Database::query($sql);
- return true;
- }
- /**
- * Edit a bloc for information category
- *
- * @author - Hugues peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesche <gesche@ipm.ucl.ac.be>
- * @param - $definition_id,
- * @param - $user_id,
- * @param - $user_ip, DEFAULT $REMOTE_ADDR
- * @param - $content ; if empty call delete the bloc
- * @return - boolean true if succeed, else bolean false
- */
- function edit_cat_content($definition_id, $user_id, $content ="", $user_ip="")
- {
- global $TBL_USERINFO_CONTENT;
- $definition_id = strval(intval($definition_id));
- $user_id = strval(intval($user_id));
- $content = Database::escape_string(trim($content));
- if (empty($user_ip))
- {
- $user_ip = $_SERVER['REMOTE_ADDR'];
- }
- $user_ip = Database::escape_string($user_ip);
- if (0 == $user_id || 0 == $definition_id)
- {
- return false;
- }
- if ( $content == "")
- {
- return cleanout_cat_content($user_id, $definition_id);
- }
- $sql= "UPDATE ".$TBL_USERINFO_CONTENT." SET
- content = '$content',
- editor_ip = '$user_ip',
- edition_time = now()
- WHERE definition_id = '$definition_id' AND user_id = '$user_id'";
- Database::query($sql);
- return true;
- }
- /**
- * clean the content of a bloc for information category
- *
- * @author - Hugues peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesche <gesche@ipm.ucl.ac.be>
- * @param - $definition_id,
- * @param - $user_id
- * @return - boolean true if succeed, else bolean false
- */
- function cleanout_cat_content($user_id, $definition_id)
- {
- global $TBL_USERINFO_CONTENT;
- $user_id = strval(intval($user_id));
- $definition_id = strval(intval($definition_id));
- if (0 == $user_id || 0 == $definition_id)
- {
- return false;
- }
- $sql = "DELETE FROM ".$TBL_USERINFO_CONTENT."
- WHERE user_id = '$user_id' AND definition_id = '$definition_id'";
- Database::query($sql);
- return true;
- }
- /*----------------------------------------
- SHOW USER INFORMATION TREATMENT
- --------------------------------------*/
- /**
- * get the user info from the user id
- * @author - Hugues Peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesche <gesche@ipm.ucl.ac.be>
- * @param - int $user_id user id as stored in the Dokeos main db
- * @return - array containg user info sort by categories rank
- * each rank contains 'title', 'comment', 'content', 'cat_id'
- */
- function get_course_user_info($user_id)
- {
- $TBL_USERINFO_DEF = Database :: get_course_table(TABLE_USER_INFO);
- $TBL_USERINFO_CONTENT = Database :: get_course_table(TABLE_USER_INFO_CONTENT);
- $sql = "SELECT cat.id catId, cat.title,
- cat.comment , content.content
- FROM ".$TBL_USERINFO_DEF." cat LEFT JOIN ".$TBL_USERINFO_CONTENT." content
- ON cat.id = content.definition_id AND content.user_id = '$user_id'
- ORDER BY cat.rank, content.id";
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0)
- {
- while ($userInfo = Database::fetch_array($result, 'ASSOC'))
- {
- $userInfos[]=$userInfo;
- }
- return $userInfos;
- }
- return false;
- }
- /**
- * get the main user information
- * @author - Hugues Peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesche <gesche@ipm.ucl.ac.be>
- * @param - int $user_id user id as stored in the Dokeos main db
- * @return - array containing user info as 'lastName', 'firstName'
- * 'email', 'role'
- */
- function get_main_user_info($user_id, $courseCode)
- {
- $user_id = strval(intval($user_id));
- $courseCode = Database::escape_string($courseCode);
- if (0 == $user_id)
- {
- return false;
- }
- $table_course_user = Database::get_main_table(TABLE_MAIN_COURSE_USER);
- $table_user = Database::get_main_table(TABLE_MAIN_USER);
- $sql = "SELECT u.*, u.lastname lastName, u.firstname firstName,
- u.email, u.picture_uri picture, cu.role,
- cu.status status, cu.tutor_id
- FROM $table_user u, $table_course_user cu
- WHERE u.user_id = cu.user_id AND cu.relation_type<>".COURSE_RELATION_TYPE_RRHH."
- AND u.user_id = '$user_id'
- AND cu.course_code = '$courseCode'";
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0)
- {
- $userInfo = Database::fetch_array($result, 'ASSOC');
- $userInfo['password']='';
- return $userInfo;
- }
- return false;
- }
- /**
- * get the user content of a categories plus the categories definition
- * @author - Hugues Peeters <peeters@ipm.ucl.ac.be>
- * @author - Christophe Gesche <gesche@ipm.ucl.ac.be>
- * @param - int $userId - id of the user
- * @param - int $catId - id of the categories
- * @return - array containing 'catId', 'title', 'comment',
- * 'nbline', 'contentId' and 'content'
- */
- function get_cat_content($userId, $catId)
- {
- $TBL_USERINFO_DEF = Database :: get_course_table(TABLE_USER_INFO);
- $TBL_USERINFO_CONTENT = Database :: get_course_table(TABLE_USER_INFO_CONTENT);
- $userId = strval(intval($userId));
- $catId = strval(intval($catId));
- $sql = "SELECT cat.id catId, cat.title,
- cat.comment , cat.line_count,
- content.id contentId, content.content
- FROM ".$TBL_USERINFO_DEF." cat LEFT JOIN ".$TBL_USERINFO_CONTENT." content
- ON cat.id = content.definition_id
- AND content.user_id = '$userId'
- WHERE cat.id = '$catId' ";
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0)
- {
- $catContent = Database::fetch_array($result, 'ASSOC');
- $catContent['nbline'] = $catContent['line_count'];
- return $catContent;
- }
- return false;
- }
- /**
- * get the definition of a category
- *
- * @author - Christophe Gesche <gesche@ipm.ucl.ac.be>
- * @author - Hugues Peeters <peeters@ipm.ucl.ac.be>
- * @param - int $catId - id of the categories
- * @return - array containing 'id', 'title', 'comment', and 'nbline',
- */
- function get_cat_def($catId)
- {
- $TBL_USERINFO_DEF = Database :: get_course_table(TABLE_USER_INFO);
- $catId = strval(intval($catId));
- $sql = "SELECT id, title, comment, line_count, rank FROM ".$TBL_USERINFO_DEF." WHERE id = '$catId'";
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0)
- {
- $catDef = Database::fetch_array($result, 'ASSOC');
- $catDef['nbline'] = $catDef['line_count'];
- return $catDef;
- }
- return false;
- }
- /**
- * get list of all this course categories
- *
- * @author - Christophe Gesche <gesche@ipm.ucl.ac.be>
- * @author - Hugues Peeters <peeters@ipm.ucl.ac.be>
- * @return - array containing a list of arrays.
- * And each of these arrays contains
- * 'catId', 'title', 'comment', and 'nbline',
- */
- function get_cat_def_list()
- {
- $TBL_USERINFO_DEF = Database :: get_course_table(TABLE_USER_INFO);
- $sql = "SELECT id catId, title, comment , line_count
- FROM ".$TBL_USERINFO_DEF."
- ORDER BY rank";
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0)
- {
- while ($cat_def = Database::fetch_array($result, 'ASSOC'))
- {
- $cat_def_list[]=$cat_def;
- }
- return $cat_def_list;
- }
- return false;
- }
- /**
- * transform content in a html display
- * @author - Hugues Peeters <peeters@ipm.ucl.ac.be>
- * @param - string $string string to htmlize
- * @ return - string htmlized
- */
- function htmlize($phrase)
- {
- global $charset;
- return nl2br(htmlspecialchars($phrase,ENT_QUOTES,$charset));
- }
|