ILIAS  release_5-4 Revision v5.4.26-12-gabc799a52e6
ilSystemNotification Class Reference

Wrapper classes for system notifications. More...

+ Inheritance diagram for ilSystemNotification:
+ Collaboration diagram for ilSystemNotification:

Public Member Functions

 setSubjectLangId ($a_lang_id)
 Set subject lang id. More...
 
 setSubjectDirect ($a_text)
 Set subject text. More...
 
 setIntroductionLangId ($a_lang_id)
 Set introduction lang id. More...
 
 setIntroductionDirect ($a_text)
 Set introduction text. More...
 
 setTaskLangId ($a_lang_id)
 Set task lang id. More...
 
 setReasonLangId ($a_lang_id)
 Set reason lang id. More...
 
 setGotoLangId ($a_lang_id)
 Set goto lang id. More...
 
 setChangedByUserId ($a_id)
 Set changed by user id. More...
 
 addAdditionalInfo ($a_lang_id, $a_value, $a_multiline=false, $a_lang_direct=false)
 Add additional information. More...
 
 sendMail (array $a_user_ids, $a_goto_additional=null, $a_permission="read")
 Send notification(s) More...
 
 compose ($a_user_id, $a_goto_additional=null, $a_permission="read", $a_append_signature_direct=false)
 Compose notification to single recipient. More...
 
 composeAndGetMessage ($a_user_id, $a_goto_additional=null, $a_permission="read", $a_append_signature_direct=false)
 Compose notification to single recipient. More...
 
- Public Member Functions inherited from ilMailNotification
 __construct ($a_is_personal_workspace=false)
 
 setType ($a_type)
 Set notification type. More...
 
 getType ()
 Get notification type. More...
 
 setSender ($a_usr_id)
 Set sender of mail. More...
 
 getSender ()
 get sender of mail More...
 
 setRecipients (array $a_rcp)
 
 getRecipients ()
 get array of recipients More...
 
 setAttachments ($a_att)
 Set attachments. More...
 
 getAttachments ()
 Get attachments. More...
 
 setLangModules (array $a_modules)
 Set lang modules. More...
 
 getUserLanguage ($a_usr_id)
 Get user language. More...
 
 setRefId ($a_id)
 
 getRefId ()
 
 getObjId ()
 
 setObjId ($a_obj_id)
 
 getObjType ()
 Get object type. More...
 
 setAdditionalInformation (array $a_info)
 Additional information for creating notification mails. More...
 
 getAdditionalInformation ()
 
 sendMail (array $a_rcp, $a_type, $a_parse_recipients=true)
 
 getBlockBorder ()
 Get (ascii) block border. More...
 

Protected Member Functions

 composeAndSendMail ($a_user_id, $a_goto_additional=null, $a_permission="read")
 Send notification to single recipient. More...
 
- Protected Member Functions inherited from ilMailNotification
 setSubject ($a_subject)
 
 getSubject ()
 
 setBody ($a_body)
 
 appendBody ($a_body)
 Append body text. More...
 
 getBody ()
 
 initLanguage ($a_usr_id)
 Init language. More...
 
 initLanguageByIso2Code ($a_code='')
 Init language by ISO2 code. More...
 
 setLanguage ($a_language)
 
 getLanguage ()
 
 getLanguageText ($a_keyword)
 
 getObjectTitle ($a_shorten=false)
 
 initMail ()
 
 getMail ()
 
 createPermanentLink ($a_params=array(), $a_append='')
 
 userToString ($a_usr_id)
 
 isRefIdAccessible ($a_user_id, $a_ref_id, $a_permission="read")
 Check if ref id is accessible for user. More...
 

Protected Attributes

 $subject_lang_id
 
 $subject_direct
 
 $introduction
 
 $introduction_direct
 
 $task
 
 $reason
 
 $additional
 
 $goto_caption
 
 $changed_by
 
 $all_ref_ids
 
- Protected Attributes inherited from ilMailNotification
 $type = null
 
 $sender = null
 
 $mail = null
 
 $subject = ''
 
 $body = ''
 
 $attachments = array()
 
 $language = null
 
 $lang_modules = array()
 
 $recipients = array()
 
 $ref_id = null
 
 $obj_id = null
 
 $obj_type = null
 
 $additional_info = array()
 
 $is_in_wsp
 
 $wsp_tree
 
 $wsp_access_handler
 

Additional Inherited Members

- Data Fields inherited from ilMailNotification
const SUBJECT_TITLE_LENGTH = 60
 

Detailed Description

Wrapper classes for system notifications.

