Last active
December 16, 2015 21:29
-
-
Save KaeruCT/5500114 to your computer and use it in GitHub Desktop.
choose your own adventure (really tightly coupled to board software)
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| <?php | |
| // By Kaeru~ | |
| require('lib/common.php'); | |
| $sql = new mysql; | |
| if(!@$sql->connect($sqlhost,$sqluser,$sqlpass)) | |
| { | |
| mysqlerror(); | |
| } | |
| if(!@$sql->selectdb('nwwebde1_myoa')) | |
| { | |
| mysqlerror(); | |
| } | |
| /*if($_GET['lol']=='yes') | |
| { | |
| $sql->query('TRUNCATE TABLE g_opts'); | |
| $sql->query('TRUNCATE TABLE g_stages'); | |
| $sql->query('TRUNCATE TABLE g_rep'); | |
| $sql->query('INSERT INTO g_stages SET text = "You are standing in an open field west of a white house, with a boarded front door. | |
| There is a small mailbox here. | |
| What will you do?"'); | |
| $sql->query('INSERT INTO g_opts SET stage = 1, text = "Enter house"'); | |
| $sql->query('INSERT INTO g_opts SET stage = 1, text = "Open mailbox"'); | |
| $sql->query('INSERT INTO g_opts SET stage = 1, text = "Walk away"'); | |
| print 'queries done'; | |
| }*/ | |
| function branch($stage) | |
| { | |
| global $sql; | |
| $tree = array(); | |
| $opts = $sql->query('SELECT * FROM g_opts WHERE stage = '.$stage); | |
| $stage = $sql->fetchq('SELECT * FROM g_stages WHERE id = '.$stage); | |
| $tree['text'] = $stage['text']; | |
| $tree['opts'] = array(); | |
| while($opt = $sql->fetch($opts)) | |
| { | |
| $tree['opts'][$opt['id']] = array('opt' => $opt['text'], 'branch' => branch($opt['to'])); | |
| } | |
| return $tree; | |
| } | |
| function loosends($stage, &$num) | |
| { | |
| global $sql, $visited; | |
| if (!$visited) $visited = array(); | |
| if (in_array($stage, $visited)) { | |
| return ''; | |
| } | |
| $visited[] = $stage; | |
| $out = ''; | |
| $opts = $sql->query('SELECT * FROM g_opts WHERE stage = '.$stage); | |
| while($opt = $sql->fetch($opts)) | |
| { | |
| if(!$opt['to']) | |
| { | |
| $num++; | |
| $out .= '<li><a href="game.php?option='.$opt['id'].'">'.$opt['text'].'</a></li>'; | |
| } | |
| else | |
| $out .= loosends($opt['to'], $num); | |
| } | |
| return $out; | |
| } | |
| function branchp($arr) | |
| { | |
| $out = '<div class="tree" style="display: none;">'; | |
| $out .= '<p>'.($arr['text']?nl2br(htmlval($arr['text'])):'This part of the story isn\'t done yet!').'</p>'; | |
| foreach($arr['opts'] as $k => $v) | |
| { | |
| if(is_array($v)) | |
| { | |
| $out .= '<div class="tog" onclick="$(this).next().slideToggle();">'.$v['opt'].'</div>'; | |
| $out .= branchp($v['branch']); | |
| } | |
| } | |
| $out .= '</div>'; | |
| return $out; | |
| } | |
| $links = '<a href="game.php?loose">Loose ends</a> | <a href="game.php">Beginning</a>'; | |
| $option = isset($_GET['option'])?intval($_GET['option']):0; | |
| $from = isset($_GET['from'])?intval($_GET['from']):0; | |
| $action = isset($_POST['action'])?$_POST['action']:''; | |
| $rep = isset($_GET['report'])?intval($_GET['report']):0; | |
| $msg = $link = $title = ''; | |
| if($rep) | |
| { | |
| if($sql->resultq('SELECT COUNT(*) FROM g_stages WHERE id = "'.$rep.'"')>0) | |
| { | |
| $option = $sql->resultq('SELECT id FROM g_opts WHERE `to` = "'.$rep.'"'); | |
| if($sql->resultq('SELECT COUNT(*) FROM g_rep WHERE stage = "'.$rep.'" AND user = "'.$loguser['id'].'"')>0) | |
| { | |
| $msg = 'You already reported this setting!'; | |
| } | |
| else | |
| { | |
| $sql->query('REPLACE INTO g_rep SET stage = "'.$rep.'", user = "'.$loguser['id'].'"'); | |
| $msg = 'This setting has been reported!'; | |
| } | |
| $msg .= '<br /><a href="game.php?option='.$option.'">Go back</a>'; | |
| } | |
| else | |
| $msg = 'This setting doesn\'t even exist!<br /><a href="game.php">Go back</a>'; | |
| } | |
| elseif($option!=0) | |
| { | |
| $option = $sql->fetchq('SELECT * FROM g_opts WHERE id = "'.$option.'"'); | |
| $link = '<a href="game.php">Go back to start</a>'; | |
| } | |
| else | |
| $option = array('id' => 0, 'to' => 1, 'stage' => 0, 'text' => 'The Beginning'); | |
| if(isset($_GET['branch'])) | |
| { | |
| $title = 'Branch'; | |
| $tree = branch(1); | |
| $msg = '<div class="tog" onclick="$(this).next().slideDown();">Start!</div>'.branchp($tree); | |
| } | |
| elseif(isset($_GET['loose'])) | |
| { | |
| $num = 0; | |
| $msg = '<ol>'.loosends(1, $num).'</ol>'; | |
| $title = 'Loose ends ('.$num.')'; | |
| } | |
| elseif($action) | |
| { | |
| switch($action) | |
| { | |
| case 'newsetting': | |
| $num = isset($_POST['numopts'])?intval($_POST['numopts']):2; | |
| $optid = isset($_POST['optid'])?intval($_POST['optid']):0; | |
| if($num>4) $num = 4; | |
| if($num<1) $num = 1; | |
| if($optid) | |
| { | |
| $opt = $sql->fetchq('SELECT * FROM g_opts WHERE id = "'.$_POST['optid'].'"'); | |
| $msg = ' | |
| <form method="post" action="game.php"><input type="hidden" name="optid" value="'.$_POST['optid'].'"><input type="hidden" name="numopts" value="'.$num.'"><input type="hidden" name="action" value="submitsetting"><table> | |
| <tr><th colspan="2">Setting for "'.$opt['text'].'" option</th></tr> | |
| <tr><td width="150px"><label for="setting">Setting:</label></td><td><textarea id="setting" name="setting" cols="80" rows="5"></textarea></td></tr>'; | |
| for($i=1;$i<=$num;$i++) | |
| $msg.= '<tr><td><label for="opt'.$i.'">Option '.$i.':</label></td><td><input type="text" id="opt'.$i.'" name="opt'.$i.'"></td></tr> | |
| '; | |
| $msg .= '<tr><td> </td><td><input type="submit" value="Submit"></td></tr> | |
| </table></form>'; | |
| } | |
| else | |
| $msg = 'No option ID was specified.'; | |
| break; | |
| case 'submitsetting': | |
| $num = isset($_POST['numopts'])?intval($_POST['numopts']):2; | |
| if($num>=4) $num = 4; | |
| if($num<1) $num = 1; | |
| $text = isset($_POST['setting'])?trim($_POST['setting']):''; | |
| $optid = isset($_POST['optid'])?intval($_POST['optid']):0; | |
| $err = array(); | |
| if(!$text) | |
| { | |
| $err[] = 'You didn\'t fill the "setting" field.'; | |
| } | |
| if(!$optid) | |
| { | |
| $err[] = 'No option ID was specified.'; | |
| } | |
| if($sql->resultq('SELECT COUNT(id) FROM g_opts WHERE id = "'.$optid.'"') == 0) | |
| { | |
| $err[] = 'No option with that ID exists.'; | |
| } | |
| else | |
| { | |
| $opt = $sql->fetchq('SELECT * FROM g_opts WHERE id = "'.$optid.'"'); | |
| if($opt['to']!=0) | |
| $err[] = 'Someone submitted the option before you did!'; | |
| } | |
| for($i=1;$i<=$num;$i++) | |
| { | |
| if(!trim($_POST['opt'.$i])) | |
| { | |
| $err[] = 'You didn\'t fill all the options.'; | |
| break; | |
| } | |
| } | |
| if(!$err[0]) | |
| { | |
| $sql->query('INSERT INTO g_stages SET text = "'.$text.'", user = "'.$loguser['id'].'"'); | |
| $stageid = mysql_insert_id(); | |
| $sql->query('UPDATE g_opts SET `to` = "'.$stageid.'" WHERE id = "'.$optid.'"'); | |
| for($i=1;$i<=$num;$i++) | |
| $sql->query('INSERT INTO g_opts SET stage = '.$stageid.', text = "'.$_POST['opt'.$i].'"'); | |
| sendirc('New option submitted by '.$loguser['name'].'! {boardurl}game.php?option='.$optid); | |
| $msg = 'Option submitted succesfully!<br /><a href="game.php?option='.$optid.'">Go back where you ended!</a>'; | |
| } | |
| else | |
| { | |
| $msg = 'The following error'.(sizeof($err)==1?'':'s').' occured:<ul><li>'.implode('</li><li>', $err).'</li></ul>'; | |
| } | |
| break; | |
| case 'ending': | |
| $text = isset($_POST['ending'])?trim($_POST['ending']):''; | |
| $optid = isset($_POST['optid'])?intval($_POST['optid']):0; | |
| if(!$text) | |
| { | |
| $err[] = 'You didn\'t fill the "ending" field.'; | |
| } | |
| if(!$optid) | |
| { | |
| $err[] = 'No option ID was specified.'; | |
| } | |
| if($sql->resultq('SELECT COUNT(id) FROM g_opts WHERE id = "'.$optid.'"') == 0) | |
| { | |
| $err[] = 'No option with that ID exists.'; | |
| } | |
| if(!$err[0]) | |
| { | |
| $sql->query('INSERT INTO g_stages SET text = "'.$text.'", user = "'.$loguser['id'].'"'); | |
| $stageid = mysql_insert_id(); | |
| $sql->query('UPDATE g_opts SET `to` = "'.$stageid.'" WHERE id = "'.$optid.'"'); | |
| sendirc('An ending was submitted by '.$loguser['name'].'! {boardurl}game.php?option='.$optid); | |
| $msg = 'Ending submitted succesfully!<br /><a href="game.php?option='.$optid.'">Go back where you ended!</a>'; | |
| } | |
| else | |
| { | |
| $msg = 'The following error'.(sizeof($err)==1?'':'s').' occured:<ul><li>'.implode('</li><li>', $err).'</li></ul>'; | |
| } | |
| break; | |
| case 'link': | |
| $setid = isset($_POST['settingid'])?intval($_POST['settingid']):0; | |
| $optid = isset($_POST['optid'])?intval($_POST['optid']):0; | |
| if(!$setid) | |
| { | |
| $err[] = 'You didn\'t fill the "setting ID" field.'; | |
| } | |
| if(!$optid) | |
| { | |
| $err[] = 'No option ID was specified.'; | |
| } | |
| if($sql->resultq('SELECT COUNT(id) FROM g_opts WHERE id = "'.$optid.'"') == 0) | |
| { | |
| $err[] = 'No option with that ID exists.'; | |
| } | |
| if($sql->resultq('SELECT COUNT(id) FROM g_stages WHERE id = "'.$setid.'"') == 0) | |
| { | |
| $err[] = 'No setting with that ID exists.'; | |
| } | |
| if(!$err[0]) | |
| { | |
| $sql->query('UPDATE g_opts SET `to` = "'.$setid.'" WHERE id = "'.$optid.'"'); | |
| sendirc('New option submitted by '.$loguser['name'].'! {boardurl}game.php?option='.$optid); | |
| $msg = 'Link to existing setting submitted succesfully!<br /><a href="game.php?option='.$optid.'">Go back where you ended!</a>'; | |
| } | |
| else | |
| { | |
| $msg = 'The following error'.(sizeof($err)==1?'':'s').' occured:<ul><li>'.implode('</li><li>', $err).'</li></ul>'; | |
| } | |
| break; | |
| } | |
| } | |
| elseif(!$msg) | |
| { | |
| $settingid = ''; | |
| if(!$option) | |
| { | |
| $msg = 'This option doesn\'t even exist!'; | |
| } | |
| elseif(!$option['to']) | |
| { | |
| $title = $option['text']; | |
| $msg = '<p>This part of the story isn\'t done yet. You can either continue the story, or end it here.</p> | |
| <div> | |
| <a href="#" onclick="$(\'#end\').slideUp(); $(\'#link\').slideUp(); $(\'#continue\').slideDown(); return false;">Continue</a> | | |
| <a href="#" onclick="$(\'#end\').slideUp(); $(\'#continue\').slideUp(); $(\'#link\').slideDown(); return false;">Link to an existing setting</a> | | |
| <a href="#" onclick="$(\'#continue\').slideUp(); $(\'#link\').slideUp(); $(\'#end\').slideDown(); return false;">End</a></div> | |
| <div id="continue" style="display: none;"><form method="post" action="game.php"><input type="hidden" name="optid" value="'.$option['id'].'"><input type="hidden" name="action" value="newsetting"><table> | |
| <tr><th colspan="2">Continue the story</th></tr> | |
| <tr><td width="150px"><label for="numopts">Number of options:<br>(max: 4)</label></td><td><input type="text" id="numopts" name="numopts" size="2" maxlength="1"></td></tr> | |
| <tr><td> </td><td><input type="submit" value="Submit"></td></tr> | |
| </table></form></div> | |
| <div id="end" style="display: none;"><form method="post" action="game.php"><input type="hidden" name="optid" value="'.$option['id'].'"><input type="hidden" name="action" value="ending"><table> | |
| <tr><th colspan="2">End it here</th></tr> | |
| <tr><td width="150px"><label for="ending">Ending text:</label></td><td><textarea id="ending" name="ending" cols="80" rows="5"></textarea></td></tr> | |
| <tr><td> </td><td><input type="submit" value="Submit"></td></tr> | |
| </table></form></div> | |
| <div id="link" style="display: none;"><form method="post" action="game.php"><input type="hidden" name="optid" value="'.$option['id'].'"><input type="hidden" name="action" value="link"><table> | |
| <tr><th colspan="2">Link to an existing setting</th></tr> | |
| <tr><td colspan="2">*The setting ID appears at the bottom of each setting.</td></tr> | |
| <tr> | |
| <td width="150px"><label for="settingid">Setting ID:</label></td> | |
| <td><input type="text" name="settingid" id="settingid" size="4" maxlength="4"></td | |
| </tr> | |
| <tr><td> </td><td><input type="submit" value="Submit"></td></tr> | |
| </table></form></div>'; | |
| } | |
| else | |
| { | |
| $setting = $sql->fetchq('SELECT * FROM g_stages WHERE id = "'.$option['to'].'"'); | |
| $opts = $sql->query('SELECT * FROM g_opts WHERE stage = "'.$option['to'].'"'); | |
| $title = $option['text']; | |
| $l = array(); | |
| while($opt = $sql->fetch($opts)) | |
| { | |
| $msg .= '<li><a href="game.php?option='.$opt['id'].'&from='.$setting['id'].'">'.htmlentities($opt['text']).'</a></li>'; | |
| } | |
| if(!$msg) | |
| { | |
| $msg = '<h2>THE END</h2><a href="game.php">Go back to the beginning</a>.'; | |
| } | |
| else $msg = '<ul>'.$msg.'</ul>'; | |
| } | |
| if($setting['text'] != ''){ | |
| $settingid = '<small>This setting\'s ID is: <b>'.$setting['id'].'</b></small>'; | |
| } | |
| $msg = '<div><div id="setting">'.nl2br(htmlval($setting['text'])).'</div><div id="opts">'.$msg.'</div>'.$settingid.'</div>'; | |
| if($option['stage']) | |
| { | |
| if(!$from) | |
| { | |
| $option = $sql->resultq('SELECT id FROM g_opts WHERE `to` = "'.$option['stage'].'" ORDER BY id ASC LIMIT 1'); | |
| }else{ | |
| $option = $from; | |
| } | |
| $l[] = '<a href="game.php'.($option?'?option='.$option:'').'">Go back to previous setting</a>'; | |
| } | |
| if($setting['user']) | |
| { | |
| $user = $sql->fetchq('SELECT name,sex,power,color,id FROM users WHERE id = '.$setting['user']); | |
| } | |
| /*if($log) | |
| $l[] = '<a href="game.php?report='.$setting['id'].'">Report</a>';*/ | |
| if($l[0]) | |
| $links .= ' | '.implode(' | ', $l); | |
| } | |
| ?> | |
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" | |
| "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | |
| <html xmlns="http://www.w3.org/1999/xhtml"> | |
| <head> | |
| <title><?=$title?></title> | |
| <meta http-equiv="Content-Type" content="text/html;charset=utf-8" /> | |
| <meta name="Author" content="Kaeru" /> | |
| <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js"></script> | |
| <style type="text/css"> | |
| body{color: #444; font-family: "Droid Sans", Tahoma, sans-serif; background: #fff url(%3D%3D)} | |
| #wrap {max-width: 800px; margin: 0 auto;} | |
| div#main{background: #eee; box-shadow: #000 1px 1px 3px; border-radius: 2px; padding: 16px;} | |
| div.t {background: #444; border: #666 1px solid; padding: 10px; color: #eee;} | |
| div.t > div {padding: 10px;} | |
| p.sm{font-size: .8em} | |
| div.tree{padding: 4px; border: #aaa 1px solid; background: url('theme/fragment/tdbg3.png')} | |
| div.tog{font-weight: bold; cursor: pointer; margin: 4px;} | |
| a:link{color:#333; font-weight: bold; text-decoration: none;} | |
| a:visited{color:#333; font-weight: bold; text-decoration: none;} | |
| a:active{color:#222; text-decoration: none;} | |
| a:hover{color:#111;text-decoration: underline;} | |
| form{display: inline;} | |
| table{width: 100%; margin: 20px 0;} | |
| textarea,input[type=text] {border: #888 1px solid; padding: 4px;} | |
| </style> | |
| </head> | |
| <body> | |
| <div id="wrap"> | |
| <h1><?=$title?></h1> | |
| <p class="sm"><?=$links?></p> | |
| <div id="main"> | |
| <?=$msg?> | |
| </div> | |
| </div> | |
| <!--<div><small>By Kaeru~<br /><?=pagestats();?></small></div>--> | |
| </body> | |
| </html> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment