diff --git a/contrib/shimmie_api/main.php b/contrib/shimmie_api/main.php
index b8b9bc0d..a3150372 100644
--- a/contrib/shimmie_api/main.php
+++ b/contrib/shimmie_api/main.php
@@ -6,6 +6,15 @@
* Documentation:
* Admin Warning: this exposes private data, eg IP addresses
*
Developer Warning: the API is unstable; notably, private data may get hidden
+ *
Usage:
+ *
get_tags - List of all tags. (May contain unused tags)
+ *
tags - Optional - Search for more specific tags (Searchs TAG*)
+ * get_image - Get image via id.
+ *
id - Required - User id. (Defaults to id=1 if empty)
+ * find_images - List of latest 12(?) images.
+ *
get_user - Get user info. (Defaults to id=2 if both are empty)
+ *
+ * name - Optional - User name.
*/
@@ -33,12 +42,23 @@ class ShimmieApi extends Extension {
if($event->page_matches("api/shimmie")) {
$page->set_mode("data");
$page->set_type("text/plain");
+ if(!$event->page_matches("api/shimmie/get_tags") && !$event->page_matches("api/shimmie/get_image") && !$event->page_matches("api/shimmie/find_images") && !$event->page_matches("api/shimmie/get_user")){
+ $page->set_mode("redirect");
+ $page->set_redirect(make_link("ext_doc/shimmie_api"));
+ }
- if($event->page_matches("api/shimmie/get_tags")) {
- if($event->count_args() == 2) {
+ if($event->page_matches("api/shimmie/get_tags")){
+ $arg = $event->get_arg(0);
+
+ if(!empty($arg)){
$all = $database->get_all(
"SELECT tag FROM tags WHERE tag LIKE ?",
- array($event->get_arg(0)."%"));
+ array($arg."%"));
+ }
+ elseif(isset($_GET['id'])){
+ $all = $database->get_all(
+ "SELECT tag FROM tags WHERE tag LIKE ?",
+ array($_GET['tag']."%"));
}
else {
$all = $database->get_all("SELECT tag FROM tags");
@@ -49,7 +69,16 @@ class ShimmieApi extends Extension {
}
if($event->page_matches("api/shimmie/get_image")) {
- $image = Image::by_id(int_escape($event->get_arg(0)));
+ $arg = $event->get_arg(0);
+ if(!empty($arg)){
+ $image = Image::by_id(int_escape($event->get_arg(0)));
+ }
+ elseif(isset($_GET['id'])){
+ $image = Image::by_id(int_escape($_GET['id']));
+ }
+ else{
+ $image = Image::by_id(int_escape("1")); //Default to id=1
+ }
$image->get_tag_array(); // tag data isn't loaded into the object until necessary
$safe_image = new _SafeImage($image);
$page->set_data(json_encode($safe_image));
@@ -67,6 +96,39 @@ class ShimmieApi extends Extension {
}
$page->set_data(json_encode($safe_images));
}
+
+ if($event->page_matches("api/shimmie/get_user")) {
+ if(isset($_GET['name'])){
+ $all = $database->get_all(
+ "SELECT id,name,joindate,class FROM users WHERE name=?",
+ array($_GET['name']));
+ }
+
+ if(isset($_GET['id'])){
+ $all = $database->get_all(
+ "SELECT id,name,joindate,class FROM users WHERE id=?",
+ array($_GET['id']));
+ }
+
+ if(!isset($_GET['id']) && !isset($_GET['name'])){
+ $all = $database->get_all(
+ "SELECT id,name,joindate,class FROM users WHERE id=?",
+ array("2")); //In 99% of cases, this will be the admin.
+ }
+
+ $all = $all[0];
+ //FIXME?: For some weird reason, get_all seems to return twice. Unsetting second value to make things look nice..
+ for($i=0; $i<4; $i++) unset($all[$i]);
+ /*TODO: Might be worth making it possible just to get a certain stat (Using &stat=uploadcount or something)
+ This would lessen strain on DB? */
+ $all['uploadcount'] = Image::count_images(array("user_id=".$all['id']));
+ $all['uploadperday'] = sprintf("%.1f", ($all['uploadcount'] / (((time() - strtotime($all['joindate'])) / 86400) + 1)));
+ $all['commentcount'] = $database->get_one(
+ "SELECT COUNT(*) AS count FROM comments WHERE owner_id=:owner_id",
+ array("owner_id"=>$all['id']));
+ $all['commentperday'] = sprintf("%.1f", ($all['commentcount'] / (((time() - strtotime($all['joindate'])) / 86400) + 1)));
+ $page->set_data(json_encode($all));
+ }
}
}
}
diff --git a/ext/image/main.php b/ext/image/main.php
index c999a5bc..255b6242 100644
--- a/ext/image/main.php
+++ b/ext/image/main.php
@@ -304,6 +304,12 @@ class ImageIO extends Extension {
if($handler == "merge" || isset($_GET['update'])) {
$merged = array_merge($image->get_tag_array(), $existing->get_tag_array());
send_event(new TagSetEvent($existing, $merged));
+ if(isset($_GET['rating']) && isset($_GET['update']) && file_exists("ext/rating")){
+ send_event(new RatingSetEvent($existing, $user, $_GET['rating']));
+ }
+ if(isset($_GET['source']) && isset($_GET['update'])){
+ send_event(new SourceSetEvent($existing, $_GET['source']));
+ }
return null;
}
else {