메인 콘텐츠로 건너뛰기

Documentation Index

Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

Slack 앱 통합을 통해 DM과 채널에서 프로덕션 사용 준비가 되어 있습니다. 기본 모드는 Socket Mode이며, HTTP Request URLs도 지원됩니다.

Pairing

Slack DM은 기본적으로 페어링 모드를 사용합니다.

Slash commands

기본 명령 동작 및 명령 카탈로그입니다.

Channel troubleshooting

채널 간 진단 및 복구 플레이북입니다.

Socket Mode 또는 HTTP Request URLs 선택

두 전송 방식 모두 프로덕션 사용 준비가 되어 있으며 메시징, slash commands, App Home, 상호작용 기능에서 기능 동등성을 제공합니다. 기능이 아니라 배포 형태에 따라 선택하세요.
고려 사항Socket Mode (기본값)HTTP Request URLs
공개 Gateway URL필요하지 않음필요함(DNS, TLS, 리버스 프록시 또는 터널)
아웃바운드 네트워크wss-primary.slack.com으로의 아웃바운드 WSS에 연결할 수 있어야 함아웃바운드 WS 없음, 인바운드 HTTPS만 사용
필요한 토큰Bot 토큰(xoxb-...) + connections:write가 있는 App-Level Token(xapp-...)Bot 토큰(xoxb-...) + Signing Secret
개발 노트북 / 방화벽 뒤그대로 작동공개 터널(ngrok, Cloudflare Tunnel, Tailscale Funnel) 또는 스테이징 Gateway 필요
수평 확장앱별 호스트별 Socket Mode 세션 1개, 여러 Gateway에는 별도 Slack 앱 필요상태 없는 POST 핸들러, 여러 Gateway 복제본이 로드 밸런서 뒤에서 하나의 앱을 공유할 수 있음
하나의 Gateway에서 다중 계정지원됨, 각 계정이 자체 WS를 엶지원됨, 등록이 충돌하지 않도록 각 계정에는 고유한 webhookPath(기본값 /slack/events) 필요
Slash command 전송WS 연결을 통해 전달됨, slash_commands[].url은 무시됨Slack이 slash_commands[].url로 POST함, 명령 디스패치에 해당 필드가 필요함
요청 서명사용하지 않음(인증은 App-Level Token)Slack이 모든 요청에 서명함, OpenClaw가 signingSecret으로 검증함
연결 끊김 시 복구Slack SDK가 자동으로 다시 연결함, gateway의 pong-timeout 전송 튜닝이 적용됨끊길 지속 연결 없음, 재시도는 Slack의 요청별로 처리됨
단일 Gateway 호스트, 개발 노트북, *.slack.com으로 아웃바운드는 가능하지만 인바운드 HTTPS를 받을 수 없는 온프레미스 네트워크에는 Socket Mode를 선택하세요.로드 밸런서 뒤에서 여러 Gateway 복제본을 실행하거나, 아웃바운드 WSS는 차단되었지만 인바운드 HTTPS는 허용되는 경우, 또는 이미 리버스 프록시에서 Slack Webhook을 종료하는 경우에는 HTTP Request URLs를 선택하세요.

빠른 설정

1

Create a new Slack app

api.slack.com/apps를 엽니다 → Create New AppFrom a manifest → 워크스페이스 선택 → 아래 매니페스트 중 하나 붙여넣기 → NextCreate.
{
  "display_information": {
    "name": "OpenClaw",
    "description": "Slack connector for OpenClaw"
  },
  "features": {
    "bot_user": { "display_name": "OpenClaw", "always_online": true },
    "app_home": {
      "home_tab_enabled": true,
      "messages_tab_enabled": true,
      "messages_tab_read_only_enabled": false
    },
    "slash_commands": [
      {
        "command": "/openclaw",
        "description": "Send a message to OpenClaw",
        "should_escape": false
      }
    ]
  },
  "oauth_config": {
    "scopes": {
      "bot": [
        "app_mentions:read",
        "assistant:write",
        "channels:history",
        "channels:read",
        "chat:write",
        "commands",
        "emoji:read",
        "files:read",
        "files:write",
        "groups:history",
        "groups:read",
        "im:history",
        "im:read",
        "im:write",
        "mpim:history",
        "mpim:read",
        "mpim:write",
        "pins:read",
        "pins:write",
        "reactions:read",
        "reactions:write",
        "usergroups:read",
        "users:read"
      ]
    }
  },
  "settings": {
    "socket_mode_enabled": true,
    "event_subscriptions": {
      "bot_events": [
        "app_home_opened",
        "app_mention",
        "channel_rename",
        "member_joined_channel",
        "member_left_channel",
        "message.channels",
        "message.groups",
        "message.im",
        "message.mpim",
        "pin_added",
        "pin_removed",
        "reaction_added",
        "reaction_removed"
      ]
    }
  }
}
Recommended는 번들 Slack plugin의 전체 기능 세트와 일치합니다: App Home, slash commands, 파일, 반응, 핀, 그룹 DM, 이모지/사용자 그룹 읽기. 워크스페이스 정책이 scope를 제한하는 경우 Minimal을 선택하세요. DM, 채널/그룹 기록, 멘션, slash commands를 포함하지만 파일, 반응, 핀, 그룹 DM(mpim:*), emoji:read, usergroups:read는 제외합니다. scope별 근거와 추가 slash commands 같은 추가 옵션은 매니페스트 및 scope 체크리스트를 참고하세요.
Slack이 앱을 만든 후:
  • Basic Information → App-Level Tokens → Generate Token and Scopes: connections:write를 추가하고, 저장한 다음 xapp-... 값을 복사합니다.
  • Install App → Install to Workspace: xoxb-... Bot User OAuth Token을 복사합니다.
