79 lines
1.8 KiB
TypeScript
79 lines
1.8 KiB
TypeScript
import { formatInTimeZone } from "date-fns-tz";
|
|
import { Router } from "express";
|
|
import { prodQuery } from "../prodSql/prodSqlQuery.controller.js";
|
|
import {
|
|
type SqlQuery,
|
|
sqlQuerySelector,
|
|
} from "../prodSql/prodSqlQuerySelector.utils.js";
|
|
import { apiReturn } from "../utils/returnHelper.utils.js";
|
|
import { tryCatch } from "../utils/trycatch.utils.js";
|
|
|
|
const r = Router();
|
|
|
|
r.get("/", async (req, res) => {
|
|
const { includePlantToken } = req.query;
|
|
|
|
const sqlQuery = sqlQuerySelector(`eom.lastPurchasePrice`) as SqlQuery;
|
|
|
|
if (!sqlQuery.success) {
|
|
return apiReturn(res, {
|
|
success: false,
|
|
level: "error",
|
|
module: "eom",
|
|
subModule: "lastPurchasePrice",
|
|
message:
|
|
"Failed to get last sales price sql file please, please contact support if this continues.",
|
|
data: [],
|
|
status: 400,
|
|
});
|
|
}
|
|
|
|
const { data, error } = await tryCatch(
|
|
prodQuery(
|
|
sqlQuery.query,
|
|
|
|
"Eom last purchase price data",
|
|
),
|
|
);
|
|
|
|
if (error) {
|
|
return apiReturn(res, {
|
|
success: false,
|
|
level: "error",
|
|
module: "eom",
|
|
subModule: "lastPurchasePrice",
|
|
message: `Error getting last purchase Price data info`,
|
|
data: error as any,
|
|
notify: false,
|
|
status: 400,
|
|
});
|
|
}
|
|
|
|
return apiReturn(res, {
|
|
success: data.success,
|
|
level: data.success ? "info" : "error",
|
|
module: "eom",
|
|
subModule: "lastPurchasePrice",
|
|
message: data.message,
|
|
data:
|
|
includePlantToken === "true" && data.success
|
|
? data.data.map((i) => {
|
|
return {
|
|
plantToken: process.env.PROD_PLANT_TOKEN,
|
|
...i,
|
|
//validDate: formatInTimeZone(i.validDate, "etc/utc", "M/d/yyyy"),
|
|
};
|
|
})
|
|
: data.data.map((i) => {
|
|
return {
|
|
...i,
|
|
//validDate: formatInTimeZone(i.validDate, "etc/utc", "M/d/yyyy"),
|
|
};
|
|
}),
|
|
notify: false,
|
|
status: data.success ? 200 : 400,
|
|
});
|
|
});
|
|
|
|
export default r;
|