134 lines
4.0 KiB
PHP
134 lines
4.0 KiB
PHP
|
<?php
|
||
|
/*********************************************************************************
|
||
|
** The contents of this file are subject to the vtiger CRM Public License Version 1.0
|
||
|
* ("License"); You may not use this file except in compliance with the License
|
||
|
* The Original Code is: vtiger CRM Open Source
|
||
|
* The Initial Developer of the Original Code is vtiger.
|
||
|
* Portions created by vtiger are Copyright (C) vtiger.
|
||
|
* All Rights Reserved.
|
||
|
*
|
||
|
********************************************************************************/
|
||
|
|
||
|
|
||
|
/** Class to retreive all the vtiger_users present in a group
|
||
|
*
|
||
|
*/
|
||
|
require_once('include/utils/UserInfoUtil.php');
|
||
|
require_once('include/utils/GetParentGroups.php');
|
||
|
|
||
|
class GetGroupUsers {
|
||
|
|
||
|
var $group_users=array();
|
||
|
var $group_subgroups=array();
|
||
|
|
||
|
/** to get all the vtiger_users and vtiger_groups of the specified group
|
||
|
* @params $groupId --> Group Id :: Type Integer
|
||
|
* @returns the vtiger_users present in the group in the variable $parent_groups of the class
|
||
|
* @returns the sub vtiger_groups present in the group in the variable $group_subgroups of the class
|
||
|
*/
|
||
|
function getAllUsersInGroup($groupid)
|
||
|
{
|
||
|
global $adb,$log;
|
||
|
$log->debug("Entering getAllUsersInGroup(".$groupid.") method...");
|
||
|
//Retreiving from the user2grouptable
|
||
|
$query="select * from vtiger_users2group where groupid=?";
|
||
|
$result = $adb->pquery($query, array($groupid));
|
||
|
$num_rows=$adb->num_rows($result);
|
||
|
for($i=0;$i<$num_rows;$i++)
|
||
|
{
|
||
|
$now_user_id=$adb->query_result($result,$i,'userid');
|
||
|
if(! in_array($now_user_id,$this->group_users))
|
||
|
{
|
||
|
$this->group_users[]=$now_user_id;
|
||
|
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
//Retreiving from the vtiger_group2role
|
||
|
$query="select * from vtiger_group2role where groupid=?";
|
||
|
$result = $adb->pquery($query, array($groupid));
|
||
|
$num_rows=$adb->num_rows($result);
|
||
|
for($i=0;$i<$num_rows;$i++)
|
||
|
{
|
||
|
$now_role_id=$adb->query_result($result,$i,'roleid');
|
||
|
$now_role_users=array();
|
||
|
$now_role_users=getRoleUsers($now_role_id);
|
||
|
|
||
|
foreach($now_role_users as $now_role_userid => $now_role_username)
|
||
|
{
|
||
|
if(! in_array($now_role_userid,$this->group_users))
|
||
|
{
|
||
|
$this->group_users[]=$now_role_userid;
|
||
|
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
//Retreiving from the vtiger_group2rs
|
||
|
$query="select * from vtiger_group2rs where groupid=?";
|
||
|
$result = $adb->pquery($query, array($groupid));
|
||
|
$num_rows=$adb->num_rows($result);
|
||
|
for($i=0;$i<$num_rows;$i++)
|
||
|
{
|
||
|
$now_rs_id=$adb->query_result($result,$i,'roleandsubid');
|
||
|
$now_rs_users=getRoleAndSubordinateUsers($now_rs_id);
|
||
|
foreach($now_rs_users as $now_rs_userid => $now_rs_username)
|
||
|
{
|
||
|
if(! in_array($now_rs_userid,$this->group_users))
|
||
|
{
|
||
|
$this->group_users[]=$now_rs_userid;
|
||
|
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|
||
|
//Retreving from group2group
|
||
|
$query="select * from vtiger_group2grouprel where groupid=?";
|
||
|
$result = $adb->pquery($query, array($groupid));
|
||
|
$num_rows=$adb->num_rows($result);
|
||
|
for($i=0;$i<$num_rows;$i++)
|
||
|
{
|
||
|
$now_grp_id=$adb->query_result($result,$i,'containsgroupid');
|
||
|
|
||
|
|
||
|
$focus = new GetGroupUsers();
|
||
|
$focus->getAllUsersInGroup($now_grp_id);
|
||
|
$now_grp_users=$focus->group_users;
|
||
|
$now_grp_grps=$focus->group_subgroups;
|
||
|
if(! array_key_exists($now_grp_id,$this->group_subgroups))
|
||
|
{
|
||
|
$this->group_subgroups[$now_grp_id]=$now_grp_users;
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
foreach($focus->group_users as $temp_user_id)
|
||
|
{
|
||
|
if(! in_array($temp_user_id,$this->group_users))
|
||
|
{
|
||
|
$this->group_users[]=$temp_user_id;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
foreach($focus->group_subgroups as $temp_grp_id => $users_array)
|
||
|
{
|
||
|
if(! array_key_exists($temp_grp_id,$this->group_subgroups))
|
||
|
{
|
||
|
$this->group_subgroups[$temp_grp_id]=$focus->group_users;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
$log->debug("Exiting getAllUsersInGroup method...");
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|
||
|
|
||
|
?>
|