KodExplorer/controller/system_member.class.php

477 lines
15 KiB
PHP
Raw Normal View History

2016-12-30 15:55:50 +00:00
<?php
/*
* @link http://www.kalcaddle.com/
* @author warlee | e-mail:kalcaddle@qq.com
* @copyright warlee 2014.(Shanghai)Co.,Ltd
* @license http://kalcaddle.com/tools/licenses/license.txt
*/
//用户管理【管理员配置用户or用户空间大小变更】
class system_member extends Controller{
public static $static_sql = null;
private $sql;
function __construct() {
parent::__construct();
$this->tpl = TEMPLATE.'member/';
$this->sql= self::load_data();
}
//保证只加载一次文件
public static function load_data(){
if(is_null(self::$static_sql)){
self::$static_sql = system_member_data();
}
return self::$static_sql;
}
public static function get_info($the_id){
$sql = self::load_data();
return $sql->get($the_id);
}
/**
* 空间使用变更
* @param [type] $the_id [user_id or group_id]
* @param [type] $use_size_add [变更的大小 size_max G为单位 size_use Byte为单位]
*/
public static function space_change($the_id,$use_size_add=false){
$sql = self::load_data();
$info = $sql->get($the_id);
if(!is_array($info)){
show_json($this->L["data_not_full"],false);
}
if($use_size_add===false){//重置用户空间;避免覆盖、解压等导致的问题
$pathinfo = _path_info_more(iconv_system(USER_PATH.$info['path'].'/'));
$current_use = $pathinfo['size'];
if(isset($info['home_path']) && file_exists(iconv_system($info['home_path']))){
$pathinfo = _path_info_more(iconv_system($info['home_path']));
$current_use += $pathinfo['size'];
}
}else{
$current_use = floatval($info['config']['size_use'])+floatval($use_size_add);
}
$info['config']['size_use'] = $current_use<0?0:$current_use;
$sql->set($the_id,$info);
}
/**
* 空间剩余检测
* 1073741824 —— 1G
*/
public static function space_check($the_id){
$sql = self::load_data();
$info = $sql->get($the_id);
if(!is_array($info)){
show_json($this->L["data_not_full"],false);
}
$size_use = floatval($info['config']['size_use']);
$size_max = floatval($info['config']['size_max']);
if($size_max!=0 && $size_max*1073741824<$size_use){
show_json($GLOBALS['L']['space_is_full'],false);
}
}
// 组删除后,所属该组的用户都删除;全局调用
public static function group_remove_user_update($group_id){
$sql = self::load_data();
$user_all = $sql->get();
foreach ($user_all as $key => $val) {
if(in_array($group_id,array_keys($val['group_info']))){
unset($val['group_info'][$group_id]);
$sql->set($val['user_id'],$val);
}
}
}
// 权限组删除所属该组的用户删除权限id
public static function role_remove_user_update($role_id){
$sql = self::load_data();
$user_all = $sql->get();
foreach ($user_all as $key => $val) {
if($val['role'] == $role_id){
$val['role'] = '';
$sql->set($val['user_id'],$val);
}
}
}
//判断自己对某个组的权限 return false/'read'/'write' 174不对
public static function user_auth_group($group_id){
$sql = self::load_data();
$user_info = $sql->get($_SESSION['kod_user']['user_id']);
$group_info = $user_info['group_info'];//自己所在的组
if(!is_array($group_info)){
return false;
}
if(isset($group_info[$group_id])){
return $group_info[$group_id];
}
foreach ($group_info as $key => $value) {//
$group = system_group::get_info($key);//测试组,是否在用户所在组的子组
$arr = explode(',',$group['children']);
if (in_array($group_id,$arr)) {
return $group_info[$key];
}
}
return false;
}
//删除 path id
public static function _filter_list($list,$filter_key = 'path'){
if($GLOBALS['is_root']) return $list;
foreach ($list as $key => &$val) {
unset($val[$filter_key]);
unset($val['password']);
}
return $list;
}
//获取在某个组的用户
public static function get_user_at_group($group_id){
$sql = self::load_data();
$all_user = self::_filter_list($sql->get());
if($group_id=='0'){
return $all_user;
}
$select_user = array();
foreach ($all_user as $val) {
if(isset($val['group_info'][$group_id])){
$select_user[] = $val;
}
}
return $select_user;
}
//缓存用户共享对象=======================================
public static function user_share_sql($user_id){
static $user_share_arr;
if(!is_array($user_share_arr)){
$user_share_arr = array();
}
if(!isset($user_share_arr[$user_id])){
$user_info = system_member::get_info($user_id);
if(!isset($user_info['path'])){
return;
}
$sql = new fileCache(USER_PATH.$user_info['path'].'/data/share.php');
$user_share_arr[$user_id] = $sql;
}
return $user_share_arr[$user_id];
}
//获取某个用户共享列表
public static function user_share_list($user_id){
$sql = self::user_share_sql($user_id);
$list = $sql->get();
if($user_id == $_SESSION['kod_user']['user_id']){//自己的列表则展示密码;否则清空密码
return $list;
}
foreach($list as $key=>&$val){
unset($val['share_password']);
}
return $list;
}
//获取某个用户某个共享
public static function user_share_get($user_id,$name){
$sql = self::user_share_sql($user_id);
return $sql->get('name',$name);
}
//后台管理=====================
//管理员调用===================
/**
* 获取用户列表数据,根据用户组筛选;默认输出所有用户
*/
public function get($group_id='0') {
$result = self::get_user_at_group($group_id);
show_json($result);
}
/**
* 用户添加
* system_member/add&name=warlee&password=123&size_max=0&group_info={"0":"read","10":"write"}&role=default
*/
public function add(){
if (!isset($this->in['name']) || //必填项
!isset($this->in['password']) ||
!isset($this->in['role']) ||
!isset($this->in['group_info']) || //{"0":"read","100":"read"}
!isset($this->in['size_max'])
) show_json($this->L["data_not_full"],false);
$name = trim(rawurldecode($this->in['name']));
$password = rawurldecode($this->in['password']);
$group_info = json_decode(rawurldecode($this->in['group_info']),true);
if(!is_array($group_info)){
show_json($this->L["system_member_group_error"],false);
}
if($this->sql->get(array('name',$name))){
show_json($this->L['error_repeat'],false);
}
//非系统管理员,不能将别人设置为系统管理员
if(!$GLOBALS['is_root'] && $this->in['role']=='1'){
show_json($this->L['group_role_error'],false);
}
$user_array = array();
if(isset($this->in['isImport'])){
$arr = explode("\n",$name);
foreach($arr as $v){
if(trim($v)!=''){
$user_array[] = trim($v);
}
}
}else{
$user_array[] = $name;
}
//批量添加
$error_arr = array();
foreach ($user_array as $val) {
if($this->sql->get('name',$val)){//已存在
$error_arr[] = $val;
continue;
}
$user_id = $this->sql->get_max_id().'';
$user_info = array(
'user_id' => $user_id,
'name' => $val,
'password' => md5($password),
'role' => $this->in['role'],
'config' => array('size_max' => floatval($this->in['size_max']),//M
'size_use' => 1024*1024),//总大小,目前使用大小
'group_info'=> $group_info,
'path' => make_path($val),
'status' => 1, //0禁用1启用
'last_login'=> '', //最后登录时间 首次登陆则激活
'create_time'=> time(),
);
if(file_exists(iconv_system(USER_PATH.$user_info['path'])) ){
$user_info['path'] = $user_info['path'].'_'.$user_info['user_id'];
}
if(!$GLOBALS['is_root']){
show_json($this->L['no_permission'],false);
}
//用户组目录
if( isset($this->in['home_path'])){
$user_info['home_path'] = _DIR(rawurldecode($this->in['home_path']));
if(!file_exists($user_info['home_path'])){
show_json($this->L['not_exists'],false);
}
$user_info['home_path'] = iconv_app($user_info['home_path']);
}else{
unset($user_info['home_path']);
}
if ($this->sql->set($user_id,$user_info)) {
$this->_initDir($user_info['path']);
}else{
$error_arr[] = $val;
}
}
$success = count($user_array)-count($error_arr);
$show = " success:$success";
if($success==count($user_array)){
show_json($this->L['success'].$show,true,$success);
}else if($success!=0){//部分失败
$error_info = " error:".count($error_arr);
show_json($this->L['success'].$show.$error_info,false,implode("\n",$error_arr));
}else{
show_json($this->L['error_repeat'],false);
}
}
/**
* 编辑 system_member/edit&user_id=101&name=warlee&password=123&size_max=0
* &group_info={%220%22:%22read%22,%22100%22:%22read%22}&role=default
*/
public function edit() {
if (!$this->in['user_id']) show_json($this->L["data_not_full"],false);
$user_id = $this->in['user_id'];
$user_info = $this->sql->get($user_id);
if(!$user_info){//用户不存在,或者默认用户不能修改
show_json($this->L['error'],false);
}
//非系统管理员,不能将别人设置为系统管理员
if(!$GLOBALS['is_root'] && $this->in['role']=='1'){
show_json($this->L['group_role_error'],false);
}
//非系统管理员,不能修改系统管理员
if(!$GLOBALS['is_root'] && $user_info['role']=='1'){
show_json($this->L['group_role_error_admin'],false);
}
//管理员自己不能添加自己到非管理员组
if($GLOBALS['is_root']
&& $_SESSION['kod_user']['user_id']==$user_id
&& $this->in['role']!='1'){
show_json($this->L['error'],false);
}
//修改为一个已存在的名字则提示
$the_name = trim(rawurldecode($this->in['name']));
if($user_info['name']!=$the_name){
if($this->sql->get(array('name',$the_name))){
show_json($this->L['error_repeat'],false);
}
}
$this->in['name'] = rawurlencode($the_name);//还原
$edit_arr = array('name','role','password','group_info','home_path','status','size_max');
foreach ($edit_arr as $key) {
if(!isset($this->in[$key])) continue;
$user_info[$key] = rawurldecode($this->in[$key]);
if($key == 'password'){
$user_info['password'] = md5($user_info[$key]);
}else if($key == 'size_max'){
$user_info['config']['size_max'] = floatval($user_info[$key]);
}else if($key == 'group_info'){//分组信息
$user_info['group_info'] = json_decode(rawurldecode($this->in['group_info']),true);
}
}
if(!$GLOBALS['is_root']){
show_json($this->L['no_permission'],false);
}
//用户组目录
if( isset($this->in['home_path'])){
$user_info['home_path'] = _DIR(rawurldecode($this->in['home_path']));
if(!file_exists($user_info['home_path'])){
show_json($this->L['not_exists'],false);
}
$user_info['home_path'] = iconv_app($user_info['home_path']);
}else{
unset($user_info['home_path']);
}
if($this->sql->set($user_id,$user_info)){
self::space_change($user_id);//重置用户使用空间
show_json($this->L['success'],true,$user_info);
}
show_json($this->L['error_repeat'],false);
}
/**
* 用户批量操作 system_member/do_action&action=&user_id=[101,222,131]&param=
* action :
* -------------
* del 删除用户
* status_set 启用&禁用 param=0/1
* role_set 权限组 param=role_id
* group_reset 重置分组 param=group_json
* group_remove_from 从某个组删除 param=group_id
* group_add 添加到某个分组 param=group_json
*/
public function do_action() {
if (!isset($this->in['user_id'])){
show_json($this->L["username_can_not_null"],false);
}
$action = $this->in['action'];
$user_arr = json_decode($this->in['user_id'],true);
if(!is_array($user_arr)){
show_json($this->L['error'],false);
}
if (in_array('1', $user_arr)){//批量处理,不处理系统管理员
show_json($this->L['default_user_can_not_do'],false);
}
foreach ($user_arr as $user_id) {
switch ($action) {
case 'del'://删除
$user_info = $this->sql->get($user_id);
if($this->sql->remove($user_id) && $user_info['name']!=''){
del_dir(iconv_system(USER_PATH.$user_info['path'].'/'));
}
break;
case 'status_set'://禁用&启用
$status = intval($this->in['param']);
$this->sql->set(array('user_id',$user_id),array('status',$status));
break;
case 'role_set'://设置权限组
$role = $this->in['param'];
//非系统管理员,不能将别人设置为系统管理员
if(!$GLOBALS['is_root'] && $role=='1'){
show_json($this->L['group_role_error'],false);
}
$this->sql->set(array('user_id',$user_id),array('role',$role));
break;
case 'group_reset'://设置分组
$group_arr = json_decode($this->in['param'],true);
if(!is_array($group_arr)){
show_json($this->L['error'],false);
}
$this->sql->set(array('user_id',$user_id),array('group_info',$group_arr));
break;
case 'group_remove_from'://从某个组移除
$group_id = $this->in['param'];
$user_info = $this->sql->get($user_id);
unset($user_info['group_info'][$group_id]);
$this->sql->set($user_id,$user_info);
break;
case 'group_add'://添加到某个组
$group_arr = json_decode($this->in['param'],true);
if(!is_array($group_arr)){
show_json($this->L['error'],false);
}
$user_info = $this->sql->get($user_id);
foreach ($group_arr as $key => $value) {
$user_info['group_info'][$key] = $value;
}
$this->sql->set($user_id,$user_info);
default:break;
}
}
show_json($this->L['success']);
}
public function init_install(){
$sql = system_member::load_data();
$list = $sql->get();
foreach ($list as $id => &$info) {//创建用户目录及初始化
$path = make_path($info['name']);
$this->_initDir($path);
$info['path'] = $path;
$info['create_time'] = time();
}
$sql->reset($list);
//初始化群组目录
$home_folders = explode(',',$this->config['setting_system']['new_group_folder']);
$sql = system_group::load_data();
$list = $sql->get();
foreach ($list as $id => &$info) {//创建用户目录及初始化
$path = make_path($info['name']);
$root_path = GROUP_PATH.$path.'/';
foreach ($home_folders as $dir) {
mk_dir(iconv_system($root_path.'home/'.$dir));
}
$info['path'] = $path;
$info['create_time'] = time();
}
$sql->reset($list);
}
//============内部处理函数=============
/**
*初始化用户数据和配置。
*/
private function _initDir($path){
$user_folder = array('home','recycle','data');
$home_folders = explode(',',$this->config['setting_system']['new_user_folder']);
$root_path = USER_PATH.$path.'/';
foreach ($user_folder as $dir) {
mk_dir(iconv_system($root_path.$dir));
}
foreach ($home_folders as $dir) {
mk_dir(iconv_system($root_path.'home/'.$dir));
}
fileCache::save($root_path.'data/config.php',$this->config['setting_default']);
}
}