fix(auth): validate API key from POST body and handle content type
- Switch API key validation to use POST body parameters - Add support for `application/x-www-form-urlencoded` content type - Store parsed body in context state for further use - Reject unsupported content types with 415 status
This commit is contained in:
@@ -6,11 +6,19 @@ import { ltProxyAuth } from '../ltProxyAuth.ts';
|
||||
Deno.test('ltProxyAuth: accepts valid API key', async () => {
|
||||
Deno.env.set('API_KEYS', 'valid123');
|
||||
|
||||
const req = new Request('http://localhost/?apiKey=valid123');
|
||||
const body = new URLSearchParams({ apiKey: 'valid123' });
|
||||
const req = new Request('http://localhost/', {
|
||||
method: 'POST',
|
||||
headers: {
|
||||
'content-type': 'application/x-www-form-urlencoded',
|
||||
},
|
||||
body,
|
||||
});
|
||||
|
||||
const ctx: IContext = {
|
||||
req,
|
||||
params: {},
|
||||
query: { apiKey: 'valid123' },
|
||||
query: {},
|
||||
state: {},
|
||||
};
|
||||
|
||||
@@ -26,11 +34,19 @@ Deno.test('ltProxyAuth: accepts valid API key', async () => {
|
||||
Deno.test('ltProxyAuth: rejects invalid API key', async () => {
|
||||
Deno.env.set('API_KEYS', 'valid123');
|
||||
|
||||
const req = new Request('http://localhost/?apiKey=invalid456');
|
||||
const body = new URLSearchParams({ apiKey: 'invalid456' });
|
||||
const req = new Request('http://localhost/', {
|
||||
method: 'POST',
|
||||
headers: {
|
||||
'content-type': 'application/x-www-form-urlencoded',
|
||||
},
|
||||
body,
|
||||
});
|
||||
|
||||
const ctx: IContext = {
|
||||
req,
|
||||
params: {},
|
||||
query: { apiKey: 'invalid456' },
|
||||
query: {},
|
||||
state: {},
|
||||
};
|
||||
|
||||
@@ -46,7 +62,15 @@ Deno.test('ltProxyAuth: rejects invalid API key', async () => {
|
||||
Deno.test('ltProxyAuth: rejects missing API key', async () => {
|
||||
Deno.env.set('API_KEYS', 'valid123');
|
||||
|
||||
const req = new Request('http://localhost/');
|
||||
const body = new URLSearchParams({ text: 'nur text ohne apiKey' });
|
||||
const req = new Request('http://localhost/', {
|
||||
method: 'POST',
|
||||
headers: {
|
||||
'content-type': 'application/x-www-form-urlencoded',
|
||||
},
|
||||
body,
|
||||
});
|
||||
|
||||
const ctx: IContext = {
|
||||
req,
|
||||
params: {},
|
||||
@@ -60,4 +84,5 @@ Deno.test('ltProxyAuth: rejects missing API key', async () => {
|
||||
);
|
||||
|
||||
assertEquals(response.status, 403);
|
||||
assertEquals(await response.text(), 'Forbidden – Invalid API key');
|
||||
});
|
||||
|
Reference in New Issue
Block a user