Skip to content

yoelpc4/whatsapp-service

Repository files navigation

Whatsapp Service

Whatsapp service to send message via API

Installation

  • Install project dependencies
yarn
  • Adjust env variables as needed

Serve

  • Serve for development
yarn dev
  • Build for production
yarn build

Features

Features are secured with basic auth, we need to pass header Authorization: Basic <credentials> on every request. Where credentials made of base64 encode username:password. The username and password are customizable via env variables.

In order to send a message, we need to create session from phone number in advance to initialize the whatsapp socket. Several endpoints required session to act as a sender, we need to attach the session to the request header for instance: session: +621234567890.

Public endpoints:

  • All endpoints on sessions module.

Protected endpoints:

  • All endpoints on persons module.
  • All endpoints on groups module.

Sessions Module

  • Create Session

Create sender session, returns QR code data URL. Replace the id with actual sender's phone number according to the whatsapp phone number format.

[POST] /sessions

Request body

{
  "id": "+621234567890"
}

Response body

{
  "data": {
    "qrCodeDataUrl": ""
  },
  "message": "Please scan the given QR code to continue!"
}
  • Find Session

Find existing sender session, returns message when exists.

[GET] /sessions/+621234567890

Response body

{
  "message": "Session +621234567890 is found"
}
  • Delete Session

Delete existing sender session, returns empty.

[DELETE] /sessions/+621234567890

Persons Module

  • Get Persons

Get persons in sender whatsapp contact, returns persons data.

[GET] /persons

Response body

[
  {
    "id": "+622345678901@whatsapp.net",
    "conversationTimestamp": 1668715224,
    "unreadCount": 1
  },
  {
    "id": "+623456789012@whatsapp.net",
    "conversationTimestamp": 1668715224,
    "unreadCount": 1
  }
]
  • Send Message

Send a message from sender to person, returns message.

[POST] /persons/send-message

Request body

{
  "whatsappId": "+622345678901",
  "text": "Hello world"
}

Response body

{
  "message": "Successfully send message"
}
  • Send Messages

Send bulk messages from sender to persons, returns message.

[POST] /persons/send-messages

Request body

{
  "messages": [
    {
      "whatsappId": "+622345678901",
      "text": "Hello world"
    },
    {
      "whatsappId": "+623456789012",
      "text": "Lorem ipsum dolor sit amet"
    }
  ]
}

Response body

{
  "message": "Successfully send messages"
}

Groups Module

  • Get Groups

Get groups in sender whatsapp contact, returns groups data.

[GET] /groups

Response body

[
  {
    "id": "123456789012345678@g.us",
    "conversationTimestamp": 1668715224,
    "name": "Example Group 1",
    "unreadCount": 1
  },
  {
    "id": "234567890123456789@g.us",
    "conversationTimestamp": 1668715224,
    "name": "Example Group 2",
    "unreadCount": 1
  }
]
  • Send Message

Send a message from sender to group, returns message.

[POST] /groups/send-message

Request body

{
  "whatsappId": "123456789012345678@g.us",
  "text": "Hello world"
}

Response body

{
  "message": "Successfully send message"
}
  • Send Messages

Send bulk messages from sender to groups, returns message.

[POST] /groups/send-messages

Request body

{
  "messages": [
    {
      "whatsappId": "123456789012345678@g.us",
      "text": "Hello world"
    },
    {
      "whatsappId": "234567890123456789@g.us",
      "text": "Lorem ipsum dolor sit amet"
    }
  ]
}

Response body

{
  "message": "Successfully send messages"
}

About

Whatsapp service to send message via API

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published