2022-01-25 20:22:43 +01:00
|
|
|
import { API } from "api"
|
2022-01-20 12:50:18 +01:00
|
|
|
import TableFetch from "@budibase/frontend-core/src/fetch/TableFetch.js"
|
|
|
|
import ViewFetch from "@budibase/frontend-core/src/fetch/ViewFetch.js"
|
|
|
|
import QueryFetch from "@budibase/frontend-core/src/fetch/QueryFetch.js"
|
|
|
|
import RelationshipFetch from "@budibase/frontend-core/src/fetch/RelationshipFetch.js"
|
|
|
|
import NestedProviderFetch from "@budibase/frontend-core/src/fetch/NestedProviderFetch.js"
|
|
|
|
import FieldFetch from "@budibase/frontend-core/src/fetch/FieldFetch.js"
|
|
|
|
import JSONArrayFetch from "@budibase/frontend-core/src/fetch/JSONArrayFetch.js"
|
2021-12-17 09:22:04 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetches the schema of any kind of datasource.
|
2022-01-04 16:02:43 +01:00
|
|
|
* All datasource fetch classes implement their own functionality to get the
|
|
|
|
* schema of a datasource of their respective types.
|
2022-01-17 15:03:47 +01:00
|
|
|
* @param datasource the datasource to fetch the schema for
|
|
|
|
* @param options options for enriching the schema
|
2021-12-17 09:22:04 +01:00
|
|
|
*/
|
2022-01-17 15:03:47 +01:00
|
|
|
export const fetchDatasourceSchema = async (
|
|
|
|
datasource,
|
2022-04-01 13:51:23 +02:00
|
|
|
options = { enrichRelationships: false, formSchema: false }
|
2022-01-17 15:03:47 +01:00
|
|
|
) => {
|
2021-12-17 19:39:48 +01:00
|
|
|
const handler = {
|
|
|
|
table: TableFetch,
|
|
|
|
view: ViewFetch,
|
|
|
|
query: QueryFetch,
|
2022-01-04 16:02:43 +01:00
|
|
|
link: RelationshipFetch,
|
|
|
|
provider: NestedProviderFetch,
|
|
|
|
field: FieldFetch,
|
|
|
|
jsonarray: JSONArrayFetch,
|
|
|
|
}[datasource?.type]
|
|
|
|
if (!handler) {
|
|
|
|
return null
|
2022-01-04 15:34:09 +01:00
|
|
|
}
|
2022-01-20 12:50:18 +01:00
|
|
|
const instance = new handler({ API })
|
2022-01-04 15:34:09 +01:00
|
|
|
|
2022-01-04 16:02:43 +01:00
|
|
|
// Get the datasource definition and then schema
|
2022-01-20 12:50:18 +01:00
|
|
|
const definition = await instance.getDefinition(datasource)
|
2022-04-01 13:51:23 +02:00
|
|
|
|
|
|
|
// Get the normal schema as long as we aren't wanting a form schema
|
|
|
|
let schema
|
|
|
|
if (datasource?.type !== "query" || !options?.formSchema) {
|
|
|
|
schema = instance.getSchema(datasource, definition)
|
|
|
|
} else if (definition.parameters?.length) {
|
|
|
|
schema = {}
|
|
|
|
definition.parameters.forEach(param => {
|
|
|
|
schema[param.name] = { ...param, type: "string" }
|
|
|
|
})
|
|
|
|
}
|
2022-01-04 16:02:43 +01:00
|
|
|
if (!schema) {
|
|
|
|
return null
|
2021-12-17 09:22:04 +01:00
|
|
|
}
|
|
|
|
|
2022-05-24 11:23:23 +02:00
|
|
|
// Enrich schema with relationships if required
|
|
|
|
if (definition?.sql && options?.enrichRelationships) {
|
|
|
|
const relationshipAdditions = await getRelationshipSchemaAdditions(schema)
|
|
|
|
schema = {
|
|
|
|
...schema,
|
|
|
|
...relationshipAdditions,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Ensure schema is in the correct structure
|
|
|
|
return instance.enrichSchema(schema)
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetches the schema of relationship fields for a SQL table schema
|
|
|
|
* @param schema the schema to enrich
|
|
|
|
*/
|
|
|
|
export const getRelationshipSchemaAdditions = async schema => {
|
|
|
|
if (!schema) {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
let relationshipAdditions = {}
|
|
|
|
for (let fieldKey of Object.keys(schema)) {
|
2022-01-04 16:02:43 +01:00
|
|
|
const fieldSchema = schema[fieldKey]
|
2022-05-24 11:23:23 +02:00
|
|
|
if (fieldSchema?.type === "link") {
|
|
|
|
const linkSchema = await fetchDatasourceSchema({
|
|
|
|
type: "table",
|
|
|
|
tableId: fieldSchema?.tableId,
|
2022-01-04 16:02:43 +01:00
|
|
|
})
|
2022-05-24 11:23:23 +02:00
|
|
|
Object.keys(linkSchema || {}).forEach(linkKey => {
|
|
|
|
relationshipAdditions[`${fieldKey}.${linkKey}`] = {
|
|
|
|
type: linkSchema[linkKey].type,
|
2022-01-04 16:02:43 +01:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2022-01-17 15:03:47 +01:00
|
|
|
}
|
2022-05-24 11:23:23 +02:00
|
|
|
return relationshipAdditions
|
2021-12-17 09:22:04 +01:00
|
|
|
}
|