Fix prefixes for SQS

This commit is contained in:
Adria Navarro 2024-08-05 17:25:17 +02:00
parent 1cd3347262
commit c845db966f
1 changed files with 27 additions and 11 deletions

View File

@ -135,20 +135,36 @@ function cleanupFilters(
allTables.some(table => table.schema[key]) allTables.some(table => table.schema[key])
const splitter = new dataFilters.ColumnSplitter(allTables) const splitter = new dataFilters.ColumnSplitter(allTables)
for (const filter of Object.values(filters)) {
const prefixFilters = (filters: SearchFilters) => {
for (const filterKey of Object.keys(filters) as (keyof SearchFilters)[]) {
if (
filterKey === LogicalOperator.AND ||
filterKey === LogicalOperator.OR
) {
for (const condition of filters[filterKey]!.conditions) {
prefixFilters(condition)
}
} else {
const filter = filters[filterKey]!
if (typeof filter !== "object") {
continue
}
for (const key of Object.keys(filter)) { for (const key of Object.keys(filter)) {
const { numberPrefix, relationshipPrefix, column } = splitter.run(key) const { numberPrefix, relationshipPrefix, column } = splitter.run(key)
if (keyInAnyTable(column)) { if (keyInAnyTable(column)) {
filter[ filter[
`${numberPrefix || ""}${relationshipPrefix || ""}${mapToUserColumn( `${numberPrefix || ""}${
column relationshipPrefix || ""
)}` }${mapToUserColumn(column)}`
] = filter[key] ] = filter[key]
delete filter[key] delete filter[key]
} }
} }
} }
}
}
prefixFilters(filters)
return filters return filters
} }