aboutsummaryrefslogtreecommitdiff
path: root/engine/lib/users.php
diff options
context:
space:
mode:
authormarcus <marcus@36083f99-b078-4883-b0ff-0f9b5a30f544>2009-03-31 12:18:16 +0000
committermarcus <marcus@36083f99-b078-4883-b0ff-0f9b5a30f544>2009-03-31 12:18:16 +0000
commita0a6ed1d1bcececefbff00158f9fa6ad0790ed16 (patch)
tree733bcafc1020348e0143bf766d757f2203d05e12 /engine/lib/users.php
parente484463d7c1ab37fd024c7ae8ce5ecf3c47041d7 (diff)
downloadelgg-a0a6ed1d1bcececefbff00158f9fa6ad0790ed16.tar.gz
elgg-a0a6ed1d1bcececefbff00158f9fa6ad0790ed16.tar.bz2
Closes #896: Error thrown if user not validate. Metadata physically removed rather than simply blanked when validation is requested.
Note: update_metadata no longer seems to support anonymous metadata which is likely to have knock on issues elsewhere... git-svn-id: https://code.elgg.org/elgg/trunk@3184 36083f99-b078-4883-b0ff-0f9b5a30f544
Diffstat (limited to 'engine/lib/users.php')
-rw-r--r--engine/lib/users.php27
1 files changed, 23 insertions, 4 deletions
diff --git a/engine/lib/users.php b/engine/lib/users.php
index fd8c00073..e45223e54 100644
--- a/engine/lib/users.php
+++ b/engine/lib/users.php
@@ -1003,11 +1003,30 @@
function set_user_validation_status($user_guid, $status, $method = '')
{
if (!$status) $method = '';
-
- create_metadata($user_guid, 'validated', $status,'', 0, ACCESS_PUBLIC);
- create_metadata($user_guid, 'validated_method', $method,'', 0, ACCESS_PUBLIC);
+
+ if ($status)
+ {
+ if (
+ (create_metadata($user_guid, 'validated', $status,'', 0, ACCESS_PUBLIC)) &&
+ (create_metadata($user_guid, 'validated_method', $method,'', 0, ACCESS_PUBLIC))
+ )
+ return true;
+ }
+ else
+ {
+ $validated = get_metadata_byname($user_guid, 'validated');
+ $validated_method = get_metadata_byname($user_guid, 'validated_method');
+
+ if (
+ ($validated) &&
+ ($validated_method) &&
+ (delete_metadata($validated->id)) &&
+ (delete_metadata($validated_method->id))
+ )
+ return true;
+ }
- return true;
+ return false;
}
/**