Add files via upload
This commit is contained in:
79
endpoints/cloudflare.js
Normal file
79
endpoints/cloudflare.js
Normal file
@@ -0,0 +1,79 @@
|
||||
async function cloudflare(data, page) {
|
||||
return new Promise(async (resolve, reject) => {
|
||||
if (!data.domain) return reject(new Error("Missing domain parameter"))
|
||||
|
||||
const startTime = Date.now()
|
||||
let isResolved = false
|
||||
let userAgent = null
|
||||
|
||||
const cl = setTimeout(() => {
|
||||
if (!isResolved) {
|
||||
isResolved = true
|
||||
const elapsedTime = (Date.now() - startTime) / 1000
|
||||
resolve({
|
||||
cf_clearance: null,
|
||||
user_agent: userAgent,
|
||||
elapsed_time: elapsedTime,
|
||||
})
|
||||
}
|
||||
}, 20000)
|
||||
|
||||
try {
|
||||
if (data.proxy?.username && data.proxy?.password) {
|
||||
await page.authenticate({
|
||||
username: data.proxy.username,
|
||||
password: data.proxy.password,
|
||||
})
|
||||
}
|
||||
|
||||
page.removeAllListeners("request")
|
||||
page.removeAllListeners("response")
|
||||
await page.setRequestInterception(true)
|
||||
|
||||
page.on("request", async (req) => {
|
||||
try {
|
||||
await req.continue()
|
||||
} catch (_) {}
|
||||
})
|
||||
|
||||
page.on("response", async (res) => {
|
||||
try {
|
||||
const url = res.url()
|
||||
if (url.includes("/cdn-cgi/challenge-platform/")) {
|
||||
const headers = res.headers()
|
||||
if (headers["set-cookie"]) {
|
||||
const match = headers["set-cookie"].match(/cf_clearance=([^;]+)/)
|
||||
if (match) {
|
||||
const cf_clearance = match[1]
|
||||
const userAgent = (await res.request().headers())["user-agent"]
|
||||
const elapsedTime = (Date.now() - startTime) / 1000
|
||||
|
||||
if (!isResolved) {
|
||||
isResolved = true
|
||||
clearTimeout(cl)
|
||||
|
||||
resolve({
|
||||
cf_clearance,
|
||||
user_agent: userAgent,
|
||||
elapsed_time: elapsedTime,
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (_) {}
|
||||
})
|
||||
|
||||
await page.goto(data.domain, { waitUntil: "domcontentloaded" })
|
||||
userAgent = await page.evaluate(() => navigator.userAgent)
|
||||
} catch (err) {
|
||||
if (!isResolved) {
|
||||
isResolved = true
|
||||
clearTimeout(cl)
|
||||
reject(err)
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
module.exports = cloudflare
|
||||
84
endpoints/turnstile.js
Normal file
84
endpoints/turnstile.js
Normal file
@@ -0,0 +1,84 @@
|
||||
async function turnstile({ domain, proxy, siteKey }, page) {
|
||||
if (!domain) throw new Error("Missing domain parameter");
|
||||
if (!siteKey) throw new Error("Missing siteKey parameter");
|
||||
|
||||
const timeout = global.timeOut || 60000;
|
||||
let isResolved = false;
|
||||
|
||||
const cl = setTimeout(async () => {
|
||||
if (!isResolved) {
|
||||
throw new Error("Timeout Error");
|
||||
}
|
||||
}, timeout);
|
||||
|
||||
try {
|
||||
if (proxy?.username && proxy?.password) {
|
||||
await page.authenticate({
|
||||
username: proxy.username,
|
||||
password: proxy.password,
|
||||
});
|
||||
}
|
||||
|
||||
const htmlContent = `
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<body>
|
||||
<div class="turnstile"></div>
|
||||
<script src="https://challenges.cloudflare.com/turnstile/v0/api.js?onload=onloadTurnstileCallback" defer></script>
|
||||
<script>
|
||||
window.onloadTurnstileCallback = function () {
|
||||
turnstile.render('.turnstile', {
|
||||
sitekey: '${siteKey}',
|
||||
callback: function (token) {
|
||||
var c = document.createElement('input');
|
||||
c.type = 'hidden';
|
||||
c.name = 'cf-response';
|
||||
c.value = token;
|
||||
document.body.appendChild(c);
|
||||
},
|
||||
});
|
||||
};
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
`;
|
||||
|
||||
await page.setRequestInterception(true);
|
||||
page.removeAllListeners("request");
|
||||
page.on("request", async (request) => {
|
||||
if ([domain, domain + "/"].includes(request.url()) && request.resourceType() === "document") {
|
||||
await request.respond({
|
||||
status: 200,
|
||||
contentType: "text/html",
|
||||
body: htmlContent,
|
||||
});
|
||||
} else {
|
||||
await request.continue();
|
||||
}
|
||||
});
|
||||
|
||||
await page.goto(domain, { waitUntil: "domcontentloaded" });
|
||||
|
||||
await page.waitForSelector('[name="cf-response"]', { timeout });
|
||||
|
||||
const token = await page.evaluate(() => {
|
||||
try {
|
||||
return document.querySelector('[name="cf-response"]').value;
|
||||
} catch {
|
||||
return null;
|
||||
}
|
||||
});
|
||||
|
||||
isResolved = true;
|
||||
clearTimeout(cl);
|
||||
|
||||
if (!token || token.length < 10) throw new Error("Failed to get token");
|
||||
return token;
|
||||
|
||||
} catch (e) {
|
||||
clearTimeout(cl);
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = turnstile;
|
||||
Reference in New Issue
Block a user