Breakbot is a software that serves as gateway between several communication protocols.
It was started as a way to scratch one of the author's own itch, i.e. to break free from the walled garden that WhatsApp is, and to be able to use a proper computer with a proper screen and a proper keyboard (I hate long chats in tiny screens).
It currently supports:
- WhatsApp group chats <-> IRC rooms gatewaying.
- WhatsApp phone numbers <-> IRC nick conversion.
- WhastApp image and video attachments.
- Private messaging
Things it does not currently support:
- DCC send, topic changes, etc.
- Other protocols such as XMPP or ICQ.
Contact info is at the bottom of this document.
Breakbot is in early stages, lacks documentation everywhere, needs refactoring, may set fire to your computer, take your jobs... the usual drill. Just don't blame me for any problem it causes.
You'll need a WhatsApp account (phone number + password) that Breakbot will use.
Note that WhatsApp does not allow simultaneous connections, so you may want to get a secondary phone number for your Breakbot (e.g.: buy a second SIM card, or get a free number at fonyou, etc). Otherwise the bot would log you out of your phone's WhatsApp client.
You can register a WhatsApp account for your number without an actual physical phone, by following step #4 in the list below.
Note: all phone numbers must be specified as international number
without 00
or +
. E.g: Spanish number 600600600
would become 34600600600
Steps:
- Clone the Breakbot repo.
- Get the dependencies installed by running
./get_libs.sh
. - Add your bots to whatever WhatsApp group chats you want to bridge.
- [optional] Register the phone number against WhatsApp account using the last two options of
python Yowsup/yowsup-cli -h
. - Initial setup: open
config.json
, go toconfig
section, and customize all the fields.
wa_password
is the base64-encoded password as returned by the--exists
option of yowsup-cliwa_phone
is the phone number used by the bot to connect to WhatsApp. SeeRequisites
above.irc_*
parameters are what you expect.bot_owner_nick
is the IRC nick of the bot owner (needed for private messaging).
- Run
python bot.py
so that it connects to WhatsApp
- Watch the screen for strings matching
[email protected]
. Those are the WhastApp group chats. Write them down somewhere. - Control+C to stop Breakbot.
- Final setup: open
config.json
, go tocontacts
section, and:
- Add the desired WhatsApp group chats you wrote down to that list, together with the IRC rooms you want them bridged to.
- Add the phone numbers and what IRC nick they map to.
Just cross your fingers, run python bot.py
and wait for your bot to appear at the specified IRC channels (should take about 5-10 seconds with a proper connection).
Once connected, everything you say on IRC should appear on WhastApp and vice versa.
You can notify me about problems and feature requests at the issue tracker
Feel free to hack the code and send me GitHub pull requests, or traditional patches too; I'll be more than happy to merge them.
The author Bruno Gonzalez can be reached at [email protected] and /dev/null
for personal praise and insults, respectively.