diff --git a/packages/server/src/integrations/index.ts b/packages/server/src/integrations/index.ts index 99cd391278..240f68ed91 100644 --- a/packages/server/src/integrations/index.ts +++ b/packages/server/src/integrations/index.ts @@ -57,7 +57,11 @@ const INTEGRATIONS: { [key: string]: any } = { } // optionally add oracle integration if the oracle binary can be installed -if (process.arch && !process.arch.startsWith("arm")) { +if ( + process.arch && + !process.arch.startsWith("arm") && + oracle.integration.isInstalled() +) { DEFINITIONS[SourceName.ORACLE] = oracle.schema INTEGRATIONS[SourceName.ORACLE] = oracle.integration } diff --git a/packages/server/src/integrations/oracle.ts b/packages/server/src/integrations/oracle.ts index 5f35935e12..101d459ec0 100644 --- a/packages/server/src/integrations/oracle.ts +++ b/packages/server/src/integrations/oracle.ts @@ -15,17 +15,22 @@ import { getSqlQuery, SqlClient, } from "./utils" -import oracledb, { +import Sql from "./base/sql" +import { FieldTypes } from "../constants" +import { BindParameters, Connection, ConnectionAttributes, ExecuteOptions, Result, } from "oracledb" -import Sql from "./base/sql" -import { FieldTypes } from "../constants" - -oracledb.outFormat = oracledb.OUT_FORMAT_OBJECT +let oracledb: any +try { + oracledb = require("oracledb") + oracledb.outFormat = oracledb.OUT_FORMAT_OBJECT +} catch (err) { + console.log("ORACLEDB is not installed") +} interface OracleConfig { host: string @@ -183,6 +188,10 @@ class OracleIntegration extends Sql implements DatasourcePlus { return parts.join(" || ") } + static isInstalled() { + return oracledb != null + } + /** * Map the flat tabular columns and constraints data into a nested object */