2

Configure OpenClaw

권장 SecretRef 설정:
export SLACK_APP_TOKEN=xapp-...
export SLACK_BOT_TOKEN=xoxb-...
cat > slack.socket.patch.json5 <<'JSON5'
{
  channels: {
    slack: {
      enabled: true,
      mode: "socket",
      appToken: { source: "env", provider: "default", id: "SLACK_APP_TOKEN" },
      botToken: { source: "env", provider: "default", id: "SLACK_BOT_TOKEN" },
    },
  },
}
JSON5
openclaw config patch --file ./slack.socket.patch.json5 --dry-run
openclaw config patch --file ./slack.socket.patch.json5
Env 대체 방식(기본 계정만 해당):
SLACK_APP_TOKEN=xapp-...
SLACK_BOT_TOKEN=xoxb-...
3

Start gateway

openclaw gateway

Socket Mode 전송 튜닝

OpenClaw는 기본적으로 Socket Mode에서 Slack SDK 클라이언트 pong 타임아웃을 15초로 설정합니다. 워크스페이스 또는 호스트별 튜닝이 필요한 경우에만 전송 설정을 재정의하세요.
{
  channels: {
    slack: {
      mode: "socket",
      socketMode: {
        clientPingTimeout: 20000,
        serverPingTimeout: 30000,
        pingPongLoggingEnabled: false,
      },
    },
  },
}
Slack websocket pong/서버 ping 타임아웃을 기록하는 Socket Mode 워크스페이스 또는 이벤트 루프 고갈이 알려진 호스트에서만 이것을 사용하세요. clientPingTimeout은 SDK가 클라이언트 ping을 보낸 뒤 pong을 기다리는 시간이고, serverPingTimeout은 Slack 서버 ping을 기다리는 시간입니다. 앱 메시지와 이벤트는 전송 활성 신호가 아니라 애플리케이션 상태로 유지됩니다.

매니페스트 및 범위 체크리스트

기본 Slack 앱 매니페스트는 Socket Mode와 HTTP 요청 URL에서 동일합니다. settings 블록(및 슬래시 명령 url)만 다릅니다. 기본 매니페스트(Socket Mode 기본값):
{
  "display_information": {
    "name": "OpenClaw",
    "description": "Slack connector for OpenClaw"
  },
  "features": {
    "bot_user": { "display_name": "OpenClaw", "always_online": true },
    "app_home": {
      "home_tab_enabled": true,
      "messages_tab_enabled": true,
      "messages_tab_read_only_enabled": false
    },
    "slash_commands": [
      {
        "command": "/openclaw",
        "description": "Send a message to OpenClaw",
        "should_escape": false
      }
    ]
  },
  "oauth_config": {
    "scopes": {
      "bot": [
        "app_mentions:read",
        "assistant:write",
        "channels:history",
        "channels:read",
        "chat:write",
        "commands",
        "emoji:read",
        "files:read",
        "files:write",
        "groups:history",
        "groups:read",
        "im:history",
        "im:read",
        "im:write",
        "mpim:history",
        "mpim:read",
        "mpim:write",
        "pins:read",
        "pins:write",
        "reactions:read",
        "reactions:write",
        "usergroups:read",
        "users:read"
      ]
    }
  },
  "settings": {
    "socket_mode_enabled": true,
    "event_subscriptions": {
      "bot_events": [
        "app_home_opened",
        "app_mention",
        "channel_rename",
        "member_joined_channel",
        "member_left_channel",
        "message.channels",
        "message.groups",
        "message.im",
        "message.mpim",
        "pin_added",
        "pin_removed",
        "reaction_added",
        "reaction_removed"
      ]
    }
  }
}
HTTP 요청 URL 모드의 경우 settings를 HTTP 변형으로 바꾸고 각 슬래시 명령에 url을 추가하세요. 공개 URL이 필요합니다.
{
  "features": {
    "slash_commands": [
      {
        "command": "/openclaw",
        "description": "Send a message to OpenClaw",
        "should_escape": false,
        "url": "https://gateway-host.example.com/slack/events"
      }
    ]
  },
  "settings": {
    "event_subscriptions": {
      "request_url": "https://gateway-host.example.com/slack/events",
      "bot_events": [
        "app_home_opened",
        "app_mention",
        "channel_rename",
        "member_joined_channel",
        "member_left_channel",
        "message.channels",
        "message.groups",
        "message.im",
        "message.mpim",
        "pin_added",
        "pin_removed",
        "reaction_added",
        "reaction_removed"
      ]
    },
    "interactivity": {
      "is_enabled": true,
      "request_url": "https://gateway-host.example.com/slack/events",
      "message_menu_options_url": "https://gateway-host.example.com/slack/events"
    }
  }
}

추가 매니페스트 설정

위 기본값을 확장하는 다양한 기능을 표시합니다. 기본 매니페스트는 Slack App Home Home 탭을 활성화하고 app_home_opened를 구독합니다. 워크스페이스 멤버가 Home 탭을 열면 OpenClaw는 views.publish로 안전한 기본 Home 보기를 게시합니다. 대화 페이로드나 비공개 구성은 포함되지 않습니다. Messages 탭은 Slack DM용으로 계속 활성화됩니다.
여러 기본 슬래시 명령은 다음 세부 사항을 고려하여 하나의 구성된 명령 대신 사용할 수 있습니다.
  • /status 명령은 예약되어 있으므로 /status 대신 /agentstatus를 사용하세요.
  • 한 번에 25개를 초과하는 슬래시 명령은 사용할 수 없습니다.
