mirror of
				https://github.com/Mibew/mibew.git
				synced 2025-10-26 00:06:55 +03:00 
			
		
		
		
	use mysqlprefix in names of session vars
This commit is contained in:
		
							parent
							
								
									b18085de38
								
							
						
					
					
						commit
						e160af13ef
					
				
							
								
								
									
										70
									
								
								src/messenger/.idea/projectCodeStyle.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								src/messenger/.idea/projectCodeStyle.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,70 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <project version="4"> | ||||
|   <component name="CodeStyleSettingsManager"> | ||||
|     <option name="PER_PROJECT_SETTINGS"> | ||||
|       <value> | ||||
|         <ADDITIONAL_INDENT_OPTIONS fileType="js"> | ||||
|           <option name="INDENT_SIZE" value="4" /> | ||||
|           <option name="CONTINUATION_INDENT_SIZE" value="8" /> | ||||
|           <option name="TAB_SIZE" value="4" /> | ||||
|           <option name="USE_TAB_CHARACTER" value="false" /> | ||||
|           <option name="SMART_TABS" value="false" /> | ||||
|           <option name="LABEL_INDENT_SIZE" value="0" /> | ||||
|           <option name="LABEL_INDENT_ABSOLUTE" value="false" /> | ||||
|           <option name="USE_RELATIVE_INDENTS" value="false" /> | ||||
|         </ADDITIONAL_INDENT_OPTIONS> | ||||
|         <ADDITIONAL_INDENT_OPTIONS fileType="php"> | ||||
|           <option name="INDENT_SIZE" value="4" /> | ||||
|           <option name="CONTINUATION_INDENT_SIZE" value="8" /> | ||||
|           <option name="TAB_SIZE" value="4" /> | ||||
|           <option name="USE_TAB_CHARACTER" value="false" /> | ||||
|           <option name="SMART_TABS" value="false" /> | ||||
|           <option name="LABEL_INDENT_SIZE" value="0" /> | ||||
|           <option name="LABEL_INDENT_ABSOLUTE" value="false" /> | ||||
|           <option name="USE_RELATIVE_INDENTS" value="false" /> | ||||
|         </ADDITIONAL_INDENT_OPTIONS> | ||||
|         <ADDITIONAL_INDENT_OPTIONS fileType="sass"> | ||||
|           <option name="INDENT_SIZE" value="2" /> | ||||
|           <option name="CONTINUATION_INDENT_SIZE" value="8" /> | ||||
|           <option name="TAB_SIZE" value="4" /> | ||||
|           <option name="USE_TAB_CHARACTER" value="false" /> | ||||
|           <option name="SMART_TABS" value="false" /> | ||||
|           <option name="LABEL_INDENT_SIZE" value="0" /> | ||||
|           <option name="LABEL_INDENT_ABSOLUTE" value="false" /> | ||||
|           <option name="USE_RELATIVE_INDENTS" value="false" /> | ||||
|         </ADDITIONAL_INDENT_OPTIONS> | ||||
|         <ADDITIONAL_INDENT_OPTIONS fileType="sql"> | ||||
|           <option name="INDENT_SIZE" value="2" /> | ||||
|           <option name="CONTINUATION_INDENT_SIZE" value="8" /> | ||||
|           <option name="TAB_SIZE" value="4" /> | ||||
|           <option name="USE_TAB_CHARACTER" value="false" /> | ||||
|           <option name="SMART_TABS" value="false" /> | ||||
|           <option name="LABEL_INDENT_SIZE" value="0" /> | ||||
|           <option name="LABEL_INDENT_ABSOLUTE" value="false" /> | ||||
|           <option name="USE_RELATIVE_INDENTS" value="false" /> | ||||
|         </ADDITIONAL_INDENT_OPTIONS> | ||||
|         <ADDITIONAL_INDENT_OPTIONS fileType="xml"> | ||||
|           <option name="INDENT_SIZE" value="4" /> | ||||
|           <option name="CONTINUATION_INDENT_SIZE" value="8" /> | ||||
|           <option name="TAB_SIZE" value="4" /> | ||||
|           <option name="USE_TAB_CHARACTER" value="false" /> | ||||
|           <option name="SMART_TABS" value="false" /> | ||||
|           <option name="LABEL_INDENT_SIZE" value="0" /> | ||||
|           <option name="LABEL_INDENT_ABSOLUTE" value="false" /> | ||||
|           <option name="USE_RELATIVE_INDENTS" value="false" /> | ||||
|         </ADDITIONAL_INDENT_OPTIONS> | ||||
|         <ADDITIONAL_INDENT_OPTIONS fileType="yml"> | ||||
|           <option name="INDENT_SIZE" value="2" /> | ||||
|           <option name="CONTINUATION_INDENT_SIZE" value="8" /> | ||||
|           <option name="TAB_SIZE" value="4" /> | ||||
|           <option name="USE_TAB_CHARACTER" value="false" /> | ||||
|           <option name="SMART_TABS" value="false" /> | ||||
|           <option name="LABEL_INDENT_SIZE" value="0" /> | ||||
|           <option name="LABEL_INDENT_ABSOLUTE" value="false" /> | ||||
|           <option name="USE_RELATIVE_INDENTS" value="false" /> | ||||
|         </ADDITIONAL_INDENT_OPTIONS> | ||||
|       </value> | ||||
|     </option> | ||||
|   </component> | ||||
| </project> | ||||
| 
 | ||||
