2007-07-23 22:38:02 +00:00
|
|
|
|
<?php
|
|
|
|
|
/*
|
2008-04-14 03:20:25 +00:00
|
|
|
|
Name: Danbooru Client API
|
|
|
|
|
Description: Allow Danbooru apps like Danbooru Uploader for Firefox to communicate with Shimmie
|
2007-07-23 22:38:02 +00:00
|
|
|
|
|
|
|
|
|
Author: JJS <jsutinen@gmail.com>
|
|
|
|
|
Notes:
|
|
|
|
|
danbooru API based on documentation from danbooru 1.0 - http://attachr.com/7569
|
2007-07-23 23:08:40 +00:00
|
|
|
|
I've only been able to test add_post and find_tags because I use the old danbooru firefox extension for firefox 1.5
|
2007-07-23 22:38:02 +00:00
|
|
|
|
|
|
|
|
|
Functions currently implemented:
|
|
|
|
|
add_post - title and rating are currently ignored because shimmie does not support them
|
|
|
|
|
find_posts - sort of works, filename is returned as the original filename and probably won't help when it comes to actually downloading it
|
|
|
|
|
find_tags - id, name, and after_id all work but the tags parameter is ignored just like danbooru 1.0 ignores it
|
|
|
|
|
|
2007-10-19 21:59:16 +00:00
|
|
|
|
CHANGELOG
|
2008-10-14 01:06:14 +00:00
|
|
|
|
13-OCT-08 8:00PM CST - JJS
|
|
|
|
|
Bugfix - Properly escape source attribute
|
|
|
|
|
|
2008-09-18 03:14:36 +00:00
|
|
|
|
17-SEP-08 10:00PM CST - JJS
|
|
|
|
|
Bugfix for changed page name checker in PageRequestEvent
|
|
|
|
|
|
2008-04-14 03:20:25 +00:00
|
|
|
|
13-APR-08 10:00PM CST - JJS
|
|
|
|
|
Properly escape the tags returned in find_tags and find_posts - Caught by ATravelingGeek
|
|
|
|
|
Updated extension info to be a bit more clear about its purpose
|
|
|
|
|
Deleted add_comment code as it didn't do anything anyway
|
|
|
|
|
|
2008-03-02 01:11:52 +00:00
|
|
|
|
01-MAR-08 7:00PM CST - JJS
|
|
|
|
|
Rewrote to make it compatible with Shimmie trunk again (r723 at least)
|
|
|
|
|
It may or may not support the new file handling stuff correctly, I'm only testing with images and the danbooru uploader for firefox
|
|
|
|
|
|
2007-10-22 02:09:32 +00:00
|
|
|
|
21-OCT-07 9:07PM CST - JJS
|
|
|
|
|
Turns out I actually did need to implement the new parameter names
|
|
|
|
|
for danbooru api v1.8.1. Now danbooruup should work when used with /api/danbooru/post/create.xml
|
|
|
|
|
Also correctly redirects the url provided by danbooruup in the event
|
|
|
|
|
of a duplicate image.
|
|
|
|
|
|
2007-10-19 21:59:16 +00:00
|
|
|
|
19-OCT-07 4:46PM CST - JJS
|
2009-01-04 11:18:37 -08:00
|
|
|
|
Add compatibility with danbooru api v1.8.1 style urls
|
|
|
|
|
for find_posts and add_post. NOTE: This does not implement
|
|
|
|
|
the changes to the parameter names, it is simply a
|
|
|
|
|
workaround for the latest danbooruup firefox extension.
|
2007-10-19 21:59:16 +00:00
|
|
|
|
Completely compatibility will probably involve a rewrite with a different URL
|
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
*/
|
|
|
|
|
|
2009-01-04 11:18:37 -08:00
|
|
|
|
class DanbooruApi implements Extension
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
|
|
|
|
// Receive the event
|
2009-01-04 11:18:37 -08:00
|
|
|
|
public function receive_event(Event $event)
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
|
|
|
|
// Check if someone is accessing /api/danbooru (us)
|
2009-01-04 11:18:37 -08:00
|
|
|
|
if(($event instanceof PageRequestEvent) && ($event->page_matches("api")) && ($event->get_arg(0) == 'danbooru'))
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
|
|
|
|
// execute the danbooru processing code
|
|
|
|
|
$this->api_danbooru($event);
|
|
|
|
|
}
|
2008-08-22 09:41:30 +00:00
|
|
|
|
if($event instanceof SearchTermParseEvent)
|
2008-02-06 17:27:45 +00:00
|
|
|
|
{
|
|
|
|
|
$matches = array();
|
2009-01-21 23:04:29 -08:00
|
|
|
|
if(preg_match("/^md5:([0-9a-fA-F]*)$/i", $event->term, $matches))
|
2008-02-06 17:27:45 +00:00
|
|
|
|
{
|
2008-03-02 01:11:52 +00:00
|
|
|
|
$hash = strtolower($matches[1]);
|
2008-05-19 15:59:58 +00:00
|
|
|
|
$event->set_querylet(new Querylet("images.hash = '$hash'"));
|
2008-02-06 17:27:45 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2007-07-23 22:38:02 +00:00
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
// Danbooru API
|
|
|
|
|
private function api_danbooru($event)
|
|
|
|
|
{
|
|
|
|
|
global $page;
|
|
|
|
|
global $config;
|
|
|
|
|
global $database;
|
|
|
|
|
global $user;
|
|
|
|
|
$page->set_mode("data");
|
|
|
|
|
$page->set_type("application/xml");
|
|
|
|
|
//debug
|
|
|
|
|
//$page->set_type("text/plain");
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
$results = array();
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
/*
|
|
|
|
|
add_post()
|
2009-01-04 11:18:37 -08:00
|
|
|
|
Adds a post to the database.
|
|
|
|
|
Parameters
|
2007-07-23 22:38:02 +00:00
|
|
|
|
* login: login
|
2009-01-04 11:18:37 -08:00
|
|
|
|
* password: password
|
|
|
|
|
* file: file as a multipart form
|
|
|
|
|
* source: source url
|
2007-07-23 22:38:02 +00:00
|
|
|
|
* title: title **IGNORED**
|
2009-01-04 11:18:37 -08:00
|
|
|
|
* tags: list of tags as a string, delimited by whitespace
|
|
|
|
|
* md5: MD5 hash of upload in hexadecimal format
|
2007-07-23 22:38:02 +00:00
|
|
|
|
* rating: rating of the post. can be explicit, questionable, or safe. **IGNORED**
|
2009-01-04 11:18:37 -08:00
|
|
|
|
Notes
|
|
|
|
|
* The only necessary parameter is tags and either file or source.
|
|
|
|
|
* If you want to sign your post, you need a way to authenticate your account, either by supplying login and password, or by supplying a cookie.
|
|
|
|
|
* If an account is not supplied or if it doesn<EFBFBD>t authenticate, he post will be added anonymously.
|
|
|
|
|
* If the md5 parameter is supplied and does not match the hash of what<EFBFBD>s on the server, the post is rejected.
|
|
|
|
|
Response
|
|
|
|
|
The response depends on the method used:
|
|
|
|
|
Post
|
|
|
|
|
* X-Danbooru-Location set to the URL for newly uploaded post.
|
|
|
|
|
Get
|
2007-07-23 22:38:02 +00:00
|
|
|
|
* Redirected to the newly uploaded post.
|
|
|
|
|
*/
|
2007-10-19 21:59:16 +00:00
|
|
|
|
if(($event->get_arg(1) == 'add_post') || (($event->get_arg(1) == 'post') && ($event->get_arg(2) == 'create.xml')))
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
|
|
|
|
// No XML data is returned from this function
|
|
|
|
|
$page->set_type("text/plain");
|
|
|
|
|
// Check first if a login was supplied, if it wasn't check if the user is logged in via cookie
|
|
|
|
|
// If all that fails, it's an anonymous upload
|
|
|
|
|
$this->authenticate_user();
|
|
|
|
|
// Now we check if a file was uploaded or a url was provided to transload
|
|
|
|
|
// Much of this code is borrowed from /ext/upload
|
|
|
|
|
if($config->get_bool("upload_anon") || !$user->is_anonymous())
|
|
|
|
|
{
|
|
|
|
|
$file = null;
|
|
|
|
|
$filename = "";
|
|
|
|
|
$source = "";
|
|
|
|
|
if(isset($_FILES['file']))
|
|
|
|
|
{ // A file was POST'd in
|
|
|
|
|
$file = $_FILES['file']['tmp_name'];
|
2007-07-29 20:25:34 +00:00
|
|
|
|
$filename = $_FILES['file']['name'];
|
2007-07-23 22:38:02 +00:00
|
|
|
|
// If both a file is posted and a source provided, I'm assuming source is the source of the file
|
2007-10-22 02:09:32 +00:00
|
|
|
|
if(isset($_REQUEST['source']) && !empty($_REQUEST['source']))
|
|
|
|
|
{
|
|
|
|
|
$source = $_REQUEST['source'];
|
|
|
|
|
} else
|
|
|
|
|
{
|
|
|
|
|
$source = null;
|
|
|
|
|
}
|
|
|
|
|
} elseif(isset($_FILES['post']))
|
|
|
|
|
{
|
|
|
|
|
$file = $_FILES['post']['tmp_name']['file'];
|
|
|
|
|
$filename = $_FILES['post']['name']['file'];
|
|
|
|
|
if(isset($_REQUEST['post']['source']) && !empty($_REQUEST['post']['source']))
|
|
|
|
|
{
|
|
|
|
|
$source = $_REQUEST['post']['source'];
|
2009-01-04 11:18:37 -08:00
|
|
|
|
} else
|
2007-10-22 02:09:32 +00:00
|
|
|
|
{
|
|
|
|
|
$source = null;
|
|
|
|
|
}
|
|
|
|
|
} elseif(isset($_REQUEST['source']) || isset($_REQUEST['post']['source']))
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{ // A url was provided
|
2007-10-22 02:09:32 +00:00
|
|
|
|
$url = isset($_REQUEST['source']) ? $_REQUEST['source'] : $_REQUEST['post']['source'];
|
2007-07-23 22:38:02 +00:00
|
|
|
|
$source = $url;
|
|
|
|
|
$tmp_filename = tempnam("/tmp", "shimmie_transload");
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
// Are we using fopen wrappers or curl?
|
2009-01-04 11:18:37 -08:00
|
|
|
|
if($config->get_string("transload_engine") == "fopen")
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
|
|
|
|
$fp = fopen($url, "r");
|
|
|
|
|
if(!$fp) {
|
|
|
|
|
header("HTTP/1.0 409 Conflict");
|
|
|
|
|
header("X-Danbooru-Errors: fopen read error");
|
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
$data = "";
|
|
|
|
|
$length = 0;
|
2009-01-04 11:18:37 -08:00
|
|
|
|
while(!feof($fp) && $length <= $config->get_int('upload_size'))
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
|
|
|
|
$data .= fread($fp, 8192);
|
|
|
|
|
$length = strlen($data);
|
|
|
|
|
}
|
|
|
|
|
fclose($fp);
|
|
|
|
|
|
|
|
|
|
$fp = fopen($tmp_filename, "w");
|
|
|
|
|
fwrite($fp, $data);
|
|
|
|
|
fclose($fp);
|
|
|
|
|
}
|
|
|
|
|
|
2009-01-04 11:18:37 -08:00
|
|
|
|
if($config->get_string("transload_engine") == "curl")
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
|
|
|
|
$ch = curl_init($url);
|
|
|
|
|
$fp = fopen($tmp_filename, "w");
|
|
|
|
|
|
|
|
|
|
curl_setopt($ch, CURLOPT_FILE, $fp);
|
|
|
|
|
curl_setopt($ch, CURLOPT_HEADER, 0);
|
|
|
|
|
|
|
|
|
|
curl_exec($ch);
|
|
|
|
|
curl_close($ch);
|
|
|
|
|
fclose($fp);
|
|
|
|
|
}
|
|
|
|
|
$file = $tmp_filename;
|
|
|
|
|
$filename = basename($url);
|
2009-01-04 11:18:37 -08:00
|
|
|
|
} else
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{ // Nothing was specified at all
|
|
|
|
|
header("HTTP/1.0 409 Conflict");
|
|
|
|
|
header("X-Danbooru-Errors: no input files");
|
|
|
|
|
return;
|
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-10-22 02:09:32 +00:00
|
|
|
|
// Get tags out of url
|
2008-03-02 01:11:52 +00:00
|
|
|
|
$posttags = tag_explode(isset($_REQUEST['tags']) ? $_REQUEST['tags'] : $_REQUEST['post']['tags']);
|
|
|
|
|
$hash = md5_file($file);
|
|
|
|
|
// Was an md5 supplied? Does it match the file hash?
|
2007-07-23 22:38:02 +00:00
|
|
|
|
if(isset($_REQUEST['md5']))
|
|
|
|
|
{
|
2008-03-02 01:11:52 +00:00
|
|
|
|
if(strtolower($_REQUEST['md5']) != $hash)
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
|
|
|
|
header("HTTP/1.0 409 Conflict");
|
|
|
|
|
header("X-Danbooru-Errors: md5 mismatch");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
2008-03-02 01:11:52 +00:00
|
|
|
|
// Upload size checking is now performed in the upload extension
|
|
|
|
|
// It is also currently broken due to some confusion over file variable ($tmp_filename?)
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
// Does it exist already?
|
2008-10-09 03:21:18 +00:00
|
|
|
|
$existing = Image::by_hash($config, $database, $hash);
|
2007-07-23 22:38:02 +00:00
|
|
|
|
if(!is_null($existing)) {
|
|
|
|
|
header("HTTP/1.0 409 Conflict");
|
|
|
|
|
header("X-Danbooru-Errors: duplicate");
|
2007-07-29 20:25:34 +00:00
|
|
|
|
$existinglink = make_link("post/view/" . $existing->id);
|
2007-07-23 22:38:02 +00:00
|
|
|
|
header("X-Danbooru-Location: $existinglink");
|
|
|
|
|
}
|
|
|
|
|
|
2008-03-02 01:11:52 +00:00
|
|
|
|
// Fire off an event which should process the new file and add it to the db
|
|
|
|
|
$fileinfo = pathinfo($filename);
|
|
|
|
|
$metadata['filename'] = $fileinfo['basename'];
|
|
|
|
|
$metadata['extension'] = $fileinfo['extension'];
|
|
|
|
|
$metadata['tags'] = $posttags;
|
|
|
|
|
$metadata['source'] = $source;
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2009-01-04 06:01:59 -08:00
|
|
|
|
try {
|
|
|
|
|
$nevent = new DataUploadEvent($user, $file, $metadata);
|
|
|
|
|
send_event($nevent);
|
|
|
|
|
// If it went ok, grab the id for the newly uploaded image and pass it in the header
|
2008-10-09 03:21:18 +00:00
|
|
|
|
$newimg = Image::by_hash($config, $database, $hash);
|
2007-07-23 23:08:40 +00:00
|
|
|
|
$newid = make_link("post/view/" . $newimg->id);
|
2007-07-23 22:38:02 +00:00
|
|
|
|
// Did we POST or GET this call?
|
|
|
|
|
if($_SERVER['REQUEST_METHOD'] == 'POST')
|
|
|
|
|
{
|
|
|
|
|
header("X-Danbooru-Location: $newid");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
header("Location: $newid");
|
|
|
|
|
}
|
2009-01-04 06:01:59 -08:00
|
|
|
|
catch(UploadException $ex) {
|
|
|
|
|
// Did something screw up?
|
|
|
|
|
header("HTTP/1.0 409 Conflict");
|
|
|
|
|
header("X-Danbooru-Errors: ". $ex->getMessage());
|
|
|
|
|
return;
|
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
} else
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
2007-07-29 20:25:34 +00:00
|
|
|
|
header("HTTP/1.0 409 Conflict");
|
2007-07-23 22:38:02 +00:00
|
|
|
|
header("X-Danbooru-Errors: authentication error");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
/*
|
2009-01-04 11:18:37 -08:00
|
|
|
|
find_posts()
|
|
|
|
|
Find all posts that match the search criteria. Posts will be ordered by id descending.
|
|
|
|
|
Parameters
|
|
|
|
|
* md5: md5 hash to search for (comma delimited)
|
|
|
|
|
* id: id to search for (comma delimited)
|
|
|
|
|
* tags: what tags to search for
|
|
|
|
|
* limit: limit
|
|
|
|
|
* offset: offset
|
2007-07-23 22:38:02 +00:00
|
|
|
|
* after_id: limit results to posts added after this id
|
|
|
|
|
*/
|
2007-10-19 21:59:16 +00:00
|
|
|
|
if(($event->get_arg(1) == 'find_posts') || (($event->get_arg(1) == 'post') && ($event->get_arg(2) == 'index.xml')))
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
|
|
|
|
if(isset($_GET['md5']))
|
|
|
|
|
{
|
|
|
|
|
$md5list = explode(",",$_GET['md5']);
|
|
|
|
|
foreach($md5list as $md5)
|
|
|
|
|
{
|
2008-10-09 03:21:18 +00:00
|
|
|
|
$results[] = Image::by_hash($config, $database, $md5);
|
2007-07-23 22:38:02 +00:00
|
|
|
|
}
|
|
|
|
|
} elseif(isset($_GET['id']))
|
|
|
|
|
{
|
|
|
|
|
$idlist = explode(",",$_GET['id']);
|
|
|
|
|
foreach($idlist as $id)
|
|
|
|
|
{
|
2008-10-09 03:21:18 +00:00
|
|
|
|
$results[] = Image::by_id($config, $database, $id);
|
2007-07-23 22:38:02 +00:00
|
|
|
|
}
|
|
|
|
|
} else
|
|
|
|
|
{
|
|
|
|
|
$limit = isset($_GET['limit']) ? int_escape($_GET['limit']) : 100;
|
|
|
|
|
$start = isset($_GET['offset']) ? int_escape($_GET['offset']) : 0;
|
|
|
|
|
$tags = isset($_GET['tags']) ? tag_explode($_GET['tags']) : array();
|
2008-10-09 03:21:18 +00:00
|
|
|
|
$results = Image::find_images($config,$database,$start,$limit,$tags);
|
2007-07-23 22:38:02 +00:00
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
// Now we have the array $results filled with Image objects
|
|
|
|
|
// Let's display them
|
|
|
|
|
$xml = "<posts>\n";
|
|
|
|
|
foreach($results as $img)
|
|
|
|
|
{
|
|
|
|
|
// Sanity check to see if $img is really an image object
|
|
|
|
|
// If it isn't (e.g. someone requested an invalid md5 or id), break out of the this
|
|
|
|
|
if(!is_object($img))
|
|
|
|
|
continue;
|
|
|
|
|
$taglist = $img->get_tag_list();
|
|
|
|
|
$owner = $img->get_owner();
|
2008-10-14 01:06:14 +00:00
|
|
|
|
$xml .= "<post md5=\"$img->hash\" rating=\"Questionable\" date=\"$img->posted\" is_warehoused=\"false\" file_name=\"$img->filename\" tags=\"" . $this->xmlspecialchars($taglist) . "\" source=\"" . $this->xmlspecialchars($img->source) . "\" score=\"0\" id=\"$img->id\" author=\"$owner->name\"/>\n";
|
2007-07-23 22:38:02 +00:00
|
|
|
|
}
|
|
|
|
|
$xml .= "</posts>";
|
|
|
|
|
$page->set_data($xml);
|
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
/*
|
2009-01-04 11:18:37 -08:00
|
|
|
|
find_tags() Find all tags that match the search criteria.
|
|
|
|
|
Parameters
|
|
|
|
|
* id: A comma delimited list of tag id numbers.
|
|
|
|
|
* name: A comma delimited list of tag names.
|
|
|
|
|
* tags: any typical tag query. See Tag#parse_query for details.
|
2007-07-23 22:38:02 +00:00
|
|
|
|
* after_id: limit results to tags with an id number after after_id. Useful if you only want to refresh
|
|
|
|
|
*/
|
|
|
|
|
if($event->get_arg(1) == 'find_tags')
|
|
|
|
|
{
|
|
|
|
|
if(isset($_GET['id']))
|
|
|
|
|
{
|
|
|
|
|
$idlist = explode(",",$_GET['id']);
|
|
|
|
|
foreach($idlist as $id)
|
|
|
|
|
{
|
|
|
|
|
$sqlresult = $database->execute("SELECT id,tag,count FROM tags WHERE id = ?", array($id));
|
|
|
|
|
if(!$sqlresult->EOF)
|
|
|
|
|
{
|
|
|
|
|
$results[] = array($sqlresult->fields['count'], $sqlresult->fields['tag'], $sqlresult->fields['id']);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} elseif(isset($_GET['name']))
|
|
|
|
|
{
|
|
|
|
|
$namelist = explode(",",$_GET['name']);
|
|
|
|
|
foreach($namelist as $name)
|
|
|
|
|
{
|
|
|
|
|
$sqlresult = $database->execute("SELECT id,tag,count FROM tags WHERE tag = ?", array($name));
|
|
|
|
|
if(!$sqlresult->EOF)
|
|
|
|
|
{
|
|
|
|
|
$results[] = array($sqlresult->fields['count'], $sqlresult->fields['tag'], $sqlresult->fields['id']);
|
|
|
|
|
}
|
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
}
|
2007-07-23 22:38:02 +00:00
|
|
|
|
/* Currently disabled to maintain identical functionality to danbooru 1.0's own "broken" find_tags
|
|
|
|
|
elseif(isset($_GET['tags']))
|
|
|
|
|
{
|
|
|
|
|
$start = isset($_GET['after_id']) ? int_escape($_GET['offset']) : 0;
|
|
|
|
|
$tags = tag_explode($_GET['tags']);
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
}
|
|
|
|
|
*/
|
2009-01-04 11:18:37 -08:00
|
|
|
|
else
|
2007-07-23 22:38:02 +00:00
|
|
|
|
{
|
|
|
|
|
$start = isset($_GET['after_id']) ? int_escape($_GET['offset']) : 0;
|
|
|
|
|
$sqlresult = $database->execute("SELECT id,tag,count FROM tags WHERE count > 0 AND id >= ? ORDER BY id DESC",array($start));
|
|
|
|
|
while(!$sqlresult->EOF)
|
|
|
|
|
{
|
|
|
|
|
$results[] = array($sqlresult->fields['count'], $sqlresult->fields['tag'], $sqlresult->fields['id']);
|
|
|
|
|
$sqlresult->MoveNext();
|
|
|
|
|
}
|
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
// Tag results collected, build XML output
|
|
|
|
|
$xml = "<tags>\n";
|
|
|
|
|
foreach($results as $tag)
|
|
|
|
|
{
|
2008-04-15 04:03:10 +00:00
|
|
|
|
$xml .= "<tag type=\"0\" count=\"$tag[0]\" name=\"" . $this->xmlspecialchars($tag[1]) . "\" id=\"$tag[2]\"/>\n";
|
2007-07-23 22:38:02 +00:00
|
|
|
|
}
|
|
|
|
|
$xml .= "</tags>";
|
|
|
|
|
$page->set_data($xml);
|
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-10-22 02:09:32 +00:00
|
|
|
|
// Hackery for danbooruup 0.3.2 providing the wrong view url. This simply redirects to the proper
|
|
|
|
|
// Shimmie view page
|
|
|
|
|
// Example: danbooruup says the url is http://shimmie/api/danbooru/post/show/123
|
|
|
|
|
// This redirects that to http://shimmie/post/view/123
|
|
|
|
|
if(($event->get_arg(1) == 'post') && ($event->get_arg(2) == 'show'))
|
|
|
|
|
{
|
|
|
|
|
$fixedlocation = make_link("post/view/" . $event->get_arg(3));
|
|
|
|
|
header("Location: $fixedlocation");
|
|
|
|
|
}
|
2007-07-23 22:38:02 +00:00
|
|
|
|
}
|
2009-01-04 11:18:37 -08:00
|
|
|
|
|
2007-07-23 22:38:02 +00:00
|
|
|
|
// Turns out I use this a couple times so let's make it a utility function
|
|
|
|
|
// Authenticates a user based on the contents of the login and password parameters
|
|
|
|
|
// or makes them anonymous. Does not set any cookies or anything permanent.
|
|
|
|
|
private function authenticate_user()
|
|
|
|
|
{
|
2008-08-23 12:49:47 +00:00
|
|
|
|
global $config;
|
2007-07-23 22:38:02 +00:00
|
|
|
|
global $database;
|
|
|
|
|
global $user;
|
|
|
|
|
|
|
|
|
|
if(isset($_REQUEST['login']) && isset($_REQUEST['password']))
|
|
|
|
|
{
|
|
|
|
|
// Get this user from the db, if it fails the user becomes anonymous
|
|
|
|
|
// Code borrowed from /ext/user
|
|
|
|
|
$name = $_REQUEST['login'];
|
|
|
|
|
$pass = $_REQUEST['password'];
|
|
|
|
|
$hash = md5( strtolower($name) . $pass );
|
2008-08-23 12:49:47 +00:00
|
|
|
|
$duser = User::by_name_and_hash($config, $database, $name, $hash);
|
2007-07-23 22:38:02 +00:00
|
|
|
|
if(!is_null($duser)) {
|
|
|
|
|
$user = $duser;
|
|
|
|
|
} else
|
|
|
|
|
{
|
2008-08-23 12:49:47 +00:00
|
|
|
|
$user = User::by_id($config, $database, $config->get_int("anon_id", 0));
|
2007-07-23 22:38:02 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2008-04-14 03:20:25 +00:00
|
|
|
|
|
|
|
|
|
// From htmlspecialchars man page on php.net comments
|
|
|
|
|
// If tags contain quotes they need to be htmlified
|
2009-01-04 11:18:37 -08:00
|
|
|
|
private function xmlspecialchars($text)
|
2008-04-14 03:20:25 +00:00
|
|
|
|
{
|
|
|
|
|
return str_replace(''', ''', htmlspecialchars($text, ENT_QUOTES));
|
|
|
|
|
}
|
2007-07-23 22:38:02 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
add_event_listener(new DanbooruApi());
|
2007-12-04 18:20:46 +00:00
|
|
|
|
?>
|