saleor-app-sdk-REDIS_APL/src/middleware/with-saleor-event-match.ts
Lukasz Ostrowski 47e7865dc5 Add debug messages to middlewares
Add debug messages to middlewares

Apply suggestions from code review

Co-authored-by: Krzysztof Wolski <krzysztof.k.wolski@gmail.com>

better debug messages

Add experimental debug middleware
2022-09-05 10:13:46 +02:00

31 lines
884 B
TypeScript

import { Middleware } from "retes";
import { Response } from "retes/response";
import { getSaleorHeaders } from "../headers";
import { createMiddlewareDebug } from "./middleware-debug";
const debug = createMiddlewareDebug("withSaleorEventMatch");
export const withSaleorEventMatch =
<E extends string>(expectedEvent: `${Lowercase<E>}`): Middleware =>
(handler) =>
async (request) => {
const { event } = getSaleorHeaders(request.headers);
debug("Middleware called with even header: \"%s\"", event);
if (event !== expectedEvent) {
debug(
"Event from header (%s) doesnt match expected (%s). Will respond with Bad Request",
event,
expectedEvent
);
return Response.BadRequest({
success: false,
message: `Invalid Saleor event. Expecting ${expectedEvent}.`,
});
}
return handler(request);
};