function postInstall() { global $cache; Debug::text('postInstall: ' . $this->getVersion(), __FILE__, __LINE__, __METHOD__, 9); Debug::text('l: ' . $this->getVersion(), __FILE__, __LINE__, __METHOD__, 9); /* Take permission groups we put into memory from preInstall and create them now, after schema has been updated. */ if (isset($this->permission_groups) and is_array($this->permission_groups)) { //Create permission groups and assign proper employees to each. //Debug::Arr($this->permission_groups, 'All Permission Groups: ', __FILE__, __LINE__, __METHOD__,9); foreach ($this->permission_groups as $company_id => $permission_group_data) { //Get all active users for this company, so we can assign them //to the default permission group. $ulf = new UserListFactory(); $ulf->getByCompanyId($company_id); $all_user_ids = array_keys((array) $ulf->getArrayByListFactory($ulf, FALSE, TRUE)); $assigned_user_ids = array(); foreach ($permission_group_data as $group_name => $permission_data) { Debug::text('zGroup Name: ' . $group_name, __FILE__, __LINE__, __METHOD__, 10); $pcf = new PermissionControlFactory(); $pcf->StartTransaction(); $pcf->setCompany($company_id); $pcf->setName(ucfirst($group_name)); $pcf->setDescription('Automatically Created By Installer'); if ($pcf->isValid()) { $pcf_id = $pcf->Save(FALSE); if (strtolower($group_name) == 'default') { //Assign all unassigned users to this permission group. $tmp_user_ids = array_merge((array) $this->permission_group_users[$company_id][$group_name], array_diff($all_user_ids, $assigned_user_ids)); //Debug::Arr($all_user_ids, 'Default Group All User IDs:', __FILE__, __LINE__, __METHOD__, 10); //Debug::Arr($assigned_user_ids, 'Default Group All User IDs:', __FILE__, __LINE__, __METHOD__, 10); //Debug::Arr($tmp_user_ids, 'Default Group User IDs:', __FILE__, __LINE__, __METHOD__, 10); $pcf->setUser($tmp_user_ids); unset($tmp_user_ids); } else { if (isset($this->permission_group_users[$company_id][$group_name]) and is_array($this->permission_group_users[$company_id][$group_name])) { $pcf->setUser($this->permission_group_users[$company_id][$group_name]); $assigned_user_ids = array_merge($assigned_user_ids, $this->permission_group_users[$company_id][$group_name]); } } if (is_array($permission_data)) { $pcf->setPermission($permission_data); } } //$pcf->FailTransaction(); $pcf->CommitTransaction(); } unset($all_user_ids, $assigned_user_ids); } } return TRUE; }
$pcf->Save(TRUE); if (DEMO_MODE == FALSE) { if ($action == 'apply_preset') { Debug::Text('Attempting to apply preset...', __FILE__, __LINE__, __METHOD__, 10); if (!isset($data['preset_flags'])) { $data['preset_flags'] = array(); } if ($pcf_id != '' and isset($data['preset'])) { Debug::Text('Applying Preset!', __FILE__, __LINE__, __METHOD__, 10); $pf = new PermissionFactory(); $pf->applyPreset($pcf_id, $data['preset'], $data['preset_flags']); } } } //$pcf->FailTransaction(); $pcf->CommitTransaction(); Redirect::Page(URLBuilder::getURL(array(), 'PermissionControlList.php')); break; } } $pcf->FailTransaction(); default: $pf = new PermissionFactory(); $plf = new PermissionListFactory(); if (isset($id)) { BreadCrumb::setCrumb($title); $pclf = new PermissionControlListFactory(); $pclf->getByIdAndCompanyId($id, $current_company->getId()); foreach ($pclf as $pc_obj) { $data = array('id' => $pc_obj->getId(), 'name' => $pc_obj->getName(), 'description' => $pc_obj->getDescription(), 'user_ids' => $pc_obj->getUser(), 'created_date' => $pc_obj->getCreatedDate(), 'created_by' => $pc_obj->getCreatedBy(), 'updated_date' => $pc_obj->getUpdatedDate(), 'updated_by' => $pc_obj->getUpdatedBy(), 'deleted_date' => $pc_obj->getDeletedDate(), 'deleted_by' => $pc_obj->getDeletedBy()); }