@konker.dev/neverthrow-r-middleware 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +15 -0
- package/README.md +26 -0
- package/dist/handler.d.ts +3 -0
- package/dist/handler.d.ts.map +1 -0
- package/dist/handler.js +2 -0
- package/dist/handler.js.map +1 -0
- package/dist/http/HttpApiError.d.ts +16 -0
- package/dist/http/HttpApiError.d.ts.map +1 -0
- package/dist/http/HttpApiError.js +60 -0
- package/dist/http/HttpApiError.js.map +1 -0
- package/dist/http/HttpApiError.test.d.ts +2 -0
- package/dist/http/HttpApiError.test.d.ts.map +1 -0
- package/dist/http/HttpApiError.test.js +45 -0
- package/dist/http/HttpApiError.test.js.map +1 -0
- package/dist/http/Rec.d.ts +13 -0
- package/dist/http/Rec.d.ts.map +1 -0
- package/dist/http/Rec.js +2 -0
- package/dist/http/Rec.js.map +1 -0
- package/dist/http/RequestResponseHandler.d.ts +7 -0
- package/dist/http/RequestResponseHandler.d.ts.map +1 -0
- package/dist/http/RequestResponseHandler.js +2 -0
- package/dist/http/RequestResponseHandler.js.map +1 -0
- package/dist/http/RequestW.d.ts +14 -0
- package/dist/http/RequestW.d.ts.map +1 -0
- package/dist/http/RequestW.js +17 -0
- package/dist/http/RequestW.js.map +1 -0
- package/dist/http/RequestW.test.d.ts +2 -0
- package/dist/http/RequestW.test.d.ts.map +1 -0
- package/dist/http/RequestW.test.js +26 -0
- package/dist/http/RequestW.test.js.map +1 -0
- package/dist/http/ResponseW.d.ts +11 -0
- package/dist/http/ResponseW.d.ts.map +1 -0
- package/dist/http/ResponseW.js +14 -0
- package/dist/http/ResponseW.js.map +1 -0
- package/dist/http/ResponseW.test.d.ts +2 -0
- package/dist/http/ResponseW.test.d.ts.map +1 -0
- package/dist/http/ResponseW.test.js +23 -0
- package/dist/http/ResponseW.test.js.map +1 -0
- package/dist/http/contrib/apiGatewayProxyEventV2Adapter.d.ts +14 -0
- package/dist/http/contrib/apiGatewayProxyEventV2Adapter.d.ts.map +1 -0
- package/dist/http/contrib/apiGatewayProxyEventV2Adapter.js +26 -0
- package/dist/http/contrib/apiGatewayProxyEventV2Adapter.js.map +1 -0
- package/dist/http/contrib/apiGatewayProxyEventV2Adapter.test.d.ts +2 -0
- package/dist/http/contrib/apiGatewayProxyEventV2Adapter.test.d.ts.map +1 -0
- package/dist/http/contrib/apiGatewayProxyEventV2Adapter.test.js +76 -0
- package/dist/http/contrib/apiGatewayProxyEventV2Adapter.test.js.map +1 -0
- package/dist/http/contrib/base64BodyDecoder.d.ts +7 -0
- package/dist/http/contrib/base64BodyDecoder.d.ts.map +1 -0
- package/dist/http/contrib/base64BodyDecoder.js +15 -0
- package/dist/http/contrib/base64BodyDecoder.js.map +1 -0
- package/dist/http/contrib/base64BodyDecoder.test.d.ts +2 -0
- package/dist/http/contrib/base64BodyDecoder.test.d.ts.map +1 -0
- package/dist/http/contrib/base64BodyDecoder.test.js +47 -0
- package/dist/http/contrib/base64BodyDecoder.test.js.map +1 -0
- package/dist/http/contrib/basicAuthAuthenticator.d.ts +17 -0
- package/dist/http/contrib/basicAuthAuthenticator.d.ts.map +1 -0
- package/dist/http/contrib/basicAuthAuthenticator.js +30 -0
- package/dist/http/contrib/basicAuthAuthenticator.js.map +1 -0
- package/dist/http/contrib/basicAuthAuthenticator.test.d.ts +2 -0
- package/dist/http/contrib/basicAuthAuthenticator.test.d.ts.map +1 -0
- package/dist/http/contrib/basicAuthAuthenticator.test.js +64 -0
- package/dist/http/contrib/basicAuthAuthenticator.test.js.map +1 -0
- package/dist/http/contrib/basicAuthDecoder.d.ts +13 -0
- package/dist/http/contrib/basicAuthDecoder.d.ts.map +1 -0
- package/dist/http/contrib/basicAuthDecoder.js +23 -0
- package/dist/http/contrib/basicAuthDecoder.js.map +1 -0
- package/dist/http/contrib/basicAuthDecoder.test.d.ts +2 -0
- package/dist/http/contrib/basicAuthDecoder.test.d.ts.map +1 -0
- package/dist/http/contrib/basicAuthDecoder.test.js +31 -0
- package/dist/http/contrib/basicAuthDecoder.test.js.map +1 -0
- package/dist/http/contrib/bodyValidator.d.ts +11 -0
- package/dist/http/contrib/bodyValidator.d.ts.map +1 -0
- package/dist/http/contrib/bodyValidator.js +15 -0
- package/dist/http/contrib/bodyValidator.js.map +1 -0
- package/dist/http/contrib/bodyValidator.test.d.ts +2 -0
- package/dist/http/contrib/bodyValidator.test.d.ts.map +1 -0
- package/dist/http/contrib/bodyValidator.test.js +58 -0
- package/dist/http/contrib/bodyValidator.test.js.map +1 -0
- package/dist/http/contrib/envValidator.d.ts +10 -0
- package/dist/http/contrib/envValidator.d.ts.map +1 -0
- package/dist/http/contrib/envValidator.js +12 -0
- package/dist/http/contrib/envValidator.js.map +1 -0
- package/dist/http/contrib/envValidator.test.d.ts +2 -0
- package/dist/http/contrib/envValidator.test.d.ts.map +1 -0
- package/dist/http/contrib/envValidator.test.js +49 -0
- package/dist/http/contrib/envValidator.test.js.map +1 -0
- package/dist/http/contrib/headerSignatureAuthorizer/index.d.ts +13 -0
- package/dist/http/contrib/headerSignatureAuthorizer/index.d.ts.map +1 -0
- package/dist/http/contrib/headerSignatureAuthorizer/index.js +22 -0
- package/dist/http/contrib/headerSignatureAuthorizer/index.js.map +1 -0
- package/dist/http/contrib/headerSignatureAuthorizer/index.test.d.ts +2 -0
- package/dist/http/contrib/headerSignatureAuthorizer/index.test.d.ts.map +1 -0
- package/dist/http/contrib/headerSignatureAuthorizer/index.test.js +39 -0
- package/dist/http/contrib/headerSignatureAuthorizer/index.test.js.map +1 -0
- package/dist/http/contrib/headerSignatureAuthorizer/lib.d.ts +4 -0
- package/dist/http/contrib/headerSignatureAuthorizer/lib.d.ts.map +1 -0
- package/dist/http/contrib/headerSignatureAuthorizer/lib.js +13 -0
- package/dist/http/contrib/headerSignatureAuthorizer/lib.js.map +1 -0
- package/dist/http/contrib/headerSignatureAuthorizer/lib.test.d.ts +2 -0
- package/dist/http/contrib/headerSignatureAuthorizer/lib.test.d.ts.map +1 -0
- package/dist/http/contrib/headerSignatureAuthorizer/lib.test.js +9 -0
- package/dist/http/contrib/headerSignatureAuthorizer/lib.test.js.map +1 -0
- package/dist/http/contrib/headersNormalizer/index.d.ts +9 -0
- package/dist/http/contrib/headersNormalizer/index.d.ts.map +1 -0
- package/dist/http/contrib/headersNormalizer/index.js +8 -0
- package/dist/http/contrib/headersNormalizer/index.js.map +1 -0
- package/dist/http/contrib/headersNormalizer/index.test.d.ts +2 -0
- package/dist/http/contrib/headersNormalizer/index.test.d.ts.map +1 -0
- package/dist/http/contrib/headersNormalizer/index.test.js +38 -0
- package/dist/http/contrib/headersNormalizer/index.test.js.map +1 -0
- package/dist/http/contrib/headersNormalizer/lib.d.ts +11 -0
- package/dist/http/contrib/headersNormalizer/lib.d.ts.map +1 -0
- package/dist/http/contrib/headersNormalizer/lib.js +64 -0
- package/dist/http/contrib/headersNormalizer/lib.js.map +1 -0
- package/dist/http/contrib/headersNormalizer/lib.test.d.ts +2 -0
- package/dist/http/contrib/headersNormalizer/lib.test.d.ts.map +1 -0
- package/dist/http/contrib/headersNormalizer/lib.test.js +35 -0
- package/dist/http/contrib/headersNormalizer/lib.test.js.map +1 -0
- package/dist/http/contrib/headersNormalizer/types.d.ts +10 -0
- package/dist/http/contrib/headersNormalizer/types.d.ts.map +1 -0
- package/dist/http/contrib/headersNormalizer/types.js +2 -0
- package/dist/http/contrib/headersNormalizer/types.js.map +1 -0
- package/dist/http/contrib/headersValidator.d.ts +12 -0
- package/dist/http/contrib/headersValidator.d.ts.map +1 -0
- package/dist/http/contrib/headersValidator.js +15 -0
- package/dist/http/contrib/headersValidator.js.map +1 -0
- package/dist/http/contrib/headersValidator.test.d.ts +2 -0
- package/dist/http/contrib/headersValidator.test.d.ts.map +1 -0
- package/dist/http/contrib/headersValidator.test.js +46 -0
- package/dist/http/contrib/headersValidator.test.js.map +1 -0
- package/dist/http/contrib/helmetJsHeaders.d.ts +5 -0
- package/dist/http/contrib/helmetJsHeaders.d.ts.map +1 -0
- package/dist/http/contrib/helmetJsHeaders.js +25 -0
- package/dist/http/contrib/helmetJsHeaders.js.map +1 -0
- package/dist/http/contrib/helmetJsHeaders.test.d.ts +2 -0
- package/dist/http/contrib/helmetJsHeaders.test.d.ts.map +1 -0
- package/dist/http/contrib/helmetJsHeaders.test.js +18 -0
- package/dist/http/contrib/helmetJsHeaders.test.js.map +1 -0
- package/dist/http/contrib/honoAdapter.d.ts +16 -0
- package/dist/http/contrib/honoAdapter.d.ts.map +1 -0
- package/dist/http/contrib/honoAdapter.js +28 -0
- package/dist/http/contrib/honoAdapter.js.map +1 -0
- package/dist/http/contrib/honoAdapter.test.d.ts +2 -0
- package/dist/http/contrib/honoAdapter.test.d.ts.map +1 -0
- package/dist/http/contrib/honoAdapter.test.js +75 -0
- package/dist/http/contrib/honoAdapter.test.js.map +1 -0
- package/dist/http/contrib/identity.d.ts +4 -0
- package/dist/http/contrib/identity.d.ts.map +1 -0
- package/dist/http/contrib/identity.js +3 -0
- package/dist/http/contrib/identity.js.map +1 -0
- package/dist/http/contrib/identity.test.d.ts +2 -0
- package/dist/http/contrib/identity.test.d.ts.map +1 -0
- package/dist/http/contrib/identity.test.js +12 -0
- package/dist/http/contrib/identity.test.js.map +1 -0
- package/dist/http/contrib/index.d.ts +25 -0
- package/dist/http/contrib/index.d.ts.map +1 -0
- package/dist/http/contrib/index.js +25 -0
- package/dist/http/contrib/index.js.map +1 -0
- package/dist/http/contrib/jsonBodyParserRequest.d.ts +10 -0
- package/dist/http/contrib/jsonBodyParserRequest.d.ts.map +1 -0
- package/dist/http/contrib/jsonBodyParserRequest.js +22 -0
- package/dist/http/contrib/jsonBodyParserRequest.js.map +1 -0
- package/dist/http/contrib/jsonBodyParserRequest.test.d.ts +2 -0
- package/dist/http/contrib/jsonBodyParserRequest.test.d.ts.map +1 -0
- package/dist/http/contrib/jsonBodyParserRequest.test.js +37 -0
- package/dist/http/contrib/jsonBodyParserRequest.test.js.map +1 -0
- package/dist/http/contrib/jsonBodySerializerResponse.d.ts +9 -0
- package/dist/http/contrib/jsonBodySerializerResponse.d.ts.map +1 -0
- package/dist/http/contrib/jsonBodySerializerResponse.js +15 -0
- package/dist/http/contrib/jsonBodySerializerResponse.js.map +1 -0
- package/dist/http/contrib/jsonBodySerializerResponse.test.d.ts +2 -0
- package/dist/http/contrib/jsonBodySerializerResponse.test.d.ts.map +1 -0
- package/dist/http/contrib/jsonBodySerializerResponse.test.js +31 -0
- package/dist/http/contrib/jsonBodySerializerResponse.test.js.map +1 -0
- package/dist/http/contrib/jwtAuthenticator.d.ts +15 -0
- package/dist/http/contrib/jwtAuthenticator.d.ts.map +1 -0
- package/dist/http/contrib/jwtAuthenticator.js +28 -0
- package/dist/http/contrib/jwtAuthenticator.js.map +1 -0
- package/dist/http/contrib/jwtAuthenticator.test.d.ts +2 -0
- package/dist/http/contrib/jwtAuthenticator.test.d.ts.map +1 -0
- package/dist/http/contrib/jwtAuthenticator.test.js +88 -0
- package/dist/http/contrib/jwtAuthenticator.test.js.map +1 -0
- package/dist/http/contrib/jwtAuthenticatorRsa.d.ts +15 -0
- package/dist/http/contrib/jwtAuthenticatorRsa.d.ts.map +1 -0
- package/dist/http/contrib/jwtAuthenticatorRsa.js +28 -0
- package/dist/http/contrib/jwtAuthenticatorRsa.js.map +1 -0
- package/dist/http/contrib/jwtAuthenticatorRsa.test.d.ts +2 -0
- package/dist/http/contrib/jwtAuthenticatorRsa.test.d.ts.map +1 -0
- package/dist/http/contrib/jwtAuthenticatorRsa.test.js +88 -0
- package/dist/http/contrib/jwtAuthenticatorRsa.test.js.map +1 -0
- package/dist/http/contrib/jwtDecoder.d.ts +13 -0
- package/dist/http/contrib/jwtDecoder.d.ts.map +1 -0
- package/dist/http/contrib/jwtDecoder.js +23 -0
- package/dist/http/contrib/jwtDecoder.js.map +1 -0
- package/dist/http/contrib/jwtDecoder.test.d.ts +2 -0
- package/dist/http/contrib/jwtDecoder.test.d.ts.map +1 -0
- package/dist/http/contrib/jwtDecoder.test.js +76 -0
- package/dist/http/contrib/jwtDecoder.test.js.map +1 -0
- package/dist/http/contrib/pathParametersValidator.d.ts +12 -0
- package/dist/http/contrib/pathParametersValidator.d.ts.map +1 -0
- package/dist/http/contrib/pathParametersValidator.js +15 -0
- package/dist/http/contrib/pathParametersValidator.js.map +1 -0
- package/dist/http/contrib/pathParametersValidator.test.d.ts +2 -0
- package/dist/http/contrib/pathParametersValidator.test.d.ts.map +1 -0
- package/dist/http/contrib/pathParametersValidator.test.js +46 -0
- package/dist/http/contrib/pathParametersValidator.test.js.map +1 -0
- package/dist/http/contrib/pathTokenAuthorizer.d.ts +13 -0
- package/dist/http/contrib/pathTokenAuthorizer.d.ts.map +1 -0
- package/dist/http/contrib/pathTokenAuthorizer.js +19 -0
- package/dist/http/contrib/pathTokenAuthorizer.js.map +1 -0
- package/dist/http/contrib/pathTokenAuthorizer.test.d.ts +2 -0
- package/dist/http/contrib/pathTokenAuthorizer.test.d.ts.map +1 -0
- package/dist/http/contrib/pathTokenAuthorizer.test.js +29 -0
- package/dist/http/contrib/pathTokenAuthorizer.test.js.map +1 -0
- package/dist/http/contrib/queryStringValidator.d.ts +12 -0
- package/dist/http/contrib/queryStringValidator.d.ts.map +1 -0
- package/dist/http/contrib/queryStringValidator.js +15 -0
- package/dist/http/contrib/queryStringValidator.js.map +1 -0
- package/dist/http/contrib/queryStringValidator.test.d.ts +2 -0
- package/dist/http/contrib/queryStringValidator.test.d.ts.map +1 -0
- package/dist/http/contrib/queryStringValidator.test.js +46 -0
- package/dist/http/contrib/queryStringValidator.test.js.map +1 -0
- package/dist/http/contrib/requestResponseLogger.d.ts +5 -0
- package/dist/http/contrib/requestResponseLogger.d.ts.map +1 -0
- package/dist/http/contrib/requestResponseLogger.js +8 -0
- package/dist/http/contrib/requestResponseLogger.js.map +1 -0
- package/dist/http/contrib/requestResponseLogger.test.d.ts +2 -0
- package/dist/http/contrib/requestResponseLogger.test.d.ts.map +1 -0
- package/dist/http/contrib/requestResponseLogger.test.js +18 -0
- package/dist/http/contrib/requestResponseLogger.test.js.map +1 -0
- package/dist/http/contrib/responseProcessor.d.ts +8 -0
- package/dist/http/contrib/responseProcessor.d.ts.map +1 -0
- package/dist/http/contrib/responseProcessor.js +16 -0
- package/dist/http/contrib/responseProcessor.js.map +1 -0
- package/dist/http/contrib/responseProcessor.test.d.ts +2 -0
- package/dist/http/contrib/responseProcessor.test.d.ts.map +1 -0
- package/dist/http/contrib/responseProcessor.test.js +29 -0
- package/dist/http/contrib/responseProcessor.test.js.map +1 -0
- package/dist/http/contrib/standardRequestResponseAdapter.d.ts +16 -0
- package/dist/http/contrib/standardRequestResponseAdapter.d.ts.map +1 -0
- package/dist/http/contrib/standardRequestResponseAdapter.js +27 -0
- package/dist/http/contrib/standardRequestResponseAdapter.js.map +1 -0
- package/dist/http/contrib/standardRequestResponseAdapter.test.d.ts +2 -0
- package/dist/http/contrib/standardRequestResponseAdapter.test.d.ts.map +1 -0
- package/dist/http/contrib/standardRequestResponseAdapter.test.js +85 -0
- package/dist/http/contrib/standardRequestResponseAdapter.test.js.map +1 -0
- package/dist/http/contrib/trivial.d.ts +5 -0
- package/dist/http/contrib/trivial.d.ts.map +1 -0
- package/dist/http/contrib/trivial.js +9 -0
- package/dist/http/contrib/trivial.js.map +1 -0
- package/dist/http/contrib/trivial.test.d.ts +2 -0
- package/dist/http/contrib/trivial.test.d.ts.map +1 -0
- package/dist/http/contrib/trivial.test.js +14 -0
- package/dist/http/contrib/trivial.test.js.map +1 -0
- package/dist/http/index.d.ts +6 -0
- package/dist/http/index.d.ts.map +1 -0
- package/dist/http/index.js +6 -0
- package/dist/http/index.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/Logger.d.ts +23 -0
- package/dist/lib/Logger.d.ts.map +1 -0
- package/dist/lib/Logger.js +30 -0
- package/dist/lib/Logger.js.map +1 -0
- package/dist/lib/Logger.test.d.ts +2 -0
- package/dist/lib/Logger.test.d.ts.map +1 -0
- package/dist/lib/Logger.test.js +54 -0
- package/dist/lib/Logger.test.js.map +1 -0
- package/dist/lib/MiddlewareError.d.ts +10 -0
- package/dist/lib/MiddlewareError.d.ts.map +1 -0
- package/dist/lib/MiddlewareError.js +20 -0
- package/dist/lib/MiddlewareError.js.map +1 -0
- package/dist/lib/MiddlewareError.test.d.ts +2 -0
- package/dist/lib/MiddlewareError.test.d.ts.map +1 -0
- package/dist/lib/MiddlewareError.test.js +55 -0
- package/dist/lib/MiddlewareError.test.js.map +1 -0
- package/dist/lib/index.d.ts +4 -0
- package/dist/lib/index.d.ts.map +1 -0
- package/dist/lib/index.js +4 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/utils.d.ts +7 -0
- package/dist/lib/utils.d.ts.map +1 -0
- package/dist/lib/utils.js +11 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/lib/utils.test.d.ts +2 -0
- package/dist/lib/utils.test.d.ts.map +1 -0
- package/dist/lib/utils.test.js +47 -0
- package/dist/lib/utils.test.js.map +1 -0
- package/dist/test/kitchen-sink.test.d.ts +2 -0
- package/dist/test/kitchen-sink.test.d.ts.map +1 -0
- package/dist/test/kitchen-sink.test.js +76 -0
- package/dist/test/kitchen-sink.test.js.map +1 -0
- package/dist/test/round-trip.test.d.ts +2 -0
- package/dist/test/round-trip.test.d.ts.map +1 -0
- package/dist/test/round-trip.test.js +75 -0
- package/dist/test/round-trip.test.js.map +1 -0
- package/dist/test/test-common.d.ts +17 -0
- package/dist/test/test-common.d.ts.map +1 -0
- package/dist/test/test-common.js +25 -0
- package/dist/test/test-common.js.map +1 -0
- package/package.json +265 -0
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { okAsyncR } from '@konker.dev/neverthrow-r/constructors';
|
|
2
|
+
import { Hono } from 'hono';
|
|
3
|
+
import { describe, expect, it } from 'vitest';
|
|
4
|
+
import { recordingLogger } from '../../test/test-common.js';
|
|
5
|
+
import { EMPTY_RESPONSE_W } from '../ResponseW.js';
|
|
6
|
+
import { adaptFromHonoRequest, adaptToHonoResponse, middleware as honoAdapter } from './honoAdapter.js';
|
|
7
|
+
async function makeHonoRequest() {
|
|
8
|
+
// Use a minimal Hono app to obtain a real HonoRequest.
|
|
9
|
+
const app = new Hono();
|
|
10
|
+
let captured;
|
|
11
|
+
app.post('/echo/:id', (c) => {
|
|
12
|
+
captured = c.req;
|
|
13
|
+
return c.text('ok');
|
|
14
|
+
});
|
|
15
|
+
await app.request('/echo/42?q=1', {
|
|
16
|
+
method: 'POST',
|
|
17
|
+
headers: { 'x-test': 'yes' },
|
|
18
|
+
body: 'hello',
|
|
19
|
+
});
|
|
20
|
+
if (!captured)
|
|
21
|
+
throw new Error('no captured request');
|
|
22
|
+
return captured;
|
|
23
|
+
}
|
|
24
|
+
describe('honoAdapter', () => {
|
|
25
|
+
describe('adaptFromHonoRequest', () => {
|
|
26
|
+
it('flattens a HonoRequest into a RequestW', async () => {
|
|
27
|
+
const req = await makeHonoRequest();
|
|
28
|
+
const result = await adaptFromHonoRequest(req);
|
|
29
|
+
expect(result.isOk()).toBe(true);
|
|
30
|
+
if (result.isOk()) {
|
|
31
|
+
expect(result.value.method).toBe('POST');
|
|
32
|
+
expect(result.value.body).toBe('hello');
|
|
33
|
+
expect(result.value.headers['x-test']).toBe('yes');
|
|
34
|
+
expect(result.value.queryStringParameters.q).toBe('1');
|
|
35
|
+
expect(result.value.pathParameters.id).toBe('42');
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
describe('adaptToHonoResponse', () => {
|
|
40
|
+
it('produces a fetch Response from a ResponseW', async () => {
|
|
41
|
+
const result = await adaptToHonoResponse({
|
|
42
|
+
...EMPTY_RESPONSE_W,
|
|
43
|
+
body: 'hi',
|
|
44
|
+
});
|
|
45
|
+
expect(result.isOk()).toBe(true);
|
|
46
|
+
if (result.isOk()) {
|
|
47
|
+
expect(result.value.status).toBe(200);
|
|
48
|
+
expect(await result.value.text()).toBe('hi');
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
it('uses an empty body when none is provided', async () => {
|
|
52
|
+
const result = await adaptToHonoResponse(EMPTY_RESPONSE_W);
|
|
53
|
+
expect(result.isOk()).toBe(true);
|
|
54
|
+
if (result.isOk())
|
|
55
|
+
expect(await result.value.text()).toBe('');
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
describe('middleware', () => {
|
|
59
|
+
it('round-trips a HonoRequest through a wrapped handler', async () => {
|
|
60
|
+
const { logger } = recordingLogger();
|
|
61
|
+
const req = await makeHonoRequest();
|
|
62
|
+
const wrapped = honoAdapter()((_r) => okAsyncR({
|
|
63
|
+
...EMPTY_RESPONSE_W,
|
|
64
|
+
body: 'pong',
|
|
65
|
+
}));
|
|
66
|
+
const result = await wrapped(req)({ logger });
|
|
67
|
+
expect(result.isOk()).toBe(true);
|
|
68
|
+
if (result.isOk()) {
|
|
69
|
+
expect(result.value.status).toBe(200);
|
|
70
|
+
expect(await result.value.text()).toBe('pong');
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
//# sourceMappingURL=honoAdapter.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"honoAdapter.test.js","sourceRoot":"","sources":["../../../src/http/contrib/honoAdapter.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { Rec, RequestResponseHandler } from '../RequestResponseHandler.js';
|
|
2
|
+
export declare const TAG = "identity";
|
|
3
|
+
export declare const middleware: (_params?: never) => <I extends Rec, O extends Rec, E, R>(wrapped: RequestResponseHandler<I, R, O, E>) => RequestResponseHandler<I, R, O, E>;
|
|
4
|
+
//# sourceMappingURL=identity.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identity.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/identity.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAC;AAEhF,eAAO,MAAM,GAAG,aAAa,CAAC;AAE9B,eAAO,MAAM,UAAU,GACpB,UAAU,KAAK,MACf,CAAC,SAAS,GAAG,EAAE,CAAC,SAAS,GAAG,EAAE,CAAC,EAAE,CAAC,EACjC,SAAS,sBAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,KAC1C,sBAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAC3B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identity.js","sourceRoot":"","sources":["../../../src/http/contrib/identity.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,GAAG,GAAG,UAAU,CAAC;AAE9B,MAAM,CAAC,MAAM,UAAU,GACrB,CAAC,OAAe,EAAE,EAAE,CACpB,CACE,OAA2C,EACP,EAAE,CACtC,OAAO,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identity.test.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/identity.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { echoHandler, sampleRequestW } from '../../test/test-common.js';
|
|
3
|
+
import { middleware as identity } from './identity.js';
|
|
4
|
+
describe('identity middleware', () => {
|
|
5
|
+
it('returns the wrapped handler unchanged', async () => {
|
|
6
|
+
const handler = echoHandler();
|
|
7
|
+
const wrapped = identity()(handler);
|
|
8
|
+
const result = await wrapped(sampleRequestW)(undefined);
|
|
9
|
+
expect(result.isOk() && result.value.statusCode).toBe(200);
|
|
10
|
+
});
|
|
11
|
+
});
|
|
12
|
+
//# sourceMappingURL=identity.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identity.test.js","sourceRoot":"","sources":["../../../src/http/contrib/identity.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AACxE,OAAO,EAAE,UAAU,IAAI,QAAQ,EAAE,MAAM,eAAe,CAAC;AAEvD,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACrD,MAAM,OAAO,GAAG,WAAW,EAAE,CAAC;QAC9B,MAAM,OAAO,GAAG,QAAQ,EAAE,CAAC,OAAO,CAAC,CAAC;QACpC,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,cAAc,CAAC,CAAC,SAAS,CAAC,CAAC;QACxD,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC7D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export * as apiGatewayProxyEventV2Adapter from './apiGatewayProxyEventV2Adapter.js';
|
|
2
|
+
export * as base64BodyDecoder from './base64BodyDecoder.js';
|
|
3
|
+
export * as basicAuthAuthenticator from './basicAuthAuthenticator.js';
|
|
4
|
+
export * as basicAuthDecoder from './basicAuthDecoder.js';
|
|
5
|
+
export * as bodyValidator from './bodyValidator.js';
|
|
6
|
+
export * as envValidator from './envValidator.js';
|
|
7
|
+
export * as headerSignatureAuthorizer from './headerSignatureAuthorizer/index.js';
|
|
8
|
+
export * as headersNormalizer from './headersNormalizer/index.js';
|
|
9
|
+
export * as headersValidator from './headersValidator.js';
|
|
10
|
+
export * as helmetJsHeaders from './helmetJsHeaders.js';
|
|
11
|
+
export * as honoAdapter from './honoAdapter.js';
|
|
12
|
+
export * as identity from './identity.js';
|
|
13
|
+
export * as jsonBodyParserRequest from './jsonBodyParserRequest.js';
|
|
14
|
+
export * as jsonBodySerializerResponse from './jsonBodySerializerResponse.js';
|
|
15
|
+
export * as jwtAuthenticator from './jwtAuthenticator.js';
|
|
16
|
+
export * as jwtAuthenticatorRsa from './jwtAuthenticatorRsa.js';
|
|
17
|
+
export * as jwtDecoder from './jwtDecoder.js';
|
|
18
|
+
export * as pathParametersValidator from './pathParametersValidator.js';
|
|
19
|
+
export * as pathTokenAuthorizer from './pathTokenAuthorizer.js';
|
|
20
|
+
export * as queryStringValidator from './queryStringValidator.js';
|
|
21
|
+
export * as requestResponseLogger from './requestResponseLogger.js';
|
|
22
|
+
export * as responseProcessor from './responseProcessor.js';
|
|
23
|
+
export * as standardRequestResponseAdapter from './standardRequestResponseAdapter.js';
|
|
24
|
+
export * as trivial from './trivial.js';
|
|
25
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,6BAA6B,MAAM,oCAAoC,CAAC;AACpF,OAAO,KAAK,iBAAiB,MAAM,wBAAwB,CAAC;AAC5D,OAAO,KAAK,sBAAsB,MAAM,6BAA6B,CAAC;AACtE,OAAO,KAAK,gBAAgB,MAAM,uBAAuB,CAAC;AAC1D,OAAO,KAAK,aAAa,MAAM,oBAAoB,CAAC;AACpD,OAAO,KAAK,YAAY,MAAM,mBAAmB,CAAC;AAClD,OAAO,KAAK,yBAAyB,MAAM,sCAAsC,CAAC;AAClF,OAAO,KAAK,iBAAiB,MAAM,8BAA8B,CAAC;AAClE,OAAO,KAAK,gBAAgB,MAAM,uBAAuB,CAAC;AAC1D,OAAO,KAAK,eAAe,MAAM,sBAAsB,CAAC;AACxD,OAAO,KAAK,WAAW,MAAM,kBAAkB,CAAC;AAChD,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAC;AAC1C,OAAO,KAAK,qBAAqB,MAAM,4BAA4B,CAAC;AACpE,OAAO,KAAK,0BAA0B,MAAM,iCAAiC,CAAC;AAC9E,OAAO,KAAK,gBAAgB,MAAM,uBAAuB,CAAC;AAC1D,OAAO,KAAK,mBAAmB,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,UAAU,MAAM,iBAAiB,CAAC;AAC9C,OAAO,KAAK,uBAAuB,MAAM,8BAA8B,CAAC;AACxE,OAAO,KAAK,mBAAmB,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,oBAAoB,MAAM,2BAA2B,CAAC;AAClE,OAAO,KAAK,qBAAqB,MAAM,4BAA4B,CAAC;AACpE,OAAO,KAAK,iBAAiB,MAAM,wBAAwB,CAAC;AAC5D,OAAO,KAAK,8BAA8B,MAAM,qCAAqC,CAAC;AACtF,OAAO,KAAK,OAAO,MAAM,cAAc,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export * as apiGatewayProxyEventV2Adapter from './apiGatewayProxyEventV2Adapter.js';
|
|
2
|
+
export * as base64BodyDecoder from './base64BodyDecoder.js';
|
|
3
|
+
export * as basicAuthAuthenticator from './basicAuthAuthenticator.js';
|
|
4
|
+
export * as basicAuthDecoder from './basicAuthDecoder.js';
|
|
5
|
+
export * as bodyValidator from './bodyValidator.js';
|
|
6
|
+
export * as envValidator from './envValidator.js';
|
|
7
|
+
export * as headerSignatureAuthorizer from './headerSignatureAuthorizer/index.js';
|
|
8
|
+
export * as headersNormalizer from './headersNormalizer/index.js';
|
|
9
|
+
export * as headersValidator from './headersValidator.js';
|
|
10
|
+
export * as helmetJsHeaders from './helmetJsHeaders.js';
|
|
11
|
+
export * as honoAdapter from './honoAdapter.js';
|
|
12
|
+
export * as identity from './identity.js';
|
|
13
|
+
export * as jsonBodyParserRequest from './jsonBodyParserRequest.js';
|
|
14
|
+
export * as jsonBodySerializerResponse from './jsonBodySerializerResponse.js';
|
|
15
|
+
export * as jwtAuthenticator from './jwtAuthenticator.js';
|
|
16
|
+
export * as jwtAuthenticatorRsa from './jwtAuthenticatorRsa.js';
|
|
17
|
+
export * as jwtDecoder from './jwtDecoder.js';
|
|
18
|
+
export * as pathParametersValidator from './pathParametersValidator.js';
|
|
19
|
+
export * as pathTokenAuthorizer from './pathTokenAuthorizer.js';
|
|
20
|
+
export * as queryStringValidator from './queryStringValidator.js';
|
|
21
|
+
export * as requestResponseLogger from './requestResponseLogger.js';
|
|
22
|
+
export * as responseProcessor from './responseProcessor.js';
|
|
23
|
+
export * as standardRequestResponseAdapter from './standardRequestResponseAdapter.js';
|
|
24
|
+
export * as trivial from './trivial.js';
|
|
25
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/http/contrib/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,6BAA6B,MAAM,oCAAoC,CAAC;AACpF,OAAO,KAAK,iBAAiB,MAAM,wBAAwB,CAAC;AAC5D,OAAO,KAAK,sBAAsB,MAAM,6BAA6B,CAAC;AACtE,OAAO,KAAK,gBAAgB,MAAM,uBAAuB,CAAC;AAC1D,OAAO,KAAK,aAAa,MAAM,oBAAoB,CAAC;AACpD,OAAO,KAAK,YAAY,MAAM,mBAAmB,CAAC;AAClD,OAAO,KAAK,yBAAyB,MAAM,sCAAsC,CAAC;AAClF,OAAO,KAAK,iBAAiB,MAAM,8BAA8B,CAAC;AAClE,OAAO,KAAK,gBAAgB,MAAM,uBAAuB,CAAC;AAC1D,OAAO,KAAK,eAAe,MAAM,sBAAsB,CAAC;AACxD,OAAO,KAAK,WAAW,MAAM,kBAAkB,CAAC;AAChD,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAC;AAC1C,OAAO,KAAK,qBAAqB,MAAM,4BAA4B,CAAC;AACpE,OAAO,KAAK,0BAA0B,MAAM,iCAAiC,CAAC;AAC9E,OAAO,KAAK,gBAAgB,MAAM,uBAAuB,CAAC;AAC1D,OAAO,KAAK,mBAAmB,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,UAAU,MAAM,iBAAiB,CAAC;AAC9C,OAAO,KAAK,uBAAuB,MAAM,8BAA8B,CAAC;AACxE,OAAO,KAAK,mBAAmB,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,oBAAoB,MAAM,2BAA2B,CAAC;AAClE,OAAO,KAAK,qBAAqB,MAAM,4BAA4B,CAAC;AACpE,OAAO,KAAK,iBAAiB,MAAM,wBAAwB,CAAC;AAC5D,OAAO,KAAK,8BAA8B,MAAM,qCAAqC,CAAC;AACtF,OAAO,KAAK,OAAO,MAAM,cAAc,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { WithLogger } from '../../lib/Logger.js';
|
|
2
|
+
import type { MiddlewareError } from '../../lib/MiddlewareError.js';
|
|
3
|
+
import type { BodyRec, Override, RequestResponseHandler, StrBodyRec } from '../RequestResponseHandler.js';
|
|
4
|
+
export declare const TAG = "jsonBodyParserRequest";
|
|
5
|
+
export type WithParsedBody = {
|
|
6
|
+
readonly body: unknown;
|
|
7
|
+
readonly jsonBodyParserRaw: string | undefined;
|
|
8
|
+
};
|
|
9
|
+
export declare const middleware: () => <I extends StrBodyRec, O extends BodyRec, E, R>(wrapped: RequestResponseHandler<Override<I, WithParsedBody>, R, O, E>) => RequestResponseHandler<I, R & WithLogger, O, E | MiddlewareError>;
|
|
10
|
+
//# sourceMappingURL=jsonBodyParserRequest.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonBodyParserRequest.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/jsonBodyParserRequest.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEtD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAEpE,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,sBAAsB,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAI1G,eAAO,MAAM,GAAG,0BAA0B,CAAC;AAE3C,MAAM,MAAM,cAAc,GAAG;IAC3B,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC;IACvB,QAAQ,CAAC,iBAAiB,EAAE,MAAM,GAAG,SAAS,CAAC;CAChD,CAAC;AAEF,eAAO,MAAM,UAAU,SAEpB,CAAC,SAAS,UAAU,EAAE,CAAC,SAAS,OAAO,EAAE,CAAC,EAAE,CAAC,EAC5C,SAAS,sBAAsB,CAAC,QAAQ,CAAC,CAAC,EAAE,cAAc,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,KACpE,sBAAsB,CAAC,CAAC,EAAE,CAAC,GAAG,UAAU,EAAE,CAAC,EAAE,CAAC,GAAG,eAAe,CA6BhE,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { andThenAsync, mapAsync } from '@konker.dev/neverthrow-r/async';
|
|
2
|
+
import { errAsyncR, okAsyncR } from '@konker.dev/neverthrow-r/constructors';
|
|
3
|
+
import { pipe } from '@konker.dev/neverthrow-r/pipe';
|
|
4
|
+
import { tapLogger } from '../../lib/Logger.js';
|
|
5
|
+
import { tryJsonParse } from '../../lib/utils.js';
|
|
6
|
+
import { makeRequestW } from '../RequestW.js';
|
|
7
|
+
import { makeResponseW } from '../ResponseW.js';
|
|
8
|
+
export const TAG = 'jsonBodyParserRequest';
|
|
9
|
+
export const middleware = () => (wrapped) => (i) => pipe(okAsyncR(i), tapLogger('debug', `[${TAG}] IN`), andThenAsync((req) => {
|
|
10
|
+
const raw = req.body;
|
|
11
|
+
if (raw === undefined || raw === '') {
|
|
12
|
+
return okAsyncR(makeRequestW(req, {
|
|
13
|
+
body: undefined,
|
|
14
|
+
jsonBodyParserRaw: raw,
|
|
15
|
+
}));
|
|
16
|
+
}
|
|
17
|
+
return tryJsonParse(raw).match((value) => okAsyncR(makeRequestW(req, {
|
|
18
|
+
body: value,
|
|
19
|
+
jsonBodyParserRaw: raw,
|
|
20
|
+
})), (error) => errAsyncR(error));
|
|
21
|
+
}), andThenAsync(wrapped), mapAsync((res) => makeResponseW(res)), tapLogger('debug', `[${TAG}] OUT`));
|
|
22
|
+
//# sourceMappingURL=jsonBodyParserRequest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonBodyParserRequest.js","sourceRoot":"","sources":["../../../src/http/contrib/jsonBodyParserRequest.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,IAAI,EAAE,MAAM,+BAA+B,CAAC;AAGrD,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD,OAAO,EAAE,YAAY,EAAiB,MAAM,gBAAgB,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhD,MAAM,CAAC,MAAM,GAAG,GAAG,uBAAuB,CAAC;AAO3C,MAAM,CAAC,MAAM,UAAU,GACrB,GAAG,EAAE,CACL,CACE,OAAqE,EACF,EAAE,CACvE,CAAC,CAAc,EAAE,EAAE,CACjB,IAAI,CACF,QAAQ,CAAC,CAAC,CAAC,EACX,SAAS,CAAC,OAAO,EAAE,IAAI,GAAG,MAAM,CAAC,EACjC,YAAY,CAAC,CAAC,GAAgB,EAAE,EAAE;IAChC,MAAM,GAAG,GAAG,GAAG,CAAC,IAAI,CAAC;IACrB,IAAI,GAAG,KAAK,SAAS,IAAI,GAAG,KAAK,EAAE,EAAE,CAAC;QACpC,OAAO,QAAQ,CACb,YAAY,CAAC,GAAG,EAAE;YAChB,IAAI,EAAE,SAAoB;YAC1B,iBAAiB,EAAE,GAAG;SACvB,CAAC,CACH,CAAC;IACJ,CAAC;IACD,OAAO,YAAY,CAAC,GAAG,CAAC,CAAC,KAAK,CAC5B,CAAC,KAAK,EAAE,EAAE,CACR,QAAQ,CACN,YAAY,CAAC,GAAG,EAAE;QAChB,IAAI,EAAE,KAAK;QACX,iBAAiB,EAAE,GAAG;KACvB,CAAC,CACH,EACH,CAAC,KAAK,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAC5B,CAAC;AACJ,CAAC,CAAC,EACF,YAAY,CAAC,OAAO,CAAC,EACrB,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,EACrC,SAAS,CAAC,OAAO,EAAE,IAAI,GAAG,OAAO,CAAC,CACnC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonBodyParserRequest.test.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/jsonBodyParserRequest.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { okAsyncR } from '@konker.dev/neverthrow-r/constructors';
|
|
2
|
+
import { describe, expect, it } from 'vitest';
|
|
3
|
+
import { recordingLogger, sampleRequestW } from '../../test/test-common.js';
|
|
4
|
+
import { makeRequestW } from '../RequestW.js';
|
|
5
|
+
import { EMPTY_RESPONSE_W } from '../ResponseW.js';
|
|
6
|
+
import { middleware as jsonBodyParserRequest } from './jsonBodyParserRequest.js';
|
|
7
|
+
describe('jsonBodyParserRequest', () => {
|
|
8
|
+
it('parses a JSON body and forwards it to the wrapped handler', async () => {
|
|
9
|
+
const { logger } = recordingLogger();
|
|
10
|
+
const wrapped = jsonBodyParserRequest()((req) => okAsyncR({
|
|
11
|
+
...EMPTY_RESPONSE_W,
|
|
12
|
+
body: req.body,
|
|
13
|
+
}));
|
|
14
|
+
const input = makeRequestW(sampleRequestW, { body: '{"a":1}' });
|
|
15
|
+
const result = await wrapped(input)({ logger });
|
|
16
|
+
expect(result.isOk() && result.value.body).toEqual({
|
|
17
|
+
a: 1,
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
it('passes undefined through when there is no body', async () => {
|
|
21
|
+
const { logger } = recordingLogger();
|
|
22
|
+
const wrapped = jsonBodyParserRequest()((req) => okAsyncR({
|
|
23
|
+
...EMPTY_RESPONSE_W,
|
|
24
|
+
body: req.body,
|
|
25
|
+
}));
|
|
26
|
+
const result = await wrapped(sampleRequestW)({ logger });
|
|
27
|
+
expect(result.isOk() && result.value.body).toBeUndefined();
|
|
28
|
+
});
|
|
29
|
+
it('fails with a MiddlewareError on invalid JSON', async () => {
|
|
30
|
+
const { logger } = recordingLogger();
|
|
31
|
+
const wrapped = jsonBodyParserRequest()((_req) => okAsyncR(EMPTY_RESPONSE_W));
|
|
32
|
+
const input = makeRequestW(sampleRequestW, { body: 'not json' });
|
|
33
|
+
const result = await wrapped(input)({ logger });
|
|
34
|
+
expect(result.isErr() && result.error.message).toBe('Invalid JSON');
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
//# sourceMappingURL=jsonBodyParserRequest.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonBodyParserRequest.test.js","sourceRoot":"","sources":["../../../src/http/contrib/jsonBodyParserRequest.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,uCAAuC,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC5E,OAAO,EAAE,YAAY,EAAiB,MAAM,gBAAgB,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAkB,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,UAAU,IAAI,qBAAqB,EAAuB,MAAM,4BAA4B,CAAC;AAEtG,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,EAAE,CAAC,2DAA2D,EAAE,KAAK,IAAI,EAAE;QACzE,MAAM,EAAE,MAAM,EAAE,GAAG,eAAe,EAAE,CAAC;QACrC,MAAM,OAAO,GAAG,qBAAqB,EAAE,CAAC,CAAC,GAA6B,EAAE,EAAE,CACxE,QAAQ,CAAY;YAClB,GAAG,gBAAgB;YACnB,IAAI,EAAE,GAAG,CAAC,IAAI;SACF,CAAC,CAChB,CAAC;QACF,MAAM,KAAK,GAAG,YAAY,CAAC,cAAc,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;QAChE,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QAChD,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAK,MAAM,CAAC,KAA4B,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC;YACzE,CAAC,EAAE,CAAC;SACL,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,KAAK,IAAI,EAAE;QAC9D,MAAM,EAAE,MAAM,EAAE,GAAG,eAAe,EAAE,CAAC;QACrC,MAAM,OAAO,GAAG,qBAAqB,EAAE,CAAC,CAAC,GAA6B,EAAE,EAAE,CACxE,QAAQ,CAAY;YAClB,GAAG,gBAAgB;YACnB,IAAI,EAAE,GAAG,CAAC,IAAI;SACF,CAAC,CAChB,CAAC;QACF,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAK,MAAM,CAAC,KAA4B,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC;IACrF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;QAC5D,MAAM,EAAE,MAAM,EAAE,GAAG,eAAe,EAAE,CAAC;QACrC,MAAM,OAAO,GAAG,qBAAqB,EAAE,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,QAAQ,CAAY,gBAAgB,CAAC,CAAC,CAAC;QACzF,MAAM,KAAK,GAAG,YAAY,CAAC,cAAc,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QACjE,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QAChD,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { WithLogger } from '../../lib/Logger.js';
|
|
2
|
+
import type { MiddlewareError } from '../../lib/MiddlewareError.js';
|
|
3
|
+
import type { BodyRec, Override, RequestResponseHandler, StrBodyRec } from '../RequestResponseHandler.js';
|
|
4
|
+
export declare const TAG = "jsonBodySerializerResponse";
|
|
5
|
+
export type WithSerializedBody = {
|
|
6
|
+
readonly body: string;
|
|
7
|
+
};
|
|
8
|
+
export declare const middleware: () => <I extends StrBodyRec, O extends BodyRec, E, R>(wrapped: RequestResponseHandler<I, R, O, E>) => RequestResponseHandler<I, R & WithLogger, Override<O, WithSerializedBody>, E | MiddlewareError>;
|
|
9
|
+
//# sourceMappingURL=jsonBodySerializerResponse.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonBodySerializerResponse.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/jsonBodySerializerResponse.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEtD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAEpE,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,sBAAsB,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAI1G,eAAO,MAAM,GAAG,+BAA+B,CAAC;AAEhD,MAAM,MAAM,kBAAkB,GAAG;IAC/B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,eAAO,MAAM,UAAU,SAEpB,CAAC,SAAS,UAAU,EAAE,CAAC,SAAS,OAAO,EAAE,CAAC,EAAE,CAAC,EAC5C,SAAS,sBAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,KAC1C,sBAAsB,CAAC,CAAC,EAAE,CAAC,GAAG,UAAU,EAAE,QAAQ,CAAC,CAAC,EAAE,kBAAkB,CAAC,EAAE,CAAC,GAAG,eAAe,CAiB9F,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { andThenAsync, mapAsync } from '@konker.dev/neverthrow-r/async';
|
|
2
|
+
import { errAsyncR, okAsyncR } from '@konker.dev/neverthrow-r/constructors';
|
|
3
|
+
import { pipe } from '@konker.dev/neverthrow-r/pipe';
|
|
4
|
+
import { tapLogger } from '../../lib/Logger.js';
|
|
5
|
+
import { tryJsonStringify } from '../../lib/utils.js';
|
|
6
|
+
import {} from '../RequestW.js';
|
|
7
|
+
import { makeResponseW } from '../ResponseW.js';
|
|
8
|
+
export const TAG = 'jsonBodySerializerResponse';
|
|
9
|
+
export const middleware = () => (wrapped) => (i) => pipe(okAsyncR(i), tapLogger('debug', `[${TAG}] IN`), andThenAsync(wrapped), andThenAsync((res) => {
|
|
10
|
+
if (res.body === undefined) {
|
|
11
|
+
return okAsyncR(makeResponseW(res, { body: '' }));
|
|
12
|
+
}
|
|
13
|
+
return tryJsonStringify(res.body).match((value) => okAsyncR(makeResponseW(res, { body: value })), (error) => errAsyncR(error));
|
|
14
|
+
}), mapAsync((res) => makeResponseW(res)), tapLogger('debug', `[${TAG}] OUT`));
|
|
15
|
+
//# sourceMappingURL=jsonBodySerializerResponse.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonBodySerializerResponse.js","sourceRoot":"","sources":["../../../src/http/contrib/jsonBodySerializerResponse.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,IAAI,EAAE,MAAM,+BAA+B,CAAC;AAGrD,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEtD,OAAO,EAAiB,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAkB,MAAM,iBAAiB,CAAC;AAEhE,MAAM,CAAC,MAAM,GAAG,GAAG,4BAA4B,CAAC;AAMhD,MAAM,CAAC,MAAM,UAAU,GACrB,GAAG,EAAE,CACL,CACE,OAA2C,EACsD,EAAE,CACrG,CAAC,CAAc,EAAE,EAAE,CACjB,IAAI,CACF,QAAQ,CAAC,CAAC,CAAC,EACX,SAAS,CAAC,OAAO,EAAE,IAAI,GAAG,MAAM,CAAC,EACjC,YAAY,CAAC,OAAO,CAAC,EACrB,YAAY,CAAC,CAAC,GAAiB,EAAE,EAAE;IACjC,IAAI,GAAG,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC3B,OAAO,QAAQ,CAAC,aAAa,CAAC,GAAG,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACpD,CAAC;IACD,OAAO,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,KAAK,CACrC,CAAC,KAAK,EAAE,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC,GAAG,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,EACxD,CAAC,KAAK,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAC5B,CAAC;AACJ,CAAC,CAAC,EACF,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,EACrC,SAAS,CAAC,OAAO,EAAE,IAAI,GAAG,OAAO,CAAC,CACnC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonBodySerializerResponse.test.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/jsonBodySerializerResponse.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { okAsyncR } from '@konker.dev/neverthrow-r/constructors';
|
|
2
|
+
import { describe, expect, it } from 'vitest';
|
|
3
|
+
import { recordingLogger, sampleRequestW } from '../../test/test-common.js';
|
|
4
|
+
import { EMPTY_RESPONSE_W } from '../ResponseW.js';
|
|
5
|
+
import { middleware as jsonBodySerializerResponse } from './jsonBodySerializerResponse.js';
|
|
6
|
+
describe('jsonBodySerializerResponse', () => {
|
|
7
|
+
it('serialises a structured body to a JSON string', async () => {
|
|
8
|
+
const { logger } = recordingLogger();
|
|
9
|
+
const wrapped = jsonBodySerializerResponse()(() => okAsyncR({
|
|
10
|
+
...EMPTY_RESPONSE_W,
|
|
11
|
+
body: { hello: 'world' },
|
|
12
|
+
}));
|
|
13
|
+
const result = await wrapped(sampleRequestW)({ logger });
|
|
14
|
+
expect(result.isOk() && result.value.body).toBe('{"hello":"world"}');
|
|
15
|
+
});
|
|
16
|
+
it('produces an empty-string body when the response has no body', async () => {
|
|
17
|
+
const { logger } = recordingLogger();
|
|
18
|
+
const wrapped = jsonBodySerializerResponse()(() => okAsyncR(EMPTY_RESPONSE_W));
|
|
19
|
+
const result = await wrapped(sampleRequestW)({ logger });
|
|
20
|
+
expect(result.isOk() && result.value.body).toBe('');
|
|
21
|
+
});
|
|
22
|
+
it('fails with a MiddlewareError for circular references', async () => {
|
|
23
|
+
const { logger } = recordingLogger();
|
|
24
|
+
const circ = {};
|
|
25
|
+
circ.self = circ;
|
|
26
|
+
const wrapped = jsonBodySerializerResponse()(() => okAsyncR({ ...EMPTY_RESPONSE_W, body: circ }));
|
|
27
|
+
const result = await wrapped(sampleRequestW)({ logger });
|
|
28
|
+
expect(result.isErr() && result.error.message).toBe('JSON stringify failed');
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
//# sourceMappingURL=jsonBodySerializerResponse.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonBodySerializerResponse.test.js","sourceRoot":"","sources":["../../../src/http/contrib/jsonBodySerializerResponse.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,uCAAuC,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC5E,OAAO,EAAE,gBAAgB,EAAkB,MAAM,iBAAiB,CAAC;AACnE,OAAO,EAAE,UAAU,IAAI,0BAA0B,EAAE,MAAM,iCAAiC,CAAC;AAE3F,QAAQ,CAAC,4BAA4B,EAAE,GAAG,EAAE;IAC1C,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,MAAM,EAAE,MAAM,EAAE,GAAG,eAAe,EAAE,CAAC;QACrC,MAAM,OAAO,GAAG,0BAA0B,EAAE,CAAC,GAAG,EAAE,CAChD,QAAQ,CAAY;YAClB,GAAG,gBAAgB;YACnB,IAAI,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE;SACZ,CAAC,CAChB,CAAC;QACF,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6DAA6D,EAAE,KAAK,IAAI,EAAE;QAC3E,MAAM,EAAE,MAAM,EAAE,GAAG,eAAe,EAAE,CAAC;QACrC,MAAM,OAAO,GAAG,0BAA0B,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAY,gBAAgB,CAAC,CAAC,CAAC;QAC1F,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sDAAsD,EAAE,KAAK,IAAI,EAAE;QACpE,MAAM,EAAE,MAAM,EAAE,GAAG,eAAe,EAAE,CAAC;QACrC,MAAM,IAAI,GAA4B,EAAE,CAAC;QACzC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,MAAM,OAAO,GAAG,0BAA0B,EAAE,CAAC,GAAG,EAAE,CAChD,QAAQ,CAAY,EAAE,GAAG,gBAAgB,EAAE,IAAI,EAAE,IAAI,EAAe,CAAC,CACtE,CAAC;QACF,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;IAC/E,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { JwtVerificationConfig } from '@konker.dev/neverthrow-r-auth-utils/jwt';
|
|
2
|
+
import type { Handler } from '../../handler.js';
|
|
3
|
+
import type { WithLogger } from '../../lib/Logger.js';
|
|
4
|
+
import type { HttpApiError } from '../HttpApiError.js';
|
|
5
|
+
import type { Rec } from '../Rec.js';
|
|
6
|
+
import { type RequestW } from '../RequestW.js';
|
|
7
|
+
import type { ResponseW } from '../ResponseW.js';
|
|
8
|
+
import type { WithNormalizedInputHeaders } from './headersNormalizer/types.js';
|
|
9
|
+
export declare const TAG = "jwtAuthenticator";
|
|
10
|
+
export type JwtAuthenticatorDeps = JwtVerificationConfig;
|
|
11
|
+
export type WithUserId = {
|
|
12
|
+
readonly userId: string | undefined;
|
|
13
|
+
};
|
|
14
|
+
export declare const middleware: () => <I extends Rec, O extends Rec, E, R>(wrapped: Handler<RequestW<I & WithNormalizedInputHeaders & WithUserId>, R, ResponseW<O>, E>) => Handler<RequestW<I & WithNormalizedInputHeaders>, R & WithLogger & JwtAuthenticatorDeps, ResponseW<O>, E | HttpApiError>;
|
|
15
|
+
//# sourceMappingURL=jwtAuthenticator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwtAuthenticator.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/jwtAuthenticator.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAIrF,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEvD,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,8BAA8B,CAAC;AAE/E,eAAO,MAAM,GAAG,qBAAqB,CAAC;AAEtC,MAAM,MAAM,oBAAoB,GAAG,qBAAqB,CAAC;AAEzD,MAAM,MAAM,UAAU,GAAG;IACvB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;CACrC,CAAC;AAEF,eAAO,MAAM,UAAU,SAEpB,CAAC,SAAS,GAAG,EAAE,CAAC,SAAS,GAAG,EAAE,CAAC,EAAE,CAAC,EACjC,SAAS,OAAO,CAAC,QAAQ,CAAC,CAAC,GAAG,0BAA0B,GAAG,UAAU,CAAC,EAAE,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAC1F,OAAO,CACR,QAAQ,CAAC,CAAC,GAAG,0BAA0B,CAAC,EACxC,CAAC,GAAG,UAAU,GAAG,oBAAoB,EACrC,SAAS,CAAC,CAAC,CAAC,EACZ,CAAC,GAAG,YAAY,CAiCjB,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { extractBearerToken } from '@konker.dev/neverthrow-r-auth-utils/helpers';
|
|
2
|
+
import { jwtVerifyToken } from '@konker.dev/neverthrow-r-auth-utils/jwt';
|
|
3
|
+
import { errAsync } from 'neverthrow';
|
|
4
|
+
import { toHttpApiError } from '../HttpApiError.js';
|
|
5
|
+
import {} from '../RequestW.js';
|
|
6
|
+
export const TAG = 'jwtAuthenticator';
|
|
7
|
+
export const middleware = () => (wrapped) => (i) => (r) => {
|
|
8
|
+
r.logger.debug(`[${TAG}] IN`);
|
|
9
|
+
const authResult = extractBearerToken(i.headers.authorization)(undefined).andThen((authToken) => jwtVerifyToken(authToken, r)(undefined));
|
|
10
|
+
if (authResult.isErr()) {
|
|
11
|
+
const error = toHttpApiError(authResult.error, 401, `Invalid JWT credentials: ${authResult.error instanceof Error ? authResult.error.message : String(authResult.error)}`);
|
|
12
|
+
r.logger.error(error);
|
|
13
|
+
return errAsync(error);
|
|
14
|
+
}
|
|
15
|
+
if (!authResult.value.verified) {
|
|
16
|
+
const error = toHttpApiError(undefined, 401, 'Invalid JWT credentials');
|
|
17
|
+
r.logger.error(error);
|
|
18
|
+
return errAsync(error);
|
|
19
|
+
}
|
|
20
|
+
return wrapped({
|
|
21
|
+
...i,
|
|
22
|
+
userId: authResult.value.sub,
|
|
23
|
+
})(r).map((res) => {
|
|
24
|
+
r.logger.debug(`[${TAG}] OUT`);
|
|
25
|
+
return res;
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=jwtAuthenticator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwtAuthenticator.js","sourceRoot":"","sources":["../../../src/http/contrib/jwtAuthenticator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,6CAA6C,CAAC;AAEjF,OAAO,EAAE,cAAc,EAAE,MAAM,yCAAyC,CAAC;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAKtC,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,OAAO,EAAiB,MAAM,gBAAgB,CAAC;AAI/C,MAAM,CAAC,MAAM,GAAG,GAAG,kBAAkB,CAAC;AAQtC,MAAM,CAAC,MAAM,UAAU,GACrB,GAAG,EAAE,CACL,CACE,OAA2F,EAM3F,EAAE,CACJ,CAAC,CAAC,EAAE,EAAE,CACN,CAAC,CAAC,EAAE,EAAE;IACJ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC,CAAC;IAE9B,MAAM,UAAU,GAAG,kBAAkB,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE,CAC9F,cAAc,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CACxC,CAAC;IAEF,IAAI,UAAU,CAAC,KAAK,EAAE,EAAE,CAAC;QACvB,MAAM,KAAK,GAAG,cAAc,CAC1B,UAAU,CAAC,KAAK,EAChB,GAAG,EACH,4BAA4B,UAAU,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CACtH,CAAC;QACF,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACtB,OAAO,QAAQ,CAAiC,KAAK,CAAC,CAAC;IACzD,CAAC;IAED,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QAC/B,MAAM,KAAK,GAAG,cAAc,CAAC,SAAS,EAAE,GAAG,EAAE,yBAAyB,CAAC,CAAC;QACxE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACtB,OAAO,QAAQ,CAAiC,KAAK,CAAC,CAAC;IACzD,CAAC;IAED,OAAO,OAAO,CAAC;QACb,GAAG,CAAC;QACJ,MAAM,EAAE,UAAU,CAAC,KAAK,CAAC,GAAG;KAC4B,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;QACzE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,GAAG,OAAO,CAAC,CAAC;QAC/B,OAAO,GAAG,CAAC;IACb,CAAC,CAAC,CAAC;AACL,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwtAuthenticator.test.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/jwtAuthenticator.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { errR, okAsyncR } from '@konker.dev/neverthrow-r/constructors';
|
|
2
|
+
import * as helpers from '@konker.dev/neverthrow-r-auth-utils/helpers';
|
|
3
|
+
import { TEST_JWT_ISS, TEST_JWT_NOW_MS, TEST_JWT_SIGNING_SECRET, } from '@konker.dev/neverthrow-r-auth-utils/test/fixtures/jwt';
|
|
4
|
+
import { TEST_TOKEN_STRING_PAYLOAD } from '@konker.dev/neverthrow-r-auth-utils/test/fixtures/test-jwt-tokens';
|
|
5
|
+
import { TEST_TOKEN } from '@konker.dev/neverthrow-r-auth-utils/test/fixtures/test-jwt-tokens';
|
|
6
|
+
import { afterEach, describe, expect, it, vi } from 'vitest';
|
|
7
|
+
import { recordingLogger, sampleRequestW } from '../../test/test-common.js';
|
|
8
|
+
import { makeRequestW } from '../RequestW.js';
|
|
9
|
+
import { EMPTY_RESPONSE_W } from '../ResponseW.js';
|
|
10
|
+
import { middleware as jwtAuthenticator } from './jwtAuthenticator.js';
|
|
11
|
+
describe('jwtAuthenticator', () => {
|
|
12
|
+
afterEach(() => {
|
|
13
|
+
vi.restoreAllMocks();
|
|
14
|
+
});
|
|
15
|
+
it('authenticates a valid JWT', async () => {
|
|
16
|
+
vi.spyOn(Date, 'now').mockReturnValue(TEST_JWT_NOW_MS);
|
|
17
|
+
const { logger } = recordingLogger();
|
|
18
|
+
const wrapped = jwtAuthenticator()((req) => okAsyncR({
|
|
19
|
+
...EMPTY_RESPONSE_W,
|
|
20
|
+
body: req.userId,
|
|
21
|
+
}));
|
|
22
|
+
const input = makeRequestW(sampleRequestW, {
|
|
23
|
+
headers: { authorization: `Bearer ${TEST_TOKEN}` },
|
|
24
|
+
headersNormalizerRequestRaw: { Authorization: `Bearer ${TEST_TOKEN}` },
|
|
25
|
+
});
|
|
26
|
+
const result = await wrapped(input)({
|
|
27
|
+
logger,
|
|
28
|
+
issuer: TEST_JWT_ISS,
|
|
29
|
+
signingSecret: TEST_JWT_SIGNING_SECRET,
|
|
30
|
+
});
|
|
31
|
+
expect(result.isOk() && result.value.body).toBe('test-sub');
|
|
32
|
+
});
|
|
33
|
+
it('returns a 401 HttpApiError for an invalid JWT', async () => {
|
|
34
|
+
const { logger } = recordingLogger();
|
|
35
|
+
const wrapped = jwtAuthenticator()(() => okAsyncR(EMPTY_RESPONSE_W));
|
|
36
|
+
const input = makeRequestW(sampleRequestW, {
|
|
37
|
+
headers: { authorization: 'Bearer banana' },
|
|
38
|
+
headersNormalizerRequestRaw: { Authorization: 'Bearer banana' },
|
|
39
|
+
});
|
|
40
|
+
const result = await wrapped(input)({
|
|
41
|
+
logger,
|
|
42
|
+
issuer: TEST_JWT_ISS,
|
|
43
|
+
signingSecret: TEST_JWT_SIGNING_SECRET,
|
|
44
|
+
});
|
|
45
|
+
expect(result.isErr() && result.error.statusCode).toBe(401);
|
|
46
|
+
});
|
|
47
|
+
it('returns a 401 HttpApiError when the auth header is missing', async () => {
|
|
48
|
+
const { logger } = recordingLogger();
|
|
49
|
+
const wrapped = jwtAuthenticator()(() => okAsyncR(EMPTY_RESPONSE_W));
|
|
50
|
+
const input = makeRequestW(sampleRequestW, {
|
|
51
|
+
headers: {},
|
|
52
|
+
headersNormalizerRequestRaw: {},
|
|
53
|
+
});
|
|
54
|
+
const result = await wrapped(input)({
|
|
55
|
+
logger,
|
|
56
|
+
issuer: TEST_JWT_ISS,
|
|
57
|
+
signingSecret: TEST_JWT_SIGNING_SECRET,
|
|
58
|
+
});
|
|
59
|
+
expect(result.isErr() && result.error.statusCode).toBe(401);
|
|
60
|
+
});
|
|
61
|
+
it('returns a 401 HttpApiError when verification returns unverified', async () => {
|
|
62
|
+
vi.spyOn(Date, 'now').mockReturnValue(TEST_JWT_NOW_MS);
|
|
63
|
+
const { logger } = recordingLogger();
|
|
64
|
+
const wrapped = jwtAuthenticator()(() => okAsyncR(EMPTY_RESPONSE_W));
|
|
65
|
+
const input = makeRequestW(sampleRequestW, {
|
|
66
|
+
headers: { authorization: `Bearer ${TEST_TOKEN_STRING_PAYLOAD}` },
|
|
67
|
+
headersNormalizerRequestRaw: { Authorization: `Bearer ${TEST_TOKEN_STRING_PAYLOAD}` },
|
|
68
|
+
});
|
|
69
|
+
const result = await wrapped(input)({
|
|
70
|
+
logger,
|
|
71
|
+
issuer: TEST_JWT_ISS,
|
|
72
|
+
signingSecret: TEST_JWT_SIGNING_SECRET,
|
|
73
|
+
});
|
|
74
|
+
expect(result.isErr() && result.error.statusCode).toBe(401);
|
|
75
|
+
});
|
|
76
|
+
it('stringifies non-Error bearer extraction failures', async () => {
|
|
77
|
+
vi.spyOn(helpers, 'extractBearerToken').mockReturnValue(errR('boom'));
|
|
78
|
+
const { logger } = recordingLogger();
|
|
79
|
+
const wrapped = jwtAuthenticator()(() => okAsyncR(EMPTY_RESPONSE_W));
|
|
80
|
+
const result = await wrapped(makeRequestW(sampleRequestW, { headers: {}, headersNormalizerRequestRaw: {} }))({
|
|
81
|
+
logger,
|
|
82
|
+
issuer: TEST_JWT_ISS,
|
|
83
|
+
signingSecret: TEST_JWT_SIGNING_SECRET,
|
|
84
|
+
});
|
|
85
|
+
expect(result.isErr() && result.error.message).toContain('boom');
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
//# sourceMappingURL=jwtAuthenticator.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwtAuthenticator.test.js","sourceRoot":"","sources":["../../../src/http/contrib/jwtAuthenticator.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { JwtVerificationConfigRsa } from '@konker.dev/neverthrow-r-auth-utils/jwt/rsa';
|
|
2
|
+
import type { Handler } from '../../handler.js';
|
|
3
|
+
import type { WithLogger } from '../../lib/Logger.js';
|
|
4
|
+
import type { HttpApiError } from '../HttpApiError.js';
|
|
5
|
+
import type { Rec } from '../Rec.js';
|
|
6
|
+
import { type RequestW } from '../RequestW.js';
|
|
7
|
+
import type { ResponseW } from '../ResponseW.js';
|
|
8
|
+
import type { WithNormalizedInputHeaders } from './headersNormalizer/types.js';
|
|
9
|
+
export declare const TAG = "jwtAuthenticatorRsa";
|
|
10
|
+
export type JwtAuthenticatorRsaDeps = JwtVerificationConfigRsa;
|
|
11
|
+
export type WithUserId = {
|
|
12
|
+
readonly userId: string | undefined;
|
|
13
|
+
};
|
|
14
|
+
export declare const middleware: () => <I extends Rec, O extends Rec, E, R>(wrapped: Handler<RequestW<I & WithNormalizedInputHeaders & WithUserId>, R, ResponseW<O>, E>) => Handler<RequestW<I & WithNormalizedInputHeaders>, R & WithLogger & JwtAuthenticatorRsaDeps, ResponseW<O>, E | HttpApiError>;
|
|
15
|
+
//# sourceMappingURL=jwtAuthenticatorRsa.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwtAuthenticatorRsa.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/jwtAuthenticatorRsa.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,6CAA6C,CAAC;AAI5F,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEvD,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,8BAA8B,CAAC;AAE/E,eAAO,MAAM,GAAG,wBAAwB,CAAC;AAEzC,MAAM,MAAM,uBAAuB,GAAG,wBAAwB,CAAC;AAE/D,MAAM,MAAM,UAAU,GAAG;IACvB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;CACrC,CAAC;AAEF,eAAO,MAAM,UAAU,SAEpB,CAAC,SAAS,GAAG,EAAE,CAAC,SAAS,GAAG,EAAE,CAAC,EAAE,CAAC,EACjC,SAAS,OAAO,CAAC,QAAQ,CAAC,CAAC,GAAG,0BAA0B,GAAG,UAAU,CAAC,EAAE,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAC1F,OAAO,CACR,QAAQ,CAAC,CAAC,GAAG,0BAA0B,CAAC,EACxC,CAAC,GAAG,UAAU,GAAG,uBAAuB,EACxC,SAAS,CAAC,CAAC,CAAC,EACZ,CAAC,GAAG,YAAY,CAmCjB,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { extractBearerToken } from '@konker.dev/neverthrow-r-auth-utils/helpers';
|
|
2
|
+
import { jwtVerifyTokenRsa } from '@konker.dev/neverthrow-r-auth-utils/jwt/rsa';
|
|
3
|
+
import { errAsync } from 'neverthrow';
|
|
4
|
+
import { toHttpApiError } from '../HttpApiError.js';
|
|
5
|
+
import {} from '../RequestW.js';
|
|
6
|
+
export const TAG = 'jwtAuthenticatorRsa';
|
|
7
|
+
export const middleware = () => (wrapped) => (i) => (r) => {
|
|
8
|
+
r.logger.debug(`[${TAG}] IN`);
|
|
9
|
+
const authResult = extractBearerToken(i.headers.authorization)(undefined).andThen((authToken) => jwtVerifyTokenRsa(authToken, r)(undefined));
|
|
10
|
+
if (authResult.isErr()) {
|
|
11
|
+
const error = toHttpApiError(authResult.error, 401, `Invalid JWT RSA credentials: ${authResult.error instanceof Error ? authResult.error.message : String(authResult.error)}`);
|
|
12
|
+
r.logger.error(error);
|
|
13
|
+
return errAsync(error);
|
|
14
|
+
}
|
|
15
|
+
if (!authResult.value.verified) {
|
|
16
|
+
const error = toHttpApiError(undefined, 401, 'Invalid JWT RSA credentials');
|
|
17
|
+
r.logger.error(error);
|
|
18
|
+
return errAsync(error);
|
|
19
|
+
}
|
|
20
|
+
return wrapped({
|
|
21
|
+
...i,
|
|
22
|
+
userId: authResult.value.sub,
|
|
23
|
+
})(r).map((res) => {
|
|
24
|
+
r.logger.debug(`[${TAG}] OUT`);
|
|
25
|
+
return res;
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=jwtAuthenticatorRsa.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwtAuthenticatorRsa.js","sourceRoot":"","sources":["../../../src/http/contrib/jwtAuthenticatorRsa.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,6CAA6C,CAAC;AAEjF,OAAO,EAAE,iBAAiB,EAAE,MAAM,6CAA6C,CAAC;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAKtC,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,OAAO,EAAiB,MAAM,gBAAgB,CAAC;AAI/C,MAAM,CAAC,MAAM,GAAG,GAAG,qBAAqB,CAAC;AAQzC,MAAM,CAAC,MAAM,UAAU,GACrB,GAAG,EAAE,CACL,CACE,OAA2F,EAM3F,EAAE,CACJ,CAAC,CAAC,EAAE,EAAE,CACN,CAAC,CAAC,EAAE,EAAE;IACJ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC,CAAC;IAE9B,MAAM,UAAU,GAAG,kBAAkB,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE,CAC9F,iBAAiB,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAC3C,CAAC;IAEF,IAAI,UAAU,CAAC,KAAK,EAAE,EAAE,CAAC;QACvB,MAAM,KAAK,GAAG,cAAc,CAC1B,UAAU,CAAC,KAAK,EAChB,GAAG,EACH,gCACE,UAAU,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CACxF,EAAE,CACH,CAAC;QACF,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACtB,OAAO,QAAQ,CAAiC,KAAK,CAAC,CAAC;IACzD,CAAC;IAED,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QAC/B,MAAM,KAAK,GAAG,cAAc,CAAC,SAAS,EAAE,GAAG,EAAE,6BAA6B,CAAC,CAAC;QAC5E,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACtB,OAAO,QAAQ,CAAiC,KAAK,CAAC,CAAC;IACzD,CAAC;IAED,OAAO,OAAO,CAAC;QACb,GAAG,CAAC;QACJ,MAAM,EAAE,UAAU,CAAC,KAAK,CAAC,GAAG;KAC4B,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;QACzE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,GAAG,OAAO,CAAC,CAAC;QAC/B,OAAO,GAAG,CAAC;IACb,CAAC,CAAC,CAAC;AACL,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwtAuthenticatorRsa.test.d.ts","sourceRoot":"","sources":["../../../src/http/contrib/jwtAuthenticatorRsa.test.ts"],"names":[],"mappings":""}
|