ER-Sourceviewer 2007 v2.0

Alle Dateien, die hier eingesehen werden können, sind unter der GNU GPL lizenziert. Wenn du etwas darin findest, das du gerne hättest, so schreibe mir doch bitte eine Anfrage damit ich, wenn ich es rausgeben will, alle Änderungen raussuchen könnte. Denn ich übernehme keine Verantwortung, solltest du was rausnehmen und es geht nicht. Und Support deswegen geb ich schon gar nicht.

Solltest du eine Schwachstelle im Code finden, sei es eine kritische Lücke oder eine Möglichkeit zu cheaten, dann bitte ich dich, mir das mitzuteilen. Solltest du beim cheaten erwischt werden, werde ich deinen Account eigenhändig löschen & bannen; Solltest du meinen Server angreifen, so werde ich meine Rechtsschutzversicherung kontaktieren.

Zur Source springen

Verzeichnisse:


Source anzeigen

Nach Oben


<?php

// 09072004

/*************************************************************
HUNTER'S LODGE for LoGD 0.9.7 ext (GER)
by weasel and anpera

*************************************************************/

require_once "common.php"
addcommentary();
page_header("Jägerhütte"); 
$session['user']['standort'] = "Jägerhütte";

addnav("Zurück zur Stadt","village.php"); 
addnav("Hexfarben Generator Atrahor","https://www.atrahor.de/static/farbverlauf_hc.html",false,false,true);
if (
$_GET[op]!="points"addnav("Punkte","lodge.php?op=points");
if (
$_GET[op]=="points"addnav("Empfehlungen","referral.php"); 

$config unserialize($session['user']['donationconfig']); 
$pointsavailable=$session['user']['donation']-$session['user']['donationspent']; 

if (
$_GET['op']==""){
output("`n`n`c<font size='10' face='Monotype Corsiva'>`Y<u>`YDi`Ce J`vägerh`Cüt`Yte</u></font>`c`n`n",true);
output("`c<img src='/images/places/saint/ph.jpg' width='250' hight='250'>`c`n`n",true);
output("`c<table width=600'><tr><td><div align=justify>
`YDu `Cma`vchst dich außerhalb Saint-Omars, über einen  kleinen Waldweg, in Richtung der Jägerhütt`Ce a`Yuf.`n
`YEs`C da`vuert auch nicht lange, da siehst du sie vor dir zwischen ein paar Bäumen auftauchen. Dir ist bewusst, dass nicht j`Ced`Yer
`Ydo`Crt`v hinein kann, du musst schon ein wahrer Held sein. Daher versuchst du möglichst imposant auszus`Ceh`Yen.</div></tr></td></table>`c`n`n"
,true);
    if (
$session['user']['donation']<=10){
output("`c<table width='600'><tr><td>
`YJe`Cdo`vch geht dies erfolglos aus. Du kommst hier erst rein, wenn du etwas erfolgreicher `Cbi`Yst.`n
`YMa`Cn g`vibt dir den Tipp, dass du mindestens 10 Punkte besitzen soll`Cte`Yst...
</tr></td></table>`c`n`n"
,true);
addnav("Empfehlungen","referral.php"); 
}
           if (
$session['user']['donation']>=0){ 
 
output("`c<table width='600'><tr><td><div align=justify>
`YGl`Cüc`vklicherweise hast du es in die Hütte geschafft. Dir fällt auf, dass hier wirklich nur Helden zu finden `Csi`Ynd.`n
`YAu`Cf e`viner großen Liste an der Wand siehst du auch wie viele Punkte du noch hast. Dort s`Cte`Yht:`n
`YDu`C be`vsitzt noch `$`b
$pointsavailable`b`v Donationpu`Cnk`Yte.`n
`YDa`Cmi`vt bist du eigentlich ganz zufrieden, aber warum nicht ein größerer Held we`Crd`Yen?`n
`YEr`Cst`v lässt du dich am gemütlichen Kamin nieder, wo man sich bereits Geschichten erzählt. Neugierig hörst d`Cu d`Yen
`YHe`Cld`ven zu. In der Nähe einer wichtig aussehenden Person liegt ein großer Jagdhund, bei dem es dich schon beim Hinsch`Cau`Yen
`Yg`Cr`vuse`Cl`Yt.`n
`YWe`Cr i`vst das und warum besitzt er ein solches Mon`Cst`Yer?`n
`YJa`Cgt`v er damit Rehe? Das kannst du dir nicht vorstellen. Und tatsächlich mustert dich die Bestie. Nach einiger Zeit blickt sie `Cku`Yrz
`Yih`Cre`vn Herren an und legt sich wiede`Cr h`Yin.`n
`YJe`Ctz`vt verstehst du... Dem Mann gehört diese Hütte und der Hund ist sein Beschü`Ctz`Yer.`n
`YNu`Cn f`vühlst du dich selbst sicherer und lehnst dich zu`Crü`Yck.`n`n
</div></tr></td></table>`c`n"
,true);
                
viewcommentary("hunterlodge","`n`YSp`Cri`vch mit den He`Cld`Yen:`n",25); 
                
addnav("Punkte einsetzen");
                   
addnav("Charmepunkte abfragen (20 Punkte)","lodge.php?op=charm"); 
                if (
$config['namechange']==1){ 
                        
addnav("Farbiger Name (0 Punkte)","lodge.php?op=namechange"); 
                }else{ 
                        
addnav("Farbiger Name (0 Punkte)","lodge.php?op=namechange"); 
                } 
                
addnav("10 Nächte in der Kneipe (30 Punkte)","lodge.php?op=innstays"); 
                
addnav("Edelsteine kaufen (je 2 für 50 Punkte)","lodge.php?op=gems");
                
addnav("Extra Waldkämpfe für 30 Tage (100 Punkte)","lodge.php?op=forestfights"); 
                
addnav("Heilerin Golinda für 30 Tage (100 Punkte)","lodge.php?op=golinda");
                
addnav("Zur Burg reiten (100 Punkte)","lodge.php?op=reiten1");
                
addnav("PvP-Immunität (300 Punkte)","lodge.php?op=immun");
                if (
$session[user][house]>&& $session[user][housekey]==$session[user][house]) addnav("Hausschlüssel","lodge.php?op=keys1");  
                if (
$session['user']['donation'] >= && $pointsavailable>=0) {
                    
addnav("Sonderbonus");
                    
addnav("Titel ändern (0 Punkte)","lodge.php?op=titeel1");
                }
                else {
                    if(
$pointsavailable >= 0)
                        
addnav('Farbloser Titel (0 Punkte)''lodge.php?op=nocotit1');
                }
        }
        else { 
                
output("Du ziehst die Karte deines Lieblingsgasthauses heraus, wo 9 von 10 Slots mit dem kleinen Profil von Cederik abgestempelt sind. 
                `n`n 
                Der Türsteher schaut flüchtig auf deine Karte, rät dir nicht soviel zu trinken und weist dir den Weg zurück."
); 
        } 
}else if (
$_GET['op']=="points"){ 
        
addnav("Zurück zur Lodge","lodge.php"); 
        
output("`bPunkte:`b`n`n
       Legend of the Green Dragon bietet dir die Möglichkeit, spezielle \"Donationpoints\" zu sammeln, mit denen du Sonderfunktionen freischalten kannst.`n
      Diese Punkte gibt es für besondere (geheime) Leistungen, sie können gekauft werden und für sogenannte \"Referrals\" (Empfehlungen) als Belohnung gesammelt werden. Erst wenn du mindestens 10 Donationpoints hast, kommst du in die Jägerhütte.`n`n
    Klicke im Eingangsbereich der Jägerhütte auf \"Empfehlungen\", wenn du wissen willst, wie du auf diesem Weg an Donationpoints kommst."
);
    
output("`n`nUm Punkte zu kaufen, überweise `b1 Euro pro 100 Punkte`b auf das Konto des Admins.`n`bSchicke dazu bitte eine Hilfsanfrage  oder eine E-Mail an ".getsetting("gameadminemail","")." ab, um die Bankverbindung zu erfahren");
    if (
getsetting("paypalemail","")) output(", oder benutze den PayPal Link \"ADMIN\" oben rechts");
    
output(".`b`nDas Geld wird ausschliesslich zur Finanzierung des Servers verwendet.`n");
//output("`nWenn du den Programmierer von LoGD belohnen willst, kannst du pro gespendetem US-\$ ebenfalls 100 Punkte kassieren.
//Schicke dazu irgendeinen Beweis deiner Spende, z.B. einen Screenshot der PayPal-Bestätigung, an ".getsetting("gameadminemail","").". Für eine Spende an den Programmierer (Eric Stevens a.k.a. MightyE) benutze den PayPal-Link, der auf jeder Seite oben rechts zu finden ist.");
    
output("`n`n
       `bDas kannst du mit diesen Punkten anstellen:`b`n
        - Umsonst in der Kneipe wohnen (10 Nächte für 30 Punkte).`n 
    - Edelsteine kaufen (2 Stück für 50 Punkte)`n
        - Zusätzliche Waldkämpfe kaufen (100 Punkte für 30 Tage lang 1 extra Kampf; maximal 5 mehr pro Tag)!`n
    - 'Zur Burg reiten' im Wald freischalten (100 Punkte),`n
    - PvP-Immunität kaufen (300 Punkte für permanente Immunität)`n
        - Einen farbigen Namen machen (300 Punkte). Umfärben kostet nur noch 25 Punkte. `n
    - Anzeige der Charmepunkte (20 Punkte)`n
    - Ersatzschlüssel (10) und zusätzliche Schlüssel (50) für dein Haus kaufen.`n 
    - Ab 2000 gesammelten Punkten (ob ausgegeben oder nicht) kannst du dir für 50 Punkte einen eigenen Titel aussuchen.`n
    `n`n`7Du hast noch `\$`b
$pointsavailable`b`7 Punkte von insgesamt `4".$session[user][donation]." `7gesammelten Punkten übrig. 
        "
); 
}elseif (
$_GET['op']=="golinda"){ 
        
output("30 Tage Zugang zu Golinda der Heilerin kosten 100 Punkte. Golinda heilt zum halben Preis.");
    if(
$pointsavailable<100){
        
output("`n`n`\$Du hast nicht genug Punkte!`0");
    } else {
            
addnav("Betätige Zugang zu Golinda");
            
addnav("JA","lodge.php?op=golindaconfirm");
    }
        
addnav("Zurück zur Lodge","lodge.php"); 
}elseif (
$_GET['op']=="golindaconfirm"){ 
        if (
$pointsavailable >= 100) {
              
$config['healer'] += 30;
              
output("J. C. Peterson gibt dir eine Karte und sagt \"Mit dieser Karte kannst du an 30 verschiedenen Tagen bei Golinda vorstellig werden.\"");
              
$session['user']['donationspent']+=100
        }
        
addnav("Zurück zur Lodge","lodge.php");

}elseif (
$_GET['op']=="reiten1"){
    if (
$config['castle']) {
        
output("Du hast diese Option bereits gekauft. Um zur Burg zu kommen, brauchst du ansonsten nur ein `bPferd`b. Ein `iPferd`i ist ein Tier der Kategorie 'Pferde' in Mericks Stall.");
    } else {
            
output("Hiermit schaffst du dir die Möglichkeit, mit einem Reittier im Wald auch zur Burg reiten zu können. Du kannst nur auf Pferden reiten, also die Tiere in Merick's Stall, die in der Kategorie 'Pferde' stehen.");
        if(
$pointsavailable<100){
            
output("`n`n`\$Du hast nicht genug Punkte!`0");
        } else {
                
addnav("Betätige Freischaltung");
                
addnav("JA","lodge.php?op=reiten2");
        }
     }
        
addnav("Zurück zur Lodge","lodge.php"); 
}elseif (
$_GET['op']=="reiten2"){ 
        if (
$pointsavailable >= 100) {
              
$config['castle'] = 100;
              
output("J. C. Peterson gibt dir eine Karte und sagt \"Mit dieser Karte findest du den Weg zur Burg, wenn du ein Pferd hast.\"");
              
$session['user']['donationspent']+=100
        }
        
addnav("Zurück zur Lodge","lodge.php");

}elseif (
$_GET['op']=="forestfights"){ 
        if (!
is_array($config['forestfights'])) $config['forestfights']=array(); 
        
output("1 Extra Waldkampf pro Tag für 30 Tage kostet 100 Punkte. Du bekommst einen extra Waldkampf an jedem Tag, an dem du spielst.`n"); 
    if(
$pointsavailable<100){
        
output("`n`n`\$Du hast nicht genug Punkte!`0");
    } else {
            
addnav("Bestätige Extra Waldkämpfe"); 
            
addnav("JA","lodge.php?op=fightbuy"); 
    }
        
addnav("Zurück zur Lodge","lodge.php"); 
        
reset($config['forestfights']); 
        while (list(
$key,$val)=each($config['forestfights'])){ 
                
//output("Du hast noch {$val['left']} Tage, an denen zu einen zusätzlichen Waldkampf für deine am {$val['bought]} bekommst.`n");
        
output("Du hast noch {$val['left']} Tage, an denen zu einen zusätzlichen Waldkampf für deine am {$val['bought']} bekommst.`n");
        } 
}elseif (
$_GET['op']=="fightbuy"){ 
        if (
count($config['forestfights'])>=5){ 
                
output("Du Kannst maximal 5 extra Waldkämpfe haben pro Tag.`n"); 
        }else{ 
                if (
$pointsavailable>0){ 
                        
array_push($config['forestfights'],array("left"=>30,"bought"=>date("M d"))); 
                        
output("Du wirst in den nächsten 30 Tagen, an denen du spielst, einen extra Waldkampf haben."); 
                        
$session['user']['donationspent']+=100
                }else{ 
                        
output("Extra Waldkämpfe zu kaufen kostet 100 Punkte, aber du hast nicht so viele."); 
                } 
        } 
      
addnav("Zurück zur Lodge","lodge.php"); 
}elseif (
$_GET['op']=="innstays"){ 
        
output("10 freie Übernachtungen in der Kneipe kosten 30 Punkte. Bist du dir sicher, dass du das willst?"); 
    if(
$pointsavailable<30){
        
output("`n`n`\$Du hast nicht genug Punkte!`0");
    } else {
            
addnav("Bestätige 10 freie Übernachtungen"); 
            
addnav("JA","lodge.php?op=innconfirm"); 
    }
        
addnav("Zurück zur Lodge","lodge.php"); 
}elseif (
$_GET['op']=="innconfirm"){ 
        if (
$pointsavailable>=30){ 
                
output("J. C. Petersen gibt dir eine Karte und sagt \"Coupon: Gut für 10 Übernachtungen in der Boar's Head Kneipe\""); 
                
$config['innstays']+=10
                
$session['user']['donationspent']+=30
        } 
    
addnav("Zurück zur Lodge","lodge.php"); 
}elseif (
$_GET['op']=="charm"){
        
output("Du fragst J. C. Petersen, ob er dein Aussehen beurteilen kann. Er mustert dich kurz und verspricht dir dann, dass er dir für die Kleinigkeit von 20 Punkten eine ehrliche Antwort geben wird.");
    if(
$pointsavailable<20){
        
output("`n`n`\$Du hast nicht genug Punkte!`0");
    } else {
            
addnav("Bestätige Charmepunkt-Anzeige");
            
addnav("JA","lodge.php?op=charmconfirm");
    }
    
addnav("Zurück zur Lodge","lodge.php");
}elseif (
$_GET['op']=="charmconfirm"){
    if (
$pointsavailable>=20){
        if (
$session['user']['charm']<=0output("J. C. Petersen schaut dich angewidert an und sagt \"Du bist hässlich wie die Nacht, ich kann einfach nichts Schönes an dir finden.\"");
        elseif (
$session['user']['charm']==1output("J. C. Petersen schaut dich kurz an und sagt \"Du bist genauso häßlich wie jeder gemeine Bürger, mehr als `^1 Punkt`0 wird dir kein Preisrichter geben.\"");
        else 
output("J. C. Petersen mustert dich noch einmal ganz genau und sagt \"Du bist `^".$session['user']['charm']."`0mal so schön wie der gemeine Bürger.\"");
        
$session['user']['donationspent']+=20;
    }
    
addnav("Zurück zur Lodge","lodge.php");
}elseif (
$_GET['op']=="gems"){ 
    if(
$pointsavailable<50)
        
output("`n`n`\$Du hast nicht genug Punkte!`0");
    
    else
    {
        
$maxgems floor($pointsavailable 50) * 2;
        
output("Du kannst maximal ".$maxgems." Edelsteine für ".($maxgems*25)." Donationpoints erstehen.`nWie viele Edelsteine möchtest du kaufen?`n");
        
output('<form action="lodge.php?op=gemsconfirm" method="POST">
               <input name="gems">
               <input type="submit" class="button" value="kaufen">
               </form>'
true);    
        
addnav('''lodge.php?op=gemsconfirm');
    }
    
addnav("Zurück zur Lodge","lodge.php"); 
}elseif (
$_GET['op']=="gemsconfirm"){
        if(!
is_numeric($_POST['gems']) || $_POST['gems'] <= 0)
            
output('`$Fehler bei der Eingabe.`0');
        
        else if(
$_POST['gems'] > (floor($pointsavailable 50) * 2))
            
output('`$Nana, du wirst Petersen doch wohl nicht betrügen wollen?`0');
        
        else
        { 
                
output("J. C. Petersen gibt dir ".floor($_POST['gems'])." Edelsteine und sagt \"Damit, mein Freund, wird dein Leben leichter werden.\""); 
                
$session['user']['gems'] += floor($_POST['gems']); 
                
$session['user']['donationspent'] += floor($_POST['gems']) * 25
        } 
        
addnav("Zurück zur Lodge","lodge.php");
}  
else if (
$_GET['op'] == "titeel1"){
    
addnav('Zurück zur Lodge''lodge.php');
    
    
$n $session['user']['name'];
    if(
$session['user']['ctitle']) {
        
$teil $session['user']['ctitle'];
    } 
    else {
        
$teil $session['user']['title'];
    }
    
    
output("Dein bisheriger Titel lautet: `b".$teil."`b, dein kompletter Name: `b".$n."`b`n`nWie soll dein Titel von nun an lauten?`n(Sende ein leeres Feld ab, wenn du deinen regulären Titel wieder haben willst.)`n"true); 
    
rawoutput("<form action='lodge.php?op=titeel2' method='POST'>
                    <input name='teil' value=\""
.HTMLEntities($teil)."\"> 
                    <input type='submit' value='Vorschau'>
                </form>"
);
    
addnav("","lodge.php?op=titeel2"); 
}
elseif(
$_GET['op'] == "titeel2") {
    
addnav("Zurück zur Lodge","lodge.php");
    
    
$falsetitle false;
    
    if(
$_POST['teil'] == "") {
        
$teil $session['user']['title'];
    } 
    else {
        
# Titel von nervigen Backslashes befreien
        
$teil stripslashes($_POST['teil']);
        
        
# Titel von Farben befreien (für überprüfung ob es der gleiche wie ein regulär durch DKs zu bekommender Titel ist)
        
$teil preg_replace("/`[^".$appoencode_str."]/"""$teil);
        
        
// Anführungszeichen machen nur Probleme...
        
$teil str_replace('\'','',$teil);
        
$teil str_replace('"','',$teil);
        
        
// Titel nicht leer, aber auch nix reguläres drin?
        
if(trim(preg_replace('/`./'''$teil)) == '') {
            
$teil $session['user']['title'];
            
$_POST['teil'] = '';
        }
        else {
            
# Überprüfen ob der Titel mit einem regulär durch DKs erhaltbaren Titel gleich ist
            
$cleartitle strtolower(preg_replace("/`./"""$teil));
            foreach(
$titles AS $this2) {
                if(
strtolower($this2[0])==$cleartitle || strtolower($this2[1])==$cleartitle) {
                    
$falsetitle true;
                    break;
                }
            }
        }
    }
    
    
# Titelbegrenzung erhöht - überprüfung ob nicht mehr als 5000 Zeichen (wer das schafft ist krank!)
    
if(strlen($teil) > 5000) {
        
output("Du hast dir zwar einen neuen Titel verdient, aber so lang muss er ja nun wirklich nicht sein.");
        
output("`n`n<a href='lodge.php?op=titeel1'>Lass es mich nochmal probieren</a>",true); 
        
addnav("","lodge.php?op=titeel1"); 
    }
    elseif(
$falsetitle) {
        
output('Diesen Titel hast du nicht verdient. Bitte wähle einen eigenen.');
        
output("`n`n<a href='lodge.php?op=titeel1'>Lass es mich nochmal probieren</a>",true); 
        
addnav("","lodge.php?op=titeel1");         
    }
    else {
        
$n $session['user']['name'];
        
/*if($session['user']['ctitle'] == "") {
            $neu = $teil.substr($n, strlen($session['user']['title']));
        } 
        else {
            $neu = $teil.substr($n, strlen($session['user']['ctitle']));
        }*/
        
if($session['user']['ctitle'] == '')
            
$n_only str_replace($session['user']['title'], ''$n);
        else
            
$n_only str_replace($session['user']['ctitle'], ''$n);
        
        
$new appoencode($teiltrue);
        
output("Dein neuer Titel soll ".$new."`0 sein, dein Name also ".$new.appoencode($n_onlytrue)."`0 ?"true);
        if(
$_POST['teil'] == "") {
             
$output.="<form action=\"lodge.php?op=titeel3\" method='POST'><input type='hidden' name='teil' value=\"\"><input type='submit' value='Ja' class='button'>, ändere meinen Titel zurück auf $new für 0 Punkte.</form>"
        } 
        else {
             
$output.="<form action=\"lodge.php?op=titeel3\" method='POST'><input type='hidden' name='teil' value=\"$teil\"><input type='submit' value='Ja' class='button'>, ändere meinen Titel auf $new für 0 Punkte.</form>"
        }
         
output("`n`n<a href='lodge.php?op=titeel1'>Nein, lass es mich nochmal probieren</a>",true); 
        
addnav("","lodge.php?op=titeel1"); 
        
addnav("","lodge.php?op=titeel3"); 
    }

elseif(
$_GET['op'] == "titeel3") {
    
addnav("Zurück zur Lodge","lodge.php");
    
    if(
$pointsavailable >= 0) { 
        
# Backslashes entfernen
        
$teil stripslashes($_POST['teil']);
        
# Farben entfernen
        
$teil preg_replace("/`[^".$appoencode_str."]/"""$teil);
        
// Anführungszeichen machen nur Probleme...
        
$teil str_replace('\'','',$teil);
        
$teil str_replace('"','',$teil);
        
        
// Titel nicht leer, aber auch nix reguläres drin?
        
if(trim(preg_replace('/`./','',$teil))=='') {
            
$teil $session['user']['title'];
            
$_POST['teil'] = '';
        }
        
        
        if(
strlen($teil)>5200) {
            
output("Du hast dir zwar einen neuen Titel verdient, aber so lang muss er ja nun wirklich nicht sein.");
            
output("`n`n<a href='lodge.php?op=titeel1'>Lass es mich nochmal probieren</a>",true); 
            
addnav("","lodge.php?op=titeel1"); 
        }
        else {        
            
$news "`&{$session['user']['name']}`^ ist nun bekannt als `^";
            
$n $session['user']['name'];

            
            if(
$session['user']['ctitle'] == '')
                
$n_only str_replace($session['user']['title'], ''$n);
            else
                
$n_only str_replace($session['user']['ctitle'], ''$n);
            
            
$neu $teil.$n_only;
            
            
$session['user']['donationspent'] += 0;
            
            if(
$teil "") {
                
$session['user']['name'] = $neu;
                
$session['user']['ctitle'] = $teil;
            }
            else {
                
/*if($session['user']['ctitle'] == "") {
                    $neu2 = substr($n, strlen($session['user']['title']));
                } 
                else {
                    $neu2 = substr($n, strlen($session['user']['ctitle']));
                }*/
                
                
if($session['user']['ctitle'] == '')
                    
$n_only str_replace($session['user']['title'], ''$n);
                else
                    
$n_only str_replace($session['user']['ctitle'], ''$n);
                
                
$session['user']['name'] = $session['user']['title'].$n_only;
                
$session['user']['ctitle'] = "";
            }
            
            
$news .= "{$session['user']['name']}`&!"
            
addnews($news); 
            
output("Gratulation, dein neuer Name ist jetzt  {$session['user']['name']}`0!`n`n"true); 
        }
    }
    else{ 
        
output("Den Titel zu ändern kostet 0 Punkte, aber du hast nur $pointsavailable Punkte."); 
    } 

}elseif (
$_GET['op']=="namechange"){ 
        
addnav("Zurück zur Lodge","lodge.php"); 
        
output("`bNamens Farbe ändern`b`n`n"); 
        if (
$config['namechange']==1){ 
                
output("Da du schon vorher viele Punkte für die Farbänderung gegeben hast kostet es dich auch diesmal nur 0 Punkte ."); 
        }else{ 
                
output("Da es deine erste Farbänderung ist kostet es dich 0 Punkte . Beim nächsten Wechsel fallen ebenfalls keine Kosten an"); 
        } 
        
output("`n`nDein geänderter Name muss der selbe Name sein wie vor der Farbänderung, nur dass er jetzt die Farbcodes enthalten darf.`n`n"); 
          
$n $session[user][name]; 
    if (
$session[user][ctitle]=="") {
                
//$x = strpos($n,$session[user][title])+1; 
                //$regname=str_replace("`0","",trim(substr($n,$x+strlen($session[user][title])))); 
                        
$regname str_replace(array($session['user']['title'].' ','`0'),'',$n);
     } else {
                
//$x = strpos($n,$session[user][ctitle])+1; 
                //$regname=str_replace("`0","",trim(substr($n,$x+strlen($session[user][ctitle])))); 
                
$regname str_replace(array($session['user']['ctitle'].' ','`0'),'',$n);
     }
        
output("Deine Name bisher ist: $regname"true); 
        
output(", und so wird er aussehen: $regname"true); 
        
output("`n`n`0Wie soll dein Name aussehen ?`n"); 
        
$output.="<form action='lodge.php?op=namepreview' method='POST'><input name='newname' value=\"".HTMLEntities($regname)."\"> <input type='submit' value='Vorschau'></form>"
        
addnav("","lodge.php?op=namepreview"); 
}elseif (
$_GET['op']=="namepreview"){ 
        
addnav("Zurück zur Lodge","lodge.php"); 
        
$n $session[user][name]; 
    if (
$session[user][ctitle]=="") {
                        
//$x = strpos($n,$session[user][title])+1;
                        //$regname=str_replace("`0","",trim(substr($n,$x+strlen($session[user][title]))));
                        
$regname str_replace(array($session['user']['title'].' ','`0'),'',$n);
             } else {
                        
//$x = strpos($n,$session[user][ctitle])+1;
                        //$regname=str_replace("`0","",trim(substr($n,$x+strlen($session[user][ctitle]))));
                        
$regname str_replace(array($session['user']['ctitle'].' ','`0'),'',$n);
     }
        
$_POST['newname']=str_replace("`0","",$_POST['newname']); 
     
//        $comp1 = strtolower($session['user']['login']);
        
$comp1 strtolower(preg_replace("/\s*|#[0-9a-f]{6}|[`][".$appoencode_str."]/i","",$regname)); // no black, no background colors
        
$comp2 strtolower(preg_replace("/\s*|#[0-9a-f]{6}|[`][".$appoencode_str."]/i","",$_POST['newname'])); 
        if (
$session['user']['acctid'] == 7123 || $session['user']['acctid'] == 7091) {
            
output($comp1 "`n");
            
output($comp2 "`n");
        }
        
//$output.="[$comp1] compared to [$comp2]"; 
        
if ($comp1!=$comp2$msg.="Dein neuer Name muss genau so bleiben, wie dein alter Name. Du kannst die Gross-/Kleinschreibung ändern, Farbcodes entfernen oder hinzufügen, aber ansonsten muss alles so bleiben. Du wählst {$_POST['newname']}`0`n"
        if (
strlen($_POST['newname'])>1000$msg.="Dein neuer name ist zu lang, inklusive Farbcodes darf er nicht länger als 30 Zeichen sein.`n"
        
$colorcount=0
        for (
$x=0;$x<strlen($_POST['newname']);$x++){ 
            if (
substr($_POST['newname'],$x,1)=="`"){ 
                        
$x++; 
                        
$colorcount++; 
                } 
        } 
        if (
$colorcount>getsetting("maxcolors",120)){ 
                
$msg.="Du hast zu viele Farben in deinem Namen benutzt. Du kannst maximal ".getsetting("maxcolors",120)." Farbcodes benutzen.`n"
        } 
        if (
$msg==""){ 
                
output("Deine Name wird so aussehen: ".$_POST['newname'], true);
                
output("`n`n`0Ist es das was du willst?`n`n"true); 
                
$p = ($config['namechange']==1?0:0); 
                
$output.="<form action=\"lodge.php?op=changename\" method='POST'><input type='hidden' name='name' value=\"".HTMLEntities($_POST['newname'])."\"><input type='submit' value='Ja' class='button'>, ändere meinen Namen auf ".appoencode("{$_POST['newname']}`0"true)." für $p Punkte.</form>"
                
output("`n`n<a href='lodge.php?op=namechange'>Nein, lass es mich nochmal probieren</a>",true); 
                
addnav("","lodge.php?op=namechange"); 
                
addnav("","lodge.php?op=changename"); 
        }else{ 
                
output("`bFalscher Name`b`n$msg"true); 
                
output("`n`nDeine Name bisher ist: $regname"true); 
                
output("`0, und wird so aussehen $regname"true); 
                
output("`n`nWie soll dein Name aussehen?`n"); 
                
$output.="<form action='lodge.php?op=namepreview' method='POST'><input name='newname' value=\"".HTMLEntities($regname)."\"> <input type='submit' value='Vorschau'></form>"
                
addnav("","lodge.php?op=namepreview"); 
        } 
}elseif (
$_GET['op']=="immun"){
    if (
$session['user']['pvpflag']=="5013-10-06 00:42:00"){
        
output("J. C. Petersen nickt dir zu und gibt dir zu verstehen, dass du noch immer unter seinem Schutz stehst.");
    } elseif (
$session['user']['pvpflag']=="1986-10-06 00:42:00") {
        
output("J. C. Petersen zeigt dir einen Vogel und macht dir sehr schnell klar, dass er vorerst nichts mehr für dich tun kann. Er kann niemanden schützen, der selbst mordend durchs Land zieht.");
    }else{
         
output("Du fragst J. C. Petersen, ob er deinen Aufenthaltsort vor herumstreifenden Dieben und Mördern verbergen kann.");
        
output(" Er nickt und verspricht dir, dass dir für die Kleinigkeit von 300 Punkten niemand mehr ein Haar krümmen wird. Er wird auch mit Dag Durnick reden. Allerdings kann er für nichts mehr garantieren, wenn du selbst einen Mord begehst!`n`n");
        
output("300 Punkte für permanente PvP Immunität ausgeben?`n(Die Immunität verfällt, sobald du selbst PvP machst, oder ein Kopfgeld auf jemanden aussetzt und kann dann `bnicht`b mehr so schnell erneuert werden!)");
            
addnav("Immunität bestätigen?"); 
            
addnav("JA","lodge.php?op=immunconfirm");
    } 
      
addnav("Zurück zur Lodge","lodge.php"); 
}elseif (
$_GET['op']=="immunconfirm"){ 
        if (
$pointsavailable>=300){ 
                
output("J. C. Petersen nutzt seinen Einfluss, um dich für PvP-Spieler unangreifbar zu machen. Es kann auch kein (weiteres) Kopfgeld auf dich ausgesetzt werden.`nDenke daran, dass du nur so lange geschützt bist, bis du selbst jemanden angreifst, oder jemanden auf Dag's "); 
        
output(" Kopfgeldliste setzt. Tust du das, kann selbst Petersen dir in Zukunft nicht mehr helfen.");
                
$session[user][pvpflag]="5013-10-06 00:42:00"
                
$session['user']['donationspent']+=300
        }else{
        
output("Du hast nicht genug Punkte!");
    }

}elseif (
$_GET['op']=="changename"){ 
        
$p = ($config['namechange']==1?0:0); 
        if (
$pointsavailable>=$p){ 
                
$session['user']['donationspent']+=$p
                
$config['namechange']=1
                
$news "{$session['user']['name']}`^ ist nun bekannt als `0";
        if (
$session[user][ctitle]=="") {
            
$session['user']['name']=$session['user']['title']." ".$_POST['name']."`0"
        } else {
            
$session['user']['name']=$session['user']['ctitle']." ".$_POST['name']."`0"
        }
            
$news.="{$session['user']['name']}`^!"
             
addnews($news); 
             
output("Gratulation, dein neuer Name ist jetzt  {$session['user']['name']}`0!`n`n"true); 
        }else{ 
                
output("Eine Farbänderung kostet $p Punkte, aber du hast nur $pointsavailable Punkte."); 
        } 
        
addnav("Zurück zur Lodge","lodge.php"); 
}elseif (
$_GET['op']=="keys1"){
    
$sql "SELECT * FROM items WHERE owner=0 AND class='Schlüssel' AND value1=".$session[user][house]." ORDER BY id ASC";
    
$result db_query($sql) or die(db_error(LINK));
    if (
db_num_rows($result)){
        
output("`b`c`&Verlorene Schlüssel:`c`b<table cellpadding=2 align='center'><tr><td>`bNr.`b</td><td>`bAktion`b</td></tr>",true);
        for (
$i=0;$i<db_num_rows($result);$i++){
            
$row db_fetch_assoc($result);
            
$bgcolor=($i%2==1?"trlight":"trdark");
            
output("<tr class='$bgcolor'><td align='center'>$row[value2]</td><td><a href='lodge.php?op=keys2&id=$row[id]'>Ersetzen (10 Punkte)</a></td></tr>",true);
            
addnav("","lodge.php?op=keys2&id=$row[id]");
        }
        
output("</table>",true);
    }else{
        
output("Der Schlüsselsatz für dein Haus ist komplett. Willst du einen zusätzlichen Schlüssel für 50 Punkte kaufen?");
        
addnav("Zusätzlicher Schlüssel (50 Punkte)","lodge.php?op=keys2&id=new");
    }
    
addnav("Zurück zur Lodge","lodge.php");
}elseif (
$_GET['op']=="keys2"){
    if (
$_GET[id]=="new"){
        
output("`b50`b ");
    }else{
        
output("`b10`b ");
    }
    
output("Punkte für diesen Schlüssel ausgeben?");
        
addnav("Schlüsselkauf bestätigen?"); 
        
addnav("JA","lodge.php?op=keys3&id=".$_GET[id]."");
    
addnav("Zurück zur Lodge","lodge.php");
}elseif (
$_GET['op']=="keys3"){
    if (
$_GET[id]=="new"){
        if (
$pointsavailable<50){
            
output("Du hast nicht genug Punkte übrig.");
        }else{
            
$sql "SELECT * FROM items WHERE class='Schlüssel' AND value1=".$session[user][house]." ORDER BY id ASC";
            
$result db_query($sql) or die(db_error(LINK));
            
$nummer=db_num_rows($result)+1;
            
db_free_result($result);
            
$sql="INSERT INTO items (name,owner,class,value1,value2,gold,gems,description) VALUES ('Hausschlüssel',".$session[user][acctid].",'Schlüssel',".$session[user][house].",$nummer,0,0,'Schlüssel für Haus Nummer ".$session[user][house]."')";
            
db_query($sql) or die(db_error(LINK));
            
$session['user']['donationspent']+=50;
            
output("Du hast jetzt `b$nummer`b Schlüssel für dein Haus! Überlege gut, an wen du sie vergibst.");
        }
    }else{
        if (
$pointsavailable<10){
            
output("Du hast nicht genug Punkte übrig.");
        }else{
            
$nummer=$_GET[id];
            
$sql="UPDATE items SET owner=".$session[user][acctid].",hvalue=0 WHERE id=$nummer";
            
db_query($sql);
            
$session['user']['donationspent']+=10;
            
output("Der Schlüssel wurde ersetzt.");
        }
    }
    
addnav("Zurück zur Lodge","lodge.php");
}

elseif(
$_GET['op'] == 'nocotit1') {
    if(isset(
$_POST['newnocotit'])) {
        if(empty(
$_POST['newnocotit'])) {
            
output('Du hast keinen Titel eingegeben. Bitte gib einen Titel ein!');
            
            
addnav('Aktionen');
            
addnav('Noch einmal''lodge.php?op=nocotit1');
        }
        elseif(
is_numeric($_POST['newnocotit'])) {
            
output('Dein Titel sollte aus Buchstaben bestehen und nicht aus Zahlen! Bitte wähle einen anderen Titel.');
            
            
addnav('Aktionen');
            
addnav('Noch einmal''lodge.php?op=nocotit1');
        }
        else {
            
// Name ohne Titel erzeugen
            
if(strpos($session['user']['name'], $session['user']['title']) === false && $session['user']['ctitle'] != '')
                
$notitname str_replace($session['user']['ctitle'].' '''$session['user']['name']);
            elseif(
$session['user']['title'] != '')
                
$notitname str_replace($session['user']['title'].' '''$session['user']['name']);
            else
                
$notitname $session['user']['name'];
                
            
// Titel bearbeiten
            
$title stripcolors($_POST['newnocotit']);
            
$dont = array('`b''`c''`i''\'''"');
            
$title str_replace($dont''$title);
            
            
// überprüfen ob der Titel leer ist. Wenn ja, zurück auf Systemtitel setzen.
            
if($title == '' || empty($title) || strlen(Str_replace(' '''$title)) == 0)
                
$itlte $session['user']['title'];
            
            
// Ausgabe
            
output('Dein Neuer Titel lautet '.$title.'. Mit deinem Namen zusammen wäre das '.$title.' '.$notitname.'`0. `n
                    Willst du den Titel wirklich ändern? `n`n
                    <center><table border="0" cellpadding="3" cellspacing="0">
                    <tr>
                        <td width="100" align="left">
                            <input type="button" class="button" value="Ja, ändern." onClick="location.href=\'lodge.php?op=nocotit2\'">
                        </td>
                        <td width="100" align="right">
                            <input type="button" class="button" value="Nein, nicht ändern" onClick="location.href=\'lodge.php?op=nocotit1\'">
                        </td>
                    </tr>
                    </table></center>'
true);
            
addnav('''lodge.php?op=nocotit2');
            
addnav('''lodge.php?op=nocotit1');
            
            
addnav('Aktionen');
            
addnav('Ändern''lodge.php?op=nocotit2');
            
addnav('Nicht ändern''lodge.php?op=nocotit1');
            
            
$session['TitleNameData'] = array('name' => $notitname'title' => $title);
        }
    }
    else {
        if(
$pointsavailable 0)
            
redirect('lodge.php');
            
        
output('Gib hier den gewünschten Titel ein. (Farbcodes nicht erlaubt!) `n `n
                <form action="lodge.php?op=nocotit1" method="POST">
                    <input name="newnocotit">
                    <input type="submit" class="button" value="Abschicken">'
true);
        
        
addnav('''lodge.php?op=nocotit1');
    }
    
    
addnav('Umkehren');
    
addnav('zur Jägerhütte''lodge.php');
}
elseif(
$_GET['op'] == 'nocotit2') {
    
$session['user']['name'] = $session['TitleNameData']['title'].' '.$session['TitleNameData']['name'];
    
$session['user']['ctitle'] = $session['TitleNameData']['title'];
    
    unset(
$session['TitleNameData']);
    
    
output('Dein Name wurde erfolgreich zu '.$session['user']['name'].'`0 geändert!');
    
    
$session['user']['donationspent'] += 0;
    
    
addnav('Umkehren');
    
addnav('zur Jägerhütte''lodge.php');
}
    

$session['user']['donationconfig'] = serialize($config); 

page_footer(); 

?>