기존 features.slash_commands 섹션을 사용 가능한 명령의 하위 집합으로 바꾸세요.
{
  "slash_commands": [
    {
      "command": "/new",
      "description": "Start a new session",
      "usage_hint": "[model]"
    },
    {
      "command": "/reset",
      "description": "Reset the current session"
    },
    {
      "command": "/compact",
      "description": "Compact the session context",
      "usage_hint": "[instructions]"
    },
    {
      "command": "/stop",
      "description": "Stop the current run"
    },
    {
      "command": "/session",
      "description": "Manage thread-binding expiry",
      "usage_hint": "idle <duration|off> or max-age <duration|off>"
    },
    {
      "command": "/think",
      "description": "Set the thinking level",
      "usage_hint": "<level>"
    },
    {
      "command": "/verbose",
      "description": "Toggle verbose output",
      "usage_hint": "on|off|full"
    },
    {
      "command": "/fast",
      "description": "Show or set fast mode",
      "usage_hint": "[status|on|off]"
    },
    {
      "command": "/reasoning",
      "description": "Toggle reasoning visibility",
      "usage_hint": "[on|off|stream]"
    },
    {
      "command": "/elevated",
      "description": "Toggle elevated mode",
      "usage_hint": "[on|off|ask|full]"
    },
    {
      "command": "/exec",
      "description": "Show or set exec defaults",
      "usage_hint": "host=<auto|sandbox|gateway|node> security=<deny|allowlist|full> ask=<off|on-miss|always> node=<id>"
    },
    {
      "command": "/model",
      "description": "Show or set the model",
      "usage_hint": "[name|#|status]"
    },
    {
      "command": "/models",
      "description": "List providers/models",
      "usage_hint": "[provider] [page] [limit=<n>|size=<n>|all]"
    },
    {
      "command": "/help",
      "description": "Show the short help summary"
    },
    {
      "command": "/commands",
      "description": "Show the generated command catalog"
    },
    {
      "command": "/tools",
      "description": "Show what the current agent can use right now",
      "usage_hint": "[compact|verbose]"
    },
    {
      "command": "/agentstatus",
      "description": "Show runtime status, including provider usage/quota when available"
    },
    {
      "command": "/tasks",
      "description": "List active/recent background tasks for the current session"
    },
    {
      "command": "/context",
      "description": "Explain how context is assembled",
      "usage_hint": "[list|detail|json]"
    },
    {
      "command": "/whoami",
      "description": "Show your sender identity"
    },
    {
      "command": "/skill",
      "description": "Run a skill by name",
      "usage_hint": "<name> [input]"
    },
    {
      "command": "/btw",
      "description": "Ask a side question without changing session context",
      "usage_hint": "<question>"
    },
    {
      "command": "/side",
      "description": "Ask a side question without changing session context",
      "usage_hint": "<question>"
    },
    {
      "command": "/usage",
      "description": "Control the usage footer or show cost summary",
      "usage_hint": "off|tokens|full|cost"
    }
  ]
}
나가는 메시지가 기본 Slack 앱 ID 대신 활성 에이전트 ID(사용자 지정 사용자 이름 및 아이콘)를 사용하도록 하려면 chat:write.customize 봇 범위를 추가하세요.이모지 아이콘을 사용하는 경우 Slack은 :emoji_name: 구문을 기대합니다.
channels.slack.userToken을 구성하는 경우 일반적인 읽기 범위는 다음과 같습니다.
  • channels:history, groups:history, im:history, mpim:history
  • channels:read, groups:read, im:read, mpim:read
  • users:read
  • reactions:read
  • pins:read
  • emoji:read
  • search:read(Slack 검색 읽기에 의존하는 경우)

토큰 모델

  • Socket Mode에는 botToken + appToken이 필요합니다.
  • HTTP 모드에는 botToken + signingSecret이 필요합니다.
  • botToken, appToken, signingSecret, userToken은 일반 텍스트 문자열 또는 SecretRef 객체를 허용합니다.
  • 구성 토큰은 env fallback보다 우선합니다.
  • SLACK_BOT_TOKEN / SLACK_APP_TOKEN env fallback은 기본 계정에만 적용됩니다.
  • userToken(xoxp-...)은 구성 전용(env fallback 없음)이며 기본값은 읽기 전용 동작(userTokenReadOnly: true)입니다.
상태 스냅샷 동작:
  • Slack 계정 검사는 자격 증명별 *Source*Status 필드(botToken, appToken, signingSecret, userToken)를 추적합니다.
  • 상태는 available, configured_unavailable, missing 중 하나입니다.
  • configured_unavailable은 계정이 SecretRef 또는 다른 비인라인 비밀 소스를 통해 구성되었지만, 현재 명령/런타임 경로에서 실제 값을 확인할 수 없었음을 의미합니다.
  • HTTP 모드에서는 signingSecretStatus가 포함됩니다. Socket Mode에서는 필요한 쌍이 botTokenStatus + appTokenStatus입니다.
작업/디렉터리 읽기의 경우 구성되어 있으면 사용자 토큰을 우선 사용할 수 있습니다. 쓰기의 경우 봇 토큰이 계속 우선됩니다. 사용자 토큰 쓰기는 userTokenReadOnly: false이고 봇 토큰을 사용할 수 없을 때만 허용됩니다.

작업 및 게이트

