".myiconv($webim_encoding,"utf-8",escape_with_cdata(getstring("agent.not_logged_in")))."";
	exit;
}
$threadstate_to_string = array(
	$state_queue => "wait",
	$state_waiting => "prio",
	$state_chatting => "chat",
	$state_closed => "closed"
);
$threadstate_key = array(
	$state_queue => "chat.thread.state_wait",
	$state_waiting => "chat.thread.state_wait_for_another_agent",
	$state_chatting => "chat.thread.state_chatting_with_agent",
	$state_closed => "chat.thread.state_closed"
);
function thread_to_xml($thread) {
	global $threadstate_to_string, $threadstate_key;
	$state = $threadstate_to_string[$thread['istate']];
	$result = "";
	$state = getstring($threadstate_key[$thread['istate']]);
	$result .= " canopen=\"true\" state=\"$state\">";
	$result .= "".htmlspecialchars($thread['userName'])."";
	$result .= "".htmlspecialchars($thread['remote'])."";
	$result .= "".htmlspecialchars($thread['agentName'] ? $thread['agentName'] : "-")."";
	$result .= "";
	$result .= "".$thread['unix_timestamp(dtmmodified)']."000";
	$result .= "";
	return $result;
}
function print_pending_threads($since) {
	global $webim_encoding;
	$link = connect();
	$revision = $since;
	$output = array();
	$query = "select threadid, userName, agentName, unix_timestamp(dtmcreated), unix_timestamp(dtmmodified), lrevision, istate, remote from chatthread where lrevision > $since ORDER BY threadid";
	$result = mysql_query($query,$link) or die(' Query failed: ' .mysql_error().": ".$query);
	while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) {
		$thread = thread_to_xml($row);
		$output[] = $thread;
		if( $row['lrevision'] > $revision )
			$revision = $row['lrevision'];
	}
	mysql_free_result($result);
	mysql_close($link);
	start_xml_output();
	echo "";
	foreach( $output as $thr ) {
		print myiconv($webim_encoding,"utf-8",$thr);
	}
	echo "";
}
////////
$since = verifyparam( "since", "/^\d{1,9}$/", 0);
print_pending_threads($since);
notify_operator_alive($operator['operatorid']);
exit;
?>