diff options
author | Sem <sembrestels@riseup.net> | 2013-08-23 04:57:17 +0200 |
---|---|---|
committer | Sem <sembrestels@riseup.net> | 2013-08-23 04:57:17 +0200 |
commit | e90c8fef1af6a1ce1e5480067955ca29caba3b83 (patch) | |
tree | 3791b151f7d3e6c526f39e1357fc425e4cc2b02d /actions/friends/remove.php | |
parent | bc99d5609275d0949cb1c4830cf6e7c1c5a5d758 (diff) | |
download | elgg-e90c8fef1af6a1ce1e5480067955ca29caba3b83.tar.gz elgg-e90c8fef1af6a1ce1e5480067955ca29caba3b83.tar.bz2 |
Updated to Elgg 1.8.16.
Diffstat (limited to 'actions/friends/remove.php')
-rw-r--r-- | actions/friends/remove.php | 43 |
1 files changed, 27 insertions, 16 deletions
diff --git a/actions/friends/remove.php b/actions/friends/remove.php index 1ad9471b3..786f08352 100644 --- a/actions/friends/remove.php +++ b/actions/friends/remove.php @@ -1,24 +1,35 @@ <?php +/** + * Elgg remove friend action + * + * @package Elgg.Core + * @subpackage Friends.Management + */ -$friend = get_entity(sanitize_int(get_input('friend'))); -$user = elgg_get_logged_in_user_entity(); +// Get the GUID of the user to friend +$friend_guid = get_input('friend'); +$friend = get_entity($friend_guid); +$errors = false; -if(!elgg_instanceof($friend, 'user')){ - register_error(elgg_echo('friends:remove:failure', array($friend->name))); - forward(REFERER); +// Get the user +try{ + if ($friend instanceof ElggUser) { + elgg_get_logged_in_user_entity()->removeFriend($friend_guid); + $ia = elgg_set_ignore_access(true); + $friend->removeFriend($elgg_get_logged_in_user_guid()); + elgg_set_ignore_access($ia); + } else { + register_error(elgg_echo("friends:remove:failure", array($friend->name))); + $errors = true; + } +} catch (Exception $e) { + register_error(elgg_echo("friends:remove:failure", array($friend->name))); + $errors = true; } -if(check_entity_relationship($user->guid, "friend", $friend->guid)) { - try { - $user->removeFriend($friend->guid); - if(check_entity_relationship($friend->guid, "friend", $user->guid)){ - $friend->removeFriend($user->guid); - } - } catch (Exception $e) { - register_error(elgg_echo('friends:remove:failure', array($friend->name))); - forward(REFERER); - } +if (!$errors) { + system_message(elgg_echo("friends:remove:successful", array($friend->name))); } -system_message(elgg_echo('friends:remove:successful', array($friend->name))); +// Forward back to the page you made the friend on forward(REFERER); |