61 lines
1.7 KiB
TypeScript
61 lines
1.7 KiB
TypeScript
import { NextRequest, NextResponse } from 'next/server';
|
|
|
|
import { getLogger } from '@/packages/shared/src/logger';
|
|
import { retrieveOrder } from '@lib/data/orders';
|
|
|
|
import { getMedipostDispatchTries } from '~/lib/services/audit.service';
|
|
import { sendOrderToMedipost } from '~/lib/services/medipost/medipostPrivateMessage.service';
|
|
import { getOrderedAnalysisIds } from '~/lib/services/medusaOrder.service';
|
|
|
|
import loadEnv from '../handler/load-env';
|
|
import validateApiKey from '../handler/validate-api-key';
|
|
|
|
export const POST = async (request: NextRequest) => {
|
|
const logger = await getLogger();
|
|
const ctx = {
|
|
api: '/job/medipost-retry-dispatch',
|
|
};
|
|
loadEnv();
|
|
|
|
const { medusaOrderId } = await request.json();
|
|
|
|
try {
|
|
validateApiKey(request);
|
|
} catch {
|
|
return NextResponse.json({}, { status: 401, statusText: 'Unauthorized' });
|
|
}
|
|
|
|
const tries = await getMedipostDispatchTries(medusaOrderId);
|
|
if (tries >= 3) {
|
|
return NextResponse.json(
|
|
{
|
|
message: 'Order has been retried too many times',
|
|
},
|
|
{ status: 400 },
|
|
);
|
|
}
|
|
|
|
try {
|
|
const medusaOrder = await retrieveOrder(medusaOrderId);
|
|
const orderedAnalysisElements = await getOrderedAnalysisIds({
|
|
medusaOrder,
|
|
});
|
|
await sendOrderToMedipost({ medusaOrderId, orderedAnalysisElements });
|
|
logger.info(ctx, 'Successfully sent order to medipost');
|
|
return NextResponse.json(
|
|
{
|
|
message: 'Successfully sent order to medipost',
|
|
},
|
|
{ status: 200 },
|
|
);
|
|
} catch (error) {
|
|
logger.error({ ...ctx, error }, 'Error sending order to medipost');
|
|
return NextResponse.json(
|
|
{
|
|
message: 'Failed to send order to medipost',
|
|
},
|
|
{ status: 500 },
|
|
);
|
|
}
|
|
};
|