MCPcopy
hub / github.com/wwebjs/whatsapp-web.js

github.com/wwebjs/whatsapp-web.js @v1.34.7 sqlite

repository ↗ · DeepWiki ↗ · release v1.34.7 ↗
606 symbols 1,114 edges 62 files 265 documented · 44%
README
    <a href="https://wwebjs.dev">
        <img src="https://github.com/wwebjs/Assets/blob/main/Collection/GitHub/whatsapp-web.js.png?raw=true"
            title="whatsapp-web.js" alt="WWebJS Website" />
    </a>






    <a href="https://www.npmjs.com/package/whatsapp-web.js"><img
            src="https://img.shields.io/npm/v/whatsapp-web.js.svg" alt="npm" /></a>
    <a href="https://www.npmjs.com/package/whatsapp-web.js"><img alt="NPM Downloads"
            src="https://img.shields.io/npm/d18m/whatsapp-web.js" /></a>
    <a href="https://github.com/wwebjs/whatsapp-web.js/graphs/contributors"><img alt="GitHub contributors"
            src="https://img.shields.io/github/contributors-anon/wwebjs/whatsapp-web.js" /></a>
    <a href="https://depfu.com/github/wwebjs/whatsapp-web.js?project_id=9765"><img
            src="https://badges.depfu.com/badges/4a65a0de96ece65fdf39e294e0c8dcba/overview.svg" alt="Depfu" /></a>
    <a href="https://discord.wwebjs.dev"><img
            src="https://img.shields.io/discord/698610475432411196.svg?logo=discord" alt="Discord server" /></a>

About

whatsapp‑web.js is a powerful Node.js library that lets you interact with WhatsApp Web, making it easy to build a dynamic WhatsApp API with nearly all features of the web client. It uses Puppeteer to access WhatsApp Web’s internal functions and runs them in a managed browser instance to reduce the risk of being blocked.

Links

Installation

Node.js v18.0.0 or higher, is required.

npm install whatsapp-web.js
yarn add whatsapp-web.js
pnpm add whatsapp-web.js

Having trouble installing? Take a peak at the Guide for more detailed instructions.

Example usage

const { Client } = require('whatsapp-web.js');
const qrcode = require('qrcode-terminal');

const client = new Client();

client.on('qr', (qr) => {
    qrcode.generate(qr, { small: true });
});

client.on('ready', () => {
    console.log('Client is ready!');
});

client.on('message', (msg) => {
    if (msg.body == '!ping') {
        msg.reply('pong');
    }
});

client.initialize();

Take a look at example.js for additional examples and use cases.
For more details on saving and restoring sessions, check out the Authentication Strategies.

Supported features

Feature Status
Multi Device
Send messages
Receive messages
Send media (images/audio/documents)
Send media (video) (requires Google Chrome)
Send stickers
Receive media (images/audio/video/documents)
Send contact cards
Send location
Send buttons (DEPRECATED)
Send lists (DEPRECATED)
Receive location
Message replies
Join groups by invite
Get invite for group
Modify group info (subject, description)
Modify group settings (send messages, edit info)
Add group participants
Kick group participants
Promote/demote group participants
Mention users
Mention groups
Mute/unmute chats
Block/unblock contacts
Get contact info
Get profile pictures
Set user status message
React to messages
Create polls
Channels
Vote in polls
Communities 🔜

Something missing? Make an issue and let us know!

Supporting the project

You can support the maintainer of this project through the links below:

Contributing

Feel free to open pull requests; we welcome contributions! However, for significant changes, it's best to open an issue beforehand. Make sure to review our contribution guidelines before creating a pull request. Before creating your own issue or pull request, always check to see if one already exists!

Disclaimer

This project is not affiliated, associated, authorized, endorsed by, or in any way officially connected with WhatsApp or any of its subsidiaries or its affiliates. The official WhatsApp website can be found at whatsapp.com. "WhatsApp" as well as related names, marks, emblems and images are registered trademarks of their respective owners. Also it is not guaranteed you will not be blocked by using this method. WhatsApp does not allow bots or unofficial clients on their platform, so this shouldn't be considered totally safe.

License

Copyright 2019 Pedro S Lopez

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this project except in compliance with the License.
You may obtain a copy of the License at https://www.apache.org/licenses/LICENSE-2.0.

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Extension points exported contracts — how you extend this code

Contact (Interface)
(no doc) [2 implementers]
index.d.ts
Channel (Interface)
(no doc) [1 implementers]
index.d.ts
ClientInfo (Interface)
(no doc)
index.d.ts
ClientInfoPhone (Interface)
(no doc)
index.d.ts
ClientOptions (Interface)
(no doc)
index.d.ts

Core symbols most depended-on inside this repo

getChat
called by 52
src/structures/Contact.js
sendMessage
called by 44
index.d.ts
getChatById
called by 35
src/Client.js
o
called by 32
docs/scripts/tree.jquery.js
reply
called by 29
src/structures/Message.js
exposeFunctionIfAbsent
called by 24
src/util/Puppeteer.js
getContactById
called by 15
src/Client.js
S
called by 15
docs/scripts/prettify.js

Shape

Method 320
Function 120
Class 107
Interface 52
Enum 7

Languages

TypeScript100%

Modules by API surface

index.d.ts99 symbols
src/Client.js94 symbols
docs/scripts/jquery.min.js83 symbols
src/structures/Message.js30 symbols
src/structures/Chat.js27 symbols
src/structures/GroupChat.js25 symbols
src/structures/Channel.js23 symbols
docs/scripts/prettify.js17 symbols
src/authStrategies/RemoteAuth.js16 symbols
src/util/InterfaceController.js13 symbols
src/structures/Contact.js13 symbols
src/authStrategies/BaseAuthStrategy.js12 symbols

Used by 1 indexed graphs manifest dependencies, hub-wide

Dependencies from manifests, versioned

@commitlint/cli20.4.3 · 1×
@commitlint/config-conventional20.4.3 · 1×
@eslint/js9.39.4 · 1×
@types/node-fetch2.6.13 · 1×
chai4.5.0 · 1×
chai-as-promised7.1.2 · 1×
dotenv16.6.1 · 1×
eslint9.39.4 · 1×
eslint-config-prettier10.1.8 · 1×
eslint-plugin-mocha11.2.0 · 1×
fluent-ffmpeg2.1.3 · 1×

For agents

$ claude mcp add whatsapp-web.js \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact