2020-09-21 17:17:34 +00:00
|
|
|
// SPDX-License-Identifier: MIT
|
2020-05-26 16:34:33 +00:00
|
|
|
//
|
2020-09-21 17:17:34 +00:00
|
|
|
// EmulationStation Desktop Edition
|
2020-06-21 12:25:28 +00:00
|
|
|
// ScreenScraper.h
|
2020-05-26 16:34:33 +00:00
|
|
|
//
|
2020-06-21 12:25:28 +00:00
|
|
|
// Functions specifically for scraping from screenscraper.fr
|
|
|
|
// Called from Scraper.
|
2020-05-26 16:34:33 +00:00
|
|
|
//
|
|
|
|
|
2019-01-11 19:51:05 +00:00
|
|
|
#ifndef ES_APP_SCRAPERS_SCREEN_SCRAPER_H
|
|
|
|
#define ES_APP_SCRAPERS_SCREEN_SCRAPER_H
|
|
|
|
|
|
|
|
#include "EmulationStation.h"
|
2021-07-07 18:03:42 +00:00
|
|
|
#include "scrapers/Scraper.h"
|
2019-01-11 19:51:05 +00:00
|
|
|
|
2021-07-07 18:03:42 +00:00
|
|
|
namespace pugi
|
|
|
|
{
|
|
|
|
class xml_document;
|
|
|
|
}
|
2019-01-11 19:51:05 +00:00
|
|
|
|
2021-07-07 18:03:42 +00:00
|
|
|
void screenscraper_generate_scraper_requests(const ScraperSearchParams& params,
|
|
|
|
std::queue<std::unique_ptr<ScraperRequest>>& requests,
|
|
|
|
std::vector<ScraperSearchResult>& results);
|
2019-01-11 19:51:05 +00:00
|
|
|
|
|
|
|
class ScreenScraperRequest : public ScraperHttpRequest
|
|
|
|
{
|
|
|
|
public:
|
2022-01-15 12:38:09 +00:00
|
|
|
// Constructor for a GetGamelist request.
|
2021-03-27 09:26:13 +00:00
|
|
|
ScreenScraperRequest(std::queue<std::unique_ptr<ScraperRequest>>& requestsWrite,
|
2021-07-07 18:03:42 +00:00
|
|
|
std::vector<ScraperSearchResult>& resultsWrite,
|
|
|
|
const std::string& url)
|
|
|
|
: ScraperHttpRequest(resultsWrite, url)
|
|
|
|
, mRequestQueue(&requestsWrite)
|
|
|
|
{
|
|
|
|
}
|
2020-06-21 12:25:28 +00:00
|
|
|
|
2022-01-15 12:38:09 +00:00
|
|
|
// Constructor for a GetGame request.
|
2021-07-07 18:03:42 +00:00
|
|
|
ScreenScraperRequest(std::vector<ScraperSearchResult>& resultsWrite, const std::string& url)
|
|
|
|
: ScraperHttpRequest(resultsWrite, url)
|
|
|
|
, mRequestQueue(nullptr)
|
|
|
|
{
|
|
|
|
}
|
2020-06-21 12:25:28 +00:00
|
|
|
|
|
|
|
// Settings for the scraper.
|
|
|
|
static const struct ScreenScraperConfig {
|
|
|
|
std::string getGameSearchUrl(const std::string gameName) const;
|
|
|
|
|
|
|
|
// Access to the API.
|
2021-08-17 16:41:45 +00:00
|
|
|
const std::string API_DEV_U = {15, 21, 39, 22, 42, 40};
|
|
|
|
const std::string API_DEV_P = {32, 70, 46, 54, 12, 5, 13, 120, 50, 66, 25};
|
|
|
|
const std::string API_DEV_KEY = {67, 112, 72, 120, 121, 77, 119, 74, 84, 56,
|
|
|
|
75, 122, 78, 98, 69, 86, 56, 120, 120, 49};
|
2020-06-21 12:25:28 +00:00
|
|
|
const std::string API_URL_BASE = "https://www.screenscraper.fr/api2";
|
2021-07-07 18:03:42 +00:00
|
|
|
const std::string API_SOFT_NAME =
|
|
|
|
"EmulationStation-DE " + static_cast<std::string>(PROGRAM_VERSION_STRING);
|
2020-06-21 12:25:28 +00:00
|
|
|
|
|
|
|
// Which type of image artwork we need. Possible values (not a comprehensive list):
|
|
|
|
// - ss: in-game screenshot
|
|
|
|
// - box-3D: 3D boxart
|
2021-07-07 18:03:42 +00:00
|
|
|
// - box-2D: 2D boxart
|
2020-06-21 12:25:28 +00:00
|
|
|
// - screenmarque : marquee
|
|
|
|
// - sstitle: in-game start screenshot
|
|
|
|
// - steamgrid: Steam artwork
|
|
|
|
// - wheel: spine
|
|
|
|
// - support-2D: media showing the 2d boxart on the cart
|
|
|
|
// - support-3D: media showing the 3d boxart on the cart
|
2020-08-05 20:38:44 +00:00
|
|
|
// - video: gameplay videos
|
|
|
|
// - video-normalized: gameplay videos in smaller file sizes with lower audio quality
|
2020-06-21 12:25:28 +00:00
|
|
|
//
|
2020-08-05 20:38:44 +00:00
|
|
|
// Note that not all games contain values for all these, so we default to "ss".
|
2020-06-21 12:25:28 +00:00
|
|
|
//
|
|
|
|
|
|
|
|
std::string media_3dbox = "box-3D";
|
2021-10-28 19:00:23 +00:00
|
|
|
std::string media_backcover = "box-2D-back";
|
2020-06-21 12:25:28 +00:00
|
|
|
std::string media_cover = "box-2D";
|
2022-01-15 12:16:23 +00:00
|
|
|
std::string media_fanart = "fanart";
|
2020-06-21 12:25:28 +00:00
|
|
|
std::string media_marquee = "wheel";
|
2021-10-28 19:00:23 +00:00
|
|
|
std::string media_physicalmedia = "support-2D";
|
2020-06-21 12:25:28 +00:00
|
|
|
std::string media_screenshot = "ss";
|
2021-10-28 19:00:23 +00:00
|
|
|
std::string media_titlescreen = "sstitle";
|
2020-08-05 20:38:44 +00:00
|
|
|
std::string media_video = "video";
|
2020-06-21 12:25:28 +00:00
|
|
|
|
2020-11-14 14:30:49 +00:00
|
|
|
bool isArcadeSystem;
|
|
|
|
|
2020-06-21 12:25:28 +00:00
|
|
|
// Which Region to use when selecting the artwork.
|
|
|
|
// Applies to: artwork, name of the game, date of release.
|
2021-07-07 18:03:42 +00:00
|
|
|
// This is read from es_settings.xml, setting "ScraperRegion".
|
2020-06-21 12:25:28 +00:00
|
|
|
|
|
|
|
// Which Language to use when selecting the textual information.
|
|
|
|
// Applies to: description, genre.
|
2021-07-07 18:03:42 +00:00
|
|
|
// This is read from es_settings.xml, setting "ScraperLanguage".
|
2020-06-21 12:25:28 +00:00
|
|
|
|
2021-07-07 18:03:42 +00:00
|
|
|
ScreenScraperConfig() {}
|
2020-06-21 12:25:28 +00:00
|
|
|
} configuration;
|
2019-01-11 19:51:05 +00:00
|
|
|
|
|
|
|
protected:
|
2020-06-21 12:25:28 +00:00
|
|
|
void process(const std::unique_ptr<HttpReq>& req,
|
2021-07-07 18:03:42 +00:00
|
|
|
std::vector<ScraperSearchResult>& results) override;
|
2020-06-21 12:25:28 +00:00
|
|
|
|
|
|
|
void processList(const pugi::xml_document& xmldoc, std::vector<ScraperSearchResult>& results);
|
|
|
|
void processGame(const pugi::xml_document& xmldoc, std::vector<ScraperSearchResult>& results);
|
|
|
|
void processMedia(ScraperSearchResult& result,
|
2021-07-07 18:03:42 +00:00
|
|
|
const pugi::xml_node& media_list,
|
|
|
|
std::string mediaType,
|
|
|
|
std::string& fileURL,
|
|
|
|
std::string& fileFormat,
|
|
|
|
std::string region);
|
2020-06-21 12:25:28 +00:00
|
|
|
bool isGameRequest() { return !mRequestQueue; }
|
|
|
|
|
2020-11-14 14:30:49 +00:00
|
|
|
std::queue<std::unique_ptr<ScraperRequest>>* mRequestQueue;
|
2019-01-11 19:51:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // ES_APP_SCRAPERS_SCREEN_SCRAPER_H
|