");
}
+
}
function setFromRoo($ar, $roo)
function beforeDelete($dependants_array, $roo)
{
-
//delete group membership except for admin group..
// if they are a member of admin group do not delete anything.
$default_admin = false;
$e = DB_DataObject::Factory('Events');
$e->whereAdd('person_id = ' . $this->id);
- $g = DB_DataObject::Factory('core_group_member');
- $g->whereAdd('group_id is NOT NULL AND user_id IS NOT NULL');
-
- if ($g->count()) {
- // add the current user to the admin group..
- $g = DB_DataObject::Factory('core_group');
- if ($g->get('name', 'Administrators')) {
- $roo->jerr("can not delete admin user");
- }
- else{
- $e->delete(true);
- }
-
+ $g = DB_DataObject::Factory('core_group');
+ $g->get('name', 'Administrators'); // select * from core_group where name = 'Administrators'
+
+ $p = DB_DataObject::Factory('core_group_member');
+ $p->setFrom(array(
+ 'user_id' => $this->id,
+ 'group_id' => $g->id
+ ));
+
+ if ($p->count()) {
+ $roo->jerr();
}
+
+
+ $p = DB_DataObject::Factory('core_group_member');
+ $p->user_id = $this->id;
+ $mem = $p->fetchAll(); // fetch all the rows and set the $mem variable to the rows data, just like mysqli_fetch_assoc
+
+ $e->logDeletedRecord($p);
+
+ foreach($mem as $p) {
+ $p->delete();
+ }
$roo->jok($qrcode);
}
+ // handle group_id here..
+ if(!empty($q['group_id'])){
+
+ // insert data into core_person_member...
+
+
+ }
}
function generateOathKey()