Pełna wersja: Unofficial modifications
nieoficjalne modyfikacje for?w phpBB by Przemo
 
lo - fi version Unofficial modifications index

Blokada pisania w ShoutBoxie po otrzymaniu ostrze?enia
Kliknij tutaj aby przejśc do pełnej wersji tematu
Idź do strony Wstecz  1, 2
 
       Unofficial modifications Strona Główna -> Modyfikacje mniejsze
Poprzedni temat :: Następny temat  
kidzior Wysłany: Wto 20 Cze, 2006  

I co, ju? kto? wymy?li?, jak powinno to brzmie?, kiedy ma si? zainstalowanego Robota?

Tak wygl?daj? te linie u mnie:

Kod
if ( !$too_long && !$flood_msg && !$shoutbox_banned && $is_auth_send )
{
$msg_id = $db->sql_nextid();

$sql = "INSERT INTO " . SHOUTBOX_TABLE . "
VALUES($msg_id, $sb_user_id, '" . str_replace("\'", "''", $msg) . "', '" . CR_TIME . "')";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not insert shoutbox message', '', __LINE__, __FILE__, $sql);
}
include($phpbb_root_path . 'robot_data.'.$phpEx);
$rw_total = ( $user_wulg_warn - 1 );
$robot_wulg_message = ( $userdata['user_wulg'] == $rw_total ) ? $warning_text_a : $warning_text_b;

foreach ( $robot_words as $user_word => $robot_word )
{
if ( strstr(strtolower($msg), $user_word) )
{
if ( $robot_word == 'wulg' )
{
$sql = "UPDATE " . USERS_TABLE . " SET user_wulg = ( `user_wulg` + 1 ) WHERE user_id = '$sb_user_id'";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not update user_wulg', '', __LINE__, __FILE__, $sql);
}

$sql = "INSERT INTO " . SHOUTBOX_TABLE . "
VALUES(NULL, '$robot_id', '$robot_wulg_message', '" . CR_TIME . "')";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not insert robot message', '', __LINE__, __FILE__, $sql);
}
}
else
{
$sql = "INSERT INTO " . SHOUTBOX_TABLE . "
VALUES(NULL, '$robot_id', '$robot_word', '" . CR_TIME . "')";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not insert robot message', '', __LINE__, __FILE__, $sql);
}
}
}
}
if ( $userdata['user_wulg'] == $rw_total )
{
$sql = "INSERT INTO " . WARNINGS_TABLE . "
VALUES(NULL, '$sb_user_id', '$robot_id', '" . CR_TIME . "', '1', '$warn_reason', '0', '1')";

if ( !$result = $db->sql_query($sql) )
{
message_die(GENERAL_ERROR, 'Could not insert warning', '', __LINE__, __FILE__, $sql);
}
$sql = "UPDATE " . USERS_TABLE . " SET user_wulg = '0' WHERE user_id = '$sb_user_id'";
$db->sql_query($sql);
}
$start = CR_TIME - $shoutbox_config['delete_days'] * 86400;

$sql = "DELETE FROM " . SHOUTBOX_TABLE . "
WHERE timestamp < $start";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not delete shoutbox messages', '', __LINE__, __FILE__, $sql);
}

sql_cache('clear', 'sb_count');
}
}

By?bym bardzo wdzi?czny za pomoc. :)
Lordzi Wysłany: Pią 30 Cze, 2006  

KnofeL, odemnie te? masz piwo :twisted:
kris_yul Wysłany: Sro 05 Lip, 2006  

No mam ten sam problem z linijk? 530 rzekomo. Co mam z tym zrobi?, czemu nikt nie da? rozwi?zania??

[ Dodano: Sro 05 Lip, 2006 ]
Trezba doda? na ko?cu tego kodu co trzeba wklei? jedno }
KaweX Wysłany: Sro 05 Lip, 2006  

przeczytaj m?j post na pierwszej stronie
tam jest poprawka w instrukcji
kris_yul Wysłany: Sro 05 Lip, 2006  

Sory, ale Twoja poprawka te? nie dzia?a?a, bo jest taka sama jak orygina?. :)
KnofeL Wysłany: Sro 05 Lip, 2006  

Spr?bujcie tego:

Znajd?:
PHP Code:<?php

if ( !$too_long && !$flood_msg && !$shoutbox_banned && $is_auth_send )  {  $msg_id = $db->sql_nextid();  $sql = "INSERT INTO " . SHOUTBOX_TABLE . "  VALUES($msg_id, $sb_user_id, '" . str_replace("\'", "''", $msg) . "', '" . CR_TIME . "')";  if ( !($result = $db->sql_query($sql)) )  {  message_die(GENERAL_ERROR, 'Could not insert shoutbox message', '', __LINE__, __FILE__, $sql);  }  $start = CR_TIME - $shoutbox_config['delete_days'] * 86400;  $sql = "DELETE FROM " . SHOUTBOX_TABLE . "  WHERE timestamp < $start";  if ( !($result = $db->sql_query($sql)) )  {  message_die(GENERAL_ERROR, 'Could not delete shoutbox messages', '', __LINE__, __FILE__, $sql);  }  sql_cache('clear', 'sb_count');  }  }

?>

Zmie? na:
PHP Code:<?php

