whatsapp-api-client library for javascript
data:image/s3,"s3://crabby-images/fb06b/fb06b5bc40cee369b3a68c9d9c2c7ff5d183a272" alt="npm version"
This library helps you easily create a javascript application to connect the WhatsApp API using service basis-api.com. You need to get API_HOST
ID_INSTANCE
and API_TOKEN_INSTANCE
in the personal cabinet in order to use this library. It's free for developers.
API
The API corresponds with REST API from basis-api since the library wraps own methods as https calls to the service. Therefore using these docs is highly encouraged.
Installing
Library supports both browser environment without package managers and Node/Webpack apps with package manager that can handle require
or import
module expressions.
For webpack and npm based apps:
npm i @basisapi/whatsapp-api-client
For vanilla html-js website modify index.html:
<script src="https://unpkg.com/@basisapi/whatsapp-api-client/lib/whatsapp-api-client.min.js"></script>
Importing
There are several ways to import the library in a project
Using common javascript
const whatsAppClient = require("@basisapi/whatsapp-api-client");
Using ES6 javascript
import whatsAppClient from "@basisapi/whatsapp-api-client";
Using typescript
import * as whatsAppClient from "@basisapi/whatsapp-api-client";
Using browser javascript
<script src="https://unpkg.com/@basisapi/whatsapp-api-client/lib/whatsapp-api-client.min.js"></script>
Authentification
Sending WhatsApp message like any other call to the API requires account registered on basis-api.com and authentication completed on mobile WhatsApp app. To register account you have to proceed to the control panel. After registering you wll get own unique pair of ID_INSTANCE
and API_TOKEN_INSTANCE
keys.
WhatsApp mobile app authentication may be achived by using control panel. You need to scan QR-code generated within the control panel.
Examples
Please do not use 'phoneNumber' parameter when calling methods. It is deprecated. Examples below are based on 'chatId' paramemeter
Send WhatsApp message
Use common javascript
const whatsAppClient = require("@basisapi/whatsapp-api-client");
const restAPI = whatsAppClient.restAPI({
host: YOUR_API_HOST,
idInstance: "YOUR_ID_INSTANCE",
apiTokenInstance: "YOUR_API_TOKEN_INSTANCE",
});
restAPI.message.sendMessage("79999999999@c.us", null , "hello world").then((data) => {
console.log(data);
});
or use browser js script
<script src="https://unpkg.com/@basisapi/whatsapp-api-client/lib/whatsapp-api-client.min.js"></script>
<script>
const restAPI = whatsAppClient.restAPI({
host: YOUR_API_HOST,
idInstance: "YOUR_ID_INSTANCE",
apiTokenInstance: "YOUR_API_TOKEN_INSTANCE",
});
restAPI.message
.sendMessage("79999999999@c.us", null, "hello world")
.then((data) => {
console.log(data);
})
.catch((reason) => {
console.error(reason);
});
</script>
Or use ES6 syntax. For node js app, you propably have to add in package.json
property "type": "module"
. Notice that all examples below are ES6 based.
import whatsAppClient from "@basisapi/whatsapp-api-client";
(async () => {
const restAPI = whatsAppClient.restAPI({
host: "YOUR_API_HOST",
idInstance: "YOUR_ID_INSTANCE",
apiTokenInstance: "YOUR_API_TOKEN_INSTANCE",
});
const response = await restAPI.message.sendMessage(
"79999999999@c.us",
null,
"hello world"
);
})();
Using credentials file for ID_INSTANCE
and API_TOKEN_INSTANCE
keys (nodejs only!)
You might want to store yours credentials separatedly from code. The library allow you to create a text file with preferred name and location with the format:
API_TOKEN_INSTANCE = "MY_API_TOKEN_INSTANCE"
ID_INSTANCE = "MY_ID_INSTANCE"
And then pass this file as described below:
const restAPI = whatsAppClient.restAPI({
credentialsPath: "examples\\credentials",
});
Receive notifications using webhook service REST API
import whatsAppClient from "@basisapi/whatsapp-api-client";
(async () => {
let restAPI = whatsAppClient.restAPI({
host: "YOUR_API_HOST",
idInstance: "YOUR_ID_INSTANCE",
apiTokenInstance: "YOUR_API_TOKEN_INSTANCE",
});
try {
console.log("Waiting incoming notifications...");
await restAPI.webhookService.startReceivingNotifications();
restAPI.webhookService.onReceivingMessageText((body) => {
console.log(body);
restAPI.webhookService.stopReceivingNotifications();
});
restAPI.webhookService.onReceivingDeviceStatus((body) => {
console.log(body);
});
restAPI.webhookService.onReceivingAccountStatus((body) => {
console.log(body);
});
} catch (ex) {
console.error(ex.toString());
}
})();
Send WhatsApp file
import whatsAppClient from "@basisapi/whatsapp-api-client";
(async () => {
const restAPI = whatsAppClient.restAPI({
host: "YOUR_API_HOST",
idInstance: "YOUR_ID_INSTANCE",
apiTokenInstance: "YOUR_API_TOKEN_INSTANCE",
});
const response = await restAPI.file.sendFileByUrl(
"79999999999@c.us",
null,
"https://avatars.mds.yandex.net/get-pdb/477388/77f64197-87d2-42cf-9305-14f49c65f1da/s375",
"horse.png",
"horse"
);
})();
Send WhatsApp message and receive webhook
Webhooks are event-based callbacks invoked by basis-api server as responses to client API calls. Webhooks support node js and express based apps only.
import whatsAppClient from "@basisapi/whatsapp-api-client";
import express from "express";
import bodyParser from "body-parser";
(async () => {
try {
await restAPI.settings.setSettings({
webhookUrl: "MY_HTTP_SERVER:3000/webhooks",
});
const app = express();
app.use(bodyParser.json());
const webHookAPI = whatsAppClient.webhookAPI(app, "/webhooks");
webHookAPI.onIncomingMessageText(
(data, idInstance, idMessage, sender, typeMessage, textMessage) => {
console.log(`outgoingMessageStatus data ${data.toString()}`);
}
);
app.listen(3000, async () => {
console.log(`Started. App listening on port 3000!`);
const restAPI = whatsAppClient.restAPI({
host: YOUR_API_HOST,
idInstance: MY_ID_INSTANCE,
apiTokenInstance: MY_API_TOKEN_INSTANCE,
});
const response = await restAPI.message.sendMessage(
"79999999999@c.us",
null,
"hello world"
);
});
} catch (error) {
console.error(error);
process.exit(1);
}
})();
There's some cool examples too.
Deploying development environment
Any help with development and bug fixing is appreciated. In order to deploy test-ready environment please make the steps:
- Сlone repo with
git clone
- Install dependencies with
npm install
- Install globally libraries
rollup
for bundled builds. - Add webhooks as new dev express via npm
npm install express --save-dev
. Dont forget to delete it before making pull request - Create .env file in root folder and add environment variables using example file env.example
- Add
"type": "module"
to the package.json
Build
Compile browser and node|webpack versions with single command:
npm run build
Publish to npm if you have access
npm publish --access public
Third-party libraries
License
Licensed on MIT terms. For additional info have look at LICENSE