138 lines
3.6 KiB
PHP
138 lines
3.6 KiB
PHP
<?php
|
|
if ( !canView( 'Stream' ) )
|
|
{
|
|
$view = "error";
|
|
return;
|
|
}
|
|
|
|
error_reporting( E_ALL );
|
|
|
|
define( "MSG_TIMEOUT", 2.0 );
|
|
define( "MSG_DATA_SIZE", 4+256 );
|
|
|
|
header("Content-type: text/plain" );
|
|
if ( !($_REQUEST['connkey'] && $_REQUEST['command']) )
|
|
{
|
|
error_log( "No connection key or command supplied" );
|
|
return;
|
|
}
|
|
|
|
if ( !($socket = socket_create( AF_UNIX, SOCK_DGRAM, 0 )) )
|
|
{
|
|
error_log( "socket_create() failed: ".socket_strerror(socket_last_error()) );
|
|
return;
|
|
}
|
|
$loc_sock_file = ZM_PATH_SOCKS.'/zms-'.sprintf("%06d",$_REQUEST['connkey']).'w.sock';
|
|
if ( !socket_bind( $socket, $loc_sock_file ) )
|
|
{
|
|
error_log( "socket_bind() failed: ".socket_strerror(socket_last_error()) );
|
|
return;
|
|
}
|
|
|
|
switch ( $_REQUEST['command'] )
|
|
{
|
|
case CMD_ZOOMIN :
|
|
error_log( "Zooming to ".$_REQUEST['x'].",".$_REQUEST['y'] );
|
|
$msg = pack( "lcnn", MSG_CMD, $_REQUEST['command'], $_REQUEST['x'], $_REQUEST['y'] );
|
|
break;
|
|
case CMD_PAN :
|
|
error_log( "Panning to ".$_REQUEST['x'].",".$_REQUEST['y'] );
|
|
$msg = pack( "lcnn", MSG_CMD, $_REQUEST['command'], $_REQUEST['x'], $_REQUEST['y'] );
|
|
break;
|
|
case CMD_SCALE :
|
|
error_log( "Scaling to ".$_REQUEST['scale'] );
|
|
$msg = pack( "lcn", MSG_CMD, $_REQUEST['command'], $_REQUEST['scale'] );
|
|
break;
|
|
case CMD_SEEK :
|
|
error_log( "Seeking to ".$_REQUEST['offset'] );
|
|
$msg = pack( "lcN", MSG_CMD, $_REQUEST['command'], $_REQUEST['offset'] );
|
|
break;
|
|
default :
|
|
$msg = pack( "lc", MSG_CMD, $_REQUEST['command'] );
|
|
break;
|
|
}
|
|
|
|
$rem_sock_file = ZM_PATH_SOCKS.'/zms-'.sprintf("%06d",$_REQUEST['connkey']).'s.sock';
|
|
if ( !socket_sendto( $socket, $msg, strlen($msg), 0, $rem_sock_file ) )
|
|
{
|
|
error_log( "socket_sendto() failed: ".socket_strerror(socket_last_error()) );
|
|
return;
|
|
}
|
|
|
|
$r_sockets = array( $socket );
|
|
$w_sockets = NULL;
|
|
$e_sockets = NULL;
|
|
$num_sockets = socket_select( $r_sockets, $w_sockets, $e_sockets, MSG_TIMEOUT );
|
|
|
|
if ( $num_sockets === false)
|
|
{
|
|
error_log( "Timed out waiting for msg" );
|
|
return;
|
|
}
|
|
else if ( $num_sockets > 0 )
|
|
{
|
|
if ( count($r_sockets) != 1 )
|
|
{
|
|
error_log( "Bogus return from select" );
|
|
return;
|
|
}
|
|
}
|
|
|
|
switch( $nbytes = socket_recvfrom( $socket, $msg, MSG_DATA_SIZE, 0, $rem_addr ) )
|
|
{
|
|
case -1 :
|
|
{
|
|
error_log( "socket_recvfrom() failed: ".socket_strerror(socket_last_error()) );
|
|
return;
|
|
}
|
|
case 0 :
|
|
{
|
|
error_log( "No data to read from socket" );
|
|
return;
|
|
}
|
|
default :
|
|
{
|
|
if ( $nbytes != MSG_DATA_SIZE )
|
|
{
|
|
error_log( "Got unexpected message size, got $nbytes, expected ".MSG_DATA_SIZE );
|
|
return;
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
$data = unpack( "ltype", $msg );
|
|
switch ( $data['type'] )
|
|
{
|
|
case MSG_DATA_WATCH :
|
|
{
|
|
$data = unpack( "ltype/dfps/istate/ilevel/Cdelayed/Cpaused/C/C/irate/ddelay/izoom", $msg );
|
|
$data['fps'] = sprintf( "%.2f", $data['fps'] );
|
|
$data['rate'] /= 100;
|
|
$data['delay'] = sprintf( "%.2f", $data['delay'] );
|
|
$data['zoom'] = sprintf( "%.1f", $data['zoom']/100 );
|
|
break;
|
|
}
|
|
case MSG_DATA_EVENT :
|
|
{
|
|
$data = unpack( "ltype/ievent/Cpaused/C/C/C/iprogress/irate/izoom", $msg );
|
|
//$data['progress'] = sprintf( "%.2f", $data['progress'] );
|
|
$data['rate'] /= 100;
|
|
$data['zoom'] = sprintf( "%.1f", $data['zoom']/100 );
|
|
break;
|
|
}
|
|
default :
|
|
{
|
|
error_log( "Unexpected received message type $type" );
|
|
return;
|
|
}
|
|
}
|
|
|
|
$response = array( 'status' => $data );
|
|
echo jsValue( $response );
|
|
|
|
socket_close( $socket );
|
|
unlink( $loc_sock_file );
|
|
|
|
?>
|