hrms-api-log/src/controllers/log-controller.ts

88 lines
2.9 KiB
TypeScript
Raw Normal View History

2024-07-10 17:53:27 +07:00
import { Controller, Get, Query, Route, Security } from "tsoa";
import { Client as ElasticsearchClient } from "@elastic/elasticsearch";
function getEnvVar(name: string) {
const value = process.env[name];
if (!value) throw new Error(`${name} is required.`);
return value;
}
const ELASTICSEARCH_PROTOCOL = getEnvVar("ELASTICSEARCH_PROTOCOL");
const ELASTICSEARCH_HOST = getEnvVar("ELASTICSEARCH_HOST");
const ELASTICSEARCH_PORT = getEnvVar("ELASTICSEARCH_PORT");
const ELASTICSEARCH_INDEX = getEnvVar("ELASTICSEARCH_INDEX");
const elasticsearch = new ElasticsearchClient({
node: `${ELASTICSEARCH_PROTOCOL}://${ELASTICSEARCH_HOST}:${ELASTICSEARCH_PORT}`,
});
@Route("/api/v1/log")
@Security("keycloak")
export class LogController extends Controller {
@Get()
async GET(
@Query() size: number = 30,
@Query() search?: string,
@Query() searchAfter?: number,
@Query() systemName?: string,
2024-07-11 16:12:11 +07:00
@Query() date?: Date,
2024-07-30 09:15:12 +07:00
@Query() startDate?: Date,
@Query() endDate?: Date,
2024-07-31 11:21:43 +07:00
@Query() timezone = "+07:00",
@Query() sort: "asc" | "desc" = "desc",
2024-07-10 17:53:27 +07:00
) {
2024-07-30 09:15:26 +07:00
let startDateString: string | undefined;
let endDateString: string | undefined;
2024-07-31 11:21:43 +07:00
let startTimeString = "00:00:00";
let endTimeString = "23:59:59";
2024-07-30 09:15:26 +07:00
2024-07-31 11:21:43 +07:00
if (date && !startDate && !endDate) {
startDateString = `${date.getFullYear()}-${`${date.getMonth() + 1}`.padStart(2, "0")}-${`${date.getDate()}`.padStart(2, "0")}T${startTimeString}`;
endDateString = `${date.getFullYear()}-${`${date.getMonth() + 1}`.padStart(2, "0")}-${`${date.getDate()}`.padStart(2, "0")}T${endTimeString}`;
2024-07-30 09:15:26 +07:00
}
2024-07-31 11:21:43 +07:00
if (startDate) startDateString = startDate.toISOString();
if (endDate) endDateString = endDate.toISOString();
2024-07-30 09:15:12 +07:00
2024-07-10 17:53:27 +07:00
const queryData = await elasticsearch.search({
index: ELASTICSEARCH_INDEX,
query: {
bool: {
must: [
...(systemName ? [{ match: { systemName } }] : []),
...(search
? [
{
bool: {
should: ["method", "logType", "endpoint", "host", "responseCode"].map(
(v) => ({
wildcard: { [v]: "*" + search + "*" },
}),
),
2024-07-10 17:53:27 +07:00
},
},
]
: []),
2024-07-30 09:15:26 +07:00
...(startDateString || endDateString
2024-07-11 16:12:11 +07:00
? [
{
range: {
startTimeStamp: {
2024-07-31 11:21:43 +07:00
time_zone: timezone,
2024-07-30 09:15:12 +07:00
gte: startDateString,
lte: endDateString,
2024-07-11 16:12:11 +07:00
},
},
},
]
: []),
2024-07-10 17:53:27 +07:00
],
},
},
search_after: searchAfter ? [searchAfter] : undefined,
2024-07-31 11:21:43 +07:00
sort: [{ startTimeStamp: sort }],
2024-07-10 17:53:27 +07:00
size: size,
});
return queryData.hits.hits;
}
}