From 1ae7eab4711353b2144d0da40ac33270bc79a081 Mon Sep 17 00:00:00 2001 From: Malf Furious Date: Sun, 26 Mar 2017 22:52:30 -0400 Subject: Add function user::getGroups_ordByOwnByName() Lookup all groups a user owns or is a member of. --- app/class/user.class.php | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) (limited to 'app') diff --git a/app/class/user.class.php b/app/class/user.class.php index 9892277..97309f8 100644 --- a/app/class/user.class.php +++ b/app/class/user.class.php @@ -250,6 +250,34 @@ class user extends agent $this->emailVer = substr(self::getBlob(), 0, 8); $this->emailConf = 0; } + + /* + * Get all groups this user owns or is a member of. This isn't necessarily + * all groups this user cas access permissions for. Results are sorted by + * ownership, then by name. + */ + public function getGroups_ordByOwnByName() : array + { + $groups = array(); + + /* owner */ + $query = "SELECT guid FROM objects WHERE objtype = 'group' AND owner = '" . database::esc($this->guid) . "' " . + "ORDER BY name"; + $res = database::query($query); + + foreach ($res as $g) + $groups[] = new group($g['guid']); + + /* member */ + $query = "SELECT o.guid FROM objects o JOIN members m ON o.guid = m.guid WHERE o.objtype = 'group' AND " . + "m.member = '" . database::esc($this->guid) . "' ORDER BY o.name"; + $res = database::query($query); + + foreach ($res as $g) + $groups[] = new group($g['guid']); + + return $groups; + } } ?> -- cgit v1.2.3