Merge branch 'master' of https://github.com/MillenniumEarl/F95API into master

pull/36/head
samuele.berlusconi 2020-10-21 15:36:54 +02:00
commit fd45eb7796
7 changed files with 45 additions and 31 deletions

View File

@ -9,8 +9,9 @@
Unofficial Node JS module for scraping F95Zone platform Unofficial Node JS module for scraping F95Zone platform
# Guidelines for errors # Guidelines for errors
+ If you can, return a meaningful value
+ Return `null` only if the function should return a complex object (including strings) - If you can, return a meaningful value
+ Return an empty array if the function should return an array - Return `null` only if the function should return a complex object (including strings)
+ Return `false`, `-1` when the function should retrn `boolean` or `number` - Return an empty array if the function should return an array
+ Throw an exception only if it is an error or if a wrong value could mess up the functioning of the library - Return `false`, `-1` when the function should retrn `boolean` or `number`
- Throw an exception only if it is an error or if a wrong value could mess up the functioning of the library

View File

@ -114,7 +114,9 @@ module.exports.login = async function (username, password) {
} }
// Else, log in throught browser // Else, log in throught browser
shared.logger.info("No saved sessions or expired session, login on the platform"); shared.logger.info(
"No saved sessions or expired session, login on the platform"
);
if (_browser === null && !shared.isolation) _browser = await prepareBrowser(); if (_browser === null && !shared.isolation) _browser = await prepareBrowser();
const browser = shared.isolation ? await prepareBrowser() : _browser; const browser = shared.isolation ? await prepareBrowser() : _browser;
@ -267,7 +269,8 @@ module.exports.getGameDataFromURL = async function (url) {
// Check URL // Check URL
const exists = await urlHelper.urlExists(url); const exists = await urlHelper.urlExists(url);
if (!exists) throw new URIError(url + " is not a valid URL"); if (!exists) throw new URIError(url + " is not a valid URL");
if (!urlHelper.isF95URL(url)) throw new Error(url + " is not a valid F95Zone URL"); if (!urlHelper.isF95URL(url))
throw new Error(url + " is not a valid F95Zone URL");
// Gets the search results of the game being searched for // Gets the search results of the game being searched for
if (_browser === null && !shared.isolation) _browser = await prepareBrowser(); if (_browser === null && !shared.isolation) _browser = await prepareBrowser();
@ -393,7 +396,9 @@ function isCookieExpired(cookie) {
const expirationDate = new Date(expirationUnixTimestamp * 1000); const expirationDate = new Date(expirationUnixTimestamp * 1000);
if (expirationDate < Date.now()) { if (expirationDate < Date.now()) {
shared.logger.warn("Cookie " + cookie.name + " expired, you need to re-authenticate"); shared.logger.warn(
"Cookie " + cookie.name + " expired, you need to re-authenticate"
);
expiredCookies = true; expiredCookies = true;
} }
} }
@ -498,18 +503,17 @@ async function loginF95(browser, username, password) {
let message = ""; let message = "";
// Check if the user is logged in // Check if the user is logged in
let success = await page.evaluate( const success = await page.evaluate(
/* istanbul ignore next */ (selector) => /* istanbul ignore next */ (selector) =>
document.querySelector(selector) !== null, document.querySelector(selector) !== null,
selectorK.AVATAR_INFO selectorK.AVATAR_INFO
); );
let errorMessageExists = await page.evaluate( const errorMessageExists = await page.evaluate(
/* istanbul ignore next */ /* istanbul ignore next */
(selector) => (selector) => document.querySelector(selector) !== null,
document.querySelector(selector) !== null,
selectorK.LOGIN_MESSAGE_ERROR selectorK.LOGIN_MESSAGE_ERROR
) );
// Save cookies to avoid re-auth // Save cookies to avoid re-auth
if (success) { if (success) {
@ -525,7 +529,10 @@ async function loginF95(browser, username, password) {
if (errorMessage === "Incorrect password. Please try again.") { if (errorMessage === "Incorrect password. Please try again.") {
message = "Incorrect password"; message = "Incorrect password";
} else if (errorMessage ==='The requested user \'' + username + '\' could not be found.') { } else if (
errorMessage ===
"The requested user '" + username + "' could not be found."
) {
// The escaped quotes are important! // The escaped quotes are important!
message = "Incorrect username"; message = "Incorrect username";
} else message = errorMessage; } else message = errorMessage;

View File

@ -26,7 +26,8 @@ module.exports.getGameInfo = async function (browser, url) {
// Verify the correctness of the URL // Verify the correctness of the URL
const exists = await urlHelper.urlExists(url); const exists = await urlHelper.urlExists(url);
if (!exists) throw new URIError(url + " is not a valid URL"); if (!exists) throw new URIError(url + " is not a valid URL");
if (!urlHelper.isF95URL(url)) throw new Error(url + " is not a valid F95Zone URL"); if (!urlHelper.isF95URL(url))
throw new Error(url + " is not a valid F95Zone URL");
const page = await preparePage(browser); // Set new isolated page const page = await preparePage(browser); // Set new isolated page
await page.setCookie(...shared.cookies); // Set cookies to avoid login await page.setCookie(...shared.cookies); // Set cookies to avoid login
@ -308,7 +309,8 @@ async function getLastChangelog(page) {
let parsedText = HTMLParser.parse(changelogHTML).structuredText; let parsedText = HTMLParser.parse(changelogHTML).structuredText;
// Clean the text // Clean the text
if (parsedText.startsWith("Spoiler")) parsedText = parsedText.replace("Spoiler", ""); if (parsedText.startsWith("Spoiler"))
parsedText = parsedText.replace("Spoiler", "");
if (parsedText.startsWith(":")) parsedText = parsedText.replace(":", ""); if (parsedText.startsWith(":")) parsedText = parsedText.replace(":", "");
return parsedText.trim(); return parsedText.trim();
} }

View File

@ -124,10 +124,7 @@ async function getThreadURL(page, handle) {
if (isF95URL(relativeURLThread)) return relativeURLThread; if (isF95URL(relativeURLThread)) return relativeURLThread;
// ... else compose the URL and return // ... else compose the URL and return
const urlThread = new URL( const urlThread = new URL(relativeURLThread, urlK.F95_BASE_URL).toString();
relativeURLThread,
urlK.F95_BASE_URL
).toString();
return urlThread; return urlThread;
} }
//#endregion Private methods //#endregion Private methods

View File

@ -52,7 +52,7 @@ module.exports.urlExists = async function (url, checkRedirect) {
if (!valid) return false; if (!valid) return false;
if (checkRedirect) { if (checkRedirect) {
let redirectUrl = await exports.getUrlRedirect(url); const redirectUrl = await exports.getUrlRedirect(url);
if (redirectUrl === url) valid = true; if (redirectUrl === url) valid = true;
else valid = false; else valid = false;
} }

View File

@ -172,8 +172,8 @@ describe("Search game data", function () {
expect(result, "Without being logged should return null").to.be.null; expect(result, "Without being logged should return null").to.be.null;
}); });
it("Test game serialization", function () { it("Test game serialization", function () {
let json = JSON.stringify(testGame); const json = JSON.stringify(testGame);
let parsedGameInfo = JSON.parse(json); const parsedGameInfo = JSON.parse(json);
expect(parsedGameInfo).to.be.equal(testGame); expect(parsedGameInfo).to.be.equal(testGame);
}); });
}); });
@ -257,15 +257,22 @@ describe("Test url-helper", function () {
expect(exists).to.be.false; expect(exists).to.be.false;
// Now check for more specific URLs (with redirect)... // Now check for more specific URLs (with redirect)...
exists = urlHelper.urlExists("https://f95zone.to/threads/perverted-education-v0-9601-april-ryan.1854/"); exists = urlHelper.urlExists(
"https://f95zone.to/threads/perverted-education-v0-9601-april-ryan.1854/"
);
expect(exists).to.be.true; expect(exists).to.be.true;
exists = urlHelper.urlExists("https://f95zone.to/threads/perverted-education-v0-9601-april-ryan.1854/", true); exists = urlHelper.urlExists(
"https://f95zone.to/threads/perverted-education-v0-9601-april-ryan.1854/",
true
);
expect(exists).to.be.false; expect(exists).to.be.false;
}); });
it("Check if URL belong to the platform", async function () { it("Check if URL belong to the platform", async function () {
let belong = urlHelper.isF95URL("https://f95zone.to/threads/perverted-education-v0-9601-april-ryan.1854/"); let belong = urlHelper.isF95URL(
"https://f95zone.to/threads/perverted-education-v0-9601-april-ryan.1854/"
);
expect(belong).to.be.true; expect(belong).to.be.true;
belong = urlHelper.isF95URL("https://www.google/"); belong = urlHelper.isF95URL("https://www.google/");