1 | <?php
|
---|
2 |
|
---|
3 | $ScriptStartTime = GetMicrotime();
|
---|
4 |
|
---|
5 | if(isset($_SERVER['REMOTE_ADDR'])) session_start();
|
---|
6 |
|
---|
7 | // SQL injection hack protection
|
---|
8 | foreach($_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 | }
|
---|
14 | foreach($_GET as $Index => $Item) $_GET[$Index] = addslashes($_GET[$Index]);
|
---|
15 |
|
---|
16 | include_once(dirname(__FILE__).'/config.php');
|
---|
17 | include_once(dirname(__FILE__).'/error.php');
|
---|
18 | include_once(dirname(__FILE__).'/databaseconection.php');
|
---|
19 | include_once(dirname(__FILE__).'/global_function.php');
|
---|
20 | include_once(dirname(__FILE__).'/rss.php');
|
---|
21 | include_once(dirname(__FILE__).'/system.php');
|
---|
22 | include_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 |
|
---|
36 | function GetMicrotime()
|
---|
37 | {
|
---|
38 | list($Usec, $Sec) = explode(' ', microtime());
|
---|
39 | return ((float)$Usec + (float)$Sec);
|
---|
40 | }
|
---|
41 |
|
---|
42 | function 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 |
|
---|
56 | function 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> <a href="'.$Config['Web']['BaseURL'].'registrace.php">Registrace</a></span>');
|
---|
72 | }
|
---|
73 | echo('</div>');
|
---|
74 | }
|
---|
75 |
|
---|
76 | function 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 |
|
---|
102 | function 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 |
|
---|
120 | function 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&channel=%23wowpreklad&forcePrompt=true&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 |
|
---|
156 | function 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.'&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.'&not&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'].'&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(' <a title="Zde můžete začít překládat" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&action=notran">Nepřeložené</a><br />
|
---|
174 | <a title="Přeložené texty, můžete zde hlasovat, nebo opravovat překlady" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&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(' <a title="Vypsání souvislostí" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&action=connexion_list">Souvislosti</a><br />');
|
---|
178 |
|
---|
179 | if($User->Licence(LICENCE_USER))
|
---|
180 | {
|
---|
181 | echo(' <a title="Nedokončené překlady" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&action=mydevelop">Rozepsané</a><br />
|
---|
182 | <a title="Všechny překlady, které jste přeložil" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&action=my">Vlastní</a><br />');
|
---|
183 | }
|
---|
184 | echo(' <a title="Sestavit speciální filtr" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&action=filter">Filtr</a><br />');
|
---|
185 | echo('</div>');
|
---|
186 | }
|
---|
187 | echo ('</div>');
|
---|
188 | }
|
---|
189 |
|
---|
190 | function 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 |
|
---|
205 | function 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 |
|
---|
261 | function 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 |
|
---|
274 | function 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 <a href="http://wowpreklad.zdechov.net/trac/wowpreklad/browser/trunk">Zdrojové soubory</a> '.
|
---|
290 | '<a href="http://wowpreklad.zdechov.net/trac/wowpreklad/log/trunk?verbose=on">Novinky</a> '.
|
---|
291 | '<a href="http://counter.cnw.cz/"><img src="http://counter.cnw.cz/monika.cgi?wowpreklad&5&000000&FFFFFF&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 Použitá paměť: '.HumanSize(memory_get_peak_usage(FALSE)).' / '.ini_get('memory_limit').'B <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 |
|
---|
308 | function 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 |
|
---|
324 | function 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 | ?>
|
---|