}
// POST params management
if ($req[0] == 'POST') {
+ $conttype_all = explode(";", $header['Content-Type']);
+ $header['Content-Type'] = $conttype_all[0];
+ // $path_all[1-] other things like charset and so on
+
if ($header['Content-Type'] != 'application/x-www-form-urlencoded'
|| !isset($header['Content-Length'])) {
return FALSE;
}
- $post_len = mb_strlen($line, "latin1");
+ $post_len = mb_strlen($line, "ASCII");
$a = explode('&', $line);
for ($i = 0 ; $i < count($a) ; $i++) {
$b = explode('=', $a[$i]);
var $file_socket;
var $unix_socket;
var $socks;
- var $s2u;
+ var $s2u; // user associated with input socket
+ var $s2p; // pending page associated with input socket
var $pending_pages;
var $list;
$thiz->debug = $debug;
$thiz->socks = array();
$thiz->s2u = array();
+ $thiz->s2p = array();
$thiz->pending_pages = array();
// create a couple of sockets for control management
return ($thiz);
}
- function socks_set($sock, $user)
+ function socks_set($sock, $user, $pendpage)
{
$id = intval($sock);
- $this->s2u[$id] = $user;
$this->socks[$id] = $sock;
+ if ($user != NULL)
+ $this->s2u[$id] = $user;
+ if ($pendpage != NULL)
+ $this->s2p[$id] = $pendpage;
}
function socks_unset($sock)
{
$id = intval($sock);
- unset($this->s2u[$id]);
+ if (isset($this->s2u[$id]))
+ unset($this->s2u[$id]);
+ if (isset($this->s2p[$id]))
+ unset($this->s2p[$id]);
unset($this->socks[$id]);
}
- function pendpage_try_addflush($enc, &$new_socket, $tout, $header_out, $content)
+ function pendpage_try_addflush(&$new_socket, $tout, $enc, $header_out, $content)
{
- $pgflush = PendingPage::pendingpage_flushing($new_socket, $enc, $this->curtime, $tout, $header_out, $content);
+ $pendpage = PendingPage::pendingpage_flushing($new_socket, $this->curtime, $tout, $enc, $header_out, $content);
- if ($pgflush->try_flush($this->curtime) == FALSE) {
- // Add $pgflush to the pgflush array
- $this->pgflush_add($pgflush);
+ if ($pendpage->try_flush($this->curtime) == FALSE) {
+ // Add $pendpage to the pendpage array
+ $this->pendpage_add($pendpage);
}
}
- function pgflush_add($pgflush)
+ function pendpage_add($pendpage)
{
- array_push($this->pending_pages, $pgflush);
+ array_push($this->pending_pages, $pendpage);
}
function garbage_manager($force)
$this->app->garbage_manager($force);
foreach ($this->socks as $k => $sock) {
- if ($this->s2u[intval($sock)]->sess == '') {
- if ($this->s2u[intval($sock)]->rd_socket_get() != NULL) {
- $this->s2u[intval($sock)]->rd_socket_set(NULL);
+ $id = intval($sock);
+ if (isset($this->s2u[$id])) {
+ if ($this->s2u[$id]->sess == '') {
+ if ($this->s2u[$id]->rd_socket_get() != NULL) {
+ $this->s2u[$id]->rd_socket_set(NULL);
+ }
+ unset($this->socks[$id]);
+ unset($this->s2u[$id]);
+ fclose($sock);
+ printf("CLOSE ON GARBAGE MANAGER\n");
}
- unset($this->socks[intval($sock)]);
- unset($this->s2u[intval($sock)]);
- fclose($sock);
- printf("CLOSE ON GARBAGE MANAGER\n");
}
}
}
}
$write = NULL;
$except = NULL;
- $num_changed_sockets = @stream_select($read, $write, $except, 0, 500000);
+ $num_changed_sockets = @stream_select($read, $write, $except, 5, 500000);
if ($num_changed_sockets == 0) {
printf(" no data in 5 secs, splash [%d]\n", $G_with_splash);
}
/* At least at one of the sockets something interesting happened */
foreach ($read as $i => $sock) {
+ $id = intval($sock);
+ $manage_page = FALSE;
/* is_resource check is required because there is the possibility that
during new request an old connection is closed */
if (!is_resource($sock)) {
stream_set_blocking($new_socket, $this->blocking_mode); // Set the stream to non-blocking
printf("RECEIVED HEADER:\n%s", $stream_info);
$path = spu_process_info($stream_info, $method, $header, $get, $post, $cookie);
+ $addr = stream_socket_get_name($new_socket, TRUE);
printf("PATH: [%s]\n", $path);
printf("M: %s\nHEADER:\n", $method);
+ if ($method == "POST") {
+ // ADD PUSH INTO FD ARRAY AS WAITING DATA
+ // Passing all infos from spu_process_info as arguments:
+ //
+ // MAYBE: $stream_info,
+ // $method, $header, $get, $post, $cookie
+ // $s_a_p (this), $new_socket, substr($path, SITE_PREFIX_LEN),
+ // $addr
+ }
+ else {
+ $manage_page = TRUE;
+ }
print_r($header);
printf("GET:\n");
print_r($get);
print_r($post);
printf("COOKIE:\n");
print_r($cookie);
- $addr = stream_socket_get_name($new_socket, TRUE);
$header_out = array();
- $subs = SITE_PREFIX."briskin5/";
- $subs_l = strlen($subs);
+ // TODO: MOVE DOWN request_mgr to factorize new_sockets and POST closed
$rret = FALSE;
if (!strncmp($path, SITE_PREFIX, SITE_PREFIX_LEN)) {
$rret = $this->app->request_mgr($this, $header, $header_out, $new_socket, substr($path, SITE_PREFIX_LEN), $addr, $get, $post, $cookie);
$buf = fread($sock, 512);
// if socket is closed
if ($buf == FALSE || strlen($buf) == 0) {
+ // close socket case
if ($buf == FALSE) {
printf("ERROR READING\n");
}
return(22);
}
else {
- // $user_a[$s2u[intval($sock)]]->disable();
- if ($this->s2u[intval($sock)]->rd_socket_get() != NULL) {
- $this->s2u[intval($sock)]->rd_socket_set(NULL);
+ unset($this->socks[$id]);
+ if (isset($this->s2u[$id])) {
+ // $user_a[$s2u[$id]]->disable();
+ if ($this->s2u[$id]->rd_socket_get() != NULL) {
+ $this->s2u[$id]->rd_socket_set(NULL);
+ }
+ unset($this->s2u[$id]);
}
- unset($this->socks[intval($sock)]);
- unset($this->s2u[intval($sock)]);
}
fclose($sock);
printf("CLOSE ON READ\n");
}
}
}
+ // TODO: MOVE HERE request_mgr to factorize new_sockets and POST closed
+ // $rret = $this->app->request_mgr
}
}
/* manage open streaming */
foreach ($this->socks as $k => $sock) {
- if (isset($this->s2u[intval($sock)])) {
- $user = $this->s2u[intval($sock)];
+ $id = intval($sock);
+ if (isset($this->s2u[$id])) {
+ $user = $this->s2u[$id];
$response = $user->rd_cache_get();
$do_ping = FALSE;
if (($this->curtime - $user->lacc) > (EXPIRE_TIME_RD / 3)) {
// close socket after a while to prevent client memory consumption
if ($user->rd_endtime_is_expired($this->curtime)) {
- if ($this->s2u[intval($sock)]->rd_socket_get() != NULL) {
- $this->s2u[intval($sock)]->rd_socket_set(NULL);
+ if ($this->s2u[$id]->rd_socket_get() != NULL) {
+ $this->s2u[$id]->rd_socket_set(NULL);
}
- unset($this->socks[intval($sock)]);
- unset($this->s2u[intval($sock)]);
+ unset($this->socks[$id]);
+ unset($this->s2u[$id]);
fclose($sock);
printf("CLOSE ON LOOP\n");
}