Codementor Events

How I Created Whatsapp bot to talk with my friends?

Published Aug 09, 2019
How I Created Whatsapp bot to talk with my friends?

šŸ¤” Why?

The title seems kinda rude and lazy. Right? But if you think about the situation I am in then youā€™ll understand. Here in India itā€™s important to be socially active than being alive. If you donā€™t reply or send a few ā€œgood morningā€ messages in a few groups, People would think you are actually dead. and taunt you for being busy and not spending time with them.šŸ˜¤

Now, the thing with me and social media is, I want to use it on my time not when they send me a notification. So, there are situations Where I reply to a post after 4ā€“5 days and by that time my reply would not matter, as that moment would have been gone. Letā€™s consider about posting. For example birthdays anniversaries etcā€¦ But the thing is I donā€™t want to be that guy who replies after 4ā€“5 days. We all have 24 hours and I try my best to allocate it to all the things and priorities I have at my disposal. Iā€™d get disappointed if someone replies to me after a week so I donā€™t want to be that guy for them.
So, I have come up with my programming skills to solve/automate this scenario which will save my screen time.šŸ¤©

šŸ¤Ø How?

How did I got inspired?

I was looking to do an automation on the web and just like Googleā€™s top result, Selenium popped up in my mind but, as a JavaScript enthusiast, I choose JS as my ally. As an matter of fact, I found few modules in npm for Selenium but wasnā€™t really impressed by thatšŸ˜.
While searching for that I stumbled upon this video from google IO 2018 and then this one which got me thinking like

this

How I did it?

First, I learned about a few tricks from this post
then, I realized that relying on DOM is not a good ideašŸ¤Ø. What if classes or selectors I have used got updated in the pagešŸ¤”? So I decided not to use DOM. (But I ended up using it any way for other featurešŸ¤·ā€ā™‚ļø. Will write about it in another post. Stay Tunedā€¦ā€¦.šŸ˜Ž)

Just like a production issue solved before the deadlinešŸ˜, I found one repo which gives programmable access to the WhatsApp which works the same way as I want it.

Enough, Show me the code

Here are the overall steps and gist. I have added a link to the repo as well.

  1. First I created a puppeteer browser window and opened Whatsapp like this
    code screenshot

  2. Then, I created a json file to manage messages and itā€™s equivalent reply and also to add some configs.
    code screenshot

  3. Next, I added a function inside inject.js which would be called every time I get a new message

code screenshot

Final results

With the few garnishing with libraries like Ora, Cli-progress and qrcode-terminal on the top

Garnishing giphy meme

I got this

preview of wbot

Here is the full code

āœŒ Conclusion

This is what technology is all about. Identify the problem and fix the problem with the tools/tech. Isnā€™t it?
There are so many possibilities with the combination of the tools like Google Puppeteer and NodeJS. We just need to be self aware enough to look for solution to the problem we have in day to day life.

!! Reward me with your comments belowšŸŽā€¦.. You are awesome !!

P.S: This is the first time I am sharing/writing over the internet. Feel free to point out mistakes so that I can improve that for my next post.

Originally posted on dev.to

Discover and read more posts from Arpit Vasani
get started
post comments1Reply
Arpit Vasani
2 years ago

I am getting notification about comments on this post but I am unable to see them here. If you have any questions feel free to reach out to me on twitter or telegram.

Thanks āœŒ