From 3361c73a30ff20eae69a736dab0f9bc573cb540a Mon Sep 17 00:00:00 2001 From: marcus Date: Sat, 7 Mar 2009 12:02:48 +0000 Subject: Closes #843: Introducing intermediary invite action to establish invite relationship but ask a user to join git-svn-id: https://code.elgg.org/elgg/trunk@3124 36083f99-b078-4883-b0ff-0f9b5a30f544 --- mod/groups/actions/invite.php | 66 ++++++++++++++++++++++++ mod/groups/languages/en.php | 3 +- mod/groups/start.php | 3 +- mod/groups/views/default/forms/groups/invite.php | 2 +- 4 files changed, 71 insertions(+), 3 deletions(-) create mode 100644 mod/groups/actions/invite.php (limited to 'mod') diff --git a/mod/groups/actions/invite.php b/mod/groups/actions/invite.php new file mode 100644 index 000000000..3820ffb15 --- /dev/null +++ b/mod/groups/actions/invite.php @@ -0,0 +1,66 @@ +owner_guid) + { + if (!check_entity_relationship($group->guid, 'invited', $user->guid)) + { + if ($user->isFriend()) + { + + // Create relationship + add_entity_relationship($group->guid, 'invited', $user->guid); + + // Send email + if (notify_user($user->getGUID(), $group->owner_guid, + sprintf(elgg_echo('groups:invite:subject'), $user->name, $group->name), + sprintf(elgg_echo('groups:invite:body'), $user->name, $group->name, "{$CONFIG->url}action/groups/join?user_guid={$user->guid}&group_guid={$group->guid}"), + NULL)) + system_message(elgg_echo("groups:userinvited")); + else + register_error(elgg_echo("groups:usernotinvited")); + + } + else + register_error(elgg_echo("groups:usernotinvited")); + } + else + register_error(elgg_echo("groups:useralreadyinvited")); + } + else + register_error(elgg_echo("groups:notowner")); + } + } + } + + forward($_SERVER['HTTP_REFERER']); + +?> \ No newline at end of file diff --git a/mod/groups/languages/en.php b/mod/groups/languages/en.php index 95cad18ed..0a8367b90 100644 --- a/mod/groups/languages/en.php +++ b/mod/groups/languages/en.php @@ -134,7 +134,8 @@ 'groups:notowner' => 'Sorry, you are not the owner of this group.', 'groups:alreadymember' => 'You are already a member of this group!', 'groups:userinvited' => 'User has been invited.', - 'groups:usernotinvited' => 'User could not be invited.', + 'groups:usernotinvited' => 'User could not be invited.', + 'groups:useralreadyinvited' => 'User has already been invited', 'groups:updated' => "Last comment", 'groups:invite:subject' => "%s you have been invited to join %s!", 'groups:started' => "Started by", diff --git a/mod/groups/start.php b/mod/groups/start.php index e8ef1af11..29f96785d 100644 --- a/mod/groups/start.php +++ b/mod/groups/start.php @@ -46,7 +46,8 @@ register_action("groups/leave",false, $CONFIG->pluginspath . "groups/actions/leave.php"); register_action("groups/joinrequest",false, $CONFIG->pluginspath . "groups/actions/joinrequest.php"); register_action("groups/killrequest",false,$CONFIG->pluginspath . "groups/actions/groupskillrequest.php"); - register_action("groups/addtogroup",false, $CONFIG->pluginspath . "groups/actions/addtogroup.php"); + register_action("groups/addtogroup",false, $CONFIG->pluginspath . "groups/actions/addtogroup.php"); + register_action("groups/invite",false, $CONFIG->pluginspath . "groups/actions/invite.php"); // Use group widgets use_widgets('groups'); diff --git a/mod/groups/views/default/forms/groups/invite.php b/mod/groups/views/default/forms/groups/invite.php index ac75e6a49..b92ffc208 100644 --- a/mod/groups/views/default/forms/groups/invite.php +++ b/mod/groups/views/default/forms/groups/invite.php @@ -16,7 +16,7 @@ ?>
-
+