Skip to content

indoomni/strapi-plugin-whatsapp-web

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

🚀 Getting started with Strapi

Wrapper for pedroslopez's whatsapp-web.js library to be used with Strapi apps.

Installation

Add the library to your Strapi project. Learn more


yarn add @indoomni/strapi-plugin-whatsapp-web
yarn install
yarn build


Configuration

Add the following configuration attributes to your server.js.


# config/server.js or config/env/**/server.js
# -------------------------------------------

module.exports = ({ env }) => ({
  host: env('HOST'),
  port: env.int('PORT'),
  app: {
    env: env('ENV'),
    name: env('APP_NAME'),
    keys: env.array('APP_KEYS'),
  },
  // ...
  'whatsapp-web': {
    enabled: true,
    config: {
      clientId: `${env('APP_NAME')}_${env('ENV')}_wa`,
      handler: 'whatsapp-handler.js',
      test: {
        msisdn: '+628999175163',
        message: 'Hello world!',
      },
    },
  },
  // ...
});

Notice config sub-attribute in the the 'whatsapp-web' attribute. Don't forget to use the single-quotation marks.

Now, notice the configFile attribute. You can add your own handler in the handler attribute (we use "src" as the base directory). If you supply a test attribute, the library will try to send a message to the said phone number after the client gets authenticated by WhatsApp and becomes ready.
In the handler script, you can hook event functions to provide your own processing. If in the hook functions you return false, the event won't get propagated to the default code.


# src/whatsapp-handler.js
# -------------------------------------------

module.exports = {
  prepare: async () => {
    console.log('Cutting carrots and chopping onions..');
    return true;
  },

  // Uncomment if you want to consume the 'qr' event.
  // Return true if you want the 'qr' event propagate to the default code.
  // onQr: async qr => {
  //   return true;
  // },

  // Uncomment if you want to consume the 'authenticated' event.
  // Return true if you want the 'authenticated' event propagate to the default code.
  // onAuthenticated: async session => {
  //   return true;
  // },

  // Uncomment if you want to consume the 'ready' event.
  // Return true if you want the 'ready' event propagate to the default code.
  // onReady: async () => {
  //   return true;
  // },

  // Uncomment if you want to consume the 'message' event.
  // Return true if you want the 'message' event propagate to the default code.
  // onMessage: async message => {
  //   strapi.log.info(
  //     `I am sample handler file ${__filename}, edit me..`,
  //   );
  //   strapi.log.info(
  //     `Received message: ${strapi.inspect(message)}`,
  //   );

  //   return false;
  // },
};


How to send messages

Anywhere in your code, write as in the following snippet. Refer to the client controller inside the library, and call send function. Supply a client's MSISDN, message, and media if necessary (optional).


# src/**/any.js
# ------------------------------

// ...
try {
  await strapi
    .plugin('whatsapp-web')
    .controller('client')
    .send(msisdn, message);
} catch (err) {
  strapi.log.debug('📺: ', err);
}
// ...


📚 Learn more



Feel free to check out my GitHub repository. Your feedback and contributions are welcome!

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published