Microsoft Teams
“Tinggalkan segala harapan, wahai kalian yang masuk ke sini.”Diperbarui: 2026-03-25 Status: teks + lampiran DM didukung; pengiriman file saluran/grup memerlukan
sharePointSiteId + izin Graph (lihat Mengirim file di obrolan grup). Polls dikirim melalui Adaptive Cards. Tindakan pesan mengekspos upload-file yang eksplisit untuk pengiriman yang mengutamakan file.
Plugin bawaan
Microsoft Teams dikirim sebagai plugin bawaan dalam rilis OpenClaw saat ini, jadi tidak diperlukan instalasi terpisah pada build paket normal. Jika Anda menggunakan build lama atau instalasi kustom yang tidak menyertakan Teams bawaan, instal secara manual:Penyiapan cepat (pemula)
- Pastikan plugin Microsoft Teams tersedia.
- Rilis OpenClaw paket saat ini sudah menyertakannya secara bawaan.
- Instalasi lama/kustom dapat menambahkannya secara manual dengan perintah di atas.
- Buat Azure Bot (App ID + client secret + tenant ID).
- Konfigurasikan OpenClaw dengan kredensial tersebut.
- Ekspos
/api/messages(port 3978 secara default) melalui URL publik atau tunnel. - Instal paket aplikasi Teams dan jalankan gateway.
channels.msteams.groupPolicy: "allowlist"). Untuk mengizinkan balasan grup, setel channels.msteams.groupAllowFrom (atau gunakan groupPolicy: "open" untuk mengizinkan anggota mana pun, dengan gerbang mention).
Tujuan
- Berbicara dengan OpenClaw melalui DM Teams, obrolan grup, atau saluran.
- Menjaga perutean tetap deterministik: balasan selalu kembali ke saluran tempat pesan datang.
- Menggunakan perilaku saluran yang aman secara default (mention wajib kecuali dikonfigurasi sebaliknya).
Penulisan konfigurasi
Secara default, Microsoft Teams diizinkan menulis pembaruan konfigurasi yang dipicu oleh/config set|unset (memerlukan commands.config: true).
Nonaktifkan dengan:
Kontrol akses (DM + grup)
Akses DM- Default:
channels.msteams.dmPolicy = "pairing". Pengirim yang tidak dikenal diabaikan sampai disetujui. channels.msteams.allowFromsebaiknya menggunakan ID objek AAD yang stabil.- UPN/nama tampilan dapat berubah; pencocokan langsung dinonaktifkan secara default dan hanya diaktifkan dengan
channels.msteams.dangerouslyAllowNameMatching: true. - Wizard dapat menyelesaikan nama menjadi ID melalui Microsoft Graph jika kredensial mengizinkan.
- Default:
channels.msteams.groupPolicy = "allowlist"(diblokir kecuali Anda menambahkangroupAllowFrom). Gunakanchannels.defaults.groupPolicyuntuk mengganti default saat tidak disetel. channels.msteams.groupAllowFrommengontrol pengirim mana yang dapat memicu di obrolan grup/saluran (fallback kechannels.msteams.allowFrom).- Setel
groupPolicy: "open"untuk mengizinkan anggota mana pun (tetap dengan gerbang mention secara default). - Untuk mengizinkan tidak ada saluran, setel
channels.msteams.groupPolicy: "disabled".
- Batasi balasan grup/saluran dengan mencantumkan teams dan saluran di bawah
channels.msteams.teams. - Kunci sebaiknya menggunakan ID team yang stabil dan ID percakapan saluran.
- Saat
groupPolicy="allowlist"dan allowlist teams tersedia, hanya teams/saluran yang tercantum yang diterima (dengan gerbang mention). - Wizard konfigurasi menerima entri
Team/Channeldan menyimpannya untuk Anda. - Saat startup, OpenClaw menyelesaikan nama team/saluran dan nama pengguna pada allowlist menjadi ID (jika izin Graph mengizinkan)
dan mencatat pemetaannya; nama team/saluran yang tidak terselesaikan tetap disimpan seperti yang diketik tetapi diabaikan untuk perutean secara default kecuali
channels.msteams.dangerouslyAllowNameMatching: truediaktifkan.
Cara kerjanya
- Pastikan plugin Microsoft Teams tersedia.
- Rilis OpenClaw paket saat ini sudah menyertakannya secara bawaan.
- Instalasi lama/kustom dapat menambahkannya secara manual dengan perintah di atas.
- Buat Azure Bot (App ID + secret + tenant ID).
- Bangun paket aplikasi Teams yang mereferensikan bot dan menyertakan izin RSC di bawah ini.
- Unggah/instal aplikasi Teams ke dalam team (atau cakupan personal untuk DM).
- Konfigurasikan
msteamsdi~/.openclaw/openclaw.json(atau env vars) dan jalankan gateway. - Gateway mendengarkan lalu lintas webhook Bot Framework pada
/api/messagessecara default.
Penyiapan Azure Bot (Prasyarat)
Sebelum mengonfigurasi OpenClaw, Anda perlu membuat resource Azure Bot.Langkah 1: Buat Azure Bot
- Buka Create Azure Bot
-
Isi tab Basics:
Field Value Bot handle Nama bot Anda, misalnya openclaw-msteams(harus unik)Subscription Pilih langganan Azure Anda Resource group Buat baru atau gunakan yang sudah ada Pricing tier Free untuk dev/pengujian Type of App Single Tenant (disarankan - lihat catatan di bawah) Creation type Create new Microsoft App ID
Pemberitahuan deprecasi: Pembuatan bot multi-tenant baru telah deprecated setelah 2025-07-31. Gunakan Single Tenant untuk bot baru.
- Klik Review + create → Create (tunggu ~1-2 menit)
Langkah 2: Dapatkan Kredensial
- Buka resource Azure Bot Anda → Configuration
- Salin Microsoft App ID → ini adalah
appIdAnda - Klik Manage Password → buka App Registration
- Di bawah Certificates & secrets → New client secret → salin Value → ini adalah
appPasswordAnda - Buka Overview → salin Directory (tenant) ID → ini adalah
tenantIdAnda
Langkah 3: Konfigurasikan Endpoint Pesan
- Di Azure Bot → Configuration
- Setel Messaging endpoint ke URL webhook Anda:
- Produksi:
https://your-domain.com/api/messages - Dev lokal: Gunakan tunnel (lihat Pengembangan Lokal di bawah)
- Produksi:
Langkah 4: Aktifkan Saluran Teams
- Di Azure Bot → Channels
- Klik Microsoft Teams → Configure → Save
- Setujui Terms of Service
Autentikasi Federasi (Sertifikat + Managed Identity)
Ditambahkan pada 2026.3.24Untuk deployment produksi, OpenClaw mendukung autentikasi federasi sebagai alternatif yang lebih aman dibandingkan client secret. Tersedia dua metode:
Opsi A: Autentikasi berbasis sertifikat
Gunakan sertifikat PEM yang terdaftar pada app registration Entra ID Anda. Penyiapan:- Buat atau dapatkan sertifikat (format PEM dengan private key).
- Di Entra ID → App Registration → Certificates & secrets → Certificates → unggah sertifikat publik.
MSTEAMS_AUTH_TYPE=federatedMSTEAMS_CERTIFICATE_PATH=/path/to/cert.pem
Opsi B: Azure Managed Identity
Gunakan Azure Managed Identity untuk autentikasi tanpa kata sandi. Ini ideal untuk deployment pada infrastruktur Azure (AKS, App Service, Azure VM) yang memiliki managed identity. Cara kerjanya:- Pod/VM bot memiliki managed identity (system-assigned atau user-assigned).
- Sebuah federated identity credential menautkan managed identity ke app registration Entra ID.
- Saat runtime, OpenClaw menggunakan
@azure/identityuntuk memperoleh token dari endpoint Azure IMDS (169.254.169.254). - Token diteruskan ke SDK Teams untuk autentikasi bot.
- Infrastruktur Azure dengan managed identity diaktifkan (AKS workload identity, App Service, VM)
- Federated identity credential dibuat pada app registration Entra ID
- Akses jaringan ke IMDS (
169.254.169.254:80) dari pod/VM
MSTEAMS_AUTH_TYPE=federatedMSTEAMS_USE_MANAGED_IDENTITY=trueMSTEAMS_MANAGED_IDENTITY_CLIENT_ID=<client-id>(hanya untuk user-assigned)
Penyiapan AKS Workload Identity
Untuk deployment AKS yang menggunakan workload identity:- Aktifkan workload identity pada cluster AKS Anda.
-
Buat federated identity credential pada app registration Entra ID:
-
Tambahkan anotasi pada service account Kubernetes dengan app client ID:
-
Tambahkan label pada pod untuk injeksi workload identity:
-
Pastikan akses jaringan ke IMDS (
169.254.169.254) — jika menggunakan NetworkPolicy, tambahkan aturan egress yang mengizinkan lalu lintas ke169.254.169.254/32pada port 80.
Perbandingan jenis autentikasi
| Method | Config | Pros | Cons |
|---|---|---|---|
| Client secret | appPassword | Penyiapan sederhana | Perlu rotasi secret, kurang aman |
| Certificate | authType: "federated" + certificatePath | Tidak ada shared secret di jaringan | Ada beban pengelolaan sertifikat |
| Managed Identity | authType: "federated" + useManagedIdentity | Tanpa kata sandi, tidak perlu kelola secret | Memerlukan infrastruktur Azure |
authType tidak disetel, OpenClaw secara default menggunakan autentikasi client secret. Konfigurasi yang ada tetap berfungsi tanpa perubahan.
Pengembangan Lokal (Tunneling)
Teams tidak dapat menjangkaulocalhost. Gunakan tunnel untuk pengembangan lokal:
Opsi A: ngrok
Teams Developer Portal (Alternatif)
Alih-alih membuat ZIP manifest secara manual, Anda dapat menggunakan Teams Developer Portal:- Klik + New app
- Isi info dasar (nama, deskripsi, info pengembang)
- Buka App features → Bot
- Pilih Enter a bot ID manually dan tempel Azure Bot App ID Anda
- Centang cakupan: Personal, Team, Group Chat
- Klik Distribute → Download app package
- Di Teams: Apps → Manage your apps → Upload a custom app → pilih ZIP
Menguji Bot
Opsi A: Azure Web Chat (verifikasi webhook terlebih dahulu)- Di Azure Portal → resource Azure Bot Anda → Test in Web Chat
- Kirim pesan - Anda seharusnya melihat respons
- Ini mengonfirmasi endpoint webhook Anda berfungsi sebelum penyiapan Teams
- Instal aplikasi Teams (sideload atau katalog organisasi)
- Temukan bot di Teams dan kirim DM
- Periksa log gateway untuk aktivitas masuk
Penyiapan (minimal hanya teks)
-
Pastikan plugin Microsoft Teams tersedia
- Rilis OpenClaw paket saat ini sudah menyertakannya secara bawaan.
- Instalasi lama/kustom dapat menambahkannya secara manual:
- Dari npm:
openclaw plugins install @openclaw/msteams - Dari checkout lokal:
openclaw plugins install ./path/to/local/msteams-plugin
- Dari npm:
-
Pendaftaran bot
- Buat Azure Bot (lihat di atas) dan catat:
- App ID
- Client secret (App password)
- Tenant ID (single-tenant)
- Buat Azure Bot (lihat di atas) dan catat:
-
Manifest aplikasi Teams
- Sertakan entri
botdenganbotId = <App ID>. - Cakupan:
personal,team,groupChat. supportsFiles: true(wajib untuk penanganan file pada cakupan personal).- Tambahkan izin RSC (di bawah).
- Buat ikon:
outline.png(32x32) dancolor.png(192x192). - Zip ketiga file bersama-sama:
manifest.json,outline.png,color.png.
- Sertakan entri
-
Konfigurasikan OpenClaw
Anda juga dapat menggunakan environment variable alih-alih kunci konfigurasi:
MSTEAMS_APP_IDMSTEAMS_APP_PASSWORDMSTEAMS_TENANT_IDMSTEAMS_AUTH_TYPE(opsional:"secret"atau"federated")MSTEAMS_CERTIFICATE_PATH(federated + sertifikat)MSTEAMS_CERTIFICATE_THUMBPRINT(opsional, tidak wajib untuk autentikasi)MSTEAMS_USE_MANAGED_IDENTITY(federated + managed identity)MSTEAMS_MANAGED_IDENTITY_CLIENT_ID(hanya untuk user-assigned MI)
-
Endpoint bot
- Setel Azure Bot Messaging Endpoint ke:
https://<host>:3978/api/messages(atau path/port pilihan Anda).
- Setel Azure Bot Messaging Endpoint ke:
-
Jalankan gateway
- Saluran Teams dimulai secara otomatis saat plugin bawaan atau plugin yang diinstal manual tersedia dan konfigurasi
msteamsada beserta kredensialnya.
- Saluran Teams dimulai secara otomatis saat plugin bawaan atau plugin yang diinstal manual tersedia dan konfigurasi
Tindakan info anggota
OpenClaw mengekspos tindakanmember-info berbasis Graph untuk Microsoft Teams agar agen dan otomasi dapat menyelesaikan detail anggota saluran (nama tampilan, email, peran) langsung dari Microsoft Graph.
Persyaratan:
- Izin RSC
Member.Read.Group(sudah ada dalam manifest yang direkomendasikan) - Untuk lookup lintas team: izin Aplikasi Graph
User.Read.Alldengan admin consent
channels.msteams.actions.memberInfo (default: aktif saat kredensial Graph tersedia).
Konteks riwayat
channels.msteams.historyLimitmengontrol berapa banyak pesan saluran/grup terbaru yang dibungkus ke dalam prompt.- Fallback ke
messages.groupChat.historyLimit. Setel0untuk menonaktifkan (default 50). - Riwayat thread yang diambil difilter berdasarkan allowlist pengirim (
allowFrom/groupAllowFrom), jadi penyemaian konteks thread hanya menyertakan pesan dari pengirim yang diizinkan. - Konteks lampiran kutipan (
ReplyTo*yang diturunkan dari HTML balasan Teams) saat ini diteruskan sebagaimana diterima. - Dengan kata lain, allowlist mengendalikan siapa yang dapat memicu agen; saat ini hanya jalur konteks tambahan tertentu yang difilter.
- Riwayat DM dapat dibatasi dengan
channels.msteams.dmHistoryLimit(giliran pengguna). Override per pengguna:channels.msteams.dms["<user_id>"].historyLimit.
Izin RSC Teams Saat Ini (Manifest)
Ini adalah izin resourceSpecific yang ada dalam manifest aplikasi Teams kami. Izin ini hanya berlaku di dalam team/chat tempat aplikasi diinstal. Untuk saluran (cakupan team):ChannelMessage.Read.Group(Application) - menerima semua pesan saluran tanpa @mentionChannelMessage.Send.Group(Application)Member.Read.Group(Application)Owner.Read.Group(Application)ChannelSettings.Read.Group(Application)TeamMember.Read.Group(Application)TeamSettings.Read.Group(Application)
ChatMessage.Read.Chat(Application) - menerima semua pesan obrolan grup tanpa @mention
Contoh Manifest Teams (disamarkan)
Contoh minimal yang valid dengan field yang diperlukan. Ganti ID dan URL.Catatan manifest (field yang wajib ada)
bots[].botIdharus cocok dengan Azure Bot App ID.webApplicationInfo.idharus cocok dengan Azure Bot App ID.bots[].scopesharus menyertakan permukaan yang ingin Anda gunakan (personal,team,groupChat).bots[].supportsFiles: truewajib untuk penanganan file pada cakupan personal.authorization.permissions.resourceSpecificharus menyertakan pembacaan/pengiriman saluran jika Anda menginginkan lalu lintas saluran.
Memperbarui aplikasi yang sudah ada
Untuk memperbarui aplikasi Teams yang sudah terinstal (misalnya, untuk menambahkan izin RSC):- Perbarui
manifest.jsonAnda dengan pengaturan baru - Naikkan field
version(misalnya1.0.0→1.1.0) - Zip ulang manifest dengan ikon (
manifest.json,outline.png,color.png) - Unggah zip baru:
- Opsi A (Teams Admin Center): Teams Admin Center → Teams apps → Manage apps → temukan aplikasi Anda → Upload new version
- Opsi B (Sideload): Di Teams → Apps → Manage your apps → Upload a custom app
- Untuk saluran team: Instal ulang aplikasi di setiap team agar izin baru berlaku
- Keluar sepenuhnya dan luncurkan ulang Teams (bukan hanya menutup jendela) untuk menghapus metadata aplikasi yang tersimpan di cache
Kemampuan: hanya RSC vs Graph
Dengan Teams RSC saja (aplikasi terinstal, tanpa izin API Graph)
Berfungsi:- Membaca konten teks pesan saluran.
- Mengirim konten teks pesan saluran.
- Menerima lampiran file personal (DM).
- Konten gambar atau file saluran/grup (payload hanya menyertakan stub HTML).
- Mengunduh lampiran yang disimpan di SharePoint/OneDrive.
- Membaca riwayat pesan (di luar event webhook langsung).
Dengan Teams RSC + izin Aplikasi Microsoft Graph
Menambahkan:- Mengunduh konten yang di-host (gambar yang ditempel ke dalam pesan).
- Mengunduh lampiran file yang disimpan di SharePoint/OneDrive.
- Membaca riwayat pesan saluran/chat melalui Graph.
RSC vs Graph API
| Capability | RSC Permissions | Graph API |
|---|---|---|
| Pesan real-time | Ya (melalui webhook) | Tidak (hanya polling) |
| Pesan historis | Tidak | Ya (dapat mengkueri riwayat) |
| Kompleksitas setup | Hanya manifest aplikasi | Memerlukan admin consent + alur token |
| Berfungsi offline | Tidak (harus berjalan) | Ya (dapat mengkueri kapan saja) |
ChannelMessage.Read.All (memerlukan admin consent).
Media + riwayat dengan Graph (wajib untuk saluran)
Jika Anda memerlukan gambar/file di saluran atau ingin mengambil riwayat pesan, Anda harus mengaktifkan izin Microsoft Graph dan memberikan admin consent.- Di App Registration Entra ID (Azure AD), tambahkan izin Aplikasi Microsoft Graph:
ChannelMessage.Read.All(lampiran saluran + riwayat)Chat.Read.AllatauChatMessage.Read.All(obrolan grup)
- Berikan admin consent untuk tenant.
- Naikkan versi manifest aplikasi Teams, unggah ulang, dan instal ulang aplikasi di Teams.
- Keluar sepenuhnya dan luncurkan ulang Teams untuk menghapus metadata aplikasi yang tersimpan di cache.
User.Read.All (Application) dan berikan admin consent.
Keterbatasan yang Diketahui
Timeout webhook
Teams mengirimkan pesan melalui webhook HTTP. Jika pemrosesan memakan waktu terlalu lama (misalnya, respons LLM lambat), Anda mungkin melihat:- Timeout gateway
- Teams mencoba ulang pesan (menyebabkan duplikasi)
- Balasan yang terlewat
Pemformatan
Markdown Teams lebih terbatas daripada Slack atau Discord:- Pemformatan dasar berfungsi: tebal, miring,
code, tautan - Markdown kompleks (tabel, daftar bertingkat) mungkin tidak dirender dengan benar
- Adaptive Cards didukung untuk polls dan pengiriman kartu arbitrer (lihat di bawah)
Konfigurasi
Pengaturan utama (lihat/gateway/configuration untuk pola saluran bersama):
channels.msteams.enabled: aktifkan/nonaktifkan saluran.channels.msteams.appId,channels.msteams.appPassword,channels.msteams.tenantId: kredensial bot.channels.msteams.webhook.port(default3978)channels.msteams.webhook.path(default/api/messages)channels.msteams.dmPolicy:pairing | allowlist | open | disabled(default: pairing)channels.msteams.allowFrom: allowlist DM (ID objek AAD direkomendasikan). Wizard menyelesaikan nama menjadi ID selama penyiapan saat akses Graph tersedia.channels.msteams.dangerouslyAllowNameMatching: toggle break-glass untuk mengaktifkan kembali pencocokan UPN/nama tampilan yang dapat berubah dan perutean langsung nama team/saluran.channels.msteams.textChunkLimit: ukuran chunk teks keluar.channels.msteams.chunkMode:length(default) ataunewlineuntuk memisah pada baris kosong (batas paragraf) sebelum chunking berdasarkan panjang.channels.msteams.mediaAllowHosts: allowlist untuk host lampiran masuk (default ke domain Microsoft/Teams).channels.msteams.mediaAuthAllowHosts: allowlist untuk melampirkan header Authorization pada percobaan ulang media (default ke host Graph + Bot Framework).channels.msteams.requireMention: mewajibkan @mention di saluran/grup (default true).channels.msteams.replyStyle:thread | top-level(lihat Gaya Balasan).channels.msteams.teams.<teamId>.replyStyle: override per-team.channels.msteams.teams.<teamId>.requireMention: override per-team.channels.msteams.teams.<teamId>.tools: override kebijakan tool default per-team (allow/deny/alsoAllow) yang digunakan saat override saluran tidak ada.channels.msteams.teams.<teamId>.toolsBySender: override kebijakan tool default per-team per-pengirim ("*"wildcard didukung).channels.msteams.teams.<teamId>.channels.<conversationId>.replyStyle: override per-saluran.channels.msteams.teams.<teamId>.channels.<conversationId>.requireMention: override per-saluran.channels.msteams.teams.<teamId>.channels.<conversationId>.tools: override kebijakan tool per-saluran (allow/deny/alsoAllow).channels.msteams.teams.<teamId>.channels.<conversationId>.toolsBySender: override kebijakan tool per-saluran per-pengirim ("*"wildcard didukung).- Kunci
toolsBySenderharus menggunakan prefiks eksplisit:id:,e164:,username:,name:(kunci lama tanpa prefiks masih dipetakan keid:saja). channels.msteams.actions.memberInfo: aktifkan atau nonaktifkan tindakan info anggota berbasis Graph (default: aktif saat kredensial Graph tersedia).channels.msteams.authType: jenis autentikasi —"secret"(default) atau"federated".channels.msteams.certificatePath: path ke file sertifikat PEM (federated + autentikasi sertifikat).channels.msteams.certificateThumbprint: thumbprint sertifikat (opsional, tidak wajib untuk autentikasi).channels.msteams.useManagedIdentity: aktifkan autentikasi managed identity (mode federated).channels.msteams.managedIdentityClientId: client ID untuk managed identity user-assigned.channels.msteams.sharePointSiteId: ID situs SharePoint untuk unggahan file di obrolan grup/saluran (lihat Mengirim file di obrolan grup).
Perutean & Sesi
- Kunci sesi mengikuti format agen standar (lihat /concepts/session):
- Pesan langsung berbagi sesi utama (
agent:<agentId>:<mainKey>). - Pesan saluran/grup menggunakan ID percakapan:
agent:<agentId>:msteams:channel:<conversationId>agent:<agentId>:msteams:group:<conversationId>
- Pesan langsung berbagi sesi utama (
Gaya Balasan: Thread vs Postingan
Teams baru-baru ini memperkenalkan dua gaya UI saluran di atas model data dasar yang sama:| Style | Description | replyStyle yang direkomendasikan |
|---|---|---|
| Posts (klasik) | Pesan muncul sebagai kartu dengan balasan berutas di bawahnya | thread (default) |
| Threads (mirip Slack) | Pesan mengalir secara linear, lebih mirip Slack | top-level |
replyStyle yang salah:
threaddi saluran bergaya Threads → balasan tampak bertingkat dengan canggungtop-leveldi saluran bergaya Posts → balasan muncul sebagai postingan tingkat atas terpisah, bukan di dalam thread
replyStyle per-saluran berdasarkan cara saluran disiapkan:
Lampiran & Gambar
Keterbatasan saat ini:- DM: Gambar dan lampiran file berfungsi melalui API file bot Teams.
- Saluran/grup: Lampiran berada di penyimpanan M365 (SharePoint/OneDrive). Payload webhook hanya menyertakan stub HTML, bukan byte file sebenarnya. Izin Graph API diperlukan untuk mengunduh lampiran saluran.
- Untuk pengiriman eksplisit yang mengutamakan file, gunakan
action=upload-filedenganmedia/filePath/path;messageopsional menjadi teks/komentar pendamping, danfilenamemenggantikan nama yang diunggah.
channels.msteams.mediaAllowHosts (gunakan ["*"] untuk mengizinkan host apa pun).
Header Authorization hanya dilampirkan untuk host di channels.msteams.mediaAuthAllowHosts (default ke host Graph + Bot Framework). Pertahankan daftar ini tetap ketat (hindari suffix multi-tenant).
Mengirim file di obrolan grup
Bot dapat mengirim file di DM menggunakan alur FileConsentCard (bawaan). Namun, mengirim file di obrolan grup/saluran memerlukan penyiapan tambahan:| Context | How files are sent | Setup needed |
|---|---|---|
| DM | FileConsentCard → pengguna menerima → bot mengunggah | Langsung berfungsi |
| Obrolan grup/saluran | Unggah ke SharePoint → bagikan tautan | Memerlukan sharePointSiteId + izin Graph |
| Gambar (konteks apa pun) | Inline dengan enkode Base64 | Langsung berfungsi |
Mengapa obrolan grup memerlukan SharePoint
Bot tidak memiliki drive OneDrive personal (endpoint Graph API/me/drive tidak berfungsi untuk identitas aplikasi). Untuk mengirim file di obrolan grup/saluran, bot mengunggah ke situs SharePoint dan membuat tautan berbagi.
Penyiapan
-
Tambahkan izin Graph API di Entra ID (Azure AD) → App Registration:
Sites.ReadWrite.All(Application) - unggah file ke SharePointChat.Read.All(Application) - opsional, mengaktifkan tautan berbagi per-pengguna
- Berikan admin consent untuk tenant.
-
Dapatkan ID situs SharePoint Anda:
-
Konfigurasikan OpenClaw:
Perilaku berbagi
| Permission | Sharing behavior |
|---|---|
Sites.ReadWrite.All saja | Tautan berbagi ke seluruh organisasi (siapa pun di organisasi dapat mengakses) |
Sites.ReadWrite.All + Chat.Read.All | Tautan berbagi per-pengguna (hanya anggota chat yang dapat mengakses) |
Chat.Read.All tidak ada, bot akan fallback ke berbagi ke seluruh organisasi.
Perilaku fallback
| Scenario | Result |
|---|---|
Obrolan grup + file + sharePointSiteId dikonfigurasi | Unggah ke SharePoint, kirim tautan berbagi |
Obrolan grup + file + tidak ada sharePointSiteId | Coba unggah ke OneDrive (mungkin gagal), kirim teks saja |
| Chat personal + file | Alur FileConsentCard (berfungsi tanpa SharePoint) |
| Konteks apa pun + gambar | Inline dengan enkode Base64 (berfungsi tanpa SharePoint) |
Lokasi penyimpanan file
File yang diunggah disimpan di folder/OpenClawShared/ dalam pustaka dokumen default situs SharePoint yang dikonfigurasi.
Polls (Adaptive Cards)
OpenClaw mengirim polls Teams sebagai Adaptive Cards (tidak ada API poll Teams native).- CLI:
openclaw message poll --channel msteams --target conversation:<id> ... - Vote dicatat oleh gateway di
~/.openclaw/msteams-polls.json. - Gateway harus tetap online untuk mencatat vote.
- Poll belum otomatis memposting ringkasan hasil (periksa file store jika diperlukan).
Adaptive Cards (arbitrer)
Kirim JSON Adaptive Card apa pun ke pengguna atau percakapan Teams menggunakan toolmessage atau CLI.
Parameter card menerima objek JSON Adaptive Card. Saat card diberikan, teks pesan bersifat opsional.
Tool agen:
Format target
Target MSTeams menggunakan prefiks untuk membedakan pengguna dan percakapan:| Target type | Format | Example |
|---|---|---|
| Pengguna (berdasarkan ID) | user:<aad-object-id> | user:40a1a0ed-4ff2-4164-a219-55518990c197 |
| Pengguna (berdasarkan nama) | user:<display-name> | user:John Smith (memerlukan Graph API) |
| Grup/saluran | conversation:<conversation-id> | conversation:19:abc123...@thread.tacv2 |
| Grup/saluran (raw) | <conversation-id> | 19:abc123...@thread.tacv2 (jika mengandung @thread) |
user:, nama secara default akan menggunakan resolusi grup/team. Selalu gunakan user: saat menargetkan orang berdasarkan nama tampilan.
Pesan proaktif
- Pesan proaktif hanya dimungkinkan setelah pengguna berinteraksi, karena kami menyimpan referensi percakapan pada saat itu.
- Lihat
/gateway/configurationuntuk gerbangdmPolicydan allowlist.
ID Team dan Saluran (Kesalahan Umum)
Parameter kuerigroupId dalam URL Teams BUKAN ID team yang digunakan untuk konfigurasi. Ekstrak ID dari path URL sebagai gantinya:
URL Team:
- ID Team = segmen path setelah
/team/(hasil URL-decode, misalnya19:Bk4j...@thread.tacv2) - ID Saluran = segmen path setelah
/channel/(hasil URL-decode) - Abaikan parameter kueri
groupId
Saluran Privat
Bot memiliki dukungan terbatas di saluran privat:| Feature | Standard Channels | Private Channels |
|---|---|---|
| Instalasi bot | Ya | Terbatas |
| Pesan real-time (webhook) | Ya | Mungkin tidak berfungsi |
| Izin RSC | Ya | Mungkin berperilaku berbeda |
| @mentions | Ya | Jika bot dapat diakses |
| Riwayat Graph API | Ya | Ya (dengan izin) |
- Gunakan saluran standar untuk interaksi bot
- Gunakan DM - pengguna selalu dapat mengirim pesan langsung ke bot
- Gunakan Graph API untuk akses historis (memerlukan
ChannelMessage.Read.All)
Pemecahan Masalah
Masalah umum
- Gambar tidak muncul di saluran: izin Graph atau admin consent belum ada. Instal ulang aplikasi Teams dan keluar/buka kembali Teams sepenuhnya.
- Tidak ada respons di saluran: mention diwajibkan secara default; setel
channels.msteams.requireMention=falseatau konfigurasikan per team/saluran. - Versi tidak cocok (Teams masih menampilkan manifest lama): hapus + tambahkan ulang aplikasi dan keluar dari Teams sepenuhnya untuk menyegarkan.
- 401 Unauthorized dari webhook: Ini wajar saat menguji secara manual tanpa Azure JWT - artinya endpoint dapat dijangkau tetapi autentikasi gagal. Gunakan Azure Web Chat untuk pengujian yang benar.
Kesalahan unggah manifest
- “Icon file cannot be empty”: Manifest mereferensikan file ikon yang berukuran 0 byte. Buat ikon PNG yang valid (32x32 untuk
outline.png, 192x192 untukcolor.png). - “webApplicationInfo.Id already in use”: Aplikasi masih terinstal di team/chat lain. Temukan dan copot pemasangannya terlebih dahulu, atau tunggu 5-10 menit untuk propagasi.
- “Something went wrong” saat unggah: Unggah melalui https://admin.teams.microsoft.com sebagai gantinya, buka browser DevTools (F12) → tab Network, dan periksa body respons untuk melihat kesalahan sebenarnya.
- Sideload gagal: Coba “Upload an app to your org’s app catalog” alih-alih “Upload a custom app” - ini sering melewati pembatasan sideload.
Izin RSC tidak berfungsi
- Verifikasi
webApplicationInfo.idcocok persis dengan App ID bot Anda - Unggah ulang aplikasi dan instal ulang di team/chat
- Periksa apakah admin organisasi Anda memblokir izin RSC
- Konfirmasikan Anda menggunakan cakupan yang benar:
ChannelMessage.Read.Groupuntuk teams,ChatMessage.Read.Chatuntuk obrolan grup
Referensi
- Create Azure Bot - panduan penyiapan Azure Bot
- Teams Developer Portal - membuat/mengelola aplikasi Teams
- Teams app manifest schema
- Receive channel messages with RSC
- RSC permissions reference
- Teams bot file handling (saluran/grup memerlukan Graph)
- Proactive messaging
Terkait
- Ikhtisar Saluran — semua saluran yang didukung
- Pairing — autentikasi DM dan alur pairing
- Grup — perilaku obrolan grup dan gerbang mention
- Perutean Saluran — perutean sesi untuk pesan
- Keamanan — model akses dan hardening