source: trunk/includes/global.php@ 174

Last change on this file since 174 was 174, checked in by maron, 16 years ago

import překladů do AoWoW, zobrazení odkazu, a přidání položky do globálního vyhledávání

File size: 12.5 KB
Line 
1<?php
2
3$ScriptStartTime = GetMicrotime();
4
5if(!isset($_SESSION)) 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('config.php');
17include_once('error.php');
18include('databaseconection.php');
19include('global_function.php');
20
21$Database = new Database($Config['Database']['Host'], $Config['Database']['User'], $Config['Database']['Password']);
22$Database->SQLCommand('SET NAMES '.$Config['Database']['Charset']);
23$Database->SelectDatabase($Config['Database']['Database']);
24
25$TranslationTree = GetTranslationTree();
26
27function GetMicrotime()
28{
29 list($Usec, $Sec) = explode(' ', microtime());
30 return ((float)$Usec + (float)$Sec);
31}
32
33function ShowShoutbox()
34{
35 global $Database;
36
37 echo('<strong>Shoutbox:</strong><a href="action.php?action=shoutbox">Vložit</a>'.
38 '<div class="box"><table>');
39 $ID = $Database->SQLCommand('SELECT * FROM shoutbox ORDER BY ID DESC LIMIT 20');
40 while($Line = mysql_fetch_assoc($ID))
41 echo('<tr><td><strong>'.$Line['user'].'</strong>: '.$Line['text'].'</td></tr>');
42 echo('</table></div>');
43}
44
45function ShowLoginBox()
46{
47 if(Licence(LICENCE_USER))
48 {
49 // echo 'Jste přihlášen jako: <b>'.$_SESSION['User'].'</b> <a href="index.php?Logout">Odhlásit</a>';
50 } else
51 {
52 echo('<strong>Přihlášení:</strong>
53 <form action="" method="post">
54 <table>
55 <tr>
56 <td><input type="text" name="LoginUser" size="13" /></td>
57 </tr>
58 <tr>
59 <td><input type="password" name="LoginPass" size="13" /></td>
60 </tr>
61 <tr>
62 <th><input type="submit" value="Přihlásit" /></th>
63 </tr>
64 </table>
65 </form>');
66 }
67}
68
69function ShowSearchBox()
70{
71 echo('<strong>Hledání:</strong>
72 <form action="action.php" method="get"><input type="hidden" name="action" value="search" />
73 <table>
74 <tr>
75 <td><input type="text" name="search" size="13" /></td>
76 </tr>
77 <tr>
78 <th><input type="submit" value="Hledat" /></th>
79 </tr>
80 </table>
81 </form>');
82}
83
84function ShowMainMenu()
85{
86 global $TranslationTree, $Config;
87
88 $Menu = array
89 (
90 $Config['Web']['BaseURL'].'index.php' => array(LICENCE_ANONYMOUS, 'Hlavní stránka', 'Domů'),
91 'http://wow.zdechov.net/forum/viewforum.php?f=22' => array(LICENCE_ANONYMOUS, 'Diskuze na téma překládání', 'Fórum projektu'),
92 'javascript:void(0)' => array(LICENCE_ANONYMOUS, 'Slovník WoW výrazů', 'Slovníček', 'javascript:window.open(\'dictionary.php\', \'Slovník\', \'width=400, height=390\'); return false;'),
93 $Config['Web']['BaseURL'].'banners.php' => array(LICENCE_ANONYMOUS, 'Weby odkazující na tento projekt bennerem', 'Odkazují na nás'),
94 $Config['Web']['BaseURL'].'statistic.php' => array(LICENCE_ANONYMOUS, 'Stav dokončení překládů', 'Stav dokončení'),
95 $Config['Web']['BaseURL'].'userlist.php' => array(LICENCE_ANONYMOUS, 'Seznam registrovaných uživatelů', 'Uživatelé'),
96 $Config['Web']['BaseURL'].'team.php' => array(LICENCE_ANONYMOUS, 'Seznam překladatelských týmů', 'Týmy'),
97 $Config['Web']['BaseURL'].'download.php' => array(LICENCE_ANONYMOUS, 'Zde si můžete stáhnout přeložené texty', 'Stahování'),
98 $Config['Web']['BaseURL'].'info.php' => array(LICENCE_ANONYMOUS, 'Informace k překladu hry', 'Informace'),
99 $Config['Web']['BaseURL'].'registrace.php' => array(LICENCE_ANONYMOUS, 'Registrace uživatele pro překládání', 'Registrace'),
100 $Config['Web']['BaseURL'].'TranslationList.php?action=grouplist' => array(LICENCE_ANONYMOUS, 'Informace o překladových skupinách', 'Zdroje dat'),
101 $Config['Web']['BaseURL'].'aowow' => array(LICENCE_ANONYMOUS, 'Vyhledávací databáze podobná WoWHead s překlady', 'AoWoW'),
102 $Config['Web']['BaseURL'].'Options.php' => array(LICENCE_USER, 'Nastavení uživatele', 'Nastavení'),
103 $Config['Web']['BaseURL'].'index.php?Logout' => array(LICENCE_USER, 'Odhlášení ze systému', 'Odhlásit'),
104 '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'),
105 $Config['Web']['BaseURL'].'log.php' => array(LICENCE_MODERATOR, 'Log dění (Pouze moderátor)', 'Záznamy'),
106 $Config['Web']['BaseURL'].'import/' => array(LICENCE_ADMIN, 'Načtení zdrojových textů do databáze (pouze admin)', 'Import textů'),
107 $Config['Web']['BaseURL'].'img_level.php?nothide' => array(LICENCE_ADMIN, 'Načtení levelů a generování obrázků (pouze admin)', 'Generování lvl'),
108 $Config['Web']['BaseURL'].'action.php?action=dbkit' => array(LICENCE_ADMIN, 'Opravy databáze (pouze admin)', 'DB opravy'),
109 //'client_files/generate_SQL.php' => array(LICENCE_ADMIN, 'Generování clientských souborů (pouze admin)', 'Generování C.S.'),
110 'https://wow.zdechov.net/mysql/' => array(LICENCE_ADMIN, 'phpMyAdmin(pouze admin)', 'Správa databáze'),
111 );
112 //echo('Jste přihlášen jako: <strong>'.$_SESSION['User'].'</strong>
113
114
115 echo('<strong>Hlavní menu:</strong>'.
116 '<div class="verticalmenu"><ul>');
117
118 foreach($Menu as $MenuTarget => $MenuItem)
119 {
120 if(isset($MenuItem[3])) $OnClick = ' onclick="'.$MenuItem[3].'"'; else $OnClick = '';
121 if(Licence($MenuItem[0])) echo('<li><a class="verticalmenua" title="'.$MenuItem[1].'" href="'.$MenuTarget.'"'.$OnClick.'>'.$MenuItem[2].'</a></li>');
122 }
123 echo('</ul></div>');
124}
125
126function ShowTranslatedMenu()
127{
128 global $TranslationTree, $Config;
129
130 echo('<strong>Překladové skupiny:</strong><br /><div id="TranslationMenu">');
131 if(Licence(LICENCE_USER)) echo ('<a title="Všechny překlady, které jste přeložil" href="'.$Config['Web']['BaseURL'].'TranslationList.php?user='.$_SESSION['UserID'].'&amp;action=userall">Všechny moje texty</a><br /><br />');
132 foreach($TranslationTree as $Group)
133 {
134 echo('<div id="menuitem-group'.$Group['Id'].'" onmousemove="show(\'group'.$Group['Id'].'\')" onmouseout="hide(\'group'.$Group['Id'].'\')">
135 <a href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&amp;action=filter">'.$Group['Name'].'</a></div>
136 <div id="group'.$Group['Id'].'" class="hidden-menu-item" onmousemove="show(\'group'.$Group['Id'].'\')" onmouseout="hide(\'group'.$Group['Id'].'\')">');
137 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 />
138 &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 />');
139 if(Licence(LICENCE_USER))
140 {
141 echo('&nbsp;<a title="Nedokončené překlady" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&amp;action=mydevelop">Rozepsané</a><br />
142 &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 />');
143 }
144 echo('&nbsp;<a title="Sestavit speciální filtr" href="'.$Config['Web']['BaseURL'].'TranslationList.php?group='.$Group['Id'].'&amp;action=filter">Filtr</a><br />');
145 echo('</div>');
146 }
147 echo ('</div>');
148}
149
150function ShowOnlineUserList()
151{
152 global $Database, $Moderators;
153
154 echo('Online uživatelé:<br />');
155 $ID = $Database->SQLCommand("SELECT user, GM, ID FROM `user` WHERE LastLogin >= Now() - 300");
156 while ($Line = mysql_fetch_assoc($ID))
157 {
158 if(Licence(LICENCE_MODERATOR)) $Name = '<a href="user.php?user='.$Line['ID'].'">'.$Line['user'].'</a>';
159 else $Name = $Line['user'];
160 if($Line['GM'] <> 0) $TextGM = '<small>('.$Moderators[$Line['GM']].')</small>';
161 else $TextGM = '';
162 echo('<strong>'.$Name.'</strong>'.$TextGM.'<br />');
163 }
164}
165
166function ShowPage()
167{
168 global $Config, $Database, $RSSChannels;
169
170 echo('<?xml version="1.0" encoding="'.$Config['Web']['Charset'].'"?>
171<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
172<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="cs" lang="cs">
173<head>'.
174'<meta http-equiv="content-type" content="application/xhtml+xml; charset=utf-8" />'.
175'<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" />'.
176'<meta name="description" content="Projekt překládání textů hry World of Warcraft" />'.
177'<meta name="robots" content="all" />'.
178'<link rel="stylesheet" href="'.$Config['Web']['BaseURL'].'style/style.css" type="text/css" media="all" />'.
179'<script type="text/javascript" src="'.$Config['Web']['BaseURL'].'style/global.js"></script>'.
180'<link rel="SHORTCUT ICON" href="'.$Config['Web']['BaseURL'].'images/favicon.ico" />');
181 if(isset($RSSChannels))
182 foreach($RSSChannels as $Channel)
183 echo(' <link rel="alternate" title="'.$Channel['Title'].'" href="'.$Channel['URL'].'" type="application/rss+xml" />');
184 echo('<title>Projekt překládání textů WoW</title>
185</head>
186<body>
187<table id="bannertable"><tr>
188 <td id="banner1"></td>
189 <td id="banner"><div id="bannertitle">Projekt překládání textů WoW</div></td>
190 <td id="banner2"></td></tr>
191</table>');
192
193if(!array_key_exists('UserID', $_SESSION)) $_SESSION['UserID'] = '';
194if(!array_key_exists('User', $_SESSION)) $_SESSION['User'] = 'NotRegistred';
195if(!array_key_exists('Pass', $_SESSION)) $_SESSION['Pass'] = '';
196
197
198//odhlášení
199if(array_key_exists('Logout', $_GET))
200{
201 WriteLog('Odhlášení', 3);
202 $_SESSION['User'] = '';
203 $_SESSION['Pass'] = '';
204 $_SESSION['UserID'] = '';
205}
206
207// Přihlášení
208if(array_key_exists('LoginUser', $_POST))
209{
210 $_SESSION['User'] = $_POST['LoginUser'];
211 $_SESSION['Pass'] = $_POST['LoginPass'];
212
213 $Line = mysql_fetch_array($Database->SQLCommand("SELECT * FROM user WHERE LOWER(user) = LOWER('".$_SESSION['User']."') AND pass = sha1('".$_SESSION['Pass']."')"));
214 if(!$Line)
215 {
216 echo('<script> alert("Jméno nebo heslo bylo zadáno špatně!"); </script>');
217 $_SESSION['UserID'] = '';
218 $_SESSION['User'] = '';
219 $_SESSION['Pass'] = '';
220 } else
221 {
222 $_SESSION['UserID'] = $Line['ID'];
223 $_SESSION['User'] = $Line['user'];
224 WriteLog('Login: '.$_SESSION['User'], 3);
225 }
226}
227
228 //záznam o aktivitě
229 if(Licence(0)) $Database->SQLCommand('UPDATE user SET LastIP = "'.$_SERVER['REMOTE_ADDR'].'", LastLogin = NOW() WHERE ID = '.$_SESSION['UserID']);
230
231 echo ('<table class="page"><tr><td class="menu">');
232 ShowMainMenu();
233
234 // echo('<br />');
235 ShowLoginBox();
236 echo('<br />');
237 ShowOnlineUserList();
238 echo('<br />');
239 ShowSearchBox();
240 echo('</td><td id="border-left"></td><td class="content">');
241}
242
243$UnitNames = array('B', 'kB', 'MB', 'GB', 'TB', 'PB', 'EB');
244
245function HumanSize($Value)
246{
247 global $UnitNames;
248
249 $UnitIndex = 0;
250 while($Value > 1024)
251 {
252 $Value = round($Value / 1024, 3);
253 $UnitIndex++;
254 }
255 return($Value.' '.$UnitNames[$UnitIndex]);
256}
257
258function ShowFooter()
259{
260 global $Database, $Config, $ScriptStartTime;
261
262 $ScriptGenerateDuration = round(GetMicrotime() - $ScriptStartTime, 2);
263
264 echo('</td>');
265 echo('<td class="menu2">');
266 ShowTranslatedMenu();
267 echo('<br />');
268 ShowShoutBox();
269 echo('</td>');
270 echo ('</tr>
271 <tr>
272 <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; ');
273 echo('<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>
274 <script type="text/javascript">
275 <!--
276 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>");
277 // -->
278 </script>');
279
280 echo('</td></tr>');
281 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</td></tr>');
282echo('</table>
283 </body>
284</html>');
285 $Database->Disconnect();
286}
287
288?>
Note: See TracBrowser for help on using the repository browser.