Slack 작업은 channels.slack.actions.*로 제어됩니다. 현재 Slack 도구에서 사용할 수 있는 작업 그룹:
그룹기본값
messages활성화
reactions활성화
pins활성화
memberInfo활성화
emojiList활성화
현재 Slack 메시지 작업에는 send, upload-file, download-file, read, edit, delete, pin, unpin, list-pins, member-info, emoji-list가 포함됩니다. download-file은 인바운드 파일 플레이스홀더에 표시된 Slack 파일 ID를 허용하고, 이미지에는 이미지 미리보기를, 다른 파일 유형에는 로컬 파일 메타데이터를 반환합니다.

액세스 제어 및 라우팅

channels.slack.dmPolicy는 DM 액세스를 제어합니다. channels.slack.allowFrom은 표준 DM 허용 목록입니다.
  • pairing(기본값)
  • allowlist
  • open(channels.slack.allowFrom"*"가 포함되어야 함)
  • disabled
DM 플래그:
  • dm.enabled(기본값 true)
  • channels.slack.allowFrom
  • dm.allowFrom(레거시)
  • dm.groupEnabled(그룹 DM 기본값 false)
  • dm.groupChannels(선택적 MPIM 허용 목록)
다중 계정 우선순위:
  • channels.slack.accounts.default.allowFromdefault 계정에만 적용됩니다.
  • 이름이 지정된 계정은 자체 allowFrom이 설정되지 않은 경우 channels.slack.allowFrom을 상속합니다.
  • 이름이 지정된 계정은 channels.slack.accounts.default.allowFrom을 상속하지 않습니다.
레거시 channels.slack.dm.policychannels.slack.dm.allowFrom은 호환성을 위해 계속 읽힙니다. openclaw doctor --fix는 액세스를 변경하지 않고 수행할 수 있을 때 이를 dmPolicyallowFrom으로 마이그레이션합니다.DM에서의 페어링은 openclaw pairing approve slack <code>를 사용합니다.

스레딩, 세션 및 답글 태그

  • DM은 direct로, 채널은 channel로, MPIM은 group으로 라우팅됩니다.
  • Slack 라우트 바인딩은 원시 피어 ID와 channel:C12345678, user:U12345678, <@U12345678> 같은 Slack 대상 형식을 허용합니다.
  • 기본 session.dmScope=main에서는 Slack DM이 에이전트 기본 세션으로 합쳐집니다.
  • 채널 세션: agent:<agentId>:slack:channel:<channelId>.
  • 스레드 답글은 해당되는 경우 스레드 세션 접미사(:thread:<threadTs>)를 만들 수 있습니다.
  • OpenClaw가 명시적 멘션 없이 최상위 메시지를 처리하는 채널에서는 off가 아닌 replyToMode가 처리된 각 루트를 agent:<agentId>:slack:channel:<channelId>:thread:<rootTs>로 라우팅하므로, 보이는 Slack 스레드가 첫 턴부터 하나의 OpenClaw 세션에 매핑됩니다.
  • channels.slack.thread.historyScope 기본값은 thread이고, thread.inheritParent 기본값은 false입니다.
  • channels.slack.thread.initialHistoryLimit는 새 스레드 세션이 시작될 때 가져올 기존 스레드 메시지 수를 제어합니다(기본값 20, 비활성화하려면 0으로 설정).
  • channels.slack.thread.requireExplicitMention(기본값 false): true이면 암시적 스레드 멘션을 억제하여 봇이 이미 스레드에 참여했더라도 스레드 안에서 명시적 @bot 멘션에만 응답합니다. 이것이 없으면 봇이 참여한 스레드의 답글은 requireMention 게이트를 우회합니다.
답글 스레딩 제어:
  • channels.slack.replyToMode: off|first|all|batched(기본값 off)
  • channels.slack.replyToModeByChatType: direct|group|channel별 설정
  • 직접 채팅용 레거시 fallback: channels.slack.dm.replyToMode
수동 답글 태그가 지원됩니다.
  • [[reply_to_current]]
  • [[reply_to:<id>]]
message 도구에서 명시적 Slack 스레드 답글을 보낼 때 Slack에 스레드 답글을 상위 채널에도 브로드캐스트하도록 요청하려면 action: "send"threadId 또는 replyTo와 함께 replyBroadcast: true를 설정하세요. 이는 Slack의 chat.postMessage reply_broadcast 플래그에 매핑되며, 미디어 업로드가 아닌 텍스트 또는 Block Kit 전송에만 지원됩니다. message 도구 호출이 Slack 스레드 안에서 실행되고 동일한 채널을 대상으로 할 때, OpenClaw는 일반적으로 replyToMode에 따라 현재 Slack 스레드를 상속합니다. 대신 새 상위 채널 메시지를 강제로 보내려면 action: "send" 또는 action: "upload-file"topLevel: true를 설정하세요. threadId: null도 동일한 최상위 opt-out으로 허용됩니다.
replyToMode="off"는 명시적 [[reply_to_*]] 태그를 포함해 Slack의 모든 답글 스레딩을 비활성화합니다. 이는 "off" 모드에서도 명시적 태그가 여전히 적용되는 Telegram과 다릅니다. Slack 스레드는 채널에서 메시지를 숨기는 반면 Telegram 답글은 인라인으로 계속 표시됩니다.

승인 반응

ackReaction은 OpenClaw가 인바운드 메시지를 처리하는 동안 승인 이모지를 보냅니다. 확인 순서:
  • channels.slack.accounts.<accountId>.ackReaction
  • channels.slack.ackReaction
  • messages.ackReaction
  • 에이전트 ID 이모지 fallback(agents.list[].identity.emoji, 없으면 ”👀”)
