Community translations by veiseule.ai — Help improve them on Crowdin
Skip to main content

Matrix (plugin)

Matrix သည် ဖွင့်လှစ်ထားပြီး ဗဟိုမဲ့သော စာပို့ဆက်သွယ်ရေး ပရိုတိုကော တစ်ခုဖြစ်သည်။ OpenClaw သည် Matrix user အဖြစ် ချိတ်ဆက်သည်။ on any homeserver, so you need a Matrix account for the bot. Once it is logged in, you can DM the bot directly or invite it to rooms (Matrix "groups"). Beeper is a valid client option too, but it requires E2EE to be enabled.

အခြေအနေ - plugin (@vector-im/matrix-bot-sdk) မှတစ်ဆင့် ပံ့ပိုးထားသည်။ တိုက်ရိုက်စာများ၊ အခန်းများ၊ threads များ၊ မီဒီယာ၊ reactions များ၊ polls (send + poll-start as text), location, and E2EE (with crypto support).

Plugin လိုအပ်ချက်

Matrix သည် plugin အဖြစ် ထည့်သွင်းထားပြီး core install တွင် မပါဝင်ပါ။

CLI (npm registry) ဖြင့် ထည့်သွင်းရန်:

openclaw plugins install @openclaw/matrix

Local checkout (git repo မှ chạy သောအခါ):

openclaw plugins install ./extensions/matrix

configure/onboarding အတွင်း Matrix ကို ရွေးချယ်ပြီး git checkout ကို တွေ့ရှိပါက, OpenClaw သည် local install လမ်းကြောင်းကို အလိုအလျောက် အကြံပြုပါမည်။

အသေးစိတ်: Plugins

တပ်ဆင်ခြင်း

  1. Matrix plugin ကို ထည့်သွင်းပါ: - npm မှ: openclaw plugins install @openclaw/matrix - local checkout မှ: openclaw plugins install ./extensions/matrix

  2. homeserver တစ်ခုတွင် Matrix အကောင့် ဖန်တီးပါ: - hosting ရွေးချယ်စရာများကို https://matrix.org/ecosystem/hosting/ တွင် ကြည့်ရှုပါ - သို့မဟုတ် ကိုယ်တိုင် host ပြုလုပ်ပါ။

  3. bot အကောင့်အတွက် access token ရယူပါ:

  • သင့် homeserver တွင် curl ကို အသုံးပြုပြီး Matrix login API ကို သုံးပါ:

bash curl --request POST \ --url https://matrix.example.org/_matrix/client/v3/login \ --header 'Content-Type: application/json' \ --data '{ "type": "m.login.password", "identifier": { "type": "m.id.user", "user": "your-user-name" }, "password": "your-password" }'

  • matrix.example.org ကို သင့် homeserver URL ဖြင့် အစားထိုးပါ။
  • သို့မဟုတ် channels.matrix.userId + channels.matrix.password ကို သတ်မှတ်ပါ: OpenClaw သည် အတူတူသော login endpoint ကို ခေါ်ပြီး access token ကို ~/.openclaw/credentials/matrix/credentials.json တွင် သိမ်းဆည်းကာ နောက်တစ်ကြိမ် စတင်ချိန်တွင် ပြန်လည် အသုံးပြုပါသည်။
  1. credentials ကို ဖွဲ့စည်းပြင်ဆင်ပါ: - Env: MATRIX_HOMESERVER, MATRIX_ACCESS_TOKEN (သို့မဟုတ် MATRIX_USER_ID + MATRIX_PASSWORD) - သို့မဟုတ် config: channels.matrix.* - နှစ်ခုလုံး သတ်မှတ်ထားပါက config ကို ဦးစားပေးပါသည်။ - access token ဖြင့် အသုံးပြုသောအခါ user ID ကို /whoami မှတစ်ဆင့် အလိုအလျောက် ရယူပါသည်။ - channels.matrix.userId ကို သတ်မှတ်ပါက Matrix ID အပြည့်အစုံ ဖြစ်ရပါမည် (ဥပမာ: @bot:example.org)။

  2. Gateway ကို ပြန်လည်စတင်ပါ (သို့မဟုတ် onboarding ကို ပြီးဆုံးစေပါ)။

  3. မည်သည့် Matrix client မဆိုမှ bot နှင့် DM စတင်ပါ သို့မဟုတ် ၎င်းကို အခန်းတစ်ခုသို့ ဖိတ်ခေါ်ပါ။ (Element, Beeper, etc.; see https://matrix.org/ecosystem/clients/). Beeper requires E2EE, so set channels.matrix.encryption: true and verify the device.

အနည်းဆုံး config (access token, user ID ကို အလိုအလျောက် ရယူ):

{
  channels: {
    matrix: {
      enabled: true,
      homeserver: "https://matrix.example.org",
      accessToken: "syt_***",
      dm: { policy: "pairing" },
    },
  },
}

E2EE config (end to end encryption ကို ဖွင့်ထားခြင်း):

{
  channels: {
    matrix: {
      enabled: true,
      homeserver: "https://matrix.example.org",
      accessToken: "syt_***",
      encryption: true,
      dm: { policy: "pairing" },
    },
  },
}

လျှို့ဝှက်ရေး (E2EE)

End-to-end encryption ကို Rust crypto SDK ဖြင့် ပံ့ပိုးထားပါသည်

channels.matrix.encryption: true ဖြင့် ဖွင့်ပါ:

  • crypto module ကို load လုပ်နိုင်ပါက encrypted rooms များကို အလိုအလျောက် decrypt လုပ်ပါသည်။
  • encrypted rooms သို့ ပို့သော outbound media ကို encryption လုပ်ပါသည်။
  • ပထမဆုံး ချိတ်ဆက်ချိန်တွင် OpenClaw သည် သင့်အခြား session များမှ device verification ကို တောင်းခံပါသည်။
  • key မျှဝေမှုကို ဖွင့်ရန် အခြား Matrix client (Element စသည်) တွင် device ကို အတည်ပြုပါ။
  • crypto module ကို load မလုပ်နိုင်ပါက E2EE ကို ပိတ်ထားပြီး encrypted rooms များကို decrypt မလုပ်နိုင်ပါ; OpenClaw သည် သတိပေးချက်ကို log ထဲတွင် ရေးသားပါသည်။
  • crypto module မရှိကြောင်း error များကို တွေ့ရပါက (ဥပမာ @matrix-org/matrix-sdk-crypto-nodejs-*), @matrix-org/matrix-sdk-crypto-nodejs အတွက် build scripts ကို ခွင့်ပြုပြီး pnpm rebuild @matrix-org/matrix-sdk-crypto-nodejs ကို chạy ပါ သို့မဟုတ် node node_modules/@matrix-org/matrix-sdk-crypto-nodejs/download-lib.js ဖြင့် binary ကို ရယူပါ။

Crypto state ကို account + access token တစ်ခုချင်းစီအလိုက် တွင် သိမ်းဆည်းထားသည် ~/.openclaw/matrix/accounts/<account>/<homeserver>__<user>/<token-hash>/crypto/ (SQLite database). Sync state lives alongside it in bot-storage.json. If the access token (device) changes, a new store is created and the bot must be re-verified for encrypted rooms.

Device verification: When E2EE is enabled, the bot will request verification from your other sessions on startup. Open Element (or another client) and approve the verification request to establish trust. Once verified, the bot can decrypt messages in encrypted rooms.

Routing model

  • ပြန်ကြားချက်များသည် အမြဲတမ်း Matrix သို့ ပြန်ပို့ပါသည်။
  • DMs များသည် agent ၏ အဓိက session ကို မျှဝေသုံးစွဲပြီး rooms များကို group sessions အဖြစ် ချိတ်ဆက်ပါသည်။

Access control (DMs)

  • မူလ: channels.matrix.dm.policy = "pairing"။ Unknown senders get a pairing code.
  • အတည်ပြုရန်:
  • openclaw pairing list matrix
  • openclaw pairing approve matrix <CODE>
  • အများပြည်သူ DMs: channels.matrix.dm.policy="open" နှင့် channels.matrix.dm.allowFrom=["*"]
  • channels.matrix.dm.allowFrom accepts full Matrix user IDs (example: @user:server). The wizard resolves display names to user IDs when directory search finds a single exact match.

Rooms (groups)

  • Default: channels.matrix.groupPolicy = "allowlist" (mention ဖြင့်သာ ဝင်ရောက်နိုင်ခြင်း)။ Use channels.defaults.groupPolicy to override the default when unset.
  • channels.matrix.groups ဖြင့် rooms များကို allowlist ပြုလုပ်ပါ (room IDs သို့မဟုတ် aliases; directory search တွင် တစ်ခုတည်းသော တိကျကိုက်ညီမှုကို တွေ့ရှိပါက name များကို ID များအဖြစ် ဖြေရှင်းပါသည်):
{
  channels: {
    matrix: {
      groupPolicy: "allowlist",
      groups: {
        "!roomId:example.org": { allow: true },
        "#alias:example.org": { allow: true },
      },
      groupAllowFrom: ["@owner:example.org"],
    },
  },
}
  • requireMention: false သည် ထိုအခန်းတွင် auto-reply ကို ဖွင့်ပါသည်။
  • groups."*" သည် rooms များအတွင်း mention gating အတွက် မူလတန်ဖိုးများကို သတ်မှတ်နိုင်ပါသည်။
  • groupAllowFrom သည် rooms များတွင် bot ကို trigger လုပ်နိုင်သော ပို့သူများကို ကန့်သတ်ပါသည် (Matrix user ID အပြည့်အစုံ)။
  • အခန်းတစ်ခန်းချင်းစီအလိုက် users allowlists များဖြင့် အခန်းအတွင်း ပို့သူများကို ထပ်မံ ကန့်သတ်နိုင်ပါသည် (Matrix user ID အပြည့်အစုံကို အသုံးပြုပါ)။
  • configure wizard သည် room allowlists (room IDs, aliases သို့မဟုတ် names) ကို မေးမြန်းပြီး တိကျပြီး ထူးခြားသော ကိုက်ညီမှုရှိမှသာ names များကို ဖြေရှင်းပါသည်။
  • စတင်ချိန်တွင် OpenClaw သည် allowlists အတွင်းရှိ room/user names များကို IDs များအဖြစ် ဖြေရှင်းပြီး mapping ကို log ထဲတွင် ရေးသားပါသည်; မဖြေရှင်းနိုင်သော entries များကို allowlist matching အတွက် လျစ်လျူရှုပါသည်။
  • ဖိတ်ခေါ်ချက်များကို မူလအနေဖြင့် အလိုအလျောက် join လုပ်ပါသည်; channels.matrix.autoJoin နှင့် channels.matrix.autoJoinAllowlist ဖြင့် ထိန်းချုပ်နိုင်ပါသည်။
  • အခန်း မရှိစေရန်, channels.matrix.groupPolicy: "disabled" ကို သတ်မှတ်ပါ (သို့မဟုတ် allowlist ကို အလွတ်ထားပါ)။
  • Legacy key: channels.matrix.rooms (groups နှင့် ပုံစံတူ)။

Threads

  • Reply threading ကို ပံ့ပိုးထားပါသည်။
  • channels.matrix.threadReplies သည် ပြန်ကြားချက်များကို thread အတွင်း ဆက်လက်ထားမည်မဟုတ်မည်ကို ထိန်းချုပ်ပါသည်:
  • off, inbound (မူလ), always
  • channels.matrix.replyToMode သည် thread မဟုတ်သောအခါ reply-to metadata ကို ထိန်းချုပ်ပါသည်:
  • off (မူလ), first, all

Capabilities

Feature Status
Direct messages ✅ ပံ့ပိုးထားသည်
Rooms ✅ ပံ့ပိုးထားသည်
Threads ✅ ပံ့ပိုးထားသည်
Media ✅ ပံ့ပိုးထားသည်
E2EE ✅ ပံ့ပိုးထားသည် (crypto module လိုအပ်)
Reactions ✅ ပံ့ပိုးထားသည် (tools မှတစ်ဆင့် ပို့/ဖတ်)
Polls ✅ ပို့ခြင်း ပံ့ပိုးထားသည်; ဝင်လာသော poll start များကို စာသားအဖြစ် ပြောင်းလဲသည် (responses/ends ကို လျစ်လျူရှု)
Location ✅ ပံ့ပိုးထားသည် (geo URI; altitude ကို လျစ်လျူရှု)
Native commands ✅ ပံ့ပိုးထားသည်

Troubleshooting

အရင်ဆုံး အောက်ပါ ladder ကို chạy ပါ:

openclaw status
openclaw gateway status
openclaw logs --follow
openclaw doctor
openclaw channels status --probe

လိုအပ်ပါက DM pairing အခြေအနေကို အတည်ပြုပါ:

openclaw pairing list matrix

တွေ့ရလေ့ရှိသော အမှားများ:

  • Logged in ဖြစ်သော်လည်း room မက်ဆေ့ချ်များကို လျစ်လျူရှုခြင်း: room ကို groupPolicy သို့မဟုတ် room allowlist မှ ပိတ်ထားခြင်း။
  • DMs ကို လျစ်လျူရှုခြင်း: channels.matrix.dm.policy="pairing" ဖြစ်နေချိန်တွင် ပို့သူသည် အတည်ပြုရန် စောင့်ဆိုင်းနေခြင်း။
  • Encrypted rooms မအောင်မြင်ခြင်း: crypto ပံ့ပိုးမှု သို့မဟုတ် encryption ဆက်တင် မကိုက်ညီခြင်း။

triage လမ်းကြောင်းအတွက်: /channels/troubleshooting

Configuration reference (Matrix)

Configuration အပြည့်အစုံ: Configuration

Provider ရွေးချယ်စရာများ:

  • channels.matrix.enabled: channel စတင်ခြင်းကို ဖွင့်/ပိတ်။
  • channels.matrix.homeserver: homeserver URL။
  • channels.matrix.userId: Matrix user ID (access token ရှိပါက မလိုအပ်)။
  • channels.matrix.accessToken: access token။
  • channels.matrix.password: login အတွက် စကားဝှက် (token ကို သိမ်းဆည်းထားသည်)။
  • channels.matrix.deviceName: device display name။
  • channels.matrix.encryption: E2EE ကို ဖွင့် (မူလ: false)။
  • channels.matrix.initialSyncLimit: initial sync limit။
  • channels.matrix.threadReplies: off | inbound | always (မူလ: inbound)။
  • channels.matrix.textChunkLimit: outbound စာသား chunk အရွယ်အစား (chars)။
  • channels.matrix.chunkMode: length (မူလ) သို့မဟုတ် newline ကို အသုံးပြုပြီး အလွတ်လိုင်းများ (paragraph boundaries) အပေါ် မူတည်၍ ခွဲထုတ်ပြီးနောက် အရှည်အလိုက် chunk ပြုလုပ်ခြင်း။
  • channels.matrix.dm.policy: pairing | allowlist | open | disabled (မူလ: pairing)။
  • channels.matrix.dm.allowFrom: DM allowlist (full Matrix user IDs). open requires "*". The wizard resolves names to IDs when possible.
  • channels.matrix.groupPolicy: allowlist | open | disabled (မူလ: allowlist)။
  • channels.matrix.groupAllowFrom: group မက်ဆေ့ချ်များအတွက် allowlisted ပို့သူများ (Matrix user ID အပြည့်အစုံ)။
  • channels.matrix.allowlistOnly: DMs + rooms အတွက် allowlist စည်းမျဉ်းများကို အတင်းအကျပ် အသုံးပြုစေခြင်း။
  • channels.matrix.groups: group allowlist + per-room settings map။
  • channels.matrix.rooms: legacy group allowlist/config။
  • channels.matrix.replyToMode: threads/tags အတွက် reply-to mode။
  • channels.matrix.mediaMaxMb: inbound/outbound media ကန့်သတ်ချက် (MB)။
  • channels.matrix.autoJoin: invite ကို ကိုင်တွယ်ပုံ (always | allowlist | off, မူလ: always)။
  • channels.matrix.autoJoinAllowlist: auto-join အတွက် ခွင့်ပြုထားသော room IDs/aliases။
  • channels.matrix.actions: action တစ်ခုချင်းစီအလိုက် tool gating (reactions/messages/pins/memberInfo/channelInfo)။