2015-10-22 14:55:11 +02:00
|
|
|
<?php
|
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
class Releases3DSBridge extends BridgeAbstract
|
|
|
|
{
|
|
|
|
const MAINTAINER = 'ORelio';
|
|
|
|
const NAME = '3DS Scene Releases';
|
2024-01-22 13:44:28 +01:00
|
|
|
const URI = 'http://3dsdb.com/';
|
2022-07-01 15:10:30 +02:00
|
|
|
const CACHE_TIMEOUT = 10800; // 3h
|
|
|
|
const DESCRIPTION = 'Returns the newest scene releases for Nintendo 3DS.';
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
public function collectData()
|
|
|
|
{
|
|
|
|
$this->collectDataUrl(self::URI . 'xml.php');
|
|
|
|
}
|
2020-08-31 19:02:25 +02:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
protected function collectDataUrl($dataUrl)
|
|
|
|
{
|
|
|
|
$xml = getContents($dataUrl);
|
|
|
|
$limit = 0;
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
foreach (array_reverse(explode('<release>', $xml)) as $element) {
|
|
|
|
if ($limit >= 5) {
|
|
|
|
break;
|
|
|
|
}
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
if (strpos($element, '</release>') === false) {
|
|
|
|
continue;
|
|
|
|
}
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
$releasename = extractFromDelimiters($element, '<releasename>', '</releasename>');
|
|
|
|
if (empty($releasename)) {
|
|
|
|
continue;
|
|
|
|
}
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
$id = extractFromDelimiters($element, '<id>', '</id>');
|
|
|
|
$name = extractFromDelimiters($element, '<name>', '</name>');
|
|
|
|
$publisher = extractFromDelimiters($element, '<publisher>', '</publisher>');
|
|
|
|
$region = extractFromDelimiters($element, '<region>', '</region>');
|
|
|
|
$group = extractFromDelimiters($element, '<group>', '</group>');
|
|
|
|
$imagesize = extractFromDelimiters($element, '<imagesize>', '</imagesize>');
|
|
|
|
$serial = extractFromDelimiters($element, '<serial>', '</serial>');
|
|
|
|
$titleid = extractFromDelimiters($element, '<titleid>', '</titleid>');
|
|
|
|
$imgcrc = extractFromDelimiters($element, '<imgcrc>', '</imgcrc>');
|
|
|
|
$filename = extractFromDelimiters($element, '<filename>', '</filename>');
|
|
|
|
$trimmedsize = extractFromDelimiters($element, '<trimmedsize>', '</trimmedsize>');
|
|
|
|
$firmware = extractFromDelimiters($element, '<firmware>', '</firmware>');
|
|
|
|
$type = extractFromDelimiters($element, '<type>', '</type>');
|
|
|
|
$card = extractFromDelimiters($element, '<card>', '</card>');
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
//Main section : Release description from 3DS database
|
|
|
|
$releaseDescription = '<h3>Release Details</h3><b>Release ID: </b>' . $id
|
|
|
|
. '<br /><b>Game Name: </b>' . $name
|
|
|
|
. '<br /><b>Publisher: </b>' . $publisher
|
|
|
|
. '<br /><b>Region: </b>' . $region
|
|
|
|
. '<br /><b>Group: </b>' . $group
|
|
|
|
. '<br /><b>Image size: </b>' . (intval($imagesize) / 8)
|
|
|
|
. 'MB<br /><b>Serial: </b>' . $serial
|
|
|
|
. '<br /><b>Title ID: </b>' . $titleid
|
|
|
|
. '<br /><b>Image CRC: </b>' . $imgcrc
|
|
|
|
. '<br /><b>File Name: </b>' . $filename
|
|
|
|
. '<br /><b>Release Name: </b>' . $releasename
|
|
|
|
. '<br /><b>Trimmed size: </b>' . intval(intval($trimmedsize) / 1048576)
|
|
|
|
. 'MB<br /><b>Firmware: </b>' . $firmware
|
|
|
|
. '<br /><b>Type: </b>' . $this->typeToString($type)
|
|
|
|
. '<br /><b>Card: </b>' . $this->cardToString($card)
|
|
|
|
. '<br />';
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
//Build search links section to facilitate release search using search engines
|
|
|
|
$releaseNameEncoded = urlencode(str_replace(' ', '+', $releasename));
|
|
|
|
$searchLinkGoogle = 'https://google.com/?q=' . $releaseNameEncoded;
|
|
|
|
$searchLinkDuckDuckGo = 'https://duckduckgo.com/?q=' . $releaseNameEncoded;
|
|
|
|
$searchLinkQwant = 'https://lite.qwant.com/?q=' . $releaseNameEncoded . '&t=web';
|
|
|
|
$releaseSearchLinks = '<h3>Search this release</h3><ul><li><a href="'
|
|
|
|
. $searchLinkGoogle
|
|
|
|
. '">Search using Google</a></li><li><a href="'
|
|
|
|
. $searchLinkDuckDuckGo
|
|
|
|
. '">Search using DuckDuckGo</a></li><li><a href="'
|
|
|
|
. $searchLinkQwant
|
|
|
|
. '">Search using Qwant</a></li></ul>';
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
//Build and add final item with the above three sections
|
|
|
|
$item = [];
|
|
|
|
$item['title'] = $name;
|
|
|
|
$item['author'] = $publisher;
|
2023-07-03 10:48:33 +02:00
|
|
|
//$item['timestamp'] = $ignDate;
|
|
|
|
//$item['enclosures'] = [$ignCoverArt];
|
2022-07-01 15:10:30 +02:00
|
|
|
$item['uri'] = empty($ignLink) ? $searchLinkDuckDuckGo : $ignLink;
|
2023-07-03 10:48:33 +02:00
|
|
|
$item['content'] = $releaseDescription . $releaseSearchLinks;
|
2022-07-01 15:10:30 +02:00
|
|
|
$this->items[] = $item;
|
|
|
|
$limit++;
|
|
|
|
}
|
|
|
|
}
|
2017-02-11 16:16:56 +01:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
private function typeToString($type)
|
|
|
|
{
|
|
|
|
switch ($type) {
|
|
|
|
case 1:
|
|
|
|
return 'Card Game';
|
|
|
|
case 4:
|
|
|
|
return 'eShop';
|
|
|
|
default:
|
|
|
|
return '??? (' . $type . ')';
|
|
|
|
}
|
|
|
|
}
|
2019-10-03 21:46:09 +02:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
private function cardToString($card)
|
|
|
|
{
|
|
|
|
switch ($card) {
|
|
|
|
case 1:
|
|
|
|
return 'Regular (CARD1)';
|
|
|
|
case 2:
|
|
|
|
return 'NAND (CARD2)';
|
|
|
|
default:
|
|
|
|
return '??? (' . $card . ')';
|
|
|
|
}
|
|
|
|
}
|
2015-10-22 14:55:11 +02:00
|
|
|
}
|