참고:
  • Slack은 쇼트코드(예: "eyes")를 기대합니다.
  • Slack 계정 또는 전역에서 반응을 비활성화하려면 ""를 사용하세요.

텍스트 스트리밍

channels.slack.streaming은 라이브 미리보기 동작을 제어합니다.
  • off: 라이브 미리보기 스트리밍을 비활성화합니다.
  • partial(기본값): 미리보기 텍스트를 최신 부분 출력으로 교체합니다.
  • block: 청크로 나뉜 미리보기 업데이트를 추가합니다.
  • progress: 생성 중 진행 상태 텍스트를 표시한 다음 최종 텍스트를 보냅니다.
  • streaming.preview.toolProgress: 초안 미리보기가 활성화되어 있을 때 도구/진행 업데이트를 동일한 편집 미리보기 메시지로 라우팅합니다(기본값: true). 별도의 도구/진행 메시지를 유지하려면 false로 설정하세요.
  • streaming.preview.commandText / streaming.progress.commandText: 원시 명령/실행 텍스트를 숨기면서 간결한 도구 진행 라인을 유지하려면 status로 설정합니다(기본값: raw).
간결한 진행 라인은 유지하면서 원시 명령/실행 텍스트 숨기기:
{
  "channels": {
    "slack": {
      "streaming": {
        "mode": "progress",
        "progress": {
          "toolProgress": true,
          "commandText": "status"
        }
      }
    }
  }
}
channels.slack.streaming.nativeTransportchannels.slack.streaming.modepartial일 때 Slack 네이티브 텍스트 스트리밍을 제어합니다(기본값: true).
  • 네이티브 텍스트 스트리밍과 Slack 어시스턴트 스레드 상태가 표시되려면 답장 스레드를 사용할 수 있어야 합니다. 스레드 선택은 여전히 replyToMode를 따릅니다.
  • 채널, 그룹 채팅, 최상위 DM 루트는 네이티브 스트리밍을 사용할 수 없거나 답장 스레드가 없을 때도 일반 초안 미리보기를 사용할 수 있습니다.
  • 최상위 Slack DM은 기본적으로 스레드 밖에 유지되므로 Slack의 스레드 방식 네이티브 스트림/상태 미리보기를 표시하지 않습니다. 대신 OpenClaw가 DM에 초안 미리보기를 게시하고 편집합니다.
  • 미디어와 비텍스트 페이로드는 일반 전달로 폴백합니다.
  • 미디어/오류 최종 응답은 대기 중인 미리보기 편집을 취소합니다. 대상 텍스트/블록 최종 응답은 미리보기를 제자리에서 편집할 수 있을 때만 플러시됩니다.
  • 스트리밍이 답장 중간에 실패하면 OpenClaw는 남은 페이로드에 대해 일반 전달로 폴백합니다.
Slack 네이티브 텍스트 스트리밍 대신 초안 미리보기를 사용합니다:
{
  channels: {
    slack: {
      streaming: {
        mode: "partial",
        nativeTransport: false,
      },
    },
  },
}
레거시 키:
  • channels.slack.streamMode(replace | status_final | append)는 channels.slack.streaming.mode의 레거시 런타임 별칭입니다.
  • boolean channels.slack.streamingchannels.slack.streaming.modechannels.slack.streaming.nativeTransport의 레거시 런타임 별칭입니다.
  • 레거시 channels.slack.nativeStreamingchannels.slack.streaming.nativeTransport의 런타임 별칭입니다.
  • 저장된 Slack 스트리밍 구성을 정식 키로 다시 쓰려면 openclaw doctor --fix를 실행하세요.

입력 중 반응 폴백

typingReaction은 OpenClaw가 답장을 처리하는 동안 수신 Slack 메시지에 임시 반응을 추가한 다음, 실행이 완료되면 제거합니다. 기본 “입력 중…” 상태 표시기를 사용하는 스레드 답장 외부에서 가장 유용합니다. 해결 순서:
  • channels.slack.accounts.<accountId>.typingReaction
  • channels.slack.typingReaction
참고:
  • Slack은 쇼트코드(예: "hourglass_flowing_sand")를 예상합니다.
  • 반응은 최선의 방식으로 시도되며, 답장 또는 실패 경로가 완료된 뒤 정리가 자동으로 시도됩니다.

미디어, 청크 처리 및 전달

Slack 파일 첨부는 Slack이 호스팅하는 비공개 URL(토큰 인증 요청 흐름)에서 다운로드되며, 가져오기가 성공하고 크기 제한이 허용하면 미디어 저장소에 기록됩니다. 파일 플레이스홀더에는 Slack fileId가 포함되어 에이전트가 download-file로 원본 파일을 가져올 수 있습니다.다운로드에는 제한된 유휴 및 전체 타임아웃이 사용됩니다. Slack 파일 가져오기가 멈추거나 실패하면 OpenClaw는 메시지 처리를 계속하고 파일 플레이스홀더로 폴백합니다.런타임 수신 크기 상한은 channels.slack.mediaMaxMb로 재정의하지 않는 한 기본값이 20MB입니다.
  • 텍스트 청크는 channels.slack.textChunkLimit(기본값 4000)을 사용합니다.
  • channels.slack.chunkMode="newline"은 문단 우선 분할을 활성화합니다.
  • 파일 전송은 Slack 업로드 API를 사용하며 스레드 답장(thread_ts)을 포함할 수 있습니다.
  • 발신 미디어 상한은 구성된 경우 channels.slack.mediaMaxMb를 따릅니다. 그렇지 않으면 채널 전송은 미디어 파이프라인의 MIME 종류 기본값을 사용합니다.
