12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228 |
- <?php
- /* For licensing terms, see /license.txt */
- use Chamilo\CoreBundle\Entity\ExtraField as ExtraFieldEntity;
- use Chamilo\CoreBundle\Entity\ExtraFieldValues;
- use Chamilo\CourseBundle\Entity\CAnnouncement;
- use Chamilo\CourseBundle\Entity\CItemProperty;
- /**
- * Include file with functions for the announcements module.
- *
- * @author jmontoya
- *
- * @package chamilo.announcements
- *
- * @todo use OOP
- */
- class AnnouncementManager
- {
- /**
- * Constructor.
- */
- public function __construct()
- {
- }
- /**
- * @return array
- */
- public static function getTags()
- {
- $tags = [
- '((user_name))',
- '((user_email))',
- '((user_firstname))',
- '((user_lastname))',
- '((user_official_code))',
- '((course_title))',
- '((course_link))',
- ];
- $tags[] = '((teachers))';
- $extraField = new ExtraField('user');
- $extraFields = $extraField->get_all(['filter = ?' => 1]);
- if (!empty($extraFields)) {
- foreach ($extraFields as $extra) {
- $tags[] = "((extra_".$extra['variable']."))";
- }
- }
- $sessionId = api_get_session_id();
- if (!empty($sessionId)) {
- $tags[] = '((coaches))';
- $tags[] = '((general_coach))';
- $tags[] = '((general_coach_email))';
- }
- return $tags;
- }
- /**
- * @param int $userId
- * @param string $content
- * @param string $courseCode
- * @param int $sessionId
- *
- * @return string
- */
- public static function parseContent(
- $userId,
- $content,
- $courseCode,
- $sessionId = 0
- ) {
- $readerInfo = api_get_user_info($userId, false, false, true, true);
- $courseInfo = api_get_course_info($courseCode);
- $teacherList = CourseManager::getTeacherListFromCourseCodeToString($courseInfo['code']);
- $generalCoachName = '';
- $generalCoachEmail = '';
- $coaches = '';
- if (!empty($sessionId)) {
- $sessionInfo = api_get_session_info($sessionId);
- $coaches = CourseManager::get_coachs_from_course_to_string(
- $sessionId,
- $courseInfo['real_id']
- );
- $generalCoach = api_get_user_info($sessionInfo['id_coach']);
- $generalCoachName = $generalCoach['complete_name'];
- $generalCoachEmail = $generalCoach['email'];
- }
- $data = [];
- $data['user_name'] = '';
- $data['user_firstname'] = '';
- $data['user_lastname'] = '';
- $data['user_official_code'] = '';
- $data['user_email'] = '';
- if (!empty($readerInfo)) {
- $data['user_name'] = $readerInfo['username'];
- $data['user_email'] = $readerInfo['email'];
- $data['user_firstname'] = $readerInfo['firstname'];
- $data['user_lastname'] = $readerInfo['lastname'];
- $data['user_official_code'] = $readerInfo['official_code'];
- }
- $data['course_title'] = $courseInfo['name'];
- $courseLink = api_get_course_url($courseCode, $sessionId);
- $data['course_link'] = Display::url($courseLink, $courseLink);
- $data['teachers'] = $teacherList;
- if (!empty($readerInfo)) {
- $extraField = new ExtraField('user');
- $extraFields = $extraField->get_all(['filter = ?' => 1]);
- if (!empty($extraFields)) {
- foreach ($extraFields as $extra) {
- $data['extra_'.$extra['variable']] = '';
- }
- }
- if (!empty($readerInfo['extra'])) {
- foreach ($readerInfo['extra'] as $extra) {
- if (isset($extra['value'])) {
- /** @var \Chamilo\CoreBundle\Entity\ExtraFieldValues $value */
- $value = $extra['value'];
- if ($value instanceof ExtraFieldValues) {
- $field = $value->getField();
- if ($field instanceof ExtraFieldEntity) {
- $data['extra_'.$field->getVariable()] = $value->getValue();
- }
- }
- }
- }
- }
- }
- if (!empty($sessionId)) {
- $data['coaches'] = $coaches;
- $data['general_coach'] = $generalCoachName;
- $data['general_coach_email'] = $generalCoachEmail;
- }
- $tags = self::getTags();
- foreach ($tags as $tag) {
- $simpleTag = str_replace(['((', '))'], '', $tag);
- $value = isset($data[$simpleTag]) ? $data[$simpleTag] : '';
- $content = str_replace($tag, $value, $content);
- }
- return $content;
- }
- /**
- * Gets all announcements from a course.
- *
- * @param array $course_info
- * @param int $session_id
- *
- * @return array html with the content and count of announcements or false otherwise
- */
- public static function get_all_annoucement_by_course($course_info, $session_id = 0)
- {
- $session_id = (int) $session_id;
- $courseId = $course_info['real_id'];
- $tbl_announcement = Database::get_course_table(TABLE_ANNOUNCEMENT);
- $tbl_item_property = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $sql = "SELECT DISTINCT
- announcement.id,
- announcement.title,
- announcement.content
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property i
- ON (announcement.id = i.ref AND announcement.c_id = i.c_id)
- WHERE
- i.tool='announcement' AND
- announcement.session_id = '$session_id' AND
- announcement.c_id = $courseId AND
- i.c_id = $courseId
- ORDER BY display_order DESC";
- $rs = Database::query($sql);
- $num_rows = Database::num_rows($rs);
- if ($num_rows > 0) {
- $list = [];
- while ($row = Database::fetch_array($rs)) {
- $list[] = $row;
- }
- return $list;
- }
- return false;
- }
- /**
- * This functions switches the visibility a course resource
- * using the visibility field in 'item_property'.
- *
- * @param array $courseInfo
- * @param int $id ID of the element of the corresponding type
- *
- * @return bool False on failure, True on success
- */
- public static function change_visibility_announcement($courseInfo, $id)
- {
- $session_id = api_get_session_id();
- $item_visibility = api_get_item_visibility(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $id,
- $session_id
- );
- if ($item_visibility == '1') {
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $id,
- 'invisible',
- api_get_user_id()
- );
- } else {
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $id,
- 'visible',
- api_get_user_id()
- );
- }
- return true;
- }
- /**
- * Deletes an announcement.
- *
- * @param array $courseInfo the course array
- * @param int $id the announcement id
- */
- public static function delete_announcement($courseInfo, $id)
- {
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $id,
- 'delete',
- api_get_user_id()
- );
- }
- /**
- * Deletes all announcements by course.
- *
- * @param array $courseInfo the course array
- */
- public static function delete_all_announcements($courseInfo)
- {
- $announcements = self::get_all_annoucement_by_course(
- $courseInfo,
- api_get_session_id()
- );
- if (!empty($announcements)) {
- foreach ($announcements as $annon) {
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $annon['id'],
- 'delete',
- api_get_user_id()
- );
- }
- }
- }
- /**
- * @param string $title
- * @param int $courseId
- * @param int $sessionId
- * @param int $visibility 1 or 0
- *
- * @return mixed
- */
- public static function getAnnouncementsByTitle(
- $title,
- $courseId,
- $sessionId = 0,
- $visibility = 1
- ) {
- $dql = "SELECT a
- FROM ChamiloCourseBundle:CAnnouncement a
- JOIN ChamiloCourseBundle:CItemProperty ip
- WITH a.id = ip.ref AND a.cId = ip.course
- WHERE
- ip.tool = 'announcement' AND
- a.cId = :course AND
- a.sessionId = :session AND
- a.title like :title AND
- ip.visibility = :visibility
- ORDER BY a.displayOrder DESC";
- $qb = Database::getManager()->createQuery($dql);
- $result = $qb->execute(
- [
- 'course' => $courseId,
- 'session' => $sessionId,
- 'visibility' => $visibility,
- 'title' => "%$title%",
- ]
- );
- return $result;
- }
- /**
- * @param int $announcementId
- * @param int $courseId
- * @param int $userId
- * @param int $groupId
- *
- * @return array
- */
- public static function getAnnouncementInfoById(
- $announcementId,
- $courseId,
- $userId,
- $groupId = 0
- ) {
- $announcementId = (int) $announcementId;
- $courseId = (int) $courseId;
- $userId = (int) $userId;
- $groupId = (int) $groupId;
- if (api_is_allowed_to_edit(false, true) ||
- (api_get_course_setting('allow_user_edit_announcement') && !api_is_anonymous())
- ) {
- $dql = "SELECT a, ip
- FROM ChamiloCourseBundle:CAnnouncement a
- JOIN ChamiloCourseBundle:CItemProperty ip
- WITH a.id = ip.ref AND a.cId = ip.course
- WHERE
- a.id = :announcement AND
- ip.tool = 'announcement' AND
- a.cId = :course
- ORDER BY a.displayOrder DESC";
- } else {
- $groupList[] = $groupId;
- if (api_get_user_id() != 0) {
- $extraGroupCondition = '';
- if (!empty($groupId)) {
- $groupProperties = GroupManager::get_group_properties($groupId);
- if ($groupProperties['announcements_state'] == GroupManager::TOOL_PRIVATE_BETWEEN_USERS) {
- $extraGroupCondition = " AND (
- ip.toUser = $userId AND ip.group = $groupId OR
- (ip.group IN ('0') OR ip.group IS NULL) OR
- (ip.group = $groupId AND (ip.toUser IS NULL OR ip.toUser = 0))
- )";
- }
- }
- $dql = "SELECT a, ip
- FROM ChamiloCourseBundle:CAnnouncement a
- JOIN ChamiloCourseBundle:CItemProperty ip
- WITH a.id = ip.ref AND a.cId = ip.course
- WHERE
- a.id = :announcement AND
- ip.tool='announcement' AND
- (
- ip.toUser = $userId OR
- ip.group IN ('0', '".$groupId."') OR
- ip.group IS NULL
- ) AND
- ip.visibility = '1' AND
- ip.course = :course
- $extraGroupCondition
- ORDER BY a.displayOrder DESC";
- } else {
- $dql = "SELECT a, ip
- FROM ChamiloCourseBundle:CAnnouncement a
- JOIN ChamiloCourseBundle:CItemProperty ip
- WITH a.id = ip.ref AND a.cId = ip.course
- WHERE
- a.id = :announcement AND
- ip.tool = 'announcement' AND
- (ip.group = '0' OR ip.group IS NULL) AND
- ip.visibility = '1' AND
- ip.course = :course";
- }
- }
- $qb = Database::getManager()->createQuery($dql);
- $result = $qb->execute(
- [
- 'announcement' => $announcementId,
- 'course' => $courseId,
- ]
- );
- if (!empty($result)) {
- return [
- 'announcement' => $result[0],
- 'item_property' => $result[1],
- ];
- }
- return [];
- }
- /**
- * Displays one specific announcement.
- *
- * @param int $id, the id of the announcement you want to display
- *
- * @return string
- */
- public static function displayAnnouncement($id)
- {
- $id = (int) $id;
- if (empty($id)) {
- return '';
- }
- global $charset;
- $html = '';
- $result = self::getAnnouncementInfoById(
- $id,
- api_get_course_int_id(),
- api_get_user_id(),
- api_get_group_id()
- );
- if (empty($result)) {
- return '';
- }
- /** @var CAnnouncement $announcement */
- $announcement = $result['announcement'];
- /** @var CItemProperty $itemProperty */
- $itemProperty = $result['item_property'];
- if (empty($announcement) || empty($itemProperty)) {
- return '';
- }
- $title = $announcement->getTitle();
- $content = $announcement->getContent();
- $html .= "<table height=\"100\" width=\"100%\" cellpadding=\"5\" cellspacing=\"0\" class=\"data_table\">";
- $html .= "<tr><td><h2>".$title."</h2></td></tr>";
- if (api_is_allowed_to_edit(false, true) ||
- (api_get_course_setting('allow_user_edit_announcement') && !api_is_anonymous())
- ) {
- $modify_icons = "<a href=\"".api_get_self()."?".api_get_cidreq()."&action=modify&id=".$id."\">".
- Display::return_icon('edit.png', get_lang('Edit'), '', ICON_SIZE_SMALL)."</a>";
- $image_visibility = 'invisible';
- $alt_visibility = get_lang('Visible');
- if ($itemProperty->getVisibility() === 1) {
- $image_visibility = 'visible';
- $alt_visibility = get_lang('Hide');
- }
- global $stok;
- $modify_icons .= "<a href=\"".api_get_self()."?".api_get_cidreq()."&action=showhide&id=".$id."&sec_token=".$stok."\">".
- Display::return_icon($image_visibility.'.png', $alt_visibility, '', ICON_SIZE_SMALL)."</a>";
- if (api_is_allowed_to_edit(false, true)) {
- $modify_icons .= "<a href=\"".api_get_self()."?".api_get_cidreq()."&action=delete&id=".$id."&sec_token=".$stok."\" onclick=\"javascript:if(!confirm('".addslashes(api_htmlentities(get_lang('Please confirm your choice'), ENT_QUOTES, $charset))."')) return false;\">".
- Display::return_icon('delete.png', get_lang('Delete'), '', ICON_SIZE_SMALL).
- "</a>";
- }
- $html .= "<tr><th style='text-align:right'>$modify_icons</th></tr>";
- }
- // The user id is always the current one.
- $toUserId = api_get_user_id();
- $content = self::parseContent(
- $toUserId,
- $content,
- api_get_course_id(),
- api_get_session_id()
- );
- $html .= "<tr><td>$content</td></tr>";
- $html .= "<tr>";
- $html .= "<td class=\"announcements_datum\">".get_lang('Latest update')." : ";
- $lastEdit = $itemProperty->getLasteditDate();
- $html .= Display::dateToStringAgoAndLongDate($lastEdit);
- $html .= "</td></tr>";
- $allow = !api_get_configuration_value('hide_announcement_sent_to_users_info');
- if ($allow && api_is_allowed_to_edit(false, true)) {
- $sent_to = self::sent_to('announcement', $id);
- $sentToForm = self::sent_to_form($sent_to);
- $html .= Display::tag(
- 'td',
- get_lang('Visible to').': '.$sentToForm,
- ['class' => 'announcements_datum']
- );
- }
- $attachment_list = self::get_attachment($id);
- if (count($attachment_list) > 0) {
- $html .= "<tr><td>";
- $realname = $attachment_list['path'];
- $user_filename = $attachment_list['filename'];
- $full_file_name = 'download.php?'.api_get_cidreq().'&file='.$realname;
- $html .= '<br/>';
- $html .= Display::return_icon('attachment.gif', get_lang('Attachment'));
- $html .= '<a href="'.$full_file_name.' "> '.$user_filename.' </a>';
- $html .= ' - <span class="forum_attach_comment" >'.$attachment_list['comment'].'</span>';
- if (api_is_allowed_to_edit(false, true)) {
- $url = api_get_self()."?".api_get_cidreq().
- "&action=delete_attachment&id_attach=".$attachment_list['id']."&sec_token=".$stok;
- $html .= Display::url(
- Display::return_icon(
- 'delete.png',
- get_lang('Delete'),
- '',
- 16
- ),
- $url
- );
- }
- $html .= '</td></tr>';
- }
- $html .= '</table>';
- return $html;
- }
- /**
- * @param array $courseInfo
- *
- * @return int
- */
- public static function getLastAnnouncementOrder($courseInfo)
- {
- if (empty($courseInfo)) {
- return 0;
- }
- if (!isset($courseInfo['real_id'])) {
- return false;
- }
- $courseId = $courseInfo['real_id'];
- $table = Database::get_course_table(TABLE_ANNOUNCEMENT);
- $sql = "SELECT MAX(display_order)
- FROM $table
- WHERE c_id = $courseId ";
- $result = Database::query($sql);
- $order = 0;
- if (Database::num_rows($result)) {
- $row = Database::fetch_array($result);
- $order = (int) $row[0] + 1;
- }
- return $order;
- }
- /**
- * Store an announcement in the database (including its attached file if any).
- *
- * @param array $courseInfo
- * @param int $sessionId
- * @param string $title Announcement title (pure text)
- * @param string $newContent Content of the announcement (can be HTML)
- * @param array $sentTo Array of users and groups to send the announcement to
- * @param array $file uploaded file $_FILES
- * @param string $file_comment Comment describing the attachment
- * @param string $end_date
- * @param bool $sendToUsersInSession
- * @param int $authorId
- *
- * @return int false on failure, ID of the announcement on success
- */
- public static function add_announcement(
- $courseInfo,
- $sessionId,
- $title,
- $newContent,
- $sentTo,
- $file = [],
- $file_comment = null,
- $end_date = null,
- $sendToUsersInSession = false,
- $authorId = 0
- ) {
- if (empty($courseInfo)) {
- return false;
- }
- if (!isset($courseInfo['real_id'])) {
- return false;
- }
- $courseId = $courseInfo['real_id'];
- $tbl_announcement = Database::get_course_table(TABLE_ANNOUNCEMENT);
- $authorId = empty($authorId) ? api_get_user_id() : $authorId;
- if (empty($end_date)) {
- $end_date = api_get_utc_datetime();
- }
- $order = self::getLastAnnouncementOrder($courseInfo);
- // store in the table announcement
- $params = [
- 'c_id' => $courseId,
- 'content' => $newContent,
- 'title' => $title,
- 'end_date' => $end_date,
- 'display_order' => $order,
- 'session_id' => (int) $sessionId,
- ];
- $last_id = Database::insert($tbl_announcement, $params);
- if (empty($last_id)) {
- return false;
- } else {
- $sql = "UPDATE $tbl_announcement SET id = iid WHERE iid = $last_id";
- Database::query($sql);
- if (!empty($file)) {
- self::add_announcement_attachment_file(
- $last_id,
- $file_comment,
- $_FILES['user_upload']
- );
- }
- // store in item_property (first the groups, then the users
- if (empty($sentTo) ||
- (!empty($sentTo) && isset($sentTo[0]) && $sentTo[0] == 'everyone')
- ) {
- // The message is sent to EVERYONE, so we set the group to 0
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $last_id,
- 'AnnouncementAdded',
- $authorId,
- '0',
- null,
- null,
- null,
- $sessionId
- );
- } else {
- $send_to = CourseManager::separateUsersGroups($sentTo);
- $batchSize = 20;
- $em = Database::getManager();
- // Storing the selected groups
- if (is_array($send_to['groups']) &&
- !empty($send_to['groups'])
- ) {
- $counter = 1;
- foreach ($send_to['groups'] as $group) {
- $groupInfo = GroupManager::get_group_properties($group);
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $last_id,
- 'AnnouncementAdded',
- $authorId,
- $groupInfo
- );
- if (($counter % $batchSize) === 0) {
- $em->flush();
- $em->clear();
- }
- $counter++;
- }
- }
- // Storing the selected users
- if (is_array($send_to['users'])) {
- $counter = 1;
- foreach ($send_to['users'] as $user) {
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $last_id,
- 'AnnouncementAdded',
- $authorId,
- '',
- $user
- );
- if (($counter % $batchSize) === 0) {
- $em->flush();
- $em->clear();
- }
- $counter++;
- }
- }
- }
- if ($sendToUsersInSession) {
- self::addAnnouncementToAllUsersInSessions($last_id);
- }
- return $last_id;
- }
- }
- /**
- * @param string $title
- * @param string $newContent
- * @param int $groupId
- * @param array $to_users
- * @param array $file
- * @param string $file_comment
- * @param bool $sendToUsersInSession
- *
- * @return bool|int
- */
- public static function addGroupAnnouncement(
- $title,
- $newContent,
- $groupId,
- $to_users,
- $file = [],
- $file_comment = '',
- $sendToUsersInSession = false
- ) {
- $courseInfo = api_get_course_info();
- // Database definitions
- $table = Database::get_course_table(TABLE_ANNOUNCEMENT);
- $order = self::getLastAnnouncementOrder($courseInfo);
- $now = api_get_utc_datetime();
- $courseId = api_get_course_int_id();
- // store in the table announcement
- $params = [
- 'c_id' => $courseId,
- 'content' => $newContent,
- 'title' => $title,
- 'end_date' => $now,
- 'display_order' => $order,
- 'session_id' => api_get_session_id(),
- ];
- $last_id = Database::insert($table, $params);
- // Store the attach file
- if ($last_id) {
- $sql = "UPDATE $table SET id = iid
- WHERE iid = $last_id";
- Database::query($sql);
- if (!empty($file)) {
- self::add_announcement_attachment_file(
- $last_id,
- $file_comment,
- $file
- );
- }
- $send_to_users = CourseManager::separateUsersGroups($to_users);
- // if nothing was selected in the menu then send to all the group
- $sentToAllGroup = false;
- if (empty($send_to_users['groups']) && empty($send_to_users['users'])) {
- $groupInfo = GroupManager::get_group_properties($groupId);
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $last_id,
- 'AnnouncementAdded',
- api_get_user_id(),
- $groupInfo
- );
- $sentToAllGroup = true;
- }
- if ($sentToAllGroup === false) {
- if (!empty($send_to_users['groups'])) {
- foreach ($send_to_users['groups'] as $group) {
- $groupInfo = GroupManager::get_group_properties($group);
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $last_id,
- 'AnnouncementAdded',
- api_get_user_id(),
- $groupInfo
- );
- }
- }
- $groupInfo = GroupManager::get_group_properties($groupId);
- if (!empty($send_to_users['users'])) {
- foreach ($send_to_users['users'] as $user) {
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $last_id,
- 'AnnouncementAdded',
- api_get_user_id(),
- $groupInfo,
- $user
- );
- }
- }
- }
- if ($sendToUsersInSession) {
- self::addAnnouncementToAllUsersInSessions($last_id);
- }
- }
- return $last_id;
- }
- /**
- * This function stores the announcement item in the announcement table
- * and updates the item_property table.
- *
- * @param int $id id of the announcement
- * @param string $title
- * @param string $newContent
- * @param array $to users that will receive the announcement
- * @param mixed $file attachment
- * @param string $file_comment file comment
- * @param bool $sendToUsersInSession
- */
- public static function edit_announcement(
- $id,
- $title,
- $newContent,
- $to,
- $file = [],
- $file_comment = '',
- $sendToUsersInSession = false
- ) {
- $courseInfo = api_get_course_info();
- $courseId = api_get_course_int_id();
- $tbl_item_property = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $table = Database::get_course_table(TABLE_ANNOUNCEMENT);
- $id = (int) $id;
- $params = [
- 'title' => $title,
- 'content' => $newContent,
- ];
- Database::update(
- $table,
- $params,
- ['c_id = ? AND id = ?' => [$courseId, $id]]
- );
- // save attachment file
- $row_attach = self::get_attachment($id);
- $id_attach = 0;
- if ($row_attach) {
- $id_attach = (int) $row_attach['id'];
- }
- if (!empty($file)) {
- if (empty($id_attach)) {
- self::add_announcement_attachment_file(
- $id,
- $file_comment,
- $file
- );
- } else {
- self::edit_announcement_attachment_file(
- $id_attach,
- $file,
- $file_comment
- );
- }
- }
- // We remove everything from item_property for this
- $sql = "DELETE FROM $tbl_item_property
- WHERE c_id = $courseId AND ref='$id' AND tool='announcement'";
- Database::query($sql);
- if ($sendToUsersInSession) {
- self::addAnnouncementToAllUsersInSessions($id);
- }
- // store in item_property (first the groups, then the users
- if (!empty($to)) {
- // !is_null($to): when no user is selected we send it to everyone
- $send_to = CourseManager::separateUsersGroups($to);
- // storing the selected groups
- if (is_array($send_to['groups'])) {
- foreach ($send_to['groups'] as $group) {
- $groupInfo = GroupManager::get_group_properties($group);
- if (empty($groupInfo)) {
- // Probably the group id and iid are different try checking the iid
- $groupInfo = GroupManager::get_group_properties($group, true);
- }
- if ($groupInfo) {
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $id,
- 'AnnouncementUpdated',
- api_get_user_id(),
- $groupInfo
- );
- }
- }
- }
- // storing the selected users
- if (is_array($send_to['users'])) {
- foreach ($send_to['users'] as $user) {
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $id,
- 'AnnouncementUpdated',
- api_get_user_id(),
- 0,
- $user
- );
- }
- }
- // Send to everyone
- if (isset($to[0]) && $to[0] === 'everyone') {
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $id,
- 'AnnouncementUpdated',
- api_get_user_id(),
- 0
- );
- }
- } else {
- // the message is sent to everyone, so we set the group to 0
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $id,
- 'AnnouncementUpdated',
- api_get_user_id(),
- 0
- );
- }
- }
- /**
- * @param int $announcementId
- */
- public static function addAnnouncementToAllUsersInSessions($announcementId)
- {
- $courseCode = api_get_course_id();
- $courseInfo = api_get_course_info();
- $sessionList = SessionManager::get_session_by_course(api_get_course_int_id());
- if (!empty($sessionList)) {
- foreach ($sessionList as $sessionInfo) {
- $sessionId = $sessionInfo['id'];
- $userList = CourseManager::get_user_list_from_course_code(
- $courseCode,
- $sessionId
- );
- if (!empty($userList)) {
- foreach ($userList as $user) {
- api_item_property_update(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $announcementId,
- 'AnnouncementUpdated',
- api_get_user_id(),
- 0,
- $user['user_id'],
- 0,
- 0,
- $sessionId
- );
- }
- }
- }
- }
- }
- /**
- * @param int $insert_id
- *
- * @return bool
- */
- public static function update_mail_sent($insert_id)
- {
- $table = Database::get_course_table(TABLE_ANNOUNCEMENT);
- if ($insert_id != strval(intval($insert_id))) {
- return false;
- }
- $insert_id = intval($insert_id);
- $courseId = api_get_course_int_id();
- // store the modifications in the table tbl_annoucement
- $sql = "UPDATE $table SET email_sent='1'
- WHERE c_id = $courseId AND id = $insert_id";
- Database::query($sql);
- }
- /**
- * @param int $user_id
- *
- * @return array|bool
- */
- public static function getAnnoucementCourseTotalByUser($user_id)
- {
- $user_id = (int) $user_id;
- if (empty($user_id)) {
- return false;
- }
- $tbl_announcement = Database::get_course_table(TABLE_ANNOUNCEMENT);
- $tbl_item_property = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $sql = "SELECT DISTINCT
- announcement.c_id,
- count(announcement.id) count
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.id = ip.ref AND announcement.c_id = ip.c_id)
- WHERE
- ip.tool='announcement' AND
- (
- ip.to_user_id = '$user_id' AND
- (ip.to_group_id='0' OR ip.to_group_id IS NULL)
- )
- AND ip.visibility='1'
- AND announcement.session_id = 0
- GROUP BY announcement.c_id";
- $rs = Database::query($sql);
- $num_rows = Database::num_rows($rs);
- $result = [];
- if ($num_rows > 0) {
- while ($row = Database::fetch_array($rs, 'ASSOC')) {
- if (empty($row['c_id'])) {
- continue;
- }
- $result[] = ['course' => api_get_course_info_by_id($row['c_id']), 'count' => $row['count']];
- }
- }
- return $result;
- }
- /**
- * Returns announcement info from its id.
- *
- * @param int $courseId
- * @param int $id
- *
- * @return array
- */
- public static function get_by_id($courseId, $id)
- {
- $id = (int) $id;
- $courseId = $courseId ? (int) $courseId : api_get_course_int_id();
- $tbl_announcement = Database::get_course_table(TABLE_ANNOUNCEMENT);
- $tbl_item_property = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $sql = "SELECT DISTINCT
- announcement.id,
- announcement.title,
- announcement.content,
- ip.to_group_id
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON
- announcement.id = ip.ref AND
- announcement.c_id = ip.c_id
- WHERE
- announcement.c_id = $courseId AND
- ip.tool='announcement' AND
- announcement.id = $id
- ";
- $result = Database::query($sql);
- if (Database::num_rows($result)) {
- return Database::fetch_array($result);
- }
- return [];
- }
- /**
- * this function gets all the groups of the course,
- * not including linked courses.
- */
- public static function get_course_groups()
- {
- $session_id = api_get_session_id();
- if ($session_id != 0) {
- $new_group_list = CourseManager::get_group_list_of_course(
- api_get_course_id(),
- $session_id,
- 1
- );
- } else {
- $new_group_list = CourseManager::get_group_list_of_course(
- api_get_course_id(),
- 0,
- 1
- );
- }
- return $new_group_list;
- }
- /**
- * This tools loads all the users and all the groups who have received
- * a specific item (in this case an announcement item).
- *
- * @param string $tool
- * @param int $id
- * @param bool $includeGroupWhenLoadingUser
- *
- * @return array
- */
- public static function loadEditUsers($tool, $id, $includeGroupWhenLoadingUser = false)
- {
- $table = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $tool = Database::escape_string($tool);
- $id = (int) $id;
- $courseId = api_get_course_int_id();
- $groupId = api_get_group_id();
- $sql = "SELECT to_user_id, to_group_id FROM $table
- WHERE c_id = $courseId AND tool='$tool' AND ref = $id";
- $result = Database::query($sql);
- $to = [];
- while ($row = Database::fetch_array($result)) {
- // This is the iid of c_group_info
- $toGroup = $row['to_group_id'];
- if (empty($row['to_user_id']) && !empty($groupId) && $groupId != $toGroup) {
- //continue;
- }
- switch ($toGroup) {
- // it was send to one specific user
- case null:
- if (isset($row['to_user_id']) && !empty($row['to_user_id'])) {
- if (!in_array('USER:'.$row['to_user_id'], $to)) {
- $to[] = 'USER:'.$row['to_user_id'];
- }
- }
- break;
- // it was sent to everyone
- case 0:
- return 'everyone';
- break;
- default:
- if (isset($row['to_user_id']) && !empty($row['to_user_id'])) {
- if (!in_array('USER:'.$row['to_user_id'], $to)) {
- $to[] = 'USER:'.$row['to_user_id'];
- }
- } else {
- if (!in_array('GROUP:'.$toGroup, $to)) {
- $to[] = 'GROUP:'.$toGroup;
- }
- }
- if ($includeGroupWhenLoadingUser) {
- if (!in_array('GROUP:'.$toGroup, $to)) {
- $to[] = 'GROUP:'.$toGroup;
- }
- }
- break;
- }
- }
- return $to;
- }
- /**
- * constructs the form to display all the groups and users the message has been sent to.
- *
- * @param array $sent_to_array
- * input:
- * $sent_to_array is a 2 dimensional array containing the groups and the users
- * the first level is a distinction between groups and users:
- * $sent_to_array['groups'] * and $sent_to_array['users']
- * $sent_to_array['groups'] (resp. $sent_to_array['users']) is also an array
- * containing all the id's of the groups (resp. users) who have received this message.
- *
- * @return string
- *
- * @author Patrick Cool <patrick.cool@>
- */
- public static function sent_to_form($sent_to_array)
- {
- // we find all the names of the groups
- $group_names = self::get_course_groups();
- // we count the number of users and the number of groups
- $number_users = 0;
- if (isset($sent_to_array['users'])) {
- $number_users = count($sent_to_array['users']);
- }
- $number_groups = 0;
- if (isset($sent_to_array['groups'])) {
- $number_groups = count($sent_to_array['groups']);
- }
- $total_numbers = $number_users + $number_groups;
- // starting the form if there is more than one user/group
- $output = [];
- if ($total_numbers > 1) {
- // outputting the name of the groups
- if (is_array($sent_to_array['groups'])) {
- foreach ($sent_to_array['groups'] as $group_id) {
- $users = GroupManager::getStudents($group_id, true);
- $userToArray = [];
- foreach ($users as $student) {
- $userToArray[] = $student['complete_name_with_username'];
- }
- $output[] =
- '<br />'.
- Display::label($group_names[$group_id]['name'], 'info').
- ' '.implode(', ', $userToArray);
- }
- }
- if (isset($sent_to_array['users'])) {
- if (is_array($sent_to_array['users'])) {
- $usersToArray = [];
- foreach ($sent_to_array['users'] as $user_id) {
- $user_info = api_get_user_info($user_id);
- $usersToArray[] = $user_info['complete_name_with_username'];
- }
- $output[] = '<br />'.Display::label(get_lang('Users')).' '.implode(', ', $usersToArray);
- }
- }
- } else {
- // there is only one user/group
- if (isset($sent_to_array['users']) && is_array($sent_to_array['users'])) {
- $user_info = api_get_user_info($sent_to_array['users'][0]);
- $output[] = api_get_person_name($user_info['firstname'], $user_info['lastname']);
- }
- if (isset($sent_to_array['groups']) &&
- is_array($sent_to_array['groups']) &&
- isset($sent_to_array['groups'][0]) &&
- $sent_to_array['groups'][0] !== 0
- ) {
- $group_id = $sent_to_array['groups'][0];
- $users = GroupManager::getStudents($group_id, true);
- $userToArray = [];
- foreach ($users as $student) {
- $userToArray[] = $student['complete_name_with_username'];
- }
- $output[] =
- '<br />'.
- Display::label($group_names[$group_id]['name'], 'info').
- ' '.implode(', ', $userToArray);
- }
- if (empty($sent_to_array['groups']) && empty($sent_to_array['users'])) {
- $output[] = " ".get_lang('All');
- }
- }
- if (!empty($output)) {
- $output = array_filter($output);
- if (count($output) > 0) {
- $output = implode('<br />', $output);
- }
- return $output;
- }
- }
- /**
- * Returns all the users and all the groups a specific announcement item
- * has been sent to.
- *
- * @param string The tool (announcement, agenda, ...)
- * @param int ID of the element of the corresponding type
- *
- * @return array Array of users and groups to whom the element has been sent
- */
- public static function sent_to($tool, $id)
- {
- $table = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $tool = Database::escape_string($tool);
- $id = (int) $id;
- $sent_to_group = [];
- $sent_to = [];
- $courseId = api_get_course_int_id();
- $sql = "SELECT to_group_id, to_user_id
- FROM $table
- WHERE c_id = $courseId AND tool = '$tool' AND ref=".$id;
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result)) {
- // if to_user_id <> 0 then it is sent to a specific user
- if ($row['to_user_id'] != 0) {
- $sent_to_user[] = $row['to_user_id'];
- continue;
- }
- // if to_group_id is null then it is sent to a specific user
- // if to_group_id = 0 then it is sent to everybody
- if ($row['to_group_id'] != 0) {
- $sent_to_group[] = $row['to_group_id'];
- }
- }
- if (isset($sent_to_group)) {
- $sent_to['groups'] = $sent_to_group;
- }
- if (isset($sent_to_user)) {
- $sent_to['users'] = $sent_to_user;
- }
- return $sent_to;
- }
- /**
- * Show a list with all the attachments according to the post's id.
- *
- * @param int $announcementId
- *
- * @return array with the post info
- *
- * @author Arthur Portugal
- *
- * @version November 2009, dokeos 1.8.6.2
- */
- public static function get_attachment($announcementId)
- {
- $table = Database::get_course_table(TABLE_ANNOUNCEMENT_ATTACHMENT);
- $announcementId = (int) $announcementId;
- $courseId = api_get_course_int_id();
- $row = [];
- $sql = 'SELECT id, path, filename, comment
- FROM '.$table.'
- WHERE c_id = '.$courseId.' AND announcement_id = '.$announcementId;
- $result = Database::query($sql);
- if (Database::num_rows($result) != 0) {
- $row = Database::fetch_array($result, 'ASSOC');
- }
- return $row;
- }
- /**
- * This function add a attachment file into announcement.
- *
- * @param int announcement id
- * @param string file comment
- * @param array uploaded file $_FILES
- *
- * @return int -1 if failed, 0 if unknown (should not happen), 1 if success
- */
- public static function add_announcement_attachment_file(
- $announcement_id,
- $file_comment,
- $file
- ) {
- $courseInfo = api_get_course_info();
- $table = Database::get_course_table(TABLE_ANNOUNCEMENT_ATTACHMENT);
- $return = 0;
- $announcement_id = intval($announcement_id);
- $courseId = api_get_course_int_id();
- if (is_array($file) && $file['error'] == 0) {
- // TODO: This path is obsolete. The new document repository scheme should be kept in mind here.
- $courseDir = $courseInfo['path'].'/upload/announcements';
- $sys_course_path = api_get_path(SYS_COURSE_PATH);
- $updir = $sys_course_path.$courseDir;
- // Try to add an extension to the file if it hasn't one
- $new_file_name = add_ext_on_mime(stripslashes($file['name']), $file['type']);
- // user's file name
- $file_name = $file['name'];
- if (!filter_extension($new_file_name)) {
- $return = -1;
- echo Display::return_message(get_lang('File upload failed: this file extension or file type is prohibited'), 'error');
- } else {
- $new_file_name = uniqid('');
- $new_path = $updir.'/'.$new_file_name;
- // This file is copy here but its cleaned in api_mail_html in api.lib.php
- copy($file['tmp_name'], $new_path);
- $params = [
- 'c_id' => $courseId,
- 'filename' => $file_name,
- 'comment' => $file_comment,
- 'path' => $new_file_name,
- 'announcement_id' => $announcement_id,
- 'size' => intval($file['size']),
- ];
- $insertId = Database::insert($table, $params);
- if ($insertId) {
- $sql = "UPDATE $table SET id = iid
- WHERE iid = $insertId";
- Database::query($sql);
- }
- $return = 1;
- }
- }
- return $return;
- }
- /**
- * This function edit a attachment file into announcement.
- *
- * @param int attach id
- * @param array uploaded file $_FILES
- * @param string file comment
- *
- * @return int
- */
- public static function edit_announcement_attachment_file(
- $id_attach,
- $file,
- $file_comment
- ) {
- $courseInfo = api_get_course_info();
- $table = Database::get_course_table(TABLE_ANNOUNCEMENT_ATTACHMENT);
- $return = 0;
- $courseId = api_get_course_int_id();
- if (is_array($file) && $file['error'] == 0) {
- // TODO: This path is obsolete. The new document repository scheme should be kept in mind here.
- $courseDir = $courseInfo['path'].'/upload/announcements';
- $sys_course_path = api_get_path(SYS_COURSE_PATH);
- $updir = $sys_course_path.$courseDir;
- // Try to add an extension to the file if it hasn't one
- $new_file_name = add_ext_on_mime(
- stripslashes($file['name']),
- $file['type']
- );
- // user's file name
- $file_name = $file['name'];
- if (!filter_extension($new_file_name)) {
- $return = -1;
- echo Display::return_message(
- get_lang('File upload failed: this file extension or file type is prohibited'),
- 'error'
- );
- } else {
- $new_file_name = uniqid('');
- $new_path = $updir.'/'.$new_file_name;
- copy($file['tmp_name'], $new_path);
- $safe_file_comment = Database::escape_string($file_comment);
- $safe_file_name = Database::escape_string($file_name);
- $safe_new_file_name = Database::escape_string($new_file_name);
- $id_attach = intval($id_attach);
- $sql = "UPDATE $table SET
- filename = '$safe_file_name',
- comment = '$safe_file_comment',
- path = '$safe_new_file_name',
- size ='".intval($file['size'])."'
- WHERE c_id = $courseId AND id = '$id_attach'";
- $result = Database::query($sql);
- if ($result === false) {
- $return = -1;
- echo Display::return_message(
- get_lang('The uploaded file could not be saved (perhaps a permission problem?)'),
- 'error'
- );
- } else {
- $return = 1;
- }
- }
- }
- return $return;
- }
- /**
- * This function delete a attachment file by id.
- *
- * @param int $id attachment file Id
- *
- * @return bool
- */
- public static function delete_announcement_attachment_file($id)
- {
- $table = Database::get_course_table(TABLE_ANNOUNCEMENT_ATTACHMENT);
- $id = intval($id);
- $courseId = api_get_course_int_id();
- if (empty($courseId) || empty($id)) {
- return false;
- }
- $sql = "DELETE FROM $table
- WHERE c_id = $courseId AND id = $id";
- Database::query($sql);
- return true;
- }
- /**
- * @param array $courseInfo
- * @param int $sessionId
- * @param int $announcementId
- * @param bool $sendToUsersInSession
- * @param bool $sendToDrhUsers
- * @param Monolog\Handler\HandlerInterface logger
- * @param int $senderId
- * @param bool $directMessage
- *
- * @return array
- */
- public static function sendEmail(
- $courseInfo,
- $sessionId,
- $announcementId,
- $sendToUsersInSession = false,
- $sendToDrhUsers = false,
- $logger = null,
- $senderId = 0,
- $directMessage = false
- ) {
- $email = new AnnouncementEmail($courseInfo, $sessionId, $announcementId, $logger);
- return $email->send($sendToUsersInSession, $sendToDrhUsers, $senderId, $directMessage);
- }
- /**
- * @param $stok
- * @param $announcement_number
- * @param bool $getCount
- * @param null $start
- * @param null $limit
- * @param string $sidx
- * @param string $sord
- * @param string $titleToSearch
- * @param int $userIdToSearch
- * @param int $userId
- * @param int $courseId
- * @param int $sessionId
- *
- * @return array
- */
- public static function getAnnouncements(
- $stok,
- $announcement_number,
- $getCount = false,
- $start = null,
- $limit = null,
- $sidx = '',
- $sord = '',
- $titleToSearch = '',
- $userIdToSearch = 0,
- $userId = 0,
- $courseId = 0,
- $sessionId = 0
- ) {
- $tbl_announcement = Database::get_course_table(TABLE_ANNOUNCEMENT);
- $tbl_item_property = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $user_id = $userId ?: api_get_user_id();
- $group_id = api_get_group_id();
- $session_id = $sessionId ?: api_get_session_id();
- if (empty($courseId)) {
- $courseInfo = api_get_course_info();
- $courseId = $courseInfo['real_id'];
- } else {
- $courseId = (int) $courseId;
- $courseInfo = api_get_course_info_by_id($courseId);
- }
- if (empty($courseInfo)) {
- return [];
- }
- $condition_session = api_get_session_condition(
- $session_id,
- true,
- true,
- 'announcement.session_id'
- );
- $group_memberships = GroupManager::get_group_ids(
- $courseId,
- api_get_user_id()
- );
- $allowUserEditSetting = api_get_course_setting('allow_user_edit_announcement');
- $select = ' DISTINCT
- announcement.*,
- ip.visibility,
- ip.to_group_id,
- ip.insert_user_id,
- ip.insert_date,
- ip.lastedit_date';
- $groupBy = ' GROUP BY announcement.iid';
- if ($getCount) {
- $groupBy = '';
- $select = ' COUNT(DISTINCT announcement.iid) count';
- }
- $searchCondition = '';
- if (!empty($titleToSearch)) {
- $titleToSearch = Database::escape_string($titleToSearch);
- $searchCondition .= " AND (title LIKE '%$titleToSearch%')";
- }
- if (!empty($userIdToSearch)) {
- $userIdToSearch = (int) $userIdToSearch;
- $searchCondition .= " AND (ip.insert_user_id = $userIdToSearch)";
- }
- $allowOnlyGroup = api_get_configuration_value('hide_base_course_announcements_in_group');
- $extraGroupCondition = '';
- if ($allowOnlyGroup) {
- $extraGroupCondition = " AND ip.to_group_id = $group_id ";
- }
- $allowDrhAccess = api_get_configuration_value('allow_drh_access_announcement');
- if ($allowDrhAccess && api_is_drh()) {
- // DRH only can see visible
- $searchCondition .= ' AND (ip.visibility = 1)';
- }
- if (api_is_allowed_to_edit(false, true) ||
- ($allowUserEditSetting && !api_is_anonymous()) ||
- ($allowDrhAccess && api_is_drh())
- ) {
- // A.1. you are a course admin with a USER filter
- // => see only the messages of this specific user + the messages of the group (s)he is member of.
- //if (!empty($user_id)) {
- if (0) {
- if (is_array($group_memberships) &&
- count($group_memberships) > 0
- ) {
- $sql = "SELECT $select
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.id = ip.ref AND ip.c_id = announcement.c_id)
- WHERE
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.tool = 'announcement' AND
- (
- ip.to_user_id = $user_id OR
- ip.to_group_id IS NULL OR
- ip.to_group_id IN (0, ".implode(", ", $group_memberships).")
- ) AND
- ip.visibility IN ('1', '0')
- $condition_session
- $searchCondition
- ORDER BY display_order DESC";
- } else {
- $sql = "SELECT $select
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.id = ip.ref AND ip.c_id = announcement.c_id)
- WHERE
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.tool ='announcement' AND
- (ip.to_user_id = $user_id OR ip.to_group_id='0' OR ip.to_group_id IS NULL) AND
- ip.visibility IN ('1', '0')
- $condition_session
- $searchCondition
- ORDER BY display_order DESC";
- }
- } elseif ($group_id != 0) {
- // A.2. you are a course admin with a GROUP filter
- // => see only the messages of this specific group
- $sql = "SELECT $select
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.id = ip.ref AND announcement.c_id = ip.c_id)
- WHERE
- ip.tool='announcement' AND
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.visibility<>'2' AND
- (ip.to_group_id = $group_id OR ip.to_group_id='0' OR ip.to_group_id IS NULL)
- $condition_session
- $searchCondition
- $extraGroupCondition
- $groupBy
- ORDER BY display_order DESC";
- } else {
- // A.3 you are a course admin without any group or user filter
- // A.3.a you are a course admin without user or group filter but WITH studentview
- // => see all the messages of all the users and groups without editing possibilities
- if (isset($isStudentView) && $isStudentView == 'true') {
- $sql = "SELECT $select
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.id = ip.ref AND announcement.c_id = ip.c_id)
- WHERE
- ip.tool='announcement' AND
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.visibility='1'
- $condition_session
- $searchCondition
- $groupBy
- ORDER BY display_order DESC";
- } else {
- // A.3.a you are a course admin without user or group filter and WTIHOUT studentview (= the normal course admin view)
- // => see all the messages of all the users and groups with editing possibilities
- $sql = "SELECT $select
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.id = ip.ref AND announcement.c_id = ip.c_id)
- WHERE
- ip.tool = 'announcement' AND
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- (ip.visibility='0' OR ip.visibility='1')
- $condition_session
- $searchCondition
- $groupBy
- ORDER BY display_order DESC";
- }
- }
- } else {
- // STUDENT
- if (is_array($group_memberships) && count($group_memberships) > 0) {
- if ($allowUserEditSetting && !api_is_anonymous()) {
- if ($group_id == 0) {
- // No group
- $cond_user_id = " AND (
- ip.lastedit_user_id = '".$user_id."' OR (
- (ip.to_user_id='$user_id' OR ip.to_user_id IS NULL) OR
- (ip.to_group_id IS NULL OR ip.to_group_id IN (0, ".implode(", ", $group_memberships)."))
- )
- ) ";
- } else {
- $cond_user_id = " AND (
- ip.lastedit_user_id = '".$user_id."' OR ip.to_group_id IS NULL OR ip.to_group_id IN (0, ".$group_id.")
- )";
- $cond_user_id .= $extraGroupCondition;
- }
- } else {
- if ($group_id == 0) {
- $cond_user_id = " AND (
- (ip.to_user_id='$user_id' OR ip.to_user_id IS NULL) AND
- (ip.to_group_id IS NULL OR ip.to_group_id IN (0, ".implode(", ", $group_memberships)."))
- ) ";
- } else {
- $cond_user_id = " AND (
- (ip.to_user_id='$user_id' OR ip.to_user_id IS NULL) AND
- (ip.to_group_id IS NULL OR ip.to_group_id IN (0, ".$group_id."))
- )";
- $cond_user_id .= $extraGroupCondition;
- }
- }
- $sql = "SELECT $select
- FROM $tbl_announcement announcement INNER JOIN
- $tbl_item_property ip
- ON (announcement.id = ip.ref AND announcement.c_id = ip.c_id)
- WHERE
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.tool='announcement'
- $cond_user_id
- $condition_session
- $searchCondition AND
- ip.visibility='1'
- $groupBy
- ORDER BY display_order DESC";
- } else {
- if ($user_id) {
- if ($allowUserEditSetting && !api_is_anonymous()) {
- $cond_user_id = " AND (
- ip.lastedit_user_id = '".api_get_user_id()."' OR
- ((ip.to_user_id='$user_id' OR ip.to_user_id IS NULL) AND
- (ip.to_group_id='0' OR ip.to_group_id IS NULL)
- )
- ) ";
- } else {
- $cond_user_id = " AND ((ip.to_user_id='$user_id' OR ip.to_user_id IS NULL) AND
- (ip.to_group_id='0' OR ip.to_group_id IS NULL) ) ";
- }
- $sql = "SELECT $select
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.id = ip.ref AND announcement.c_id = ip.c_id)
- WHERE
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.tool='announcement'
- $cond_user_id
- $condition_session
- $searchCondition
- AND ip.visibility='1'
- AND announcement.session_id IN(0, ".$session_id.")
- $groupBy
- ORDER BY display_order DESC";
- } else {
- if (($allowUserEditSetting && !api_is_anonymous())) {
- $cond_user_id = " AND (
- ip.lastedit_user_id = '".$user_id."' OR ip.to_group_id='0' OR ip.to_group_id IS NULL
- )";
- } else {
- $cond_user_id = " AND ip.to_group_id='0' OR ip.to_group_id IS NULL ";
- }
- $sql = "SELECT $select
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.id = ip.ref AND announcement.c_id = ip.c_id)
- WHERE
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.tool='announcement'
- $cond_user_id
- $condition_session
- $searchCondition AND
- ip.visibility='1' AND
- announcement.session_id IN ( 0,".api_get_session_id().")
- $groupBy
- ";
- }
- }
- }
- if (!is_null($start) && !is_null($limit)) {
- $start = (int) $start;
- $limit = (int) $limit;
- $sql .= " LIMIT $start, $limit";
- }
- $result = Database::query($sql);
- if ($getCount) {
- $result = Database::fetch_array($result, 'ASSOC');
- return $result['count'];
- }
- $iterator = 1;
- $bottomAnnouncement = $announcement_number;
- $displayed = [];
- $results = [];
- $actionUrl = api_get_path(WEB_CODE_PATH).'announcements/announcements.php?'.api_get_cidreq();
- $emailIcon = '<i class="fa fa-envelope-o" title="'.get_lang('Announcement sent by e-mail').'"></i>';
- $attachmentIcon = '<i class="fa fa-paperclip" title="'.get_lang('Attachment').'"></i>';
- $editIcon = Display::return_icon(
- 'edit.png',
- get_lang('Edit'),
- '',
- ICON_SIZE_SMALL
- );
- $editIconDisable = Display::return_icon(
- 'edit_na.png',
- get_lang('Edit'),
- '',
- ICON_SIZE_SMALL
- );
- $deleteIcon = Display::return_icon(
- 'delete.png',
- get_lang('Delete'),
- '',
- ICON_SIZE_SMALL
- );
- $deleteIconDisable = Display::return_icon(
- 'delete_na.png',
- get_lang('Delete'),
- '',
- ICON_SIZE_SMALL
- );
- $isTutor = false;
- if (!empty($group_id)) {
- $groupInfo = GroupManager::get_group_properties(api_get_group_id());
- //User has access in the group?
- $isTutor = GroupManager::is_tutor_of_group(
- api_get_user_id(),
- $groupInfo
- );
- }
- while ($row = Database::fetch_array($result, 'ASSOC')) {
- if (!in_array($row['id'], $displayed)) {
- $sent_to_icon = '';
- // the email icon
- if ($row['email_sent'] == '1') {
- $sent_to_icon = ' '.$emailIcon;
- }
- $groupReference = $row['to_group_id'] > 0 ? ' <span class="label label-info">'.get_lang('Group').'</span> ' : '';
- $disableEdit = false;
- $to = self::loadEditUsers('announcement', $row['id'], true);
- $separated = CourseManager::separateUsersGroups($to);
- if (!empty($group_id)) {
- // If the announcement was sent to many groups, disable edition inside a group
- if (isset($separated['groups']) && count($separated['groups']) > 1) {
- $disableEdit = true;
- }
- // If the announcement was sent only to the course disable edition
- if (empty($separated['groups']) && empty($separated['users'])) {
- $disableEdit = true;
- }
- // Announcement sent to only a user
- if ($separated['groups'] > 1 && !in_array($group_id, $separated['groups'])) {
- $disableEdit = true;
- }
- } else {
- if (isset($separated['groups']) && count($separated['groups']) > 1) {
- $groupReference = '';
- }
- }
- $title = $row['title'].$groupReference.$sent_to_icon;
- $item_visibility = api_get_item_visibility(
- $courseInfo,
- TOOL_ANNOUNCEMENT,
- $row['id'],
- $session_id
- );
- $row['visibility'] = $item_visibility;
- // show attachment list
- $attachment_list = self::get_attachment($row['id']);
- $attachment_icon = '';
- if (count($attachment_list) > 0) {
- $attachment_icon = ' '.$attachmentIcon;
- }
- /* TITLE */
- $user_info = api_get_user_info($row['insert_user_id']);
- $username = sprintf(get_lang('Login: %s'), $user_info['username']);
- $username_span = Display::tag(
- 'span',
- $user_info['complete_name'],
- ['title' => $username]
- );
- $title = Display::url(
- $title.$attachment_icon,
- $actionUrl.'&action=view&id='.$row['id']
- );
- // we can edit if : we are the teacher OR the element belongs to
- // the session we are coaching OR the option to allow users to edit is on
- if (api_is_allowed_to_edit(false, true) ||
- (api_is_session_general_coach() && api_is_element_in_the_session(TOOL_ANNOUNCEMENT, $row['id'])) ||
- (api_get_course_setting('allow_user_edit_announcement') && !api_is_anonymous()) ||
- ($row['to_group_id'] == $group_id && $isTutor)
- ) {
- if ($disableEdit === true) {
- $modify_icons = "<a href='#'>".$editIconDisable."</a>";
- } else {
- $modify_icons = "<a href=\"".$actionUrl."&action=modify&id=".$row['id']."\">".$editIcon."</a>";
- }
- if ($row['visibility'] == 1) {
- $image_visibility = "visible";
- $alt_visibility = get_lang('Hide');
- } else {
- $image_visibility = "invisible";
- $alt_visibility = get_lang('Visible');
- }
- $modify_icons .= "<a href=\"".$actionUrl."&action=showhide&id=".$row['id']."&sec_token=".$stok."\">".
- Display::return_icon($image_visibility.'.png', $alt_visibility, '', ICON_SIZE_SMALL)."</a>";
- // DISPLAY MOVE UP COMMAND only if it is not the top announcement
- if ($iterator != 1) {
- $modify_icons .= "<a href=\"".$actionUrl."&action=move&up=".$row["id"]."&sec_token=".$stok."\">".
- Display::return_icon('up.gif', get_lang('Up'))."</a>";
- } else {
- $modify_icons .= Display::return_icon('up_na.gif', get_lang('Up'));
- }
- if ($iterator < $bottomAnnouncement) {
- $modify_icons .= "<a href=\"".$actionUrl."&action=move&down=".$row["id"]."&sec_token=".$stok."\">".
- Display::return_icon('down.gif', get_lang('down'))."</a>";
- } else {
- $modify_icons .= Display::return_icon('down_na.gif', get_lang('down'));
- }
- if (api_is_allowed_to_edit(false, true)) {
- if ($disableEdit === true) {
- $modify_icons .= Display::url($deleteIconDisable, '#');
- } else {
- $modify_icons .= "<a href=\"".$actionUrl."&action=delete&id=".$row['id']."&sec_token=".$stok."\" onclick=\"javascript:if(!confirm('".addslashes(
- api_htmlentities(
- get_lang('Please confirm your choice'),
- ENT_QUOTES,
- api_get_system_encoding()
- )
- )."')) return false;\">".
- $deleteIcon."</a>";
- }
- }
- $iterator++;
- } else {
- $modify_icons = Display::url(
- Display::return_icon('default.png'),
- $actionUrl.'&action=view&id='.$row['id']
- );
- }
- $announcement = [
- 'id' => $row['id'],
- 'title' => $title,
- 'username' => $username_span,
- 'insert_date' => api_convert_and_format_date(
- $row['insert_date'],
- DATE_TIME_FORMAT_LONG
- ),
- 'lastedit_date' => api_convert_and_format_date(
- $row['lastedit_date'],
- DATE_TIME_FORMAT_LONG
- ),
- 'actions' => $modify_icons,
- ];
- $results[] = $announcement;
- }
- $displayed[] = $row['id'];
- }
- return $results;
- }
- /**
- * @return int
- */
- public static function getNumberAnnouncements()
- {
- // Maximum title messages to display
- $maximum = '12';
- // Database Table Definitions
- $tbl_announcement = Database::get_course_table(TABLE_ANNOUNCEMENT);
- $tbl_item_property = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $session_id = api_get_session_id();
- $courseInfo = api_get_course_info();
- $courseId = $courseInfo['real_id'];
- $userId = api_get_user_id();
- $condition_session = api_get_session_condition(
- $session_id,
- true,
- true,
- 'announcement.session_id'
- );
- if (api_is_allowed_to_edit(false, true)) {
- // check teacher status
- if (empty($_GET['origin']) || $_GET['origin'] !== 'learnpath') {
- if (api_get_group_id() == 0) {
- $group_condition = '';
- } else {
- $group_condition = " AND (ip.to_group_id='".api_get_group_id()."' OR ip.to_group_id = 0 OR ip.to_group_id IS NULL)";
- }
- $sql = "SELECT
- announcement.*,
- ip.visibility,
- ip.to_group_id,
- ip.insert_user_id
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.c_id = ip.c_id AND announcement.id = ip.ref)
- WHERE
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.tool = 'announcement' AND
- ip.visibility <> '2'
- $group_condition
- $condition_session
- GROUP BY ip.ref
- ORDER BY display_order DESC
- LIMIT 0, $maximum";
- }
- } else {
- // students only get to see the visible announcements
- if (empty($_GET['origin']) || $_GET['origin'] !== 'learnpath') {
- $group_memberships = GroupManager::get_group_ids(
- $courseInfo['real_id'],
- $userId
- );
- if ((api_get_course_setting('allow_user_edit_announcement') &&
- !api_is_anonymous())
- ) {
- if (api_get_group_id() == 0) {
- $cond_user_id = " AND (
- ip.lastedit_user_id = '".$userId."' OR (
- ip.to_user_id='".$userId."' OR
- ip.to_group_id IN (0, ".implode(", ", $group_memberships).") OR
- ip.to_group_id IS NULL
- )
- )
- ";
- } else {
- $cond_user_id = " AND (
- ip.lastedit_user_id = '".$userId."'OR
- ip.to_group_id IN (0, ".api_get_group_id().") OR
- ip.to_group_id IS NULL
- )";
- }
- } else {
- if (api_get_group_id() == 0) {
- $cond_user_id = " AND (
- ip.to_user_id='".$userId."' OR
- ip.to_group_id IN (0, ".implode(", ", $group_memberships).") OR
- ip.to_group_id IS NULL
- ) ";
- } else {
- $cond_user_id = " AND (
- ip.to_user_id='".$userId."' OR
- ip.to_group_id IN (0, ".api_get_group_id().") OR
- ip.to_group_id IS NULL
- ) ";
- }
- }
- // the user is member of several groups => display personal announcements AND
- // his group announcements AND the general announcements
- if (is_array($group_memberships) && count($group_memberships) > 0) {
- $sql = "SELECT announcement.*, ip.visibility, ip.to_group_id, ip.insert_user_id
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.id = ip.ref AND announcement.c_id = ip.c_id)
- WHERE
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.tool='announcement' AND
- ip.visibility='1'
- $cond_user_id
- $condition_session
- GROUP BY ip.ref
- ORDER BY display_order DESC
- LIMIT 0, $maximum";
- } else {
- // the user is not member of any group
- // this is an identified user => show the general announcements AND his personal announcements
- if ($userId) {
- if ((api_get_course_setting('allow_user_edit_announcement') &&
- !api_is_anonymous())
- ) {
- $cond_user_id = " AND (
- ip.lastedit_user_id = '".$userId."' OR
- ( ip.to_user_id='".$userId."' OR ip.to_group_id='0' OR ip.to_group_id IS NULL)
- ) ";
- } else {
- $cond_user_id = " AND ( ip.to_user_id='".$userId."' OR ip.to_group_id='0' OR ip.to_group_id IS NULL) ";
- }
- $sql = "SELECT announcement.*, ip.visibility, ip.to_group_id, ip.insert_user_id
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.c_id = ip.c_id AND announcement.id = ip.ref)
- WHERE
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.tool='announcement' AND
- ip.visibility='1'
- $cond_user_id
- $condition_session
- GROUP BY ip.ref
- ORDER BY display_order DESC
- LIMIT 0, $maximum";
- } else {
- if (api_get_course_setting('allow_user_edit_announcement')) {
- $cond_user_id = " AND (
- ip.lastedit_user_id = '".api_get_user_id()."' OR ip.to_group_id='0' OR ip.to_group_id IS NULL
- ) ";
- } else {
- $cond_user_id = " AND ip.to_group_id='0' ";
- }
- // the user is not identiefied => show only the general announcements
- $sql = "SELECT
- announcement.*,
- ip.visibility,
- ip.to_group_id,
- ip.insert_user_id
- FROM $tbl_announcement announcement
- INNER JOIN $tbl_item_property ip
- ON (announcement.id = ip.ref AND announcement.c_id = ip.c_id)
- WHERE
- announcement.c_id = $courseId AND
- ip.c_id = $courseId AND
- ip.tool='announcement' AND
- ip.visibility='1' AND
- ip.to_group_id='0'
- $condition_session
- GROUP BY ip.ref
- ORDER BY display_order DESC
- LIMIT 0, $maximum";
- }
- }
- }
- }
- $result = Database::query($sql);
- return Database::num_rows($result);
- }
- }
|