mirror of
https://github.com/wukko/cobalt.git
synced 2024-11-15 12:50:01 +00:00
api: add support for cloudflare turnstile
This commit is contained in:
parent
384c6deced
commit
4283774c6c
3 changed files with 40 additions and 1 deletions
|
@ -32,6 +32,8 @@ const env = {
|
|||
&& parseInt(process.env.PROCESSING_PRIORITY),
|
||||
|
||||
externalProxy: process.env.API_EXTERNAL_PROXY,
|
||||
|
||||
turnstileSecret: process.env.TURNSTILE_SECRET,
|
||||
}
|
||||
|
||||
export {
|
||||
|
|
|
@ -12,7 +12,8 @@ import { languageCode } from "../misc/utils.js";
|
|||
|
||||
import { createResponse, normalizeRequest, getIP } from "../processing/request.js";
|
||||
import { verifyStream, getInternalStream } from "../stream/manage.js";
|
||||
import { randomizeCiphers } from '../misc/randomize-ciphers.js';
|
||||
import { randomizeCiphers } from "../misc/randomize-ciphers.js";
|
||||
import { verifyTurnstileToken } from "../misc/turnstile.js";
|
||||
import { extract } from "../processing/url.js";
|
||||
import match from "../processing/match.js";
|
||||
import stream from "../stream/stream.js";
|
||||
|
@ -134,6 +135,23 @@ export function runAPI(express, app, __dirname) {
|
|||
return fail('ErrorNoLink');
|
||||
}
|
||||
|
||||
if (env.turnstileSecret) {
|
||||
const turnstileResponse = req.header("cf-turnstile-response");
|
||||
|
||||
if (!turnstileResponse) {
|
||||
return fail("error.api.authentication");
|
||||
}
|
||||
|
||||
const turnstileResult = await verifyTurnstileToken(
|
||||
turnstileResponse,
|
||||
req.ip
|
||||
);
|
||||
|
||||
if (!turnstileResult) {
|
||||
return fail("error.api.authentication");
|
||||
}
|
||||
}
|
||||
|
||||
if (request.youtubeDubBrowserLang) {
|
||||
request.youtubeDubLang = lang;
|
||||
}
|
||||
|
|
19
api/src/misc/turnstile.js
Normal file
19
api/src/misc/turnstile.js
Normal file
|
@ -0,0 +1,19 @@
|
|||
import { env } from "../config.js";
|
||||
|
||||
export const verifyTurnstileToken = async (turnstileResponse, ip) => {
|
||||
const result = await fetch("https://challenges.cloudflare.com/turnstile/v0/siteverify", {
|
||||
method: "POST",
|
||||
headers: {
|
||||
"Content-Type": "application/json",
|
||||
},
|
||||
body: JSON.stringify({
|
||||
secret: env.turnstileSecret,
|
||||
response: turnstileResponse,
|
||||
remoteip: ip,
|
||||
}),
|
||||
})
|
||||
.then(r => r.json())
|
||||
.catch(() => {});
|
||||
|
||||
return !!result?.success;
|
||||
}
|
Loading…
Reference in a new issue