Browse Source

[new bridge] Lolibooru

Mitsukarenai 9 years ago
parent
commit
410d0a6d88
1 changed files with 54 additions and 0 deletions
  1. 54 0
      bridges/LolibooruBridge.php

+ 54 - 0
bridges/LolibooruBridge.php

@@ -0,0 +1,54 @@
+<?php
+/**
+* RssBridgeLolibooru
+* Returns images from given page and tags
+*
+* @name Lolibooru
+* @homepage http://lolibooru.moe/
+* @description Returns images from given page and tags
+* @maintainer mitsukarenai
+* @update 2015-03-21
+* @use1(p="page", t="tags")
+*/
+class LolibooruBridge extends BridgeAbstract{
+
+    public function collectData(array $param){
+	$page = 1; $tags = '';
+        if (isset($param['p'])) { 
+            $page = (int)preg_replace("/[^0-9]/",'', $param['p']); 
+        }
+        if (isset($param['t'])) { 
+            $tags = urlencode($param['t']); 
+        }
+        $html = file_get_html("http://lolibooru.moe/post?page=$page&tags=$tags") or $this->returnError('Could not request Lolibooru.', 404);
+	$input_json = explode('Post.register(', $html);
+	foreach($input_json as $element)
+	 $data[] = preg_replace('/}\)(.*)/', '}', $element);
+	unset($data[0]);
+    
+        foreach($data as $datai) {
+	    $json = json_decode($datai, TRUE);
+            $item = new \Item();
+            $item->uri = 'http://lolibooru.moe/post/show/'.$json['id'];
+            $item->postid = $json['id'];
+            $item->timestamp = $json['created_at'];
+            $item->imageUri = $json['file_url'];
+            $item->thumbnailUri = $json['preview_url'];
+            $item->title = 'Lolibooru | '.$json['id'];
+            $item->content = '<a href="' . $item->imageUri . '"><img src="' . $item->thumbnailUri . '" /></a><br>Tags: '.$json['tags']; 
+            $this->items[] = $item;
+        }
+    }
+
+    public function getName(){
+        return 'Lolibooru';
+    }
+
+    public function getURI(){
+        return 'http://lolibooru.moe/post';
+    }
+
+    public function getCacheDuration(){
+        return 1800; // 30 minutes
+    }
+}