From 419e2de602571a5e864032e4b9490e03e25781ac Mon Sep 17 00:00:00 2001 From: Adria Navarro Date: Tue, 16 May 2023 13:21:05 +0200 Subject: [PATCH 1/2] Test airtable connection --- packages/server/src/integrations/airtable.ts | 29 ++++++++++++++++++-- 1 file changed, 26 insertions(+), 3 deletions(-) diff --git a/packages/server/src/integrations/airtable.ts b/packages/server/src/integrations/airtable.ts index d606cd570b..e513c8cfc1 100644 --- a/packages/server/src/integrations/airtable.ts +++ b/packages/server/src/integrations/airtable.ts @@ -1,12 +1,12 @@ import { - DatasourceFeature, + ConnectionInfo, DatasourceFieldType, Integration, IntegrationBase, QueryType, } from "@budibase/types" -const Airtable = require("airtable") +import Airtable from "airtable" interface AirtableConfig { apiKey: string @@ -83,13 +83,36 @@ const SCHEMA: Integration = { class AirtableIntegration implements IntegrationBase { private config: AirtableConfig - private client: any + private client constructor(config: AirtableConfig) { this.config = config this.client = new Airtable(config).base(config.base) } + async testConnection(): Promise { + const mockTable = Date.now().toString() + try { + await this.client.makeRequest({ + path: `/${mockTable}`, + }) + + return { connected: true } + } catch (e: any) { + if ( + e.message === + `Could not find table ${mockTable} in application ${this.config.base}` + ) { + return { connected: true } + } + + return { + connected: false, + error: e.message as string, + } + } + } + async create(query: { table: any; json: any }) { const { table, json } = query From 87497fee7373776dfe6ca83fddb3099868157761 Mon Sep 17 00:00:00 2001 From: Adria Navarro Date: Tue, 16 May 2023 13:22:02 +0200 Subject: [PATCH 2/2] Comments --- packages/server/src/integrations/airtable.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/packages/server/src/integrations/airtable.ts b/packages/server/src/integrations/airtable.ts index e513c8cfc1..54a91132e3 100644 --- a/packages/server/src/integrations/airtable.ts +++ b/packages/server/src/integrations/airtable.ts @@ -103,6 +103,7 @@ class AirtableIntegration implements IntegrationBase { e.message === `Could not find table ${mockTable} in application ${this.config.base}` ) { + // The request managed to check the application, so the credentials are valid return { connected: true } }