| @ -33,179 +33,197 @@ $permission_ids = array( | ||||
| 	$can_modifyprofile => "modifyprofile" | ||||
| ); | ||||
| 
 | ||||
| function operator_by_login($login) { | ||||
|     global $mysqlprefix; | ||||
| function operator_by_login($login) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$link = connect(); | ||||
| 	$operator = select_one_row( | ||||
| 		 "select * from ${mysqlprefix}chatoperator where vclogin = '".mysql_real_escape_string($login)."'", $link ); | ||||
| 		"select * from ${mysqlprefix}chatoperator where vclogin = '" . mysql_real_escape_string($login) . "'", $link); | ||||
| 	mysql_close($link); | ||||
| 	return $operator; | ||||
| } | ||||
| 
 | ||||
| function operator_by_email($mail) { | ||||
|     global $mysqlprefix; | ||||
| function operator_by_email($mail) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$link = connect(); | ||||
| 	$operator = select_one_row( | ||||
| 		 "select * from ${mysqlprefix}chatoperator where vcemail = '".mysql_real_escape_string($mail)."'", $link ); | ||||
| 		"select * from ${mysqlprefix}chatoperator where vcemail = '" . mysql_real_escape_string($mail) . "'", $link); | ||||
| 	mysql_close($link); | ||||
| 	return $operator; | ||||
| } | ||||
| 
 | ||||
| function operator_by_id_($id,$link) { | ||||
|     global $mysqlprefix; | ||||
| function operator_by_id_($id, $link) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	return select_one_row( | ||||
| 		 "select * from ${mysqlprefix}chatoperator where operatorid = $id", $link ); | ||||
| 		"select * from ${mysqlprefix}chatoperator where operatorid = $id", $link); | ||||
| } | ||||
| 
 | ||||
