Regional platforms
บอต QQ
QQ Bot เชื่อมต่อกับ OpenClaw ผ่าน QQ Bot API อย่างเป็นทางการ (Gateway แบบ WebSocket) Plugin รองรับแชตส่วนตัวแบบ C2C, @messages ในกลุ่ม และข้อความในช่องกิลด์ พร้อม สื่อสมบูรณ์ (รูปภาพ, เสียง, วิดีโอ, ไฟล์)
สถานะ: Plugin ที่ดาวน์โหลดได้ รองรับข้อความส่วนตัว, แชตกลุ่ม, ช่องกิลด์ และ สื่อ ไม่รองรับปฏิกิริยาและเธรด
ติดตั้ง
ติดตั้ง QQ Bot ก่อนตั้งค่า:
openclaw plugins install @openclaw/qqbot
ตั้งค่า
- ไปที่ QQ Open Platform แล้วสแกนรหัส QR ด้วย QQ บนโทรศัพท์ของคุณเพื่อลงทะเบียน / เข้าสู่ระบบ
- คลิก Create Bot เพื่อสร้างบอต QQ ใหม่
- หา AppID และ AppSecret ในหน้าการตั้งค่าของบอต แล้วคัดลอกไว้
AppSecret จะไม่ถูกจัดเก็บเป็นข้อความธรรมดา หากคุณออกจากหน้าโดยไม่บันทึก คุณจะต้องสร้างใหม่อีกครั้ง
- เพิ่มช่องทาง:
openclaw channels add --channel qqbot --token "AppID:AppSecret"
- รีสตาร์ต Gateway
เส้นทางตั้งค่าแบบโต้ตอบ:
openclaw channels add
openclaw configure --section channels
กำหนดค่า
ค่ากำหนดขั้นต่ำ:
{
channels: {
qqbot: {
enabled: true,
appId: "YOUR_APP_ID",
clientSecret: "YOUR_APP_SECRET",
},
},
}
ตัวแปรสภาพแวดล้อมสำหรับบัญชีเริ่มต้น:
QQBOT_APP_IDQQBOT_CLIENT_SECRET
AppSecret ที่อ้างอิงจากไฟล์:
{
channels: {
qqbot: {
enabled: true,
appId: "YOUR_APP_ID",
clientSecretFile: "/path/to/qqbot-secret.txt",
},
},
}
AppSecret แบบ Env SecretRef:
{
channels: {
qqbot: {
enabled: true,
appId: "YOUR_APP_ID",
clientSecret: { source: "env", provider: "default", id: "QQBOT_CLIENT_SECRET" },
},
},
}
หมายเหตุ:
- การสำรองด้วย env ใช้กับบัญชี QQ Bot เริ่มต้นเท่านั้น
openclaw channels add --channel qqbot --token-file ...ให้เฉพาะ AppSecret เท่านั้น; ต้องตั้งค่า AppID ไว้แล้วใน config หรือQQBOT_APP_IDclientSecretยังรับอินพุต SecretRef ได้ ไม่ใช่แค่สตริงข้อความธรรมดา- สตริงเครื่องหมาย
secretref:/...แบบเดิมไม่ใช่ค่าclientSecretที่ใช้ได้; ให้ใช้ออบเจ็กต์ SecretRef แบบมีโครงสร้างเหมือนตัวอย่างด้านบน
การตั้งค่าหลายบัญชี
รันบอต QQ หลายตัวภายใต้อินสแตนซ์ OpenClaw เดียว:
{
channels: {
qqbot: {
enabled: true,
appId: "111111111",
clientSecret: "secret-of-bot-1",
accounts: {
bot2: {
enabled: true,
appId: "222222222",
clientSecret: "secret-of-bot-2",
},
},
},
},
}
แต่ละบัญชีจะเปิดการเชื่อมต่อ WebSocket ของตัวเอง และดูแลแคช
โทเค็นแยกต่างหาก (แยกด้วย appId)
เพิ่มบอตตัวที่สองผ่าน CLI:
openclaw channels add --channel qqbot --account bot2 --token "222222222:secret-of-bot-2"
แชตกลุ่ม
การรองรับแชตกลุ่มของ QQ Bot ใช้ OpenID ของกลุ่ม QQ ไม่ใช่ชื่อที่แสดง เพิ่มบอต เข้ากลุ่ม จากนั้นกล่าวถึงบอต หรือกำหนดค่ากลุ่มให้ทำงานโดยไม่ต้องกล่าวถึง
{
channels: {
qqbot: {
groupPolicy: "allowlist",
groupAllowFrom: ["member_openid"],
groups: {
"*": {
requireMention: true,
historyLimit: 50,
toolPolicy: "restricted",
},
GROUP_OPENID: {
name: "Release room",
requireMention: false,
ignoreOtherMentions: true,
historyLimit: 20,
prompt: "Keep replies short and operational.",
},
},
},
},
}
groups["*"] ตั้งค่าเริ่มต้นสำหรับทุกกลุ่ม และรายการ
groups.GROUP_OPENID แบบเจาะจงจะแทนที่ค่าเริ่มต้นเหล่านั้นสำหรับหนึ่งกลุ่ม การตั้งค่า
กลุ่มประกอบด้วย:
requireMention: กำหนดให้ต้องมี @mention ก่อนที่บอตจะตอบ ค่าเริ่มต้น:trueignoreOtherMentions: ทิ้งข้อความที่กล่าวถึงคนอื่นแต่ไม่ได้กล่าวถึงบอตhistoryLimit: เก็บข้อความกลุ่มล่าสุดที่ไม่ได้กล่าวถึงไว้เป็นบริบทสำหรับรอบถัดไปที่มีการกล่าวถึง ตั้งค่า0เพื่อปิดใช้toolPolicy:full,restrictedหรือnoneสำหรับเครื่องมือในขอบเขตกลุ่มname: ป้ายชื่อที่อ่านง่าย ใช้ในบันทึกและบริบทกลุ่มprompt: พรอมป์พฤติกรรมรายกลุ่มที่ต่อท้ายในบริบทของเอเจนต์
โหมดการเปิดใช้งานคือ mention และ always โดย requireMention: true แมปไปที่
mention; requireMention: false แมปไปที่ always หากมีการแทนที่การเปิดใช้งาน
ระดับเซสชัน การตั้งค่านั้นจะมีผลเหนือ config
คิวขาเข้าเป็นแบบต่อเพียร์ เพียร์กลุ่มจะได้ขนาดคิวสูงกว่า รักษาข้อความของมนุษย์ ให้อยู่ก่อนข้อความพูดคุยที่เขียนโดยบอตเมื่อคิวเต็ม และรวมข้อความกลุ่มปกติ ที่เข้ามาเป็นชุดให้เป็นหนึ่งรอบพร้อมการระบุผู้ส่ง คำสั่งสแลชยังคงรันทีละคำสั่ง
เสียง (STT / TTS)
STT และ TTS รองรับการกำหนดค่าสองระดับพร้อมการสำรองตามลำดับความสำคัญ:
| การตั้งค่า | เฉพาะ Plugin | ค่าสำรองของเฟรมเวิร์ก |
|---|---|---|
| STT | channels.qqbot.stt |
tools.media.audio.models[0] |
| TTS | channels.qqbot.tts, channels.qqbot.accounts.<id>.tts |
messages.tts |
{
channels: {
qqbot: {
stt: {
provider: "your-provider",
model: "your-stt-model",
},
tts: {
provider: "your-provider",
model: "your-tts-model",
voice: "your-voice",
},
accounts: {
"qq-main": {
tts: {
providers: {
openai: { voice: "shimmer" },
},
},
},
},
},
},
}
ตั้งค่า enabled: false ที่รายการใดรายการหนึ่งเพื่อปิดใช้
การแทนที่ TTS ระดับบัญชีใช้รูปทรงเดียวกับ messages.tts และทำ deep-merge
ทับ config TTS ระดับช่องทาง/ทั่วโลก
ไฟล์แนบเสียงขาเข้าของ QQ จะถูกเปิดเผยต่อเอเจนต์เป็นเมตาดาทาสื่อเสียง ในขณะที่
กันไฟล์เสียงดิบออกจาก MediaPaths ทั่วไป การตอบกลับข้อความธรรมดา [[audio_as_voice]]
จะสังเคราะห์ TTS และส่งข้อความเสียง QQ แบบเนทีฟเมื่อกำหนดค่า TTS ไว้
สามารถปรับพฤติกรรมการอัปโหลด/แปลงรหัสเสียงขาออกได้ด้วย
channels.qqbot.audioFormatPolicy:
sttDirectFormatsuploadDirectFormatstranscodeEnabled
รูปแบบเป้าหมาย
| รูปแบบ | คำอธิบาย |
|---|---|
qqbot:c2c:OPENID |
แชตส่วนตัว (C2C) |
qqbot:group:GROUP_OPENID |
แชตกลุ่ม |
qqbot:channel:CHANNEL_ID |
ช่องกิลด์ |
แต่ละบอตมีชุด OpenID ของผู้ใช้เป็นของตัวเอง OpenID ที่ได้รับโดย Bot A ไม่สามารถ ใช้ส่งข้อความผ่าน Bot B ได้
คำสั่งสแลช
คำสั่งในตัวที่ถูกดักก่อนคิว AI:
| คำสั่ง | คำอธิบาย |
|---|---|
/bot-ping |
ทดสอบเวลาแฝง |
/bot-version |
แสดงเวอร์ชันเฟรมเวิร์ก OpenClaw |
/bot-help |
แสดงรายการคำสั่งทั้งหมด |
/bot-me |
แสดง ID ผู้ใช้ QQ ของผู้ส่ง (openid) สำหรับตั้งค่า allowFrom/groupAllowFrom |
/bot-upgrade |
แสดงลิงก์คู่มืออัปเกรด QQBot |
/bot-logs |
ส่งออกบันทึก Gateway ล่าสุดเป็นไฟล์ |
/bot-approve |
อนุมัติการดำเนินการ QQ Bot ที่รอดำเนินการ (เช่น การยืนยันการอัปโหลด C2C หรือกลุ่ม) ผ่านโฟลว์เนทีฟ |
ต่อท้าย ? กับคำสั่งใดก็ได้เพื่อดูวิธีใช้ (เช่น /bot-upgrade ?)
คำสั่งผู้ดูแล (/bot-me, /bot-upgrade, /bot-logs, /bot-clear-storage, /bot-streaming, /bot-approve) ใช้ได้เฉพาะข้อความส่วนตัว และต้องมี openid ของผู้ส่งในรายการ allowFrom แบบไม่ใช้ไวลด์การ์ดที่ระบุไว้อย่างชัดเจน ไวลด์การ์ด allowFrom: ["*"] อนุญาตให้แชตได้ แต่ไม่ได้ให้สิทธิ์เข้าถึงคำสั่งผู้ดูแล ข้อความกลุ่มจะเทียบกับ groupAllowFrom ก่อน แล้วจึงย้อนกลับไปใช้ allowFrom การรันคำสั่งผู้ดูแลในกลุ่มจะส่งคำแนะนำกลับแทนที่จะทิ้งเงียบๆ
สถาปัตยกรรมเอนจิน
QQ Bot มาพร้อมเอนจินที่สมบูรณ์ในตัวภายใน Plugin:
- แต่ละบัญชีเป็นเจ้าของสแต็กทรัพยากรที่แยกกัน (การเชื่อมต่อ WebSocket, ไคลเอนต์ API, แคชโทเค็น, รากที่เก็บสื่อ) โดยใช้
appIdเป็นคีย์ บัญชีจะไม่แชร์สถานะขาเข้า/ขาออกกัน - ตัวบันทึกหลายบัญชีจะแท็กบรรทัดบันทึกด้วยบัญชีที่เป็นเจ้าของ เพื่อให้การวินิจฉัยแยกจากกันได้เมื่อคุณรันบอตหลายตัวภายใต้ Gateway เดียว
- เส้นทางขาเข้า, ขาออก และบริดจ์ Gateway ใช้รากเพย์โหลดสื่อเดียวกันภายใต้
~/.openclaw/mediaดังนั้นการอัปโหลด, ดาวน์โหลด และแคชการแปลงรหัสจะอยู่ภายใต้ไดเรกทอรีที่มีการป้องกันเดียว แทนที่จะเป็นโครงสร้างแยกตามระบบย่อย - การส่งสื่อสมบูรณ์ผ่านเส้นทาง
sendMediaเดียวสำหรับเป้าหมาย C2C และกลุ่ม ไฟล์ในเครื่องและบัฟเฟอร์ที่ใหญ่กว่าเกณฑ์ไฟล์ขนาดใหญ่จะใช้ endpoint อัปโหลดแบบแบ่งชิ้นของ QQ ขณะที่เพย์โหลดขนาดเล็กใช้ API สื่อแบบครั้งเดียว - สามารถสำรองและกู้คืนข้อมูลประจำตัวเป็นส่วนหนึ่งของสแนปช็อตข้อมูลประจำตัวมาตรฐานของ OpenClaw ได้ เอนจินจะแนบสแต็กทรัพยากรของแต่ละบัญชีกลับเข้าไปเมื่อกู้คืน โดยไม่ต้องจับคู่รหัส QR ใหม่
การเริ่มต้นใช้งานด้วยรหัส QR
นอกเหนือจากการวาง AppID:AppSecret ด้วยตนเอง เอนจินยังรองรับโฟลว์เริ่มต้นใช้งานด้วยรหัส QR สำหรับเชื่อมโยง QQ Bot กับ OpenClaw:
- รันเส้นทางตั้งค่า QQ Bot (เช่น
openclaw channels add --channel qqbot) แล้วเลือกโฟลว์รหัส QR เมื่อระบบถาม - สแกนรหัส QR ที่สร้างขึ้นด้วยแอปบนโทรศัพท์ที่ผูกกับ QQ Bot เป้าหมาย
- อนุมัติการจับคู่บนโทรศัพท์ OpenClaw จะคงข้อมูลประจำตัวที่ส่งกลับไว้ใน
credentials/ภายใต้ขอบเขตบัญชีที่ถูกต้อง
พรอมป์อนุมัติที่บอตสร้างขึ้นเอง (เช่น โฟลว์ "อนุญาตการดำเนินการนี้หรือไม่?" ที่เปิดเผยโดย QQ Bot API) จะแสดงเป็นพรอมป์ OpenClaw แบบเนทีฟ ซึ่งคุณสามารถยอมรับด้วย /bot-approve แทนการตอบผ่านไคลเอนต์ QQ ดิบ
การแก้ไขปัญหา
- บอตตอบว่า "gone to Mars": ยังไม่ได้กำหนดค่าข้อมูลประจำตัว หรือยังไม่ได้เริ่ม Gateway
- ไม่มีข้อความขาเข้า: ตรวจสอบว่า
appIdและclientSecretถูกต้อง และ เปิดใช้บอตบน QQ Open Platform แล้ว - ตอบตัวเองซ้ำ: OpenClaw บันทึกดัชนีอ้างอิงขาออกของ QQ เป็น
ข้อความที่เขียนโดยบอต และละเว้นเหตุการณ์ขาเข้าที่
msgIdxปัจจุบันตรงกับ บัญชีบอตเดียวกัน วิธีนี้ป้องกันลูป echo ของแพลตฟอร์ม ขณะยังอนุญาตให้ผู้ใช้ อ้างอิงหรือตอบกลับข้อความก่อนหน้าของบอตได้ - ตั้งค่าด้วย
--token-fileแล้วยังแสดงว่ายังไม่ได้กำหนดค่า:--token-fileตั้งค่าเฉพาะ AppSecret เท่านั้น คุณยังต้องมีappIdใน config หรือQQBOT_APP_ID - ข้อความเชิงรุกไม่มาถึง: QQ อาจดักข้อความที่บอตเป็นฝ่ายเริ่ม หาก ผู้ใช้ไม่ได้โต้ตอบเมื่อเร็วๆ นี้
- เสียงไม่ถูกถอดความ: ตรวจสอบว่ากำหนดค่า STT แล้ว และเข้าถึง provider ได้