An extensible Framework for WhatsApp!
- Create a new folder and start the project with
npm init
- Install WhatFramework:
npm install --save @kamuridesu/whatframework
WhatFramework needs modules to work. A module is made of a file called entrypoint.js file, which has a class Entrypoint
that has some properties and methods used by the Framework to define how the bot will handle commands and messages.
The following parameters are needed to start the framework:
prefix
: the commands prefix for your bot;name
: the name of the bot;botNumber
: the number of the bot;ownerNumber
: Number of the bot owner;
Optional parameters:
language
: Language of the bot. Defaults to en-us;commandsFilename
: Name of the commands file. The reason for this will be explained later.
We need to define at least the two following methods in our Entrypoin class:
chatHandlers
: Handles any message received by the bot, except those who start with theprefix
property.commandHandlers
: Handles any message that starts with theprefix
property.
Each method will have a different signature:
chatHandlers
must have the following parameters:
bot
: a bot instance;message
: a string with the message;context
: a MessageData instance containing all the data for that message;group
: a GroupData instance holding all the data for a group. If the chat is not a group, the value isundefined
;metadata
: a ChatMetadata instance containing some meta info for the chat.
commandHandlers
must have the following parameters:
bot
: a bot instance;command
: a string with the command;args
: command arguments, if any;context
: a MessageData instance containing all the data for that message;group
: a GroupData instance holding all the data for a group. If the chat is not a group, the value isundefined
;metadata
: a ChatMetadata instance containing some meta info for the chat.
You can see an example in examples.
The framework have some libs to help the developer to build their bots.
Helper libs will be available in whatframework/libs/
.
After installing WhatFramework and creating your module with the entrypoint, just run the following command:
npx whatframework
You'll be prompted to scan a QR code to login with a phone number. Scan the code and the bot will start.