* Description: A JSON interface to shimmie data [WARNING] * 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) *

*

get_image - Get image via id. *

*

find_images - List of latest 12(?) images. *

get_user - Get user info. (Defaults to id=2 if both are empty) *

* */ class _SafeImage { #{"id":"2","height":"768","width":"1024","hash":"71cdfaabbcdad3f777e0b60418532e94","filesize":"439561","filename":"HeilAmu.png","ext":"png","owner_ip":"0.0.0.0","posted":"0000-00-00 00:00:00","source":null,"locked":"N","owner_id":"0","rating":"u","numeric_score":"0","text_score":"0","notes":"0","favorites":"0","posted_timestamp":-62169955200,"tag_array":["cat","kunimitsu"]} function __construct(Image $img) { $this->id = $img->id; $this->height = $img->height; $this->width = $img->width; $this->hash = $img->hash; $this->filesize = $img->filesize; $this->ext = $img->ext; $this->posted = $img->posted_timestamp; $this->source = $img->source; $this->owner_id = $img->owner_id; $this->tags = $img->tag_array; } } class ShimmieApi extends Extension { public function onPageRequest(PageRequestEvent $event) { global $database, $page; if($event->page_matches("api")) { $page->set_mode("data"); $page->set_type("text/plain"); if(!$event->page_matches("api/get_tags") && !$event->page_matches("api/get_image") && !$event->page_matches("api/find_images") && !$event->page_matches("api/get_user")){ $page->set_mode("redirect"); $page->set_redirect(make_link("ext_doc/shimmie_api")); } if($event->page_matches("api/get_tags")) { if(isset($_GET['tag'])) { $all = $database->get_all( "SELECT tag FROM tags WHERE tag LIKE ?", array($_GET['tag']."%")); } else { $all = $database->get_all("SELECT tag FROM tags"); } $res = array(); foreach($all as $row) {$res[] = $row["tag"];} $page->set_data(json_encode($res)); } if($event->page_matches("api/get_image")) { if(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)); } if($event->page_matches("api/find_images")) { $search_terms = $event->get_search_terms(); $page_number = $event->get_page_number(); $page_size = $event->get_page_size(); $images = Image::find_images(($page_number-1)*$page_size, $page_size, $search_terms); $safe_images = array(); foreach($images as $image) { $image->get_tag_array(); $safe_images[] = new _SafeImage($image); } $page->set_data(json_encode($safe_images)); } if($event->page_matches("api/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)); } } } } ?>