i guess
This commit is contained in:
MallocNull 2014-07-18 16:22:05 -05:00
parent 7be5dd1e36
commit 32d4fc69fc
3 changed files with 288 additions and 6 deletions

View file

@ -101,6 +101,8 @@ namespace bot {
Console.WriteLine(_G.propername + " has started successfully.");
DateTime lastAction = new DateTime(0);
while(Chat.isChatting(_G.driver)) {
Message msg = Chat.waitForNewMessage(_G.driver);
if(msg == null) break;
@ -112,15 +114,19 @@ namespace bot {
Bot.loadResponseList();
Chat.sendMessage("response list updated");
}
foreach(Response response in responseList)
response.triggerResponse(msg);
foreach(Response response in responseList) {
if((DateTime.Now - lastAction).TotalSeconds >= _G.defaultCooldown) {
if(response.triggerResponse(msg)) lastAction = DateTime.Now;
}
}
}
_G.stopAllThreads();
Console.WriteLine("Restarting bot ...");
} catch(Exception err) {
_G.criticalError("Main thread experienced unexpected fatal error! Details: "+ err.Message +" in "+ err.StackTrace, true);
_G.criticalError("Main thread experienced unexpected fatal error! Details: "+ err.Message +" "+ err.StackTrace, true);
}
}
}

View file

@ -34,14 +34,19 @@ namespace bot {
this.lastCall = new DateTime(0);
}
public void triggerResponse(Message msg) {
public bool triggerResponse(Message msg) {
if(cooldown != -1) {
if((DateTime.Now - lastCall).TotalSeconds < cooldown)
return;
return false;
}
if(msg.name.ToLower() != _G.username.ToLower()) {
if(conditions.calculateValue(msg)) ResponseCaller.callResponse(responseType, parameters, msg);
if(conditions.calculateValue(msg)) {
ResponseCaller.callResponse(responseType, parameters, msg);
lastCall = DateTime.Now;
return true;
}
}
return false;
}
}
}

271
www/auto.php Normal file
View file

