diff options
-rw-r--r-- | engine/lib/input.php | 26 | ||||
-rw-r--r-- | engine/lib/pagehandler.php | 17 |
2 files changed, 40 insertions, 3 deletions
diff --git a/engine/lib/input.php b/engine/lib/input.php index c1b575e64..8cbea6986 100644 --- a/engine/lib/input.php +++ b/engine/lib/input.php @@ -23,9 +23,31 @@ if (isset($_REQUEST[$variable])) {
$value = $_REQUEST[$variable]; return trim($_REQUEST[$variable]);
- } + }
+
+ global $CONFIG;
+
+ if (isset($CONFIG->input[$variable]))
+ return $CONFIG->input[$variable]; return $default;
- } + }
+
+ /**
+ * Sets an input value that may later be retrieved by get_input
+ *
+ * @param string $variable The name of the variable
+ * @param string $value The value of the variable
+ */
+ function set_input($variable, $value) {
+
+ global $CONFIG;
+ if (!isset($CONFIG->input))
+ $CONFIG->input = array();
+ $CONFIG->input[trim($variable)] = trim($value);
+
+ }
+
+ ?>
\ No newline at end of file diff --git a/engine/lib/pagehandler.php b/engine/lib/pagehandler.php index b5bb831db..267d34bd2 100644 --- a/engine/lib/pagehandler.php +++ b/engine/lib/pagehandler.php @@ -22,6 +22,21 @@ global $CONFIG;
+ $query = parse_url($_SERVER['REQUEST_URI']);
+ if (isset($query['query'])) {
+ $query = $query['query'];
+ $query = rawurldecode($query);
+ $query = explode('&',$query);
+ if (sizeof($query) > 0) {
+ foreach($query as $queryelement) {
+ $vals = explode('=',$queryelement);
+ if (sizeof($vals) > 1) {
+ set_input(trim($vals[0]),trim($vals[1]));
+ }
+ }
+ }
+ }
+
$page = explode('/',$page);
if (!isset($CONFIG->pagehandler) || empty($handler)) {
$result = false;
@@ -38,7 +53,7 @@ if (!$result) {
$result = default_page_handler($page, $handler);
}
- if ($result !== false) $result = true;
+ if ($result !== false) $result = true;
return $result;
|