"Person" : [ "ADEPS", "S" , "Contacts"] ,
"Offices" : [ "ADEPS", "S" , "Contact Offices"] ,
- "Companies" : [ "ADEPS", "S" , "Contact Companies"] ,
+ "Companies" : [ "ADEPS", "S" , "Company Management"] ,
"Staff" : [ "ADEPS", "S" , "Staff"] ,
"Groups" : [ "ADEPS", "" , "Group Management"] ,
"Events" : [ "PS", "", "Event Log"] ,
- "ChangePassword" : [ "S", "S", "User Can Change Password"]
+ "ChangePassword" : [ "S", "S", "User Can Change Password"]
}
}
}
- 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);
");
}
- $cgm = DB_DataObject::Factory('core_group_member')->tableName();
-
- $this->selectAdd("
- (
- SELECT GROUP_CONCAT({$cgm}.group_id)
- FROM
- {$cgm}
- WHERE
- {$cgm}.user_id = {$this->tableName()}.id
- ) AS membership_list
-
- ");
-
}
function beforeUpdate($old, $q, $roo)
{
-
-
if(!empty($q['_generate_oath_key'])){
$o = clone($this);
$this->generateOathKey();
$roo->jok($qrcode);
}
- if(!empty($q['membership_list'])){
-
-
- if ($roo->authUser->id == $old->id) {
- // you are editing yourself...
-
- // if was admin before....
- // -if new membership does not icnlude admin id
- // -- then show error
-
-
- }
-
-
-
-
-
- $x = PDO_DataObject::factory('core_group_member');
- $x->select('group_id');
- $x->user_id = $q['id'];
-
- $ar = $x->fetchAll('group_id');
-
- $group_id_arr = explode(",", $q['membership_list']);
-
- $result_del = array_diff($ar, $group_id_arr);
-
- // check if id needs to be deleted
- if(!empty($result_del)){
- /*
- $x = PDO_DataObject::factory('core_group_member');
- $x->user_id = $q['id'];
- $x->whereAddIn('group_id', $result_del, 'int');
- foreach($x->fetchAll() as $cgm) {
- $cgm->delete();
- }
-
-
- */
- foreach($result_del as $group_id){
- $x = PDO_DataObject::factory('core_group_member');
- $x->user_id = $q['id'];
- $x->group_id = $group_id;
- $x->find(true);
- $x->delete();
- }
- }
-
- $result_add = array_diff($group_id_arr, $ar);
-
-
- // insert data into core_person_member...
- //PDO_DataObject::Factory('coremytable_group_member')->set([ 'group_id' => 'test', 'user_id' => "{$this->tableName()}.id"])->insert();
- if(!empty($result_add)){
- foreach($result_add as $gid){
- PDO_DataObject::Factory('core_group_member')->set(array(
- 'group_id'=> $gid,
- 'user_id' => $q['id']
- ))->insert();
- }
- }
- }
$this->email = trim($this->email);
}