9 Commits

Author SHA1 Message Date
William Oldham
5a09e0c602 Merge pull request #26 from movie-web/dev
Version 2.1.3: Push updates to support AWS
2024-01-06 20:54:30 +00:00
mrjvs
8852fca320 Merge branch 'master' into dev 2024-01-06 21:53:48 +01:00
William Oldham
1e147a793d Bump version 2024-01-06 20:52:02 +00:00
William Oldham
e88a4f3203 Bump dep versions and add error handling 2024-01-06 20:51:48 +00:00
William Oldham
7dc9d1809f Merge pull request #25 from movie-web/dev
Proxy v2.1.2
2024-01-06 17:48:18 +00:00
William Oldham
02b4dca218 Merge pull request #24 from movie-web/block-more-headers
Block more headers
2024-01-06 17:47:17 +00:00
mrjvs
5faca36cb4 Add ability to do debug logging with REQ_DEBUG=true 2024-01-06 18:44:06 +01:00
mrjvs
ad0ae4aaae Add version identifying on proxy 2024-01-06 18:37:40 +01:00
mrjvs
07a87b4571 Block more headers, where possible 2024-01-06 18:32:53 +01:00
6 changed files with 540 additions and 309 deletions

View File

@@ -1,9 +1,13 @@
import { join } from "path";
import pkg from "./package.json";
//https://nitro.unjs.io/config
export default defineNitroConfig({
noPublicDir: true,
srcDir: "./src",
runtimeConfig: {
version: pkg.version
},
alias: {
"@": join(__dirname, "src")
}

View File

@@ -1,7 +1,7 @@
{
"name": "simple-proxy",
"private": true,
"version": "2.1.1",
"version": "2.1.3",
"scripts": {
"prepare": "nitropack prepare",
"dev": "nitropack dev",
@@ -15,9 +15,9 @@
"preinstall": "npx only-allow pnpm"
},
"dependencies": {
"h3": "^1.9.0",
"h3": "^1.10.0",
"jose": "^5.2.0",
"nitropack": "latest"
"nitropack": "^2.8.1"
},
"devDependencies": {
"@typescript-eslint/eslint-plugin": "^6.7.0",

790
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@@ -21,7 +21,9 @@ export default defineEventHandler(async (event) => {
event,
status: 200,
data: {
message: 'Proxy is working as expected',
message: `Proxy is working as expected (v${
useRuntimeConfig(event).version
})`,
},
});
@@ -39,17 +41,22 @@ export default defineEventHandler(async (event) => {
const token = await createTokenIfNeeded(event);
// proxy
await specificProxyRequest(event, destination, {
blacklistedHeaders: getBlacklistedHeaders(),
fetchOptions: {
redirect: 'follow',
headers: getProxyHeaders(event.headers),
body,
},
onResponse(outputEvent, response) {
const headers = getAfterResponseHeaders(response.headers, response.url);
setResponseHeaders(outputEvent, headers);
if (token) setTokenHeader(event, token);
},
});
try {
await specificProxyRequest(event, destination, {
blacklistedHeaders: getBlacklistedHeaders(),
fetchOptions: {
redirect: 'follow',
headers: getProxyHeaders(event.headers),
body,
},
onResponse(outputEvent, response) {
const headers = getAfterResponseHeaders(response.headers, response.url);
setResponseHeaders(outputEvent, headers);
if (token) setTokenHeader(event, token);
},
});
} catch (e) {
console.log('Error fetching', e);
throw e;
}
});

View File

@@ -12,11 +12,15 @@ const blacklistedHeaders = [
'cf-ray',
'cf-visitor',
'cf-ew-via',
'cdn-loop',
'x-amzn-trace-id',
'cf-ipcountry',
'x-forwarded-for',
'x-forwarded-host',
'x-forwarded-proto',
'forwarded',
'x-real-ip',
'content-length',
...Object.keys(headerMap),
];

View File

@@ -69,7 +69,15 @@ export async function specificProxyRequest(
opts.fetchOptions?.headers,
opts.headers,
);
(fetchHeaders.forEach as any)(console.log);
const headerObj = Object.fromEntries([...(fetchHeaders.entries as any)()]);
if (process.env.REQ_DEBUG === 'true') {
console.log({
type: 'request',
method,
url: target,
headers: headerObj,
});
}
return sendProxy(event, target, {
...opts,