typo fixed
[brisk.git] / web / index.php
index 43def6d..6c7b5b2 100644 (file)
@@ -2,7 +2,7 @@
 /*
  *  brisk - index.php
  *
- *  Copyright (C) 2006-2011 Matteo Nastasi
+ *  Copyright (C) 2006-2012 Matteo Nastasi
  *                          mailto: nastasi@alternativeoutput.it 
  *                                  matteo.nastasi@milug.org
  *                          web: http://www.alternativeoutput.it
@@ -22,8 +22,6 @@
  *
  */
 
-$G_base = "";
-
 require_once("Obj/brisk.phh");
 require_once("Obj/auth.phh");
 require_once("Obj/proxyscan.phh");
@@ -40,7 +38,7 @@ $mlang_room = array( 'userpasserr'  => array('it' => 'Utente e/o password errati
                                              'en' => 'Standing players'),
                      'headline'     => array('it' => 'briscola chiamata in salsa ajax',
                                              'en' => 'declaration briscola in ajax sauce <b>(Beta)</b>'),
-                     'wellcome'     => array('it' => 'Digita il tuo nickname per accedere ai tavoli della briscola',
+                     'welcome'      => array('it' => 'Digita il tuo nickname per accedere ai tavoli della briscola',
                                              'en' => 'Enter your nickname to access to the tables of briscola'),
                      'btn_enter'    => array('it' => 'entra',
                                              'en' => 'enter'),
@@ -84,6 +82,14 @@ $mlang_room = array( 'userpasserr'  => array('it' => 'Utente e/o password errati
                                              'en' => 'baby'),
                      'st_mop_desc'  => array('it' => 'pulizie',
                                              'en' => 'mop'),
+                     'st_babbo_desc'  => array('it' => 'babbo',
+                                             'en' => 'mop'),
+                     'st_renna_desc'  => array('it' => 'renna',
+                                             'en' => 'mop'),
+                     'st_pupaz_desc'  => array('it' => 'pupazzo',
+                                             'en' => 'mop'),
+                     'st_visch_desc'  => array('it' => 'vischio',
+                                             'en' => 'mop'),
                      
                      'tit_ticker'   => array('it' => 'scrivi un invito al tavolo e clicca',
                                              'en' => 'write an invitation at the table and click'),
@@ -175,18 +181,9 @@ $mlang_room = array( 'userpasserr'  => array('it' => 'Utente e/o password errati
                                              'en' => 'Close.')
                      );
 
-// Use of proxies isn't allowed.
-if (!$G_is_local && is_proxy()) 
-   exit;
-
-require_once("briskin5/Obj/briskin5.phh");
-if (DEBUGGING == "local" && $_SERVER['REMOTE_ADDR'] != '127.0.0.1') {
-  echo "Debugging time!";
-  exit;
-}
 
-log_load("index.php");
 
+require_once("briskin5/Obj/briskin5.phh");
 
 function poll_dom() {
   GLOBAL $G_with_poll, $G_poll_title, $G_poll_entries;
@@ -218,15 +215,32 @@ function carousel_top()
     return (sprintf('<a target="_blank" href="http://shop.alternativeoutput.it"><img class="nobo" style="display: inline; border: 1px solid #808080;" src="img/briskshop%d.gif"></a>', $rn));
 }
 
-function main()
+function index_main(&$room, $transp_type, &$header_out, $addr, $get, $post, $cookie)
 {
-  GLOBAL $G_with_donors, $G_donors_cur, $G_donors_all;
-  GLOBAL $G_with_topbanner, $G_topbanner, $G_is_local;
-  GLOBAL $G_with_sidebanner, $G_sidebanner; 
-  GLOBAL $G_with_sidebanner2, $G_sidebanner2; 
-  GLOBAL $G_with_poll;
-  GLOBAL $sess, $name, $pass_private, $table_idx, $table_token, $BRISK_SHOWHTML, $BRISK_DEBUG, $_SERVER;
-  GLOBAL $G_lang, $G_lng, $mlang_room;
+    GLOBAL $G_with_donors, $G_donors_cur, $G_donors_all;
+    GLOBAL $G_with_topbanner, $G_topbanner, $G_is_local;
+    GLOBAL $G_with_sidebanner, $G_sidebanner; 
+    GLOBAL $G_with_sidebanner2, $G_sidebanner2; 
+    GLOBAL $G_with_poll;
+    GLOBAL $G_lang, $G_lng, $mlang_room;
+    GLOBAL $BRISK_SHOWHTML, $BRISK_DEBUG, $_SERVER;
+
+    if (($sess = gpcs_var('sess', $get, $post, $cookie)) === FALSE) 
+        $sess = "";
+    if (($name = gpcs_var('name', $get, $post, $cookie)) === FALSE)
+        unset($name);
+    if (($pass_private = gpcs_var('pass_private', $get, $post, $cookie)) === FALSE)
+        unset ($pass_private);
+    if (($table_idx = gpcs_var('table_idx', $get, $post, $cookie)) === FALSE)
+        unset ($table_idx);
+    if (($table_token = gpcs_var('table_idx', $get, $post, $cookie)) === FALSE)
+        unset ($table_token);
+
+    // Use of proxies isn't allowed.
+    if (!$G_is_local && is_proxy($addr)) {
+        return FALSE;
+    }
+
   $is_login = FALSE;
   $body = "";
   $tables = "";
@@ -235,12 +249,7 @@ function main()
   
   if (isset($BRISK_SHOWHTML) == FALSE) {
       $is_table = FALSE;
-      $sem = Room::lock_data(TRUE);
       log_main("lock Room");
-      if (($room = Room::load_data()) == FALSE) {
-          log_crit("load_data failed");
-          exit();
-      }
       $curtime = time();
       
       /* Actions */
@@ -252,24 +261,16 @@ function main()
           if (($user = &$room->get_user($sess, &$idx)) != FALSE) {
               log_main("user stat: ".$user->stat);
               if ($user->stat == "table") {
-                  if (Room::save_data(&$room) == FALSE) {
-                      echo "ERRORE SALVATAGGIO\n";
-                      exit;
-                  }
-                  log_main("unlock Room");
-                  Room::unlock_data($sem);
-                  setcookie("table_token", $user->table_token, $curtime + 31536000);
-                  setcookie("table_idx", $user->table, $curtime + 31536000);
-                  header ("Location: briskin5/index.php");
-                  exit;
+                  $cookies = new Cookies();
+                  $cookies->add("table_token", $user->table_token, $curtime + 31536000);
+                  $cookies->add("table_idx", $user->table, $curtime + 31536000);
+                  $header_out['cookies'] = $cookies;
+                  $header_out['Location'] = "briskin5/index.php";
+                  return TRUE;
               }
               $ACTION = "room";
           }
           
-          if (Room::save_data(&$room) == FALSE) {
-              echo "ERRORE SALVATAGGIO\n";
-              exit;
-          }
       }
       
       if ($ACTION == "login" && isset($name)) {
@@ -282,37 +283,36 @@ function main()
           
           $room->garbage_manager(TRUE);
           /* try login */
-          if (($user = $room->add_user(&$sess, &$idx, $name, $pass_private, $_SERVER['REMOTE_ADDR'])) != FALSE) {
+          $ipv4addr_arr = explode(':' , $addr);
+          if (isset($ipv4addr_arr[3])) {
+              $ipv4addr = $ipv4addr_arr[3];
+          }
+          else {
+              $ipv4addr = $addr;
+          }
+          if (($user = $room->add_user(&$sess, &$idx, $name, $pass_private, $ipv4addr, $cookie)) != FALSE) {
               $ACTION = "room";
               if ($idx < 0) {
                   $idx = -$idx - 1;
                   $is_login = TRUE;
               }
               
-              log_legal($curtime, $user, "STAT:LOGIN", '');
+              log_legal($curtime, $ipv4addr, $user, "STAT:LOGIN", '');
               
               // recovery lost game
               if ($user->stat == "table") {
-                  if (Room::save_data(&$room) == FALSE) {
-                      echo "ERRORE SALVATAGGIO\n";
-                      exit;
-                  }
-                  log_main("unlock Room");
-                  Room::unlock_data($sem);
-                  setcookie("table_token", $user->table_token, $curtime + 31536000);
-                  setcookie("table_idx", $user->table, $curtime + 31536000);
-                  header ("Location: briskin5/index.php");
-                  exit;
+                  $cookies = new Cookies();
+                  $cookies->add("table_token", $user->table_token, $curtime + 31536000);
+                  $cookies->add("table_idx", $user->table, $curtime + 31536000);
+                  $header_out['cookies'] = $cookies;
+                  $header_out['Location'] = "briskin5/index.php";
+                  return TRUE;
               }
               
               
               // setcookie ("sess", "", time() + 180);      
               $room->standup_update(&$user);
               
-              if (Room::save_data($room) == FALSE) {
-                  echo "ERRORE SALVATAGGIO\n";
-                  exit;
-              }
           }
           else {
               /* Login Rendering */
@@ -343,7 +343,6 @@ function main()
               $body .= '<div class="urgmsg"><b>'.$mlang_room['userpass'.$sfx][$G_lang].'</b></div>';
           }
       }
-      Room::unlock_data($sem);
   }
   /* Rendering. */
 
@@ -353,7 +352,7 @@ function main()
   else if ($BRISK_SHOWHTML == "debuglogin") {
       $ACTION = "login";
   }
-  
+
   if ($ACTION == "room") {
       $tables .= '<div class="room_tab">';
       $tables .= '<table class="room_tab">';
@@ -415,14 +414,18 @@ function main()
                                array ( 'id' => 'btn_foroli',
                                        'url' => 'http://www.forumolimpia.it',
                                        'content' => 'img/forumolimpia.gif',
-                                       'content_big' => 'img/forumolimpia_big.png' ) );
+                                       'content_big' => 'img/forumolimpia_big.png' ),
+                               array ( 'id'=> 'btn_niini',
+                                       'url' => 'http://www.niinivirta.it',
+                                       'content' => 'img/niinivirta.png',
+                                       'content_big' => 'img/niinivirta_big.png') );
   
   
   
   $altout_support = "";
   $altout_support_big = "";
-  for ($i = 0 ; $i < 3 ; $i++) {
-      $ii = ($i < 2 ? $i : 0);
+  for ($i = 0 ; $i < 4 ; $i++) {
+      $ii = ($i < 3 ? $i : 0);
       
       $altout_support .= sprintf('<a style="position: absolute; top: %dpx; left: 7px;" target="_blank" href="%s"><img class="nobo" id="%s" src="%s" onMouseOver="show_bigpict(this, \'over\',100,10);" onMouseOut="show_bigpict(this, \'out\',0,0);"></a><br>',
                                  $i * 20, $altout_support_arr[$ii]['url'],
@@ -523,7 +526,7 @@ google_color_url = "000000";
 "<div style='background-color: #ffd780; border: 1px solid black; text-align: center;'><img class='nobo' src=\"donometer.php?c=".$G_donors_cur."&a=".$G_donors_all."\"><div style='padding: 1px; background-color: white;'><b>donatori</b></div></div>") ) : '').'</td>
 <td align="right"><div style="padding-right: 8px;">
 '.$banner_top_right.'</div></td>
-</td></table>
+</tr></table>
 </div>';
 
 /* MLANG: ALL THE VERTICAL MENU */
@@ -570,7 +573,7 @@ google_color_url = "000000";
 <a target="_blank" href="http://www.alternativeoutput.it/briskhome.php#prop" 
    onmouseover="menu_hide(0,1);"
    title="'.$mlang_room['tit_pro'][$G_lang].'">'.$mlang_room['itm_pro'][$G_lang].'</a><br>
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,1);"
    title="credits" onclick="act_about();">about</a><br>
 
@@ -581,15 +584,15 @@ google_color_url = "000000";
 <hr>
 
 <!--
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,1);"
    title="perché supportare brisk?" onclick="act_whysupport();">supportare?</a><br>
 -->
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,1);"
    title="'.$mlang_room['tit_cla'][$G_lang].'" onclick="act_placing();">'.$mlang_room['itm_cla'][$G_lang].'</a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,1);"
    title="'.$mlang_room['tit_rmap'][$G_lang].'" onclick="act_roadmap();">'.$mlang_room['itm_rmap'][$G_lang].'</a><br>
 