권장되는 명시적 대상:
  • DM용 user:<id>
  • 채널용 channel:<id>
텍스트/블록 전용 Slack DM은 사용자 ID에 직접 게시할 수 있습니다. 파일 업로드와 스레드 전송은 해당 경로에 구체적인 대화 ID가 필요하므로 먼저 Slack 대화 API로 DM을 엽니다.

명령과 슬래시 동작

슬래시 명령은 Slack에서 구성된 단일 명령 또는 여러 네이티브 명령으로 표시됩니다. 명령 기본값을 변경하려면 channels.slack.slashCommand를 구성하세요:
  • enabled: false
  • name: "openclaw"
  • sessionPrefix: "slack:slash"
  • ephemeral: true
/openclaw /help
네이티브 명령에는 Slack 앱의 추가 매니페스트 설정이 필요하며, 대신 channels.slack.commands.native: true 또는 전역 구성의 commands.native: true로 활성화됩니다.
  • Slack에서는 네이티브 명령 자동 모드가 꺼져 있으므로 commands.native: "auto"는 Slack 네이티브 명령을 활성화하지 않습니다.
/help
네이티브 인수 메뉴는 선택된 옵션 값을 디스패치하기 전에 확인 모달을 표시하는 적응형 렌더링 전략을 사용합니다:
  • 최대 5개 옵션: 버튼 블록
  • 6-100개 옵션: 정적 선택 메뉴
  • 100개 초과 옵션: 상호작용 옵션 핸들러를 사용할 수 있을 때 비동기 옵션 필터링을 포함한 외부 선택
  • Slack 제한 초과: 인코딩된 옵션 값은 버튼으로 폴백합니다.
/think
슬래시 세션은 agent:<agentId>:slack:slash:<userId> 같은 격리된 키를 사용하며, 여전히 CommandTargetSessionKey를 사용해 대상 대화 세션으로 명령 실행을 라우팅합니다.

대화형 답장

Slack은 에이전트가 작성한 대화형 답장 컨트롤을 렌더링할 수 있지만, 이 기능은 기본적으로 비활성화되어 있습니다. 전역으로 활성화합니다:
{
  channels: {
    slack: {
      capabilities: {
        interactiveReplies: true,
      },
    },
  },
}
또는 단일 Slack 계정에만 활성화합니다:
{
  channels: {
    slack: {
      accounts: {
        ops: {
          capabilities: {
            interactiveReplies: true,
          },
        },
      },
    },
  },
}
활성화되면 에이전트는 Slack 전용 답장 지시문을 내보낼 수 있습니다:
  • [[slack_buttons: Approve:approve, Reject:reject]]
  • [[slack_select: Choose a target | Canary:canary, Production:production]]
이 지시문은 Slack Block Kit으로 컴파일되고 클릭 또는 선택을 기존 Slack 상호작용 이벤트 경로를 통해 다시 라우팅합니다. 참고:
  • 이는 Slack 전용 UI입니다. 다른 채널은 Slack Block Kit 지시문을 자체 버튼 시스템으로 변환하지 않습니다.
  • 대화형 콜백 값은 에이전트가 작성한 원시 값이 아니라 OpenClaw가 생성한 불투명 토큰입니다.
  • 생성된 대화형 블록이 Slack Block Kit 제한을 초과할 경우, OpenClaw는 잘못된 blocks 페이로드를 보내는 대신 원래 텍스트 답장으로 폴백합니다.

Slack의 Exec 승인

Slack은 웹 UI 또는 터미널로 폴백하는 대신, 대화형 버튼과 상호작용이 있는 네이티브 승인 클라이언트로 동작할 수 있습니다.
  • Exec 승인은 네이티브 DM/채널 라우팅에 channels.slack.execApprovals.*를 사용합니다.
  • 요청이 이미 Slack에 도착했고 승인 ID 종류가 plugin:이면 Plugin 승인은 동일한 Slack 네이티브 버튼 표면을 통해 계속 해결될 수 있습니다.
  • 승인자 권한 부여는 계속 적용됩니다. 승인자로 식별된 사용자만 Slack을 통해 요청을 승인하거나 거부할 수 있습니다.
이는 다른 채널과 동일한 공유 승인 버튼 표면을 사용합니다. Slack 앱 설정에서 interactivity가 활성화되면 승인 프롬프트가 대화 안에 직접 Block Kit 버튼으로 렌더링됩니다. 해당 버튼이 있으면 기본 승인 UX가 됩니다. 도구 결과가 채팅 승인을 사용할 수 없거나 수동 승인이 유일한 경로라고 할 때만 OpenClaw는 수동 /approve 명령을 포함해야 합니다. 구성 경로:
  • channels.slack.execApprovals.enabled
  • channels.slack.execApprovals.approvers(선택 사항, 가능한 경우 commands.ownerAllowFrom으로 폴백)
  • channels.slack.execApprovals.target(dm | channel | both, 기본값: dm)
  • agentFilter, sessionFilter
