Getting ready to make repo public
This commit is contained in:
parent
d7965df422
commit
219ce89cc5
@ -1,5 +1,11 @@
|
|||||||
# CloudOnFire
|
# CloudOnFire
|
||||||
|
|
||||||
|
## Notice
|
||||||
|
|
||||||
|
This is just a POC. Cloudflare sends your original IP inside the headers of every requests. Don't use this to do any bullshit.
|
||||||
|
|
||||||
|
## How it works
|
||||||
|
|
||||||
This script accepts PROXY-Calls on 9097 and tunnels them into the Edge of the Cloudflare Infrastructure.
|
This script accepts PROXY-Calls on 9097 and tunnels them into the Edge of the Cloudflare Infrastructure.
|
||||||
This way you can access the Internet using a huge range of IPs, that change on every request and are considered clean.
|
This way you can access the Internet using a huge range of IPs, that change on every request and are considered clean.
|
||||||
In order for this to work, we MITM all SSL-Trafic using our own certs. This means all websites with HSTS won't work.
|
In order for this to work, we MITM all SSL-Trafic using our own certs. This means all websites with HSTS won't work.
|
||||||
|
58
worker.js
Normal file
58
worker.js
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
// This script has to be deployed as a worker on cloudflare
|
||||||
|
addEventListener('fetch', event => {
|
||||||
|
event.respondWith(forwardReq(event.request))
|
||||||
|
})
|
||||||
|
|
||||||
|
const TOKEN_HEADER = 'H-Token'
|
||||||
|
const TOKEN_VALUE = 'agfjkewjkfvasfhgkzuc'
|
||||||
|
const HOST_HEADER = 'H-Host'
|
||||||
|
const IP_HEADER = 'H-IP'
|
||||||
|
|
||||||
|
async function forwardReq(request) {
|
||||||
|
if (request.headers.get(TOKEN_HEADER) != TOKEN_VALUE) {
|
||||||
|
return new Response("Error 418 - I'm a Teapot")
|
||||||
|
}
|
||||||
|
|
||||||
|
let newHdrs = new Headers()
|
||||||
|
for (const [key, value] of request.headers) {
|
||||||
|
if (key.toLowerCase() == TOKEN_HEADER.toLowerCase()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (key.toLowerCase() == HOST_HEADER.toLowerCase()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (key.toLowerCase() == IP_HEADER.toLowerCase()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (key.toLowerCase().startsWith('cf-')) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (key.toLowerCase() == 'x-forwarded-for') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (key.toLowerCase() == 'x-real-ip') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
newHdrs.set(key, value)
|
||||||
|
}
|
||||||
|
newHdrs.set('Host', request.headers.get(HOST_HEADER))
|
||||||
|
newHdrs.set('X-Forwarded-For', request.headers.get(IP_HEADER))
|
||||||
|
|
||||||
|
let address = ''
|
||||||
|
const url = new URL(request.url)
|
||||||
|
address = request.url.replace(url.hostname, request.headers.get(HOST_HEADER))
|
||||||
|
|
||||||
|
|
||||||
|
const init = {
|
||||||
|
body: request.body,
|
||||||
|
headers: newHdrs,
|
||||||
|
method: request.method
|
||||||
|
}
|
||||||
|
|
||||||
|
let response = await fetch (address, init);
|
||||||
|
|
||||||
|
return new Response(response.body, {
|
||||||
|
status: response.status,
|
||||||
|
statusText: response.statusText
|
||||||
|
})
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user