Merge pull request #14791 from Budibase/fix/inconsistent-column-schemas

Fixing inconsistent column schemas
This commit is contained in:
Adria Navarro 2024-10-14 15:23:01 +02:00 committed by GitHub
commit 490c4ae392
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 18 additions and 10 deletions

View File

@ -23,6 +23,7 @@
sourceType: DB_TYPE_EXTERNAL, sourceType: DB_TYPE_EXTERNAL,
schema: { schema: {
id: { id: {
name: "id",
autocolumn: true, autocolumn: true,
type: "number", type: "number",
}, },

View File

@ -71,19 +71,20 @@ export async function fetch(ctx: UserCtx<void, FetchTablesResponse>) {
const datasources = await sdk.datasources.getExternalDatasources() const datasources = await sdk.datasources.getExternalDatasources()
const external = datasources.flatMap(datasource => { const external: Table[] = []
for (const datasource of datasources) {
let entities = datasource.entities let entities = datasource.entities
if (entities) { if (entities) {
return Object.values(entities).map<Table>((entity: Table) => ({ for (const entity of Object.values(entities)) {
...entity, external.push({
sourceType: TableSourceType.EXTERNAL, ...(await processTable(entity)),
sourceId: datasource._id!, sourceType: TableSourceType.EXTERNAL,
sql: isSQL(datasource), sourceId: datasource._id!,
})) sql: isSQL(datasource),
} else { })
return [] }
} }
}) }
const result: FetchTablesResponse = [] const result: FetchTablesResponse = []
for (const table of [...internal, ...external]) { for (const table of [...internal, ...external]) {

View File

@ -20,7 +20,13 @@ export async function processTable(table: Table): Promise<Table> {
if (!table) { if (!table) {
return table return table
} }
table = { ...table }
if (table._id && isExternalTableID(table._id)) { if (table._id && isExternalTableID(table._id)) {
// Old created external tables via Budibase might have a missing field name breaking some UI such as filters
if (table.schema["id"] && !table.schema["id"].name) {
table.schema["id"].name = "id"
}
return { return {
...table, ...table,
type: "table", type: "table",