LoGD Standardrelease steht hier zum Download zur Verfügung!
<?php
// 12092004
require_once "dbwrapper.php";
require_once "anticheat.php";
$pagestarttime = getmicrotime();
$nestedtags=array();
$output="";
$HTTP_GET_VARS = &$_GET;
$HTTP_POST_VARS = &$_POST;
$HTTP_COOKIE_VARS = &$_COOKIE;
$HTTP_SESSION_VARS = &$_SESSION;
function useronline(){ //Wer ist hier online? V.1.0 by Devilzimti
global $session,$SCRIPT_NAME;
$useronline = "<table border='0' cellpadding='0' cellspacing='0' class='vitalinfo'>
<tr><td><tr><td class='charhead' colspan='2' width='184' height='27'><b> `&Hier anwesend:`0<br></b></td></tr>";
$sql = "SELECT name,login FROM accounts
WHERE (accounts.restorepage LIKE '".$SCRIPT_NAME."%"."' OR accounts.acctid=".$session[user][acctid].")
AND loggedin = 1
AND locked = 0
AND laston>'".date("Y-m-d H:i:s",strtotime("-".getsetting("LOGINTIMEOUT",900)." seconds"))."'
ORDER BY dragonkills,level;
";
$query =db_query($sql);
while($row = db_fetch_assoc($query)){
$useronline.= "<tr><td> <a href='mail.php?op=write&to=".rawurlencode($row['login'])."' target='_blank' onClick=\"".popup("mail.php?op=write&to=".rawurlencode($row['login'])).";return false;\"><img src='images/newscroll.GIF' width='16' height='16' alt='SMS schreiben' border='0'></a> ";
$useronline.= "`0<a href='biopopup.php?char=".rawurlencode($row[login])."'target='_blank' onClick='".popup("biopopup.php?char=".rawurlencode($row[login])).";return false;'>$row[name]</a></td></tr>";
}
$useronline.= "</td></tr></table>";
$useronline = appoencode($useronline,true);
return $useronline;
}
function pvpwarning($dokill=false) {
global $session;
$days = getsetting("pvpimmunity", 5);
$exp = getsetting("pvpminexp", 1500);
if ($session['user']['age'] <= $days &&
$session['user']['dragonkills'] == 0 &&
$session['user']['user']['pk'] == 0 &&
$session['user']['experience'] <= $exp) {
if ($dokill) {
output("`áWarnung!`& Da du selbst noch vor PvP geschützt warst, aber jetzt einen anderen Spieler angreifst, hast du deine Immunität verloren!!`n`n");
$session['user']['pk'] = 1;
} else {
output("`áWarnung!`& Innerhalb der ersten $days Tage in dieser Welt, oder bis sie $exp Erfahrungspunkte gesammelt haben, sind alle Spieler vor PvP-Angriffen geschützt. Wenn du einen anderen Spieler angreifst, verfällt diese Immunität für dich!`n`n");
}
}
}
function navStripC($string) {
$regexp = '/
(?:
(\?|&)(?:c=)
)
(
[[:digit:]-[:digit:]]
*?)
/uUix';
$string = preg_replace($regexp, '', $string);
return $string;
}
/*function rawoutput($indata) {
global $output;
$output .= $indata . "\n";
}*/
function rawoutput($data) {
/**
* A mod from "Basilius-Extensions"
*
* Basiert auf der originalen rawoutput()-Funktion des Release 0.9.7+jt ext GER 3
* Erweitert von Basilius "Wasili" Sauter
*
* Version vom 5. Februar 2007
*/
global $output;
// Anzahl Argumente sowie die Werte aller Argumente speichern
$argsnum = func_num_args();
$args = func_get_args();
// Nur wenn es mehr Argumente als eines, und nur dann muss vsprintf aufgerufen werden!
if($argsnum > 1) {
// Filtriere `& heraus und "Escape" das % Zeichen mit sich selbst:
$data = str_replace('`%', '`%%', $data);
// Array der Schönheithalber erstellen
$args4vsprintf = array();
// Solange $i kleiner als die Zahl der Argumente soll den neuen Array den Wert übergeben werden
for($i = 1; $i < $argsnum; $i++) {
$args4vsprintf[] = $args[$i];
}
// %s auswerten. Mehr dazu im PHP-Manual
$data = vsprintf($data, $args4vsprintf);
}
$output .= $data . "\r\n";
}
/*function output($indata,$priv=false){
global $nestedtags,$output;
$data = translate($indata);
// Aprilscherz deaktiviert ;)
// if (date("m-d")=="04-01"){
// $out = appoencode($data,$priv);
// if ($priv==false) $out = borkalize($out);
// $output.=$out;
// }else{
$output.=appoencode($data,$priv);
// }
$output.="\n";
return 0;
}*/
function striptag($data,$search=false)
{
// 2005 by Eliwood
if($search === false)
$search = array("`1","`&","`&","`4","`5","`6","`7","`8","`9",
"`!","`@","`&","`$","`&","`&","`Q","`q",
"`R","`r","`*","`~","`?","`V",
"`v","`G","`g","`T","`t");
$data = str_replace($search,"",$data);
return $data;
}
function output($data) {
/**
* A mod from "Basilius-Extensions"
*
* Basiert auf der originalen output()-Funktion des Release 0.9.7+jt ext GER 3
* Erweitert von Basilius "Wasili" Sauter
*
* Version vom 5. Februar 2007
*/
global $output;
// global $nestedtags, $output # "deprecated"
$data = translate($data);
// Anzahl Argumente sowie die Werte aller Argumente speichern
$argsnum = func_num_args();
$args = func_get_args();
// Wenn das zweite Argument boolensch ist, kann es nur als HTML-Schalter zählen;
// Speichere den Wert in $priv und setzte $j auf 2, damit die For-Schleife nicht das Argument überflüssigerweise auswertet.
if(is_bool($args[1])) {
$priv = $args[1];
$j = 2;
}
else {
$priv = false;
$j = 1;
}
// Nur wenn es mehr Argumente als eines, bzw. zwei (Im Falle vom HTML-Schalter) gibt, und nur dann muss vsprintf aufgerufen werden!
if(($j == 1 && $argsnum > 1) || ($j == 2 && $argsnum > 2)) {
// Filtriere `& heraus und "Escape" das % Zeichen mit sich selbst:
$data = str_replace('`&', '`&%', $data);
// Array der Schönheithalber erstellen
$args4vsprintf = array();
// Solange $i kleiner als die Zahl der Argumente soll den neuen Array den Wert übergeben werden
for($i = $j; $i < $argsnum; $i++) {
$args4vsprintf[] = $args[$i];
}
// %s auswerten. Mehr dazu im PHP-Manual
$data = vsprintf($data, $args4vsprintf);
}
$output .= appoencode($data, $priv);
$output .= "\r\n";
return 1;
}
function db_real_escape_string($text) {
$fname = DBTYPE.'_real_escape_string';
$fname2 = DBTYPE.'_escape_string';
if(function_exists($fname)) {
$r = $fname($text, LINK);
}
elseif(function_exists($fname2)) {
$r = $fname($text);
}
else {
$r = addslashes($text);
$r = str_replace(array("\x00", "\r", "\n", "\x1a"), array("\\x00", "\\r", "\\n", "\\x1a"), $r);
}
return $r;
}
function db_query_secure($sql, $args) {
/**
* db_query_secure()
* Eine Wrapper für mysql_query mit Vorkehrungen gegen SQL-Injections
* Imitiert PDO::Prepare und PDO::Execute
*
* Version 1.0 vom 6. August 2008
*
* © Copyright 2008 by Basilius Sauter
* Lizenziert unter der GNU GPL in Version 2 oder neuer
* Basiert auf der Originalen Funktion db_query und dem MySQL-Wrapper
* des Engelsreiches
*/
# Verfügbarmachen einiger Variablen für die Zeitauswertung
global $dbqueriesthishit, $dbtimethishit;
# Einfügen der Argumente und maskieren derselbigen
foreach($args as $key => $value) {
# Maskieren von ? und : im Argument, sofern keine Zahl vorhanden ist
if(is_int($value) === false AND is_numeric($value) === false) {
$value = str_replace('?', '!-!QUESTION_MARK_QWERTZU!-!', $value);
$value = str_replace(':', '!-!DOUBLE_POINT_QWERTZU!-!', $value);
}
if($key == '?' OR is_numeric($key)) {
if(is_int($value) OR is_float($value)) {
# Integer und Fliesskommazahlen enthalten keine Gefährlichen Zeichen. Eine Maskierung oder das
# Setzen in Fuss-Zeichen (') nicht notwendig und kann zu verfälschenden Resultaten führen
$id = md5(mt_rand(0, 30000));
$sql = preg_replace('/\?/', ":PREREPLACE_$id", $sql, 1); # preg_replace, da str_replace keine Limitationen beherrscht
$sql = str_replace(":PREREPLACE_$id", $value, $sql);
}
else {
$value = db_real_escape_string($value); # Wrapper-Funktion für mysql_real_escape_string()
$id = md5(mt_rand(0, 30000));
$sql = preg_replace('/\?/', ":PREREPLACE_$id", $sql, 1); # preg_replace, da str_replace keine Limitationen beherrscht
$sql = str_replace(":PREREPLACE_$id", "'$value'", $sql);
}
}
elseif(substr($key, 0, 1) == ':') {
if(is_int($value) OR is_float($value)) {
# Integer und Fliesskommazahlen enthalten keine Gefährlichen Zeichen. Eine Maskierung oder das
# Setzen in Fuss-Zeichen (') nicht notwendig und kann zu verfälschenden Resultaten führen
$sql = str_replace($key, "$value", $sql);
}
else {
$value = db_real_escape_string($value); # Wrapper-Funktion für mysql_real_escape_string()
$sql = str_replace($key, "'".$value."'", $sql);
}
}
}
# Demaskieren der Platzhalter für ? und :
$sql = str_replace('!-!QUESTION_MARK_QWERTZU!-!', '?', $sql);
$sql = str_replace('!-!DOUBLE_POINT_QWERTZU!-!', ':', $sql);
# Zeitmessung für DB-Statistik
$dbqueriesthishit++;
$dbtimethishit -= getmicrotime();
# Funktionsname zusammensetzen
$fname = DBTYPE."_query";
# Schreiben in die Datenbank
$res = $fname($sql, LINK);
# Fehlerausgabe
if($res === false) {
global $session;
if($session['user']['superuser'] >= 3) {
printf("<pre>%s</pre>", HTMLSpecialchars($sql));
}
print db_error(LINK);
exit;
}
# Zeitmessung für DB-Statistik
$dbtimethishit += getmicrotime();
# Rückgabe
return $res;
}
function allownav($link) {
global $session;
$session[allowednavs][$link]=true;
$session[allowednavs][str_replace(" ", "%20", $link)]=true;
$session[allowednavs][str_replace(" ", "+", $link)]=true;
}
function compress_out ($input) {
//Based on old YaBBSE code (c)
//Open-Source Project by Zef Hemel (zef@zefnet.com <mailto:zef@zefnet.com>)
//Copyright (c) 2001-2002 The YaBB Development Team
if((function_exists("gzcompress")) && (function_exists("crc32"))){
if(strpos(" " . $_SERVER['HTTP_ACCEPT_ENCODING'], "x-gzip")){
$encode = "x-gzip";
}
elseif(strpos(" " . $_SERVER['HTTP_ACCEPT_ENCODING'], "gzip")){
$encode = "gzip";
}
if (isset($encode)){
header("Content-Encoding: $encode");
$encode_size = strlen($input);
$encode_crc = crc32($input);
$out = "\x1f\x8b\x08\x00\x00\x00\x00\x00";
$out .= substr(gzcompress($input, 1), 0, -4);
$out .= pack("V", $encode_crc);
$out .= pack("V", $encode_size);
}
else{
$out = $input;
}
}
else{
$out = $input;
}
return ($out);
}
function safeescape($input){
return preg_replace('/([&\\\\])(["\'])/s',"\\1\\\\\\2",$input);
}
//by Chaosmaker
function petitionmail($subject,$body,$petition,$from,$seen=0,$to=0,$messageid=0) {
$subject = safeescape($subject);
$subject=str_replace("\n","",$subject);
$subject=str_replace("`n","",$subject);
$body = safeescape($body);
$sql = "INSERT INTO petitionmail (petitionid,messageid,msgfrom,msgto,subject,body,sent,seen) VALUES ('".(int)$petition."','".(int)$messageid."','".(int)$from."','".(int)$to."','".addslashes($subject)."','".addslashes($body)."',now(),'$seen')";
db_query($sql);
$sql = 'UPDATE petitions SET lastact=NOW() WHERE petitionid="'.(int)$petition.'"';
db_query($sql);
}
//end petitionmail
function systemmail($to,$subject,$body,$from=0,$noemail=false){
//$subject = safeescape($subject);
$subject = addslashes($subject);
$subject=str_replace("\n","",$subject);
$subject=str_replace("`n","",$subject);
$body = addslashes($body);
//$body = safeescape($body);
//echo $subject."<br>".$body;
$sql = "SELECT prefs,emailaddress FROM accounts WHERE acctid='$to'";
$result = db_query($sql);
$row = db_fetch_assoc($result);
db_free_result($result);
$prefs = unserialize($row['prefs']);
if ($prefs['dirtyemail']){
//output("Not cleaning: $prefs[dirtyemail]");
}else{
//output("Cleaning: $prefs[dirtyemail]");
$subject=soap($subject);
$body=soap($body);
}
$sql = "INSERT INTO mail (msgfrom,msgto,subject,body,sent) VALUES ('".(int)$from."','".(int)$to."','$subject','$body',now())";
db_query($sql);
$email=false;
if ($prefs['emailonmail'] && $from>0){
$email=true;
}elseif($prefs[emailonmail] && $from==0 && $prefs[systemmail]){
$email=true;
}
if (!is_email($row['emailaddress'])) $email=false;
if ($email && !$noemail){
$sql = "SELECT name FROM accounts WHERE acctid='$from'";
$result = db_query($sql);
$row1=db_fetch_assoc($result);
db_free_result($result);
if ($row1['name']!="") $fromline="From: ".preg_replace("'[`].'","",$row1[name])."\n";
// We've inserted it into the database, so.. strip out any formatting
// codes from the actual email we send out... they make things
// unreadable
$body = preg_replace("'[`]n'", "\n", $body);
$body = preg_replace("'[`].'", "", $body);
mail($row['emailaddress'],"Neue LoGD Mail","Du hast eine neue Nachricht von LoGD @ http://".$_SERVER[HTTP_HOST].dirname($_SERVER[SCRIPT_NAME])." empfangen.\n\n$fromline"
."Betreff: ".preg_replace("'[`].'","",stripslashes($subject))."\n"
."Body: ".stripslashes($body)."\n"
."\nDu kannst diese Meldungen in deinen Einstellungen abschalten.",
"From: ".getsetting("gameadminemail","postmaster@localhost")
);
}
}
function isnewday($level){
global $session;
if ($session['user']['superuser']<$level) {
clearnav();
$session['output']="";
page_header("FREVEL!");
$session['bufflist']['angrygods']=array(
"name"=>"`&Die Götter sind wütend!",
"rounds"=>10,
"wearoff"=>"`&Es ist den Göttern langweilig geworden, dich zu quälen.",
"minioncount"=>$session['user']['level'],
"maxgoodguydamage"=> 2,
"effectmsg"=>"`áDie Götter verfluchen dich und machen dir `&{damage}`á Schaden!",
"effectnodmgmsg"=>"`áDie Götter haben beschlossen, dich erstmal nicht zu quälen.",
"activate"=>"roundstart",
"survivenewday"=>1,
"newdaymessage"=>"`áDie Götter sind dir immer noch böse!"
);
output("DU darfst da nicht rein!`n`n");
//output("`\$Ramius, der Gott der Toten`) erscheint dir in einer Vision. Dafür, dass du versucht hast, deinen Geist mit seinem zu messen, sagt er dir wortlos, dass du keinen Gefallen mehr bei ihm hast.`n`n");
//addnews("`&Für den Versuch, die Götter zu besudeln, wurde ".$session['user']['name']." zu Tode gequält! (Hackversuch gescheitert).");
//$session['user']['hitpoints']=0;
//$session['user']['alive']=1;
//$session['user']['soulpoints']=0;
//$session['user']['gravefights']=0;
//$session['user']['deathpower']=0;
//$session['user']['experience']*=0.75;
addnav("Weiter","village.php");
page_footer();
$sql = "SELECT acctid FROM accounts WHERE superuser>=3";
$result = db_query($sql);
while ($row = db_fetch_assoc($result)) {
systemmail($row['acctid'],"`&{$session['user']['name']}`& hat versucht, Superuser-Seiten zu hacken!","Böse(r), böse(r), böse(r) {$session['user']['name']}, du bist ein Hacker!");
}
exit();
}
}
function forest($noshowmessage=false) {
global $session,$playermount;
$conf = unserialize($session['user']['donationconfig']);
addnav("Aktionen");
addnav("B?Etwas zum Bekämpfen suchen","forest.php?op=search");
if ($session['user']['level']>1)
addnav("H?Herumziehen","forest.php?op=search&type=slum");
addnav("N?Nervenkitzel suchen","forest.php?op=search&type=thrill");
//Komplette Heilung by Morpheus
if ($session['user']['hitpoints']<$session['user']['maxhitpoints']){
$config = unserialize($session['user']['donationconfig']);
if ($config['healer'] || $session[user][acctid]==getsetting("hasegg",0)) $golinda = 1;
$loglev = log($session['user']['level']);
$cost = ($loglev * ($session['user']['maxhitpoints']-$session['user']['hitpoints'])) + ($loglev*10);
if ($golinda) $cost *= .5;
$nc=100;
$newcost=round($nc*$cost/100,0);
if ($session['user']['gold']>=$newcost){
addnav("`ÑKomplette Heilung `&($newcost Gold)","forest.php?op=heal");
}
}
//Komplette Heilung Ende
addnav("","forest.php");
if ($session['user']['level']>=15 && $session['user']['seendragon']==0){
addnav("Heldentat begehen","forest.php?op=dragon");
}
addnav("Wege");
if ($conf['healer'] || $session['user']['acctid']==getsetting("hasegg",0)) {
addnav("Dharas Hütte","healer.php");
} else {
addnav("H?Hütte des Heilers","healer.php");
}
if ($session[user][hashorse]>=2) addnav("D?Dark Horse Tavern","forest.php?op=darkhorse");
//if ($playermount['tavern']>0) addnav("D?Nimm {$playermount['mountname']} zur Dark Horse Taverne","forest.php?op=darkhorse");
if ($playermount['tavern']>0 && $conf['castle']) addnav("B?Nimm {$playermount['mountname']} zur Burg","forest.php?op=castle");
addnav("Z?Zurück zum Marktplatz","village.php");
addnav("Sonstiges");
if ($session['user']['gold']>0){
addnav("Greifenfelsen","schnellbank.php");
}
if ($conf['goldmine']>0) addnav("Goldmine (".$conf[goldmine]."x)","paths.php?ziel=goldmine&pass=conf");
addnav("P?Plumpsklo","outhouse.php");
if ($session['user']['turns']<=1 ) addnav("Hexenhaus","hexe.php");
if ($noshowmessage!=true){
output("`c<table width='800'><tr>
<td width='50'></td><td> <img src='images/wald.jpg' width='700' hight='50'>
</td></tr>
</table>`c`n`0",true);
output("`c<table width='700'><tr><td align='justify'>`i`1Abseits Duskryns findet sich der erste Ausläufer des gewaltigen Lythirwaldes. Anfänglich stehen die Bäume noch weit auseinander und die kleinen Trampelpfade sind noch gut zu erkennen, die sich hier einen Weg hindurchbahnen. Hoch oben in den Ästen hört man die Vögel zwitschern und im Unterholz raschelt es leise.`n Doch je weiter man vordringt, desto unwegsamer wird das Gelände und das fröhliche Vogelgezwitscher verebbt fast gänzlich. Das dichte Blätterdach lässt nur wenig Licht hindurch und verleiht dem Wald etwas unheimliches. Du spürst, dass dies ein sehr alter Wald ist, der viele Geheimnisse und Gefahren in sich birgt. Wege gibt es hier so gut wie gar nicht mehr und so musst du deinen eigenen Weg durch das grüne Dickicht suchen.`i`n`n</td></tr></table>`c",true);
if ($session['user']['turns']<=1) output("`c<table width='700'><tr><td align='justify'>`i`1Du weißt, dass hier auch irgendwo ein altes Hexenweib lebt. Und gerade als du darüber nachdenkst, siehst du eine kleine Rauchschwade aus einem Kamin aufsteigen.`i`n`n</td></tr></table>`c",true);
}
if ($session['user']['superuser']>1){
output("`n`n`áSUPERUSER Specials:`n`0");
$d = dir("special");
while (false !== ($entry = $d->read())){
// Skip non php files (including directories)
if(strpos($entry, ".php") === false) continue;
// Skip any hidden files
if (substr($entry,0,1)==".") continue;
output("<a href='forest.php?specialinc=$entry'>$entry</a>`n", true);
addnav("","forest.php?specialinc=$entry");
}
}
}
function borkalize($in){
$out = $in;
$out = str_replace(". ",". Bork bork. ",$out);
$out = str_replace(", ",", bork, ",$out);
$out = str_replace(" h"," hoor",$out);
$out = str_replace(" v"," veer",$out);
$out = str_replace("g ","gen ",$out);
$out = str_replace(" p"," pere",$out);
$out = str_replace(" qu"," quee",$out);
$out = str_replace("n ","nen ",$out);
$out = str_replace("e ","eer ",$out);
$out = str_replace("s ","ses ",$out);
return $out;
}
function getmicrotime(){
list($usec, $sec) = explode(" ",microtime());
return ((float)$usec + (float)$sec);
}
function make_seed() {
list($usec, $sec) = explode(' ', microtime());
return (float) $sec + ((float) $usec * 100000);
}
mt_srand(make_seed());
function e_rand($min=false,$max=false){
if ($min===false) return mt_rand();
$min*=1000;
if ($max===false) return round(mt_rand($min)/1000,0);
$max*=1000;
if ($min==$max) return round($min/1000,0);
// if ($min==0 && $max==0) return 0; //do NOT as me why this line can be executed, it makes no sense, but it *does* get executed.
if ($min<$max){
return round(@mt_rand($min,$max)/1000,0);
}else if($min>$max){
return round(@mt_rand($max,$min)/1000,0);
}
}
function is_email($email){
return preg_match("/[[:alnum:]_.-]+[@][[:alnum:]_.-]{2,}.[[:alnum:]_.-]{2,}/",$email);
}
function checkban($login=false){
global $session;
if ($session['banoverride']) return false;
if ($login===false){
$ip=$_SERVER[REMOTE_ADDR];
$id=$_COOKIE[lgi];
//echo "<br>Orig output: $ip, $id<br>";
}else{
$sql = "SELECT lastip,uniqueid,banoverride FROM accounts WHERE login='$login'";
$result = db_query($sql) or die(db_error(LINK));
$row = db_fetch_assoc($result);
if ($row['banoverride']){
$session['banoverride']=true;
//echo "`nYou are absolved of your bans, son.";
return false;
}else{
//echo "`nNo absolution here, son.";
}
db_free_result($result);
$ip=$row['lastip'];
$id=$row['uniqueid'];
//echo "<br>Secondary output: $ip, $id<br>";
}
$sql = "select * from bans where ((substring('$ip',1,length(ipfilter))=ipfilter AND ipfilter<>'') OR (uniqueid='$id' AND uniqueid<>'')) AND (banexpire='0000-00-00' OR banexpire>'".date("Y-m-d")."')";
//echo $sql;
$result = db_query($sql) or die(db_error(LINK));
if (db_num_rows($result)>0){
// $msg.=$session['message'];
$session=array();
//$session['message'] = $msg;
//echo "Session Abandonment";
$session[message].="`n`áDu bist einer Verbannung zum Opfer gefallen:`n";
for ($i=0;$i<db_num_rows($result);$i++){
$row = db_fetch_assoc($result);
$session[message].=$row[banreason];
if ($row[banexpire]=="0000-00-00") $session[message].=" `\$Die Verbannung ist permanent!`0";
if ($row[banexpire]!="0000-00-00") $session[message].=" `&Der Bann wird am ".date("M d, Y",strtotime($row[banexpire]))." aufgehoben `0";
$session[message].="`n";
}
$session[message].="`áWenn du willst, kannst du mit einer Anfrage nach dem Grund fragen.";
header("Location: index.php");
exit();
}
db_free_result($result);
}
function increment_specialty(){
global $session;
if ($session[user][specialty]>0){
$skillnames = array(1=>"Dunkle Künste","Mystische Kräfte","Diebeskunst");
$skills = array(1=>"darkarts","magic","thievery");
$skillpoints = array(1=>"darkartuses","magicuses","thieveryuses");
$session[user][$skills[$session[user][specialty]]]++;
output("`nDu steigst in `f".$skillnames[$session[user][specialty]]."`& ein Level auf ".$session[user][$skills[$session[user][specialty]]]." auf. ");
$x = ($session[user][$skills[$session[user][specialty]]]) % 3;
if ($x == 0){
output("Du bekommst eine zusätzliche Anwendung!`n");
$session[user][$skillpoints[$session[user][specialty]]]++;
}else{
output("Nur noch ".(3-$x)." weitere Stufen, bis du eine zusätzliche Anwendung erhältst!`n");
}
}else{
output("`5Du wanderst ziel- und planlos durchs Leben. Du solltest eine Rast machen und einige wichtige Entscheidungen für dein weiteres Leben treffen.`n");
}
}
function fightnav($allowspecial=true, $allowflee=true){
global $PHP_SELF,$session;
//$script = str_replace("/","",$PHP_SELF);
$script = substr($PHP_SELF,strrpos($PHP_SELF,"/")+1);
addnav("Kämpfen","$script?op=fight");
if ($allowflee) {
addnav("Wegrennen","$script?op=run");
}
if (getsetting("autofight",0)){
addnav("AutoFight");
addnav("5 Runden kämpfen","$script?op=fight&auto=five");
addnav("Bis zum bitteren Ende","$script?op=fight&auto=full");
}
if ($allowspecial) {
addnav("`bBesondere Fähigkeiten`b");
if ($session[user][darkartuses]>0) {
addnav("`àDunkle Künste`0", "");
addnav("`à• Skelette herbeirufen`& (1/".$session[user][darkartuses].")`0","$script?op=fight&skill=DA&l=1",true);
}
if ($session[user][darkartuses]>1)
addnav("`à• Voodoo`& (2/".$session[user][darkartuses].")`0","$script?op=fight&skill=DA&l=2",true);
if ($session[user][darkartuses]>2)
addnav("`à• Geist verfluchen`& (3/".$session[user][darkartuses].")`0","$script?op=fight&skill=DA&l=3",true);
if ($session[user][darkartuses]>4)
addnav("`à• Seele verdorren`& (5/".$session[user][darkartuses].")`0","$script?op=fight&skill=DA&l=5",true);
if ($session[user][thieveryuses]>0) {
addnav("`fDiebeskünste`0","");
addnav("`f• Beleidigen`& (1/".$session[user][thieveryuses].")`0","$script?op=fight&skill=TS&l=1",true);
}
if ($session[user][thieveryuses]>1)
addnav("`f• Waffe vergiften`& (2/".$session[user][thieveryuses].")`0","$script?op=fight&skill=TS&l=2",true);
if ($session[user][thieveryuses]>2)
addnav("`f• Versteckter Angriff`& (3/".$session[user][thieveryuses].")`0","$script?op=fight&skill=TS&l=3",true);
if ($session[user][thieveryuses]>4)
addnav("`f• Angriff von hinten`& (5/".$session[user][thieveryuses].")`0","$script?op=fight&skill=TS&l=5",true);
if ($session[user][magicuses]>0) {
addnav("`lMystische Kräfte`0","");
//disagree with making this 'n', players shouldn't have their behavior dictated by convenience of god mode, hehe
addnav("g?`l• Regeneration`& (1/".$session[user][magicuses].")`0","$script?op=fight&skill=MP&l=1",true);
}
if ($session[user][magicuses]>1)
addnav("`l• Erdenfaust`& (2/".$session[user][magicuses].")`0","$script?op=fight&skill=MP&l=2",true);
if ($session[user][magicuses]>2)
addnav("L?`l• Leben absaugen`& (3/".$session[user][magicuses].")`0","$script?op=fight&skill=MP&l=3",true);
if ($session[user][magicuses]>4)
addnav("A?`l• Blitz Aura`& (5/".$session[user][magicuses].")`0","$script?op=fight&skill=MP&l=5",true);
if ($session[user][superuser]>=3) {
addnav("`RSuperuser`0","");
addnav("!?`R• __GOD MODE","$script?op=fight&skill=godmode",true);
}
// spells by anpera
$sql="SELECT * FROM items WHERE class='Zauber' AND owner=".$session[user][acctid]." AND value1>0 ORDER BY name ASC";
$result=db_query($sql) or die(db_error(LINK));
if (db_num_rows($result)>0) addnav("Zauber");
for ($i=0;$i<db_num_rows($result);$i++){
$row = db_fetch_assoc($result);
$spellbuff=unserialize($row[buff]);
addnav("`T$spellbuff[name] `0(".$row[value1]."x)","$script?op=fight&skill=zauber&itemid=$row[id]");
}
// end spells
}
}
function appoencode($data,$priv=false)
{
global $nestedtags,$session,$appoencode;
/* Überarbeitet und verkleinert von Eliwood =D */
$output = "";
while( !(($x=strpos($data,"`")) === false) )
{
$tag=substr($data,$x+1,1);
$append=substr($data,0,$x);
$output.=($priv?$append:HTMLEntities($append));
$data=substr($data,$x+2);
if($tag == "0")
{
if ($nestedtags['color']) $output.="</span>";
unset($nestedtags['color']);
}
elseif($tag == "`")
{
$output.="`";
}
elseif($tag == "z")
{
// Zufällige Farbe - by Devilzimti
$appoencode_s = $appoencode;
shuffle($appoencode_s);
$rand = e_rand(0,count($appoencode_s));
if ($nestedtags['color']) $output.="</span>"; else $nestedtags['color']=true;
$output.="<span style='color: #".$appoencode_s[$rand]['color'].";'>";
}
else
{
if(isset($appoencode[$tag]))
{
$tagrow = $appoencode[$tag];
if(empty($tagrow['color']))
{
if($nestedtags[$tagrow['tag']] && strchr($tagrow['tag']," /")==false)
{
$output.="</".$tagrow['tag'].">";
unset($nestedtags[$tagrow['tag']]);
}
elseif(strchr($tagrow['tag']," /")==true) $output.="<".$tagrow['tag'].">\n";
else
{
$output.="<".$tagrow['tag']." ".$tagrow['style'].">";
$nestedtags[$tagrow['tag']] = true;
}
}
else
{
if ($nestedtags['color']) $output.="</span>"; else $nestedtags['color']=true;
$output.="<span style='color: #".$tagrow['color'].";'>";
}
}
else $output.=$tag;
}
}
if ($priv)
$output.=$data;
else
$output.=HTMLEntities($data);
return $output;
}
function Load_Tags()
{
global $db,$link;
/* (c) 2005 by Eliwood & Serra */
$result = DB_Query("SELECT SQL_CACHE * FROM appoencode",LINK);
$tags = array();
while($row = DB_Fetch_Assoc($result))
{
$tags[$row['code']] = $row;
}
return $tags;
}
function Get_Allowed_Tags()
{
global $appoencode;
/* (c) 2005 by Eliwood & Serra */
while(list($key,$val) = each($appoencode))
{
if($val['allowed'] == true) $list.=$val['code'];
}
return preg_quote($list);
}
/**
* @desc Erzeugt einen HTML Link
* @param STR $name Name des Links
* @param STR $link Adresse, zu der der Link führen soll
* @param BOOL $direct_out TRUE wenn der Link direkt mit der Funktion output ausgegeben werden soll. FALSE wenn er mit return zurückgegeen werden soll.
* @param STR $sec_confirm Text für die Sicherheitsabfrage. FALSE wenn keine Sicherheitsabfrage gestellt werden soll
* @return STR Der fertige HTML Link
* @autor Andras/Draza´ar 26.03.2011
*/
function createLink($name, $link, $direct_out=true, $sec_confirm=false)
{
$ret = '<a href="'.$link.'"'.($sec_confirm?' onClick="return confirm(\''.$sec_confirm.'\'); return false"':'').'>'.$name.'</a>';
if($direct_out)
output($ret, true);
else
return $ret;
}
// Angegebene Tags am Ende des Strings schließen
// (macht keinen Sinn bei Farben, da die nicht geschlossen werden)
function closetags($string, $tags) {
$tags = explode('`',$tags);
foreach ($tags as $siht) {
$siht = trim($siht);
if ($siht=='') continue;
if (substr_count($string,'`'.$siht)%2) $string .= '`'.$siht;
}
return $string;
}
function templatereplace($itemname,$vals=false){
global $template;
@reset($vals);
if (!isset($template[$itemname])) output("`bWarnung:`b Das `i$itemname`i Template wurde nicht gefunden!`n");
$out = $template[$itemname];
//output($template[$itemname]."`n");
while (list($key,$val)=@each($vals)){
if (strpos($out,"{".$key."}")===false) output("`bWarnung:`b Das `i$key`i Teil wurde im `i$itemname`i Template nicht gefunden! (".$out.")`n");
$out = str_replace("{"."$key"."}",$val,$out);
}
return $out;
}
function addcharstat($title,$value=false){
// 2005 by Eliwood
if ($value===false)
{
$charstat.=appoencode(templatereplace("stathead",array("title"=>$title)),true);
}
else
{
$charstat.=appoencode(
templatereplace("statrow",array("title"=>"$title","value"=>"$value"))
,true);
}
return $charstat;
}
function charstats(){
global $session;
$u =& $session[user];
if ($session[loggedin]){
$u['hitpoints']=round($u['hitpoints'],0);
$u['experience']=round($u['experience'],0);
$u['maxhitpoints']=round($u['maxhitpoints'],0);
$exparray=array(1=>100,400,1002,1912,3140,4707,6641,8985,11795,15143,19121,23840,29437,36071,43930,55000);
while (list($key,$val)=each($exparray)){
$exparray[$key]= round($val + ($session['user']['dragonkills']/4) * $session['user']['level'] * 100,0);
}
$exp = $session[user][experience]-$exparray[$session[user][level]-1];
$req=$exparray[$session[user][level]]-$exparray[$session[user][level]-1];
$goldbank ="`F". $u['gold']."/".$u['goldinbank'];
$waffei = $u['weapon']."`0 (".$u['weapondmg'].")";
$rusti = $u['armor']."`0 (".$u['armordef'].")";
$spirits=array("-6"=>"Wiedererweckt","-2"=>"Sehr schlecht","-1"=>"Schlecht","0"=>"Normal","1"=>"Gut","2"=>"Sehr gut");
if ($u[alive]){ }else{ $spirits[$u[spirits]] = "TOT"; }
reset($session[bufflist]);
$atk=$u[attack];
$def=$u[defence];
while (list($key,$val)=each($session[bufflist])){
$buffs.=appoencode("`N$val[name] `&($val[rounds] Runden übrig)`n",true);
if (isset($val[atkmod])) $atk *= $val[atkmod];
if (isset($val[defmod])) $def *= $val[defmod];
}
$atk = round($atk, 2);
$def = round($def, 2);
$atk = ($atk == $u[attack] ? "`&" : ($atk > $u[attack] ? "`&" : "`$")) . "`0`b$atk`b`0";
$def = ($def == $u[defence] ? "`&" : ($def > $u[defence] ? "`&" : "`$")) . "`0`b$def`b`0";
if (count($session[bufflist])==0){
$buffs.=appoencode("`&Keine`0",true);
}
$charstat=appoencode(templatereplace("statstart")
.templatereplace("stathead",array("title"=>"Vital Info"))
.templatereplace("statrow",array("title"=>"Name`0","value"=>appoencode($u[name],false)))
,true);
if ($session['user']['alive']){
$charstat.=appoencode(
templatereplace("statrow",array("title"=>"Lebenspunkte`0","value"=>"$u[hitpoints]`0/$u[maxhitpoints]".grafbar($u[maxhitpoints],$u[hitpoints])))
.templatereplace("statrow",array("title"=>"Runden`&","value"=>$u['turns']))
,true);
}else{
$charstat.=appoencode(
templatereplace("statrow",array("title"=>"Seelenpunkte`0","value"=>"$u[soulpoints]".grafbar((5*$u[level]+50),$u[soulpoints])))
.templatereplace("statrow",array("title"=>"Foltern`0","value"=>$u['gravefights']))
.templatereplace("statrow",array("title"=>"Gefallene","value"=>$u['deathpower']))
,true);
}
$charstat.=appoencode(
templatereplace("statrow",array("title"=>"Stimmung`0","value"=>"`b".$spirits[(string)$u['spirits']]."`b"))
.templatereplace("statrow",array("title"=>"Erfahrung","value"=>"".$u[experience]."/`0".$exparray[$session[user][level]]."".grafbar($req,$exp).""))
.templatereplace("statrow",array("title"=>"Level`0","value"=>"`b".$u['level']."`b"))
.templatereplace("statrow",array("title"=>"Edelsteine`0","value"=>$u['gems']))
//.templatereplace("statrow",array("title"=>"Gold`0","value"=>$u['gold']))
.templatereplace("statrow",array("title"=>"Gold / Bank","value"=>$goldbank))
.templatereplace("statrow",array("title"=>"RPG-Punkte`0","value"=>$u['donation']-$u['donationspent']))
.templatereplace("statrow",array("title"=>"Charme","value"=>$u['charm']))
.templatereplace("stathead",array("title"=>"Weitere Infos"))
.($session['user']['alive']?
templatereplace("statrow",array("title"=>"Angriff`0","value"=>$atk))
.templatereplace("statrow",array("title"=>"Verteidigung`0","value"=>$def))
:
templatereplace("statrow",array("title"=>"Psyche`0","value"=>10 + round(($u['level']-1)*1.5)))
.templatereplace("statrow",array("title"=>"Geist`0","value"=>10 + round(($u['level']-1)*1.5)))
)
.templatereplace("statrow",array("title"=>"Waffe","value"=>$waffei))
.templatereplace("statrow",array("title"=>"Rüstung","value"=>$rusti)),true);
$charstat.=appoencode(templatereplace("statrow",array("title"=>"Profil`0","value"=>"<a href='prefs.php?op=popi' target='_blank' onClick='".popup("prefs.php?op=popi").";return false;'>bearbeiten</a>")),true);
$charstat.=appoencode(templatereplace("statrow",array("title"=>"Inventar`0","value"=>"<a href='inventory.php?op=inventory' target='_blank' onClick='".popup("inventory.php?op=inventory").";return false;'>anzeigen</a>")),true);
$charstat .= appoencode(templatereplace("statrow",array("title"=>"Farben`0","value"=>"<a href='farben.php' target='_blank' onClick=\"".popup("farben.php").";return false;\">aussuchen</a>")),true);
if (getsetting("dispnextday",0)){
$time = gametime();
$tomorrow = strtotime(date("Y-m-d H:i:s",$time)." + 1 day");
$tomorrow = strtotime(date("Y-m-d 00:00:00",$tomorrow));
$secstotomorrow = $tomorrow-$time;
$realsecstotomorrow = round($secstotomorrow / (int)getsetting("daysperday",4));
$charstat.=appoencode(templatereplace("statrow",array("title"=>"Nächster Tag`0","value"=>date("G\\h, i\\m, s\\s \\",strtotime("1980-01-01 00:00:00 + $realsecstotomorrow seconds")))),true);
}
if (!is_array($session[bufflist])) $session[bufflist]=array();
$charstat.=appoencode(templatereplace("statbuff",array("title"=>"Aktionen`0","value"=>$buffs)),true);
$charstat.=appoencode(templatereplace("statend"),true);
return $charstat;
}else{
/* Spieler; Moderatoren; Admin; Onlineanzeige by Eliwood */
$onlinecount = 0; $users = 0; $stadtwache = 0; $moderator = 0; $admin = 0;
$sql="SELECT name,superuser FROM accounts WHERE locked=0 AND loggedin=1 AND laston>'".date("Y-m-d H:i:s",strtotime(date("r")."-".getsetting("LOGINTIMEOUT",900)." seconds"))."' ORDER BY level DESC";
$result = db_query($sql) or die(db_error($sql));
while ($row = db_fetch_assoc($result)){
switch($row['superuser']):
case 0:
case 1:
case 2:
$text.="`&$row[name]";
$users ++;
break;
case 3:
$text4.="`&$row[name]`n";
$admin++;
break;
endswitch;
$onlinecount++;
}
$ret.=appoencode("`n$admin Admins Online:`n");
$ret.=appoencode($text4."`0");
if ($admin==0) $ret.=appoencode("`iKeine Admins Online`i`n");
$ret.=appoencode("`n$users Bewohner Online`n");
$ret.=appoencode($text."`0");
if ($users ==0) $ret.=appoencode("`iKeine Bewohner Online`i`n");
db_free_result($result);
$ret.=(getsetting("maxonline",10)>0?grafbar(getsetting("maxonline",10),(getsetting("maxonline",10)-$onlinecount),180):"");
return $ret;
}
}
$accesskeys=array();
$quickkeys=array();
function addnav($text,$link=false,$priv=false,$pop=false,$newwin=false){
global $nav,$session,$accesskeys,$REQUEST_URI,$quickkeys;
$text = translate($text);
/*
if (date("m-d")=="04-01"){
$text = borkalize($text);
}
*/
if ($link===false){
$nav.=templatereplace("navhead",array("title"=>appoencode($text,$priv)));
}elseif ($link === "") {
$nav.=templatereplace("navhelp",array("text"=>appoencode($text,$priv)));
}else{
if ($text!=""){
$extra="";
if ($newwin===false) {
if (strpos($link,"?")){
$extra="&c=$session[counter]";
}else{
$extra="?c=$session[counter]";
}
}
if ($newwin===false) $extra.="-".date("His");
//$link = str_replace(" ","%20",$link);
//hotkey for the link.
$key="";
if (substr($text,1,1)=="?") {
// check to see if a key was specified up front.
if ($accesskeys[strtolower(substr($text, 0, 1))]==1){
// output ("key ".substr($text,0,1)." already taken`n");
$text = substr($text,2);
}else{
$key = substr($text,0,1);
$text = substr($text,2);
//output("key set to $key`n");
$found=false;
for ($i=0;$i<strlen($text); $i++){
$char = substr($text,$i,1);
if ($ignoreuntil == $char){
$ignoreuntil="";
}else{
if ($ignoreuntil<>""){
if ($char=="<") $ignoreuntil=">";
if ($char=="&") $ignoreuntil=";";
if ($char=="`") $ignoreuntil=substr($text,$i+1,1);
}else{
if ($char==$key) {
$found=true;
break;
}
}
}
}
if ($found==false) {
if (strpos($text, "__") !== false)
$text=str_replace("__", "(".$key.") ", $text);
else
$text="(".strtoupper($key).") ".$text;
$i=strpos($text, $key);
// output("Not found`n");
}
}
//
}
if ($key==""){
for ($i=0;$i<strlen($text); $i++){
$char = substr($text,$i,1);
if ($ignoreuntil == $char) {
$ignoreuntil="";
}else{
if (($accesskeys[strtolower($char)]==1) || (strpos("abcdefghijklmnopqrstuvwxyz0123456789", strtolower($char)) === false) || $ignoreuntil<>"") {
if ($char=="<") $ignoreuntil=">";
if ($char=="&") $ignoreuntil=";";
if ($char=="`") $ignoreuntil=substr($text,$i+1,1);
}else{
break;
}
}
}
}
if ($i<strlen($text)){
$key=substr($text,$i,1);
$accesskeys[strtolower($key)]=1;
$keyrep=" accesskey=\"$key\" ";
}else{
$key="";
$keyrep="";
}
//output("Key is $key for $text`n");
if ($key==""){
//$nav.="<a href=\"".HTMLEntities($link.$extra)."\" class='nav'>".appoencode($text,$priv)."<br></a>";
//$key==""; // This is useless
}else{
$text=substr($text,0,strpos($text,$key))."`H".$key."`H".substr($text,strpos($text,$key)+1);
if ($pop){
$quickkeys[$key]=popup($link.$extra);
}else{
$quickkeys[$key]="window.location='$link$extra';";
}
}
$nav.=templatereplace("navitem",array(
"text"=>appoencode($text,$priv),
"link"=>HTMLEntities($link.$extra),
"accesskey"=>$keyrep,
"popup"=>($pop==true ? "target='_blank' onClick=\"".popup($link.$extra)."; return false;\"" : ($newwin==true?"target='_blank'":""))
));
//$nav.="<a href=\"".HTMLEntities($link.$extra)."\" $keyrep class='nav'>".appoencode($text,$priv)."<br></a>";
}
$session[allowednavs][$link.$extra]=true;
$session[allowednavs][str_replace(" ", "%20", $link).$extra]=true;
$session[allowednavs][str_replace(" ", "+", $link).$extra]=true;
}
}
function savesetting($settingname,$value){
global $settings;
loadsettings();
if ($value>""){
if (!isset($settings[$settingname])){
$sql = "INSERT INTO settings (setting,value) VALUES (\"".addslashes($settingname)."\",\"".addslashes($value)."\")";
}else{
$sql = "UPDATE settings SET value=\"".addslashes($value)."\" WHERE setting=\"".addslashes($settingname)."\"";
}
db_query($sql) or die(db_error(LINK));
$settings[$settingname]=$value;
if (db_affected_rows()>0) return true; else return false;
}
return false;
}
function loadsettings(){
global $settings;
//as this seems to be a common complaint, examine the execution path of this function,
//it will only load the settings once per page hit, in subsequent calls to this function,
//$settings will be an array, thus this function will do nothing.
if (!is_array($settings)){
$settings=array();
$sql = "SELECT * FROM settings";
$result = db_query($sql) or die(db_error(LINK));
for ($i=0;$i<db_num_rows($result);$i++){
$row = db_fetch_assoc($result);
$settings[$row[setting]] = $row[value];
}
db_free_result($result);
$ch=0;
if ($ch=1 && strpos($_SERVER['SCRIPT_NAME'],"login.php")){
//@file("http://www.mightye.org/logdserver?".$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI']);
}
}
}
function getsetting($settingname,$default){
global $settings;
loadsettings();
if (!isset($settings[$settingname])){
savesetting($settingname,$default);
return $default;
}else{
if (trim($settings[$settingname])=="") $settings[$settingname]=$default;
return $settings[$settingname];
}
}
function showform($layout,$row,$nosave=false){
global $output;
output("<table>",true);
while(list($key,$val)=each($layout)){
$info = split(",",$val);
if ($info[1]=="title"){
output("<tr><td colspan='2' bgcolor='#CCCCCC'>",true);
output("`b$info[0]`0`b");
output("</td></tr>",true);
}else{
output("<tr><td nowrap valign='top'>",true);
output("$info[0]");
output("</td><td>",true);
}
switch ($info[1]){
case "title":
break;
case "enum":
reset($info);
list($k,$v)=each($info);
list($k,$v)=each($info);
$output.="<select name='$key'>";
while (list($k,$v)=each($info)){
$optval = $v;
list($k,$v)=each($info);
$optdis = $v;
$output.="<option value='$optval'".($row[$key]==$optval?" selected":"").">".HTMLEntities("$optval : $optdis")."</option>";
}
$output.="</select>";
break;
case "password":
$output.="<input type='password' name='$key' value='".HTMLEntities($row[$key])."'>";
break;
case "bool":
$output.="<select name='$key'>";
$output.="<option value='0'".($row[$key]==0?" selected":"").">Nein</option>";
$output.="<option value='1'".($row[$key]==1?" selected":"").">Ja</option>";
$output.="</select>";
break;
case "hidden":
$output.="<input type='hidden' name='$key' value=\"".HTMLEntities($row[$key])."\">".HTMLEntities($row[$key]);
break;
case "viewonly":
output(dump_item($row[$key]), true);
// output(str_replace("{","<blockquote>{",str_replace("}","}</blockquote>",HTMLEntities(preg_replace("'(b:[[:digit:]]+;)'","\\1`n",$row[$key])))),true);
break;
case "int":
$output.="<input name='$key' value=\"".HTMLEntities($row[$key])."\" size='5'>";
break;
case "textarea":
$output.="<textarea name='$key' class='input' cols='$info[2]' rows='$info[3]'>".HTMLEntities($row[$key])."</textarea>";
break;
case 'file':
$output .= "<input name='$key' type='file'>";
break;
default:
$output.=("<input size='50' name='$key' value=\"".HTMLEntities($row[$key])."\">");
//output("`n$val");
}
output("</td></tr>",true);
}
output("</table>",true);
if ($nosave) {} else output("<input type='submit' class='button' value='Speichern'>",true);
}
function clearnav(){
$session[allowednavs]=array();
}
function redirect($location,$reason=false){
global $session,$REQUEST_URI;
if ($location!="badnav.php"){
$session[allowednavs]=array();
addnav("",$location);
}
if (strpos($location,"badnav.php")===false) $session[output]="<a href=\"".HTMLEntities($location)."\">Hier klicken</a>";
$session['debug'].="Redirected to $location from $REQUEST_URI. $reason\n";
saveuser();
header("Location: $location");
echo $location;
echo $session['debug'];
exit();
}
function loadtemplate($templatename){
if (!file_exists("templates/$templatename") || $templatename=="") $templatename="Duskryn.htm";
$fulltemplate = join("",file("templates/$templatename"));
$fulltemplate = explode("<!--!",$fulltemplate);
while (list($key,$val)=each($fulltemplate)){
$fieldname=substr($val,0,strpos($val,"-->"));
if ($fieldname!=""){
$template[$fieldname]=substr($val,strpos($val,"-->")+3);
}
}
return $template;
}
function maillink(){
global $session;
$sql = "SELECT sum(if(seen=1,1,0)) AS seencount, sum(if(seen=0,1,0)) AS notseen FROM mail WHERE msgto=\"".$session[user][acctid]."\"";
$result = db_query($sql) or die(mysql_error(LINK));
$row = db_fetch_assoc($result);
db_free_result($result);
$row[seencount]=(int)$row[seencount];
$row[notseen]=(int)$row[notseen];
if ($row[notseen]>0){
return "<a href='mail.php' target='_blank' onClick=\"".popup("mail.php").";return false;\" class='hotmotd'><font size='2'>Post:</font> $row[notseen] neu, $row[seencount] alt</a>";
}else{
return "<a href='mail.php' target='_blank' onClick=\"".popup("mail.php").";return false;\" class='motd'><font size='2'>Post:</font> $row[notseen] neu, $row[seencount] alt</a>";
}
}
function motdlink(){
// missing $session caused unread motd's to never highlight the link
global $session;
if ($session[needtoviewmotd]){
return "<a href='motd.php' target='_blank' onClick=\"".popup("motd.php").";return false;\" class='hotmotd'><font size='2'><b>MoTD</b></font></a>";
}else{
return "<a href='motd.php' target='_blank' onClick=\"".popup("motd.php").";return false;\" class='motd'><font size='2'><b>MoTD</b></font></a>";
}
}
function page_header($title="LoGD 0.9.7 +jt ext (GER) 3"){
global $header,$SCRIPT_NAME,$session,$template;
$nopopups["login.php"]=1;
$nopopups["motd.php"]=1;
$nopopups["index.php"]=1;
$nopopups["create.php"]=1;
$nopopups["impressum.php"]=1;
$nopopups["about.php"]=1;
$nopopups["mail.php"]=1;
$nopopups["chat.php"]=1;
$nopopups["prefs.php"]=1;
$nopopups["inventory.php"]=1;
$nopopups["bio.php"]=1;
$nopopups["wegweiser.php"]=1;
$nopopups["biopopup.php"]=1;
$nopopups["status.php"]=1;
$nopopups["farbtab.php"]=1;
$nopopups["hexcodes.php"]=1;
$nopopups["rpanfrage.php"]=1;
$nopopups["rpbereit.php"]=1;
$nopopups["avatarlist.php"]=1;
$nopopups["farben.php"]=1;
$nopopups["comedit.php"]=1;
$header = $template['header'];
$sql = "SELECT motddate FROM motd ORDER BY motditem DESC LIMIT 1";
$result = db_query($sql);
$row = db_fetch_assoc($result);
db_free_result($result);
if (($row[motddate]>$session[user][lastmotd]) && $nopopups[$SCRIPT_NAME]!=1 && $session[user][loggedin]){
$header=str_replace("{headscript}","<script language=\"JavaScript\" type=\"text/javascript\">".popup("motd.php")."</script>",$header);
$session[needtoviewmotd]=true;
}else{
$header=str_replace("{headscript}","",$header);
$session[needtoviewmotd]=false;
}
$header=str_replace("{title}",$title,$header);
$session['user']['ort']=$title;
}
function popup($page){
return "window.open('$page','".preg_replace("([&[:alnum:]])","",$page)."','scrollbars=yes,resizable=yes,width=550,height=300')";
}
function page_footer(){
$forumlink=getsetting("forum","http://lotgd.net/forum");
//$forumlink="http://www.anpera.net/forum/index.php?c=12#";
global $output,$nestedtags,$header,$nav,$session,$REMOTE_ADDR,$REQUEST_URI,$pagestarttime,$dbtimethishit,$dbqueriesthishit,$quickkeys,$template,$logd_version;
while (list($key,$val)=each($nestedtags)){
$output.="</$key>";
unset($nestedtags[$key]);
}
$script = "<script language=\"JavaScript\" type=\"text/javascript\">
<!--
function keyevent(e){
var c;
var target;
var altKey;
var ctrlKey;
if (window.event != null) {
c=String.fromCharCode(window.event.keyCode).toUpperCase();
altKey=window.event.altKey;
ctrlKey=window.event.ctrlKey;
}else{
c=String.fromCharCode((e.charCode ? e.charCode : e.keyCode)).toUpperCase();
altKey=e.altKey;
ctrlKey=e.ctrlKey;
}
if (window.event != null)
target=window.event.srcElement || window.event.target;
else
target=e.originalTarget || e.target;
if (target.nodeName.toUpperCase()!='INPUT' && target.nodeName.toUpperCase()!='TEXTAREA' && !altKey && !ctrlKey){";
reset($quickkeys);
while (list($key,$val)=each($quickkeys)){
$script.="\n if (c == '".strtoupper($key)."') { $val; return false; }";
}
$script.="
}
}
document.onkeypress=keyevent;
//-->
</script>";
$footer = $template['footer'];
if (strpos($footer,"{paypal}") || strpos($header,"{paypal}")){ $palreplace="{paypal}"; }else{ $palreplace="{stats}"; }
//NOTICE
//NOTICE Although I will not deny you the ability to remove the below paypal link, I do request, as the author of this software
//NOTICE that you leave it in.
//NOTICE
$paypalstr = '<table align="center"><tr><td>';
$paypalstr .= '<form action="https://www.paypal.com/cgi-bin/webscr" method="post" target="_blank">
<input type="hidden" name="cmd" value="_xclick">
<input type="hidden" name="business" value="nahdude81@hotmail.com">
<input type="hidden" name="item_name" value="Legend of the Green Dragon Author Donation from '.preg_replace("/[`]./","",$session['user']['name']).'">
<input type="hidden" name="item_number" value="'.htmlentities($session['user']['login']).":".$_SERVER['HTTP_HOST']."/".$_SERVER['REQUEST_URI'].'">
<input type="hidden" name="no_shipping" value="1">
<input type="hidden" name="cn" value="Your Character Name">
<input type="hidden" name="cs" value="1">
<input type="hidden" name="currency_code" value="USD">
<input type="hidden" name="tax" value="0">
<input type="image" src="images/paypal1.gif" border="0" name="submit" alt="Donate!">
</form>';
$paysite = getsetting("paypalemail", "");
if ($paysite != "") {
$paypalstr .= '</td><td>';
$paypalstr .= '<form action="https://www.paypal.com/cgi-bin/webscr" method="post" target="_blank">
<input type="hidden" name="cmd" value="_xclick">
<input type="hidden" name="business" value="'.$paysite.'">
<input type="hidden" name="item_name" value="Legend of the Green Dragon Site Donation from '.preg_replace("/[`]./","",$session['user']['name']).'">
<input type="hidden" name="item_number" value="'.htmlentities($session['user']['login']).":".$_SERVER['HTTP_HOST']."/".$_SERVER['REQUEST_URI'].'">
<input type="hidden" name="no_shipping" value="1">
<input type="hidden" name="cn" value="Your Character Name">
<input type="hidden" name="cs" value="1">
<input type="hidden" name="currency_code" value="USD">
<input type="hidden" name="tax" value="0">
<input type="image" src="images/paypal2.gif" border="0" name="submit" alt="Donate!">
</form>';
}
$paypalstr .= '</td></tr></table>';
// $paypalstr .= '</td></tr><tr><td span="2" align="right" valign="top"><a href="http://www.anpera.net" target="_blank"><img src="images/anpnet-klein.gif" alt="Sponsor" border="0"></a></td></tr></table>';
$footer=str_replace($palreplace,(strpos($palreplace,"paypal")?"":"{stats}").$paypalstr,$footer);
$header=str_replace($palreplace,(strpos($palreplace,"paypal")?"":"{stats}").$paypalstr,$header);
//NOTICE
//NOTICE Although I will not deny you the ability to remove the above paypal link, I do request, as the author of this software
//NOTICE that you leave it in.
//NOTICE
$header=str_replace("{nav}",$nav,$header);
$footer=str_replace("{nav}",$nav,$footer);
$header = str_replace("{motd}", motdlink(), $header);
$footer = str_replace("{motd}", motdlink(), $footer);
$header = str_replace("{forum}", "<a href='$forumlink' target='_blank' class='motd'><font size='2'>Forum</font></a>", $header);
$footer = str_replace("{forum}", "<a href='$forumlink' target='_blank' class='motd'><font size='2'>Forum</font></a>", $footer);
if ($session[user][acctid]>0) {
$header=str_replace("{mail}",maillink(),$header);
$footer=str_replace("{mail}",maillink(),$footer);
$header=str_replace("{useronline}",useronline(),$header);
$footer=str_replace("{useronline}",useronline(),$footer);
$header=str_replace("{chat}","<a href='chat.php' target='_blank' class='motd' onClick=\"".popup("chat.php").";return false;\">Chat</a>",$header);
$footer=str_replace("{chat}","<a href='chat.php' target='_blank' class='motd' onClick=\"".popup("chat.php").";return false;\">Chat</a>",$footer);
}else{
$header = str_replace("{motd}", motdlink(), $header);
$footer = str_replace("{motd}", motdlink(), $footer);
$header=str_replace("{mail}","",$header);
$footer=str_replace("{mail}","",$footer);
$header=str_replace("{useronline}","",$header);
$footer=str_replace("{useronline}","",$footer);
$header=str_replace("{chat}","",$header);
$footer=str_replace("{chat}","",$footer);
}
$header=str_replace("{petition}","<a href='petition.php' onClick=\"".popup("petition.php").";return false;\" target='_blank' align='right' class='motd'><font size='2'>Anfragen</font></a>",$header);
$footer=str_replace("{petition}","<a href='petition.php' onClick=\"".popup("petition.php").";return false;\" target='_blank' align='right' class='motd'><font size='2'>Anfragen</font></a>",$footer);
/*if ($session[user][loggedin]&& $session[user][namecheck]){
$footer = "<table border='0' cellpadding='5' cellspacing='0' align='left'><tr><td><b><a href='wegweiser_2.php'><br /><br /><span style='color: #5A7132;'>Wegweiser</span></b> Kein Pop_up!</a></td></tr></table>".$footer;
addnav('','wegweiser_2.php');
}*/
if ($session['user']['superuser']>=1){
// $sql = "SELECT count(petitionid) AS c,status FROM petitions GROUP BY status";
$sql = "SELECT max(lastact) AS lastact, count(petitionid) AS c,status FROM petitions GROUP BY status";
$result = db_query($sql);
$petitions=array(0=>0,1=>0,2=>0);
$petitions['unread'] = false;
for ($i=0;$i<db_num_rows($result);$i++){
$row = db_fetch_assoc($result);
$petitions[(int)$row['status']] = $row['c'];
if ($row['lastact']>$session['lastlogoff']) $petitions['unread'] = true;
}
db_free_result($result);
// Neue Petitionen; schauen, ob Sternchen nötig ist
$petitions['star'] = '';
if ($petitions['unread']) {
$sql = 'SELECT petitionid, lastact FROM petitions WHERE lastact > "'.$session['lastlogoff'].'"';
$result = db_query($sql);
while ($row = db_fetch_assoc($result)) {
if (!$session['petitions'][$row['petitionid']]) {
$petitions['star'] = '<span class="colDkRed">*</span>';
}
}
db_free_result($result);
}
$footer = "<table border='0' cellpadding='5' cellspacing='0' align='right'><tr><td><b><a href='viewpetition.php'><br /><br />Anfragen</a>$petitions[star]:</b> $petitions[0] Ungelesen, $petitions[1] Gelesen, $petitions[2] Geschlossen.</td></tr></table>".$footer;
//$footer = "<table border='0' cellpadding='5' cellspacing='0' align='right'><tr><td><b>Anfragen</b> $petitions[0] Ungelesen, $petitions[1] Gelesen, $petitions[2] Geschlossen.</td></tr></table>".$footer;
addnav('','viewpetition.php');
}
$footer=str_replace("{stats}",charstats(),$footer);
$header=str_replace("{stats}",charstats(),$header);
$header=str_replace("{script}",$script,$header);
if ($session[user][loggedin]){
$footer=str_replace("{source}","<a href='source.php?url=".preg_replace("/[?].*/","",($_SERVER['REQUEST_URI']))."' target='_blank'>Source</a>",$footer);
$header=str_replace("{source}","<a href='source.php?url=".preg_replace("/[?].*/","",($_SERVER['REQUEST_URI']))."' target='_blank'>Source</a>",$header);
}else{
$footer=str_replace("{source}","<a href='source.php' target='_blank'>Source</a>",$footer);
$header=str_replace("{source}","<a href='source.php' target='_blank'>Source</a>",$header);
}
$footer=str_replace("{copyright}","Copyright 2002-2003, Game: Eric Stevens",$footer);
$footer=str_replace("{version}", "Version: $logd_version", $footer);
$gentime = getmicrotime()-$pagestarttime;
$session[user][gentime]+=$gentime;
$session[user][gentimecount]++;
$dbtimethishit=round($dbtimethishit,2);
$footer=str_replace("{pagegen}","Seitengenerierung: ".round($gentime,2)."s, Schnitt: ".round($session[user][gentime]/$session[user][gentimecount],2)."s - ".round($session[user][gentime],2)."/".round($session[user][gentimecount],2)."".($session[user][superuser]>1?"; DB: $dbqueriesthishit in $dbtimethishit s":"")."",$footer);
// $footer=str_replace("{pagegen}","Seitengenerierung: ".round($gentime,2)."s, Schnitt: ".round($session[user][gentime]/$session[user][gentimecount],2)."s".($session[user][superuser]>1?"; DB: $dbqueriesthishit in ".$dbtimethishit."s":"")."",$footer);
if (strpos($_SERVER['HTTP_HOST'],"lotgd.net")!==false){
$footer=str_replace(
"</html>",
'<script language="JavaScript" type="text/JavaScript" src="http://www.reinvigorate.net/archive/app.bin/jsinclude.php?5193"></script></html>',
$footer
);
}
$output=$header.$output.$footer;
$session['user']['gensize']+=strlen($output);
$session[output]=$output;
saveuser();
session_write_close();
//`mpg123 -g 100 -q hit.mp3 2>&1 > /dev/null`;
//echo compress_out($output);
echo $output;
exit();
}
function popup_header($title="Legend of the Green Dragon"){
global $header;
$header.="<html><head><title>$title</title>";
//$header.="<link href=\"newstyle.css\" rel=\"stylesheet\" type=\"text/css\">";
$header.="<link href=\"templates/Duskryn.css\" rel=\"stylesheet\" type=\"text/css\">";
$header.="</head><body bgcolor='#000000' text='#CCCCCC'><table cellpadding=5 cellspacing=0 width='100%'>";
$header.="<tr><td class='popupheader'><b>$title</b></td></tr>";
$header.="<tr><td valign='top' width='100%'>";
/*
//motd style [Code from & conformistly 1.0.2 by Eliwood,Day]
global $header, $template;
$header = $template['popuphead'];
$header = str_replace("{title}", $title, $header);
$header.="<html><body bgcolor='#000000' text='#CCCCCC'><table cellpadding=5 cellspacing=0 width='100%'>";
$header.="<tr><td class='popupheader'><b>$title</b></td></tr>";
$header.="<tr><td valign='top' width='100%'>";
*/
}
function popup_footer(){
global $output,$nestedtags,$header,$nav,$session;
while (list($key,$val)=each($nestedtags)){
$output.="</$key>";
unset($nestedtags[$key]);
}
$output.="</td></tr><tr><td align='center'><hr><br>Skin: Ben Wong • Redesign: xXxX<br>Copyright 2002-2003, Game: Eric Stevens</td></tr></table></body></html>";
$output=$header.$output;
//$session[output]=$output;
saveuser();
echo $output;
exit();
}
function clearoutput(){
global $output,$nestedtags,$header,$nav,$session;
$session[allowednavs]="";
$output="";
unset($nestedtags);
$header="";
$nav="";
}
function soap($input){
if (getsetting("soap",1)){
$sql = "SELECT * FROM nastywords";
$result = db_query($sql);
$row = db_fetch_assoc($result);
$search = $row['words'];
$search = str_replace("a",'[a4@]',$search);
$search = str_replace("l",'[l1!]',$search);
$search = str_replace("i",'[li1!]',$search);
$search = str_replace("e",'[e3]',$search);
$search = str_replace("t",'[t7+]',$search);
$search = str_replace("o",'[o0]',$search);
$search = str_replace("s",'[sz$]',$search);
$search = str_replace("k",'c',$search);
$search = str_replace("c",'[c(k]',$search);
$start = "'(\s|\A)";
$end = "(\s|\Z)'iU";
$search = str_replace("*","([[:alnum:]]*)",$search);
$search = str_replace(" ","$end $start", $search);
$search = "$start".$search."$end";
//echo $search;
$search = split(" ",$search);
//$input = " $input ";
return preg_replace($search,"\\1`i$@#%`i\\2",$input);
}else{
return $input;
}
}
function saveuser(){
global $session,$dbqueriesthishit;
// $cmd = date("Y-m-d H:i:s")." $dbqueriesthishit ".$_SERVER['REQUEST_URI'];
// @exec("echo $cmd >> /home/groups/l/lo/lotgd/sessiondata/data/queryusage-".$session['user']['login'].".txt");
if ($session[loggedin] && $session[user][acctid]!=""){
$session[user][output]=$session[output];
$session[user][allowednavs]=serialize($session[allowednavs]);
$session[user][bufflist]=serialize($session[bufflist]);
if (is_array($session[user][prefs])) $session[user][prefs]=serialize($session[user][prefs]);
if (is_array($session[user][dragonpoints])) $session[user][dragonpoints]=serialize($session[user][dragonpoints]);
//$session[user][laston] = date("Y-m-d H:i:s");
$sql="UPDATE accounts SET ";
reset($session[user]);
while(list($key,$val)=each($session[user])){
if (is_array($val)){
$sql.="$key='".addslashes(serialize($val))."', ";
}else{
$sql.="$key='".addslashes($val)."', ";
}
}
$sql = substr($sql,0,strlen($sql)-2);
$sql.=" WHERE acctid = ".$session[user][acctid];
db_query($sql);
}
}
function createstring($array){
if (is_array($array)){
reset($array);
while (list($key,$val)=each($array)){
$output.=rawurlencode( rawurlencode($key)."\"".rawurlencode($val) )."\"";
}
$output=substr($output,0,strlen($output)-1);
}
return $output;
}
function createarray($string){
$arr1 = split("\"",$string);
$output = array();
while (list($key,$val)=each($arr1)){
$arr2=split("\"",rawurldecode($val));
$output[rawurldecode($arr2[0])] = rawurldecode($arr2[1]);
}
return $output;
}
function output_array($array,$prefix=""){
while (list($key,$val)=@each($array)){
$output.=$prefix."[$key] = ";
if (is_array($val)){
$output.="array{\n".output_array($val,$prefix."[$key]")."\n}\n";
}else{
$output.=$val."\n";
}
}
return $output;
}
function dump_item($item){
$output = "";
if (is_array($item)) $temp = $item;
else $temp = unserialize($item);
if (is_array($temp)) {
$output .= "array(" . count($temp) . ") {<blockquote>";
while(list($key, $val) = @each($temp)) {
$output .= "'$key' = '" . dump_item($val) . "'`n";
}
$output .= "</blockquote>}";
} else {
$output .= $item;
}
return $output;
}
function addnews($news){
global $session;
$sql = "INSERT INTO news(newstext,newsdate,accountid) VALUES ('".addslashes($news)."',NOW(),".$session[user][acctid].")";
return db_query($sql) or die(db_error($link));
}
function checkday() {
global $session,$revertsession,$REQUEST_URI;
//output("`&`iChecking to see if you're due for a new day: ".$session[user][laston].", ".date("Y-m-d H:i:s")."`i`n`0");
if ($session['user']['loggedin']){
output("<!--CheckNewDay()-->",true);
if(is_new_day()){
$session=$revertsession;
$session[user][restorepage]=$REQUEST_URI;
$session[allowednavs]=array();
addnav("","newday.php");
redirect("newday.php");
}
}
//check if they are starving
if ($session[user][alive]==1){
if ($session['user']['hunger']>160) output("");
if ($session['user']['hunger']>200){
output("");
$session['user']['hitpoints']*=.90;
}
}
//before $u['hitpoints']=round($u['hitpoints'],0);
//add
//$currentpage=$_SERVER['REQUEST_URI'];
if (strstr($currentpage, "?op") !=""){
$position=strrpos($currentpage,"?op");
$currentpage=substr($currentpage,0,$position);
}
//logd may need to be adjusted to fit your game location
$currentpage=str_replace("/logd/","",$currentpage);
//hunger meter
$hunger="`7- ";
$len=0;
$len2=0;
for ($i=0;$i<200;$i+=10){
if ($session['user']['hunger']>$i){
$len+=2;
}else{
$len2+=2;
}
}
$hunger.="<img src=\"./images/hmeter.gif\" title=\"\" alt=\"\" style=\"width: $len\px; height: 10px;\">";
$hunger.="<img src=\"./images/hmeterclear.gif\" title=\"\" alt=\"\" style=\"width: $len2\px; height: 10px;\">";
$hunger.="`7 +";
//end hunger meter
}
function is_new_day(){
global $session;
$t1 = gametime();
$t2 = convertgametime(strtotime($session[user][lasthit]));
$d1 = date("Y-m-d",$t1);
$d2 = date("Y-m-d",$t2);
if ($d1!=$d2){
return true;
}else{
return false;
}
}
function getgametime(){
// return date("g:i a",gametime());
return date(getsetting('gametimeformat','g:i a'),gametime());
}
// Gamedate-Mod by Chaosmaker
function getgamedate() {
$date = explode('-',getsetting('gamedate','0005-01-01'));
$find = array('%Y','%y','%m','%n','%d','%j');
$replace = array($date[0],sprintf('%02d',$date[0]%100),sprintf('%02d',$date[1]),(int)$date[1],sprintf('%02d',$date[2]),(int)$date[2]);
return str_replace($find,$replace,getsetting('gamedateformat','%Y-%m-%d'));
}
function gametime(){
$time = convertgametime(strtotime(date("c")));
return $time;
}
function convertgametime($intime){
// Hehe, einen hamwa noch, einen hamwa noch: by JT & anpera
$multi = getsetting("daysperday",4);
$offset = getsetting("gameoffsetseconds",0);
$fixtime = mktime(0,0,0-$offset,date("m")-$multi,date("d"),date("Y"));
$time=$multi*(strtotime(date("Y-m-d H:i:s",$intime))-$fixtime);
$time=strtotime(date("Y-m-d H:i:s",$time)."+".($multi*date("I",$intime))." hour");
$time=strtotime(date("Y-m-d H:i:s",$time)."-".date("I",$time). " hour");
$time=strtotime(date("Y-m-d H:i:s",$time)."+".(23-$multi)." hour");
return $time;
}
function sql_error($sql){
global $session;
return output_array($session)."SQL = <pre>$sql</pre>".db_error(LINK);
}
function ordinal($val){
$exceptions = array(1=>"ten",2=>"ten",3=>"ten",11=>"ten",12=>"ten",13=>"ten");
$x = ($val % 100);
if (isset($exceptions[$x])){
return $val.$exceptions[$x];
}else{
$x = ($val % 10);
if (isset($exceptions[$x])){
return $val.$exceptions[$x];
}else{
return $val."ten";
}
}
}
function dhms($secs,$dec=false){
if ($dec===false) $secs=round($secs,0);
return (int)($secs/86400)."d".(int)($secs/3600%24)."h".(int)($secs/60%60)."m".($secs%60).($dec?substr($secs-(int)$secs,1):"")."s";
}
function getmount($horse=0) {
$sql = "SELECT * FROM mounts WHERE mountid='$horse'";
$result = db_query($sql);
if (db_num_rows($result)>0){
return db_fetch_assoc($result);
}else{
return array();
}
}
function debuglog($message,$target=0){
global $session;
$sql = "DELETE from debuglog WHERE date <'".date("Y-m-d H:i:s",strtotime(date("c")."-".(getsetting("expirecontent",180)/10)." days"))."'";
db_query($sql);
$sql = "INSERT INTO debuglog VALUES(0,now(),{$session['user']['acctid']},$target,'".addslashes($message)."')";
db_query($sql);
}
// exp bar mod coded by: dvd871 with modifications by: anpera
function expbar() {
global $session;
$exparray=array(1=>100,400,1002,1912,3140,4707,6641,8985,11795,15143,19121,23840,29437,36071,43930,55000);
while (list($key,$val)=each($exparray)){
$exparray[$key]= round($val + ($session['user']['dragonkills']/4) * $key * 100,0);
}
$exp = $session[user][experience]-$exparray[$session[user][level]-1];
$req=$exparray[$session[user][level]]-$exparray[$session[user][level]-1];
$u="<font face=\"verdana\" size=1>".$session[user][experience]."<br>".grafbar($req,$exp)."</font>";
return($u);
}
// end exp bar mod
function grafbar($full,$left,$width=70,$height=5) {
$col2="#000000";
if ($left<=0){
$col="#000000";
}else if ($left<$full/4){
$col="#FF0000";
}else if ($left<$full/2){
$col="yellow";
}else if ($left>=$full){
$col="#00AA00";
$col2="#00AA00";
}else{
$col="#00FF00";
}
if ($full==0) $full=1;
$u = "<table cellspacing=\"0\" style=\"border: solid 1px #000000\" width=\"$width\" height=\"$height\"><tr><td width=\"" . ($left / $full * 100) . "%\" bgcolor=\"$col\"></td><td width=\"".(100-($left / $full * 100)) ."%\" bgcolor=\"$col2\"></td></tr></table>";
return($u);
}
if (file_exists("dbconnect.php")){
require_once "dbconnect.php";
}else{
echo "Du must die benötigten Informationen in die Datei \"dbconnect.php.dist\" eintragen und sie unter dem Namen \"dbconnect.php\" speichern.".
exit();
}
$link = db_pconnect($DB_HOST, $DB_USER, $DB_PASS) or die (db_error($link));
db_select_db ($link, $DB_NAME) or die (db_error($link));
@define("LINK", false);
$appoencode = Load_Tags();
$appoencode_str = Get_Allowed_Tags();
require_once "translator.php";
//session_register("session");
session_name('DuskrynSession');
session_start();
function register_global(&$var){
@reset($var);
while (list($key,$val)=@each($var)){
global $$key;
$$key = $val;
}
@reset($var);
}
$session =& $_SESSION['session'];
//echo nl2br(htmlentities(output_array($session)));
//register_global($_SESSION);
register_global($_SERVER);
if (strtotime(date("c")."-".getsetting("LOGINTIMEOUT",900)." seconds") > $session['lasthit'] && $session['lasthit']>0 && $session[loggedin]){
//force the abandoning of the session when the user should have been sent to the fields.
//echo "Session abandon:".(strtotime("now")-$session[lasthit]);
$session=array();
$session['message'].="`n`áDeine Session ist abgelaufen!`0`n";
}
$session[lasthit]=strtotime(date("c"));
$revertsession=$session;
if ($PATH_INFO != "") {
$SCRIPT_NAME=$PATH_INFO;
$REQUEST_URI="";
}
if ($REQUEST_URI==""){
//necessary for some IIS installations (CGI in particular)
if (is_array($_GET) && count($_GET)>0){
$REQUEST_URI=$SCRIPT_NAME."?";
reset($_GET);
$i=0;
while (list($key,$val)=each($_GET)){
if ($i>0) $REQUEST_URI.="&";
$REQUEST_URI.="$key=".URLEncode($val);
$i++;
}
}else{
$REQUEST_URI=$SCRIPT_NAME;
}
$_SERVER['REQUEST_URI'] = $REQUEST_URI;
}
$SCRIPT_NAME=substr($SCRIPT_NAME,strrpos($SCRIPT_NAME,"/")+1);
if (strpos($REQUEST_URI,"?")){
$REQUEST_URI=$SCRIPT_NAME.substr($REQUEST_URI,strpos($REQUEST_URI,"?"));
}else{
$REQUEST_URI=$SCRIPT_NAME;
}
$allowanonymous=array("index.php"=>true,"login.php"=>true,"regel.php"=>true,"create.php"=>true,"farbversuche.php"=>true,"comedit.php"=>true,"about.php"=>true,"list.php"=>true,"impressum.php"=>true,"dank.php"=>true,"petition.php"=>true,"connector.php"=>true,"logdnet.php"=>true,"referral.php"=>true,"news.php"=>true,"motd.php"=>true,"topwebvote.php"=>true,"source.php"=>true,"createrpg.php"=>true);
$allownonnav = array("badnav.php"=>true,"showdetail.php"=>true,"motd.php"=>true,"petition.php"=>true,"mail.php"=>true,"comedit.php"=>true,"topwebvote.php"=>true,"chat.php"=>true,"inventory.php"=>true,"source.php"=>true,"prefs.php"=>true,"wegweiser.php"=>true,"kiosk.php"=>true,"farbtab.php"=>true,"hexcodes.php"=>true,"farben.php"=>true,"biopopup.php"=>true,"farbversuche.php"=>true,"status.php"=>true,"verfuegbar.php"=>true,"paintballregel.php"=>true);
if ($session[loggedin]){
$sql = "SELECT * FROM accounts WHERE acctid = '".$session[user][acctid]."'";
$result = db_query($sql);
if (db_num_rows($result)==1){
$session[user]=db_fetch_assoc($result);
$session[output]=$session[user][output];
$session[user][dragonpoints]=unserialize($session[user][dragonpoints]);
$session[user][prefs]=unserialize($session[user][prefs]);
if (!is_array($session[user][dragonpoints])) $session[user][dragonpoints]=array();
if (is_array(unserialize($session[user][allowednavs]))){
$session[allowednavs]=unserialize($session[user][allowednavs]);
}else{
//depreciated, left only for legacy support.
$session[allowednavs]=createarray($session[user][allowednavs]);
}
if (!$session[user][loggedin] || (0 && (date("U") - strtotime($session[user][laston])) > getsetting("LOGINTIMEOUT",900)) ){
$session=array();
redirect("index.php?op=timeout","Account ist nicht eingeloggt, aber die Session denkt, er ist es.");
}
}else{
$session=array();
$session[message]="`áFehler! Dein Login war falsch.`0";
redirect("index.php","Account verschwunden!");
}
db_free_result($result);
if ($session[allowednavs][$REQUEST_URI] && !$allownonnav[$SCRIPT_NAME]){
$session[allowednavs]=array();
}else{
if (!$allownonnav[$SCRIPT_NAME]){
redirect("badnav.php","Navigation auf $REQUEST_URI nicht erlaubt");
}
}
}else{
//if ($SCRIPT_NAME!="index.php" && $SCRIPT_NAME!="login.php" && $SCRIPT_NAME!="regel.php" && $SCRIPT_NAME!="create.php" && $SCRIPT_NAME!="about.php"){
if (!$allowanonymous[$SCRIPT_NAME]){
$session['message']="`áDu bist nicht eingeloggt. Wahrscheinlich ist deine Sessionzeit abgelaufen.";
redirect("index.php?op=timeout","Not logged in: $REQUEST_URI");
}
}
//if ($session[user][loggedin]!=true && $SCRIPT_NAME!="index.php" && $SCRIPT_NAME!="login.php" && $SCRIPT_NAME!="regel.php" &&$SCRIPT_NAME!="create" && $SCRIPT_NAME!="about.php"){
if ($session[user][loggedin]!=true && !$allowanonymous[$SCRIPT_NAME]){
redirect("login.php?op=logout");
}
$session[counter]++;
$nokeeprestore=array("newday.php"=>1,"badnav.php"=>1,"motd.php"=>1,"mail.php"=>1,"petition.php"=>1,"chat.php"=>1,"inventory.php"=>1,"prefs.php"=>1,"biopopup.php"=>1,"farben.php"=>1,"comedit.php"=>1,"wegweiser.php"=>1,"kiosk,php"=>1,"rpanfrage.php"=>1,"hexcodes.php"=>1);
if (!$nokeeprestore[$SCRIPT_NAME]) { //strpos($REQUEST_URI,"newday.php")===false && strpos($REQUEST_URI,"badnav.php")===false && strpos($REQUEST_URI,"motd.php")===false && strpos($REQUEST_URI,"mail.php")===false
$session[user][restorepage]=$REQUEST_URI;
}else{
}
if ($session['user']['hitpoints']>0){
$session['user']['alive']=true;
}else{
$session['user']['alive']=false;
}
$session[bufflist]=unserialize($session[user][bufflist]);
if (!is_array($session[bufflist])) $session[bufflist]=array();
$session[user][lastip]=$REMOTE_ADDR;
if (strlen($_COOKIE[lgi])<32){
if (strlen($session[user][uniqueid])<32){
$u=md5(microtime());
setcookie("lgi",$u,strtotime(date("c")."+365 days"));
$_COOKIE['lgi']=$u;
$session[user][uniqueid]=$u;
}else{
setcookie("lgi",$session[user][uniqueid],strtotime(date("c")."+365 days"));
}
}else{
$session[user][uniqueid]=$_COOKIE[lgi];
}
$url = "http://".$_SERVER['SERVER_NAME'].dirname($_SERVER['REQUEST_URI']);
$url = substr($url,0,strlen($url)-1);
if (substr($_SERVER['HTTP_REFERER'],0,strlen($url))==$url || $_SERVER['HTTP_REFERER']==""){
}else{
$sql = "SELECT * FROM referers WHERE uri='{$_SERVER['HTTP_REFERER']}'";
$result = db_query($sql);
$row = db_fetch_assoc($result);
db_free_result($result);
$site = str_replace("http://","",$_SERVER['HTTP_REFERER']);
if (strpos($site,"/"))
$site = substr($site,0,strpos($site,"/"));
if ($row['refererid']>""){
$sql = "UPDATE referers SET count=count+1,last=now(),site='".addslashes($site)."' WHERE refererid='{$row['refererid']}'";
}else{
$sql = "INSERT INTO referers (uri,count,last,site) VALUES ('{$_SERVER['HTTP_REFERER']}',1,now(),'".addslashes($site)."')";
}
db_query($sql);
}
if ($_COOKIE['template']!="") $templatename=$_COOKIE['template'];
if ($templatename=="" || !file_exists("templates/$templatename")) $templatename="Duskryn.htm";
$template = loadtemplate($templatename);
//tags that must appear in the header
$templatetags=array("title","headscript","script");
foreach ($templatetags AS $val) {
if (strpos($template['header'],"{".$val."}")===false) $templatemessage.="You do not have {".$val."} defined in your header\n";
}
//tags that must appear in the footer
$templatetags=array();
foreach ($templatetags AS $val) {
if (strpos($template['footer'],"{".$val."}")===false) $templatemessage.="You do not have {".$val."} defined in your footer\n";
}
//tags that may appear anywhere but must appear
//touch the copyright and we will force your server to be shut down
$templatetags=array("nav","stats","petition","motd","mail","copyright","source");
foreach ($templatetags AS $val) {
if (strpos($template['header'],"{".$val."}")===false && strpos($template['footer'],"{".$val."}")===false) $templatemessage.="You do not have {".$val."} defined in either your header or footer\n";
}
if ($templatemessage!=""){
echo "<b>Du hast einen oder mehrere Fehler in deinem Template!</b><br>".nl2br($templatemessage);
$template=loadtemplate("Duskryn.htm");
}
$sqlr = "SELECT name,raceid FROM race WHERE raceid='{$u[race]}'";
$resultr = db_query($sqlr);
$race = db_fetch_assoc($resultr);
if ($u['race']!=$race['raceid']) $nrace = 'Unbekannt'; else $nrace = $race['name'];
$super=array(1=>"Stadtwache",2=>"Moderator",3=>"Admin");
$logd_version = "Duskryn Edition";
$session['user']['laston']=date("Y-m-d H:i:s");
$playermount = getmount($session['user']['hashorse']);
$titles = array(
0=>array("Fremder","Fremde"),
1=>array("Neuankömmling", "Neuankömmling"),
2=>array("Herumtreiber", "Herumtreiberin"),
3=>array("Streuner", "Streunerin"),
4=>array("Halunke","Halunkin"),
5=>array("Wegelagerer","Wegelagerin"),
6=>array("Taschendieb","Taschendiebin"),
7=>array("Trickbetrüger","Trickbetrügerin"),
8=>array("Tagelöhner","Tagelöhnerin"),
9=>array("Hafenarbeiter","Hafenarbeiterin"),
10=>array("Spurenleser","Spurenleserin"),
11=>array("Jäger","Jägerin"),
12=>array("Bogenschütze","Bogenschützin"),
13=>array("Schwertkämpfer", "Schwertkämpferin"),
14=>array("Meister","Meisterin"),
15=>array("Gladiator", "Gladiatorin"),
16=>array("Major", "Major"),
17=>array("General", "General"),
18=>array("Edler", "Edle"),
19=>array("Ritter", "Ritterin"),
20=>array("Junker", "Junkerin"),
21=>array("Freiherr", "Freifrau"),
22=>array("Baron", "Baronin"),
23=>array("Fürst", "Fürstin"),
24=>array("Grossfürst", "Grossfürstin"),
25=>array("Herzog", "Herzogin"),
26=>array("Graf", "Gräfin"),
27=>array("Prinz", "Prinzessin"),
28=>array("Kronprinz", "Kronprinzessin"),
29=>array("König", "Königin"),
30=>array("Kaiser", "Kaiserin"),
31=>array("Drachentöter","Drachentöterin"),
32=>array("Bischof","Bischöfin"),
33=>array("Papst", "Päpstin"),
34=>array("Seele", "Seele"),
35=>array("Seliger", "Selige"),
36=>array("Heiliger", "Heilige"),
37=>array("Engel", "Engel"),
38=>array("Erzengel", "Erzengel"),
39=>array("Kraft", "Kraft"),
40=>array("Macht", "Macht"),
41=>array("Herrschaft", "Herrschaft"),
42=>array("Thron", "Thron"),
43=>array("Seraphim", "Seraphim"),
44=>array("Cherubim", "Cherubim"),
45=>array("Titan","Titanin"),
46=>array("Erztitan","Erztitanin"),
47=>array("Halbgott", "Halbgöttin"),
48=>array("Untergott","Untergöttin")
);
$beta = (getsetting("beta",0) == 1 || $session['user']['beta']==1);
Include 'lib/commentary.php';
?>