You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

521 lines
23 KiB

<?php
/*
* @copyright Leyun internet Technology(Shanghai)Co.,Ltd
* @license http://www.dzzoffice.com/licenses/license.txt
* @package DzzOffice
* @link http://www.dzzoffice.com
* @author zyx(zyx@dzz.cc)
*/
if (!defined('IN_DZZ')) {
exit('Access Denied');
}
include_once libfile('function/organization');
function getuserIcon($uids, $datas, &$data) {
$uids = array_unique($uids);
$avatars = array();
foreach (DB::fetch_all('select u.avatarstatus,u.uid,s.svalue from %t u left join %t s on u.uid=s.uid and s.skey=%s where u.uid in(%n)', array('user', 'user_setting', 'headerColor', $uids)) as $v) {
if ($v['avatarstatus'] == 1) {
$avatars[$v['uid']]['avatarstatus'] = 1;
} else {
$avatars[$v['uid']]['avatarstatus'] = 0;
$avatars[$v['uid']]['headerColor'] = $v['svalue'];
}
}
$userarr = array();
$data1 = array();
foreach ($datas as $v) {
$uid = $v['li_attr']['uid'];
$avatarstatus = $avatars[$uid]['avatarstatus'];
if ($avatars[$v['li_attr']['uid']]['avatarstatus']) {
$v['icon'] = 'avatar.php?uid=' . $v['li_attr']['uid'];
} elseif ($avatars[$uid]['headerColor']) {
$headercolor = $avatars[$uid]['headerColor'];
$v['icon'] = false;
$v['text'] = '<span class="iconFirstWord" style="background:' . $headercolor . ';">' . strtoupper(new_strsubstr($v['text'], 1, '')) . '</span>' . $v['text'];
} else {
$v['icon'] = false;
$v['text'] = avatar_block($uid, array(), 'iconFirstWord') . $v['text'];
}
$data[] = $v;
}
}
$do = trim($_GET['do']);
$orgid = intval($_GET['orgid']);
if ($do == 'upload') {//上传图片文件
include libfile('class/uploadhandler');
$options = array('accept_file_types' => '/\.(gif|jpe?g|png)$/i',
'upload_dir' => $_G['setting']['attachdir'] . 'cache/',
'upload_url' => $_G['setting']['attachurl'] . 'cache/',
'thumbnail' => array('max-width' => 40, 'max-height' => 40));
$upload_handler = new uploadhandler($options);
exit();
} /*elseif ($do == 'getdefaultpic') {//获取群组默认图片,上传图片保存
$imgs = C::t('resources_grouppic')->fetch_user_pic();
if (isset($_GET['aid'])) {
$aid = intval($_GET['aid']);
if ($_G['adminid'] == 1) $dafault = 1;
else $default = 0;
if (C::t('resources_grouppic')->insert_data($aid, $default)) {
showTips(array('success' => true), 'json');
} else {
showTips(array('error' => true), 'json');
}
}
}*/ elseif ($do == 'getchildren') {
$id = intval($_GET['id']);
$list = array();
$limit = 0;
$html = '';
//判断用户有没有操作权限
$ismoderator = C::t('organization_admin')->ismoderator_by_uid_orgid($id, $_G['uid']);
if ($ismoderator) {
$disable = '';
$type = 'user';
} else {
$disable = '"disabled":true,';
$type = "disabled";
}
if ($id) {
$icon = 'dzz/system/images/department.png';
} else {
$icon = 'dzz/system/images/organization.png';
}
$data = array();
if ($_GET['id'] == '#') {
if ($_G['adminid'] != 1) $topids = C::t('organization_admin')->fetch_toporgids_by_uid($_G['uid']);
foreach (C::t('organization')->fetch_all_by_forgid($id, 0, 0) as $value) {
if ($value['type'] == 1) continue;//过滤群
if ($_G['adminid'] != 1 && !in_array($value['orgid'], $topids)) continue;
if (C::t('organization_admin')->ismoderator_by_uid_orgid($value['orgid'], $_G['uid'])) {
$orgdisable = false;
$orgtype = 'organization';
} else {
$orgdisable = true;
$orgtype = 'disabled';
}
$arr = array('id' => $value['orgid'], 'text' => $value['orgname'], 'icon' => $icon, 'state' => array('disabled' => $orgdisable), "type" => $orgtype, 'children' => true);
if (intval($value['aid']) == 0) {
$arr['text'] = avatar_group($value['orgid'], array($value['orgid'] => array('aid' => $value['aid'], 'orgname' => $value['orgname']))) . $value['orgname'];
$arr['icon'] = false;
} else {
$arr['text'] = $value['orgname'];
$arr['icon'] = 'index.php?mod=io&op=thumbnail&width=24&height=24&path=' . dzzencode('attach::' . $value['aid']);
}
$data[] = $arr;
}
if($_G['adminid'] == 1) {
$data[] = array('id' => 'other', 'text' => lang('no_institution_users'), 'state' => array('disabled' => $disable), "type" => 'group', 'children' => true);
}
} else {
//获取用户列表
if (!$id) {
if ($ismoderator) {
$uids = array();
$datas = array();
foreach (C::t('organization_user')->fetch_user_not_in_orgid($limit) as $value) {
if (!$value['uid']) continue;
$uids[] = $value['uid'];
$datas[] = array('id' => 'uid_' . $value['uid'], 'text' => $value['username'] . '<em class="hide">' . $value['email'] . '</em>', 'icon' => 'dzz/system/images/user.png', 'state' => array('disabled' => $disable), "type" => $type, 'li_attr' => array('uid' => $value['uid']));
}
getuserIcon($uids, $datas, $data);
}
} else {
foreach (C::t('organization')->fetch_all_by_forgid($id) as $value) {
if (C::t('organization_admin')->ismoderator_by_uid_orgid($value['orgid'], $_G['uid'])) {
$orgdisable = '';
$orgtype = 'organization';
} else {
$orgdisable = '"disabled":true,';
$orgtype = 'disabled';
}
$arr = array('id' => $value['orgid'], 'text' => $value['orgname'], 'icon' => $icon, 'state' => array('disabled' => $orgdisable), "type" => $orgtype, 'children' => true);
if (intval($value['aid']) == 0) {
$arr['text'] = avatar_group($value['orgid'], array($value['orgid'] => array('aid' => $value['aid'], 'orgname' => $value['orgname']))) . $value['orgname'];
$arr['icon'] = false;
} else {
$arr['text'] = $value['orgname'];
$arr['icon'] = 'index.php?mod=io&op=thumbnail&width=24&height=24&path=' . dzzencode('attach::' . $value['aid']);
}
$data[] = $arr;
}
if ($ismoderator) {
$uids = array();
$datas = array();
foreach (C::t('organization_user')->fetch_user_by_orgid($id, $limit) as $value) {
if (!$value['uid']) continue;
$uids[] = $value['uid'];
$datas[] = array('id' => 'orgid_' . $value['orgid'] . '_uid_' . $value['uid'], 'text' => $value['username'] . '<em class="hide">' . $value['email'] . '</em>', 'icon' => 'dzz/system/images/user.png', 'state' => array('disabled' => $disable), "type" => $type, 'li_attr' => array('uid' => $value['uid']));
}
getuserIcon($uids, $datas, $data);
}
}
}
exit(json_encode($data));
} elseif ($do == 'search') {//jstree搜索接口
$str = trim($_GET['str']);
$str = '%' . $str . '%';
$sql = "username LIKE %s";
//搜索用户
$data = array('other');
$uids = array();
foreach (DB::fetch_all("select * from %t where $sql ", array('user', $str)) as $value) {
$uids[] = $value['uid'];
$data['uid_' . $value['uid']] = 'uid_' . $value['uid'];
}
$orgids = array();
foreach ($orgusers = C::t('organization_user')->fetch_all_by_uid($uids) as $value) {
$data['uid_' . $value['uid']] = 'orgid_' . $value['orgid'] . '_uid_' . $value['uid'];
$orgids[] = $value['orgid'];
}
foreach ($orgids as $orgid) {
$uporgids = C::t('organization')->fetch_parent_by_orgid($orgid);
foreach ($uporgids as $value) {
$data[$value] = $value;
}
}
$temp = array();
foreach ($data as $value) {
$temp[] = $value;
}
exit(json_encode($temp));
} elseif ($do == 'getjobs') {
$orgid = intval($_GET['orgid']);
$jobs = C::t('organization_job')->fetch_all_by_orgid($orgid);
$html = '<li><a href="javascript:;" class="dropdown-item" tabindex="-1" role="menuitem" _jobid="0" onclick="selJob(this)">' . lang('none') . '</a></li>';
foreach ($jobs as $job) {
$html .= '<li><a href="javascript:;" class="dropdown-item" tabindex="-1" role="menuitem" _jobid="' . $job['jobid'] . '" onclick="selJob(this)">' . $job['name'] . '</a></li>';
}
exit($html);
} elseif ($do == 'create') {
$forgid = intval($_GET['forgid']);
$borgid = intval($_GET['orgid']);
//放在此部门后面
if (!$ismoderator = C::t('organization_admin')->ismoderator_by_uid_orgid($forgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
/*默认新建机构和部门开始群组manageon群组管理员开启 syatemon系统管理员开启 available 系统管理员开启共享目录,保留diron(群组管理员开启目录)控制是否开启目录显示在前台*/
$setarr = array('forgid' => intval($_GET['forgid']), 'orgname' => lang('new_department'), 'fid' => 0, 'disp' => intval($_GET['disp']), 'indesk' => 0, 'dateline' => TIMESTAMP, 'available' => 1, 'syatemon' => 1, 'manageon' => 1, 'maxspacesize' => getglobal('orgmemorySpace', 'setting'));
if ($setarr = C::t('organization')->insert_by_forgid($setarr, $borgid)) {
include_once libfile('function/cache');
updatecache('organization');
} else {
$setarr['error'] = 'create organization failure';
}
exit(json_encode($setarr));
} elseif ($do == 'rename') {
$orgid = intval($_GET['orgid']);
if (!$ismoderator = C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization')->update_by_orgid($orgid, array('orgname' => getstr($_GET['text'])))) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('msg' => lang('rechristen_error'))));
}
} elseif ($do == 'delete') {
if ($_GET['type'] == 'user') {//删除用户
$forgid = intval($_GET['forgid']);
$uids = $_GET['uids'];
$realdelete = intval($_GET['realdelete']);
if ($realdelete) {
if ($_G['adminid'] != 1)
exit(json_encode(array('error' => lang('privilege'))));
//判断用户是否在部门中,在部门中的用户不彻底删除
if (C::t('organization_user')->fetch_orgids_by_uid($uids)) {
exit(json_encode(array('error' => lang('orguser_ajax_delete'))));
}
foreach ($uids as $uid) {
//删除用户
C::t('user')->delete_by_uid($uid);
}
exit(json_encode(array('msg' => 'success')));
} else {
//检测权限
if (!$ismoderator = C::t('organization_admin')->chk_memberperm($forgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization_user')->delete_by_uid_orgid($uids, $forgid)) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('msg' => lang('delete_error'))));
}
}
} else {
$orgid = ($_GET['orgid']);
$forgid = intval($_GET['forgid']);
if (!$ismoderator = C::t('organization_admin')->ismoderator_by_uid_orgid($forgid, $_G['uid'])) {
exit(json_encode(array('error' => loang('privilege'))));
}
if ($return = C::t('organization')->delete_by_orgid($orgid)) {//删除部门,部门的用户移动到上级部门去;
if ($return['error']) {
exit(json_encode($return));
}
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('msg' => lang('delete_error'))));
}
}
} elseif ($do == 'move') {
if ($_GET['type'] == 'user') {//移动用户
$orgid = intval($_GET['orgid']);
$forgid = intval($_GET['forgid']);
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($forgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
$copy = intval($_GET['copy']);
$uid = intval($_GET['uid']);
if (C::t('organization_user')->move_to_by_uid_orgid($uid, $forgid, $orgid, $copy)) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('error' => lang('movement_error'))));
}
} else {
$orgid = intval($_GET['orgid']);
$disp = intval($_GET['position']);
$forgid = intval($_GET['forgid']);
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($forgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization')->setDispByOrgid($orgid, $disp, $forgid)) {//移动部门;
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('msg' => lang('delete_error'))));
}
}
} elseif ($do == 'jobedit') {
$jobid = intval($_GET['jobid']);
$orgid = intval($_GET['orgid']);
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
$name = str_replace('...', '', getstr($_GET['name'], 30));
if (C::t('organization_job')->update($jobid, array('name' => $name))) {
exit(json_encode(array('jobid' => $jobid, 'name' => $name)));
} else {
exit(json_encode(array('error' => lang('edit_error'))));
}
} elseif ($do == 'jobdel') {
$jobid = intval($_GET['jobid']);
$orgid = intval($_GET['orgid']);
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization_job')->delete($jobid)) {
exit(json_encode(array('jobid' => $jobid)));
} else {
exit(json_encode(array('error' => lang('delete_unsuccess'))));
}
} elseif ($do == 'jobadd') {
$orgid = intval($_GET['orgid']);
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
$setarr = array('orgid' => $orgid, 'name' => str_replace('...', '', getstr($_GET['name'], 30)), 'dateline' => TIMESTAMP, 'opuid' => $_G['uid']);
if ($setarr['jobid'] = C::t('organization_job')->insert($setarr)) {
exit(json_encode($setarr));
} else {
exit(json_encode(array('error' => lang('add_unsuccess'))));
}
} elseif ($do == 'moderator_add') {
$orgid = intval($_GET['orgid']);
$org = C::t('organization')->fetch($orgid);
$perm = C::t('organization_admin')->chk_memberperm($orgid, $_G['uid']);
if ($perm < 2) {
exit(json_encode(array('error' => lang('privilege'))));
}
$setarr = array('orgid' => $orgid, 'uid' => intval($_GET['uid']), 'dateline' => TIMESTAMP, 'opuid' => $_G['uid']);
if ($setarr['id'] = C::t('organization_admin')->insert(intval($_GET['uid']), $orgid)) {
$user = getuserbyuid($setarr['uid']);
$setarr['username'] = $user['username'];
$setarr['avatar'] = avatar_block($setarr['uid']);
exit(json_encode($setarr));
} else {
exit(json_encode(array('error' => lang('add_administrator_unsuccess'))));
}
} elseif ($do == 'moderator_del') {
$orgid = intval($_GET['orgid']);
$org = C::t('organization_admin')->fetch($orgid);
//获取当前操作用户权限,系统管理员,上级部门管理员和群组创建人均返回2
$perm = C::t('organization_admin')->chk_memberperm($orgid, $_G['uid']);
if ($perm < 2) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization_admin')->delete_by_id(intval($_GET['id']))) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('error' => lang('add_administrator_unsuccess'))));
}
} elseif ($do == 'folder_available') {
$orgid = intval($_GET['orgid']);
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization')->setFolderAvailableByOrgid($orgid, intval($_GET['available']))) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('error' => lang('unable_set') . ',如果上级没有开启目录共享,下级无法开启')));
}
} elseif ($do == 'folder_indesk') {
$orgid = intval($_GET['orgid']);
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization')->setIndeskByOrgid($orgid, intval($_GET['indesk']))) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('error' => lang('no_open_Shared_directory'))));
}
} elseif ($do == 'set_org_orgname') {
$orgid = intval($_GET['orgid']);
$orgname = getstr($_GET['orgname'], 255);
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization')->update_by_orgid($orgid, array('orgname' => $orgname))) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('error' => lang('rechristen_error'))));
}
} elseif ($do == 'set_org_logo') {
$orgid = intval($_GET['orgid']);
$img = intval(($_GET['aid']));
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization')->update_by_orgid($orgid, array('aid' => $img))) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('error' => lang('rechristen_error'))));
}
} elseif ($do == 'set_org_desc') {
$orgid = intval($_GET['orgid']);
$desc = getstr($_GET['desc']);
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization')->update_by_orgid($orgid, array('desc' => $desc))) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('error' => lang('rechristen_error'))));
}
} elseif ($do == 'group_on') {
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (C::t('organization')->setgroupByOrgid($orgid, intval($_GET['available']))) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('error' => lang('unable_set'))));
}
} elseif ($do == 'orginfo') {
$array = isset($_GET['arr']) ? $_GET['arr'] : '';
if (!empty($array)) {
$orgid = intval($array['orgid']);
if (!C::t('organization_admin')->ismoderator_by_uid_orgid($orgid, $_G['uid'])) {
exit(json_encode(array('error' => lang('privilege'))));
}
if (!$org = C::t('organization')->fetch($orgid)) {
exit(json_encode(array('error' => lang('organization_not_exists'))));
}
$setarr = array(
'desc' => getstr($array['desc']),
'groupback' => isset($array['groupback']) ? intval($array['groupback']) : 0,
'aid' => isset($array['aid']) ? intval($array['aid']) : 0,
//'orgname'=>getstr($array['orgname']);
);
if (C::t('organization')->update($orgid, $setarr)) {
$addaids = array();
$delaids = array();
if (!empty($array['aid']) && $array['aid'] != $org['aid']) {
$addaids[] = $array['aid'];
$delaids[] = $org['aid'];
}
if (!empty($array['groupback']) && $array['groupback'] != $org['groupback']) {
$addaids[] = $array['groupback'];
$delaids[] = $org['groupback'];
}
if (!empty($addaids)) {
C::t('attachment')->addcopy_by_aid($addaids);
}
if (!empty($delaids)) {
C::t('attachment')->addcopy_by_aid($delaids, -1);
}
exit(json_encode(array('success' => true)));
} else {
exit(json_encode(array('error' => lang('edit_error'))));
}
}
} elseif ($do == 'folder_maxspacesize') {
$orgid = intval($_GET['orgid']);
$setspacesize = intval($_GET['maxspacesize']);
if (!$org = C::t('organization')->fetch($orgid)) {
exit(json_encode(array('error' => '该机构或群组不存在或被删除')));
}
//暂时只允许系统管理员进行空间相关设置
if ($_G['adminid'] != 1) {
exit(json_encode(array('error' => '没有权限')));
}
if ($setspacesize != 0) {
//获取允许设置的空间值
$allowallotspace = C::t('organization')->get_allowallotspacesize_by_orgid($orgid);
if ($allowallotspace < 0) {
exit(json_encode(array('error' => '可分配空间不足')));
}
//获取当前已占用空间大小
$currentallotspace = C::t('organization')->get_orgallotspace_by_orgid($orgid, 0, false);
//设置值小于当前下级分配总空间值即:当前设置值 < 下级分配总空间
if ($setspacesize > 0 && $setspacesize * 1024 * 1024 < $currentallotspace) {
exit(json_encode(array('error' => '设置空间值不足,小于已分配空间值!', 'val' => $org['maxspacesize'])));
}
//上级包含空间限制时,无限制不处理,直接更改设置值
if ($allowallotspace > 0 && ($setspacesize * 1024 * 1024 > $allowallotspace)) {
exit(json_encode(array('error' => '总空间不足!', 'val' => $org['maxspacesize'])));
}
}
//设置新的空间值
if (C::t('organization')->update($orgid, array('maxspacesize' => $setspacesize))) {
exit(json_encode(array('msg' => 'success')));
} else {
exit(json_encode(array('error' => '设置不成功或未更改', 'val' => $org['maxspacesize'])));
}
} elseif ($do == 'guide') {
include template('guide');
}
exit();
?>