@@ -647,92 +650,120 @@ google_color_url = "000000";
           .$mlang_room['stat_desc'][$G_lang].
 '</a><br>
 <div id="menu_state" class="webstart">
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st normale\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_norm_desc'][$G_lang].
 '</a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st pausa\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_paus_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_pau.png"></a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st fuori\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_out_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_out.png"></a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st cane\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_dog_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_dog.png"></a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st cibo\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_food_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_eat.png"></a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st lavoro\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_work_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_wrk.png"></a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st sigaretta\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_smok_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_smk.png"></a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st presente\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_pres_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_eye.png"></a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st coniglio\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_rabb_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_rabbit.png"></a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st calcio\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_socc_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_soccer.png"></a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st pupo\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_baby_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_baby.png"></a><br>
 
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st pulizie\'); menu_over(-1,this);">'
           // MLANG
           .$mlang_room['st_mop_desc'][$G_lang].
 '&nbsp;<img class="unbo" src="img/st_mop.png"></a><br>
 
+<a href="#"
+   onmouseover="menu_hide(0,2);"
+   title="" onclick="act_chatt(\'/st babbo\'); menu_over(-1,this);">'
+          // MLANG
+          .$mlang_room['st_babbo_desc'][$G_lang].
+'&nbsp;<img class="unbo" src="img/st_babbo.png"></a><br>
+
+<a href="#"
+   onmouseover="menu_hide(0,2);"
+   title="" onclick="act_chatt(\'/st renna\'); menu_over(-1,this);">'
+          // MLANG
+          .$mlang_room['st_renna_desc'][$G_lang].
+'&nbsp;<img class="unbo" src="img/st_renna.png"></a><br>
+
+<a href="#"
+   onmouseover="menu_hide(0,2);"
+   title="" onclick="act_chatt(\'/st pupazzo\'); menu_over(-1,this);">'
+          // MLANG
+          .$mlang_room['st_pupaz_desc'][$G_lang].
+'&nbsp;<img class="unbo" src="img/st_pupaz.png"></a><br>
+
+<a href="#"
+   onmouseover="menu_hide(0,2);"
+   title="" onclick="act_chatt(\'/st vischio\'); menu_over(-1,this);">'
+          // MLANG
+          .$mlang_room['st_visch_desc'][$G_lang].
+'&nbsp;<img class="unbo" src="img/st_visch.png"></a><br>
+
 <!--