if ( !$too_long && !$flood_msg && !$shoutbox_banned && $is_auth_send )  { if ( $userdata['user_id'] > 1 )  { $sql = "SELECT count(*) as ile FROM " . WARNINGS_TABLE . " WHERE userid = '" . $userdata['user_id'] . "' AND archive = '0'";  if ( !($result = $db->sql_query($sql)) )  { message_die(GENERAL_ERROR, 'Could not obtain warnings info', '', __LINE__, __FILE__, $sql);  } } $warns = $db->sql_fetchrow($result);  if ( $warns['ile'] < 1 )  { $msg_id = $db->sql_nextid();  $sql = "INSERT INTO " . SHOUTBOX_TABLE . "  VALUES($msg_id, $sb_user_id, '" . str_replace("\'", "''", $msg) . "', '" . CR_TIME . "')";    if ( !($result = $db->sql_query($sql)) )  { message_die(GENERAL_ERROR, 'Could not insert shoutbox message', '', __LINE__, __FILE__, $sql);  }  $start = CR_TIME - $shoutbox_config['delete_days'] * 86400;  $sql = "DELETE FROM " . SHOUTBOX_TABLE . "  WHERE timestamp < $start";  if ( !($result = $db->sql_query($sql)) )  {  message_die(GENERAL_ERROR, 'Could not delete shoutbox messages', '', __LINE__, __FILE__, $sql);  }  sql_cache('clear', 'sb_count');  }  } else  { echo '<body onload="window.scrollTo(0,0);" />  <table cellpadding="0" cellspacing="0" align="center"><tr><td align="center"><span class="gensmall">  <b>' . $lang['Too_many_warns'] . '</b></span></td></tr></table>';  } 

?>
KaweX Wysłany: Sro 05 Lip, 2006  

dzia?a bo ja te? mia?em 530 b??d i chodzi?o o jedn? }
kris_yul Wysłany: Sro 05 Lip, 2006  

Ale ja ju? w moim pierwszym po?cie napisa?em, ?e trzeba doda? jedno }. Knofel nie ma co modyfikowa? :)
KnofeL Wysłany: Sro 05 Lip, 2006  

To ?e trzeba doda? jedno } to wiem, tyle tylko ?e tam ?andego } nie brakuje :?

Ale jak patrze na plik shoutbox_view.php to wydaje mi si? ?e to co mamy podmeni? powinno wyglaa? tak:
PHP Code:<?php

    if ( !$too_long && !$flood_msg && !$shoutbox_banned && $is_auth_send )     {         $msg_id = $db->sql_nextid();         $sql = "INSERT INTO " . SHOUTBOX_TABLE . "             VALUES($msg_id, $sb_user_id, '" . str_replace("\'", "''", $msg) . "', '" . CR_TIME . "')";         if ( !($result = $db->sql_query($sql)) )         {             message_die(GENERAL_ERROR, 'Could not insert shoutbox message', '', __LINE__, __FILE__, $sql);         }         $start = CR_TIME - $shoutbox_config['delete_days'] * 86400;         $sql = "DELETE FROM " . SHOUTBOX_TABLE . "             WHERE timestamp < $start";         if ( !($result = $db->sql_query($sql)) )         {             message_die(GENERAL_ERROR, 'Could not delete shoutbox messages', '', __LINE__, __FILE__, $sql);         }         sql_cache('clear', 'sb_count');     }

?>

Czyli nie zmieniamy dw?ch ostatnich klamr tylko jedn?.

Dlaczego, bo jak zliczmy klamry w tym co poda? qbs mam 3 klamry { i a? 4 }

My?le ?e jak dodacie jeszcze jedn? klamr? na koniec - po podmianie - nie powinni?cie mie? problem?w ;)
grzech1991 Wysłany: Wto 29 Sie, 2006  

Mam kolejny problem po napisaniu u?ytkownika z warnem w sb nic nie ma i jest ok ale nie wy?wietla mu si? ?aden text czy mo?e kto? lookn?? co jest ?le? z g?ry dzi?kuj?

Kod$lang['Pruning_unread_posts'] = 'Twoje konto przekroczy?o maksymaln± ilo¶? nieprzeczytanych post?w: <b>%s</b> Zosta?y usuni?te informacje o nieczytanych postach z wyj±tkiem post?w napisanych przez ostatnie: <b>%s</b> dni<br />Ilo¶? usuni?tych nieczytanych post?w: <b>%s</b><br /><br />Aby nie otrzymywa? tego komunikatu, przeczytaj oznaczone tematy, lub oznacz wszystkie jako przeczytane.<br />W ka?dej chwili mo?esz skorzysta? z wyszukiwarki post?w aby odszuka? posty napisane w ci±gu ostatniego wybranego czasu.';
$lang['Too_many_warns'] = 'Otrzyma?e¶ jedno ostrze?enie, nie mo?esz pisa? w ShoutBoxie.';

//
// That's all Folks!
// -------------------------------------------------

?>
cezarylee Wysłany: Nie 03 Gru, 2006  

?adnie dziala :)
warna Wysłany: Pon 04 Gru, 2006  

W razie by kto? chcia? dopisa? fragment, ?eby nie obejmowa?o to admina, to niech znajdzie:
Kodif( $userdata['user_id'] > 1 )

na

Kodif( $userdata['user_id'] > 1 && $userdata['user_level'] != ADMIN )

Mo?e si? komu? przyda :]
Raknor Wysłany: Czw 14 Cze, 2007  

A mo?e by tak, pierwsze ostrze?enie trwa przez 30 minut. Natomiast otrzymanie drugiego ostrze?enie, trwa tyle ile sobie ustawili?my w panelu administracyjnym (PA -> Og?lne -> Ostrze?enia u?ytkownik?w -> Czas trwania ostrze?enia).

:?:
InTWO Wysłany: Wto 04 Wrz, 2007  

Wszystko dzia?a w/g opisu qbs

Piwko sie nale?y ;)
 
       Unofficial modifications Strona Główna -> Modyfikacje mniejsze Idź do strony Wstecz  1, 2
Strona 2 z 2
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.