diff options
| author | Steve Clay <steve@mrclay.org> | 2012-11-14 11:29:29 -0500 | 
|---|---|---|
| committer | Steve Clay <steve@mrclay.org> | 2012-11-14 11:29:29 -0500 | 
| commit | 44bd1cd943b261a9b048f1b2d89629698e07adf5 (patch) | |
| tree | 3ece1ba68a648dbc66feb846a9a3cc61e9d2b13b | |
| parent | ba045f003a8c50aaa42b139b0ed694e230348486 (diff) | |
| download | elgg-44bd1cd943b261a9b048f1b2d89629698e07adf5.tar.gz elgg-44bd1cd943b261a9b048f1b2d89629698e07adf5.tar.bz2  | |
messages_send() better var names and fixed notification if sender not current user
| -rw-r--r-- | mod/messages/start.php | 65 | 
1 files changed, 37 insertions, 28 deletions
diff --git a/mod/messages/start.php b/mod/messages/start.php index 324abd59b..e17640098 100644 --- a/mod/messages/start.php +++ b/mod/messages/start.php @@ -212,18 +212,20 @@ function messages_can_edit_container($hook_name, $entity_type, $return_value, $p   *   * @param string $subject The subject line of the message   * @param string $body The body of the mesage - * @param int $send_to The GUID of the user to send to - * @param int $from Optionally, the GUID of the user to send from - * @param int $reply The GUID of the message to reply from (default: none) - * @param true|false $notify Send a notification (default: true) - * @param true|false $add_to_sent If true (default), will add a message to the sender's 'sent' tray + * @param int $recipient_guid The GUID of the user to send to + * @param int $sender_guid Optionally, the GUID of the user to send from + * @param int $original_msg_guid The GUID of the message to reply from (default: none) + * @param bool $notify Send a notification (default: true) + * @param bool $add_to_sent If true (default), will add a message to the sender's 'sent' tray   * @return bool   */ -function messages_send($subject, $body, $send_to, $from = 0, $reply = 0, $notify = true, $add_to_sent = true) { +function messages_send($subject, $body, $recipient_guid, $sender_guid = 0, $original_msg_guid = 0, $notify = true, $add_to_sent = true) { +	// @todo remove globals  	global $messagesendflag;  	$messagesendflag = 1; +	// @todo remove globals  	global $messages_pm;  	if ($notify) {  		$messages_pm = 1; @@ -231,33 +233,40 @@ function messages_send($subject, $body, $send_to, $from = 0, $reply = 0, $notify  		$messages_pm = 0;  	} -	// If $from == 0, set to current user -	if ($from == 0) { -		$from = (int) elgg_get_logged_in_user_guid(); +	// If $sender_guid == 0, set to current user +	if ($sender_guid == 0) { +		$sender_guid = (int) elgg_get_logged_in_user_guid();  	}  	// Initialise 2 new ElggObject  	$message_to = new ElggObject();  	$message_sent = new ElggObject(); +  	$message_to->subtype = "messages";  	$message_sent->subtype = "messages"; -	$message_to->owner_guid = $send_to; -	$message_to->container_guid = $send_to; -	$message_sent->owner_guid = $from; -	$message_sent->container_guid = $from; + +	$message_to->owner_guid = $recipient_guid; +	$message_to->container_guid = $recipient_guid; +	$message_sent->owner_guid = $sender_guid; +	$message_sent->container_guid = $sender_guid; +  	$message_to->access_id = ACCESS_PUBLIC;  	$message_sent->access_id = ACCESS_PUBLIC; +  	$message_to->title = $subject;  	$message_to->description = $body; +  	$message_sent->title = $subject;  	$message_sent->description = $body; -	$message_to->toId = $send_to; // the user receiving the message -	$message_to->fromId = $from; // the user receiving the message + +	$message_to->toId = $recipient_guid; // the user receiving the message +	$message_to->fromId = $sender_guid; // the user receiving the message  	$message_to->readYet = 0; // this is a toggle between 0 / 1 (1 = read)  	$message_to->hiddenFrom = 0; // this is used when a user deletes a message in their sentbox, it is a flag  	$message_to->hiddenTo = 0; // this is used when a user deletes a message in their inbox -	$message_sent->toId = $send_to; // the user receiving the message -	$message_sent->fromId = $from; // the user receiving the message + +	$message_sent->toId = $recipient_guid; // the user receiving the message +	$message_sent->fromId = $sender_guid; // the user receiving the message  	$message_sent->readYet = 0; // this is a toggle between 0 / 1 (1 = read)  	$message_sent->hiddenFrom = 0; // this is used when a user deletes a message in their sentbox, it is a flag  	$message_sent->hiddenTo = 0; // this is used when a user deletes a message in their inbox @@ -270,7 +279,7 @@ function messages_send($subject, $body, $send_to, $from = 0, $reply = 0, $notify  	// Save the copy of the message that goes to the sender  	if ($add_to_sent) { -		$success2 = $message_sent->save(); +		$message_sent->save();  	}  	$message_to->access_id = ACCESS_PRIVATE; @@ -283,25 +292,25 @@ function messages_send($subject, $body, $send_to, $from = 0, $reply = 0, $notify  	// if the new message is a reply then create a relationship link between the new message  	// and the message it is in reply to -	if ($reply && $success){ -		$create_relationship = add_entity_relationship($message_sent->guid, "reply", $reply); +	if ($original_msg_guid && $success) { +		add_entity_relationship($message_sent->guid, "reply", $original_msg_guid);  	}  	$message_contents = strip_tags($body); -	if (($send_to != elgg_get_logged_in_user_guid()) && $notify) { -		$to_user = get_user($send_to); -		$from_user = elgg_get_logged_in_user_entity(); +	if (($recipient_guid != elgg_get_logged_in_user_guid()) && $notify) { +		$recipient = get_user($recipient_guid); +		$sender = get_user($sender_guid);  		$subject = elgg_echo('messages:email:subject');  		$body = elgg_echo('messages:email:body', array( -			$from_user->name, +			$sender->name,  			$message_contents, -			elgg_get_site_url() . "messages/inbox/" . $to_user->username, -			$from_user->name, -			elgg_get_site_url() . "messages/compose?send_to=" . $from_user->getGUID() +			elgg_get_site_url() . "messages/inbox/" . $recipient->username, +			$sender->name, +			elgg_get_site_url() . "messages/compose?send_to=" . $sender_guid  		)); -		notify_user($to_user->getGUID(), $from_user->getGUID(), $subject, $body); +		notify_user($recipient_guid, $sender_guid, $subject, $body);  	}  	$messagesendflag = 0;  | 