enabled가 설정되지 않았거나 "auto"이고 하나 이상의 승인자가 해결되면 Slack은 네이티브 exec 승인을 자동으로 활성화합니다. Slack을 네이티브 승인 클라이언트로 명시적으로 비활성화하려면 enabled: false를 설정하세요. 승인자가 해결될 때 네이티브 승인을 강제로 켜려면 enabled: true를 설정하세요. 명시적 Slack exec 승인 구성이 없을 때의 기본 동작:
{
  commands: {
    ownerAllowFrom: ["slack:U12345678"],
  },
}
명시적 Slack 네이티브 구성은 승인자를 재정의하거나, 필터를 추가하거나, 원본 채팅 전달을 사용하도록 선택하려는 경우에만 필요합니다:
{
  channels: {
    slack: {
      execApprovals: {
        enabled: true,
        approvers: ["U12345678"],
        target: "both",
      },
    },
  },
}
공유 approvals.exec 전달은 별도입니다. exec 승인 프롬프트도 다른 채팅이나 명시적인 대역 외 대상으로 라우팅해야 할 때만 사용하세요. 공유 approvals.plugin 전달도 별도입니다. 해당 요청이 이미 Slack에 도착한 경우 Slack 네이티브 버튼은 여전히 Plugin 승인을 해결할 수 있습니다. 명령을 이미 지원하는 Slack 채널과 DM에서는 같은 채팅의 /approve도 작동합니다. 전체 승인 전달 모델은 Exec 승인을 참조하세요.

이벤트 및 운영 동작

  • 메시지 편집/삭제는 시스템 이벤트로 매핑됩니다.
  • 스레드 브로드캐스트(“채널에도 보내기” 스레드 답장)는 일반 사용자 메시지로 처리됩니다.
  • 반응 추가/제거 이벤트는 시스템 이벤트로 매핑됩니다.
  • 멤버 참여/나가기, 채널 생성/이름 변경, 핀 추가/제거 이벤트는 시스템 이벤트로 매핑됩니다.
  • configWrites가 활성화되면 channel_id_changed가 채널 구성 키를 마이그레이션할 수 있습니다.
  • 채널 주제/목적 메타데이터는 신뢰할 수 없는 컨텍스트로 취급되며 라우팅 컨텍스트에 삽입될 수 있습니다.
  • 스레드 시작자와 초기 스레드 기록 컨텍스트 시딩은 해당되는 경우 구성된 발신자 허용 목록에 따라 필터링됩니다.
  • 블록 작업과 모달 상호작용은 풍부한 페이로드 필드를 포함한 구조화된 Slack interaction: ... 시스템 이벤트를 내보냅니다:
    • 블록 작업: 선택된 값, 레이블, 선택기 값 및 workflow_* 메타데이터
    • 라우팅된 채널 메타데이터와 폼 입력을 포함한 모달 view_submissionview_closed 이벤트

구성 참조

기본 참조: 구성 참조 - Slack.
  • 모드/인증: mode, botToken, appToken, signingSecret, webhookPath, accounts.*
  • DM 접근: dm.enabled, dmPolicy, allowFrom(레거시: dm.policy, dm.allowFrom), dm.groupEnabled, dm.groupChannels
  • 호환성 토글: dangerouslyAllowNameMatching(긴급용, 필요하지 않으면 꺼 두세요)
  • 채널 접근: groupPolicy, channels.*, channels.*.users, channels.*.requireMention
  • 스레드/기록: replyToMode, replyToModeByChatType, thread.*, historyLimit, dmHistoryLimit, dms.*.historyLimit
  • 전달: textChunkLimit, chunkMode, mediaMaxMb, streaming, streaming.nativeTransport, streaming.preview.toolProgress
  • 미리보기 펼치기: chat.postMessage 링크/미디어 미리보기 제어용 unfurlLinks, unfurlMedia
  • 운영/기능: configWrites, commands.native, slashCommand.*, actions.*, userToken, userTokenReadOnly

문제 해결