See also
FeatureWiki/Guidelines/System Notification Guideline
Author
Jörg Lützenkirchen luetz.nosp@m.enki.nosp@m.rchen.nosp@m.@lei.nosp@m.fos.c.nosp@m.om
Id
class.ilObjExerciseGUI.php 24003 2010-05-26 14:35:42Z akill

Definition at line 16 of file class.ilSystemNotification.php.

Member Function Documentation

◆ addAdditionalInfo()

ilSystemNotification::addAdditionalInfo (   $a_lang_id,
  $a_value,
  $a_multiline = false,
  $a_lang_direct = false 
)

Add additional information.

Parameters
string$a_lang_id
mixed$a_value
bool$a_multiline
bool$a_lang_direct

Definition at line 119 of file class.ilSystemNotification.php.

120  {
121  $this->additional[$a_lang_id] = array(trim($a_value), (bool) $a_multiline, (bool) $a_lang_direct);
122  }

◆ compose()

ilSystemNotification::compose (   $a_user_id,
  $a_goto_additional = null,
  $a_permission = "read",
  $a_append_signature_direct = false 
)

Compose notification to single recipient.

Parameters
mixed$a_rcp
string$a_goto_additional
string$a_permission
bool$a_append_signature_direct
Returns
bool

Definition at line 181 of file class.ilSystemNotification.php.

References ilMailNotification\$ref_id, ilMail\_getAutoGeneratedMessageString(), ilMail\_getInstallationSignature(), ilMailNotification\appendBody(), ilMailNotification\createPermanentLink(), ilMailNotification\getBlockBorder(), ilMailNotification\getLanguage(), ilMailNotification\getLanguageText(), ilMailNotification\getMail(), ilUserUtil\getNamePresentation(), ilMailNotification\getObjectTitle(), ilMailNotification\getObjId(), ilMailNotification\getObjType(), ilMailNotification\getRefId(), ilMail\getSalutation(), ilMailNotification\initLanguage(), ilMailNotification\initMail(), ilMailNotification\isRefIdAccessible(), ilMailNotification\setBody(), and ilMailNotification\setSubject().

Referenced by composeAndGetMessage(), and composeAndSendMail().

182  {
183  $this->initLanguage($a_user_id);
184  $this->initMail();
185 
186  if ($this->subject_direct) {
187  $this->setSubject($this->subject_direct);
188  } else {
189  $this->setSubject(
190  sprintf($this->getLanguageText($this->subject_lang_id), $this->getObjectTitle(true))
191  );
192  }
193 
194  $this->setBody(ilMail::getSalutation($a_user_id, $this->getLanguage()));
195  $this->appendBody("\n\n");
196 
197  if ($this->introduction) {
198  $this->appendBody($this->getLanguageText($this->introduction));
199  $this->appendBody("\n\n");
200  }
201 
202  if ($this->introduction_direct) {
203  $this->appendBody($this->introduction_direct);
204  $this->appendBody("\n\n");
205  }
206 
207  if ($this->task) {
208  $this->appendBody($this->getLanguageText($this->task));
209  $this->appendBody("\n\n");
210  }
211 
212  // details table
213  if ($this->getObjId()) {
214  $this->appendBody($this->getLanguageText("obj_" . $this->getObjType()) . ": " .
215  $this->getObjectTitle() . "\n");
216  }
217  if (is_array($this->additional)) {
218  foreach ($this->additional as $lang_id => $item) {
219  $caption = "";
220  if ($lang_id) {
221  $caption = (!$item[2])
222  ? $this->getLanguageText($lang_id)
223  : $lang_id;
224  }
225  if (!$item[1]) {
226  if ($caption) {
227  $caption .= ": ";
228  }
229  $this->appendBody($caption . $item[0] . "\n");
230  } else {
231  if ($caption) {
232  $caption .= "\n";
233  }
234  $this->appendBody("\n" . $caption .
235  $this->getBlockBorder() .
236  $item[0] . "\n" .
237  $this->getBlockBorder() . "\n");
238  }
239  }
240  }
241  $this->body = trim($this->body);
242  $this->appendBody("\n\n");
243 
244  if ($this->changed_by) {
245  $this->appendBody($this->getLanguageText("system_notification_installation_changed_by") . ": " .
246  ilUserUtil::getNamePresentation($this->changed_by));
247  $this->appendBody("\n\n");
248  }
249 
250  if ($this->getObjId()) {
251  // try to find accessible ref_id
252  if (!$this->getRefId() && $this->all_ref_ids) {
253  $find_ref_id = true;
254  foreach ($this->all_ref_ids as $ref_id) {
255  if ($this->isRefIdAccessible($a_user_id, $ref_id, $a_permission)) {
256  $this->ref_id = $ref_id;
257  break;
258  }
259  }
260  }
261 
262  // check if initially given ref_id is accessible for current recipient
263  if ($this->getRefId() &&
264  !$find_ref_id &&
265  !$this->isRefIdAccessible($a_user_id, $this->getRefId(), $a_permission)) {
266  return false;
267  }
268 
269  $goto = $this->createPermanentLink(array(), $a_goto_additional);
270  if ($goto) {
271  $this->appendBody($this->getLanguageText($this->goto_caption) . ": " .
272  $goto);
273  $this->appendBody("\n\n");
274  }
275 
276  if ($find_ref_id) {
277  $this->ref_id = null;
278  }
279  }
280 
281  if ($this->reason) {
282  $this->appendBody($this->getLanguageText($this->reason));
283  $this->appendBody("\n\n");
284  }
285 
287 
288  // signature will append new lines
289  $this->body = trim($this->body);
290 
291  if (!$a_append_signature_direct) {
292  $this->getMail()->appendInstallationSignature(true);
293  } else {
295  }
296 
297  return true;
298  }
initLanguage($a_usr_id)
Init language.
isRefIdAccessible($a_user_id, $a_ref_id, $a_permission="read")
Check if ref id is accessible for user.
getObjectTitle($a_shorten=false)
static getNamePresentation( $a_user_id, $a_user_image=false, $a_profile_link=false, $a_profile_back_link="", $a_force_first_lastname=false, $a_omit_login=false, $a_sortable=true, $a_return_data_array=false, $a_ctrl_path="ilpublicuserprofilegui")
Default behaviour is:
getObjType()
Get object type.
getBlockBorder()
Get (ascii) block border.
createPermanentLink($a_params=array(), $a_append='')
static _getAutoGeneratedMessageString(ilLanguage $lang=null)
Get auto generated info string.
appendBody($a_body)
Append body text.
static _getInstallationSignature()
static getSalutation($a_usr_id, ilLanguage $a_language=null)
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ composeAndGetMessage()

