source: trunk/includes/global.php@ 376

Last change on this file since 376 was 376, checked in by george, 15 years ago
  • Upraveno: Informace o přihlášeném uživateli nově pročištěny a sjednoceny do třídy User. SQL pro kontrolu a generovány hesel dostupné přímo přes metodu CryptPasswordSQL. Přístup k Id přihlášeného uživatele přes globální proměnnou $User a vlastnost Id ($User->Id). Podobně přístup k dalším vlastnostem uživatele.
  • Opraveno: Některé chyby z předchozích předělávek.
File size: 14.4 KB
Line 
1<?php
2
3$ScriptStartTime = GetMicrotime();
4
5if(isset($_SERVER['REMOTE_ADDR'])) session_start();
6
7// SQL injection hack protection
8foreach($_POST as $Index => $Item)
9{
10 if(is_array($_POST[$Index]))
11 foreach($_POST[$Index] as $Index2 => $Item2) $_POST[$Index][$Index2] = addslashes($Item2);
12 else $_POST[$Index] = addslashes($_POST[$Index]);
13}
14foreach($_GET as $Index => $Item) $_GET[$Index] = addslashes($_GET[$Index]);
15
16include_once(dirname(__FILE__).'/config.php');
17include_once(dirname(__FILE__).'/error.php');
18include_once(dirname(__FILE__).'/databaseconection.php');
19include_once(dirname(__FILE__).'/global_function.php');
20include_once(dirname(__FILE__).'/rss.php');
21include_once(dirname(__FILE__).'/system.php');
22include_once(dirname(__FILE__).'/user.php');
23
24$Database = new Database($Config['Database']['Host'], $Config['Database']['User'], $Config['Database']['Password']);
25$Database->SQLCommand('SET NAMES '.$Config['Database']['Charset']);
26$Database->SelectDatabase($Config['Database']['Database']);
27
28$TranslationTree = GetTranslationTree();
29$LanguageList = GetLanguageList();
30
31$System = new System();
32$System->Init();
33$User = new User();
34$User->Restore();
35
36function GetMicrotime()
37{
38 list($Usec, $Sec) = explode(' ', microtime());
39 return ((float)$Usec + (float)$Sec);
40}
41
42function ShowShoutbox()
43{
44 global $Database, $Config, $User;
45
46 echo('<strong><a href="'.$Config['Web']['BaseURL'].'action.php?action=ShoutBoxView">Kecátko:</a></strong>');
47 if($User->Licence(LICENCE_USER))
48 echo(' <a href="'.$Config['Web']['BaseURL'].'action.php?action=shoutbox">Vložit</a>');
49 echo('<div class="box"><table>');
50 $ID = $Database->SQLCommand('SELECT * FROM `ShoutBox` ORDER BY `ID` DESC LIMIT 20');
51 while($Line = mysql_fetch_assoc($ID))
52 echo('<tr><td><strong>'.$Line['User'].'</strong>: '.htmlspecialchars($Line['Text']).'</td></tr>');
53 echo('</table></div>');
54}
55
56function ShowTopBar()
57{
58 global $Config, $Database, $User;
59
60 echo('<div class="Menu">');
61 echo('<span class="MenuItem"></span>');
62 if($User->Licence(LICENCE_USER))
63 {
64 $DbResult = $Database->SQLCommand('SELECT `Id`, `Name` FROM `Team` WHERE `Id`='.$User->Team);
65 $Team = mysql_fetch_assoc($DbResult);
66
67 //echo('<span class="MenuItem">Moje překlady: <a href="">Dokončené</a> <a href="">Rozpracované</a> <a href="">Exporty</a> Tým: <a href="">'.$Team['name'].'</a></span>');
68 echo('<span class="MenuItem2">'.$User->Name.' <a href="'.$Config['Web']['BaseURL'].'?action=logout">Odhlášení</a> <a href="'.$Config['Web']['BaseURL'].'Options.php">Nastavení</a></span>');
69 } else
70 {
71 echo('<span class="MenuItem2"><form action="?action=login" method="post"> Jméno: <input type="text" name="LoginUser" size="8 " /> Heslo: <td><input type="password" name="LoginPass" size="8" /> <input type="submit" value="Přihlásit" /></form> &nbsp; <a href="'.$Config['Web']['BaseURL'].'registrace.php">Registrace</a></span>');
72 }
73 echo('</div>');
74}
75
76function ShowLoginBox()
77{
78 global $User;
79
80 if($User->Licence(LICENCE_USER))
81 {
82 // echo 'Jste přihlášen jako: <b>'.$User->Id.'</b> <a href="index.php?Logout">Odhlásit</a>';
83 } else
84 {
85 echo('<strong>Přihlášení:</strong>
86 <form action="" method="post">
87 <table>
88 <tr>
89 <td><input type="text" name="LoginUser" size="13" /></td>
90 </tr>
91 <tr>
92 <td><input type="password" name="LoginPass" size="13" /></td>
93 </tr>
94 <tr>
95 <th><input type="submit" value="Přihlásit" /></th>
96 </tr>
97 </table>
98 </form>');
99 }
100}
101
102function ShowSearchBox()
103{
104 global $Config;
105
106 echo('<strong>Hledání:</strong>'.
107 '<form action="'.$Config['Web']['BaseURL'].'action.php" method="get"><div>'.
108 '<input type="hidden" name="action" value="search" />'.
109 '<table>'.
110 '<tr>'.
111 '<td><input type="text" name="search" size="13" /></td>'.
112 '</tr>'.
113 '<tr>'.
114 '<th><input type="submit" value="Hledat" /></th>'.
115 '</tr>'.
116 '</table></div>'.
117 '</form>');
118}
119
120function ShowMainMenu()
121{
122 global $TranslationTree, $Config, $User;
123
124 $Menu = array
125 (
126 $Config['Web']['BaseURL'].'index.php' => array(LICENCE_ANONYMOUS, 'Hlavní stránka', 'Domů'),
127 //'http://wow.zdechov.net/forum/viewforum.php?f=22' => array(LICENCE_ANONYMOUS, 'Diskuze na téma překládání', 'Fórum projektu'),
128 $Config['Web']['BaseURL'].'dictionary.php' => array(LICENCE_ANONYMOUS, 'Slovník WoW výrazů', 'Slovníček'),
129 $Config['Web']['BaseURL'].'statistic.php' => array(LICENCE_ANONYMOUS, 'Stav dokončení překládů', 'Stav dokončení'),
130 $Config['Web']['BaseURL'].'userlist.php?action=nofilter' => array(LICENCE_ANONYMOUS, 'Seznam registrovaných uživatelů', 'Překladatelé'),
131 $Config['Web']['BaseURL'].'team.php?search=' => array(LICENCE_ANONYMOUS, 'Seznam překladatelských týmů', 'Týmy'),
132 $Config['Web']['BaseURL'].'export/' => array(LICENCE_ANONYMOUS, 'Zde si můžete stáhnout přeložené texty', 'Exporty'),
133 $Config['Web']['BaseURL'].'download.php' => array(LICENCE_ANONYMOUS, 'Stahování různých pomocných souborů a programů', 'Soubory'),
134 $Config['Web']['BaseURL'].'info.php' => array(LICENCE_ANONYMOUS, 'Informace k překladu hry', 'Informace'),
135 $Config['Web']['BaseURL'].'TranslationList.php?action=grouplist' => array(LICENCE_ANONYMOUS, 'Informace o překladových skupinách', 'Zdroje dat'),
136 $Config['Web']['BaseURL'].'banners.php' => array(LICENCE_ANONYMOUS, 'Informace k propagaci tohoto projektu', 'Propagace'),
137 $Config['Web']['BaseURL'].'promotion.php' => array(LICENCE_ANONYMOUS, 'Prezentace a motivace překladu', 'Prezentace'),
138 $Config['Web']['BaseURL'].'version.php' => array(LICENCE_ANONYMOUS, 'Seznam verzí herního klienta', 'Verze hry'),
139 $Config['Web']['BaseURL'].'aowow' => array(LICENCE_ANONYMOUS, 'Vyhledávací databáze podobná WoWHead s překlady', 'AoWoW'),
140 $Config['Web']['BaseURL'].'server.php' => array(LICENCE_ANONYMOUS, 'Pomocný WoW server pro překladatele', 'Test server'),
141'http://embed.mibbit.com/?server=game.zdechov.net%3A6667&amp;channel=%23wowpreklad&amp;forcePrompt=true&amp;charset=utf-8' => array(LICENCE_ANONYMOUS, 'IRC chat pro překladatele', 'Chat'),
142 $Config['Web']['BaseURL'].'admin.php' => array(LICENCE_ADMIN, 'Volby pro správu', 'Administrace'),
143 );
144
145 echo('<strong>Hlavní menu:</strong>'.
146 '<div class="verticalmenu"><ul>');
147 foreach($Menu as $MenuTarget => $MenuItem)
148 {
149 if(isset($MenuItem[3])) $OnClick = ' onclick="'.$MenuItem[3].'"';
150 else $OnClick = '';
151 if($User->Licence($MenuItem[0])) echo('<li><a class="verticalmenua" title="'.$MenuItem[1].'" href="'.$MenuTarget.'"'.$OnClick.'>'.$MenuItem[2].'</a></li>');
152 }
153 echo('</ul></div>');
154}
155
156function ShowTranslatedMenu()
157{
158 global $TranslationTree, $Config, $Database, $User;
159
160 echo('<strong>Překladové skupiny:</strong><br /><div id="TranslationMenu">');
161 if($User->Licence(LICENCE_USER))
162 {
163 echo('<a title="Všechny překlady, které jste přeložil" href="'.$Config['Web']['BaseURL'].'TranslationList.php?user='.$User->Id.'&amp;action=userall">Všechny moje texty</a><br />');
164 echo('<a title="Všechny překlady, které jste rozepsal a nedokončil" href="'.$Config['Web']['BaseURL'].'TranslationList.php?user='.$User->Id.'&amp;not&amp;action=userall">Rozpracované texty</a>');
165 //TODO: počet nedokončených
166 echo('<br /><br />');
167 }
168 foreach($TranslationTree as $Group)
169 {
170 echo('<div id="menuitem-group'.$Group['Id'].'" onmousemove="show(\'group'.$Group['Id'].'\')" onmouseout="hide(\'group'.$Group['Id'].'\')">
171 <a href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&amp;action=filter">'.$Group['Name'].'</a></div>
172 <div id="group'.$Group['Id'].'" class="hidden-menu-item" onmousemove="show(\'group'.$Group['Id'].'\')" onmouseout="hide(\'group'.$Group['Id'].'\')">');
173 echo('&nbsp;<a title="Zde můžete začít překládat" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&amp;action=notran">Nepřeložené</a><br />
174 &nbsp;<a title="Přeložené texty, můžete zde hlasovat, nebo opravovat překlady" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&amp;action=Translate">Přeložené</a><br />');
175 $ID = $Database->SQLCommand('SELECT * FROM connexion WHERE `Group` = '.$Group['Id']);
176 if (mysql_num_rows($ID) > 0)
177 echo('&nbsp;<a title="Vypsání souvislostí" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&amp;action=connexion_list">Souvislosti</a><br />');
178
179 if($User->Licence(LICENCE_USER))
180 {
181 echo('&nbsp;<a title="Nedokončené překlady" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&amp;action=mydevelop">Rozepsané</a><br />
182 &nbsp;<a title="Všechny překlady, které jste přeložil" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&amp;action=my">Vlastní</a><br />');
183 }
184 echo('&nbsp;<a title="Sestavit speciální filtr" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&amp;action=filter">Filtr</a><br />');
185 echo('</div>');
186 }
187 echo ('</div>');
188}
189
190function ShowOnlineUserList()
191{
192 global $Database, $Moderators, $User;
193
194 echo('Online překladatelé:<br />');
195 $ID = $Database->SQLCommand('SELECT `Name`, `GM`, `ID` FROM `User` WHERE `LastLogin` >= NOW() - 300 AND ((`LastLogout` < `LastLogin`) OR (ISNULL(`LastLogout`)))');
196 while($DbUser = mysql_fetch_assoc($ID))
197 {
198 if($User->Licence(LICENCE_MODERATOR)) $Name = '<a href="user.php?user='.$DbUser['ID'].'">'.$DbUser['Name'].'</a>';
199 else $Name = $DbUser['Name'];
200 $TextGM = '';
201 echo('<strong>'.$Name.'</strong>'.$TextGM.'<br />');
202 }
203}
204
205function ShowPage()
206{
207 global $User, $Config, $Database, $RSSChannels, $PageFooterRequested;
208
209 echo('<?xml version="1.0" encoding="'.$Config['Web']['Charset'].'"?>
210 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
211<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="cs">'.
212'<head>'.
213'<meta http-equiv="content-type" content="application/xhtml+xml; charset=utf-8" />'.
214'<meta name="keywords" content="wow, quest, questy, questů, preklad, mangos, překlad, překládání, přeložený, přeložení, čeština, world of warcraft, open source, free, addon" />'.
215'<meta name="description" content="Projekt překládání textů hry World of Warcraft" />'.
216'<meta name="robots" content="all" />'.
217'<link rel="stylesheet" href="'.$Config['Web']['BaseURL'].'style/style.css" type="text/css" media="all" />'.
218'<script type="text/javascript" src="'.$Config['Web']['BaseURL'].'style/global.js"></script>'.
219'<link rel="SHORTCUT ICON" href="'.$Config['Web']['BaseURL'].'images/favicon.ico" />');
220 if(isset($RSSChannels))
221 foreach($RSSChannels as $Channel)
222 echo(' <link rel="alternate" title="'.$Channel['Title'].'" href="'.$Channel['URL'].'" type="application/rss+xml" />');
223 echo('<title>'.$Config['Web']['Title'].'</title>
224</head>
225<body>
226<table id="bannertable"><tr>
227 <td id="banner1"></td>
228 <td id="banner"><div id="bannertitle">'.$Config['Web']['Title'].'</div></td>
229 <td id="banner2"></td></tr>
230</table>');
231
232 if(array_key_exists('action', $_GET))
233 {
234 if($_GET['action'] == 'login')
235 {
236 $User->Login($_POST['LoginUser'], $_POST['LoginPass']);
237 if($User->Role == LICENCE_ANONYMOUS) echo('<script> alert("Jméno nebo heslo bylo zadáno špatně!"); </script>');
238 } else
239 if($_GET['action'] == 'logout')
240 {
241 if($User->Role != LICENCE_ANONYMOUS)
242 {
243 $User->Logout();
244 WriteLog('Odhlášení', LOG_TYPE_USER);
245 }
246 }
247 }
248 ShowTopBar();
249
250 echo('<table class="page"><tr><td class="menu">');
251 ShowMainMenu();
252 ShowOnlineUserList();
253 echo('<br />');
254 ShowSearchBox();
255 echo('</td><td id="border-left"></td><td class="content">');
256 $PageFooterRequested = true;
257}
258
259$UnitNames = array('B', 'kB', 'MB', 'GB', 'TB', 'PB', 'EB');
260
261function HumanSize($Value)
262{
263 global $UnitNames;
264
265 $UnitIndex = 0;
266 while($Value > 1024)
267 {
268 $Value = round($Value / 1024, 3);
269 $UnitIndex++;
270 }
271 return($Value.' '.$UnitNames[$UnitIndex]);
272}
273
274function ShowFooter()
275{
276 global $Database, $Config, $ScriptStartTime, $PageFooterRequested, $User;
277
278 if(isset($PageFooterRequested))
279 {
280 $ScriptGenerateDuration = round(GetMicrotime() - $ScriptStartTime, 2);
281
282 echo('</td>');
283 echo('<td class="menu2">');
284 ShowTranslatedMenu();
285 echo('<br />');
286 ShowShoutBox();
287 echo('</td>'.
288 '</tr><tr>'.
289 '<td colspan="4" class="page-bottom">Autoři: maron, chronos &nbsp; <a href="http://wowpreklad.zdechov.net/trac/wowpreklad/browser/trunk">Zdrojové soubory</a> &nbsp; '.
290 '<a href="http://wowpreklad.zdechov.net/trac/wowpreklad/log/trunk?verbose=on">Novinky</a> &nbsp; '.
291 '<a href="http://counter.cnw.cz/"><img src="http://counter.cnw.cz/monika.cgi?wowpreklad&amp;5&amp;000000&amp;FFFFFF&amp;on" alt="CNW:Counter" /></a>
292 <script type="text/javascript">
293 <!--
294 document.write("<a href=\"http://counter.cnw.cz\" target=\"_parent\"><img src=\"http://counter.cnw.cz/trackit.cgi?wowpreklad&t3&" + escape(top.document.referrer) + "\" alt=\"CNW:Tracker\" border=\"0\" width=\"1\" height=\"1\"><\/a>");
295 // -->
296 </script>');
297
298 echo('</td></tr>');
299 if($Config['Web']['ShowRuntimeInfo'] == true) echo('<tr><td colspan="3" style="text-align: center;">Doba generování: '.$ScriptGenerateDuration.' s / '.ini_get('max_execution_time').' s &nbsp;&nbsp; Použitá paměť: '.HumanSize(memory_get_peak_usage(FALSE)).' / '.ini_get('memory_limit').'B &nbsp;&nbsp; <a href="http://validator.w3.org/check?uri='.htmlentities('http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'].'?'.$_SERVER['QUERY_STRING']).'">HTML validator</a></td></tr>');
300 echo('</table>'.
301 '</body>'.
302 '</html>');
303 $Database->Disconnect();
304 $User->Store();
305 }
306}
307
308function GetQueryStringArray($QueryString)
309{
310 $Result = array();
311 $Parts = explode('&', $QueryString);
312 foreach($Parts as $Part)
313 {
314 if($Part != '')
315 {
316 if(!strpos($Part, '=')) $Part .= '=';
317 $Item = explode('=', $Part);
318 $Result[$Item[0]] = $Item[1];
319 }
320 }
321 return($Result);
322}
323
324function SetQueryStringArray($QueryStringArray)
325{
326 $Parts = array();
327 foreach($QueryStringArray as $Index => $Item)
328 {
329 $Parts[] = $Index.'='.$Item;
330 }
331 return(implode('&', $Parts));
332}
333
334?>
Note: See TracBrowser for help on using the repository browser.