| function operator_by_id($id) { | ||||
| function operator_by_id($id) | ||||
| { | ||||
| 	$link = connect(); | ||||
| 	$operator = operator_by_id_($id,$link); | ||||
| 	$operator = operator_by_id_($id, $link); | ||||
| 	mysql_close($link); | ||||
| 	return $operator; | ||||
| } | ||||
| 
 | ||||
| function operator_get_all() { | ||||
|     global $mysqlprefix; | ||||
| function operator_get_all() | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$link = connect(); | ||||
| 
 | ||||
| 	$query = "select operatorid, vclogin, vclocalename, vccommonname, istatus, (unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time ". | ||||
| 	$query = "select operatorid, vclogin, vclocalename, vccommonname, istatus, (unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time " . | ||||
| 			 "from ${mysqlprefix}chatoperator order by vclogin"; | ||||
| 	$operators = select_multi_assoc($query, $link); | ||||
| 	mysql_close($link); | ||||
| 	return $operators; | ||||
| } | ||||
| 
 | ||||
| function operator_is_online($operator) { | ||||
| function operator_is_online($operator) | ||||
| { | ||||
| 	global $settings; | ||||
| 	return $operator['time'] < $settings['online_timeout']; | ||||
| } | ||||
| 
 | ||||
| function operator_is_available($operator) { | ||||
| function operator_is_available($operator) | ||||
| { | ||||
| 	global $settings; | ||||
| 	return $operator['istatus'] == 0 && $operator['time'] < $settings['online_timeout'] ? "1" : "";	 | ||||
| 	return $operator['istatus'] == 0 && $operator['time'] < $settings['online_timeout'] ? "1" : ""; | ||||
| } | ||||
| 
 | ||||
| function operator_is_away($operator) { | ||||
| function operator_is_away($operator) | ||||
| { | ||||
| 	global $settings; | ||||
| 	return $operator['istatus'] != 0 && $operator['time'] < $settings['online_timeout'] ? "1" : "";	 | ||||
| 	return $operator['istatus'] != 0 && $operator['time'] < $settings['online_timeout'] ? "1" : ""; | ||||
| } | ||||
| 
 | ||||
| function update_operator($operatorid,$login,$email,$password,$localename,$commonname) { | ||||
|     global $mysqlprefix; | ||||
| function update_operator($operatorid, $login, $email, $password, $localename, $commonname) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$link = connect(); | ||||
| 	$query = sprintf( | ||||
| 		"update ${mysqlprefix}chatoperator set vclogin = '%s',%s vclocalename = '%s', vccommonname = '%s'". | ||||
| 		", vcemail = '%s', vcjabbername= '%s'". | ||||
| 		"update ${mysqlprefix}chatoperator set vclogin = '%s',%s vclocalename = '%s', vccommonname = '%s'" . | ||||
| 		", vcemail = '%s', vcjabbername= '%s'" . | ||||
| 		" where operatorid = %s", | ||||
| 		mysql_real_escape_string($login), | ||||
| 		($password ? " vcpassword='".md5($password)."'," : ""), | ||||
| 		($password ? " vcpassword='" . md5($password) . "'," : ""), | ||||
| 		mysql_real_escape_string($localename), | ||||
| 		mysql_real_escape_string($commonname), | ||||
| 		mysql_real_escape_string($email), | ||||
| 		'', | ||||
| 		$operatorid ); | ||||
| 		$operatorid); | ||||
| 
 | ||||
| 	perform_query($query,$link); | ||||
| 	perform_query($query, $link); | ||||
| 	mysql_close($link); | ||||
| } | ||||
| 
 | ||||
| function update_operator_avatar($operatorid,$avatar) { | ||||
|     global $mysqlprefix; | ||||
| function update_operator_avatar($operatorid, $avatar) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$link = connect(); | ||||
| 	$query = sprintf( | ||||
| 		"update ${mysqlprefix}chatoperator set vcavatar = '%s' where operatorid = %s", | ||||
| 		mysql_real_escape_string($avatar), $operatorid ); | ||||
| 		mysql_real_escape_string($avatar), $operatorid); | ||||
| 
 | ||||
| 	perform_query($query,$link); | ||||
| 	perform_query($query, $link); | ||||
| 	mysql_close($link); | ||||
| } | ||||
| 
 | ||||
| function create_operator_($login,$email,$password,$localename,$commonname,$avatar,$link) { | ||||
|     global $mysqlprefix; | ||||
| function create_operator_($login, $email, $password, $localename, $commonname, $avatar, $link) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$query = sprintf( | ||||
| 		"insert into ${mysqlprefix}chatoperator (vclogin,vcpassword,vclocalename,vccommonname,vcavatar,vcemail,vcjabbername) values ('%s','%s','%s','%s','%s','%s','%s')", | ||||
| 			mysql_real_escape_string($login), | ||||
| 			md5($password), | ||||
| 			mysql_real_escape_string($localename), | ||||
| 			mysql_real_escape_string($commonname), | ||||
| 			mysql_real_escape_string($avatar), | ||||
| 			mysql_real_escape_string($email), ''); | ||||
| 		mysql_real_escape_string($login), | ||||
| 		md5($password), | ||||
| 		mysql_real_escape_string($localename), | ||||
| 		mysql_real_escape_string($commonname), | ||||
| 		mysql_real_escape_string($avatar), | ||||
| 		mysql_real_escape_string($email), ''); | ||||
| 
 | ||||
| 	perform_query($query,$link); | ||||
| 	perform_query($query, $link); | ||||
| 	$id = mysql_insert_id($link); | ||||
| 
 | ||||
| 	return select_one_row("select * from ${mysqlprefix}chatoperator where operatorid = $id", $link ); | ||||
| 	return select_one_row("select * from ${mysqlprefix}chatoperator where operatorid = $id", $link); | ||||
| } | ||||
| 
 | ||||
| function create_operator($login,$email,$password,$localename,$commonname,$avatar) { | ||||
| function create_operator($login, $email, $password, $localename, $commonname, $avatar) | ||||
| { | ||||
| 	$link = connect(); | ||||
| 	$newop = create_operator_($login,$email,$password,$localename,$commonname,$avatar,$link); | ||||
| 	$newop = create_operator_($login, $email, $password, $localename, $commonname, $avatar, $link); | ||||
| 	mysql_close($link); | ||||
| 	return $newop; | ||||
| } | ||||
| 
 | ||||
| function notify_operator_alive($operatorid, $istatus) { | ||||
|     global $mysqlprefix; | ||||
| function notify_operator_alive($operatorid, $istatus) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$link = connect(); | ||||
| 	perform_query("update ${mysqlprefix}chatoperator set istatus = $istatus, dtmlastvisited = CURRENT_TIMESTAMP where operatorid = $operatorid",$link); | ||||
| 	perform_query("update ${mysqlprefix}chatoperator set istatus = $istatus, dtmlastvisited = CURRENT_TIMESTAMP where operatorid = $operatorid", $link); | ||||
| 	mysql_close($link); | ||||
| } | ||||
| 
 | ||||
| function has_online_operators($groupid="") { | ||||
| function has_online_operators($groupid = "") | ||||
| { | ||||
| 	global $settings, $mysqlprefix; | ||||
| 	loadsettings(); | ||||
| 	$link = connect(); | ||||
| 	$query = "select count(*) as total, min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time from ${mysqlprefix}chatoperator"; | ||||
| 	if($groupid) { | ||||
| 	if ($groupid) { | ||||
| 		$query .= ", ${mysqlprefix}chatgroupoperator where groupid = $groupid and ${mysqlprefix}chatoperator.operatorid = ${mysqlprefix}chatgroupoperator.operatorid and istatus = 0"; | ||||
| 	} else { | ||||
| 		$query .= " where istatus = 0"; | ||||
| 	} | ||||
| 	$row = select_one_row($query,$link); | ||||
| 	$row = select_one_row($query, $link); | ||||
| 	mysql_close($link); | ||||
| 	return $row['time'] < $settings['online_timeout'] && $row['total'] > 0; | ||||
| } | ||||
| 
 | ||||
| function is_operator_online($operatorid, $link) { | ||||
| function is_operator_online($operatorid, $link) | ||||
| { | ||||
| 	global $settings, $mysqlprefix; | ||||
| 	loadsettings_($link); | ||||
| 	$query = "select count(*) as total, min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time ". | ||||
| 	$query = "select count(*) as total, min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time " . | ||||
| 			 "from ${mysqlprefix}chatoperator where operatorid = $operatorid"; | ||||
| 	$row = select_one_row($query,$link); | ||||
| 	$row = select_one_row($query, $link); | ||||
| 	return $row['time'] < $settings['online_timeout'] && $row['total'] == 1; | ||||
| } | ||||
| 
 | ||||
| function get_operator_name($operator) { | ||||
| function get_operator_name($operator) | ||||
| { | ||||
| 	global $home_locale, $current_locale; | ||||
| 	if( $home_locale == $current_locale ) | ||||
| 	if ($home_locale == $current_locale) | ||||
| 		return $operator['vclocalename']; | ||||
| 	else | ||||
| 		return $operator['vccommonname']; | ||||
| } | ||||
| 
 | ||||
| function append_query($link,$pv) { | ||||
| function append_query($link, $pv) | ||||
| { | ||||
| 	$infix = '?'; | ||||
| 	if( strstr($link,$infix) !== FALSE ) | ||||
| 	if (strstr($link, $infix) !== FALSE) | ||||
| 		$infix = '&'; | ||||
| 	return "$link$infix$pv"; | ||||
| } | ||||
| 
 | ||||
| function check_login($redirect=true) { | ||||
| 	global $webimroot; | ||||
| 	if( !isset( $_SESSION['operator'] ) ) { | ||||
| 		if( isset($_COOKIE['webim_lite']) ) { | ||||
| 			list($login,$pwd) = preg_split("/,/", $_COOKIE['webim_lite'], 2); | ||||
| function check_login($redirect = true) | ||||
| { | ||||
| 	global $webimroot, $mysqlprefix; | ||||
| 	if (!isset($_SESSION["${mysqlprefix}operator"])) { | ||||
| 		if (isset($_COOKIE['webim_lite'])) { | ||||
| 			list($login, $pwd) = preg_split("/,/", $_COOKIE['webim_lite'], 2); | ||||
| 			$op = operator_by_login($login); | ||||
| 			if( $op && isset($pwd) && isset($op['vcpassword']) && md5($op['vcpassword']) == $pwd ) { | ||||
| 				$_SESSION['operator'] = $op; | ||||
| 			if ($op && isset($pwd) && isset($op['vcpassword']) && md5($op['vcpassword']) == $pwd) { | ||||
| 				$_SESSION["${mysqlprefix}operator"] = $op; | ||||
| 				return $op; | ||||
| 			} | ||||
| 		} | ||||
| 		$requested = $_SERVER['PHP_SELF']; | ||||
| 		if($_SERVER['REQUEST_METHOD'] == 'GET' && $_SERVER['QUERY_STRING']) { | ||||
| 			$requested .= "?".$_SERVER['QUERY_STRING']; | ||||
| 		if ($_SERVER['REQUEST_METHOD'] == 'GET' && $_SERVER['QUERY_STRING']) { | ||||
| 			$requested .= "?" . $_SERVER['QUERY_STRING']; | ||||
| 		} | ||||
| 		if($redirect) { | ||||
| 		if ($redirect) { | ||||
| 			$_SESSION['backpath'] = $requested; | ||||
| 			header("Location: $webimroot/operator/login.php"); | ||||
| 			exit; | ||||
| @ -213,35 +231,40 @@ function check_login($redirect=true) { | ||||
| 			return null; | ||||
| 		} | ||||
| 	} | ||||
| 	return $_SESSION['operator']; | ||||
| 	return $_SESSION["${mysqlprefix}operator"]; | ||||
| } | ||||
| 
 | ||||
| function get_logged_in() { | ||||
| 	return isset( $_SESSION['operator'] ) ? $_SESSION['operator'] : FALSE; | ||||
| function get_logged_in() | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	return isset($_SESSION["${mysqlprefix}operator"]) ? $_SESSION["${mysqlprefix}operator"] : FALSE; | ||||
| } | ||||
| 
 | ||||
| function login_operator($operator,$remember) { | ||||
| 	global $webimroot; | ||||
| 	$_SESSION['operator'] = $operator; | ||||
| 	if( $remember ) { | ||||
| 		$value = $operator['vclogin'].",".md5($operator['vcpassword']); | ||||
| 		setcookie('webim_lite', $value, time()+60*60*24*1000, "$webimroot/"); | ||||
| function login_operator($operator, $remember) | ||||
| { | ||||
| 	global $webimroot, $mysqlprefix; | ||||
| 	$_SESSION["${mysqlprefix}operator"] = $operator; | ||||
| 	if ($remember) { | ||||
| 		$value = $operator['vclogin'] . "," . md5($operator['vcpassword']); | ||||
| 		setcookie('webim_lite', $value, time() + 60 * 60 * 24 * 1000, "$webimroot/"); | ||||
| 
 | ||||
| 	} else if( isset($_COOKIE['webim_lite']) ) { | ||||
| 	} else if (isset($_COOKIE['webim_lite'])) { | ||||
| 		setcookie('webim_lite', '', time() - 3600, "$webimroot/"); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| function logout_operator() { | ||||
| 	global $webimroot; | ||||
| 	unset($_SESSION['operator']); | ||||
| function logout_operator() | ||||
| { | ||||
| 	global $webimroot, $mysqlprefix; | ||||
| 	unset($_SESSION["${mysqlprefix}operator"]); | ||||
| 	unset($_SESSION['backpath']); | ||||
| 	if( isset($_COOKIE['webim_lite']) ) { | ||||
| 	if (isset($_COOKIE['webim_lite'])) { | ||||
| 		setcookie('webim_lite', '', time() - 3600, "$webimroot/"); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| function setup_redirect_links($threadid,$token) { | ||||
| function setup_redirect_links($threadid, $token) | ||||
| { | ||||
| 	global $page, $webimroot, $settings, $mysqlprefix; | ||||
| 	loadsettings(); | ||||
| 	$link = connect(); | ||||
| @ -249,59 +272,59 @@ function setup_redirect_links($threadid,$token) { | ||||
| 	$operatorscount = db_rows_count("${mysqlprefix}chatoperator", array(), "", $link); | ||||
| 
 | ||||
| 	$groupscount = 0; | ||||
|     $groups = array(); | ||||
| 	if($settings['enablegroups'] == "1") { | ||||
| 		foreach(get_groups($link, true) as $group) { | ||||
| 			if($group['inumofagents'] == 0) { | ||||
| 	$groups = array(); | ||||
| 	if ($settings['enablegroups'] == "1") { | ||||
| 		foreach (get_groups($link, true) as $group) { | ||||
| 			if ($group['inumofagents'] == 0) { | ||||
| 				continue; | ||||
| 			} | ||||
| 			$groups[] = $group; | ||||
| 		} | ||||
| 		$groupscount = count($groups); | ||||
| 	} | ||||
| 	 | ||||
| 	prepare_pagination(max($operatorscount,$groupscount),8); | ||||
| 
 | ||||
| 	prepare_pagination(max($operatorscount, $groupscount), 8); | ||||
| 	$p = $page['pagination']; | ||||
| 	$limit = $p['limit']; | ||||
| 
 | ||||
| 	$operators = select_multi_assoc(db_build_select( | ||||
| 		"operatorid, vclogin, vclocalename, vccommonname, istatus, (unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time", | ||||
| 		"${mysqlprefix}chatoperator", array(), "order by vclogin $limit"), $link); | ||||
| 	 | ||||
|    	$groups = array_slice($groups, $p['start'], $p['end']-$p['start']); | ||||
| 										"operatorid, vclogin, vclocalename, vccommonname, istatus, (unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time", | ||||
| 										"${mysqlprefix}chatoperator", array(), "order by vclogin $limit"), $link); | ||||
| 
 | ||||
| 	$groups = array_slice($groups, $p['start'], $p['end'] - $p['start']); | ||||
| 	mysql_close($link); | ||||
| 
 | ||||
| 	$agent_list = ""; | ||||
| 	$params = array('thread' => $threadid, 'token' => $token); | ||||
| 	foreach($operators as $agent) { | ||||
| 	foreach ($operators as $agent) { | ||||
| 		$params['nextAgent'] = $agent['operatorid']; | ||||
| 		$status = $agent['time'] < $settings['online_timeout'] | ||||
| 			? ($agent['istatus'] == 0 | ||||
| 				? getlocal("char.redirect.operator.online_suff") | ||||
| 				: getlocal("char.redirect.operator.away_suff") | ||||
| 			)  | ||||
| 			: ""; | ||||
| 		$agent_list .= "<li><a href=\"".add_params($webimroot."/operator/redirect.php",$params). | ||||
| 						"\" title=\"".topage(get_operator_name($agent))."\">". | ||||
| 						    topage(get_operator_name($agent)). | ||||
| 						"</a> $status</li>"; | ||||
| 				? ($agent['istatus'] == 0 | ||||
| 						? getlocal("char.redirect.operator.online_suff") | ||||
| 						: getlocal("char.redirect.operator.away_suff") | ||||
| 				) | ||||
| 				: ""; | ||||
| 		$agent_list .= "<li><a href=\"" . add_params($webimroot . "/operator/redirect.php", $params) . | ||||
| 					   "\" title=\"" . topage(get_operator_name($agent)) . "\">" . | ||||
| 					   topage(get_operator_name($agent)) . | ||||
| 					   "</a> $status</li>"; | ||||
| 	} | ||||
| 	$page['redirectToAgent'] = $agent_list; | ||||
| 
 | ||||
| 	$group_list = ""; | ||||
| 	if($settings['enablegroups'] == "1") { | ||||
| 	if ($settings['enablegroups'] == "1") { | ||||
| 		$params = array('thread' => $threadid, 'token' => $token); | ||||
| 		foreach($groups as $group) { | ||||
| 		foreach ($groups as $group) { | ||||
| 			$params['nextGroup'] = $group['groupid']; | ||||
| 			$status = $group['ilastseen'] !== NULL && $group['ilastseen'] < $settings['online_timeout']  | ||||
| 					? getlocal("char.redirect.operator.online_suff")  | ||||
| 			$status = $group['ilastseen'] !== NULL && $group['ilastseen'] < $settings['online_timeout'] | ||||
| 					? getlocal("char.redirect.operator.online_suff") | ||||
| 					: ($group['ilastseenaway'] !== NULL && $group['ilastseenaway'] < $settings['online_timeout'] | ||||
| 						? getlocal("char.redirect.operator.away_suff") | ||||
| 						: ""); | ||||
| 			$group_list .= "<li><a href=\"".add_params($webimroot."/operator/redirect.php",$params). | ||||
| 								"\" title=\"".topage(get_group_name($group))."\">". | ||||
| 								topage(get_group_name($group)). | ||||
| 							"</a> $status</li>"; | ||||
| 							? getlocal("char.redirect.operator.away_suff") | ||||
| 							: ""); | ||||
| 			$group_list .= "<li><a href=\"" . add_params($webimroot . "/operator/redirect.php", $params) . | ||||
| 						   "\" title=\"" . topage(get_group_name($group)) . "\">" . | ||||
| 						   topage(get_group_name($group)) . | ||||
| 						   "</a> $status</li>"; | ||||
| 		} | ||||
| 	} | ||||
| 	$page['redirectToGroup'] = $group_list; | ||||
| @ -309,10 +332,11 @@ function setup_redirect_links($threadid,$token) { | ||||
| 
 | ||||
| $permission_list = array(); | ||||
| 
 | ||||
| function get_permission_list() { | ||||
| function get_permission_list() | ||||
| { | ||||
| 	global $permission_list, $permission_ids; | ||||
| 	if(count($permission_list) == 0) { | ||||
| 		foreach($permission_ids as $permid) { | ||||
| 	if (count($permission_list) == 0) { | ||||
| 		foreach ($permission_ids as $permid) { | ||||
| 			$permission_list[] = array( | ||||
| 				'id' => $permid, | ||||
| 				'descr' => getlocal("permission.$permid") | ||||
| @ -322,15 +346,17 @@ function get_permission_list() { | ||||
| 	return $permission_list; | ||||
| } | ||||
| 
 | ||||
| function is_capable($perm,$operator) { | ||||
| function is_capable($perm, $operator) | ||||
| { | ||||
| 	$permissions = $operator && isset($operator['iperm']) ? $operator['iperm'] : 0; | ||||
| 	return $perm >= 0 && $perm < 32 && ($permissions & (1 << $perm)) != 0; | ||||
| } | ||||
| 
 | ||||
| function prepare_menu($operator,$hasright=true) { | ||||
| function prepare_menu($operator, $hasright = true) | ||||
| { | ||||
| 	global $page, $settings, $can_administrate; | ||||
| 	$page['operator'] = topage(get_operator_name($operator)); | ||||
| 	if($hasright) { | ||||
| 	if ($hasright) { | ||||
| 		loadsettings(); | ||||
| 		$page['showban'] = $settings['enableban'] == "1"; | ||||
| 		$page['showgroups'] = $settings['enablegroups'] == "1"; | ||||
| @ -340,31 +366,34 @@ function prepare_menu($operator,$hasright=true) { | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| function get_all_groups($link) { | ||||
|     global $mysqlprefix; | ||||
| function get_all_groups($link) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$query = "select ${mysqlprefix}chatgroup.groupid as groupid, vclocalname, vclocaldescription from ${mysqlprefix}chatgroup order by vclocalname"; | ||||
| 	return select_multi_assoc($query, $link); | ||||
| } | ||||
| 
 | ||||
| function get_groups($link,$checkaway) { | ||||
|     global $mysqlprefix; | ||||
| 	$query = "select ${mysqlprefix}chatgroup.groupid as groupid, vclocalname, vclocaldescription". | ||||
| 			", (SELECT count(*) from ${mysqlprefix}chatgroupoperator where ${mysqlprefix}chatgroup.groupid = ${mysqlprefix}chatgroupoperator.groupid) as inumofagents". | ||||
| 			", (SELECT min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time ". | ||||
| 					"from ${mysqlprefix}chatgroupoperator, ${mysqlprefix}chatoperator where istatus = 0 and ${mysqlprefix}chatgroup.groupid = ${mysqlprefix}chatgroupoperator.groupid ". | ||||
| 					"and ${mysqlprefix}chatgroupoperator.operatorid = ${mysqlprefix}chatoperator.operatorid) as ilastseen". | ||||
| 			($checkaway | ||||
| 				 ? ", (SELECT min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time ". | ||||
| 						"from ${mysqlprefix}chatgroupoperator, ${mysqlprefix}chatoperator where istatus <> 0 and ${mysqlprefix}chatgroup.groupid = ${mysqlprefix}chatgroupoperator.groupid ". | ||||
| 						"and ${mysqlprefix}chatgroupoperator.operatorid = ${mysqlprefix}chatoperator.operatorid) as ilastseenaway" | ||||
| 				 : "" | ||||
| 			 ). | ||||
| function get_groups($link, $checkaway) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$query = "select ${mysqlprefix}chatgroup.groupid as groupid, vclocalname, vclocaldescription" . | ||||
| 			 ", (SELECT count(*) from ${mysqlprefix}chatgroupoperator where ${mysqlprefix}chatgroup.groupid = ${mysqlprefix}chatgroupoperator.groupid) as inumofagents" . | ||||
| 			 ", (SELECT min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time " . | ||||
| 			 "from ${mysqlprefix}chatgroupoperator, ${mysqlprefix}chatoperator where istatus = 0 and ${mysqlprefix}chatgroup.groupid = ${mysqlprefix}chatgroupoperator.groupid " . | ||||
| 			 "and ${mysqlprefix}chatgroupoperator.operatorid = ${mysqlprefix}chatoperator.operatorid) as ilastseen" . | ||||
| 			 ($checkaway | ||||
| 					 ? ", (SELECT min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time " . | ||||
| 					   "from ${mysqlprefix}chatgroupoperator, ${mysqlprefix}chatoperator where istatus <> 0 and ${mysqlprefix}chatgroup.groupid = ${mysqlprefix}chatgroupoperator.groupid " . | ||||
| 					   "and ${mysqlprefix}chatgroupoperator.operatorid = ${mysqlprefix}chatoperator.operatorid) as ilastseenaway" | ||||
| 					 : "" | ||||
| 			 ) . | ||||
| 			 " from ${mysqlprefix}chatgroup order by vclocalname"; | ||||
| 	return select_multi_assoc($query, $link); | ||||
| } | ||||
| 
 | ||||
| function get_operator_groupids($operatorid) { | ||||
|     global $mysqlprefix; | ||||
| function get_operator_groupids($operatorid) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$link = connect(); | ||||
| 	$query = "select groupid from ${mysqlprefix}chatgroupoperator where operatorid = $operatorid"; | ||||
| 	$result = select_multi_assoc($query, $link); | ||||
|  | ||||
| @ -77,8 +77,8 @@ if( !$op ) { | ||||
| 	if(count($errors) == 0) { | ||||
| 		update_operator_avatar($op['operatorid'],$avatar); | ||||
| 
 | ||||
| 		if ($opId && $avatar && $_SESSION['operator'] && $operator['operatorid'] == $opId) { | ||||
| 			$_SESSION['operator']['vcavatar'] = $avatar; | ||||
| 		if ($opId && $avatar && $_SESSION["${mysqlprefix}operator"] && $operator['operatorid'] == $opId) { | ||||
| 			$_SESSION["${mysqlprefix}operator"]['vcavatar'] = $avatar; | ||||
| 		} | ||||
| 		header("Location: $webimroot/operator/avatar.php?op=$opId"); | ||||
| 		exit; | ||||
|  | ||||
| @ -25,45 +25,46 @@ require_once('../libs/operator_settings.php'); | ||||
| 
 | ||||
| $operator = check_login(); | ||||
| 
 | ||||
| function update_operator_permissions($operatorid,$newvalue) { | ||||
|     global $mysqlprefix; | ||||
| function update_operator_permissions($operatorid, $newvalue) | ||||
| { | ||||
| 	global $mysqlprefix; | ||||
| 	$link = connect(); | ||||
| 	$query = "update ${mysqlprefix}chatoperator set iperm = $newvalue where operatorid = $operatorid"; | ||||
| 
 | ||||
| 	perform_query($query,$link); | ||||
| 	perform_query($query, $link); | ||||
| 	mysql_close($link); | ||||
| } | ||||
| 
 | ||||
| $opId = verifyparam( "op","/^\d{1,9}$/"); | ||||
| $opId = verifyparam("op", "/^\d{1,9}$/"); | ||||
| $page = array('opid' => $opId, 'canmodify' => is_capable($can_administrate, $operator) ? "1" : ""); | ||||
| $errors = array(); | ||||
| 
 | ||||
| $op = operator_by_id($opId); | ||||
| 
 | ||||
| if( !$op ) { | ||||
| if (!$op) { | ||||
| 	$errors[] = getlocal("no_such_operator"); | ||||
| 
 | ||||
| } else if( isset($_POST['op']) ) { | ||||
| } else if (isset($_POST['op'])) { | ||||
| 
 | ||||
| 	if(!is_capable($can_administrate, $operator)) { | ||||
| 	if (!is_capable($can_administrate, $operator)) { | ||||
| 		$errors[] = getlocal('page_agent.cannot_modify'); | ||||
| 	} | ||||
| 
 | ||||
| 	$new_permissions = isset($op['iperm']) ? $op['iperm'] : 0; | ||||
| 
 | ||||
| 	foreach($permission_ids as $perm => $id) { | ||||
| 		if( verifyparam("permissions$id","/^on$/", "") == "on") { | ||||
| 	foreach ($permission_ids as $perm => $id) { | ||||
| 		if (verifyparam("permissions$id", "/^on$/", "") == "on") { | ||||
| 			$new_permissions |= (1 << $perm); | ||||
| 		} else { | ||||
| 			$new_permissions &= ~ (1 << $perm); | ||||
| 			$new_permissions &= ~(1 << $perm); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	if(count($errors) == 0) { | ||||
| 		update_operator_permissions($op['operatorid'],$new_permissions); | ||||
| 	if (count($errors) == 0) { | ||||
| 		update_operator_permissions($op['operatorid'], $new_permissions); | ||||
| 
 | ||||
| 		if ($opId && $_SESSION['operator'] && $operator['operatorid'] == $opId) { | ||||
| 			$_SESSION['operator']['iperm'] = $new_permissions; | ||||
| 		if ($opId && $_SESSION["${mysqlprefix}operator"] && $operator['operatorid'] == $opId) { | ||||
| 			$_SESSION["${mysqlprefix}operator"]['iperm'] = $new_permissions; | ||||
| 		} | ||||
| 		header("Location: $webimroot/operator/permissions.php?op=$opId&stored"); | ||||
| 		exit; | ||||
| @ -73,11 +74,11 @@ if( !$op ) { | ||||
| 
 | ||||
| $page['permissionsList'] = get_permission_list(); | ||||
| $page['formpermissions'] = array(""); | ||||
| $page['currentop'] = $op ? topage(get_operator_name($op))." (".$op['vclogin'].")" : "-not found-"; | ||||
| $page['currentop'] = $op ? topage(get_operator_name($op)) . " (" . $op['vclogin'] . ")" : "-not found-"; | ||||
| 
 | ||||
| if($op) { | ||||
| 	foreach($permission_ids as $perm => $id) { | ||||
| 		if(is_capable($perm,$op)) { | ||||
| if ($op) { | ||||
| 	foreach ($permission_ids as $perm => $id) { | ||||
| 		if (is_capable($perm, $op)) { | ||||
| 			$page['formpermissions'][] = $id; | ||||
| 		} | ||||
| 	} | ||||
| @ -85,7 +86,7 @@ if($op) { | ||||
| 
 | ||||
| $page['stored'] = isset($_GET['stored']); | ||||
| prepare_menu($operator); | ||||
| setup_operator_settings_tabs($opId,3); | ||||
| setup_operator_settings_tabs($opId, 3); | ||||
| start_html_output(); | ||||
| require('../view/permissions.php'); | ||||
| ?>
 | ||||
| @ -23,6 +23,7 @@ require_once('../libs/common.php'); | ||||
| require_once('../libs/chat.php'); | ||||
| require_once('../libs/userinfo.php'); | ||||
| require_once('../libs/operator.php'); | ||||
| require_once('../libs/groups.php'); | ||||
| 
 | ||||
| $operator = get_logged_in(); | ||||
| if( !$operator ) { | ||||
| @ -167,8 +168,13 @@ $since = verifyparam( "since", "/^\d{1,9}$/", 0); | ||||
| $status = verifyparam( "status", "/^\d{1,2}$/", 0); | ||||
| $showonline = verifyparam( "showonline", "/^1$/", 0); | ||||
| 
 | ||||
| loadsettings(); | ||||
| $groupids = $_SESSION['operatorgroups']; | ||||
| $link = connect(); | ||||
| loadsettings_($link); | ||||
| if(!isset($_SESSION['operatorgroups'])) { | ||||
| 	$_SESSION["${mysqlprefix}operatorgroups"] = get_operator_groupslist($operator['operatorid'], $link); | ||||
| } | ||||
| mysql_close($link); | ||||
| $groupids = $_SESSION["${mysqlprefix}operatorgroups"]; | ||||
| 
 | ||||
| start_xml_output(); | ||||
| echo '<update>'; | ||||
|  | ||||
| @ -30,7 +30,7 @@ notify_operator_alive($operator['operatorid'], $status); | ||||
| 
 | ||||
| $link = connect(); | ||||
| loadsettings_($link); | ||||
| $_SESSION['operatorgroups'] = get_operator_groupslist($operator['operatorid'], $link); | ||||
| $_SESSION["${mysqlprefix}operatorgroups"] = get_operator_groupslist($operator['operatorid'], $link); | ||||
| mysql_close($link); | ||||
| 
 | ||||
| $page = array(); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user