Fixing an issue where searching on a relationship column which is in a broken state would break in SQS (previously this was allowed and would return empty relationships).
This commit is contained in:
parent
c0ad7d6f16
commit
bbcb77c738
|
@ -151,7 +151,10 @@ export function buildExternalRelationships(
|
||||||
return relationships
|
return relationships
|
||||||
}
|
}
|
||||||
|
|
||||||
export function buildInternalRelationships(table: Table): RelationshipsJson[] {
|
export function buildInternalRelationships(
|
||||||
|
table: Table,
|
||||||
|
allTables: Table[]
|
||||||
|
): RelationshipsJson[] {
|
||||||
const relationships: RelationshipsJson[] = []
|
const relationships: RelationshipsJson[] = []
|
||||||
const links = Object.values(table.schema).filter(
|
const links = Object.values(table.schema).filter(
|
||||||
column => column.type === FieldType.LINK
|
column => column.type === FieldType.LINK
|
||||||
|
@ -164,6 +167,10 @@ export function buildInternalRelationships(table: Table): RelationshipsJson[] {
|
||||||
const linkTableId = link.tableId!
|
const linkTableId = link.tableId!
|
||||||
const junctionTableId = generateJunctionTableID(tableId, linkTableId)
|
const junctionTableId = generateJunctionTableID(tableId, linkTableId)
|
||||||
const isFirstTable = tableId > linkTableId
|
const isFirstTable = tableId > linkTableId
|
||||||
|
// skip relationships with missing table definitions
|
||||||
|
if (!allTables.find(table => table._id === linkTableId)) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
relationships.push({
|
relationships.push({
|
||||||
through: junctionTableId,
|
through: junctionTableId,
|
||||||
column: link.name,
|
column: link.name,
|
||||||
|
|
|
@ -71,20 +71,27 @@ export const getQueryableFields = async (
|
||||||
// avoid circular loops
|
// avoid circular loops
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
const relatedTable = await sdk.tables.getTable(subSchema.tableId)
|
try {
|
||||||
const relatedFields = await extractTableFields(
|
const relatedTable = await sdk.tables.getTable(subSchema.tableId)
|
||||||
relatedTable,
|
const relatedFields = await extractTableFields(
|
||||||
Object.keys(relatedTable.schema),
|
relatedTable,
|
||||||
[...fromTables, subSchema.tableId]
|
Object.keys(relatedTable.schema),
|
||||||
)
|
[...fromTables, subSchema.tableId]
|
||||||
|
)
|
||||||
|
|
||||||
result.push(
|
result.push(
|
||||||
...relatedFields.flatMap(f => [
|
...relatedFields.flatMap(f => [
|
||||||
`${subSchema.name}.${f}`,
|
`${subSchema.name}.${f}`,
|
||||||
// should be able to filter by relationship using table name
|
// should be able to filter by relationship using table name
|
||||||
`${relatedTable.name}.${f}`,
|
`${relatedTable.name}.${f}`,
|
||||||
])
|
])
|
||||||
)
|
)
|
||||||
|
} catch (err: any) {
|
||||||
|
// if related table is removed, ignore
|
||||||
|
if (err.status !== 404) {
|
||||||
|
throw err
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
result.push(field)
|
result.push(field)
|
||||||
}
|
}
|
||||||
|
|
|
@ -297,7 +297,7 @@ export async function search(
|
||||||
throw new Error("Unable to find table")
|
throw new Error("Unable to find table")
|
||||||
}
|
}
|
||||||
|
|
||||||
const relationships = buildInternalRelationships(table)
|
const relationships = buildInternalRelationships(table, allTables)
|
||||||
|
|
||||||
const searchFilters: SearchFilters = {
|
const searchFilters: SearchFilters = {
|
||||||
...cleanupFilters(query, table, allTables),
|
...cleanupFilters(query, table, allTables),
|
||||||
|
|
Loading…
Reference in New Issue