ilSystemNotification::composeAndGetMessage (   $a_user_id,
  $a_goto_additional = null,
  $a_permission = "read",
  $a_append_signature_direct = false 
)

Compose notification to single recipient.

Parameters
mixed$a_user_id
string$a_goto_additional
string$a_permission
bool$a_append_signature_direct
Returns
string

Definition at line 326 of file class.ilSystemNotification.php.

References ilMailNotification\$body, and compose().

327  {
328  if ($this->compose($a_user_id, $a_goto_additional, $a_permission, $a_append_signature_direct)) {
329  return $this->body;
330  }
331  }
compose($a_user_id, $a_goto_additional=null, $a_permission="read", $a_append_signature_direct=false)
Compose notification to single recipient.
+ Here is the call graph for this function:

◆ composeAndSendMail()

ilSystemNotification::composeAndSendMail (   $a_user_id,
  $a_goto_additional = null,
  $a_permission = "read" 
)
protected

Send notification to single recipient.

Parameters
mixed$a_rcp
string$a_goto_additional
string$a_permission
Returns
bool

Definition at line 308 of file class.ilSystemNotification.php.

References compose().

Referenced by sendMail().

309  {
310  if ($this->compose($a_user_id, $a_goto_additional, $a_permission)) {
311  parent::sendMail(array($a_user_id), array('system'), is_numeric($a_user_id));
312  return true;
313  }
314  return false;
315  }
compose($a_user_id, $a_goto_additional=null, $a_permission="read", $a_append_signature_direct=false)
Compose notification to single recipient.
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ sendMail()

ilSystemNotification::sendMail ( array  $a_user_ids,
  $a_goto_additional = null,
  $a_permission = "read" 
)

Send notification(s)

Parameters
array$a_user_ids
string$a_goto_additional
string$a_permission
Returns
array recipient ids

Definition at line 132 of file class.ilSystemNotification.php.

References ilObject\_getAllReferences(), composeAndSendMail(), ilMailNotification\getObjId(), and ilMailNotification\getRefId().