@ -0,0 +1,271 @@
<?php include("conn.php");
if($_GET['del']) {
mysql_query("DELETE FROM `autonomous` WHERE `id`=".$_GET['del']);
header("Location: auto.php");
}
if($_POST["editId"]) {
// TODO update this
mysql_query("UPDATE `responses` SET `conditions`='". mysql_real_escape_string($c) ."', `respid`=". $_POST['resptype'] .", `parameters`='". mysql_real_escape_string($_POST['parameters']) ."', `cooldown`=". (($_POST['cdd']==0)?-1:$_POST['cooldown']) ." WHERE `id`=". $_POST['editId']) or die(mysql_error());
mysql_query("UPDATE `updater` SET `autonomous`=1 WHERE `id`=1");
header("Location: auto.php");
}
if($_POST["resptype"] && !$_POST["editId"]) {
$c = "";
for($i=1;;$i++) {
if(!isset($_POST["if". $i ."param"])) break;
$c .= $_POST['if'.$i.'lpar'].",".$_POST['if'.$i.'not'].",".$_POST['if'.$i.'cond'].",".$_POST['if'.$i.'param'].",".$_POST['if'.$i.'rpar'].";";
if(isset($_POST["op".$i])) $c .= $_POST["op".$i] .";";
}
mysql_query("INSERT INTO `responses` (`conditions`,`respid`,`parameters`,`cooldown`) VALUES ('". mysql_real_escape_string($c) ."',". $_POST['resptype'] .",'". mysql_real_escape_string($_POST['parameters']) ."',". (($_POST['ccd']==0)?-1:$_POST['cooldown']) .")") or die(mysql_error());
mysql_query("UPDATE `updater` SET `responses`=1 WHERE `id`=1");
header("Location: auto.php");
}
include("header.php");
?>
<script type="text/javascript">
/*var defaultCool = <?php echo $config->cooldown; ?>;
function confirmDeletion(id) {
var q = confirm("Are you sure you want to delete this response?");
if(q) window.location.href = "resp.php?del="+id;
}*/
function handleRespChange() {
document.getElementById("respDesc").innerHTML = document.getElementById(""+document.getElementById("resptype").selectedIndex).innerHTML;
}
/*function coolChange() {
if(document.getElementById("cdd").selectedIndex == 0) {
document.getElementById("cooldown").disabled = true;
document.getElementById("cooldown").value = defaultCool;
} else
document.getElementById("cooldown").disabled = false;
}*/
</script>
<center>
<fieldset class="wide" style="padding-bottom: 0;">
<?php if(!$_GET["do"]) { ?>
<legend>Autonomy List</legend>
<p style="margin-top: 0;"><a href="auto.php?do=new">New Autonomous Routine</a></p>
<center>
<?php
$q = mysql_query("SELECT * FROM `auto`");
// TODO update this
/*while($resp = mysql_fetch_object($q)) {
echo "
<table border='0' style='width:790px;border:1px solid black;margin:5px;'>
<tr>
<td style='width:50px;text-align:center;verticle-align:middle;'>
<a href='resp.php?do=edit&id=". $resp->id ."' style='verticle-align: middle;'><img src='img/edit.png' border='0' /></a>
&nbsp;<img src='img/delete.png' border='0' class='fakelink' onclick='confirmDeletion(". $resp->id .");' />
</td>
<td>
". parseConditionString($resp->conditions, mysql_fetch_object(mysql_query("SELECT * FROM `resptypes` WHERE `id`=". $resp->respid))->friendlyname) ."
</td>
</tr>
</table>";
}*/
?>
</center>
<?php } else if($_GET["do"]=="new") { ?>
<legend>Create New Autonomous Routine</legend>
<form method="post" action="" id="auto">
<p>
</p>
<p>
then
<select name="resptype" id="resptype" onchange="handleRespChange();">
<?php
$q = mysql_query("SELECT * FROM `resptypes`");
$descarr = array();
for($i = 0;;$i++) {
$type = mysql_fetch_object($q);
if(!$type) break;
echo "<option value='". $type->id ."'>". $type->friendlyname ."</option>";
$descarr[$i] = $type->description;
}
?>
</select>
<?php
$i = 0;
foreach($descarr as $desc) {
echo "<p style='display:none;' id='$i'>". $desc ."</p>";
$i++;
}
?>
</p>
<p>
<span class="block" id="respDesc">
<?php echo $descarr[0]; ?>
</span>
<span class="block">Parameters:
<center>
<textarea name="parameters" rows="8" style="width:95%;"></textarea>
</center></span>
</p>
<p>
Cooldown:
<select name="cdd" id="cdd" onchange="coolChange();">
<option value="0">Default</option>
<option value="1">Custom</option>
</select>
<input type="textbox" name="cooldown" id="cooldown" size="6" value="<?php echo $config->cooldown; ?>" disabled="disabled" /> seconds
</p>
<p>
<input type="button" name="addResponse" value="Add Response" onclick="evaluateCondition();" />
&nbsp;&nbsp;&nbsp;&nbsp;
<input type="button" value="Cancel" onclick="window.location.href = 'resp.php';" />
</p>
</form>
<?php } else if($_GET["do"]=="edit") {
$response = mysql_fetch_object(mysql_query("SELECT * FROM `responses` WHERE `id`=".$_GET['id']));
?>
<legend>Edit Response</legend>
<form method="post" action="" id="resp">
<p>
If
<span id="ifholder">
<?php
$conds = mysql_fetch_object(mysql_query("SELECT * FROM `responses` WHERE `id`=". $_GET['id']))->conditions;
$conds = explode(";",$conds);
$conds = array_slice($conds, 0, count($conds)-1);
$on = 1;
foreach($conds as $cond) {
$tk = explode(",",$cond);
if(count($tk) > 3) { ?>
<span id="if<?php echo $on; ?>" class="block">
<select name="if<?php echo $on; ?>lpar">
<?php
for($i = 0; $i < 6; $i++) {
echo "<option value=\"$i\"";
if($i==intval($tk[0]))
echo " selected='selected'";
echo ">";
for($j = 0; $j < $i; $j++)
echo "(";
echo "</option>";
}
?>
</select>
<select name="if<?php echo $on; ?>not">
<option value="0"></option>
<option value="1"<?php if(intval($tk[1])==1) { ?> selected="selected"<?php } ?>>not</option>
</select>
<select name="if<?php echo $on; ?>cond">
<?php
$q = mysql_query("SELECT * FROM `conditions`");
while($cond = mysql_fetch_object($q)) {
echo "<option value='". $cond->id ."'";
if($cond->id == intval($tk[2]))
echo " selected='selected'";
echo ">". $cond->friendlyname ."</option>";
}
?>
</select>
<input type="text" name="if<?php echo $on; ?>param" value="<?php echo escapeDoubleQuotes($tk[3]); ?>" />
<select name="if<?php echo $on; ?>rpar">
<?php
for($i = 0; $i < 6; $i++) {
echo "<option value=\"$i\"";
if($i==intval($tk[4]))
echo " selected='selected'";
echo ">";
for($j = 0; $j < $i; $j++)
echo ")";
echo "</option>";
}
?>
</select>
<img src='img/arrow_up.png' class='fakelink' style='vertical-align: text-bottom;' onclick='handleRowUp(<?php echo $on; ?>);' />
<img src='img/arrow_down.png' class='fakelink' style='vertical-align: text-bottom;' onclick='handleRowDown(<?php echo $on; ?>);' />
<img src='img/delete.png' class='fakelink' style='vertical-align: text-bottom;' onclick='handleRowDelete(<?php echo $on; ?>);' />
</span>
<?php for($i = 0; $i < intval($tk[0]); $i++)
$ret .= "(";
if($tk[1] == "1")
$ret .= "not ";
$ret .= $condtypes[intval($tk[2])] ." ". $tk[3];
for($i = 0; $i < intval($tk[4]); $i++)
$ret .= ")";
$ret .= " ";
$i++;
} else { ?>
<span id="op<?php echo $i; ?>">
<select name='op<?php echo $i; ?>'>
<option value='0'>and</option>
<option value='1'<?php if(intval($tk[0]==1)) { ?> selected="selected" <?php } ?>>or</option>
</select>
</span>
<?php }
}
?>
</span>
<span class="block">
<a href="javascript:addCondition();">Add Condition</a>
</span>
</p>
<p>
then
<select name="resptype" id="resptype" onchange="handleRespChange();">
<?php
$q = mysql_query("SELECT * FROM `resptypes`");
$descarr = array();
for($i = 0;;$i++) {
$type = mysql_fetch_object($q);
if(!$type) break;
echo "<option value='". $type->id ."'";
if($type->id==$response->respid)
echo " selected='selected'";
echo ">". $type->friendlyname ."</option>";
$descarr[$i] = $type->description;
}
?>
</select>
<?php
$i = 0;
foreach($descarr as $desc) {
echo "<p style='display:none;' id='$i'>". $desc ."</p>";
$i++;
}
?>
</p>
<p>
<span class="block" id="respDesc">
<?php
echo $d = mysql_fetch_object(mysql_query("SELECT * FROM `resptypes` WHERE `id`=". $response->respid))->description;
?>
</span>
<span class="block">Parameters:
<center>
<textarea name="parameters" rows="8" style="width:95%;"><?php echo $response->parameters; ?></textarea>
</center>
</span>
</p>
<p>
Cooldown:
<select name="cdd" id="cdd" onchange="coolChange();">
<option value="0">Default</option>
<option value="1"<?php if($response->cooldown != -1) { ?> selected="selected"<?php } ?>>Custom</option>
</select>
<input type="textbox" name="cooldown" id="cooldown" size="6" value="<?php if($response->cooldown == -1) echo $config->cooldown; else echo $response->cooldown; ?>"<?php if($response->cooldown == -1) { ?> disabled="disabled"<?php } ?> /> seconds
</p>
<p>
<input type="button" name="editResponse" value="Edit Response" onclick="evaluateCondition();" />
<input type="hidden" name="editId" value="<?php echo $_GET['id']; ?>" />
&nbsp;&nbsp;&nbsp;&nbsp;
<input type="button" value="Cancel" onclick="window.location.href = 'resp.php';" />
</p>
</form>
<script type="text/javascript">
redrawList();
</script>
<?php } ?>
</fieldset>
</center>
<?php include("footer.php"); ?>