$v = $this->escape($q['query']['name_starts']);
$this->whereAdd("{$this->tableName()}.name like '{$v}%'");
}
+ if (!empty($q['query']['name_contains'])) {
+ $v = $this->escape($q['query']['name_contains']);
+ $this->whereAdd("{$this->tableName()}.name like '%{$v}%'");
+ }
if(!empty($q['_count_member_by_name'])){
}
}
- if(!empty($q['_with_membership_user'])){
- $q['_with_membership_user'] = 1*$q['_with_membership_user'];
+ if(!empty($q['_is_in_group'])){
$this->selectAdd("
- COALESCE(
- (SELECT id from core_group_member
+ COALESCE((
+ SELECT
+ COUNT(id)
+ FROM
+ core_group_member
WHERE
- user_id = {$q['_with_membership_user']}
+ user_id = {$q['_is_in_group']}
AND
group_id = {$this->tableName()}.id
- LIMIT 1
- ),0) as group_membership_user_id
- ");
+ ), 0) AS is_in_group
+ ");
}
) AS group_member_count
");
- /*WHERE
- {$this->tableName()}.id = core_group_member.group_id
- AND
- core_group_member.user_id = core_person.id
- AND
- core_person.active = 1
- )*/
-
-// $this->whereAdd("{$this->tableName()}.id = core_group_member.group_id");
-// $this->whereAdd("core_group_member.user_id = core_person.id");
-// $this->whereAdd("core_person.active = 1");
-
-
- /*$cgmDBObj->joinAdd($cpObj);
- $this->joinAdd($cgmDBObj);
- DB_DataObject::debugLevel();*/
}
function toEventString() {
$roo->jerr("missing group id");
}
- foreach(explode(',', $q['user_ids']) as $uid) {
+
+ $user_ids = explode(',', $q['user_ids']);
+
+ foreach($user_ids as $uid) {
+
switch($q['_action']) {
case 'add':
$g->addMember($uid,$roo);
break;
case 'sub':
- $g->removeMember($uid);
+
+ $g->removeMember($uid, $roo);
break;
default:
$roo->jerr('invalid action');
$roo->jok('updated');
}
+ if (isset($q['display_name']) && !isset($q['name']) && !$this->is_system) {
+ $this->name = $q['display_name'];
+ }
}
+
+ function beforeUpdate($old, $q,$roo)
+ {
+ if (isset($q['display_name']) && empty($q['name']) && !$this->is_system) {
+ $this->name = $q['display_name'];
+ }
+ }
function beforeDelete()
$gm = DB_Dataobject::factory('core_group_member');
$gm->group_id = $this->id;
$gm->user_id = is_object($person) ? $person->id : $person;
+
if (!$gm->count()) {
$gm->insert();
}
}
- function removeMember($person)
+ function removeMember($person, $roo)
{
$gm = DB_Dataobject::factory('core_group_member');
$gm->group_id = $this->id;
$gm->user_id = is_object($person) ? $person->id : $person;
-
+ $au = $roo->getAuthUser();
+ if ($gm->group()->name == 'Administrators' && $gm->user_id = $au->id) {
+ $roo->jerr("You can not remove yourself from the admin group");
+ }
+
if ($gm->find(true)) {
$gm->delete();
}
$o = clone($g);
}
+ $display_name = (isset($gi['display_name'])) ? $gi['display_name'] : '';
+
+ unset($gi['display_name']);
+
$g->setFrom($gi);
-
- if(!$g->find(true)){
- $g->insert();
+
+ if(empty($o) || empty($o->display_name)){
+ $g->display_name = $display_name;
}
+
+ (empty($o)) ? $g->insert() : $g->update($o);
if(count($g->members()) || empty($gi['members'])){
continue;