$content = ob_get_contents();
ob_end_clean();
- $s_a_p->pgflush_try_add($enc, $new_socket, 20, $header_out, $content);
+ $s_a_p->pendpage_try_addflush($enc, $new_socket, 20, $header_out, $content);
return TRUE;
break;
$content = ob_get_contents();
ob_end_clean();
- $s_a_p->pgflush_try_add($enc, $new_socket, 20, $header_out, $content);
+ $s_a_p->pendpage_try_addflush($enc, $new_socket, 20, $header_out, $content);
return TRUE;
break;
$content = User::stream_fini($transp, $s_a_p->rndstr, TRUE);
- $s_a_p->pgflush_try_add($enc, $new_socket, 20, $header_out, $content);
+ $s_a_p->pendpage_try_addflush($enc, $new_socket, 20, $header_out, $content);
return TRUE;
break;
}
// GET params management
$get_vars = explode('?', $req[1], 2);
- $path = $get_vars[0];
+ $path = $get_vars[0];
if (count($get_vars) > 1) {
$a = explode('&', $get_vars[1]);
printf("A COUNT: [%s] %d\n", $a[0], count($a));
var $unix_socket;
var $socks;
var $s2u;
- var $pages_flush;
+ var $pending_pages;
var $list;
var $in;
$thiz->debug = $debug;
$thiz->socks = array();
$thiz->s2u = array();
- $thiz->pages_flush = array();
+ $thiz->pending_pages = array();
// create a couple of sockets for control management
if (($sockpair = stream_socket_pair(STREAM_PF_UNIX, STREAM_SOCK_STREAM,
unset($this->socks[$id]);
}
- function pgflush_try_add($enc, &$new_socket, $tout, $header_out, $content)
+ function pendpage_try_addflush($enc, &$new_socket, $tout, $header_out, $content)
{
- $pgflush = new PageFlush($new_socket, $enc, $this->curtime, $tout, $header_out, $content);
+ $pgflush = PendingPage::pendingpage_flushing($new_socket, $enc, $this->curtime, $tout, $header_out, $content);
if ($pgflush->try_flush($this->curtime) == FALSE) {
// Add $pgflush to the pgflush array
function pgflush_add($pgflush)
{
- array_push($this->pages_flush, $pgflush);
+ array_push($this->pending_pages, $pgflush);
}
function garbage_manager($force)
while ($this->main_loop) {
$this->curtime = time();
- printf("IN LOOP: Current opened: %d pages_flush: %d - ", count($this->socks), count($this->pages_flush));
+ printf("IN LOOP: Current opened: %d pending_pages: %d - ", count($this->socks), count($this->pending_pages));
/* Prepare the read array */
/* // when we manage it ... */
$this->garbage_manager(FALSE);
/* manage unfinished pages */
- foreach ($this->pages_flush as $k => $pgflush) {
+ foreach ($this->pending_pages as $k => $pgflush) {
+ // TODO: try_flush if exists in the class
if ($pgflush->try_flush($this->curtime) == TRUE) {
- unset($this->pages_flush[$k]);
+ unset($this->pending_pages[$k]);
}
}
$content = ob_get_contents();
ob_end_clean();
- $s_a_p->pgflush_try_add($enc, $new_socket, 20, $header_out, $content);
+ $s_a_p->pendpage_try_addflush($enc, $new_socket, 20, $header_out, $content);
return TRUE;
break;
else {
$content = "Bin5 Load data error";
}
- $s_a_p->pgflush_try_add($enc, $new_socket, 20, $header_out, $content);
+ $s_a_p->pendpage_try_addflush($enc, $new_socket, 20, $header_out, $content);
return TRUE;
break;
|| (($user = $bri->get_user($cookie['sess'], $idx)) == FALSE)) {
$content = Bin5_user::stream_fini($transp_type, $s_a_p->rndstr, TRUE);
- $s_a_p->pgflush_try_add($enc, $new_socket, 20, $header_out, $content);
+ $s_a_p->pendpage_try_addflush($enc, $new_socket, 20, $header_out, $content);
return TRUE;
break;
$HTTP_HOST="dodo.birds.lan";
define('USOCK_PATH', "/tmp/brisk.sock");
-class PageFlush {
+define('PENDINGPAGE_WAITDATA', 0);
+define('PENDINGPAGE_FLUSHING', 1);
+
+class PendingPage {
var $socket; // socket handler of page stream
+ var $status; // status can be 0: waiting for data, 1: flush phase
+
var $kalive; // if no message are sent after RD_KEEPALIVE_TOUT secs we send a keepalive from server
var $msg; // place where store failed fwrite data
var $msg_sz; // size of content
- function PageFlush($socket, $enc, $curtime, $kalive, $header_out, $body)
+
+
+ function PendingPage($socket)
+ {
+ $this->socket = $socket;
+ }
+
+ static function pendingpage_waiting($socket, $method, $header, $get, $post, $cookie, $path, $addr)
+ {
+ $thiz = new PendingPage($socket);
+
+ // TODO
+ }
+
+ function try_wait($curtime)
+ {
+ // if completed return TRUE to allow data to be processed,
+ // if timeout or max content dimension is exceeded move to flushing
+ }
+
+ static function pendingpage_flushing($socket, $enc, $curtime, $kalive, $header_out, $body)
+ {
+ $thiz = new PendingPage($socket);
+
+ $thiz->to_flushing($enc, $curtime, $kalive, $header_out, $body);
+
+ return ($thiz);
+ }
+
+ function to_flushing($enc, $curtime, $kalive, $header_out, $body)
{
printf("TRY FLUSH CREATE\n");
$body_out = ZLibStream::compress($enc, $body);
$hea = headers_render($header_out, $body_out_sz);
$hea_sz = mb_strlen($hea, "ASCII");
- $this->socket = $socket;
+ $this->status = PENDINGPAGE_FLUSHING;
$this->kalive = $curtime + $kalive;
$this->msg = $hea.$body_out;
$this->msg_sz = $hea_sz + $body_out_sz;
/* return TRUE if is removable from it's list */
function try_flush($curtime)
{
+ if ($this->status != PENDINGPAGE_FLUSHING)
+ return (FALSE);
+
printf("TRY FLUSH IN\n");
if ($this->kalive < $curtime) {
printf("TRY FLUSH CLOSE 1\n");
$wret = @fwrite($this->socket, $this->msg);
if ($wret == FALSE && $wret !== FALSE) {
- printf("TRY FLUSH PageFlush::try_flush: wret 0 but not FALSE\n");
+ printf("TRY FLUSH PendingPage::try_flush: wret 0 but not FALSE\n");
}
if ($wret == $this->msg_sz) {
printf("TRY FLUSH CLOSE 2\n");