-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathcapabilityStatement.ts
More file actions
39 lines (35 loc) · 1.34 KB
/
capabilityStatement.ts
File metadata and controls
39 lines (35 loc) · 1.34 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
import {APIGatewayProxyEvent, APIGatewayProxyResult} from "aws-lambda"
import {Logger} from "@aws-lambda-powertools/logger"
import {injectLambdaContext} from "@aws-lambda-powertools/logger/middleware"
import middy from "@middy/core"
import inputOutputLogger from "@middy/input-output-logger"
import errorHandler from "@nhs/fhir-middy-error-handler"
import capabilityStatement from "./apim-medicines-prescriptionstatusupdate.json"
const logger = new Logger({serviceName: "capabilityStatement"})
const lambdaHandler = async (event: APIGatewayProxyEvent): Promise<APIGatewayProxyResult> => {
logger.appendKeys({
"nhsd-correlation-id": event.headers["nhsd-correlation-id"],
"x-request-id": event.headers["x-request-id"],
"nhsd-request-id": event.headers["nhsd-request-id"],
"x-correlation-id": event.headers["x-correlation-id"],
"apigw-request-id": event.requestContext.requestId
})
return {
statusCode: 200,
body: JSON.stringify(capabilityStatement),
headers: {
"Content-Type": "application/fhir+json",
"Cache-Control": "no-cache"
}
}
}
export const handler = middy(lambdaHandler)
.use(injectLambdaContext(logger, {clearState: true}))
.use(
inputOutputLogger({
logger: (request) => {
logger.info("inputOutputLogger request", {request})
}
})
)
.use(errorHandler({logger: logger}))