用戶安裝 FBE 後,擴充功能會在客戶的企業管理平台上建立員工系統用戶。系統會根據 {App Name} System User (FBE)
的模式為這位新系統用戶命名。
系統用戶所代表的伺服器或軟件會針對企業管理平台所擁有或管理的資產執行 API 呼叫。
此系統用戶擁有全部關聯 FBE 資產的權限,以及下列任務權限:
'MANAGE'
'MANAGE'
'MANAGE'
'EDIT'
如果安裝 FBE 後,您透過 Webhook 或企業登入收到用戶存取憑證,您可以將同一個憑證用來獲取企業管理平台的系統用戶存取憑證。如要執行此操作,請發出以下 API 呼叫:
curl -X POST \ -F 'app_id={app_id}' \ -F 'scope={permissions}' \ -F 'access_token={access_token}' \ -F 'fbe_external_business_id={fbe_external_business_id}' \ https://graph.facebook.com/<API_VERSION>/<client_business_manager_id>/access_token
對於 scope
欄位,請使用 manage_business_extension
權限,但視乎您的使用案例而定,您可能也需要 ads_management
或 catalog_management
權限。
對於 access_token
欄位,您可以傳遞用戶存取憑證 (user_access_token
) 或合作夥伴企業管理平台的管理員系統用戶存取憑證 (partner_bm_admin_system_user_token
)。進一步了解企業存取憑證。
Webhook 中的 token_type
欄位表明收到的 access_token
是用戶存取憑證還是系統用戶存取憑證。
如果用戶透過 Instagram 安裝 FBE,Webhook 會傳回在客戶的企業管理平台上產生的系統用戶憑證,因此您無需呼叫此 API。
每當您的企業安裝、修改或解除安裝 FBE,我們都會觸發 Webhook 事件,以便您及時接收有關安裝、解除安裝和重新配置 FBE 的更新。
每次用戶安裝或修改 FBE 時,您的應用程式都應檢查 Webhook 配置,以了解用戶修改、新增或從應用程式的連結中移除了哪些資產。您應用程式的行為應根據最新的已連結資產來作更新。
GET
) 和事件通知 (POST
)。每次收到安裝 Webhook 時,您的應用程式都需要執行以下操作。
請在解除安裝時執行以下步驟:
回應欄位
欄位 | 說明 |
---|---|
ad_account_id 類型:字串 | 用戶在 Facebook Business 擴充功能中選擇的廣告帳戶編號。如果您的應用程式具有 |
business_manager_id 類型:字串 | Facebook Business 擴充功能所用的企業管理平台編號。請參閱 |
catalog_id 類型:字串 | 用戶在 Facebook Business 擴充功能中選擇的目錄編號。用戶可以使用此編號管理其商品目錄。請參閱 |
fbe_event 類型:字串 | FBE 事件,表明事件通知是安裝還是解除安裝。請參閱 |
flow 類型:字串 | 表明用戶透過哪個方式作初始設定的流程(例如 |
commerce_merchant_settings_id 類型:字串 | 商務商家設定編號,用於支援合作夥伴讀取有關所選 Facebook Business 擴充功能商務商家設定的資訊。請參閱 |
onsite_eligible 類型:布林值 | 站內商務資格。表明所選資產是否符合資格用於站內商務。商家必須仍有在網站上使用的意向,並在合作夥伴網站選擇退貨/裝運/付款操作。請參閱 |
profiles 類型:陣列 | 個人檔案清單(Facebook 專頁編號和/或 Instagram 商業檔案編號)。使用這些編號,為您可能擁有的其他 Facebook 整合工具建立獨立的 Graph API 要求。請參閱 |
pages 類型:陣列 | Facebook 專頁編號清單。使用這些編號,為您可能擁有的其他 Facebook 專頁整合工具建立獨立的 Graph API 要求。請參閱 |
instagram_profiles 類型:陣列 | Instagram 商業檔案編號清單。使用這些編號,為您可能擁有的其他 Facebook/Instagram 整合工具建立獨立的 Graph API 要求。如果未有包含此欄位,即表示適用範圍僅限與 Instagram 相關。例如,存取憑證中不包含 |
pixel_id 類型:字串 | 不重複的像素編號,您應儲存並使用此編號來觸發像素事件。請參閱 |
token_type 類型:字串 | |
installed_features 類型:陣列 | 此企業透過初始功能流程整合/安裝的功能清單。請參閱最新的功能清單。 |
feature_instance_id 類型:陣列 | 代表每項已安裝功能的不重複編號。可供日後用於修改或解除安裝特定實例。與功能配置 API 和 Webhook 中引用的 |
feature_type 類型:字串 | 已安裝功能的類型。功能清單表格列有完整的功能組合。您只需追蹤已啟用的功能即可。 |
connected_assets 類型:陣列 | 與每項功能相關的特定資產清單。資產說明與此表頂部提及的說明相對。 |
additional_info 類型:陣列 | 有關已連結功能的其他資訊。 |
接收到新安裝的 Webhook 事件時,您必須:1)保持 business_id
與其 pixel_id
之間的配對,因為此像素編號是該企業所獨有的不重複編號,您應該使用此編號來觸發標準像素事件;2)使用其中一個目錄推送 API(如已啟用)來更新該企業的庫存。
onsite_commerce_eligible
欄位的裝載{ "data": [{ "ad_account_id": "<ad_account_id>", "business_manager_id": "<business_manager_id>", "catalog_id": "<catalog_id>", "commerce_merchant_settings_id": "<commerce_merchant_settings_id>", "onsite_eligible": true, "profiles": [ "<page_id>", "<instagram_profile_id>" ], "pages": [ "<page_id>" ], "instagram_profiles": [ "<instagram_profile_id>" ], "pixel_id": "<pixel_id>", "token_type": "<token_type>", "installed_features": [ { "feature_instance_id": "<unique_id>", "feature_name" : string, "feature_type": enum, "connected_assets": { "ad_account_id": "<ad_account_id>", "business_manager_id": "<business_manager_id>", "catalog_id": "<catalog_id>", "commerce_merchant_settings_id": "<commerce_merchant_settings_id>", "ig_profile_id": "<instagram_profile_id>" "page_id": "<page_id>", "pixel_id": "<pixel_id>", }, "additional_info": { "onsite_commerce_eligible": bool }, { "shop_status": array }, { "shop_status_info": array } } ] }] }
如果企業已安裝 FBE,您可以使用下列端點來查詢基本安裝資訊(pixel_id
和附有 IG Business ID and/or Page ID
的個人檔案清單):
CURL -X GET 'https://graph.facebook.com/<API_VERSION>/fbe_business/fbe_installs?fbe_external_business_id=<fbe_external_business_id>&access_token=<access_token>'
{ "data": [{ "token_type": "<token_type>" "installed_features": [ { "feature_instance_id": "<unique_id>", “feature_name” : string, "feature_type": enum, "connected_assets": { “ad_account_id”: "<ad_account_id>", “business_manager_id”: "<business_manager_id>", “catalog_id”: "<catalog_id>", “commerce_merchant_settings_id”: "<commerce_merchant_settings_id>", “ig_profile_id”: "<instagram_profile_id>" "page_id": "<page_id>", "pixel_id": "<pixel_id>", }, "additional_info": { "onsite_commerce_eligible": bool }, { "shop_status": array }, { "shop_status_info": array } } ] }] }
回應包含以下欄位。這些是「installed_features」清單目前已連結資產的真實來源:
欄位 | 說明 |
---|---|
類型:字串 | |
類型:陣列 | 此企業透過初始設定流程整合或安裝的功能清單。 |
類型:字串 | 代表每項已安裝功能的不重複編號。可供日後用於修改或解除安裝特定實例。此欄位與功能配置 API 和 Webhook 中引用的 |
類型:字串 | 不重複功能的名稱。 |
類型:字串 | 已安裝功能的類型。您只需追蹤已啟用的功能即可。 |
類型:陣列 | 每項功能的專屬資產清單。 |
類型:字串 | 有關已連結功能的其他資訊(包括 「Active」表示商店可顯示。「Inactive_offsite」表示商店因未有使用站內結帳功能而無法顯示。「Inactive_other」表示商店因某個與結帳方式無關的原因而無法顯示。「No_longer_available」表示商店因不在美國境內或不在主要市場而無法再使用。 |
模型包含每項功能的功能實例編號和欄位,這些欄位由該企業安裝的所有此類功能的陣列組成(例如多個專頁 CTA)。
對於不可自訂的功能,系統只會顯示功能實例編號和已啟用標記。POST
要求只能用於更新可自訂的功能。
此模型不同於 Facebook Business 擴充功能安裝 API,因為前者會提供已連結資產以外的其他功能資訊,包括已啟用狀態和具體的功能自訂項目。呼叫 Facebook Business 擴充功能安裝 API 後,如有需要,請使用此 API 來獲取更多有關功能已啟用狀態或配置的資訊。
讀取
您可以發出以下要求,以讀取任何企業目前的功能配置狀態:
CURL -X GET 'https://graph.facebook.com/<API_VERSION>/fbe_business/?fbe_external_business_id=<fbe_external_business_id>&access_token=<access_token>'
更新
如要更新所有功能,請使用以下 POST
要求:
CURL -i -X POST \ -F 'fbe_external_business_id=<fbe_external_business_id>' \ -F 'business_config={business_config object}' \ -F 'access_token=<access_token>' "https://graph.facebook.com/<API_VERSION>/fbe_business"
回應
{ "page_cta": { "feature_instance_id": id1, "enabled": true, "cta_button_text": "Book Now", "cta_button_url": "https://partner-site.com/foo-business1", "below_button_text": "Powered by FBE Partner" }, "page_ctas": [ { "feature_instance_id": id1, "enabled": true, "cta_button_text": "Book Now", "cta_button_url": "https://partner-site.com/foo-business1", "below_button_text": "Powered by FBE Partner" }, { "feature_instance_id": id2, "enabled": true, "cta_button_text": "Book Now", "cta_button_url": "https://partner-site.com/foo-business2", "below_button_text": "Powered by FBE Partner" } ], “ig_cta”: {...} "ig_ctas": [{...}, {...}], “ads”: [ { "feature_instance_id": id3, “enabled”: true, }, { "feature_instance_id": id4, “enabled”: true, }, ], ... }