X-Git-Url: http://mop.ddnsfree.com/gitweb/?p=brisk.git;a=blobdiff_plain;f=web%2FObj%2Fbrisk.phh;h=a171273782a7f67b33ce115c68d427d4db0638a3;hp=62b80a77109f9c8cef8f03a2d6f59d3e237a1563;hb=6d8db1ee47d3c0bb14133d3ab2e0a6bdc7ed60a0;hpb=28be75bdd1253bb56c8bef5476f59be63013eb71 diff --git a/web/Obj/brisk.phh b/web/Obj/brisk.phh index 62b80a7..a171273 100644 --- a/web/Obj/brisk.phh +++ b/web/Obj/brisk.phh @@ -2,7 +2,7 @@ /* * brisk - brisk.phh * - * Copyright (C) 2006-2014 Matteo Nastasi + * Copyright (C) 2006-2015 Matteo Nastasi * mailto: nastasi@alternativeoutput.it * matteo.nastasi@milug.org * web: http://www.alternativeoutput.it @@ -90,7 +90,6 @@ define('DEBUGGING', "no-debugging"); require_once("$DOCUMENT_ROOT/Etc/".BRISK_CONF); require_once("${G_base}Obj/ipclass.phh"); -require_once("${G_base}Obj/provider_proxy.phh"); $mlang_brisk = array( 'btn_backstand'=> array( 'it' => 'torna in piedi', 'en' => 'back standing' ), @@ -141,26 +140,24 @@ $mlang_brisk = array( 'btn_backstand'=> array( 'it' => 'torna in piedi', 'en' => 'Connection to the database failed
All authentications are suspended temporarly, you login as normal user.
We are about the limitation'), 'tos_old' => array( 'it' => '%s ha sottoscritto dei Termini del Servizio antecedenti a quelli necessari per poter richiedere questa funzionalità.', - 'en' => 'EN %s ha sottoscritto dei Termini del Servizio antecedenti a quelli necessari per poter richiedere questa funzionalità.'), - 'gua_nfd' => array( 'it' => 'Non è stato trovato un garante per %s.', + 'en' => 'EN %s ha sottoscritto dei Termini del Servizio antecedenti a quelli necessarig per poter richiedere questa funzionalità.'), + 'inf_self' => array( 'it' => 'Non puoi informarti su te stesso.', + 'en' => 'EN Non puoi informarti su te stesso.'), + 'inf_nfd' => array( 'it' => 'Non è stato trovato un garante per %s.', 'en' => 'EN Non è stato trovato un garante per %s.'), - 'gua_self' => array( 'it' => '%s si è auto-garantito.', - 'en' => 'EN %s si è auto-garantito.'), - 'gua_info' => array( 'it' => 'Il garante di %s è %s.', - 'en' => 'EN Il garante di %s è %s.'), - 'gua_err' => array( 'it' => 'Error %d. Utilizzo: /guar <login>.', - 'en' => 'Error %d. Usage: /guar <login>.') + 'inf_err' => array( 'it' => 'Error %d. Utilizzo: /info <login>.', + 'en' => 'Error %d. Usage: /info <login>.') ); $G_lng = langtolng($G_lang); $G_all_points = array( 11,10,4,3,2, 0,0,0,0,0 ); -$G_brisk_version = "4.17.0"; +$G_brisk_version = "4.18.5"; /* MLANG: ALL THE INFO STRINGS IN brisk.phh */ -$root_wellarr = array( 'it' => array ( 'Brisk (Ver. '.$G_brisk_version.'), NOVITA\': gestione accessi da sistemi di anonimizzazione, nuovi termini di utilizzo.', +$root_wellarr = array( 'it' => array ( 'Brisk (Ver. '.$G_brisk_version.'), NOVITA\': Puffin riattivato, accessi da cloud disattivati, corretto bug sulla gestione di puffin, riabilitato blocco dei proxy.', 'Se vuoi iscriverti alla Mailing List, cliccala!' ), - 'en' => array ( 'Brisk (Ver. '.$G_brisk_version.'), NEWS: engine refactoring and logout message.', + 'en' => array ( 'Brisk (Ver. '.$G_brisk_version.'), NEWS: Puffin re-enabled, cloud accesses disabled, fixed puffin mgmt bug, re-enabled proxy access block.', 'If you want to subscribe our Mailing List, click it!' ) ); $G_room_help = array( 'it' => ' @@ -188,7 +185,7 @@ Dopo che è iniziata una partita per uscirne dovete chiedere agli altri gi
/tav <frase di invito> - invito per gli altri giocatori al tavolo dove si è seduti
/st <stato> - cambia l\'icona associata al tuo user; stato può valere: \\"normale\\", \\"fuori\\", \\"pausa\\", \\"cibo\\", \\"cane\\", \\"lavoro\\", \\"presente\\" oppure \\"sigaretta\\"
/cont <id partita> - quando si è a un tavolo per garantiti, permette di proseguire una partita giocata in precedenza con gli stessi giocatori -
/guar <login> - mostra il garante dell\'utente con il login passato come argomento +
/info <login> - mostra lo stato corrente dell\'utente passato come argomento e in che relazione siete
/authreq - se si è autenticati permette di garantire per un utente fidato
/mesgtoadm - se si è autenticati permette di lasciare un messaggio all\'amministratore del sito
/listen <all or auth> - se si è autenticati permette leggere solo i messaggi degli altri autenticati (auth) o di tutti (all) @@ -221,7 +218,7 @@ Dopo che è iniziata una partita per uscirne dovete chiedere agli altri gi
/tav <frase di invito> - invito per gli altri giocatori al tavolo dove si è seduti
/st <stato> - cambia l\'icona associata al tuo user; stato può valere: \\"normale\\", \\"fuori\\", \\"pausa\\", \\"cibo\\", \\"cane\\", \\"lavoro\\", \\"presente\\" oppure \\"sigaretta\\"
/cont <id partita> - quando si è a un tavolo per garantiti, permette di proseguire una partita giocata in precedenza con gli stessi giocatori -
/guar <login> - mostra il garante dell\'utente con il login passato come argomento +
/info <login> - mostra lo stato corrente dell\'utente passato come argomento e in che relazione siete
/authreq - se si è autenticati permette di garantire per un utente fidato
/mesgtoadm - se si è autenticati permette di lasciare un messaggio all\'amministratore del sito
/listen <all or auth> - se si è autenticati permette leggere solo i messaggi degli altri autenticati (auth) o di tutti (all) @@ -346,6 +343,39 @@ $G_PG_cons_n = 345; /* printf("\n"); */ /* } */ +function ip2int($s) +{ + return (ip2long($s)); +} + +function int2ip($i) +{ + return (long2ip($i)); +} + +function int2four($l) +{ + if (PHP_INT_SIZE == 4) + return ($l); + + return ( ($l & 0x80000000 ? 0xffffffff00000000 : 0x00) | $l ); +} + +function four2int($s) +{ + return ($s & 0xffffffff); +} + +function ip2four($s) +{ + return int2four( ip2int($s) ); +} + +function four2ip($i) +{ + return int2ip( four2int($i) ); +} + function nickserv_msg($dt, $msg) { return sprintf('chatt_sub("%s",[0x040003,"%s"],"%s");', $dt, NICKSERV, $msg); } @@ -784,13 +814,13 @@ class Table { if ($sitted < PLAYERS_N) { switch ($this->auth_type) { case TABLE_AUTH_TY_CERT: - if ($user->is_cert()) + if ($user->is_cert() && !$user->is_appr()) $act = "sitcert"; else $act = 'resercert'; break; case TABLE_AUTH_TY_AUTH: - if ($user->is_auth()) + if ($user->is_auth() && !$user->is_appr()) $act = "sitreser"; else $act = 'reserved'; @@ -965,6 +995,7 @@ define('GHOST_SESS_REAS_ANOT', 2); // another user get session define('GHOST_SESS_REAS_TOUT', 3); // room timeout define('GHOST_SESS_REAS_TTOT', 4); // table timeout define('GHOST_SESS_REAS_ANON', 5); // anonymizer access +define('GHOST_SESS_REAS_PROX', 6); // proxy access class GhostSessEl { @@ -1039,9 +1070,9 @@ class Brisk var $garbage_timeout; var $shm_sz; - var $ban_list; // ban list (authized allowed) - var $black_list; // black list (anti-dos, noone allowed) - var $provider_proxy; // list of provider/browser that offer proxy service + var $ban_list; // ban list (authized allowed) + var $black_list; // black list (anti-dos, noone allowed) + var $cloud_smasher; // list of cloud ip ranges to be rejected var $ghost_sess; var $delay_mgr; @@ -1055,13 +1086,13 @@ class Brisk } // constructor - static function create($crystal_filename, $ban_list, $black_list, $prov_proxy) { + static function create($crystal_filename, $ban_list, $black_list, $cloud_smasher) { if (($brisk_ser = @file_get_contents($crystal_filename)) != FALSE) { if (($brisk = unserialize($brisk_ser)) != FALSE) { fprintf(STDERR, "ROOM FROM FILE\n"); rename($crystal_filename, $crystal_filename.".old"); - $brisk->reload(TRUE, $ban_list, $black_list, $prov_proxy); + $brisk->reload(TRUE, $ban_list, $black_list, $cloud_smasher); return($brisk); } @@ -1077,7 +1108,7 @@ class Brisk $thiz->ban_list = IpClass::create(); $thiz->black_list = IpClass::create(); - $thiz->provider_proxy = ProviderProxy::create(); + $thiz->cloud_smasher = IpClass::create(); $thiz->ghost_sess = new GhostSess(); for ($i = 0 ; $i < MAX_PLAYERS ; $i++) { @@ -1094,14 +1125,15 @@ class Brisk static::$sess_cur = FALSE; - $thiz->reload(TRUE, $ban_list, $black_list, $prov_proxy); + $thiz->reload(TRUE, $ban_list, $black_list, $cloud_smasher); return ($thiz); } - function reload($is_first, $ban_list, $black_list, $prov_proxy) + function reload($is_first, $ban_list, $black_list, $cloud_smasher) { - fprintf(STDERR, "RELOAD STUFF (%d)(%d)(%d)\n", count($ban_list), count($black_list), count($prov_proxy)); + fprintf(STDERR, "RELOAD STUFF (%d)(%d)(%d)\n", + count($ban_list), count($black_list), count($cloud_smasher)); if (defined('CURL_DE_SAC_VERS')) { if (brisk_cds_reload($this) == FALSE) { @@ -1110,7 +1142,7 @@ class Brisk } $this->ban_list->update($ban_list); $this->black_list->update($black_list); - $this->provider_proxy->update($prov_proxy); + $this->cloud_smasher->update($cloud_smasher); if (!$is_first) { $this->banned_kickoff(); @@ -1145,7 +1177,8 @@ class Brisk continue; // check if the IP is blacklisted - if ($this->black_check($user_cur->ip)) { + if ($this->black_check($user_cur->ip) || + $this->cloud_check($user_cur->ip)) { $user_cur->lacc = 0; $is_ban = TRUE; continue; @@ -1175,9 +1208,9 @@ class Brisk return ($this->black_list->check($ip_str)); } - function pproxy_realip($header, $ip_str) + function cloud_check($ip_str) { - return ($this->provider_proxy->realip($header, $ip_str)); + return ($this->cloud_smasher->check($ip_str)); } function users_cleanup() @@ -1419,7 +1452,6 @@ class Brisk return ($ret); } - function room_wakeup($user) { $table_idx = $user->table; @@ -1462,7 +1494,6 @@ class Brisk $remove_wagon = TRUE; } - /* aggiorna l'array dei giocatori al tavolo. */ $table->user_rem($this, $user); @@ -1612,10 +1643,11 @@ class Brisk } } - function guarantee_show($user, $user_login, $dt) + function info_show($user, $user_login, $dt) { GLOBAL $G_lang, $mlang_brisk, $G_base; + $mesg = ""; $user_code = -1; $ret = 0; @@ -1632,6 +1664,11 @@ class Brisk $ret = 3; break; } + if ($user_login == $user->name) { + $ret = 4; + $mesg = sprintf($mlang_brisk['inf_self'][$G_lang]); + break; + } if (($guar_item = $bdb->getitem_bycode($user_item->guar_code_get())) != FALSE) { $guar_login = $guar_item->login_get(); } @@ -1641,28 +1678,25 @@ class Brisk $user_tos_vers = $user_item->tos_vers_get(); if (versions_cmp($user_tos_vers, "1.2") < 0) { - $mesg = nickserv_msg($dt, sprintf($mlang_brisk['tos_old'][$G_lang], xcape($user_login))); + $mesg = sprintf($mlang_brisk['tos_old'][$G_lang], xcape($user_login)); } else if ($guar_login == "") { - $mesg = nickserv_msg($dt, sprintf($mlang_brisk['gua_nfd'][$G_lang], xcape($user_login))); - } - else if ($guar_login == $user_login) { - $mesg = nickserv_msg($dt, sprintf($mlang_brisk['gua_self'][$G_lang], xcape($user_login))); - } - else { - $mesg = nickserv_msg($dt, sprintf($mlang_brisk['gua_info'][$G_lang], - xcape($user_login), xcape($guar_login))); + $mesg = sprintf($mlang_brisk['inf_nfd'][$G_lang], xcape($user_login)); } } while (0); - if ($ret > 0) { - $mesg = nickserv_msg($dt, sprintf($mlang_brisk['gua_err'][$G_lang], $ret)); + if ($ret > 0 && $mesg == "") { + $mesg = sprintf($mlang_brisk['inf_err'][$G_lang], $ret); } - $user->comm[$user->step % COMM_N] = "gst.st = ".($user->step+1)."; ".$mesg; - $user->step_inc(); + if ($ret != 0) { + $jret = json_encode(array("ret" => $ret, "mesg" => $mesg)); + } + else { + $jret = json_encode(array("ret" => 0, "mesg" => "", "guar" => $guar_login)); + } - return TRUE; + return $jret; } function room_outstandup($user) @@ -1816,6 +1850,8 @@ class Brisk GLOBAL $G_base, $G_alarm_passwd, $mlang_brisk, $G_lang; $only_you = FALSE; + fprintf(STDERR, "WE ARE HERE: [%s]\n", $mesg); + // common settings $msg = mb_substr($mesg, 6, 128, "UTF-8"); $curtime = time(); @@ -1961,7 +1997,7 @@ class Brisk $to_user = nickserv_msg($dt, $mlang_brisk['mesgmust'][$G_lang]); } } - else if (strncmp($msg, "/nick ", 6) == 0) { + else if (FALSE && strncmp($msg, "/nick ", 6) == 0) { log_main("chatt_send BEGIN"); do { @@ -2022,10 +2058,11 @@ class Brisk $update_room = TRUE; } while (0); } // nick chat command - else if (strncmp($msg, "/guar ", 6) == 0 || $msg == "/guar") { + else if (strncmp($msg, "/info ", 6) == 0) { $guar_user = substr($msg, 6); - $this->guarantee_show($user, $guar_user, $dt); + error_log("here [" . $guar_user."]"); + echo $this->info_show($user, $guar_user, $dt); } else if (strncmp($msg, "/st ", 4) == 0) { log_main("chatt_send BEGIN"); @@ -2122,17 +2159,19 @@ class Brisk if ( TRUE && (! $user->is_auth()) ) { $to_user = nickserv_msg($dt, xcape("Visto l'elevato numero di molestatori che ultimamente hanno preso dimora su Brisk abbiamo deciso")); $to_user .= nickserv_msg($dt, xcape("di disattivare temporaneamente la chat in room per i non registrati, non ce ne vogliate e buone feste.")); - $aug_head = array("Tanti", "Tantissimi", "Un enormità", "Un milione", "Un' esagerazione"); - $aug_body = array("a tutti gli utenti", "a tutti gli uomini", "a tutte le donne", "a tutti gli utenti"); - $aug_tail = array("di Brisk", "del sito", "della ciurma", "della comitiva", "del gruppo"); - - $auguri = sprintf("%s auguri %s %s.", - $aug_head[mt_rand(0, count($aug_head)-1)], - $aug_body[mt_rand(0, count($aug_body)-1)], - $aug_tail[mt_rand(0, count($aug_tail)-1)]); - - $to_room = sprintf('chatt_sub("%s",[%d,"%s"],"%s");', $dt, $user->flags, xcape($user->name), - xcape($auguri)); + if (FALSE) { + $aug_head = array("Tanti", "Tantissimi", "Un enormità", "Un milione", "Un' esagerazione"); + $aug_body = array("a tutti gli utenti", "a tutti gli uomini", "a tutte le donne", "a tutti gli utenti"); + $aug_tail = array("di Brisk", "del sito", "della ciurma", "della comitiva", "del gruppo"); + + $auguri = sprintf("%s auguri %s %s.", + $aug_head[mt_rand(0, count($aug_head)-1)], + $aug_body[mt_rand(0, count($aug_body)-1)], + $aug_tail[mt_rand(0, count($aug_tail)-1)]); + + $to_room = sprintf('chatt_sub("%s",[%d,"%s"],"%s");', $dt, $user->flags, xcape($user->name), + xcape($auguri)); + } } else { $to_user = sprintf('chatt_sub("%s",[%d,"%s"],"%s");', $dt, $user->flags, xcape($user->name), xcape($msg)); @@ -2614,18 +2653,22 @@ class Brisk function request_mgr(&$s_a_p, $header, &$header_out, &$new_socket, $path, $addr, $get, $post, $cookie) { - GLOBAL $G_ban_list, $G_black_list, $G_provider_proxy; + GLOBAL $G_ban_list, $G_black_list, $G_cloud_smasher; printf("NEW_SOCKET (root): %d PATH [%s]\n", intval($new_socket), $path); - // $remote_addr = addrtoipv4($addr); - $remote_addr = $this->pproxy_realip($header, addrtoipv4($addr)); - fprintf(STDERR, "\n\n\n PRE_BLACK_CHECK \n\n\n"); - if ($this->black_check($remote_addr)) { + fprintf(STDERR, "\n\n\n PRE_BLACK [%s]\n\n\n", $addr); + if ($this->black_check($addr)) { // TODO: waiting async 5 sec before close fprintf(STDERR, "\n\n\n BLACK CHECK\n\n\n"); return (FALSE); } + if ($path != "" && $path != "index.php") { + if ($this->cloud_check($addr)) { + // TODO: waiting async 5 sec before close + return (FALSE); + } + } $enc = get_encoding($header); if (isset($header['User-Agent'])) { @@ -3293,7 +3336,7 @@ function validate_name($name) { $name_new = str_replace(' ', '_', mb_substr(trim($name),0,12, "UTF-8")); - for ($i = 0 ; $i < strlen($name_new) ; $i++) { + for ($i = 0 ; $i < mb_strlen($name_new) ; $i++) { $c = $name_new[$i]; if (($c >= "a" && $c <= "z") || ($c >= "A" && $c <= "Z") || ($c >= "0" && $c <= "9")) return ($name_new);