diff --git a/bridges/PixivBridge.php b/bridges/PixivBridge.php
index 4af2da5a..a7c12179 100644
--- a/bridges/PixivBridge.php
+++ b/bridges/PixivBridge.php
@@ -1,72 +1,113 @@
array(
+ 'name' => 'Post Type',
+ 'type' => 'list',
+ 'values' => array('Illustration' => 'illustrations/',
+ 'Manga' => 'manga/',
+ 'Novel' => 'novels/')
+ ),
'tag' => array(
- 'name' => 'Tag to search',
- 'exampleValue' => 'example',
+ 'name' => 'Query to search',
+ 'exampleValue' => '葬送のフリーレン',
'required' => true
),
+ 'posts' => array(
+ 'name' => 'Post Limit',
+ 'type' => 'number',
+ 'defaultValue' => '10'
+ ),
+ 'fullsize' => array(
+ 'name' => 'Full-size Image',
+ 'type' => 'checkbox'
+ )
));
- public function collectData(){
+ const JSON_KEY_MAP = array(
+ 'illustrations/' => 'illust',
+ 'manga/' => 'manga',
+ 'novels/' => 'novel'
+ );
+ const WORK_LINK_MAP = array(
+ 'illustrations/' => 'artworks/',
+ 'manga/' => 'artworks/',
+ 'novels/' => 'novel/show.php?id='
+ );
- $html = getContents(static::URI . 'search.php?word=' . urlencode($this->getInput('tag')))
- or returnClientError('Unable to query pixiv.net');
- $regex = '/getSearchURI());
+ $content = json_decode($content, true);
- preg_match_all($regex, $html, $matches, PREG_SET_ORDER, 0);
- if(!$matches) return;
-
- $content = json_decode(html_entity_decode($matches[0][1]), true);
+ $key = self::JSON_KEY_MAP[$this->getInput('mode')];
$count = 0;
- foreach($content as $result) {
- if($count == 10) break;
+ foreach($content['body'][$key]['data'] as $result) {
$count++;
+ if ($count > $this->getInput('posts')) {
+ break;
+ }
$item = array();
- $item['id'] = $result['illustId'];
- $item['uri'] = 'https://www.pixiv.net/member_illust.php?mode=medium&illust_id=' . $result['illustId'];
- $item['title'] = $result['illustTitle'];
+ $item['id'] = $result['id'];
+ $item['uri'] = static::URI . self::WORK_LINK_MAP[$this->getInput('mode')] . $result['id'];
+ $item['title'] = $result['title'];
$item['author'] = $result['userName'];
-
- preg_match_all($timeRegex, $result['url'], $dt, PREG_SET_ORDER, 0);
- $elementDate = DateTime::createFromFormat('YmdHis',
- $dt[0][1] . $dt[0][2] . $dt[0][3] . $dt[0][4] . $dt[0][5] . $dt[0][6],
- new DateTimeZone('Asia/Tokyo'));
- $item['timestamp'] = $elementDate->getTimestamp();
-
+ $item['timestamp'] = $result['updateDate'];
$item['content'] = "
";
+
$this->items[] = $item;
}
}
+ private function getSearchURI() {
+ $query = urlencode($this->getInput('tag'));
+
+ $uri = static::URI . 'ajax/search/' . $this->getInput('mode')
+ . $query . '?word=' . $query . '&order=date_d&mode=all&p=1';
+
+ return $uri;
+ }
+
private function cacheImage($url, $illustId) {
+ $illustId = preg_replace('/[^0-9]/', '', $illustId);
+ $thumbnailurl = $url;
- $url = str_replace('_master1200', '', $url);
- $url = str_replace('c/240x240/img-master/', 'img-original/', $url);
$path = PATH_CACHE . 'pixiv_img/';
-
if(!is_dir($path))
mkdir($path, 0755, true);
- if(!is_file($path . '/' . $illustId . '.jpeg')) {
- $headers = array('Referer: https://www.pixiv.net/member_illust.php?mode=medium&illust_id=' . $illustId);
- $illust = getContents($url, $headers);
- if(strpos($illust, '404 Not Found') !== false) {
- $illust = getContents(str_replace('jpg', 'png', $url), $headers);
+ $path .= $illustId;
+ if ($this->getInput('fullsize')) {
+ $path .= '_fullsize';
+ }
+ $path .= '.jpg';
+
+ if(!is_file($path)) {
+
+ // Get fullsize URL
+ if (!$this->getInput('mode') !== 'novels/' && $this->getInput('fullsize')) {
+ $ajax_uri = static::URI . 'ajax/illust/' . $illustId;
+ $imagejson = json_decode(getContents($ajax_uri), true);
+ $url = $imagejson['body']['urls']['original'];
}
- file_put_contents($path . '/' . $illustId . '.jpeg', $illust);
+
+ $headers = array('Referer: ' . static::URI);
+ try {
+ $illust = getContents($url, $headers);
+ } catch (Exception $e) {
+ $illust = getContents($thumbnailurl, $headers); // Original thumbnail
+ }
+ file_put_contents($path, $illust);
}
- return 'cache/pixiv_img/' . $illustId . '.jpeg';
-
+ return 'cache/pixiv_img/' . preg_replace('/.*\//', '', $path);
}
}