X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=classes%2FGroup_member.php;h=7b1760f767e489ee068f70e8ce9c3ffee310a424;hb=419c38cc0bf3f2649be9ad18e983b9f0ac8dfec0;hp=32243fe4580c1f42684d499833503313bd2d7ecf;hpb=0824bb2e1df68fd6634ca915e4c87664ee2ef872;p=quix0rs-gnu-social.git diff --git a/classes/Group_member.php b/classes/Group_member.php old mode 100755 new mode 100644 index 32243fe458..7b1760f767 --- a/classes/Group_member.php +++ b/classes/Group_member.php @@ -2,7 +2,6 @@ /** * Table Definition for group_member */ -require_once 'classes/Memcached_DataObject.php'; class Group_member extends Memcached_DataObject { @@ -21,4 +20,46 @@ class Group_member extends Memcached_DataObject /* the code above is auto generated do not remove the tag below */ ###END_AUTOCODE + + function pkeyGet($kv) + { + return Memcached_DataObject::pkeyGet('Group_member', $kv); + } + + static function join($group_id, $profile_id) + { + $member = new Group_member(); + + $member->group_id = $group_id; + $member->profile_id = $profile_id; + $member->created = common_sql_now(); + + $result = $member->insert(); + + if (!$result) { + common_log_db_error($member, 'INSERT', __FILE__); + throw new Exception(_("Group join failed.")); + } + + return true; + } + + static function leave($group_id, $profile_id) + { + $member = Group_member::pkeyGet(array('group_id' => $group_id, + 'profile_id' => $profile_id)); + + if (empty($member)) { + throw new Exception(_("Not part of group.")); + } + + $result = $member->delete(); + + if (!$result) { + common_log_db_error($member, 'INSERT', __FILE__); + throw new Exception(_("Group leave failed.")); + } + + return true; + } }