system queries + custom template selection

This commit is contained in:
Julian Krauser 2025-03-19 15:19:03 +01:00
parent a085de6e2f
commit f8a5183f1a
5 changed files with 52 additions and 8 deletions

View file

@ -314,6 +314,13 @@ export default abstract class DynamicQueryBuilder {
count: number;
}
> {
if (query == "member") {
query = memberQuery;
}
if (query == "memberByRunningMembership") {
query = memberByRunningMembershipQuery;
}
if (typeof query == "string") {
const upperQuery = query.trim().toUpperCase();
if (!upperQuery.startsWith("SELECT") || /INSERT|UPDATE|DELETE|ALTER|DROP|CREATE|TRUNCATE/.test(upperQuery)) {
@ -330,7 +337,7 @@ export default abstract class DynamicQueryBuilder {
return await dataSource
.transaction(async (manager) => {
data = await manager.query(query);
data = await manager.query(query.toString());
throw new Error("AllwaysRollbackQuery");
})
@ -382,3 +389,29 @@ export default abstract class DynamicQueryBuilder {
}
}
}
const memberQuery: DynamicQueryStructure = {
select: "*",
table: "member",
orderBy: [
{ column: "lastname", order: "ASC" },
{ column: "firstname", order: "ASC" },
],
};
const memberByRunningMembershipQuery: DynamicQueryStructure = {
select: "*",
table: "member",
join: [
{
select: "*",
table: "membership",
where: [{ structureType: "condition", concat: "_", operation: "null", column: "end", value: "" }],
foreignColumn: "memberships",
},
],
orderBy: [
{ column: "lastname", order: "ASC" },
{ column: "firstname", order: "ASC" },
],
};