2007-10-10 19:15:47 +04:00
|
|
|
<?php
|
|
|
|
/*
|
2009-06-04 02:44:32 +04:00
|
|
|
* This file is part of Mibew Messenger project.
|
2007-10-10 19:15:47 +04:00
|
|
|
*
|
2009-06-04 02:44:32 +04:00
|
|
|
* Copyright (c) 2005-2009 Mibew Messenger Community
|
2007-10-10 19:15:47 +04:00
|
|
|
* All rights reserved. This program and the accompanying materials
|
|
|
|
* are made available under the terms of the Eclipse Public License v1.0
|
|
|
|
* which accompanies this distribution, and is available at
|
|
|
|
* http://www.eclipse.org/legal/epl-v10.html
|
|
|
|
*
|
|
|
|
* Contributors:
|
|
|
|
* Evgeny Gryaznov - initial API and implementation
|
|
|
|
*/
|
|
|
|
|
2008-12-08 03:34:28 +03:00
|
|
|
$can_administrate = 0;
|
|
|
|
$can_takeover = 1;
|
|
|
|
$can_viewthreads = 2;
|
2009-05-31 20:13:22 +04:00
|
|
|
$can_modifyprofile = 3;
|
2008-12-08 03:34:28 +03:00
|
|
|
|
2009-05-31 20:13:22 +04:00
|
|
|
$can_count = 4;
|
2008-12-08 03:34:28 +03:00
|
|
|
|
|
|
|
$permission_ids = array(
|
|
|
|
$can_administrate => "admin",
|
|
|
|
$can_takeover => "takeover",
|
2009-05-31 20:13:22 +04:00
|
|
|
$can_viewthreads => "viewthreads",
|
|
|
|
$can_modifyprofile => "modifyprofile"
|
2008-12-08 03:34:28 +03:00
|
|
|
);
|
|
|
|
|
2007-10-10 19:15:47 +04:00
|
|
|
function operator_by_login($login) {
|
|
|
|
$link = connect();
|
|
|
|
$operator = select_one_row(
|
|
|
|
"select * from chatoperator where vclogin = '".mysql_real_escape_string($login)."'", $link );
|
|
|
|
mysql_close($link);
|
|
|
|
return $operator;
|
|
|
|
}
|
|
|
|
|
|
|
|
function operator_by_id_($id,$link) {
|
|
|
|
return select_one_row(
|
|
|
|
"select * from chatoperator where operatorid = $id", $link );
|
|
|
|
}
|
|
|
|
|
|
|
|
function operator_by_id($id) {
|
|
|
|
$link = connect();
|
|
|
|
$operator = operator_by_id_($id,$link);
|
|
|
|
mysql_close($link);
|
|
|
|
return $operator;
|
|
|
|
}
|
|
|
|
|
|
|
|
function update_operator($operatorid,$login,$password,$localename,$commonname) {
|
|
|
|
$link = connect();
|
|
|
|
$query = sprintf(
|
2008-03-05 01:22:48 +03:00
|
|
|
"update chatoperator set vclogin = '%s',%s vclocalename = '%s', vccommonname = '%s'".
|
2008-10-06 03:46:54 +04:00
|
|
|
", vcjabbername= '%s'".
|
2008-03-05 01:22:48 +03:00
|
|
|
" where operatorid = %s",
|
2007-10-10 19:15:47 +04:00
|
|
|
mysql_real_escape_string($login),
|
|
|
|
($password ? " vcpassword='".md5($password)."'," : ""),
|
|
|
|
mysql_real_escape_string($localename),
|
|
|
|
mysql_real_escape_string($commonname),
|
2008-10-06 03:46:54 +04:00
|
|
|
'',
|
2007-10-10 19:15:47 +04:00
|
|
|
$operatorid );
|
|
|
|
|
|
|
|
perform_query($query,$link);
|
|
|
|
mysql_close($link);
|
|
|
|
}
|
|
|
|
|
2008-10-06 03:46:54 +04:00
|
|
|
function update_operator_avatar($operatorid,$avatar) {
|
|
|
|
$link = connect();
|
|
|
|
$query = sprintf(
|
|
|
|
"update chatoperator set vcavatar = '%s' where operatorid = %s",
|
|
|
|
mysql_real_escape_string($avatar), $operatorid );
|
|
|
|
|
|
|
|
perform_query($query,$link);
|
|
|
|
mysql_close($link);
|
|
|
|
}
|
|
|
|
|
|
|
|
function create_operator_($login,$password,$localename,$commonname,$avatar,$link) {
|
2007-10-10 19:15:47 +04:00
|
|
|
$query = sprintf(
|
2008-10-06 03:46:54 +04:00
|
|
|
"insert into chatoperator (vclogin,vcpassword,vclocalename,vccommonname,vcavatar,vcjabbername) values ('%s','%s','%s','%s','%s','%s')",
|
2007-10-10 19:15:47 +04:00
|
|
|
mysql_real_escape_string($login),
|
|
|
|
md5($password),
|
|
|
|
mysql_real_escape_string($localename),
|
2008-10-06 03:46:54 +04:00
|
|
|
mysql_real_escape_string($commonname),
|
|
|
|
mysql_real_escape_string($avatar), '');
|
2007-10-10 19:15:47 +04:00
|
|
|
|
|
|
|
perform_query($query,$link);
|
|
|
|
$id = mysql_insert_id($link);
|
|
|
|
|
2007-10-17 14:43:34 +04:00
|
|
|
return select_one_row("select * from chatoperator where operatorid = $id", $link );
|
|
|
|
}
|
|
|
|
|
2008-10-06 03:46:54 +04:00
|
|
|
function create_operator($login,$password,$localename,$commonname,$avatar) {
|
2007-10-17 14:43:34 +04:00
|
|
|
$link = connect();
|
2008-10-06 03:46:54 +04:00
|
|
|
$newop = create_operator_($login,$password,$localename,$commonname,$avatar,$link);
|
2007-10-10 19:15:47 +04:00
|
|
|
mysql_close($link);
|
|
|
|
return $newop;
|
|
|
|
}
|
|
|
|
|
|
|
|
function notify_operator_alive($operatorid) {
|
|
|
|
$link = connect();
|
|
|
|
perform_query("update chatoperator set dtmlastvisited = CURRENT_TIMESTAMP where operatorid = $operatorid",$link);
|
|
|
|
mysql_close($link);
|
|
|
|
}
|
|
|
|
|
2009-06-05 03:01:17 +04:00
|
|
|
function has_online_operators($groupid="") {
|
2009-01-14 01:19:12 +03:00
|
|
|
global $settings;
|
|
|
|
loadsettings();
|
2007-10-10 19:15:47 +04:00
|
|
|
$link = connect();
|
2009-06-05 21:33:14 +04:00
|
|
|
$query = "select count(*) as total, min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time from chatoperator";
|
2009-06-05 03:01:17 +04:00
|
|
|
if($groupid) {
|
|
|
|
$query .= ", chatgroupoperator where groupid = $groupid and chatoperator.operatorid = chatgroupoperator.operatorid";
|
|
|
|
}
|
|
|
|
$row = select_one_row($query,$link);
|
2007-10-10 19:15:47 +04:00
|
|
|
mysql_close($link);
|
2009-06-05 21:33:14 +04:00
|
|
|
return $row['time'] < $settings['online_timeout'] && $row['total'] > 0;
|
2007-10-10 19:15:47 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
function get_operator_name($operator) {
|
|
|
|
global $home_locale, $current_locale;
|
|
|
|
if( $home_locale == $current_locale )
|
|
|
|
return $operator['vclocalename'];
|
|
|
|
else
|
|
|
|
return $operator['vccommonname'];
|
|
|
|
}
|
|
|
|
|
2009-03-25 02:34:57 +03:00
|
|
|
function append_query($link,$pv) {
|
|
|
|
$infix = '?';
|
|
|
|
if( strstr($link,$infix) !== FALSE )
|
|
|
|
$infix = '&';
|
|
|
|
return "$link$infix$pv";
|
|
|
|
}
|
|
|
|
|
|
|
|
function generate_button($title,$locale,$style,$group,$inner,$showhost,$forcesecure) {
|
|
|
|
$link = get_app_location($showhost,$forcesecure)."/client.php";
|
|
|
|
if($locale)
|
|
|
|
$link = append_query($link, "locale=$locale");
|
|
|
|
if($style)
|
|
|
|
$link = append_query($link, "style=$style");
|
|
|
|
if($group)
|
|
|
|
$link = append_query($link, "group=$group");
|
|
|
|
|
|
|
|
$jslink = append_query("'".$link,"url='+escape(document.location.href)+'&referrer='+escape(document.referrer)");
|
|
|
|
$temp = get_popup($link, "$jslink",
|
2009-02-04 02:33:30 +03:00
|
|
|
$inner, $title, "webim", "toolbar=0,scrollbars=0,location=0,status=1,menubar=0,width=640,height=480,resizable=1" );
|
2008-05-06 01:08:57 +04:00
|
|
|
return "<!-- webim button -->".$temp."<!-- / webim button -->";
|
2007-10-10 19:15:47 +04:00
|
|
|
}
|
|
|
|
|
2009-05-31 18:36:11 +04:00
|
|
|
function check_login($redirect=true) {
|
2007-10-30 15:13:04 +03:00
|
|
|
global $webimroot;
|
2007-10-10 19:15:47 +04:00
|
|
|
if( !isset( $_SESSION['operator'] ) ) {
|
|
|
|
if( isset($_COOKIE['webim_lite']) ) {
|
|
|
|
list($login,$pwd) = split(",", $_COOKIE['webim_lite'], 2);
|
|
|
|
$op = operator_by_login($login);
|
|
|
|
if( $op && isset($pwd) && isset($op['vcpassword']) && md5($op['vcpassword']) == $pwd ) {
|
|
|
|
$_SESSION['operator'] = $op;
|
|
|
|
return $op;
|
|
|
|
}
|
|
|
|
}
|
2009-02-04 02:33:30 +03:00
|
|
|
$requested = $_SERVER['PHP_SELF'];
|
|
|
|
if($_SERVER['REQUEST_METHOD'] == 'GET' && $_SERVER['QUERY_STRING']) {
|
|
|
|
$requested .= "?".$_SERVER['QUERY_STRING'];
|
|
|
|
}
|
2009-05-31 18:36:11 +04:00
|
|
|
if($redirect) {
|
|
|
|
$_SESSION['backpath'] = $requested;
|
|
|
|
header("Location: $webimroot/operator/login.php");
|
|
|
|
exit;
|
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
2007-10-10 19:15:47 +04:00
|
|
|
}
|
|
|
|
return $_SESSION['operator'];
|
|
|
|
}
|
|
|
|
|
|
|
|
function get_logged_in() {
|
|
|
|
return isset( $_SESSION['operator'] ) ? $_SESSION['operator'] : FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
function login_operator($operator,$remember) {
|
2007-10-30 15:13:04 +03:00
|
|
|
global $webimroot;
|
2007-10-10 19:15:47 +04:00
|
|
|
$_SESSION['operator'] = $operator;
|
|
|
|
if( $remember ) {
|
|
|
|
$value = $operator['vclogin'].",".md5($operator['vcpassword']);
|
2007-10-30 15:13:04 +03:00
|
|
|
setcookie('webim_lite', $value, time()+60*60*24*1000, "$webimroot/");
|
2007-10-10 19:15:47 +04:00
|
|
|
|
|
|
|
} else if( isset($_COOKIE['webim_lite']) ) {
|
2007-10-30 15:13:04 +03:00
|
|
|
setcookie('webim_lite', '', time() - 3600, "$webimroot/");
|
2007-10-10 19:15:47 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function logout_operator() {
|
2007-10-30 15:13:04 +03:00
|
|
|
global $webimroot;
|
2009-04-05 01:14:35 +04:00
|
|
|
unset($_SESSION['operator']);
|
|
|
|
unset($_SESSION['backpath']);
|
2007-10-10 19:15:47 +04:00
|
|
|
if( isset($_COOKIE['webim_lite']) ) {
|
2007-10-30 15:13:04 +03:00
|
|
|
setcookie('webim_lite', '', time() - 3600, "$webimroot/");
|
2007-10-10 19:15:47 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-03-29 03:51:33 +04:00
|
|
|
function setup_redirect_links($threadid,$token) {
|
|
|
|
global $page, $webimroot, $settings;
|
|
|
|
loadsettings();
|
|
|
|
$link = connect();
|
|
|
|
|
|
|
|
$operatorscount = rows_count($link, "chatoperator");
|
|
|
|
$groupscount = $settings['enablegroups'] == "1" ? rows_count($link, "chatgroup") : 0;
|
|
|
|
|
|
|
|
prepare_pagination(max($operatorscount,$groupscount),8);
|
|
|
|
$limit = $page['pagination']['limit'];
|
|
|
|
|
|
|
|
$query = "select operatorid, vclogin, vclocalename, vccommonname, (unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time ".
|
|
|
|
"from chatoperator order by vclogin $limit";
|
|
|
|
$operators = select_multi_assoc($query, $link);
|
|
|
|
|
|
|
|
if($settings['enablegroups'] == "1") {
|
2009-07-19 04:07:34 +04:00
|
|
|
$groups = get_groups($link, true, true);
|
2009-03-29 03:51:33 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
mysql_close($link);
|
2008-10-15 01:14:49 +04:00
|
|
|
|
|
|
|
$agent_list = "";
|
|
|
|
$params = array('thread' => $threadid, 'token' => $token);
|
2009-03-29 03:51:33 +04:00
|
|
|
foreach($operators as $agent) {
|
2008-10-15 01:14:49 +04:00
|
|
|
$params['nextAgent'] = $agent['operatorid'];
|
2009-03-29 03:51:33 +04:00
|
|
|
$online = $agent['time'] < $settings['online_timeout'] ? getlocal("char.redirect.operator.online_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> $online</li>";
|
|
|
|
}
|
|
|
|
$page['redirectToAgent'] = $agent_list;
|
|
|
|
|
|
|
|
$group_list = "";
|
|
|
|
if($settings['enablegroups'] == "1") {
|
|
|
|
$params = array('thread' => $threadid, 'token' => $token);
|
|
|
|
foreach($groups as $group) {
|
2009-07-19 04:07:34 +04:00
|
|
|
if($group['inumofagents'] == 0) {
|
|
|
|
continue;
|
|
|
|
}
|
2009-03-29 03:51:33 +04:00
|
|
|
$params['nextGroup'] = $group['groupid'];
|
2009-07-19 04:07:34 +04:00
|
|
|
$online = $group['ilastseen'] < $settings['online_timeout'] ? getlocal("char.redirect.operator.online_suff") : "";
|
2009-03-29 03:51:33 +04:00
|
|
|
$group_list .= "<li><a href=\"".add_params($webimroot."/operator/redirect.php",$params).
|
|
|
|
"\" title=\"".topage(get_group_name($group))."\">".
|
|
|
|
topage(get_group_name($group)).
|
2009-07-19 04:07:34 +04:00
|
|
|
"</a> $online</li>";
|
2009-03-29 03:51:33 +04:00
|
|
|
}
|
2008-10-15 01:14:49 +04:00
|
|
|
}
|
2009-03-29 03:51:33 +04:00
|
|
|
$page['redirectToGroup'] = $group_list;
|
2008-10-15 01:14:49 +04:00
|
|
|
}
|
|
|
|
|
2008-12-08 03:34:28 +03:00
|
|
|
$permission_list = array();
|
|
|
|
|
|
|
|
function get_permission_list() {
|
|
|
|
global $permission_list, $permission_ids;
|
|
|
|
if(count($permission_list) == 0) {
|
|
|
|
foreach($permission_ids as $permid) {
|
|
|
|
$permission_list[] = array(
|
|
|
|
'id' => $permid,
|
|
|
|
'descr' => getlocal("permission.$permid")
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $permission_list;
|
|
|
|
}
|
|
|
|
|
|
|
|
function is_capable($perm,$operator) {
|
|
|
|
$permissions = $operator && isset($operator['iperm']) ? $operator['iperm'] : 0;
|
|
|
|
return $perm >= 0 && $perm < 32 && ($permissions & (1 << $perm)) != 0;
|
|
|
|
}
|
|
|
|
|
2009-03-16 04:20:04 +03:00
|
|
|
function prepare_menu($operator,$hasright=true) {
|
|
|
|
global $page, $settings, $can_administrate;
|
|
|
|
$page['operator'] = topage(get_operator_name($operator));
|
|
|
|
if($hasright) {
|
|
|
|
loadsettings();
|
|
|
|
$page['showban'] = $settings['enableban'] == "1";
|
2009-03-23 00:22:51 +03:00
|
|
|
$page['showgroups'] = $settings['enablegroups'] == "1";
|
2009-03-22 14:54:59 +03:00
|
|
|
$page['showstat'] = $settings['enablestatistics'] == "1";
|
2009-03-16 04:20:04 +03:00
|
|
|
$page['showadmin'] = is_capable($can_administrate, $operator);
|
2009-04-10 18:12:57 +04:00
|
|
|
$page['currentopid'] = $operator['operatorid'];
|
2009-03-16 04:20:04 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-07-19 04:07:34 +04:00
|
|
|
function get_groups($link,$countagents, $checkonline=false) {
|
2009-03-25 02:34:57 +03:00
|
|
|
$query = "select chatgroup.groupid as groupid, vclocalname, vclocaldescription".
|
|
|
|
($countagents
|
|
|
|
? ", (SELECT count(*) from chatgroupoperator where chatgroup.groupid = chatgroupoperator.groupid) as inumofagents"
|
|
|
|
: "").
|
2009-07-19 04:07:34 +04:00
|
|
|
($checkonline
|
|
|
|
? ", (SELECT min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time ".
|
|
|
|
"from chatgroupoperator, chatoperator where chatgroup.groupid = chatgroupoperator.groupid ".
|
|
|
|
"and chatgroupoperator.operatorid = chatoperator.operatorid) as ilastseen"
|
|
|
|
: "").
|
|
|
|
|
2009-03-23 00:22:51 +03:00
|
|
|
" from chatgroup order by vclocalname";
|
2009-07-19 04:07:34 +04:00
|
|
|
return select_multi_assoc($query, $link);
|
2009-03-23 00:22:51 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function get_operator_groupids($operatorid) {
|
|
|
|
$link = connect();
|
|
|
|
$query = "select groupid from chatgroupoperator where operatorid = $operatorid";
|
|
|
|
$result = select_multi_assoc($query, $link);
|
|
|
|
mysql_close($link);
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2008-05-06 01:08:57 +04:00
|
|
|
?>
|