adding validation for envvar bindings

adding validation for envvar bindings
This commit is contained in:
Mateus Badan de Pieri 2023-01-19 15:07:56 +00:00
parent f8a2c9e169
commit 6e5c126d5a
1 changed files with 8 additions and 1 deletions

View File

@ -7,6 +7,7 @@ import {
PASSWORD_REPLACEMENT, PASSWORD_REPLACEMENT,
} from "@budibase/types" } from "@budibase/types"
import { cloneDeep } from "lodash/fp" import { cloneDeep } from "lodash/fp"
import { env } from "process"
import { getEnvironmentVariables } from "../../utils" import { getEnvironmentVariables } from "../../utils"
async function enrichDatasourceWithValues(datasource: Datasource) { async function enrichDatasourceWithValues(datasource: Datasource) {
@ -40,7 +41,13 @@ export async function get(
export async function getWithEnvVars(datasourceId: string) { export async function getWithEnvVars(datasourceId: string) {
const appDb = context.getAppDB() const appDb = context.getAppDB()
const datasource = await appDb.get(datasourceId) const datasource = await appDb.get(datasourceId)
return enrichDatasourceWithValues(datasource) const blocks = findHBSBlocks(JSON.stringify(datasource))
const usesEnvVars = blocks.find(block => block.includes("env.")) != null
if (usesEnvVars) {
return enrichDatasourceWithValues(datasource)
} else {
throw new Error("Environment variables binding format incorrect")
}
} }
export function removeSecrets( export function removeSecrets(