Skip to content

kakao-bart-lee/openclaw-kakao-talkchannel-plugin

Repository files navigation

OpenClaw Kakao TalkChannel Plugin

카카오톡 채널을 OpenClaw에 연결하는 플러그인입니다.

English


설치

npm

npm install @openclaw/kakao-talkchannel
pnpm add @openclaw/kakao-talkchannel

OpenClaw CLI

OpenClaw에게 말하세요:

"카카오톡 플러그인 설치해줘"

그게 끝입니다. OpenClaw가 알아서 설치합니다.


사용자 가이드

카카오톡 연결

  1. OpenClaw에게 "카카오톡 연결해줘"
  2. OpenClaw가 페어링 코드 제공 (예: ABCD-1234)
  3. 카카오톡 채널 접속
  4. 채팅창에 /pair ABCD-1234 입력
  5. 연결 완료!

중요: 반드시 OpenClaw가 먼저 코드를 생성합니다.

문제 해결

문제 OpenClaw에게 요청
플러그인이 안 됨 "플러그인 진단해줘"
채널이 안 보임 "게이트웨이 재시작해줘"
페어링이 안 됨 "카카오톡 연결해줘" (처음부터 다시)
대화가 멈춤 / tool 에러 /reset 또는 /compact 실행

OpenClaw 세션 관리

대화가 길어지면 OpenClaw 코어의 컴팩션 과정에서 tool 관련 에러가 발생할 수 있습니다:

messages.60.content.1: unexpected tooluseid found in toolresult blocks

이는 OpenClaw 코어의 알려진 버그로, 고아 toolResult를 transcript hygiene이 감지하지 못한 케이스입니다.

예방 및 해결 방법:

방법 언제 사용 효과
/compact 대화가 복잡해지기 전 히스토리 압축으로 문제 예방
/reset 에러로 대화가 막혔을 때 세션 초기화로 즉시 해결

권장: 장시간 대화 시 주기적으로 /compact를 실행하세요.


OpenClaw 에이전트 가이드

이 섹션은 OpenClaw가 참조하는 자동화 지침입니다.

플러그인 설치 요청 시

사용자가 "카카오톡 플러그인 설치", "카톡 연동" 등을 요청하면:

# 1. 설치
openclaw plugins install @openclaw/kakao-talkchannel

# 2. 확인 (kakao-talkchannel이 loaded 상태인지)
openclaw plugins list

# 3. 게이트웨이 재시작
openclaw gateway restart

# 4. 채널 확인
openclaw channels list

카카오톡 연결 요청 시

사용자가 "카카오톡 연결", "카톡 연동" 등을 요청하면:

  1. 페어링 코드 생성
  2. 사용자에게 안내:

    "카카오톡 채널(http://pf.kakao.com/_scexbC)에서 /pair {코드}를 입력하세요"

  3. 페어링 완료 대기

로컬 플러그인 설치 요청 시

사용자가 경로를 지정하며 로컬 설치를 요청하면:

# 링크 모드 (개발용, 소스 수정 즉시 반영)
openclaw plugins install -l {경로}

# 복사 모드
openclaw plugins install {경로}

카드 메시지

에이전트가 JSON 형식으로 응답하면 카카오톡 카드로 자동 변환됩니다.

지원 카드 타입

타입 설명
textCard 텍스트 + 버튼
basicCard 이미지 + 텍스트 + 버튼
listCard 리스트 형태
commerceCard 상품 카드
simpleImage 이미지만
carousel 여러 카드 슬라이드

예시: textCard

{"textCard":{"title":"제목","description":"설명","buttons":[{"label":"버튼","action":"message","messageText":"클릭!"}]}}

예시: basicCard

{"basicCard":{"title":"제목","description":"설명","thumbnail":{"imageUrl":"https://example.com/image.jpg"},"buttons":[{"label":"자세히","action":"webLink","webLinkUrl":"https://example.com"}]}}

버튼 액션

action 설명 필수 필드
message 메시지 전송 messageText
webLink 웹 링크 webLinkUrl
phone 전화 걸기 phoneNumber
share 공유하기 -

quickReplies (빠른 응답)

{"textCard":{"title":"선택하세요"},"quickReplies":[{"label":"A","action":"message","messageText":"A"},{"label":"B","action":"message","messageText":"B"}]}

참고: 일반 텍스트는 그대로 전송됩니다. JSON 형식일 때만 카드로 변환됩니다.

주의: 카드를 보낼 때는 JSON만 단독으로 보내야 합니다. 텍스트와 섞으면 변환되지 않습니다.

자세한 내용은 CLAUDE.md를 참조하세요.


릴레이 서버

이 플러그인은 릴레이 서버를 통해 카카오톡 채널과 통신합니다. 두 가지 방식으로 사용할 수 있습니다.

방식 1: 기본 채널 사용 (권장)

설치 후 별도 설정 없이 바로 사용할 수 있습니다. 기본 릴레이 서버(k.tess.dev)와 공유 카카오톡 채널(Samantha)이 제공됩니다.

  • 설정 불필요, 설치 즉시 동작
  • 페어링 코드로 OpenClaw 인스턴스에 연결
  • 여러 사용자가 하나의 채널을 공유

방식 2: 별도 릴레이 서버 배포

자체 카카오톡 채널과 릴레이 서버를 운영하고 싶다면 직접 배포할 수 있습니다.

  1. kakao-talkchannel-relay-openclaw 저장소에서 릴레이 서버 배포
  2. 카카오 i 오픈빌더에서 챗봇 생성 및 스킬 연결 (릴레이 서버의 설정 가이드 참고)
  3. 릴레이 서버 Admin UI에서 Account 생성 후 relayToken 발급
  4. 플러그인 설정에서 relayUrlrelayToken 지정
{
  "channels": {
    "kakao-talkchannel": {
      "accounts": {
        "default": {
          "relayUrl": "https://your-relay-server.example.com",
          "relayToken": "발급받은_토큰"
        }
      }
    }
  }
}

자체 릴레이 서버를 사용하면:

  • 독립적인 카카오톡 채널 운영 가능
  • 채널 브랜딩 및 프로필 커스터마이징
  • 메시지 로그 및 Admin UI 직접 관리

설정 레퍼런스

대부분의 경우 설정이 필요 없습니다. 설치 후 바로 사용 가능합니다.

설정 파일 위치

~/.openclaw/openclaw.json 또는 config.yaml

사용자 설정

옵션 설명 기본값
enabled 채널 활성화 true
dmPolicy DM 정책 "pairing"
allowFrom 허용 사용자 목록 (allowlist 모드) -

dmPolicy 옵션

설명
pairing 페어링된 사용자만 (기본값, 권장)
allowlist allowFrom 목록의 사용자만
open 모든 사용자
disabled DM 비활성화

고급 설정 (대부분 불필요)

옵션 설명 기본값
channelId 채널 식별자 자동
relayUrl 릴레이 서버 URL (별도 배포 시 변경) https://k.tess.dev/
relayToken 릴레이 인증 토큰 (별도 서버 사용 시 필수) 환경변수 또는 자동

설정 예시

{
  "channels": {
    "kakao-talkchannel": {
      "accounts": {
        "default": {
          "enabled": true,
          "dmPolicy": "pairing"
        }
      }
    }
  }
}

라이선스

MIT

About

openclaw 와 kakao talk channel 을 연결하기 위한 플러그인.

Topics

Resources

Stars

Watchers

Forks

Packages

 
 
 

Contributors