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 .
2009-08-04 20:30:39 +04:00
*
2011-02-16 03:22:22 +03:00
* Copyright ( c ) 2005 - 2011 Mibew Messenger Community
2009-08-04 19:03:27 +04:00
* All rights reserved . The contents of this file are subject to 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
2009-08-04 20:30:39 +04:00
*
2009-08-04 17:38:37 +04:00
* Alternatively , the contents of this file may be used under the terms of
* the GNU General Public License Version 2 or later ( the " GPL " ), in which case
* the provisions of the GPL are applicable instead of those above . If you wish
* to allow use of your version of this file only under the terms of the GPL , and
* not to allow others to use your version of this file under the terms of the
* EPL , indicate your decision by deleting the provisions above and replace them
* with the notice and other provisions required by the GPL .
2009-08-04 20:30:39 +04:00
*
2007-10-10 19:15:47 +04:00
* 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 ) {
2011-02-26 16:13:16 +03:00
global $mysqlprefix ;
2007-10-10 19:15:47 +04:00
$link = connect ();
$operator = select_one_row (
2011-02-26 16:13:16 +03:00
" select * from ${ mysqlprefix } chatoperator where vclogin = ' " . mysql_real_escape_string ( $login ) . " ' " , $link );
2007-10-10 19:15:47 +04:00
mysql_close ( $link );
return $operator ;
}
2009-09-01 02:43:30 +04:00
function operator_by_email ( $mail ) {
2011-02-26 16:13:16 +03:00
global $mysqlprefix ;
2009-09-01 02:43:30 +04:00
$link = connect ();
$operator = select_one_row (
2011-02-26 16:13:16 +03:00
" select * from ${ mysqlprefix } chatoperator where vcemail = ' " . mysql_real_escape_string ( $mail ) . " ' " , $link );
2009-09-01 02:43:30 +04:00
mysql_close ( $link );
return $operator ;
}
2007-10-10 19:15:47 +04:00
function operator_by_id_ ( $id , $link ) {
2011-02-26 16:13:16 +03:00
global $mysqlprefix ;
2007-10-10 19:15:47 +04:00
return select_one_row (
2011-02-26 16:13:16 +03:00
" select * from ${ mysqlprefix } chatoperator where operatorid = $id " , $link );
2007-10-10 19:15:47 +04:00
}
function operator_by_id ( $id ) {
$link = connect ();
$operator = operator_by_id_ ( $id , $link );
mysql_close ( $link );
return $operator ;
}
2011-02-21 03:02:39 +03:00
function operator_get_all () {
2011-02-26 16:13:16 +03:00
global $mysqlprefix ;
2011-02-21 03:02:39 +03:00
$link = connect ();
$query = " select operatorid, vclogin, vclocalename, vccommonname, istatus, (unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time " .
2011-02-26 16:13:16 +03:00
" from ${ mysqlprefix } chatoperator order by vclogin " ;
2011-02-21 03:02:39 +03:00
$operators = select_multi_assoc ( $query , $link );
mysql_close ( $link );
return $operators ;
}
function operator_is_online ( $operator ) {
global $settings ;
return $operator [ 'time' ] < $settings [ 'online_timeout' ];
}
function operator_is_available ( $operator ) {
global $settings ;
return $operator [ 'istatus' ] == 0 && $operator [ 'time' ] < $settings [ 'online_timeout' ] ? " 1 " : " " ;
}
function operator_is_away ( $operator ) {
global $settings ;
return $operator [ 'istatus' ] != 0 && $operator [ 'time' ] < $settings [ 'online_timeout' ] ? " 1 " : " " ;
}
2009-09-01 02:43:30 +04:00
function update_operator ( $operatorid , $login , $email , $password , $localename , $commonname ) {
2011-02-26 16:13:16 +03:00
global $mysqlprefix ;
2007-10-10 19:15:47 +04:00
$link = connect ();
$query = sprintf (
2011-02-26 16:13:16 +03:00
" update ${ mysqlprefix } chatoperator set vclogin = '%s',%s vclocalename = '%s', vccommonname = '%s' " .
2009-09-01 02:43:30 +04:00
" , vcemail = '%s', 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 ),
2009-09-01 02:43:30 +04:00
mysql_real_escape_string ( $email ),
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 ) {
2011-02-26 16:13:16 +03:00
global $mysqlprefix ;
2008-10-06 03:46:54 +04:00
$link = connect ();
$query = sprintf (
2011-02-26 16:13:16 +03:00
" update ${ mysqlprefix } chatoperator set vcavatar = '%s' where operatorid = %s " ,
2008-10-06 03:46:54 +04:00
mysql_real_escape_string ( $avatar ), $operatorid );
perform_query ( $query , $link );
mysql_close ( $link );
}
2009-09-01 02:43:30 +04:00
function create_operator_ ( $login , $email , $password , $localename , $commonname , $avatar , $link ) {
2011-02-26 16:13:16 +03:00
global $mysqlprefix ;
2007-10-10 19:15:47 +04:00
$query = sprintf (
2011-02-26 16:13:16 +03:00
" insert into ${ mysqlprefix } chatoperator (vclogin,vcpassword,vclocalename,vccommonname,vcavatar,vcemail,vcjabbername) values ('%s','%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 ),
2009-09-01 02:43:30 +04:00
mysql_real_escape_string ( $avatar ),
mysql_real_escape_string ( $email ), '' );
2007-10-10 19:15:47 +04:00
perform_query ( $query , $link );
$id = mysql_insert_id ( $link );
2011-02-26 16:13:16 +03:00
return select_one_row ( " select * from ${ mysqlprefix } chatoperator where operatorid = $id " , $link );
2007-10-17 14:43:34 +04:00
}
2009-09-01 02:43:30 +04:00
function create_operator ( $login , $email , $password , $localename , $commonname , $avatar ) {
2007-10-17 14:43:34 +04:00
$link = connect ();
2009-09-01 02:43:30 +04:00
$newop = create_operator_ ( $login , $email , $password , $localename , $commonname , $avatar , $link );
2007-10-10 19:15:47 +04:00
mysql_close ( $link );
return $newop ;
}
2009-07-24 11:37:58 +04:00
function notify_operator_alive ( $operatorid , $istatus ) {
2011-02-26 16:13:16 +03:00
global $mysqlprefix ;
2007-10-10 19:15:47 +04:00
$link = connect ();
2011-02-26 16:13:16 +03:00
perform_query ( " update ${ mysqlprefix } chatoperator set istatus = $istatus , dtmlastvisited = CURRENT_TIMESTAMP where operatorid = $operatorid " , $link );
2007-10-10 19:15:47 +04:00
mysql_close ( $link );
}
2009-06-05 03:01:17 +04:00
function has_online_operators ( $groupid = " " ) {
2011-02-26 16:13:16 +03:00
global $settings , $mysqlprefix ;
2009-01-14 01:19:12 +03:00
loadsettings ();
2007-10-10 19:15:47 +04:00
$link = connect ();
2011-02-26 16:13:16 +03:00
$query = " select count(*) as total, min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time from ${ mysqlprefix } chatoperator " ;
2009-06-05 03:01:17 +04:00
if ( $groupid ) {
2011-02-26 16:13:16 +03:00
$query .= " , ${ mysqlprefix } chatgroupoperator where groupid = $groupid and ${ mysqlprefix } chatoperator.operatorid = ${ mysqlprefix } chatgroupoperator.operatorid and istatus = 0 " ;
2009-07-24 11:37:58 +04:00
} else {
$query .= " where istatus = 0 " ;
2009-06-05 03:01:17 +04:00
}
$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
}
2011-02-26 15:24:29 +03:00
function is_operator_online ( $operatorid , $link ) {
2011-02-26 16:13:16 +03:00
global $settings , $mysqlprefix ;
2011-02-26 15:24:29 +03:00
loadsettings_ ( $link );
$query = " select count(*) as total, min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time " .
2011-02-26 16:13:16 +03:00
" from ${ mysqlprefix } chatoperator where operatorid = $operatorid " ;
2011-02-26 15:24:29 +03:00
$row = select_one_row ( $query , $link );
return $row [ 'time' ] < $settings [ 'online_timeout' ] && $row [ 'total' ] == 1 ;
}
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 " ;
}
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' ]) ) {
2009-08-25 02:06:55 +04:00
list ( $login , $pwd ) = preg_split ( " /,/ " , $_COOKIE [ 'webim_lite' ], 2 );
2007-10-10 19:15:47 +04:00
$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 ) {
2011-02-26 16:13:16 +03:00
global $page , $webimroot , $settings , $mysqlprefix ;
2009-03-29 03:51:33 +04:00
loadsettings ();
$link = connect ();
2011-02-26 16:13:16 +03:00
$operatorscount = db_rows_count ( " ${ mysqlprefix } chatoperator " , array (), " " , $link );
2009-03-29 03:51:33 +04:00
2011-02-16 03:43:19 +03:00
$groupscount = 0 ;
2011-02-26 16:13:16 +03:00
$groups = array ();
2009-03-29 03:51:33 +04:00
if ( $settings [ 'enablegroups' ] == " 1 " ) {
2011-02-16 03:43:19 +03:00
foreach ( get_groups ( $link , true ) as $group ) {
if ( $group [ 'inumofagents' ] == 0 ) {
continue ;
}
$groups [] = $group ;
}
$groupscount = count ( $groups );
2009-03-29 03:51:33 +04:00
}
2011-02-16 03:43:19 +03:00
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 " ,
2011-02-26 16:13:16 +03:00
" ${ mysqlprefix } chatoperator " , array (), " order by vclogin $limit " ), $link );
2011-02-16 03:43:19 +03:00
2011-02-26 16:13:16 +03:00
$groups = array_slice ( $groups , $p [ 'start' ], $p [ 'end' ] - $p [ 'start' ]);
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-07-24 11:37:58 +04:00
$status = $agent [ 'time' ] < $settings [ 'online_timeout' ]
? ( $agent [ 'istatus' ] == 0
? getlocal ( " char.redirect.operator.online_suff " )
: getlocal ( " char.redirect.operator.away_suff " )
)
: " " ;
2009-03-29 03:51:33 +04:00
$agent_list .= " <li><a href= \" " . add_params ( $webimroot . " /operator/redirect.php " , $params ) .
" \" title= \" " . topage ( get_operator_name ( $agent )) . " \" > " .
topage ( get_operator_name ( $agent )) .
2009-07-24 11:37:58 +04:00
" </a> $status </li> " ;
2009-03-29 03:51:33 +04:00
}
$page [ 'redirectToAgent' ] = $agent_list ;
$group_list = " " ;
if ( $settings [ 'enablegroups' ] == " 1 " ) {
$params = array ( 'thread' => $threadid , 'token' => $token );
foreach ( $groups as $group ) {
$params [ 'nextGroup' ] = $group [ 'groupid' ];
2009-07-24 11:37:58 +04:00
$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 " )
: " " );
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-24 11:37:58 +04:00
" </a> $status </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-24 11:37:58 +04:00
function get_all_groups ( $link ) {
2011-02-26 16:13:16 +03:00
global $mysqlprefix ;
$query = " select ${ mysqlprefix } chatgroup.groupid as groupid, vclocalname, vclocaldescription from ${ mysqlprefix } chatgroup order by vclocalname " ;
2009-07-24 11:37:58 +04:00
return select_multi_assoc ( $query , $link );
}
function get_groups ( $link , $checkaway ) {
2011-02-26 16:13:16 +03:00
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 " .
2009-07-24 11:37:58 +04:00
" , (SELECT min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time " .
2011-02-26 16:13:16 +03:00
" from ${ mysqlprefix } chatgroupoperator, ${ mysqlprefix } chatoperator where istatus = 0 and ${ mysqlprefix } chatgroup.groupid = ${ mysqlprefix } chatgroupoperator.groupid " .
" and ${ mysqlprefix } chatgroupoperator.operatorid = ${ mysqlprefix } chatoperator.operatorid) as ilastseen " .
2009-07-24 11:37:58 +04:00
( $checkaway
? " , (SELECT min(unix_timestamp(CURRENT_TIMESTAMP)-unix_timestamp(dtmlastvisited)) as time " .
2011-02-26 16:13:16 +03:00
" from ${ mysqlprefix } chatgroupoperator, ${ mysqlprefix } chatoperator where istatus <> 0 and ${ mysqlprefix } chatgroup.groupid = ${ mysqlprefix } chatgroupoperator.groupid " .
" and ${ mysqlprefix } chatgroupoperator.operatorid = ${ mysqlprefix } chatoperator.operatorid) as ilastseenaway "
2009-07-24 11:37:58 +04:00
: " "
) .
2011-02-26 16:13:16 +03:00
" from ${ mysqlprefix } 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 ) {
2011-02-26 16:13:16 +03:00
global $mysqlprefix ;
2009-03-23 00:22:51 +03:00
$link = connect ();
2011-02-26 16:13:16 +03:00
$query = " select groupid from ${ mysqlprefix } chatgroupoperator where operatorid = $operatorid " ;
2009-03-23 00:22:51 +03:00
$result = select_multi_assoc ( $query , $link );
mysql_close ( $link );
return $result ;
}
2009-08-04 20:30:39 +04:00
?>