X-Git-Url: https://mop.ddnsfree.com/gitweb/?p=brisk.git;a=blobdiff_plain;f=web%2Findex.php;h=cbdca2cc57e45777f3b3cc3199257a8b86cbba23;hp=9486808fbcda0e0e11bb828f256396473de807d4;hb=01399c6a3c1c0cc4bbefce5765d5157998812b4d;hpb=131fa3f1c1c059e7a7aa9e485d29cb5249b0901f diff --git a/web/index.php b/web/index.php index 9486808..cbdca2c 100644 --- a/web/index.php +++ b/web/index.php @@ -25,16 +25,17 @@ require_once("Obj/user.phh"); require_once("Obj/brisk.phh"); require_once("Obj/auth.phh"); -require_once("Obj/proxyscan.phh"); -$mlang_room = array( 'userpasserr' => array('it' => 'Utente e/o password errati.', - 'en' => 'Wrong user and/or password.'), - 'userpassmust' => array('it' => 'Il nickname deve contenere almeno una lettera o una cifra.', - 'en' => 'The nickname have to contain at least one letter or one number.'), +$mlang_room = array( 'userpassuse' => array('it' => 'Il tuo nickname è già in uso.', + 'en' => 'Your nickname is already in use.'), 'userpassend' => array('it' => 'Spiacenti, non ci sono più posti liberi. Riprova più tardi.', 'en' => 'We are sorry, there aren\'t free place. Try again later.'), - 'userpassuse' => array('it' => 'Il tuo nickname è già in uso.', - 'en' => 'Your nickname is already in use.'), + 'userpassmust' => array('it' => 'Il nickname deve contenere almeno una lettera o una cifra.', + 'en' => 'The nickname have to contain at least one letter or one number.'), + 'userpasserr' => array('it' => 'Utente e/o password errati.', + 'en' => 'Wrong user and/or password.'), + 'userpassban' => array('it' => 'Il tuo indirizzo IP è stato bannato perché precedentemente utilizzato da qualche molestatore.', + 'en' => 'Your IP address is banned because trolling activity was detected from it.'), 'standing' => array('it' => 'Giocatori in piedi', 'en' => 'Standing players'), 'headline' => array('it' => 'briscola chiamata in salsa ajax', @@ -51,10 +52,15 @@ $mlang_room = array( 'userpasserr' => array('it' => 'Utente e/o password errati 'en' => 'EN Abbiamo perso le tue tracce mentre stavi giocando, quindi ti abbiamo disconnesso.'), 'reas_anon' => array('it' => 'L\' accesso attraverso sistemi di anonimizzazione non è consentito.', 'en' => 'EN L\' accesso attraverso sistemi di anonimizzazione non è consentito.'), + 'reas_prox' => array('it' => 'L\' accesso attraverso proxy non è consentito, se lo usi solo tu e pochi altri utenti comunica il suo indirizzo IP all\' amministratore per aggiungerlo alle eccezioni.', + 'en' => 'EN L\' accesso attraverso proxy non è consentito, se lo usi solo tu e pochi altri utenti comunica il suo indirizzo IP all\' amministratore per aggiungerlo alle eccezioni.'), 'reas_anot' => array('it' => 'La tua sessione è stata assegnata ad un altro browser.', 'en' => 'EN La tua sessione è stata assegnata ad un altro browser.'), - 'btn_enter' => array('it' => 'entra', - 'en' => 'enter'), + 'reas_cloud' => array('it' => 'La connessione dai computer di una cloud non è ammessa.', + 'en' => 'Connection from cloud computers is not allowed.'), + + 'btn_enter' => array('it' => 'Entra.', + 'en' => 'Enter.'), 'passwarn' => array('it' => 'Se non hai ancora una password, lascia il campo in bianco ed entra.', 'en' => 'If you don\'t have a password, leave blank the field and enter.'), 'browwarn' => array('it' => 'Se qualcosa non funziona prova a ricaricare la pagina con Ctrl + F5

Se non riesci più ad entrare nel nuovo Brisk e prima ci riuscivi potrebbe essere un problema di antivirus,
guarda la pagina sugli antivirus per maggiori informazioni su come configurarlo.

