flm01/web/drupal/modules/logger/patches/invite.escalation.to.target.role.patch
2009-09-16 22:39:58 +00:00

64 lines
2.6 KiB
Diff

Index: invite.module
===================================================================
RCS file: /cvs/drupal-contrib/contributions/modules/invite/invite.module,v
retrieving revision 1.25.2.6
diff -u -p -r1.25.2.6 invite.module
--- invite.module 27 Apr 2009 17:24:44 -0000 1.25.2.6
+++ invite.module 15 Jun 2009 12:30:45 -0000
@@ -423,7 +423,7 @@ function invite_user($op, &$edit, &$acco
}
}
if ($invite) {
- _invite_accept($invite, $account);
+ _invite_accept($invite, $account, $edit);
// Flag the inviting user, this triggers status notifications and
// saves us some queries otherwise.
@@ -449,7 +449,7 @@ function invite_user($op, &$edit, &$acco
* @param $account
* The user object of the invitee.
*/
-function _invite_accept($invite, $account) {
+function _invite_accept($invite, $account, &$edit) {
// Update the invitation record.
db_query("UPDATE {invite} SET email = '%s', invitee = %d, joined = %d WHERE reg_code = '%s'", $account->mail, $account->uid, time(), $invite->reg_code);
// Delete all invites to these e-mail addresses, except this one.
@@ -458,7 +458,7 @@ function _invite_accept($invite, $accoun
// notification queue.
db_query("INSERT INTO {invite_notifications} (uid, invitee) SELECT uid, %d from {invite} WHERE (email = '%s' OR email = '%s') AND canceled = 0", $account->uid, $invite->email, $account->mail);
// Escalate the invitee's role.
- _invite_escalate_role($account);
+ _invite_escalate_role($account, $edit);
// Unblock user account.
db_query("UPDATE {users} SET status = 1 WHERE uid = %d", $account->uid);
}
@@ -469,7 +469,7 @@ function _invite_accept($invite, $accoun
* @param $account
* The user object of the invitee.
*/
-function _invite_escalate_role($account) {
+function _invite_escalate_role($account, &$edit) {
// Default target role.
$roles = array('default');
@@ -489,15 +489,12 @@ function _invite_escalate_role($account)
}
}
- // Notify other modules of changed user.
- $edit = array('roles' => $targets);
- user_module_invoke('update', $edit, $account);
-
- // Save new user role(s).
- foreach ($targets as $target) {
- db_query("DELETE FROM {users_roles} WHERE uid = %d AND rid = %d", $account->uid, $target);
- db_query("INSERT INTO {users_roles} (uid, rid) VALUES (%d, %d)", $account->uid, $target);
+ // Let user_save() save the new user role(s).
+ if (!is_array($edit['roles'])) {
+ $edit['roles'] = array();
}
+ $edit['roles'] += $targets;
+ $account->roles += $targets;
// Notify other modules of role escalation.
$args = array('invitee' => $account, 'inviter' => $inviter, 'roles' => $targets);