-<a href="#" 
+<a href="#"
    onmouseover="menu_hide(0,2);"
    title="" onclick="act_chatt(\'/st coniglio\'); menu_over(-1,this);">'
           // MLANG
@@ -859,11 +890,12 @@ supported by:<br>
 </div><br><br></div>
 %s
 %s
-<br></div>';
+<br>
+<img id="stm_stat" class="nobo" src="img/line-status_b.png"></div>';
     
   /* Templates. */
   if ($ACTION == 'login') {
-    header('Content-type: text/html; charset="utf-8"',true);
+      $header_out['Content-type'] = "text/html; charset=\"utf-8\"";
 ?>
 <html>
 <head>
@@ -871,10 +903,10 @@ supported by:<br>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 <link rel="shortcut icon" href="img/brisk_ico.png">
 <script type="text/javascript" src="commons.js"></script> 
-<script type="text/javascript" src="myconsole.js"></script>
+<!-- <script type="text/javascript" src="myconsole.js"></script> -->
 <script type="text/javascript" src="menu.js"></script>
 <script type="text/javascript" src="heartbit.js"></script>
-<script type="text/javascript" src="xynt-http-streaming.js"></script>
+<script type="text/javascript" src="xynt-streaming.js"></script>
 <script type="text/javascript" src="preload_img<?php echo langtolng($G_lang); ?>.js"></script>
 <script type="text/javascript" src="AC_OETags.js"></script>
 <script type="text/javascript" src="room.js"></script>
@@ -884,17 +916,18 @@ supported by:<br>
 <link rel="stylesheet" type="text/css" href="room.css">
 
 <SCRIPT type="text/javascript"><!--
+   var g_debug = 0;
    var g_lang = "<? echo $G_lang; ?>";
    var g_lng = "<? echo $G_lng; ?>";
    var g_tables_n = <? echo TABLES_N; ?>;
    var g_tables_auth_n = <? echo TABLES_AUTH_N; ?>;
    var g_listen;
    var g_withflash = false;
-   var g_is_spawn = 0; 
+   var g_is_spawn = 0;
    var gst  = new globst();
    var topbanner_sfx, topbanner_dx;
    var g_brow = null;
-   var hstm = null;
+   var xstm = null;
    var sess = "not_connected";
    var spo_slide, sup_slide;
 
@@ -902,7 +935,7 @@ supported by:<br>
      // alert(window.onbeforeunload);
      g_brow = get_browser_agent();
      spo_slide  = new sideslide($('spon_caro'), 80, 20);
-     sup_slide  = new sideslide($('supp_caro'), 60, 20);
+     sup_slide  = new sideslide($('supp_caro'), 80, 20);
 
      login_init();
 <?php
@@ -961,7 +994,7 @@ echo "$body"; ?>
 <br>
 <div style="text-align: center;">
    <br><br><br>
-<?php echo $mlang_room['wellcome'][$G_lang];?>
+<?php echo $mlang_room['welcome'][$G_lang];?>
 <br><br>
 <form accept-charset="utf-8" method="post" action="" onsubmit="return j_login_manager(this);">
 <input id="passid_private" name="pass_private" type="hidden" value="">
@@ -997,7 +1030,7 @@ echo "$body"; ?>
 <?php
   }
   else if ($ACTION == 'room') {
-    header('Content-type: text/html; charset="utf-8"',true);
+      $header_out['Content-type'] = "text/html; charset=\"utf-8\"";
   ?>
 <html>
 <head>
@@ -1005,11 +1038,11 @@ echo "$body"; ?>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 <link rel="shortcut icon" href="img/brisk_ico.png">
 <script type="text/javascript" src="commons.js"></script>
-<script type="text/javascript" src="myconsole.js"></script>
+<!-- <script type="text/javascript" src="myconsole.js"></script> -->
 <script type="text/javascript" src="menu.js"></script>
 <script type="text/javascript" src="ticker.js"></script>
 <script type="text/javascript" src="heartbit.js"></script>
-<script type="text/javascript" src="xynt-http-streaming.js"></script>
+<script type="text/javascript" src="xynt-streaming.js"></script>
 <script type="text/javascript" src="room.js"></script>
 <script type="text/javascript" src="preload_img<?php echo langtolng($G_lang); ?>.js"></script>
 <script type="text/javascript" src="AC_OETags.js"></script>
@@ -1018,6 +1051,7 @@ echo "$body"; ?>
 <link rel="stylesheet" type="text/css" href="room.css">
 <SCRIPT type="text/javascript"><!--
    var sess = "not_connected";
+   var g_debug = 0;
    var g_lang = "<? echo $G_lang; ?>";
    var g_lng = "<? echo $G_lng; ?>";
    var g_tables_n = <? echo TABLES_N; ?>;
@@ -1039,7 +1073,7 @@ echo "$body"; ?>
    window.onload = function() {
      g_brow = get_browser_agent();
      spo_slide  = new sideslide($('spon_caro'), 80, 20);
-     sup_slide  = new sideslide($('supp_caro'), 60, 20);
+     sup_slide  = new sideslide($('supp_caro'), 80, 20);
 
 <?php
 if ($BRISK_SHOWHTML == "debugtable") {
@@ -1064,8 +1098,8 @@ else {
 
 ?>
      sess = "<?php echo "$sess"; ?>";
-     hstm = new http_streaming(window, console, gst, 'index_php', 'sess', sess, $('sandbox'), 'index_rd_ifra.php', function(com){eval(com);});
-     hstm.hbit_set(heartbit);
+xstm = new xynt_streaming(window, "<?php echo "$transp_type"; ?>", null /* console */, gst, 'index_php', 'sess', sess, $('sandbox'), 'index_rd_ifra.php', function(com){eval(com);});
+     xstm.hbit_set(heartbit);
      tra = new train($('room_tit'));
      window.onunload = onunload_cb;
      window.onbeforeunload = onbeforeunload_cb;
@@ -1077,9 +1111,10 @@ else {
        $("proflashext").innerHTML = "";
 
      // console.log("session from main: "+sess);
-     hstm.start();
+     xstm.start();
      // alert("ARR LENGTH "+g_preload_img_arr.length);
-     setTimeout(preload_images, 0, g_preload_img_arr, g_imgct); 
+     // FIXME: preload image will be fired by stream instead here
+     // setTimeout(preload_images, 0, g_preload_img_arr, g_imgct); 
      $("txt_in").focus();
 <?php
 if ($is_login) {
@@ -1213,6 +1248,4 @@ type="submit" class="button" onclick="this.form.elements['realsub'].value = 'chi
    }
 }
 
-main();
-
 ?>