Zalo (Bot API)
상태: 실험적입니다. 다이렉트 메시지만 지원하며, 그룹은 Zalo 문서에 따라 곧 제공될 예정입니다.플러그인 필요
Zalo 는 플러그인으로 제공되며 코어 설치에 번들되어 있지 않습니다.- CLI 로 설치:
openclaw plugins install @openclaw/zalo - 또는 온보딩 중 Zalo 를 선택하고 설치 프롬프트를 확인합니다.
- 자세한 내용: Plugins
빠른 설정 (초보자용)
- Zalo 플러그인을 설치합니다:
- 소스 체크아웃에서:
openclaw plugins install ./extensions/zalo - npm 에서 (게시된 경우):
openclaw plugins install @openclaw/zalo - 또는 온보딩에서 Zalo 를 선택하고 설치 프롬프트를 확인합니다.
- 소스 체크아웃에서:
- 토큰을 설정합니다:
- Env:
ZALO_BOT_TOKEN=... - 또는 구성:
channels.zalo.botToken: "...".
- Env:
- Gateway(게이트웨이) 를 재시작합니다(또는 온보딩을 완료합니다).
- DM 접근은 기본적으로 페어링입니다. 최초 접촉 시 페어링 코드를 승인합니다.
What it is
Zalo 는 베트남 중심의 메시징 앱입니다. Bot API 를 통해 Gateway(게이트웨이) 가 1:1 대화를 위한 봇을 실행할 수 있습니다. 결정론적 라우팅으로 Zalo 로의 응답이 보장되어야 하는 지원 또는 알림에 적합합니다.- Gateway(게이트웨이) 가 소유한 Zalo Bot API 채널입니다.
- 결정론적 라우팅: 응답은 Zalo 로 되돌아가며, 모델은 채널을 선택하지 않습니다.
- DM 은 에이전트의 메인 세션을 공유합니다.
- 그룹은 아직 지원되지 않습니다(Zalo 문서에 “곧 제공”으로 명시됨).
설정 (빠른 경로)
1. 봇 토큰 생성 (Zalo Bot Platform)
- https://bot.zaloplatforms.com 로 이동하여 로그인합니다.
- 새 봇을 생성하고 설정을 구성합니다.
- 봇 토큰을 복사합니다(형식:
12345689:abc-xyz).
2) 토큰 구성 (환경 변수 또는 구성)
예시:ZALO_BOT_TOKEN=... (기본 계정에만 동작).
다중 계정 지원: 계정별 토큰과 선택적 name 을 사용하여 channels.zalo.accounts 를 사용합니다.
- Gateway(게이트웨이) 를 재시작합니다. 토큰이 해결되면(환경 변수 또는 구성) Zalo 가 시작됩니다.
- DM 접근은 기본적으로 페어링입니다. 봇이 처음 연락을 받을 때 코드를 승인합니다.
작동 방식 (동작)
- 수신 메시지는 미디어 플레이스홀더와 함께 공유 채널 엔벨로프로 정규화됩니다.
- 응답은 항상 동일한 Zalo 채팅으로 라우팅됩니다.
- 기본값은 롱 폴링입니다.
channels.zalo.webhookUrl로 웹훅 모드를 사용할 수 있습니다.
제한 사항
- 발신 텍스트는 2000 자로 분할됩니다(Zalo API 제한).
- 미디어 다운로드/업로드는
channels.zalo.mediaMaxMb로 제한됩니다(기본값 5). - 2000 자 제한으로 스트리밍의 효용이 낮아 기본적으로 스트리밍은 차단됩니다.
접근 제어 (DMs)
DM access
- 기본값:
channels.zalo.dmPolicy = "pairing". 알 수 없는 발신자는 페어링 코드를 받으며, 승인될 때까지 메시지는 무시됩니다(코드는 1 시간 후 만료). - 승인 방법:
openclaw pairing list zaloopenclaw pairing approve zalo <CODE>
- 페어링은 기본 토큰 교환 방식입니다. 자세한 내용: Pairing
channels.zalo.allowFrom는 숫자 사용자 ID 를 허용합니다(사용자명 조회는 제공되지 않음).
Long-polling vs webhook
- 기본값: 롱 폴링(공개 URL 불필요).
- 웹훅 모드:
channels.zalo.webhookUrl및channels.zalo.webhookSecret을 설정합니다.- 웹훅 시크릿은 8-256 자여야 합니다.
- 웹훅 URL 은 HTTPS 를 사용해야 합니다.
- Zalo 는 검증을 위해
X-Bot-Api-Secret-Token헤더와 함께 이벤트를 전송합니다. - Gateway(게이트웨이) HTTP 는
channels.zalo.webhookPath에서 웹훅 요청을 처리합니다(기본값은 웹훅 URL 경로).
Supported message types
- 텍스트 메시지: 2000 자 분할로 완전 지원.
- 이미지 메시지: 수신 이미지 다운로드 및 처리,
sendPhoto를 통해 이미지 전송. - 스티커: 기록되지만 완전히 처리되지는 않습니다(에이전트 응답 없음).
- 미지원 유형: 기록됨(예: 보호된 사용자로부터의 메시지).
Capabilities
| 기능 | 상태 |
|---|---|
| 다이렉트 메시지 | ✅ 지원됨 |
| 그룹 | ❌ 곧 제공 (Zalo 문서 기준) |
| 미디어 (이미지) | ✅ 지원됨 |
| 반응 | ❌ 미지원 |
| 스레드 | ❌ 미지원 |
| 투표 | ❌ 미지원 |
| 네이티브 명령 | ❌ 미지원 |
| 스트리밍 | ⚠️ 차단됨 (2000 자 제한) |
Delivery targets (CLI/cron)
- 대상에 채팅 ID 를 사용합니다.
- 예시:
openclaw message send --channel zalo --target 123456789 --message "hi".
Troubleshooting
봇이 응답하지 않음:- 토큰이 유효한지 확인합니다:
openclaw channels status --probe - 발신자가 승인되었는지 확인합니다(페어링 또는 allowFrom)
- Gateway(게이트웨이) 로그를 확인합니다:
openclaw logs --follow
- 웹훅 URL 이 HTTPS 인지 확인합니다.
- 시크릿 토큰이 8-256 자인지 확인합니다.
- 구성된 경로에서 Gateway(게이트웨이) HTTP 엔드포인트에 접근 가능한지 확인합니다.
- getUpdates 폴링이 실행 중이 아닌지 확인합니다(상호 배타적).
Configuration reference (Zalo)
전체 구성: Configuration 프로바이더 옵션:channels.zalo.enabled: 채널 시작 활성화/비활성화.channels.zalo.botToken: Zalo Bot Platform 의 봇 토큰.channels.zalo.tokenFile: 파일 경로에서 토큰 읽기.channels.zalo.dmPolicy:pairing | allowlist | open | disabled(기본값: 페어링).channels.zalo.allowFrom: DM 허용 목록(사용자 ID).open는"*"가 필요합니다. 마법사는 숫자 ID 를 요청합니다.channels.zalo.mediaMaxMb: 수신/발신 미디어 한도(MB, 기본값 5).channels.zalo.webhookUrl: 웹훅 모드 활성화(HTTPS 필요).channels.zalo.webhookSecret: 웹훅 시크릿(8-256 자).channels.zalo.webhookPath: Gateway(게이트웨이) HTTP 서버의 웹훅 경로.channels.zalo.proxy: API 요청용 프록시 URL.
channels.zalo.accounts.<id>.botToken: 계정별 토큰.channels.zalo.accounts.<id>.tokenFile: 계정별 토큰 파일.channels.zalo.accounts.<id>.name: 표시 이름.channels.zalo.accounts.<id>.enabled: 계정 활성화/비활성화.channels.zalo.accounts.<id>.dmPolicy: 계정별 DM 정책.channels.zalo.accounts.<id>.allowFrom: 계정별 허용 목록.channels.zalo.accounts.<id>.webhookUrl: 계정별 웹훅 URL.channels.zalo.accounts.<id>.webhookSecret: 계정별 웹훅 시크릿.channels.zalo.accounts.<id>.webhookPath: 계정별 웹훅 경로.channels.zalo.accounts.<id>.proxy: 계정별 프록시 URL.