Disable schema dumping for Postgres in Budicloud.

This commit is contained in:
Sam Rose 2024-02-06 15:47:47 +00:00
parent df5279b96f
commit 3be9ad7d78
No known key found for this signature in database
2 changed files with 20 additions and 1 deletions

View File

@ -12,12 +12,16 @@
import PromptQueryModal from "./_components/PromptQueryModal.svelte" import PromptQueryModal from "./_components/PromptQueryModal.svelte"
import SettingsPanel from "./_components/panels/Settings.svelte" import SettingsPanel from "./_components/panels/Settings.svelte"
import { helpers } from "@budibase/shared-core" import { helpers } from "@budibase/shared-core"
import { admin } from "stores/portal"
import { IntegrationTypes } from "constants/backend"
let selectedPanel = null let selectedPanel = null
let panelOptions = [] let panelOptions = []
$: datasource = $datasources.selected $: datasource = $datasources.selected
$: isCloud = $admin.cloud
$: isPostgres = datasource?.source === IntegrationTypes.POSTGRES
$: getOptions(datasource) $: getOptions(datasource)
const getOptions = datasource => { const getOptions = datasource => {
@ -41,7 +45,13 @@
} }
// always the last option for SQL // always the last option for SQL
if (helpers.isSQL(datasource)) { if (helpers.isSQL(datasource)) {
panelOptions.push("Settings") if (isCloud && isPostgres) {
// We don't show the settings panel for Postgres on Budicloud because
// it requires pg_dump to work and we don't want to enable shell injection
// attacks.
} else {
panelOptions.push("Settings")
}
} }
} }
</script> </script>

View File

@ -29,6 +29,7 @@ import { Client, ClientConfig, types } from "pg"
import { getReadableErrorMessage } from "./base/errorMapping" import { getReadableErrorMessage } from "./base/errorMapping"
import { exec } from "child_process" import { exec } from "child_process"
import { storeTempFile } from "../utilities/fileSystem" import { storeTempFile } from "../utilities/fileSystem"
import { env } from "@budibase/backend-core"
// Return "date" and "timestamp" types as plain strings. // Return "date" and "timestamp" types as plain strings.
// This lets us reference the original stored timezone. // This lets us reference the original stored timezone.
@ -433,6 +434,14 @@ class PostgresIntegration extends Sql implements DatasourcePlus {
} }
async getExternalSchema() { async getExternalSchema() {
if (!env.SELF_HOSTED) {
// This is because it relies on shelling out to pg_dump and we don't want
// to enable shell injection attacks.
throw new Error(
"schema export for Postgres is not supported in Budibase Cloud"
)
}
const dumpCommandParts = [ const dumpCommandParts = [
`user=${this.config.user}`, `user=${this.config.user}`,
`host=${this.config.host}`, `host=${this.config.host}`,