| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331 | <?php/** * 管理员后台会员审核操作类 */defined('IN_PHPCMS') or exit('No permission resources.');pc_base::load_app_class('admin', 'admin', 0);pc_base::load_sys_class('format', '', 0);class member_verify extends admin {		private $db, $member_db;		function __construct() {		parent::__construct();		$this->db = pc_base::load_model('member_verify_model');		$this->_init_phpsso();	}	/**	 * defalut	 */	function init() {		include $this->admin_tpl('member_init');	}		/**	 * member list	 */	function manage() {		$status = !empty($_GET['s']) ? $_GET['s'] : 0;		$where = array('status'=>$status);		$page = isset($_GET['page']) ? intval($_GET['page']) : 1;		$memberlist = $this->db->listinfo($where, 'regdate DESC', $page, 10);		$pages = $this->db->pages;		$member_model = getcache('member_model', 'commons');		include $this->admin_tpl('member_verify');	}		function modelinfo() {		$userid = !empty($_GET['userid']) ? intval($_GET['userid']) : showmessage(L('illegal_parameters'), HTTP_REFERER);		$modelid = !empty($_GET['modelid']) ? intval($_GET['modelid']) : showmessage(L('illegal_parameters'), HTTP_REFERER);				$memberinfo = $this->db->get_one(array('userid'=>$userid));		//模型字段名称		$this->member_field_db = pc_base::load_model('sitemodel_field_model');		$model_fieldinfo = $this->member_field_db->select(array('modelid'=>$modelid), "*", 100);		//用户模型字段信息		$member_fieldinfo = string2array($memberinfo['modelinfo']);				//交换数组key值		foreach($model_fieldinfo as $v) {			if(array_key_exists($v['field'], $member_fieldinfo)) {				$tmp = $member_fieldinfo[$v['field']];				unset($member_fieldinfo[$v['field']]);				$member_fieldinfo[$v['name']] = $tmp;				unset($tmp);			}		}		include $this->admin_tpl('member_verify_modelinfo');	}			/**	 * pass member	 */	function pass() {		if (isset($_POST['userid'])) {			$this->member_db = pc_base::load_model('member_model');			$uidarr = isset($_POST['userid']) ? $_POST['userid'] : showmessage(L('illegal_parameters'), HTTP_REFERER);			$where = to_sqls($uidarr, '', 'userid');			$userarr = $this->db->listinfo($where);			$success_uids = $info = array();						foreach($userarr as $v) {				$status = $this->client->ps_member_register($v['username'], $v['password'], $v['email'], $v['regip'], $v['encrypt']);				if ($status > 0) {					$info['phpssouid'] = $status;					$info['password'] = password($v['password'], $v['encrypt']);					$info['regdate'] = $info['lastdate'] = $v['regdate'];					$info['username'] = $v['username'];					$info['nickname'] = $v['nickname'];					$info['email'] = $v['email'];					$info['regip'] = $v['regip'];					$info['point'] = $v['point'];					$info['groupid'] = $this->_get_usergroup_bypoint($v['point']);					$info['amount'] = $v['amount'];					$info['encrypt'] = $v['encrypt'];					$info['modelid'] = $v['modelid'] ? $v['modelid'] : 10;					if($v['mobile']) $info['mobile'] = $v['mobile'];					$userid = $this->member_db->insert($info, 1);					if($v['modelinfo']) {	//如果数据模型不为空						//插入会员模型数据						$user_model_info = string2array($v['modelinfo']);						$user_model_info['userid'] = $userid;						$this->member_db->set_model($info['modelid']);						$this->member_db->insert($user_model_info);					}										if($userid) {						$success_uids[] = $v['userid'];					}				}			}			$where = to_sqls($success_uids, '', 'userid');						$this->db->update(array('status'=>1, 'message'=>$_POST['message']), $where);						//phpsso注册失败的用户状态直接置为审核期间phpsso已注册该会员			$fail_uids = array_diff($uidarr, $success_uids);			if (!empty($fail_uids)) {				$where = to_sqls($fail_uids, '', 'userid');				$this->db->update(array('status'=>5, 'message'=>$_POST['message']), $where);			}						//发送 email通知			if($_POST['sendemail']) {				$memberinfo = $this->db->select($where);				pc_base::load_sys_func('mail');				foreach ($memberinfo as $v) {					sendmail($v['email'], L('reg_pass'), $_POST['message']);				}			}						showmessage(L('pass').L('operation_success'), HTTP_REFERER);		} else {			showmessage(L('operation_failure'), HTTP_REFERER);		}	}		/**	 * delete member	 */	function delete() {		if(isset($_POST['userid'])) {			$uidarr = isset($_POST['userid']) ? $_POST['userid'] : showmessage(L('illegal_parameters'), HTTP_REFERER);			$message = stripslashes($_POST['message']);			$where = to_sqls($uidarr, '', 'userid');			$this->db->delete($where);									showmessage(L('delete').L('operation_success'), HTTP_REFERER);		} else {			showmessage(L('operation_failure'), HTTP_REFERER);		}	}	/**	 * reject member	 */	function reject() {		if(isset($_POST['userid'])) {			$uidarr = isset($_POST['userid']) ? $_POST['userid'] : showmessage(L('illegal_parameters'), HTTP_REFERER);			$where = to_sqls($uidarr, '', 'userid');			$res = $this->db->update(array('status'=>4, 'message'=>$_POST['message']), $where);			//发送 email通知			if($res) {				if($_POST['sendemail']) {					$memberinfo = $this->db->select($where);					pc_base::load_sys_func('mail');					foreach ($memberinfo as $v) {						sendmail($v['email'], L('reg_reject'), $_POST['message']);					}				}			}						showmessage(L('reject').L('operation_success'), HTTP_REFERER);		} else {			showmessage(L('operation_failure'), HTTP_REFERER);		}	}	/**	 * ignore member	 */	function ignore() {		if(isset($_POST['userid'])) {					$uidarr = isset($_POST['userid']) ? $_POST['userid'] : showmessage(L('illegal_parameters'), HTTP_REFERER);			$where = to_sqls($uidarr, '', 'userid');			$res = $this->db->update(array('status'=>2, 'message'=>$_POST['message']), $where);			//发送 email通知			if($res) {				if($_POST['sendemail']) {					$memberinfo = $this->db->select($where);					pc_base::load_sys_func('mail');					foreach ($memberinfo as $v) {						sendmail($v['email'], L('reg_ignore'), $_POST['message']);					}				}			}			showmessage(L('ignore').L('operation_success'), HTTP_REFERER);		} else {			showmessage(L('operation_failure'), HTTP_REFERER);		}	}			/*	 * change password	 */	function _edit_password($userid, $password){		$userid = intval($userid);		if($userid < 1) return false;		if(!is_password($password))		{			showmessage(L('password_format_incorrect'));			return false;		}		$passwordinfo = password($password);		return $this->db->update($passwordinfo,array('userid'=>$userid));	}		private function _checkuserinfo($data, $is_edit=0) {		if(!is_array($data)){			showmessage(L('need_more_param'));return false;		} elseif (!is_username($data['username']) && !$is_edit){			showmessage(L('username_format_incorrect'));return false;		} elseif (!isset($data['userid']) && $is_edit) {			showmessage(L('username_format_incorrect'));return false;		}  elseif (empty($data['email']) || !is_email($data['email'])){			showmessage(L('email_format_incorrect'));return false;		}		return $data;	}			private function _checkpasswd($password){		if (!is_password($password)){			return false;		}		return true;	}		private function _checkname($username) {		$username =  trim($username);		if ($this->db->get_one(array('username'=>$username))){			return false;		}		return true;	}		/**	 *根据积分算出用户组	 * @param $point int 积分数	 */	private function _get_usergroup_bypoint($point=0) {		$groupid = 2;		if(empty($point)) {			$member_setting = getcache('member_setting');			$point = $member_setting['defualtpoint'] ? $member_setting['defualtpoint'] : 0;		}		$grouplist = getcache('grouplist');				foreach ($grouplist as $k=>$v) {			$grouppointlist[$k] = $v['point'];		}		arsort($grouppointlist);		//如果超出用户组积分设置则为积分最高的用户组		if($point > max($grouppointlist)) {			$groupid = key($grouppointlist);		} else {			foreach ($grouppointlist as $k=>$v) {				if($point >= $v) {					$groupid = $tmp_k;					break;				}				$tmp_k = $k;			}		}		return $groupid;	}		/**	 * 初始化phpsso	 * about phpsso, include client and client configure	 * @return string phpsso_api_url phpsso地址	 */	private function _init_phpsso() {		pc_base::load_app_class('client', '', 0);		define('APPID', pc_base::load_config('system', 'phpsso_appid'));		$phpsso_api_url = pc_base::load_config('system', 'phpsso_api_url');		$phpsso_auth_key = pc_base::load_config('system', 'phpsso_auth_key');		$this->client = new client($phpsso_api_url, $phpsso_auth_key);		return $phpsso_api_url;	}		/**	 * check uername status	 */	public function checkname_ajax() {		$username = isset($_GET['username']) && trim($_GET['username']) ? trim($_GET['username']) : exit(0);		$username = iconv('utf-8', CHARSET, $username);				$status = $this->client->ps_checkname($username);		if($status == -4) {	//deny_register			exit('0');		}				$status = $this->client->ps_get_member_info($username, 2);		if (is_array($status)) {			exit('0');		} else {			exit('1');		}	}		/**	 * check email status	 */	public function checkemail_ajax() {		$email = isset($_GET['email']) && trim($_GET['email']) ? trim($_GET['email']) : exit(0);				$status = $this->client->ps_checkemail($email);		if($status == -5) {	//deny_register			exit('0');		}						$status = $this->client->ps_get_member_info($email, 3);		if(isset($_GET['phpssouid']) && isset($status['uid'])) {			if ($status['uid'] == intval($_GET['phpssouid'])) {				exit('1');			}		}		if (is_array($status)) {			exit('0');		} else {			exit('1');		}	}}?>
 |