ILIAS  release_5-3 Revision v5.3.23-19-g915713cf615
ilChatroomPostMessageGUI Class Reference

Class ilChatroomPostMessageGUI. More...

+ Inheritance diagram for ilChatroomPostMessageGUI:
+ Collaboration diagram for ilChatroomPostMessageGUI:

Public Member Functions

 executeDefault ($method)
 Prepares and posts message fetched from $_REQUEST['message'] to recipients fetched from $_REQUEST['recipient'] and adds an entry to history if successful. More...
 
- Public Member Functions inherited from ilChatroomGUIHandler
 __construct (ilChatroomObjectGUI $gui)
 
 sendResponse ($response)
 Sends a json encoded response and exits the php process. More...
 
 hasPermission ($permission)
 Checks for access with ilRbacSystem. More...
 
 execute ($method)
 Executes given $method if existing, otherwise executes executeDefault() method. More...
 
 executeDefault ($requestedMethod)
 
 redirectIfNoPermission ($permission)
 Checks for requested permissions and redirects if the permission check failed. More...
 
 isSuccessful ($response)
 Checks for success param in an json decoded response. More...
 

Private Member Functions

 buildMessage ($messageString, $params, ilChatroomUser $chat_user)
 Instantiates stdClass, sets $data->user, $data->message, $data->public and $data->recipients using given $chat_user, $messageString and $params and returns $data. More...
 

Additional Inherited Members

- Protected Member Functions inherited from ilChatroomGUIHandler
 getRoomByObjectId ($objectId)
 
 exitIfNoRoomExists ($room)
 Checks if a ilChatroom exists. More...
 
 exitIfNoRoomPermission ($room, $subRoom, $chat_user)
 Check if user can moderate a chatroom. More...
 
 canModerate ($room, $subRoom, $user_id)
 Checks if the user has permission to moderate a ilChatroom. More...
 
 isMainRoom ($subRoomId)
 
- Protected Attributes inherited from ilChatroomGUIHandler
 $gui
 
 $ilUser
 
 $ilCtrl
 
 $ilLng
 
 $webDirectory
 
 $upload
 

Detailed Description

Class ilChatroomPostMessageGUI.

Author
Jan Posselt jposs.nosp@m.elt@.nosp@m.datab.nosp@m.ay.d.nosp@m.e
Version
$Id$

DELETE THIS

Definition at line 11 of file class.ilChatroomPostMessageGUI.php.

Member Function Documentation

◆ buildMessage()

ilChatroomPostMessageGUI::buildMessage (   $messageString,
  $params,
ilChatroomUser  $chat_user 
)
private

Instantiates stdClass, sets $data->user, $data->message, $data->public and $data->recipients using given $chat_user, $messageString and $params and returns $data.

Parameters
string$messageString
array$params
ilChatroomUser$chat_user
Returns
stdClass

Definition at line 96 of file class.ilChatroomPostMessageGUI.php.

References $data, $params, and time.

Referenced by executeDefault().

97  {
98  $data = new stdClass();
99 
100  $data->user = $this->gui->object->getPersonalInformation($chat_user);
101  $data->message = $messageString;
102  $data->timestamp = time() * 1000;//date( 'c' );
103  $data->type = 'message';
104  isset($params['sub']) ? ($data->sub = $params['sub']) : false;
105  $data->public = (int) $params['public'];
106  $data->recipients = $params['recipients']; // ? explode(",", $params['recipients']) : array();
107  $data->recipient_names = $params['recipient_names'];
108 
109  return $data;
110  }
$params
Definition: disable.php:11
Add data(end) time
Method that wraps PHPs time in order to allow simulations with the workflow.
+ Here is the caller graph for this function:

◆ executeDefault()

ilChatroomPostMessageGUI::executeDefault (   $method)

Prepares and posts message fetched from $_REQUEST['message'] to recipients fetched from $_REQUEST['recipient'] and adds an entry to history if successful.

ilObjUser $ilUser

Parameters
string$method

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

References ilChatroomGUIHandler\$ilCtrl, ilChatroomGUIHandler\$ilUser, $message, $params, $query, $response, array, buildMessage(), ilChatroom\byObjectId(), exit, ilChatroomGUIHandler\redirectIfNoPermission(), and ilUtil\stripSlashes().

21  {
22  throw new Exception('METHOD_NOT_IN_USE', 1456435027);
23  global $ilUser, $ilCtrl;
24 
25  require_once 'Modules/Chatroom/classes/class.ilChatroom.php';
26  require_once 'Modules/Chatroom/classes/class.ilChatroomUser.php';
27 
28  $this->redirectIfNoPermission('read');
29 
30  $room = ilChatroom::byObjectId($this->gui->object->getId());
31 
32  $chat_user = new ilChatroomUser($ilUser, $room);
33  $user_id = $chat_user->getUserId();
34 
35  if (!$room) {
36  throw new Exception('unkown room');
37  } elseif (!$room->isSubscribed($chat_user->getUserId())) {
38  throw new Exception('not subscribed');
39  } elseif (isset($_REQUEST['sub']) && !$room->userIsInPrivateRoom($_REQUEST['sub'], $chat_user->getUserId())) {
40  $response = json_encode(array(
41  'success' => false,
42  'reason' => 'not subscribed to private room'
43  ));
44  echo json_encode($response);
45  exit;
46  }
47 
48  $scope = $room->getRoomId();
49  $params = array();
50 
51  if (($recipient = $_REQUEST['recipient'])) {
52  $params['recipients'] = join(',', array_unique(array($user_id, $recipient)));
53  $params['recipient_names'] = implode(',', array($chat_user->getUsername(), $_REQUEST['recipient_name']));
54  $params['public'] = isset($_REQUEST['public']) ? (int) $_REQUEST['public'] : 0;
55  } else {
56  $params['public'] = 1;
57  }
58 
59  if ($_REQUEST['sub']) {
60  $params['sub'] = (int) $_REQUEST['sub'];
61  }
62 
63  $messageObject = $this->buildMessage(
64  ilUtil::stripSlashes($_REQUEST['message']),
65  $params,
66  $chat_user
67  );
68 
69  $message = json_encode($messageObject);
70 
71  $params = array_merge($params, array('message' => $message));
72  //print_r($params);exit;
73  $query = http_build_query($params);
74  $connector = $this->gui->getConnector();
75  $response = $connector->post($scope, $query);
76 
77  $responseObject = json_decode($response);
78 
79  if ($responseObject->success == true /*&& $room->getSetting( 'enable_history' )*/) {
80  $room->addHistoryEntry($messageObject, $recipient, $publicMessage);
81  }
82 
83  echo $response;
84  exit;
85  }
$params
Definition: disable.php:11
redirectIfNoPermission($permission)
Checks for requested permissions and redirects if the permission check failed.
catch(Exception $e) $message
buildMessage($messageString, $params, ilChatroomUser $chat_user)
Instantiates stdClass, sets $data->user, $data->message, $data->public and $data->recipients using gi...
$query
static stripSlashes($a_str, $a_strip_html=true, $a_allow="")
strip slashes if magic qoutes is enabled
Create styles array
The data for the language used.
Class ilChatroomUser.
static byObjectId($object_id)
Returns ilChatroom object by given $object_id.
$response
+ Here is the call graph for this function:

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