58 lines
1.9 KiB
TypeScript
58 lines
1.9 KiB
TypeScript
import { createRoute, OpenAPIHono, z } from "@hono/zod-openapi";
|
|
import { responses } from "../../../../globalUtils/routeDefs/responses.js";
|
|
import { ordersIn } from "../../controller/dm/ordersIn/ordersIn.js";
|
|
import { verify } from "hono/jwt";
|
|
|
|
const app = new OpenAPIHono();
|
|
|
|
// const Body = z
|
|
// .object({
|
|
// age: z.number().optional().openapi({ example: 90 }),
|
|
// //email: z.string().optional().openapi({example: "s.smith@example.com"}),
|
|
// type: z.string().optional().openapi({ example: "fg" }),
|
|
// })
|
|
// .openapi("User");
|
|
app.openapi(
|
|
createRoute({
|
|
tags: ["logistics"],
|
|
summary: "Post orders to DM",
|
|
method: "post",
|
|
path: "/postbulkorders",
|
|
// request: {
|
|
// body: {
|
|
// content: {
|
|
// "application/json": { schema: Body },
|
|
// },
|
|
// },
|
|
// },
|
|
// description:
|
|
// "Provided a running number and lot number you can consume material.",
|
|
responses: responses(),
|
|
}),
|
|
async (c) => {
|
|
//apiHit(c, { endpoint: "api/sqlProd/close" });
|
|
const body = await c.req.parseBody();
|
|
const authHeader = c.req.header("Authorization");
|
|
const token = authHeader?.split("Bearer ")[1] || "";
|
|
//console.log(body); // File | string
|
|
|
|
// if (body["fileType"] === "standard") {
|
|
// console.log(`doing standard orders in.`);
|
|
// }
|
|
try {
|
|
const payload = await verify(token, process.env.JWT_SECRET!);
|
|
const orders = await ordersIn(body, payload.user);
|
|
|
|
return c.json({
|
|
success: orders.success,
|
|
message: orders.message,
|
|
data: orders.data,
|
|
});
|
|
} catch (error) {
|
|
console.log(error);
|
|
return c.json({ success: false, message: "Unauthorized" }, 401);
|
|
}
|
|
}
|
|
);
|
|
export default app;
|