From 9e89a46853f175da17ebd0ad0e914b5a6d5c16ba Mon Sep 17 00:00:00 2001 From: Ingo Schommer Date: Sat, 15 Sep 2007 00:23:44 +0000 Subject: [PATCH] mlanthaler: Member class is now completely documented, although the documentation of Member::map() and Member::mapInGroups() should be improved (marked with an @todo tag). (merged from branches/gsoc) git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@41836 467b73ca-7a2a-4603-9d3b-597d59a354a9 --- security/Member.php | 37 ++++++++++++++++++++++++++++--------- 1 file changed, 28 insertions(+), 9 deletions(-) diff --git a/security/Member.php b/security/Member.php index 85c18279d..e53cf8d9c 100644 --- a/security/Member.php +++ b/security/Member.php @@ -107,7 +107,7 @@ class Member extends DataObject { /** * Generate an auto login hash * - * @todo This is relative insecure, check if we should fix it + * @todo This is relative insecure, check if we should fix it (Markus) */ function generateAutologinHash() { $linkHash = sprintf('%10d', time() ); @@ -231,8 +231,6 @@ class Member extends DataObject { * * @param bool $val Set to TRUE if the address should be added to the * blacklist, otherwise to FALSE. - * @return - * @todo Check for what the parameter $val is needed! (Markus) */ function setBlacklistedEmail($val) { if($val && $this->Email) { @@ -406,7 +404,6 @@ class Member extends DataObject { * * @return string Returns the first- and surname of the member. If the ID * of the member is equal 0, only the surname is returned. - * @todo Check for what this method is used! (Markus) */ public function getTitle() { if($this->getField('ID') === 0) @@ -454,7 +451,11 @@ class Member extends DataObject { /** - * @todo Figure out what this function does and document it! (Markus) + * Get a "many-to-many" map that holds for all members their group + * memberships + * + * @return Member_GroupSet Returns a map holding for all members their + * group memberships. */ public function Groups() { $groups = $this->getManyManyComponents("Groups"); @@ -469,7 +470,8 @@ class Member extends DataObject { $groupIDs = $groups->column(); $collatedGroups = array(); foreach($groups as $group) { - $collatedGroups = array_merge((array)$collatedGroups, $group->collateAncestorIDs()); + $collatedGroups = array_merge((array)$collatedGroups, + $group->collateAncestorIDs()); } $table = "Group_Members"; @@ -482,14 +484,22 @@ class Member extends DataObject { $result = new Member_GroupSet(); } - $result->setComponentInfo("many-to-many", $this, "Member", $table, "Group"); + $result->setComponentInfo("many-to-many", $this, "Member", $table, + "Group"); return $result; } /** - * @todo Figure out what this function does and document it! (Markus) + * Get member SQLMap + * + * @param string $filter Filter for the SQL statement (WHERE clause) + * @param string $sort Sorting function (ORDER clause) + * @param string $blank Shift a blank member in the items + * @return SQLMap Returns an SQLMap that returns all Member data. + * + * @todo Improve documentation of this function! (Markus) */ public function map($filter = "", $sort = "", $blank="") { $ret = new SQLMap(singleton('Member')->extendedSQL($filter, $sort)); @@ -500,12 +510,21 @@ class Member extends DataObject { $ret->getItems()->shift($blankMember); } + return $ret; } /** - * @todo Figure out what this function does and document it! (Markus) + * Get a member SQLMap of members in specific groups + * + * @param mixed $groups Optional groups to include in the map. If NULL is + * passed, all groups are returned, i.e. + * {@link map()} will be called. + * @return SQLMap Returns an SQLMap that returns all Member data. + * @see map() + * + * @todo Improve documentation of this function! (Markus) */ public static function mapInGroups($groups = null) { if(!$groups)