define('USER_FLAG_S_SOCC', 0x900); // done
define('USER_FLAG_S_BABY', 0xa00); // done
define('USER_FLAG_S_MOP', 0xb00); // done
+define('USER_FLAG_S_BABBO', 0xc00); // done
+define('USER_FLAG_S_RENNA', 0xd00); // done
+define('USER_FLAG_S_PUPAZ', 0xe00); // done
+define('USER_FLAG_S_VISCH', 0xf00); // done
define('USER_FLAG_S_ALL', 0xf00); // done
define('USER_FLAG_TY_ALL', 0xff0000); // done
define('USER_FLAG_TY_NORM', 0x010000); // done
define('USER_FLAG_TY_SUPER', 0x020000); // done
+define('USER_FLAG_TY_CERT', 0x040000); // done
// ... other usefull status ...
+define('USER_FLAG_TY_FIRONLY', 0x200000); // done
define('USER_FLAG_TY_SUSPEND', 0x400000); // done
define('USER_FLAG_TY_DISABLE', 0x800000); // done
var $rd_cache; // place where store failed fwrite data
var $rd_zls; // zlibstream object handle if compressed stream, else FALSE
var $rd_transp; // class that define stream encapsulation type (iframe, xhr, ...)
+ var $rd_is_chunked; // is the transport chunked or not ?
var $comm; // commands array
// var $asta_card; //
var $table_pos; // idx on the table
var $table_token;// token that identify a game on a table
var $flags; // Bitfield with: AUTHENTICATE: 0x02
+ var $rec; // field with user db record or FALSE
var $the_end; // Flag to change the end of the session
var $chat_lst; // Last chat line
function User() {
}
- function create(&$room, $idx, $name, $sess, $stat = "", $subst = "", $table = -1, $ip="0.0.0.0") {
+ static function create(&$room, $idx, $name, $sess, $stat = "", $subst = "", $table = -1, $ip="0.0.0.0") {
if (($thiz = new User()) == FALSE)
return (FALSE);
$thiz->rd_cache = "";
$thiz->rd_zls = FALSE;
$thiz->rd_transp = NULL;
+ $thiz->rd_is_chunked = FALSE;
$thiz->asta_card = -2;
$thiz->asta_pnt = -1;
$thiz->exitislock = TRUE;
$thiz->flags = 0x00;
-
+ $thiz->rec = FALSE;
+
$thiz->chattime = array_fill(0, CHAT_N, 0);
$thiz->chat_cur = 0;
$thiz->chat_lst = "";
$this->exitislock = $from->exitislock;
$this->flags = $from->flags;
+ $this->rec = $from->rec;
$this->chattime = array();
for ($i = 0 ; $i < CHAT_N ; $i++)
}
- function myclone($from)
+ static function myclone($from)
{
if (($thiz = new User()) == FALSE)
return (FALSE);
return ($thiz);
}
- function spawn($from, $table, $table_pos)
+ static function spawn($from, $table, $table_pos)
{
if (($thiz = new User()) == FALSE)
return (FALSE);
$thiz->the_end = $from->the_end;
$thiz->flags = $from->flags;
+ $thiz->rec = $from->rec;
$thiz->chattime = array_fill(0, CHAT_N, 0);
$thiz->chat_cur = 0;
return ($thiz);
}
- function rd_data_set($curtime, $enc, $stat, $subst, $step, $from)
+ function flags_set($flags, $mask)
+ {
+ $flags_old = $this->flags & (~$mask);
+ $this->flags = ($flags_old | ($flags & $mask));
+ }
+
+ function store_set()
+ {
+ if (($bdb = BriskDB::create()) == FALSE) {
+ return FALSE;
+ }
+ return ($bdb->user_prefs_update($this->code, ($this->flags & (USER_FLAG_TY_ALL | USER_FLAG_MAP_AUTH)),
+ $this->rec->supp_comp));
+ }
+
+ function rd_data_set($curtime, $transp, $enc, $stat, $subst, $step, $from)
{
$this->rd_endtime = $curtime + RD_ENDTIME_DELTA;
$this->rd_stat = $stat;
$this->rd_scristp = 0;
$this->rd_kalive = $curtime + RD_KEEPALIVE_TOUT;
$this->rd_zls = ZLibStream::create($enc);
- $this->rd_transp = new Transport_iframe();
+ $this->rd_transp = Transport::create($transp);
+ $this->rd_is_chunked = $this->rd_transp->is_chunked();
}
function rd_socket_get() {
function reset() {
$curtime = time();
- log_legal($curtime, 'xxx', $this, "STAT:LOGOUT", '');
+ log_legal($curtime, $this->ip, $this, "STAT:LOGOUT", '');
$tmp_sess = $this->sess;
$this->sess = "";
$is_super = $this->flags & USER_FLAG_TY_SUPER;
$ret .= show_notify_ex(str_replace("\n", " ", $G_splash_content[$G_lang]),
($is_super ? 0 : $G_splash_timeout),
- $mlang_indrd[($is_super ? 'btn_btotabsup' : 'btn_backtotab')][$G_lang],
+ // $mlang_indrd[($is_super ? 'btn_btotabsup' : 'btn_backtotab')][$G_lang],
+ $mlang_indrd['btn_backtotab'][$G_lang],
$G_splash_w, $G_splash_h, true,
($is_super ? 0 : $G_splash_timeout));
$ret .= sprintf('|createCookie("CO_splashdate%d", %d, 24*365, cookiepath);', $G_splash_idx, $curtime);
return ($ret);
} // function maincheck (...
- public static function stream_fini($init_string, $is_unrecoverable)
+ public static function stream_fini($transp, $init_string, $is_unrecoverable)
{
printf("xXx user::stream_fini\n");
// FIXME: dynamic "Transport_" type
- $tans_class = "Transport_iframe";
- $body = $tansclass::fini($init_string, static::blocking_error($is_unrecoverable));
+ $trans_class = Transport::gettype($transp);
+ $body = $trans_class::fini($init_string, self::base_get(), static::blocking_error($is_unrecoverable));
// ELSE IF XHR THEN:
// return (static::blocking_error($is_unrecoverable));
stat
step
*/
-function stream_init($init_string, $enc, &$header_out, &$body, $get, $post, $cookie)
+function stream_init($init_string, $enc, $header, &$header_out, &$body, $get, $post, $cookie)
{
$curtime = time();
printf("CLASS: [%s] base: [%s]\n", get_class($this), self::base_get());
-
- // (webservers_exceeded() || stristr($HTTP_USER_AGENT, "Mozilla/5.0 (Windows NT 6.1; rv:5.0)") || stristr($HTTP_USER_AGENT, "MSIE") || stristr($HTTP_USER_AGENT, "CHROME") ? TRUE : FALSE);
log_load("index_rd_ifra_init.php");
$subst = "";
if (($step = gpcs_var('step', $get, $post, $cookie)) === FALSE)
unset($step);
+ if (($transp = gpcs_var('transp', $get, $post, $cookie)) === FALSE)
+ $transp = "iframe";
- $this->rd_data_set($curtime, $enc, $stat, $subst, $step, $from);
+ $this->rd_data_set($curtime, $transp, $enc, $stat, $subst, $step, $from);
- $body .= $this->rd_transp->init($enc, &$header_out, $init_string, self::base_get(), $this->rd_scristp);
+ $body .= $this->rd_transp->init($enc, $header, &$header_out, $init_string, self::base_get(), $this->rd_scristp);
return TRUE;
}
return $c::BASE;
}
+function is_supp_custom()
+{
+ if ($this->rec != FALSE) {
+ if ($this->flags & USER_FLAG_TY_SUPER) {
+ return (TRUE);
+ }
+ /*
+ if ($this->rec->last_dona > 1356994800) {
+ return (TRUE);
+ }
+ */
+ }
+ return (FALSE);
+}
+
+function is_chunked()
+{
+ return $this->rd_is_chunked;
+}
+
+
+function chunked_content($content)
+{
+ if ($this->rd_zls) {
+ $cont_comp = $this->rd_zls->compress_chunk($content);
+ }
+ else {
+ $cont_comp = $content;
+ }
+ $cont_comp_l = mb_strlen($cont_comp, "ASCII");
+ // printf("CHUNK: [%s]\n", $content);
+
+ if ($this->is_chunked()) {
+ return (sprintf("%X\r\n", $cont_comp_l).$cont_comp."\r\n");
+ }
+ else {
+ return $content;
+ }
+}
+
+function chunked_fini()
+{
+ return sprintf("0\r\n");
+}
+
+
} // end class User