A few fixes for logical operators, there was a lot of cleanup that was not occurring as it is supposed to be recursive, this wasn't happening.

This commit is contained in:
mike12345567 2024-08-15 18:35:30 +01:00
parent 20baecc9fb
commit aa1eaa1d3d
4 changed files with 50 additions and 33 deletions

View File

@ -58,8 +58,9 @@ export async function searchView(
}) })
}) })
} else { } else {
const operator = query.allOr ? "$or" : "$and"
query = { query = {
$and: { [operator]: {
conditions: [query, body.query], conditions: [query, body.query],
}, },
} }

View File

@ -139,14 +139,8 @@ 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)
const prefixFilters = (filters: SearchFilters) => {
for (const filterKey of Object.keys(filters) as (keyof SearchFilters)[]) { for (const filterKey of Object.keys(filters) as (keyof SearchFilters)[]) {
if (isLogicalSearchOperator(filterKey)) { if (!isLogicalSearchOperator(filterKey)) {
for (const condition of filters[filterKey]!.conditions) {
prefixFilters(condition)
}
} else {
const filter = filters[filterKey]! const filter = filters[filterKey]!
if (typeof filter !== "object") { if (typeof filter !== "object") {
continue continue
@ -155,18 +149,19 @@ function cleanupFilters(
const { numberPrefix, relationshipPrefix, column } = splitter.run(key) const { numberPrefix, relationshipPrefix, column } = splitter.run(key)
if (keyInAnyTable(column)) { if (keyInAnyTable(column)) {
filter[ filter[
`${numberPrefix || ""}${ `${numberPrefix || ""}${relationshipPrefix || ""}${mapToUserColumn(
relationshipPrefix || "" column
}${mapToUserColumn(column)}` )}`
] = filter[key] ] = filter[key]
delete filter[key] delete filter[key]
} }
} }
} }
} }
}
prefixFilters(filters) return dataFilters.recurseLogicalOperators(filters, (f: SearchFilters) => {
return filters return cleanupFilters(f, table, allTables)
})
} }
function buildTableMap(tables: Table[]) { function buildTableMap(tables: Table[]) {

View File

@ -12,6 +12,7 @@ import { getSQLClient } from "./utils"
import { cloneDeep } from "lodash" import { cloneDeep } from "lodash"
import datasources from "../datasources" import datasources from "../datasources"
import { BudibaseInternalDB } from "../../../db/utils" import { BudibaseInternalDB } from "../../../db/utils"
import { dataFilters } from "@budibase/shared-core"
type PerformQueryFunction = ( type PerformQueryFunction = (
datasource: Datasource, datasource: Datasource,
@ -199,7 +200,8 @@ export default class AliasTables {
) )
} }
if (json.filters) { if (json.filters) {
for (let [filterKey, filter] of Object.entries(json.filters)) { const aliasFilters = (filters: SearchFilters): SearchFilters => {
for (let [filterKey, filter] of Object.entries(filters)) {
if (typeof filter !== "object") { if (typeof filter !== "object") {
continue continue
} }
@ -207,8 +209,11 @@ export default class AliasTables {
for (let key of Object.keys(filter)) { for (let key of Object.keys(filter)) {
aliasedFilters[this.aliasField(key)] = filter[key] aliasedFilters[this.aliasField(key)] = filter[key]
} }
json.filters[filterKey as keyof SearchFilters] = aliasedFilters filters[filterKey as keyof SearchFilters] = aliasedFilters
} }
return dataFilters.recurseLogicalOperators(filters, aliasFilters)
}
json.filters = aliasFilters(json.filters)
} }
if (json.meta?.table) { if (json.meta?.table) {
this.getAlias(json.meta.table.name) this.getAlias(json.meta.table.name)

View File

@ -113,6 +113,20 @@ export const NoEmptyFilterStrings = [
OperatorOptions.In.value, OperatorOptions.In.value,
] as (keyof SearchQueryFields)[] ] as (keyof SearchQueryFields)[]
export function recurseLogicalOperators(
filters: SearchFilters,
fn: (f: SearchFilters) => SearchFilters
) {
for (const logical of Object.values(LogicalOperator)) {
if (filters[logical]) {
filters[logical]!.conditions = filters[logical]!.conditions.map(
condition => fn(condition)
)
}
}
return filters
}
/** /**
* Removes any fields that contain empty strings that would cause inconsistent * Removes any fields that contain empty strings that would cause inconsistent
* behaviour with how backend tables are filtered (no value means no filter). * behaviour with how backend tables are filtered (no value means no filter).
@ -145,6 +159,7 @@ export const cleanupQuery = (query: SearchFilters) => {
} }
} }
} }
query = recurseLogicalOperators(query, cleanupQuery)
return query return query
} }
@ -410,6 +425,7 @@ export function fixupFilterArrays(filters: SearchFilters) {
} }
} }
} }
recurseLogicalOperators(filters, fixupFilterArrays)
return filters return filters
} }