순서대로 확인하세요:
  • groupPolicy
  • 채널 허용 목록(channels.slack.channels) — 키는 채널 ID여야 합니다(C12345678). 이름(#channel-name)이 아닙니다. 채널 라우팅은 기본적으로 ID 우선이므로 이름 기반 키는 groupPolicy: "allowlist"에서 오류 없이 실패합니다. ID를 찾으려면 Slack에서 채널을 마우스 오른쪽 버튼으로 클릭 → 링크 복사 — URL 끝의 C... 값이 채널 ID입니다.
  • requireMention
  • 채널별 users 허용 목록
유용한 명령:
openclaw channels status --probe
openclaw logs --follow
openclaw doctor
확인하세요:
  • channels.slack.dm.enabled
  • channels.slack.dmPolicy(또는 레거시 channels.slack.dm.policy)
  • 페어링 승인 / 허용 목록 항목
  • Slack 어시스턴트 DM 이벤트: drop message_changed를 언급하는 자세한 로그는 보통 Slack이 메시지 메타데이터에서 복구 가능한 사람 발신자 없이 편집된 어시스턴트 스레드 이벤트를 보냈음을 의미합니다.
openclaw pairing list slack
Slack 앱 설정에서 봇 + 앱 토큰과 Socket Mode 활성화를 검증하세요.openclaw channels status --probe --jsonbotTokenStatus 또는 appTokenStatus: "configured_unavailable"가 표시되면 Slack 계정은 구성되어 있지만 현재 런타임이 SecretRef 기반 값을 해결할 수 없었던 것입니다.
확인하세요:
  • 서명 시크릿
  • Webhook 경로
  • Slack 요청 URL(이벤트 + 상호작용 + 슬래시 명령)
  • HTTP 계정별 고유한 webhookPath
계정 스냅샷에 signingSecretStatus: "configured_unavailable"이 표시되면, HTTP 계정은 구성되어 있지만 현재 런타임이 SecretRef 기반 서명 시크릿을 확인할 수 없었다는 뜻입니다.
의도한 항목이 무엇인지 확인하세요:
  • Slack에 등록된 일치하는 슬래시 명령과 함께 사용하는 네이티브 명령 모드(channels.slack.commands.native: true)
  • 또는 단일 슬래시 명령 모드(channels.slack.slashCommand.enabled: true)
commands.useAccessGroups와 채널/사용자 허용 목록도 확인하세요.

첨부 파일 비전 참조

Slack 파일 다운로드가 성공하고 크기 제한이 허용하는 경우 Slack은 다운로드된 미디어를 에이전트 턴에 첨부할 수 있습니다. 이미지 파일은 미디어 이해 경로를 통해 전달되거나 비전 지원 응답 모델로 직접 전달될 수 있습니다. 다른 파일은 이미지 입력으로 처리되지 않고 다운로드 가능한 파일 컨텍스트로 유지됩니다.

지원되는 미디어 유형

미디어 유형소스현재 동작참고
JPEG / PNG / GIF / WebP 이미지Slack 파일 URL다운로드되어 비전 지원 처리를 위해 턴에 첨부됨파일당 한도: channels.slack.mediaMaxMb(기본값 20 MB)
PDF 파일Slack 파일 URL다운로드되어 download-file 또는 pdf 같은 도구의 파일 컨텍스트로 노출됨Slack 인바운드는 PDF를 이미지 비전 입력으로 자동 변환하지 않음
기타 파일Slack 파일 URL가능한 경우 다운로드되어 파일 컨텍스트로 노출됨바이너리 파일은 이미지 입력으로 처리되지 않음
스레드 답글스레드 시작 파일답글에 직접 미디어가 없는 경우 루트 메시지 파일을 컨텍스트로 수화할 수 있음파일만 있는 시작 메시지는 첨부 파일 플레이스홀더를 사용함
다중 이미지 메시지여러 Slack 파일각 파일은 독립적으로 평가됨Slack 처리는 메시지당 최대 8개 파일로 제한됨

인바운드 파이프라인

파일 첨부가 있는 Slack 메시지가 도착하면:
  1. OpenClaw는 봇 토큰(xoxb-...)을 사용해 Slack의 비공개 URL에서 파일을 다운로드합니다.
  2. 성공하면 파일이 미디어 저장소에 기록됩니다.
  3. 다운로드된 미디어 경로와 콘텐츠 유형이 인바운드 컨텍스트에 추가됩니다.
  4. 이미지 지원 모델/도구 경로는 해당 컨텍스트의 이미지 첨부 파일을 사용할 수 있습니다.
  5. 이미지가 아닌 파일은 이를 처리할 수 있는 도구를 위해 파일 메타데이터 또는 미디어 참조로 계속 사용할 수 있습니다.

스레드 루트 첨부 파일 상속

메시지가 스레드에 도착하는 경우(thread_ts 부모가 있음):
  • 답글 자체에 직접 미디어가 없고 포함된 루트 메시지에 파일이 있으면, Slack은 루트 파일을 스레드 시작 컨텍스트로 수화할 수 있습니다.
  • 직접 답글 첨부 파일은 루트 메시지 첨부 파일보다 우선합니다.
  • 파일만 있고 텍스트가 없는 루트 메시지는 폴백이 해당 파일을 계속 포함할 수 있도록 첨부 파일 플레이스홀더로 표현됩니다.

다중 첨부 파일 처리

하나의 Slack 메시지에 여러 파일 첨부가 포함된 경우:
  • 각 첨부 파일은 미디어 파이프라인을 통해 독립적으로 처리됩니다.
  • 다운로드된 미디어 참조는 메시지 컨텍스트로 집계됩니다.
  • 처리 순서는 이벤트 페이로드의 Slack 파일 순서를 따릅니다.
  • 한 첨부 파일의 다운로드 실패가 다른 첨부 파일을 차단하지 않습니다.

크기, 다운로드, 모델 제한

  • 크기 한도: 기본값은 파일당 20 MB입니다. channels.slack.mediaMaxMb를 통해 구성할 수 있습니다.
  • 다운로드 실패: Slack이 제공할 수 없는 파일, 만료된 URL, 접근할 수 없는 파일, 크기 초과 파일, Slack 인증/로그인 HTML 응답은 지원되지 않는 형식으로 보고되지 않고 건너뜁니다.
  • 비전 모델: 이미지 분석은 비전을 지원하는 경우 활성 응답 모델을 사용하거나, agents.defaults.imageModel에 구성된 이미지 모델을 사용합니다.

알려진 제한

시나리오현재 동작우회 방법
만료된 Slack 파일 URL파일을 건너뜀. 오류는 표시되지 않음Slack에 파일을 다시 업로드
비전 모델이 구성되지 않음이미지 첨부 파일은 미디어 참조로 저장되지만 이미지로 분석되지 않음agents.defaults.imageModel을 구성하거나 비전 지원 응답 모델 사용
매우 큰 이미지(기본값 기준 > 20 MB)크기 한도에 따라 건너뜀Slack이 허용하는 경우 channels.slack.mediaMaxMb 증가
전달/공유된 첨부 파일텍스트와 Slack 호스팅 이미지/파일 미디어는 최선 노력 방식으로 처리됨OpenClaw 스레드에서 직접 다시 공유
PDF 첨부 파일파일/미디어 컨텍스트로 저장되며 이미지 비전을 통해 자동 라우팅되지 않음파일 메타데이터에는 download-file을 사용하거나 PDF 분석에는 pdf 도구 사용

관련 문서

관련 항목

페어링

Slack 사용자를 Gateway에 페어링합니다.

그룹

채널 및 그룹 DM 동작.

채널 라우팅

인바운드 메시지를 에이전트로 라우팅합니다.

보안

위협 모델과 강화.

구성

구성 레이아웃과 우선순위.

슬래시 명령

명령 카탈로그와 동작.