remove difficulty, finish index refactor
This commit is contained in:
parent
0511da22fb
commit
ea7e6e8646
268
public/admin.php
268
public/admin.php
|
@ -11,7 +11,7 @@ $controlrow = mysql_fetch_array($controlquery);
|
||||||
|
|
||||||
if (isset($_GET["do"])) {
|
if (isset($_GET["do"])) {
|
||||||
$do = explode(":",$_GET["do"]);
|
$do = explode(":",$_GET["do"]);
|
||||||
|
|
||||||
if ($do[0] == "main") { main(); }
|
if ($do[0] == "main") { main(); }
|
||||||
elseif ($do[0] == "items") { items(); }
|
elseif ($do[0] == "items") { items(); }
|
||||||
elseif ($do[0] == "edititem") { edititem($do[1]); }
|
elseif ($do[0] == "edititem") { edititem($do[1]); }
|
||||||
|
@ -28,18 +28,18 @@ if (isset($_GET["do"])) {
|
||||||
elseif ($do[0] == "users") { users(); }
|
elseif ($do[0] == "users") { users(); }
|
||||||
elseif ($do[0] == "edituser") { edituser($do[1]); }
|
elseif ($do[0] == "edituser") { edituser($do[1]); }
|
||||||
elseif ($do[0] == "news") { addnews(); }
|
elseif ($do[0] == "news") { addnews(); }
|
||||||
|
|
||||||
} else { donothing(); }
|
} else { donothing(); }
|
||||||
|
|
||||||
function donothing() {
|
function donothing() {
|
||||||
|
|
||||||
$page = "Welcome to the Dragon Knight Administration section. Use the links on the left bar to control and edit various elements of the game.<br /><br />Please note that the control panel has been created mostly as a shortcut for certain individual settings. It is meant for use primarily with editing one thing at a time. If you need to completely replace an entire table (say, to replace all stock monsters with your own new ones), it is suggested that you use a more in-depth database tool such as <a href=\"http://www.phpmyadmin.net\" target=\"_new\">phpMyAdmin</a>. Also, you may want to have a copy of the Dragon Knight development kit, available from the <a href=\"http://dragon.se7enet.com/dev.php\">Dragon Knight homepage</a>.<br /><br />Also, you should be aware that certain portions of the DK code are dependent on the formatting of certain database results (for example, the special attributes on item drops). While I have attempted to point these out throughout the admin script, you should definitely pay attention and be careful when editing some fields, because mistakes in the database content may result in script errors or your game breaking completely.";
|
$page = "Welcome to the Dragon Knight Administration section. Use the links on the left bar to control and edit various elements of the game.<br /><br />Please note that the control panel has been created mostly as a shortcut for certain individual settings. It is meant for use primarily with editing one thing at a time. If you need to completely replace an entire table (say, to replace all stock monsters with your own new ones), it is suggested that you use a more in-depth database tool such as <a href=\"http://www.phpmyadmin.net\" target=\"_new\">phpMyAdmin</a>. Also, you may want to have a copy of the Dragon Knight development kit, available from the <a href=\"http://dragon.se7enet.com/dev.php\">Dragon Knight homepage</a>.<br /><br />Also, you should be aware that certain portions of the DK code are dependent on the formatting of certain database results (for example, the special attributes on item drops). While I have attempted to point these out throughout the admin script, you should definitely pay attention and be careful when editing some fields, because mistakes in the database content may result in script errors or your game breaking completely.";
|
||||||
admindisplay($page, "Admin Home");
|
admindisplay($page, "Admin Home");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function main() {
|
function main() {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$errors = 0;
|
$errors = 0;
|
||||||
|
@ -51,22 +51,17 @@ function main() {
|
||||||
if ($class1name == "") { $errors++; $errorlist .= "Class 1 name is required.<br />"; }
|
if ($class1name == "") { $errors++; $errorlist .= "Class 1 name is required.<br />"; }
|
||||||
if ($class2name == "") { $errors++; $errorlist .= "Class 2 name is required.<br />"; }
|
if ($class2name == "") { $errors++; $errorlist .= "Class 2 name is required.<br />"; }
|
||||||
if ($class3name == "") { $errors++; $errorlist .= "Class 3 name is required.<br />"; }
|
if ($class3name == "") { $errors++; $errorlist .= "Class 3 name is required.<br />"; }
|
||||||
if ($diff1name == "") { $errors++; $errorlist .= "Difficulty 1 name is required.<br />"; }
|
|
||||||
if ($diff2name == "") { $errors++; $errorlist .= "Difficulty 2 name is required.<br />"; }
|
if ($errors == 0) {
|
||||||
if ($diff3name == "") { $errors++; $errorlist .= "Difficulty 3 name is required.<br />"; }
|
|
||||||
if ($diff2mod == "") { $errors++; $errorlist .= "Difficulty 2 value is required.<br />"; }
|
|
||||||
if ($diff3mod == "") { $errors++; $errorlist .= "Difficulty 3 value is required.<br />"; }
|
|
||||||
|
|
||||||
if ($errors == 0) {
|
|
||||||
$query = doquery("UPDATE {{table}} SET gamename='$gamename',gamesize='$gamesize',forumtype='$forumtype',forumaddress='$forumaddress',compression='$compression',class1name='$class1name',class2name='$class2name',class3name='$class3name',diff1name='$diff1name',diff2name='$diff2name',diff3name='$diff3name',diff2mod='$diff2mod',diff3mod='$diff3mod',gameopen='$gameopen',verifyemail='$verifyemail',gameurl='$gameurl',adminemail='$adminemail',shownews='$shownews',showonline='$showonline',showbabble='$showbabble' WHERE id='1' LIMIT 1", "control");
|
$query = doquery("UPDATE {{table}} SET gamename='$gamename',gamesize='$gamesize',forumtype='$forumtype',forumaddress='$forumaddress',compression='$compression',class1name='$class1name',class2name='$class2name',class3name='$class3name',diff1name='$diff1name',diff2name='$diff2name',diff3name='$diff3name',diff2mod='$diff2mod',diff3mod='$diff3mod',gameopen='$gameopen',verifyemail='$verifyemail',gameurl='$gameurl',adminemail='$adminemail',shownews='$shownews',showonline='$showonline',showbabble='$showbabble' WHERE id='1' LIMIT 1", "control");
|
||||||
admindisplay("Settings updated.","Main Settings");
|
admindisplay("Settings updated.","Main Settings");
|
||||||
} else {
|
} else {
|
||||||
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Main Settings");
|
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Main Settings");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
global $controlrow;
|
global $controlrow;
|
||||||
|
|
||||||
$page = <<<END
|
$page = <<<END
|
||||||
<b><u>Main Settings</u></b><br />
|
<b><u>Main Settings</u></b><br />
|
||||||
These options control several major settings for the overall game engine.<br /><br />
|
These options control several major settings for the overall game engine.<br /><br />
|
||||||
|
@ -87,11 +82,6 @@ These options control several major settings for the overall game engine.<br /><
|
||||||
<tr><td width="20%">Class 1 Name:</td><td><input type="text" name="class1name" size="20" maxlength="50" value="{{class1name}}" /><br /></td></tr>
|
<tr><td width="20%">Class 1 Name:</td><td><input type="text" name="class1name" size="20" maxlength="50" value="{{class1name}}" /><br /></td></tr>
|
||||||
<tr><td width="20%">Class 2 Name:</td><td><input type="text" name="class2name" size="20" maxlength="50" value="{{class2name}}" /><br /></td></tr>
|
<tr><td width="20%">Class 2 Name:</td><td><input type="text" name="class2name" size="20" maxlength="50" value="{{class2name}}" /><br /></td></tr>
|
||||||
<tr><td width="20%">Class 3 Name:</td><td><input type="text" name="class3name" size="20" maxlength="50" value="{{class3name}}" /><br /></td></tr>
|
<tr><td width="20%">Class 3 Name:</td><td><input type="text" name="class3name" size="20" maxlength="50" value="{{class3name}}" /><br /></td></tr>
|
||||||
<tr><td width="20%">Difficulty 1 Name:</td><td><input type="text" name="diff1name" size="20" maxlength="50" value="{{diff1name}}" /><br /></td></tr>
|
|
||||||
<tr><td width="20%">Difficulty 2 Name:</td><td><input type="text" name="diff2name" size="20" maxlength="50" value="{{diff2name}}" /><br /></td></tr>
|
|
||||||
<tr><td width="20%">Difficulty 2 Value:</td><td><input type="text" name="diff2mod" size="3" maxlength="3" value="{{diff2mod}}" /><br /><span class="small">Default is 1.2. Specify factoral value for medium difficulty here.</span></td></tr>
|
|
||||||
<tr><td width="20%">Difficulty 3 Name:</td><td><input type="text" name="diff3name" size="20" maxlength="50" value="{{diff3name}}" /><br /></td></tr>
|
|
||||||
<tr><td width="20%">Difficulty 3 Value:</td><td><input type="text" name="diff3mod" size="3" maxlength="3" value="{{diff3mod}}" /><br /><span class="small">Default is 1.5. Specify factoral value for hard difficulty here.</span></td></tr>
|
|
||||||
</table>
|
</table>
|
||||||
<input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" />
|
<input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" />
|
||||||
</form>
|
</form>
|
||||||
|
@ -119,7 +109,7 @@ END;
|
||||||
}
|
}
|
||||||
|
|
||||||
function items() {
|
function items() {
|
||||||
|
|
||||||
$query = doquery("SELECT id,name FROM {{table}} ORDER BY id", "items");
|
$query = doquery("SELECT id,name FROM {{table}} ORDER BY id", "items");
|
||||||
$page = "<b><u>Edit Items</u></b><br />Click an item's name to edit it.<br /><br /><table width=\"50%\">\n";
|
$page = "<b><u>Edit Items</u></b><br />Click an item's name to edit it.<br /><br /><table width=\"50%\">\n";
|
||||||
$count = 1;
|
$count = 1;
|
||||||
|
@ -130,13 +120,13 @@ function items() {
|
||||||
if (mysql_num_rows($query) == 0) { $page .= "<tr><td width=\"8%\" style=\"background-color: #eeeeee;\">No items found.</td></tr>\n"; }
|
if (mysql_num_rows($query) == 0) { $page .= "<tr><td width=\"8%\" style=\"background-color: #eeeeee;\">No items found.</td></tr>\n"; }
|
||||||
$page .= "</table>";
|
$page .= "</table>";
|
||||||
admindisplay($page, "Edit Items");
|
admindisplay($page, "Edit Items");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function edititem($id) {
|
function edititem($id) {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$errors = 0;
|
$errors = 0;
|
||||||
$errorlist = "";
|
$errorlist = "";
|
||||||
|
@ -146,17 +136,17 @@ function edititem($id) {
|
||||||
if ($attribute == "") { $errors++; $errorlist .= "Attribute is required.<br />"; }
|
if ($attribute == "") { $errors++; $errorlist .= "Attribute is required.<br />"; }
|
||||||
if (!is_numeric($attribute)) { $errors++; $errorlist .= "Attribute must be a number.<br />"; }
|
if (!is_numeric($attribute)) { $errors++; $errorlist .= "Attribute must be a number.<br />"; }
|
||||||
if ($special == "" || $special == " ") { $special = "X"; }
|
if ($special == "" || $special == " ") { $special = "X"; }
|
||||||
|
|
||||||
if ($errors == 0) {
|
if ($errors == 0) {
|
||||||
$query = doquery("UPDATE {{table}} SET name='$name',type='$type',buycost='$buycost',attribute='$attribute',special='$special' WHERE id='$id' LIMIT 1", "items");
|
$query = doquery("UPDATE {{table}} SET name='$name',type='$type',buycost='$buycost',attribute='$attribute',special='$special' WHERE id='$id' LIMIT 1", "items");
|
||||||
admindisplay("Item updated.","Edit Items");
|
admindisplay("Item updated.","Edit Items");
|
||||||
} else {
|
} else {
|
||||||
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Items");
|
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Items");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "items");
|
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "items");
|
||||||
$row = mysql_fetch_array($query);
|
$row = mysql_fetch_array($query);
|
||||||
|
|
||||||
|
@ -186,18 +176,18 @@ dexterity - dexterity (which also adds to defensepower)<br />
|
||||||
attackpower - total attack power<br />
|
attackpower - total attack power<br />
|
||||||
defensepower - total defense power
|
defensepower - total defense power
|
||||||
END;
|
END;
|
||||||
|
|
||||||
if ($row["type"] == 1) { $row["type1select"] = "selected=\"selected\" "; } else { $row["type1select"] = ""; }
|
if ($row["type"] == 1) { $row["type1select"] = "selected=\"selected\" "; } else { $row["type1select"] = ""; }
|
||||||
if ($row["type"] == 2) { $row["type2select"] = "selected=\"selected\" "; } else { $row["type2select"] = ""; }
|
if ($row["type"] == 2) { $row["type2select"] = "selected=\"selected\" "; } else { $row["type2select"] = ""; }
|
||||||
if ($row["type"] == 3) { $row["type3select"] = "selected=\"selected\" "; } else { $row["type3select"] = ""; }
|
if ($row["type"] == 3) { $row["type3select"] = "selected=\"selected\" "; } else { $row["type3select"] = ""; }
|
||||||
|
|
||||||
$page = parsetemplate($page, $row);
|
$page = parsetemplate($page, $row);
|
||||||
admindisplay($page, "Edit Items");
|
admindisplay($page, "Edit Items");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function drops() {
|
function drops() {
|
||||||
|
|
||||||
$query = doquery("SELECT id,name FROM {{table}} ORDER BY id", "drops");
|
$query = doquery("SELECT id,name FROM {{table}} ORDER BY id", "drops");
|
||||||
$page = "<b><u>Edit Drops</u></b><br />Click an item's name to edit it.<br /><br /><table width=\"50%\">\n";
|
$page = "<b><u>Edit Drops</u></b><br />Click an item's name to edit it.<br /><br /><table width=\"50%\">\n";
|
||||||
$count = 1;
|
$count = 1;
|
||||||
|
@ -208,13 +198,13 @@ function drops() {
|
||||||
if (mysql_num_rows($query) == 0) { $page .= "<tr><td width=\"8%\" style=\"background-color: #eeeeee;\">No items found.</td></tr>\n"; }
|
if (mysql_num_rows($query) == 0) { $page .= "<tr><td width=\"8%\" style=\"background-color: #eeeeee;\">No items found.</td></tr>\n"; }
|
||||||
$page .= "</table>";
|
$page .= "</table>";
|
||||||
admindisplay($page, "Edit Drops");
|
admindisplay($page, "Edit Drops");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function editdrop($id) {
|
function editdrop($id) {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$errors = 0;
|
$errors = 0;
|
||||||
$errorlist = "";
|
$errorlist = "";
|
||||||
|
@ -223,17 +213,17 @@ function editdrop($id) {
|
||||||
if (!is_numeric($mlevel)) { $errors++; $errorlist .= "Monster level must be a number.<br />"; }
|
if (!is_numeric($mlevel)) { $errors++; $errorlist .= "Monster level must be a number.<br />"; }
|
||||||
if ($attribute1 == "" || $attribute1 == " " || $attribute1 == "X") { $errors++; $errorlist .= "First attribute is required.<br />"; }
|
if ($attribute1 == "" || $attribute1 == " " || $attribute1 == "X") { $errors++; $errorlist .= "First attribute is required.<br />"; }
|
||||||
if ($attribute2 == "" || $attribute2 == " ") { $attribute2 = "X"; }
|
if ($attribute2 == "" || $attribute2 == " ") { $attribute2 = "X"; }
|
||||||
|
|
||||||
if ($errors == 0) {
|
if ($errors == 0) {
|
||||||
$query = doquery("UPDATE {{table}} SET name='$name',mlevel='$mlevel',attribute1='$attribute1',attribute2='$attribute2' WHERE id='$id' LIMIT 1", "drops");
|
$query = doquery("UPDATE {{table}} SET name='$name',mlevel='$mlevel',attribute1='$attribute1',attribute2='$attribute2' WHERE id='$id' LIMIT 1", "drops");
|
||||||
admindisplay("Item updated.","Edit Drops");
|
admindisplay("Item updated.","Edit Drops");
|
||||||
} else {
|
} else {
|
||||||
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Drops");
|
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Drops");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "drops");
|
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "drops");
|
||||||
$row = mysql_fetch_array($query);
|
$row = mysql_fetch_array($query);
|
||||||
|
|
||||||
|
@ -262,14 +252,14 @@ dexterity - dexterity (which also adds to defensepower)<br />
|
||||||
attackpower - total attack power<br />
|
attackpower - total attack power<br />
|
||||||
defensepower - total defense power
|
defensepower - total defense power
|
||||||
END;
|
END;
|
||||||
|
|
||||||
$page = parsetemplate($page, $row);
|
$page = parsetemplate($page, $row);
|
||||||
admindisplay($page, "Edit Drops");
|
admindisplay($page, "Edit Drops");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function towns() {
|
function towns() {
|
||||||
|
|
||||||
$query = doquery("SELECT id,name FROM {{table}} ORDER BY id", "towns");
|
$query = doquery("SELECT id,name FROM {{table}} ORDER BY id", "towns");
|
||||||
$page = "<b><u>Edit Towns</u></b><br />Click an town's name to edit it.<br /><br /><table width=\"50%\">\n";
|
$page = "<b><u>Edit Towns</u></b><br />Click an town's name to edit it.<br /><br /><table width=\"50%\">\n";
|
||||||
$count = 1;
|
$count = 1;
|
||||||
|
@ -280,13 +270,13 @@ function towns() {
|
||||||
if (mysql_num_rows($query) == 0) { $page .= "<tr><td width=\"8%\" style=\"background-color: #eeeeee;\">No towns found.</td></tr>\n"; }
|
if (mysql_num_rows($query) == 0) { $page .= "<tr><td width=\"8%\" style=\"background-color: #eeeeee;\">No towns found.</td></tr>\n"; }
|
||||||
$page .= "</table>";
|
$page .= "</table>";
|
||||||
admindisplay($page, "Edit Towns");
|
admindisplay($page, "Edit Towns");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function edittown($id) {
|
function edittown($id) {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$errors = 0;
|
$errors = 0;
|
||||||
$errorlist = "";
|
$errorlist = "";
|
||||||
|
@ -303,17 +293,17 @@ function edittown($id) {
|
||||||
if ($travelpoints == "") { $errors++; $errorlist .= "Travel Points is required.<br />"; }
|
if ($travelpoints == "") { $errors++; $errorlist .= "Travel Points is required.<br />"; }
|
||||||
if (!is_numeric($travelpoints)) { $errors++; $errorlist .= "Travel Points must be a number.<br />"; }
|
if (!is_numeric($travelpoints)) { $errors++; $errorlist .= "Travel Points must be a number.<br />"; }
|
||||||
if ($itemslist == "") { $errors++; $errorlist .= "Items List is required.<br />"; }
|
if ($itemslist == "") { $errors++; $errorlist .= "Items List is required.<br />"; }
|
||||||
|
|
||||||
if ($errors == 0) {
|
if ($errors == 0) {
|
||||||
$query = doquery("UPDATE {{table}} SET name='$name',latitude='$latitude',longitude='$longitude',innprice='$innprice',mapprice='$mapprice',travelpoints='$travelpoints',itemslist='$itemslist' WHERE id='$id' LIMIT 1", "towns");
|
$query = doquery("UPDATE {{table}} SET name='$name',latitude='$latitude',longitude='$longitude',innprice='$innprice',mapprice='$mapprice',travelpoints='$travelpoints',itemslist='$itemslist' WHERE id='$id' LIMIT 1", "towns");
|
||||||
admindisplay("Town updated.","Edit Towns");
|
admindisplay("Town updated.","Edit Towns");
|
||||||
} else {
|
} else {
|
||||||
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Towns");
|
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Towns");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "towns");
|
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "towns");
|
||||||
$row = mysql_fetch_array($query);
|
$row = mysql_fetch_array($query);
|
||||||
|
|
||||||
|
@ -333,26 +323,26 @@ $page = <<<END
|
||||||
<input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" />
|
<input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" />
|
||||||
</form>
|
</form>
|
||||||
END;
|
END;
|
||||||
|
|
||||||
$page = parsetemplate($page, $row);
|
$page = parsetemplate($page, $row);
|
||||||
admindisplay($page, "Edit Towns");
|
admindisplay($page, "Edit Towns");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function monsters() {
|
function monsters() {
|
||||||
|
|
||||||
global $controlrow;
|
global $controlrow;
|
||||||
|
|
||||||
$statquery = doquery("SELECT * FROM {{table}} ORDER BY level DESC LIMIT 1", "monsters");
|
$statquery = doquery("SELECT * FROM {{table}} ORDER BY level DESC LIMIT 1", "monsters");
|
||||||
$statrow = mysql_fetch_array($statquery);
|
$statrow = mysql_fetch_array($statquery);
|
||||||
|
|
||||||
$query = doquery("SELECT id,name FROM {{table}} ORDER BY id", "monsters");
|
$query = doquery("SELECT id,name FROM {{table}} ORDER BY id", "monsters");
|
||||||
$page = "<b><u>Edit Monsters</u></b><br />";
|
$page = "<b><u>Edit Monsters</u></b><br />";
|
||||||
|
|
||||||
if (($controlrow["gamesize"]/5) != $statrow["level"]) {
|
if (($controlrow["gamesize"]/5) != $statrow["level"]) {
|
||||||
$page .= "<span class=\"highlight\">Note:</span> Your highest monster level does not match with your entered map size. Highest monster level should be ".($controlrow["gamesize"]/5).", yours is ".$statrow["level"].". Please fix this before opening the game to the public.<br /><br />";
|
$page .= "<span class=\"highlight\">Note:</span> Your highest monster level does not match with your entered map size. Highest monster level should be ".($controlrow["gamesize"]/5).", yours is ".$statrow["level"].". Please fix this before opening the game to the public.<br /><br />";
|
||||||
} else { $page .= "Monster level and map size match. No further actions are required for map compatibility.<br /><br />"; }
|
} else { $page .= "Monster level and map size match. No further actions are required for map compatibility.<br /><br />"; }
|
||||||
|
|
||||||
$page .= "Click an monster's name to edit it.<br /><br /><table width=\"50%\">\n";
|
$page .= "Click an monster's name to edit it.<br /><br /><table width=\"50%\">\n";
|
||||||
$count = 1;
|
$count = 1;
|
||||||
while ($row = mysql_fetch_array($query)) {
|
while ($row = mysql_fetch_array($query)) {
|
||||||
|
@ -362,13 +352,13 @@ function monsters() {
|
||||||
if (mysql_num_rows($query) == 0) { $page .= "<tr><td width=\"8%\" style=\"background-color: #eeeeee;\">No towns found.</td></tr>\n"; }
|
if (mysql_num_rows($query) == 0) { $page .= "<tr><td width=\"8%\" style=\"background-color: #eeeeee;\">No towns found.</td></tr>\n"; }
|
||||||
$page .= "</table>";
|
$page .= "</table>";
|
||||||
admindisplay($page, "Edit Monster");
|
admindisplay($page, "Edit Monster");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function editmonster($id) {
|
function editmonster($id) {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$errors = 0;
|
$errors = 0;
|
||||||
$errorlist = "";
|
$errorlist = "";
|
||||||
|
@ -385,17 +375,17 @@ function editmonster($id) {
|
||||||
if (!is_numeric($maxexp)) { $errors++; $errorlist .= "Max Exp must be a number.<br />"; }
|
if (!is_numeric($maxexp)) { $errors++; $errorlist .= "Max Exp must be a number.<br />"; }
|
||||||
if ($maxgold == "") { $errors++; $errorlist .= "Max Gold is required.<br />"; }
|
if ($maxgold == "") { $errors++; $errorlist .= "Max Gold is required.<br />"; }
|
||||||
if (!is_numeric($maxgold)) { $errors++; $errorlist .= "Max Gold must be a number.<br />"; }
|
if (!is_numeric($maxgold)) { $errors++; $errorlist .= "Max Gold must be a number.<br />"; }
|
||||||
|
|
||||||
if ($errors == 0) {
|
if ($errors == 0) {
|
||||||
$query = doquery("UPDATE {{table}} SET name='$name',maxhp='$maxhp',maxdam='$maxdam',armor='$armor',level='$level',maxexp='$maxexp',maxgold='$maxgold',immune='$immune' WHERE id='$id' LIMIT 1", "monsters");
|
$query = doquery("UPDATE {{table}} SET name='$name',maxhp='$maxhp',maxdam='$maxdam',armor='$armor',level='$level',maxexp='$maxexp',maxgold='$maxgold',immune='$immune' WHERE id='$id' LIMIT 1", "monsters");
|
||||||
admindisplay("Monster updated.","Edit monsters");
|
admindisplay("Monster updated.","Edit monsters");
|
||||||
} else {
|
} else {
|
||||||
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit monsters");
|
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit monsters");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "monsters");
|
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "monsters");
|
||||||
$row = mysql_fetch_array($query);
|
$row = mysql_fetch_array($query);
|
||||||
|
|
||||||
|
@ -416,18 +406,18 @@ $page = <<<END
|
||||||
<input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" />
|
<input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" />
|
||||||
</form>
|
</form>
|
||||||
END;
|
END;
|
||||||
|
|
||||||
if ($row["immune"] == 1) { $row["immune1select"] = "selected=\"selected\" "; } else { $row["immune1select"] = ""; }
|
if ($row["immune"] == 1) { $row["immune1select"] = "selected=\"selected\" "; } else { $row["immune1select"] = ""; }
|
||||||
if ($row["immune"] == 2) { $row["immune2select"] = "selected=\"selected\" "; } else { $row["immune2select"] = ""; }
|
if ($row["immune"] == 2) { $row["immune2select"] = "selected=\"selected\" "; } else { $row["immune2select"] = ""; }
|
||||||
if ($row["immune"] == 3) { $row["immune3select"] = "selected=\"selected\" "; } else { $row["immune3select"] = ""; }
|
if ($row["immune"] == 3) { $row["immune3select"] = "selected=\"selected\" "; } else { $row["immune3select"] = ""; }
|
||||||
|
|
||||||
$page = parsetemplate($page, $row);
|
$page = parsetemplate($page, $row);
|
||||||
admindisplay($page, "Edit Monsters");
|
admindisplay($page, "Edit Monsters");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function spells() {
|
function spells() {
|
||||||
|
|
||||||
$query = doquery("SELECT id,name FROM {{table}} ORDER BY id", "spells");
|
$query = doquery("SELECT id,name FROM {{table}} ORDER BY id", "spells");
|
||||||
$page = "<b><u>Edit Spells</u></b><br />Click an spell's name to edit it.<br /><br /><table width=\"50%\">\n";
|
$page = "<b><u>Edit Spells</u></b><br />Click an spell's name to edit it.<br /><br /><table width=\"50%\">\n";
|
||||||
$count = 1;
|
$count = 1;
|
||||||
|
@ -438,13 +428,13 @@ function spells() {
|
||||||
if (mysql_num_rows($query) == 0) { $page .= "<tr><td width=\"8%\" style=\"background-color: #eeeeee;\">No spells found.</td></tr>\n"; }
|
if (mysql_num_rows($query) == 0) { $page .= "<tr><td width=\"8%\" style=\"background-color: #eeeeee;\">No spells found.</td></tr>\n"; }
|
||||||
$page .= "</table>";
|
$page .= "</table>";
|
||||||
admindisplay($page, "Edit Spells");
|
admindisplay($page, "Edit Spells");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function editspell($id) {
|
function editspell($id) {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$errors = 0;
|
$errors = 0;
|
||||||
$errorlist = "";
|
$errorlist = "";
|
||||||
|
@ -453,17 +443,17 @@ function editspell($id) {
|
||||||
if (!is_numeric($mp)) { $errors++; $errorlist .= "MP must be a number.<br />"; }
|
if (!is_numeric($mp)) { $errors++; $errorlist .= "MP must be a number.<br />"; }
|
||||||
if ($attribute == "") { $errors++; $errorlist .= "Attribute is required.<br />"; }
|
if ($attribute == "") { $errors++; $errorlist .= "Attribute is required.<br />"; }
|
||||||
if (!is_numeric($attribute)) { $errors++; $errorlist .= "Attribute must be a number.<br />"; }
|
if (!is_numeric($attribute)) { $errors++; $errorlist .= "Attribute must be a number.<br />"; }
|
||||||
|
|
||||||
if ($errors == 0) {
|
if ($errors == 0) {
|
||||||
$query = doquery("UPDATE {{table}} SET name='$name',mp='$mp',attribute='$attribute',type='$type' WHERE id='$id' LIMIT 1", "spells");
|
$query = doquery("UPDATE {{table}} SET name='$name',mp='$mp',attribute='$attribute',type='$type' WHERE id='$id' LIMIT 1", "spells");
|
||||||
admindisplay("Spell updated.","Edit Spells");
|
admindisplay("Spell updated.","Edit Spells");
|
||||||
} else {
|
} else {
|
||||||
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Spells");
|
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Spells");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "spells");
|
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "spells");
|
||||||
$row = mysql_fetch_array($query);
|
$row = mysql_fetch_array($query);
|
||||||
|
|
||||||
|
@ -486,43 +476,43 @@ END;
|
||||||
if ($row["type"] == 3) { $row["type3select"] = "selected=\"selected\" "; } else { $row["type3select"] = ""; }
|
if ($row["type"] == 3) { $row["type3select"] = "selected=\"selected\" "; } else { $row["type3select"] = ""; }
|
||||||
if ($row["type"] == 4) { $row["type4select"] = "selected=\"selected\" "; } else { $row["type4select"] = ""; }
|
if ($row["type"] == 4) { $row["type4select"] = "selected=\"selected\" "; } else { $row["type4select"] = ""; }
|
||||||
if ($row["type"] == 5) { $row["type5select"] = "selected=\"selected\" "; } else { $row["type5select"] = ""; }
|
if ($row["type"] == 5) { $row["type5select"] = "selected=\"selected\" "; } else { $row["type5select"] = ""; }
|
||||||
|
|
||||||
$page = parsetemplate($page, $row);
|
$page = parsetemplate($page, $row);
|
||||||
admindisplay($page, "Edit Spells");
|
admindisplay($page, "Edit Spells");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function levels() {
|
function levels() {
|
||||||
|
|
||||||
$query = doquery("SELECT id FROM {{table}} ORDER BY id DESC LIMIT 1", "levels");
|
$query = doquery("SELECT id FROM {{table}} ORDER BY id DESC LIMIT 1", "levels");
|
||||||
$row = mysql_fetch_array($query);
|
$row = mysql_fetch_array($query);
|
||||||
|
|
||||||
$options = "";
|
$options = "";
|
||||||
for($i=2; $i<$row["id"]; $i++) {
|
for($i=2; $i<$row["id"]; $i++) {
|
||||||
$options .= "<option value=\"$i\">$i</option>\n";
|
$options .= "<option value=\"$i\">$i</option>\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
$page = <<<END
|
$page = <<<END
|
||||||
<b><u>Edit Levels</u></b><br />Select a level number from the dropdown box to edit it.<br /><br />
|
<b><u>Edit Levels</u></b><br />Select a level number from the dropdown box to edit it.<br /><br />
|
||||||
<form action="admin.php?do=editlevel" method="post">
|
<form action="admin.php?do=editlevel" method="post">
|
||||||
<select name="level">
|
<select name="level">
|
||||||
$options
|
$options
|
||||||
</select>
|
</select>
|
||||||
<input type="submit" name="go" value="Submit" />
|
<input type="submit" name="go" value="Submit" />
|
||||||
</form>
|
</form>
|
||||||
END;
|
END;
|
||||||
|
|
||||||
admindisplay($page, "Edit Levels");
|
admindisplay($page, "Edit Levels");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function editlevel() {
|
function editlevel() {
|
||||||
|
|
||||||
if (!isset($_POST["level"])) { admindisplay("No level to edit.", "Edit Levels"); die(); }
|
if (!isset($_POST["level"])) { admindisplay("No level to edit.", "Edit Levels"); die(); }
|
||||||
$id = $_POST["level"];
|
$id = $_POST["level"];
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$errors = 0;
|
$errors = 0;
|
||||||
$errorlist = "";
|
$errorlist = "";
|
||||||
|
@ -555,7 +545,7 @@ function editlevel() {
|
||||||
if (!is_numeric($_POST["two_strength"])) { $errors++; $errorlist .= "Class 2 Strength must be a number.<br />"; }
|
if (!is_numeric($_POST["two_strength"])) { $errors++; $errorlist .= "Class 2 Strength must be a number.<br />"; }
|
||||||
if (!is_numeric($_POST["two_dexterity"])) { $errors++; $errorlist .= "Class 2 Dexterity must be a number.<br />"; }
|
if (!is_numeric($_POST["two_dexterity"])) { $errors++; $errorlist .= "Class 2 Dexterity must be a number.<br />"; }
|
||||||
if (!is_numeric($_POST["two_spells"])) { $errors++; $errorlist .= "Class 2 Spells must be a number.<br />"; }
|
if (!is_numeric($_POST["two_spells"])) { $errors++; $errorlist .= "Class 2 Spells must be a number.<br />"; }
|
||||||
|
|
||||||
if ($_POST["three_exp"] == "") { $errors++; $errorlist .= "Class 3 Experience is required.<br />"; }
|
if ($_POST["three_exp"] == "") { $errors++; $errorlist .= "Class 3 Experience is required.<br />"; }
|
||||||
if ($_POST["three_hp"] == "") { $errors++; $errorlist .= "Class 3 HP is required.<br />"; }
|
if ($_POST["three_hp"] == "") { $errors++; $errorlist .= "Class 3 HP is required.<br />"; }
|
||||||
if ($_POST["three_mp"] == "") { $errors++; $errorlist .= "Class 3 MP is required.<br />"; }
|
if ($_POST["three_mp"] == "") { $errors++; $errorlist .= "Class 3 MP is required.<br />"; }
|
||||||
|
@ -571,7 +561,7 @@ function editlevel() {
|
||||||
if (!is_numeric($_POST["three_dexterity"])) { $errors++; $errorlist .= "Class 3 Dexterity must be a number.<br />"; }
|
if (!is_numeric($_POST["three_dexterity"])) { $errors++; $errorlist .= "Class 3 Dexterity must be a number.<br />"; }
|
||||||
if (!is_numeric($_POST["three_spells"])) { $errors++; $errorlist .= "Class 3 Spells must be a number.<br />"; }
|
if (!is_numeric($_POST["three_spells"])) { $errors++; $errorlist .= "Class 3 Spells must be a number.<br />"; }
|
||||||
|
|
||||||
if ($errors == 0) {
|
if ($errors == 0) {
|
||||||
$updatequery = <<<END
|
$updatequery = <<<END
|
||||||
UPDATE {{table}} SET
|
UPDATE {{table}} SET
|
||||||
1_exp='$one_exp', 1_hp='$one_hp', 1_mp='$one_mp', 1_tp='$one_tp', 1_strength='$one_strength', 1_dexterity='$one_dexterity', 1_spells='$one_spells',
|
1_exp='$one_exp', 1_hp='$one_hp', 1_mp='$one_mp', 1_tp='$one_tp', 1_strength='$one_strength', 1_dexterity='$one_dexterity', 1_spells='$one_spells',
|
||||||
|
@ -583,11 +573,11 @@ END;
|
||||||
admindisplay("Level updated.","Edit Levels");
|
admindisplay("Level updated.","Edit Levels");
|
||||||
} else {
|
} else {
|
||||||
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Spells");
|
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Spells");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "levels");
|
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "levels");
|
||||||
$row = mysql_fetch_array($query);
|
$row = mysql_fetch_array($query);
|
||||||
global $controlrow;
|
global $controlrow;
|
||||||
|
@ -636,14 +626,14 @@ Experience values for each level should be the cumulative total amount of experi
|
||||||
<input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" />
|
<input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" />
|
||||||
</form>
|
</form>
|
||||||
END;
|
END;
|
||||||
|
|
||||||
$page = parsetemplate($page, $row);
|
$page = parsetemplate($page, $row);
|
||||||
admindisplay($page, "Edit Levels");
|
admindisplay($page, "Edit Levels");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function users() {
|
function users() {
|
||||||
|
|
||||||
$query = doquery("SELECT id,username FROM {{table}} ORDER BY id", "users");
|
$query = doquery("SELECT id,username FROM {{table}} ORDER BY id", "users");
|
||||||
$page = "<b><u>Edit Users</u></b><br />Click a username to edit the account.<br /><br /><table width=\"50%\">\n";
|
$page = "<b><u>Edit Users</u></b><br />Click a username to edit the account.<br /><br /><table width=\"50%\">\n";
|
||||||
$count = 1;
|
$count = 1;
|
||||||
|
@ -658,23 +648,21 @@ function users() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function edituser($id) {
|
function edituser($id) {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$errors = 0;
|
$errors = 0;
|
||||||
$errorlist = "";
|
$errorlist = "";
|
||||||
if ($email == "") { $errors++; $errorlist .= "Email is required.<br />"; }
|
if ($email == "") { $errors++; $errorlist .= "Email is required.<br />"; }
|
||||||
if ($verify == "") { $errors++; $errorlist .= "Verify is required.<br />"; }
|
if ($verify == "") { $errors++; $errorlist .= "Verify is required.<br />"; }
|
||||||
if ($charname == "") { $errors++; $errorlist .= "Character Name is required.<br />"; }
|
|
||||||
if ($authlevel == "") { $errors++; $errorlist .= "Auth Level is required.<br />"; }
|
if ($authlevel == "") { $errors++; $errorlist .= "Auth Level is required.<br />"; }
|
||||||
if ($latitude == "") { $errors++; $errorlist .= "Latitude is required.<br />"; }
|
if ($latitude == "") { $errors++; $errorlist .= "Latitude is required.<br />"; }
|
||||||
if ($longitude == "") { $errors++; $errorlist .= "Longitude is required.<br />"; }
|
if ($longitude == "") { $errors++; $errorlist .= "Longitude is required.<br />"; }
|
||||||
if ($difficulty == "") { $errors++; $errorlist .= "Difficulty is required.<br />"; }
|
|
||||||
if ($charclass == "") { $errors++; $errorlist .= "Character Class is required.<br />"; }
|
if ($charclass == "") { $errors++; $errorlist .= "Character Class is required.<br />"; }
|
||||||
if ($currentaction == "") { $errors++; $errorlist .= "Current Action is required.<br />"; }
|
if ($currentaction == "") { $errors++; $errorlist .= "Current Action is required.<br />"; }
|
||||||
if ($currentfight == "") { $errors++; $errorlist .= "Current Fight is required.<br />"; }
|
if ($currentfight == "") { $errors++; $errorlist .= "Current Fight is required.<br />"; }
|
||||||
|
|
||||||
if ($currentmonster == "") { $errors++; $errorlist .= "Current Monster is required.<br />"; }
|
if ($currentmonster == "") { $errors++; $errorlist .= "Current Monster is required.<br />"; }
|
||||||
if ($currentmonsterhp == "") { $errors++; $errorlist .= "Current Monster HP is required.<br />"; }
|
if ($currentmonsterhp == "") { $errors++; $errorlist .= "Current Monster HP is required.<br />"; }
|
||||||
if ($currentmonstersleep == "") { $errors++; $errorlist .= "Current Monster Sleep is required.<br />"; }
|
if ($currentmonstersleep == "") { $errors++; $errorlist .= "Current Monster Sleep is required.<br />"; }
|
||||||
|
@ -714,17 +702,16 @@ function edituser($id) {
|
||||||
if ($dropcode == "") { $errors++; $errorlist .= "Drop Code is required.<br />"; }
|
if ($dropcode == "") { $errors++; $errorlist .= "Drop Code is required.<br />"; }
|
||||||
if ($spells == "") { $errors++; $errorlist .= "Spells is required.<br />"; }
|
if ($spells == "") { $errors++; $errorlist .= "Spells is required.<br />"; }
|
||||||
if ($towns == "") { $errors++; $errorlist .= "Towns is required.<br />"; }
|
if ($towns == "") { $errors++; $errorlist .= "Towns is required.<br />"; }
|
||||||
|
|
||||||
if (!is_numeric($authlevel)) { $errors++; $errorlist .= "Auth Level must be a number.<br />"; }
|
if (!is_numeric($authlevel)) { $errors++; $errorlist .= "Auth Level must be a number.<br />"; }
|
||||||
if (!is_numeric($latitude)) { $errors++; $errorlist .= "Latitude must be a number.<br />"; }
|
if (!is_numeric($latitude)) { $errors++; $errorlist .= "Latitude must be a number.<br />"; }
|
||||||
if (!is_numeric($longitude)) { $errors++; $errorlist .= "Longitude must be a number.<br />"; }
|
if (!is_numeric($longitude)) { $errors++; $errorlist .= "Longitude must be a number.<br />"; }
|
||||||
if (!is_numeric($difficulty)) { $errors++; $errorlist .= "Difficulty must be a number.<br />"; }
|
|
||||||
if (!is_numeric($charclass)) { $errors++; $errorlist .= "Character Class must be a number.<br />"; }
|
if (!is_numeric($charclass)) { $errors++; $errorlist .= "Character Class must be a number.<br />"; }
|
||||||
if (!is_numeric($currentfight)) { $errors++; $errorlist .= "Current Fight must be a number.<br />"; }
|
if (!is_numeric($currentfight)) { $errors++; $errorlist .= "Current Fight must be a number.<br />"; }
|
||||||
if (!is_numeric($currentmonster)) { $errors++; $errorlist .= "Current Monster must be a number.<br />"; }
|
if (!is_numeric($currentmonster)) { $errors++; $errorlist .= "Current Monster must be a number.<br />"; }
|
||||||
if (!is_numeric($currentmonsterhp)) { $errors++; $errorlist .= "Current Monster HP must be a number.<br />"; }
|
if (!is_numeric($currentmonsterhp)) { $errors++; $errorlist .= "Current Monster HP must be a number.<br />"; }
|
||||||
if (!is_numeric($currentmonstersleep)) { $errors++; $errorlist .= "Current Monster Sleep must be a number.<br />"; }
|
if (!is_numeric($currentmonstersleep)) { $errors++; $errorlist .= "Current Monster Sleep must be a number.<br />"; }
|
||||||
|
|
||||||
if (!is_numeric($currentmonsterimmune)) { $errors++; $errorlist .= "Current Monster Immune must be a number.<br />"; }
|
if (!is_numeric($currentmonsterimmune)) { $errors++; $errorlist .= "Current Monster Immune must be a number.<br />"; }
|
||||||
if (!is_numeric($currentuberdamage)) { $errors++; $errorlist .= "Current Uber Damage must be a number.<br />"; }
|
if (!is_numeric($currentuberdamage)) { $errors++; $errorlist .= "Current Uber Damage must be a number.<br />"; }
|
||||||
if (!is_numeric($currentuberdefense)) { $errors++; $errorlist .= "Current Uber Defense must be a number.<br />"; }
|
if (!is_numeric($currentuberdefense)) { $errors++; $errorlist .= "Current Uber Defense must be a number.<br />"; }
|
||||||
|
@ -735,7 +722,7 @@ function edituser($id) {
|
||||||
if (!is_numeric($maxmp)) { $errors++; $errorlist .= "Max MP must be a number.<br />"; }
|
if (!is_numeric($maxmp)) { $errors++; $errorlist .= "Max MP must be a number.<br />"; }
|
||||||
if (!is_numeric($maxtp)) { $errors++; $errorlist .= "Max TP must be a number.<br />"; }
|
if (!is_numeric($maxtp)) { $errors++; $errorlist .= "Max TP must be a number.<br />"; }
|
||||||
if (!is_numeric($level)) { $errors++; $errorlist .= "Level must be a number.<br />"; }
|
if (!is_numeric($level)) { $errors++; $errorlist .= "Level must be a number.<br />"; }
|
||||||
|
|
||||||
if (!is_numeric($gold)) { $errors++; $errorlist .= "Gold must be a number.<br />"; }
|
if (!is_numeric($gold)) { $errors++; $errorlist .= "Gold must be a number.<br />"; }
|
||||||
if (!is_numeric($experience)) { $errors++; $errorlist .= "Experience must be a number.<br />"; }
|
if (!is_numeric($experience)) { $errors++; $errorlist .= "Experience must be a number.<br />"; }
|
||||||
if (!is_numeric($goldbonus)) { $errors++; $errorlist .= "Gold Bonus must be a number.<br />"; }
|
if (!is_numeric($goldbonus)) { $errors++; $errorlist .= "Gold Bonus must be a number.<br />"; }
|
||||||
|
@ -746,18 +733,18 @@ function edituser($id) {
|
||||||
if (!is_numeric($defensepower)) { $errors++; $errorlist .= "Defense Power must be a number.<br />"; }
|
if (!is_numeric($defensepower)) { $errors++; $errorlist .= "Defense Power must be a number.<br />"; }
|
||||||
if (!is_numeric($weaponid)) { $errors++; $errorlist .= "Weapon ID must be a number.<br />"; }
|
if (!is_numeric($weaponid)) { $errors++; $errorlist .= "Weapon ID must be a number.<br />"; }
|
||||||
if (!is_numeric($armorid)) { $errors++; $errorlist .= "Armor ID must be a number.<br />"; }
|
if (!is_numeric($armorid)) { $errors++; $errorlist .= "Armor ID must be a number.<br />"; }
|
||||||
|
|
||||||
if (!is_numeric($shieldid)) { $errors++; $errorlist .= "Shield ID must be a number.<br />"; }
|
if (!is_numeric($shieldid)) { $errors++; $errorlist .= "Shield ID must be a number.<br />"; }
|
||||||
if (!is_numeric($slot1id)) { $errors++; $errorlist .= "Slot 1 ID must be a number.<br />"; }
|
if (!is_numeric($slot1id)) { $errors++; $errorlist .= "Slot 1 ID must be a number.<br />"; }
|
||||||
if (!is_numeric($slot2id)) { $errors++; $errorlist .= "Slot 2 ID must be a number.<br />"; }
|
if (!is_numeric($slot2id)) { $errors++; $errorlist .= "Slot 2 ID must be a number.<br />"; }
|
||||||
if (!is_numeric($slot3id)) { $errors++; $errorlist .= "Slot 3 ID must be a number.<br />"; }
|
if (!is_numeric($slot3id)) { $errors++; $errorlist .= "Slot 3 ID must be a number.<br />"; }
|
||||||
if (!is_numeric($dropcode)) { $errors++; $errorlist .= "Drop Code must be a number.<br />"; }
|
if (!is_numeric($dropcode)) { $errors++; $errorlist .= "Drop Code must be a number.<br />"; }
|
||||||
|
|
||||||
if ($errors == 0) {
|
if ($errors == 0) {
|
||||||
$updatequery = <<<END
|
$updatequery = <<<END
|
||||||
UPDATE {{table}} SET
|
UPDATE {{table}} SET
|
||||||
email="$email", verify="$verify", charname="$charname", authlevel="$authlevel", latitude="$latitude",
|
email="$email", verify="$verify", authlevel="$authlevel", latitude="$latitude",
|
||||||
longitude="$longitude", difficulty="$difficulty", charclass="$charclass", currentaction="$currentaction", currentfight="$currentfight",
|
longitude="$longitude", charclass="$charclass", currentaction="$currentaction", currentfight="$currentfight",
|
||||||
currentmonster="$currentmonster", currentmonsterhp="$currentmonsterhp", currentmonstersleep="$currentmonstersleep", currentmonsterimmune="$currentmonsterimmune", currentuberdamage="$currentuberdamage",
|
currentmonster="$currentmonster", currentmonsterhp="$currentmonsterhp", currentmonstersleep="$currentmonstersleep", currentmonsterimmune="$currentmonsterimmune", currentuberdamage="$currentuberdamage",
|
||||||
currentuberdefense="$currentuberdefense", currenthp="$currenthp", currentmp="$currentmp", currenttp="$currenttp", maxhp="$maxhp",
|
currentuberdefense="$currentuberdefense", currenthp="$currenthp", currentmp="$currentmp", currenttp="$currenttp", maxhp="$maxhp",
|
||||||
maxmp="$maxmp", maxtp="$maxtp", level="$level", gold="$gold", experience="$experience",
|
maxmp="$maxmp", maxtp="$maxtp", level="$level", gold="$gold", experience="$experience",
|
||||||
|
@ -771,10 +758,10 @@ END;
|
||||||
admindisplay("User updated.","Edit Users");
|
admindisplay("User updated.","Edit Users");
|
||||||
} else {
|
} else {
|
||||||
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Users");
|
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Edit Users");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "users");
|
$query = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "users");
|
||||||
$row = mysql_fetch_array($query);
|
$row = mysql_fetch_array($query);
|
||||||
global $controlrow;
|
global $controlrow;
|
||||||
|
@ -793,7 +780,6 @@ $page = <<<END
|
||||||
<tr><td width="20%">Username:</td><td>{{username}}</td></tr>
|
<tr><td width="20%">Username:</td><td>{{username}}</td></tr>
|
||||||
<tr><td width="20%">Email:</td><td><input type="text" name="email" size="30" maxlength="100" value="{{email}}" /></td></tr>
|
<tr><td width="20%">Email:</td><td><input type="text" name="email" size="30" maxlength="100" value="{{email}}" /></td></tr>
|
||||||
<tr><td width="20%">Verify:</td><td><input type="text" name="verify" size="30" maxlength="8" value="{{verify}}" /></td></tr>
|
<tr><td width="20%">Verify:</td><td><input type="text" name="verify" size="30" maxlength="8" value="{{verify}}" /></td></tr>
|
||||||
<tr><td width="20%">Character Name:</td><td><input type="text" name="charname" size="30" maxlength="30" value="{{charname}}" /></td></tr>
|
|
||||||
<tr><td width="20%">Register Date:</td><td>{{regdate}}</td></tr>
|
<tr><td width="20%">Register Date:</td><td>{{regdate}}</td></tr>
|
||||||
<tr><td width="20%">Last Online:</td><td>{{onlinetime}}</td></tr>
|
<tr><td width="20%">Last Online:</td><td>{{onlinetime}}</td></tr>
|
||||||
<tr><td width="20%">Auth Level:</td><td><select name="authlevel"><option value="0" {{auth0select}}>User</option><option value="1" {{auth1select}}>Admin</option><option value="2" {{auth2select}}>Blocked</option></select><br /><span class="small">Set to "Blocked" to temporarily (or permanently) ban a user.</span></td></tr>
|
<tr><td width="20%">Auth Level:</td><td><select name="authlevel"><option value="0" {{auth0select}}>User</option><option value="1" {{auth1select}}>Admin</option><option value="2" {{auth2select}}>Blocked</option></select><br /><span class="small">Set to "Blocked" to temporarily (or permanently) ban a user.</span></td></tr>
|
||||||
|
@ -802,7 +788,6 @@ $page = <<<END
|
||||||
|
|
||||||
<tr><td width="20%">Latitude:</td><td><input type="text" name="latitude" size="5" maxlength="6" value="{{latitude}}" /></td></tr>
|
<tr><td width="20%">Latitude:</td><td><input type="text" name="latitude" size="5" maxlength="6" value="{{latitude}}" /></td></tr>
|
||||||
<tr><td width="20%">Longitude:</td><td><input type="text" name="longitude" size="5" maxlength="6" value="{{longitude}}" /></td></tr>
|
<tr><td width="20%">Longitude:</td><td><input type="text" name="longitude" size="5" maxlength="6" value="{{longitude}}" /></td></tr>
|
||||||
<tr><td width="20%">Difficulty:</td><td><select name="difficulty"><option value="1" {{diff1select}}>$diff1name</option><option value="2" {{diff2select}}>$diff2name</option><option value="3" {{diff3select}}>$diff3name</option></select></td></tr>
|
|
||||||
<tr><td width="20%">Character Class:</td><td><select name="charclass"><option value="1" {{class1select}}>$class1name</option><option value="2" {{class2select}}>$class2name</option><option value="3" {{class3select}}>$class3name</option></select></td></tr>
|
<tr><td width="20%">Character Class:</td><td><select name="charclass"><option value="1" {{class1select}}>$class1name</option><option value="2" {{class2select}}>$class2name</option><option value="3" {{class3select}}>$class3name</option></select></td></tr>
|
||||||
|
|
||||||
<tr><td colspan="2" style="background-color:#cccccc;"> </td></tr>
|
<tr><td colspan="2" style="background-color:#cccccc;"> </td></tr>
|
||||||
|
@ -869,33 +854,30 @@ END;
|
||||||
if ($row["charclass"] == 1) { $row["class1select"] = "selected=\"selected\" "; } else { $row["class1select"] = ""; }
|
if ($row["charclass"] == 1) { $row["class1select"] = "selected=\"selected\" "; } else { $row["class1select"] = ""; }
|
||||||
if ($row["charclass"] == 2) { $row["class2select"] = "selected=\"selected\" "; } else { $row["class2select"] = ""; }
|
if ($row["charclass"] == 2) { $row["class2select"] = "selected=\"selected\" "; } else { $row["class2select"] = ""; }
|
||||||
if ($row["charclass"] == 3) { $row["class3select"] = "selected=\"selected\" "; } else { $row["class3select"] = ""; }
|
if ($row["charclass"] == 3) { $row["class3select"] = "selected=\"selected\" "; } else { $row["class3select"] = ""; }
|
||||||
if ($row["difficulty"] == 1) { $row["diff1select"] = "selected=\"selected\" "; } else { $row["diff1select"] = ""; }
|
|
||||||
if ($row["difficulty"] == 2) { $row["diff2select"] = "selected=\"selected\" "; } else { $row["diff2select"] = ""; }
|
|
||||||
if ($row["difficulty"] == 3) { $row["diff3select"] = "selected=\"selected\" "; } else { $row["diff3select"] = ""; }
|
|
||||||
|
|
||||||
$page = parsetemplate($page, $row);
|
$page = parsetemplate($page, $row);
|
||||||
admindisplay($page, "Edit Users");
|
admindisplay($page, "Edit Users");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function addnews() {
|
function addnews() {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$errors = 0;
|
$errors = 0;
|
||||||
$errorlist = "";
|
$errorlist = "";
|
||||||
if ($content == "") { $errors++; $errorlist .= "Content is required.<br />"; }
|
if ($content == "") { $errors++; $errorlist .= "Content is required.<br />"; }
|
||||||
|
|
||||||
if ($errors == 0) {
|
if ($errors == 0) {
|
||||||
$query = doquery("INSERT INTO {{table}} SET id='',postdate=NOW(),content='$content'", "news");
|
$query = doquery("INSERT INTO {{table}} SET id='',postdate=NOW(),content='$content'", "news");
|
||||||
admindisplay("News post added.","Add News");
|
admindisplay("News post added.","Add News");
|
||||||
} else {
|
} else {
|
||||||
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Add News");
|
admindisplay("<b>Errors:</b><br /><div style=\"color:red;\">$errorlist</div><br />Please go back and try again.", "Add News");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$page = <<<END
|
$page = <<<END
|
||||||
<b><u>Add A News Post</u></b><br /><br />
|
<b><u>Add A News Post</u></b><br /><br />
|
||||||
<form action="admin.php?do=news" method="post">
|
<form action="admin.php?do=news" method="post">
|
||||||
|
@ -904,9 +886,9 @@ Type your post below and then click Submit to add it.<br />
|
||||||
<input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" />
|
<input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" />
|
||||||
</form>
|
</form>
|
||||||
END;
|
END;
|
||||||
|
|
||||||
admindisplay($page, "Add News");
|
admindisplay($page, "Add News");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
|
|
@ -17,12 +17,12 @@ if ($userrow["authlevel"] == 2) { die("Your account has been blocked. Please try
|
||||||
|
|
||||||
if (isset($_GET["do"])) {
|
if (isset($_GET["do"])) {
|
||||||
$do = explode(":",$_GET["do"]);
|
$do = explode(":",$_GET["do"]);
|
||||||
|
|
||||||
if ($do[0] == "thread") { showthread($do[1], $do[2]); }
|
if ($do[0] == "thread") { showthread($do[1], $do[2]); }
|
||||||
elseif ($do[0] == "new") { newthread(); }
|
elseif ($do[0] == "new") { newthread(); }
|
||||||
elseif ($do[0] == "reply") { reply(); }
|
elseif ($do[0] == "reply") { reply(); }
|
||||||
elseif ($do[0] == "list") { donothing($do[1]); }
|
elseif ($do[0] == "list") { donothing($do[1]); }
|
||||||
|
|
||||||
} else { donothing(0); }
|
} else { donothing(0); }
|
||||||
|
|
||||||
function donothing($start=0) {
|
function donothing($start=0) {
|
||||||
|
@ -30,9 +30,9 @@ function donothing($start=0) {
|
||||||
$query = doquery("SELECT * FROM {{table}} WHERE parent='0' ORDER BY newpostdate DESC LIMIT 20", "forum");
|
$query = doquery("SELECT * FROM {{table}} WHERE parent='0' ORDER BY newpostdate DESC LIMIT 20", "forum");
|
||||||
$page = "<table width=\"100%\"><tr><td style=\"padding:1px; background-color:black;\"><table width=\"100%\" style=\"margins:0px;\" cellspacing=\"1\" cellpadding=\"3\"><tr><th colspan=\"3\" style=\"background-color:#dddddd;\"><center><a href=\"forum.php?do=new\">New Thread</a></center></th></tr><tr><th width=\"50%\" style=\"background-color:#dddddd;\">Thread</th><th width=\"10%\" style=\"background-color:#dddddd;\">Replies</th><th style=\"background-color:#dddddd;\">Last Post</th></tr>\n";
|
$page = "<table width=\"100%\"><tr><td style=\"padding:1px; background-color:black;\"><table width=\"100%\" style=\"margins:0px;\" cellspacing=\"1\" cellpadding=\"3\"><tr><th colspan=\"3\" style=\"background-color:#dddddd;\"><center><a href=\"forum.php?do=new\">New Thread</a></center></th></tr><tr><th width=\"50%\" style=\"background-color:#dddddd;\">Thread</th><th width=\"10%\" style=\"background-color:#dddddd;\">Replies</th><th style=\"background-color:#dddddd;\">Last Post</th></tr>\n";
|
||||||
$count = 1;
|
$count = 1;
|
||||||
if (mysql_num_rows($query) == 0) {
|
if (mysql_num_rows($query) == 0) {
|
||||||
$page .= "<tr><td style=\"background-color:#ffffff;\" colspan=\"3\"><b>No threads in forum.</b></td></tr>\n";
|
$page .= "<tr><td style=\"background-color:#ffffff;\" colspan=\"3\"><b>No threads in forum.</b></td></tr>\n";
|
||||||
} else {
|
} else {
|
||||||
while ($row = mysql_fetch_array($query)) {
|
while ($row = mysql_fetch_array($query)) {
|
||||||
if ($count == 1) {
|
if ($count == 1) {
|
||||||
$page .= "<tr><td style=\"background-color:#ffffff;\"><a href=\"forum.php?do=thread:".$row["id"].":0\">".$row["title"]."</a></td><td style=\"background-color:#ffffff;\">".$row["replies"]."</td><td style=\"background-color:#ffffff;\">".$row["newpostdate"]."</td></tr>\n";
|
$page .= "<tr><td style=\"background-color:#ffffff;\"><a href=\"forum.php?do=thread:".$row["id"].":0\">".$row["title"]."</a></td><td style=\"background-color:#ffffff;\">".$row["replies"]."</td><td style=\"background-color:#ffffff;\">".$row["newpostdate"]."</td></tr>\n";
|
||||||
|
@ -44,9 +44,9 @@ function donothing($start=0) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$page .= "</table></td></tr></table>";
|
$page .= "</table></td></tr></table>";
|
||||||
|
|
||||||
display($page, "Forum");
|
display($page, "Forum");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function showthread($id, $start) {
|
function showthread($id, $start) {
|
||||||
|
@ -67,36 +67,36 @@ function showthread($id, $start) {
|
||||||
}
|
}
|
||||||
$page .= "</table></td></tr></table><br />";
|
$page .= "</table></td></tr></table><br />";
|
||||||
$page .= "<table width=\"100%\"><tr><td><b>Reply To This Thread:</b><br /><form action=\"forum.php?do=reply\" method=\"post\"><input type=\"hidden\" name=\"parent\" value=\"$id\" /><input type=\"hidden\" name=\"title\" value=\"Re: ".$row2["title"]."\" /><textarea name=\"content\" rows=\"7\" cols=\"40\"></textarea><br /><input type=\"submit\" name=\"submit\" value=\"Submit\" /> <input type=\"reset\" name=\"reset\" value=\"Reset\" /></form></td></tr></table>";
|
$page .= "<table width=\"100%\"><tr><td><b>Reply To This Thread:</b><br /><form action=\"forum.php?do=reply\" method=\"post\"><input type=\"hidden\" name=\"parent\" value=\"$id\" /><input type=\"hidden\" name=\"title\" value=\"Re: ".$row2["title"]."\" /><textarea name=\"content\" rows=\"7\" cols=\"40\"></textarea><br /><input type=\"submit\" name=\"submit\" value=\"Submit\" /> <input type=\"reset\" name=\"reset\" value=\"Reset\" /></form></td></tr></table>";
|
||||||
|
|
||||||
display($page, "Forum");
|
display($page, "Forum");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function reply() {
|
function reply() {
|
||||||
|
|
||||||
global $userrow;
|
global $userrow;
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$query = doquery("INSERT INTO {{table}} SET id='',postdate=NOW(),newpostdate=NOW(),author='".$userrow["charname"]."',parent='$parent',replies='0',title='$title',content='$content'", "forum");
|
$query = doquery("INSERT INTO {{table}} SET id='',postdate=NOW(),newpostdate=NOW(),author='".$userrow["username"]."',parent='$parent',replies='0',title='$title',content='$content'", "forum");
|
||||||
$query2 = doquery("UPDATE {{table}} SET newpostdate=NOW(),replies=replies+1 WHERE id='$parent' LIMIT 1", "forum");
|
$query2 = doquery("UPDATE {{table}} SET newpostdate=NOW(),replies=replies+1 WHERE id='$parent' LIMIT 1", "forum");
|
||||||
header("Location: forum.php?do=thread:$parent:0");
|
header("Location: forum.php?do=thread:$parent:0");
|
||||||
die();
|
die();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function newthread() {
|
function newthread() {
|
||||||
|
|
||||||
global $userrow;
|
global $userrow;
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$query = doquery("INSERT INTO {{table}} SET id='',postdate=NOW(),newpostdate=NOW(),author='".$userrow["charname"]."',parent='0',replies='0',title='$title',content='$content'", "forum");
|
$query = doquery("INSERT INTO {{table}} SET id='',postdate=NOW(),newpostdate=NOW(),author='".$userrow["username"]."',parent='0',replies='0',title='$title',content='$content'", "forum");
|
||||||
header("Location: forum.php");
|
header("Location: forum.php");
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
|
|
||||||
$page = "<table width=\"100%\"><tr><td><b>Make A New Post:</b><br /><br/ ><form action=\"forum.php?do=new\" method=\"post\">Title:<br /><input type=\"text\" name=\"title\" size=\"50\" maxlength=\"50\" /><br /><br />Message:<br /><textarea name=\"content\" rows=\"7\" cols=\"40\"></textarea><br /><br /><input type=\"submit\" name=\"submit\" value=\"Submit\" /> <input type=\"reset\" name=\"reset\" value=\"Reset\" /></form></td></tr></table>";
|
$page = "<table width=\"100%\"><tr><td><b>Make A New Post:</b><br /><br/ ><form action=\"forum.php?do=new\" method=\"post\">Title:<br /><input type=\"text\" name=\"title\" size=\"50\" maxlength=\"50\" /><br /><br />Message:<br /><textarea name=\"content\" rows=\"7\" cols=\"40\"></textarea><br /><br /><input type=\"submit\" name=\"submit\" value=\"Submit\" /> <input type=\"reset\" name=\"reset\" value=\"Reset\" /></form></td></tr></table>";
|
||||||
display($page, "Forum");
|
display($page, "Forum");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
include('lib.php');
|
include('lib.php');
|
||||||
$link = opendb();
|
$link = opendb();
|
||||||
$controlquery = doquery("SELECT * FROM {{table}} WHERE id='1' LIMIT 1", "control");
|
$controlquery = doquery("SELECT * FROM {{table}} WHERE id='1' LIMIT 1", "control");
|
||||||
$controlrow = mysql_fetch_array($controlquery);
|
$controlrow = mysql_fetch_array($controlquery);
|
||||||
|
@ -79,7 +79,6 @@ a:hover {
|
||||||
<ul>
|
<ul>
|
||||||
<li /><a href="#intro">Introduction</a>
|
<li /><a href="#intro">Introduction</a>
|
||||||
<li /><a href="#classes">Character Classes</a>
|
<li /><a href="#classes">Character Classes</a>
|
||||||
<li /><a href="#difficulties">Difficulty Levels</a>
|
|
||||||
<li /><a href="#intown">Playing The Game: In Town</a>
|
<li /><a href="#intown">Playing The Game: In Town</a>
|
||||||
<li /><a href="#exploring">Playing The Game: Exploring & Fighting</a>
|
<li /><a href="#exploring">Playing The Game: Exploring & Fighting</a>
|
||||||
<li /><a href="#status">Playing The Game: Status Panels</a>
|
<li /><a href="#status">Playing The Game: Status Panels</a>
|
||||||
|
@ -93,16 +92,16 @@ a:hover {
|
||||||
<hr />
|
<hr />
|
||||||
|
|
||||||
<h3><a name="intro"></a>Introduction</h3>
|
<h3><a name="intro"></a>Introduction</h3>
|
||||||
Firstly, I'd like to say thank you for playing my game. The <i>Dragon Knight</i> game engine is the result of several months of
|
Firstly, I'd like to say thank you for playing my game. The <i>Dragon Knight</i> game engine is the result of several months of
|
||||||
planning, coding and testing. The original idea was to create a web-based tribute to the NES game, <i>Dragon
|
planning, coding and testing. The original idea was to create a web-based tribute to the NES game, <i>Dragon
|
||||||
Warrior</i>. In its current iteration, only the underlying fighting system really resembles that game, as almost
|
Warrior</i>. In its current iteration, only the underlying fighting system really resembles that game, as almost
|
||||||
everything else in DK has been made bigger and better. But you should still recognize bits and pieces as stemming
|
everything else in DK has been made bigger and better. But you should still recognize bits and pieces as stemming
|
||||||
from <i>Dragon Warrior</i> and other RPGs of old.<br /><br />
|
from <i>Dragon Warrior</i> and other RPGs of old.<br /><br />
|
||||||
This is the first game I've ever written, and it has definitely been a positive experience. It got difficult at
|
This is the first game I've ever written, and it has definitely been a positive experience. It got difficult at
|
||||||
times, admittedly, but it was still a lot of fun to write, and even more fun to play. And I hope to use this
|
times, admittedly, but it was still a lot of fun to write, and even more fun to play. And I hope to use this
|
||||||
experience so that if I ever want to create another game it will be even better than this one.<br /><br />
|
experience so that if I ever want to create another game it will be even better than this one.<br /><br />
|
||||||
If you are a site administrator, and would like to install a copy of DK on your own server, you may visit the
|
If you are a site administrator, and would like to install a copy of DK on your own server, you may visit the
|
||||||
<a href="http://dragon.se7enet.com/dev.php" target="_new">development site</a> for <i>Dragon Knight</i>. This page
|
<a href="http://dragon.se7enet.com/dev.php" target="_new">development site</a> for <i>Dragon Knight</i>. This page
|
||||||
includes the downloadable game souce code, as well as some other resources that developers and administrators may
|
includes the downloadable game souce code, as well as some other resources that developers and administrators may
|
||||||
find valuable.<br /><br />
|
find valuable.<br /><br />
|
||||||
Once again, thanks for playing!<br /><br />
|
Once again, thanks for playing!<br /><br />
|
||||||
|
@ -163,22 +162,6 @@ for the game. If your administrator has used his/her own class setup, this infor
|
||||||
|
|
||||||
<br /><br /><hr />
|
<br /><br /><hr />
|
||||||
|
|
||||||
<h3><a name="difficulties"></a>Difficulty Levels</h3>
|
|
||||||
<i><? echo $controlrow["gamename"]; ?></i> includes the ability to play using one of three difficulty levels.
|
|
||||||
All monster statistics in the game are set at a base number. However, using a difficulty multiplier, certain statistics
|
|
||||||
are increased. The amount of hit points a monster has goes up, which means it will take longer to kill. But the amount
|
|
||||||
of experience and gold you gain from killing it also goes up. So the game is a little bit harder, but it is also more
|
|
||||||
rewarding. The following are the three difficulty levels and their statistic multiplier, which applies to the monster's
|
|
||||||
HP, experience drop, and gold drop.
|
|
||||||
<ul>
|
|
||||||
<li /><? echo $controlrow["diff1name"] . ": <b>" . $controlrow["diff1mod"] . "</b>"; ?>
|
|
||||||
<li /><? echo $controlrow["diff2name"] . ": <b>" . $controlrow["diff2mod"] . "</b>"; ?>
|
|
||||||
<li /><? echo $controlrow["diff3name"] . ": <b>" . $controlrow["diff3mod"] . "</b>"; ?>
|
|
||||||
</ul>
|
|
||||||
[ <a href="#top">Top</a> ]
|
|
||||||
|
|
||||||
<br /><br /><hr />
|
|
||||||
|
|
||||||
<h3><a name="intown"></a>Playing The Game: In Town</h3>
|
<h3><a name="intown"></a>Playing The Game: In Town</h3>
|
||||||
When you begin a new game, the first thing you see is the Town screen. Towns serve four primary functions: healing, buying items,
|
When you begin a new game, the first thing you see is the Town screen. Towns serve four primary functions: healing, buying items,
|
||||||
buying maps, and displaying game information.<br /><br />
|
buying maps, and displaying game information.<br /><br />
|
||||||
|
@ -206,10 +189,10 @@ administrator, a list of players who have been online recently, and the Babble B
|
||||||
Once you're done in town, you are free to start exploring the world. Use the compass buttons on the left status panel to move around.
|
Once you're done in town, you are free to start exploring the world. Use the compass buttons on the left status panel to move around.
|
||||||
The game world is basically a big square, divided into four quadrants. Each quadrant is <? echo $controlrow["gamesize"]; ?> spaces
|
The game world is basically a big square, divided into four quadrants. Each quadrant is <? echo $controlrow["gamesize"]; ?> spaces
|
||||||
square. The first town is usually located at (0N,0E). Click the North button from the first town, and now you'll be at (1N,0E).
|
square. The first town is usually located at (0N,0E). Click the North button from the first town, and now you'll be at (1N,0E).
|
||||||
Likewise, if you now click the West button, you'll be at (1N,1W). Monster levels increase with every 5 spaces you move outward
|
Likewise, if you now click the West button, you'll be at (1N,1W). Monster levels increase with every 5 spaces you move outward
|
||||||
from (0N,0E).<br /><br />
|
from (0N,0E).<br /><br />
|
||||||
While you're exploring, you will occasionally run into monsters. As in pretty much any other RPG game, you and the monster take turns
|
While you're exploring, you will occasionally run into monsters. As in pretty much any other RPG game, you and the monster take turns
|
||||||
hitting each other in an attempt to reduce each other's hit points to zero. Once you run into a monster, the Exploring screen changes
|
hitting each other in an attempt to reduce each other's hit points to zero. Once you run into a monster, the Exploring screen changes
|
||||||
to the Fighting screen.<br /><br />
|
to the Fighting screen.<br /><br />
|
||||||
When a fight begins, you'll see the monster's name and hit points, and the game will ask you for your first command. You then get to
|
When a fight begins, you'll see the monster's name and hit points, and the game will ask you for your first command. You then get to
|
||||||
pick whether you want to fight, use a spell, or run away. Note, though, that sometimes the monster has the chance to hit you
|
pick whether you want to fight, use a spell, or run away. Note, though, that sometimes the monster has the chance to hit you
|
||||||
|
@ -320,4 +303,4 @@ All original coding and graphics for the <i>Dragon Knight</i> game engine are &c
|
||||||
<td width="50%" align="center">Powered by <a href="http://dragon.se7enet.com/dev.php" target="_new">Dragon Knight</a></td><td width="50%" align="center">© 2003-2006 by renderse7en</td>
|
<td width="50%" align="center">Powered by <a href="http://dragon.se7enet.com/dev.php" target="_new">Dragon Knight</a></td><td width="50%" align="center">© 2003-2006 by renderse7en</td>
|
||||||
</tr></table>
|
</tr></table>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
222
public/index.php
222
public/index.php
|
@ -2,10 +2,7 @@
|
||||||
|
|
||||||
// index.php :: Primary program script, evil alien overlord, you decide.
|
// index.php :: Primary program script, evil alien overlord, you decide.
|
||||||
|
|
||||||
if (!file_exists('../.installed')) {
|
if (!file_exists('../.installed')) redirect('install.php');
|
||||||
header('Location: install.php');
|
|
||||||
exit;
|
|
||||||
}
|
|
||||||
|
|
||||||
require_once '../src/lib.php';
|
require_once '../src/lib.php';
|
||||||
|
|
||||||
|
@ -81,8 +78,7 @@ function donothing()
|
||||||
$page = doexplore();
|
$page = doexplore();
|
||||||
$title = "Exploring";
|
$title = "Exploring";
|
||||||
} elseif ($userrow["currentaction"] == "Fighting") {
|
} elseif ($userrow["currentaction"] == "Fighting") {
|
||||||
$page = dofight();
|
redirect('index.php?do=fight');
|
||||||
$title = "Fighting";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
display($page, $title);
|
display($page, $title);
|
||||||
|
@ -95,53 +91,53 @@ function dotown()
|
||||||
{
|
{
|
||||||
global $userrow, $controlrow;
|
global $userrow, $controlrow;
|
||||||
|
|
||||||
$townquery = db()->query('SELECT * FROM towns WHERE latitude = ? AND longitude = ? LIMIT 1;', [$userrow["latitude"], $userrow["longitude"]]);
|
$townrow = get_town_by_xy($userrow['longitude'], $userrow['latitude']);
|
||||||
if ($townquery === false) display("There is an error with your user account, or with the town data. Please try again.", "Error");
|
|
||||||
$townrow = $townquery->fetchArray(SQLITE3_ASSOC);
|
|
||||||
if ($townrow === false) display("There is an error with your user account, or with the town data. Please try again.","Error");
|
if ($townrow === false) display("There is an error with your user account, or with the town data. Please try again.","Error");
|
||||||
|
|
||||||
|
$townrow["news"] = "";
|
||||||
|
$townrow["whosonline"] = "";
|
||||||
|
$townrow["babblebox"] = "";
|
||||||
|
|
||||||
// News box. Grab latest news entry and display it. Something a little more graceful coming soon maybe.
|
// News box. Grab latest news entry and display it. Something a little more graceful coming soon maybe.
|
||||||
if ($controlrow["shownews"] == 1) {
|
if ($controlrow["shownews"] == 1) {
|
||||||
$newsrow = db()->query('SELECT * FROM news ORDER BY id DESC LIMIT 1;')->fetchArray(SQLITE3_ASSOC);
|
$newsrow = db()->query('SELECT * FROM news ORDER BY id DESC LIMIT 1;')->fetchArray(SQLITE3_ASSOC);
|
||||||
$townrow["news"] = "<table width=\"95%\"><tr><td class=\"title\">Latest News</td></tr><tr><td>\n";
|
$townrow["news"] = "<table width=\"95%\"><tr><td class=\"title\">Latest News</td></tr><tr><td>\n";
|
||||||
$townrow["news"] .= "<span class=\"light\">[".prettydate($newsrow["postdate"])."]</span><br />".nl2br($newsrow["content"]);
|
$townrow["news"] .= "<span class=\"light\">[".prettydate($newsrow["postdate"])."]</span><br />".nl2br($newsrow["content"]);
|
||||||
$townrow["news"] .= "</td></tr></table>\n";
|
$townrow["news"] .= "</td></tr></table>\n";
|
||||||
} else {
|
}
|
||||||
$townrow["news"] = "";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Who's Online. Currently just members. Guests maybe later.
|
// Who's Online. Currently just members. Guests maybe later.
|
||||||
if ($controlrow["showonline"] == 1) {
|
if ($controlrow["showonline"] == 1) {
|
||||||
$onlinequery = db()->query("SELECT * FROM news WHERE strftime('%s', onlinetime) >= strftime('%s', 'now') - 600 ORDER BY charname");
|
$onlinequery = db()->query("SELECT id, username FROM users WHERE strftime('%s', onlinetime) >= strftime('%s', 'now') - 600 ORDER BY username");
|
||||||
|
|
||||||
$online_count = 0;
|
$online_count = 0;
|
||||||
$online_rows = [];
|
$online_rows = [];
|
||||||
|
|
||||||
foreach ($onlinequery->fetchArray(SQLITE3_ASSOC) as $onlinerow) {
|
while ($onlinerow = $onlinequery->fetchArray(SQLITE3_ASSOC)) {
|
||||||
$online_count++;
|
$online_count++;
|
||||||
$online_rows[] = "<a href=\"index.php?do=onlinechar:".$onlinerow["id"]."\">".$onlinerow["charname"]."</a>" . ", ";
|
$online_rows[] = "<a href=\"index.php?do=onlinechar:".$onlinerow["id"]."\">".$onlinerow["username"]."</a>" . ", ";
|
||||||
}
|
}
|
||||||
|
|
||||||
$townrow["whosonline"] = "<table width=\"95%\"><tr><td class=\"title\">Who's Online</td></tr><tr><td>\n";
|
$townrow["whosonline"] = "<table width=\"95%\"><tr><td class=\"title\">Who's Online</td></tr><tr><td>\n";
|
||||||
$townrow["whosonline"] .= "There are <b>$online_count</b> user(s) online within the last 10 minutes: ";
|
$townrow["whosonline"] .= "There are <b>$online_count</b> user(s) online within the last 10 minutes: ";
|
||||||
$townrow["whosonline"] .= rtrim(implode(', ', $online_rows), ', ');
|
$townrow["whosonline"] .= rtrim(implode(', ', $online_rows), ', ');
|
||||||
$townrow["whosonline"] .= "</td></tr></table>\n";
|
$townrow["whosonline"] .= "</td></tr></table>\n";
|
||||||
} else {
|
}
|
||||||
$townrow["whosonline"] = "";
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($controlrow["showbabble"] == 1) {
|
if ($controlrow["showbabble"] == 1) {
|
||||||
$townrow["babblebox"] = "<table width=\"95%\"><tr><td class=\"title\">Babble Box</td></tr><tr><td>\n";
|
$townrow["babblebox"] = <<<HTML
|
||||||
$townrow["babblebox"] .= "<iframe src=\"index.php?do=babblebox\" name=\"sbox\" width=\"100%\" height=\"250\" frameborder=\"0\" id=\"bbox\">Your browser does not support inline frames! The Babble Box will not be available until you upgrade to a newer <a href=\"http://www.mozilla.org\" target=\"_new\">browser</a>.</iframe>";
|
<table width="95%">
|
||||||
$townrow["babblebox"] .= "</td></tr></table>\n";
|
<tr><td class="title">Babble Box</td></tr>
|
||||||
} else {
|
<tr><td>
|
||||||
$townrow["babblebox"] = "";
|
<iframe src="index.php?do=babblebox" name="sbox" width="100%" height="250" frameborder="0" id="bbox">
|
||||||
}
|
Your browser does not support inline frames! The Babble Box will not be available until you upgrade to a newer <a href="http://www.mozilla.org" target="_new">browser</a>.
|
||||||
|
</iframe>
|
||||||
|
</td></tr>
|
||||||
|
</table>
|
||||||
|
HTML;
|
||||||
|
}
|
||||||
|
|
||||||
$page = gettemplate("towns");
|
return parsetemplate(gettemplate("towns"), $townrow);
|
||||||
$page = parsetemplate($page, $townrow);
|
|
||||||
|
|
||||||
return $page;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -160,154 +156,104 @@ function doexplore()
|
||||||
HTML;
|
HTML;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Redirect to fighting.
|
|
||||||
*/
|
|
||||||
function dofight()
|
|
||||||
{
|
|
||||||
header("Location: index.php?do=fight");
|
|
||||||
}
|
|
||||||
|
|
||||||
function showchar()
|
function showchar()
|
||||||
{
|
{
|
||||||
global $userrow, $controlrow;
|
global $userrow, $controlrow;
|
||||||
|
|
||||||
// Format various userrow stuffs.
|
$userrow["experience"] = number_format($userrow["experience"]);
|
||||||
$userrow["experience"] = number_format($userrow["experience"]);
|
$userrow["gold"] = number_format($userrow["gold"]);
|
||||||
$userrow["gold"] = number_format($userrow["gold"]);
|
|
||||||
if ($userrow["expbonus"] > 0) {
|
|
||||||
$userrow["plusexp"] = "<span class=\"light\">(+".$userrow["expbonus"]."%)</span>";
|
|
||||||
} elseif ($userrow["expbonus"] < 0) {
|
|
||||||
$userrow["plusexp"] = "<span class=\"light\">(".$userrow["expbonus"]."%)</span>";
|
|
||||||
} else { $userrow["plusexp"] = ""; }
|
|
||||||
if ($userrow["goldbonus"] > 0) {
|
|
||||||
$userrow["plusgold"] = "<span class=\"light\">(+".$userrow["goldbonus"]."%)</span>";
|
|
||||||
} elseif ($userrow["goldbonus"] < 0) {
|
|
||||||
$userrow["plusgold"] = "<span class=\"light\">(".$userrow["goldbonus"]."%)</span>";
|
|
||||||
} else { $userrow["plusgold"] = ""; }
|
|
||||||
|
|
||||||
$levelquery = doquery("SELECT ". $userrow["charclass"]."_exp FROM {{table}} WHERE id='".($userrow["level"]+1)."' LIMIT 1", "levels");
|
$userrow["plusexp"] = $userrow["expbonus"] != 0
|
||||||
$levelrow = mysql_fetch_array($levelquery);
|
? "<span class=\"light\">(" . ($userrow["expbonus"] > 0 ? "+" : "") . $userrow["expbonus"] . "%)</span>"
|
||||||
if ($userrow["level"] < 99) { $userrow["nextlevel"] = number_format($levelrow[$userrow["charclass"]."_exp"]); } else { $userrow["nextlevel"] = "<span class=\"light\">None</span>"; }
|
: "";
|
||||||
|
|
||||||
if ($userrow["charclass"] == 1) { $userrow["charclass"] = $controlrow["class1name"]; }
|
$userrow["plusgold"] = $userrow["goldbonus"] != 0
|
||||||
elseif ($userrow["charclass"] == 2) { $userrow["charclass"] = $controlrow["class2name"]; }
|
? "<span class=\"light\">(" . ($userrow["goldbonus"] > 0 ? "+" : "") . $userrow["goldbonus"] . "%)</span>"
|
||||||
elseif ($userrow["charclass"] == 3) { $userrow["charclass"] = $controlrow["class3name"]; }
|
: "";
|
||||||
|
|
||||||
if ($userrow["difficulty"] == 1) { $userrow["difficulty"] = $controlrow["diff1name"]; }
|
$levelrow = db()->query("SELECT `{$userrow["charclass"]}_exp` FROM levels WHERE id=? LIMIT 1;", [$userrow['level'] + 1])->fetchArray(SQLITE3_ASSOC);
|
||||||
elseif ($userrow["difficulty"] == 2) { $userrow["difficulty"] = $controlrow["diff2name"]; }
|
$userrow["nextlevel"] = $userrow['level'] < 99 ? number_format($levelrow[$userrow["charclass"]."_exp"]) : '<span class="light">None</span>';
|
||||||
elseif ($userrow["difficulty"] == 3) { $userrow["difficulty"] = $controlrow["diff3name"]; }
|
|
||||||
|
|
||||||
$spellquery = doquery("SELECT id,name FROM {{table}}","spells");
|
$userrow['charclass'] = match ((int) $userrow['charclass']) {
|
||||||
$userspells = explode(",",$userrow["spells"]);
|
1 => $controlrow["class1name"],
|
||||||
$userrow["magiclist"] = "";
|
2 => $controlrow["class2name"],
|
||||||
while ($spellrow = mysql_fetch_array($spellquery)) {
|
3 => $controlrow["class3name"]
|
||||||
|
};
|
||||||
|
|
||||||
|
$spells = db()->query('SELECT id, name FROM spells;');
|
||||||
|
$userspells = explode(',', $userrow['spells']);
|
||||||
|
$userrow["magiclist"] = '';
|
||||||
|
while ($spellrow = $spells->fetchArray(SQLITE3_ASSOC)) {
|
||||||
$spell = false;
|
$spell = false;
|
||||||
foreach($userspells as $a => $b) {
|
foreach($userspells as $b) if ($b == $spellrow["id"]) $spell = true;
|
||||||
if ($b == $spellrow["id"]) { $spell = true; }
|
if ($spell == true) $userrow["magiclist"] .= $spellrow["name"]."<br />";
|
||||||
}
|
|
||||||
if ($spell == true) {
|
|
||||||
$userrow["magiclist"] .= $spellrow["name"]."<br />";
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if ($userrow["magiclist"] == "") { $userrow["magiclist"] = "None"; }
|
if ($userrow["magiclist"] == "") $userrow["magiclist"] = "None";
|
||||||
|
|
||||||
// Make page tags for XHTML validation.
|
$array = ["content" => parsetemplate(gettemplate("showchar"), $userrow), "title" => "Character Information"];
|
||||||
$xml = "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?>\n"
|
echo parsetemplate("<html>\n" . gettemplate("minimal"), $array);
|
||||||
. "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"DTD/xhtml1-transitional.dtd\">\n"
|
|
||||||
. "<html xmlns=\"http://www.w3.org/1999/xhtml\" xml:lang=\"en\" lang=\"en\">\n";
|
|
||||||
|
|
||||||
$charsheet = gettemplate("showchar");
|
|
||||||
$page = $xml . gettemplate("minimal");
|
|
||||||
$array = array("content"=>parsetemplate($charsheet, $userrow), "title"=>"Character Information");
|
|
||||||
echo parsetemplate($page, $array);
|
|
||||||
die();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function onlinechar($id) {
|
function onlinechar($id)
|
||||||
|
{
|
||||||
global $controlrow;
|
global $controlrow;
|
||||||
$userquery = doquery("SELECT * FROM {{table}} WHERE id='$id' LIMIT 1", "users");
|
|
||||||
if (mysql_num_rows($userquery) == 1) { $userrow = mysql_fetch_array($userquery); } else { display("No such user.", "Error"); }
|
|
||||||
|
|
||||||
// Format various userrow stuffs.
|
$query = db()->query('SELECT * FROM users WHERE id=? LIMIT 1;', [$id]);
|
||||||
|
if ($query !== false) { $userrow = $query->fetchArray(SQLITE3_ASSOC); } else { display("No such user.", "Error"); }
|
||||||
|
unset($userrow['password']);
|
||||||
|
|
||||||
$userrow["experience"] = number_format($userrow["experience"]);
|
$userrow["experience"] = number_format($userrow["experience"]);
|
||||||
$userrow["gold"] = number_format($userrow["gold"]);
|
$userrow["gold"] = number_format($userrow["gold"]);
|
||||||
if ($userrow["expbonus"] > 0) {
|
|
||||||
$userrow["plusexp"] = "<span class=\"light\">(+".$userrow["expbonus"]."%)</span>";
|
|
||||||
} elseif ($userrow["expbonus"] < 0) {
|
|
||||||
$userrow["plusexp"] = "<span class=\"light\">(".$userrow["expbonus"]."%)</span>";
|
|
||||||
} else { $userrow["plusexp"] = ""; }
|
|
||||||
if ($userrow["goldbonus"] > 0) {
|
|
||||||
$userrow["plusgold"] = "<span class=\"light\">(+".$userrow["goldbonus"]."%)</span>";
|
|
||||||
} elseif ($userrow["goldbonus"] < 0) {
|
|
||||||
$userrow["plusgold"] = "<span class=\"light\">(".$userrow["goldbonus"]."%)</span>";
|
|
||||||
} else { $userrow["plusgold"] = ""; }
|
|
||||||
|
|
||||||
$levelquery = doquery("SELECT ". $userrow["charclass"]."_exp FROM {{table}} WHERE id='".($userrow["level"]+1)."' LIMIT 1", "levels");
|
$userrow["plusexp"] = $userrow["expbonus"] != 0
|
||||||
$levelrow = mysql_fetch_array($levelquery);
|
? "<span class=\"light\">(" . ($userrow["expbonus"] > 0 ? "+" : "") . $userrow["expbonus"] . "%)</span>"
|
||||||
$userrow["nextlevel"] = number_format($levelrow[$userrow["charclass"]."_exp"]);
|
: "";
|
||||||
|
|
||||||
if ($userrow["charclass"] == 1) { $userrow["charclass"] = $controlrow["class1name"]; }
|
$userrow["plusgold"] = $userrow["goldbonus"] != 0
|
||||||
elseif ($userrow["charclass"] == 2) { $userrow["charclass"] = $controlrow["class2name"]; }
|
? "<span class=\"light\">(" . ($userrow["goldbonus"] > 0 ? "+" : "") . $userrow["goldbonus"] . "%)</span>"
|
||||||
elseif ($userrow["charclass"] == 3) { $userrow["charclass"] = $controlrow["class3name"]; }
|
: "";
|
||||||
|
|
||||||
if ($userrow["difficulty"] == 1) { $userrow["difficulty"] = $controlrow["diff1name"]; }
|
$levelrow = db()->query("SELECT `{$userrow["charclass"]}_exp` FROM levels WHERE id=? LIMIT 1;", [$userrow['level'] + 1])->fetchArray(SQLITE3_ASSOC);
|
||||||
elseif ($userrow["difficulty"] == 2) { $userrow["difficulty"] = $controlrow["diff2name"]; }
|
$userrow["nextlevel"] = $userrow['level'] < 99 ? number_format($levelrow[$userrow["charclass"]."_exp"]) : '<span class="light">None</span>';
|
||||||
elseif ($userrow["difficulty"] == 3) { $userrow["difficulty"] = $controlrow["diff3name"]; }
|
|
||||||
|
|
||||||
$charsheet = gettemplate("onlinechar");
|
$userrow['charclass'] = match ((int) $userrow['charclass']) {
|
||||||
$page = parsetemplate($charsheet, $userrow);
|
1 => $controlrow["class1name"],
|
||||||
display($page, "Character Information");
|
2 => $controlrow["class2name"],
|
||||||
|
3 => $controlrow["class3name"]
|
||||||
|
};
|
||||||
|
|
||||||
|
display(parsetemplate(gettemplate("onlinechar"), $userrow), "Character Information");
|
||||||
}
|
}
|
||||||
|
|
||||||
function showmap() {
|
function showmap()
|
||||||
|
{
|
||||||
global $userrow;
|
$array = ["content" => "<center><img src=\"images/map.gif\" alt=\"Map\" /></center>", "title" => "Map"];
|
||||||
|
echo parsetemplate("<html>\n" . gettemplate("minimal"), $array);
|
||||||
// Make page tags for XHTML validation.
|
|
||||||
$xml = "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?>\n"
|
|
||||||
. "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"DTD/xhtml1-transitional.dtd\">\n"
|
|
||||||
. "<html xmlns=\"http://www.w3.org/1999/xhtml\" xml:lang=\"en\" lang=\"en\">\n";
|
|
||||||
|
|
||||||
$page = $xml . gettemplate("minimal");
|
|
||||||
$array = array("content"=>"<center><img src=\"images/map.gif\" alt=\"Map\" /></center>", "title"=>"Map");
|
|
||||||
echo parsetemplate($page, $array);
|
|
||||||
die();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function babblebox() {
|
function babblebox()
|
||||||
|
{
|
||||||
global $userrow;
|
global $userrow;
|
||||||
|
|
||||||
if (isset($_POST["babble"])) {
|
if (isset($_POST["babble"])) {
|
||||||
$safecontent = makesafe($_POST["babble"]);
|
$safecontent = makesafe($_POST["babble"]);
|
||||||
if ($safecontent == "" || $safecontent == " ") { //blank post. do nothing.
|
if (!empty($safecontent)) {
|
||||||
} else { $insert = doquery("INSERT INTO {{table}} SET id='',posttime=NOW(),author='".$userrow["charname"]."',babble='$safecontent'", "babble"); }
|
db()->query('INSERT INTO babble (posttime, author, babble) VALUES (CURRENT_TIMESTAMP, ?, ?);', [$userrow['username'], $safecontent]);
|
||||||
header("Location: index.php?do=babblebox");
|
}
|
||||||
die();
|
redirect('index.php?do=babblebox');
|
||||||
}
|
}
|
||||||
|
|
||||||
$babblebox = array("content"=>"");
|
$babblebox = ["content" => ""];
|
||||||
$bg = 1;
|
$bg = 1;
|
||||||
$babblequery = doquery("SELECT * FROM {{table}} ORDER BY id DESC LIMIT 20", "babble");
|
$query = db()->query('SELECT * FROM babble ORDER BY id DESC LIMIT 20;');
|
||||||
while ($babblerow = mysql_fetch_array($babblequery)) {
|
while ($babblerow = $query->fetchArray(SQLITE3_ASSOC)) {
|
||||||
if ($bg == 1) { $new = "<div style=\"width:98%; background-color:#eeeeee;\">[<b>".$babblerow["author"]."</b>] ".$babblerow["babble"]."</div>\n"; $bg = 2; }
|
if ($bg == 1) { $new = "<div style=\"width:98%; background-color:#eeeeee;\">[<b>".$babblerow["author"]."</b>] ".$babblerow["babble"]."</div>\n"; $bg = 2; }
|
||||||
else { $new = "<div style=\"width:98%; background-color:#ffffff;\">[<b>".$babblerow["author"]."</b>] ".stripslashes($babblerow["babble"])."</div>\n"; $bg = 1; }
|
else { $new = "<div style=\"width:98%; background-color:#ffffff;\">[<b>".$babblerow["author"]."</b>] ".stripslashes($babblerow["babble"])."</div>\n"; $bg = 1; }
|
||||||
$babblebox["content"] = $new . $babblebox["content"];
|
$babblebox["content"] = $new . $babblebox["content"];
|
||||||
}
|
}
|
||||||
$babblebox["content"] .= "<center><form action=\"index.php?do=babblebox\" method=\"post\"><input type=\"text\" name=\"babble\" size=\"15\" maxlength=\"120\" /><br /><input type=\"submit\" name=\"submit\" value=\"Babble\" /> <input type=\"reset\" name=\"reset\" value=\"Clear\" /></form></center>";
|
$babblebox["content"] .= "<center><form action=\"index.php?do=babblebox\" method=\"post\"><input type=\"text\" name=\"babble\" size=\"15\" maxlength=\"120\" /><br /><input type=\"submit\" name=\"submit\" value=\"Babble\" /> <input type=\"reset\" name=\"reset\" value=\"Clear\" /></form></center>";
|
||||||
|
|
||||||
// Make page tags for XHTML validation.
|
echo parsetemplate("<html>\n" . gettemplate("babblebox"), $babblebox);
|
||||||
$xml = "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?>\n"
|
|
||||||
. "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"DTD/xhtml1-transitional.dtd\">\n"
|
|
||||||
. "<html xmlns=\"http://www.w3.org/1999/xhtml\" xml:lang=\"en\" lang=\"en\">\n";
|
|
||||||
$page = $xml . gettemplate("babblebox");
|
|
||||||
echo parsetemplate($page, $babblebox);
|
|
||||||
die();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -7,7 +7,8 @@ if (file_exists('../.installed')) {
|
||||||
|
|
||||||
require_once '../src/lib.php';
|
require_once '../src/lib.php';
|
||||||
|
|
||||||
match ((int) $_GET['page'] ?? 1) {
|
$page = $_GET['page'] ?? 1;
|
||||||
|
match ((int) $page) {
|
||||||
2 => second(),
|
2 => second(),
|
||||||
3 => third(),
|
3 => third(),
|
||||||
4 => fourth(),
|
4 => fourth(),
|
||||||
|
@ -42,8 +43,6 @@ function first()
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
HTML;
|
HTML;
|
||||||
|
|
||||||
exit;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -628,7 +627,6 @@ function second()
|
||||||
`authlevel` INTEGER NOT NULL default 0,
|
`authlevel` INTEGER NOT NULL default 0,
|
||||||
`latitude` INTEGER NOT NULL default 0,
|
`latitude` INTEGER NOT NULL default 0,
|
||||||
`longitude` INTEGER NOT NULL default 0,
|
`longitude` INTEGER NOT NULL default 0,
|
||||||
`difficulty` INTEGER NOT NULL default 0,
|
|
||||||
`charclass` INTEGER NOT NULL default 0,
|
`charclass` INTEGER NOT NULL default 0,
|
||||||
`currentaction` TEXT NOT NULL default 'In Town',
|
`currentaction` TEXT NOT NULL default 'In Town',
|
||||||
`currentfight` INTEGER NOT NULL default 0,
|
`currentfight` INTEGER NOT NULL default 0,
|
||||||
|
@ -675,7 +673,6 @@ function second()
|
||||||
|
|
||||||
$time = round((microtime(true) - START), 4);
|
$time = round((microtime(true) - START), 4);
|
||||||
echo "<br />Database setup complete in $time seconds.<br /><br /><a href=\"install.php?page=3\">Click here to continue with installation.</a></body></html>";
|
echo "<br />Database setup complete in $time seconds.<br /><br /><a href=\"install.php?page=3\">Click here to continue with installation.</a></body></html>";
|
||||||
exit;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -699,15 +696,12 @@ function third()
|
||||||
<tr><td style="vertical-align:top;">Email Address:</td><td><input type="text" name="email1" size="30" maxlength="100" /></td></tr>
|
<tr><td style="vertical-align:top;">Email Address:</td><td><input type="text" name="email1" size="30" maxlength="100" /></td></tr>
|
||||||
<tr><td style="vertical-align:top;">Verify Email:</td><td><input type="text" name="email2" size="30" maxlength="100" /><br /><br /><br /></td></tr>
|
<tr><td style="vertical-align:top;">Verify Email:</td><td><input type="text" name="email2" size="30" maxlength="100" /><br /><br /><br /></td></tr>
|
||||||
<tr><td style="vertical-align:top;">Character Class:</td><td><select name="charclass"><option value="1">Mage</option><option value="2">Warrior</option><option value="3">Paladin</option></select></td></tr>
|
<tr><td style="vertical-align:top;">Character Class:</td><td><select name="charclass"><option value="1">Mage</option><option value="2">Warrior</option><option value="3">Paladin</option></select></td></tr>
|
||||||
<tr><td style="vertical-align:top;">Difficulty:</td><td><select name="difficulty"><option value="1">Easy</option><option value="2">Medium</option><option value="3">Hard</option></select></td></tr>
|
|
||||||
<tr><td colspan="2"><input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" /></td></tr>
|
<tr><td colspan="2"><input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" /></td></tr>
|
||||||
</table>
|
</table>
|
||||||
</form>
|
</form>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
HTML;
|
HTML;
|
||||||
|
|
||||||
exit;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -780,8 +774,6 @@ function fourth()
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
HTML;
|
HTML;
|
||||||
|
|
||||||
exit;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -790,7 +782,7 @@ function fourth()
|
||||||
function fifth()
|
function fifth()
|
||||||
{
|
{
|
||||||
if (mail("sky@sharkk.net", "Dragon Knight Call Home", $_SERVER["SERVER_NAME"].$_SERVER["PHP_SELF"]) !== true) {
|
if (mail("sky@sharkk.net", "Dragon Knight Call Home", $_SERVER["SERVER_NAME"].$_SERVER["PHP_SELF"]) !== true) {
|
||||||
die('Dragon Knight was unable to send your URL. Please go back and try again, or just continue on to <a href=\"index.php\">the game</a>.');
|
exit('Dragon Knight was unable to send your URL. Please go back and try again, or just continue on to <a href=\"index.php\">the game</a>.');
|
||||||
}
|
}
|
||||||
|
|
||||||
echo <<<HTML
|
echo <<<HTML
|
||||||
|
@ -805,6 +797,4 @@ function fifth()
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
HTML;
|
HTML;
|
||||||
|
|
||||||
exit;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ function login()
|
||||||
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
|
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
|
||||||
$u = trim($_POST['username'] ?? '');
|
$u = trim($_POST['username'] ?? '');
|
||||||
|
|
||||||
$query = db()->query('SELECT * FROM users WHERE username = ? LIMIT 1;', [$u]);
|
$query = db()->query('SELECT id, username, password FROM users WHERE username = ? LIMIT 1;', [$u]);
|
||||||
if ($query === false) die("Invalid username or password. Please go back and try again.");
|
if ($query === false) die("Invalid username or password. Please go back and try again.");
|
||||||
$row = $query->fetchArray(SQLITE3_ASSOC);
|
$row = $query->fetchArray(SQLITE3_ASSOC);
|
||||||
if (!password_verify($_POST['password'] ?? '', $row['password'])) die("Invalid username or password. Please go back and try again.");
|
if (!password_verify($_POST['password'] ?? '', $row['password'])) die("Invalid username or password. Please go back and try again.");
|
||||||
|
|
|
@ -4,53 +4,47 @@ include('lib.php');
|
||||||
$link = opendb();
|
$link = opendb();
|
||||||
|
|
||||||
if (isset($_GET["do"])) {
|
if (isset($_GET["do"])) {
|
||||||
|
|
||||||
$do = $_GET["do"];
|
$do = $_GET["do"];
|
||||||
if ($do == "register") { register(); }
|
if ($do == "register") { register(); }
|
||||||
elseif ($do == "verify") { verify(); }
|
elseif ($do == "verify") { verify(); }
|
||||||
elseif ($do == "lostpassword") { lostpassword(); }
|
elseif ($do == "lostpassword") { lostpassword(); }
|
||||||
elseif ($do == "changepassword") { changepassword(); }
|
elseif ($do == "changepassword") { changepassword(); }
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function register() { // Register a new account.
|
function register() { // Register a new account.
|
||||||
|
|
||||||
$controlquery = doquery("SELECT * FROM {{table}} WHERE id='1' LIMIT 1", "control");
|
$controlquery = doquery("SELECT * FROM {{table}} WHERE id='1' LIMIT 1", "control");
|
||||||
$controlrow = mysql_fetch_array($controlquery);
|
$controlrow = mysql_fetch_array($controlquery);
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
|
|
||||||
$errors = 0; $errorlist = "";
|
$errors = 0; $errorlist = "";
|
||||||
|
|
||||||
// Process username.
|
// Process username.
|
||||||
if ($username == "") { $errors++; $errorlist .= "Username field is required.<br />"; }
|
if ($username == "") { $errors++; $errorlist .= "Username field is required.<br />"; }
|
||||||
if (preg_match("/[^A-z0-9_\-]/", $username)==1) { $errors++; $errorlist .= "Username must be alphanumeric.<br />"; } // Thanks to "Carlos Pires" from php.net!
|
if (preg_match("/[^A-z0-9_\-]/", $username)==1) { $errors++; $errorlist .= "Username must be alphanumeric.<br />"; } // Thanks to "Carlos Pires" from php.net!
|
||||||
$usernamequery = doquery("SELECT username FROM {{table}} WHERE username='$username' LIMIT 1","users");
|
$usernamequery = doquery("SELECT username FROM {{table}} WHERE username='$username' LIMIT 1","users");
|
||||||
if (mysql_num_rows($usernamequery) > 0) { $errors++; $errorlist .= "Username already taken - unique username required.<br />"; }
|
if (mysql_num_rows($usernamequery) > 0) { $errors++; $errorlist .= "Username already taken - unique username required.<br />"; }
|
||||||
|
|
||||||
// Process charname.
|
|
||||||
if ($charname == "") { $errors++; $errorlist .= "Character Name field is required.<br />"; }
|
|
||||||
if (preg_match("/[^A-z0-9_\-]/", $charname)==1) { $errors++; $errorlist .= "Character Name must be alphanumeric.<br />"; } // Thanks to "Carlos Pires" from php.net!
|
|
||||||
$characternamequery = doquery("SELECT charname FROM {{table}} WHERE charname='$charname' LIMIT 1","users");
|
|
||||||
if (mysql_num_rows($characternamequery) > 0) { $errors++; $errorlist .= "Character Name already taken - unique Character Name required.<br />"; }
|
|
||||||
|
|
||||||
// Process email address.
|
// Process email address.
|
||||||
if ($email1 == "" || $email2 == "") { $errors++; $errorlist .= "Email fields are required.<br />"; }
|
if ($email1 == "" || $email2 == "") { $errors++; $errorlist .= "Email fields are required.<br />"; }
|
||||||
if ($email1 != $email2) { $errors++; $errorlist .= "Emails don't match.<br />"; }
|
if ($email1 != $email2) { $errors++; $errorlist .= "Emails don't match.<br />"; }
|
||||||
if (! is_email($email1)) { $errors++; $errorlist .= "Email isn't valid.<br />"; }
|
if (! is_email($email1)) { $errors++; $errorlist .= "Email isn't valid.<br />"; }
|
||||||
$emailquery = doquery("SELECT email FROM {{table}} WHERE email='$email1' LIMIT 1","users");
|
$emailquery = doquery("SELECT email FROM {{table}} WHERE email='$email1' LIMIT 1","users");
|
||||||
if (mysql_num_rows($emailquery) > 0) { $errors++; $errorlist .= "Email already taken - unique email address required.<br />"; }
|
if (mysql_num_rows($emailquery) > 0) { $errors++; $errorlist .= "Email already taken - unique email address required.<br />"; }
|
||||||
|
|
||||||
// Process password.
|
// Process password.
|
||||||
if (trim($password1) == "") { $errors++; $errorlist .= "Password field is required.<br />"; }
|
if (trim($password1) == "") { $errors++; $errorlist .= "Password field is required.<br />"; }
|
||||||
if (preg_match("/[^A-z0-9_\-]/", $password1)==1) { $errors++; $errorlist .= "Password must be alphanumeric.<br />"; } // Thanks to "Carlos Pires" from php.net!
|
if (preg_match("/[^A-z0-9_\-]/", $password1)==1) { $errors++; $errorlist .= "Password must be alphanumeric.<br />"; } // Thanks to "Carlos Pires" from php.net!
|
||||||
if ($password1 != $password2) { $errors++; $errorlist .= "Passwords don't match.<br />"; }
|
if ($password1 != $password2) { $errors++; $errorlist .= "Passwords don't match.<br />"; }
|
||||||
$password = md5($password1);
|
$password = md5($password1);
|
||||||
|
|
||||||
if ($errors == 0) {
|
if ($errors == 0) {
|
||||||
|
|
||||||
if ($controlrow["verifyemail"] == 1) {
|
if ($controlrow["verifyemail"] == 1) {
|
||||||
$verifycode = "";
|
$verifycode = "";
|
||||||
for ($i=0; $i<8; $i++) {
|
for ($i=0; $i<8; $i++) {
|
||||||
|
@ -59,9 +53,9 @@ function register() { // Register a new account.
|
||||||
} else {
|
} else {
|
||||||
$verifycode='1';
|
$verifycode='1';
|
||||||
}
|
}
|
||||||
|
|
||||||
$query = doquery("INSERT INTO {{table}} SET id='',regdate=NOW(),verify='$verifycode',username='$username',password='$password',email='$email1',charname='$charname',charclass='$charclass',difficulty='$difficulty'", "users") or die(mysql_error());
|
$query = doquery("INSERT INTO {{table}} SET id='',regdate=NOW(),verify='$verifycode',username='$username',password='$password',email='$email1',charclass='$charclass'", "users") or die(mysql_error());
|
||||||
|
|
||||||
if ($controlrow["verifyemail"] == 1) {
|
if ($controlrow["verifyemail"] == 1) {
|
||||||
if (sendregmail($email1, $verifycode) == true) {
|
if (sendregmail($email1, $verifycode) == true) {
|
||||||
$page = "Your account was created successfully.<br /><br />You should receive an Account Verification email shortly. You will need the verification code contained in that email before you are allowed to log in. Once you have received the email, please visit the <a href=\"users.php?do=verify\">Verification Page</a> to enter your code and start playing.";
|
$page = "Your account was created successfully.<br /><br />You should receive an Account Verification email shortly. You will need the verification code contained in that email before you are allowed to log in. Once you have received the email, please visit the <a href=\"users.php?do=verify\">Verification Page</a> to enter your code and start playing.";
|
||||||
|
@ -71,32 +65,32 @@ function register() { // Register a new account.
|
||||||
} else {
|
} else {
|
||||||
$page = "Your account was created succesfully.<br /><br />You may now continue to the <a href=\"login.php?do=login\">Login Page</a> and continue playing ".$controlrow["gamename"]."!";
|
$page = "Your account was created succesfully.<br /><br />You may now continue to the <a href=\"login.php?do=login\">Login Page</a> and continue playing ".$controlrow["gamename"]."!";
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$page = "The following error(s) occurred when your account was being made:<br /><span style=\"color:red;\">$errorlist</span><br />Please go back and try again.";
|
$page = "The following error(s) occurred when your account was being made:<br /><span style=\"color:red;\">$errorlist</span><br />Please go back and try again.";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$page = gettemplate("register");
|
$page = gettemplate("register");
|
||||||
if ($controlrow["verifyemail"] == 1) {
|
if ($controlrow["verifyemail"] == 1) {
|
||||||
$controlrow["verifytext"] = "<br /><span class=\"small\">A verification code will be sent to the address above, and you will not be able to log in without first entering the code. Please be sure to enter your correct email address.</span>";
|
$controlrow["verifytext"] = "<br /><span class=\"small\">A verification code will be sent to the address above, and you will not be able to log in without first entering the code. Please be sure to enter your correct email address.</span>";
|
||||||
} else {
|
} else {
|
||||||
$controlrow["verifytext"] = "";
|
$controlrow["verifytext"] = "";
|
||||||
}
|
}
|
||||||
$page = parsetemplate($page, $controlrow);
|
$page = parsetemplate($page, $controlrow);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$topnav = "<a href=\"login.php?do=login\"><img src=\"images/button_login.gif\" alt=\"Log In\" border=\"0\" /></a><a href=\"users.php?do=register\"><img src=\"images/button_register.gif\" alt=\"Register\" border=\"0\" /></a><a href=\"help.php\"><img src=\"images/button_help.gif\" alt=\"Help\" border=\"0\" /></a>";
|
$topnav = "<a href=\"login.php?do=login\"><img src=\"images/button_login.gif\" alt=\"Log In\" border=\"0\" /></a><a href=\"users.php?do=register\"><img src=\"images/button_register.gif\" alt=\"Register\" border=\"0\" /></a><a href=\"help.php\"><img src=\"images/button_help.gif\" alt=\"Help\" border=\"0\" /></a>";
|
||||||
display($page, "Register", false, false, false);
|
display($page, "Register", false, false, false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function verify() {
|
function verify() {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$userquery = doquery("SELECT username,email,verify FROM {{table}} WHERE username='$username' LIMIT 1","users");
|
$userquery = doquery("SELECT username,email,verify FROM {{table}} WHERE username='$username' LIMIT 1","users");
|
||||||
|
@ -112,11 +106,11 @@ function verify() {
|
||||||
$page = gettemplate("verify");
|
$page = gettemplate("verify");
|
||||||
$topnav = "<a href=\"login.php?do=login\"><img src=\"images/button_login.gif\" alt=\"Log In\" border=\"0\" /></a><a href=\"users.php?do=register\"><img src=\"images/button_register.gif\" alt=\"Register\" border=\"0\" /></a><a href=\"help.php\"><img src=\"images/button_help.gif\" alt=\"Help\" border=\"0\" /></a>";
|
$topnav = "<a href=\"login.php?do=login\"><img src=\"images/button_login.gif\" alt=\"Log In\" border=\"0\" /></a><a href=\"users.php?do=register\"><img src=\"images/button_register.gif\" alt=\"Register\" border=\"0\" /></a><a href=\"help.php\"><img src=\"images/button_help.gif\" alt=\"Help\" border=\"0\" /></a>";
|
||||||
display($page, "Verify Email", false, false, false);
|
display($page, "Verify Email", false, false, false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function lostpassword() {
|
function lostpassword() {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$userquery = doquery("SELECT email FROM {{table}} WHERE email='$email' LIMIT 1","users");
|
$userquery = doquery("SELECT email FROM {{table}} WHERE email='$email' LIMIT 1","users");
|
||||||
|
@ -137,11 +131,11 @@ function lostpassword() {
|
||||||
$page = gettemplate("lostpassword");
|
$page = gettemplate("lostpassword");
|
||||||
$topnav = "<a href=\"login.php?do=login\"><img src=\"images/button_login.gif\" alt=\"Log In\" border=\"0\" /></a><a href=\"users.php?do=register\"><img src=\"images/button_register.gif\" alt=\"Register\" border=\"0\" /></a><a href=\"help.php\"><img src=\"images/button_help.gif\" alt=\"Help\" border=\"0\" /></a>";
|
$topnav = "<a href=\"login.php?do=login\"><img src=\"images/button_login.gif\" alt=\"Log In\" border=\"0\" /></a><a href=\"users.php?do=register\"><img src=\"images/button_register.gif\" alt=\"Register\" border=\"0\" /></a><a href=\"help.php\"><img src=\"images/button_help.gif\" alt=\"Help\" border=\"0\" /></a>";
|
||||||
display($page, "Lost Password", false, false, false);
|
display($page, "Lost Password", false, false, false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function changepassword() {
|
function changepassword() {
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
extract($_POST);
|
extract($_POST);
|
||||||
$userquery = doquery("SELECT * FROM {{table}} WHERE username='$username' LIMIT 1","users");
|
$userquery = doquery("SELECT * FROM {{table}} WHERE username='$username' LIMIT 1","users");
|
||||||
|
@ -158,18 +152,18 @@ function changepassword() {
|
||||||
}
|
}
|
||||||
$page = gettemplate("changepassword");
|
$page = gettemplate("changepassword");
|
||||||
$topnav = "<a href=\"login.php?do=login\"><img src=\"images/button_login.gif\" alt=\"Log In\" border=\"0\" /></a><a href=\"users.php?do=register\"><img src=\"images/button_register.gif\" alt=\"Register\" border=\"0\" /></a><a href=\"help.php\"><img src=\"images/button_help.gif\" alt=\"Help\" border=\"0\" /></a>";
|
$topnav = "<a href=\"login.php?do=login\"><img src=\"images/button_login.gif\" alt=\"Log In\" border=\"0\" /></a><a href=\"users.php?do=register\"><img src=\"images/button_register.gif\" alt=\"Register\" border=\"0\" /></a><a href=\"help.php\"><img src=\"images/button_help.gif\" alt=\"Help\" border=\"0\" /></a>";
|
||||||
display($page, "Change Password", false, false, false);
|
display($page, "Change Password", false, false, false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function sendpassemail($emailaddress, $password) {
|
function sendpassemail($emailaddress, $password) {
|
||||||
|
|
||||||
$controlquery = doquery("SELECT * FROM {{table}} WHERE id='1' LIMIT 1", "control");
|
$controlquery = doquery("SELECT * FROM {{table}} WHERE id='1' LIMIT 1", "control");
|
||||||
$controlrow = mysql_fetch_array($controlquery);
|
$controlrow = mysql_fetch_array($controlquery);
|
||||||
extract($controlrow);
|
extract($controlrow);
|
||||||
|
|
||||||
$email = <<<END
|
$email = <<<END
|
||||||
You or someone using your email address submitted a Lost Password application on the $gamename server, located at $gameurl.
|
You or someone using your email address submitted a Lost Password application on the $gamename server, located at $gameurl.
|
||||||
|
|
||||||
We have issued you a new password so you can log back into the game.
|
We have issued you a new password so you can log back into the game.
|
||||||
|
|
||||||
|
@ -180,20 +174,20 @@ END;
|
||||||
|
|
||||||
$status = mymail($emailaddress, "$gamename Lost Password", $email);
|
$status = mymail($emailaddress, "$gamename Lost Password", $email);
|
||||||
return $status;
|
return $status;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function sendregmail($emailaddress, $vercode) {
|
function sendregmail($emailaddress, $vercode) {
|
||||||
|
|
||||||
$controlquery = doquery("SELECT * FROM {{table}} WHERE id='1' LIMIT 1", "control");
|
$controlquery = doquery("SELECT * FROM {{table}} WHERE id='1' LIMIT 1", "control");
|
||||||
$controlrow = mysql_fetch_array($controlquery);
|
$controlrow = mysql_fetch_array($controlquery);
|
||||||
extract($controlrow);
|
extract($controlrow);
|
||||||
$verurl = $gameurl . "?do=verify";
|
$verurl = $gameurl . "?do=verify";
|
||||||
|
|
||||||
$email = <<<END
|
$email = <<<END
|
||||||
You or someone using your email address recently signed up for an account on the $gamename server, located at $gameurl.
|
You or someone using your email address recently signed up for an account on the $gamename server, located at $gameurl.
|
||||||
|
|
||||||
This email is sent to verify your registration email. In order to begin using your account, you must verify your email address.
|
This email is sent to verify your registration email. In order to begin using your account, you must verify your email address.
|
||||||
Please visit the Verification Page ($verurl) and enter the code below to activate your account.
|
Please visit the Verification Page ($verurl) and enter the code below to activate your account.
|
||||||
Verification code: $vercode
|
Verification code: $vercode
|
||||||
|
|
||||||
|
@ -202,7 +196,7 @@ END;
|
||||||
|
|
||||||
$status = mymail($emailaddress, "$gamename Account Verification", $email);
|
$status = mymail($emailaddress, "$gamename Account Verification", $email);
|
||||||
return $status;
|
return $status;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function mymail($to, $title, $body, $from = '') { // thanks to arto dot PLEASE dot DO dot NOT dot SPAM at artoaaltonen dot fi.
|
function mymail($to, $title, $body, $from = '') { // thanks to arto dot PLEASE dot DO dot NOT dot SPAM at artoaaltonen dot fi.
|
||||||
|
@ -210,7 +204,7 @@ function mymail($to, $title, $body, $from = '') { // thanks to arto dot PLEASE d
|
||||||
$controlquery = doquery("SELECT * FROM {{table}} WHERE id='1' LIMIT 1", "control");
|
$controlquery = doquery("SELECT * FROM {{table}} WHERE id='1' LIMIT 1", "control");
|
||||||
$controlrow = mysql_fetch_array($controlquery);
|
$controlrow = mysql_fetch_array($controlquery);
|
||||||
extract($controlrow);
|
extract($controlrow);
|
||||||
|
|
||||||
|
|
||||||
$from = trim($from);
|
$from = trim($from);
|
||||||
|
|
||||||
|
@ -238,8 +232,8 @@ function mymail($to, $title, $body, $from = '') { // thanks to arto dot PLEASE d
|
||||||
$body = str_replace("\n", "\r\n", $body);
|
$body = str_replace("\n", "\r\n", $body);
|
||||||
|
|
||||||
return mail($to, $title, $body, $head);
|
return mail($to, $title, $body, $head);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
|
|
@ -22,7 +22,6 @@ class Database extends SQLite3
|
||||||
{
|
{
|
||||||
$p = strpos($query, '?') !== false;
|
$p = strpos($query, '?') !== false;
|
||||||
$stmt = $this->prepare($query);
|
$stmt = $this->prepare($query);
|
||||||
|
|
||||||
foreach ($params ?? [] as $k => $v) $stmt->bindValue($p ? $k + 1 : $k, $v, $this->getSQLiteType($v));
|
foreach ($params ?? [] as $k => $v) $stmt->bindValue($p ? $k + 1 : $k, $v, $this->getSQLiteType($v));
|
||||||
|
|
||||||
$start = microtime(true);
|
$start = microtime(true);
|
||||||
|
|
|
@ -1,37 +1,31 @@
|
||||||
<?php // explore.php :: Handles all map exploring, chances to fight, etc.
|
<?php
|
||||||
|
|
||||||
function move() {
|
// explore.php :: Handles all map exploring, chances to fight, etc.
|
||||||
|
|
||||||
|
function move()
|
||||||
|
{
|
||||||
global $userrow, $controlrow;
|
global $userrow, $controlrow;
|
||||||
|
|
||||||
if ($userrow["currentaction"] == "Fighting") { header("Location: index.php?do=fight"); die(); }
|
if ($userrow["currentaction"] == "Fighting") { header("Location: index.php?do=fight"); die(); }
|
||||||
|
|
||||||
$latitude = $userrow["latitude"];
|
$latitude = $userrow["latitude"];
|
||||||
$longitude = $userrow["longitude"];
|
$longitude = $userrow["longitude"];
|
||||||
if (isset($_POST["north"])) { $latitude++; if ($latitude > $controlrow["gamesize"]) { $latitude = $controlrow["gamesize"]; } }
|
if (isset($_POST["north"])) { $latitude++; if ($latitude > $controlrow["gamesize"]) { $latitude = $controlrow["gamesize"]; } }
|
||||||
if (isset($_POST["south"])) { $latitude--; if ($latitude < ($controlrow["gamesize"]*-1)) { $latitude = ($controlrow["gamesize"]*-1); } }
|
if (isset($_POST["south"])) { $latitude--; if ($latitude < ($controlrow["gamesize"]*-1)) { $latitude = ($controlrow["gamesize"]*-1); } }
|
||||||
if (isset($_POST["east"])) { $longitude++; if ($longitude > $controlrow["gamesize"]) { $longitude = $controlrow["gamesize"]; } }
|
if (isset($_POST["east"])) { $longitude++; if ($longitude > $controlrow["gamesize"]) { $longitude = $controlrow["gamesize"]; } }
|
||||||
if (isset($_POST["west"])) { $longitude--; if ($longitude < ($controlrow["gamesize"]*-1)) { $longitude = ($controlrow["gamesize"]*-1); } }
|
if (isset($_POST["west"])) { $longitude--; if ($longitude < ($controlrow["gamesize"]*-1)) { $longitude = ($controlrow["gamesize"]*-1); } }
|
||||||
|
|
||||||
$townquery = doquery("SELECT id FROM {{table}} WHERE latitude='$latitude' AND longitude='$longitude' LIMIT 1", "towns");
|
$townquery = db()->query('SELECT id FROM towns WHERE latitude = ? AND longitude = ? LIMIT 1;', [$latitude, $longitude]);
|
||||||
if (mysql_num_rows($townquery) > 0) {
|
if ($townquery !== false) {
|
||||||
$townrow = mysql_fetch_array($townquery);
|
$townrow = $townquery->fetchArray(SQLITE3_ASSOC);
|
||||||
include('towns.php');
|
require_once __DIR__ . '/towns.php';
|
||||||
travelto($townrow["id"], false);
|
travelto($townrow["id"], false);
|
||||||
die();
|
exit;
|
||||||
}
|
|
||||||
|
|
||||||
$chancetofight = rand(1,5);
|
|
||||||
if ($chancetofight == 1) {
|
|
||||||
$action = "currentaction='Fighting', currentfight='1',";
|
|
||||||
} else {
|
|
||||||
$action = "currentaction='Exploring',";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$chancetofight = rand(1, 5);
|
||||||
$updatequery = doquery("UPDATE {{table}} SET $action latitude='$latitude', longitude='$longitude', dropcode='0' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
$action = $chancetofight === 1 ? "currentaction='Fighting', currentfight='1'," : "currentaction='Exploring',";
|
||||||
|
|
||||||
|
db()->query("UPDATE users SET $action latitude = ?, longitude = ?, dropcode = 0 WHERE id = ?;", [$latitude, $longitude, $userrow['id']]);
|
||||||
header("Location: index.php");
|
header("Location: index.php");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
|
168
src/fight.php
168
src/fight.php
|
@ -1,12 +1,12 @@
|
||||||
<?php // fight.php :: Handles all fighting action.
|
<?php // fight.php :: Handles all fighting action.
|
||||||
|
|
||||||
function fight() { // One big long function that determines the outcome of the fight.
|
function fight() { // One big long function that determines the outcome of the fight.
|
||||||
|
|
||||||
global $userrow, $controlrow;
|
global $userrow, $controlrow;
|
||||||
if ($userrow["currentaction"] != "Fighting") { display("Cheat attempt detected.<br /><br />Get a life, loser.", "Error"); }
|
if ($userrow["currentaction"] != "Fighting") { display("Cheat attempt detected.<br /><br />Get a life, loser.", "Error"); }
|
||||||
$pagearray = array();
|
$pagearray = array();
|
||||||
$playerisdead = 0;
|
$playerisdead = 0;
|
||||||
|
|
||||||
$pagearray["magiclist"] = "";
|
$pagearray["magiclist"] = "";
|
||||||
$userspells = explode(",",$userrow["spells"]);
|
$userspells = explode(",",$userrow["spells"]);
|
||||||
$spellquery = doquery("SELECT id,name FROM {{table}}", "spells");
|
$spellquery = doquery("SELECT id,name FROM {{table}}", "spells");
|
||||||
|
@ -22,50 +22,48 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
}
|
}
|
||||||
if ($pagearray["magiclist"] == "") { $pagearray["magiclist"] = "<option value=\"0\">None</option>\n"; }
|
if ($pagearray["magiclist"] == "") { $pagearray["magiclist"] = "<option value=\"0\">None</option>\n"; }
|
||||||
$magiclist = $pagearray["magiclist"];
|
$magiclist = $pagearray["magiclist"];
|
||||||
|
|
||||||
$chancetoswingfirst = 1;
|
$chancetoswingfirst = 1;
|
||||||
|
|
||||||
// First, check to see if we need to pick a monster.
|
// First, check to see if we need to pick a monster.
|
||||||
if ($userrow["currentfight"] == 1) {
|
if ($userrow["currentfight"] == 1) {
|
||||||
|
|
||||||
if ($userrow["latitude"] < 0) { $userrow["latitude"] *= -1; } // Equalize negatives.
|
if ($userrow["latitude"] < 0) { $userrow["latitude"] *= -1; } // Equalize negatives.
|
||||||
if ($userrow["longitude"] < 0) { $userrow["longitude"] *= -1; } // Ditto.
|
if ($userrow["longitude"] < 0) { $userrow["longitude"] *= -1; } // Ditto.
|
||||||
$maxlevel = floor(max($userrow["latitude"]+5, $userrow["longitude"]+5) / 5); // One mlevel per five spaces.
|
$maxlevel = floor(max($userrow["latitude"]+5, $userrow["longitude"]+5) / 5); // One mlevel per five spaces.
|
||||||
if ($maxlevel < 1) { $maxlevel = 1; }
|
if ($maxlevel < 1) { $maxlevel = 1; }
|
||||||
$minlevel = $maxlevel - 2;
|
$minlevel = $maxlevel - 2;
|
||||||
if ($minlevel < 1) { $minlevel = 1; }
|
if ($minlevel < 1) { $minlevel = 1; }
|
||||||
|
|
||||||
|
|
||||||
// Pick a monster.
|
// Pick a monster.
|
||||||
$monsterquery = doquery("SELECT * FROM {{table}} WHERE level>='$minlevel' AND level<='$maxlevel' ORDER BY RAND() LIMIT 1", "monsters");
|
$monsterquery = doquery("SELECT * FROM {{table}} WHERE level>='$minlevel' AND level<='$maxlevel' ORDER BY RAND() LIMIT 1", "monsters");
|
||||||
$monsterrow = mysql_fetch_array($monsterquery);
|
$monsterrow = mysql_fetch_array($monsterquery);
|
||||||
$userrow["currentmonster"] = $monsterrow["id"];
|
$userrow["currentmonster"] = $monsterrow["id"];
|
||||||
$userrow["currentmonsterhp"] = rand((($monsterrow["maxhp"]/5)*4),$monsterrow["maxhp"]);
|
$userrow["currentmonsterhp"] = rand((($monsterrow["maxhp"]/5)*4),$monsterrow["maxhp"]);
|
||||||
if ($userrow["difficulty"] == 2) { $userrow["currentmonsterhp"] = ceil($userrow["currentmonsterhp"] * $controlrow["diff2mod"]); }
|
|
||||||
if ($userrow["difficulty"] == 3) { $userrow["currentmonsterhp"] = ceil($userrow["currentmonsterhp"] * $controlrow["diff3mod"]); }
|
|
||||||
$userrow["currentmonstersleep"] = 0;
|
$userrow["currentmonstersleep"] = 0;
|
||||||
$userrow["currentmonsterimmune"] = $monsterrow["immune"];
|
$userrow["currentmonsterimmune"] = $monsterrow["immune"];
|
||||||
|
|
||||||
$chancetoswingfirst = rand(1,10) + ceil(sqrt($userrow["dexterity"]));
|
$chancetoswingfirst = rand(1,10) + ceil(sqrt($userrow["dexterity"]));
|
||||||
if ($chancetoswingfirst > (rand(1,7) + ceil(sqrt($monsterrow["maxdam"])))) { $chancetoswingfirst = 1; } else { $chancetoswingfirst = 0; }
|
if ($chancetoswingfirst > (rand(1,7) + ceil(sqrt($monsterrow["maxdam"])))) { $chancetoswingfirst = 1; } else { $chancetoswingfirst = 0; }
|
||||||
|
|
||||||
unset($monsterquery);
|
unset($monsterquery);
|
||||||
unset($monsterrow);
|
unset($monsterrow);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Next, get the monster statistics.
|
// Next, get the monster statistics.
|
||||||
$monsterquery = doquery("SELECT * FROM {{table}} WHERE id='".$userrow["currentmonster"]."' LIMIT 1", "monsters");
|
$monsterquery = doquery("SELECT * FROM {{table}} WHERE id='".$userrow["currentmonster"]."' LIMIT 1", "monsters");
|
||||||
$monsterrow = mysql_fetch_array($monsterquery);
|
$monsterrow = mysql_fetch_array($monsterquery);
|
||||||
$pagearray["monstername"] = $monsterrow["name"];
|
$pagearray["monstername"] = $monsterrow["name"];
|
||||||
|
|
||||||
// Do run stuff.
|
// Do run stuff.
|
||||||
if (isset($_POST["run"])) {
|
if (isset($_POST["run"])) {
|
||||||
|
|
||||||
$chancetorun = rand(4,10) + ceil(sqrt($userrow["dexterity"]));
|
$chancetorun = rand(4,10) + ceil(sqrt($userrow["dexterity"]));
|
||||||
if ($chancetorun > (rand(1,5) + ceil(sqrt($monsterrow["maxdam"])))) { $chancetorun = 1; } else { $chancetorun = 0; }
|
if ($chancetorun > (rand(1,5) + ceil(sqrt($monsterrow["maxdam"])))) { $chancetorun = 1; } else { $chancetorun = 0; }
|
||||||
|
|
||||||
if ($chancetorun == 0) {
|
if ($chancetorun == 0) {
|
||||||
$pagearray["yourturn"] = "You tried to run away, but were blocked in front!<br /><br />";
|
$pagearray["yourturn"] = "You tried to run away, but were blocked in front!<br /><br />";
|
||||||
$pagearray["monsterhp"] = "Monster's HP: " . $userrow["currentmonsterhp"] . "<br /><br />";
|
$pagearray["monsterhp"] = "Monster's HP: " . $userrow["currentmonsterhp"] . "<br /><br />";
|
||||||
$pagearray["monsterturn"] = "";
|
$pagearray["monsterturn"] = "";
|
||||||
|
@ -80,8 +78,6 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
}
|
}
|
||||||
if ($userrow["currentmonstersleep"] == 0) { // Only do this if the monster is awake.
|
if ($userrow["currentmonstersleep"] == 0) { // Only do this if the monster is awake.
|
||||||
$tohit = ceil(rand($monsterrow["maxdam"]*.5,$monsterrow["maxdam"]));
|
$tohit = ceil(rand($monsterrow["maxdam"]*.5,$monsterrow["maxdam"]));
|
||||||
if ($userrow["difficulty"] == 2) { $tohit = ceil($tohit * $controlrow["diff2mod"]); }
|
|
||||||
if ($userrow["difficulty"] == 3) { $tohit = ceil($tohit * $controlrow["diff3mod"]); }
|
|
||||||
$toblock = ceil(rand($userrow["defensepower"]*.75,$userrow["defensepower"])/4);
|
$toblock = ceil(rand($userrow["defensepower"]*.75,$userrow["defensepower"])/4);
|
||||||
$tododge = rand(1,150);
|
$tododge = rand(1,150);
|
||||||
if ($tododge <= sqrt($userrow["dexterity"])) {
|
if ($tododge <= sqrt($userrow["dexterity"])) {
|
||||||
|
@ -109,19 +105,19 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
$updatequery = doquery("UPDATE {{table}} SET currentaction='Exploring' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
$updatequery = doquery("UPDATE {{table}} SET currentaction='Exploring' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
||||||
header("Location: index.php");
|
header("Location: index.php");
|
||||||
die();
|
die();
|
||||||
|
|
||||||
// Do fight stuff.
|
// Do fight stuff.
|
||||||
} elseif (isset($_POST["fight"])) {
|
} elseif (isset($_POST["fight"])) {
|
||||||
|
|
||||||
// Your turn.
|
// Your turn.
|
||||||
$pagearray["yourturn"] = "";
|
$pagearray["yourturn"] = "";
|
||||||
$tohit = ceil(rand($userrow["attackpower"]*.75,$userrow["attackpower"])/3);
|
$tohit = ceil(rand($userrow["attackpower"]*.75,$userrow["attackpower"])/3);
|
||||||
$toexcellent = rand(1,150);
|
$toexcellent = rand(1,150);
|
||||||
if ($toexcellent <= sqrt($userrow["strength"])) { $tohit *= 2; $pagearray["yourturn"] .= "Excellent hit!<br />"; }
|
if ($toexcellent <= sqrt($userrow["strength"])) { $tohit *= 2; $pagearray["yourturn"] .= "Excellent hit!<br />"; }
|
||||||
$toblock = ceil(rand($monsterrow["armor"]*.75,$monsterrow["armor"])/3);
|
$toblock = ceil(rand($monsterrow["armor"]*.75,$monsterrow["armor"])/3);
|
||||||
$tododge = rand(1,200);
|
$tododge = rand(1,200);
|
||||||
if ($tododge <= sqrt($monsterrow["armor"])) {
|
if ($tododge <= sqrt($monsterrow["armor"])) {
|
||||||
$tohit = 0; $pagearray["yourturn"] .= "The monster is dodging. No damage has been scored.<br />";
|
$tohit = 0; $pagearray["yourturn"] .= "The monster is dodging. No damage has been scored.<br />";
|
||||||
$monsterdamage = 0;
|
$monsterdamage = 0;
|
||||||
} else {
|
} else {
|
||||||
$monsterdamage = $tohit - $toblock;
|
$monsterdamage = $tohit - $toblock;
|
||||||
|
@ -138,7 +134,7 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
header("Location: index.php?do=victory");
|
header("Location: index.php?do=victory");
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Monster's turn.
|
// Monster's turn.
|
||||||
$pagearray["monsterturn"] = "";
|
$pagearray["monsterturn"] = "";
|
||||||
if ($userrow["currentmonstersleep"] != 0) { // Check to wake up.
|
if ($userrow["currentmonstersleep"] != 0) { // Check to wake up.
|
||||||
|
@ -152,8 +148,6 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
}
|
}
|
||||||
if ($userrow["currentmonstersleep"] == 0) { // Only do this if the monster is awake.
|
if ($userrow["currentmonstersleep"] == 0) { // Only do this if the monster is awake.
|
||||||
$tohit = ceil(rand($monsterrow["maxdam"]*.5,$monsterrow["maxdam"]));
|
$tohit = ceil(rand($monsterrow["maxdam"]*.5,$monsterrow["maxdam"]));
|
||||||
if ($userrow["difficulty"] == 2) { $tohit = ceil($tohit * $controlrow["diff2mod"]); }
|
|
||||||
if ($userrow["difficulty"] == 3) { $tohit = ceil($tohit * $controlrow["diff3mod"]); }
|
|
||||||
$toblock = ceil(rand($userrow["defensepower"]*.75,$userrow["defensepower"])/4);
|
$toblock = ceil(rand($userrow["defensepower"]*.75,$userrow["defensepower"])/4);
|
||||||
$tododge = rand(1,150);
|
$tododge = rand(1,150);
|
||||||
if ($tododge <= sqrt($userrow["dexterity"])) {
|
if ($tododge <= sqrt($userrow["dexterity"])) {
|
||||||
|
@ -176,14 +170,14 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
$playerisdead = 1;
|
$playerisdead = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Do spell stuff.
|
// Do spell stuff.
|
||||||
} elseif (isset($_POST["spell"])) {
|
} elseif (isset($_POST["spell"])) {
|
||||||
|
|
||||||
// Your turn.
|
// Your turn.
|
||||||
$pickedspell = $_POST["userspell"];
|
$pickedspell = $_POST["userspell"];
|
||||||
if ($pickedspell == 0) { display("You must select a spell first. Please go back and try again.", "Error"); die(); }
|
if ($pickedspell == 0) { display("You must select a spell first. Please go back and try again.", "Error"); die(); }
|
||||||
|
|
||||||
$newspellquery = doquery("SELECT * FROM {{table}} WHERE id='$pickedspell' LIMIT 1", "spells");
|
$newspellquery = doquery("SELECT * FROM {{table}} WHERE id='$pickedspell' LIMIT 1", "spells");
|
||||||
$newspellrow = mysql_fetch_array($newspellquery);
|
$newspellrow = mysql_fetch_array($newspellquery);
|
||||||
$spell = false;
|
$spell = false;
|
||||||
|
@ -192,7 +186,7 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
}
|
}
|
||||||
if ($spell != true) { display("You have not yet learned this spell. Please go back and try again.", "Error"); die(); }
|
if ($spell != true) { display("You have not yet learned this spell. Please go back and try again.", "Error"); die(); }
|
||||||
if ($userrow["currentmp"] < $newspellrow["mp"]) { display("You do not have enough Magic Points to cast this spell. Please go back and try again.", "Error"); die(); }
|
if ($userrow["currentmp"] < $newspellrow["mp"]) { display("You do not have enough Magic Points to cast this spell. Please go back and try again.", "Error"); die(); }
|
||||||
|
|
||||||
if ($newspellrow["type"] == 1) { // Heal spell.
|
if ($newspellrow["type"] == 1) { // Heal spell.
|
||||||
$newhp = $userrow["currenthp"] + $newspellrow["attribute"];
|
$newhp = $userrow["currenthp"] + $newspellrow["attribute"];
|
||||||
if ($userrow["maxhp"] < $newhp) { $newspellrow["attribute"] = $userrow["maxhp"] - $userrow["currenthp"]; $newhp = $userrow["currenthp"] + $newspellrow["attribute"]; }
|
if ($userrow["maxhp"] < $newhp) { $newspellrow["attribute"] = $userrow["maxhp"] - $userrow["currenthp"]; $newhp = $userrow["currenthp"] + $newspellrow["attribute"]; }
|
||||||
|
@ -223,16 +217,16 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
} elseif ($newspellrow["type"] == 5) { // +Defense spell.
|
} elseif ($newspellrow["type"] == 5) { // +Defense spell.
|
||||||
$userrow["currentuberdefense"] = $newspellrow["attribute"];
|
$userrow["currentuberdefense"] = $newspellrow["attribute"];
|
||||||
$userrow["currentmp"] -= $newspellrow["mp"];
|
$userrow["currentmp"] -= $newspellrow["mp"];
|
||||||
$pagearray["yourturn"] = "You have cast the ".$newspellrow["name"]." spell, and will gain ".$newspellrow["attribute"]."% defense until the end of this fight.<br /><br />";
|
$pagearray["yourturn"] = "You have cast the ".$newspellrow["name"]." spell, and will gain ".$newspellrow["attribute"]."% defense until the end of this fight.<br /><br />";
|
||||||
}
|
}
|
||||||
|
|
||||||
$pagearray["monsterhp"] = "Monster's HP: " . $userrow["currentmonsterhp"] . "<br /><br />";
|
$pagearray["monsterhp"] = "Monster's HP: " . $userrow["currentmonsterhp"] . "<br /><br />";
|
||||||
if ($userrow["currentmonsterhp"] <= 0) {
|
if ($userrow["currentmonsterhp"] <= 0) {
|
||||||
$updatequery = doquery("UPDATE {{table}} SET currentmonsterhp='0',currenthp='".$userrow["currenthp"]."',currentmp='".$userrow["currentmp"]."' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
$updatequery = doquery("UPDATE {{table}} SET currentmonsterhp='0',currenthp='".$userrow["currenthp"]."',currentmp='".$userrow["currentmp"]."' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
||||||
header("Location: index.php?do=victory");
|
header("Location: index.php?do=victory");
|
||||||
die();
|
die();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Monster's turn.
|
// Monster's turn.
|
||||||
$pagearray["monsterturn"] = "";
|
$pagearray["monsterturn"] = "";
|
||||||
if ($userrow["currentmonstersleep"] != 0) { // Check to wake up.
|
if ($userrow["currentmonstersleep"] != 0) { // Check to wake up.
|
||||||
|
@ -246,8 +240,6 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
}
|
}
|
||||||
if ($userrow["currentmonstersleep"] == 0) { // Only do this if the monster is awake.
|
if ($userrow["currentmonstersleep"] == 0) { // Only do this if the monster is awake.
|
||||||
$tohit = ceil(rand($monsterrow["maxdam"]*.5,$monsterrow["maxdam"]));
|
$tohit = ceil(rand($monsterrow["maxdam"]*.5,$monsterrow["maxdam"]));
|
||||||
if ($userrow["difficulty"] == 2) { $tohit = ceil($tohit * $controlrow["diff2mod"]); }
|
|
||||||
if ($userrow["difficulty"] == 3) { $tohit = ceil($tohit * $controlrow["diff3mod"]); }
|
|
||||||
$toblock = ceil(rand($userrow["defensepower"]*.75,$userrow["defensepower"])/4);
|
$toblock = ceil(rand($userrow["defensepower"]*.75,$userrow["defensepower"])/4);
|
||||||
$tododge = rand(1,150);
|
$tododge = rand(1,150);
|
||||||
if ($tododge <= sqrt($userrow["dexterity"])) {
|
if ($tododge <= sqrt($userrow["dexterity"])) {
|
||||||
|
@ -270,7 +262,7 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
$playerisdead = 1;
|
$playerisdead = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Do a monster's turn if person lost the chance to swing first. Serves him right!
|
// Do a monster's turn if person lost the chance to swing first. Serves him right!
|
||||||
} elseif ( $chancetoswingfirst == 0 ) {
|
} elseif ( $chancetoswingfirst == 0 ) {
|
||||||
$pagearray["yourturn"] = "The monster attacks before you are ready!<br /><br />";
|
$pagearray["yourturn"] = "The monster attacks before you are ready!<br /><br />";
|
||||||
|
@ -287,8 +279,6 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
}
|
}
|
||||||
if ($userrow["currentmonstersleep"] == 0) { // Only do this if the monster is awake.
|
if ($userrow["currentmonstersleep"] == 0) { // Only do this if the monster is awake.
|
||||||
$tohit = ceil(rand($monsterrow["maxdam"]*.5,$monsterrow["maxdam"]));
|
$tohit = ceil(rand($monsterrow["maxdam"]*.5,$monsterrow["maxdam"]));
|
||||||
if ($userrow["difficulty"] == 2) { $tohit = ceil($tohit * $controlrow["diff2mod"]); }
|
|
||||||
if ($userrow["difficulty"] == 3) { $tohit = ceil($tohit * $controlrow["diff3mod"]); }
|
|
||||||
$toblock = ceil(rand($userrow["defensepower"]*.75,$userrow["defensepower"])/4);
|
$toblock = ceil(rand($userrow["defensepower"]*.75,$userrow["defensepower"])/4);
|
||||||
$tododge = rand(1,150);
|
$tododge = rand(1,150);
|
||||||
if ($tododge <= sqrt($userrow["dexterity"])) {
|
if ($tododge <= sqrt($userrow["dexterity"])) {
|
||||||
|
@ -317,7 +307,7 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
$pagearray["monsterhp"] = "Monster's HP: " . $userrow["currentmonsterhp"] . "<br /><br />";
|
$pagearray["monsterhp"] = "Monster's HP: " . $userrow["currentmonsterhp"] . "<br /><br />";
|
||||||
$pagearray["monsterturn"] = "";
|
$pagearray["monsterturn"] = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
$newmonster = $userrow["currentmonster"];
|
$newmonster = $userrow["currentmonster"];
|
||||||
|
|
||||||
$newmonsterhp = $userrow["currentmonsterhp"];
|
$newmonsterhp = $userrow["currentmonsterhp"];
|
||||||
|
@ -327,9 +317,9 @@ function fight() { // One big long function that determines the outcome of the f
|
||||||
$newuberdefense = $userrow["currentuberdefense"];
|
$newuberdefense = $userrow["currentuberdefense"];
|
||||||
$newfight = $userrow["currentfight"] + 1;
|
$newfight = $userrow["currentfight"] + 1;
|
||||||
$newhp = $userrow["currenthp"];
|
$newhp = $userrow["currenthp"];
|
||||||
$newmp = $userrow["currentmp"];
|
$newmp = $userrow["currentmp"];
|
||||||
|
|
||||||
if ($playerisdead != 1) {
|
if ($playerisdead != 1) {
|
||||||
$pagearray["command"] = <<<END
|
$pagearray["command"] = <<<END
|
||||||
Command?<br /><br />
|
Command?<br /><br />
|
||||||
<form action="index.php?do=fight" method="post">
|
<form action="index.php?do=fight" method="post">
|
||||||
|
@ -342,41 +332,37 @@ END;
|
||||||
} else {
|
} else {
|
||||||
$pagearray["command"] = "<b>You have died.</b><br /><br />As a consequence, you've lost half of your gold. However, you have been given back a portion of your hit points to continue your journey.<br /><br />You may now continue back to <a href=\"index.php\">town</a>, and we hope you fair better next time.";
|
$pagearray["command"] = "<b>You have died.</b><br /><br />As a consequence, you've lost half of your gold. However, you have been given back a portion of your hit points to continue your journey.<br /><br />You may now continue back to <a href=\"index.php\">town</a>, and we hope you fair better next time.";
|
||||||
}
|
}
|
||||||
|
|
||||||
// Finalize page and display it.
|
// Finalize page and display it.
|
||||||
$template = gettemplate("fight");
|
$template = gettemplate("fight");
|
||||||
$page = parsetemplate($template,$pagearray);
|
$page = parsetemplate($template,$pagearray);
|
||||||
|
|
||||||
display($page, "Fighting");
|
display($page, "Fighting");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function victory() {
|
function victory() {
|
||||||
|
|
||||||
global $userrow, $controlrow;
|
global $userrow, $controlrow;
|
||||||
|
|
||||||
if ($userrow["currentmonsterhp"] != 0) { header("Location: index.php?do=fight"); die(); }
|
if ($userrow["currentmonsterhp"] != 0) { header("Location: index.php?do=fight"); die(); }
|
||||||
if ($userrow["currentfight"] == 0) { header("Location: index.php"); die(); }
|
if ($userrow["currentfight"] == 0) { header("Location: index.php"); die(); }
|
||||||
|
|
||||||
$monsterquery = doquery("SELECT * FROM {{table}} WHERE id='".$userrow["currentmonster"]."' LIMIT 1", "monsters");
|
$monsterquery = doquery("SELECT * FROM {{table}} WHERE id='".$userrow["currentmonster"]."' LIMIT 1", "monsters");
|
||||||
$monsterrow = mysql_fetch_array($monsterquery);
|
$monsterrow = mysql_fetch_array($monsterquery);
|
||||||
|
|
||||||
$exp = rand((($monsterrow["maxexp"]/6)*5),$monsterrow["maxexp"]);
|
$exp = rand((($monsterrow["maxexp"]/6)*5),$monsterrow["maxexp"]);
|
||||||
if ($exp < 1) { $exp = 1; }
|
if ($exp < 1) { $exp = 1; }
|
||||||
if ($userrow["difficulty"] == 2) { $exp = ceil($exp * $controlrow["diff2mod"]); }
|
|
||||||
if ($userrow["difficulty"] == 3) { $exp = ceil($exp * $controlrow["diff3mod"]); }
|
|
||||||
if ($userrow["expbonus"] != 0) { $exp += ceil(($userrow["expbonus"]/100)*$exp); }
|
if ($userrow["expbonus"] != 0) { $exp += ceil(($userrow["expbonus"]/100)*$exp); }
|
||||||
$gold = rand((($monsterrow["maxgold"]/6)*5),$monsterrow["maxgold"]);
|
$gold = rand((($monsterrow["maxgold"]/6)*5),$monsterrow["maxgold"]);
|
||||||
if ($gold < 1) { $gold = 1; }
|
if ($gold < 1) { $gold = 1; }
|
||||||
if ($userrow["difficulty"] == 2) { $gold = ceil($gold * $controlrow["diff2mod"]); }
|
|
||||||
if ($userrow["difficulty"] == 3) { $gold = ceil($gold * $controlrow["diff3mod"]); }
|
|
||||||
if ($userrow["goldbonus"] != 0) { $gold += ceil(($userrow["goldbonus"]/100)*$exp); }
|
if ($userrow["goldbonus"] != 0) { $gold += ceil(($userrow["goldbonus"]/100)*$exp); }
|
||||||
if ($userrow["experience"] + $exp < 16777215) { $newexp = $userrow["experience"] + $exp; $warnexp = ""; } else { $newexp = $userrow["experience"]; $exp = 0; $warnexp = "You have maxed out your experience points."; }
|
if ($userrow["experience"] + $exp < 16777215) { $newexp = $userrow["experience"] + $exp; $warnexp = ""; } else { $newexp = $userrow["experience"]; $exp = 0; $warnexp = "You have maxed out your experience points."; }
|
||||||
if ($userrow["gold"] + $gold < 16777215) { $newgold = $userrow["gold"] + $gold; $warngold = ""; } else { $newgold = $userrow["gold"]; $gold = 0; $warngold = "You have maxed out your experience points."; }
|
if ($userrow["gold"] + $gold < 16777215) { $newgold = $userrow["gold"] + $gold; $warngold = ""; } else { $newgold = $userrow["gold"]; $gold = 0; $warngold = "You have maxed out your experience points."; }
|
||||||
|
|
||||||
$levelquery = doquery("SELECT * FROM {{table}} WHERE id='".($userrow["level"]+1)."' LIMIT 1", "levels");
|
$levelquery = doquery("SELECT * FROM {{table}} WHERE id='".($userrow["level"]+1)."' LIMIT 1", "levels");
|
||||||
if (mysql_num_rows($levelquery) == 1) { $levelrow = mysql_fetch_array($levelquery); }
|
if (mysql_num_rows($levelquery) == 1) { $levelrow = mysql_fetch_array($levelquery); }
|
||||||
|
|
||||||
if ($userrow["level"] < 100) {
|
if ($userrow["level"] < 100) {
|
||||||
if ($newexp >= $levelrow[$userrow["charclass"]."_exp"]) {
|
if ($newexp >= $levelrow[$userrow["charclass"]."_exp"]) {
|
||||||
$newhp = $userrow["maxhp"] + $levelrow[$userrow["charclass"]."_hp"];
|
$newhp = $userrow["maxhp"] + $levelrow[$userrow["charclass"]."_hp"];
|
||||||
|
@ -387,13 +373,13 @@ function victory() {
|
||||||
$newattack = $userrow["attackpower"] + $levelrow[$userrow["charclass"]."_strength"];
|
$newattack = $userrow["attackpower"] + $levelrow[$userrow["charclass"]."_strength"];
|
||||||
$newdefense = $userrow["defensepower"] + $levelrow[$userrow["charclass"]."_dexterity"];
|
$newdefense = $userrow["defensepower"] + $levelrow[$userrow["charclass"]."_dexterity"];
|
||||||
$newlevel = $levelrow["id"];
|
$newlevel = $levelrow["id"];
|
||||||
|
|
||||||
if ($levelrow[$userrow["charclass"]."_spells"] != 0) {
|
if ($levelrow[$userrow["charclass"]."_spells"] != 0) {
|
||||||
$userspells = $userrow["spells"] . ",".$levelrow[$userrow["charclass"]."_spells"];
|
$userspells = $userrow["spells"] . ",".$levelrow[$userrow["charclass"]."_spells"];
|
||||||
$newspell = "spells='$userspells',";
|
$newspell = "spells='$userspells',";
|
||||||
$spelltext = "You have learned a new spell.<br />";
|
$spelltext = "You have learned a new spell.<br />";
|
||||||
} else { $spelltext = ""; $newspell=""; }
|
} else { $spelltext = ""; $newspell=""; }
|
||||||
|
|
||||||
$page = "Congratulations. You have defeated the ".$monsterrow["name"].".<br />You gain $exp experience. $warnexp <br />You gain $gold gold. $warngold <br /><br /><b>You have gained a level!</b><br /><br />You gain ".$levelrow[$userrow["charclass"]."_hp"]." hit points.<br />You gain ".$levelrow[$userrow["charclass"]."_mp"]." magic points.<br />You gain ".$levelrow[$userrow["charclass"]."_tp"]." travel points.<br />You gain ".$levelrow[$userrow["charclass"]."_strength"]." strength.<br />You gain ".$levelrow[$userrow["charclass"]."_dexterity"]." dexterity.<br />$spelltext<br />You can now continue <a href=\"index.php\">exploring</a>.";
|
$page = "Congratulations. You have defeated the ".$monsterrow["name"].".<br />You gain $exp experience. $warnexp <br />You gain $gold gold. $warngold <br /><br /><b>You have gained a level!</b><br /><br />You gain ".$levelrow[$userrow["charclass"]."_hp"]." hit points.<br />You gain ".$levelrow[$userrow["charclass"]."_mp"]." magic points.<br />You gain ".$levelrow[$userrow["charclass"]."_tp"]." travel points.<br />You gain ".$levelrow[$userrow["charclass"]."_strength"]." strength.<br />You gain ".$levelrow[$userrow["charclass"]."_dexterity"]." dexterity.<br />$spelltext<br />You can now continue <a href=\"index.php\">exploring</a>.";
|
||||||
$title = "Courage and Wit have served thee well!";
|
$title = "Courage and Wit have served thee well!";
|
||||||
$dropcode = "";
|
$dropcode = "";
|
||||||
|
@ -408,13 +394,13 @@ function victory() {
|
||||||
$newlevel = $userrow["level"];
|
$newlevel = $userrow["level"];
|
||||||
$newspell = "";
|
$newspell = "";
|
||||||
$page = "Congratulations. You have defeated the ".$monsterrow["name"].".<br />You gain $exp experience. $warnexp <br />You gain $gold gold. $warngold <br /><br />";
|
$page = "Congratulations. You have defeated the ".$monsterrow["name"].".<br />You gain $exp experience. $warnexp <br />You gain $gold gold. $warngold <br /><br />";
|
||||||
|
|
||||||
if (rand(1,30) == 1) {
|
if (rand(1,30) == 1) {
|
||||||
$dropquery = doquery("SELECT * FROM {{table}} WHERE mlevel <= '".$monsterrow["level"]."' ORDER BY RAND() LIMIT 1", "drops");
|
$dropquery = doquery("SELECT * FROM {{table}} WHERE mlevel <= '".$monsterrow["level"]."' ORDER BY RAND() LIMIT 1", "drops");
|
||||||
$droprow = mysql_fetch_array($dropquery);
|
$droprow = mysql_fetch_array($dropquery);
|
||||||
$dropcode = "dropcode='".$droprow["id"]."',";
|
$dropcode = "dropcode='".$droprow["id"]."',";
|
||||||
$page .= "This monster has dropped an item. <a href=\"index.php?do=drop\">Click here</a> to reveal and equip the item, or you may also move on and continue <a href=\"index.php\">exploring</a>.";
|
$page .= "This monster has dropped an item. <a href=\"index.php?do=drop\">Click here</a> to reveal and equip the item, or you may also move on and continue <a href=\"index.php\">exploring</a>.";
|
||||||
} else {
|
} else {
|
||||||
$dropcode = "";
|
$dropcode = "";
|
||||||
$page .= "You can now continue <a href=\"index.php\">exploring</a>.";
|
$page .= "You can now continue <a href=\"index.php\">exploring</a>.";
|
||||||
}
|
}
|
||||||
|
@ -424,79 +410,79 @@ function victory() {
|
||||||
}
|
}
|
||||||
|
|
||||||
$updatequery = doquery("UPDATE {{table}} SET currentaction='Exploring',level='$newlevel',maxhp='$newhp',maxmp='$newmp',maxtp='$newtp',strength='$newstrength',dexterity='$newdexterity',attackpower='$newattack',defensepower='$newdefense', $newspell currentfight='0',currentmonster='0',currentmonsterhp='0',currentmonstersleep='0',currentmonsterimmune='0',currentuberdamage='0',currentuberdefense='0',$dropcode experience='$newexp',gold='$newgold' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
$updatequery = doquery("UPDATE {{table}} SET currentaction='Exploring',level='$newlevel',maxhp='$newhp',maxmp='$newmp',maxtp='$newtp',strength='$newstrength',dexterity='$newdexterity',attackpower='$newattack',defensepower='$newdefense', $newspell currentfight='0',currentmonster='0',currentmonsterhp='0',currentmonstersleep='0',currentmonsterimmune='0',currentuberdamage='0',currentuberdefense='0',$dropcode experience='$newexp',gold='$newgold' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
||||||
|
|
||||||
|
|
||||||
display($page, $title);
|
display($page, $title);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function drop() {
|
function drop() {
|
||||||
|
|
||||||
global $userrow;
|
global $userrow;
|
||||||
|
|
||||||
if ($userrow["dropcode"] == 0) { header("Location: index.php"); die(); }
|
if ($userrow["dropcode"] == 0) { header("Location: index.php"); die(); }
|
||||||
|
|
||||||
$dropquery = doquery("SELECT * FROM {{table}} WHERE id='".$userrow["dropcode"]."' LIMIT 1", "drops");
|
$dropquery = doquery("SELECT * FROM {{table}} WHERE id='".$userrow["dropcode"]."' LIMIT 1", "drops");
|
||||||
$droprow = mysql_fetch_array($dropquery);
|
$droprow = mysql_fetch_array($dropquery);
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
$slot = $_POST["slot"];
|
$slot = $_POST["slot"];
|
||||||
|
|
||||||
if ($slot == 0) { display("Please go back and select an inventory slot to continue.","Error"); }
|
if ($slot == 0) { display("Please go back and select an inventory slot to continue.","Error"); }
|
||||||
|
|
||||||
if ($userrow["slot".$slot."id"] != 0) {
|
if ($userrow["slot".$slot."id"] != 0) {
|
||||||
|
|
||||||
$slotquery = doquery("SELECT * FROM {{table}} WHERE id='".$userrow["slot".$slot."id"]."' LIMIT 1", "drops");
|
$slotquery = doquery("SELECT * FROM {{table}} WHERE id='".$userrow["slot".$slot."id"]."' LIMIT 1", "drops");
|
||||||
$slotrow = mysql_fetch_array($slotquery);
|
$slotrow = mysql_fetch_array($slotquery);
|
||||||
|
|
||||||
$old1 = explode(",",$slotrow["attribute1"]);
|
$old1 = explode(",",$slotrow["attribute1"]);
|
||||||
if ($slotrow["attribute2"] != "X") { $old2 = explode(",",$slotrow["attribute2"]); } else { $old2 = array(0=>"maxhp",1=>0); }
|
if ($slotrow["attribute2"] != "X") { $old2 = explode(",",$slotrow["attribute2"]); } else { $old2 = array(0=>"maxhp",1=>0); }
|
||||||
$new1 = explode(",",$droprow["attribute1"]);
|
$new1 = explode(",",$droprow["attribute1"]);
|
||||||
if ($droprow["attribute2"] != "X") { $new2 = explode(",",$droprow["attribute2"]); } else { $new2 = array(0=>"maxhp",1=>0); }
|
if ($droprow["attribute2"] != "X") { $new2 = explode(",",$droprow["attribute2"]); } else { $new2 = array(0=>"maxhp",1=>0); }
|
||||||
|
|
||||||
$userrow[$old1[0]] -= $old1[1];
|
$userrow[$old1[0]] -= $old1[1];
|
||||||
$userrow[$old2[0]] -= $old2[1];
|
$userrow[$old2[0]] -= $old2[1];
|
||||||
if ($old1[0] == "strength") { $userrow["attackpower"] -= $old1[1]; }
|
if ($old1[0] == "strength") { $userrow["attackpower"] -= $old1[1]; }
|
||||||
if ($old1[0] == "dexterity") { $userrow["defensepower"] -= $old1[1]; }
|
if ($old1[0] == "dexterity") { $userrow["defensepower"] -= $old1[1]; }
|
||||||
if ($old2[0] == "strength") { $userrow["attackpower"] -= $old2[1]; }
|
if ($old2[0] == "strength") { $userrow["attackpower"] -= $old2[1]; }
|
||||||
if ($old2[0] == "dexterity") { $userrow["defensepower"] -= $old2[1]; }
|
if ($old2[0] == "dexterity") { $userrow["defensepower"] -= $old2[1]; }
|
||||||
|
|
||||||
$userrow[$new1[0]] += $new1[1];
|
$userrow[$new1[0]] += $new1[1];
|
||||||
$userrow[$new2[0]] += $new2[1];
|
$userrow[$new2[0]] += $new2[1];
|
||||||
if ($new1[0] == "strength") { $userrow["attackpower"] += $new1[1]; }
|
if ($new1[0] == "strength") { $userrow["attackpower"] += $new1[1]; }
|
||||||
if ($new1[0] == "dexterity") { $userrow["defensepower"] += $new1[1]; }
|
if ($new1[0] == "dexterity") { $userrow["defensepower"] += $new1[1]; }
|
||||||
if ($new2[0] == "strength") { $userrow["attackpower"] += $new2[1]; }
|
if ($new2[0] == "strength") { $userrow["attackpower"] += $new2[1]; }
|
||||||
if ($new2[0] == "dexterity") { $userrow["defensepower"] += $new2[1]; }
|
if ($new2[0] == "dexterity") { $userrow["defensepower"] += $new2[1]; }
|
||||||
|
|
||||||
if ($userrow["currenthp"] > $userrow["maxhp"]) { $userrow["currenthp"] = $userrow["maxhp"]; }
|
if ($userrow["currenthp"] > $userrow["maxhp"]) { $userrow["currenthp"] = $userrow["maxhp"]; }
|
||||||
if ($userrow["currentmp"] > $userrow["maxmp"]) { $userrow["currentmp"] = $userrow["maxmp"]; }
|
if ($userrow["currentmp"] > $userrow["maxmp"]) { $userrow["currentmp"] = $userrow["maxmp"]; }
|
||||||
if ($userrow["currenttp"] > $userrow["maxtp"]) { $userrow["currenttp"] = $userrow["maxtp"]; }
|
if ($userrow["currenttp"] > $userrow["maxtp"]) { $userrow["currenttp"] = $userrow["maxtp"]; }
|
||||||
|
|
||||||
$newname = addslashes($droprow["name"]);
|
$newname = addslashes($droprow["name"]);
|
||||||
$query = doquery("UPDATE {{table}} SET slot".$_POST["slot"]."name='$newname',slot".$_POST["slot"]."id='".$droprow["id"]."',$old1[0]='".$userrow[$old1[0]]."',$old2[0]='".$userrow[$old2[0]]."',$new1[0]='".$userrow[$new1[0]]."',$new2[0]='".$userrow[$new2[0]]."',attackpower='".$userrow["attackpower"]."',defensepower='".$userrow["defensepower"]."',currenthp='".$userrow["currenthp"]."',currentmp='".$userrow["currentmp"]."',currenttp='".$userrow["currenttp"]."',dropcode='0' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
$query = doquery("UPDATE {{table}} SET slot".$_POST["slot"]."name='$newname',slot".$_POST["slot"]."id='".$droprow["id"]."',$old1[0]='".$userrow[$old1[0]]."',$old2[0]='".$userrow[$old2[0]]."',$new1[0]='".$userrow[$new1[0]]."',$new2[0]='".$userrow[$new2[0]]."',attackpower='".$userrow["attackpower"]."',defensepower='".$userrow["defensepower"]."',currenthp='".$userrow["currenthp"]."',currentmp='".$userrow["currentmp"]."',currenttp='".$userrow["currenttp"]."',dropcode='0' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$new1 = explode(",",$droprow["attribute1"]);
|
$new1 = explode(",",$droprow["attribute1"]);
|
||||||
if ($droprow["attribute2"] != "X") { $new2 = explode(",",$droprow["attribute2"]); } else { $new2 = array(0=>"maxhp",1=>0); }
|
if ($droprow["attribute2"] != "X") { $new2 = explode(",",$droprow["attribute2"]); } else { $new2 = array(0=>"maxhp",1=>0); }
|
||||||
|
|
||||||
$userrow[$new1[0]] += $new1[1];
|
$userrow[$new1[0]] += $new1[1];
|
||||||
$userrow[$new2[0]] += $new2[1];
|
$userrow[$new2[0]] += $new2[1];
|
||||||
if ($new1[0] == "strength") { $userrow["attackpower"] += $new1[1]; }
|
if ($new1[0] == "strength") { $userrow["attackpower"] += $new1[1]; }
|
||||||
if ($new1[0] == "dexterity") { $userrow["defensepower"] += $new1[1]; }
|
if ($new1[0] == "dexterity") { $userrow["defensepower"] += $new1[1]; }
|
||||||
if ($new2[0] == "strength") { $userrow["attackpower"] += $new2[1]; }
|
if ($new2[0] == "strength") { $userrow["attackpower"] += $new2[1]; }
|
||||||
if ($new2[0] == "dexterity") { $userrow["defensepower"] += $new2[1]; }
|
if ($new2[0] == "dexterity") { $userrow["defensepower"] += $new2[1]; }
|
||||||
|
|
||||||
$newname = addslashes($droprow["name"]);
|
$newname = addslashes($droprow["name"]);
|
||||||
$query = doquery("UPDATE {{table}} SET slot".$_POST["slot"]."name='$newname',slot".$_POST["slot"]."id='".$droprow["id"]."',$new1[0]='".$userrow[$new1[0]]."',$new2[0]='".$userrow[$new2[0]]."',attackpower='".$userrow["attackpower"]."',defensepower='".$userrow["defensepower"]."',dropcode='0' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
$query = doquery("UPDATE {{table}} SET slot".$_POST["slot"]."name='$newname',slot".$_POST["slot"]."id='".$droprow["id"]."',$new1[0]='".$userrow[$new1[0]]."',$new2[0]='".$userrow[$new2[0]]."',attackpower='".$userrow["attackpower"]."',defensepower='".$userrow["defensepower"]."',dropcode='0' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
||||||
|
|
||||||
}
|
}
|
||||||
$page = "The item has been equipped. You can now continue <a href=\"index.php\">exploring</a>.";
|
$page = "The item has been equipped. You can now continue <a href=\"index.php\">exploring</a>.";
|
||||||
display($page, "Item Drop");
|
display($page, "Item Drop");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$attributearray = array("maxhp"=>"Max HP",
|
$attributearray = array("maxhp"=>"Max HP",
|
||||||
"maxmp"=>"Max MP",
|
"maxmp"=>"Max MP",
|
||||||
"maxtp"=>"Max TP",
|
"maxtp"=>"Max TP",
|
||||||
|
@ -506,35 +492,35 @@ function drop() {
|
||||||
"dexterity"=>"Dexterity",
|
"dexterity"=>"Dexterity",
|
||||||
"expbonus"=>"Experience Bonus",
|
"expbonus"=>"Experience Bonus",
|
||||||
"goldbonus"=>"Gold Bonus");
|
"goldbonus"=>"Gold Bonus");
|
||||||
|
|
||||||
$page = "The monster dropped the following item: <b>".$droprow["name"]."</b><br /><br />";
|
$page = "The monster dropped the following item: <b>".$droprow["name"]."</b><br /><br />";
|
||||||
$page .= "This item has the following attribute(s):<br />";
|
$page .= "This item has the following attribute(s):<br />";
|
||||||
|
|
||||||
$attribute1 = explode(",",$droprow["attribute1"]);
|
$attribute1 = explode(",",$droprow["attribute1"]);
|
||||||
$page .= $attributearray[$attribute1[0]];
|
$page .= $attributearray[$attribute1[0]];
|
||||||
if ($attribute1[1] > 0) { $page .= " +" . $attribute1[1] . "<br />"; } else { $page .= $attribute1[1] . "<br />"; }
|
if ($attribute1[1] > 0) { $page .= " +" . $attribute1[1] . "<br />"; } else { $page .= $attribute1[1] . "<br />"; }
|
||||||
|
|
||||||
if ($droprow["attribute2"] != "X") {
|
if ($droprow["attribute2"] != "X") {
|
||||||
$attribute2 = explode(",",$droprow["attribute2"]);
|
$attribute2 = explode(",",$droprow["attribute2"]);
|
||||||
$page .= $attributearray[$attribute2[0]];
|
$page .= $attributearray[$attribute2[0]];
|
||||||
if ($attribute2[1] > 0) { $page .= " +" . $attribute2[1] . "<br />"; } else { $page .= $attribute2[1] . "<br />"; }
|
if ($attribute2[1] > 0) { $page .= " +" . $attribute2[1] . "<br />"; } else { $page .= $attribute2[1] . "<br />"; }
|
||||||
}
|
}
|
||||||
|
|
||||||
$page .= "<br />Select an inventory slot from the list below to equip this item. If the inventory slot is already full, the old item will be discarded.";
|
$page .= "<br />Select an inventory slot from the list below to equip this item. If the inventory slot is already full, the old item will be discarded.";
|
||||||
$page .= "<form action=\"index.php?do=drop\" method=\"post\"><select name=\"slot\"><option value=\"0\">Choose One</option><option value=\"1\">Slot 1: ".$userrow["slot1name"]."</option><option value=\"2\">Slot 2: ".$userrow["slot2name"]."</option><option value=\"3\">Slot 3: ".$userrow["slot3name"]."</option></select> <input type=\"submit\" name=\"submit\" value=\"Submit\" /></form>";
|
$page .= "<form action=\"index.php?do=drop\" method=\"post\"><select name=\"slot\"><option value=\"0\">Choose One</option><option value=\"1\">Slot 1: ".$userrow["slot1name"]."</option><option value=\"2\">Slot 2: ".$userrow["slot2name"]."</option><option value=\"3\">Slot 3: ".$userrow["slot3name"]."</option></select> <input type=\"submit\" name=\"submit\" value=\"Submit\" /></form>";
|
||||||
$page .= "You may also choose to just continue <a href=\"index.php\">exploring</a> and give up this item.";
|
$page .= "You may also choose to just continue <a href=\"index.php\">exploring</a> and give up this item.";
|
||||||
|
|
||||||
display($page, "Item Drop");
|
display($page, "Item Drop");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function dead() {
|
function dead() {
|
||||||
|
|
||||||
$page = "<b>You have died.</b><br /><br />As a consequence, you've lost half of your gold. However, you have been given back a portion of your hit points to continue your journey.<br /><br />You may now continue back to <a href=\"index.php\">town</a>, and we hope you fair better next time.";
|
$page = "<b>You have died.</b><br /><br />As a consequence, you've lost half of your gold. However, you have been given back a portion of your hit points to continue your journey.<br /><br />You may now continue back to <a href=\"index.php\">town</a>, and we hope you fair better next time.";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
|
27
src/lib.php
27
src/lib.php
|
@ -14,6 +14,15 @@ function db(): Database
|
||||||
return $GLOBALS['database'] ??= new Database(__DIR__ . '/../database.db');
|
return $GLOBALS['database'] ??= new Database(__DIR__ . '/../database.db');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Redirect to a different URL, exit.
|
||||||
|
*/
|
||||||
|
function redirect(string $location): void
|
||||||
|
{
|
||||||
|
header("Location: $location");
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
function gettemplate($templatename) { // SQL query for the template.
|
function gettemplate($templatename) { // SQL query for the template.
|
||||||
|
|
||||||
$filename = __DIR__ . "/../templates/" . $templatename . ".php";
|
$filename = __DIR__ . "/../templates/" . $templatename . ".php";
|
||||||
|
@ -164,7 +173,7 @@ function display($content, $title, $topnav=true, $leftnav=true, $rightnav=true,
|
||||||
$spellquery = db()->query('SELECT id, name, type FROM spells;');
|
$spellquery = db()->query('SELECT id, name, type FROM spells;');
|
||||||
$userspells = explode(",",$userrow["spells"]);
|
$userspells = explode(",",$userrow["spells"]);
|
||||||
$userrow["magiclist"] = "";
|
$userrow["magiclist"] = "";
|
||||||
foreach ($spellquery->fetchArray(SQLITE3_ASSOC) as $spellrow) {
|
while ($spellrow = $spellquery->fetchArray(SQLITE3_ASSOC)) {
|
||||||
$spell = false;
|
$spell = false;
|
||||||
foreach($userspells as $a => $b) {
|
foreach($userspells as $a => $b) {
|
||||||
if ($b == $spellrow["id"] && $spellrow["type"] == 1) { $spell = true; }
|
if ($b == $spellrow["id"] && $spellrow["type"] == 1) { $spell = true; }
|
||||||
|
@ -179,7 +188,7 @@ function display($content, $title, $topnav=true, $leftnav=true, $rightnav=true,
|
||||||
$townslist = explode(",",$userrow["towns"]);
|
$townslist = explode(",",$userrow["towns"]);
|
||||||
$townquery2 = db()->query('SELECT * FROM towns ORDER BY id;');
|
$townquery2 = db()->query('SELECT * FROM towns ORDER BY id;');
|
||||||
$userrow["townslist"] = "";
|
$userrow["townslist"] = "";
|
||||||
foreach ($townquery2->fetchArray(SQLITE3_ASSOC) as $townrow2) {
|
while ($townrow2 = $townquery2->fetchArray(SQLITE3_ASSOC)) {
|
||||||
$town = false;
|
$town = false;
|
||||||
foreach($townslist as $a => $b) {
|
foreach($townslist as $a => $b) {
|
||||||
if ($b == $townrow2["id"]) { $town = true; }
|
if ($b == $townrow2["id"]) { $town = true; }
|
||||||
|
@ -217,14 +226,14 @@ function checkcookies()
|
||||||
// COOKIE FORMAT:
|
// COOKIE FORMAT:
|
||||||
// {ID} {USERNAME} {PASSWORDHASH} {REMEMBERME}
|
// {ID} {USERNAME} {PASSWORDHASH} {REMEMBERME}
|
||||||
$theuser = explode(" ",$_COOKIE["dkgame"]);
|
$theuser = explode(" ",$_COOKIE["dkgame"]);
|
||||||
$query = db()->query('SELECT * FROM users WHERE id = ?, username = ?, password = ? LIMIT 1;', [$theuser[0], $theuser[1], $theuser[2]]);
|
$query = db()->query('SELECT * FROM users WHERE id = ? AND username = ? AND password = ? LIMIT 1;', [$theuser[0], $theuser[1], $theuser[2]]);
|
||||||
if ($query === false) {
|
if ($query === false) {
|
||||||
set_cookie('dkgame', '', -3600);
|
set_cookie('dkgame', '', -3600);
|
||||||
die("Invalid cookie data. Please log in again.");
|
die("Invalid cookie data. Please log in again.");
|
||||||
}
|
}
|
||||||
$row = $query->fetchArray(SQLITE3_ASSOC);
|
$row = $query->fetchArray(SQLITE3_ASSOC);
|
||||||
set_cookie('dkgame', implode(" ", $theuser), (int) $theuser[3] === 1 ? time() + 31536000 : 0);
|
set_cookie('dkgame', implode(" ", $theuser), (int) $theuser[3] === 1 ? time() + 31536000 : 0);
|
||||||
db()->exec('UPDATE users SET onlinetime = CURRENT_TIMESTAMP WHERE id = ? LIMIT 1;', [$theuser[0]]);
|
db()->exec('UPDATE users SET onlinetime = CURRENT_TIMESTAMP WHERE id = ?;', [$theuser[0]]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $row;
|
return $row;
|
||||||
|
@ -254,3 +263,13 @@ function get_control_row(): array|false
|
||||||
if ($query === false) return false;
|
if ($query === false) return false;
|
||||||
return $query->fetchArray(SQLITE3_ASSOC);
|
return $query->fetchArray(SQLITE3_ASSOC);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a town's data by it's coordinates.
|
||||||
|
*/
|
||||||
|
function get_town_by_xy(int $x, int $y): array|false
|
||||||
|
{
|
||||||
|
$query = db()->query('SELECT * FROM towns WHERE longitude = ? AND latitude = ? LIMIT 1;', [$x, $y]);
|
||||||
|
if ($query === false) return false;
|
||||||
|
return $query->fetchArray(SQLITE3_ASSOC);
|
||||||
|
}
|
||||||
|
|
|
@ -1,39 +1,41 @@
|
||||||
<?php // towns.php :: Handles all actions you can do in town.
|
<?php
|
||||||
|
|
||||||
function inn() { // Staying at the inn resets all expendable stats to their max values.
|
// towns.php :: Handles all actions you can do in town.
|
||||||
|
|
||||||
global $userrow, $numqueries;
|
/**
|
||||||
|
* Staying at the inn resets all expendable stats to their max values.
|
||||||
|
*/
|
||||||
|
function inn()
|
||||||
|
{
|
||||||
|
global $userrow;
|
||||||
|
|
||||||
$townquery = doquery("SELECT name,innprice FROM {{table}} WHERE latitude='".$userrow["latitude"]."' AND longitude='".$userrow["longitude"]."' LIMIT 1", "towns");
|
$townrow = get_town_by_xy($userrow["longitude"], $userrow["latitude"]);
|
||||||
if (mysql_num_rows($townquery) != 1) { display("Cheat attempt detected.<br /><br />Get a life, loser.", "Error"); }
|
if ($townrow === false) { display("Cheat attempt detected.<br /><br />Get a life, loser.", "Error"); }
|
||||||
$townrow = mysql_fetch_array($townquery);
|
|
||||||
|
|
||||||
if ($userrow["gold"] < $townrow["innprice"]) { display("You do not have enough gold to stay at this Inn tonight.<br /><br />You may return to <a href=\"index.php\">town</a>, or use the direction buttons on the left to start exploring.", "Inn"); die(); }
|
if ($userrow["gold"] < $townrow["innprice"]) {
|
||||||
|
display("You do not have enough gold to stay at this Inn tonight.<br /><br />You may return to <a href=\"index.php\">town</a>, or use the direction buttons on the left to start exploring.", "Inn");
|
||||||
|
}
|
||||||
|
|
||||||
if (isset($_POST["submit"])) {
|
if (isset($_POST["submit"])) {
|
||||||
|
|
||||||
$newgold = $userrow["gold"] - $townrow["innprice"];
|
$newgold = $userrow["gold"] - $townrow["innprice"];
|
||||||
$query = doquery("UPDATE {{table}} SET gold='$newgold',currenthp='".$userrow["maxhp"]."',currentmp='".$userrow["maxmp"]."',currenttp='".$userrow["maxtp"]."' WHERE id='".$userrow["id"]."' LIMIT 1", "users");
|
db()->query(
|
||||||
|
'UPDATE users SET gold=?, currenthp=?, currentmp=?, currenttp=? WHERE id=?',
|
||||||
|
[$newgold, $userrow['maxhp'], $userrow['maxmp'], $userrow['maxtp'], $userrow['id']
|
||||||
|
]);
|
||||||
$title = "Inn";
|
$title = "Inn";
|
||||||
$page = "You wake up feeling refreshed and ready for action.<br /><br />You may return to <a href=\"index.php\">town</a>, or use the direction buttons on the left to start exploring.";
|
$page = "You wake up feeling refreshed and ready for action.<br /><br />You may return to <a href=\"index.php\">town</a>, or use the direction buttons on the left to start exploring.";
|
||||||
|
|
||||||
} elseif (isset($_POST["cancel"])) {
|
} elseif (isset($_POST["cancel"])) {
|
||||||
|
redirect('index.php');
|
||||||
header("Location: index.php"); die();
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$title = "Inn";
|
$title = "Inn";
|
||||||
$page = "Resting at the inn will refill your current HP, MP, and TP to their maximum levels.<br /><br />\n";
|
$page = "Resting at the inn will refill your current HP, MP, and TP to their maximum levels.<br /><br />\n";
|
||||||
$page .= "A night's sleep at this Inn will cost you <b>" . $townrow["innprice"] . " gold</b>. Is that ok?<br /><br />\n";
|
$page .= "A night's sleep at this Inn will cost you <b>" . $townrow["innprice"] . " gold</b>. Is that ok?<br /><br />\n";
|
||||||
$page .= "<form action=\"index.php?do=inn\" method=\"post\">\n";
|
$page .= "<form action=\"index.php?do=inn\" method=\"post\">\n";
|
||||||
$page .= "<input type=\"submit\" name=\"submit\" value=\"Yes\" /> <input type=\"submit\" name=\"cancel\" value=\"No\" />\n";
|
$page .= "<input type=\"submit\" name=\"submit\" value=\"Yes\" /> <input type=\"submit\" name=\"cancel\" value=\"No\" />\n";
|
||||||
$page .= "</form>\n";
|
$page .= "</form>\n";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
display($page, $title);
|
display($page, $title);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function buy() { // Displays a list of available items for purchase.
|
function buy() { // Displays a list of available items for purchase.
|
||||||
|
|
|
@ -1,41 +1,39 @@
|
||||||
<?php
|
<?php
|
||||||
$template = <<<THEVERYENDOFYOU
|
$template = <<<HTML
|
||||||
Here is the character profile for <b>{{charname}}</b>.<br /><br />
|
Here is the character profile for <b>{{username}}</b>.<br /><br />
|
||||||
When you're finished, you may <a href="index.php">return to town</a>.<br /><br />
|
When you're finished, you may <a href="index.php">return to town</a>.<br /><br />
|
||||||
<table width="200">
|
<table width="200">
|
||||||
<tr><td class="title"><img src="images/button_character.gif" alt="Character" title="Character" /></td></tr>
|
<tr><td class="title"><img src="images/button_character.gif" alt="Character" title="Character" /></td></tr>
|
||||||
<tr><td>
|
<tr><td>
|
||||||
<b>{{charname}}</b><br /><br />
|
<b>{{username}}</b><br /><br />
|
||||||
|
|
||||||
Difficulty: {{difficulty}}<br />
|
Class: {{charclass}}<br /><br />
|
||||||
Class: {{charclass}}<br /><br />
|
|
||||||
|
|
||||||
Level: {{level}}<br />
|
Level: {{level}}<br />
|
||||||
Experience: {{experience}}<br />
|
Experience: {{experience}}<br />
|
||||||
Gold: {{gold}}<br />
|
Gold: {{gold}}<br />
|
||||||
Hit Points: {{currenthp}} / {{maxhp}}<br />
|
Hit Points: {{currenthp}} / {{maxhp}}<br />
|
||||||
Magic Points: {{currentmp}} / {{maxmp}}<br />
|
Magic Points: {{currentmp}} / {{maxmp}}<br />
|
||||||
Travel Points: {{currenttp}} / {{maxtp}}<br /><br />
|
Travel Points: {{currenttp}} / {{maxtp}}<br /><br />
|
||||||
|
|
||||||
Strength: {{strength}}<br />
|
Strength: {{strength}}<br />
|
||||||
Dexterity: {{dexterity}}<br />
|
Dexterity: {{dexterity}}<br />
|
||||||
Attack Power: {{attackpower}}<br />
|
Attack Power: {{attackpower}}<br />
|
||||||
Defense Power: {{defensepower}}<br />
|
Defense Power: {{defensepower}}<br />
|
||||||
</td></tr>
|
</td></tr>
|
||||||
</table><br />
|
</table><br />
|
||||||
|
|
||||||
<table width="200">
|
<table width="200">
|
||||||
<tr><td class="title"><img src="images/button_inventory.gif" alt="Inventory" title="Inventory" /></td></tr>
|
<tr><td class="title"><img src="images/button_inventory.gif" alt="Inventory" title="Inventory" /></td></tr>
|
||||||
<tr><td>
|
<tr><td>
|
||||||
<table width="100%">
|
<table width="100%">
|
||||||
<tr><td><img src="images/icon_weapon.gif" alt="Weapon" title="Weapon" /></td><td width="100%">Weapon: {{weaponname}}</td></tr>
|
<tr><td><img src="images/icon_weapon.gif" alt="Weapon" title="Weapon" /></td><td width="100%">Weapon: {{weaponname}}</td></tr>
|
||||||
<tr><td><img src="images/icon_armor.gif" alt="Armor" title="Armor" /></td><td width="100%">Armor: {{armorname}}</td></tr>
|
<tr><td><img src="images/icon_armor.gif" alt="Armor" title="Armor" /></td><td width="100%">Armor: {{armorname}}</td></tr>
|
||||||
<tr><td><img src="images/icon_shield.gif" alt="Shield" title="Shield" /></td><td width="100%">Shield: {{shieldname}}</td></tr>
|
<tr><td><img src="images/icon_shield.gif" alt="Shield" title="Shield" /></td><td width="100%">Shield: {{shieldname}}</td></tr>
|
||||||
</table>
|
</table>
|
||||||
Slot 1: {{slot1name}}<br />
|
Slot 1: {{slot1name}}<br />
|
||||||
Slot 2: {{slot2name}}<br />
|
Slot 2: {{slot2name}}<br />
|
||||||
Slot 3: {{slot3name}}
|
Slot 3: {{slot3name}}
|
||||||
</td></tr>
|
</td></tr>
|
||||||
</table><br />
|
</table><br />
|
||||||
THEVERYENDOFYOU;
|
HTML;
|
||||||
?>
|
|
||||||
|
|
|
@ -7,12 +7,10 @@ $template = <<<THEVERYENDOFYOU
|
||||||
<tr><td>Verify Password:</td><td><input type="password" name="password2" size="30" maxlength="10" /><br />Passwords must be 10 alphanumeric characters or less.<br /><br /><br /></td></tr>
|
<tr><td>Verify Password:</td><td><input type="password" name="password2" size="30" maxlength="10" /><br />Passwords must be 10 alphanumeric characters or less.<br /><br /><br /></td></tr>
|
||||||
<tr><td>Email Address:</td><td><input type="text" name="email1" size="30" maxlength="100" /></td></tr>
|
<tr><td>Email Address:</td><td><input type="text" name="email1" size="30" maxlength="100" /></td></tr>
|
||||||
<tr><td>Verify Email:</td><td><input type="text" name="email2" size="30" maxlength="100" />{{verifytext}}<br /><br /><br /></td></tr>
|
<tr><td>Verify Email:</td><td><input type="text" name="email2" size="30" maxlength="100" />{{verifytext}}<br /><br /><br /></td></tr>
|
||||||
<tr><td>Character Name:</td><td><input type="text" name="charname" size="30" maxlength="30" /></td></tr>
|
|
||||||
<tr><td>Character Class:</td><td><select name="charclass"><option value="1">{{class1name}}</option><option value="2">{{class2name}}</option><option value="3">{{class3name}}</option></select></td></tr>
|
<tr><td>Character Class:</td><td><select name="charclass"><option value="1">{{class1name}}</option><option value="2">{{class2name}}</option><option value="3">{{class3name}}</option></select></td></tr>
|
||||||
<tr><td>Difficulty:</td><td><select name="difficulty"><option value="1">{{diff1name}}</option><option value="2">{{diff2name}}</option><option value="3">{{diff3name}}</option></select></td></tr>
|
<tr><td colspan="2">See <a href="help.php">Help</a> for more information about character classes.<br /><br /></td></tr>
|
||||||
<tr><td colspan="2">See <a href="help.php">Help</a> for more information about character classes and difficulty levels.<br /><br /></td></tr>
|
|
||||||
<tr><td colspan="2"><input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" /></td></tr>
|
<tr><td colspan="2"><input type="submit" name="submit" value="Submit" /> <input type="reset" name="reset" value="Reset" /></td></tr>
|
||||||
</table>
|
</table>
|
||||||
</form>
|
</form>
|
||||||
THEVERYENDOFYOU;
|
THEVERYENDOFYOU;
|
||||||
?>
|
?>
|
||||||
|
|
|
@ -3,7 +3,7 @@ $template = <<<THEVERYENDOFYOU
|
||||||
<table width="100%">
|
<table width="100%">
|
||||||
<tr><td class="title"><img src="images/button_character.gif" alt="Character" title="Character" /></td></tr>
|
<tr><td class="title"><img src="images/button_character.gif" alt="Character" title="Character" /></td></tr>
|
||||||
<tr><td>
|
<tr><td>
|
||||||
<b>{{charname}}</b><br />
|
<b>{{username}}</b><br />
|
||||||
Level: {{level}}<br />
|
Level: {{level}}<br />
|
||||||
Exp: {{experience}}<br />
|
Exp: {{experience}}<br />
|
||||||
Gold: {{gold}}<br />
|
Gold: {{gold}}<br />
|
||||||
|
@ -36,4 +36,4 @@ Slot 3: {{slot3name}}
|
||||||
</td></tr>
|
</td></tr>
|
||||||
</table><br />
|
</table><br />
|
||||||
THEVERYENDOFYOU;
|
THEVERYENDOFYOU;
|
||||||
?>
|
?>
|
||||||
|
|
|
@ -3,9 +3,8 @@ $template = <<<THEVERYENDOFYOU
|
||||||
<table width="100%">
|
<table width="100%">
|
||||||
<tr><td class="title"><img src="images/button_character.gif" alt="Character" title="Character" /></td></tr>
|
<tr><td class="title"><img src="images/button_character.gif" alt="Character" title="Character" /></td></tr>
|
||||||
<tr><td>
|
<tr><td>
|
||||||
<b>{{charname}}</b><br /><br />
|
<b>{{username}}</b><br /><br />
|
||||||
|
|
||||||
Difficulty: {{difficulty}}<br />
|
|
||||||
Class: {{charclass}}<br /><br />
|
Class: {{charclass}}<br /><br />
|
||||||
|
|
||||||
Level: {{level}}<br />
|
Level: {{level}}<br />
|
||||||
|
@ -44,4 +43,4 @@ Slot 3: {{slot3name}}
|
||||||
</td></tr>
|
</td></tr>
|
||||||
</table><br />
|
</table><br />
|
||||||
THEVERYENDOFYOU;
|
THEVERYENDOFYOU;
|
||||||
?>
|
?>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user