Coder Social home page Coder Social logo

zhouao / chrishubert-whatsapp-api Goto Github PK

View Code? Open in Web Editor NEW

This project forked from chrishubert/whatsapp-api

0.0 0.0 0.0 1017 KB

This project is a REST API wrapper for the whatsapp-web.js library, providing an easy-to-use interface to interact with the WhatsApp Web platform.

Home Page: https://www.christophehubert.com

License: Other

JavaScript 99.50% Dockerfile 0.50%

chrishubert-whatsapp-api's Introduction

WhatsApp REST API

REST API wrapper for the whatsapp-web.js library, providing an easy-to-use interface to interact with the WhatsApp Web platform. It is designed to be used as a docker container, scalable, secure, and easy to integrate with other non-NodeJs projects.

This project is a work in progress: star it, create issues, features or pull requests ❣️

NOTE: I can't guarantee you will not be blocked by using this method, although it has worked for me. WhatsApp does not allow bots or unofficial clients on their platform, so this shouldn't be considered totally safe.

Table of Contents

1. Quick Start with Docker

2. Features

3. Run Locally

4. Testing

5. Documentation

6. Deploy to Production

7. Contributing

8. License

9. Star History

Quick Start with Docker

dockeri.co

  1. Clone the repository:
git clone https://github.com/chrishubert/whatsapp-api.git
cd whatsapp-api
  1. Run the Docker Compose:
docker-compose pull && docker-compose up
  1. Visit http://localhost:3000/session/start/ABCD

  2. Scan the QR on your console using WhatsApp mobile app -> Linked Device -> Link a Device (it may take time to setup the session)

  3. Visit http://localhost:3000/client/getContacts/ABCD

  4. EXTRA: Look at all the callbacks data in ./session/message_log.txt

Quick Start

Features

  1. API and Callbacks
Actions Status Sessions Status Callbacks Status
Send Image Message Initiate session Callback QR code
Send Video Message Terminate session Callback new message
Send Audio Message Terminate inactive sessions Callback status change
Send Document Message Terminate all sessions Callback message media attachment
Send File URL Healthcheck
Send Button Message Local test callback
Send Contact Message
Send List Message
Set Status
Send Button With Media
Is On Whatsapp?
Download Profile Pic
User Status
Block/Unblock User
Update Profile Picture
Create Group
Leave Group
All Groups
Invite User
Make Admin
Demote Admin
Group Invite Code
Update Group Participants
Update Group Setting
Update Group Subject
Update Group Description
  1. Handle multiple client sessions (session data saved locally), identified by unique id

  2. All endpoints may be secured by a global API key

  3. On server start, all existing sessions are restored

  4. Set messages automatically as read

  5. Disable any of the callbacks

Run Locally

  1. Clone the repository:
git clone https://github.com/chrishubert/whatsapp-api.git
cd whatsapp-api
  1. Install the dependencies:
npm install
  1. Copy the .env.example file to .env and update the required environment variables:
cp .env.example .env
  1. Run the application:
npm run start
  1. Access the API at http://localhost:3000

Testing

Run the test suite with the following command:

npm run test

Documentation

API documentation can be found in the swagger.json file. See this file directly into Swagger Editor or any other OpenAPI-compatible tool to view and interact with the API documentation.

This documentation is straightforward if you are familiar with whatsapp-web.js library (https://docs.wwebjs.dev/) If you are still confused - open an issue and I'll improve it.

Also, there is an option to run the documentation endpoint locally by setting the ENABLE_SWAGGER_ENDPOINT environment variable. Restart the service and go to /api-docs endpoint to see it.

By default, all callback events are delivered to the webhook defined with the BASE_WEBHOOK_URL environment variable. This can be overridden by setting the *_WEBHOOK_URL environment variable, where * is your sessionId. For example, if you have the sessionId defined as DEMO, the environment variable must be DEMO_WEBHOOK_URL.

By setting the DISABLED_CALLBACKS environment variable you can specify what events you are not willing to receive on your webhook.

Scanning QR code

In order to validate a new WhatsApp Web instance you need to scan the QR code using your mobile phone. Official documentation can be found at (https://faq.whatsapp.com/1079327266110265/?cms_platform=android) page. The service itself delivers the QR code content as a webhook event or you can use the REST endpoints (/session/qr/:sessionId or /session/qr/:sessionId/image to get the QR code as a png image).

Deploy to Production

  • Load the docker image in docker-compose, or your Kubernetes environment
  • Disable the ENABLE_LOCAL_CALLBACK_EXAMPLE environment variable
  • Set the API_KEY environment variable to protect the REST endpoints
  • Run periodically the /api/terminateInactiveSessions endpoint to prevent useless sessions to take up space and resources(only in case you are not in control of the sessions)

Contributing

Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.

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 https://whatsapp.com. "WhatsApp" as well as related names, marks, emblems and images are registered trademarks of their respective owners.

License

This project is licensed under the MIT License - see the LICENSE.md file for details.

Star History

Star History Chart

chrishubert-whatsapp-api's People

Contributors

chrishubert avatar avoylenko avatar snyk-bot avatar ruanfernandes avatar autodepo avatar khsalem95 avatar mkhleel avatar dependabot[bot] avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.