133  {
134  $this->all_ref_ids = null;
135 
136  // prepare object related info
137  if ($this->getObjId()) {
138  if (!$this->getRefId()) {
139  // try to find ref_id(s)
140  if (!$this->is_in_wsp) {
141  $ref_ids = ilObject::_getAllReferences($this->getObjId());
142  if (sizeof($ref_ids) == 1) {
143  $this->ref_id = array_shift($ref_ids);
144  } else {
145  $this->all_ref_ids = $ref_ids;
146  }
147  }
148  } elseif ($this->is_in_wsp) { // #11680
149  $this->ref_id = $this->wsp_tree->lookupNodeId($this->getObjId());
150  }
151 
152  // default values
153  if (!$this->goto_caption) {
154  $this->goto_caption = "url";
155  }
156  }
157 
158  $recipient_ids = array();
159  foreach (array_unique($a_user_ids) as $user_id) {
160  // author of change should not get notification
161  if ($this->changed_by == $user_id) {
162  continue;
163  }
164  if ($this->composeAndSendMail($user_id, $a_goto_additional, $a_permission)) {
165  $recipient_ids[] = $user_id;
166  }
167  }
168 
169  return $recipient_ids;
170  }
static _getAllReferences($a_id)
get all reference ids of object
composeAndSendMail($a_user_id, $a_goto_additional=null, $a_permission="read")
Send notification to single recipient.
+ Here is the call graph for this function:

◆ setChangedByUserId()

ilSystemNotification::setChangedByUserId (   $a_id)

Set changed by user id.

Parameters
int$a_id

Definition at line 104 of file class.ilSystemNotification.php.

105  {
106  $this->changed_by = (int) $a_id;
107 
108  include_once "Services/User/classes/class.ilUserUtil.php";
109  }

◆ setGotoLangId()

ilSystemNotification::setGotoLangId (   $a_lang_id)

Set goto lang id.

Parameters
string$a_lang_id

Definition at line 94 of file class.ilSystemNotification.php.

95  {
96  $this->goto_caption = (string) $a_lang_id;
97  }

◆ setIntroductionDirect()

ilSystemNotification::setIntroductionDirect (   $a_text)

Set introduction text.

Parameters
string$a_text

Definition at line 64 of file class.ilSystemNotification.php.

65  {
66  $this->introduction_direct = trim($a_text);
67  }

◆ setIntroductionLangId()

ilSystemNotification::setIntroductionLangId (   $a_lang_id)

Set introduction lang id.

Parameters
string$a_lang_id

Definition at line 54 of file class.ilSystemNotification.php.

55  {
56  $this->introduction = (string) $a_lang_id;
57  }

◆ setReasonLangId()

ilSystemNotification::setReasonLangId (   $a_lang_id)

Set reason lang id.

Parameters
string$a_lang_id

Definition at line 84 of file class.ilSystemNotification.php.

85  {
86  $this->reason = (string) $a_lang_id;
87  }

◆ setSubjectDirect()

ilSystemNotification::setSubjectDirect (   $a_text)

Set subject text.

Parameters
string$a_text

Definition at line 44 of file class.ilSystemNotification.php.

45  {
46  $this->subject_direct = trim($a_text);
47  }

◆ setSubjectLangId()

ilSystemNotification::setSubjectLangId (   $a_lang_id)

Set subject lang id.

Parameters
string$a_lang_id

Definition at line 34 of file class.ilSystemNotification.php.

35  {
36  $this->subject_lang_id = (string) $a_lang_id;
37  }

◆ setTaskLangId()

ilSystemNotification::setTaskLangId (   $a_lang_id)

Set task lang id.

Parameters
string$a_lang_id

Definition at line 74 of file class.ilSystemNotification.php.

75  {
76  $this->task = (string) $a_lang_id;
77  }

Field Documentation

◆ $additional

ilSystemNotification::$additional
protected

Definition at line 24 of file class.ilSystemNotification.php.

◆ $all_ref_ids

ilSystemNotification::$all_ref_ids
protected

Definition at line 27 of file class.ilSystemNotification.php.

◆ $changed_by

ilSystemNotification::$changed_by
protected

Definition at line 26 of file class.ilSystemNotification.php.

◆ $goto_caption

ilSystemNotification::$goto_caption
protected

Definition at line 25 of file class.ilSystemNotification.php.

◆ $introduction

ilSystemNotification::$introduction
protected

Definition at line 20 of file class.ilSystemNotification.php.

◆ $introduction_direct

ilSystemNotification::$introduction_direct
protected

Definition at line 21 of file class.ilSystemNotification.php.

◆ $reason

ilSystemNotification::$reason
protected

Definition at line 23 of file class.ilSystemNotification.php.

◆ $subject_direct

ilSystemNotification::$subject_direct
protected

Definition at line 19 of file class.ilSystemNotification.php.

◆ $subject_lang_id

ilSystemNotification::$subject_lang_id
protected

Definition at line 18 of file class.ilSystemNotification.php.

◆ $task

ilSystemNotification::$task
protected

Definition at line 22 of file class.ilSystemNotification.php.


The documentation for this class was generated from the following file: