summaryrefslogtreecommitdiffstats
path: root/application/controllers/api.php
diff options
context:
space:
mode:
authorFlorian Pritz <bluewind@xinu.at>2014-10-26 21:39:58 +0100
committerFlorian Pritz <bluewind@xinu.at>2015-01-16 17:38:38 +0100
commit349e9f6dc7da0c44ee80d0a73963c1c5cef87131 (patch)
treeecde4a60e67e4de5c40f4d11db5d49ef3c1df9ca /application/controllers/api.php
parentd59962443687127ea1defc2f8ac41af1c2c02fe4 (diff)
misc
Signed-off-by: Florian Pritz <bluewind@xinu.at>
Diffstat (limited to 'application/controllers/api.php')
-rw-r--r--application/controllers/api.php28
1 files changed, 21 insertions, 7 deletions
diff --git a/application/controllers/api.php b/application/controllers/api.php
index 626e7b91a..a7bd09f34 100644
--- a/application/controllers/api.php
+++ b/application/controllers/api.php
@@ -19,20 +19,34 @@ class Api extends MY_Controller {
public function route() {
$requested_version = $this->uri->segment(2);
- $function = $this->uri->segment(3);
+ $controller = $this->uri->segment(3);
+ $function = $this->uri->segment(4);
$major = intval(explode(".", $requested_version)[0]);
- $class = "controllers\\api\\v".$major;
-
- if (!class_exists($class) || version_compare($class::get_version(), $requested_version, "<")) {
- return send_json_error_reply("Requested API version is not supported");
+ if (!preg_match("/^[a-zA-Z-_]+$/", $controller)) {
+ return send_json_error_reply("Invalid controller requested");
}
if (!preg_match("/^[a-zA-Z-_]+$/", $function)) {
return send_json_error_reply("Invalid function requested");
}
- $controller = new $class;
- return $controller->$function();
+ $namespace = "controllers\\api\\v".$major;
+ $class = $namespace."\\".$controller;
+ $class_info = $namespace."\\api_info";
+
+ if (!class_exists($class_info) || version_compare($class_info::get_version(), $requested_version, "<")) {
+ return send_json_error_reply("Requested API version is not supported");
+ }
+
+ if (!class_exists($class)) {
+ return send_json_error_reply("Unknown controller requested");
+ }
+
+ $c= new $class;
+ if (!method_exists($c, $function)) {
+ return send_json_error_reply("Unknown function requested");
+ }
+ return $c->$function();
}
}