X-Git-Url: http://mop.ddnsfree.com/gitweb/?a=blobdiff_plain;f=web%2Fbriskin5%2FObj%2Fbriskin5.phh;h=ecd4b41521a2ca2dbd3e2affdc8eed995c820cb7;hb=971fb704f6cb6091d0c597209f5f878c04336d51;hp=927f703ed0b9c509851cd21469fa3df945c859c5;hpb=f0c4c4d0bed38d1211249c0032da8e546c5d5df9;p=brisk.git
diff --git a/web/briskin5/Obj/briskin5.phh b/web/briskin5/Obj/briskin5.phh
index 927f703..ecd4b41 100644
--- a/web/briskin5/Obj/briskin5.phh
+++ b/web/briskin5/Obj/briskin5.phh
@@ -5,24 +5,35 @@ class Briskin5 {
var $user;
var $table;
var $table_idx;
+ var $table_token;
+
var $comm; // commands for many people
var $step; // current step of the comm array
var $garbage_timeout;
- function Briskin5 (&$room, $table_idx) {
+ var $tok;
+
+ function Briskin5 (&$room, $table_idx, $table_token) {
$this->user = array();
$this->table = array();
+ if (($this->tok = ftok(FTOK_PATH."/table".$table_idx, "B")) == -1) {
+ echo "FTOK FAILED";
+ exit;
+ }
+
$user =& $room->user;
$table =& $room->table[$table_idx];
log_wr("xxx", "Briskin5 constructor");
- for ($i = 0 ; $i < $table->player_n ; $i++)
+ for ($i = 0 ; $i < $table->player_n ; $i++) {
+ $user[$table->player[$i]]->table_token = $table_token;
$this->user[$i] =& User::spawn(&$user[$table->player[$i]], 0, $i);
-
+ }
$this->table[0] =& Table::spawn(&$table);
$this->table_idx = $table_idx;
+ $this->table_token = $table_token;
$this->garbage_timeout = 0;
log_wr("xxx", "Briskin5 constructor end");
@@ -58,10 +69,11 @@ class Briskin5 {
{
/* Garbage collector degli utenti in timeout */
+ $ismod = FALSE;
$curtime = time();
if ($force || $this->garbage_timeout < $curtime) {
- for ($i = 0 ; $i < MAX_PLAYERS ; $i++) {
+ for ($i = 0 ; $i < MAX_BRISKIN5_PLAYERS ; $i++) {
$user_cur = &$this->user[$i];
if ($user_cur->sess == "")
continue;
@@ -69,41 +81,32 @@ class Briskin5 {
if ($user_cur->lacc + EXPIRE_TIME_RD < $curtime) { // Auto logout dell'utente
log_rd2($user_cur->sess, "AUTO LOGOUT.");
- if ($user_cur->stat == 'table' || $user_cur->stat == 'room') {
+ if ($user_cur->stat == 'table') {
log_auth($user_cur->sess, "Autologout session.");
-
+
+ /* SI DELEGA AL garbage_manager principale LA RIMOZIONE DELL'UTENTE
+
$tmp_sess = $user_cur->sess;
$user_cur->sess = "";
step_unproxy($tmp_sess);
$user_cur->name = "";
$user_cur->the_end = FALSE;
+ */
+
log_rd2($user_cur->sess, "AUTO LOGOUT.");
- if ($user_cur->subst == 'sitdown' || $user_cur->stat == 'table')
- $this->room_wakeup(&$user_cur);
- else if ($user_cur->subst == 'standup')
- $this->room_outstandup(&$user_cur);
- else
- log_rd2($sess, "LOGOUT FROM WHAT ???");
- }
- }
- if ($user_cur->laccwr + EXPIRE_TIME_SMAMMA < $curtime) { // lo rimettiamo in piedi
- if ($user_cur->stat == 'room' && $user_cur->subst == 'sitdown') {
- $this->room_wakeup(&$user_cur);
- $user_cur->comm[$user_cur->step % COMM_N] = "gst.st = ".($user_cur->step+1)."; ";
- $user_cur->comm[$user_cur->step % COMM_N] .= show_notify("
Sei stato inattivo per ".(EXPIRE_TIME_SMAMMA/60.0)." minuti.
Quindi ritorni tra i Giocatori in piedi.", 0, "torna ai tavoli", 400, 100);
- $user_cur->step_inc();
+ $this->table_wakeup(&$user_cur);
}
}
}
log_rd2($user_cur->sess, "GARBAGE UPDATED!");
- $this->garbage_timeout = time() + GARBAGE_TIMEOUT;
+ $this->garbage_timeout = $curtime + GARBAGE_TIMEOUT;
+ $ismod = TRUE;
}
- // BAN_IP_CLEAN
-
+ return ($ismod);
}
@@ -112,7 +115,7 @@ class Briskin5 {
//
// static functions
//
- function &load_data($table_idx)
+ function &load_data($table_idx, $table_token = "")
{
GLOBAL $G_false, $sess;
$shm = FALSE;
@@ -124,12 +127,23 @@ class Briskin5 {
}
do {
+ // if (shmchk_exists($tok) == FALSE)
+ if (locshm_exists($tok) == FALSE)
+ break;
+
if (($shm = shm_attach($tok, SHM_DIMS)) == FALSE)
break;
if (($bri = @shm_get_var($shm, $tok)) == FALSE)
break;
-
+
+ if ($table_token != "" && $bri->table_token != $table_token) {
+ log_wr($sess, "bri->table_token: ".$bri->table_token."table_token: ".$table_token);
+
+ break;
+ }
+ $bri->tok = $tok;
+
shm_detach($shm);
$ret = &$bri;
@@ -138,6 +152,8 @@ class Briskin5 {
if ($shm != FALSE)
shm_detach($shm);
+
+ log_wr($sess, "briskin5 load_data failed");
return ($G_false);
}
@@ -151,19 +167,20 @@ class Briskin5 {
$shm = FALSE;
$isacq = FALSE;
+ log_main("XXX", "SAVE BRISKIN5 DATA");
// var_dump($bri);
- if (($tok = ftok(FTOK_PATH."/table".$bri->table_idx, "B")) == -1)
+ if (!isset($bri->tok))
return (FALSE);
do {
$isacq = TRUE;
- if (($shm = shm_attach($tok, SHM_DIMS)) == FALSE)
+ if (($shm = shm_attach($bri->tok, SHM_DIMS)) == FALSE)
break;
// log_only($sess, "PUT_VAR DI ".strlen(serialize($bri)));
- if (shm_put_var($shm, $tok, $bri) == FALSE) {
+ if (shm_put_var($shm, $bri->tok, $bri) == FALSE) {
log_only($sess, "PUT_VAR FALLITA ".strlen(serialize($bri)));
log_only($sess, serialize($bri));
break;
@@ -178,6 +195,47 @@ class Briskin5 {
return ($ret);
}
+ function destroy_data($table_idx)
+ {
+ GLOBAL $sess;
+
+ $ret = FALSE;
+ $shm = FALSE;
+ $isacq = FALSE;
+
+ log_main("XXX", "DESTROY BRISKIN5 DATA");
+
+
+ do {
+ $isacq = TRUE;
+
+ log_main("XXX", "DESTROY2 BRISKIN5 DATA");
+
+ if (($tok = ftok(FTOK_PATH."/table".$table_idx, "B")) == -1)
+ break;
+
+ if (($shm = shm_attach($tok, SHM_DIMS)) === FALSE)
+ break;
+
+ if (shm_remove($shm) === FALSE) {
+ log_only($sess, "REMOVE FALLITA ".strlen(serialize($bri)));
+ log_only($sess, serialize($bri));
+ break;
+ }
+
+ $shm = FALSE;
+ log_main("XXX", "DESTROY2 BRISKIN5 DATA SUCCESS");
+
+ // log_main("XXX", "QUI CI ARRIVA [".$bri->user[0]->name."]");
+ $ret = TRUE;
+ } while (0);
+
+ if ($shm)
+ shm_detach($shm);
+
+ return ($ret);
+ }
+
function lock_data($table_idx)
{
GLOBAL $sess;
@@ -212,7 +270,177 @@ class Briskin5 {
}
+ function chatt_send(&$user, $mesg)
+ {
+ if ($user->stat == 'table') {
+ $table = &$this->table[$user->table];
+ }
+
+ $user_mesg = substr($mesg,6);
+
+ $timecur = time();
+
+ $dt = date("H:i ", $timecur);
+ if (strncmp($user_mesg, "/nick ", 6) == 0) {
+ log_main($user->sess, "chatt_send BEGIN");
+
+ if (($name_new = validate_name(substr($user_mesg, 6))) == FALSE) {
+ $user->comm[$user->step % COMM_N] = "gst.st = ".($user->step+1)."; ";
+ $user->comm[$user->step % COMM_N] .= sprintf('chatt_sub("%s","Il nickname deve contenere almeno una lettera o una cifra.");', $dt.NICKSERV, xcape($name_new));
+ $user->step_inc();
+
+ return;
+ }
+ $user_mesg = "COMMAND ".$user_mesg;
+ // Search dup name
+ // change
+ // update local graph
+ // update remote graphs
+ for ($i = 0 ; $i < MAX_PLAYERS ; $i++) {
+ $user_cur = &$this->user[$i];
+ // if ($user_cur->sess == '' || $user_cur->stat != 'room')
+ if ($user_cur->sess == '')
+ continue;
+ if ($user_cur->name == $name_new) {
+ $user->comm[$user->step % COMM_N] = "gst.st = ".($user->step+1)."; ";
+ $user->comm[$user->step % COMM_N] .= sprintf('chatt_sub("%s","Nickname %s già in uso.");', $dt.NICKSERV, xcape($name_new));
+ $user->step_inc();
+ break;
+ }
+ }
+ if ($i == MAX_PLAYERS) {
+ $user->name = $name_new;
+
+ log_main($user->sess, "chatt_send start set");
+
+
+ for ($i = 0 ; $i < MAX_PLAYERS ; $i++) {
+ log_main($user->sess, "chatt_send set loop");
+
+ $user_cur = &$this->user[$i];
+ if ($user_cur->sess == '')
+ continue;
+ if ($user_cur->stat == 'room') {
+ if ($user->stat == 'room' && $user->subst == 'standup') {
+ $this->standup_update(&$user);
+ }
+ else if ($user->stat == 'room' && $user->subst == 'sitdown' ||
+ $user->stat == 'table') {
+ log_main($user->sess, "chatt_send pre table update");
+
+ $this->table_update(&$user);
+
+ log_main($user->sess, "chatt_send post table update");
+ }
+ }
+ else if ($user_cur->stat == 'table' && $user_cur->table == $user->table) {
+ $table = &$this->table[$user->table];
+
+ $user_cur->comm[$user_cur->step % COMM_N] = "gst.st = ".($user_cur->step+1)."; ";
+ $user_cur->comm[$user_cur->step % COMM_N] .= sprintf('set_names(" %s", " %s", " %s", " %s", " %s"); ',
+ xcape($this->user[$table->player[($user_cur->table_pos)%PLAYERS_N]]->name),
+ xcape($this->user[$table->player[($user_cur->table_pos+1)%PLAYERS_N]]->name),
+ xcape($this->user[$table->player[($user_cur->table_pos+2)%PLAYERS_N]]->name),
+ (PLAYERS_N == 3 ? "" : xcape($this->user[$table->player[($user_cur->table_pos+3)%PLAYERS_N]]->name)),
+ (PLAYERS_N == 3 ? "" : xcape($this->user[$table->player[($user_cur->table_pos+4)%PLAYERS_N]]->name)));
+ if ($user_cur == $user)
+ $user_cur->comm[$user_cur->step % COMM_N] .= sprintf('$("myname").innerHTML = "%s";',
+ xcape($user->name,ENT_COMPAT,"UTF-8"));
+ $user_cur->step_inc();
+ }
+ }
+ }
+ }
+ else {
+ for ($i = 0 ; $i < ($user->stat == 'room' ? MAX_PLAYERS : PLAYERS_N) ; $i++) {
+ if ($user->stat == 'room') {
+ $user_cur = &$this->user[$i];
+ if ($user_cur->sess == '' || $user_cur->stat != 'room')
+ continue;
+ }
+ else {
+ $user_cur = &$this->user[$table->player[$i]];
+ }
+
+ $user_cur->comm[$user_cur->step % COMM_N] = "gst.st = ".($user_cur->step+1)."; ";
+ $user_cur->comm[$user_cur->step % COMM_N] .= sprintf('chatt_sub("%s","%s");',
+ $dt.xcape($user->name), xcape($user_mesg));
+ $user_cur->step_inc();
+ }
+ log_legal($timecur, $user->sess, $user->name,
+ ($user->stat == 'room' ? 'room' : 'table '.$user->table),$user_mesg);
+ }
+ }
+ function table_wakeup(&$user)
+ {
+ $table = &$this->table[0];
+
+ log_main("BRISKIN5_WAKEUP", "begin function table stat: ".$user->stat." subst: ".$user->subst);
+
+ $curtime = time();
+
+ log_main("BRISKIN5_WAKEUP", "from table [".$user->table."] nplayers_n: ".$this->table[$user->table]->player_n);
+
+ for ($i = 0 ; $i < $table->player_n ; $i++) {
+ $user_cur = &$this->user[$i];
+ log_main("PREIMPOST", "INLOOP name: ".$user_cur->name);
+
+ if ($user_cur == $user)
+ $user_cur->subst = "shutdowner";
+ else
+ $user_cur->subst = "shutdowned";
+ $user_cur->laccwr = $curtime;
+
+ $ret = "gst.st = ".($user_cur->step+1)."; ";
+ $ret .= 'gst.st_loc++; the_end=true; window.onunload = null; document.location.assign("../index.php");|';
+
+ log_wr($user_cur->sess, "BRISKIN5_WAKEUP: ".$ret);
+ $user_cur->comm[$user_cur->step % COMM_N] = $ret;
+ $user_cur->step_inc();
+ }
+ }
+
+ /*
+ * If all players are freezed the room garbage_manager clean up table and users.
+ */
+ function is_abandoned()
+ {
+ $is_ab = TRUE;
+ $curtime = time();
+
+ $table = &$this->table[0];
+
+ for ($i = 0 ; $i < $table->player_n ; $i++) {
+ $user_cur = &$this->user[$i];
+
+ if ($user_cur->lacc + (EXPIRE_TIME_RD * 2) >= $curtime) {
+ $is_ab = FALSE;
+ break;
+ }
+ }
+
+ return ($is_ab);
+ }
+} // end of class Briskin5
+
+function locshm_exists($tok)
+{
+ // return (TRUE);
+
+ if (($id = shmop_open($tok,"a", 0, 0)) == FALSE) {
+ log_main($tok, "SHM NOT exists");
+
+ return (FALSE);
+ }
+ else {
+ shmop_close($id);
+ log_main($tok, "SHM exists");
+
+ return (TRUE);
+ }
+
}
+
?>
\ No newline at end of file