X-Git-Url: https://mop.ddnsfree.com/gitweb/?a=blobdiff_plain;f=web%2Fspush%2Fbrisk-spush.phh;h=3de49efa86aaa434b29e383c073cfb31a8f495af;hb=b000085f6c20397e104ae63a05a1dc9943ca9b6a;hp=f0bcfcbf7ce4feef3bc234c004e0e5456eec3992;hpb=f3ef056194d18f022f0d8fba5b5df1947a849760;p=brisk.git diff --git a/web/spush/brisk-spush.phh b/web/spush/brisk-spush.phh index f0bcfcb..3de49ef 100644 --- a/web/spush/brisk-spush.phh +++ b/web/spush/brisk-spush.phh @@ -24,30 +24,71 @@ $DOCUMENT_ROOT=""; $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, $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_sz = mb_strlen($body, "ASCII"); - // add length to header_out - $hea = headers_render($header_out, 0); + $body_out = ZLibStream::compress($enc, $body); + if ($enc != 'plain') + $header_out['Content-Encoding'] = $enc; + $body_out_sz = mb_strlen($body_out, "ASCII"); + $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; - $this->msg_sz = mb_strlen($this->msg, "ASCII"); + $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"); @@ -57,7 +98,7 @@ class PageFlush { $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");