{
  "schemaVersion": "1.0",
  "item": {
    "slug": "whatsapp-ultimate",
    "name": "Whatsapp Ultimate",
    "source": "tencent",
    "type": "skill",
    "category": "通讯协作",
    "sourceUrl": "https://clawhub.ai/globalcaos/whatsapp-ultimate",
    "canonicalUrl": "https://clawhub.ai/globalcaos/whatsapp-ultimate",
    "targetPlatform": "OpenClaw"
  },
  "install": {
    "downloadMode": "redirect",
    "downloadUrl": "/downloads/whatsapp-ultimate",
    "sourceDownloadUrl": "https://clawhub.ai/api/v1/download?slug=whatsapp-ultimate",
    "sourcePlatform": "tencent",
    "targetPlatform": "OpenClaw",
    "installMethod": "Manual import",
    "extraction": "Extract archive",
    "prerequisites": [
      "OpenClaw"
    ],
    "packageFormat": "ZIP package",
    "includedAssets": [
      "SKILL.md",
      "description.md",
      "scripts/apply-history-fix.sh",
      "scripts/apply-model-prefix.sh",
      "scripts/wa-create-group.ts",
      "scripts/wa-fetch-contacts.ts"
    ],
    "primaryDoc": "SKILL.md",
    "quickSetup": [
      "Download the package from Yavira.",
      "Extract the archive and review SKILL.md first.",
      "Import or place the package into your OpenClaw setup."
    ],
    "agentAssist": {
      "summary": "Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.",
      "steps": [
        "Download the package from Yavira.",
        "Extract it into a folder your agent can access.",
        "Paste one of the prompts below and point your agent at the extracted folder."
      ],
      "prompts": [
        {
          "label": "New install",
          "body": "I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete."
        },
        {
          "label": "Upgrade existing",
          "body": "I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run."
        }
      ]
    },
    "sourceHealth": {
      "source": "tencent",
      "status": "healthy",
      "reason": "direct_download_ok",
      "recommendedAction": "download",
      "checkedAt": "2026-04-30T16:55:25.780Z",
      "expiresAt": "2026-05-07T16:55:25.780Z",
      "httpStatus": 200,
      "finalUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=network",
      "contentType": "application/zip",
      "probeMethod": "head",
      "details": {
        "probeUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=network",
        "contentDisposition": "attachment; filename=\"network-1.0.0.zip\"",
        "redirectLocation": null,
        "bodySnippet": null
      },
      "scope": "source",
      "summary": "Source download looks usable.",
      "detail": "Yavira can redirect you to the upstream package for this source.",
      "primaryActionLabel": "Download for OpenClaw",
      "primaryActionHref": "/downloads/whatsapp-ultimate"
    },
    "validation": {
      "installChecklist": [
        "Use the Yavira download entry.",
        "Review SKILL.md after the package is downloaded.",
        "Confirm the extracted package contains the expected setup assets."
      ],
      "postInstallChecks": [
        "Confirm the extracted package includes the expected docs or setup files.",
        "Validate the skill or prompts are available in your target agent workspace.",
        "Capture any manual follow-up steps the agent could not complete."
      ]
    },
    "downloadPageUrl": "https://openagent3.xyz/downloads/whatsapp-ultimate",
    "agentPageUrl": "https://openagent3.xyz/skills/whatsapp-ultimate/agent",
    "manifestUrl": "https://openagent3.xyz/skills/whatsapp-ultimate/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/whatsapp-ultimate/agent.md"
  },
  "agentAssist": {
    "summary": "Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.",
    "steps": [
      "Download the package from Yavira.",
      "Extract it into a folder your agent can access.",
      "Paste one of the prompts below and point your agent at the extracted folder."
    ],
    "prompts": [
      {
        "label": "New install",
        "body": "I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete."
      },
      {
        "label": "Upgrade existing",
        "body": "I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run."
      }
    ]
  },
  "documentation": {
    "source": "clawhub",
    "primaryDoc": "SKILL.md",
    "sections": [
      {
        "title": "WhatsApp Ultimate",
        "body": "Everything you can do in WhatsApp, your AI agent can do too.\n\nThis skill documents all WhatsApp capabilities available through OpenClaw's native channel integration. No external Docker services, no CLI wrappers — just direct WhatsApp Web protocol via Baileys."
      },
      {
        "title": "Prerequisites",
        "body": "OpenClaw with WhatsApp channel configured\nWhatsApp account linked via QR code (openclaw whatsapp login)"
      },
      {
        "title": "Capabilities Overview",
        "body": "CategoryFeaturesMessagingText, media, polls, stickers, voice notes, GIFsInteractionsReactions, replies/quotes, edit, unsendGroupsCreate, rename, icon, description, participants, admin, invite links\n\nTotal: 22 distinct actions"
      },
      {
        "title": "Send Text",
        "body": "message action=send channel=whatsapp to=\"+34612345678\" message=\"Hello!\""
      },
      {
        "title": "Send Media (Image/Video/Document)",
        "body": "message action=send channel=whatsapp to=\"+34612345678\" message=\"Check this out\" filePath=/path/to/image.jpg\n\nSupported: JPG, PNG, GIF, MP4, PDF, DOC, etc."
      },
      {
        "title": "Send Poll",
        "body": "message action=poll channel=whatsapp to=\"+34612345678\" pollQuestion=\"What time?\" pollOption=[\"3pm\", \"4pm\", \"5pm\"]"
      },
      {
        "title": "Send Sticker",
        "body": "message action=sticker channel=whatsapp to=\"+34612345678\" filePath=/path/to/sticker.webp\n\nMust be WebP format, ideally 512x512."
      },
      {
        "title": "Send Voice Note",
        "body": "message action=send channel=whatsapp to=\"+34612345678\" filePath=/path/to/audio.ogg asVoice=true\n\nCritical: Use OGG/Opus format for WhatsApp voice notes. MP3 may not play correctly."
      },
      {
        "title": "Send GIF",
        "body": "message action=send channel=whatsapp to=\"+34612345678\" filePath=/path/to/animation.mp4 gifPlayback=true\n\nConvert GIF to MP4 first (WhatsApp requires this):\n\nffmpeg -i input.gif -movflags faststart -pix_fmt yuv420p -vf \"scale=trunc(iw/2)*2:trunc(ih/2)*2\" output.mp4 -y"
      },
      {
        "title": "Add Reaction",
        "body": "message action=react channel=whatsapp chatJid=\"34612345678@s.whatsapp.net\" messageId=\"ABC123\" emoji=\"🚀\""
      },
      {
        "title": "Remove Reaction",
        "body": "message action=react channel=whatsapp chatJid=\"34612345678@s.whatsapp.net\" messageId=\"ABC123\" remove=true"
      },
      {
        "title": "Reply/Quote Message",
        "body": "message action=reply channel=whatsapp to=\"34612345678@s.whatsapp.net\" replyTo=\"QUOTED_MSG_ID\" message=\"Replying to this!\""
      },
      {
        "title": "Edit Message (Own Messages Only)",
        "body": "message action=edit channel=whatsapp chatJid=\"34612345678@s.whatsapp.net\" messageId=\"ABC123\" message=\"Updated text\""
      },
      {
        "title": "Unsend/Delete Message",
        "body": "message action=unsend channel=whatsapp chatJid=\"34612345678@s.whatsapp.net\" messageId=\"ABC123\""
      },
      {
        "title": "Create Group",
        "body": "message action=group-create channel=whatsapp name=\"Project Team\" participants=[\"+34612345678\", \"+34687654321\"]"
      },
      {
        "title": "Rename Group",
        "body": "message action=renameGroup channel=whatsapp groupId=\"123456789@g.us\" name=\"New Name\""
      },
      {
        "title": "Set Group Icon",
        "body": "message action=setGroupIcon channel=whatsapp groupId=\"123456789@g.us\" filePath=/path/to/icon.jpg"
      },
      {
        "title": "Set Group Description",
        "body": "message action=setGroupDescription channel=whatsapp groupJid=\"123456789@g.us\" description=\"Team chat for Q1 project\""
      },
      {
        "title": "Add Participant",
        "body": "message action=addParticipant channel=whatsapp groupId=\"123456789@g.us\" participant=\"+34612345678\""
      },
      {
        "title": "Remove Participant",
        "body": "message action=removeParticipant channel=whatsapp groupId=\"123456789@g.us\" participant=\"+34612345678\""
      },
      {
        "title": "Promote to Admin",
        "body": "message action=promoteParticipant channel=whatsapp groupJid=\"123456789@g.us\" participants=[\"+34612345678\"]"
      },
      {
        "title": "Demote from Admin",
        "body": "message action=demoteParticipant channel=whatsapp groupJid=\"123456789@g.us\" participants=[\"+34612345678\"]"
      },
      {
        "title": "Leave Group",
        "body": "message action=leaveGroup channel=whatsapp groupId=\"123456789@g.us\""
      },
      {
        "title": "Get Invite Link",
        "body": "message action=getInviteCode channel=whatsapp groupJid=\"123456789@g.us\"\n\nReturns: https://chat.whatsapp.com/XXXXX"
      },
      {
        "title": "Revoke Invite Link",
        "body": "message action=revokeInviteCode channel=whatsapp groupJid=\"123456789@g.us\""
      },
      {
        "title": "Get Group Info",
        "body": "message action=getGroupInfo channel=whatsapp groupJid=\"123456789@g.us\"\n\nReturns: name, description, participants, admins, creation date."
      },
      {
        "title": "JID Formats",
        "body": "WhatsApp uses JIDs (Jabber IDs) internally:\n\nTypeFormatExampleIndividual<number>@s.whatsapp.net34612345678@s.whatsapp.netGroup<id>@g.us123456789012345678@g.us\n\nWhen using to= with phone numbers, OpenClaw auto-converts to JID format."
      },
      {
        "title": "Voice Notes",
        "body": "Always use OGG/Opus format:\n\nffmpeg -i input.wav -c:a libopus -b:a 64k output.ogg"
      },
      {
        "title": "Stickers",
        "body": "Convert images to WebP stickers:\n\nffmpeg -i input.png -vf \"scale=512:512:force_original_aspect_ratio=decrease,pad=512:512:(ow-iw)/2:(oh-ih)/2:color=0x00000000\" output.webp"
      },
      {
        "title": "Acknowledgment Messages (ackMessage)",
        "body": "Send an instant text message when an inbound message is received — fires at gateway level before model inference:\n\n{\n  \"channels\": {\n    \"whatsapp\": {\n      \"ackMessage\": {\n        \"text\": \"⚡\",\n        \"direct\": true,\n        \"group\": \"never\"\n      }\n    }\n  }\n}\n\nFieldTypeDefaultDescriptiontextstring\"\"Message to send (empty = disabled)directbooleantrueSend in direct chatsgroup\"always\" / \"mentions\" / \"never\"\"never\"Group behavior\n\nThis is different from ackReaction (which sends an emoji reaction). ackMessage sends a standalone message bubble — visible in WhatsApp Web even when reaction flips aren't."
      },
      {
        "title": "Rate Limits",
        "body": "WhatsApp has anti-spam measures. Avoid:\n\nBulk messaging to many contacts\nRapid-fire messages\nMessages to contacts who haven't messaged you first"
      },
      {
        "title": "Message IDs",
        "body": "To react/edit/unsend, you need the message ID. Incoming messages include this in the event payload. For your own sent messages, the send response includes the ID."
      },
      {
        "title": "Comparison with Other Skills",
        "body": "Featurewhatsapp-ultimatewacliwhatsapp-automationgif-whatsappNative integration✅❌ (CLI)❌ (Docker)N/ASend text✅✅❌❌Send media✅✅❌❌Polls✅❌❌❌Stickers✅❌❌❌Voice notes✅❌❌❌GIFs✅❌❌✅Reactions✅❌❌❌Reply/Quote✅❌❌❌Edit✅❌❌❌Unsend✅❌❌❌Group create✅❌❌❌Group management✅ (full)❌❌❌Receive messages✅✅✅❌Two-way chat✅❌❌❌External depsNoneGo binaryDocker + WAHAffmpeg"
      },
      {
        "title": "Media Download (from History)",
        "body": "Download images, videos, documents, and audio from past WhatsApp messages stored in the history database. Uses Baileys' downloadContentFromMessage with the media keys stored in raw_json — no active socket needed."
      },
      {
        "title": "List Recent Media",
        "body": "cd ~/src/tinkerclaw && npx tsx src/whatsapp-history/download-media.ts --list-media [--since YYYY-MM-DD] [--chat <jid|name>] [--limit N]"
      },
      {
        "title": "Download by Message ID",
        "body": "cd ~/src/tinkerclaw && npx tsx src/whatsapp-history/download-media.ts --id <messageId> [--out <directory>]\n\nDefault output: ~/.openclaw/workspace/data/wa-media/<messageId>.<ext>"
      },
      {
        "title": "Notes",
        "body": "Media URLs on WhatsApp servers expire after ~2 weeks. Download promptly.\nWorks for: images, videos, documents, audio, stickers, voice notes.\nExtension auto-detected from the message's mimetype.\nThe raw_json column in the messages table must contain the original Baileys proto (live-captured messages only, not imported .txt exports)."
      },
      {
        "title": "3.5.1",
        "body": "Added: Media download from history — download-media.ts script extracts media keys from stored raw_json and downloads/decrypts directly from WhatsApp CDN without needing an active socket connection."
      },
      {
        "title": "3.5.0",
        "body": "Added: ackMessage — gateway-level instant message acknowledgment. Sends a configurable text message (e.g. ⚡) the moment an inbound message arrives, before any model inference. Fires at the same speed as ackReaction (emoji flip). Useful as a visual cue to distinguish your messages from bot replies in WhatsApp Web where reaction flips aren't visible."
      },
      {
        "title": "3.4.0",
        "body": "Fixed: Chat search now resolves LID/JID aliases — searching by chat name finds messages across both @lid and @s.whatsapp.net JID formats\nAdded: resolveChatJids() cross-references chats, contacts, and messages tables to discover all JID aliases for a given chat filter\nImproved: Search falls back to original LIKE behaviour if no JIDs resolve, so no regressions"
      },
      {
        "title": "3.0.0",
        "body": "Your Agent\n    ↓\nOpenClaw message tool\n    ↓\nWhatsApp Channel Plugin\n    ↓\nBaileys (WhatsApp Web Protocol)\n    ↓\nWhatsApp Servers\n\nNo external services. No Docker. No CLI tools. Direct protocol integration."
      },
      {
        "title": "License",
        "body": "MIT — Part of OpenClaw"
      },
      {
        "title": "Pairs Well With",
        "body": "outlook-hack — same philosophy for Outlook: reads everything, drafts replies, won't send\nteams-hack — Teams integration with the same browser-relay approach\nagent-superpowers — engineering discipline for the agent running behind these channels\n\n👉 https://github.com/globalcaos/tinkerclaw\n\nClone it. Fork it. Break it. Make it yours."
      }
    ],
    "body": "WhatsApp Ultimate\n\nEverything you can do in WhatsApp, your AI agent can do too.\n\nThis skill documents all WhatsApp capabilities available through OpenClaw's native channel integration. No external Docker services, no CLI wrappers — just direct WhatsApp Web protocol via Baileys.\n\nPrerequisites\nOpenClaw with WhatsApp channel configured\nWhatsApp account linked via QR code (openclaw whatsapp login)\nCapabilities Overview\nCategory\tFeatures\nMessaging\tText, media, polls, stickers, voice notes, GIFs\nInteractions\tReactions, replies/quotes, edit, unsend\nGroups\tCreate, rename, icon, description, participants, admin, invite links\n\nTotal: 22 distinct actions\n\nMessaging\nSend Text\nmessage action=send channel=whatsapp to=\"+34612345678\" message=\"Hello!\"\n\nSend Media (Image/Video/Document)\nmessage action=send channel=whatsapp to=\"+34612345678\" message=\"Check this out\" filePath=/path/to/image.jpg\n\n\nSupported: JPG, PNG, GIF, MP4, PDF, DOC, etc.\n\nSend Poll\nmessage action=poll channel=whatsapp to=\"+34612345678\" pollQuestion=\"What time?\" pollOption=[\"3pm\", \"4pm\", \"5pm\"]\n\nSend Sticker\nmessage action=sticker channel=whatsapp to=\"+34612345678\" filePath=/path/to/sticker.webp\n\n\nMust be WebP format, ideally 512x512.\n\nSend Voice Note\nmessage action=send channel=whatsapp to=\"+34612345678\" filePath=/path/to/audio.ogg asVoice=true\n\n\nCritical: Use OGG/Opus format for WhatsApp voice notes. MP3 may not play correctly.\n\nSend GIF\nmessage action=send channel=whatsapp to=\"+34612345678\" filePath=/path/to/animation.mp4 gifPlayback=true\n\n\nConvert GIF to MP4 first (WhatsApp requires this):\n\nffmpeg -i input.gif -movflags faststart -pix_fmt yuv420p -vf \"scale=trunc(iw/2)*2:trunc(ih/2)*2\" output.mp4 -y\n\nInteractions\nAdd Reaction\nmessage action=react channel=whatsapp chatJid=\"34612345678@s.whatsapp.net\" messageId=\"ABC123\" emoji=\"🚀\"\n\nRemove Reaction\nmessage action=react channel=whatsapp chatJid=\"34612345678@s.whatsapp.net\" messageId=\"ABC123\" remove=true\n\nReply/Quote Message\nmessage action=reply channel=whatsapp to=\"34612345678@s.whatsapp.net\" replyTo=\"QUOTED_MSG_ID\" message=\"Replying to this!\"\n\nEdit Message (Own Messages Only)\nmessage action=edit channel=whatsapp chatJid=\"34612345678@s.whatsapp.net\" messageId=\"ABC123\" message=\"Updated text\"\n\nUnsend/Delete Message\nmessage action=unsend channel=whatsapp chatJid=\"34612345678@s.whatsapp.net\" messageId=\"ABC123\"\n\nGroup Management\nCreate Group\nmessage action=group-create channel=whatsapp name=\"Project Team\" participants=[\"+34612345678\", \"+34687654321\"]\n\nRename Group\nmessage action=renameGroup channel=whatsapp groupId=\"123456789@g.us\" name=\"New Name\"\n\nSet Group Icon\nmessage action=setGroupIcon channel=whatsapp groupId=\"123456789@g.us\" filePath=/path/to/icon.jpg\n\nSet Group Description\nmessage action=setGroupDescription channel=whatsapp groupJid=\"123456789@g.us\" description=\"Team chat for Q1 project\"\n\nAdd Participant\nmessage action=addParticipant channel=whatsapp groupId=\"123456789@g.us\" participant=\"+34612345678\"\n\nRemove Participant\nmessage action=removeParticipant channel=whatsapp groupId=\"123456789@g.us\" participant=\"+34612345678\"\n\nPromote to Admin\nmessage action=promoteParticipant channel=whatsapp groupJid=\"123456789@g.us\" participants=[\"+34612345678\"]\n\nDemote from Admin\nmessage action=demoteParticipant channel=whatsapp groupJid=\"123456789@g.us\" participants=[\"+34612345678\"]\n\nLeave Group\nmessage action=leaveGroup channel=whatsapp groupId=\"123456789@g.us\"\n\nGet Invite Link\nmessage action=getInviteCode channel=whatsapp groupJid=\"123456789@g.us\"\n\n\nReturns: https://chat.whatsapp.com/XXXXX\n\nRevoke Invite Link\nmessage action=revokeInviteCode channel=whatsapp groupJid=\"123456789@g.us\"\n\nGet Group Info\nmessage action=getGroupInfo channel=whatsapp groupJid=\"123456789@g.us\"\n\n\nReturns: name, description, participants, admins, creation date.\n\nJID Formats\n\nWhatsApp uses JIDs (Jabber IDs) internally:\n\nType\tFormat\tExample\nIndividual\t<number>@s.whatsapp.net\t34612345678@s.whatsapp.net\nGroup\t<id>@g.us\t123456789012345678@g.us\n\nWhen using to= with phone numbers, OpenClaw auto-converts to JID format.\n\nTips\nVoice Notes\n\nAlways use OGG/Opus format:\n\nffmpeg -i input.wav -c:a libopus -b:a 64k output.ogg\n\nStickers\n\nConvert images to WebP stickers:\n\nffmpeg -i input.png -vf \"scale=512:512:force_original_aspect_ratio=decrease,pad=512:512:(ow-iw)/2:(oh-ih)/2:color=0x00000000\" output.webp\n\nAcknowledgment Messages (ackMessage)\n\nSend an instant text message when an inbound message is received — fires at gateway level before model inference:\n\n{\n  \"channels\": {\n    \"whatsapp\": {\n      \"ackMessage\": {\n        \"text\": \"⚡\",\n        \"direct\": true,\n        \"group\": \"never\"\n      }\n    }\n  }\n}\n\nField\tType\tDefault\tDescription\ntext\tstring\t\"\"\tMessage to send (empty = disabled)\ndirect\tboolean\ttrue\tSend in direct chats\ngroup\t\"always\" / \"mentions\" / \"never\"\t\"never\"\tGroup behavior\n\nThis is different from ackReaction (which sends an emoji reaction). ackMessage sends a standalone message bubble — visible in WhatsApp Web even when reaction flips aren't.\n\nRate Limits\n\nWhatsApp has anti-spam measures. Avoid:\n\nBulk messaging to many contacts\nRapid-fire messages\nMessages to contacts who haven't messaged you first\nMessage IDs\n\nTo react/edit/unsend, you need the message ID. Incoming messages include this in the event payload. For your own sent messages, the send response includes the ID.\n\nComparison with Other Skills\nFeature\twhatsapp-ultimate\twacli\twhatsapp-automation\tgif-whatsapp\nNative integration\t✅\t❌ (CLI)\t❌ (Docker)\tN/A\nSend text\t✅\t✅\t❌\t❌\nSend media\t✅\t✅\t❌\t❌\nPolls\t✅\t❌\t❌\t❌\nStickers\t✅\t❌\t❌\t❌\nVoice notes\t✅\t❌\t❌\t❌\nGIFs\t✅\t❌\t❌\t✅\nReactions\t✅\t❌\t❌\t❌\nReply/Quote\t✅\t❌\t❌\t❌\nEdit\t✅\t❌\t❌\t❌\nUnsend\t✅\t❌\t❌\t❌\nGroup create\t✅\t❌\t❌\t❌\nGroup management\t✅ (full)\t❌\t❌\t❌\nReceive messages\t✅\t✅\t✅\t❌\nTwo-way chat\t✅\t❌\t❌\t❌\nExternal deps\tNone\tGo binary\tDocker + WAHA\tffmpeg\nMedia Download (from History)\n\nDownload images, videos, documents, and audio from past WhatsApp messages stored in the history database. Uses Baileys' downloadContentFromMessage with the media keys stored in raw_json — no active socket needed.\n\nList Recent Media\ncd ~/src/tinkerclaw && npx tsx src/whatsapp-history/download-media.ts --list-media [--since YYYY-MM-DD] [--chat <jid|name>] [--limit N]\n\nDownload by Message ID\ncd ~/src/tinkerclaw && npx tsx src/whatsapp-history/download-media.ts --id <messageId> [--out <directory>]\n\n\nDefault output: ~/.openclaw/workspace/data/wa-media/<messageId>.<ext>\n\nNotes\nMedia URLs on WhatsApp servers expire after ~2 weeks. Download promptly.\nWorks for: images, videos, documents, audio, stickers, voice notes.\nExtension auto-detected from the message's mimetype.\nThe raw_json column in the messages table must contain the original Baileys proto (live-captured messages only, not imported .txt exports).\n3.5.1\nAdded: Media download from history — download-media.ts script extracts media keys from stored raw_json and downloads/decrypts directly from WhatsApp CDN without needing an active socket connection.\n3.5.0\nAdded: ackMessage — gateway-level instant message acknowledgment. Sends a configurable text message (e.g. ⚡) the moment an inbound message arrives, before any model inference. Fires at the same speed as ackReaction (emoji flip). Useful as a visual cue to distinguish your messages from bot replies in WhatsApp Web where reaction flips aren't visible.\n3.4.0\nFixed: Chat search now resolves LID/JID aliases — searching by chat name finds messages across both @lid and @s.whatsapp.net JID formats\nAdded: resolveChatJids() cross-references chats, contacts, and messages tables to discover all JID aliases for a given chat filter\nImproved: Search falls back to original LIKE behaviour if no JIDs resolve, so no regressions\n3.0.0\nYour Agent\n    ↓\nOpenClaw message tool\n    ↓\nWhatsApp Channel Plugin\n    ↓\nBaileys (WhatsApp Web Protocol)\n    ↓\nWhatsApp Servers\n\n\nNo external services. No Docker. No CLI tools. Direct protocol integration.\n\nLicense\n\nMIT — Part of OpenClaw\n\nPairs Well With\noutlook-hack — same philosophy for Outlook: reads everything, drafts replies, won't send\nteams-hack — Teams integration with the same browser-relay approach\nagent-superpowers — engineering discipline for the agent running behind these channels\n\n👉 https://github.com/globalcaos/tinkerclaw\n\nClone it. Fork it. Break it. Make it yours."
  },
  "trust": {
    "sourceLabel": "tencent",
    "provenanceUrl": "https://clawhub.ai/globalcaos/whatsapp-ultimate",
    "publisherUrl": "https://clawhub.ai/globalcaos/whatsapp-ultimate",
    "owner": "globalcaos",
    "version": "1.4.0",
    "license": null,
    "verificationStatus": "Indexed source record"
  },
  "links": {
    "detailUrl": "https://openagent3.xyz/skills/whatsapp-ultimate",
    "downloadUrl": "https://openagent3.xyz/downloads/whatsapp-ultimate",
    "agentUrl": "https://openagent3.xyz/skills/whatsapp-ultimate/agent",
    "manifestUrl": "https://openagent3.xyz/skills/whatsapp-ultimate/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/whatsapp-ultimate/agent.md"
  }
}