Airtable
Airtable 連接器可讓您對 Airtable 資料執行插入、刪除、更新和讀取作業。
支援的版本
這個連接器支援 Airtable API v0 版。
事前準備
使用 Airtable 連接器前,請先完成下列工作:
- 在 Google Cloud 專案中:
- 確認已設定網路連線。如要瞭解網路模式,請參閱「網路連線」。
- 將 roles/connectors.admin IAM 角色授予設定連線器的使用者。
- 將下列 IAM 角色授予要用於連接器的服務帳戶:
roles/secretmanager.viewer
roles/secretmanager.secretAccessor
服務帳戶是特殊的 Google 帳戶類型,主要用於代表需要驗證且必須取得授權才能存取 Google API 資料的非人類使用者。如果您沒有服務帳戶,請務必建立服務帳戶。連接器和服務帳戶必須屬於同一個專案。詳情請參閱「建立服務帳戶」。
- 啟用下列服務:
secretmanager.googleapis.com
(Secret Manager API)connectors.googleapis.com
(Connectors API)
如要瞭解如何啟用服務,請參閱「啟用服務」。
如果專案先前未啟用這些服務或權限,系統會在設定連結器時提示您啟用。
- 如要瞭解如何建立 Airtable 工作區,請參閱「開始使用 Airtable」。 如要瞭解 Airtable API,請參閱 Airtable API 參考資料。
設定連接器
連線專屬於資料來源。也就是說,如果您有多個資料來源,則必須為每個資料來源建立個別的連線。如要建立連線,請按照下列步驟操作:
- 在 Cloud 控制台中,前往「Integration Connectors」>「Connections」頁面,然後選取或建立 Google Cloud 專案。
- 按一下「+ 建立新連線」,開啟「建立連線」頁面。
- 在「位置」部分中,選擇連線位置。
- 區域:從下拉式清單中選取位置。
如需所有支援的地區清單,請參閱「位置」一文。
- 點按「下一步」。
- 區域:從下拉式清單中選取位置。
- 在「連線詳細資料」部分,完成下列步驟:
- 連接器:從可用連接器的下拉式清單中選取「Airtable」。
- 連接器版本:從可用版本的下拉式清單中選取連接器版本。
- 在「連線名稱」欄位中,輸入連線執行個體的名稱。
連線名稱必須符合下列條件:
- 連線名稱可使用英文字母、數字或連字號。
- 字母必須為小寫。
- 連線名稱開頭須為英文字母,結尾則須為英文字母或數字。
- 連結名稱不得超過 49 個字元。
- 視需要輸入連線執行個體的「Description」(說明)。
- 或者,可啟用 Cloud Logging,然後選取記錄層級。記錄層級預設為
Error
。 - 服務帳戶:選取具備必要角色的服務帳戶。
- Base Id:Airtable 資料庫的 ID。如果指定 Base ID,系統只會擷取相關聯的中繼資料。如果已啟用 Airtable Metadata API,就不必指定 Base ID。
- 基本名稱:要使用的架構,對應至 Airtable 資料庫。只有在啟用 Airtable Metadata API 時,才能使用這個欄位。
- 顯示物件 ID:選取這個選項,即可將結構定義、資料表、檢視區塊和資料欄名稱替換為對應的內部 ID。
- 路徑分隔符號:指定要用來做為分隔符號的字元,根據路徑建立資料欄名稱。
- 使用者定義的檢視區塊:指定包含自訂檢視區塊的 JSON 設定檔路徑。
- 值分隔符:以單一字串指定陣列值使用的分隔符。
- (選用) 按一下「+ 新增標籤」,以鍵/值組合的形式為連結新增標籤。
- 點按「下一步」。
- 視需要設定「連線節點設定」:
- 節點數量下限:輸入連線節點數量下限。
- 節點數量上限:輸入連線節點數量上限。
節點是用來處理交易的連線單位 (或備用資源)。連線處理的交易量越多,就需要越多節點;反之,處理的交易量越少,需要的節點就越少。如要瞭解節點對連線器定價的影響,請參閱「 連線節點定價」。如未輸入任何值,系統預設會將節點下限設為 2 (提高可用性),節點上限則設為 50。
-
在「Authentication」(驗證) 部分,輸入驗證詳細資料。
- 選取「驗證類型」並輸入相關詳細資料。
Airtable 連線支援下列驗證類型:
- 個人存取權杖
- 點按「下一步」。
如要瞭解如何設定這些驗證類型,請參閱「設定驗證」。
- 選取「驗證類型」並輸入相關詳細資料。
- 檢查:檢查連線和驗證詳細資料。
- 點選「建立」。
設定驗證機制
根據要使用的驗證方式輸入詳細資料。
- 個人存取權杖:包含個人存取權杖的 Secret Manager 密鑰。
- 密鑰版本:所選密鑰的密鑰版本。
連線設定範例
本節列出建立連線時設定的各個欄位範例值。
個人存取權杖連線類型
欄位名稱 | 詳細資料 |
---|---|
位置 | europe-west1 |
連接器 | Airtable |
連接器版本 | 1 |
連線名稱 | airtable-connection-new |
啟用 Cloud Logging | 是 |
服務帳戶 | SERVICE_ACCOUNT_NAME@PROJECT_ID.iam.gserviceaccount.com |
Base ID | appK32XeZXReEQzja |
基準名稱 | 車輛測試資料 |
路徑分隔符號 | 不適用 |
使用者定義的檢視畫面 | 不適用 |
值分隔符號 | 不適用 |
節點數量下限 | 2 |
節點數量上限 | 50 |
個人存取權杖 | 是 |
個人存取權杖 | projects/617888XXXX/secrets/airtable-new-conn/versions/3 |
密鑰版本 | 3 |
系統限制
每個節點的 Airtable 連接器每秒最多可處理 3 筆交易,超過此限制的交易會遭到節流。根據預設,Integration Connectors 會為連線分配 2 個節點 (提高可用性)。
如要瞭解 Integration Connectors 適用的限制,請參閱「限制」一文。
在整合服務中使用 Airtable 連線
建立連線後,Apigee Integration 和 Application Integration 都會提供該連線。您可以在整合中透過「連接器」工作使用連線。
- 如要瞭解如何在 Apigee Integration 中建立及使用「連線器」工作,請參閱「連線器工作」。
- 如要瞭解如何在 Application Integration 中建立及使用「連線器」工作,請參閱「連線器工作」。
實體、作業和動作
所有整合連接器都會為所連應用程式的物件提供抽象層。您只能透過這個抽象化程序存取應用程式的物件。抽象化會以實體、作業和動作的形式呈現。
- 實體: 實體可以視為已連結應用程式或服務中的物件,或是屬性集合。實體的定義因連接器而異。舉例來說,在資料庫連接器中,資料表是實體;在檔案伺服器連接器中,資料夾是實體;在訊息系統連接器中,佇列是實體。
不過,連接器可能不支援或沒有任何實體,在這種情況下,
Entities
清單會是空白。 - 作業: 作業是指您可以在實體上執行的活動。您可以對實體執行下列任一操作:
從可用清單中選取實體,系統會產生該實體可用的作業清單。如需作業的詳細說明,請參閱 Connectors 工作的實體作業。 不過,如果連接器不支援任何實體作業,系統就不會在
Operations
清單中列出這些不支援的作業。 - 動作: 動作是透過連接器介面提供給整合的第一類函式。動作可讓您變更一或多個實體,且因連接器而異。一般來說,動作會有一些輸入參數和輸出參數。不過,連接器可能不支援任何動作,此時
Actions
清單會是空白。
實體作業範例
本節說明如何使用這個連接器執行部分實體作業。
範例 - 聯絡人資料 (記錄) 實體的清單作業
- 在「
Configure connector task
」對話方塊中,按一下Entities
。 - 從
Entity
清單中選取Contact Data
。 - 選取「
List
」作業,然後按一下「完成」。 - 「連結器」工作的「工作輸入」部分,您可以根據客戶需求設定 filterClause。
請一律以單引號 (') 括住篩選子句值。
您也可以對下列實體執行清單作業:
聯絡人資料.主要檢視畫面、聯絡人資料.日曆、聯絡人資料.看板、聯絡人資料.相片庫、聯絡人資料.清單和聯絡人資料_協作者
範例 - 取得「聯絡人資料 (記錄)」實體的記錄
- 在「
Configure connector task
」對話方塊中,按一下Entities
。 - 從
Entity
清單中選取Contact Data
。 - 選取「
GET
」作業,然後按一下「完成」。 - 將實體 ID 設為「recg7qjPRMa7DBwIb」,這是要傳遞的金鑰。如要設定實體 ID,請在「資料對應」的「資料對應器」部分,按一下「開啟資料對應編輯器」,然後在「輸入值」欄位中輸入
"recg7qjPRMa7DBwIb"
,並選擇 EntityId 做為本機變數。其中,實體 ID:「recg7qjPRMa7DBwIb」是不重複的主鍵值,必須直接傳遞。
如果實體有複合式主鍵,您可以指定篩選子句。
您也可以對下列實體執行 get 作業: Contacts Data.Main View、Contacts Data.Calendar、Contacts Data.Kanban、Contacts Data.Gallery、Contacts Data.List 和 Contacts Data_Collaborators。
範例 - 刪除聯絡人資料 (記錄) 實體的記錄
- 在「
Configure connector task
」對話方塊中,按一下Entities
。 - 從
Entity
清單中選取Contact Data
。 - 選取「
Delete
」作業,然後按一下「完成」。 - 將實體 ID 設為「recg7qjPRMa7DBwIb」,這是要傳遞的鍵。如要設定實體 ID,請在「資料對應」的「資料對應工具」部分,按一下「開啟資料對應編輯器」,然後在「輸入值」欄位中輸入
"recg7qjPRMa7DBwIb"
,並選擇 EntityId 做為本機變數。
如果實體有複合式主鍵,您可以指定篩選子句。
範例 - 為聯絡人資料 (記錄) 實體建立作業
- 在「
Configure connector task
」對話方塊中,按一下Entities
。 - 從
Entity
清單中選取Contact Data
。 - 選取「
Create
」作業,然後按一下「完成」。 - 在「資料對應」工作的「資料對應器」部分,按一下
Open Data Mapping Editor
,然後在Input Value
欄位中輸入類似下列的值,並選擇 EntityId/ConnectorInputPayload 做為本機變數。{ "First Name": "Demo4", "Last Name": "Alex", "Email": "cloudysanfrancisco@gmail.com", "DOB": "2000-04-14", "Office": "Denver", "Phone Number": "1-175-432-1437", "Current Brand": "Mercedes" }
如果整合成功,連接器工作的
connectorOutputPayload
回應參數值會類似於下列內容:{ "Internal_Id": "recg7qjPRMa7DBwIb" } <pre> function helloWorld() { alert('Hello, world! This sentence is so long that it wraps onto a second line.'); } /n <h3>Example title</h3> </pre>
範例 - 更新「聯絡人資料 (記錄)」實體的作業
- 在「
Configure connector task
」對話方塊中,按一下Entities
。 - 從
Entity
清單中選取ContactData
。 - 選取「
Update
」作業,然後按一下「完成」。 - 在「資料對應」工作的「資料對應器」部分中,按一下
Open Data Mapping Editor
,然後在Input Value
欄位中輸入類似下列的值,並選擇 EntityId/ConnectorInputPayload/FilterClause 做為本機變數。{ "Phone Number": "1-175-432-4312", "Current Brand": "Honda" }
除了指定 entityId,您也可以將 filterClause 設為
Internal_Id='reckqGnFusjDlnmvs'
。
如果整合成功,連接器工作會輸出下列 connectorOutputPayload
變數:
{ "Internal_Id": "reckqGnFusjDlnmvs" }
範例 - 聯絡人資料 (附件) 實體的更新作業
- 在「
Configure connector task
」對話方塊中,按一下Entities
。 - 從
Entity
清單中選取Contact Data
。 - 選取「
Update
」作業,然後按一下「完成」。 - 在「資料對應」工作的「資料對應器」部分中,按一下
Open Data Mapping Editor
,然後在Input Value
欄位中輸入類似下列的值,並選擇 EntityId/ConnectorInputPayload/FilterClause 做為本機變數。{ "Attachment": "[{\"url\":\"https://media.istockphoto.com/id/2086323995/photo/global-communication-east-asia.jpg?s=2048x2048&w=is&k=20&c=Z50lesspQQzxWug0m11QrPZMOUzMeTufgnLHh_3COy4=\",\"filename\":\"BMW\"}]" }
除了指定 entityId,您也可以將 filterClause 設為
Internal_Id='reckqGnFusjDlnmvs'
。如果整合成功,連接器工作會輸出下列
connectorOutputPayload
變數:{ "Internal_Id": "recoGHHp8y11aSx0E" }
範例 - 聯絡人資料 (核取方塊) 實體的更新作業
- 在「
Configure connector task
」對話方塊中,按一下Entities
。 - 從
Entity
清單中選取Contact Data
。 - 選取「
Update
」作業,然後按一下「完成」。 - 在「資料對應」工作的「資料對應器」部分中,按一下
Open Data Mapping Editor
,然後在Input Value
欄位中輸入類似下列的值,並選擇 EntityId/ConnectorInputPayload/FilterClause 做為本機變數。{ "Checkbox": true }
除了指定 entityId,您也可以將 filterClause 設為
Internal_Id='reckqGnFusjDlnmvs'
。如果整合成功,連接器工作會輸出下列
connectorOutputPayload
變數:{ "Internal_Id": "recoGHHp8y11aSx0E" }
範例 - 更新「聯絡人資料 (號碼)」實體的作業
- 在「
Configure connector task
」對話方塊中,按一下Entities
。 - 從
Entity
清單中選取ContactData
。 - 選取「
Update
」作業,然後按一下「完成」。 - 在「資料對應」工作的「資料對應器」部分中,按一下
Open Data Mapping Editor
,然後在Input Value
欄位中輸入類似下列的值,並選擇 EntityId/ConnectorInputPayload/FilterClause 做為本機變數。{ "Number": 1001.0 }
除了指定 entityId,您也可以將 filterClause 設為
Internal_Id='reckqGnFusjDlnmvs'
。如果整合成功,連接器工作會輸出下列
connectorOutputPayload
變數:{ "Internal_Id": "recoGHHp8y11aSx0E" }
範例 - 更新「聯絡人資料」(DateField) 實體的作業
- 在「
Configure connector task
」對話方塊中,按一下Entities
。 - 從
Entity
清單中選取ContactData
。 - 選取「
Update
」作業,然後按一下「完成」。 - 在「資料對應」工作的「資料對應器」部分中,按一下
Open Data Mapping Editor
,然後在Input Value
欄位中輸入類似下列的值,並選擇 EntityId/ConnectorInputPayload/FilterClause 做為本機變數。{ "DOB": "2000-04-14" }
除了指定 entityId,您也可以將 filterClause 設為
Internal_Id='reckqGnFusjDlnmvs'
。如果整合成功,連接器工作會輸出下列
connectorOutputPayload
變數:{ "Internal_Id": "recoGHHp8y11aSx0E" }
範例 - 聯絡人資料 (文字) 實體的更新作業
- 在「
Configure connector task
」對話方塊中,按一下Entities
。 - 從
Entity
清單中選取ContactData
。 - 選取「
Update
」作業,然後按一下「完成」。 - 在「資料對應」工作的「資料對應器」部分中,按一下
Open Data Mapping Editor
,然後在Input Value
欄位中輸入類似下列的值,並選擇 EntityId/ConnectorInputPayload/FilterClause 做為本機變數。{ "Singlelinetext": "Airtable Application", "Long text": "Airtable is a cloud-based collaboration platform that combines the features of a spreadsheet with the capabilities of a database. " }
除了指定 entityId,您也可以將 filterClause 設為
Internal_Id='reckqGnFusjDlnmvs'
。如果整合成功,連接器工作會輸出下列
connectorOutputPayload
變數:{ "Internal_Id": "recoGHHp8y11aSx0E" }