Se ancora non funziona nulla contatta l\'amministratore del sito.', @@ -65,12 +71,14 @@ $mlang_room = array( 'userpasserr' => array('it' => 'Utente e/o password errati 'en' => 'back to tables'), 'btn_exit' => array('it' => 'Esco.', 'en' => 'Exit.'), - 'btn_prefs_save' => array('it' => 'Salva.', + 'btn_save' => array('it' => 'Salva.', 'en' => 'Save.'), - 'btn_prefs_reset' => array('it' => 'Annulla.', + 'btn_reset' => array('it' => 'Annulla.', 'en' => 'Reset.'), - 'btn_prefs_close' => array('it' => 'Chiudi.', + 'btn_close' => array('it' => 'Chiudi.', 'en' => 'Close.'), + 'btn_send' => array('it' => 'Invia.', + 'en' => 'Send.'), 'tit_tabl' => array('it' => 'Tavolo ', 'en' => 'Table '), 'tit_stat' => array('it' => 'imposta lo stato del tuo utente', @@ -194,6 +202,14 @@ $mlang_room = array( 'userpasserr' => array('it' => 'Utente e/o password errati 'en' => 'contacts'), 'itm_mail' => array('it' => 'contatti', 'en' => 'contacts'), + 'tit_cook' => array('it' => 'policy sui cookie', + 'en' => 'cookie policy'), + 'itm_cook' => array('it' => 'cookie', + 'en' => 'cookie'), + 'tit_dtmg' => array('it' => 'trattamento dati personali', + 'en' => 'personal data management'), + 'itm_dtmg' => array('it' => 'dati personali', + 'en' => 'personal data'), 'tit_cla' => array('it' => 'classifiche degli utenti', 'en' => 'user\'s placings'), 'itm_cla' => array('it' => 'classifiche', @@ -216,10 +232,34 @@ $mlang_room = array( 'userpasserr' => array('it' => 'Utente e/o password errati 'en' => 'Send a message to the administrator:'), 'mesgtoadm_sub'=> array('it' => 'soggetto:', 'en' => 'subject:'), - 'btn_send' => array('it' => 'Invia.', - 'en' => 'Send.'), - 'btn_close' => array('it' => 'Chiudi.', - 'en' => 'Close.') + 'info_login' => array('it' => 'Utente', + 'en' => 'User'), + 'info_status' => array('it' => 'Stato', + 'en' => 'Status'), + 'info_status_tit' => array('it' => 'Stato dell\' utente.', + 'en' => 'User status.'), + 'info_guar' => array('it' => 'Garante', + 'en' => 'Guarantee'), + 'info_match' => array('it' => 'Partite', + 'en' => 'Matches'), + 'info_match_tit' => array('it' => 'Partite giocate ai tavoli riservati.', + 'en' => 'Matches played at reserved tables.'), + 'info_party' => array('it' => 'Party', + 'en' => 'Party'), + 'info_party_tit' => array('it' => 'Bravura calcolata in base ad amici, agli amici fidati e agli amici degli amici fidati in base alla credibilità degli amici fidati.', + 'en' => 'Skill calculated with party rules.'), + 'info_game' => array('it' => 'Mani', + 'en' => 'Hands'), + 'info_game_tit' => array('it' => 'Mani giocate ai tavoli riservati.', + 'en' => 'Hands played at reserved tables.'), + 'info_frie' => array('it' => 'Conoscenza:', + 'en' => 'Friendship:'), + 'info_repfrie' => array('it' => 'Cosa ne pensano gli amici', + 'en' => 'Friends reputation'), + 'info_repbff' => array('it' => 'Cosa ne pensano gli amici fidati', + 'en' => 'Best friends reputation'), + 'info_skill' => array('it' => 'Bravura', + 'en' => 'Skill') ); require_once("briskin5/Obj/briskin5.phh"); @@ -304,7 +344,13 @@ function sidebanners_render($sidebanner, $sidebanner_idx) $tit = eschtml($sb['title']); printf(' alt="%s" title="%s">', $tit, $tit); printf("\n"); - printf('', $i, $sb['icon_big']); + + $ib_class = ""; + if (array_key_exists('icon_big_class', $sb)) { + $ib_class = $sb['icon_big_class']; + } + + printf('', $ib_class, $i, $sb['icon_big']); printf("\n"); } } @@ -316,12 +362,18 @@ function index_main(&$brisk, $transp_type, $header, &$header_out, $remote_addr_f GLOBAL $G_sidebanner, $G_sidebanner_idx; GLOBAL $G_with_poll; GLOBAL $G_lang, $G_lng, $mlang_room; - GLOBAL $BRISK_SHOWHTML, $BRISK_DEBUG, $_SERVER; + GLOBAL $BRISK_SHOWHTML, $BRISK_DEBUG, $_SERVER, $_COOKIE; + + $transp_port = ((array_key_exists("X-Forwarded-Proto", $header) && + $header["X-Forwarded-Proto"] == "https") ? 443 : 80); if (($sess = gpcs_var('sess', $get, $post, $cookie)) === FALSE) $sess = ""; if (($name = gpcs_var('name', $get, $post, $cookie)) === FALSE) unset($name); + else + log_step("LOGIN: $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) @@ -329,12 +381,12 @@ function index_main(&$brisk, $transp_type, $header, &$header_out, $remote_addr_f if (($table_token = gpcs_var('table_idx', $get, $post, $cookie)) === FALSE) unset ($table_token); - $remote_addr = addrtoipv4($remote_addr_full); + // default values + $_cookie_law_3party = 'true'; + if (isset($cookie['_cookie_law_3party'])) + $_cookie_law_3party = $cookie['_cookie_law_3party']; - // Use of proxies isn't allowed. - if (!$G_is_local && is_proxy($remote_addr)) { - return FALSE; - } + $remote_addr = addrtoipv4($remote_addr_full); $is_login = FALSE; $body = ""; @@ -342,6 +394,7 @@ function index_main(&$brisk, $transp_type, $header, &$header_out, $remote_addr_f $standup = ""; $ACTION = "login"; $last_msg = ""; + $banned = FALSE; if (isset($BRISK_SHOWHTML) == FALSE) { $is_table = FALSE; @@ -366,16 +419,26 @@ function index_main(&$brisk, $transp_type, $header, &$header_out, $remote_addr_f case GHOST_SESS_REAS_ANON: $last_msg = $mlang_room['reas_anon'][$G_lang]; break; + case GHOST_SESS_REAS_PROX: + $last_msg = $mlang_room['reas_prox'][$G_lang]; + break; default: $last_msg = $mlang_room['reas_unkn'][$G_lang]; break; } } + if ($brisk->cloud_check($remote_addr)) { + // TODO: find a way to add a nonblocking sleep(5) here + $banned = TRUE; + $last_msg = $mlang_room['reas_cloud'][$G_lang]; + } + + if (validate_sess($sess)) { log_main("pre garbage_manager UNO"); $brisk->garbage_manager(TRUE); log_main("post garbage_manager"); - if (($user = &$brisk->get_user($sess, &$idx)) != FALSE) { + if (($user = $brisk->get_user($sess, $idx)) != FALSE) { if ($user->the_end == FALSE) { $brisk->sess_cur_set($user->sess); log_main("user stat: ".$user->stat); @@ -391,9 +454,7 @@ function index_main(&$brisk, $transp_type, $header, &$header_out, $remote_addr_f } } } - - $banned = FALSE; - if ($ACTION == "login" && isset($name)) { + if (!$banned && $ACTION == "login" && isset($name)) { log_main("pre garbage_manager DUE"); if (isset($pass_private) == FALSE || $pass_private == "") { @@ -402,7 +463,7 @@ function index_main(&$brisk, $transp_type, $header, &$header_out, $remote_addr_f if ($brisk->ban_check($remote_addr)) { // TODO: find a way to add a nonblocking sleep(5) here $banned = TRUE; - $idx = -1; + $idx = -4; } } @@ -410,7 +471,7 @@ function index_main(&$brisk, $transp_type, $header, &$header_out, $remote_addr_f /* try login */ if ($banned == FALSE && - ($user = $brisk->add_user(&$sess, &$idx, $name, $pass_private, + ($user = $brisk->add_user($sess, $idx, $name, $pass_private, $remote_addr, $header, $cookie)) != FALSE) { $brisk->sess_cur_set($user->sess); $ACTION = "room"; @@ -432,15 +493,24 @@ function index_main(&$brisk, $transp_type, $header, &$header_out, $remote_addr_f } } else { + // fprintf(STDERR, "POST CHECK QUI\n"); /* Login Rendering */ - if ($idx == -3) + switch($idx) { + case -4: + $sfx = 'ban'; + break; + case -3: $sfx = 'err'; - else if ($idx == -2) + break; + case -2: $sfx = 'must'; - else if ($idx == -1) + break; + case -1: $sfx = 'end'; - else + break; + default: $sfx = 'use'; + } $body .= '
'.$mlang_room['userpass'.$sfx][$G_lang].'
'; } @@ -459,7 +529,7 @@ function index_main(&$brisk, $transp_type, $header, &$header_out, $remote_addr_f $tables .= '
'; $tables .= ''; for ($ii = 0 ; $ii < TABLES_N ; $ii++) { - if ($user->is_auth()) + if ($user->is_auth() && !$user->is_appr()) $i = $ii; else $i = TABLES_N - $ii - 1; @@ -568,7 +638,7 @@ function index_main(&$brisk, $transp_type, $header, &$header_out, $remote_addr_f /* MLANG: "briscola chiamata in salsa ajax", */ mt_srand(make_seed()); - if (!$G_is_local) { + if (!$G_is_local && $_cookie_law_3party == 'true') { $rn = rand(0, 1); if ($rn == 0) { @@ -586,7 +656,7 @@ google_color_text = "404040"; google_color_url = "000000"; //--> -'; +'; $banner_top_right = carousel_top(); } else { @@ -605,7 +675,7 @@ google_color_text = "404040"; google_color_url = "000000"; //--> -'; +'; } } else { // !$G_is_local @@ -616,18 +686,19 @@ google_color_url = "000000"; $brisk_header_form = '
- - +       +
'.$banner_top_left.'
'.(($G_with_topbanner || $G_with_donors) ? ' /* MLANG: ALL THE VERTICAL MENU */ $brisk_vertical_menu = ' @@ -681,13 +752,17 @@ google_color_url = "000000"; onmouseover="menu_hide(0,1);" title="'.$mlang_room['tit_mail'][$G_lang].'">'.$mlang_room['itm_mail'][$G_lang].'
-
+'.$mlang_room['itm_cook'][$G_lang].'
- + title="'.$mlang_room['tit_dtmg'][$G_lang].'" + alt="'.$mlang_room['tit_dtmg'][$G_lang].'">'.$mlang_room['itm_dtmg'][$G_lang].'
+
+ '.$mlang_room['itm_cla'][$G_lang].'
@@ -710,7 +785,7 @@ google_color_url = "000000"; Parma 11/09
+ title="1° Torneo-Meeting di Parma del 22/11/2009">Parma 11/09
'.$altout_support_big.'
-
+ ' . ( /* NOTE: here facebook or fake facebook */ -! $G_is_local ? +(!$G_is_local && $_cookie_law_3party == 'true') ? '
-' : '
FACEBOOK HERE
-' ) . '
+' : '' ) . '
%s %s @@ -950,18 +1024,21 @@ supported by:
Brisk - - - - - - - - - - - - + + + + + + + + + + + + + + + @@ -970,11 +1047,12 @@ var g_debug = 0; var g_lang = ""; var g_lng = ""; var g_tables_n = ; +var g_tables_appr_n = ; var g_tables_auth_n = ; var g_tables_cert_n = ; var g_prefs, g_prefs_new = null; var g_listen; -var g_withflash = false; +var g_jukebox = null; var g_is_spawn = 0; var g_nd = null; var g_brow = null; @@ -1001,19 +1079,20 @@ window.onload = function() { sidebanners_init($G_sidebanner_idx); ?> - g_withflash = DetectFlashVer(6,0,0); - if (g_withflash == false) { - $("proflash").innerHTML = 'Audio con Flash.
'; + g_jukebox = new jukebox([]); + if (g_jukebox.is_enabled() == false) { + $("proaudio").innerHTML = 'Audio HTML5 non supportato.'; + } + else { + $("proaudioext").innerHTML = ""; } - else - $("proflashext").innerHTML = ""; $("nameid").focus(); } //--> @@ -1057,21 +1136,35 @@ window.onload = function() {
' : '').'
- - '.$mlang_room['headline'][$G_lang].'
+ + + - +
'.$banner_top_left.'
'.(($G_with_topbanner || $G_with_donors) ? '
' : '').'
+ ' +/* ciao Prof' */ + .$mlang_room['headline'][$G_lang].'
'.( ($G_with_topbanner || $G_with_donors) ? sprintf('
%s
', ($G_with_topbanner ? $G_topbanner : "
donatori
") ) : '').'
-'.$banner_top_right.'
'.$banner_top_right.'
'; +//
'.$banner_top_right.'
- + - +
-

+ +

+ +

+ +


-



-



-



-



-



@@ -1083,6 +1176,12 @@ window.onload = function() {
+ + Brisk - - - - - - - - - - - - + + + + + + + + + + + + + + + @@ -1281,8 +1385,8 @@ type="submit" class="button" onclick="this.form.elements['realsub'].value = 'chi
-       -
@@ -1297,6 +1401,104 @@ type="submit" class="button" onclick="this.form.elements['realsub'].value = 'chi
+ + +
- - - + + +
+