user is_auth() is_cert() methods added
[brisk.git] / web / index.php
1 <?php
2 /*
3  *  brisk - index.php
4  *
5  *  Copyright (C) 2006-2012 Matteo Nastasi
6  *                          mailto: nastasi@alternativeoutput.it
7  *                                  matteo.nastasi@milug.org
8  *                          web: http://www.alternativeoutput.it
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful, but
16  * WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABLILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18  * General Public License for more details. You should have received a
19  * copy of the GNU General Public License along with this program; if
20  * not, write to the Free Software Foundation, Inc, 59 Temple Place -
21  * Suite 330, Boston, MA 02111-1307, USA.
22  *
23  */
24
25 require_once("Obj/brisk.phh");
26 require_once("Obj/auth.phh");
27 require_once("Obj/proxyscan.phh");
28
29 $mlang_room = array( 'userpasserr'  => array('it' => 'Utente e/o password errati.',
30                                              'en' => 'Wrong user and/or password.'),
31                      'userpassmust' => array('it' => 'Il nickname deve contenere almeno una lettera o una cifra.',
32                                              'en' => 'The nickname have to contain at least one letter or one number.'),
33                      'userpassend'  => array('it' => 'Spiacenti, non ci sono pi&ugrave; posti liberi. Riprova pi&ugrave; tardi.',
34                                              'en' => 'We are sorry, there aren\'t free place. Try again later.'),
35                      'userpassuse'  => array('it' => 'Il tuo nickname &egrave; gi&agrave; in uso.',
36                                              'en' => 'Your nickname is already in use.'),
37                      'standing'     => array('it' => 'Giocatori in piedi',
38                                              'en' => 'Standing players'),
39                      'headline'     => array('it' => 'briscola chiamata in salsa ajax',
40                                              'en' => 'declaration briscola in ajax sauce <b>(Beta)</b>'),
41                      'welcome'      => array('it' => 'Digita il tuo nickname per accedere ai tavoli della briscola',
42                                              'en' => 'Enter your nickname to access to the tables of briscola'),
43                      'btn_enter'    => array('it' => 'entra',
44                                              'en' => 'enter'),
45                      'passwarn'     => array('it' => 'Se non hai ancora una password, lascia il campo in bianco ed entra.',
46                                              'en' => 'If you don\'t have a password, leave blank the field and enter.'),
47                      'browwarn'     => array('it' => 'Se qualcosa non funziona prova a ricaricare la pagina con <b>Ctrl + F5</b><br><br>Se non riesci piĆ¹ ad entrare nel nuovo Brisk e prima ci riuscivi potrebbe essere un problema di antivirus,<br>guarda la <a class=\'flat\' style=\'background-color: white; font-weight: bold;\' target=\'_blank\' href=\'http://www.alternativeoutput.it/blog/doku.php?id=brisk:guida_agli_antivirus\'>pagina sugli antivirus</a> per maggiori informazioni su come configurarlo.<br><br>Se ancora non funziona nulla contatta <a class=\'flat\' style=\'background-color: white; font-weight: bold;\' href=\'mailto:brisk@alternativeoutput.it\'>l\'amministratore del sito</a>.',
48                                              'en' => '(if something don\'t work<br>try to reload the current page with <b>Ctrl + F5</b>)'),
49                      'regwarn'      => array('it' => '<br>Il nickname che stai usando &egrave; gi&agrave; registrato,<br><br>se il suo proprietario si autentificher&agrave;<br><br>verrai rinominato d\'ufficio come ghost<i>N</i>.',
50                                              'en' => '<br>The nickname you are using it\'s already registered, <br><br>if its proprietary authenticates<br><br>you will named ghost<i>N</i>.'),
51                      'btn_rettabs'  => array('it' => 'torna ai tavoli',
52                                              'en' => 'back to tables'),
53                      'btn_exit'     => array('it' => 'Esco.',
54                                              'en' => 'Exit.'),
55                      'btn_prefs_save' => array('it' => 'Salva.',
56                                              'en' => 'Save.'),
57                      'btn_prefs_reset' => array('it' => 'Annulla.',
58                                              'en' => 'Reset.'),
59                      'btn_prefs_close' => array('it' => 'Chiudi.',
60                                              'en' => 'Close.'),
61                      'tit_tabl'     => array('it' => 'Tavolo ',
62                                              'en' => 'Table '),
63                      'tit_stat'     => array('it' => 'imposta lo stato del tuo utente',
64                                              'en' => 'set the status of the user'),
65                      'stat_desc'    => array('it' => 'stato',
66                                              'en' => 'mode' ),
67                      'st_norm_desc' => array('it' => 'normale',
68                                              'en' => 'normal'),
69                      'st_paus_desc' => array('it' => 'pausa',
70                                              'en' => 'pause'),
71                      'st_out_desc'  => array('it' => 'fuori',
72                                              'en' => 'out'),
73                      'st_dog_desc'  => array('it' => 'cane',
74                                              'en' => 'dog'),
75                      'st_food_desc' => array('it' => 'cibo',
76                                              'en' => 'food'),
77                      'st_work_desc' => array('it' => 'lavoro',
78                                              'en' => 'work'),
79                      'st_smok_desc' => array('it' => 'sigaretta',
80                                              'en' => 'smoke'),
81                      'st_pres_desc' => array('it' => 'presente',
82                                              'en' => 'present'),
83                      'st_rabb_desc' => array('it' => 'coniglio',
84                                              'en' => 'rabbit'),
85                      'st_socc_desc' => array('it' => 'calcio',
86                                              'en' => 'soccer'),
87                      'st_baby_desc' => array('it' => 'pupo',
88                                              'en' => 'baby'),
89                      'st_mop_desc'  => array('it' => 'pulizie',
90                                              'en' => 'mop'),
91                      'st_babbo_desc'  => array('it' => 'babbo',
92                                              'en' => 'mop'),
93                      'st_renna_desc'  => array('it' => 'renna',
94                                              'en' => 'mop'),
95                      'st_pupaz_desc'  => array('it' => 'pupazzo',
96                                              'en' => 'mop'),
97                      'st_visch_desc'  => array('it' => 'vischio',
98                                              'en' => 'mop'),
99
100                      'tit_ticker'   => array('it' => 'scrivi un invito al tavolo e clicca',
101                                              'en' => 'write an invitation at the table and click'),
102                      'itm_warr'     => array('it' => 'garantisci',
103                                              'en' => 'guarantee'),
104                      'warr_desc'    => array('it' => 'garantisci per un tuo conoscente',
105                                              'en' => 'guarantee for a friend'),
106                      'tit_warr'     => array('it' => 'Garantisci per un tuo conoscente.',
107                                              'en' => 'Guarantee for a friend.'),
108                      'itm_list'     => array('it' => 'ascolta',
109                                              'en' => 'listen'),
110                      'list_desc'    => array('it' => 'imposta le regole di ascolto',
111                                              'en' => 'set the listen rules'),
112                      'tit_listall'  => array('it' => 'tutti',
113                                              'en' => 'everybody'),
114                      'listall_desc' => array('it' => 'leggi tutti i messaggi di tutti gli utenti collegati',
115                                              'en' => 'listen all messages from each user connected'),
116                      'tit_listaut'  => array('it' => 'solo autenticati',
117                                              'en' => 'only authorized'),
118                      'tit_listisol'  => array('it' => 'isolamento',
119                                              'en' => 'isolation'),
120                      'listaut_desc' => array('it' => 'leggi soltanto i messaggi degli utenti con password',
121                                              'en' => 'listen messages only from authenticated users'),
122                      'listisol_desc'=> array('it' => 'visualizza Brisk come se fosse solo per utenti con password',
123                                             'en' => 'show Brisk like an authenticated user only site'),
124                      'suppcomp_tit' =>  array('it' => 'personalizza la tua S',
125                                             'en' => 'customize your S'),
126                      'suppcomp_r' =>  array('it' => 'rosso',
127                                             'en' => 'red'),
128                      'suppcomp_g' =>  array('it' => 'verde',
129                                             'en' => 'green'),
130                      'suppcomp_b' =>  array('it' => 'blu',
131                                             'en' => 'blue'),
132                      'suppcomp_fg' =>  array('it' => 'colore',
133                                             'en' => 'color'),
134                      'suppcomp_bg' =>  array('it' => 'sfondo',
135                                             'en' => 'background'),
136                      'suppcomp_range' =>  array('it' => '(0-255)',
137                                             'en' => '(0-255)'),
138                      'tit_splash'   => array('it' => 'splash',
139                                              'en' => 'splash'),
140                      'splash_desc'  => array('it' => 'attiva la finestra di splash',
141                                              'en' => 'show the splash window'),
142                      'tit_prefs'   => array('it' => 'preferenze',
143                                              'en' => 'preferences'),
144                      'prefs_desc'  => array('it' => 'preferenze dell\' utente',
145                                              'en' => 'user\'s preferences'),
146                      'tit_help'     => array('it' => 'informazioni utili su Brisk',
147                                              'en' => 'usefull information about Brisk'),
148                      'itm_help'     => array('it' => 'aiuto',
149                                              'en' => 'help'),
150                      'tit_hpage'    => array('it' => 'homepage del progetto',
151                                              'en' => 'project homepage (ita)'),
152                      'tit_what'     => array('it' => 'di cosa si tratta',
153                                              'en' => 'what is the project'),
154                      'itm_what'     => array('it' => 'cos\'&egrave;',
155                                              'en' => 'what is it'),
156                      'url_rules'    => array('it' => 'http://it.wikipedia.org/wiki/Briscola#Gioco_a_5',
157                                              'en' => 'http://it.wikipedia.org/wiki/Briscola#Gioco_a_5&EN=true'),
158                      'itm_rules'    => array('it' => 'regole',
159                                              'en' => 'rules'),
160                      'tit_rules'    => array('it' => 'come si gioca',
161                                              'en' => 'how to play'),
162                      'tit_shot'     => array('it' => 'screenshots dell\'applicazione',
163                                              'en' => 'screenshots of the web-application'),
164                      'tit_comp'     => array('it' => 'compatibilit&agrave; con i browser',
165                                              'en' => 'browsers compatibility'),
166                      'itm_comp'     => array('it' => 'compatibilit&agrave;',
167                                              'en' => 'compatibility'),
168                      'tit_src'      => array('it' => 'sorgenti dell\'applicazione web',
169                                              'en' => 'sources of the web-application'),
170                      'itm_src'      => array('it' => 'sorgenti',
171                                              'en' => 'sources'),
172                      'tit_ml'       => array('it' => 'come iscriversi alla mailing list',
173                                              'en' => 'how to subscribe the mailing list'),
174                      'itm_ml'       => array('it' => 'mailing&nbsp;list',
175                                              'en' => 'mailing&nbsp;list'),
176                      'tit_pro'      => array('it' => 'come fare pubblicit&agrave; a Brisk!',
177                                              'en' => 'how to spread Brisk!'),
178                      'itm_pro'      => array('it' => 'propaganda',
179                                              'en' => 'propaganda'),
180                      'tit_mail'     => array('it' => 'contatti',
181                                              'en' => 'contacts'),
182                      'itm_mail'     => array('it' => 'contatti',
183                                              'en' => 'contacts'),
184                      'tit_cla'      => array('it' => 'classifiche degli utenti',
185                                              'en' => 'user\'s placings'),
186                      'itm_cla'      => array('it' => 'classifiche',
187                                              'en' => 'placings'),
188                      'tit_mnu'      => array('it' => 'minuta giornaliera',
189                                              'en' => 'daily report'),
190                      'itm_mnu'      => array('it' => 'minuta',
191                                              'en' => 'daily deport'),
192                      'tit_rmap'     => array('it' => 'prossime funzionalitĆ  implementate',
193                                              'en' => 'roadmap of next functionalities'),
194                      'itm_rmap'     => array('it' => 'roadmap',
195                                              'en' => 'roadmap'),
196                      'tit_meet'     => array('it' => 'foto dei raduni di briskisti (serve Facebook)',
197                                              'en' => 'photos of brisk meetings'),
198                      'itm_meet'     => array('it' => 'BriskMeeting',
199                                              'en' => 'BriskMeeting'),
200                      'tit_mesg'     => array('it' => 'manda un messaggio o una segnalazione all\'amministratore del sito',
201                                              'en' => 'send a message or a signalling to the administrator' ),
202                      'mesgtoadm_tit'=> array('it' => 'Invia un messaggio o una segnalazione all\'amministratore:',
203                                              'en' => 'Send a message to the administrator:'),
204                      'mesgtoadm_sub'=> array('it' => 'soggetto:',
205                                              'en' => 'subject:'),
206                      'btn_send'     => array('it' => 'Invia.',
207                                              'en' => 'Send.'),
208                      'btn_close'    => array('it' => 'Chiudi.',
209                                              'en' => 'Close.')
210                      );
211
212
213
214 require_once("briskin5/Obj/briskin5.phh");
215
216 function poll_dom() {
217   GLOBAL $G_with_poll, $G_poll_title, $G_poll_entries;
218
219   if ($G_with_poll) {
220     $ret = sprintf('<div style="padding: 0px;margin: 0px; height: 8px; font-size: 1px;"></div>
221
222 <img class="nobo" src="img/brisk_poll.png" onmouseover="menu_hide(0,0); menu_show(\'menu_poll\');">
223
224 <div style="width: 300px;" class="webstart" id="menu_poll" onmouseover="menu_over(1,this);" onmouseout="menu_over(-1,this);">
225 <b>%s</b><br><br>
226 <form id="poll_form" accept-charset="utf-8" method="post" action="" onsubmit="return j_pollbox(this);">
227 <input type="hidden" name="realsub" value="666">', $G_poll_title);
228     for ($i = 0 ; $i < count($G_poll_entries) ; $i++) {
229       $ret .= sprintf('<INPUT TYPE="radio" NAME="category" VALUE="%s">%s<hr><br>', $G_poll_entries[$i]['id'],
230                       $G_poll_entries[$i]['cont']);
231     }
232     $ret .= sprintf('<div style="text-align: center;"><input type="submit" class="input_sub" onclick="this.form.elements[\'realsub\'].value = this.value;" value="invia" name="sub" id="subid"/></div>
233 </form></div>');
234     return ($ret);
235   }
236   else
237     return '';
238 }
239
240 function index_main(&$brisk, $transp_type, &$header_out, $remote_addr_full, $get, $post, $cookie)
241 {
242     GLOBAL $G_with_donors, $G_donors_cur, $G_donors_all;
243     GLOBAL $G_with_topbanner, $G_topbanner, $G_is_local;
244     GLOBAL $G_with_sidebanner, $G_sidebanner;
245     GLOBAL $G_with_sidebanner2, $G_sidebanner2;
246     GLOBAL $G_with_poll;
247     GLOBAL $G_lang, $G_lng, $mlang_room;
248     GLOBAL $BRISK_SHOWHTML, $BRISK_DEBUG, $_SERVER;
249
250     if (($sess = gpcs_var('sess', $get, $post, $cookie)) === FALSE)
251         $sess = "";
252     if (($name = gpcs_var('name', $get, $post, $cookie)) === FALSE)
253         unset($name);
254     if (($pass_private = gpcs_var('pass_private', $get, $post, $cookie)) === FALSE)
255         unset ($pass_private);
256     if (($table_idx = gpcs_var('table_idx', $get, $post, $cookie)) === FALSE)
257         unset ($table_idx);
258     if (($table_token = gpcs_var('table_idx', $get, $post, $cookie)) === FALSE)
259         unset ($table_token);
260
261     $remote_addr = addrtoipv4($remote_addr_full);
262
263     // Use of proxies isn't allowed.
264     if (!$G_is_local && is_proxy($remote_addr)) {
265         return FALSE;
266     }
267
268   $is_login = FALSE;
269   $body = "";
270   $tables = "";
271   $standup = "";
272   $ACTION = "login";
273
274   if (isset($BRISK_SHOWHTML) == FALSE) {
275       $is_table = FALSE;
276       log_main("lock Brisk");
277       $curtime = time();
278
279       /* Actions */
280
281       if (validate_sess($sess)) {
282           log_main("pre garbage_manager UNO");
283           $brisk->garbage_manager(TRUE);
284           log_main("post garbage_manager");
285           if (($user = &$brisk->get_user($sess, &$idx)) != FALSE) {
286               $brisk->sess_cur_set($user->sess);
287               log_main("user stat: ".$user->stat);
288               if ($user->stat == "table") {
289                   $cookies = new Cookies();
290                   $cookies->add("table_token", $user->table_token, $curtime + 31536000);
291                   $cookies->add("table_idx", $user->table, $curtime + 31536000);
292                   $header_out['cookies'] = $cookies;
293                   $header_out['Location'] = "briskin5/index.php";
294                   return TRUE;
295               }
296               $ACTION = "room";
297           }
298       }
299
300       if ($ACTION == "login" && isset($name)) {
301           log_main("pre garbage_manager DUE");
302
303           if (isset($pass_private) == FALSE || $pass_private == "") {
304               $pass_private = FALSE;
305
306               $banned = FALSE;
307               if ($brisk->ban_check($remote_addr)) {
308                   // TODO: find a way to add a nonblocking sleep(5) here
309                   $banned = TRUE;
310                   $idx = -1;
311               }
312           }
313
314           $brisk->garbage_manager(TRUE);
315           /* try login */
316
317           if ($banned == FALSE &&
318               ($user = $brisk->add_user(&$sess, &$idx, $name, $pass_private, $remote_addr, $cookie)) != FALSE) {
319               $brisk->sess_cur_set($user->sess);
320               $ACTION = "room";
321               if ($idx < 0) {
322                   $idx = -$idx - 1;
323                   $is_login = TRUE;
324               }
325
326               log_legal($curtime, $remote_addr, $user, "STAT:LOGIN", '');
327
328               // recovery lost game
329               if ($user->stat == "table") {
330                   $cookies = new Cookies();
331                   $cookies->add("table_token", $user->table_token, $curtime + 31536000);
332                   $cookies->add("table_idx", $user->table, $curtime + 31536000);
333                   $header_out['cookies'] = $cookies;
334                   $header_out['Location'] = "briskin5/index.php";
335                   return TRUE;
336               }
337
338               // setcookie ("sess", "", time() + 180);      
339               $brisk->standup_update(&$user);
340           }
341           else {
342               /* Login Rendering */
343               /* MLANG: "Utente e/o password errati.", "Il nickname deve contenere almeno una lettera o una cifra.", "Spiacenti, non ci sono pi&ugrave; posti liberi. Riprova pi&ugrave; tardi.", "Il tuo nickname &egrave; gi&agrave; in uso." */
344               /*
345                if ($idx == -3)
346                $body .= '<div class="urgmsg"><b>'.$mlang_room['userpasserr'][$G_lang].'</b></div>';
347                else if ($idx == -2)
348                // $body .= '<div class="urgmsg"><b>Il nickname deve contenere almeno una lettera o una cifra.</b></div>';
349                $body .= '<div class="urgmsg"><b>'.$mlang_room['userpassmust'][$G_lang].'</b></div>';
350                else if ($idx == -1)
351                // $body .= '<div class="urgmsg"><b>Spiacenti, non ci sono pi&ugrave; posti liberi. Riprova pi&ugrave; tardi.</b></div>';
352                $body .= '<div class="urgmsg"><b>'.$mlang_room['userpassend'][$G_lang].'</b></div>';
353                else
354                // $body .= '<div class="urgmsg"><b>Il tuo nickname &egrave; gi&agrave; in uso.</b></div>';
355                $body .= '<div class="urgmsg"><b>'.$mlang_room['userpassuse'][$G_lang].'</b></div>';
356               */
357
358               if ($idx == -3)
359                   $sfx = 'err';
360               else if ($idx == -2)
361                   $sfx = 'must';
362               else if ($idx == -1)
363                   $sfx = 'end';
364               else
365                   $sfx = 'use';
366
367               $body .= '<div class="urgmsg"><b>'.$mlang_room['userpass'.$sfx][$G_lang].'</b></div>';
368           }
369       }
370   }
371   /* Rendering. */
372
373   if ($BRISK_SHOWHTML == "debugtable") {
374       $ACTION = "room";
375   }
376   else if ($BRISK_SHOWHTML == "debuglogin") {
377       $ACTION = "login";
378   }
379
380   if ($ACTION == "room") {
381       $tables .= '<div class="room_tab">';
382       $tables .= '<table class="room_tab">';
383       for ($ii = 0 ; $ii < TABLES_N ; $ii++) {
384           if ($user->is_auth())
385               $i = $ii;
386           else
387               $i = TABLES_N - $ii - 1;
388
389           if ($ii % 4 == 0) {
390               $tables .= '<tr id = "tr_noauth'.$ii.'">';
391           }
392           if (TRUE || !($user->flags & USER_FLAG_ISOLAUTH) || $ii < TABLES_AUTH_N) {
393               $tables .= '<td id = "td_noauth'.$ii.'">';
394
395               $tables .= '<div class="room_div"><div class="room_tit"><b>'.$mlang_room['tit_tabl'][$G_lang].$i.'</b></div>';
396               $tables .= sprintf('<div class="proxhr" id="table%d"></div>', $i);
397               $tables .= sprintf('<div class="table_act" id="table_act%d"></div>', $i);
398               $tables .= '</div>';
399               $tables .= '</td>'."\n";
400           }
401           if ($ii % 4 == 3) {
402               $tables .= '</tr>';
403           }
404       }
405       $tables .= '</table></div>';
406
407       $standup .= '<table class="room_standup"><tr><td><div class="room_standup_orig" id="room_standup_orig"></div>';
408       $standup .= '<div class="room_ex_standup">';
409       /* MLANG: "Giocatori in piedi" */
410       // $standup .= '<div id="room_tit"><span class="room_titin"><b>Giocatori in piedi</b> - <a target="_blank" href="weboftrust.php">Come ottenere user e password</a> - </span></div>';
411       $standup .= '<div id="room_tit"><span class="room_titin"><b>'.$mlang_room['standing'][$G_lang].'</b></span></div>';
412
413       $standup .= sprintf('<div id="standup" class="room_standup"></div>');
414       // MLANG Esco.
415       $standup .= '<div id="esco" class="esco"><input type="button" class="button" name="xreload"  value="Reload." onclick="act_reloadroom();"><input class="button" name="logout" value="'.$mlang_room['btn_exit'][$G_lang].'" onclick="esco_cb();" type="button"></div>';
416       $standup .= '</div></td></tr></table>';
417   }
418   
419   $altout_sponsor_arr = array( array ( 'id' => 'btn_altout',
420                                        'url' => 'http://www.alternativeoutput.it',
421                                        'content' => 'img/altout80x15.png',
422                                        'content_big' => 'img/logotxt_banner.png'),
423                                array ( 'id' => 'btn_virtualsky',
424                                        'url' => 'http://virtualsky.alternativeoutput.it',
425                                        'content' => 'img/virtualsky80x15a.gif',
426                                        'content_big' => 'img/virtualsky_big.png'),
427                                array ( 'id' => 'btn_dynamica',
428                                        'url' => 'http://www.dynamica.it',
429                                        'content' => 'img/dynamica.png',
430                                        'content_big' => 'img/dynamica_big.png')
431                                );
432   
433   $altout_support_arr = array( array ( 'id' => 'btn_brichi',
434                                        'url' => 'http://www.briscolachiamata.it',
435                                        'content' => 'img/brichi.png',
436                                        'content_big' => 'img/brichi_big.png'),
437                                array ( 'id' => 'btn_foroli',
438                                        'url' => 'http://www.forumolimpia.it',
439                                        'content' => 'img/forumolimpia.gif',
440                                        'content_big' => 'img/forumolimpia_big.png' ),
441                                array ( 'id'=> 'btn_niini',
442                                        'url' => 'http://www.niinivirta.it',
443                                        'content' => 'img/niinivirta.png',
444                                        'content_big' => 'img/niinivirta_big.png') );
445   
446   
447   
448   $altout_support = "";
449   $altout_support_big = "";
450   for ($i = 0 ; $i < 4 ; $i++) {
451       $ii = ($i < 3 ? $i : 0);
452       
453       $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>',
454                                  $i * 20, $altout_support_arr[$ii]['url'],
455                                  $altout_support_arr[$ii]['id'], $altout_support_arr[$ii]['content']);
456       
457       $altout_support_big .= sprintf('<img style="position: absolute;" class="nobohide" id="%s_big" src="%s">',
458                                      $altout_support_arr[$ii]['id'], $altout_support_arr[$ii]['content_big']);
459   }
460   
461   
462   // seed with microseconds since last "whole" second
463   // srand ((double) microtime() * 1000000);
464   // $randval = rand(0,count($altout_sponsor_arr)-1);
465   $altout_sponsor = "";
466   $altout_sponsor_big = "";
467   for ($i = 0 ; $i < 4 ; $i++) {
468       $ii = ($i < 3 ? $i : 0);
469       
470       $altout_sponsor .= 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>',
471                                  $i * 20, $altout_sponsor_arr[$ii]['url'],
472                                  $altout_sponsor_arr[$ii]['id'], $altout_sponsor_arr[$ii]['content']);
473       
474       $altout_sponsor_big .= sprintf('<img class="nobohide" id="%s_big" src="%s">',
475                                    $altout_sponsor_arr[$ii]['id'], $altout_sponsor_arr[$ii]['content_big']);
476   }
477   
478   
479   
480   /* NOTE: Brisk donate or donate fake if local */
481   if (!$G_is_local)
482       $brisk_donate = file_get_contents(FTOK_PATH."/brisk_donate.txt");
483   else
484       $brisk_donate = '<div style="background-color: #ff0; height: 27px; margin-top: 4px;">BRISK_DONATE</div>';
485
486   if ($brisk_donate == FALSE)
487       $brisk_donate = "";
488   
489   
490   /* MLANG: "briscola chiamata in salsa ajax", */
491   
492   mt_srand(make_seed());
493   if (!$G_is_local) {
494       $rn = rand(0, 1);
495       
496       if ($rn == 0) { 
497           $banner_top_left = '<script type="text/javascript"><!--
498 google_ad_client = "pub-5246925322544303";
499 google_ad_width = 234;
500 google_ad_height = 60;
501 google_ad_format = "234x60_as";
502 google_ad_type = "text_image";
503 google_ad_channel = "";
504 google_color_border = "808080";
505 google_color_bg = "f6f6f6";
506 google_color_link = "ffae00";
507 google_color_text = "404040";
508 google_color_url = "000000";
509 //-->
510 </script>
511 <script type="text/javascript"
512   src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
513 </script>';
514           $banner_top_right = carousel_top();
515       }
516       else { 
517           $banner_top_left = carousel_top();
518           $banner_top_right = '<script type="text/javascript"><!--
519 google_ad_client = "pub-5246925322544303";
520 google_ad_width = 234;
521 google_ad_height = 60;
522 google_ad_format = "234x60_as";
523 google_ad_type = "text_image";
524 google_ad_channel = "";
525 google_color_border = "808080";
526 google_color_bg = "f6f6f6";
527 google_color_link = "ffae00";
528 google_color_text = "404040";
529 google_color_url = "000000";
530 //-->
531 </script>
532 <script type="text/javascript"
533   src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
534 </script>';
535       }
536   }
537   else { // !$G_is_local
538       $banner_top_left  = carousel_top();
539       $banner_top_right = carousel_top();
540   }
541
542   $brisk_header_form = '<div class="container">
543 <!-- =========== header ===========  -->
544 <div id="header" class="header">
545 <table width="100%%" border="0" cols="3"><tr>
546 <td align="left"><div style="padding-left: 8px;">'.$banner_top_left.'</div></td>
547 <td align="center">'.(($G_with_topbanner || $G_with_donors) ? '<table><tr><td>' : '').'<div style="text-align: center;">
548     <img class="nobo" src="img/brisk_logo64.png">
549     '.$mlang_room['headline'][$G_lang].'<br>
550     </div>'.( ($G_with_topbanner || $G_with_donors) ? sprintf('</td><td>%s</td></tr></table>', 
551                                                                 ($G_with_topbanner ? $G_topbanner : 
552 "<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>
553 <td align="right"><div style="padding-right: 8px;">
554 '.$banner_top_right.'</div></td>
555 </tr></table>
556 </div>';
557
558 /* MLANG: ALL THE VERTICAL MENU */
559   $brisk_vertical_menu = '
560 <!--  =========== vertical menu ===========  -->
561 <div class="topmenu">
562 <!-- <a target="_blank" href="/briskhome.php"></a> -->
563
564 <div class="webstart_hilite">
565 <img class="nobo" style="cursor: pointer;" src="img/brisk_start.png" onmouseover="menu_hide(0,0); menu_show(\'menu_webstart\');">
566 <div class="webstart" id="menu_webstart" onmouseover="menu_over(1,this);" onmouseout="menu_over(-1,this);">
567
568 <a href="#" onmouseover="menu_hide(0,1);" title="'.$mlang_room['tit_help'][$G_lang].'" onclick="act_help();"
569    >'.$mlang_room['itm_help'][$G_lang].'</a><br>
570
571 <a target="_blank" href="http://www.alternativeoutput.it/briskhome.php" 
572    onmouseover="menu_hide(0,1);"
573    title="'.$mlang_room['tit_hpage'][$G_lang].'">homepage</a><br>
574
575 <a target="_blank" href="http://www.alternativeoutput.it/briskhome.php#cose" 
576    onmouseover="menu_hide(0,1);"
577    title="'.$mlang_room['tit_what'][$G_lang].'">'.$mlang_room['itm_what'][$G_lang].'</a><br>
578
579 <a target="_blank" href="'.$mlang_room['url_rules'][$G_lang].'" 
580    onmouseover="menu_hide(0,1);"
581    title="'.$mlang_room['tit_rules'][$G_lang].'">'.$mlang_room['itm_rules'][$G_lang].'</a><br>
582
583 <a target="_blank" href="http://www.alternativeoutput.it/briskhome.php#shots" 
584    onmouseover="menu_hide(0,1);"
585    title="'.$mlang_room['tit_shot'][$G_lang].'">screenshoots</a><br>
586
587 <a target="_blank" href="http://www.alternativeoutput.it/briskhome.php#comp" 
588    onmouseover="menu_hide(0,1);"
589    title="'.$mlang_room['tit_comp'][$G_lang].'">'.$mlang_room['itm_comp'][$G_lang].'</a><br>
590
591 <a target="_blank" href="http://www.alternativeoutput.it/briskhome.php#sources" 
592    onmouseover="menu_hide(0,1);"
593    title="'.$mlang_room['tit_src'][$G_lang].'">'.$mlang_room['itm_src'][$G_lang].'</a><br>
594
595 <a target="_blank" href="http://www.alternativeoutput.it/briskhome.php#mailing" 
596    onmouseover="menu_hide(0,1);"
597    title="'.$mlang_room['tit_ml'][$G_lang].'">'.$mlang_room['itm_ml'][$G_lang].'</a><br>
598
599 <a target="_blank" href="http://www.alternativeoutput.it/briskhome.php#prop" 
600    onmouseover="menu_hide(0,1);"
601    title="'.$mlang_room['tit_pro'][$G_lang].'">'.$mlang_room['itm_pro'][$G_lang].'</a><br>
602 <a href="#"
603    onmouseover="menu_hide(0,1);"
604    title="credits" onclick="act_about();">about</a><br>
605
606 <a href="mailto:brisk@alternativeoutput.it" 
607    onmouseover="menu_hide(0,1);"
608    title="'.$mlang_room['tit_mail'][$G_lang].'">'.$mlang_room['itm_mail'][$G_lang].'</a><br>
609
610 <hr>
611
612 <!--
613 <a href="#"
614    onmouseover="menu_hide(0,1);"
615    title="perchĆ© supportare brisk?" onclick="act_whysupport();">supportare?</a><br>
616 -->
617 <a href="#"
618    onmouseover="menu_hide(0,1);"
619    title="'.$mlang_room['tit_cla'][$G_lang].'" onclick="act_placing();">'.$mlang_room['itm_cla'][$G_lang].'</a><br>
620
621 <a target="_blank" href="briskin5/explain.php"
622    onmouseover="menu_hide(0,1);"
623    title="'.$mlang_room['tit_mnu'][$G_lang].'">'.$mlang_room['itm_mnu'][$G_lang].'</a><br>
624
625 <a href="#"
626    onmouseover="menu_hide(0,1);"
627    title="'.$mlang_room['tit_rmap'][$G_lang].'" onclick="act_roadmap();">'.$mlang_room['itm_rmap'][$G_lang].'</a><br>
628
629 <a href="#" title="'.$mlang_room['tit_meet'][$G_lang].'" 
630    onmouseover="menu_show(\'menu_meeting\');">'.$mlang_room['itm_meet'][$G_lang].'</a><br>
631
632 <div style="text-align: right;" id="menu_meeting" class="webstart">
633 <a href="http://it-it.facebook.com/event.php?eid=262482143080&index=1"
634    target="_blank" onmouseover="menu_hide(0,2);"
635    title="1Ā° Torneo-Meeting di Lodi del 21/02/2010" ><img style="display: inline;" class="nobo" src="img/coppa16.png">Lodi 02/10</a><br>
636
637 <a href="http://it-it.facebook.com/event.php?eid=165523204539&index=1"
638    target="_blank" onmouseover="menu_hide(0,2);"
639    title="1Ā° Torneo-Meeting di Parma del 22/11/2009" <img style="display: inline;" class="nobo" src="img/coppa16.png">Parma 11/09</a><br>
640
641 <a href="http://it-it.facebook.com/event.php?eid=105699129890&index=1"
642    target="_blank" onmouseover="menu_hide(0,2);"
643    title="BriskMeeting di Parma del 13/09/2009" >Parma 09/09</a><br>
644
645 <a href="http://it-it.facebook.com/event.php?eid=97829048656&index=1"
646    target="_blank" onmouseover="menu_hide(0,2);"
647    title="BriskMeeting di Clusane d\'Iseo del 5/07/2009" >Clusane 07/09</a><br>
648
649 <a href="http://it-it.facebook.com/event.php?eid=103366692570&index=1"
650    target="_blank" onmouseover="menu_hide(0,2);"
651    title="BriskMeeting Siciliano del 14/06/2009" >Catania 06/09</a><br>
652
653 <a href="http://it-it.facebook.com/event.php?eid=81488770852&index=1" 
654    target="_blank" onmouseover="menu_hide(0,2);"
655    title="BriskMeeting di Piacenza del 19/04/2009" >Piacenza 04/09</a><br>
656
657 <a href="http://it-it.facebook.com/event.php?eid=51159131399&index=1" 
658    target="_blank" onmouseover="menu_hide(0,2);"
659    title="BriskMeeting di Parma del 22/02/2009" >Parma 02/09</a><br>
660
661 <a href="http://www.anomalia.it/mop/photoo?album=brisk_pc0806" 
662    target="_blank" onmouseover="menu_hide(0,2);"
663    title="Raduno di Piacenza del del 15/06/2008" >Piacenza 06/08</a><br>
664
665 <a href="http://www.anomalia.it/mop/photoo" 
666    target="_blank" onmouseover="menu_hide(0,2);"
667    title="Torneo di Milano del 17/05/2008" >Milano 05/08</a><br>
668
669 </div>
670 </div>'. ($ACTION == "room" ? '<div style="padding: 0px; margin: 0px; witdh: 50px; height: 8px; font-size: 1px;"></div><img class="nobo" style="cursor: pointer;" src="img/brisk_commands'.langtolng($G_lang).'.png" onmouseover="menu_hide(0,0); menu_show(\'menu_commands\');">
671
672 <div class="webstart" id="menu_commands" onmouseover="menu_over(1,this);" onmouseout="menu_over(-1,this);">
673
674 <a href="#" title="'
675           // MLANG
676           .$mlang_room['tit_stat'][$G_lang].
677 '" 
678    onmouseover="menu_hide(0,1); menu_show(\'menu_state\');">'
679           // MLANG
680           .$mlang_room['stat_desc'][$G_lang].
681 '</a><br>
682 <div id="menu_state" class="webstart">
683 <a href="#"
684    onmouseover="menu_hide(0,2);"
685    title="" onclick="act_chatt(\'/st normale\'); menu_over(-1,this);">'
686           // MLANG
687           .$mlang_room['st_norm_desc'][$G_lang].
688 '</a><br>
689
690 <a href="#"
691    onmouseover="menu_hide(0,2);"
692    title="" onclick="act_chatt(\'/st pausa\'); menu_over(-1,this);">'
693           // MLANG
694           .$mlang_room['st_paus_desc'][$G_lang].
695 '&nbsp;<img class="unbo" src="img/st_pau.png"></a><br>
696
697 <a href="#"
698    onmouseover="menu_hide(0,2);"
699    title="" onclick="act_chatt(\'/st fuori\'); menu_over(-1,this);">'
700           // MLANG
701           .$mlang_room['st_out_desc'][$G_lang].
702 '&nbsp;<img class="unbo" src="img/st_out.png"></a><br>
703
704 <a href="#"
705    onmouseover="menu_hide(0,2);"
706    title="" onclick="act_chatt(\'/st cane\'); menu_over(-1,this);">'
707           // MLANG
708           .$mlang_room['st_dog_desc'][$G_lang].
709 '&nbsp;<img class="unbo" src="img/st_dog.png"></a><br>
710
711 <a href="#"
712    onmouseover="menu_hide(0,2);"
713    title="" onclick="act_chatt(\'/st cibo\'); menu_over(-1,this);">'
714           // MLANG
715           .$mlang_room['st_food_desc'][$G_lang].
716 '&nbsp;<img class="unbo" src="img/st_eat.png"></a><br>
717
718 <a href="#"
719    onmouseover="menu_hide(0,2);"
720    title="" onclick="act_chatt(\'/st lavoro\'); menu_over(-1,this);">'
721           // MLANG
722           .$mlang_room['st_work_desc'][$G_lang].
723 '&nbsp;<img class="unbo" src="img/st_wrk.png"></a><br>
724
725 <a href="#"
726    onmouseover="menu_hide(0,2);"
727    title="" onclick="act_chatt(\'/st sigaretta\'); menu_over(-1,this);">'
728           // MLANG
729           .$mlang_room['st_smok_desc'][$G_lang].
730 '&nbsp;<img class="unbo" src="img/st_smk.png"></a><br>
731
732 <a href="#"
733    onmouseover="menu_hide(0,2);"
734    title="" onclick="act_chatt(\'/st presente\'); menu_over(-1,this);">'
735           // MLANG
736           .$mlang_room['st_pres_desc'][$G_lang].
737 '&nbsp;<img class="unbo" src="img/st_eye.png"></a><br>
738
739 <a href="#"
740    onmouseover="menu_hide(0,2);"
741    title="" onclick="act_chatt(\'/st coniglio\'); menu_over(-1,this);">'
742           // MLANG
743           .$mlang_room['st_rabb_desc'][$G_lang].
744 '&nbsp;<img class="unbo" src="img/st_rabbit.png"></a><br>
745
746 <a href="#"
747    onmouseover="menu_hide(0,2);"
748    title="" onclick="act_chatt(\'/st calcio\'); menu_over(-1,this);">'
749           // MLANG
750           .$mlang_room['st_socc_desc'][$G_lang].
751 '&nbsp;<img class="unbo" src="img/st_soccer.png"></a><br>
752
753 <a href="#"
754    onmouseover="menu_hide(0,2);"
755    title="" onclick="act_chatt(\'/st pupo\'); menu_over(-1,this);">'
756           // MLANG
757           .$mlang_room['st_baby_desc'][$G_lang].
758 '&nbsp;<img class="unbo" src="img/st_baby.png"></a><br>
759
760 <a href="#"
761    onmouseover="menu_hide(0,2);"
762    title="" onclick="act_chatt(\'/st pulizie\'); menu_over(-1,this);">'
763           // MLANG
764           .$mlang_room['st_mop_desc'][$G_lang].
765 '&nbsp;<img class="unbo" src="img/st_mop.png"></a><br>
766
767 <a href="#"
768    onmouseover="menu_hide(0,2);"
769    title="" onclick="act_chatt(\'/st babbo\'); menu_over(-1,this);">'
770           // MLANG
771           .$mlang_room['st_babbo_desc'][$G_lang].
772 '&nbsp;<img class="unbo" src="img/st_babbo.png"></a><br>
773
774 <a href="#"
775    onmouseover="menu_hide(0,2);"
776    title="" onclick="act_chatt(\'/st renna\'); menu_over(-1,this);">'
777           // MLANG
778           .$mlang_room['st_renna_desc'][$G_lang].
779 '&nbsp;<img class="unbo" src="img/st_renna.png"></a><br>
780
781 <a href="#"
782    onmouseover="menu_hide(0,2);"
783    title="" onclick="act_chatt(\'/st pupazzo\'); menu_over(-1,this);">'
784           // MLANG
785           .$mlang_room['st_pupaz_desc'][$G_lang].
786 '&nbsp;<img class="unbo" src="img/st_pupaz.png"></a><br>
787
788 <a href="#"
789    onmouseover="menu_hide(0,2);"
790    title="" onclick="act_chatt(\'/st vischio\'); menu_over(-1,this);">'
791           // MLANG
792           .$mlang_room['st_visch_desc'][$G_lang].
793 '&nbsp;<img class="unbo" src="img/st_visch.png"></a><br>
794
795 </div>
796
797 <a href="#" title="avvia un ticker pubblicitario per il tuo tavolo" 
798    onmouseover="menu_hide(0,1);" onclick="act_chatt(\'/tav \'+$(\'txt_in\').value); menu_over(-1,this);">ticker &nbsp;<img class="unbo" src="img/train.png"></a><br>
799
800 <a href="#" title="'
801           // MLANG garantisci per un tuo conoscente
802           .$mlang_room['warr_desc'][$G_lang].
803 '" 
804    onmouseover="menu_hide(0,1);" onclick="act_chatt(\'/authreq\'); menu_over(-1,this);">'
805           // MLANG garantisci
806           .$mlang_room['itm_warr'][$G_lang].
807           '</a><br>
808
809
810
811 <a href="#" title="'
812           // MLANG garantisci per un tuo conoscente
813           .$mlang_room['splash_desc'][$G_lang].
814 '" 
815    onmouseover="menu_hide(0,1);" onclick="act_splash(); menu_over(-1,this);">'
816           // MLANG garantisci
817           .$mlang_room['tit_splash'][$G_lang].
818           '</a><br>
819 '.($user->is_auth() ? '
820 <a href="#" title="'
821           // MLANG garantisci per un tuo conoscente
822           .$mlang_room['prefs_desc'][$G_lang].'"
823    onmouseover="menu_hide(0,1);" onclick="$(\'preferences\').style.visibility = \'visible\'; menu_over(-1,this);">'
824           // MLANG garantisci
825    .$mlang_room['tit_prefs'][$G_lang].'</a><br>' : '').'
826
827 </div>'.($G_with_poll ? '' : '<div style="padding: 0px; margin: 0px; witdh: 50px; height: 8px; font-size: 1px;"></div>
828 <img style="cursor: pointer;" class="nobo" src="img/brisk_help'.langtolng($G_lang).'.png" title="'.$mlang_room['tit_help'][$G_lang].'" onmouseover="menu_hide(0,0);" onclick="act_help();">').'
829 <div style="padding: 0px; margin: 0px; witdh: 50px; height: 8px; font-size: 1px;"></div>
830 '.($user->flags & USER_FLAG_AUTH ? '
831 <img style="cursor: pointer;" class="nobo" src="img/brisk_signal'.langtolng($G_lang).'.png" title="'.$mlang_room['tit_mesg'][$G_lang].'" onmouseover="menu_hide(0,0);" onclick="act_chatt(\'/mesgtoadm\');">'.poll_dom()
832  : '
833 <img style="cursor: pointer;" class="nobo" src="img/brisk_password.png" title="Come ottenere una password su Brisk." onmouseover="menu_hide(0,0);" onclick="act_passwdhowto();">
834 ').'
835
836 ' : '').'
837
838 </div>
839 <div style="padding: 0px; margin: 0px; witdh: 50px; height: 8px; font-size: 1px;"></div>
840 sponsored by:<br>
841 <div style="padding: 0px; margin: 0px; witdh: 50px; height: 4px; font-size: 1px;"></div>
842 <div id="spon_caro" style="overflow: hidden; height: 18px; /* border: 1px solid red; */ ">
843 <div style="/*background-color: green; */ text-align: left; position: relative; padding: 0px; margin: 0px; top: 0px; height: 80px;">'.$altout_sponsor.'<br>
844 </div></div>
845 <div style="position: absolute;">
846 '.$altout_sponsor_big.'
847 </div>
848 <div style="padding: 0px; margin: 0px; witdh: 50px; height: 8px; font-size: 1px;"></div>
849 supported by:<br>
850 <div style="padding: 0px; margin: 0px; witdh: 50px; height: 4px; font-size: 1px;"></div>
851 <div id="supp_caro" style="overflow: hidden; height: 18px; /* border: 1px solid red; */">
852 <div style="/* background-color: green; */ text-align: left; position: relative; padding: 0px; margin: 0px; top: 0px; height: 80px;">'.$altout_support.'<br> 
853
854 </div>
855 </div>
856 <div style="position: absolute;">
857 '.$altout_support_big.'
858 </div>
859 <a style="/* position: absolute; top: 40px; left: 6px;" */ target="_blank" href="http://it-it.facebook.com/group.php?gid=59742820791"><img class="nobo" id="btn_facebook" src="img/facebook_btn.png" title="unisciti al gruppo \'quelli della brisk\'"></a>
860 ' . ( /* NOTE: here facebook or fake facebook */
861 ! $G_is_local ?
862 '<div class="fb-like" style="margin-top: 4px;" data-href="https://www.facebook.com/pages/Brisk-briscola-chiamata-in-salsa-ajax/716026558416911" data-share="false" data-send="true" data-width="70" data-show-faces="false" data-colorscheme="dark" layout="button_count"></div>
863 ' : '<div style="margin-top: 4px; height: 20px; background-color: #00f;">FACEBOOK HERE</div>
864 ' ) . '<div id="proflashext" class="proflashext"><div id="proflash" class="proflash"></div></div>
865 <img id="stm_stat" class="nobo" style="margin-top: 4px;" src="img/line-status_b.png">
866 %s
867 %s
868 </div>';
869     
870   /* Templates. */
871   if ($ACTION == 'login') {
872       $header_out['Content-type'] = "text/html; charset=\"utf-8\"";
873 ?>
874 <html>
875 <head>
876 <title>Brisk</title>
877 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
878 <link rel="shortcut icon" href="img/brisk_ico.png">
879 <script type="text/javascript" src="commons.js"></script> 
880 <script type="text/javascript" src="prefs.js"></script>
881 <!-- <script type="text/javascript" src="myconsole.js"></script> -->
882 <script type="text/javascript" src="menu.js"></script>
883 <script type="text/javascript" src="heartbit.js"></script>
884 <script type="text/javascript" src="xynt-streaming.js"></script>
885 <script type="text/javascript" src="preload_img<?php echo langtolng($G_lang); ?>.js"></script>
886 <script type="text/javascript" src="AC_OETags.js"></script>
887 <script type="text/javascript" src="room.js"></script>
888 <script type="text/javascript" src="md5.js"></script>
889 <script type="text/javascript" src="probrowser.js"></script>
890 <script type="text/javascript" src="json2.js"></script>
891 <link rel="stylesheet" type="text/css" href="brisk.css">
892 <link rel="stylesheet" type="text/css" href="room.css">
893
894 <SCRIPT type="text/javascript"><!--
895    var g_debug = 0;
896    var g_lang = "<? echo $G_lang; ?>";
897    var g_lng = "<? echo $G_lng; ?>";
898    var g_tables_n = <? echo TABLES_N; ?>;
899    var g_tables_auth_n = <? echo TABLES_AUTH_N; ?>;
900    var g_tables_cert_n = <? echo TABLES_CERT_N; ?>;
901    var g_prefs, g_prefs_new = null;
902    var g_listen;
903    var g_withflash = false;
904    var g_is_spawn = 0;
905    var g_nd = null;
906    var g_brow = null;
907    var gst  = new globst();
908    var topbanner_sfx, topbanner_dx;
909    var xstm = null;
910    var sess = "not_connected";
911    var spo_slide, sup_slide;
912
913    window.onload = function() {
914      // alert(window.onbeforeunload);
915      g_brow = get_browser_agent();
916
917      g_prefs = new client_prefs(null);
918
919      spo_slide  = new sideslide($('spon_caro'), 80, 20);
920      sup_slide  = new sideslide($('supp_caro'), 80, 20);
921
922      login_init();
923 <?php
924      if ($G_with_topbanner) {
925        printf("     topbanner_init();\n");
926     }
927      if ($G_with_sidebanner) {
928        printf("     sidebanner_init();\n");
929     }
930      if ($G_with_sidebanner2) {
931        printf("     sidebanner2_init();\n");
932     }
933 ?>
934
935      g_withflash = DetectFlashVer(6,0,0);
936      if (g_withflash == false) {
937        $("proflash").innerHTML = 'Audio con Flash.<br><a href="http://www.macromedia.com/"><img class="nobo" style="padding: 4px; width:73; height: 19;" src="img/download_now_flash.gif"></a>';
938      }
939      else
940        $("proflashext").innerHTML = "";
941      $("nameid").focus();
942    }
943    //-->
944 </SCRIPT>
945 </head>
946 <?php
947     if (!$G_is_local) {
948 ?>
949 <!-- if myconsole <body onunload="deconsole();"> -->
950 <body xmlns:fb="http://ogp.me/ns/fb#">
951 <div id="fb-root"></div>
952 <script>(function(d, s, id) {
953   var js, fjs = d.getElementsByTagName(s)[0];
954   if (d.getElementById(id)) return;
955   js = d.createElement(s); js.id = id;
956   js.src = "//connect.facebook.net/it_IT/all.js#xfbml=1";
957   fjs.parentNode.insertBefore(js, fjs);
958 }(document, 'script', 'facebook-jssdk'));</script>
959 <?php
960     }
961     else {
962 ?>
963 <body>
964 <?php
965   }
966 ?>
967 <?php
968     printf($brisk_header_form);
969     printf("<table class=\"floaty\"><tr><td class=\"floatyleft\">\n");
970     printf($brisk_vertical_menu, '', '');
971
972    if ($G_with_sidebanner xor $G_with_sidebanner2) {
973      printf("<br><br>");
974    }
975
976    if ($G_with_sidebanner) {
977      printf("%s", $G_sidebanner);
978    }
979
980
981    if ($G_with_sidebanner2) {
982      printf("%s", $G_sidebanner2);
983    }
984    printf("</td><td>");
985 ?> 
986
987 <!--  =========== tables ===========  -->
988 <?php
989
990 /* MLANG: "Digita il tuo nickname per accedere ai tavoli della briscola.", "entra", "Se non hai ancora una password, lascia il campo in bianco ed entra." ,"(se usi firefox e qualcosa non funziona prova a ricaricare la pagina con Ctrl + F5)" */
991 echo "$body"; ?>
992 <br>
993 <div style="text-align: center;">
994    <br><br><br>
995 <?php echo $mlang_room['welcome'][$G_lang];?>
996 <br><br>
997 <form accept-charset="utf-8" method="post" action="" onsubmit="return j_login_manager(this);">
998 <input id="passid_private" name="pass_private" type="hidden" value="">
999 <table class="login">
1000 <tr><td>user:</td>
1001 <td><input id="nameid" class="input_text" name="name" type="text" size="24" maxlength="12" value=""></td></tr>
1002 <tr><td>pwd:</td>
1003 <td><input id="passid" class="input_text" name="pass" type="password" size="24" maxlength="64" value=""></td></tr>
1004 <tr><td colspan="2"><input id="sub" value="<?php echo $mlang_room['btn_enter'][$G_lang];?>" type="submit" class="button"></td></tr>
1005 </table>
1006 </form><br>
1007 <b><?php echo $mlang_room['passwarn'][$G_lang];?></b><br><br>
1008 <?php echo $mlang_room['browwarn'][$G_lang];?><br>
1009 </div>
1010 <br><br><br><br>
1011 <br><br><br><br>
1012 <br><br><br><br>
1013 <br><br><br><br>
1014 <br><br><br><br>
1015
1016 <div id="imgct"></div>
1017 <div id="logz"></div>
1018 <div id="sandbox"></div>
1019 <div id="sandbox2"></div>
1020 <div id="response"></div>
1021 <div id="xhrstart"></div>
1022 <pre>
1023 <div id="xhrlog"></div>
1024 </pre>
1025 <div id="xhrdeltalog"></div>
1026 </body>
1027 </html>
1028 <?php
1029   }
1030   else if ($ACTION == 'room') {
1031       $header_out['Content-type'] = "text/html; charset=\"utf-8\"";
1032   ?>
1033 <html>
1034 <head>
1035 <title>Brisk</title>
1036 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
1037 <link rel="shortcut icon" href="img/brisk_ico.png">
1038 <script type="text/javascript" src="commons.js"></script>
1039 <script type="text/javascript" src="prefs.js"></script>
1040 <!-- <script type="text/javascript" src="myconsole.js"></script> -->
1041 <script type="text/javascript" src="menu.js"></script>
1042 <script type="text/javascript" src="ticker.js"></script>
1043 <script type="text/javascript" src="heartbit.js"></script>
1044 <script type="text/javascript" src="xynt-streaming.js"></script>
1045 <script type="text/javascript" src="room.js"></script>
1046 <script type="text/javascript" src="preload_img<?php echo langtolng($G_lang); ?>.js"></script>
1047 <script type="text/javascript" src="AC_OETags.js"></script>
1048 <script type="text/javascript" src="probrowser.js"></script>
1049 <script type="text/javascript" src="json2.js"></script>
1050 <link rel="stylesheet" type="text/css" href="brisk.css">
1051 <link rel="stylesheet" type="text/css" href="room.css">
1052 <SCRIPT type="text/javascript"><!--
1053    var sess = "not_connected";
1054    var g_debug = 0;
1055    var g_lang = "<? echo $G_lang; ?>";
1056    var g_lng = "<? echo $G_lng; ?>";
1057    var g_tables_n = <? echo TABLES_N; ?>;
1058    var g_tables_auth_n = <? echo TABLES_AUTH_N; ?>;
1059    var g_tables_cert_n = <? echo TABLES_CERT_N; ?>;
1060    var g_prefs, g_prefs_new = null;
1061    var g_listen;
1062    var g_is_spawn = 0;
1063    var g_withflash = false;
1064    var g_imgct = 0;
1065    var g_imgtot = g_preload_img_arr.length;
1066    var g_brow = null;
1067    var g_nd = null;
1068    var tra = null;
1069    var stat = "";
1070    var subst = "";
1071    var gst  = new globst();
1072    var topbanner_sfx, topbanner_dx;
1073    // var nonunload = false;
1074    var spo_slide, sup_slide;
1075
1076    window.onload = function() {
1077      g_brow = get_browser_agent();
1078
1079      g_prefs = new client_prefs(null);
1080
1081      spo_slide  = new sideslide($('spon_caro'), 80, 20);
1082      sup_slide  = new sideslide($('supp_caro'), 80, 20);
1083
1084 <?php
1085 if ($BRISK_SHOWHTML == "debugtable") {
1086 ?>
1087      room_checkspace(12, <?php echo TABLES_N; ?>, 50);
1088 <?php
1089 }
1090 else {
1091 ?>
1092     // alert("INDEX START");
1093      menu_init();
1094 <?php
1095      if ($G_with_topbanner) {
1096        printf("     topbanner_init();\n");
1097      }
1098      if ($G_with_sidebanner) {
1099        printf("     sidebanner_init();\n");
1100     }
1101      if ($G_with_sidebanner2) {
1102        printf("     sidebanner2_init();\n");
1103     }
1104
1105 ?>
1106      sess = "<?php echo "$sess"; ?>";
1107 xstm = new xynt_streaming(window, "<?php echo "$transp_type"; ?>", 80, 2, null /* console */, gst, 'index_php', 'sess', sess, $('sandbox'), 'index_rd.php', function(com){eval(com);});
1108      xstm.hbit_set(heartbit);
1109      tra = new train($('room_tit'));
1110      window.onunload = onunload_cb;
1111      window.onbeforeunload = onbeforeunload_cb;
1112      g_withflash = DetectFlashVer(6,0,0);
1113      if (g_withflash == false) {
1114        $("proflash").innerHTML = 'Audio con Flash.<br><a href="http://www.macromedia.com/"><img class="nobo" style="padding: 4px; width:73; height: 19;" src="img/download_now_flash.gif"></a>';
1115      }
1116      else
1117        $("proflashext").innerHTML = "";
1118
1119      // console.log("session from main: "+sess);
1120      xstm.start();
1121      // alert("ARR LENGTH "+g_preload_img_arr.length);
1122      // FIXME: preload image will be fired by stream instead here
1123      // setTimeout(preload_images, 0, g_preload_img_arr, g_imgct); 
1124      $("txt_in").focus();
1125 <?php
1126 if ($is_login) {
1127   /* MLANG: "<br>Il nickname che stai usando &egrave; gi&agrave; registrato,<br><br>se il suo proprietario si autentificher&agrave;<br><br>verrai rinominato d'ufficio come ghost<i>N</i>.", "torna ai tavoli" */
1128   echo show_notify($mlang_room['regwarn'][$G_lang], 0, $mlang_room['btn_rettabs'][$G_lang], 400, 150);
1129 }
1130 ?>
1131 <?php
1132 }
1133 ?>
1134    }
1135    //-->
1136 </SCRIPT>
1137 </head>
1138 <?php
1139     if (!$G_is_local) {
1140 ?>
1141 <!-- if myconsole <body onunload="deconsole();"> -->
1142 <body xmlns:fb="http://ogp.me/ns/fb#">
1143 <div id="fb-root"></div>
1144 <script>(function(d, s, id) {
1145   var js, fjs = d.getElementsByTagName(s)[0];
1146   if (d.getElementById(id)) return;
1147   js = d.createElement(s); js.id = id;
1148   js.src = "//connect.facebook.net/it_IT/all.js#xfbml=1";
1149   fjs.parentNode.insertBefore(js, fjs);
1150 }(document, 'script', 'facebook-jssdk'));</script>
1151 <?php
1152     }
1153     else {
1154 ?>
1155 <body>
1156 <?php
1157   }
1158 ?>
1159 <?php
1160    printf($brisk_header_form);
1161    printf("<table class=\"floaty\"><tr><td class=\"floatyleft\">\n");
1162    printf($brisk_vertical_menu, '', $brisk_donate);
1163
1164
1165    if ($G_with_sidebanner xor $G_with_sidebanner2) {
1166      printf("<br><br>");
1167    }
1168
1169    if ($G_with_sidebanner) {
1170      printf("%s", $G_sidebanner);
1171    }
1172
1173
1174    if ($G_with_sidebanner2) {
1175      printf("%s", $G_sidebanner2);
1176    }
1177
1178    printf("</td><td>");
1179 ?>
1180 <!--  =========== tables ===========  -->
1181 <input name="sess" type="hidden" value="<?php echo "$user->sess"; ?>">
1182 <table class="macro"><tr><td>
1183 <?php echo "$tables"; ?>
1184 </td></tr><tr><td>
1185     <?php echo "$standup"; ?>
1186 </td></tr></table>
1187 </td></tr></table>
1188
1189 <!--  =========== bottom ===========  -->
1190     <div id="bottom" class="bottom">
1191 <b>Chat</b> <span id="list_info" style="color: red;"></span><br>
1192 <div id="txt" class="chatt">
1193 </div>
1194 <div style="text-align: center; ">
1195     <!-- MLANG: scrivi un invito al tavolo e clicca -->
1196     <table style="width: 98%; margin: auto;"><tr><td id="tickbut" class="tickbut"><img class="tickbut" src="img/train.png" onclick="act_tav();" title="<?php echo $mlang_room['tit_ticker'][$G_lang];?>"></td><td style="width:1%; text-align: center;">
1197     <div id="myname"></div>
1198     </td><td>
1199     <input id="txt_in" maxlength="128" type="text" style="width: 100%;" onkeypress="chatt_checksend(this,event);">
1200     </td></tr></table>
1201 </div>
1202 </div>
1203
1204     <div id="authbox" class="notify" style="text-align: center;">
1205        <br>
1206        <b>
1207     <!-- MLANG: Garantisci per un tuo conoscente: -->
1208     <?php echo $mlang_room['tit_warr'][$G_lang]; ?>
1209 </b>
1210        <br><br>
1211
1212        <form id="auth_form" accept-charset="utf-8" method="post" action="" onsubmit="return j_authbox(this);">
1213        <input type="hidden" name="realsub" value="666">
1214 <table class="login">
1215 <tr><td>nickname:</td>
1216 <td><input id="nameid" class="input_text" name="name" type="text" size="24" maxlength="12" value=""></td></tr>
1217 <tr><td>e-mail:</td>
1218 <td><input id="emailid" class="input_text" name="email" type="text" size="24" maxlength="1024" value=""></td></tr>
1219 <tr><td colspan="2" style="text-align: center;">
1220     <!-- MLANG: Garantisci per un tuo conoscente: -->
1221        <input id="subid" name="sub" value=
1222 "<?php echo $mlang_room['btn_send'][$G_lang]; ?>"
1223  type="submit" onclick="this.form.elements['realsub'].value = 'invia';" class="button">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
1224     <!-- MLANG: Garantisci per un tuo conoscente: -->
1225 <input id="cloid" name="clo" value=
1226 "<?php echo $mlang_room['btn_close'][$G_lang]; ?>" 
1227 type="submit" class="button" onclick="this.form.elements['realsub'].value = 'chiudi';"></td></tr>
1228 </table>
1229     </form>
1230     </div>
1231     <div id="mesgtoadmbox" class="notify_opaque" style="text-align: center;">
1232        <br>
1233 <!--MLANG: Invia un messaggio o una segnalazione all\'amministratore: -->
1234        <b><?php echo $mlang_room['mesgtoadm_tit'][$G_lang];?></b>
1235        <br><br>
1236        <form id="mesgtoadm_form" accept-charset="utf-8" method="post" action="" onsubmit="return j_mesgtoadmbox(this);">
1237        <input type="hidden" name="realsub" value="666">
1238 <table class="login">
1239 <!--MLANG: soggetto -->
1240 <tr><td><b><?php echo $mlang_room['mesgtoadm_sub'][$G_lang];?></b></td>
1241 <td><input id="subjid" class="input_text" name="subj" type="text" size="32" maxlength="255" value=""></td></tr></table>
1242 <table class="login">
1243 <tr><td><img title="messaggio" class="nobo" src="img/mesgtoadm_mesg<?php echo $G_lng;?>.png"></td>
1244 <td><textarea id="mesgid" class="input_text" name="mesg" cols="40" rows="8" wrap="soft"></textarea></td></tr>
1245 <tr><td colspan="2" style="text-align: center;">
1246        <input id="subid" name="sub" value="<?php echo $mlang_room['btn_send'][$G_lang];?>" type="submit" onclick="this.form.elements['realsub'].value = 'invia';" class="button">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
1247 <input id="cloid" name="clo" value="<?php echo $mlang_room['btn_close'][$G_lang];?>" type="submit" class="button" onclick="this.form.elements['realsub'].value = 'chiudi';"></td></tr>
1248 </table>
1249     </form>
1250     </div>
1251 <div id="heartbit"></div>
1252 <div id="sandbox"></div>
1253 <div id="imgct"></div>
1254 <div id="logz"></div>
1255 <div id="sandbox2"></div>
1256 <div id="response"></div>
1257 <div id="remark"></div>
1258 <div id="xhrstart"></div>
1259 <div id="xhrlog"></div>
1260 <div id="xhrdeltalog"></div>
1261 </div>
1262 <div id="preferences" class="notify" style="z-index: 200; width: 600px; margin-left: -300px; height: 240px; top: 150px; visibility: hidden;">
1263 <div id="preferences_child" style="border-bottom: 1px solid gray; overflow: auto; height: 370px;">
1264
1265 <h2><?php echo $mlang_room['tit_prefs'][$G_lang]; ?></h2>
1266 <table style="margin: auto;"><tr><td style="vertical-align: top;">
1267 <!--#
1268     #  LISTEN
1269     #-->
1270 <div style="float: left; padding: 8px;">
1271 <table style="border: 1px solid gray;"><tr><th style="background-color: #cccccc;">
1272 <?php echo $mlang_room['itm_list'][$G_lang];?>
1273 </th></tr>
1274 <tr><td><input style="vertical-align: bottom;" id="ra_listen_all" type="radio" name="listen" value="0" onclick="prefs_update('listen');" title="'
1275 <?php echo $mlang_room['listall_desc'][$G_lang];?>
1276 '"><span id="list_all">
1277 <?php echo $mlang_room['tit_listall'][$G_lang];?>
1278 </span></td></tr>
1279 <tr><td><input style="vertical-align: bottom;" id="ra_listen_auth" type="radio" name="listen" value="1" onclick="prefs_update('listen');" title="'
1280 <?php echo $mlang_room['listaut_desc'][$G_lang];?>
1281 '"><span id="list_auth">
1282 <?php echo $mlang_room['tit_listaut'][$G_lang];?>
1283 </span></td></tr>
1284 <tr><td><input style="vertical-align: bottom;" id="ra_listen_isol" type="radio" name="listen" value="2" onclick="prefs_update('listen');" title="'
1285 <?php echo $mlang_room['listisol_desc'][$G_lang];?>
1286 '"><span id="list_isol">
1287 <?php echo $mlang_room['tit_listisol'][$G_lang];?>
1288 </span></td></tr>
1289 </table>
1290 </div>
1291 <?php
1292 if ($user->is_supp_custom()) {
1293 ?>
1294 </td>
1295 <td style="vertical-align: top;">
1296 <!--#
1297     #  SUPPORTER ONLY
1298     #-->
1299 <div style="float: left; padding: 8px;">
1300 <table style="border: 1px solid gray;"><tr><th colspan="4" style="background-color: #cccccc;">
1301 <?php echo $mlang_room['suppcomp_tit'][$G_lang];?>
1302 </th></tr>
1303 <tr>
1304 <th>
1305 <?php echo $mlang_room['suppcomp_fg'][$G_lang];?>
1306 </th><td><input style="width: 3em;" id="s_fg_r" type="text" maxlength="3" size="3" name="s_fg_r"
1307  onchange="prefs_update('supp');" value="255"
1308  title="'<?php echo $mlang_room['suppcomp_range'][$G_lang];?>'">
1309    <span id="list_all"><?php echo $mlang_room['suppcomp_r'][$G_lang];?></span></td>
1310 <td><input style="width: 3em;" id="s_fg_g" type="text" maxlength="3" size="3" name="s_fg_g"
1311  onchange="prefs_update('supp');" value="255"
1312  title="'<?php echo $mlang_room['suppcomp_range'][$G_lang];?>'">
1313    <span id="list_all"><?php echo $mlang_room['suppcomp_g'][$G_lang];?></span></td>
1314 <td><input style="width: 3em;" id="s_fg_b" type="text" maxlength="3" size="3" name="s_fg_b"
1315  onchange="prefs_update('supp');" value="255"
1316  title="'<?php echo $mlang_room['suppcomp_range'][$G_lang];?>'">
1317    <span id="list_all"><?php echo $mlang_room['suppcomp_b'][$G_lang];?></span></td>
1318 </tr>
1319 <tr>
1320 <th>
1321 <?php echo $mlang_room['suppcomp_bg'][$G_lang];?>
1322 </th>
1323 <td><input style="width: 3em;" id="s_bg_r" type="text" maxlength="3" size="3" name="s_bg_r"
1324  onchange="prefs_update('supp');" value="255"
1325  title="'<?php echo $mlang_room['suppcomp_range'][$G_lang];?>'">
1326    <span id="list_all"><?php echo $mlang_room['suppcomp_r'][$G_lang];?></span></td>
1327 <td><input style="width: 3em;" id="s_bg_g" type="text" maxlength="3" size="3" name="s_bg_g"
1328  onchange="prefs_update('supp');" value="255"
1329  title="'<?php echo $mlang_room['suppcomp_range'][$G_lang];?>'">
1330    <span id="list_all"><?php echo $mlang_room['suppcomp_g'][$G_lang];?></span></td>
1331 <td><input style="width: 3em;" id="s_bg_b" type="text" maxlength="3" size="3" name="s_bg_b"
1332  onchange="prefs_update('supp');" value="255"
1333  title="'<?php echo $mlang_room['suppcomp_range'][$G_lang];?>'">
1334    <span id="list_all"><?php echo $mlang_room['suppcomp_b'][$G_lang];?></span></td>
1335 </tr>
1336 <tr><td colspan="4" style="text-align: center;">
1337 <img id="s_img" class="nobo" src="img/noimg.png">
1338 </td></tr>
1339 </table>
1340 </div>
1341 </td>
1342 <td>
1343 <?php
1344 }
1345 else {
1346 ?>
1347 <input id="s_fg_r" type="hidden" name="s_fg_r">
1348 <input id="s_fg_g" type="hidden" name="s_fg_g">
1349 <input id="s_fg_b" type="hidden" name="s_fg_b">
1350 <input id="s_bg_r" type="hidden" name="s_bg_r">
1351 <input id="s_bg_g" type="hidden" name="s_bg_g">
1352 <input id="s_bg_b" type="hidden" name="s_bg_b">
1353 <input id="s_img"  type="hidden" name="s_bg_b">
1354 <?php
1355 }
1356 ?>
1357 </td></tr></table>
1358 <div style="width: 95%; /* background-color: red; */ margin: auto; text-align: left;">
1359 <br><br>
1360                                                           <!-- <input type="checkbox" name="pref_ring_endauct" id="pref_ring_endauct" onclick="pref_ring_endauct_set(this);"><?php /* echo $mlang_room['itm_ringauc'][$G_lang]; */ ?> -->
1361 </div>
1362
1363
1364 </div>
1365 <div class="notify_clo">
1366 <input type="submit" class="input_sub" style="bottom: 4px;" onclick="$('preferences').style.visibility = 'hidden';" value="<?php echo $mlang_room['btn_prefs_close'][$G_lang]; ?>"/> 
1367 <input type="submit" class="input_sub" style="bottom: 4px;" onclick="prefs_reset();" value="<?php echo $mlang_room['btn_prefs_reset'][$G_lang]; ?>"/>
1368 <input type="submit" class="input_sub" style="bottom: 4px;" onclick="prefs_save();" value="<?php echo $mlang_room['btn_prefs_save'][$G_lang]; ?>"/>
1369 </div>
1370 </div>
1371 </body>
1372 </html>
1373 <?php
1374    }
1375 }
1376
1377 ?>