Whalesong is a python library to manage WebApps remotely. Currently WhatsappWeb is implemented
- Python 3.6+
- Geckodriver
- Firefox 50+
- node (only for development)
- npm (only for development)
- make (only for development)
$ pip install whalesong
- Non blocking driver. It can do more than one thing at same time.
- Monitor feature. Python code could react to Javascript event.
- Iterator feature. Large item list are passed to Python as async iterators.
- Persistent Firefox profile.
- Easy way to build new features.
- AmpersandJS/BackboneJS models and collection monitor.
- AmpersandJS/BackboneJS field monitor.
- Monitor localStorage.
- Take screenshots (page and css elements).
- Monitor connection state.
- Monitor QR changes.
- Monitor stream state.
- It's able to refresh QR.
- It's able to take over session.
- List chats.
- List contacts.
- List messages
- Monitor new messages.
- Monitor unread messages.
- Monitor message acks.
- Monitor new contacts.
- Monitor new chats.
- Send text messages.
- Reply messages.
- Send VCard messages.
- Send Media (image/video/pdf) messages.
- Send seen to chats.
- Removed send_vcard on chats. It is not possible now because WhatsappWeb changes.
- Added send_contact and send_contact_phone in order to send contacts using contact id or contact name and phone.
- Small changes and refactors.
- Reduce Firefox footprint.
- Message classes.
- Improved getMessages example. Now, it downloads media files.
- Package published at Pypi.
Warning
Command separator changed from . to |.
- Simplified code to manage models.
- Added remove_item_by_id, get_length, get_first and get_last methods to collection managers.
- Added load_earlier_messages and load_all_earlier_messages methods to chat manager.
- Tests, tests, tests.
- Documentation.
- More examples.
- Missing Whatsapp features.
- Implement scriptlet for other WebApp (maybe `Android Messages<https://messages.android.com/>`_).
- Drop Selenium and Geckodriver.
- Create/Use a small footprint headless browser with async interface (like marionette).
- Push results. Avoid continuous polling.
$ make requirements
You have to rebuild scriptlet after any change if you want to use in Python code.
$ make build-js
You must to beautify code before make a pull request. Ugly code will not be accepted.
$ make beautify
It monitors Stream state, Connection state and localStorage. It prints any change on them. It takes a page screenshot on each stream state change.
It tries to own WhatsappWeb session, it means that it will restore session if you open a new session in other browser.
On the other hand, if session is not started, it will renew QR automatically when it expires. It will save QR image each time it changes.
$ PYTHONPATH=.:$PYTHONPATH python3 examples/driver/statemonitor.py
It prints contact list.
$ PYTHONPATH=.:$PYTHONPATH python3 examples/driver/getcontacts.py
It prints chat list.
$ PYTHONPATH=.:$PYTHONPATH python3 examples/driver/getchats.py
It prints message list and monitors it. So, if new messages are received it will print them. It monitors message acknowledgments and prints them, as well.
$ PYTHONPATH=.:$PYTHONPATH python3 examples/driver/getmessages.py
It monitors Stream state, Connection state and localStorage. It prints any change on them. It takes a page screenshot on each stream state change.
It tries to own WhatsappWeb session, it means that it will restore session if you open a new session in other browser.
On the other hand, if session is not started, it will renew QR automatically when it expires. It will save QR image each time it changes.
$ PYTHONPATH=.:$PYTHONPATH python3 examples/statemonitor.py
It prints contact list.
$ PYTHONPATH=.:$PYTHONPATH python3 examples/getcontacts.py
It prints chat list.
$ PYTHONPATH=.:$PYTHONPATH python3 examples/getchats.py
It prints message list and monitors it. So, if new messages are received it will print them. It monitors message acknowledgments and prints them, as well.
It stores files and thumbnails from media messages.
$ PYTHONPATH=.:$PYTHONPATH python3 examples/getmessages.py
Minibot implements 3 features:
When a contact sends /echo [text] it replies with [text].
When a contact sends /contact [contactID] it replies with the contact in VCard format.
When a contact sends /download [url] it replies with content pointed by URL (image, pdf, video).
$ PYTHONPATH=.:$PYTHONPATH python3 examples/minibot.py
This code is in no way affiliated with, authorized, maintained, sponsored or endorsed by WhatsApp or any of its affiliates or subsidiaries. This is an independent and unofficial software. Use at your own risk.