2023-09-14 05:24:02 +02:00
|
|
|
<?php
|
|
|
|
abstract class oracle {
|
|
|
|
// some info to spit out alongside the result, so the user knows
|
|
|
|
// what exactly is giving out the answer. prevents confusion
|
|
|
|
// about what oracle is answering them for ambiguous queries.
|
|
|
|
public $info = [
|
|
|
|
"name" => "some oracle"
|
|
|
|
];
|
|
|
|
// this function should take in a query string search from $_GET,
|
|
|
|
// and return a bool determining whether or not it is a question
|
|
|
|
// intended for the oracle.
|
|
|
|
public function check_query($q) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
// produce the correct answer for the query using the oracle.
|
|
|
|
// note: if it becomes apparent /during generation/ that the
|
|
|
|
// query is not in fact for the oracle, returning an empty
|
|
|
|
// string will kill the oracle pane.
|
|
|
|
// answer format: ["ans1 title" => "ans1", ...]
|
|
|
|
public function generate_response($q) {
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
}
|
2023-09-15 02:10:13 +02:00
|
|
|
// backwards compatibility
|
|
|
|
if (!function_exists('str_starts_with')) {
|
|
|
|
function str_starts_with($haystack, $needle) {
|
|
|
|
return strncmp($haystack, $needle, strlen($needle)) === 0;;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!function_exists('str_contains')) {
|
|
|
|
function str_contains($haystack, $needle) {
|
|
|
|
return strpos((string)$haystack, (string)$needle) !== false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-09-14 05:24:02 +02:00
|
|
|
?>
|